@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/fonts/InterVariable.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:100 900;font-display:swap;src:url(/fonts/InterVariable-Italic.woff2) format("woff2")}:root{--canvas: #F9F9FB;--bg: #FFFFFF;--surface: #F4F4F6;--surface-2: #E9E9EC;--hairline: #E6E6EA;--ink: #1D1D1F;--ink-2: #3A3A3C;--ink-muted: #636367;--ink-faint: #8E8E93;--border: #D6D6DB;--border-strong:#C4C4C9;--sky: #5AC8FA;--sky-soft: #ECF1F6;--sky-pale: #F4F7FA;--ocean: #0B6BB5;--sea: #0A4F86;--sea-deep: #073A63;--nav: #0A4F86;--nav-hover: #073A63;--accent: var(--sea);--accent-hover:var(--sea-deep);--sea-wash: #ECF1F6;--sea-line: #CAD6E4;--sea-rail: var(--sea);--rail-active: inset 2px 0 0 0 var(--sea-rail);--rail-sky: inset 2px 0 0 0 var(--sky);--ok: #16A34A;--ok-bg: #ECFDF3;--ok-border: #BBF7D0;--ok-ink: #15803D;--warn: #D97706;--warn-bg: #FFFBEB;--warn-border: #FDE68A;--warn-ink: #B45309;--err: #DC2626;--err-bg: #FEF2F2;--err-border: #FECACA;--err-ink: #B91C1C;--blue: #0A84FF;--blue-press: #0071E3;--gradient-sea: linear-gradient(180deg, #0B6BB5 0%, #0A4F86 52%, #073A63 100%);--gradient-mark: linear-gradient(135deg, #5AC8FA, #0071E3);--gradient-side: radial-gradient(120% 42% at 50% 0%, rgb(10 132 255 / .1) 0%, rgb(10 132 255 / 0) 58%), linear-gradient(180deg, #16181D 0%, #0B0D11 100%);--radius-lg: 10px;--radius: 8px;--radius-md: 6px;--radius-sm: 4px;--radius-xs: 3px;--radius-pill: 999px;--focus-ring: 0 0 0 3px rgb(10 132 255 / .3);--focus-ring-onnavy: 0 0 0 3px rgb(90 200 250 / .45);--shadow-xs: 0 1px 1px 0 rgb(17 24 39 / .04);--shadow-sm: 0 1px 2px 0 rgb(17 24 39 / .06), 0 0 0 1px rgb(17 24 39 / .02);--shadow-md: 0 2px 4px -1px rgb(17 24 39 / .08), 0 1px 2px -1px rgb(17 24 39 / .05);--shadow-lg: 0 8px 16px -4px rgb(17 24 39 / .1), 0 2px 4px -2px rgb(17 24 39 / .06);--shadow-xl: 0 16px 32px -8px rgb(17 24 39 / .14), 0 4px 8px -4px rgb(17 24 39 / .08);--ease-apple: cubic-bezier(.2, .7, .2, 1);--font-sans: "Söhne", "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "Söhne Mono", ui-monospace, "SF Mono", "SFMono-Regular", Menlo, Consolas, monospace;--fw-medium: 510;--fw-semibold: 590;--fw-bold: 680}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}html{scrollbar-gutter:stable}body{background:var(--canvas);color:var(--ink);font-family:var(--font-sans);font-size:13.5px;line-height:1.5;letter-spacing:-.006em;font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}table,.tbl,.mono,.kpi .value,.dl dd{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}::selection{background:var(--sea-wash);color:var(--ink)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:3px solid var(--canvas)}::-webkit-scrollbar-thumb:hover{background:var(--ink-faint)}.ico{width:18px;height:18px;display:block;flex:none}.ico-sm{width:15px;height:15px;display:inline-block;flex:none;vertical-align:-2px}.full-center{display:flex;align-items:center;justify-content:center;height:100%}.spinner{width:28px;height:28px;border-radius:50%;border:3px solid var(--surface-2);border-top-color:var(--sea);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shell{display:grid;grid-template-columns:256px 1fr;min-height:100vh}.sidebar{background:var(--gradient-side);color:#fff;padding:18px 12px 12px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 20px}.brand .mark{width:30px;height:30px;flex:none}.brand .name{font-weight:600;letter-spacing:-.02em;font-size:17px;color:var(--ink)}.brand .sub{font-size:11px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.sidebar .brand .name{color:#fff}.sidebar .brand .sub{color:#ffffff8c}.nav-link{display:flex;align-items:center;gap:11px;padding:8px 11px;border-radius:var(--radius-md);color:#fff9;font-weight:var(--fw-medium);font-size:13px;letter-spacing:-.006em;transition:background .14s var(--ease-apple),color .14s var(--ease-apple),box-shadow .14s var(--ease-apple)}.nav-link:hover{background:#ffffff0f;color:#fff}.nav-link.active{background:#ffffff14;color:#fff;font-weight:var(--fw-semibold);box-shadow:var(--rail-sky),inset 0 0 0 1px #ffffff0f}.nav-link.disabled{opacity:.4;cursor:not-allowed}.nav-link.sm{font-size:13px}.nav-link:focus-visible{outline:none;box-shadow:var(--focus-ring-onnavy)}.nav-link .ico{opacity:.92}.nav-section{color:#ffffff57;font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;font-weight:var(--fw-semibold);padding:16px 12px 5px}.site-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}.site-head .page-title{margin:0}.site-tabs{display:inline-flex;gap:3px;padding:5px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-pill)}.site-tab{display:inline-grid;place-items:center;padding:8px 18px;font-size:14.5px;font-weight:var(--fw-semibold);line-height:1;color:var(--ink-muted);border-radius:var(--radius-pill);white-space:nowrap;transition:color .15s var(--ease-apple),background .15s var(--ease-apple),box-shadow .15s var(--ease-apple)}.site-tab>span{grid-area:1 / 1}.site-tab:hover{color:var(--ink)}.site-tab.active{color:var(--sea);background:var(--bg);box-shadow:var(--shadow-sm)}.site-tab:focus-visible{outline:none;box-shadow:0 0 0 3px #0a84ff59}.sidebar .faint{color:#ffffff73}.side-foot{margin-top:auto;display:flex;flex-direction:column;gap:3px;padding-top:14px}.side-note{color:#ffffff6b;font-size:11px;padding:4px 11px 10px}.side-profile{position:relative;border-top:1px solid rgb(255 255 255 / .09);padding-top:12px}.profile-trigger{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;background:#ffffff0d;border:1px solid rgb(255 255 255 / .1);border-radius:10px;cursor:pointer;color:#fff;text-align:left;font:inherit;transition:background .15s var(--ease-apple),border-color .15s var(--ease-apple)}.profile-trigger:hover,.profile-trigger.open{background:#ffffff1a;border-color:#ffffff2e}.profile-trigger:focus-visible{outline:none;box-shadow:0 0 0 3px #5ac8fa80}.profile-id{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.profile-id .profile-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-id .profile-role{font-size:11px;color:#ffffff8c;text-transform:capitalize}.profile-trigger .chev{color:#ffffff80}.profile-menu{position:absolute;bottom:calc(100% + 10px);left:0;right:0;z-index:40;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);box-shadow:var(--shadow-xl);padding:6px;color:var(--ink);animation:menu-pop .16s var(--ease-apple)}@keyframes menu-pop{0%{opacity:0;transform:translateY(6px) scale(.98)}}.profile-menu-head{display:flex;align-items:center;gap:11px;padding:10px 10px 9px}.profile-menu-id{min-width:0;display:flex;flex-direction:column;gap:1px}.profile-menu-id .profile-name{font-weight:600;font-size:14px;letter-spacing:-.01em}.profile-menu-id .profile-mail{font-size:12px;color:var(--ink-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-menu-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:0 6px 4px;padding:8px 10px;background:var(--surface);border-radius:var(--radius-md);font-size:12px;color:var(--ink-muted)}.role-tag{text-transform:capitalize;font-weight:var(--fw-semibold);font-size:11px;color:var(--sea);background:var(--sea-wash);border:1px solid var(--sea-line);padding:2px 8px;border-radius:var(--radius-sm)}.profile-menu-sep{height:1px;background:var(--hairline);margin:5px 8px}.profile-menu-item{width:100%;display:flex;align-items:center;gap:9px;padding:9px 10px;border:none;background:none;border-radius:var(--radius-md);font:inherit;font-size:13.5px;font-weight:500;color:var(--ink-2);cursor:pointer;text-align:left;transition:background .12s var(--ease-apple),color .12s}.profile-menu-item:hover{background:var(--surface);color:var(--ink)}.profile-menu-item.danger{color:var(--err-ink)}.profile-menu-item.danger:hover{background:var(--err-bg)}.avatar{width:30px;height:30px;border-radius:50%;flex:none;background:var(--gradient-mark);color:#fff;display:grid;place-items:center;font-weight:600;font-size:12px}.avatar.lg{width:38px;height:38px;font-size:14px}.main{display:flex;flex-direction:column;min-width:0;background:var(--canvas)}.content{padding:32px 36px 44px;width:100%}@media (max-width: 980px){.content{padding:22px 18px 36px}}.page-title{font-size:25px;font-weight:var(--fw-bold);letter-spacing:-.022em;margin:0 0 4px;color:var(--ink)}.page-sub{color:var(--ink-muted);margin:0 0 22px;font-size:14px;letter-spacing:-.006em}.grid{display:grid;gap:16px}.kpis{grid-template-columns:repeat(4,1fr)}@media (max-width: 980px){.kpis{grid-template-columns:repeat(2,1fr)}.shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}}.card{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}.card.pad-lg{padding:24px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-head h3{margin:0;font-size:13.5px;font-weight:var(--fw-semibold);letter-spacing:-.008em;color:var(--ink)}.card-head .hint{color:var(--ink-faint);font-size:12px}.kpi .label{color:var(--ink-muted);font-size:12px;font-weight:var(--fw-medium);letter-spacing:0}.kpi .value{font-size:29px;font-weight:var(--fw-bold);margin-top:6px;letter-spacing:-.022em;color:var(--ink);font-variant-numeric:tabular-nums}.kpi .delta{font-size:12px;margin-top:4px;color:var(--ink-faint)}.kpi .delta.up{color:var(--ok)}.kpi .ico-badge{width:36px;height:36px;border-radius:var(--radius-md);display:grid;place-items:center;background:var(--sea-wash);color:var(--sea);box-shadow:inset 0 0 0 1px var(--sea-line)}.kpi-top{display:flex;align-items:flex-start;justify-content:space-between}.pill{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:var(--radius-sm);font-size:11.5px;font-weight:var(--fw-semibold);letter-spacing:-.002em;border:1px solid transparent}.pill .dot{width:7px;height:7px;border-radius:50%;background:currentColor}.pill.online{color:var(--ok-ink);background:var(--ok-bg);border-color:var(--ok-border)}.pill.offline{color:var(--ink-muted);background:var(--surface);border-color:var(--hairline)}.pill.error{color:var(--err-ink);background:var(--err-bg);border-color:var(--err-border)}.pill.warn{color:var(--warn-ink);background:var(--warn-bg);border-color:var(--warn-border)}.pill.connecting{color:var(--ocean);background:var(--sky-soft);border-color:var(--sea-line)}.pill.neutral{color:var(--ink-muted);background:var(--surface);border-color:var(--hairline)}.tag{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:var(--fw-semibold);background:var(--surface);color:var(--ink-muted);border:1px solid var(--hairline);margin-right:5px}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse}table.tbl th{text-align:left;color:var(--ink-faint);font-weight:var(--fw-semibold);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;padding:0 14px 11px;border-bottom:1px solid var(--hairline)}table.tbl td{padding:12px 14px;border-bottom:1px solid var(--hairline);color:var(--ink);font-variant-numeric:tabular-nums}table.tbl tr.row{cursor:pointer;transition:background .12s var(--ease-apple)}table.tbl tr.row:hover td{background:var(--surface)}table.tbl tr.row.sel td{background:var(--sea-wash)}table.tbl tr.row.sel td:first-child{box-shadow:var(--rail-active)}table.tbl tr:last-child td{border-bottom:none}.cell-strong{font-weight:600}.cell-dim{color:var(--ink-muted)}.mono{font-family:var(--font-mono);font-size:12.5px}.chart{width:100%;display:block}.chart .grid-line{stroke:var(--hairline);stroke-width:1}.chart .axis-label{fill:var(--ink-faint);font-size:10px}.legend{display:flex;gap:18px;align-items:center;margin-top:4px}.legend .item{display:flex;align-items:center;gap:7px;color:var(--ink-muted);font-size:12px}.legend .swatch{width:11px;height:11px;border-radius:3px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 15px;border-radius:var(--radius-md);font-weight:var(--fw-semibold);font-size:13.5px;letter-spacing:-.006em;border:1px solid var(--border);background:var(--bg);color:var(--ink);cursor:pointer;box-shadow:var(--shadow-xs);transition:background .15s var(--ease-apple),filter .15s,transform .04s,border-color .15s,box-shadow .15s}.btn:hover{background:var(--surface);border-color:var(--border-strong)}.btn:active{transform:translateY(.5px)}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn.primary{background:var(--sea);color:#fff;border-color:transparent;box-shadow:inset 0 1px #ffffff24,var(--shadow-sm)}.btn.primary:hover{background:var(--ocean)}.btn.ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--ink-muted)}.btn.ghost:hover{background:var(--surface);color:var(--ink)}.btn.primary.danger{background:var(--err)}.btn.primary.danger:hover{background:var(--err-ink)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.sm{padding:6px 11px;font-size:12.5px}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}.field label{font-size:13px;color:var(--ink-muted);font-weight:500}.input{padding:9px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);color:var(--ink);font-size:13.5px;outline:none;transition:border-color .15s,box-shadow .15s}.input::placeholder{color:var(--ink-faint)}.input:focus{border-color:var(--blue);box-shadow:var(--focus-ring)}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(120% 80% at 50% -10%,#eaf4fd,#eaf4fd00 55%),linear-gradient(180deg,#fbfbfd,#f3f7fb)}.login-card{width:100%;max-width:400px;box-shadow:var(--shadow-xl);border-radius:var(--radius-lg)}.login-card .brand{padding:0 0 22px}.login-hint{margin-top:16px;padding:11px 13px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--hairline);color:var(--ink-muted);font-size:12.5px}.login-hint code{color:var(--nav);background:var(--sky-soft);padding:1px 5px;border-radius:3px;font-family:var(--font-mono);font-size:11.5px}.error-banner{padding:10px 13px;border-radius:var(--radius-md);background:var(--err-bg);border:1px solid var(--err-border);color:var(--err-ink);font-size:13px;margin-bottom:16px}.row-2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}@media (max-width: 900px){.row-2{grid-template-columns:1fr}}.section-gap{margin-top:16px}.muted{color:var(--ink-muted)}.faint{color:var(--ink-faint)}.flex{display:flex;align-items:center;gap:10px}.flex-between{display:flex;align-items:center;justify-content:space-between}.stack{display:flex;flex-direction:column;gap:4px}.back-link{color:var(--ink-muted);font-size:13px;display:inline-flex;gap:6px;align-items:center;margin-bottom:14px}.back-link:hover{color:var(--ink)}.dl{display:grid;grid-template-columns:140px 1fr;gap:11px 16px}.dl dt{color:var(--ink-faint);font-size:13px}.dl dd{margin:0;font-weight:500;color:var(--ink)}.gauge-track{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:10px}.gauge-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--sky),var(--sea))}.editor{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start}@media (max-width: 1080px){.editor{grid-template-columns:1fr}}.editor-canvas{padding:12px}.editor-canvas .konvajs-content{border-radius:6px;overflow:hidden;box-shadow:inset 0 0 0 1px var(--hairline)}.editor-hint{margin-top:10px;font-size:12.5px;color:var(--ink-muted)}.editor-panel{display:flex;flex-direction:column;gap:14px;position:sticky;top:20px}.feature-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px}.feature-tab{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:var(--radius-md);border:1px solid var(--hairline);background:var(--bg);color:var(--ink-muted);font-weight:600;font-size:13px;cursor:pointer;transition:background .15s var(--ease-apple),border-color .15s,color .15s}.feature-tab:hover{background:var(--surface)}.feature-tab.active{border-color:var(--sea-line);color:var(--ink);background:var(--sea-wash);box-shadow:var(--rail-active)}.feature-tab .swatch{width:10px;height:10px;border-radius:3px;flex:none}.toggle-row{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink-2);cursor:pointer;padding:2px 0}.toggle-row input{width:16px;height:16px;accent-color:var(--sea);cursor:pointer}.tool-row{display:flex;gap:8px}.grid-fields{display:flex;gap:12px}.grid-fields label{font-size:12px;color:var(--ink-muted);display:flex;flex-direction:column;gap:5px;flex:1}.input.sm{padding:7px 9px;font-size:13px}.shape-list{border-top:1px solid var(--hairline);padding-top:12px}.shape-list-head{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);font-weight:600;margin-bottom:6px}.shape-row{display:flex;align-items:center;justify-content:space-between;padding:7px 8px;border-radius:6px;font-size:13px}.shape-row.sel,.shape-row:hover{background:var(--surface)}.shape-row .mono{font-size:12.5px;color:var(--ink-2)}.row-actions{display:flex;gap:12px}.linkbtn{background:none;border:none;padding:0;font-size:12px;font-weight:600;color:var(--nav);cursor:pointer}.linkbtn:hover{text-decoration:underline}.linkbtn.danger{color:var(--err)}.flip{transform:rotate(180deg)}.form-row{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}.form-row .field{margin-bottom:0;flex:1 1 180px}.field>span{font-size:13px;color:var(--ink-muted);font-weight:500}.field input,.field select{padding:9px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);color:var(--ink);font-size:13.5px;outline:none;transition:border-color .15s,box-shadow .15s}.field input::placeholder{color:var(--ink-faint)}.field input:focus,.field select:focus{border-color:var(--blue);box-shadow:var(--focus-ring)}.field-actions{display:flex;gap:8px;align-items:flex-end}.site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-top:8px}.site-card{text-align:left;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:15px 18px;cursor:pointer;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden;transition:box-shadow .16s var(--ease-apple),border-color .16s,transform .16s var(--ease-apple)}.site-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-1px)}.site-card:hover:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--sea-rail)}.site-card:active{transform:translateY(0)}.site-card-top{display:flex;align-items:center;justify-content:space-between}.site-name{font-weight:var(--fw-semibold);font-size:14.5px;color:var(--ink);letter-spacing:-.012em}.site-city{color:var(--ink-muted);font-size:13px}.site-stats{display:flex;gap:14px;font-size:13px;color:var(--ink-muted);margin-top:6px;flex-wrap:wrap}.site-stats b{color:var(--ink)}.site-stats .ok{color:var(--ok)}.warn-text{color:var(--warn-ink)}.stack-list{display:flex;flex-direction:column;gap:8px}.pending-card{border-color:var(--sky);background:var(--sky-pale)}.pending-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 12px;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius-md)}.pending-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.empty-note{color:var(--ink-muted);font-size:13.5px;line-height:1.55}.code-row{display:flex;align-items:center;gap:12px;padding:8px 12px;border:1px solid var(--hairline);border-radius:var(--radius-md)}.code-chip{font-size:15px;font-weight:600;letter-spacing:.08em;color:var(--ink)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0712204d;backdrop-filter:saturate(1.25) blur(8px);-webkit-backdrop-filter:saturate(1.25) blur(8px);display:grid;place-items:center;z-index:50;padding:20px}.modal{background:var(--bg);border-radius:var(--radius-lg);padding:24px 26px;width:100%;max-width:440px;box-shadow:var(--shadow-xl);border:1px solid var(--hairline);animation:menu-pop .18s var(--ease-apple)}.modal h3{margin:0;font-size:16px;font-weight:var(--fw-semibold);letter-spacing:-.014em}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.dialog-overlay{z-index:100}.code-display{font-size:32px;font-weight:700;letter-spacing:.14em;text-align:center;padding:22px 16px;margin:16px 0 12px;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius);color:var(--sea);font-family:var(--font-mono)}.dev-frame{display:flex;flex-direction:column;min-height:100vh;background:var(--canvas)}.dev-topbar{min-height:46px;flex:none;display:flex;align-items:center;gap:16px;padding:0 18px;background:#0d1b2a;color:#fff;position:sticky;top:0;z-index:30}.dev-badge{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#5ac8fa}.dev-switch{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap;justify-content:flex-end;padding:6px 0}.dev-switch-link{font-size:12.5px;font-weight:600;color:#fff9;padding:5px 11px;border-radius:6px}.dev-switch-link:hover{background:#ffffff1a;color:#fff}.dev-switch-link.on{background:#5ac8fa2e;color:#fff}.dev-plan{width:100%;height:100%;display:block;background:#fbfbfd}.dev-plan-frame{border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden;background:#fbfbfd;box-shadow:var(--shadow-xs);aspect-ratio:1000 / 600}.dev-plan-frame.sm{max-width:560px}.dev-swatch{width:10px;height:10px;border-radius:3px;display:inline-block;flex:none}.dev-dot{width:9px;height:9px;border-radius:50%;flex:none;display:inline-block}.dev-dot.online{background:var(--ok)}.dev-dot.offline{background:var(--ink-faint)}.dev-dot.error{background:var(--err)}.dev-toggle{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink-2);cursor:pointer;padding:7px 0}.dev-toggle input{width:16px;height:16px;accent-color:var(--sea);cursor:pointer;flex:none}.dev-shape-head{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);font-weight:700;margin:16px 0 4px}.dev-shape-row{display:flex;align-items:center;justify-content:space-between;padding:7px 8px;border-radius:6px;font-size:13px}.dev-shape-row:hover{background:var(--surface)}.dev-grid-fields{display:flex;gap:12px;margin-top:12px}.dev-grid-fields label{font-size:12px;color:var(--ink-muted);display:flex;flex-direction:column;gap:5px;flex:1}.dev-ws{flex:1;display:grid;grid-template-columns:264px 1fr 320px;min-height:0}@media (max-width: 1100px){.dev-ws{grid-template-columns:220px 1fr}.dev-ws-inspector{display:none}}.dev-ws-rail{border-right:1px solid var(--hairline);background:var(--bg);display:flex;flex-direction:column;min-height:0}.dev-rail-head{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;font-weight:600;font-size:15px}.dev-rail-list{overflow-y:auto;padding:0 10px 12px;display:flex;flex-direction:column;gap:4px}.dev-site-row{text-align:left;background:transparent;border:1px solid transparent;border-radius:6px;padding:11px 12px;cursor:pointer;display:flex;flex-direction:column;gap:2px;transition:background .12s,border-color .12s}.dev-site-row:hover{background:var(--surface)}.dev-site-row.sel{background:var(--sky-soft);border-color:var(--sea-line)}.dev-site-row-name{font-weight:600;font-size:14px;color:var(--ink)}.dev-site-row-sub{font-size:12px;color:var(--ink-muted)}.dev-site-row-stats{display:flex;gap:10px;font-size:11.5px;color:var(--ink-muted);margin-top:4px}.dev-site-row-stats b{color:var(--ink)}.dev-site-row-stats .ok{color:var(--ok)}.dev-ws-stage{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--canvas)}.dev-stage-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--hairline);flex-wrap:wrap}.dev-stage-title{display:flex;align-items:baseline;gap:10px;font-size:15px}.dev-mode-chips{display:flex;gap:6px;flex-wrap:wrap}.dev-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:999px;cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--ink-muted);font-size:12.5px;font-weight:600;transition:background .12s,border-color .12s,color .12s}.dev-chip:hover{background:var(--surface)}.dev-chip.active{background:var(--sky-soft);color:var(--ink);border-color:var(--sea)}.dev-stage-canvas{flex:1;min-height:0;padding:20px;display:flex}.dev-stage-canvas .dev-plan{border:1px solid var(--hairline);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.dev-stage-foot{padding:0 20px 16px;font-size:12.5px}.dev-ws-inspector{border-left:1px solid var(--hairline);background:var(--bg);display:flex;flex-direction:column;min-height:0}.dev-insp-head{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--hairline);font-weight:600;font-size:14px}.dev-insp-scroll{overflow-y:auto;padding:14px 16px}.dev-insp-device{padding:12px 0;border-bottom:1px solid var(--hairline)}.dev-insp-device:last-child{border-bottom:none}.dev-insp-device-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.dev-cam-row{width:100%;text-align:left;display:flex;align-items:center;gap:9px;padding:8px 10px;margin-top:6px;background:var(--surface);border:1px solid transparent;border-radius:6px;cursor:pointer;font-size:13px;color:var(--ink-2)}.dev-cam-row:hover{background:var(--surface-2)}.dev-cam-row.sel{background:var(--sky-soft);border-color:var(--sea-line);color:var(--ink)}.dev-tabs-page{flex:1;padding:28px;max-width:1100px;width:100%;margin:0 auto}.dev-tabs-page.wide{max-width:1360px}.dev-tabs-family{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-bottom:22px}.dev-tabs-family-link{min-height:66px;display:flex;flex-direction:column;justify-content:center;gap:3px;padding:10px 12px;border:1px solid var(--hairline);border-radius:6px;background:var(--bg);color:var(--ink-muted);box-shadow:var(--shadow-xs);transition:background .12s,border-color .12s,color .12s}.dev-tabs-family-link:hover{background:var(--surface);color:var(--ink)}.dev-tabs-family-link.active{background:var(--sky-soft);border-color:var(--sea-line);color:var(--ink)}.dev-tabs-family-link b{font-size:13.5px;color:var(--ink)}.dev-tabs-family-link span{font-size:12px;line-height:1.35}.dev-tabbar{display:flex;gap:4px;border-bottom:1px solid var(--hairline);margin-bottom:20px}.dev-tab{display:inline-flex;align-items:center;gap:7px;padding:11px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:14px;font-weight:600;color:var(--ink-muted);cursor:pointer;transition:color .12s,border-color .12s}.dev-tab:hover{color:var(--ink)}.dev-tab.active{color:var(--sea);border-bottom-color:var(--sea)}.dev-tab-body{min-height:300px}.dev-subtabs{display:flex;gap:8px;flex-wrap:wrap}.dev-tabs-version-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}.dev-tabs-version-head.compact{align-items:center;margin-bottom:14px}.dev-tabs-version-head h2{margin:0 0 4px;font-size:20px;letter-spacing:-.02em}.dev-tabs-split-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:16px;align-items:start}.dev-tabs-site-rail,.dev-tabs-panel{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);min-width:0}.dev-tabs-rail-row{width:100%;display:flex;flex-direction:column;gap:2px;text-align:left;padding:11px 12px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--ink);cursor:pointer}.dev-tabs-rail-row:hover{background:var(--surface)}.dev-tabs-rail-row.sel{background:var(--sky-soft);border-color:var(--sea-line)}.dev-tabs-rail-meta{display:flex;gap:9px;flex-wrap:wrap;margin-top:4px;color:var(--ink-muted);font-size:11.5px}.dev-tabs-rail-meta b{color:var(--ink)}.dev-tabs-rail-meta .ok{color:var(--ok)}.dev-tabs-split-main{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);min-width:0}.dev-tabs-split-content{display:grid;grid-template-columns:minmax(320px,430px) minmax(0,1fr);gap:16px;align-items:start}.dev-tabs-plan-side{position:sticky;top:70px;display:flex;flex-direction:column;gap:10px;min-width:0}.dev-tabs-side-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;color:var(--ink-muted);font-size:12px}.dev-tabs-side-metrics span{padding:9px;background:var(--surface);border:1px solid var(--hairline);border-radius:6px}.dev-tabs-side-metrics b{display:block;color:var(--ink);font-size:14px}.dev-tabs-work-side{min-width:0}.dev-check-stack{display:flex;flex-direction:column;gap:10px}.dev-check-line{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--hairline)}.dev-check-line:last-child{border-bottom:none}.dev-setup-tabs{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:16px}.dev-setup-tab{min-height:48px;display:flex;align-items:center;gap:9px;padding:9px 11px;border:1px solid var(--hairline);border-radius:6px;background:var(--bg);color:var(--ink-muted);font-weight:700;cursor:pointer;text-align:left}.dev-setup-tab span{width:22px;height:22px;display:grid;place-items:center;border-radius:6px;background:var(--surface);color:var(--ink-muted);border:1px solid var(--hairline);font-size:12px}.dev-setup-tab.done span{background:var(--ok-bg);color:var(--ok-ink);border-color:var(--ok-border)}.dev-setup-tab.active,.dev-setup-tab:hover{background:var(--sky-soft);border-color:var(--sea-line);color:var(--ink)}.dev-setup-tab.active span{background:var(--sea);color:#fff;border-color:var(--sea)}.dev-setup-grid{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:16px;align-items:start}.dev-setup-stage,.dev-setup-summary{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);min-width:0}.dev-setup-stage h2{margin:0 0 16px;font-size:21px;letter-spacing:-.02em}.dev-setup-fields{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.dev-setup-fields label{display:flex;flex-direction:column;gap:6px;color:var(--ink-muted);font-size:13px;font-weight:600}.dev-publish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.dev-publish-card{padding:14px;background:var(--surface);border:1px solid var(--hairline);border-radius:6px;display:flex;flex-direction:column;gap:2px}.dev-publish-card b{font-size:26px;line-height:1;color:var(--ink)}.dev-publish-card span{color:var(--ink-muted);font-size:12px}.dev-publish-card.warn{background:var(--warn-bg);border-color:var(--warn-border)}.dev-publish-card.warn b{color:var(--warn-ink)}.dev-cal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:14px}.dev-cal-grid{display:grid;grid-template-columns:260px minmax(0,1fr) 300px;gap:16px;align-items:start}.dev-camera-tabs{display:flex;flex-direction:column;gap:7px}.dev-camera-tab{width:100%;display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:9px;padding:9px 10px;border:1px solid var(--hairline);border-radius:6px;background:var(--canvas);color:var(--ink-2);text-align:left;cursor:pointer}.dev-camera-tab:hover{background:var(--surface)}.dev-camera-tab.active{background:var(--sky-soft);border-color:var(--sea-line);color:var(--ink)}.dev-camera-tab b{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint)}.dev-cal-plan,.dev-floor-shell{min-width:0}.dev-floor-builder{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:18px;align-items:start;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;min-width:0}.dev-floor-panel,.dev-floor-stage-card{background:transparent;border:0;border-radius:0;box-shadow:none;min-width:0}.dev-floor-panel{padding:0}.dev-floor-tools{position:sticky;top:64px;padding-left:18px;border-left:1px solid var(--hairline)}.dev-floor-tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.dev-floor-tool{min-height:74px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:1px solid var(--hairline);border-radius:6px;background:var(--canvas);color:var(--ink-muted);cursor:pointer;font-weight:750;transition:background .12s,border-color .12s,color .12s}.dev-floor-tool:hover{background:var(--surface);color:var(--ink)}.dev-floor-tool.active{background:var(--sea-wash);color:var(--ink);border-color:var(--sea-line);box-shadow:var(--rail-active)}.dev-floor-tool-icon{width:26px;height:26px;display:grid;place-items:center;border-radius:6px;background:var(--bg);border:1px solid var(--hairline);color:var(--sea);font-family:var(--font-mono);font-size:13px;font-weight:800}.dev-floor-action-grid{display:grid;grid-template-columns:1fr;gap:7px}.dev-floor-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.dev-floor-drop{width:100%;min-height:150px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:18px;border:1px dashed var(--border-strong);border-radius:6px;background:var(--canvas);color:var(--ink-muted);cursor:pointer;text-align:center}.dev-floor-drop:hover{background:var(--surface);color:var(--ink)}.dev-floor-drop:disabled{opacity:.65;cursor:wait}.dev-floor-drop b{color:var(--ink)}.dev-floor-drop span{max-width:190px;font-size:12.5px;line-height:1.4}.dev-floor-stage-card{padding:0}.dev-floor-stage-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:12px}.dev-floor-stage-head h3{margin:0 0 2px;font-size:15px;letter-spacing:-.01em}.dev-floor-stage-head span{color:var(--ink-muted);font-size:12.5px}.dev-floor-mini-kpis{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}.dev-floor-mini-kpis span{padding:5px 8px;border-radius:6px;background:var(--surface);border:1px solid var(--hairline);color:var(--ink-muted);font-size:12px;font-weight:650}.dev-floor-canvas{width:100%;aspect-ratio:1000 / 600;display:block;border:1px solid var(--hairline);border-radius:6px;background:#fbfbfd;box-shadow:inset 0 0 0 1px #ffffffa6;touch-action:none}.dev-floor-canvas.readonly{max-width:640px}.dev-floor-preview{width:100%;max-width:640px;border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden;background:#fbfbfd}.dev-floor-corner-list{display:grid;grid-template-columns:1fr 1fr;gap:7px;max-height:168px;overflow:auto;padding-right:2px}.dev-floor-corner{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px;border:1px solid var(--hairline);border-radius:6px;background:var(--canvas);color:var(--ink-muted);cursor:pointer;font-size:12px}.dev-floor-corner:hover:not(:disabled){background:var(--surface);color:var(--ink)}.dev-floor-corner:disabled{cursor:default;opacity:.7}.dev-floor-corner b{width:20px;height:20px;display:grid;place-items:center;flex:none;border-radius:4px;background:var(--sky-soft);color:var(--sea);font-size:11px}.dev-floor-corner span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dev-floor-save-row{margin-top:16px}.dev-canvas-page{flex:1;position:relative;min-height:0;background:#eef1f5;overflow:hidden}.dev-cv-topbar{position:absolute;top:14px;left:14px;right:14px;z-index:10;height:50px;display:flex;align-items:center;gap:16px;padding:0 12px 0 16px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--hairline);border-radius:10px;box-shadow:var(--shadow-md)}.dev-cv-icon{font-size:18px;color:var(--sea)}.dev-cv-select{font-size:15px;font-weight:600;border:none;background:none;color:var(--ink);cursor:pointer;outline:none;padding:4px}.dev-cv-summary{font-size:12.5px;margin:0 auto 0 4px}.dev-cv-summary .ok{color:var(--ok)}.dev-cv-summary b{color:var(--ink)}.dev-cv-rail{position:absolute;top:84px;left:14px;z-index:10;display:flex;flex-direction:column;gap:6px;padding:8px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--hairline);border-radius:10px;box-shadow:var(--shadow-md)}.dev-cv-tool{width:42px;height:42px;border-radius:6px;border:1px solid transparent;background:transparent;cursor:pointer;display:grid;place-items:center;color:var(--ink-muted);transition:background .12s,color .12s}.dev-cv-tool:hover{background:var(--surface);color:var(--ink)}.dev-cv-tool.on{background:var(--sea-wash);color:var(--sea);border-color:var(--sea-line);box-shadow:var(--rail-active)}.dev-cv-glyph{font-size:19px;line-height:1}.dev-cv-stage{position:absolute;top:0;right:0;bottom:0;left:0;padding:78px 0 0;display:flex}.dev-cv-stage .dev-plan{background:transparent}.dev-cv-legend{position:absolute;bottom:14px;left:50%;transform:translate(-50%);z-index:10;display:flex;gap:16px;padding:8px 16px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--hairline);border-radius:999px;box-shadow:var(--shadow-md);font-size:12px;color:var(--ink-muted)}.dev-cv-legend-item{display:inline-flex;align-items:center;gap:6px}.dev-cv-drawer{position:absolute;top:84px;right:14px;bottom:14px;width:300px;z-index:10;background:var(--bg);border:1px solid var(--hairline);border-radius:10px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transform:translate(calc(100% + 20px));opacity:0;transition:transform .25s var(--ease-apple),opacity .2s;overflow:hidden}.dev-cv-drawer.open{transform:translate(0);opacity:1}.dev-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--hairline)}.dev-drawer-body{padding:14px 16px;overflow-y:auto}.dev-drawer-actions{display:flex;gap:8px;margin-top:14px}.dev-tip-list{margin:6px 0 0;padding-left:18px;font-size:12.5px;color:var(--ink-muted);line-height:1.7}.dev-ops-page{flex:1;padding:28px;width:100%;max-width:1360px;margin:0 auto}.dev-ops-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:18px}.dev-ops-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.dev-ops-metric{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-xs)}.dev-ops-metric .label{color:var(--ink-muted);font-size:12px;font-weight:600}.dev-ops-metric .value{margin-top:4px;font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.dev-ops-metric.ok .value{color:var(--ok-ink)}.dev-ops-metric.warn .value{color:var(--warn-ink)}.dev-ops-grid{display:grid;grid-template-columns:290px minmax(0,1fr) 300px;gap:16px;align-items:stretch}.dev-ops-panel{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);min-width:0}.dev-panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:700;margin-bottom:14px}.dev-ops-site-list{display:flex;flex-direction:column;gap:8px}.dev-ops-site{width:100%;text-align:left;border:1px solid var(--hairline);background:var(--canvas);border-radius:6px;padding:12px;cursor:pointer;transition:background .12s,border-color .12s,transform .05s}.dev-ops-site:hover{background:var(--surface)}.dev-ops-site.sel{border-color:var(--sea-line);background:var(--sky-soft)}.dev-ready{font-size:12px;font-weight:800;padding:2px 7px;border-radius:4px;background:var(--surface);color:var(--ink-muted)}.dev-ready.ok{background:var(--ok-bg);color:var(--ok-ink)}.dev-ready.warn{background:var(--warn-bg);color:var(--warn-ink)}.dev-ready.bad{background:var(--err-bg);color:var(--err-ink)}.dev-progress{display:block;height:6px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin:9px 0 7px}.dev-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--sky),var(--sea))}.dev-ops-tags{display:flex;flex-wrap:wrap;gap:8px;font-size:11.5px;color:var(--ink-muted)}.dev-ops-main-grid{display:grid;grid-template-columns:minmax(360px,1fr) 320px;gap:16px;align-items:start}.dev-rollout{display:flex;flex-direction:column;gap:10px}.dev-rollout-row{display:grid;grid-template-columns:minmax(120px,1fr) 92px 42px;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--hairline)}.dev-rollout-row:last-child{border-bottom:none}.dev-rollout-meter{height:8px;border-radius:999px;overflow:hidden;background:var(--surface-2)}.dev-rollout-meter span{display:block;height:100%;border-radius:inherit;background:var(--sea)}.dev-ops-task{display:flex;gap:11px;padding:12px 0;border-bottom:1px solid var(--hairline)}.dev-ops-task:last-of-type{border-bottom:none}.dev-task-dot{width:22px;height:22px;border-radius:6px;display:inline-grid;place-items:center;flex:none;font-size:12px;font-weight:800;border:1px solid var(--hairline)}.dev-task-dot.done{background:var(--ok-bg);color:var(--ok-ink);border-color:var(--ok-border)}.dev-task-dot.open{background:var(--warn-bg);color:var(--warn-ink);border-color:var(--warn-border)}.dev-ops-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.dev-wizard-page{flex:1;padding:28px;max-width:1180px;width:100%;margin:0 auto}.dev-wizard-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap}.dev-wizard-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0 10px}.dev-wizard-step{display:flex;align-items:center;gap:9px;text-align:left;padding:10px 12px;border-radius:6px;border:1px solid var(--hairline);background:var(--bg);color:var(--ink-muted);font-weight:700;cursor:pointer}.dev-wizard-step span{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;background:var(--surface);color:var(--ink-muted);font-size:12px}.dev-wizard-step.active{border-color:var(--sea-line);background:var(--sky-soft);color:var(--ink)}.dev-wizard-step.active span,.dev-wizard-step.done span{background:var(--sea);color:#fff}.dev-wizard-progress{height:7px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-bottom:16px}.dev-wizard-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--sky),var(--sea))}.dev-wizard-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;align-items:start}.dev-wizard-stage,.dev-wizard-side{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}.dev-wizard-stage h2{margin:0 0 16px;font-size:21px;letter-spacing:-.02em}.dev-step-kicker{color:var(--sea);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:800;margin-bottom:6px}.dev-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.dev-form-grid label{display:flex;flex-direction:column;gap:6px;color:var(--ink-muted);font-size:13px;font-weight:600}.dev-upload-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.dev-wizard-plan{height:360px;border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden;background:#fbfbfd}.dev-claim-grid{display:flex;flex-direction:column;gap:10px}.dev-claim-row,.dev-claim-code{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--hairline);border-radius:6px;background:var(--canvas)}.dev-claim-code .mono{font-size:16px;font-weight:800;color:var(--sea);letter-spacing:.06em}.dev-module-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.dev-module-row{display:grid;grid-template-columns:18px 12px 1fr;align-items:center;gap:10px;padding:13px;border:1px solid var(--hairline);border-radius:6px;background:var(--canvas);cursor:pointer}.dev-module-row input{width:16px;height:16px;accent-color:var(--sea)}.dev-module-row b{display:block;color:var(--ink)}.dev-module-row small{display:block;color:var(--ink-muted);font-size:12px;margin-top:2px}.dev-wizard-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.dev-wizard-checks{margin-top:16px;display:flex;flex-direction:column;gap:10px}.dev-check-row{display:flex;align-items:center;gap:10px;color:var(--ink-2);font-size:13px}.dev-field-page{flex:1;display:grid;grid-template-columns:260px minmax(360px,430px) 300px;gap:18px;align-items:center;justify-content:center;padding:28px;background:#eef1f5}.dev-field-queue,.dev-field-tools{align-self:stretch;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.dev-field-site{width:100%;display:flex;flex-direction:column;gap:2px;text-align:left;padding:12px;border:1px solid var(--hairline);border-radius:6px;background:var(--canvas);cursor:pointer;margin-bottom:8px}.dev-field-site.sel{background:var(--sky-soft);border-color:var(--sea-line)}.dev-phone-shell{width:100%;min-height:720px;border:10px solid #111827;border-radius:24px;overflow:hidden;background:var(--bg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column}.dev-phone-top{padding:18px 18px 12px;display:flex;justify-content:space-between;gap:14px;align-items:flex-start;border-bottom:1px solid var(--hairline)}.dev-phone-plan{height:300px;background:#f8fafc;border-bottom:1px solid var(--hairline)}.dev-phone-sheet{flex:1;padding:12px 14px 16px;background:var(--bg)}.dev-sheet-grabber{width:48px;height:5px;border-radius:999px;background:var(--surface-2);margin:0 auto 12px}.dev-phone-camera-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.dev-phone-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}.dev-phone-camera-list{display:flex;flex-direction:column;gap:6px}.dev-field-tools{display:flex;flex-direction:column;gap:8px}.dev-shopper-flow-page{flex:1;padding:24px;width:100%;max-width:1480px;margin:0 auto}.dev-shopper-flow-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:14px}.dev-shopper-flow-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.dev-shopper-flow-tabs{display:inline-flex;gap:4px;padding:4px;background:var(--surface);border:1px solid var(--hairline);border-radius:6px;margin-bottom:14px}.dev-shopper-flow-tab{min-width:136px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 13px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--ink-muted);font-weight:750;cursor:pointer}.dev-shopper-flow-tab span{width:10px;height:10px;border-radius:3px}.dev-shopper-flow-tab:hover{color:var(--ink);background:var(--bg)}.dev-shopper-flow-tab.active{color:var(--ink);background:var(--bg);border-color:var(--hairline);box-shadow:var(--shadow-xs)}.dev-shopper-flow-grid{display:grid;grid-template-columns:290px minmax(0,1fr) 300px;gap:14px;align-items:start}.dev-shopper-flow-panel,.dev-shopper-flow-stage-card{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);min-width:0}.dev-shopper-flow-stage-card{padding:12px}.dev-segmented{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;background:var(--surface);border:1px solid var(--hairline);border-radius:6px;margin-bottom:14px}.dev-segmented button{border:0;background:transparent;color:var(--ink-muted);border-radius:6px;padding:8px 10px;font-size:12.5px;font-weight:750;cursor:pointer}.dev-segmented button.active{background:var(--bg);color:var(--ink);box-shadow:var(--shadow-xs)}.dev-shopper-flow-range{display:flex;flex-direction:column;gap:7px;padding:12px 0;border-bottom:1px solid var(--hairline)}.dev-shopper-flow-range span{display:flex;justify-content:space-between;gap:10px;color:var(--ink-muted);font-size:12.5px}.dev-shopper-flow-range b{color:var(--ink);font-weight:700}.dev-shopper-flow-range input{accent-color:var(--sea)}.dev-shopper-flow-toggle-list{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:14px 0 4px}.dev-shopper-flow-toggle{display:flex;align-items:center;gap:8px;padding:8px 9px;border:1px solid var(--hairline);background:var(--canvas);border-radius:6px;color:var(--ink-2);font-size:12.5px;font-weight:650;cursor:pointer}.dev-shopper-flow-toggle input{accent-color:var(--sea)}.dev-shopper-flow-player{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center}.dev-shopper-flow-player input{accent-color:var(--sea);min-width:0}.dev-shopper-flow-player b{grid-column:1 / -1;text-align:center;color:var(--ink)}.dev-shopper-flow-map{position:relative;width:100%;aspect-ratio:1200 / 760;overflow:hidden;border:1px solid var(--hairline);border-radius:6px;background:#f8fafc;cursor:crosshair}.dev-shopper-flow-heat,.dev-shopper-flow-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.dev-shopper-flow-heat{z-index:1}.dev-shopper-flow-svg{z-index:2;pointer-events:none}.dev-shopper-flow-tooltip{position:absolute;z-index:4;pointer-events:none;transform:translateY(-50%);padding:7px 9px;background:#1d1d1fe0;color:#fff;border-radius:6px;font-size:12px;font-weight:750;white-space:nowrap;box-shadow:var(--shadow-md)}.dev-shopper-flow-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.dev-shopper-flow-summary div{padding:10px;background:var(--surface);border:1px solid var(--hairline);border-radius:6px}.dev-shopper-flow-summary span{display:block;color:var(--ink-muted);font-size:11.5px;font-weight:650}.dev-shopper-flow-summary b{display:block;color:var(--ink);font-size:16px;margin-top:2px}.dev-shopper-flow-camera-list,.dev-shopper-flow-content-list{display:flex;flex-direction:column;gap:8px}.dev-shopper-flow-camera{display:grid;grid-template-columns:16px 10px 1fr;align-items:center;gap:9px;padding:10px;border:1px solid var(--hairline);background:var(--canvas);border-radius:6px;cursor:pointer}.dev-shopper-flow-camera input{accent-color:var(--sea)}.dev-shopper-flow-camera b{display:block;color:var(--ink)}.dev-shopper-flow-camera small{display:block;color:var(--ink-muted);font-size:11.5px;margin-top:1px}.dev-shopper-flow-content-list button{text-align:left;border:1px solid var(--hairline);background:var(--canvas);border-radius:6px;padding:10px 11px;cursor:pointer}.dev-shopper-flow-content-list button.active{border-color:var(--sea-line);background:var(--sky-soft)}.dev-shopper-flow-content-list b{display:block;color:var(--ink)}.dev-shopper-flow-content-list span{display:block;color:var(--ink-muted);font-size:12px}.dev-shopper-flow-note{padding:10px 0;border-bottom:1px solid var(--hairline)}.dev-shopper-flow-note:last-child{border-bottom:0}.dev-shopper-flow-note b{display:block;color:var(--ink);margin-bottom:3px}.dev-shopper-flow-note span{display:block;color:var(--ink-muted);font-size:12.5px;line-height:1.45}.dev-cmp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}@media (max-width: 900px){.dev-cmp-grid{grid-template-columns:1fr}}.dev-cmp-card{position:relative;display:block;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-xs);transition:box-shadow .15s,border-color .15s,transform .05s}.dev-cmp-card:hover{box-shadow:var(--shadow-md);border-color:var(--border)}.dev-cmp-card:active{transform:translateY(1px)}.dev-cmp-tag{position:absolute;top:24px;left:24px;width:26px;height:26px;border-radius:6px;background:var(--gradient-sea);color:#fff;font-weight:700;font-size:13px;display:grid;place-items:center}.dev-cmp-name{font-weight:600;font-size:16px;margin-top:12px;color:var(--ink)}.dev-cmp-blurb{color:var(--ink-muted);font-size:13px;margin:6px 0 12px;line-height:1.5}.dev-cmp-meta{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin-top:6px}.dev-cmp-label{font-weight:700;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;margin-right:6px}.dev-cmp-label.ok{color:var(--ok-ink)}.dev-cmp-label.warn{color:var(--warn-ink)}.dev-cmp-open{display:inline-block;margin-top:14px;font-size:13px;font-weight:600;color:var(--sea)}.dev-thumb{height:116px;border-radius:6px;background:var(--surface);border:1px solid var(--hairline);overflow:hidden;padding:8px}.dev-thumb-row{display:flex;gap:5px;height:100%}.dev-thumb-col{display:flex;flex-direction:column;gap:5px;height:100%}.dev-thumb-box{border-radius:3px;background:#fff;border:1px solid var(--border)}.dev-thumb-box.rail{width:26%}.dev-thumb-box.insp{width:30%}.dev-thumb-box.plan{flex:1;background:repeating-linear-gradient(45deg,#fff,#fff 6px,#f0f4f8 6px,#f0f4f8 12px)}.dev-thumb-box.plan.tall,.dev-thumb-box.plan.full{width:100%}.dev-thumb-tabs{display:flex;gap:4px}.dev-thumb-tabs span{width:22px;height:7px;border-radius:3px;background:var(--border)}.dev-thumb-tabs span.on{background:var(--sea)}.dev-thumb-canvas{position:relative;height:100%}.dev-thumb-toolrail{position:absolute;top:8px;left:4px;z-index:2;display:flex;flex-direction:column;gap:4px}.dev-thumb-toolrail i{width:12px;height:12px;border-radius:3px;background:#fff;border:1px solid var(--border)}.dev-thumb-drawer{position:absolute;top:6px;right:4px;bottom:6px;width:26%;background:#fff;border:1px solid var(--border);border-radius:3px;z-index:2}.dev-thumb-ops,.dev-thumb-wizard,.dev-thumb-field{height:100%;display:flex;flex-direction:column;gap:5px}.dev-thumb-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.dev-thumb-strip span{height:16px;border-radius:3px;background:#fff;border:1px solid var(--border)}.dev-thumb-steps{display:flex;gap:5px}.dev-thumb-steps span{flex:1;height:8px;border-radius:999px;background:var(--border)}.dev-thumb-steps span.done,.dev-thumb-steps span.on{background:var(--sea)}.dev-thumb-field{align-items:center;justify-content:center}.dev-thumb-phone{width:62px;height:94px;border:5px solid #1D1D1F;border-radius:12px;background:#fff;display:flex;flex-direction:column;gap:5px;padding:8px 6px}.dev-thumb-phone span{height:8px;border-radius:3px;background:var(--surface-2)}.dev-thumb-phone .map{height:34px;background:repeating-linear-gradient(45deg,#fff,#fff 5px,#f0f4f8 5px,#f0f4f8 10px);border:1px solid var(--border)}.dev-thumb-heatmap{position:relative;height:100%;overflow:hidden}.dev-thumb-heatmap .dev-thumb-box{position:absolute;top:0;right:0;bottom:0;left:0}.dev-thumb-heatmap .hot{position:absolute;border-radius:50%;filter:blur(2px);opacity:.82}.dev-thumb-heatmap .hot.a{width:54px;height:54px;right:26px;top:28px;background:#be123c}.dev-thumb-heatmap .hot.b{width:68px;height:68px;left:48px;bottom:15px;background:#d97706}.dev-thumb-heatmap .hot.c{width:74px;height:44px;left:74px;top:35px;background:#0f9488}.dev-thumb-heatmap .mask{position:absolute;height:13px;background:#1d1d1f5c;border:1px solid rgb(29 29 31 / .45);border-radius:3px}.dev-thumb-heatmap .mask.one{left:78px;right:32px;top:38px}.dev-thumb-heatmap .mask.two{left:62px;right:54px;bottom:33px}.dev-thumb-floor-builder{position:relative;height:100%;overflow:hidden}.dev-thumb-floor-builder .dev-thumb-box{position:absolute;top:0;right:0;bottom:0;left:0}.dev-thumb-floor-builder .corner{position:absolute;width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid var(--sea);z-index:2}.dev-thumb-floor-builder .corner.a{left:32px;top:22px}.dev-thumb-floor-builder .corner.b{right:28px;top:22px}.dev-thumb-floor-builder .corner.c{right:58px;bottom:24px}.dev-thumb-floor-builder .corner.d{left:34px;bottom:28px}.dev-thumb-floor-builder .trace{position:absolute;height:3px;background:#0f9488;border-radius:999px;opacity:.75;z-index:2}.dev-thumb-floor-builder .trace.one{left:38px;right:34px;top:28px}.dev-thumb-floor-builder .trace.two{right:34px;width:82px;top:58px;transform:rotate(90deg);transform-origin:right center}.dev-thumb-floor-builder .trace.three{left:40px;right:64px;bottom:34px}@media (max-width: 1180px){.dev-ops-grid{grid-template-columns:260px 1fr}.dev-ops-grid>aside:last-child{grid-column:1 / -1}.dev-ops-main-grid,.dev-tabs-split-shell,.dev-tabs-split-content,.dev-cal-grid,.dev-floor-builder{grid-template-columns:1fr}.dev-tabs-plan-side{position:static}.dev-floor-tools{position:static;padding-left:0;padding-top:16px;border-left:0;border-top:1px solid var(--hairline)}.dev-shopper-flow-grid{grid-template-columns:1fr}.dev-field-page{grid-template-columns:1fr minmax(340px,430px);align-items:start}.dev-field-tools{grid-column:1 / -1}}@media (max-width: 860px){.dev-topbar{align-items:flex-start;flex-direction:column;gap:4px;padding:8px 12px}.dev-switch{margin-left:0;justify-content:flex-start}.dev-tabs-family,.dev-setup-tabs,.dev-setup-fields,.dev-publish-grid,.dev-ops-metrics,.dev-wizard-steps,.dev-form-grid,.dev-module-grid,.dev-ops-grid,.dev-wizard-grid,.dev-field-page,.dev-setup-grid,.dev-floor-tool-grid{grid-template-columns:1fr}.dev-shopper-flow-tabs,.dev-shopper-flow-summary{display:grid;grid-template-columns:1fr}.dev-shopper-flow-toggle-list{grid-template-columns:1fr}.dev-phone-shell{min-height:680px;max-width:430px;margin:0 auto}}.fp-page{flex:1;min-height:0;display:flex;flex-direction:column}.fp-picker{padding:28px;max-width:1100px;margin:0 auto;width:100%}.fp-editor{flex:1;min-height:0;display:flex;flex-direction:column}.fp-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 14px;background:var(--bg);border-bottom:1px solid var(--hairline)}.fp-topbar-left{display:flex;align-items:center;gap:10px;min-width:0}.fp-title{font-size:14px;letter-spacing:-.01em}.fp-topbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.fp-btn-group{display:inline-flex;border:1px solid var(--hairline);border-radius:var(--radius-md);overflow:hidden}.fp-btn-group>.btn{border-radius:0;border:none;box-shadow:none}.fp-icon-btn{width:30px;height:30px;display:grid;place-items:center;background:var(--bg);border:none;border-right:1px solid var(--hairline);cursor:pointer;font-size:15px;color:var(--ink-2);transition:background .14s var(--ease-apple),color .14s}.fp-btn-group>.fp-icon-btn:last-child{border-right:none}.fp-icon-btn:hover:not(:disabled){background:var(--surface);color:var(--ink)}.fp-icon-btn:disabled{opacity:.4;cursor:default}.fp-check{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--ink-muted);cursor:pointer}.fp-check input{width:15px;height:15px;accent-color:var(--sea)}.fp-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 14px;font-size:12.5px;border-bottom:1px solid var(--hairline)}.fp-banner.ok{background:var(--ok-bg);color:var(--ok-ink)}.fp-banner.busy{background:var(--sky-pale);color:var(--ocean)}.fp-banner.warn{background:var(--warn-bg);color:var(--warn-ink)}.fp-banner.error{background:var(--err-bg);color:var(--err-ink)}.fp-body{flex:1;min-height:0;display:flex;position:relative}.fp-layoutbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 14px;background:var(--bg);border-bottom:1px solid var(--hairline)}.fp-layoutbar-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);margin-right:2px}.fp-layout-chip{display:inline-flex;align-items:center;gap:7px;padding:5px 12px;border-radius:999px;border:1px solid var(--hairline);background:var(--bg);color:var(--ink-muted);font-size:12.5px;font-weight:600;cursor:pointer;transition:background .15s var(--ease-apple),border-color .15s,color .15s}.fp-layout-chip:hover{background:var(--surface)}.fp-layout-chip.active{background:var(--sky-soft);border-color:var(--sea-line);color:var(--ink)}.fp-layout-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--ok)}.fp-flyout{position:absolute;left:140px;top:12px;z-index:40;width:290px;max-height:calc(100% - 24px);overflow-y:auto;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);padding:14px}.fp-flyout-head{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:13px;color:var(--ink)}@media (max-width: 980px){.fp-flyout{left:64px}}.fp-rail{width:132px;flex:none;background:var(--bg);border-right:1px solid var(--hairline);padding:10px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.fp-rail-group{display:flex;flex-direction:column;gap:5px;padding-bottom:10px;border-bottom:1px solid var(--hairline)}.fp-rail-group:last-child{border-bottom:none}.fp-tool{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:var(--radius-md);background:transparent;border:1px solid transparent;cursor:pointer;color:var(--ink-2);font-size:13px;text-align:left;transition:background .14s var(--ease-apple),border-color .14s var(--ease-apple),color .14s,transform .08s var(--ease-apple)}.fp-tool:hover{background:var(--surface);color:var(--ink)}.fp-tool:active{transform:scale(.97)}.fp-tool.active{background:var(--sea-wash);border-color:var(--sea-line);color:var(--ink);box-shadow:var(--rail-active)}.fp-tool-ico{width:18px;text-align:center;font-size:14px}.fp-tool-label{flex:1}.fp-tool-key{font-size:10.5px;color:var(--ink-faint);border:1px solid var(--hairline);border-radius:3px;padding:0 4px;font-family:var(--font-mono)}.fp-tool.active .fp-tool-key{color:var(--sea);border-color:var(--sea-line)}.fp-tool-key.ok{color:var(--ok-ink);border-color:var(--ok-border)}.fp-tool:disabled{cursor:default;opacity:.7}.fp-tool.done .fp-tool-ico{color:var(--ok)}.fp-tool-badge{min-width:17px;height:17px;padding:0 4px;border-radius:6px;background:var(--warn);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.fp-camlist{margin-top:10px;display:flex;flex-direction:column;gap:10px}.fp-camlist-status{font-size:11.5px;color:var(--ink-muted);font-weight:600}.fp-camlist-done{color:var(--ok-ink)}.fp-camlist-group{display:flex;flex-direction:column;gap:3px}.fp-camlist-dev{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);font-weight:700;margin-bottom:1px}.fp-camrow{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-md);border:1px solid var(--hairline);background:var(--bg);cursor:pointer;font-size:12.5px;text-align:left;transition:background .12s var(--ease-apple),border-color .12s}.fp-camrow:hover:not(:disabled){background:var(--surface)}.fp-camrow.queued{border-color:var(--sea-line);background:var(--sky-soft)}.fp-camrow.placed{opacity:.75;cursor:default}.fp-camrow-dot{width:14px;text-align:center;color:var(--ink-muted)}.fp-camrow.placed .fp-camrow-dot{color:var(--ok)}.fp-camrow.queued .fp-camrow-dot{color:var(--sea)}.fp-camrow-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink);font-weight:550}.fp-camrow-tag{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);font-weight:700}.fp-camrow.queued .fp-camrow-tag{color:var(--sea)}.fp-camrow.placed .fp-camrow-tag{color:var(--ok-ink)}.fp-canvas-cell{flex:1;min-width:0;position:relative;background:var(--canvas)}.fp-stage-wrap{position:absolute;top:0;right:0;bottom:0;left:0}.fp-scalebadge{position:absolute;left:12px;bottom:12px;display:flex;align-items:center;gap:8px;background:#ffffffe6;border:1px solid var(--hairline);border-radius:var(--radius-md);padding:5px 10px;font-size:12px;color:var(--ink-muted);font-family:var(--font-mono);box-shadow:var(--shadow-sm)}.fp-scalebadge .fp-dot{width:4px;height:4px;border-radius:50%;background:var(--border-strong)}.fp-inspector{width:290px;flex:none;background:var(--bg);border-left:1px solid var(--hairline);padding:14px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.fp-section{display:flex;flex-direction:column}.fp-section-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);margin-bottom:9px}.fp-help{font-size:12.5px;line-height:1.5;color:var(--ink-muted);margin:0}.fp-help b{color:var(--ink-2)}.fp-pill{font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:6px;text-transform:none;letter-spacing:0}.fp-pill.ok{background:var(--ok-bg);color:var(--ok-ink)}.fp-pill.warn{background:var(--warn-bg);color:var(--warn-ink)}.fp-field{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}.fp-field>label{font-size:12px;color:var(--ink-2);display:flex;justify-content:space-between}.fp-suffix{color:var(--ink-faint)}.fp-range-row{display:flex;align-items:center;gap:8px}.fp-range-row input[type=range]{flex:1;accent-color:var(--sea)}.fp-num{width:64px;flex:none}.fp-gallery{display:flex;flex-direction:column;gap:12px;margin-top:10px;max-height:420px;overflow-y:auto;padding-right:2px}.fp-gallery-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);margin-bottom:6px}.fp-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.fp-gallery-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--bg);cursor:pointer;transition:background .14s var(--ease-apple),border-color .14s var(--ease-apple),transform .08s}.fp-gallery-item:hover{background:var(--surface)}.fp-gallery-item:active{transform:scale(.95)}.fp-gallery-item.active{background:var(--sky-soft)}.fp-gallery-ico{font-size:19px;line-height:1}.fp-gallery-label{font-size:10px;color:var(--ink-muted);text-align:center;line-height:1.15}.fp-gallery-item.active .fp-gallery-label{color:var(--ink)}.fp-seg{display:inline-flex;border:1px solid var(--hairline);border-radius:var(--radius-md);overflow:hidden}.fp-seg button{flex:1;padding:7px 10px;background:var(--bg);border:none;border-right:1px solid var(--hairline);cursor:pointer;font-size:12.5px;color:var(--ink-muted);text-transform:capitalize;transition:background .14s var(--ease-apple),color .14s}.fp-seg button:last-child{border-right:none}.fp-seg button.active{background:var(--sea-wash);color:var(--sea);font-weight:var(--fw-semibold)}.fp-layer-row{display:flex;align-items:center;gap:9px;padding:5px 6px;margin:0 -6px;border-radius:var(--radius-sm);font-size:13px;color:var(--ink-2);cursor:pointer;transition:background .14s var(--ease-apple)}.fp-layer-row:hover{background:var(--surface)}.fp-layer-row input{width:15px;height:15px;accent-color:var(--sea)}.fp-caption{margin:12px 0 0;padding-top:9px;border-top:1px solid var(--hairline);font-size:11.5px;color:var(--ink-faint)}@media (max-width: 980px){.fp-rail{width:56px}.fp-tool-label,.fp-tool-key{display:none}.fp-inspector{width:240px}}.fp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:var(--canvas);display:flex;flex-direction:column}.plan-shell{display:grid;grid-template-columns:minmax(0,1fr) 400px;gap:14px;align-items:start}.plan-main{min-width:0}.plan-main-actions{display:flex;align-items:center;gap:14px;margin-top:12px;flex-wrap:wrap}.plan-empty{display:flex;flex-direction:column;gap:14px;align-items:flex-start;padding:24px 4px}.plan-rail{display:flex;flex-direction:column;gap:14px;min-width:0}@media (max-width: 1150px){.plan-shell{grid-template-columns:1fr}}.preview-layout-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}.floor-row{display:flex;flex-direction:column;gap:9px;padding:10px 12px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--bg);cursor:pointer;transition:background .15s var(--ease-apple),border-color .15s}.floor-row:hover{background:var(--surface)}.floor-row.sel{background:var(--sky-soft);border-color:var(--sea-line)}.floor-row-main{display:flex;align-items:center;gap:11px}.floor-level{flex:none;font-size:11px;font-weight:700;color:var(--ink-muted);border:1px solid var(--hairline);border-radius:6px;padding:3px 6px;background:var(--bg)}.floor-row-actions{display:flex;gap:6px;flex-wrap:wrap}.layout-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 12px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--bg)}.layout-id{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.plan-choice.sel{background:var(--sky-soft);border-color:var(--sea-line)}.plan-choices{display:flex;flex-direction:column;gap:10px}.plan-choice{display:flex;align-items:center;gap:14px;text-align:left;width:100%;padding:13px 14px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--bg);cursor:pointer;transition:background .15s var(--ease-apple),border-color .15s}.plan-choice:hover{background:var(--surface);border-color:var(--border)}.plan-choice-ico{font-size:21px;flex:none;width:30px;text-align:center}.plan-choice b{display:block;font-size:14px;color:var(--ink)}.plan-choice small{display:block;margin-top:2px;font-size:12.5px;color:var(--ink-muted);line-height:1.4}.plan-shape-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.plan-shape-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 10px 10px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--bg);cursor:pointer;transition:background .15s var(--ease-apple),border-color .15s}.plan-shape-item:hover{background:var(--surface);border-color:var(--sea)}.plan-shape-item svg{width:100%;height:64px}.plan-shape-item b{font-size:13px;color:var(--ink)}.plan-shape-item small{font-size:11.5px}.dev-dot.connecting{background:var(--warn, #C2410C)}.site-plan-editor{display:flex;flex-direction:column;gap:0}.site-plan-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.site-plan-toolbar .seg{display:flex;gap:4px;flex-wrap:wrap}.site-plan-shell{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:16px;align-items:start}.site-plan-shell:has(.site-plan-side:empty),.site-plan-shell.no-side{grid-template-columns:1fr}.site-plan-side{display:flex;flex-direction:column;gap:7px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md);padding:14px}.site-plan-facing{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--hairline)}.site-plan-facing input[type=range]{width:100%;accent-color:var(--sea)}@media (max-width: 980px){.site-plan-shell{grid-template-columns:1fr}}.cam-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.cam-tile{padding:0;overflow:hidden;display:flex;flex-direction:column}.cam-tile-shot{position:relative;aspect-ratio:16 / 9;background:var(--surface-2);border-bottom:1px solid var(--hairline)}.cam-tile-shot img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.cam-tile-shot .pill{position:absolute;top:10px;left:10px;box-shadow:var(--shadow-sm)}.cam-tile-foot{display:flex;flex-direction:column;gap:9px;padding:12px 14px 14px}.cam-tile-id{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.cam-tile-id .cell-strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cam-tile-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}.cam-tile-mods{display:inline-flex;gap:9px;align-items:center;flex-wrap:wrap;min-width:0}.cam-tile-mod{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--ink-muted)}.cam-preview-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:2px 2px 12px}.editor-save{display:flex;flex-direction:column;gap:9px;border-top:1px solid var(--hairline);padding-top:14px}.cam-wall-head{display:flex;align-items:baseline;gap:10px;margin:24px 2px 14px;flex-wrap:wrap}.cam-wall-head h3{margin:0;font-size:16px;font-weight:650;letter-spacing:-.01em;color:var(--ink)}.cam-wall-head .hint{color:var(--ink-faint);font-size:12.5px}.occ-head-actions{display:flex;justify-content:flex-end;margin-bottom:4px}.occ-row{display:flex;align-items:flex-start;gap:11px;flex-wrap:wrap;padding:12px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--bg)}.occ-row>.dev-swatch{margin-top:5px;width:11px;height:11px;border-radius:3px}.occ-row-main{min-width:0}.occ-modal{max-width:480px}.occ-counter-pick{display:flex;flex-direction:column;gap:12px;margin-top:6px;max-height:280px;overflow-y:auto;padding:12px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md)}.occ-cam-group{display:flex;flex-direction:column;gap:2px}.occ-cam-group-head{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);font-weight:700;margin-bottom:3px}.seg{display:inline-flex;gap:2px;padding:3px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md)}.seg-btn{padding:6px 15px;font-size:13px;font-weight:var(--fw-medium);color:var(--ink-muted);border:0;background:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s var(--ease-apple),color .15s var(--ease-apple)}.seg-btn:hover{color:var(--ink)}.seg-btn.active{background:var(--bg);color:var(--sea);font-weight:var(--fw-semibold);box-shadow:var(--shadow-sm)}.seg-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.cam-place{margin-top:16px;border-top:1px solid var(--hairline);padding-top:14px}.cam-place-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.cam-place-strip{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}.cam-place-item{flex:0 0 auto;width:124px;display:flex;flex-direction:column;gap:5px}.cam-place-item.unplaced{opacity:.92}.cam-place-shot{position:relative;aspect-ratio:16 / 10;border-radius:var(--radius-md);overflow:hidden;background:var(--surface);border:1px solid var(--hairline)}.cam-place-item.unplaced .cam-place-shot{border-color:#e0a106;border-style:dashed}.cam-place-shot img{width:100%;height:100%;object-fit:cover;display:block}.cam-place-shot .dev-dot{position:absolute;top:6px;right:6px;box-shadow:0 0 0 2px #fff}.cam-place-id{display:flex;flex-direction:column;gap:1px;min-width:0}.cam-place-id .cell-strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cam-place-warn{font-size:11px;font-weight:600;color:#b45309}.fz-modal{max-width:620px}.fz-canvas-frame{margin-top:6px;border:1px solid var(--hairline);border-radius:var(--radius-md);overflow:hidden;background:#fbfbfd}.fz-canvas{display:block;width:100%;height:340px;touch-action:none;cursor:crosshair}.analytic-row{display:flex;align-items:center;gap:9px;padding:8px 9px;border:1px solid transparent;border-radius:var(--radius-md);font-size:13px;cursor:pointer;transition:background .12s var(--ease-apple),border-color .12s}.analytic-row:hover{background:var(--surface)}.analytic-row.sel{background:var(--sky-soft);border-color:var(--sea-line)}.analytic-row-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;color:var(--ink)}.analytic-row-type{font-size:11px;color:var(--ink-faint);font-weight:600;text-transform:uppercase;letter-spacing:.04em;flex:none}.analytic-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--sea);cursor:pointer;flex:none}.ae-chooser,.ae-drawing{display:flex;flex-direction:column;gap:10px}.ae-add-modal{max-width:560px}.ae-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ae-type-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:12px;text-align:left;cursor:pointer;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);font:inherit;transition:border-color .15s,background .15s,transform .1s}.ae-type-card:hover:not(:disabled){border-color:var(--sea);background:var(--surface)}.ae-type-card:active:not(:disabled){transform:translateY(1px)}.ae-type-card:disabled{opacity:.5;cursor:not-allowed}.ae-type-card .ae-illus{width:100%;height:auto}.ae-type-label{font-weight:600;font-size:13.5px}.ae-type-card small{color:var(--ink-faint);font-size:11.5px;line-height:1.4}.ae-params{display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--hairline);padding-top:12px}.ae-param{display:grid;grid-template-columns:92px 1fr;align-items:center;gap:10px}.ae-param>span{font-size:12.5px;color:var(--ink-muted);font-weight:500}button.back-link{background:none;border:0;padding:0;font:inherit;font-size:13px;cursor:pointer}.cam-switch-bar{display:flex;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap}.cam-switch-bar .back-link{margin-bottom:0;flex:none}.cam-switch-select{width:auto;min-width:160px;max-width:240px;cursor:pointer}.login-card .auth-title{margin:0 0 4px;font-size:19px}.auth-sub{margin-top:0;margin-bottom:18px;font-size:13.5px;line-height:1.5}.auth-center{text-align:center;padding:6px 0}.auth-center .spinner{margin:10px auto}.auth-icon{font-size:28px;line-height:1;margin-bottom:8px}.auth-tabs{display:flex;gap:4px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md);padding:4px;margin-bottom:18px}.auth-tab{flex:1;border:none;background:transparent;padding:8px 10px;border-radius:calc(var(--radius-md) - 3px);font-size:13.5px;font-weight:600;color:var(--ink-muted);cursor:pointer}.auth-tab.on{background:var(--bg);color:var(--ink);box-shadow:var(--shadow-sm)}.gbtn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 12px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--bg);color:var(--ink);font-size:14px;font-weight:600;text-decoration:none;cursor:pointer}.gbtn:hover{background:var(--surface)}.gbtn svg{flex:none}.auth-divider{display:flex;align-items:center;gap:12px;color:var(--ink-faint);font-size:12px;margin:16px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--hairline)}.auth-label-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.auth-hint{font-size:12px;color:var(--ink-faint);margin-top:6px}.auth-fineprint{font-size:12px;color:var(--ink-faint);text-align:center;margin:12px 0 0}.auth-alt{text-align:center;margin:16px 0 0;font-size:13px}.auth-note{padding:9px 12px;border-radius:var(--radius-md);background:var(--sky-soft);border:1px solid var(--hairline);color:var(--ink-muted);font-size:12.5px;margin-bottom:14px}.linklike{background:none;border:none;padding:0;color:var(--blue);font:inherit;font-weight:600;cursor:pointer}.linklike:hover{text-decoration:underline}.linklike.sm{font-size:12.5px;font-weight:500}.linklike:disabled{opacity:.6;cursor:default;text-decoration:none}.dl-relnote{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin:-12px 0 26px;font-size:13px;color:var(--ink-muted)}.dl-relnote .dl-ver{font-weight:var(--fw-semibold);color:var(--ink)}.dl-relnote .dl-dot{color:var(--ink-faint)}.dl-sec{margin:0 0 16px}.dl-sec.spaced{margin-top:34px}.dl-sec-t{display:flex;align-items:center;gap:10px}.dl-sec-t h2{margin:0;font-size:18px;font-weight:var(--fw-bold);letter-spacing:-.02em;color:var(--ink)}.dl-sec-tag{font-size:10px;font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);background:var(--surface);border:1px solid var(--hairline);padding:3px 8px;border-radius:var(--radius-pill)}.dl-sec p{margin:5px 0 0;font-size:13px;color:var(--ink-muted);max-width:74ch;line-height:1.5}.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:30px}.dl-cams{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:16px}.dl-card{position:relative;display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);transition:box-shadow .16s var(--ease-apple),transform .16s var(--ease-apple),border-color .16s}.dl-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dl-card.rec{border-color:var(--sea-line);box-shadow:inset 2px 0 0 var(--sea),var(--shadow-sm)}.dl-card.rec:hover{box-shadow:inset 2px 0 0 var(--sea),var(--shadow-md)}.dl-rec-badge{position:absolute;top:16px;right:16px;font-size:10px;font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--sea);background:var(--sea-wash);border:1px solid var(--sea-line);padding:3px 8px;border-radius:var(--radius-pill)}.dl-ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:var(--surface);color:var(--ink);margin-bottom:16px}.dl-ic svg{width:30px;height:30px}.dl-name{font-size:18px;font-weight:var(--fw-bold);letter-spacing:-.02em;color:var(--ink)}.dl-req{margin-top:5px;font-size:12.5px;color:var(--ink-muted);line-height:1.45;min-height:36px}.dl-file{margin-top:16px;padding-top:14px;border-top:1px solid var(--hairline);display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--ink-faint)}.dl-file .fn{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-muted);word-break:break-all}.dl-act{margin-top:18px}.dl-btn{width:100%;justify-content:center;gap:8px}.dl-spin{width:14px;height:14px;border-radius:50%;border:2px solid rgb(255 255 255 / .4);border-top-color:#fff;animation:spin .7s linear infinite;display:inline-block}.dl-prog{display:flex;align-items:center;gap:10px;height:36px}.dl-bar{flex:1;height:8px;background:var(--surface);border-radius:5px;overflow:hidden}.dl-bar i{display:block;height:100%;background:var(--sea);border-radius:5px;transition:width .2s linear}.dl-pct{font-size:12px;font-variant-numeric:tabular-nums;color:var(--ink-muted);width:36px;text-align:right}.dl-cancel{width:24px;height:24px;flex:none;display:grid;place-items:center;border:none;background:none;color:var(--ink-faint);font-size:18px;line-height:1;cursor:pointer;border-radius:var(--radius-sm)}.dl-cancel:hover{background:var(--surface);color:var(--ink)}.dl-done{display:flex;align-items:center;justify-content:space-between;gap:8px;height:36px}.dl-done-l{display:inline-flex;align-items:center;gap:7px;color:var(--ok-ink);font-size:13.5px;font-weight:var(--fw-semibold)}.dl-again{background:none;border:none;color:var(--sea);font-size:12.5px;font-weight:var(--fw-semibold);cursor:pointer;padding:5px 7px;border-radius:var(--radius-sm)}.dl-again:hover{background:var(--surface)}.dl-info{display:grid;grid-template-columns:1.3fr 1fr;gap:16px;margin-bottom:6px}.dl-panel{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}.dl-panel-h{margin:0 0 16px;font-size:14.5px;font-weight:var(--fw-semibold);color:var(--ink)}.dl-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}.dl-steps li{display:flex;gap:13px}.dl-step-n{flex:none;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--sea-wash);color:var(--sea);font-size:12.5px;font-weight:var(--fw-bold);box-shadow:inset 0 0 0 1px var(--sea-line)}.dl-step-tx{display:flex;flex-direction:column;gap:2px}.dl-step-t{font-size:13.5px;font-weight:var(--fw-semibold);color:var(--ink)}.dl-step-d{font-size:12.5px;color:var(--ink-muted);line-height:1.5}.dl-step-d a{color:var(--sea);font-weight:var(--fw-medium)}.dl-reqs{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}.dl-reqs li{display:flex;gap:9px;align-items:flex-start;font-size:12.5px;color:var(--ink-2);line-height:1.45}.dl-reqs li .ico-sm{color:var(--ok);flex:none;margin-top:1px}.dl-camguide{margin-bottom:26px}.dl-camguide .dl-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.dl-foot{font-size:12.5px;color:var(--ink-faint);margin:0}.dl-foot a{color:var(--sea);font-weight:var(--fw-medium)}@media (max-width:980px){.dl-grid,.dl-cams,.dl-info,.dl-camguide .dl-steps{grid-template-columns:1fr}}.ob-page{min-height:100dvh;background:linear-gradient(180deg,#f6f8fb,#eef2f7);padding:40px 20px;overflow-y:auto}.ob-shell{width:100%;max-width:720px;margin:0 auto}.ob-brand{display:flex;align-items:center;gap:11px;margin-bottom:20px}.ob-brand .name{font-weight:var(--fw-bold);font-size:18px;letter-spacing:-.02em;color:var(--ink)}.ob-brand .sub{font-size:11px;color:var(--ink-faint)}.ob-steps{display:flex;align-items:center;margin:0 0 20px}.ob-step{display:flex;align-items:center;gap:9px}.ob-step .n{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:12.5px;font-weight:var(--fw-bold);background:var(--surface);color:var(--ink-faint);border:1px solid var(--hairline)}.ob-step.on .n{background:var(--sea);color:#fff;border-color:var(--sea)}.ob-step.done .n{background:var(--sea-wash);color:var(--sea);border-color:var(--sea-line)}.ob-step .lbl{font-size:13px;font-weight:var(--fw-semibold);color:var(--ink-faint)}.ob-step.on .lbl,.ob-step.done .lbl{color:var(--ink)}.ob-step-line{flex:1;height:1px;background:var(--hairline);margin:0 12px;min-width:18px}.ob-card{background:var(--bg);border:1px solid var(--hairline);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:30px}.ob-h{margin:0 0 4px;font-size:21px;font-weight:var(--fw-bold);letter-spacing:-.02em;color:var(--ink)}.ob-sub{margin:0 0 22px;font-size:13.5px;color:var(--ink-muted);line-height:1.55}.ob-verify{display:flex;gap:11px;align-items:flex-start;background:var(--sea-wash);border:1px solid var(--sea-line);border-radius:var(--radius-md);padding:12px 14px;margin:0 0 20px;font-size:13px;color:var(--ink-2);line-height:1.5}.ob-verify .em{font-weight:var(--fw-semibold);color:var(--ink)}.ob-verify .ico-sm{color:var(--sea);flex:none;margin-top:1px}.ob-modes{display:grid;grid-template-columns:1fr 1fr;gap:14px}.ob-mode{text-align:left;background:var(--bg);border:1.5px solid var(--hairline);border-radius:var(--radius);padding:20px;cursor:pointer;display:flex;flex-direction:column;gap:10px;transition:border-color .15s,box-shadow .15s,transform .15s var(--ease-apple)}.ob-mode:hover{border-color:var(--sea-line);transform:translateY(-2px);box-shadow:var(--shadow-md)}.ob-mode.on{border-color:var(--sea);box-shadow:0 0 0 3px var(--sea-wash)}.ob-mode .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--surface);color:var(--ink)}.ob-mode .ic svg{width:26px;height:26px}.ob-mode .t{font-size:15.5px;font-weight:var(--fw-bold);color:var(--ink)}.ob-mode .d{font-size:12.5px;color:var(--ink-muted);line-height:1.5}.ob-mode .pick{margin-top:auto;font-size:12px;font-weight:var(--fw-semibold);color:var(--sea);display:inline-flex;align-items:center;gap:6px;opacity:0;transition:opacity .15s}.ob-mode.on .pick{opacity:1}.ob-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:24px}.ob-foot{text-align:center;font-size:12.5px;color:var(--ink-faint);margin-top:18px}.ob-foot a,.ob-foot .linklike{color:var(--sea);font-weight:var(--fw-medium)}@media (max-width:680px){.ob-modes{grid-template-columns:1fr}.ob-step .lbl{display:none}}
