@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--bg-base:#0b1326;--bg-surface:#131b2e;--bg-card:#1a2440;--bg-elevated:#222a3d;--bg-glass:#222a3d99;--primary:#0ea5e9;--primary-dim:#0284c7;--primary-glow:#0ea5e926;--secondary:#10b981;--secondary-dim:#059669;--secondary-glow:#10b98126;--accent:#f59e0b;--text-primary:#e8f0fd;--text-secondary:#94a3b8;--text-muted:#64748b;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#0ea5e9;--border:#ffffff0f;--border-active:#0ea5e94d;--font-display:"Outfit", sans-serif;--font-body:"Plus Jakarta Sans", sans-serif;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-glow:0 0 24px #0ea5e933;--transition:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.02em;line-height:1.2}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{border:none;outline:none;font-family:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:2px}.app-container{flex-direction:column;min-height:100vh;display:flex}.portal-selector{background:radial-gradient(at 50% 0,#0ea5e91f 0%,#0000 60%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.portal-selector .logo{font-family:var(--font-display);background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:2.8rem;font-weight:800}.portal-selector .tagline{color:var(--text-secondary);text-align:center;margin-bottom:48px;font-size:.95rem}.portal-grid{grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:500px;display:grid}.portal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);text-align:center;cursor:pointer;transition:all var(--transition);padding:28px 20px}.portal-card:hover{border-color:var(--border-active);background:var(--bg-elevated);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.portal-card .icon{margin-bottom:12px;font-size:2.4rem}.portal-card .label{font-family:var(--font-display);color:var(--text-primary);margin-bottom:4px;font-size:1rem;font-weight:700}.portal-card .sublabel{color:var(--text-muted);font-size:.78rem}.mobile-shell{background:var(--bg-base);flex-direction:column;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}@media (width>=600px){.mobile-shell{border:14px solid #000;border-radius:44px;width:390px;height:844px;max-height:90vh;margin:4vh auto;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a}.mobile-shell:before{content:"";z-index:110;background:#000;border-bottom-right-radius:18px;border-bottom-left-radius:18px;width:120px;height:28px;position:absolute;top:0;left:50%;transform:translate(-50%)}}.mobile-content{flex:1;padding-bottom:80px;overflow-y:auto}.mobile-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border);z-index:50;background:#0d1326f2;justify-content:space-around;align-items:center;height:72px;padding:0 8px;display:flex;position:absolute;bottom:0;left:0;right:0}.nav-item{border-radius:var(--r-md);cursor:pointer;transition:all var(--transition);flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 16px;display:flex}.nav-item .nav-icon{font-size:1.3rem;line-height:1}.nav-item .nav-label{color:var(--text-muted);font-size:.65rem;font-weight:500}.nav-item.active .nav-label{color:var(--primary)}.nav-item.active .nav-icon{filter:drop-shadow(0 0 6px #0ea5e999)}.desktop-shell{min-height:100vh;display:flex}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;padding:24px 0;display:flex}.sidebar-logo{font-family:var(--font-display);background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;padding:0 24px 24px;font-size:1.3rem;font-weight:800}.sidebar-logo span{color:var(--text-muted);-webkit-text-fill-color:var(--text-muted);font-size:.7rem;font-weight:400;display:block}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:0 12px;display:flex}.sidebar-item{border-radius:var(--r-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);align-items:center;gap:10px;padding:10px 14px;font-size:.88rem;font-weight:500;display:flex}.sidebar-item:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar-item.active{background:var(--primary-glow);color:var(--primary);border:1px solid var(--border-active)}.sidebar-item .s-icon{text-align:center;width:22px;font-size:1.1rem}.desktop-content{background:var(--bg-base);flex:1;padding:32px;overflow-y:auto}.status-bar{color:var(--text-primary);z-index:105;justify-content:space-between;align-items:center;padding:14px 24px 6px;font-size:.75rem;font-weight:600;display:flex;position:relative}.status-bar-right{align-items:center;gap:8px;display:flex}.screen-header{align-items:center;gap:12px;padding:16px 20px 12px;display:flex}.screen-header h2{font-family:var(--font-display);color:var(--text-primary);flex:1;font-size:1.3rem;font-weight:700}.btn-back{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;width:36px;height:36px;transition:all var(--transition);justify-content:center;align-items:center;font-size:1rem;display:flex}.btn-back:hover{background:var(--bg-elevated)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}.card-glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}.card-glow-blue{border-color:var(--border-active);box-shadow:var(--shadow-glow)}.card-glow-green{border-color:#10b9814d;box-shadow:0 0 24px #10b9811f}.btn{border-radius:var(--r-full);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 24px;font-size:.95rem;font-weight:600;display:flex}.btn-primary{background:linear-gradient(135deg, var(--primary), #38bdf8);color:#001e2f;font-weight:700;box-shadow:0 4px 16px #0ea5e94d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #0ea5e966}.btn-secondary{background:linear-gradient(135deg, var(--secondary), #34d399);color:#003d28;font-weight:700;box-shadow:0 4px 16px #10b9814d}.btn-secondary:hover{transform:translateY(-1px)}.btn-outline{border:1.5px solid var(--border-active);color:var(--primary);background:0 0}.btn-outline:hover{background:var(--primary-glow)}.btn-outline-green{color:var(--secondary);background:0 0;border:1.5px solid #10b98166}.btn-outline-green:hover{background:var(--secondary-glow)}.btn-sm{padding:9px 18px;font-size:.82rem}.badge{border-radius:var(--r-full);align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--primary-glow);color:var(--primary);border:1px solid var(--border-active)}.badge-green{background:var(--secondary-glow);color:var(--secondary);border:1px solid #10b9814d}.badge-amber{color:var(--accent);background:#f59e0b26;border:1px solid #f59e0b4d}.badge-red{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.badge-muted{background:var(--bg-elevated);color:var(--text-muted)}.progress-bar{background:var(--bg-elevated);border-radius:var(--r-full);height:6px;overflow:hidden}.progress-fill{border-radius:var(--r-full);height:100%;transition:width .6s}.progress-fill-blue{background:linear-gradient(90deg, var(--primary), #38bdf8)}.progress-fill-green{background:linear-gradient(90deg, var(--secondary), #34d399)}.input-field{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-primary);transition:border-color var(--transition);padding:12px 16px;font-size:.9rem}.input-field:focus{border-color:#0ea5e966}.input-field::placeholder{color:var(--text-muted)}.select-field{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-primary);appearance:none;cursor:pointer;padding:12px 16px;font-size:.9rem}.divider{background:var(--border);height:1px;margin:16px 0}.screen-pad{padding:16px 20px}.screen-pad-lg{padding:20px}.stars{color:var(--accent);gap:2px;font-size:.9rem;display:flex}.star-score{color:var(--accent);font-size:.85rem;font-weight:700}.avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1rem;font-weight:700;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-size:.72rem;font-weight:600}.kpi-card{flex-direction:column;gap:6px;display:flex}.kpi-label{color:var(--text-secondary);font-size:.75rem}.kpi-value{font-family:var(--font-display);font-size:1.6rem;font-weight:800}.kpi-sub{color:var(--text-muted);font-size:.72rem}.kpi-grid{gap:12px;display:grid}.kpi-grid-4{grid-template-columns:repeat(4,1fr)}.kpi-grid-2{grid-template-columns:repeat(2,1fr)}.scroll-row{gap:12px;padding-bottom:8px;display:flex;overflow-x:auto}.scroll-row::-webkit-scrollbar{height:0}.map-placeholder{border-radius:var(--r-lg);background:url(/assets/map_dark.png) 50%/cover;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.map-grid{background-color:#0b132699;background-image:linear-gradient(#0ea5e91a 1px,#0000 1px),linear-gradient(90deg,#0ea5e91a 1px,#0000 1px);background-size:30px 30px;position:absolute;inset:0}.map-dot{background:var(--primary);width:12px;height:12px;box-shadow:0 0 12px var(--primary);border-radius:50%;animation:2s infinite pulse;position:absolute}.map-dot-green{background:var(--secondary);box-shadow:0 0 12px var(--secondary)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.map-label{border:1px solid var(--border-active);border-radius:var(--r-full);color:var(--primary);z-index:2;background:#0d1326e6;padding:6px 12px;font-size:.75rem;position:relative}.timeline{flex-direction:column;display:flex}.timeline-item{gap:14px;display:flex}.timeline-left{flex-direction:column;align-items:center;display:flex}.timeline-dot{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;display:flex}.timeline-dot.done{background:var(--secondary-glow);border:2px solid var(--secondary);color:var(--secondary)}.timeline-dot.active{background:var(--primary-glow);border:2px solid var(--primary);color:var(--primary);animation:2s infinite pulse}.timeline-dot.pending{background:var(--bg-elevated);border:2px solid var(--border);color:var(--text-muted)}.timeline-line{background:var(--border);flex:1;width:2px;min-height:24px;margin:4px 0}.timeline-content{flex:1;padding-bottom:20px}.timeline-title{margin-bottom:2px;font-size:.9rem;font-weight:600}.timeline-sub{color:var(--text-secondary);font-size:.78rem}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 14px;font-size:.72rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px;font-size:.85rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-elevated)}.page-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:6px;font-size:1.8rem;font-weight:800}.page-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:.88rem}.alert-banner{border-radius:var(--r-md);align-items:center;gap:10px;padding:12px 16px;font-size:.82rem;font-weight:500;display:flex}.alert-banner-blue{background:var(--primary-glow);border:1px solid var(--border-active);color:var(--primary)}.alert-banner-amber{color:var(--accent);background:#f59e0b1a;border:1px solid #f59e0b4d}.alert-banner-green{background:var(--secondary-glow);color:var(--secondary);border:1px solid #10b9814d}.tier-ring-container{justify-content:center;padding:20px 0;display:flex}.tier-ring{background:conic-gradient(var(--primary) 0% 72%, var(--bg-elevated) 72% 100%);border-radius:50%;justify-content:center;align-items:center;width:160px;height:160px;display:flex;position:relative}.tier-ring:before{content:"";background:var(--bg-surface);border-radius:50%;position:absolute;inset:12px}.tier-ring-inner{z-index:2;text-align:center;position:relative}.tier-ring-pts{font-family:var(--font-display);color:var(--primary);font-size:1.4rem;font-weight:800}.tier-ring-label{color:var(--text-secondary);font-size:.7rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.w-full{width:100%}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.text-sm{font-size:.82rem}.text-xs{font-size:.72rem}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-primary-color{color:var(--primary)}.text-green{color:var(--secondary)}.text-amber{color:var(--accent)}.font-bold{font-weight:700}.font-display{font-family:var(--font-display)}.text-right{text-align:right}.opacity-50{opacity:.5}.rounded-full{border-radius:var(--r-full)}.gradient-text{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:.3s forwards fadeInUp}@media (width<=768px){.kpi-grid-4{grid-template-columns:repeat(2,1fr)}.desktop-shell{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;width:100%;height:60px;padding:0}}
