@import "https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&family=Google+Sans:wght@400;500;700&display=swap";:root{--primary:#1a73e8;--bg-color:#f8f9fa;--card-bg:#fff;--danger:#ea4335;--warning:#fbbc05;--success:#34a853;--text-main:#202124;--text-muted:#5f6368;--border-color:#dadce0;--shadow-sm:0 1px 2px 0 #3c40434d, 0 1px 3px 1px #3c404326;--shadow-md:0 1px 2px 0 #3c40434d, 0 2px 6px 2px #3c404326;--shadow-lg:0 1px 3px 0 #3c40434d, 0 4px 8px 3px #3c404326;--border-radius:8px;--font-family:"Roboto", "Google Sans", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100vw;min-height:100vh;display:flex;overflow:auto}.card{background:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);padding:20px;transition:box-shadow .2s ease-in-out}.card:hover{box-shadow:var(--shadow-md)}.flex-row{flex-direction:row;display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.flex-1{flex:1}.text-primary{color:var(--primary)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-muted{color:var(--text-muted)}.bg-danger-light{background-color:#fce8e6}.bg-warning-light{background-color:#fef7e0}.bg-success-light{background-color:#e6f4ea}.bg-primary-light{background-color:#e8f0fe}.text-center{text-align:center}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-sm{font-size:14px}.text-xs{font-size:12px}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.w-full{width:100%}button{cursor:pointer;border:none;border-radius:4px;outline:none;justify-content:center;align-items:center;gap:8px;padding:10px 24px;font-family:inherit;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-sm);background-color:#1557b0}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{box-shadow:var(--shadow-sm);background-color:#c5221f}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover{box-shadow:var(--shadow-sm);background-color:#2d8a46}.btn-outline{color:var(--primary);border:1px solid var(--border-color);background-color:#0000}.btn-outline:hover{background-color:var(--bg-color)}.sidebar{background-color:var(--card-bg);border-right:1px solid var(--border-color);z-index:10;flex-direction:column;width:280px;padding:20px 0;display:flex}.sidebar-logo{color:var(--text-main);border-bottom:1px solid var(--border-color);align-items:center;gap:12px;margin-bottom:16px;padding:0 24px 20px;font-size:20px;font-weight:700;display:flex}.nav-item{color:var(--text-muted);cursor:pointer;align-items:center;gap:16px;padding:12px 24px;font-weight:500;transition:background .2s,color .2s;display:flex}.nav-item:hover{background-color:var(--bg-color);color:var(--text-main)}.nav-item.active{background-color:var(--bg-color);color:var(--primary);border-right:4px solid var(--primary)}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background-color:var(--card-bg);border-bottom:1px solid var(--border-color);z-index:5;justify-content:space-between;align-items:center;height:64px;min-height:64px;padding:0 24px;display:flex}.dashboard-container{flex-direction:column;flex:1;padding:24px;display:flex;overflow:hidden auto}.grid-cols-3{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.grid-cols-12{grid-template-columns:repeat(12,1fr);gap:24px;display:grid}.col-span-12{grid-column:span 12}.col-span-8{grid-column:span 8}.col-span-4{grid-column:span 4}.map-container{border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:#e3ead6;width:100%;height:450px;position:relative;overflow:hidden}.map-track{background-color:#bdbdbd;border-top:1px dashed #757575;border-bottom:1px dashed #757575;height:6px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.map-track-vertical{background-color:#bdbdbd;border-left:1px dashed #757575;border-right:1px dashed #757575;width:6px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.train-marker{color:#fff;width:36px;height:36px;box-shadow:var(--shadow-sm);z-index:2;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;transition:all 1s linear;display:flex;position:absolute;transform:translate(-50%,-50%)}.pulse{animation:2s infinite pulse}@keyframes pulse{0%{box-shadow:0 0 #ea4335b3}70%{box-shadow:0 0 0 15px #ea433500}to{box-shadow:0 0 #ea433500}}.alert-item{border-radius:var(--border-radius);border:1px solid var(--border-color);gap:12px;margin-bottom:12px;padding:16px;display:flex}.badge{text-transform:uppercase;border-radius:12px;padding:4px 8px;font-size:12px;font-weight:700}.badge-danger{color:var(--danger);background:#fce8e6}.badge-warning{color:var(--warning);background:#fef7e0}.badge-success{color:var(--success);background:#e6f4ea}.ai-log-item{border-bottom:1px solid var(--border-color);padding:12px 0;font-size:14px}.ai-log-item:last-child{border-bottom:none}.icon-box{border-radius:50%;justify-content:center;align-items:center;padding:12px;display:flex}.arch-container{justify-content:space-between;align-items:center;width:100%;max-width:900px;margin:40px auto;display:flex;position:relative}.arch-line{background-color:var(--primary);z-index:0;opacity:.2;height:4px;position:absolute;top:50%;left:50px;right:50px}.arch-node{border:2px solid var(--border-color);z-index:1;text-align:center;width:140px;box-shadow:var(--shadow-md);background:#fff;border-radius:12px;flex-direction:column;align-items:center;padding:16px;display:flex}.arch-node .icon{margin-bottom:12px}.arch-node .title{color:var(--text-main);font-size:14px;font-weight:700}.arch-node .sub{color:var(--text-muted);margin-top:4px;font-size:12px}.pf-root{color:#111827;-webkit-font-smoothing:antialiased;background:#fff;width:100%;font-family:-apple-system,Inter,Roboto,sans-serif;overflow-x:hidden}.pf-container{max-width:1160px;margin:0 auto;padding:0 32px}.pf-nav{z-index:100;border-bottom:1px solid #0000;transition:background .25s,border-color .25s,box-shadow .25s;position:fixed;inset:0 0 auto}.pf-nav--scrolled{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff0;border-bottom-color:#e5e7eb;box-shadow:0 1px 8px #0000000d}.pf-nav-inner{justify-content:space-between;align-items:center;max-width:1160px;height:68px;margin:0 auto;padding:0 32px;display:flex}.pf-logo{cursor:pointer;flex-shrink:0;align-items:center;gap:10px;text-decoration:none;display:flex}.pf-logo-icon{background:#2563eb;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.pf-logo-text{letter-spacing:-.4px;color:#111827;font-size:17px;font-weight:700}.pf-links{align-items:center;gap:2px;display:flex}.pf-link{color:#4b5563;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:14px;font-weight:500;transition:background .15s,color .15s}.pf-link:hover{color:#111827;background:#f3f4f6}.pf-nav-divider{background:#e5e7eb;width:1px;height:20px;margin:0 8px}.pf-nav-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#111827;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-size:14px;font-weight:600;transition:background .15s,transform .15s;display:inline-flex}.pf-nav-btn:hover{background:#1f2937;transform:translateY(-1px)}.pf-burger{color:#374151;cursor:pointer;background:0 0;border:none;padding:6px;display:none}.pf-hero{background:radial-gradient(80% 60% at 0 0,#2563eb0f 0%,#0000 60%),radial-gradient(60% 50% at 100% 100%,#7c3aed0d 0%,#0000 60%),#f9fafb;flex-direction:column;justify-content:center;align-items:stretch;min-height:100vh;padding:96px 0 72px;display:flex;position:relative;overflow:hidden}.pf-hero:before{content:"";z-index:0;pointer-events:none;background-image:linear-gradient(#0000000a 1px,#0000 1px),linear-gradient(90deg,#0000000a 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0}.pf-hero-inner{z-index:1;grid-template-columns:1fr 1fr;align-items:center;gap:64px;max-width:1160px;margin:0 auto;padding:0 32px;display:grid;position:relative}.pf-topbar{z-index:200;color:#065f46;white-space:nowrap;background:#fff;border:1px solid #d1fae5;border-radius:100px;align-items:center;gap:10px;padding:7px 18px;font-size:13px;font-weight:500;display:flex;position:fixed;top:76px;left:50%;transform:translate(-50%);box-shadow:0 2px 16px #00000014}.pf-topbar-dot{background:#16a34a;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s infinite pf-blink}@keyframes pf-blink{0%,to{opacity:1}50%{opacity:.25}}.pf-topbar-close{cursor:pointer;color:#6b7280;background:0 0;border:none;margin-left:4px;padding:0;display:flex}.pf-topbar-close:hover{color:#111827}.pf-eyebrow{color:#1d4ed8;letter-spacing:.3px;text-transform:uppercase;background:#eff6ff;border:1px solid #bfdbfe;border-radius:100px;align-items:center;gap:7px;margin-bottom:28px;padding:5px 14px;font-size:12px;font-weight:600;display:inline-flex}.pf-h1{letter-spacing:-2.5px;color:#0f172a;margin-bottom:20px;font-size:clamp(38px,5.5vw,68px);font-weight:800;line-height:1.07}.pf-h1-gradient{background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.pf-hero-sub{color:#4b5563;max-width:480px;margin-bottom:36px;font-size:17px;line-height:1.72}.pf-hero-btns{flex-wrap:wrap;gap:12px;margin-bottom:36px;display:flex}.pf-btn-primary{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:10px;align-items:center;gap:8px;padding:14px 28px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 1px 3px #2563eb4d,0 4px 16px #2563eb33}.pf-btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 2px 8px #2563eb66,0 8px 24px #2563eb40}.pf-btn-ghost{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:10px;align-items:center;gap:8px;padding:14px 24px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 1px 4px #0000000f}.pf-btn-ghost:hover{color:#2563eb;background:#eff6ff;border-color:#2563eb}.pf-trust-row{flex-wrap:wrap;align-items:center;gap:10px 18px;display:flex}.pf-trust-item{color:#6b7280;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.pf-trust-sep{background:#d1d5db;border-radius:50%;width:4px;height:4px}.pf-hero-visual{justify-content:center;align-items:center;display:flex}.pf-scroll-cue{z-index:1;color:#9ca3af;cursor:pointer;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.ls-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:100%;max-width:420px;padding:24px;box-shadow:0 4px 6px -1px #00000012,0 20px 60px -10px #00000014}.ls-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.ls-header-left{align-items:center;gap:7px;display:flex}.ls-live-dot{background:#16a34a;border-radius:50%;width:7px;height:7px;animation:2s infinite pf-blink}.ls-live-label{letter-spacing:1px;color:#6b7280;text-transform:uppercase;font-size:10px;font-weight:700}.ls-risk-badge{border-radius:100px;padding:4px 10px;font-size:12px;font-weight:700;transition:background .4s,color .4s}.ls-tracks{flex-direction:column;gap:20px;margin-bottom:16px;display:flex}.ls-track-row{align-items:center;gap:12px;display:flex}.ls-track-label{color:#9ca3af;flex-shrink:0;width:36px;font-size:11px;font-weight:600}.ls-track{flex:1;height:36px;position:relative}.ls-rail{background:#f3f4f6;border-radius:2px;height:2px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.ls-dot{border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #ffffffe6,0 2px 8px #00000026}.ls-dot-label{color:#fff;font-size:9px;font-weight:800}.ls-risk-bar-wrap{margin-bottom:14px}.ls-risk-bar-track{background:#f3f4f6;border-radius:4px;height:4px;overflow:hidden}.ls-risk-bar-fill{border-radius:4px;height:100%;transition:background .4s}.ls-log{background:#f9fafb;border-radius:8px;align-items:center;gap:7px;margin-bottom:16px;padding:10px 12px;font-size:12px;font-weight:500;line-height:1.4;transition:color .4s;display:flex}.ls-metrics{border-top:1px solid #f3f4f6;justify-content:space-around;align-items:center;padding-top:14px;display:flex}.ls-metric{text-align:center}.ls-metric-val{color:#0f172a;letter-spacing:-.5px;font-size:18px;font-weight:800;display:block}.ls-metric-key{color:#9ca3af;margin-top:2px;font-size:11px;font-weight:500}.ls-metric-div{background:#f3f4f6;width:1px;height:28px}.ls2-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:18px;width:100%;max-width:440px;padding:20px 20px 16px;transition:border-color .4s,box-shadow .4s;box-shadow:0 4px 6px -1px #0000000f,0 24px 64px -12px #0000001a}.ls2-card--warning{border-color:#fde68a;box-shadow:0 4px 6px -1px #d9770614,0 24px 64px -12px #d977061f}.ls2-card--critical{border-color:#fca5a5;box-shadow:0 4px 6px -1px #dc26261a,0 24px 64px -12px #dc262624}.ls2-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.ls2-header-left{align-items:center;gap:7px;display:flex}.ls2-live-dot{background:#16a34a;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.8s infinite pf-blink}.ls2-live-label{letter-spacing:1.2px;color:#6b7280;text-transform:uppercase;font-size:9.5px;font-weight:800}.ls2-risk-pill{border-radius:100px;padding:4px 12px;font-size:11px;font-weight:700;transition:background .4s,color .4s,border .4s}.ls2-map{flex-direction:column;gap:16px;margin-bottom:14px;display:flex}.ls2-line-row{align-items:center;gap:10px;display:flex}.ls2-line-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;width:18px;font-size:10px;font-weight:700}.ls2-track-area{flex:1;height:44px;position:relative}.ls2-rail-outer{flex-direction:column;gap:2px;display:flex;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.ls2-rail-top,.ls2-rail-bottom{background:#d1d5db;border-radius:2px;height:2.5px}.ls2-rail-sleepers{justify-content:space-between;padding:0 2px;display:flex}.ls2-sleeper{background:#e5e7eb;border-radius:1px;width:5px;height:5px}.ls2-station{z-index:1;pointer-events:none;flex-direction:column;align-items:center;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%)}.ls2-station-dot{z-index:1;background:#fff;border:1.5px solid #9ca3af;border-radius:50%;width:6px;height:6px;margin-bottom:0}.ls2-station-name{color:#9ca3af;white-space:nowrap;letter-spacing:.2px;margin-top:14px;font-size:7.5px;font-weight:600}.ls2-train{z-index:3;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;transition:box-shadow .3s;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%)}.ls2-train-id{color:#fff;letter-spacing:0;font-size:9px;font-weight:900}.ls2-train--braking{animation:.35s infinite alternate ls2-brake-flash}@keyframes ls2-brake-flash{0%{opacity:1}to{opacity:.65}}.ls2-brake-ring{opacity:.55;border:1.5px solid;border-radius:10px;animation:.6s ease-out infinite ls2-ring-pulse;position:absolute;inset:-5px}@keyframes ls2-ring-pulse{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.4)}}.ls2-gap-zone{z-index:2;pointer-events:none;border-radius:4px;height:10px;position:absolute;top:50%;transform:translateY(-50%)}.ls2-gap-zone--warning{background:#d977061f}.ls2-gap-zone--critical{background:#dc262626;animation:.5s infinite ls2-gap-blink}@keyframes ls2-gap-blink{0%,to{opacity:1}50%{opacity:.3}}.ls2-risk-bar-wrap{margin-bottom:12px}.ls2-risk-bar-labels{color:#9ca3af;justify-content:space-between;margin-bottom:5px;font-size:10px;font-weight:500;display:flex}.ls2-risk-track{background:#f3f4f6;border-radius:5px;height:5px;overflow:hidden}.ls2-risk-fill{border-radius:5px;height:100%}.ls2-telemetry{background:#f9fafb;border-radius:10px;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;padding:10px;display:grid}.ls2-telem-item{flex-direction:column;gap:3px;display:flex}.ls2-telem-head{align-items:center;gap:4px;display:flex}.ls2-telem-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.ls2-telem-label{color:#6b7280;text-transform:uppercase;letter-spacing:.4px;font-size:9px;font-weight:700}.ls2-brk-tag{color:#dc2626;letter-spacing:.3px;background:#fef2f2;border:1px solid #fca5a5;border-radius:3px;padding:0 3px;font-size:7.5px;font-weight:800;animation:.4s infinite alternate ls2-brake-flash}.ls2-telem-km{color:#0f172a;letter-spacing:-.5px;font-size:13px;font-weight:800;line-height:1}.ls2-telem-km span{color:#9ca3af;margin-left:1px;font-size:8px;font-weight:500}.ls2-sbar-track{background:#e5e7eb;border-radius:3px;height:3px;overflow:hidden}.ls2-sbar-fill{border-radius:3px;height:100%}.ls2-events{margin-bottom:12px;overflow:hidden}.ls2-event{border-radius:7px;align-items:center;gap:6px;margin-bottom:3px;padding:6px 10px;font-size:10.5px;font-weight:500;display:flex;overflow:hidden}.ls2-event--ok{color:#166534;background:#f0fdf4}.ls2-event--warn{color:#92400e;background:#fffbeb}.ls2-event--danger{color:#991b1b;background:#fef2f2}.ls2-metrics{border-top:1px solid #f3f4f6;justify-content:space-around;align-items:center;padding-top:12px;display:flex}.ls2-metric{text-align:center}.ls2-metric-val{color:#0f172a;letter-spacing:-.5px;font-size:17px;font-weight:800;line-height:1.1;display:block}.ls2-metric-val small{letter-spacing:0;color:#9ca3af;font-size:9px;font-weight:600}.ls2-metric-key{color:#9ca3af;margin-top:2px;font-size:10px;font-weight:500}.ls2-metric-div{background:#f3f4f6;width:1px;height:28px}.pf-stats{background:#fff;border-top:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6;padding:48px 0}.pf-stats-grid{grid-template-columns:repeat(4,1fr);gap:2px;display:grid}.st-item{text-align:center;border-right:1px solid #f3f4f6;padding:24px 32px}.st-item:last-child{border-right:none}.st-icon{justify-content:center;margin-bottom:10px;display:flex}.st-num{letter-spacing:-2px;margin-bottom:6px;font-size:44px;font-weight:800;line-height:1}.st-label{color:#6b7280;font-size:13px;font-weight:500}.pf-section{background:#fff;padding:96px 0}.pf-section--alt{background:#f9fafb}.pf-tech-band{background:#fff}.pf-section-hd{text-align:center;margin-bottom:64px}.pf-tag{color:#2563eb;letter-spacing:.5px;text-transform:uppercase;background:#eff6ff;border:1px solid #dbeafe;border-radius:100px;margin-bottom:18px;padding:4px 14px;font-size:12px;font-weight:600;display:inline-block}.pf-tag--white{color:#fff;background:#ffffff26;border-color:#ffffff40}.pf-h2{letter-spacing:-1.5px;color:#0f172a;margin-bottom:14px;font-size:clamp(26px,4vw,42px);font-weight:800;line-height:1.15}.pf-gradient-text{background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.pf-section-sub{color:#6b7280;max-width:500px;margin:0 auto;font-size:16px;line-height:1.7}.pf-feat-grid{background:#e5e7eb;border:1px solid #e5e7eb;border-radius:16px;grid-template-columns:repeat(3,1fr);gap:1px;display:grid;overflow:hidden}.fc-card{cursor:default;background:#fff;padding:32px 28px 28px;transition:background .2s;position:relative}.fc-card:hover{background:#fafafa}.fc-icon-wrap{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:18px;display:flex}.fc-title{color:#0f172a;letter-spacing:-.3px;margin-bottom:10px;font-size:16px;font-weight:700}.fc-desc{color:#6b7280;font-size:14px;line-height:1.68}.fc-arrow{color:#d1d5db;transition:color .2s,transform .2s;position:absolute;bottom:24px;right:24px}.fc-card:hover .fc-arrow{color:#2563eb;transform:translate(2px,-2px)}.pf-steps-grid{grid-template-columns:repeat(2,1fr);gap:16px;max-width:860px;margin:0 auto;display:grid}.step-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;align-items:flex-start;gap:18px;padding:28px 24px;transition:border-color .2s,box-shadow .2s;display:flex}.step-card:hover{border-color:#bfdbfe;box-shadow:0 4px 20px #2563eb14}.step-num{letter-spacing:-.5px;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:800;display:flex}.step-icon{margin-bottom:8px}.step-title{color:#0f172a;letter-spacing:-.2px;margin-bottom:8px;font-size:15px;font-weight:700}.step-desc{color:#6b7280;font-size:13.5px;line-height:1.65}.pf-tech-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.tp-pill{cursor:default;background:#fff;border:1px solid #e5e7eb;border-radius:12px;align-items:center;gap:12px;padding:16px 20px;transition:border-color .2s,box-shadow .2s;display:flex}.tp-pill:hover{box-shadow:0 2px 12px #00000012}.tp-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.tp-label{letter-spacing:-.2px;font-size:14px;font-weight:700}.tp-sub{color:#9ca3af;margin-top:1px;font-size:12px}.pf-tm-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.tm-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:28px 24px;transition:border-color .2s,box-shadow .2s}.tm-card:hover{border-color:#bfdbfe;box-shadow:0 4px 20px #2563eb12}.tm-stars{gap:3px;margin-bottom:16px;display:flex}.tm-quote{color:#374151;margin-bottom:22px;font-size:14.5px;font-style:italic;line-height:1.7}.tm-author{align-items:center;gap:12px;display:flex}.tm-avatar{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:13px;font-weight:800;display:flex}.tm-name{color:#0f172a;font-size:14px;font-weight:700}.tm-role{color:#9ca3af;margin-top:2px;font-size:12px}.pf-cta{background:linear-gradient(135deg,#fff 0%,#f1f5f9 100%);border-top:1px solid #e2e8f0;padding:96px 0;position:relative;overflow:hidden}.pf-cta:before{content:"";pointer-events:none;background:radial-gradient(circle,#2563eb14 0%,#0000 70%);border-radius:50%;width:800px;height:800px;position:absolute;top:-300px;right:-100px}.pf-cta:after{content:"";pointer-events:none;background:radial-gradient(circle,#7c3aed0d 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;bottom:-200px;left:-100px}.pf-cta-inner{text-align:center;z-index:1;max-width:620px;margin:0 auto;padding:0 32px;position:relative}.pf-cta-h2{letter-spacing:-2px;color:#0f172a;margin-bottom:16px;font-size:clamp(28px,4.5vw,52px);font-weight:800;line-height:1.1}.pf-cta-sub{color:#4b5563;margin-bottom:36px;font-size:17px;line-height:1.65}.pf-cta-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;align-items:center;gap:10px;padding:16px 32px;font-size:16px;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 14px #2563eb40}.pf-cta-btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 6px 20px #2563eb59}.pf-footer{background:#f8fafc;border-top:1px solid #e2e8f0;padding:56px 0 28px}.pf-footer-top{flex-wrap:wrap;gap:60px;margin-bottom:48px;display:flex}.pf-footer-brand{flex:0 0 240px}.pf-footer-brand .pf-logo-text{color:#0f172a}.pf-footer-tagline{color:#4b5563;margin:12px 0 20px;font-size:13px;line-height:1.5}.pf-footer-socials{gap:8px;display:flex}.pf-social{color:#64748b;background:#fff;border:1px solid #cbd5e1;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;text-decoration:none;transition:all .2s;display:flex}.pf-social:hover{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.pf-footer-links{flex-wrap:wrap;flex:1;gap:48px;display:flex}.pf-footer-col{flex-direction:column;gap:12px;min-width:110px;display:flex}.pf-footer-col-hd{text-transform:uppercase;letter-spacing:.6px;color:#0f172a;margin-bottom:4px;font-size:12px;font-weight:700}.pf-footer-link{color:#4b5563;font-size:14px;text-decoration:none;transition:color .15s}.pf-footer-link:hover{color:#2563eb}.pf-footer-bottom{color:#64748b;border-top:1px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-top:24px;font-size:13px;display:flex}.pf-footer-legal{gap:20px;display:flex}.pf-footer-legal a{color:#64748b;text-decoration:none;transition:color .15s}.pf-footer-legal a:hover{color:#2563eb}@media (width<=1024px){.pf-feat-grid{grid-template-columns:repeat(2,1fr)}.pf-tech-grid{grid-template-columns:repeat(3,1fr)}.pf-stats-grid{grid-template-columns:repeat(2,1fr)}.st-item{border-bottom:1px solid #f3f4f6;border-right:none}.st-item:nth-child(2n){border-bottom:1px solid #f3f4f6}.st-item:last-child,.st-item:nth-last-child(2){border-bottom:none}}@media (width<=768px){.pf-nav-inner{padding:0 20px}.pf-links{z-index:99;background:#fff;border-top:1px solid #e5e7eb;flex-direction:column;gap:4px;padding:24px 20px;display:none;position:fixed;inset:68px 0 0}.pf-links--open,.pf-burger{display:flex}.pf-hero-inner{grid-template-columns:1fr;gap:40px;padding:0 20px}.pf-hero-visual{display:none}.pf-container{padding:0 20px}.pf-feat-grid,.pf-steps-grid{grid-template-columns:1fr}.pf-tech-grid{grid-template-columns:repeat(2,1fr)}.pf-tm-grid{grid-template-columns:1fr}.pf-stats-grid{grid-template-columns:1fr 1fr}.pf-footer-top{flex-direction:column;gap:36px}.pf-footer-brand{flex:auto}.pf-footer-links{gap:28px}}.hp-page{color:#111827;background-color:#fff;width:100%;font-family:Roboto,Inter,sans-serif;overflow-x:hidden}.hp-navbar{z-index:100;background:#fff0;padding:0 24px;transition:background .3s,box-shadow .3s;position:fixed;top:0;left:0;right:0}.hp-navbar-scrolled{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffeb;box-shadow:0 1px #e5e7eb,0 4px 24px #0000000f}.hp-navbar-inner{justify-content:space-between;align-items:center;max-width:1200px;height:72px;margin:0 auto;display:flex}.hp-nav-logo{cursor:pointer;color:#111827;letter-spacing:-.5px;align-items:center;gap:10px;font-size:22px;font-weight:800;display:flex}.hp-nav-links{align-items:center;gap:4px;display:flex}.hp-nav-link{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.hp-nav-link:hover{color:#111827;background:#f3f4f6}.hp-nav-cta{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:50px;align-items:center;gap:8px;margin-left:12px;padding:10px 22px;font-size:14px;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 2px 12px #1a73e840}.hp-nav-cta:hover{background:#1557b0;transform:translateY(-1px);box-shadow:0 4px 20px #1a73e866}.hp-hamburger{color:#111827;cursor:pointer;background:0 0;border:none;padding:8px;display:none}.hp-hero{background:linear-gradient(160deg,#f0f7ff 0%,#fff 40%,#f5f3ff 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:100px 24px 80px;display:flex;position:relative;overflow:hidden}.hp-hero-bg{opacity:.04;z-index:0;background:url(/hero_bg.png) 50%/cover no-repeat;position:absolute;inset:0}.hp-hero-overlay{z-index:1;background:radial-gradient(70% 50% at 10% 20%,#1a73e814,#0000 60%),radial-gradient(50% 40% at 90% 80%,#6366f112,#0000 60%);position:absolute;inset:0}.hp-hero:before{content:"";z-index:0;background:radial-gradient(circle,#1a73e81a,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-100px;left:-100px}.hp-hero:after{content:"";z-index:0;background:radial-gradient(circle,#6366f11a,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-80px;right:-80px}.hp-hero-content{z-index:2;grid-template-columns:1fr 1fr;align-items:center;gap:60px;width:100%;max-width:1200px;margin:0 auto;display:grid;position:relative}.hp-hero-badge{color:#1d4ed8;text-transform:uppercase;letter-spacing:.5px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:50px;align-items:center;gap:8px;margin-bottom:24px;padding:6px 16px;font-size:12px;font-weight:600;display:inline-flex}.hp-hero-title{letter-spacing:-2px;color:#0f172a;margin-bottom:24px;font-size:clamp(36px,5vw,64px);font-weight:900;line-height:1.08}.hp-hero-gradient{background:linear-gradient(135deg,#1a73e8,#6366f1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hp-hero-subtitle{color:#4b5563;max-width:500px;margin-bottom:36px;font-size:18px;line-height:1.7}.hp-hero-actions{flex-wrap:wrap;gap:16px;margin-bottom:32px;display:flex}.hp-btn-primary{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:50px;align-items:center;gap:10px;padding:16px 32px;font-size:16px;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 20px #1a73e859}.hp-btn-primary:hover{background:#1557b0;transform:translateY(-2px);box-shadow:0 8px 32px #1a73e873}.hp-btn-large{padding:18px 44px;font-size:17px}.hp-btn-secondary{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:50px;align-items:center;gap:8px;padding:16px 28px;font-size:16px;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 1px 4px #0000000f}.hp-btn-secondary:hover{color:#1a73e8;background:#f0f7ff;border-color:#1a73e8}.hp-hero-trust{color:#6b7280;flex-wrap:wrap;align-items:center;gap:12px;font-size:13px;display:flex}.hp-trust-divider{color:#d1d5db}.hp-hero-right{justify-content:center;align-items:center;display:flex}.hp-floating-alert{z-index:200;color:#374151;background:#fff;border:1px solid #bfdbfe;border-radius:50px;align-items:center;gap:10px;padding:8px 20px;font-size:13px;display:flex;position:fixed;top:84px;left:50%;box-shadow:0 4px 24px #1a73e81f}.hp-alert-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.hp-alert-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;margin-left:4px;padding:2px;display:flex}.hp-alert-close:hover{color:#374151}.hp-scroll-cue{z-index:2;color:#9ca3af;cursor:pointer;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.hp-mini-sim{background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;width:100%;max-width:440px;padding:28px;box-shadow:0 20px 60px #00000014,0 4px 16px #1a73e814}.hp-mini-sim-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.hp-sim-badge{color:#1a73e8;letter-spacing:1px;text-transform:uppercase;background:#eff6ff;border:1px solid #bfdbfe;border-radius:50px;padding:4px 10px;font-size:11px;font-weight:700}.hp-mini-track{height:40px;margin-bottom:8px;position:relative}.hp-track-line{background:#e5e7eb;border-radius:2px;height:3px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.hp-mini-train{border-radius:50%;width:18px;height:18px;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 0 8px #0003}.hp-ai-status{color:#6b7280;border-top:1px solid #f3f4f6;align-items:center;gap:8px;margin-top:20px;padding-top:16px;font-size:12px;display:flex}.hp-ai-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s infinite pulse-dot}.hp-stats-section{background:#f8faff;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;padding:60px 24px}.hp-section-inner{max-width:1200px;margin:0 auto}.hp-stats-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.hp-stat-card{text-align:center;background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:32px 24px;transition:all .3s;box-shadow:0 2px 8px #0000000a}.hp-stat-card:hover{border-color:#1a73e8;transform:translateY(-4px);box-shadow:0 12px 32px #1a73e81f}.hp-stat-number{letter-spacing:-2px;margin:8px 0 4px;font-size:48px;font-weight:900;line-height:1}.hp-stat-label{color:#6b7280;font-size:13px;font-weight:500}.hp-features-section,.hp-hiw-section,.hp-tech-section,.hp-testimonials-section{padding:100px 24px}.hp-section-header{text-align:center;margin-bottom:64px}.hp-section-badge{color:#1d4ed8;text-transform:uppercase;letter-spacing:1px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:50px;margin-bottom:20px;padding:6px 18px;font-size:12px;font-weight:600;display:inline-block}.hp-section-title{letter-spacing:-1.5px;color:#0f172a;margin-bottom:16px;font-size:clamp(28px,4vw,44px);font-weight:800;line-height:1.15}.hp-text-glow{background:linear-gradient(135deg,#1a73e8,#6366f1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hp-section-sub{color:#6b7280;max-width:520px;margin:0 auto;font-size:17px;line-height:1.7}.hp-features-section{background:#fff}.hp-features-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.hp-feature-card{cursor:default;background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;padding:32px 28px;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000008}.hp-feature-card:hover{border-color:#1a73e8;transform:translateY(-4px);box-shadow:0 16px 48px #1a73e81a}.hp-feature-icon{border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:20px;display:flex}.hp-feature-title{color:#0f172a;margin-bottom:12px;font-size:18px;font-weight:700}.hp-feature-desc{color:#6b7280;font-size:14px;line-height:1.7}.hp-feature-bar{opacity:0;border-radius:0 0 20px 20px;height:3px;transition:opacity .3s;position:absolute;bottom:0;left:0;right:0}.hp-feature-card:hover .hp-feature-bar{opacity:1}.hp-hiw-section{background:#f8faff}.hp-hiw-grid{grid-template-columns:repeat(2,1fr);gap:32px;max-width:900px;margin:0 auto;display:grid}.hp-hiw-step{background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;align-items:flex-start;gap:20px;padding:28px;transition:all .3s;display:flex;box-shadow:0 2px 8px #0000000a}.hp-hiw-step:hover{border-color:#1a73e8;transform:translateY(-3px);box-shadow:0 8px 28px #1a73e81a}.hp-hiw-number{border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:40px;min-width:40px;height:40px;font-size:16px;font-weight:800;display:flex}.hp-hiw-icon{margin-bottom:8px}.hp-hiw-title{color:#0f172a;margin-bottom:8px;font-size:17px;font-weight:700}.hp-hiw-desc{color:#6b7280;font-size:14px;line-height:1.6}.hp-tech-section{background:#fff}.hp-tech-grid{grid-template-columns:repeat(6,1fr);gap:16px;display:grid}.hp-tech-card{text-align:center;cursor:default;background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:24px 16px;transition:all .3s;box-shadow:0 2px 8px #00000008}.hp-tech-card:hover{border-color:#1a73e8;transform:translateY(-4px);box-shadow:0 8px 24px #1a73e81a}.hp-tech-emoji{margin-bottom:10px;font-size:32px}.hp-tech-name{color:#0f172a;margin-bottom:4px;font-size:14px;font-weight:700}.hp-tech-sub{color:#9ca3af;font-size:11px}.hp-testimonials-section{background:#f8faff}.hp-testimonials-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.hp-testimonial-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;padding:28px;transition:all .3s;box-shadow:0 2px 8px #0000000a}.hp-testimonial-card:hover{border-color:#1a73e8;transform:translateY(-4px);box-shadow:0 12px 36px #1a73e81a}.hp-testimonial-stars{gap:4px;margin-bottom:16px;display:flex}.hp-testimonial-quote{color:#374151;margin-bottom:24px;font-size:15px;font-style:italic;line-height:1.7}.hp-testimonial-author{align-items:center;gap:14px;display:flex}.hp-testimonial-avatar{color:#fff;background:linear-gradient(135deg,#1a73e8,#6366f1);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:14px;font-weight:800;display:flex}.hp-testimonial-name{color:#0f172a;font-size:15px;font-weight:700}.hp-testimonial-role{color:#6b7280;margin-top:2px;font-size:12px}.hp-cta-section{background:linear-gradient(135deg,#1a73e8 0%,#6366f1 100%);padding:100px 24px;position:relative;overflow:hidden}.hp-cta-section:before{content:"";background:#ffffff0f;border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-100px}.hp-cta-section:after{content:"";background:#ffffff0d;border-radius:50%;width:400px;height:400px;position:absolute;bottom:-150px;left:-80px}.hp-cta-inner{text-align:center;z-index:1;max-width:700px;margin:0 auto;position:relative}.hp-cta-glow{display:none}.hp-cta-title{letter-spacing:-2px;color:#fff;margin-bottom:20px;font-size:clamp(32px,5vw,52px);font-weight:900;line-height:1.1}.hp-cta-sub{color:#ffffffbf;margin-bottom:40px;font-size:18px;line-height:1.6}.hp-cta-section .hp-btn-primary{color:#1a73e8;background:#fff;box-shadow:0 8px 32px #0003}.hp-cta-section .hp-btn-primary:hover{background:#f0f7ff;transform:translateY(-2px);box-shadow:0 12px 40px #0000004d}.hp-footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:60px 24px 24px}.hp-footer-inner{flex-wrap:wrap;gap:60px;max-width:1200px;margin:0 auto 48px;display:flex}.hp-footer-brand{flex:1;min-width:200px}.hp-footer-logo{color:#0f172a;align-items:center;gap:10px;margin-bottom:12px;font-size:20px;font-weight:800;display:flex}.hp-footer-tagline{color:#6b7280;margin-bottom:24px;font-size:14px}.hp-footer-socials{gap:12px;display:flex}.hp-social-icon{color:#6b7280;background:#fff;border:1.5px solid #e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;text-decoration:none;transition:all .2s;display:flex}.hp-social-icon:hover{color:#1a73e8;background:#eff6ff;border-color:#1a73e8}.hp-footer-links{flex-wrap:wrap;gap:60px;display:flex}.hp-footer-col{flex-direction:column;gap:12px;min-width:120px;display:flex}.hp-footer-col-title{color:#374151;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:13px;font-weight:700}.hp-footer-link{color:#6b7280;font-size:14px;text-decoration:none;transition:color .2s}.hp-footer-link:hover{color:#1a73e8}.hp-footer-bottom{color:#9ca3af;border-top:1px solid #e5e7eb;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1200px;margin:0 auto;padding-top:24px;font-size:13px;display:flex}.hp-footer-bottom-links{gap:20px;display:flex}.hp-footer-bottom-links a{color:#9ca3af;text-decoration:none;transition:color .2s}.hp-footer-bottom-links a:hover{color:#1a73e8}@media (width<=1024px){.hp-stats-grid,.hp-features-grid{grid-template-columns:repeat(2,1fr)}.hp-tech-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.hp-hero-content{grid-template-columns:1fr;gap:40px}.hp-hero-right,.hp-nav-links{display:none}.hp-nav-links.open{z-index:99;background:#fffffffa;border-bottom:1px solid #e5e7eb;flex-direction:column;gap:4px;padding:16px 24px;display:flex;position:fixed;top:72px;left:0;right:0;box-shadow:0 8px 24px #00000014}.hp-hamburger{display:flex}.hp-stats-grid{grid-template-columns:repeat(2,1fr)}.hp-features-grid,.hp-hiw-grid{grid-template-columns:1fr}.hp-tech-grid{grid-template-columns:repeat(2,1fr)}.hp-testimonials-grid{grid-template-columns:1fr}.hp-footer-inner{flex-direction:column;gap:40px}.hp-footer-links{gap:32px}}.rtc-panel{color:#1e293b;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:14px;width:100%;padding:18px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;box-shadow:0 10px 40px #0000000d,0 2px 10px #00000005}.rtc-topbar{color:#64748b;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding-bottom:10px;font-size:11px;display:flex}.rtc-topbar-left{align-items:center;gap:8px;display:flex}.rtc-live-beacon{background:#22c55e;border-radius:50%;flex-shrink:0;width:8px;height:8px}.rtc-live-beacon--danger{background:#ef4444;animation:1s infinite alternate rtc-flash}.rtc-live-beacon--warning{background:#eab308;animation:1s infinite alternate rtc-flash}.rtc-live-beacon--caution{background:#f97316}.rtc-live-beacon--clear{background:#22c55e}@keyframes rtc-flash{0%{opacity:1}to{opacity:.35}}.rtc-topbar-title{color:#0f172a;letter-spacing:.5px;font-weight:700}.rtc-topbar-sep{color:#cbd5e1}.rtc-topbar-sub{color:#64748b;font-weight:500}.rtc-topbar-right{align-items:center;gap:10px;font-family:monospace;display:flex}.rtc-topbar-clock{color:#0f172a}.rtc-topbar-uptime{color:#64748b}.rtc-status-strip{border:1px solid #0000;border-radius:6px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:11px;display:flex}.rtc-status-left{align-items:center;gap:12px;display:flex}.rtc-status-phase{letter-spacing:.5px;font-weight:800}.rtc-status-guardian{align-items:center;gap:5px;font-weight:700;display:flex}.rtc-status-right{align-items:center;gap:8px;display:flex}.rtc-status-risk-label{color:#64748b;font-weight:600}.rtc-mini-risk-bar{background:#e2e8f0;border-radius:3px;width:80px;height:5px;overflow:hidden}.rtc-mini-risk-fill{border-radius:3px;height:100%}.rtc-status-risk-val{text-align:right;min-width:32px;font-family:monospace;font-weight:800}.rtc-schematic{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:20px;padding:16px 12px;display:flex}.rtc-track-row{align-items:center;gap:16px;display:flex}.rtc-track-label{flex-direction:column;flex-shrink:0;gap:2px;width:90px;display:flex}.rtc-track-id{color:#1e293b;font-size:12px;font-weight:800}.rtc-track-name{color:#64748b;font-size:9.5px;font-weight:500}.rtc-track-canvas{flex:1;height:56px;position:relative}.rtc-km-mark{flex-direction:column;align-items:center;display:flex;position:absolute;bottom:0;transform:translate(-50%)}.rtc-km-tick{background:#cbd5e1;width:1px;height:5px}.rtc-km-num{color:#64748b;margin-top:2px;font-family:monospace;font-size:8px}.rtc-trackbed{pointer-events:none;flex-direction:column;justify-content:space-between;height:14px;display:flex;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.rtc-rail{background:#94a3b8;width:100%;height:2px}.rtc-rail--top,.rtc-rail--bot{border-radius:1px}.rtc-ballast{z-index:1;justify-content:space-between;padding:0 4px;display:flex;position:absolute;inset:0}.rtc-tie{background:#e2e8f0;width:1.5px;height:100%}.rtc-signal{z-index:4;flex-direction:column;align-items:center;display:flex;position:absolute;bottom:calc(50% + 5px);transform:translate(-50%)}.rtc-signal-post{background:#94a3b8;width:2px;height:14px}.rtc-signal-head{border-radius:50%;width:6px;height:6px}.rtc-station{z-index:3;flex-direction:column;align-items:center;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%)}.rtc-station-platform{background:#fff;border:1.5px solid #94a3b8;border-radius:2px;width:8px;height:18px}.rtc-station-id{color:#64748b;margin-top:3px;font-family:monospace;font-size:8px;font-weight:700}.rtc-gap-zone{z-index:2;border-radius:4px;height:10px;position:absolute;top:50%;transform:translateY(-50%)}.rtc-gap-zone--warning{background:#f59e0b14;border:1px dashed #f59e0b40}.rtc-gap-zone--danger{background:#ef44441a;border:1px dashed #ef444459}.rtc-gap-zone--caution{background:#f973160f;border:1px dashed #f9731633}.rtc-train{z-index:5;position:absolute;top:50%;transform:translate(-50%,-50%)}.rtc-train-body{border:1.5px solid #fff;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;display:flex;box-shadow:0 2px 8px #0003}.rtc-train-tag{color:#0f172a;white-space:nowrap;pointer-events:none;background:#fffffff5;border:1px solid #cbd5e1;border-radius:4px;flex-direction:column;align-items:center;padding:3px 6px;font-size:9px;display:flex;position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000014}.rtc-train-id{font-weight:700}.rtc-train-speed{color:#475569;margin-top:1px;font-family:monospace}.rtc-train-dwell{color:#ef4444;font-weight:700;animation:.5s infinite alternate rtc-flash}.rtc-ebrake-ring{pointer-events:none;border:2px solid;border-radius:50%;position:absolute;inset:-8px}.rtc-train-station-label{color:#475569;white-space:nowrap;pointer-events:none;font-size:8.5px;font-weight:600;position:absolute;top:calc(100% + 5px);left:50%;transform:translate(-50%)}.rtc-bottom-grid{grid-template-columns:1.2fr 1fr;gap:14px;display:grid}.rtc-gauges{flex-direction:column;gap:10px;display:flex}.rtc-gauge{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.rtc-gauge-header{color:#475569;align-items:center;gap:8px;font-size:11px;font-weight:600;display:flex}.rtc-gauge-dot{border-radius:50%;width:8px;height:8px}.rtc-gauge-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.rtc-badge{letter-spacing:.5px;border-radius:3px;padding:2px 5px;font-size:8.5px;font-weight:800;line-height:1}.rtc-badge--danger{color:#ef4444;background:#fee2e2;border:1px solid #fca5a5;animation:.4s infinite alternate rtc-flash}.rtc-badge--warn{color:#d97706;background:#fef3c7;border:1px solid #fde047}.rtc-gauge-value{align-items:baseline;gap:3px;display:flex}.rtc-gauge-num{color:#0f172a;font-family:monospace;font-size:22px;font-weight:700;line-height:1}.rtc-gauge-unit{color:#64748b;font-size:10px;font-weight:500}.rtc-gauge-bar-wrap{width:100%}.rtc-gauge-bar-bg{background:#e2e8f0;border-radius:3px;height:5px;position:relative;overflow:hidden}.rtc-gauge-bar-fill{border-radius:3px;height:100%}.rtc-gauge-bar-marks{color:#64748b;justify-content:space-between;margin-top:4px;font-family:monospace;font-size:8px;display:flex}.rtc-eventlog{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:10px;height:180px;padding:12px;display:flex}.rtc-eventlog-header{color:#64748b;letter-spacing:.5px;align-items:center;gap:8px;font-size:10.5px;font-weight:700;display:flex}.rtc-eventlog-list{flex-direction:column;flex:1;gap:5px;padding-right:2px;display:flex;overflow-y:auto}.rtc-eventlog-list::-webkit-scrollbar{width:4px}.rtc-eventlog-list::-webkit-scrollbar-track{background:0 0}.rtc-eventlog-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.rtc-evt{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #64748b;border-radius:4px;align-items:flex-start;gap:8px;padding:6px 8px;font-size:10.5px;line-height:1.3;display:flex}.rtc-evt--sys{color:#2563eb;border-left-color:#3b82f6}.rtc-evt--ok{color:#16a34a;border-left-color:#22c55e}.rtc-evt--caution{color:#ea580c;border-left-color:#f97316}.rtc-evt--warn{color:#d97706;border-left-color:#eab308}.rtc-evt--danger{color:#dc2626;border-left-color:#ef4444;animation:2s infinite alternate rtc-pulse-bg}@keyframes rtc-pulse-bg{0%{background:#ef444405}to{background:#ef444414}}.rtc-evt-time{color:#94a3b8;flex-shrink:0;margin-top:1px;font-family:monospace}.rtc-evt-code{color:#64748b;flex-shrink:0;margin-top:1px;font-family:monospace;font-weight:700}.rtc-evt-msg{color:#1e293b;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rtc-footer{color:#64748b;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding-top:10px;font-size:10px;display:flex}.rtc-foot-item{align-items:center;gap:5px;display:flex}.rtc-foot-item strong{color:#1e293b}.rtc-foot-sep{background:#e2e8f0;width:1px;height:10px}@media (width<=768px){.rtc-bottom-grid{grid-template-columns:1fr}}.weather-widget{background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;justify-content:space-between;align-items:center;padding:16px;display:flex}.weather-icon-box{background:var(--primary-light);width:48px;height:48px;color:var(--primary);border-radius:8px;justify-content:center;align-items:center;display:flex}.weather-info{flex:1;margin-left:12px}.weather-info h4{color:var(--text-main);margin-bottom:2px;font-size:14px;font-weight:700}.weather-info p{color:var(--text-muted);font-size:12px}.cctv-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.cctv-feed{aspect-ratio:16/9;background:#000;border-radius:6px;position:relative;overflow:hidden}.cctv-feed img{object-fit:cover;opacity:.6;filter:grayscale(80%)contrast(120%);width:100%;height:100%}.cctv-overlay{background:#0009;border-radius:4px;align-items:center;gap:6px;padding:4px 8px;display:flex;position:absolute;top:8px;left:8px}.cctv-dot{background:#ef4444;border-radius:50%;width:6px;height:6px;animation:1s infinite alternate pulse-dot}.cctv-label{color:#fff;letter-spacing:.5px;font-family:monospace;font-size:10px;font-weight:700}.chart-container{align-items:flex-end;gap:8px;height:160px;padding-top:20px;display:flex}.chart-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.chart-bar{background:var(--primary);border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:height .5s}.chart-label{color:var(--text-muted);margin-top:6px;font-family:monospace;font-size:10px}
