*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,sans-serif;background:#0f172a;color:#e2e8f0}.login-overlay{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#312e81)}.login-card{background:#1e293be6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(99,102,241,.3);border-radius:20px;padding:48px 40px;text-align:center;width:380px;max-width:90vw}.login-icon{font-size:56px;margin-bottom:12px}.login-card h1{font-size:24px;color:#f1f5f9;margin-bottom:4px}.login-subtitle{color:#94a3b8;font-size:14px;margin-bottom:28px}.login-card input{width:100%;padding:14px 18px;border-radius:12px;border:1px solid #334155;background:#1e293b;color:#f1f5f9;font-size:16px;outline:none;transition:border-color .2s}.login-card input:focus{border-color:#6366f1}.login-error{color:#f87171;font-size:13px;margin-top:8px}.login-card button{width:100%;margin-top:18px;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s}.login-card button:hover{opacity:.9}.login-card button:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:20px;color:#475569;font-size:12px}.info-content{background:#0f172a;border:1px solid #334155;border-radius:12px;padding:16px;color:#e2e8f0;line-height:1.6;min-height:160px}.info-content p{margin-bottom:8px}.info-content a{color:#93c5fd;text-decoration:underline}.info-content ul,.info-content ol{margin-left:18px;margin-bottom:8px}.info-content li{margin-bottom:4px}.info-content p:last-child{margin-bottom:0}.info-empty{color:#64748b}.info-textarea{width:100%;min-height:180px;border-radius:12px;border:1px solid #334155;background:#0f172a;color:#e2e8f0;padding:12px 14px;resize:vertical;outline:none}.info-textarea:focus{border-color:#6366f1}.app-container{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;gap:12px;padding:14px 24px;background:#1e293b;border-bottom:1px solid #334155;flex-shrink:0}.app-header h1{font-size:20px;color:#f1f5f9}.header-subtitle{color:#64748b;font-size:13px}.logout-btn{margin-left:auto;padding:8px 18px;border-radius:8px;border:1px solid #475569;background:transparent;color:#94a3b8;cursor:pointer;font-size:13px;transition:all .2s}.logout-btn:hover{background:#334155;color:#f1f5f9}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:380px;min-width:320px;background:#1e293b;display:flex;flex-direction:column;overflow:hidden}.filter-bar{display:flex;gap:6px;padding:14px 16px;background:#0f172a;border-bottom:1px solid #334155;flex-wrap:wrap}.filter-btn{padding:6px 14px;border-radius:20px;border:1px solid #334155;background:transparent;color:#94a3b8;font-size:12px;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:#6366f1;color:#c7d2fe}.filter-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.filter-toggle{border-color:#475569;color:#cbd5f5}.filter-select{padding:6px 12px;border-radius:20px;border:1px solid #334155;background:#0f172a;color:#94a3b8;font-size:12px;cursor:pointer}.filter-select:focus{outline:none;border-color:#6366f1;color:#c7d2fe}.tag-color-picker{width:20px;height:20px;border-radius:6px;border:1px solid #334155;background:#0f172a;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}.tag-color-picker input{width:28px;height:28px;padding:0;border:none;background:transparent;cursor:pointer}.activity-list{flex:1;overflow-y:auto;padding:12px}.activity-list::-webkit-scrollbar{width:6px}.activity-list::-webkit-scrollbar-thumb{background:#475569;border-radius:3px}.no-results{text-align:center;color:#64748b;padding:40px 0;font-size:14px}.activity-card{background:#0f172a;border:1px solid #1e293b;border-radius:12px;padding:16px;margin-bottom:10px;cursor:pointer;transition:all .2s}.activity-card:hover{border-color:#475569;transform:translate(4px)}.activity-card.selected{border-color:#6366f1;background:#1e1b4b;box-shadow:0 0 20px #6366f126}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.category-badge{font-size:11px;padding:3px 10px;border-radius:10px;color:#fff;font-weight:600}.card-date{font-size:12px;color:#64748b}.card-title{font-size:15px;color:#e2e8f0;margin-bottom:4px}.card-address{font-size:12px;color:#94a3b8}.card-details{margin-top:10px;padding-top:10px;border-top:1px solid #1e293b;font-size:13px;color:#cbd5e1;line-height:1.6}.map-area{flex:1;position:relative}.map-area .leaflet-container{width:100%;height:100%}.leaflet-popup-content-wrapper{border-radius:12px!important;background:#1e293b!important;color:#e2e8f0!important}.leaflet-popup-tip{background:#1e293b!important}.leaflet-popup-content{font-size:14px}@media (max-width: 768px){.main-content{flex-direction:column}.sidebar{width:100%;min-width:unset;max-height:40vh}.map-area{flex:1;min-height:50vh}.modal-card{width:95vw!important;max-height:85vh}}.header-btn{padding:8px 16px;border-radius:8px;border:1px solid #475569;background:transparent;color:#94a3b8;cursor:pointer;font-size:13px;transition:all .2s}.header-btn:hover{background:#334155;color:#f1f5f9;border-color:#6366f1}.activity-card{position:relative}.card-actions{position:absolute;bottom:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .2s}.activity-card:hover .card-actions{opacity:1}.card-action-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.card-edit-btn:hover{background:#6366f140}.card-delete-btn{position:static}.card-delete-btn:hover{background:#ef444440}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999}.modal-card{background:#1e293b;border:1px solid #334155;border-radius:16px;padding:0;width:500px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:0 25px 60px #00000080}.modal-sm{width:400px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #334155}.modal-header h2{font-size:18px;color:#f1f5f9}.modal-close-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:#94a3b8;font-size:16px;cursor:pointer;transition:all .2s}.modal-close-btn:hover{background:#334155;color:#f1f5f9}.modal-form{padding:24px;display:flex;flex-direction:column;gap:4px}.modal-form label{font-size:13px;color:#94a3b8;margin-top:12px;margin-bottom:4px}.modal-form label:first-child{margin-top:0}.modal-form input,.modal-form textarea,.modal-form select{padding:10px 14px;border-radius:10px;border:1px solid #334155;background:#0f172a;color:#e2e8f0;font-size:14px;outline:none;transition:border-color .2s;font-family:inherit}.modal-form input:focus,.modal-form textarea:focus{border-color:#6366f1}.modal-form textarea{resize:vertical}.form-row-2{display:flex;gap:12px}.form-row-2>div{flex:1}.form-error{color:#f87171;font-size:13px;margin-top:8px}.geo-status{font-size:12px;margin-top:6px;padding:4px 0}.geo-searching{color:#fbbf24}.geo-found{color:#34d399}.geo-not-found{color:#f87171}.tag-input-row{position:relative}.tag-dropdown{position:absolute;top:100%;left:0;right:0;background:#1e293b;border:1px solid #475569;border-radius:8px;max-height:160px;overflow-y:auto;z-index:100;margin-top:4px;box-shadow:0 8px 24px #00000080}.tag-dropdown-item{padding:10px 14px;cursor:pointer;font-size:14px;color:#e2e8f0;transition:background .15s}.tag-dropdown-item:hover{background:#334155}.tag-dropdown-item:first-child{border-radius:8px 8px 0 0}.tag-dropdown-item:last-child{border-radius:0 0 8px 8px}.modal-actions,.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-footer{padding:16px 24px;border-top:1px solid #334155;margin-top:0}.btn-cancel{padding:10px 20px;border-radius:10px;border:1px solid #475569;background:transparent;color:#94a3b8;font-size:14px;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#334155;color:#f1f5f9}.btn-submit{padding:10px 20px;border-radius:10px;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-submit:hover{opacity:.9}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:6px 12px;border-radius:6px;font-size:12px}.tag-list{padding:16px 24px;max-height:50vh;overflow-y:auto}.tag-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #1e293b}.tag-item:last-child{border-bottom:none}.tag-name{font-size:15px;color:#e2e8f0;font-weight:500}.tag-actions{display:flex;gap:4px}.btn-icon{width:32px;height:32px;border-radius:8px;border:none;background:transparent;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#334155}.btn-danger:hover{background:#ef444433}.tag-edit-row{display:flex;gap:6px;align-items:center;flex:1}.tag-edit-row input{flex:1;padding:8px 12px;border-radius:8px;border:1px solid #6366f1;background:#0f172a;color:#e2e8f0;font-size:14px;outline:none}@keyframes pinPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.7}to{transform:translate(-50%,-50%) scale(1.8);opacity:0}}
