@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.login-layout[data-v-ed9e0f28]{width:100%;height:100%}.app-layout[data-v-ed9e0f28]{background:#f0f2f5;flex-direction:column;min-height:100vh;display:flex}.top-navbar[data-v-ed9e0f28]{color:#fff;z-index:100;background:linear-gradient(135deg,#2d69f5,#1a56db);position:sticky;top:0;box-shadow:0 2px 8px #00000026}.navbar-inner[data-v-ed9e0f28]{align-items:center;width:100%;max-width:1400px;height:52px;margin:0 auto;padding:0 24px;display:flex}.navbar-brand[data-v-ed9e0f28]{white-space:nowrap;align-items:center;gap:8px;margin-right:32px;font-size:16px;font-weight:700;display:flex}.navbar-nav[data-v-ed9e0f28]{flex:1;align-items:center;gap:4px;display:flex}.nav-link[data-v-ed9e0f28]{color:#fffc;white-space:nowrap;border-radius:6px;align-items:center;gap:6px;padding:6px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-link[data-v-ed9e0f28]:hover{color:#fff;background:#ffffff26}.nav-link.active[data-v-ed9e0f28]{color:#fff;background:#fff3}.navbar-right[data-v-ed9e0f28]{align-items:center;display:flex}.navbar-user[data-v-ed9e0f28]{align-items:center;gap:8px;display:flex}.nav-avatar[data-v-ed9e0f28]{background:#ffffff40;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:600;display:flex;overflow:hidden}.nav-avatar img[data-v-ed9e0f28]{object-fit:cover;width:100%;height:100%}.nav-username[data-v-ed9e0f28]{white-space:nowrap;font-size:13px;font-weight:500}.nav-logout[data-v-ed9e0f28]{color:#ffffffe6;cursor:pointer;background:#ffffff26;border:none;border-radius:4px;align-items:center;gap:4px;margin-left:8px;padding:4px 12px;font-size:12px;transition:all .2s;display:flex}.nav-logout[data-v-ed9e0f28]:hover{color:#fff;background:#ffffff40}.main-area[data-v-ed9e0f28]{box-sizing:border-box;flex:1;width:100%;max-width:1400px;margin:0 auto;padding:24px}@media (width<=768px){.navbar-inner[data-v-ed9e0f28]{height:48px;padding:0 12px}.navbar-brand[data-v-ed9e0f28]{margin-right:12px;font-size:14px}.navbar-brand span[data-v-ed9e0f28]{display:none}.navbar-nav[data-v-ed9e0f28]{-webkit-overflow-scrolling:touch;gap:2px;overflow-x:auto}.nav-link[data-v-ed9e0f28]{flex-shrink:0;gap:4px;padding:4px 10px;font-size:12px}.nav-username[data-v-ed9e0f28]{display:none}.nav-avatar[data-v-ed9e0f28]{width:26px;height:26px;font-size:11px}.nav-logout[data-v-ed9e0f28]{margin-left:4px;padding:3px 8px;font-size:11px}.main-area[data-v-ed9e0f28]{padding:12px}}:root{--bg-primary:#faf9f6;--bg-secondary:#f5f4f0;--bg-card:#fff;--bg-sidebar:#1a1915;--bg-sidebar-hover:#2d2b24;--bg-sidebar-active:#3d3b33;--text-primary:#2d2b28;--text-secondary:#6b6966;--text-muted:#9b9895;--text-sidebar:#e8e5de;--text-sidebar-muted:#8b8880;--accent:#d97757;--accent-light:#f0c8b8;--accent-hover:#c46545;--border:#e8e5de;--border-light:#f0ede8;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:999px;--transition:all .2s ease;--status-presale:#e3f2fd;--status-presale-text:#1565c0;--status-bidding:#fff3e0;--status-bidding-text:#e65100;--status-implementation:#e8f5e9;--status-implementation-text:#2e7d32;--status-collecting:#fce4ec;--status-collecting-text:#c62828;--status-collected:#e0f2f1;--status-collected-text:#00695c;--status-maintenance:#f3e5f5;--status-maintenance-text:#6a1b9a}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;min-height:100vh;padding:32px 40px}.page-header{margin-bottom:28px}.page-title{color:var(--text-primary);font-size:24px;font-weight:600}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:14px}.card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:var(--transition);padding:24px}.card:hover{box-shadow:var(--shadow-md)}.card-title{color:var(--text-primary);margin-bottom:16px;font-size:16px;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:var(--transition);padding:20px 24px}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:500}.stat-value{color:var(--text-primary);font-size:32px;font-weight:700}.stat-icon{margin-bottom:12px;font-size:24px}.btn{border-radius:var(--radius-full);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:8px 20px;font-family:inherit;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{color:#c62828;background:#fee;border:1px solid #fecdd2}.btn-danger:hover{background:#fecdd2}.btn-sm{padding:5px 14px;font-size:13px}.btn-icon{border-radius:50%;width:36px;height:36px;padding:0}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{width:100%;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--transition);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-textarea{resize:vertical;min-height:100px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:12px 16px;font-size:12px;font-weight:600}.table td{border-bottom:1px solid var(--border-light);vertical-align:middle;padding:14px 16px;font-size:14px}.table tr{transition:var(--transition)}.table tbody tr:hover{background:var(--bg-secondary)}.table-link{color:var(--accent);cursor:pointer;font-weight:500;text-decoration:none}.table-link:hover{text-decoration:underline}.status-tag{border-radius:var(--radius-full);white-space:nowrap;align-items:center;padding:3px 12px;font-size:12px;font-weight:500;display:inline-flex}.status-presale{background:var(--status-presale);color:var(--status-presale-text)}.status-bidding{background:var(--status-bidding);color:var(--status-bidding-text)}.status-implementation{background:var(--status-implementation);color:var(--status-implementation-text)}.status-collecting{background:var(--status-collecting);color:var(--status-collecting-text)}.status-collected{background:var(--status-collected);color:var(--status-collected-text)}.status-maintenance{background:var(--status-maintenance);color:var(--status-maintenance-text)}.category-tag{border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-secondary);align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.timeline{padding-left:28px;position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:0;bottom:0;left:10px}.timeline-item{padding-bottom:24px;position:relative}.timeline-dot{background:var(--bg-card);border:2px solid var(--accent);border-radius:50%;width:14px;height:14px;position:absolute;top:4px;left:-24px}.timeline-dot.ai{background:#ede7f6;border-color:#7c4dff}.timeline-dot.alert{background:#fff3e0;border-color:#ff6d00}.timeline-date{color:var(--text-muted);margin-bottom:4px;font-size:12px}.timeline-source{border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-secondary);margin-bottom:6px;padding:2px 8px;font-size:11px;display:inline-block}.timeline-content{color:var(--text-primary);font-size:14px;line-height:1.7}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);min-width:200px;transition:var(--transition);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239B9895' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-position:14px;background-repeat:no-repeat;outline:none;flex:1;padding:9px 16px 9px 40px;font-family:inherit;font-size:14px}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.filter-tag{border-radius:var(--radius-full);cursor:pointer;transition:var(--transition);background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);padding:6px 16px;font-size:13px;font-weight:500}.filter-tag:hover,.filter-tag.active{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:560px;max-height:80vh;box-shadow:var(--shadow-lg);padding:28px;animation:.3s slideUp;overflow-y:auto}.modal-title{margin-bottom:20px;font-size:18px;font-weight:600}.modal-actions{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-icon{margin-bottom:16px;font-size:48px}.empty-text{font-size:15px}.alert-badge{border-radius:var(--radius-full);align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.alert-badge.warning{color:#f57f17;background:#fff8e1}.alert-badge.danger{color:#c62828;background:#ffebee}.pagination{justify-content:center;align-items:center;gap:8px;margin-top:24px;display:flex}.page-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;width:36px;height:36px;transition:var(--transition);justify-content:center;align-items:center;font-size:14px;display:flex}.page-btn:hover,.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.loading{justify-content:center;align-items:center;padding:40px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-enter-active,.fade-leave-active{transition:opacity .3s}.fade-enter-from,.fade-leave-to{opacity:0}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.text-right{text-align:right}.charts-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}.chart-container{height:280px}.toast{border-radius:var(--radius-sm);z-index:300;box-shadow:var(--shadow-lg);padding:12px 20px;font-size:14px;font-weight:500;animation:.3s slideIn;position:fixed;top:24px;right:24px}.toast-success{color:#2e7d32;background:#e8f5e9}.toast-error{color:#c62828;background:#ffebee}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:var(--transition);color:var(--text-muted);padding:40px}.drop-zone:hover,.drop-zone.dragover{border-color:var(--accent);color:var(--accent);background:#d977570d}@media (width<=768px){.main-content{padding:16px}.page-header{margin-bottom:16px}.page-title{font-size:18px}.page-subtitle{font-size:13px}.filter-bar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:8px;margin-bottom:12px;padding-bottom:4px;overflow-x:auto}.filter-tag{white-space:nowrap;flex-shrink:0;padding:5px 12px;font-size:12px}.search-input{min-width:140px;padding:8px 12px 8px 36px;font-size:13px}.stats-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.stat-card{padding:14px 16px}.stat-value{font-size:22px}.stat-label{font-size:11px}.charts-grid{grid-template-columns:1fr;gap:12px}.card{border-radius:var(--radius-sm);padding:16px}.card[style*=padding\:0],.card[style*="padding: 0"]{-webkit-overflow-scrolling:touch;overflow-x:auto}.table th,.table td{white-space:nowrap;padding:10px 12px;font-size:12px}.table th{font-size:11px}.form-row{grid-template-columns:1fr;gap:0}.form-input,.form-select,.form-textarea{font-size:16px}.btn{padding:8px 16px;font-size:13px}.btn-sm{padding:4px 10px;font-size:12px}.modal{width:95%;max-height:90vh;padding:20px}.pagination{gap:4px;margin-top:16px}.page-btn{width:32px;height:32px;font-size:13px}.toast{text-align:center;top:12px;left:12px;right:12px}.flex.justify-between{flex-wrap:wrap;gap:8px}.drop-zone{padding:24px}.timeline{padding-left:20px}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.stat-value{font-size:20px}}
