:root{--brand: #2E8B5A;--brand-light: #3DA56B;--brand-dark: #1F6B43;--brand-50: #E6F1EB;--brand-100: #CFE3D7;--accent: #E89A1B;--accent-light: #F2B144;--accent-dark: #B57613;--accent-soft: #FBF1DB;--light-chrome: #1F6B43;--light-canvas: #F2F5F2;--light-sunken: #E9EFEA;--light-line: #DCE5DF;--cw-canvas: #EAF2EC;--bg: var(--light-canvas);--surface: #FFFFFF;--surface-2: #FAF8F3;--sunken: var(--light-sunken);--ink: #0F0F12;--ink-2: #2A2A2F;--muted: #5C5C66;--muted-2: #8B8B95;--line: var(--light-line);--line-2: #DCE5DF;--paper: #F4F2EE;--paper-2: #FAF8F3;--success: #2E8B5A;--success-soft: #E6F1EB;--success-dark: #1F6B43;--warning: #D9531E;--warning-soft: #FDECE3;--warning-dark: #9A3818;--alert: #B58A0C;--alert-soft: #F6EAC8;--alert-dark: #7A5C08;--critical: #A8281C;--critical-soft: #F8E0DC;--critical-dark: #7A1B12;--info: #1F73B8;--info-soft: #E3EEF8;--info-dark: #155085;--queue: #6B7370;--queue-soft: #EDEEEC;--queue-dark: #3F4845;--energy-solar: #F4B12B;--energy-solar-soft: #FDF0D5;--energy-solar-dark: #B97D0A;--energy-grid: #2274C0;--energy-grid-soft: #E1EDF9;--energy-grid-dark: #16548F;--energy-consumption: #1FA971;--energy-consumption-soft: #DFF3E9;--energy-consumption-dark: #157A51;--energy-soc: #7C6FD6;--energy-soc-soft: #ECE9FA;--energy-soc-dark: #5246A8;--energy-grid-absent: #9B2D20;--energy-grid-absent-rgb: 155 45 32;--energy-grid-absent-soft: #F4E1DD;--energy-grid-absent-dark: #6E1F16;--energy-grid-present: var(--brand-50);--cat-1: #0E8A8A;--cat-1-soft: #DCEFEF;--cat-1-dark: #0A6464;--cat-2: #C03A86;--cat-2-soft: #F8E1EE;--cat-2-dark: #8E2962;--cat-3: #9D44B5;--cat-3-soft: #F0E0F5;--cat-3-dark: #6E2C82;--font-ui: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--t-h1: 24px;--t-h2: 19px;--t-h3: 18px;--t-body: 16px;--t-label: 14px;--t-cap: 12px;--t-tiny: 12px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}html,body{background:#ececec}body{font-family:var(--font-ui);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:var(--t-body)}.h1{font-size:var(--t-h1);font-weight:600;line-height:1.2;letter-spacing:-.01em;margin:0}.h2{font-size:var(--t-h2);font-weight:600;line-height:1.25;letter-spacing:-.005em;margin:0}.h3{font-size:var(--t-h3);font-weight:600;line-height:1.3;margin:0}.body{font-size:var(--t-body);line-height:1.5}.label{font-size:var(--t-label);font-weight:500;line-height:1.4;color:var(--muted)}.cap{font-size:var(--t-cap);line-height:1.4;color:var(--muted)}.tiny{font-size:var(--t-tiny);color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.mono{font-family:var(--font-mono)}.wordmark{font-family:Archivo Black,Archivo,Inter,sans-serif;font-weight:900;letter-spacing:.01em;font-size:16px;line-height:1;display:inline-flex;align-items:baseline;gap:1px}.wordmark .pwr{color:var(--ink)}.wordmark .hop{color:var(--brand)}.appbar{position:sticky;top:0;z-index:5;background:var(--light-chrome);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;border-bottom:1px solid var(--brand-dark)}.appbar .left{display:flex;align-items:center;gap:8px}.appbar .right{display:flex;align-items:center;gap:10px}.appbar .h2,.appbar .h1,.appbar .wordmark .pwr{color:#fff}.appbar .wordmark .hop{color:var(--accent)}.appbar .iconbtn{background:#ffffff24;border-color:#ffffff38;color:#fff}.appbar .iconbtn:hover{background:#ffffff3d}.appbar .iconbtn .dot{border-color:var(--light-chrome)}.iconbtn{width:32px;height:32px;border-radius:50%;background:#fff;border:1px solid var(--line-2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-2);position:relative}.iconbtn:hover{background:var(--surface-2)}.iconbtn .dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--alert);border:1.5px solid #fff}.tabbar{flex:none;background:var(--light-chrome);border-top:1px solid var(--brand-dark);display:flex;align-items:stretch;justify-content:space-around;padding:6px 4px 10px}.tabbar button{flex:1;background:none;border:0;padding:6px 4px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:12px;color:#fff9;font-family:var(--font-ui);font-weight:500;cursor:pointer;letter-spacing:.02em;text-transform:uppercase}.tabbar button.active{color:#fff}.tabbar button.active .ico{background:#ffffff2e;border-radius:10px;box-shadow:0 0 0 1px #ffffff47 inset}.tabbar button .ico{width:22px;height:22px;display:flex;align-items:center;justify-content:center}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px}.card.tight{padding:12px}.card.moss{background:var(--brand-50);border-color:var(--brand-100)}.card.moss .flow-node:not(.active){background:#fff;border-color:var(--line)}.card-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border-radius:10px;font-family:var(--font-ui);font-weight:600;font-size:var(--t-label);border:1px solid transparent;cursor:pointer;transition:all .12s ease;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--brand);color:#fff}.btn.primary:hover:not(:disabled){background:var(--brand-dark)}.btn.secondary{background:var(--brand-50);color:var(--brand-dark);border-color:transparent}.btn.secondary:hover:not(:disabled){background:color-mix(in srgb,var(--brand) 15%,#fff)}.btn.ghost{background:transparent;color:var(--ink)}.btn.ghost:hover:not(:disabled){background:#0000000a}.btn.destructive{background:var(--critical);color:#fff}.btn.block{width:100%}.btn.lg{padding:13px 18px;font-size:var(--t-body)}.btn.sm{padding:7px 10px;font-size:12px}.input,.textarea,.select{width:100%;background:#fff;border:1px solid var(--line-2);border-radius:10px;padding:11px 12px;font-family:var(--font-ui);font-size:var(--t-body);color:var(--ink);outline:none;transition:border-color .12s ease,box-shadow .12s ease}.input:focus,.textarea:focus,.select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2e8b5a1a}.input.err,.select.err,.textarea.err{border-color:var(--critical)}.input.err:focus,.select.err:focus,.textarea.err:focus{box-shadow:0 0 0 3px #a8281c1f}.field-label{display:block;font-size:var(--t-label);font-weight:500;color:var(--ink-2);margin-bottom:6px}.badge{display:inline-flex;align-items:center;gap:5px;font-size:var(--t-tiny);font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:3px 7px;border-radius:999px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}.badge .led{width:6px;height:6px;border-radius:50%;background:var(--muted-2)}.badge.success{background:var(--success);color:#fff;border-color:transparent}.badge.warning{background:var(--warning);color:#fff;border-color:transparent}.badge.alert{background:var(--alert);color:#fff;border-color:transparent}.badge.critical{background:var(--critical);color:#fff;border-color:transparent}.badge.info{background:var(--info);color:#fff;border-color:transparent}.badge.queue{background:var(--queue);color:#fff;border-color:transparent}.badge.brand{background:var(--brand);color:#fff;border-color:transparent}.badge.brand-dark{background:var(--brand-dark);color:#fff;border-color:transparent}.badge.accent{background:var(--accent);color:var(--ink);border-color:transparent}.badge.tinted{background:#1f73b81f;color:#155085;border-color:#1f73b866}.badge.outline{background:#fff;color:var(--muted);border-color:var(--line-2)}.badge.muted{background:var(--surface-2);color:var(--muted);border-color:var(--line-2)}.badge.success .led,.badge.warning .led,.badge.alert .led,.badge.critical .led,.badge.info .led,.badge.queue .led,.badge.brand .led,.badge.brand-dark .led,.badge.accent .led{display:none}.badge.tinted .led{background:var(--info)}.badge.outline .led,.badge.muted .led{background:var(--muted-2)}.batt-hero{background:radial-gradient(130% 120% at 0% 0%,rgba(46,139,90,.16) 0%,transparent 62%),linear-gradient(180deg,var(--brand-50) 0%,color-mix(in srgb,var(--brand-50) 45%,#fff) 100%);border:1px solid var(--brand-100);border-radius:22px;padding:18px 18px 16px;position:relative;overflow:hidden}.batt-hero .pct{font-family:var(--font-ui);font-weight:600;font-size:56px;letter-spacing:-.04em;color:var(--ink);line-height:1}.batt-hero .pct sup{font-size:22px;font-weight:500;color:var(--muted);margin-left:2px;vertical-align:top;position:relative;top:8px}.batt-bar{height:8px;background:var(--line);border-radius:4px;overflow:hidden;margin-top:12px}.batt-bar .fill{height:100%;background:linear-gradient(90deg,var(--brand) 0%,var(--brand-light) 100%);border-radius:4px;transition:width .5s ease}.batt-bar.warn .fill{background:linear-gradient(90deg,var(--warning),#E6743D)}.batt-bar.crit .fill{background:linear-gradient(90deg,var(--critical),#C04335)}.batt-hero.solid{background:radial-gradient(120% 130% at 100% 0%,rgba(46,139,90,.55) 0%,transparent 58%),var(--brand-dark);border-color:var(--brand-dark)}.batt-hero.solid .tiny{color:#ffffffbd}.batt-hero.solid .pct{color:#fff}.batt-hero.solid .pct sup{color:#ffffffb8}.batt-hero.solid .label{color:#ffffffd6}.batt-hero.solid .cap{color:#ffffffb8}.batt-hero.solid .cap.mono{color:#ffffffdb}.batt-hero.solid .tick{background:#fff}.batt-hero.solid .batt-bar{background:#ffffff3d}.batt-hero.solid .batt-bar .fill{background:#fff}.batt-hero.solid .batt-bar.warn .fill{background:var(--alert)}.batt-hero.solid .batt-bar.crit .fill{background:#fff}.batt-hero.solid .freshness,.batt-hero.solid .freshness .cap,.batt-hero.solid .freshness span{color:#ffffffe6!important}.batt-hero.solid .freshness .fdot{background:#fff!important;box-shadow:0 0 0 3px #ffffff40!important}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.kpi{background:var(--brand-50);border:1px solid var(--brand-100);border-radius:var(--r-md);padding:12px 13px;position:relative;overflow:hidden}.kpi:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--brand)}.kpi .lbl{font-size:var(--t-tiny);color:var(--brand-dark);text-transform:uppercase;letter-spacing:.06em;font-weight:600;display:flex;align-items:center;gap:5px;margin-bottom:6px}.kpi .val{font-family:var(--font-mono);font-size:18px;font-weight:500;color:var(--ink);letter-spacing:-.01em}.kpi .val .unit{font-size:12px;color:var(--muted);margin-left:3px;font-weight:400}.kpi .sub{font-size:var(--t-tiny);color:var(--muted);margin-top:2px}.flow-row{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:10px;padding:10px 0;border-bottom:1px dashed var(--line)}.flow-row:last-child{border-bottom:0}.flow-row .ico{width:22px;height:22px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.flow-row .name{font-size:var(--t-label);color:var(--ink-2);font-weight:500}.flow-row .meta{font-size:12px;color:var(--muted)}.flow-row .val{font-family:var(--font-mono);font-size:var(--t-label);font-weight:500;color:var(--ink)}.flow-row .val.muted{color:var(--muted-2)}.flow-row .val.active{color:var(--brand)}.section{display:flex;align-items:center;justify-content:space-between;margin:18px 0 10px}.section .title{font-size:var(--t-h2);font-weight:600;letter-spacing:-.005em;color:var(--brand-dark);display:flex;align-items:center;gap:8px}.section .title:before{content:"";width:3px;height:14px;border-radius:2px;background:var(--brand)}.section .link{color:var(--brand);font-size:var(--t-body);font-weight:500;cursor:pointer}.unit-pill{display:inline-flex;align-items:center;gap:7px;padding:5px 10px 5px 7px;background:#ffffff29;border:1px solid rgba(255,255,255,.24);border-radius:999px;font-size:12px;font-weight:500;color:#fff;cursor:pointer}.unit-pill .led{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 0 2px #2e8b5a2e}.unit-sheet{position:absolute;inset:auto 12px 12px 12px;background:#fff;border-radius:18px;box-shadow:0 12px 40px #0000002e;border:1px solid var(--line);z-index:30;padding:8px;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000040;z-index:25;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.unit-row{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:12px;cursor:pointer}.unit-row:hover{background:var(--surface-2)}.unit-row.selected{background:var(--brand-50)}.unit-row .name{font-size:var(--t-body);font-weight:600}.unit-row .meta{font-size:12px;color:var(--muted);font-family:var(--font-mono)}.alert-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:12px;font-size:var(--t-label);border:1px solid;margin-bottom:12px}.alert-banner.crit{background:#a8281c0f;border-color:#a8281c33;color:var(--critical)}.alert-banner.warn{background:#d9531e0f;border-color:#d9531e33;color:var(--warning)}.alert-banner.alert{background:#b58a0c14;border-color:#b58a0c40;color:var(--alert)}.alert-banner.info{background:#1f73b80f;border-color:#1f73b833;color:var(--info)}.alert-banner .ttl{font-weight:600;margin-bottom:2px;color:inherit;font-size:var(--t-label)}.alert-banner .desc{color:var(--ink-2);font-weight:400;font-size:var(--t-label);line-height:1.45}.alert-banner .recovery{margin-top:10px;background:#fff;border:1px solid rgba(168,40,28,.18);border-radius:10px;padding:10px 12px}.alert-banner .recovery-head{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--critical);margin-bottom:8px}.alert-banner .recovery-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}.alert-banner .recovery-steps li{display:flex;align-items:flex-start;gap:9px;font-size:var(--t-cap);line-height:1.4;color:var(--ink);font-weight:400}.alert-banner .recovery-steps .num{flex-shrink:0;width:18px;height:18px;border-radius:50%;background:var(--critical);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:.5px}.chart-axis{font-size:11px;fill:var(--muted);font-family:var(--font-mono)}.chart-grid{stroke:var(--line);stroke-dasharray:2 3;stroke-width:1}.login{height:100%;display:flex;flex-direction:column;background:linear-gradient(180deg,#fff,#f2f8f4);padding:32px 24px 24px}.login .logo-mark{width:fit-content;border-radius:14px;background:var(--brand);display:inline-flex;align-items:center;justify-content:center;padding:13px 16px;margin-bottom:20px}.otp-input{display:flex;gap:8px;justify-content:space-between}.otp-input input{width:44px;height:54px;text-align:center;font-family:var(--font-mono);font-size:22px;font-weight:500;border:1px solid var(--line-2);border-radius:12px;background:#fff;outline:none}.otp-input input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2e8b5a1f}.led-indicator{display:inline-flex;align-items:center;gap:7px;padding:5px 9px;background:var(--surface-2);border-radius:999px;border:1px solid var(--line);font-size:12px;font-weight:500;color:var(--ink-2)}.led-indicator .led{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 0 2px #2e8b5a2e}.led-indicator.pulse .led{animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}.segmented{display:flex;background:#ececec;border-radius:10px;padding:3px;gap:2px}.segmented button{flex:1;background:transparent;border:0;padding:7px 8px;font-family:var(--font-ui);font-size:var(--t-label);font-weight:500;color:var(--ink-2);border-radius:8px;cursor:pointer}.segmented button.active{background:#fff;color:var(--ink);box-shadow:0 1px 2px #0000000f}.list-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border-bottom:1px solid var(--line);cursor:pointer}.list-row:hover{background:var(--surface-2)}.list-row .ttl{font-size:var(--t-body);font-weight:500;color:var(--ink)}.list-row .meta{font-size:12px;color:var(--muted);margin-top:3px;font-family:var(--font-mono)}.list-group{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.list-group .list-row:last-child{border-bottom:0}.flow-diagram{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;gap:8px;padding:12px 4px 4px}.flow-node{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:10px 6px;text-align:center}.flow-node .ico{color:var(--muted);margin-bottom:4px;display:flex;justify-content:center}.flow-node .v{font-family:var(--font-mono);font-size:var(--t-label);font-weight:500}.flow-node .l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.flow-node.active{background:var(--brand-50);border-color:#2e8b5a4d}.flow-node.active .ico{color:var(--brand)}.flow-node.active .v{color:var(--brand-dark)}.flow-node.active.energy-grid{background:var(--energy-grid-soft);border-color:#2274c04d}.flow-node.active.energy-grid .ico{color:var(--energy-grid)}.flow-node.active.energy-grid .v{color:var(--energy-grid-dark)}.flow-node.active.energy-solar{background:var(--energy-solar-soft);border-color:#f4b12b66}.flow-node.active.energy-solar .ico,.flow-node.active.energy-solar .v{color:var(--energy-solar-dark)}.row{display:flex;align-items:center}.row.between{justify-content:space-between}.row.gap-2{gap:8px}.row.gap-3{gap:12px}.col{display:flex;flex-direction:column}.col.gap-2{gap:8px}.col.gap-3{gap:12px}.col.gap-4{gap:16px}.text-muted{color:var(--muted)}.text-brand{color:var(--brand)}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.p-4{padding:16px}.detail-head{position:sticky;top:0;z-index:5;background:var(--light-chrome);color:#fff;display:flex;align-items:center;gap:12px;padding:14px 14px 10px;border-bottom:1px solid var(--brand-dark)}.detail-head .h1,.detail-head .h2,.detail-head .h3{color:#fff}.detail-head .cap,.detail-head .cap.mono{color:#ffffffb3}.detail-head .back{width:32px;height:32px;border-radius:50%;background:#ffffff24;border:1px solid rgba(255,255,255,.22);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex:none}.detail-head .iconbtn{background:#ffffff24;border-color:#ffffff38;color:#fff}.empty{text-align:center;padding:32px 20px;color:var(--muted)}.empty .ico{width:48px;height:48px;border-radius:50%;background:var(--surface-2);border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px;color:var(--muted-2)}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.skel{position:relative;overflow:hidden;background:var(--surface-2);border:1px solid var(--line);border-radius:8px}.skel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:skel-sheen 1.25s ease-in-out infinite}.skel-line{height:13px;border-radius:6px}.skel-chart{height:140px;border-radius:10px}@keyframes skel-sheen{to{transform:translate(100%)}}@media (prefers-reduced-motion: reduce){.skel:after{animation:none}}@keyframes fresh-pulse{0%,to{box-shadow:0 0 0 3px #3da56b2e}50%{box-shadow:0 0 0 5px #3da56b0d}}.toast{position:absolute;bottom:90px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:10px 14px;border-radius:10px;font-size:var(--t-label);font-weight:500;z-index:50;box-shadow:0 8px 24px #00000040;display:inline-flex;align-items:center;gap:8px;animation:toastIn .25s ease}@keyframes toastIn{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}.gate{padding:20px 18px}.gate .hero{background:radial-gradient(80% 60% at 0% 0%,rgba(31,115,184,.1) 0%,transparent 70%),linear-gradient(180deg,#fff,#f4f8ff);border:1px solid rgba(31,115,184,.18);border-radius:18px;padding:18px}.checklist{display:flex;flex-direction:column;gap:8px;margin-top:14px}.check-row{display:grid;grid-template-columns:24px 1fr;align-items:start;gap:12px;padding:10px 0}.check-circle{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--line-2);background:#fff;display:flex;align-items:center;justify-content:center;margin-top:1px}.check-circle.done{background:var(--brand);border-color:var(--brand);color:#fff}.check-circle.active{border-color:var(--brand);color:var(--brand)}.check-circle.active:after{content:"";width:8px;height:8px;border-radius:50%;background:var(--brand);animation:pulse 1.4s ease-in-out infinite}.tick{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--brand);margin-left:6px;vertical-align:middle;animation:tick 2s ease-in-out infinite}@keyframes tick{0%,to{opacity:1;box-shadow:0 0 #2e8b5a66}50%{opacity:.6;box-shadow:0 0 0 5px #2e8b5a00}}.shell{width:100%;max-width:430px;height:100dvh;margin:0 auto;background:var(--cw-canvas);display:flex;flex-direction:column;position:relative;overflow:hidden}@media (min-width: 460px){#root{display:flex;align-items:center;justify-content:center}.shell{height:min(900px,100dvh);border-radius:24px;box-shadow:0 1px 1px #00000014,0 6px 14px #0000001a,0 30px 60px #0000002e;border:1px solid #DDD}}.app{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--cw-canvas);position:relative;scrollbar-width:thin}.app::-webkit-scrollbar{width:4px}.app::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.center-screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:32px 24px;text-align:center}.center-screen .spinner{border-color:#2e8b5a4d;border-top-color:var(--brand);width:22px;height:22px}.screen-pad{padding:18px}
