@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Thai:wght@300;400;500;600&family=IBM+Plex+Mono:wght@400;500&family=Space+Grotesk:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0D1117;--bg2: #161B22;--bg3: #171d2b;--bg4: #1e2638;--border: #30363D;--border2: #3a4a63;--text: #FFFFFF;--text2: #CBD5E1;--text3: #94A3B8;--accent: #4ADE80;--accent2: #22C55E;--blue: #00D1FF;--amber: #FF9F0A;--red: #F87171;--green: #4ADE80;--purple: #A78BFA;--radius: 10px;--radius-lg: 16px;--shadow: 0 8px 30px rgba(0,0,0,.6);--font: "Space Grotesk", "IBM Plex Sans Thai", sans-serif;--mono: "IBM Plex Mono", monospace}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}#root{height:100%;display:flex}h1,h2,h3,h4{color:#fff!important;font-weight:700!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.card{background:var(--bg2);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow);transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:visible;will-change:transform,box-shadow;white-space:normal;word-break:break-word;min-height:80px;z-index:1}.card:hover{z-index:100}.card:after{content:"";position:absolute;top:-20px;right:-20px;width:100px;height:100px;background:radial-gradient(circle,rgba(255,255,255,.2) 0%,transparent 70%);border-radius:50%;pointer-events:none;z-index:0}.card-sm{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow);transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:visible;will-change:transform,box-shadow;white-space:normal;word-break:break-word}.glow-green{box-shadow:0 0 25px 5px #4ade8026,0 10px 30px #00000080!important}.glow-green:hover{box-shadow:0 0 35px 10px #4ade8066,0 10px 40px #0009!important}.glow-red{box-shadow:0 0 25px 5px #f8717126,0 10px 30px #00000080!important}.glow-red:hover{box-shadow:0 0 35px 10px #f8717166,0 10px 40px #0009!important}.glow-amber{box-shadow:0 0 25px 5px #ff9f0a1f,0 10px 30px #00000080!important}.glow-amber:hover{box-shadow:0 0 35px 10px #ff9f0a59,0 10px 40px #0009!important}.glow-green-sm{box-shadow:0 4px 15px #4ade8026!important}.glow-green-sm:hover{box-shadow:0 8px 25px #4ade804d!important}.glow-red-sm{box-shadow:0 4px 15px #f8717126!important}.glow-red-sm:hover{box-shadow:0 8px 25px #f871714d!important}.glow-amber-sm{box-shadow:0 4px 15px #ff9f0a1f!important}.glow-amber-sm:hover{box-shadow:0 8px 25px #ff9f0a40!important}.card-active-portkat{border-left:5px solid var(--status-color, var(--amber))!important;padding-left:11px!important;transform:translateY(-4px);box-shadow:0 15px 40px #0009,0 0 20px #ff9f0a33!important;background:var(--bg3)!important;transition:all .4s cubic-bezier(.16,1,.3,1);will-change:transform,box-shadow;z-index:10}.btn-edit-hover:hover{background-color:#3b82f626!important;transform:scale(1.1);color:#3b82f6!important}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.badge-green{background:#22c55e40;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.badge-amber{background:#f59e0b40;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.badge-red{background:#ef444440;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.badge-blue{background:#4d9fff40;color:#93c5fd;border:1px solid rgba(77,159,255,.3)}.badge-purple{background:#a78bfa40;color:#c4b5fd;border:1px solid rgba(167,139,250,.3)}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text2);text-decoration:none;border-radius:8px;font-size:14px;font-weight:500;transition:all .2s;margin:2px 0;position:relative}.nav-link:hover{background:#ff9f0a0d;color:var(--text)}.nav-link.active{background:#ff9f0a1a;color:var(--amber);font-weight:600;border-left:3px solid var(--amber)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font);font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-primary{background:var(--accent);color:#000;box-shadow:0 4px 12px #22c55e33}.btn-primary:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 6px 16px #22c55e4d}.btn-ghost{background:var(--bg3);color:var(--text);border:1px solid var(--border2)}.btn-ghost:hover{background:var(--bg4);border-color:var(--text2)}.btn-danger{background:var(--red);color:#fff;box-shadow:0 4px 12px #ef444433}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.input{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:9px 14px;color:var(--text);font-family:var(--font);font-size:14px;width:100%;outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::-moz-placeholder{color:var(--text3)}.input::placeholder{color:var(--text3)}.stat-num{font-size:28px;font-weight:800;line-height:1}.stat-label{font-size:14px;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;margin-top:4px;font-weight:500}.risk-low{color:var(--green)}.risk-medium{color:var(--amber)}.risk-high{color:var(--red)}.risk-critical{color:var(--red);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.otp-input:focus{border-color:var(--purple)!important;background:#4f46e51a!important;box-shadow:0 0 0 4px #4f46e51a}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeUp .3s ease both}.delay-1{animation-delay:.05s}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}.delay-4{animation-delay:.2s}.delay-5{animation-delay:.25s}.mono{font-family:var(--mono)}hr{border:none;border-top:1px solid var(--border)}.tag{font-family:var(--mono);font-size:12px;background:var(--bg4);border:1px solid var(--border);border-radius:6px;padding:2px 8px;color:var(--text2)}.leaflet-container{background:#0d1117!important}.leaflet-tile{filter:invert(1) hue-rotate(180deg) brightness(.85) contrast(1.1)}.hide-mobile{display:flex}.show-mobile{display:none}@media (max-width: 768px){.hide-mobile{display:none!important}.show-mobile{display:flex!important}}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.dashboard-grid{display:grid;grid-template-columns:1fr 340px;gap:16px}.tracking-grid{display:grid;grid-template-columns:minmax(320px,400px) 1fr;gap:16px;flex:1;min-height:0}@media (max-width: 1100px){.dashboard-grid,.tracking-grid{grid-template-columns:1fr}}.sidebar{width:220px;min-width:220px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;z-index:100}.sidebar.collapsed{width:64px;min-width:64px}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--bg2);border-bottom:1px solid var(--border);z-index:90}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:95;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 1100px){.dashboard-grid{grid-template-columns:1fr}.tracking-grid{grid-template-columns:1fr;flex-direction:column;overflow-y:auto}}@media (max-width: 768px){.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.mobile-header{display:flex}.sidebar{position:fixed;top:0;bottom:0;left:-320px;width:280px!important;min-width:280px!important;box-shadow:10px 0 30px #00000080}.sidebar.mobile-open{left:0}.sidebar-overlay.mobile-open{display:block}.app-layout{flex-direction:column!important;overflow-y:auto!important;height:auto!important;min-height:100vh;--sidebar-width: 0px !important}.main-content{padding:16px!important;overflow:visible!important}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr}}
