:root{--color-bg:#f7f7f8;--color-surface:#fff;--color-surface-2:#f1f2f4;--color-ink:#1c1d1f;--color-muted:#6b6f76;--color-line:#e2e4e8;--color-accent:#2f6feb;--color-accent-2:#0d9488;--color-danger:#d64545;--color-tide-sand:#c4a46c;--color-tide-waves:#2e7da8;--font-body:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-heading:var(--font-body);--font-mono:ui-monospace, "SF Mono", "Cascadia Code", "Courier New", monospace;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-panel:0 1px 2px #1018280f, 0 4px 12px #1018280a;--space-scale:1;--shell-width:1120px;--dashboard-columns:2;color:var(--color-ink);background:var(--color-bg);font-family:var(--font-body);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.45}*{box-sizing:border-box}html{overflow-x:hidden}body{background:var(--app-body-background,var(--color-bg));min-width:320px;min-height:100svh;margin:0;overflow-x:hidden}h1,h2,h3{font-family:var(--font-heading)}button,input,textarea,select{font:inherit}button,.button-link{border:1px solid var(--color-ink);border-radius:var(--radius-md);background:var(--color-ink);min-height:40px;color:var(--color-surface);cursor:pointer;justify-content:center;align-items:center;padding:9px 14px;font-weight:700;text-decoration:none;transition:transform .18s,background-color .18s,border-color .18s,color .18s;display:inline-flex}button:hover,.button-link:hover{transform:translateY(-1px)}button:active,.button-link:active{transform:translateY(0)}button:focus-visible,.button-link:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible{outline:3px solid color-mix(in srgb, var(--color-accent) 72%, white);outline-offset:2px}button:disabled{opacity:.6;cursor:wait;transform:none}input,textarea,select{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-ink);padding:11px 12px}textarea{resize:vertical;min-height:130px}label{color:var(--color-muted);gap:6px;font-size:.88rem;font-weight:700;display:grid}.loading-screen,.login-screen{place-items:center;min-height:100svh;padding:22px;display:grid}.login-panel{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);width:min(460px,100%);box-shadow:var(--shadow-panel);padding:28px}.login-panel h1,.top-strip h1{letter-spacing:0;margin:0;font-size:clamp(2.2rem,7vw,4.9rem);line-height:.9}.login-panel form,.form-panel{gap:12px;display:grid}.app-shell{width:min(var(--shell-width), calc(100% - 28px));margin:0 auto;padding:18px 0 54px}.top-strip{justify-content:space-between;align-items:end;gap:18px;padding:20px 0;display:flex}.top-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.top-actions span{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 78%, transparent);color:var(--color-muted);font-family:var(--font-mono);padding:9px 10px;font-size:.82rem}.top-actions .origin-link{text-overflow:ellipsis;border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 78%, transparent);max-width:100%;color:var(--color-muted);font-family:var(--font-mono);padding:9px 10px;font-size:.82rem;text-decoration:none;overflow:hidden}.top-actions .origin-link:hover{color:var(--color-ink);border-color:color-mix(in srgb, var(--color-accent) 42%, var(--color-line))}.top-actions .unlock-status{border-color:color-mix(in srgb, var(--color-accent-2) 42%, var(--color-line));color:var(--color-accent-2);font-weight:800}.top-actions .unlock-status.warning{border-color:color-mix(in srgb, var(--color-danger) 58%, var(--color-line));color:var(--color-danger)}.tab-bar{z-index:5;background:color-mix(in srgb, var(--color-bg) 90%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);grid-auto-columns:minmax(0,1fr);grid-auto-flow:column;gap:8px;padding:10px 0;display:grid;position:sticky;top:0}.tab-bar button{border-color:var(--color-line);background:var(--color-surface);color:var(--color-ink)}.tab-bar button.active{border-color:var(--color-ink);background:var(--color-ink);color:var(--color-surface)}.dashboard-grid,.workspace-grid{grid-template-columns:repeat(var(--dashboard-columns), minmax(0, 1fr));gap:calc(12px * var(--space-scale));display:grid}.admin-grid{margin-top:12px}.panel{padding:calc(18px * var(--space-scale));border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-panel)}.empty-state{margin-top:12px}.empty-state h2{margin:0;font-size:clamp(1.45rem,4vw,2.4rem)}.span-2{grid-column:1/-1}.module-small{min-height:190px}.module-wide,.module-full{grid-column:1/-1}.module-full{min-height:420px}.panel-heading{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.panel h2{margin:0;font-size:clamp(1.35rem,4vw,2.1rem);line-height:1.05}.panel p{color:var(--color-muted)}.kicker{color:var(--color-accent);font-family:var(--font-mono);letter-spacing:0;text-transform:uppercase;margin:0 0 8px;font-size:.74rem;font-weight:800}.big-number{color:var(--color-ink);font-size:clamp(3rem,11vw,6rem);line-height:.82}.metric-row,.page-chip-row{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.metric-row span,.pill{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 82%, transparent);padding:8px 10px;font-weight:700}.day-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.day-grid div,.plain-row,.tide-card,.detail-box,.module-row{border:1px solid color-mix(in srgb, var(--color-line) 80%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 70%, transparent);gap:5px;min-width:0;padding:12px;display:grid}.inline-edit{min-height:unset;padding:4px 8px;font-size:.9rem}.tide-track{grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-top:14px;display:grid}.tide-card.high{border-color:color-mix(in srgb, var(--color-accent) 45%, var(--color-line))}.tide-card.low{border-color:color-mix(in srgb, var(--color-accent-2) 45%, var(--color-line))}.tide-card span,.page-chip span,.small-note,small{color:var(--color-muted);font-size:.82rem}.stack-list,.items,.module-list{gap:8px;margin-top:12px;display:grid}.stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.stat-grid div{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 70%, transparent);gap:3px;padding:12px;display:grid}.stat-grid strong{font-size:1.7rem;line-height:1}.stat-grid span{color:var(--color-muted);font-size:.82rem}.check-card.ok{border-color:color-mix(in srgb, var(--color-accent-2) 55%, var(--color-line))}.check-card.warn,.warning-row{border-color:color-mix(in srgb, var(--color-danger) 50%, var(--color-line))}.status-badge{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 80%, transparent);width:fit-content;font-family:var(--font-mono);padding:8px 10px;font-size:.78rem;font-weight:800}.status-badge.ok{border-color:color-mix(in srgb, var(--color-accent-2) 48%, var(--color-line));color:var(--color-accent-2)}.status-badge.warn{border-color:color-mix(in srgb, var(--color-danger) 58%, var(--color-line));color:var(--color-danger)}.plain-row{border-color:var(--color-line);background:color-mix(in srgb, var(--color-surface) 70%, transparent);width:100%;color:var(--color-ink);text-align:left;text-decoration:none}.page-chip{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 78%, transparent);min-width:min(190px,100%);color:var(--color-ink);padding:13px;text-decoration:none;display:grid}.inline-form{grid-template-columns:1fr auto;gap:8px;margin:12px 0;display:grid}.button-row,.inline-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.inline-controls select{width:auto;min-width:120px}.compact-link{min-height:34px;padding:7px 10px}.module-controls{grid-template-columns:minmax(0,1fr) minmax(112px,.34fr);align-items:start;gap:10px 12px;display:grid}.module-actions{flex-wrap:wrap;grid-column:1;align-items:center;gap:8px;display:flex}.module-actions button{white-space:nowrap}.module-options{grid-column:1;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.module-options>.compact-field{min-width:0}.module-options>.api-key-field,.module-options>.api-key-link{grid-column:1/-1}.module-options>.setting-secret-status{color:var(--color-muted);grid-column:1/-1;padding:2px 0;font-size:.7rem}.setting-option-help{color:var(--color-muted);margin-top:1px;font-size:.68rem;line-height:1.3;display:block}.compact-field{gap:4px;min-width:0;font-size:.74rem}.compact-field select,.compact-field input{min-height:40px}.position-field input{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.position-field{grid-area:1/2/span 12;place-self:start end;width:max-content}.position-label{color:var(--color-muted);font-size:.74rem;display:block}.reorder-bar{justify-content:flex-start;align-items:center;gap:4px;width:max-content;min-height:0;display:flex}.reorder-bar .position-value{min-width:2ch;color:var(--color-muted);font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:center;padding:0 2px;font-size:.82rem;line-height:1}.drag-handle{border-radius:var(--radius-sm);width:22px;min-height:22px;color:var(--color-muted);cursor:grab;letter-spacing:1px;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:2px 0;font-size:.7rem;line-height:1;display:inline-flex}.drag-handle:active{cursor:grabbing}.dragging{opacity:.55}.drag-over{border-color:var(--color-accent-2)!important;background:color-mix(in srgb, var(--color-accent-2) 10%, var(--color-surface))!important}.item{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 72%, transparent);grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:9px 11px;display:grid}.item.done span{color:var(--color-muted);text-decoration:line-through}.icon-button{min-width:34px;min-height:34px;padding:4px}.ghost{border-color:var(--color-line);color:var(--color-ink);background:0 0}.danger{color:var(--color-danger)}button.danger:not(.ghost){border-color:var(--color-danger);background:var(--color-danger);color:var(--color-surface)}.two-col{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.markdown{color:var(--color-ink);overflow-wrap:anywhere}.markdown p:first-child{margin-top:0}.markdown p:last-child{margin-bottom:0}.tag-line{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);width:fit-content;font-family:var(--font-mono);padding:7px 10px;font-size:.82rem}.note-panel .markdown{padding:8px 0;font-size:1.05rem;line-height:1.55}.note-actions{align-items:center;gap:4px;display:flex}.note-toolbar{align-items:center;gap:10px;display:flex}.note-search{flex:1;min-width:0}.note-sort{width:auto;min-width:0}.note-formatting-bar{align-items:center;gap:4px;display:flex}.note-tag-section{align-items:flex-start;gap:8px;display:flex}.note-tag-editor{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.note-tag-chips{flex-wrap:wrap;gap:4px;display:flex}.note-chip{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);font-family:var(--font-mono);align-items:center;gap:4px;padding:3px 8px;font-size:.78rem;display:inline-flex}.note-chip-x{color:var(--color-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.82rem;line-height:1}.note-chip-x:hover{color:var(--color-danger)}.note-tag-suggestions{flex-wrap:wrap;gap:4px;display:flex}.note-tag-suggestion{border:1px solid var(--color-line);border-radius:var(--radius-md);color:var(--color-muted);font-family:var(--font-mono);cursor:pointer;background:0 0;padding:2px 8px;font-size:.78rem}.note-tag-suggestion:hover{border-color:var(--color-ink);color:var(--color-ink)}.note-edit-form{flex-direction:column;gap:10px;display:flex}.note-edit-title{width:100%;font:inherit;color:var(--color-ink);background:0 0;border:none}.note-edit-title:focus{outline:none}.note-edit-actions{gap:8px;display:flex}.page-panel.peach,.standalone-page.peach{background:#fff1e5}.page-panel.moon,.standalone-page.moon{background:#efedf6}.page-panel.fern,.page-panel.botanical{background:#edf5e9}.standalone-page{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);min-height:min(760px,100svh - 190px);box-shadow:var(--shadow-panel);align-content:center;gap:16px;padding:clamp(24px,8vw,82px);display:grid}.standalone-page h1{max-width:780px;margin:0;font-size:clamp(2.5rem,10vw,7rem);line-height:.92}.standalone-page .button-link{width:fit-content}.standalone-page.botanical,.standalone-page.fern{background:linear-gradient(135deg,#edf5e9f2,#fffaf0f5),#edf5e9}.module-row{grid-template-columns:minmax(220px,1fr) minmax(380px,.95fr);align-items:start;gap:14px 18px}.module-row>div:first-child,.module-summary{gap:5px;display:grid}.module-title-row{align-items:center;gap:8px;display:flex}.module-row.enabled{border-color:color-mix(in srgb, var(--color-accent-2) 55%, var(--color-line))}.user-row{border:1px solid color-mix(in srgb, var(--color-line) 80%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 70%, transparent);grid-template-columns:minmax(0,1fr);align-items:start;gap:10px;min-width:0;padding:12px;display:grid}.user-row.inactive{opacity:.8}.user-meta{gap:4px;min-width:0;display:grid}.user-meta span{color:var(--color-muted)}.user-subline{flex-wrap:wrap;align-items:baseline;gap:6px 8px;display:flex}.user-username{color:var(--color-ink);font-family:var(--font-mono);white-space:nowrap;font-size:.84rem}.user-role{min-width:0}.user-actions{flex-wrap:wrap;justify-content:flex-start;align-items:flex-start;gap:8px;display:flex}.user-actions button{white-space:nowrap}.user-edit-input{width:100%}.module-config-row{align-items:start}.module-config-row.uninstalled{opacity:.82}.module-meta{flex-wrap:wrap;gap:6px;margin-top:3px;display:flex}.module-meta small{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:color-mix(in srgb, var(--color-surface) 70%, transparent);width:fit-content;font-family:var(--font-mono);text-transform:capitalize;padding:4px 7px;font-size:.72rem;line-height:1}.manifest-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.manifest-card{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 70%, transparent);gap:12px;min-width:0;padding:13px;display:grid}.manifest-card .panel-heading{align-items:flex-start}.manifest-card .panel-heading>div{gap:4px;min-width:0;display:grid}.manifest-card span,.manifest-fields dd{color:var(--color-muted)}.manifest-fields{gap:7px;margin:0;display:grid}.manifest-fields div{grid-template-columns:118px minmax(0,1fr);gap:8px;display:grid}.manifest-fields dt{color:var(--color-ink);font-size:.78rem;font-weight:800}.manifest-fields dd{overflow-wrap:anywhere;min-width:0;font-family:var(--font-mono);margin:0;font-size:.78rem}.metadata-preview textarea{min-height:96px;font-family:var(--font-mono);font-size:.8rem}.activity-list{gap:8px;margin-top:12px;display:grid}.activity-row{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 70%, transparent);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;min-width:0;padding:12px;display:grid}.activity-row>div:first-child{gap:4px;min-width:0;display:grid}.activity-row span{color:var(--color-muted);font-size:.82rem}.activity-tags{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.activity-tags small{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:color-mix(in srgb, var(--color-surface) 70%, transparent);font-family:var(--font-mono);padding:4px 7px;line-height:1}.notice,.form-error{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);margin:10px 0;padding:12px}.modal-backdrop{z-index:20;background:color-mix(in srgb, var(--color-ink) 35%, transparent);place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal-panel{width:min(460px,100%)}.icon-settings{font-size:1.1em;line-height:1}.density-fieldset{border:none;margin:16px 0 0;padding:0}.density-fieldset legend{margin-bottom:8px;font-weight:600;display:block}.density-options{gap:6px;display:flex}.density-btn{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);min-height:36px;color:var(--color-ink);cursor:pointer;flex:1;padding:6px 10px;font-size:.85rem;font-weight:600;transition:background-color .12s,border-color .12s}.density-btn:hover{background:var(--color-surface-2)}.density-btn.active{background:var(--color-ink);border-color:var(--color-ink);color:var(--color-surface)}.color-mode-fieldset{border:none;margin:16px 0 0;padding:0}.color-mode-fieldset legend{margin-bottom:8px;font-weight:600;display:block}.color-mode-options{gap:6px;display:flex}.color-mode-btn{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);min-height:36px;color:var(--color-ink);cursor:pointer;flex:1;padding:6px 10px;font-size:.85rem;font-weight:600;transition:background-color .12s,border-color .12s}.color-mode-btn:hover{background:var(--color-surface-2)}.color-mode-btn.active{background:var(--color-ink);border-color:var(--color-ink);color:var(--color-surface)}.error,.form-error{border-color:color-mix(in srgb, var(--color-danger) 50%, var(--color-line));color:var(--color-danger)}.activity-filter{flex-wrap:wrap;gap:8px;margin-top:12px;margin-bottom:4px;display:flex}.activity-filter select,.activity-filter input{flex:160px;width:auto}.metadata-preview{gap:6px;display:grid}.metadata-preview-header{color:var(--color-muted);justify-content:space-between;align-items:center;font-size:.88rem;font-weight:700;display:flex}.toast-tray{z-index:30;gap:8px;max-width:min(360px,100vw - 44px);display:grid;position:fixed;bottom:22px;right:22px}.toast{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-panel);align-items:center;gap:10px;padding:11px 14px;font-size:.9rem;animation:.18s both toast-in;display:flex}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast span{flex:1}.toast-warn{border-color:color-mix(in srgb, var(--color-danger) 45%, var(--color-line));background:color-mix(in srgb, var(--color-surface) 85%, var(--color-danger));color:var(--color-danger)}.toast button.ghost{min-height:unset;padding:4px 9px;font-size:1rem;line-height:1}:root[data-density=compact]{font-size:14px}:root[data-density=compact] .panel{padding:calc(13px * var(--space-scale))}:root[data-density=compact] .dashboard-grid,:root[data-density=compact] .workspace-grid{gap:calc(8px * var(--space-scale))}:root[data-surface=flat] .panel{box-shadow:none;border-color:#0000}:root[data-surface=outline] .panel{box-shadow:none;background:0 0}@media (width>=821px){:root[data-nav=side] .app-shell{grid-template-columns:180px minmax(0,1fr);align-items:start;column-gap:18px;display:grid}:root[data-nav=side] .top-strip{grid-column:1/-1}:root[data-nav=side] .tab-bar{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);grid-area:2/1/9999;grid-template-columns:1fr;grid-auto-columns:auto;grid-auto-flow:row;align-content:start;padding:10px;top:12px}:root[data-nav=side] .app-shell>:not(.top-strip):not(.tab-bar){grid-column:2}}.network-grid{align-items:start}.network-share-grid{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:14px;margin-top:12px;display:grid}.network-credentials{gap:8px;display:grid}.network-qr-wrap{place-items:center;display:grid}.network-qr{aspect-ratio:1;border:1px solid var(--color-line);border-radius:var(--radius-md);background:#fff;width:min(280px,100%);padding:10px}.device-row{border:1px solid color-mix(in srgb, var(--color-line) 80%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 70%, transparent);grid-template-columns:minmax(220px,1fr) auto auto;align-items:center;gap:10px;min-width:0;padding:12px;display:grid}.device-row>div{gap:4px;display:grid}.device-row span{color:var(--color-muted)}@media (width<=820px){.app-shell{width:min(100% - 18px,560px);padding-top:8px}.top-strip,.panel-heading{display:grid}.top-actions{justify-content:start}.tab-bar{grid-auto-columns:max-content;grid-auto-flow:column;overflow-x:auto}.dashboard-grid,.workspace-grid,.day-grid,.two-col,.stat-grid,.tide-feature-grid{grid-template-columns:1fr}.tide-day-events{grid-template-columns:repeat(2,minmax(0,1fr))}.tide-current-labels{flex-direction:column;gap:4px}.module-row,.network-share-grid,.device-row,.module-controls{grid-template-columns:1fr}.module-actions,.module-options,.position-field{grid-area:auto/1;justify-self:stretch;width:100%}.module-options{grid-template-columns:1fr}.module-actions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.module-actions button{width:100%}.reorder-bar{min-height:44px}.reorder-bar .icon-button{min-width:40px;min-height:40px}.module-edit-controls,.edit-options,.edit-display-options{flex-direction:column;align-items:stretch}.edit-options .compact-field,.edit-display-options .compact-field{width:100%}.hidden-widgets-list{flex-direction:column}.manifest-detail-grid,.manifest-fields div,.activity-row{grid-template-columns:1fr}.activity-tags{justify-content:flex-start}.activity-filter{flex-direction:column}.activity-filter select,.activity-filter input{flex:none;width:100%}.toast-tray{max-width:calc(100vw - 24px);bottom:12px;right:12px}.module-wide,.module-full{grid-column:auto}.note-toolbar{flex-direction:column;align-items:stretch}.note-actions,.note-formatting-bar{flex-wrap:wrap}}body{background:radial-gradient(circle at 50% -10%,#3a6f4d14,#0000 32rem),linear-gradient(#f9f8f5 0%,#f4f2ee 100%)}.app-shell{--app-green:#2f6645;--app-green-2:#477a57;--app-cream:#f7f5ef;--app-card:#fff;--app-tile:#efebe5;--app-ink:#151922;--app-muted:#76736c;--app-shadow:0 18px 34px #26392e21;width:min(568px,100% - 32px);min-height:100svh;color:var(--app-ink);padding:18px 0 112px;font-family:Aptos,Trebuchet MS,sans-serif;overflow-x:hidden}.app-shell:has(.admin-grid){width:min(var(--shell-width), calc(100% - 28px))}.app-shell:has(.whiteboard-workspace){width:100%;max-width:100%;height:100%;margin:0;padding:0;overflow:hidden}.top-strip{align-items:start;gap:14px;padding:0 4px 22px;display:grid}.top-strip h1{letter-spacing:-.04em;margin:0;font-family:Aptos Display,Trebuchet MS,sans-serif;font-size:clamp(1.25rem,4vw,1.45rem);line-height:1.1}.top-strip p{color:var(--app-muted);margin:5px 0 0;font-size:.88rem}.top-actions{justify-content:flex-start;gap:6px}.top-actions span,.top-actions .origin-link{text-overflow:ellipsis;max-width:100%;color:var(--app-muted);background:0 0;border:0;padding:0;font-size:.7rem;overflow:hidden}.top-actions button,.top-actions .ghost{min-height:30px;color:var(--app-green);box-shadow:none;background:#ffffffb8;border:1px solid #2f664533;border-radius:999px;padding:5px 9px;font-size:.78rem}.tab-bar{z-index:18;box-sizing:border-box;width:100%;max-width:100vw;padding:10px max(12px, calc((100vw - 568px) / 2)) calc(10px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffeb;border-top:1px solid #1519221f;grid-auto-columns:minmax(0,1fr);grid-auto-flow:column;gap:0;display:grid;position:fixed;inset:auto 0 0;box-shadow:0 -10px 24px #1519220d}.tab-bar button{color:#807c75;letter-spacing:.04em;text-transform:uppercase;min-height:48px;box-shadow:none;background:0 0;border:0;border-radius:16px;gap:2px;padding:3px 4px;font-size:.64rem;font-weight:800;display:grid}.tab-bar button span:first-child{font-size:1.28rem;line-height:1}.tab-bar button.active{color:var(--app-green);background:0 0}.home-dashboard{grid-template-columns:minmax(0,1fr);gap:14px;display:grid}.home-dashboard .panel{box-shadow:var(--app-shadow);border:0;border-radius:18px}.weather-panel{color:#fff;background:radial-gradient(circle at 94% 17%,#d6f2e22e 0 4.2rem,#0000 4.25rem),radial-gradient(circle at 12% 116%,#43a38452,#0000 12rem),linear-gradient(135deg,#326f4d 0%,#265e42 48%,#173d2c 100%);min-height:193px;padding:24px 22px 20px;position:relative;overflow:hidden}.weather-place{z-index:1;color:#ffffffb8;letter-spacing:0;font-size:.74rem;font-weight:900;position:relative}.weather-current{z-index:1;align-items:center;gap:18px;margin-top:10px;display:flex;position:relative}.weather-current p{color:#ffffffd1;margin:1px 0 0;font-size:.96rem;font-weight:700}.weather-icon{filter:drop-shadow(0 12px 11px #121f183d);width:72px;font-size:3.8rem;line-height:1}.weather-panel .big-number{color:#fff;letter-spacing:0;font-size:3.72rem}.weather-panel .big-number:after{content:"C";letter-spacing:0;margin-left:2px;font-size:1rem;position:relative;top:-1.05rem}.weather-panel .metric-row{z-index:1;border-top:1px solid #ffffff2e;gap:12px;margin-top:19px;padding-top:13px;position:relative}.weather-panel .metric-row span{color:#ffffffd1;background:0 0;border:0;align-items:center;gap:4px;padding:0;font-size:.8rem;font-weight:800;display:inline-flex}.weather-metric-icon{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;flex:0 0 14px;width:14px;height:14px}.weather-metric-emoji{flex:0 0 14px;justify-content:center;align-items:center;width:14px;height:14px;font-size:.9rem;line-height:1;display:inline-flex}.weather-forecast-grid{z-index:1;background:linear-gradient(90deg,#ffffff17,#0000 26%,#73bda61a),#092a1b3d;border:1px solid #daf2de2e;border-radius:16px;grid-template-columns:repeat(5,minmax(88px,1fr));gap:0;margin-top:13px;padding:10px;display:grid;position:relative;box-shadow:inset 0 1px #ffffff1f,0 16px 34px #081d1229}.weather-forecast-grid .weather-forecast-card{color:#fff;min-width:0;min-height:142px;box-shadow:none;background:0 0;border:0;border-radius:0;grid-template-rows:auto 42px minmax(34px,auto) auto 28px auto;align-content:stretch;gap:6px;padding:4px 12px 2px;display:grid;position:relative}.weather-forecast-grid .weather-forecast-card+.weather-forecast-card{border-left:1px solid #e1f7e029}.weather-forecast-date{color:#e9f9e2e0;font-size:.74rem;font-weight:900}.weather-forecast-grid .weather-forecast-card strong{color:#fff;font-size:.92rem;line-height:1.12}.weather-forecast-grid .weather-forecast-card small{color:#dbead3;font-size:.8rem;font-weight:800}.weather-extended-forecast{z-index:1;border-top:1px solid #ffffff2e;margin-top:16px;padding-top:15px;position:relative}.weather-forecast-heading{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.weather-forecast-heading .kicker{color:#ffffffc7;margin:0}.weather-forecast-heading span{color:#d8ebcdb3;font-size:.76rem;font-weight:900}.weather-extended-icon{filter:drop-shadow(0 8px 10px #07160e3d);background:linear-gradient(#fffffffa,#e2f1e4e6);border:1px solid #ffffffb8;border-radius:50%;place-items:center;width:42px;height:42px;font-size:1.7rem;line-height:1;display:inline-grid}.weather-precip-track{background:#ffffff1f;border-radius:999px;align-self:end;align-items:end;width:100%;height:26px;display:flex;overflow:hidden}.weather-precip-track span{width:100%;height:max(3px, var(--precip));border-radius:inherit;background:linear-gradient(#7ed8ff 0%,#3fa4d4 100%);display:block;box-shadow:0 0 14px #7ed8ff47}.weather-extended-precip{color:#daf0d3db;align-items:center;gap:4px;font-size:.8rem;font-weight:800;display:flex}.info-tooltip{display:inline-flex;position:relative}.info-tooltip-trigger{cursor:help;align-items:center;display:inline-flex}.info-tooltip-trigger:focus{outline-offset:2px;border-radius:4px;outline:2px solid #ffffff80}.info-tooltip-bubble{z-index:20;color:#fff;text-align:center;white-space:normal;pointer-events:none;background:#0a2416f0;border-radius:8px;max-width:220px;padding:6px 10px;font-size:.72rem;font-weight:700;line-height:1.35;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000047}.info-tooltip-bubble:after{content:"";border:5px solid #0000;border-top-color:#0a2416f0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.info-tooltip--open .info-tooltip-bubble{display:block}.weather-hourly{z-index:1;border-top:1px solid #ffffff2e;margin-top:16px;padding-top:15px;position:relative}.weather-hourly-heading{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.weather-hourly-heading .kicker{color:#ffffffc7;margin:0}.weather-hourly-heading span{color:#d8ebcdb3;font-size:.76rem;font-weight:900}.weather-hourly-track{overscroll-behavior-inline:contain;scrollbar-width:none;scroll-snap-type:x proximity;gap:8px;margin-top:12px;padding-bottom:4px;display:flex;overflow-x:auto}.weather-hourly-track::-webkit-scrollbar{display:none}.weather-hourly-tooltip{flex:none}.weather-hour-card{scroll-snap-align:start;text-align:center;background:#ffffff12;border:1px solid #daf2de24;border-radius:12px;flex-direction:column;align-items:center;gap:4px;min-width:72px;padding:8px 10px;display:flex}.weather-hour-time{color:#ffffffad;letter-spacing:.01em;font-size:.68rem;font-weight:900}.weather-hour-icon{font-size:1.3rem;line-height:1}.weather-hour-temp{color:#fff;font-size:.82rem;font-weight:800}.weather-hour-rain{color:#7ed8ffe6;font-size:.66rem;font-weight:700}.weather-precip-tooltip .info-tooltip-trigger{width:100%;display:block}.weather-environment{z-index:1;border-top:1px solid #ffffff2e;flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:13px;display:flex;position:relative}.weather-env-pill{color:#ffffffdb;cursor:default;background:#ffffff1f;border-radius:12px;align-items:center;gap:4px;padding:4px 10px;font-size:.74rem;font-weight:700;display:inline-flex}.weather-env-pill--low{color:#ffffffeb;background:#7ed8ff2e}.weather-env-pill--moderate{color:#ffffffeb;background:#ffd87e2e}.weather-env-pill--high{color:#ffffffeb;background:#ff8c642e}.weather-env-pill--very-high{color:#ffffffeb;background:#ff503c33}.weather-env-pill--extreme{color:#ffffffeb;background:#b428503d}.weather-env-pill--good{color:#ffffffeb;background:#7ed8b42e}.weather-env-pill--fair{color:#ffffffeb;background:#b4d28c2e}.weather-env-pill--poor{color:#ffffffeb;background:#ffb4502e}.weather-env-pill--very-poor{color:#ffffffeb;background:#ff783c33}.weather-env-pill--extremely-poor{color:#ffffffeb;background:#b41e4642}.weather-env-pill--unavailable{color:#ffffff80;background:#ffffff14}.weather-orb{filter:blur(1px);pointer-events:none;background:radial-gradient(circle,#e9c46a2e 0 18%,#e9c46a12 19% 42%,#0000 43%);border:1px solid #e9c46a38;border-radius:50%;width:200px;height:200px;position:absolute;top:-80px;right:-52px}.weather-workspace{--wx-ink:var(--color-ink);--wx-muted:var(--color-muted);--wx-line:var(--color-line);--wx-card:var(--color-surface);--wx-card-bg:var(--color-surface-2);--wx-accent:var(--color-accent);--wx-dim:var(--color-muted);--wx-warm:#d9821f;--wx-cool:#3b82c4;--wx-on-sky:#fffffff7;--wx-on-sky-dim:#ffffffc2;--wx-on-sky-faint:#ffffff94;--wx-glass:#ffffff21;--wx-glass-line:#fff3;width:100%;min-width:0;max-width:100%;color:var(--wx-ink);font-family:var(--font-body);gap:12px;padding:0;overflow-x:hidden}.app-shell:has(.weather-workspace){width:min(1120px,100% - 32px);max-width:100%;padding-bottom:140px}.app-shell:has(.weather-workspace) .top-strip{grid-template-columns:minmax(0,1fr) auto;align-items:end}.app-shell:has(.weather-workspace) .top-actions{justify-content:flex-end}.app-shell:has(.weather-workspace) .tab-bar{width:min(780px,100vw - 28px);max-width:calc(100vw - 28px);padding:10px 12px calc(10px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(22px)saturate(1.45);backdrop-filter:blur(22px)saturate(1.45);background:#ffffffd1;border:1px solid #15192214;border-radius:24px;left:50%;right:auto;transform:translate(-50%);box-shadow:0 18px 44px #1519221f}.app-shell:has(.weather-workspace) .tab-bar button{border-radius:14px}.app-shell:has(.weather-workspace) .tab-bar button.active{background:#2f664514}@media (prefers-reduced-motion:no-preference){.weather-workspace>*{animation:.56s cubic-bezier(.16,1,.3,1) both weather-ws-rise;animation-delay:calc(var(--wx-i,0) * 70ms)}.weather-workspace>:nth-child(2){--wx-i:1}.weather-workspace>:nth-child(3){--wx-i:2}.weather-workspace>:nth-child(4){--wx-i:3}.weather-workspace>:nth-child(5){--wx-i:4}.weather-workspace>:nth-child(6){--wx-i:5}@keyframes weather-ws-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}}.weather-ws-hero{border:1px solid var(--wx-glass-line);min-width:0;max-width:100%;min-height:clamp(360px,46vw,470px);box-shadow:var(--shadow-panel);border-radius:24px;display:flex;position:relative;overflow:hidden}.weather-ws-hero:before,.weather-ws-hero:after{z-index:1;content:"";pointer-events:none;position:absolute;inset:0}.weather-ws-hero:before{background:radial-gradient(circle at 18% 22%,#ffffff29,#0000 32%),linear-gradient(125deg,#ffffff0f,#0000 48%,#09101e1f 100%)}.weather-ws-hero:after{opacity:.28;background-image:linear-gradient(#ffffff1f 1px,#0000 1px),linear-gradient(90deg,#ffffff17 1px,#0000 1px);background-size:116px 116px;-webkit-mask-image:linear-gradient(#0000005c,#0000 84%);mask-image:linear-gradient(#0000005c,#0000 84%)}.weather-ws-hero-content{z-index:2;flex-direction:column;gap:clamp(18px,3vw,28px);width:100%;min-width:0;max-width:100%;padding:clamp(22px,4vw,40px);display:flex;position:relative;overflow:hidden}.weather-ws-hero-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.weather-ws-hero-location{color:var(--wx-on-sky);letter-spacing:.04em;text-transform:uppercase;text-shadow:0 1px 3px #080f1e4d;margin:0;font-size:.9rem;font-weight:700}.weather-ws-hero-time{color:var(--wx-on-sky-dim);font-family:var(--font-mono);text-shadow:0 1px 2px #080f1e40;margin:5px 0 0;font-size:.76rem}.weather-ws-hero-live{border:1px solid var(--wx-glass-line);background:var(--wx-glass);color:var(--wx-on-sky);font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;-webkit-backdrop-filter:blur(10px)saturate(1.2);backdrop-filter:blur(10px)saturate(1.2);border-radius:999px;align-items:center;gap:7px;padding:7px 13px;font-size:.66rem;font-weight:800;display:inline-flex;box-shadow:inset 0 1px #fff3}.weather-ws-hero-live:before{content:"";background:#5ce39a;border-radius:50%;width:7px;height:7px;box-shadow:0 0 8px #5ce39ae6}@media (prefers-reduced-motion:no-preference){.weather-ws-hero-live:before{animation:2.4s ease-in-out infinite wx-live-pulse}}@keyframes wx-live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.78)}}.weather-ws-hero-main{flex-wrap:wrap;align-items:flex-end;gap:clamp(14px,3vw,34px);display:flex}.weather-ws-hero-shell{grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);align-items:end;gap:clamp(18px,3vw,30px);min-width:0;margin-top:auto;display:grid}.weather-ws-hero-primary{gap:16px;min-width:0;display:grid}.weather-ws-hero-pulse{flex-wrap:wrap;gap:8px;display:flex}.weather-ws-hero-pulse-item{max-width:100%;min-height:34px;color:var(--wx-on-sky);text-wrap:pretty;-webkit-backdrop-filter:blur(14px)saturate(1.15);backdrop-filter:blur(14px)saturate(1.15);background:#0c14261f;border:1px solid #ffffff29;border-radius:999px;align-items:center;padding:7px 12px;font-size:.78rem;font-weight:600;line-height:1.25;display:inline-flex}.weather-ws-hero-brief{border:1px solid var(--wx-glass-line);-webkit-backdrop-filter:blur(20px)saturate(1.3);backdrop-filter:blur(20px)saturate(1.3);background:linear-gradient(#080f1e29 0%,#ffffff14 100%);border-radius:20px;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:16px;min-width:0;max-width:100%;padding:18px;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffff2e,0 10px 26px #080f1e1f}.weather-ws-hero-brief-icon{background:#ffffff14;border:1px solid #fff3;border-radius:18px;place-items:center;width:58px;height:58px;font-size:2rem;line-height:1;display:grid;box-shadow:inset 0 1px #ffffff29}.weather-ws-hero-brief-copy{gap:8px;min-width:0;display:grid}.weather-ws-hero-brief-kicker{color:var(--wx-on-sky-faint);font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:.64rem;font-weight:800}.weather-ws-hero-brief-title{color:#fff;overflow-wrap:anywhere;text-wrap:balance;min-width:0;margin:0;font-size:clamp(1.05rem,2.5vw,1.35rem);font-weight:700;line-height:1.15}.weather-ws-hero-brief-text{color:var(--wx-on-sky-dim);overflow-wrap:anywhere;text-wrap:pretty;min-width:0;margin:0;font-size:.89rem;line-height:1.5}.weather-ws-hero-brief-meta{gap:8px;display:grid}.weather-ws-hero-brief-meta span{min-width:0;color:var(--wx-on-sky);font-family:var(--font-mono);letter-spacing:.03em;overflow-wrap:anywhere;font-size:.68rem;font-weight:700}.weather-ws-hero-temp{color:#fff;font-family:var(--font-heading);letter-spacing:-.05em;text-shadow:0 4px 26px #080f1e38;font-size:clamp(4.5rem,15vw,8rem);font-weight:200;line-height:.8}.weather-ws-hero-meta{gap:7px;padding-bottom:8px;display:grid}.weather-ws-hero-label{color:#fff;text-wrap:balance;text-shadow:0 1px 8px #080f1e47;margin:0;font-size:clamp(1.2rem,3vw,1.85rem);font-weight:600;line-height:1.05}.weather-ws-hero-feels{color:var(--wx-on-sky-dim);text-shadow:0 1px 4px #080f1e40;margin:0;font-size:.92rem;font-weight:600}.weather-ws-hero-range{font-family:var(--font-mono);gap:14px;margin:2px 0 0;font-size:.82rem;font-weight:700;display:flex}.weather-ws-hero-range-hi{color:var(--wx-on-sky)}.weather-ws-hero-range-lo{color:var(--wx-on-sky-faint)}.weather-ws-stats{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.weather-ws-stat{border:1px solid var(--wx-glass-line);background:var(--wx-glass);-webkit-backdrop-filter:blur(14px)saturate(1.3);backdrop-filter:blur(14px)saturate(1.3);border-radius:14px;align-items:center;gap:10px;min-width:0;padding:12px 13px;transition:transform .2s cubic-bezier(.16,1,.3,1),background .2s;display:flex;box-shadow:inset 0 1px #ffffff2e}.weather-ws-stat:hover{background:#fff3;transform:translateY(-2px)}.weather-ws-stat-icon{color:#ffffffe0;flex-shrink:0;width:20px;height:20px}.weather-ws-stat-icon svg{width:100%;height:100%;display:block}.weather-ws-stat-text{gap:2px;min-width:0;display:grid}.weather-ws-stat-label{color:var(--wx-on-sky-faint);letter-spacing:.1em;text-transform:uppercase;font-size:.58rem;font-weight:800}.weather-ws-stat-value{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:800;overflow:hidden}.wx-scene{z-index:0;--sky-1:#3f86cc;--sky-2:#6aa6d8;--sky-3:#aacfe8;--glow:#ffe0a066;--glow-x:80%;--glow-y:20%;--cloud-col:#ffffffeb;position:absolute;inset:0;overflow:hidden}.wx-sky{background:linear-gradient(180deg, var(--sky-1) 0%, var(--sky-2) 52%, var(--sky-3) 100%);position:absolute;inset:0}.wx-sky-glow{background:radial-gradient(circle at var(--glow-x) var(--glow-y), var(--glow) 0, transparent 46%);position:absolute;inset:0}.wx-scrim{background:linear-gradient(#0c142633 0%,#0c14260a 26%,#0c14261a 60%,#0c142661 100%);position:absolute;inset:0}.wx-scene--clear{--sky-1:#2c79d4;--sky-2:#4f9ce6;--sky-3:#9bcbf0;--glow:#ffde9699;--glow-x:78%;--glow-y:18%}.wx-scene--partly-cloudy{--sky-1:#3f86cc;--sky-2:#6aa6d8;--sky-3:#aacfe8;--glow:#ffe0a06b;--glow-x:80%;--glow-y:20%}.wx-scene--overcast{--sky-1:#6d7a88;--sky-2:#838f9b;--sky-3:#9ea8b2;--glow:transparent;--cloud-col:#c6cdd5}.wx-scene--rain{--sky-1:#455667;--sky-2:#566778;--sky-3:#6b7c8c;--glow:transparent;--cloud-col:#b0bac4}.wx-scene--storm{--sky-1:#2c3038;--sky-2:#363b45;--sky-3:#434954;--glow:#78829629;--glow-x:60%;--glow-y:30%;--cloud-col:#8f98a5}.wx-scene--snow{--sky-1:#7c8ea3;--sky-2:#9aabbe;--sky-3:#c0ccd9;--glow:#ffffff38;--glow-x:70%;--glow-y:16%;--cloud-col:#dde6ef}.wx-scene--fog{--sky-1:#8a929b;--sky-2:#9da5ad;--sky-3:#b4bbc1;--glow:transparent;--cloud-col:#d2d8dd}.wx-scene--wind{--sky-1:#4a7fb5;--sky-2:#6a9dd0;--sky-3:#a4c8e8;--glow:#fff0c84d;--glow-x:75%;--glow-y:24%;--cloud-col:#d6dfe8}.wx-scene--night.wx-scene--clear,.wx-scene--night.wx-scene--partly-cloudy,.wx-scene--night.wx-scene--default{--sky-1:#0a1733;--sky-2:#14254b;--sky-3:#21386a;--glow:#96b4ff29;--glow-x:30%;--glow-y:22%}.wx-scene--night.wx-scene--overcast{--sky-1:#262b33;--sky-2:#31373f;--sky-3:#3d444e;--cloud-col:#4c545f}.wx-scene--night.wx-scene--rain{--sky-1:#1f2730;--sky-2:#29313b;--sky-3:#353f4a;--cloud-col:#424b56}.wx-scene--night.wx-scene--storm{--sky-1:#161920;--sky-2:#1f232b;--sky-3:#2a2f38;--cloud-col:#3a4049}.wx-scene--night.wx-scene--snow{--sky-1:#2e3640;--sky-2:#3b4651;--sky-3:#4a5663;--cloud-col:#aeb9c6}.wx-scene--night.wx-scene--fog{--sky-1:#343941;--sky-2:#41474f;--sky-3:#4f5660;--cloud-col:#6a727c}.wx-scene--night.wx-scene--wind{--sky-1:#1a2a42;--sky-2:#243755;--sky-3:#334d6e;--cloud-col:#4a5a6e}.wx-sun{width:clamp(86px,14vw,130px);height:clamp(86px,14vw,130px);position:absolute;top:9%;right:11%}.wx-sun-core{background:radial-gradient(circle at 40% 38%,#fff8e3,#ffd874 58%,#ffb74d);border-radius:50%;position:absolute;inset:28%;box-shadow:0 0 38px 10px #ffd1788c}.wx-sun-halo{background:radial-gradient(circle,#ffdd9680,#0000 68%);border-radius:50%;animation:5.5s ease-in-out infinite wx-sun-pulse;position:absolute;inset:0}@keyframes wx-sun-pulse{0%,to{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.16)}}.wx-moon{background:radial-gradient(circle at 36% 34%,#f6f3e8,#d6d2c0 72%);border-radius:50%;width:clamp(58px,9vw,80px);height:clamp(58px,9vw,80px);position:absolute;top:11%;right:13%;overflow:hidden;box-shadow:0 0 28px 6px #d2dcff38}.wx-moon-shadow{background:var(--sky-1);border-radius:50%;width:86%;height:86%;position:absolute;top:-10%;left:34%}.wx-stars{position:absolute;inset:0}.wx-star{background:#fff;border-radius:50%;animation:ease-in-out infinite wx-twinkle;position:absolute;box-shadow:0 0 4px #ffffffb3}@keyframes wx-twinkle{0%,to{opacity:.25;transform:scale(.7)}50%{opacity:1;transform:scale(1)}}.wx-clouds{position:absolute;inset:0}.wx-cloud{will-change:transform;width:200px;height:64px;animation:linear infinite wx-cloud-drift;position:absolute;left:-260px}@keyframes wx-cloud-drift{0%{transform:translateX(-260px) scale(var(--wx-cloud-scale,1))}to{transform:translateX(110vw) scale(var(--wx-cloud-scale,1))}}.wx-cloud-puff,.wx-cloud-base{background:var(--cloud-col);filter:drop-shadow(0 6px 10px #141e321f);border-radius:999px;position:absolute}.wx-cloud-base{width:88%;height:38%;bottom:0;left:6%}.wx-cloud-puff--a{border-radius:50%;width:44%;height:70%;bottom:18%;left:8%}.wx-cloud-puff--b{border-radius:50%;width:52%;height:92%;bottom:26%;left:32%}.wx-cloud-puff--c{border-radius:50%;width:40%;height:64%;bottom:16%;left:56%}.wx-rain{position:absolute;inset:-10% -20%;transform:rotate(9deg)}.wx-drop{will-change:transform;background:linear-gradient(#0000,#c8e2ffcc);border-radius:999px;width:1.5px;animation:linear infinite wx-rain-fall;position:absolute;top:0}@keyframes wx-rain-fall{0%{transform:translateY(-30px)}to{transform:translateY(440px)}}.wx-snow{position:absolute;inset:0}.wx-flake{will-change:transform;background:#fff;border-radius:50%;animation:linear infinite wx-snow-fall;position:absolute;top:-16px;box-shadow:0 0 4px #ffffffa6}@keyframes wx-snow-fall{0%{transform:translateY(-16px)translate(0)}to{transform:translateY(460px) translateX(var(--wx-drift,0))}}.wx-lightning{background:#fff0;animation:7s linear infinite wx-flash;position:absolute;inset:0}@keyframes wx-flash{0%,90%,to{background:#fff0}91%{background:#ffffff80}92%{background:#ffffff0a}93.5%{background:#ffffff6b}95%{background:#fff0}}.wx-bolt{clip-path:polygon(52% 0,22% 54%,46% 54%,16% 100%,80% 38%,54% 38%,76% 0);opacity:0;filter:drop-shadow(0 0 10px #dcebffe6);background:linear-gradient(#fff,#ffffff80);width:38px;height:116px;animation:7s linear infinite wx-bolt-strike;position:absolute;top:9%;left:56%}@keyframes wx-bolt-strike{0%,90%,to{opacity:0}91%{opacity:.95}92%{opacity:0}93.5%{opacity:.8}95%{opacity:0}}.wx-fog{position:absolute;inset:0}.wx-fog-band{filter:blur(10px);background:linear-gradient(90deg,#0000,#fff6,#0000);width:140%;height:46px;animation:ease-in-out infinite alternate wx-fog-drift;position:absolute;left:-20%}.wx-fog-band--1{animation-duration:9s;top:28%}.wx-fog-band--2{animation-duration:12s;animation-delay:-3s;top:48%}.wx-fog-band--3{animation-duration:10.5s;animation-delay:-6s;top:66%}@keyframes wx-fog-drift{0%{transform:translate(-12%)}to{transform:translate(12%)}}.wx-sun-beams{pointer-events:none;width:clamp(86px,14vw,130px);height:clamp(86px,14vw,130px);position:absolute;top:9%;right:11%}.wx-beam{width:var(--wx-beam-width,2px);height:var(--wx-beam-length,80px);transform-origin:top;transform:rotate(var(--wx-beam-angle,0deg));filter:blur(1.5px);will-change:opacity;background:linear-gradient(#fff0b473 0%,#ffdc8c2e 40%,#0000 100%);border-radius:0 0 999px 999px;animation:ease-in-out infinite wx-beam-shimmer;position:absolute;top:50%;left:50%}@keyframes wx-beam-shimmer{0%,to{opacity:.25}50%{opacity:.65}}.wx-wind{position:absolute;inset:0;overflow:hidden}.wx-wind-streak{will-change:transform;background:linear-gradient(90deg,#0000 0%,#ffffff8c 30%,#ffffff59 70%,#0000 100%);border-radius:999px;height:1.5px;animation:linear infinite wx-wind-blow;position:absolute;left:-160px}@keyframes wx-wind-blow{0%{transform:translate(0)}to{transform:translate(calc(100vw + 200px))}}.wx-leaves{position:absolute;inset:0;overflow:hidden}.wx-leaf{background:hsl(var(--wx-leaf-hue,35), 60%, 42%);will-change:transform;border-radius:0 50% 50%;animation:linear infinite wx-leaf-tumble;position:absolute;left:-20px;box-shadow:inset -1px -1px 2px #00000026}@keyframes wx-leaf-tumble{0%{transform:translate(0)translateY(0)rotate(0)}25%{transform:translateX(calc(var(--wx-leaf-drift,250px) * .25)) translateY(18px) rotate(calc(var(--wx-leaf-rotate,90deg) * .3))}50%{transform:translateX(calc(var(--wx-leaf-drift,250px) * .55)) translateY(-10px) rotate(calc(var(--wx-leaf-rotate,90deg) * .65))}75%{transform:translateX(calc(var(--wx-leaf-drift,250px) * .82)) translateY(22px) rotate(calc(var(--wx-leaf-rotate,90deg) * .85))}to{transform:translateX(calc(var(--wx-leaf-drift,250px) + 30px)) translateY(8px) rotate(var(--wx-leaf-rotate,90deg))}}@media (prefers-reduced-motion:reduce){.wx-scene *,.wx-beam,.wx-wind-streak,.wx-leaf,.weather-ws-hero-live:before{animation:none!important}}.weather-ws-section{border:1px solid var(--wx-line);background:linear-gradient(180deg, color-mix(in srgb, var(--wx-card) 92%, #fff) 0%, var(--wx-card) 100%);box-shadow:var(--shadow-panel);border-radius:18px;padding:clamp(18px,3vw,26px)}.weather-ws-section--hourly{flex-direction:column;display:flex}.weather-ws-detail-grid{grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);align-items:stretch;gap:14px;display:grid}.weather-ws-section--daily{flex-direction:column;display:flex}.weather-ws-section-header{border-bottom:1px solid color-mix(in srgb, var(--wx-line) 74%, transparent);justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;padding-bottom:12px;display:flex}.weather-ws-section-header-titles{flex-direction:column;gap:2px;min-width:0;display:flex}.weather-ws-section-header h2{letter-spacing:-.03em;margin:0;font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:600;line-height:1.05}.weather-ws-section-kicker{color:var(--wx-accent);font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;margin:0 0 6px;font-size:.65rem;font-weight:800}.weather-ws-section-subtitle{color:var(--wx-muted);margin:6px 0 0;font-size:.85rem;line-height:1.4}.weather-ws-section-pill{border:1px solid color-mix(in srgb, #16a34a 22%, var(--wx-line));background:color-mix(in srgb, #16a34a 6%, var(--wx-card));color:#15803d;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:7px;margin-top:4px;padding:5px 11px;font-size:.62rem;font-weight:800;display:inline-flex}.weather-ws-section-pill-dot{background:#16a34a;border-radius:50%;width:6px;height:6px;position:relative}.weather-ws-section-pill-dot:after{content:"";opacity:.4;background:#16a34a;border-radius:50%;animation:2.4s ease-in-out infinite wx-section-pulse;position:absolute;inset:-3px}@keyframes wx-section-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:0;transform:scale(1.6)}}.weather-ws-hourly-track{overscroll-behavior-inline:contain;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:color-mix(in srgb, var(--wx-cool) 50%, var(--wx-line)) transparent;flex:1;align-items:stretch;gap:8px;padding:2px 2px 8px;display:flex;overflow-x:auto}.weather-ws-hourly-track::-webkit-scrollbar{height:4px}.weather-ws-hourly-track::-webkit-scrollbar-track{background:0 0}.weather-ws-hourly-track::-webkit-scrollbar-thumb{background:color-mix(in srgb, var(--wx-cool) 50%, var(--wx-line));border-radius:999px}.weather-ws-hourly-track:focus-visible{outline:3px solid color-mix(in srgb, var(--wx-accent) 40%, transparent);outline-offset:4px;border-radius:8px}.weather-ws-hour-item{border:1px solid var(--wx-line);background:linear-gradient(180deg, color-mix(in srgb, var(--wx-card-bg) 82%, #fff) 0%, var(--wx-card-bg) 100%);text-align:center;scroll-snap-align:start;border-radius:16px;align-content:space-between;justify-items:center;gap:5px;min-width:80px;padding:12px 10px 10px;transition:transform .18s,border-color .18s,box-shadow .18s;display:grid;box-shadow:inset 0 1px #ffffffa8}.weather-ws-hour-item:hover{border-color:var(--wx-accent);box-shadow:0 10px 18px color-mix(in srgb, var(--wx-accent) 14%, transparent);transform:translateY(-2px)}.weather-ws-hour-item--now{border-color:color-mix(in srgb, var(--wx-accent) 70%, var(--wx-line));background:color-mix(in srgb, var(--wx-accent) 10%, var(--wx-card-bg));box-shadow:0 0 0 3px color-mix(in srgb, var(--wx-accent) 18%, transparent), inset 0 1px 0 #ffffffa8}.weather-ws-hour-label{color:var(--wx-dim);font-family:var(--font-mono);letter-spacing:.04em;font-size:.62rem;font-weight:800}.weather-ws-hour-item--now .weather-ws-hour-label{color:var(--wx-accent)}.weather-ws-hour-emoji{font-size:1.5rem;line-height:1}.weather-ws-hour-degrees{color:var(--wx-ink);font-size:.92rem;font-weight:800}.weather-ws-hour-condition{color:var(--wx-muted);text-overflow:ellipsis;max-height:2.4em;font-size:.68rem;font-weight:600;line-height:1.2;overflow:hidden}.weather-ws-hour-rain-bar{background:color-mix(in srgb, var(--wx-cool) 8%, var(--wx-card-bg));border:1px solid color-mix(in srgb, var(--wx-cool) 18%, transparent);border-radius:6px;align-items:end;width:100%;height:22px;margin-top:auto;display:flex;overflow:hidden}.weather-ws-hour-rain-fill{width:100%;height:var(--rain);background:linear-gradient(180deg, color-mix(in srgb, var(--wx-cool) 50%, #fff) 0%, var(--wx-cool) 100%);min-height:3px;box-shadow:0 -2px 8px color-mix(in srgb, var(--wx-cool) 45%, transparent);border-radius:6px 6px 0 0;transition:height .4s cubic-bezier(.34,1.56,.64,1)}.weather-ws-hour-rain-label{min-height:.75rem;color:var(--wx-cool);font-family:var(--font-mono);font-size:.6rem;font-weight:800}.weather-ws-daily-list{flex:1;gap:6px;display:grid}.weather-ws-daily-row{border:1px solid var(--wx-line);background:linear-gradient(90deg, color-mix(in srgb, var(--wx-card-bg) 80%, #fff) 0%, var(--wx-card-bg) 100%);border-radius:14px;grid-template-columns:minmax(54px,.8fr) 36px minmax(86px,1.2fr) minmax(76px,.8fr) auto minmax(0,1fr);align-items:center;gap:8px;padding:10px 14px;transition:border-color .18s,background .18s,transform .18s;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffffa8}.weather-ws-daily-row:hover{border-color:var(--wx-accent);background:var(--wx-card);box-shadow:0 4px 14px color-mix(in srgb, var(--wx-accent) 10%, transparent), inset 0 1px 0 #ffffffa8;transform:translateY(-1px)}.weather-ws-daily-date{color:var(--wx-dim);font-family:var(--font-mono);letter-spacing:.04em;font-size:.72rem;font-weight:800}.weather-ws-daily-icon{text-align:center;font-size:1.5rem;line-height:1}.weather-ws-daily-label{min-width:0;color:var(--wx-ink);overflow-wrap:anywhere;font-size:.85rem;font-weight:700;line-height:1.2}.weather-ws-daily-temps{align-items:baseline;gap:2px;font-size:.86rem;display:flex}.weather-ws-daily-max{color:var(--wx-ink);font-weight:800}.weather-ws-daily-max:after{content:" /";color:var(--wx-muted);font-weight:300}.weather-ws-daily-min{color:var(--wx-muted);font-weight:600}.weather-ws-daily-uv{background:color-mix(in srgb, var(--wx-warm) 12%, var(--wx-card-bg));border:1px solid color-mix(in srgb, var(--wx-warm) 22%, transparent);color:var(--wx-warm);font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;padding:3px 8px;font-size:.6rem;font-weight:800;display:inline-flex}.weather-ws-daily-rain{align-items:center;gap:7px;display:flex}.weather-ws-daily-rain-bar{background:color-mix(in srgb, var(--wx-cool) 10%, var(--wx-card-bg));border-radius:999px;flex:1;height:6px;overflow:hidden}.weather-ws-daily-rain-fill{width:var(--rain);border-radius:inherit;background:linear-gradient(90deg, color-mix(in srgb, var(--wx-cool) 55%, #fff) 0%, var(--wx-cool) 60%, color-mix(in srgb, var(--wx-cool) 85%, #1e3a5f) 100%);height:100%;box-shadow:0 0 6px color-mix(in srgb, var(--wx-cool) 30%, transparent);transition:width .4s cubic-bezier(.34,1.56,.64,1)}.weather-ws-daily-rain span{text-align:right;min-width:26px;color:var(--wx-cool);font-family:var(--font-mono);flex-shrink:0;font-size:.62rem;font-weight:800}.weather-ws-summary{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.weather-ws-summary-item{border:1px solid var(--wx-line);border-left:3px solid color-mix(in srgb, var(--wx-accent) 35%, transparent);background:linear-gradient(180deg, color-mix(in srgb, var(--wx-card) 96%, #fff) 0%, var(--wx-card) 100%);min-width:0;box-shadow:var(--shadow-panel);border-radius:14px;align-content:start;gap:4px;padding:16px 18px;transition:border-left-color .18s,transform .18s;display:grid}.weather-ws-summary-item:hover{border-left-color:var(--wx-accent);transform:translateY(-1px)}.weather-ws-summary-label{color:var(--wx-accent);font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;font-size:.58rem;font-weight:800}.weather-ws-summary-item strong{color:var(--wx-ink);letter-spacing:-.015em;font-size:1.15rem;font-weight:800;line-height:1.2}.weather-ws-summary-item p{color:var(--wx-muted);text-wrap:pretty;margin:0;font-size:.78rem;line-height:1.4}.weather-ws-lunar{border:1px solid var(--wx-line);background:linear-gradient(135deg, color-mix(in srgb, var(--wx-card) 96%, #fff) 0%, var(--wx-card-bg) 100%);box-shadow:var(--shadow-panel);border-radius:20px;grid-template-columns:auto 1fr;align-items:center;gap:clamp(24px,4vw,40px);padding:clamp(22px,3vw,32px);display:grid;position:relative;overflow:hidden}.weather-ws-lunar:before{content:"";background:radial-gradient(circle at top right, color-mix(in srgb, var(--wx-accent) 5%, transparent) 0%, transparent 70%);pointer-events:none;opacity:.5;width:240px;height:240px;position:absolute;top:0;right:0}.weather-ws-lunar-orb{flex-shrink:0;width:clamp(90px,16vw,130px);height:clamp(90px,16vw,130px);position:relative}.weather-ws-lunar-orb-face{background:radial-gradient(circle at 36% 34%,#f5f0dc,#d9d2b8 68%,#c2b898 100%);border-radius:50%;transition:box-shadow .4s;position:absolute;inset:0;overflow:hidden;box-shadow:0 0 0 1px #ffffff4d,0 0 32px 4px #d9d2b838}.weather-ws-lunar-orb-shadow-waxing{background:var(--sky-1,#1a2a42);transform-origin:0;border-radius:0 100px 100px 0;width:50%;height:100%;transition:transform .4s cubic-bezier(.33,1,.68,1);display:none;position:absolute;top:0;right:0}.weather-ws-lunar-orb-shadow-waning{background:var(--sky-1,#1a2a42);transform-origin:100%;border-radius:100px 0 0 100px;width:50%;height:100%;transition:transform .4s cubic-bezier(.33,1,.68,1);display:none;position:absolute;top:0;left:0}.weather-ws-lunar-orb--new .weather-ws-lunar-orb-face{background:radial-gradient(circle at 36% 34%,#3a3628,#2a261c 72%,#1c1a14 100%);box-shadow:0 0 0 1px #ffffff14,0 0 28px 8px #c8d2ff14}.weather-ws-lunar-orb--new .weather-ws-lunar-orb-shadow-waxing,.weather-ws-lunar-orb--new .weather-ws-lunar-orb-shadow-waning{display:block;transform:scaleX(2)}.weather-ws-lunar-orb--waxing-crescent .weather-ws-lunar-orb-shadow-waxing{display:block;transform:scaleX(1.6)}.weather-ws-lunar-orb--first-quarter .weather-ws-lunar-orb-shadow-waxing{display:block;transform:scaleX(1)}.weather-ws-lunar-orb--waxing-gibbous .weather-ws-lunar-orb-shadow-waxing{display:block;transform:scaleX(.4)}.weather-ws-lunar-orb--full .weather-ws-lunar-orb-face{box-shadow:0 0 0 1px #ffffff59,0 0 40px 8px #dcd7b94d}.weather-ws-lunar-orb--waning-gibbous .weather-ws-lunar-orb-shadow-waning{display:block;transform:scaleX(.4)}.weather-ws-lunar-orb--last-quarter .weather-ws-lunar-orb-shadow-waning{display:block;transform:scaleX(1)}.weather-ws-lunar-orb--waning-crescent .weather-ws-lunar-orb-shadow-waning{display:block;transform:scaleX(1.6)}.weather-ws-lunar-orb-glow{pointer-events:none;background:radial-gradient(circle,#d9d2b824 0%,#0000 68%);border-radius:50%;position:absolute;inset:-16px}.weather-ws-lunar-data{z-index:1;gap:16px;min-width:0;display:grid;position:relative}.weather-ws-lunar-primary{gap:6px;display:grid}.weather-ws-lunar-kicker{color:var(--wx-accent);font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;margin:0;font-size:.65rem;font-weight:800}.weather-ws-lunar-phase-name{letter-spacing:-.03em;color:var(--wx-ink);margin:0;font-size:clamp(1.4rem,3vw,2rem);font-weight:600;line-height:1.05}.weather-ws-lunar-illumination{font-family:var(--font-mono);color:var(--wx-muted);margin:0;font-size:.88rem;font-weight:700}.weather-ws-lunar-next{border:1px solid color-mix(in srgb, var(--wx-line) 70%, transparent);background:color-mix(in srgb, var(--wx-card-bg) 60%, var(--wx-card));border-radius:12px;align-items:center;gap:10px;padding:10px 14px;display:flex}.weather-ws-lunar-next-icon{width:20px;height:20px;color:var(--wx-muted);flex-shrink:0}.weather-ws-lunar-next-icon svg{width:100%;height:100%;display:block}.weather-ws-lunar-next-text{gap:2px;min-width:0;display:grid}.weather-ws-lunar-next-label{color:var(--wx-muted);letter-spacing:.04em;text-transform:uppercase;font-size:.7rem;font-weight:700}.weather-ws-lunar-next-value{color:var(--wx-ink);font-size:.88rem;font-weight:600}.weather-ws-lunar-timeline{align-items:center;gap:4px;display:flex}.weather-ws-lunar-timeline-seg{background:color-mix(in srgb, var(--wx-line) 60%, transparent);border-radius:2px;flex:1;height:4px;position:relative;overflow:hidden}.weather-ws-lunar-timeline-seg--active{background:color-mix(in srgb, var(--wx-accent) 20%, var(--wx-line))}.weather-ws-lunar-timeline-seg--active:after{content:"";background:var(--wx-accent);width:var(--lunar-fill,50%);border-radius:2px;position:absolute;inset:0}.weather-ws-lunar-timeline-dot{background:color-mix(in srgb, var(--wx-line) 60%, transparent);border-radius:50%;flex-shrink:0;width:7px;height:7px}.weather-ws-lunar-timeline-dot--active{background:var(--wx-accent);box-shadow:0 0 8px color-mix(in srgb, var(--wx-accent) 40%, transparent)}.weather-ws-env-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:start;gap:16px;display:grid}.weather-ws-env-card{border:1px solid var(--wx-line);background:linear-gradient(180deg, color-mix(in srgb, var(--wx-card) 96%, #fff) 0%, var(--wx-card-bg) 100%);box-shadow:var(--shadow-panel);border-top:3px solid #0000;border-radius:18px;flex-direction:column;gap:14px;padding:20px;transition:transform .2s,border-color .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.weather-ws-env-card:after{content:"";background:radial-gradient(circle at top right, color-mix(in srgb, var(--wx-accent) 7%, transparent) 0%, transparent 70%);pointer-events:none;opacity:.6;width:120px;height:120px;position:absolute;top:0;right:0}.weather-ws-env-card:hover{border-color:var(--wx-accent);border-top-color:var(--wx-accent);box-shadow:0 12px 28px color-mix(in srgb, var(--wx-accent) 10%, transparent);transform:translateY(-2px)}.weather-ws-env-card--uv-low,.weather-ws-env-card--aqi-good,.weather-ws-env-card--aqi-fair,.weather-ws-env-card--uv-low:hover,.weather-ws-env-card--aqi-good:hover,.weather-ws-env-card--aqi-fair:hover{border-top-color:#16a34a}.weather-ws-env-card--uv-moderate,.weather-ws-env-card--aqi-moderate,.weather-ws-env-card--uv-moderate:hover,.weather-ws-env-card--aqi-moderate:hover{border-top-color:#b45309}.weather-ws-env-card--uv-high,.weather-ws-env-card--aqi-poor,.weather-ws-env-card--uv-high:hover,.weather-ws-env-card--aqi-poor:hover{border-top-color:#dc2626}.weather-ws-env-card--uv-very-high,.weather-ws-env-card--aqi-very-poor,.weather-ws-env-card--uv-very-high:hover,.weather-ws-env-card--aqi-very-poor:hover{border-top-color:#b91c1c}.weather-ws-env-card--uv-extreme,.weather-ws-env-card--aqi-extremely-poor,.weather-ws-env-card--uv-extreme:hover,.weather-ws-env-card--aqi-extremely-poor:hover{border-top-color:#7f1d1d}.weather-ws-env-card-header{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.weather-ws-env-card-icon{background:color-mix(in srgb, var(--wx-accent) 10%, var(--wx-card));width:38px;height:38px;color:var(--wx-accent);border-radius:11px;place-items:center;transition:background .2s,transform .2s;display:grid}.weather-ws-env-card:hover .weather-ws-env-card-icon{background:color-mix(in srgb, var(--wx-accent) 16%, var(--wx-card));transform:scale(1.04)}.weather-ws-env-card-icon svg{width:21px;height:21px;display:block}.weather-ws-env-card-title{color:var(--wx-ink);letter-spacing:-.015em;font-size:.95rem;font-weight:800}.weather-ws-env-card-body{z-index:1;flex-direction:column;gap:14px;display:flex;position:relative}.weather-ws-env-card-value-row{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.weather-ws-env-card-value{color:var(--wx-ink);font-family:var(--font-heading);letter-spacing:-.05em;font-size:clamp(2.6rem,5vw,3.4rem);font-weight:300;line-height:1}.weather-ws-env-card-badge{width:fit-content;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:6px;padding:5px 11px;font-size:.66rem;font-weight:800;display:inline-flex}.weather-ws-env-card-badge:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.weather-ws-env-card-badge--low,.weather-ws-env-card-badge--good,.weather-ws-env-card-badge--fair{background:color-mix(in srgb, #4ade80 12%, var(--wx-card-bg));color:#16a34a}.weather-ws-env-card-badge--moderate{background:color-mix(in srgb, #fbbf24 12%, var(--wx-card-bg));color:#b45309}.weather-ws-env-card-badge--high,.weather-ws-env-card-badge--poor{background:color-mix(in srgb, #f87171 12%, var(--wx-card-bg));color:#dc2626}.weather-ws-env-card-badge--very-high,.weather-ws-env-card-badge--very-poor{background:color-mix(in srgb, #ef4444 16%, var(--wx-card-bg));color:#b91c1c}.weather-ws-env-card-badge--extreme,.weather-ws-env-card-badge--extremely-poor{background:color-mix(in srgb, #7f1d1d 12%, var(--wx-card-bg));color:#7f1d1d}.weather-ws-env-card-gauge{flex-direction:column;gap:6px;display:flex}.weather-ws-env-card-gauge-track{background:color-mix(in srgb, var(--wx-line) 70%, transparent);height:7px;box-shadow:inset 0 1px 2px color-mix(in srgb, var(--wx-ink) 8%, transparent);border-radius:999px;position:relative;overflow:hidden}.weather-ws-env-card-gauge-fill{height:100%;width:var(--gauge);box-shadow:0 0 0 1px color-mix(in srgb, currentColor 12%, transparent) inset;border-radius:999px;transition:width .6s cubic-bezier(.22,1,.36,1)}.weather-ws-env-card-gauge-fill--low,.weather-ws-env-card-gauge-fill--good,.weather-ws-env-card-gauge-fill--fair{background:#22c55e}.weather-ws-env-card-gauge-fill--moderate{background:#f59e0b}.weather-ws-env-card-gauge-fill--high,.weather-ws-env-card-gauge-fill--poor{background:#ef4444}.weather-ws-env-card-gauge-fill--very-high,.weather-ws-env-card-gauge-fill--very-poor{background:#dc2626}.weather-ws-env-card-gauge-fill--extreme,.weather-ws-env-card-gauge-fill--extremely-poor{background:#7f1d1d}.weather-ws-env-card-gauge-labels{color:var(--wx-dim);font-family:var(--font-mono);letter-spacing:.04em;justify-content:space-between;font-size:.6rem;font-weight:700;display:flex}.weather-ws-env-card-stats{border:1px solid var(--wx-line);background:var(--wx-line);border-radius:12px;grid-template-columns:1fr 1fr;gap:1px;padding:1px;display:grid;overflow:hidden}.weather-ws-env-card-stat{background:var(--wx-card);flex-direction:column;gap:3px;min-width:0;padding:9px 12px;display:flex}.weather-ws-env-card-stat-label{color:var(--wx-dim);font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;font-size:.58rem;font-weight:800}.weather-ws-env-card-stat strong{color:var(--wx-ink);letter-spacing:-.005em;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:700;line-height:1.2;overflow:hidden}.weather-ws-env-card-advice{border-left:2px solid var(--wx-accent);background:color-mix(in srgb, var(--wx-accent) 5%, var(--wx-card));color:var(--wx-ink);text-wrap:pretty;border-radius:0 10px 10px 0;align-items:flex-start;gap:10px;margin:0;padding:11px 12px 11px 14px;font-size:.78rem;line-height:1.5;display:flex}.weather-ws-env-card-advice strong{color:var(--wx-ink);font-weight:800}.weather-ws-env-card-advice-icon{background:color-mix(in srgb, var(--wx-accent) 14%, transparent);width:18px;height:18px;color:var(--wx-accent);border-radius:6px;flex-shrink:0;place-items:center;margin-top:1px;display:inline-grid}.weather-ws-env-card-advice-icon svg{width:12px;height:12px;display:block}.weather-ws-env-card-detail-row{flex-wrap:wrap;gap:16px;display:flex}.weather-ws-env-card-detail{color:var(--wx-muted);font-family:var(--font-mono);font-size:.74rem;font-weight:700}.weather-ws-env-card-unavailable{color:var(--wx-dim);font-size:.85rem;line-height:1.5}.weather-ws-env-card-unavailable .small-note{color:var(--wx-dim);margin-top:6px;font-size:.76rem}.weather-ws-env-card-pollen-summary{border:1px solid var(--wx-line);background:var(--wx-card);border-radius:12px;grid-template-columns:auto 1fr;align-items:stretch;gap:14px;padding:12px;display:grid}.weather-ws-env-card-pollen-level{border-right:1px solid var(--wx-line);flex-direction:column;gap:4px;padding-right:14px;display:flex}.weather-ws-env-card-pollen-level-kicker{color:var(--wx-dim);font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;font-size:.58rem;font-weight:800}.weather-ws-env-card-pollen-level-value{color:var(--wx-ink);font-family:var(--font-heading);letter-spacing:-.02em;font-size:1.5rem;font-weight:400;line-height:1}.weather-ws-env-card-pollen-top{flex-direction:column;gap:4px;min-width:0;display:flex}.weather-ws-env-card-pollen-top-kicker{color:var(--wx-dim);font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;font-size:.58rem;font-weight:800}.weather-ws-env-card-pollen-top-name{color:var(--wx-ink);letter-spacing:-.01em;text-transform:capitalize;font-size:1.05rem;font-weight:700;line-height:1.1}.weather-ws-env-card-pollen-top-count{color:var(--wx-muted);font-family:var(--font-mono);letter-spacing:.02em;font-size:.72rem;font-weight:600}.weather-ws-pollen-list{flex-direction:column;gap:6px;display:flex}.weather-ws-pollen-row{border:1px solid var(--wx-line);background:var(--wx-card);border-radius:11px;align-items:center;gap:12px;padding:8px 12px;transition:border-color .15s,background .15s;display:flex}.weather-ws-pollen-row:hover{border-color:color-mix(in srgb, var(--wx-accent) 60%, var(--wx-line));background:color-mix(in srgb, var(--wx-accent) 3%, var(--wx-card))}.weather-ws-pollen-info{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.weather-ws-pollen-name{color:var(--wx-dim);font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;font-size:.65rem;font-weight:800}.weather-ws-pollen-bar{width:100%}.weather-ws-pollen-bar-track{background:var(--wx-line);border-radius:999px;height:4px;overflow:hidden}.weather-ws-pollen-bar-fill{height:100%;width:var(--pollen);border-radius:999px;transition:width .6s cubic-bezier(.22,1,.36,1)}.weather-ws-pollen-bar-fill--low{background:#22c55e}.weather-ws-pollen-bar-fill--moderate{background:#f59e0b}.weather-ws-pollen-bar-fill--high{background:#ef4444}.weather-ws-pollen-meta{flex-shrink:0;align-items:center;gap:10px;display:flex}.weather-ws-pollen-count{color:var(--wx-ink);text-align:right;min-width:24px;font-size:.88rem;font-weight:700}.weather-ws-pollen-badge{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;text-align:center;border-radius:999px;min-width:44px;padding:3px 10px;font-size:.6rem;font-weight:800}.weather-ws-pollen-badge--low{background:color-mix(in srgb, #4ade80 12%, var(--wx-card-bg));color:#16a34a}.weather-ws-pollen-badge--moderate{background:color-mix(in srgb, #fbbf24 12%, var(--wx-card-bg));color:#b45309}.weather-ws-pollen-badge--high{background:color-mix(in srgb, #f87171 12%, var(--wx-card-bg));color:#dc2626}.weather-ws-empty{border:1px solid var(--wx-glass-line);min-height:clamp(360px,50vh,460px);box-shadow:var(--shadow-panel);border-radius:24px;align-items:center;display:flex;position:relative;overflow:hidden}.weather-ws-empty-content{z-index:2;color:#fff;max-width:560px;padding:clamp(28px,6vw,64px);position:relative}.weather-ws-empty-kicker{color:var(--wx-on-sky);font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;text-shadow:0 1px 4px #080f1e4d;margin:0 0 10px;font-size:.68rem;font-weight:800}.weather-ws-empty h2{color:#fff;letter-spacing:-.04em;text-shadow:0 2px 16px #080f1e47;max-width:600px;margin:0;font-size:clamp(2rem,6vw,3.4rem);font-weight:600;line-height:.98}.weather-ws-empty-desc{max-width:480px;color:var(--wx-on-sky-dim);text-shadow:0 1px 4px #080f1e40;margin:14px 0 0;font-size:.96rem;line-height:1.55}.weather-ws-empty-action{border:1px solid var(--wx-glass-line);background:var(--wx-glass);color:#fff;-webkit-backdrop-filter:blur(10px)saturate(1.2);backdrop-filter:blur(10px)saturate(1.2);margin-top:18px}.weather-ws-empty-action:hover{background:#ffffff38;border-color:#fff6}@media (width<=980px){.weather-ws-hero-shell{grid-template-columns:1fr}.weather-ws-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.weather-ws-detail-grid{grid-template-columns:1fr}.weather-ws-env-grid,.weather-ws-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.weather-ws-lunar{text-align:center;grid-template-columns:1fr;justify-items:center}.weather-ws-lunar-next{justify-content:center}.weather-ws-daily-row{grid-template-columns:minmax(72px,.8fr) 44px 1fr auto;gap:10px}.weather-ws-daily-uv,.weather-ws-daily-rain{display:none}}@media (width<=768px){.weather-ws-hero-shell{grid-template-columns:1fr}.weather-ws-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=620px){.app-shell:has(.weather-workspace){width:min(100% - 24px,568px)}.app-shell:has(.weather-workspace) .top-strip{grid-template-columns:1fr}.app-shell:has(.weather-workspace) .top-actions{justify-content:flex-start}.app-shell:has(.weather-workspace) .tab-bar{width:min(100% - 16px,568px);padding-inline:8px}.weather-ws-hero-content{gap:16px;padding:18px}.weather-ws-hero-main{gap:12px}.weather-ws-hero-temp{font-size:clamp(3.5rem,18vw,5.4rem)}.weather-ws-hero-pulse{gap:7px}.weather-ws-hero-pulse-item{min-height:32px;padding:6px 10px}.weather-ws-hero-brief{grid-template-columns:auto minmax(0,1fr);gap:12px;padding:14px}.weather-ws-hero-brief-icon{border-radius:14px;width:44px;height:44px;font-size:1.5rem}.weather-ws-hero-brief-meta{gap:5px}.weather-ws-stats{scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;grid-template-columns:none;grid-auto-columns:minmax(112px,1fr);grid-auto-flow:column;gap:8px;padding-bottom:4px;overflow-x:auto}.weather-ws-stat{scroll-snap-align:start;min-height:64px;padding:10px}.weather-ws-stat-value{white-space:normal;font-size:.82rem}.weather-ws-section{border-radius:16px;padding:16px}.weather-ws-hour-item{min-width:70px;padding:10px 8px}.weather-ws-daily-row{grid-template-columns:minmax(60px,.7fr) 36px 1fr auto;gap:8px;padding:10px 12px}.weather-ws-env-grid{grid-template-columns:1fr}.weather-ws-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.weather-ws-lunar{gap:20px;padding:18px}}@media (width<=400px){.weather-ws-summary,.weather-ws-hero-brief{grid-template-columns:1fr}.weather-ws-hero-brief-icon{display:none}.weather-ws-hero-content{padding:14px}}@media (width<=480px){.weather-ws-daily-row{grid-template-columns:1fr auto;gap:8px}.weather-ws-daily-icon{display:none}}@media (width<=820px){.weather-forecast-grid{grid-template-columns:repeat(3,minmax(92px,1fr));row-gap:14px}.weather-forecast-grid .weather-forecast-card:nth-child(4){border-left:0}}@media (width<=520px){.weather-panel{overflow-x:auto}.weather-panel .big-number{font-size:3.25rem}.weather-forecast-grid{overscroll-behavior-inline:contain;scrollbar-width:none;grid-template-columns:repeat(5,minmax(112px,1fr));overflow-x:auto}.weather-forecast-grid::-webkit-scrollbar{display:none}.weather-forecast-grid .weather-forecast-card:nth-child(odd){border-left:1px solid #e1f7e029}.weather-forecast-grid .weather-forecast-card:first-child{border-left:0}.weather-hourly-track{gap:6px}.weather-hour-card{min-width:64px;padding:6px 8px}.info-tooltip-bubble{max-width:180px;font-size:.68rem}}.home-dashboard+*{margin-top:0}.edit-mode-toolbar{border:1px dashed var(--color-accent);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-accent) 6%, var(--color-surface));align-items:center;gap:10px;padding:10px 14px;display:flex}.edit-mode-label{color:var(--color-accent);letter-spacing:.02em;font-size:.82rem;font-weight:700}.edit-mode-active{border-color:var(--color-accent);color:var(--color-accent)}.edit-widget-wrapper{position:relative}.edit-widget-wrapper .panel{border:2px solid #0000;transition:border-color .18s}.edit-widget-wrapper:hover .panel{border-color:color-mix(in srgb, var(--color-accent) 30%, transparent)}.module-edit-controls{border-top:1px solid var(--color-line);background:color-mix(in srgb, var(--color-surface) 85%, var(--color-bg));border-radius:0 0 var(--radius-md) var(--radius-md);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;display:flex}.edit-reorder{align-items:center;gap:4px;display:flex}.edit-options{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.edit-options .compact-field{min-width:0}.edit-display-options{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.hidden-widgets-strip{border:1px dashed var(--color-muted);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface-2) 50%, transparent);padding:12px 14px}.hidden-widgets-strip .kicker{margin-bottom:8px}.hidden-widgets-list{flex-wrap:wrap;gap:8px;display:flex}.hidden-widgets-list button{white-space:nowrap}.tide-panel{background:var(--app-card);gap:16px;padding:20px;display:grid;overflow:hidden}.tide-panel .panel-heading{background:linear-gradient(145deg, color-mix(in srgb, var(--color-accent-2) 14%, var(--app-card)) 0%, color-mix(in srgb, var(--color-accent-2) 4%, var(--app-card)) 100%);border-bottom:1px solid color-mix(in srgb, var(--color-accent-2) 22%, var(--color-line));justify-content:space-between;align-items:center;gap:16px;margin:-20px -20px 0;padding:20px 22px 18px;display:flex}.tide-panel .kicker{color:color-mix(in srgb, var(--color-accent-2) 80%, var(--color-muted));letter-spacing:.08em;margin-bottom:6px;font-family:inherit;font-size:.72rem}.tide-panel h2{color:var(--app-ink);letter-spacing:-.04em;font-family:Aptos Display,Trebuchet MS,sans-serif;font-size:1.22rem}.tide-panel-summary{max-width:30ch;color:color-mix(in srgb, var(--color-muted) 90%, var(--color-accent-2));margin-top:4px;font-size:.84rem}.tide-mark{background:color-mix(in srgb, var(--color-accent-2) 16%, var(--color-surface));border:1.5px solid color-mix(in srgb, var(--color-accent-2) 28%, var(--color-line));width:46px;height:46px;box-shadow:0 2px 8px color-mix(in srgb, var(--color-accent-2) 18%, transparent);border-radius:12px;flex:0 0 46px;place-items:center;font-size:1.45rem;line-height:1;display:inline-grid}.tide-section{gap:8px;display:grid}.tide-section-head{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.tide-section-title{color:var(--app-ink);letter-spacing:.07em;text-transform:uppercase;font-size:.86rem;font-weight:900}.tide-section-subtitle{color:#7b7772;font-size:.78rem}.tide-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.tide-feature-card,.tide-day-card,.tide-empty-state{border:1.5px solid color-mix(in srgb, var(--color-line) 80%, transparent);background:color-mix(in srgb, var(--color-surface) 70%, transparent);border-radius:14px}.tide-feature-card{gap:6px;min-height:140px;padding:16px 18px;display:grid}.tide-feature-card.high{border-color:color-mix(in srgb, var(--color-accent) 50%, var(--color-line));background:linear-gradient(155deg, color-mix(in srgb, var(--color-accent) 7%, var(--color-surface)) 0%, color-mix(in srgb, var(--color-surface) 92%, transparent) 70%)}.tide-feature-card.low{border-color:color-mix(in srgb, var(--color-accent-2) 50%, var(--color-line));background:linear-gradient(155deg, color-mix(in srgb, var(--color-accent-2) 7%, var(--color-surface)) 0%, color-mix(in srgb, var(--color-surface) 92%, transparent) 70%)}.tide-feature-badge,.tide-day-event span,.tide-day-head span{color:var(--color-muted);letter-spacing:.09em;text-transform:uppercase;font-size:.7rem;font-weight:900}.tide-feature-card strong{color:var(--app-ink);letter-spacing:-.03em;font-size:1.02rem}.tide-feature-time{color:var(--app-ink);letter-spacing:-.04em;font-size:1.62rem;font-weight:900;line-height:1}.tide-feature-card em{color:#7b7772;font-size:.76rem;font-style:normal;font-weight:700}.tide-feature-card small,.tide-day-event small{color:#77746f;font-size:.82rem}.tide-day-list{gap:10px;display:grid}.tide-day-card{gap:10px;padding:12px 14px;display:grid}.tide-day-head{justify-content:flex-start;align-items:center;gap:10px;display:flex}.tide-day-title{flex-wrap:wrap;align-items:center;gap:6px;min-width:0;display:flex}.tide-day-head strong{color:var(--app-ink);letter-spacing:-.03em;font-size:.92rem}.tide-day-badge{background:color-mix(in srgb, var(--color-accent-2) 12%, var(--color-surface));color:var(--color-accent-2);letter-spacing:.06em;text-transform:uppercase;border-radius:999px;align-items:center;padding:2px 7px;font-size:.68rem;font-weight:900;display:inline-flex}.tide-day-events{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.tide-day-event{border:1.5px solid color-mix(in srgb, var(--color-line) 75%, transparent);background:color-mix(in srgb, var(--color-surface) 82%, transparent);border-radius:12px;gap:4px;min-width:0;padding:9px 10px;display:grid}.tide-day-event.high{border-color:color-mix(in srgb, var(--color-accent) 45%, var(--color-line));background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent) 6%, var(--color-surface)) 0%, var(--color-surface) 70%)}.tide-day-event.low{border-color:color-mix(in srgb, var(--color-accent-2) 45%, var(--color-line));background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent-2) 6%, var(--color-surface)) 0%, var(--color-surface) 70%)}.tide-day-event strong{color:var(--app-ink);letter-spacing:-.02em;font-size:.94rem}.tide-empty-state{color:#6d6a65;padding:14px;font-size:.88rem}.tide-source-note{border-top:1px solid color-mix(in srgb, var(--color-line) 50%, transparent);color:#6d6a65;margin-top:4px;padding-top:8px;font-size:.83rem}.tide-source-note a{color:#285f43}.tide-current-section{gap:10px;display:grid}.tide-current-scale{gap:8px;display:grid}.tide-current-track{background:color-mix(in srgb, var(--color-line) 60%, transparent);border-radius:999px;height:8px;position:relative;overflow:visible}.tide-current-fill{background:linear-gradient(90deg, color-mix(in srgb, var(--color-tide-sand) 55%, var(--color-surface)) 0%, color-mix(in srgb, var(--color-tide-waves) 55%, var(--color-surface)) 100%);border-radius:999px;height:100%;transition:width .4s;position:absolute;top:0;left:0}.tide-current-needle{background:var(--app-ink);border:2px solid var(--color-surface);border-radius:50%;width:14px;height:14px;transition:left .4s;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 1px 4px #00000040}.tide-current-labels{justify-content:space-between;gap:12px;display:flex}.tide-current-endpoint{gap:2px;min-width:0;display:grid}.tide-current-endpoint strong{color:var(--app-ink);letter-spacing:-.02em;font-size:.78rem}.tide-current-endpoint small{color:#7b7772;font-size:.72rem}.tide-current-low strong{color:var(--color-tide-sand)}.tide-current-high strong{color:var(--color-tide-waves)}.tide-current-height{color:#77746f;font-size:.82rem}.tide-countdown-section{display:grid}.tide-countdown-row{align-items:baseline;gap:8px;display:flex}.tide-countdown-label{color:var(--color-muted);letter-spacing:.04em;text-transform:uppercase;font-size:.78rem;font-weight:700}.tide-countdown-value{color:var(--app-ink);letter-spacing:-.03em;font-size:1.15rem;font-weight:900}.workspace-grid{grid-template-columns:1fr}.workspace-grid.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.network-panel .plain-row{text-decoration:none}.network-panel .status-badge{align-self:start}.launchpad-grid,.note-launchpad-grid,.network-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.launchpad-card{min-width:0}.launchpad-card p,.launchpad-card small{color:var(--color-muted)}.note-launchpad-card{text-align:left}.note-launchpad-head{gap:4px;display:grid}.note-launchpad-card p{margin:0}.note-launchpad-card .tag-line{margin-top:4px}@media (width>=821px){:root[data-nav=side] .app-shell:not(:has(.admin-grid)){display:block}:root[data-nav=side] .app-shell:not(:has(.admin-grid))>*{grid-column:auto}}@media (width<=620px){.app-shell{width:min(100% - 24px,568px)}.top-actions span,.top-actions .origin-link{display:none}}.star-marker{color:var(--color-accent);font-style:normal}.item-row{gap:4px;display:grid}.item-row .item{margin-bottom:0}.item-metadata-form{border:1px solid var(--color-line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-surface) 85%, transparent);flex-wrap:wrap;gap:8px;margin:8px 0;padding:8px;display:flex}.item-metadata-form .metadata-field{align-items:center;gap:4px;display:flex}.item-metadata-form .metadata-field input{min-width:80px;max-width:120px;padding:4px 8px;font-size:.85rem}.item-metadata-form .metadata-label{color:var(--color-muted);white-space:nowrap;font-size:.75rem}.item-metadata-inline{flex-wrap:wrap;align-items:center;gap:6px;padding:2px 12px 6px;display:flex}.item-metadata-inline .metadata-chip{color:var(--color-muted);background:color-mix(in srgb, var(--color-line) 40%, transparent);border-radius:var(--radius-sm);white-space:nowrap;padding:2px 6px;font-size:.78rem}.item-metadata-inline .metadata-add,.item-metadata-inline .metadata-edit{min-height:unset;min-width:unset;padding:2px 6px;font-size:.75rem}.item-metadata-edit{background:color-mix(in srgb, var(--color-surface) 90%, transparent);border:1px solid var(--color-line);border-radius:var(--radius-md);flex-wrap:wrap;align-items:flex-end;gap:6px;padding:6px 12px;display:flex}.item-metadata-edit .metadata-field{flex-direction:column;gap:2px;display:flex}.item-metadata-edit .metadata-field input{min-width:80px;max-width:120px;padding:4px 8px;font-size:.85rem}.item-metadata-edit .metadata-label{color:var(--color-muted);font-size:.7rem}.status-badge{border-radius:var(--radius-sm);vertical-align:middle;text-transform:uppercase;letter-spacing:.03em;margin-left:6px;padding:1px 5px;font-size:.7rem;font-weight:600;display:inline-block}.status-overdue{background:var(--color-danger);color:var(--color-surface)}.status-due_soon{background:var(--color-accent);color:var(--color-surface)}.status-missed{background:var(--color-muted);color:var(--color-surface)}.list-filter-row{flex-wrap:wrap;gap:6px;margin:8px 0;display:flex}.list-filter-row .ghost{min-height:unset;padding:4px 8px;font-size:.8rem}.list-filter-row .ghost.active{background:var(--color-accent);color:var(--color-surface);border-color:var(--color-accent)}.home-status-overdue{color:var(--color-danger);font-weight:600}.home-status-due-soon{color:var(--color-accent);font-weight:600}.home-status-missed{color:var(--color-danger);font-weight:600}.lists-toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.lists-search{border:1px solid var(--border,#e5e7eb);background:var(--color-surface,#fff);border-radius:8px;flex:1;min-width:160px;padding:8px 12px;font-size:.85rem}.lists-type-filter,.lists-sort{border:1px solid var(--border,#e5e7eb);background:var(--color-surface,#fff);border-radius:8px;padding:8px 12px;font-size:.85rem}.list-type-description{background:var(--panel-bg,#00000005);color:var(--text-muted,#666);border-radius:8px;margin-bottom:8px;padding:8px 12px;font-size:.82rem}.list-type-description p{margin:0}.list-type-examples{opacity:.8;font-style:italic}.list-empty-state{text-align:center;color:var(--text-muted,#999);padding:24px 16px;font-size:.9rem}.list-recurring-hint{color:var(--text-muted,#888);padding:4px 0;font-size:.8rem;font-style:italic}@media (width<=920px){.workspace-grid.admin-grid{grid-template-columns:1fr}.user-actions{justify-content:flex-start}}.whiteboard-workspace{background:#fff;border:1px solid #1519221f;border-radius:12px;flex-direction:column;height:clamp(560px,100svh - 210px,760px);min-height:560px;display:flex;overflow:hidden;box-shadow:0 18px 34px #26392e14}.wb-toolbar{background:var(--panel-bg,#fff);border-bottom:1px solid var(--border,#e5e7eb);flex-wrap:wrap;align-items:center;gap:8px;min-height:48px;padding:8px 12px;display:flex}.wb-tool-group,.wb-color-group,.wb-width-group,.wb-action-group{align-items:center;gap:4px;display:flex}.wb-divider{background:var(--border,#e5e7eb);width:1px;height:24px;margin:0 4px}.wb-tool-btn{border:1px solid var(--border,#e5e7eb);background:var(--panel-bg,#fff);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:background .15s,border-color .15s;display:flex}.wb-tool-btn:hover{background:var(--hover-bg,#f3f4f6)}.wb-tool-btn.active{background:var(--active-bg,#e5e7eb);border-color:var(--accent,#3b82f6)}.wb-color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:border-color .15s,transform .1s}.wb-color-swatch.active{border-color:var(--text,#111827);transform:scale(1.15)}.wb-custom-color{border:2px dashed var(--border,#d1d5db);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;overflow:hidden}.wb-custom-color input[type=color]{cursor:pointer;border:none;width:40px;height:40px;margin:-6px;padding:0}.wb-width-btn{border:1px solid var(--border,#e5e7eb);background:var(--panel-bg,#fff);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s,border-color .15s;display:flex}.wb-width-btn:hover{background:var(--hover-bg,#f3f4f6)}.wb-width-btn.active{background:var(--active-bg,#e5e7eb);border-color:var(--accent,#3b82f6)}.wb-width-dot{background:var(--text,#111827);border-radius:50%;display:block}.wb-action-btn{border:1px solid var(--border,#e5e7eb);background:var(--panel-bg,#fff);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:background .15s;display:flex}.wb-action-btn:hover:not(:disabled){background:var(--hover-bg,#f3f4f6)}.wb-action-btn:disabled{opacity:.35;cursor:default}.wb-clear-btn:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5}.wb-canvas-container{overscroll-behavior:contain;scrollbar-gutter:stable both-edges;background-color:#fff;background-image:linear-gradient(#2f66450f 1px,#0000 1px),linear-gradient(90deg,#2f66450f 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:32px 32px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;flex:1;position:relative;overflow:auto}.wb-canvas{touch-action:none;background:0 0;max-width:none;max-height:none;display:block}@media (width<=768px){.wb-toolbar{gap:4px;padding:6px 8px}.wb-divider{display:none}.wb-color-swatch{width:24px;height:24px}.wb-tool-btn,.wb-width-btn,.wb-action-btn{width:32px;height:32px}}.whiteboard-workspace{--wb-paper:#fffdfa;background:var(--wb-paper);touch-action:none;-webkit-user-select:none;user-select:none;width:100%;height:100dvh;position:relative;overflow:hidden}.wb-canvas-viewport{position:absolute;inset:0;overflow:hidden}.wb-canvas-surface{position:absolute;inset:0}.wb-canvas-surface.surface-plain{background:var(--wb-paper)}.wb-canvas-surface.surface-grid{background:linear-gradient(#39764d12 1px, transparent 1px), linear-gradient(90deg, #39764d12 1px, transparent 1px), var(--wb-paper);background-size:32px 32px}.wb-canvas-surface.surface-dots{background:radial-gradient(circle at 1px 1px, #39764d29 1px, transparent 0), var(--wb-paper);background-size:28px 28px}.wb-canvas-surface.surface-ledger{background:linear-gradient(90deg, transparent 71px, #c1353529 72px, transparent 73px), linear-gradient(#2f68c914 1px, transparent 1px), var(--wb-paper);background-size:auto,34px 34px,auto}.wb-canvas-viewport .wb-canvas{touch-action:none;background:0 0;width:100%;max-width:none;height:100%;max-height:none;display:block;position:absolute;inset:0}.wb-empty-state{-webkit-backdrop-filter:blur(12px);pointer-events:none;z-index:2;background:#ffffffe0;border-radius:18px;gap:6px;padding:20px 28px;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 16px 40px #2134271f}.wb-empty-state strong{color:var(--app-ink,#1a2e28);font-size:1.1rem}.wb-empty-state span{color:var(--text-muted,#56636a);font-size:.88rem}.wb-floating-toolbar{bottom:max(92px, calc(env(safe-area-inset-bottom,0px) + 82px));z-index:100;-webkit-backdrop-filter:blur(20px)saturate(1.4);padding:7px 10px;padding-bottom:max(6px, env(safe-area-inset-bottom,0px));padding-left:max(8px, env(safe-area-inset-left,0px));padding-right:max(8px, env(safe-area-inset-right,0px));background:linear-gradient(#fffffff5,#f6f4eee6);border:1px solid #1c28251a;border-radius:999px;align-items:center;gap:4px;transition:opacity .3s,transform .3s;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 18px 42px #21342724,0 2px 8px #2134270f}.wb-floating-toolbar.auto-hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(8px)}.wb-floating-toolbar.visible{opacity:1;pointer-events:auto}.wb-ftool-btn{width:38px;height:38px;color:var(--app-ink,#1a2e28);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:999px;flex-shrink:0;place-items:center;font-size:1rem;transition:background .15s,color .15s,transform .15s;display:grid;position:relative}.wb-ftool-btn:hover{background:#1c282514;transform:translateY(-1px)}.wb-ftool-btn.active{color:#195c42;background:#dceee6;box-shadow:inset 0 0 0 1px #195c421a}.wb-ftool-btn:disabled{opacity:.25;cursor:default}.wb-ftool-divider{background:#1c28251a;flex-shrink:0;width:1px;height:20px;margin:0 2px}.whiteboard-widget{display:grid}.whiteboard-widget-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px;display:grid}.whiteboard-widget-stats>div{background:#f8f6f0e6;border-radius:14px;gap:4px;padding:12px 14px;display:grid}.whiteboard-widget-stats span,.whiteboard-widget-stats strong{letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted,#627177);font-size:.75rem}.whiteboard-widget-stats strong{color:var(--app-ink);font-size:1rem}.wb-preview{background:linear-gradient(#fffffff5,#f8f6f0f5);border:1px solid #21342714;border-radius:18px;min-height:140px;position:relative;overflow:hidden}.wb-preview-large{min-height:190px}.wb-preview-widget{min-height:150px;margin-bottom:14px}.wb-preview-widget.expanded{min-height:190px}.wb-preview-canvas{width:100%;height:100%;display:block}.wb-preview-empty{color:var(--text-muted,#56636a);background:#ffffffe6;border-radius:14px;gap:4px;padding:12px 14px;display:grid;position:absolute;inset:auto 18px 18px;box-shadow:0 12px 24px #21342714}@media (pointer:coarse){.wb-ftool-btn{width:44px;height:44px;font-size:1.15rem}.wb-floating-toolbar{bottom:max(88px, calc(env(safe-area-inset-bottom,0px) + 80px));gap:4px;padding:8px 10px}}@media (width<=640px){.wb-floating-toolbar{justify-content:center;width:auto;max-width:calc(100vw - 32px)}}.wb-brush-slider{right:max(20px, env(safe-area-inset-right,0px));z-index:100;-webkit-backdrop-filter:blur(18px)saturate(1.35);pointer-events:auto;-webkit-tap-highlight-color:transparent;background:linear-gradient(#fffffff7,#f6f4eee6);border:1px solid #1c28251a;border-radius:999px;flex-direction:column;align-items:center;gap:10px;padding:14px 9px;transition:opacity .3s,transform .3s;display:flex;position:fixed;top:50%;transform:translateY(-50%);box-shadow:0 18px 42px #21342724,0 2px 8px #2134270f}.wb-brush-slider.auto-hidden{opacity:0;pointer-events:none;transform:translateY(-50%)translate(8px)}.wb-brush-slider.visible{opacity:1}.wb-brush-value{min-width:26px;height:26px;color:var(--app-ink,#1a2e28);text-align:center;background:#f2f0ea;border-radius:999px;place-items:center;font-size:.72rem;font-weight:800;line-height:1;display:grid}.wb-brush-track{cursor:ns-resize;touch-action:none;border-radius:999px;justify-content:center;align-items:center;width:32px;height:154px;display:flex;position:relative}.wb-brush-track:before{content:"";background:linear-gradient(0deg, var(--app-ink,#1a2e28) var(--wb-brush-pct), #1c28251f 0);border-radius:999px;width:4px;position:absolute;top:7px;bottom:7px;left:50%;transform:translate(-50%)}.wb-brush-thumb{left:50%;bottom:var(--wb-brush-pct);background:var(--app-ink,#1a2e28);pointer-events:none;border:3px solid #fff;border-radius:50%;width:18px;height:18px;transition:bottom 50ms;position:absolute;transform:translate(-50%)translateY(50%);box-shadow:0 4px 12px #21342740,0 0 0 1px #1c282514}.wb-brush-track:focus-visible{outline-offset:3px;outline:3px solid #195c4247}.wb-brush-preview{width:var(--wb-brush-preview-size);height:var(--wb-brush-preview-size);background:var(--app-ink,#1a2e28);border-radius:50%;flex-shrink:0;transition:width .1s,height .1s}.wb-pen-icon{position:relative}.wb-pen-color-dot{border:1.5px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;bottom:2px;right:2px;box-shadow:0 0 0 1px #1c282526}.wb-color-popover{z-index:110;-webkit-backdrop-filter:blur(20px)saturate(1.4);background:linear-gradient(#fffffffa,#f6f4eeeb);border:1px solid #1c28251a;border-radius:22px;padding:12px 14px;animation:.15s wb-pop-in;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);box-shadow:0 18px 42px #21342729,0 2px 8px #2134270f}@keyframes wb-pop-in{0%{opacity:0;transform:translate(-50%)translateY(6px)scale(.96)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.wb-color-grid{grid-template-columns:repeat(7,auto);place-items:center;gap:10px;display:grid}.wb-color-swatch{cursor:pointer;-webkit-tap-highlight-color:transparent;border:3px solid #fff;border-radius:50%;flex-shrink:0;width:38px;height:38px;padding:0;transition:transform .12s,box-shadow .15s;box-shadow:0 0 0 1px #1c282514,0 5px 12px #2134271f}.wb-color-swatch:hover{transform:translateY(-1px)scale(1.06)}.wb-color-swatch.active{box-shadow:0 0 0 2px #fff, 0 0 0 4px var(--app-ink,#1a2e28), 0 8px 18px #2134272e}@media (pointer:coarse),(width<=768px){.wb-brush-slider{right:auto;left:max(12px, env(safe-area-inset-left,0px));flex-direction:column;gap:10px;padding:12px 8px;top:50%;bottom:auto;transform:translateY(-50%)}.wb-brush-slider.auto-hidden{opacity:0;pointer-events:none;transform:translateY(-50%)translate(-8px)}.wb-brush-slider.visible{opacity:1;transform:translateY(-50%)}.wb-brush-track{width:34px;height:138px}.wb-brush-thumb{width:20px;height:20px}.wb-color-popover{max-width:calc(100vw - 24px);bottom:calc(100% + 14px)}.wb-color-swatch{width:40px;height:40px}}html[data-color-mode=dark]{--color-bg:#111312;--color-surface:#1a1d1c;--color-surface-2:#242927;--color-ink:#f4f1e8;--color-muted:#8a857c;--color-line:#3b4240;--color-accent:#f0c36d;--color-accent-2:#91d0c4;--color-danger:#ff9b94}
