*{box-sizing:border-box}body{color:#18202a;background:#f5f7fb;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}a{color:inherit;text-decoration:none}#root,.app-shell{min-height:100vh}.topbar{background:#fff;border-bottom:1px solid #e7edf5}.topbar-inner{justify-content:space-between;align-items:center;gap:12px 20px;max-width:1120px;min-height:52px;margin:0 auto;padding:0 16px;display:flex}.brand{letter-spacing:-.02em;color:#0f172a;flex-shrink:0;font-size:1.0625rem;font-weight:700}a.brand:hover{color:#1e40af}.topbar-nav{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.topbar-link{color:#3d4f64;background:#f1f5f9;border:1px solid #d7e0ec;border-radius:999px;justify-content:center;align-items:center;padding:7px 16px;font-size:14px;font-weight:500;transition:background .16s,border-color .16s,color .16s;display:inline-flex}.topbar-link:hover{color:#1d4ed8;background:#e8f0ff;border-color:#93b4f0}.topbar-link--active{color:#1d4ed8;background:#eff6ff;border-color:#3b82f6;font-weight:600;box-shadow:0 0 0 1px #2563eb1f}.page-wrap{max-width:1120px;margin:0 auto;padding:24px 16px 40px}.card{background:#fff;border:1px solid #e7edf5;border-radius:12px;padding:24px}.page-hint{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin:0 0 16px;padding:0 14px 12px}.page-hint-summary{cursor:pointer;color:#0f172a;-webkit-user-select:none;user-select:none;padding:12px 4px 8px 0;font-size:14px;font-weight:600;list-style:none}.page-hint-summary::-webkit-details-marker{display:none}.page-hint-summary:before{content:"▸";color:#64748b;margin-right:8px;font-size:12px;display:inline-block;transform:translateY(-1px)}.page-hint[open] .page-hint-summary:before{content:"▾"}.page-hint-list{color:#334155;gap:6px;margin:0 0 4px;padding-left:1.25rem;font-size:13px;line-height:1.45;display:grid}.info-callout{color:#1e3a5f;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;padding:14px 16px;font-size:14px;display:flex}.info-callout-hardware{align-items:center}.info-callout-body{flex:220px;min-width:0}.info-callout-title{color:#1e3a5f;margin:0 0 4px;font-weight:600}.info-callout-secret{margin:0}.info-callout-missing{max-width:48ch;margin:0}.info-callout-copy{flex-shrink:0;align-self:center}.gateway-pass-value{letter-spacing:.04em;color:#0c1844;background:#fff;border:1px solid #93c5fd;border-radius:6px;padding:4px 10px;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:16px;font-weight:700}.hardware-instruction{color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin:0 0 16px;padding:14px 16px 12px;font-size:13px;line-height:1.5}.hardware-instruction-title{color:#0f172a;margin:0 0 10px;font-size:14px;font-weight:600}.hardware-instruction-list{gap:8px;margin:0;padding-left:1.2rem;display:grid}.hardware-instruction-list li{padding-left:.2rem}.hardware-instruction-code{background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:1px 5px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px}.hardware-block{background:#fafcff;border:1px solid #e7edf5;border-radius:10px;margin-top:14px;padding:16px 18px 18px}.hardware-block-title{color:#0f172a;margin:0 0 4px;font-size:16px;font-weight:600}.hardware-hint{margin:0 0 10px;font-size:13px}.hardware-form-row{margin-top:0}.hardware-table{margin-top:12px}.hardware-empty{margin:8px 0 0;font-size:13px}.sensor-sn-cell{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px}.sensor-binding-cell{max-width:28rem;font-size:13px;line-height:1.4}.custom-period-field--checkbox{flex-direction:row;align-items:center;gap:8px;min-height:36px;display:flex}.custom-period-field--checkbox span{color:#23374d;font-size:14px}.custom-period-field--checkbox input[type=checkbox]{accent-color:#2f6fed;width:auto;height:auto;margin:0}.ghost-btn--compact{height:32px;padding:0 10px;font-size:12px}.sensor-alerts-input{background:#fff;border:1px solid #d7e0ec;border-radius:8px;width:5.25rem;min-width:0;height:32px;padding:4px 8px;font-size:13px}.sensor-alerts-cell{text-align:center;vertical-align:middle}.telemetry-thresholds-cell{color:#4b6078;white-space:nowrap;font-size:13px}.gateway-token-cell{flex-wrap:wrap;align-items:center;gap:8px;min-width:0;max-width:36rem;display:flex}.gateway-token-value{word-break:break-all;color:#0c1844;background:#f1f5f9;border:1px solid #d7e0ec;border-radius:6px;flex:200px;min-width:0;padding:4px 8px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:11px;line-height:1.3}.gateway-token-copy{flex-shrink:0;height:auto;min-height:28px;padding:4px 10px;font-size:12px}.kicker{color:#5b6f87;text-transform:uppercase;letter-spacing:.07em;margin:0 0 8px;font-size:12px}h1{margin:0 0 12px;font-size:28px}h2{margin:0 0 12px;font-size:22px}h3{margin:0 0 8px}.muted{color:#4e5f73;margin:0}.grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px;display:grid}.grid article{background:#fafcff;border:1px solid #e7edf5;border-radius:10px;padding:14px}.stack{gap:10px;margin-top:16px;display:grid}.admin-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.admin-nav{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.admin-nav a{border:1px solid #d3deeb;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:14px;display:inline-flex}.admin-nav a.active{color:#214fb0;background:#ecf2ff;border-color:#2f6fed}.parking-clients-toolbar{flex-direction:column;gap:1rem;margin-top:.25rem;display:flex}.parking-clients-filters{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;grid-template-columns:repeat(auto-fit,minmax(148px,1fr));gap:.75rem 1rem;padding:.85rem 1rem;display:grid}.parking-clients-filter-field{gap:.3rem;min-width:0}.parking-clients-filter-field input{width:100%;font-size:14px}.parking-clients-toolbar-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.parking-lot-schematic-card .parking-lot-schematic-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:12px;overflow:auto}.parking-lot-schematic{width:100%;max-width:640px;height:auto;display:block}.menu-alert-pill{color:#fff;background:#e11d48;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:12px;font-weight:700;display:inline-flex}.menu-total-pill{color:#fff;background:#6b7280;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:12px;font-weight:700;display:inline-flex}.admin-live-strip{background:#fbfdff;border:1px solid #e7edf5;border-radius:10px;margin-top:14px;padding:12px}.admin-live-strip-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.admin-live-strip-title{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.live-critical-indicator{color:#fff;background:#dc2626;border-radius:999px;align-items:center;min-height:24px;padding:2px 10px;font-size:12px;font-weight:700;animation:1.4s ease-out infinite criticalPulse;display:inline-flex;box-shadow:0 0 #dc262673}@keyframes criticalPulse{0%{box-shadow:0 0 #dc262673}70%{box-shadow:0 0 0 10px #dc262600}to{box-shadow:0 0 #dc262600}}.admin-live-strip-tools{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-live-filter-group{border:1px solid #d3deeb;border-radius:8px;display:inline-flex;overflow:hidden}.live-quiet-toggle{color:#33475f;align-items:center;gap:6px;padding:0 2px;font-size:12px;display:inline-flex}.live-quiet-hours{align-items:center;gap:8px;display:inline-flex}.live-quiet-hours label{color:#4e5f73;align-items:center;gap:4px;font-size:12px;display:inline-flex}.live-quiet-hours input{border:1px solid #d7e0ec;border-radius:8px;width:96px;height:30px;padding:0 8px;font-size:12px}.quiet-active-pill{color:#8a5a00;background:#fff4db;border:1px solid #f4d08a;border-radius:999px;align-items:center;min-height:24px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.mini-filter-btn{cursor:pointer;background:#fff;border:0;padding:6px 10px;font-size:12px}.mini-filter-btn+.mini-filter-btn{border-left:1px solid #d3deeb}.mini-filter-btn.active{color:#214fb0;background:#ecf2ff}.admin-live-items{gap:6px;padding-right:4px;display:grid;overflow-y:auto}.admin-live-items.is-collapsed{max-height:172px}.admin-live-items.is-expanded{max-height:320px}.admin-live-item{background:#fff;border:1px solid #dfe7f2;border-radius:8px;gap:1px;padding:8px 10px;font-size:13px;display:grid}.admin-live-item-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.admin-live-item.alert{background:#fff7f7;border-color:#f8c9c9}.admin-live-item.warning{background:#fffbf3;border-color:#f5e0b7}.admin-live-item.info{background:#f9fbff;border-color:#d8e4f5}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-top:16px;display:grid}.stats-grid article{border:1px solid #e7edf5;border-radius:10px;padding:12px}.stats-grid h3{margin:0;font-size:24px}.stats-grid p{color:#61748b;margin:4px 0 0}.admin-objects-scope-card{background:#f0f6ff;border-color:#c5daf7}.admin-objects-scope-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px 24px;display:flex}.admin-objects-scope-title{margin:0 0 4px;font-size:1.1rem}.admin-objects-scope-hint{max-width:40rem;margin:0;font-size:13px;line-height:1.4}.admin-objects-scope-select{min-width:min(100%,280px)}.admin-objects-list-title{margin:0 0 12px}.admin-objects-shown{margin:8px 0 12px;font-size:13px}.admin-objects-filter-note{margin:0 0 12px;font-size:13px;line-height:1.4}.table-wrap{overflow-x:auto}.inline-link{cursor:pointer;background:#fff;border:1px solid #d3deeb;border-radius:8px;padding:6px 10px;font-size:13px}.user-review-json{background:#f8fbff;border:1px solid #d7e0ec;border-radius:10px;margin-top:10px;padding:10px;font-size:12px;line-height:1.45;overflow-x:auto}.inline-link-primary{color:#214fb0;background:#ecf2ff;border-color:#2f6fed}.objects-table{border-collapse:collapse;width:100%;min-width:620px}.objects-table th,.objects-table td{text-align:left;border-bottom:1px solid #edf2f8;padding:10px 8px;font-size:14px}.objects-table th{color:#4b6078;font-weight:600}.sort-btn{all:unset;cursor:pointer;color:inherit}.auth-card{max-width:460px;margin:24px auto 0}.auth-form{gap:12px;margin-top:18px;display:grid}.auth-form label{color:#4b6078;gap:6px;font-size:14px;display:grid}.auth-form input{border:1px solid #d7e0ec;border-radius:8px;height:40px;padding:0 12px;font-size:14px}.auth-form input:focus{border-color:#7aa4ff;outline:none;box-shadow:0 0 0 3px #dce8ff}.primary-btn,.ghost-btn{cursor:pointer;border:1px solid #0000;border-radius:8px;height:40px}.primary-btn{color:#fff;background:#2f6fed;font-weight:600}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.ghost-btn{background:#fff;border-color:#d3deeb}.error-text{color:#c33737;margin:0;font-size:14px}.page-actions{margin-bottom:10px}.asset-meta{gap:8px;display:grid}.incident-banner{border:1px solid #d3deeb;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:12px;margin:10px 0 4px;padding:10px 12px;display:flex}.incident-banner p{margin:6px 0 0}.incident-alert{background:#fff7f7;border-color:#f8c9c9}.incident-warning{background:#fffbf3;border-color:#f5e0b7}.incident-info{background:#f9fbff;border-color:#d8e4f5}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:10px;display:grid}.kpi-grid article{background:#fbfdff;border:1px solid #e7edf5;border-radius:10px;padding:10px}.kpi-title{color:#61748b;margin:0;font-size:12px}.kpi-grid h3{margin:6px 0 0;font-size:18px}.chart-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.hours-picker{color:#4b6078;align-items:center;gap:8px;font-size:14px;display:inline-flex}.hours-picker select{background:#fff;border:1px solid #d7e0ec;border-radius:8px;height:34px;padding:0 10px}.custom-period-row{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-top:10px;display:flex}.custom-period-field{color:#4b6078;gap:6px;font-size:13px;display:grid}.custom-period-field input,.custom-period-field select{background:#fff;border:1px solid #d7e0ec;border-radius:8px;height:36px;padding:0 10px}.stats-inline{color:#3d4f64;flex-wrap:wrap;gap:14px;margin-top:8px;font-size:13px;display:flex}.switch-row{color:#23374d;align-items:center;gap:8px;height:36px;font-size:14px;display:inline-flex}.refresh-presets{flex-wrap:wrap;gap:6px;display:inline-flex}.preset-btn{cursor:pointer;background:#fff;border:1px solid #d3deeb;border-radius:8px;height:34px;padding:0 10px;font-size:12px}.preset-btn.is-active{color:#214fb0;background:#ecf2ff;border-color:#2f6fed}.preset-btn:hover,.sort-btn:hover,.legend-item:hover{background:#f5f8ff}.overview-search{border:1px solid #d7e0ec;border-radius:8px;min-width:260px;height:36px;padding:0 10px}.live-log-list{gap:10px;display:grid}.live-filter-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;display:flex}.live-filter-badges{flex-wrap:wrap;gap:8px;display:flex}.live-summary-row{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.filter-badge{color:#3e556e;background:#f8fbff;border:1px solid #d3deeb;border-radius:999px;padding:4px 10px;font-size:12px}.live-alert-banner{background:#fff7f7;border-color:#f8c9c9;justify-content:space-between;align-items:center;gap:12px;display:flex}.live-log-item{background:#fff;border:1px solid #e7edf5;border-radius:10px;padding:12px}.priority-top{border-color:#ef4444;box-shadow:0 0 0 2px #ef44441f}.priority-high{border-color:#f59e0b}.priority-medium{border-color:#3b82f6}.priority-low{border-color:#d1d5db}.priority-chip{color:#fff;vertical-align:middle;background:#ef4444;border-radius:999px;justify-content:center;align-items:center;margin-left:8px;padding:2px 6px;font-size:10px;display:inline-flex}.live-log-item p{margin:8px 0 10px}.live-log-actions{flex-wrap:wrap;gap:8px;display:flex}.maintenance-file-input-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.maintenance-upload-block{margin-top:10px;margin-bottom:10px}.maintenance-upload-label{color:#4b6078;margin:0 0 6px;font-size:13px;font-weight:500;display:block}.maintenance-photos-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.maintenance-file-list{color:#334155;gap:4px;margin:8px 0 0;padding:0;font-size:13px;list-style:none;display:grid}.maintenance-file-list li{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.maintenance-file-hint{margin:6px 0 0;font-size:13px}.maintenance-log-photos{flex-wrap:wrap;gap:8px;margin:6px 0 4px;display:flex}.maintenance-log-photo-link{color:#2563eb;word-break:break-all;font-size:12px;text-decoration:underline}.maintenance-log-photo-link:hover{color:#1d4ed8}.live-log-head{flex-wrap:wrap;justify-content:space-between;gap:10px;display:flex}.live-log-head-actions{flex-shrink:0;align-items:center;gap:12px;display:flex}.object-qr-nfc-block{background:#fafbfc;border:1px solid #e2e8f0;border-radius:10px;margin-top:16px;margin-bottom:8px;padding:0 12px 12px}.object-qr-nfc-summary{cursor:pointer;padding:10px 4px;font-weight:600;list-style:none}.object-qr-nfc-summary::-webkit-details-marker{display:none}.object-qr-nfc-inner{flex-direction:column;gap:20px;display:flex}.object-qr-nfc-h{margin:0 0 8px;font-size:.95rem}.object-qr-reveal{flex-direction:column;align-items:flex-start;gap:10px;display:flex}.object-qr-img{border:1px solid #e2e8f0;border-radius:8px;max-width:100%;height:auto}.object-qr-actions{flex-wrap:wrap;align-items:center;gap:8px 12px;display:flex}.object-nfc-list{margin:0 0 12px;padding-left:0;list-style:none}.object-nfc-row{flex-wrap:wrap;align-items:center;gap:8px 12px;margin-bottom:8px;display:flex}.object-nfc-row code{word-break:break-all;font-size:.85rem}.object-nfc-add{margin-top:4px}.sensor-type-kinds{margin-top:4px;font-size:12px;font-weight:500;display:block}.live-log-alert{background:#fff7f7;border-color:#f8c9c9}.live-log-warning{background:#fffbf3;border-color:#f5e0b7}.live-log-info{background:#f9fbff;border-color:#d8e4f5}.chart-wrap{gap:12px;margin-top:12px;display:grid}.chart-wrap--echart{border:1px solid #e6edf8;border-radius:10px;overflow:hidden}.line-chart{border:1px solid #e6edf8;border-radius:10px;width:100%}.chart-legend{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;display:grid}.legend-item{color:#4e5f73;cursor:pointer;background:#fff;border:1px solid #d3deeb;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:flex}.legend-item.is-off{opacity:.45}.legend-dot{border-radius:999px;width:10px;height:10px}.status-badge{border-radius:999px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-block}.status-ok{color:#1f8b52;background:#e8f8ef}.status-warn{color:#b54708;background:#fff1ea}code{background:#f2f5fa;border-radius:6px;padding:2px 8px}.button-link{border:1px solid #d3deeb;border-radius:8px;margin-top:14px;padding:8px 12px;display:inline-block}.public-landing{width:100vw;max-width:none;margin-top:-8px;margin-left:-50vw;margin-right:-50vw;padding:0;position:relative;left:50%;right:50%}.landing{--landing-accent:#3b82f6;--landing-accent-dim:#1d4ed8;--landing-ink:#0f172a;--landing-muted:#64748b}.landing-hero{color:#e8f0ff;box-sizing:border-box;background:linear-gradient(155deg,#070d18 0%,#0c1f3a 35%,#112d52 100%);border-bottom:1px solid #60a5fa33;width:100%;margin:0;padding:clamp(2rem,5vw,3.5rem) clamp(1.25rem,4vw,2.5rem) clamp(2.5rem,5vw,3.75rem);position:relative;overflow:visible;box-shadow:0 12px 40px #08132859}.landing-hero-grid{border-radius:inherit;pointer-events:none;background-image:linear-gradient(#60a5fa0f 1px,#0000 1px),linear-gradient(90deg,#60a5fa0f 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0;overflow:hidden;-webkit-mask-image:radial-gradient(90% 75% at 50% 0,#000 30%,#0000 75%);mask-image:radial-gradient(90% 75% at 50% 0,#000 30%,#0000 75%)}.landing-hero-inner{z-index:1;min-width:0;max-width:48rem;margin:0 auto;padding:0 2px;position:relative}.landing-hero-kicker{letter-spacing:.12em;text-transform:uppercase;color:#94b4e8;margin:0 0 10px;font-size:12px;font-weight:600}.landing-h1{letter-spacing:-.03em;color:#f8fafc;text-shadow:0 2px 24px #0f172a73;overflow-wrap:anywhere;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;text-wrap:balance;margin:0 0 14px;font-size:clamp(1.35rem,2.5vw + .5rem,2rem);font-weight:800;line-height:1.25}.landing-hero-lead{color:#c7d4f5;overflow-wrap:anywhere;max-width:40rem;margin:0 0 10px;font-size:clamp(1.02rem,1.1vw + .9rem,1.2rem);font-weight:500;line-height:1.55}.landing-hero-sub{color:#9ab6e0;overflow-wrap:anywhere;max-width:38rem;margin:0;font-size:.98rem;line-height:1.6}.landing-section{padding:40px 0 44px}.landing-section-inner{min-width:0;max-width:1120px;margin:0 auto;padding:0 clamp(4px,1.5vw,8px)}.landing-section--default{background:#fff}.landing-section--alt{background:#f1f5f9}.landing-section--tint{background:linear-gradient(#f0f7ff 0%,#fff 100%)}.landing-h2{letter-spacing:-.025em;color:var(--landing-ink);margin:0 0 16px;font-size:clamp(1.25rem,1.5vw + 1rem,1.55rem);font-weight:800;line-height:1.2}.landing-h3{color:#1e3a5f;margin:0 0 6px;font-size:1.05rem;font-weight:700}.landing-h3--spaced{margin-top:18px}.landing-lead{color:var(--landing-muted);max-width:48rem;margin:0 0 18px;font-size:.95rem;line-height:1.5}.landing-prose{color:#334155;max-width:52rem;margin:0 0 12px;font-size:.98rem;line-height:1.6}.landing-prose:last-child{margin-bottom:0}.landing-prose--emphasis{color:#1e3a5f;font-weight:600}.landing-pain-list{grid-template-columns:1fr;gap:12px;margin:0;padding:0;list-style:none;display:grid}@media (width>=720px){.landing-pain-list{grid-template-columns:1fr 1fr}}.landing-pain-item{color:#1e293b;background:linear-gradient(#fff 0%,#f8fafc 100%);border:1px solid #e2e8f0e6;border-radius:14px;align-items:flex-start;padding:16px 16px 16px 48px;font-size:.95rem;line-height:1.5;display:flex;position:relative;box-shadow:0 1px 2px #0f172a0a,0 4px 16px #0f172a0a}.landing-pain-item:before{content:"!";color:#0f172a;background:linear-gradient(135deg,#fde68a 0%,#f59e0b 100%);border-radius:8px;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.8rem;font-weight:800;line-height:1.2;display:flex;position:absolute;top:15px;left:14px;transform:none;box-shadow:0 1px 3px #b4530940}.landing-timeline{flex-direction:column;gap:0;max-width:44rem;margin:20px 0 0;padding:0;list-style:none;display:flex}.landing-timeline-item{gap:16px;padding-bottom:18px;display:flex;position:relative}.landing-timeline-item:before{content:"";background:linear-gradient(180deg, var(--landing-accent), transparent);border-radius:1px;width:2px;position:absolute;top:36px;bottom:0;left:19px}.landing-timeline-item:last-child:before{display:none}.landing-timeline-marker{color:#fff;background:linear-gradient(135deg, var(--landing-accent) 0%, #1d4ed8 100%);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.9rem;font-weight:800;display:flex;box-shadow:0 4px 14px #2563eb59}.landing-timeline-body{padding-top:2px}.landing-timeline-text{color:#475569;margin:0;font-size:.92rem;line-height:1.5}.landing-cloud-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.landing-cloud-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px;box-shadow:0 2px 8px #0f172a0a}.landing-cloud-text{color:#475569;margin:6px 0 0;font-size:.9rem;line-height:1.5}.landing-bullets{color:#334155;margin:8px 0 0;padding:0 0 0 1.1rem;font-size:.95rem;line-height:1.55}.landing-bullets li{margin-bottom:6px}.landing-bullets li:last-child{margin-bottom:0}.landing-protocol-groups{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:6px;display:grid}.landing-protocol-group{min-width:0}.landing-chips{flex-wrap:wrap;gap:6px 8px;margin:8px 0 0;padding:0;list-style:none;display:flex}.landing-chip{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:600;display:inline-block}.landing-integrations{border-top:1px solid #e2e8f0;margin-top:24px;padding-top:20px}.landing-benefits{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:4px;display:grid}.landing-benefit-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px 20px;box-shadow:0 2px 10px #0f172a0d}.landing-benefit-card--accent{background:linear-gradient(160deg,#f8fcff 0%,#eff6ff 100%);border-color:#93c5fd}.landing-page-hint{max-width:48rem;margin:0 auto 32px;padding:0 clamp(8px,2vw,20px)}.landing-page-hint .page-hint{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin:24px 0 0}.landing-page-hint .page-hint-summary{color:#64748b;padding:10px 12px 8px;font-size:13px;font-weight:600}.landing-page-hint .page-hint-list{color:#64748b;margin:0;padding:0 12px 12px 28px;font-size:13px}.landing-page-hint .page-hint-list li{margin-bottom:4px}.landing-prose--hero{color:#1e3a5f;font-size:1.02rem;font-weight:500}.landing-inline-more{margin:12px 0 0}.landing-read-more{all:unset;cursor:pointer;color:#1d4ed8;text-underline-offset:3px;font-size:.9rem;font-weight:600;text-decoration:underline}.landing-read-more:hover,.landing-read-more:focus-visible{color:#1e3a8a}.landing-bento{perspective:1200px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:8px;padding:2px;display:grid}.landing-bento-card{min-height:7rem;transform-style:preserve-3d;background:linear-gradient(165deg,#fff 0%,#f8fafc 100%);border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:8px;padding:18px 18px 16px;transition:transform .22s,box-shadow .22s;display:flex;position:relative;box-shadow:inset 0 1px #fffc,0 4px 20px #0f172a0f}.landing-bento-card--3d:hover{transform:rotateX(2deg)rotateY(-2deg)translateZ(0);box-shadow:inset 0 1px #ffffffe6,0 12px 32px #0f172a1a}.landing-bento-card--wide{grid-column:1/-1}.landing-bento-title{color:#0f172a;letter-spacing:-.02em;margin:0;font-size:1.05rem;font-weight:800}.landing-bento-teaser{color:#475569;flex:1;margin:0;font-size:.9rem;line-height:1.5}.landing-step-pills{flex-wrap:wrap;gap:6px;margin:0 0 4px;padding:0;list-style:none;display:flex}.landing-step-pill{color:#334155;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:600}.landing-bullets--spaced{margin-top:0}.landing-bullets--spaced li{margin-bottom:10px}.landing-modal-steps{color:#334155;margin:8px 0 0;padding-left:1.1rem;font-size:.95rem;line-height:1.55}.landing-cloud-grid--modal{margin-top:10px}.landing-modal{width:100%;max-width:min(100vw,40rem);box-shadow:none;background:0 0;border:none;border-radius:16px;padding:0}.landing-modal::backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a73}.landing-modal-panel{background:#fff;border-radius:16px;flex-direction:column;max-height:min(85vh,720px);display:flex;overflow:hidden;box-shadow:0 20px 50px #0003}.landing-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 16px 0 20px;display:flex}.landing-modal-title{color:#0f172a;margin:0 0 12px;padding-top:4px;font-size:1.15rem;font-weight:800;line-height:1.3}.landing-modal-close{all:unset;cursor:pointer;color:#64748b;border-radius:8px;padding:4px 8px;font-size:1.5rem;line-height:1}.landing-modal-close:hover,.landing-modal-close:focus-visible{color:#0f172a;background:#f1f5f9}.landing-modal-body{padding:16px 20px 20px;overflow-y:auto}.landing-live-demo{color:#e2e8f0;background:#0b1220;border:1px solid #3b82f64d;border-radius:12px;padding:0 0 12px;position:relative;overflow:hidden;box-shadow:0 8px 30px #08132840}.landing-live-demo-chrome{pointer-events:none;background:linear-gradient(#1e3a5f59 0%,#0000 40%);position:absolute;inset:0}.landing-live-demo-header{z-index:1;justify-content:space-between;align-items:center;padding:10px 14px 6px;display:flex;position:relative}.landing-live-demo-dots{gap:5px;display:flex}.landing-live-demo-dots span{background:#475569;border-radius:999px;width:8px;height:8px}.landing-live-demo-dots span:first-child{background:#f87171}.landing-live-demo-dots span:nth-child(2){background:#fbbf24}.landing-live-demo-dots span:nth-child(3){background:#34d399}.landing-live-demo-badge{text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;border:1px solid #334155;border-radius:999px;padding:2px 8px;font-size:10px}.landing-live-demo-hint{color:#94a3b8;z-index:1;margin:0 14px 8px;font-size:12px;position:relative}.landing-live-demo-section{z-index:1;padding:0 12px 4px;position:relative}.landing-live-demo-title{color:#e2e8f0;margin:0 0 8px;font-size:15px;font-weight:600}.landing-live-demo-period{flex-wrap:wrap;gap:6px 8px;margin-bottom:8px;display:flex}.landing-live-demo-period-pill{color:#94a3b8;background:#0f172a80;border:1px solid #334155;border-radius:6px;padding:4px 10px;font-size:11px}.landing-live-demo-period-pill--on{color:#e2e8f0;background:#1e40af59;border-color:#3b82f6}.landing-live-demo-plot{align-items:stretch;gap:6px;display:flex}.landing-live-y-labels{color:#64748b;text-align:right;flex-direction:column;flex-shrink:0;justify-content:space-between;width:22px;min-height:100px;font-size:9px;line-height:1;display:flex}.landing-live-x-ticks{font-variant-numeric:tabular-nums;color:#64748b;justify-content:space-between;margin-top:2px;margin-left:28px;padding-right:2px;font-size:8px;display:flex}.landing-live-demo-chart{z-index:1;background:#0f172a99;border:1px solid #1e3a5f;border-radius:8px;margin:0;padding:6px 8px 8px;position:relative}.landing-live-demo-plot .landing-live-demo-svg{flex:1;width:100%;min-width:0;height:100px;display:block}.landing-live-demo-grid{stroke:#1e3a5f;stroke-width:.2px;opacity:.4}.landing-live-line{fill:none;stroke-width:.6px;vector-effect:non-scaling-stroke}.landing-live-line--a{stroke:#60a5fa}.landing-live-line--b{stroke:#38bdf8}.landing-live-line--c{stroke:#f87171}.landing-live-legend{color:#cbd5e1;flex-wrap:wrap;gap:12px 20px;margin-top:6px;font-size:12px;display:flex}.landing-live-legend-item{align-items:center;gap:6px;display:inline-flex}.landing-live-dot{border-radius:999px;width:8px;height:8px}.landing-live-dot--a{background:#3b82f6}.landing-live-dot--b{background:#38bdf8}.landing-live-dot--c{background:#ef4444}.landing-live-value{color:#f1f5f9;margin-left:4px;font-weight:700}@media (width<=600px){.landing-hero{padding:36px 16px 40px}.landing-timeline-item{gap:12px}}@media (prefers-reduced-motion:reduce){.landing-hero,.landing-timeline-marker,.landing-cloud-card,.landing-benefit-card{box-shadow:none}.landing-bento-card--3d:hover{transform:none}}.modal-backdrop{z-index:100;background:#0f172a8c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-card{width:100%;max-width:440px;max-height:min(90vh,720px);overflow:auto}.parking-apply-modal{background:linear-gradient(#fff 0%,#f8fafc 100%);border-radius:14px;max-width:min(100%,480px);padding:1.35rem 1.5rem 1.5rem;box-shadow:0 18px 48px #0f172a24,0 0 0 1px #94a3b81f}.parking-apply-modal__title{letter-spacing:-.02em;color:#0f172a;margin:0 0 .5rem;font-size:1.2rem;font-weight:700}.parking-apply-modal__lead{color:#64748b;margin:0 0 1.1rem;font-size:.875rem;line-height:1.5}.parking-apply-modal__form{flex-direction:column;gap:1rem;display:flex}.parking-apply-modal__section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:.65rem;padding:.85rem .95rem;display:flex}.parking-apply-modal__section-label{text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-size:.7rem;font-weight:700}.parking-apply-modal__field{flex-direction:column;gap:.3rem;display:flex}.parking-apply-modal__label{color:#334155;font-size:.8125rem;font-weight:600}.parking-apply-modal__input,.parking-apply-modal__textarea{color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:10px;min-height:46px;padding:0 .85rem;font-size:16px;transition:border-color .15s,box-shadow .15s}.parking-apply-modal__input:focus,.parking-apply-modal__textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f633}select.parking-apply-modal__input{cursor:pointer;appearance:auto;background-image:none}.parking-apply-modal__input--grow{flex:12rem;min-width:0}.parking-apply-modal__phone-row{flex-wrap:nowrap;align-items:center;gap:.4rem;display:flex}.parking-apply-modal__phone-prefix{color:#475569;flex-shrink:0;min-width:1.75rem;font-weight:700}.parking-apply-modal__textarea{resize:vertical;min-height:88px;padding-top:.65rem;padding-bottom:.65rem;font-family:inherit}.parking-apply-modal__hint{color:#64748b;margin:0;font-size:.8125rem;line-height:1.45}.parking-apply-modal__trust{color:#94a3b8;margin:0;font-size:.75rem;line-height:1.45}.parking-apply-modal__error{margin:0}.parking-apply-modal__actions{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.25rem;display:flex}.parking-apply-modal__cta{border-radius:10px;min-height:48px;padding-left:1.25rem;padding-right:1.25rem;font-weight:600}.parking-apply-modal__success{flex-direction:column;gap:1rem;display:flex}.parking-apply-modal__success-text{color:#475569;margin:0;font-size:.9375rem;line-height:1.55}.app-shell--parking-driver{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);background:linear-gradient(165deg,#e8edf5 0%,#f5f7fb 45%,#eef2f8 100%)}.app-shell--parking-driver .topbar-inner{padding-top:max(0px, env(safe-area-inset-top,0px));min-height:calc(52px + env(safe-area-inset-top,0px));justify-content:space-between}.app-shell--parking-driver .parking-driver-logout{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #d7e0ec;border-radius:10px;flex-shrink:0;min-height:44px;padding:0 14px;font-family:inherit;font-size:15px;font-weight:600}.app-shell--parking-driver .parking-driver-logout:active{background:#e2e8f0}.app-shell--parking-driver .page-wrap{max-width:560px;padding-top:24px;padding-left:max(16px, env(safe-area-inset-left,0px));padding-right:max(16px, env(safe-area-inset-right,0px));padding-bottom:max(40px, calc(24px + env(safe-area-inset-bottom,0px)));margin:0 auto}.app-shell--parking-driver .auth-card{max-width:none;margin-top:16px}.app-shell--parking-driver .auth-form input,.app-shell--parking-driver .parking-driver-panel select{min-height:48px;font-size:16px}.app-shell--parking-driver .primary-btn{width:100%;min-height:48px;font-size:1rem}.app-shell--parking-driver .parking-offline-hints summary{cursor:pointer;align-items:center;min-height:44px;padding:12px 4px;display:flex}.app-shell--parking-driver .parking-offline-hints a{color:#1d4ed8;align-items:center;min-height:44px;padding:4px 0;text-decoration:underline;display:inline-flex}.app-shell--parking-driver .parking-driver-panel{font-size:16px}.app-shell--parking-driver .parking-driver-panel h2{font-size:1.35rem}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app-shell--parking-driver .parking-pin-keypad-digit{min-height:48px;font-size:1.05rem}.parking-login-page{flex-direction:column;gap:12px;width:100%;max-width:min(100%,480px);margin:0 auto;display:flex}.parking-login-card-elevated{background:linear-gradient(#fff 0%,#f8fafc 100%);border:1px solid #e2e8f0;border-radius:14px;width:100%;padding:1.35rem 1.5rem 1.5rem;box-shadow:0 18px 48px #0f172a24,0 0 0 1px #94a3b81f}.parking-login-details{background:#fafbfc;border:1px solid #e2e8f0;border-radius:10px;margin:0 0 1rem;overflow:hidden}.parking-login-details summary{cursor:pointer;color:#64748b;padding:.5rem .75rem;font-size:.8125rem;font-weight:600;list-style:none}.parking-login-details summary::-webkit-details-marker{display:none}.parking-login-details summary:before{content:"";vertical-align:.15em;border-bottom:2px solid #94a3b8;border-right:2px solid #94a3b8;width:.35rem;height:.35rem;margin-right:.35rem;transition:transform .15s;display:inline-block;transform:rotate(-45deg)}.parking-login-details[open] summary:before{vertical-align:.05em;transform:rotate(45deg)}.parking-login-details-body{border-top:1px solid #e8edf3;padding:0 .75rem .65rem}.parking-login-details-body p{color:#64748b;margin:0 0 .5rem;font-size:.8125rem;line-height:1.45}.parking-login-details-body .parking-login-details-list{color:#64748b;margin:0 0 .5rem;padding-left:1.1rem;font-size:.8125rem;line-height:1.45}.parking-login-details-body .parking-login-details-list li{margin-bottom:.35rem}.parking-login-details-body .parking-login-details-list li:last-child,.parking-login-details-body>:last-child{margin-bottom:0}.parking-login-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:.85rem .95rem;display:flex}.parking-login-section-label{text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-size:.7rem;font-weight:700}.parking-login-field{flex-direction:column;gap:.35rem;display:flex}.parking-login-field-label{color:#334155;font-size:.8125rem;font-weight:600}.parking-login-field-hint{color:#94a3b8;font-size:.75rem;line-height:1.4}.parking-login-pin-wrap{flex-direction:column;gap:.5rem;display:flex}.parking-login-form{margin-top:0}.parking-login-error{margin:0 0 .5rem}.parking-login-actions{flex-direction:column;gap:.6rem;display:flex}.parking-login-submit,.parking-login-apply-btn{border-radius:10px;width:100%;min-height:48px;font-weight:600}.parking-login-apply-btn{margin-top:0}.parking-driver-stack{flex-direction:column;gap:12px;width:100%;display:flex}.parking-panel-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:18px 16px;box-shadow:0 4px 20px #0f172a12}.parking-panel-card--hint{padding:10px 12px 12px;box-shadow:0 2px 12px #0f172a0a}.parking-panel-card--hint .page-hint{background:#fafbfc;border-color:#e8edf3;margin:0}.parking-panel-card--footer{padding:14px 16px;font-size:14px}.parking-panel-card--footer a{color:#1d4ed8;text-underline-offset:3px;font-weight:500;text-decoration:underline}.parking-phone-row{background:#f8fafc;border:1px solid #d7e0ec;border-radius:14px;align-items:stretch;display:flex;overflow:hidden}.parking-phone-row:focus-within{border-color:#7aa4ff;box-shadow:0 0 0 3px #dce8ff}.parking-phone-prefix{color:#0f172a;background:linear-gradient(#eef2f7,#e8edf4);border-right:1px solid #d7e0ec;align-items:center;padding:0 14px;font-size:16px;font-weight:700;display:flex}.parking-phone-row input{background:0 0;border:none;outline:none;flex:1;min-width:0;min-height:52px;padding:0 14px;font-size:16px}.parking-login-page .auth-form{margin-top:8px}.parking-login-page .primary-btn{border-radius:14px;min-height:52px;font-size:1.05rem;box-shadow:0 2px 8px #2f6fed59}.parking-login-page .ghost-btn{border-width:2px;border-radius:14px;min-height:52px;font-size:1rem}.parking-pin-keypad--tiles{gap:12px!important}.parking-pin-keypad--tiles .parking-pin-keypad-dots{letter-spacing:.35em;min-height:2rem;padding:8px 0 4px;font-size:1.5rem}.parking-pin-keypad--tiles .parking-pin-keypad-digit,.parking-pin-keypad--tiles .parking-pin-keypad-actions button{color:#0f172a;background:linear-gradient(#fff,#f8fafc);border:2px solid #e2e8f0;border-radius:14px;min-width:0;min-height:52px;font-size:1.35rem;font-weight:700;transition:transform 80ms,background .12s,border-color .12s}.parking-pin-keypad--tiles .parking-pin-keypad-digit:active:not(:disabled),.parking-pin-keypad--tiles .parking-pin-keypad-actions button:active:not(:disabled){background:#eef2ff;border-color:#93b4f0;transform:scale(.97)}.parking-pin-keypad--tiles .parking-pin-keypad-digit:disabled,.parking-pin-keypad--tiles .parking-pin-keypad-actions button:disabled{opacity:.45}.parking-driver-title{letter-spacing:-.02em;color:#0f172a;margin:0 0 10px;font-size:clamp(1.35rem,4vw,1.55rem);font-weight:800}.parking-stat-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;display:grid}@media (width<=380px){.parking-stat-grid{grid-template-columns:1fr}}.parking-stat-tile{background:linear-gradient(#fafbfd,#f4f7fb);border:1px solid #e8edf3;border-radius:14px;min-height:72px;padding:12px 14px}.parking-stat-tile dt{text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin:0;font-size:11px;font-weight:600}.parking-stat-tile dd{color:#0f172a;margin:6px 0 0;font-size:1rem;font-weight:700;line-height:1.3}.parking-gate-tiles{grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:10px;margin-bottom:14px;display:grid}.parking-gate-tile{cursor:pointer;min-height:76px;font:inherit;text-align:left;background:#fff;border:2px solid #e2e8f0;border-radius:14px;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 14px;transition:border-color .15s,background .15s,transform 80ms;display:flex}.parking-gate-tile:active:not(:disabled){transform:scale(.98)}.parking-gate-tile.is-selected{background:linear-gradient(#eff6ff,#f8fafc);border-color:#2f6fed;box-shadow:0 0 0 1px #2f6fed40}.parking-gate-tile:disabled{opacity:.55;cursor:not-allowed}.parking-gate-tile-name{color:#0f172a;font-size:13px;font-weight:700;line-height:1.25}.parking-gate-tile-sub{color:#64748b;font-size:12px;line-height:1.2}.app-shell--parking-driver .parking-driver-stack .primary-btn{border-radius:14px;width:100%;min-height:52px;font-size:1.05rem;box-shadow:0 2px 10px #2f6fed4d}.app-shell--parking-driver .parking-driver-stack select{background:#fff;border:2px solid #e2e8f0;border-radius:12px;width:100%;min-height:52px;padding:0 14px;font-size:16px}
