.keeper-layout{min-height:100vh;background:#f8fafc;display:flex;flex-direction:column;max-width:480px;margin:0 auto;box-shadow:0 0 40px #0000001a}.keeper-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff}.header-title{font-size:18px;font-weight:700}.header-right{display:flex;align-items:center;gap:12px}.user-badge{display:flex;align-items:center;gap:6px;background:#fff3;padding:6px 12px;border-radius:20px;font-size:13px}.logout-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:#fff3;color:#fff;cursor:pointer;transition:background .2s ease}.logout-btn:hover{background:#ffffff4d}.keeper-main{flex:1;padding-bottom:80px;overflow-y:auto}.keeper-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -4px 20px #0000000d;z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:none;background:transparent;color:#94a3b8;font-size:11px;cursor:pointer;transition:all .2s ease}.nav-item.active{color:#0284c7}.nav-item:hover{color:#0ea5e9}.keeper-page{padding:20px}.page-title{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:20px}.page-subtitle{font-size:14px;color:#64748b;margin-top:-12px;margin-bottom:20px}.keeper-home{padding-bottom:100px}.today-summary{background:linear-gradient(135deg,#0ea5e9,#0284c7);border-radius:20px;padding:24px;color:#fff;margin-bottom:24px}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.summary-header h2{font-size:18px;font-weight:600}.summary-header .date{font-size:14px;opacity:.8}.summary-stats{display:flex;gap:12px}.stat-card{flex:1;display:flex;align-items:center;gap:12px;background:#fff3;border-radius:12px;padding:16px}.stat-card div{display:flex;flex-direction:column}.stat-value{font-size:24px;font-weight:700}.stat-label{font-size:12px;opacity:.8}.search-box{display:flex;align-items:center;gap:12px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:12px 16px;margin-bottom:24px;transition:border-color .2s ease}.search-box:focus-within{border-color:#0ea5e9}.search-box svg{color:#94a3b8}.search-box input{flex:1;border:none;outline:none;font-size:15px;color:#1e293b}.search-box input::placeholder{color:#94a3b8}.section-group{margin-bottom:24px}.section-group h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#1e293b;margin-bottom:12px}.section-group h3 svg{color:#0284c7}.section-list{display:flex;flex-direction:column;gap:8px}.section-item{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.section-item:hover{border-color:#0ea5e9;transform:translate(4px)}.section-item.recorded{background:#f0fdf4;border-color:#86efac}.section-left{display:flex;align-items:center;gap:12px}.risk-indicator{width:12px;height:12px;border-radius:50%}.risk-indicator.high{background:#ef4444;box-shadow:0 0 8px #ef444480}.risk-indicator.medium{background:#f59e0b}.risk-indicator.low{background:#10b981}.section-info{display:flex;flex-direction:column}.section-name{font-size:15px;font-weight:600;color:#1e293b}.section-city{font-size:12px;color:#64748b;margin-top:2px}.section-right{display:flex;align-items:center;gap:8px}.recorded-badge{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#10b981;color:#fff;font-size:12px;font-weight:600;border-radius:20px}.risk-badge{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#fee2e2;color:#dc2626;font-size:11px;font-weight:600;border-radius:6px}.favorite-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:transparent;cursor:pointer;transition:all .2s ease}.favorite-btn:hover{background:#fef3c7}.section-item svg{color:#94a3b8}.keeper-record{padding-bottom:120px}.record-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.record-header .back-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:12px;background:#fff;cursor:pointer;color:#64748b;transition:all .2s ease}.record-header .back-btn:hover{background:#f1f5f9;color:#1e293b}.record-header h1{flex:1;font-size:20px;font-weight:700;color:#1e293b}.today-date{font-size:14px;color:#64748b;background:#f1f5f9;padding:6px 12px;border-radius:8px}.form-section{margin-bottom:24px}.form-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#1e293b;margin-bottom:10px}.form-label svg{color:#0284c7}.form-label.required:after{content:"*";color:#ef4444;margin-left:2px}.form-label .hint{font-size:12px;font-weight:400;color:#64748b}.form-label .optional{font-size:12px;font-weight:400;color:#94a3b8}.section-selector{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left}.section-selector:hover{border-color:#0ea5e9}.section-selector .selected-section{display:flex;flex-direction:column;gap:4px}.section-selector .selected-section strong{font-size:16px;color:#1e293b}.section-selector .selected-section span{font-size:12px;color:#64748b}.section-selector .placeholder{color:#94a3b8}.section-selector svg{color:#94a3b8}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:200}.section-picker{width:100%;max-width:480px;max-height:70vh;background:#fff;border-radius:24px 24px 0 0;overflow:hidden;animation:slideUp .3s ease}.picker-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e2e8f0}.picker-header h3{font-size:18px;font-weight:600}.picker-header button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:#f1f5f9;cursor:pointer;color:#64748b}.picker-list{max-height:50vh;overflow-y:auto;padding:12px}.picker-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px;border:none;border-radius:12px;background:transparent;cursor:pointer;transition:all .2s ease;text-align:left}.picker-item:hover{background:#f1f5f9}.picker-item.selected{background:#e0f2fe}.picker-name{font-size:15px;font-weight:500;color:#1e293b}.picker-city{font-size:12px;color:#64748b}.status-options{display:flex;gap:12px}.status-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;font-size:16px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s ease}.status-btn:hover{border-color:var(--status-color)}.status-btn.selected{border-color:var(--status-color);background:var(--status-bg);color:var(--status-color)}.status-dot{width:12px;height:12px;border-radius:50%;background:currentColor}.condition-options{display:flex;flex-wrap:wrap;gap:8px}.condition-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:2px solid #e2e8f0;border-radius:25px;background:#fff;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.condition-btn:hover{border-color:#0ea5e9}.condition-btn.selected{border-color:#0284c7;background:#e0f2fe;color:#0284c7}.tag-options{display:flex;flex-wrap:wrap;gap:8px}.tag-btn{padding:8px 14px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.tag-btn:hover{border-color:var(--tag-color)}.tag-btn.selected{border-color:var(--tag-color);background:var(--tag-color);color:#fff}.memo-input{width:100%;padding:16px;border:2px solid #e2e8f0;border-radius:12px;font-size:14px;resize:none;transition:border-color .2s ease;outline:none;font-family:inherit}.memo-input:focus{border-color:#0ea5e9}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.photo-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden}.photo-item img{width:100%;height:100%;object-fit:cover}.photo-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border:none;border-radius:50%;background:#0009;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;aspect-ratio:1;border:2px dashed #cbd5e1;border-radius:12px;background:#f8fafc;color:#94a3b8;font-size:12px;cursor:pointer;transition:all .2s ease}.photo-add:hover{border-color:#0ea5e9;color:#0284c7;background:#f0f9ff}.submit-btn{position:fixed;bottom:90px;left:50%;transform:translate(-50%);width:calc(100% - 40px);max-width:440px;display:flex;align-items:center;justify-content:center;gap:10px;padding:18px;border:none;border-radius:14px;background:#e2e8f0;color:#94a3b8;font-size:16px;font-weight:600;cursor:not-allowed;transition:all .3s ease;z-index:50}.submit-btn.valid{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;cursor:pointer}.submit-btn.valid:hover{transform:translate(-50%) translateY(-2px);box-shadow:0 8px 25px #0ea5e966}.submit-btn:disabled{opacity:.7}.record-success{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 200px)}.success-content{text-align:center;animation:fadeIn .5s ease}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#fff;animation:scaleIn .5s ease}@keyframes scaleIn{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.success-content h2{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:8px}.success-content p{font-size:14px;color:#64748b}.keeper-history{padding-bottom:100px}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.history-header h1{font-size:24px;font-weight:700;color:#1e293b}.filter-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:#0ea5e9;color:#0284c7}.filter-dropdown{display:flex;gap:8px;margin-bottom:20px;padding:12px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a}.filter-dropdown button{flex:1;padding:10px;border:none;border-radius:8px;background:#f1f5f9;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.filter-dropdown button.active,.filter-dropdown button:hover{background:#0284c7;color:#fff}.history-stats{display:flex;gap:12px;margin-bottom:24px}.history-stats .stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:16px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d}.history-stats .stat-value{font-size:24px;font-weight:700;color:#0284c7}.history-stats .stat-label{font-size:12px;color:#64748b;margin-top:4px}.history-list{display:flex;flex-direction:column;gap:24px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#94a3b8}.date-group{animation:fadeIn .3s ease}.date-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#64748b;margin-bottom:12px}.date-header svg{color:#0284c7}.records{display:flex;flex-direction:column;gap:12px}.record-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000000d}.record-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.record-section{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#1e293b}.record-section svg{color:#0284c7}.record-status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.record-conditions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.condition-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#f1f5f9;border-radius:6px;font-size:12px;color:#475569}.record-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.tag-chip{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500;color:#fff}.record-memo{display:flex;gap:8px;padding:12px;background:#f8fafc;border-radius:8px;margin-bottom:10px}.record-memo svg{color:#94a3b8;flex-shrink:0;margin-top:2px}.record-memo p{font-size:13px;color:#475569;line-height:1.5}.record-photos{display:flex;align-items:center;gap:6px;font-size:12px;color:#0284c7;margin-bottom:10px}.record-time{font-size:11px;color:#94a3b8;text-align:right}.admin-layout{display:flex;min-height:100vh;background:#f1f5f9}.admin-sidebar{width:260px;background:linear-gradient(180deg,#1e293b,#0f172a);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{padding:24px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{display:flex;align-items:center;gap:12px;color:#fff}.sidebar-logo svg{color:#0ea5e9}.logo-title{display:block;font-size:16px;font-weight:700}.logo-subtitle{display:block;font-size:12px;color:#94a3b8}.sidebar-nav{flex:1;padding:16px 12px}.sidebar-nav .nav-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:none;border-radius:10px;background:transparent;color:#94a3b8;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:4px;text-align:left}.sidebar-nav .nav-item:hover{background:#ffffff0d;color:#fff}.sidebar-nav .nav-item.active{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:10px;flex:1}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.user-details{display:flex;flex-direction:column}.user-name{font-size:14px;font-weight:600;color:#fff}.user-role{font-size:11px;color:#64748b}.sidebar-footer .logout-btn{width:36px;height:36px;border:none;border-radius:8px;background:#ffffff1a;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-footer .logout-btn:hover{background:#ef444433;color:#ef4444}.admin-main{flex:1;margin-left:260px;display:flex;flex-direction:column}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:50}.header-left h1{font-size:24px;font-weight:700;color:#1e293b}.header-right{display:flex;align-items:center;gap:8px}.header-btn{position:relative;width:42px;height:42px;border:none;border-radius:10px;background:#f1f5f9;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.header-btn:hover{background:#e2e8f0;color:#1e293b}.notification-badge{position:absolute;top:6px;right:6px;width:18px;height:18px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}.admin-content{flex:1;padding:24px 32px;overflow-y:auto;min-height:0;background:#f1f5f9}@media(max-width:1024px){.admin-sidebar{width:80px}.sidebar-logo div,.sidebar-nav .nav-item span,.user-details{display:none}.sidebar-nav .nav-item{justify-content:center;padding:14px}.user-info{justify-content:center}.admin-main{margin-left:80px}}.jeju-map-container{position:relative;width:100%;background:linear-gradient(135deg,#e0f2fe,#bae6fd);border-radius:16px;overflow:hidden}.jeju-map{width:100%;height:auto;display:block}.map-tooltip{position:fixed;z-index:1000;background:#fff;border-radius:12px;padding:16px;box-shadow:0 10px 40px #00000026;min-width:180px;pointer-events:none;animation:tooltipFadeIn .15s ease}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tooltip-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #e2e8f0}.tooltip-name{font-size:16px;font-weight:700;color:#1e293b}.tooltip-city{font-size:12px;color:#64748b;background:#f1f5f9;padding:4px 8px;border-radius:4px}.tooltip-stats{display:flex;flex-direction:column;gap:8px}.tooltip-stat{display:flex;justify-content:space-between;align-items:center}.tooltip-stat .stat-label{font-size:12px;color:#64748b}.tooltip-stat .stat-value{font-size:13px;font-weight:600;color:#1e293b}.tooltip-stat .stat-value.risk-high{color:#ef4444}.tooltip-stat .stat-value.risk-medium{color:#f59e0b}.tooltip-stat .stat-value.risk-low{color:#22c55e}.tooltip-hint{margin-top:12px;padding-top:10px;border-top:1px solid #e2e8f0;font-size:11px;color:#94a3b8;text-align:center}.admin-dashboard{max-width:1400px;margin:0 auto}.date-range-bar{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:16px 20px;border-radius:12px;margin-bottom:16px;box-shadow:0 1px 3px #0000000d}.date-range-selector{display:flex;align-items:center;gap:16px}.date-icon{color:#0ea5e9}.date-inputs{display:flex;align-items:center;gap:10px}.date-input{padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:500;color:#1e293b;background:#f8fafc;cursor:pointer;transition:all .2s ease}.date-input:hover{border-color:#cbd5e1}.date-input:focus{outline:none;border-color:#0ea5e9;background:#fff}.date-separator{color:#94a3b8;font-weight:500;font-size:16px}.date-range-info{background:#e0f2fe;color:#0369a1;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600}.date-presets{display:flex;gap:8px}.preset-btn{padding:8px 14px;background:#f1f5f9;border:none;border-radius:8px;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.preset-btn:hover{background:#e0f2fe;color:#0369a1}.filter-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.filter-left{display:flex;gap:12px;align-items:center}.current-period{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f1f5f9;border-radius:10px;font-size:14px;font-weight:500;color:#475569}.current-period svg{color:#64748b}.date-filter{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:2px solid #e2e8f0;border-radius:10px}.date-filter svg{color:#64748b}.date-filter select{border:none;background:transparent;font-size:14px;font-weight:500;color:#1e293b;cursor:pointer;outline:none}.filter-toggle{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.filter-toggle:hover,.filter-toggle.active{border-color:#0ea5e9;color:#0284c7}.filter-count{background:#0ea5e9;color:#fff;font-size:11px;padding:2px 8px;border-radius:10px}.refresh-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f1f5f9;border:none;border-radius:10px;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.refresh-btn:hover{background:#e2e8f0;color:#1e293b}.filter-panel{background:#fff;border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 1px 3px #0000000d;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-section{margin-bottom:16px}.filter-section:last-child{margin-bottom:0}.filter-section h4{font-size:13px;font-weight:600;color:#64748b;margin-bottom:10px}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{padding:8px 14px;border:2px solid #e2e8f0;border-radius:20px;background:#fff;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.filter-chip:hover{border-color:#0ea5e9;color:#0284c7}.filter-chip.selected{border-color:#0284c7;background:#e0f2fe;color:#0284c7}.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.summary-card{display:flex;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000000d;position:relative}.card-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.card-icon.blue{background:linear-gradient(135deg,#0ea5e9,#0284c7)}.card-icon.red{background:linear-gradient(135deg,#ef4444,#dc2626)}.card-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.card-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.card-content{display:flex;flex-direction:column}.card-value{font-size:28px;font-weight:700;color:#1e293b}.card-label{font-size:13px;color:#64748b}.card-badge{position:absolute;top:16px;right:16px;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600}.card-badge.red{background:#fee2e2;color:#dc2626}.card-badge.warning{background:#fef3c7;color:#d97706}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:24px}.dashboard-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 3px #0000000d}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-header h3{font-size:16px;font-weight:600;color:#1e293b}.card-subtitle{font-size:12px;color:#94a3b8}.map-card{min-height:450px}.risky-sections-card{max-height:500px;display:flex;flex-direction:column}.risky-sections-list{flex:1;overflow-y:auto}.risky-section-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px;border:none;background:#f8fafc;border-radius:10px;margin-bottom:8px;cursor:pointer;transition:all .2s ease;text-align:left}.risky-section-item:hover{background:#f1f5f9;transform:translate(4px)}.section-info{display:flex;align-items:center;gap:12px}.risk-dot{width:12px;height:12px;border-radius:50%}.risk-dot.high{background:#ef4444;box-shadow:0 0 8px #ef444480}.risk-dot.medium{background:#f59e0b}.section-info>div{display:flex;flex-direction:column}.section-name{font-size:14px;font-weight:600;color:#1e293b}.section-city{font-size:11px;color:#64748b}.section-stats{display:flex;align-items:center;gap:8px}.high-ratio{font-size:14px;font-weight:700;color:#ef4444}.section-stats svg{color:#94a3b8}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#94a3b8;text-align:center}.empty-state svg{margin-bottom:12px;opacity:.5}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.chart-card{min-height:350px}.chart-card.wide{grid-column:span 2}.chart-container{margin-top:16px}.pie-container{display:flex;align-items:center;gap:20px}.pie-legend{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:8px}.legend-color{width:12px;height:12px;border-radius:3px}.legend-label{font-size:13px;color:#64748b;flex:1}.legend-value{font-size:13px;font-weight:600;color:#1e293b}@media(max-width:1200px){.summary-cards{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.charts-grid{grid-template-columns:1fr}.chart-card.wide{grid-column:span 1}}@media(max-width:768px){.date-range-bar{flex-direction:column;gap:16px;align-items:stretch}.date-range-selector,.date-presets{flex-wrap:wrap;justify-content:center}.filter-bar{flex-direction:column;gap:12px;align-items:stretch}.filter-left{justify-content:center;flex-wrap:wrap}.summary-cards{grid-template-columns:1fr}}.section-detail-page{max-width:1200px;margin:0 auto}.detail-header{display:flex;align-items:center;gap:20px;margin-bottom:24px}.detail-header .back-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:10px;background:#fff;color:#64748b;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.detail-header .back-btn:hover{background:#f1f5f9;color:#1e293b}.header-title{flex:1;display:flex;align-items:center;gap:12px}.header-title h1{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:700;color:#1e293b}.header-title h1 svg{color:#0ea5e9}.city-badge{padding:6px 12px;background:#e0f2fe;color:#0284c7;font-size:12px;font-weight:600;border-radius:6px}.detail-header .export-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:10px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.detail-header .export-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0ea5e966}.summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.summary-item{display:flex;align-items:center;gap:14px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d}.summary-item svg{color:#64748b}.summary-item.risk-high svg{color:#ef4444}.summary-item.risk-medium svg{color:#f59e0b}.summary-item.risk-low svg{color:#10b981}.summary-item>div{display:flex;flex-direction:column}.summary-label{font-size:12px;color:#64748b}.summary-value{font-size:20px;font-weight:700;color:#1e293b}.summary-item.risk-high .summary-value{color:#ef4444}.summary-item.risk-medium .summary-value{color:#f59e0b}.summary-item.risk-low .summary-value{color:#10b981}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}.detail-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 3px #0000000d}.detail-card h3{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#1e293b;margin-bottom:20px}.detail-card h3 svg{color:#0284c7}.no-data{color:#94a3b8;font-size:14px;text-align:center;padding:20px}.timeline-card{grid-column:span 2}.timeline-legend{display:flex;justify-content:center;gap:24px;margin-top:16px}.timeline-legend span{display:flex;align-items:center;gap:6px;font-size:12px;color:#64748b}.timeline-legend .dot{width:10px;height:10px;border-radius:50%}.timeline-legend .dot.high{background:#ef4444}.timeline-legend .dot.low{background:#10b981}.timeline-legend .dot.none{background:#e2e8f0}.condition-list{display:flex;flex-direction:column;gap:14px}.condition-item{display:flex;flex-direction:column;gap:8px}.condition-info{display:flex;align-items:center;gap:8px}.condition-icon{font-size:16px}.condition-name{flex:1;font-size:14px;font-weight:500;color:#1e293b}.condition-count{font-size:12px;color:#94a3b8}.condition-bar-container{display:flex;align-items:center;gap:10px;height:8px;background:#f1f5f9;border-radius:4px;overflow:visible}.condition-bar{height:100%;background:linear-gradient(90deg,#f59e0b,#ef4444);border-radius:4px;min-width:4px}.condition-ratio{font-size:12px;font-weight:600;color:#ef4444;min-width:40px}.tags-list{display:flex;flex-wrap:wrap;gap:10px}.tag-item{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f8fafc;border-radius:8px;border-left:4px solid var(--tag-color)}.tag-label{font-size:13px;font-weight:500;color:#1e293b}.tag-count{font-size:12px;color:#64748b;background:#fff;padding:2px 8px;border-radius:10px}.photos-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.photo-item{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden}.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-item:hover img{transform:scale(1.05)}.photo-overlay{position:absolute;bottom:0;left:0;right:0;padding:8px;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:11px}.records-card{margin-top:4px}.records-list{display:flex;flex-direction:column;gap:8px}.record-item{display:flex;align-items:center;gap:16px;padding:14px 16px;background:#f8fafc;border-radius:10px;transition:background .2s ease}.record-item:hover{background:#f1f5f9}.record-date{display:flex;flex-direction:column;min-width:100px}.record-date .date{font-size:13px;font-weight:600;color:#1e293b}.record-date .time{font-size:11px;color:#94a3b8}.record-status{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600}.record-conditions{display:flex;gap:4px}.mini-chip{padding:4px 8px;background:#fff;border-radius:4px;font-size:12px}.record-tags{display:flex;gap:4px;flex:1}.mini-tag{padding:3px 8px;border-radius:4px;font-size:10px;font-weight:500;color:#fff}.record-indicators{display:flex;gap:8px}.indicator{display:flex;align-items:center;gap:4px;font-size:12px;color:#64748b}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.error-state button{padding:12px 24px;background:#0ea5e9;color:#fff;border:none;border-radius:8px;cursor:pointer}@media(max-width:1024px){.summary-row{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}.timeline-card{grid-column:span 1}}@media(max-width:768px){.detail-header{flex-wrap:wrap}.header-title{order:-1;width:100%;margin-bottom:12px}.summary-row{grid-template-columns:1fr}.record-item{flex-wrap:wrap}}.admin-export{max-width:1200px;margin:0 auto}.export-header{display:flex;align-items:flex-start;gap:20px;margin-bottom:32px}.export-header .back-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:10px;background:#fff;color:#64748b;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.export-header .back-btn:hover{background:#f1f5f9;color:#1e293b}.export-header h1{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px}.export-header p{font-size:14px;color:#64748b}.export-grid{display:grid;grid-template-columns:400px 1fr;gap:24px}.export-options{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 3px #0000000d;height:fit-content}.option-section{margin-bottom:24px}.option-section:last-of-type{margin-bottom:24px}.option-section h3{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#1e293b;margin-bottom:14px}.option-section h3 svg{color:#0284c7}.select-all{margin-left:auto;padding:4px 10px;border:1px solid #e2e8f0;border-radius:6px;background:transparent;font-size:11px;color:#64748b;cursor:pointer}.select-all:hover{background:#f1f5f9}.date-options{display:flex;gap:8px}.date-btn{flex:1;padding:12px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.date-btn:hover{border-color:#0ea5e9;color:#0284c7}.date-btn.selected{border-color:#0284c7;background:#e0f2fe;color:#0284c7}.section-list{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.section-checkbox{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .2s ease}.section-checkbox:hover{background:#f8fafc}.section-checkbox input{display:none}.section-checkbox .checkmark{width:20px;height:20px;border:2px solid #e2e8f0;border-radius:5px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:transparent}.section-checkbox input:checked+.checkmark{background:#0284c7;border-color:#0284c7;color:#fff}.section-checkbox .section-info{flex:1;display:flex;flex-direction:column}.section-checkbox .name{font-size:13px;font-weight:500;color:#1e293b}.section-checkbox .city{font-size:11px;color:#94a3b8}.risk-badge{padding:3px 8px;border-radius:4px;font-size:10px;font-weight:600}.risk-badge.high{background:#fee2e2;color:#dc2626}.risk-badge.medium{background:#fef3c7;color:#d97706}.risk-badge.low{background:#d1fae5;color:#059669}.format-options{display:flex;gap:8px}.format-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease}.format-btn:hover{border-color:#0ea5e9;color:#0284c7}.format-btn.selected{border-color:#0284c7;background:#e0f2fe;color:#0284c7}.include-options{display:flex;flex-direction:column;gap:10px}.include-checkbox{display:flex;align-items:center;gap:10px;font-size:14px;color:#475569;cursor:pointer}.include-checkbox input{display:none}.include-checkbox .checkmark{width:20px;height:20px;border:2px solid #e2e8f0;border-radius:5px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:transparent}.include-checkbox input:checked+.checkmark{background:#0284c7;border-color:#0284c7;color:#fff}.export-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;border:none;border-radius:12px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.export-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0ea5e966}.export-btn:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.export-btn.loading{background:#64748b}.export-btn.success{background:linear-gradient(135deg,#10b981,#059669)}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.export-preview{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;min-height:600px}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e2e8f0}.preview-header h3{font-size:15px;font-weight:600;color:#1e293b}.preview-format{padding:4px 10px;background:#f1f5f9;border-radius:6px;font-size:12px;font-weight:600;color:#64748b}.preview-content{flex:1;padding:24px;overflow-y:auto}.preview-content pre{font-family:inherit;font-size:13px;line-height:1.8;color:#475569;white-space:pre-wrap;word-wrap:break-word}.empty-preview{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;color:#94a3b8}.empty-preview svg{margin-bottom:16px;opacity:.5}.empty-preview p{font-size:14px}@media(max-width:1024px){.export-grid{grid-template-columns:1fr}.export-preview{min-height:400px}}.ai-report-container{padding:24px;max-width:1200px;margin:0 auto;min-height:100%;background:#f1f5f9}.ai-report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.header-title{display:flex;align-items:center;gap:12px}.header-title .sparkles-icon{width:40px;height:40px;padding:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;color:#fff}.header-title h2{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.header-title p{font-size:.875rem;color:#6b7280;margin:4px 0 0}.header-controls{display:flex;align-items:center;gap:12px}.month-selector{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f3f4f6;border-radius:8px;color:#374151}.month-selector input{border:none;background:transparent;font-size:.875rem;color:#374151;cursor:pointer}.generate-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #6366f14d}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.generate-btn:disabled{opacity:.8;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.generating-overlay{position:relative;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:16px;padding:60px 40px;text-align:center;margin-bottom:24px}.generating-content h3{font-size:1.25rem;color:#4c1d95;margin:24px 0 8px}.generating-content p{color:#6b7280;margin-bottom:24px}.ai-animation{position:relative;width:80px;height:80px;margin:0 auto}.ai-animation .sparkle{position:absolute;color:#8b5cf6;animation:sparkleFloat 1.5s ease-in-out infinite}.ai-animation .s1{top:0;left:50%;transform:translate(-50%);animation-delay:0s}.ai-animation .s2{bottom:10px;left:10px;animation-delay:.5s}.ai-animation .s3{bottom:10px;right:10px;animation-delay:1s}@keyframes sparkleFloat{0%,to{opacity:.5;transform:translateY(0) scale(.8)}50%{opacity:1;transform:translateY(-10px) scale(1.2)}}.progress-bar{width:200px;height:4px;background:#ddd6fe;border-radius:2px;margin:0 auto;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#6366f1);border-radius:2px;animation:progressMove 2s ease-in-out infinite}@keyframes progressMove{0%{width:0%;margin-left:0}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}.empty-state{background:#f9fafb;border:2px dashed #e5e7eb;border-radius:16px;padding:60px 40px;text-align:center}.empty-illustration{position:relative;display:inline-block;color:#9ca3af;margin-bottom:16px}.empty-sparkle{position:absolute;top:-8px;right:-8px;color:#8b5cf6;animation:sparkleFloat 2s ease-in-out infinite}.empty-state h3{font-size:1.25rem;color:#374151;margin-bottom:8px}.empty-state p{color:#6b7280;max-width:400px;margin:0 auto 24px;line-height:1.6}.feature-list{list-style:none;padding:0;margin:0;display:inline-flex;flex-direction:column;gap:8px;text-align:left}.feature-list li{display:flex;align-items:center;gap:8px;color:#4b5563;font-size:.9rem}.feature-list li svg{color:#10b981}.report-actions{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f3f4f6;border-radius:10px;margin-bottom:20px;flex-wrap:wrap;gap:12px}.generated-time{font-size:.8rem;color:#6b7280}.action-buttons{display:flex;gap:8px}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:.8rem;color:#374151;cursor:pointer;transition:all .2s}.action-btn:hover{background:#f9fafb;border-color:#d1d5db}.report-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:16px;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;cursor:pointer;transition:background .2s}.section-header:hover{background:#f9fafb}.section-title{display:flex;align-items:center;gap:10px}.section-title svg{color:#6366f1}.section-title h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0}.section-content{padding:0 20px 20px;border-top:1px solid #f3f4f6}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:24px;padding-top:20px}.stat-card{background:linear-gradient(135deg,#f5f3ff,#ede9fe);padding:16px;border-radius:10px;text-align:center}.stat-value{font-size:1.75rem;font-weight:700;color:#4c1d95;display:block}.stat-value small{font-size:.9rem;font-weight:500;margin-left:2px}.stat-label{font-size:.8rem;color:#6b7280;margin-top:4px;display:block}.summary-text{background:#f9fafb;padding:20px;border-radius:10px;border-left:4px solid #6366f1}.summary-text h4{font-size:1.1rem;color:#1f2937;margin:0 0 12px}.summary-text p{color:#4b5563;line-height:1.7;margin:0 0 12px}.summary-text p:last-child{margin-bottom:0}.summary-text strong{color:#4c1d95;font-weight:600}.patterns-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;padding-top:20px}.pattern-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.pattern-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.pattern-icon{width:36px;height:36px;padding:8px;border-radius:8px;flex-shrink:0}.pattern-icon.typhoon{background:#fef2f2;color:#ef4444}.pattern-icon.rain{background:#eff6ff;color:#3b82f6}.pattern-icon.wave{background:#f0fdfa;color:#14b8a6}.pattern-icon.normal{background:#fefce8;color:#eab308}.pattern-title-wrap{flex:1}.pattern-title-wrap h4{font-size:.95rem;font-weight:600;color:#1f2937;margin:0 0 6px;line-height:1.3}.severity-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;color:#fff}.pattern-description{font-size:.85rem;color:#4b5563;line-height:1.6;margin:0 0 12px}.pattern-meta{display:flex;flex-direction:column;gap:6px;padding-top:12px;border-top:1px solid #e5e7eb}.meta-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#6b7280}.recommendations-list{display:flex;flex-direction:column;gap:12px;padding-top:20px}.recommendation-item{display:flex;gap:16px;background:#f9fafb;border-radius:10px;padding:16px}.priority-indicator{width:4px;border-radius:2px;flex-shrink:0}.recommendation-content{flex:1}.recommendation-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;flex-wrap:wrap}.recommendation-header h4{font-size:.95rem;font-weight:600;color:#1f2937;margin:0}.priority-badge{padding:2px 8px;border:1px solid;border-radius:4px;font-size:.7rem;font-weight:600;background:#fff}.recommendation-content p{font-size:.85rem;color:#4b5563;line-height:1.6;margin:0 0 8px}.expected-effect{font-size:.8rem;color:#059669;font-weight:500}.detailed-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:20px;padding-top:20px}.detailed-card{background:#f9fafb;border-radius:10px;padding:16px}.detailed-card h4{font-size:.9rem;font-weight:600;color:#374151;margin:0 0 12px}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th,.data-table td{padding:10px 8px;text-align:left;border-bottom:1px solid #e5e7eb}.data-table th{font-weight:600;color:#6b7280;font-size:.75rem;text-transform:uppercase}.data-table td{color:#374151}.rank-cell{width:50px}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.75rem;font-weight:700;color:#fff;background:#9ca3af}.rank-badge.rank-1{background:#f59e0b}.rank-badge.rank-2{background:#9ca3af}.rank-badge.rank-3{background:#b45309}.ratio-bar{display:flex;align-items:center;gap:8px}.ratio-fill{height:6px;background:#ef4444;border-radius:3px;max-width:100px}.ratio-bar span{font-size:.8rem;font-weight:600;color:#374151;min-width:36px}.issue-tags{display:flex;flex-wrap:wrap;gap:4px}.mini-tag{padding:2px 6px;background:#e5e7eb;border-radius:4px;font-size:.7rem;color:#4b5563}.monthly-trend{margin-top:20px;padding:16px;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:10px}.monthly-trend h4{font-size:.9rem;font-weight:600;color:#4c1d95;margin:0 0 8px}.monthly-trend p{font-size:.85rem;color:#4b5563;margin:0;line-height:1.6}@media(max-width:768px){.ai-report-container{padding:16px}.ai-report-header{flex-direction:column}.header-controls{width:100%;justify-content:space-between}.patterns-grid,.detailed-grid{grid-template-columns:1fr}.summary-stats{grid-template-columns:repeat(2,1fr)}.report-actions{flex-direction:column;align-items:flex-start}.action-buttons{width:100%;flex-wrap:wrap}.action-btn{flex:1;justify-content:center}}@media(max-width:480px){.summary-stats{grid-template-columns:1fr}.recommendation-header{flex-direction:column;gap:8px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);padding:20px}.login-container{width:100%;max-width:420px;background:#fff;border-radius:24px;padding:40px 32px;box-shadow:0 20px 60px #0000001a}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:64px;height:64px;background:linear-gradient(135deg,#0ea5e9,#0284c7);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff}.login-header h1{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:8px}.login-header p{font-size:14px;color:#64748b}.login-tabs{display:flex;gap:8px;background:#f1f5f9;padding:4px;border-radius:12px;margin-bottom:24px}.login-tabs .tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;background:transparent;color:#64748b}.login-tabs .tab.active{background:#fff;color:#0284c7;box-shadow:0 2px 8px #00000014}.user-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;max-height:280px;overflow-y:auto}.user-item{display:flex;align-items:center;gap:12px;padding:16px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.user-item:hover{border-color:#0ea5e9;background:#f0f9ff}.user-item.selected{border-color:#0284c7;background:#e0f2fe}.user-avatar{width:48px;height:48px;background:linear-gradient(135deg,#0ea5e9,#0284c7);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.user-avatar.admin{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.user-info{flex:1}.user-name{display:block;font-size:16px;font-weight:600;color:#1e293b}.user-org{display:block;font-size:12px;color:#64748b;margin-top:2px}.chevron{color:#94a3b8;transition:transform .2s ease}.user-item.selected .chevron{color:#0284c7;transform:translate(4px)}.login-btn{width:100%;padding:16px;border:none;border-radius:12px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0ea5e966}.login-btn:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.quick-access{margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0;text-align:center}.quick-access p{font-size:12px;color:#94a3b8;margin-bottom:12px}.quick-buttons{display:flex;gap:8px}.quick-buttons button{flex:1;padding:10px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;font-size:12px;color:#64748b;cursor:pointer;transition:all .2s ease}.quick-buttons button:hover{border-color:#0ea5e9;color:#0284c7;background:#f0f9ff}.back-btn{display:block;width:100%;margin-top:16px;padding:12px;border:none;background:transparent;font-size:14px;color:#64748b;cursor:pointer;transition:color .2s ease}.back-btn:hover{color:#0284c7}.landing-page{min-height:100vh;overflow-x:hidden}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0ea5e9,#0284c7,#0369a1);overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.wave{position:absolute;bottom:0;left:0;width:200%;height:200px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='%23ffffff' fill-opacity='0.3' d='M0,192L48,197.3C96,203,192,213,288,229.3C384,245,480,267,576,250.7C672,235,768,181,864,181.3C960,181,1056,235,1152,234.7C1248,235,1344,181,1392,154.7L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'%3E%3C/path%3E%3C/svg%3E") repeat-x;background-size:50% 100%;animation:wave 20s linear infinite}.wave1{opacity:.5;animation-duration:25s;bottom:0}.wave2{opacity:.3;animation-duration:20s;animation-direction:reverse;bottom:20px}.wave3{opacity:.2;animation-duration:15s;bottom:40px}@keyframes wave{0%{transform:translate(0)}to{transform:translate(-50%)}}.hero-content{position:relative;z-index:10;text-align:center;padding:40px 20px;color:#fff}.logo{display:inline-flex;align-items:center;gap:12px;background:#fff3;padding:12px 24px;border-radius:50px;margin-bottom:32px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logo span{font-size:18px;font-weight:600}.hero h1{font-size:48px;font-weight:800;line-height:1.2;margin-bottom:20px;text-shadow:0 2px 20px rgba(0,0,0,.2)}.hero h1 .subtitle{display:block;font-size:28px;font-weight:500;opacity:.85;margin-top:8px}.tagline{font-size:18px;line-height:1.6;opacity:.9;margin-bottom:40px}.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.btn-hero{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-hero.primary{background:#fff;color:#0284c7}.btn-hero.primary:hover{transform:translateY(-3px);box-shadow:0 10px 30px #0003}.btn-hero.secondary{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-hero.secondary:hover{background:#ffffff4d;transform:translateY(-3px)}.features{padding:80px 20px;background:#fff}.features h2{text-align:center;font-size:32px;font-weight:700;color:#1e293b;margin-bottom:48px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;max-width:1200px;margin:0 auto}.feature-card{padding:32px;background:#f8fafc;border-radius:16px;text-align:center;transition:all .3s ease}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 40px #0000001a}.feature-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff}.feature-card h3{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:12px}.feature-card p{font-size:14px;color:#64748b;line-height:1.6}.stats-section{padding:60px 20px;background:linear-gradient(135deg,#0ea5e9,#0284c7)}.stats-grid{display:flex;justify-content:center;gap:60px;flex-wrap:wrap;max-width:800px;margin:0 auto}.stat-item{text-align:center;color:#fff}.stat-number{display:block;font-size:48px;font-weight:800;margin-bottom:8px}.stat-label{font-size:16px;opacity:.9}.landing-footer{padding:40px 20px;background:#1e293b;color:#94a3b8;text-align:center}.landing-footer p{margin:8px 0}.demo-notice{color:#f59e0b;font-weight:500}@media(max-width:768px){.hero h1{font-size:32px}.tagline{font-size:16px}.hero-buttons{flex-direction:column;align-items:center}.btn-hero{width:100%;max-width:280px;justify-content:center}.stats-grid{gap:40px}.stat-number{font-size:36px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover{background:#d1d5db}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.card{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .2s ease;outline:none}.input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tag{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.tag-high{background:#fee2e2;color:#dc2626}.tag-medium{background:#fef3c7;color:#d97706}.tag-low{background:#d1fae5;color:#059669}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease forwards}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s ease-in-out infinite}
