:root{color-scheme:dark light;--font-display: "Space Grotesk", ui-sans-serif, system-ui, sans-serif;--font-ui: "Inter", ui-sans-serif, system-ui, sans-serif;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--step-total: clamp(3.5rem, 12vw, 7rem);--step-h1: clamp(1.5rem, 3.5vw, 2.25rem);--step-h2: clamp(1.15rem, 2.4vw, 1.5rem);--step-body: clamp(1rem, 1.5vw, 1.05rem);--step-small: .85rem}:root,:root[data-theme=dark]{color-scheme:dark;--ink: #1a120e;--surface: #241a15;--surface-2: #302319;--surface-3: #3d2d20;--border: #4c3a2b;--text: #f7edd8;--muted: #a89078;--accent: #f5811f;--accent-deep: #d15e0a;--accent-2: #2ea55a;--accent-2-deep: #1a7a3d;--go: #2ea55a;--stop: #e05a3d;--warn: #f2b93b;--btn-primary-fg: #241004;--tint-accent: rgba(245, 129, 31, .12);--tint-accent-border: rgba(245, 129, 31, .4);--tint-go: rgba(46, 165, 90, .18);--tint-go-border: rgba(46, 165, 90, .45);--tint-stop: rgba(224, 90, 61, .12);--tint-stop-border: rgba(224, 90, 61, .35);--tint-warn: rgba(242, 185, 59, .12);--tint-warn-border: rgba(242, 185, 59, .35);--topbar-bg: rgba(26, 18, 14, .85);--header-fade: rgba(26, 18, 14, .9);--backdrop: rgba(0, 0, 0, .55);--shadow-1: 0 1px 0 rgba(255, 255, 255, .03) inset, 0 8px 20px rgba(0, 0, 0, .35);--shadow-2: 0 24px 60px rgba(0, 0, 0, .55)}@media (prefers-color-scheme: light){:root:not([data-theme]){color-scheme:light;--ink: #fbf3e1;--surface: #ffffff;--surface-2: #f6e9c9;--surface-3: #ecdcac;--border: #d9c48a;--text: #2a170a;--muted: #7a5e3d;--accent: #d15e0a;--accent-deep: #a94708;--accent-2: #0f7a3a;--accent-2-deep: #0a5d2a;--go: #0f7a3a;--stop: #b23a1b;--warn: #b57a20;--btn-primary-fg: #ffffff;--tint-accent: rgba(209, 94, 10, .1);--tint-accent-border: rgba(209, 94, 10, .45);--tint-go: rgba(15, 122, 58, .12);--tint-go-border: rgba(15, 122, 58, .4);--tint-stop: rgba(178, 58, 27, .1);--tint-stop-border: rgba(178, 58, 27, .35);--tint-warn: rgba(181, 122, 32, .14);--tint-warn-border: rgba(181, 122, 32, .4);--topbar-bg: rgba(251, 243, 225, .85);--header-fade: rgba(251, 243, 225, .9);--backdrop: rgba(42, 23, 10, .45);--shadow-1: 0 1px 0 rgba(255, 255, 255, .6) inset, 0 8px 20px rgba(90, 60, 20, .1);--shadow-2: 0 24px 60px rgba(90, 60, 20, .18)}}:root[data-theme=light]{color-scheme:light;--ink: #fbf3e1;--surface: #ffffff;--surface-2: #f6e9c9;--surface-3: #ecdcac;--border: #d9c48a;--text: #2a170a;--muted: #7a5e3d;--accent: #d15e0a;--accent-deep: #a94708;--accent-2: #0f7a3a;--accent-2-deep: #0a5d2a;--go: #0f7a3a;--stop: #b23a1b;--warn: #b57a20;--btn-primary-fg: #ffffff;--tint-accent: rgba(209, 94, 10, .1);--tint-accent-border: rgba(209, 94, 10, .45);--tint-go: rgba(15, 122, 58, .12);--tint-go-border: rgba(15, 122, 58, .4);--tint-stop: rgba(178, 58, 27, .1);--tint-stop-border: rgba(178, 58, 27, .35);--tint-warn: rgba(181, 122, 32, .14);--tint-warn-border: rgba(181, 122, 32, .4);--topbar-bg: rgba(251, 243, 225, .85);--header-fade: rgba(251, 243, 225, .9);--backdrop: rgba(42, 23, 10, .45);--shadow-1: 0 1px 0 rgba(255, 255, 255, .6) inset, 0 8px 20px rgba(90, 60, 20, .1);--shadow-2: 0 24px 60px rgba(90, 60, 20, .18)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--ink);color:var(--text);font-family:var(--font-ui);font-size:var(--step-body);line-height:1.45;-webkit-font-smoothing:antialiased;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}a{color:var(--accent);text-decoration:none}a:hover,a:focus-visible{text-decoration:underline}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.tabular{font-family:var(--font-display);font-variant-numeric:tabular-nums}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.container{width:min(1200px,100%);margin-inline:auto;padding:clamp(12px,3vw,32px)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(16px,2.5vw,28px);box-shadow:var(--shadow-1)}.stack{display:flex;flex-direction:column;gap:16px}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.muted{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;background:var(--surface-2);border:1px solid var(--border)}.badge.live{background:var(--tint-go);color:var(--go);border-color:var(--tint-go-border)}.badge.done{background:var(--surface-2);color:var(--muted)}.badge.warn{background:var(--tint-warn);color:var(--warn);border-color:var(--tint-warn-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);font-weight:600;min-height:48px;transition:transform .05s ease,background-color .15s ease,border-color .15s ease}.btn:hover{background:var(--surface-3)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:var(--btn-primary-fg);border-color:var(--accent-deep)}.btn.primary:hover{background:var(--accent-deep);color:var(--btn-primary-fg)}.btn.secondary{background:var(--accent-2);color:#fff;border-color:var(--accent-2-deep)}.btn.secondary:hover{background:var(--accent-2-deep);color:#fff}.btn.ghost{background:transparent}.btn.danger{background:var(--tint-stop);border-color:var(--tint-stop-border);color:var(--stop)}.btn[disabled]{opacity:.45;cursor:not-allowed}.input,.select{background:var(--ink);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;color:var(--text);min-height:48px;width:100%}.field-label{font-size:.85rem;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.header{position:sticky;top:0;z-index:5;background:linear-gradient(180deg,var(--ink) 0%,var(--header-fade) 100%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.header-inner{display:grid;gap:8px;grid-template-columns:1fr auto;align-items:center;padding:14px clamp(12px,3vw,28px)}.header-brand{font-family:var(--font-display);font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.9rem;color:var(--muted)}.header-title{font-family:var(--font-display);font-size:var(--step-h1);font-weight:700;line-height:1.1}.header-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.header-total{text-align:right;font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:clamp(2rem,6vw,3.25rem);font-weight:700;color:var(--accent);line-height:1}.header-total .label{display:block;font-size:.75rem;font-weight:600;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}.gate{display:grid;gap:16px;padding:12px}.total-display-wrap{position:relative}.total-display{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:var(--step-total);text-align:center;padding:8px 0;color:var(--text);line-height:1;letter-spacing:-.02em}.total-display .sub{display:block;margin-top:8px;font-size:.85rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-ui);font-weight:600}.add-pulse{position:absolute;top:8px;left:50%;font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:clamp(2rem,6vw,3rem);font-weight:700;color:var(--go);pointer-events:none;animation:add-pulse-rise 1.1s cubic-bezier(.2,.7,.2,1) forwards;text-shadow:0 6px 30px var(--tint-go-border);z-index:1}@keyframes add-pulse-rise{0%{opacity:0;transform:translate(-50%,40px) scale(.6)}15%{opacity:1;transform:translate(-50%,24px) scale(1.15)}30%{opacity:1;transform:translate(-50%,16px) scale(1)}to{opacity:0;transform:translate(-50%,-60px) scale(.95)}}@media (prefers-reduced-motion: reduce){.add-pulse{animation-duration:.3s}}.number-pad{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.number-pad button{aspect-ratio:1 / 1;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);font-family:var(--font-display);font-size:clamp(2rem,6vw,2.75rem);font-weight:700;min-height:72px;transition:transform .05s ease,background-color .15s ease}.number-pad button[aria-pressed=true]{background:var(--accent);color:var(--btn-primary-fg);border-color:var(--accent-deep);box-shadow:0 0 0 2px var(--accent-deep) inset}.number-pad button:active{transform:scale(.97)}.number-pad button[disabled]{opacity:.4;cursor:not-allowed}.add-btn{width:100%;min-height:64px;font-size:1.15rem;border-radius:var(--radius-md);background:var(--accent);color:var(--btn-primary-fg);border:1px solid var(--accent-deep);font-weight:700;letter-spacing:.04em;text-transform:uppercase}.add-btn:disabled{background:var(--surface-2);color:var(--muted);border-color:var(--border)}.day-strip{display:flex;gap:6px;overflow-x:auto;padding:2px 2px 6px;scroll-snap-type:x mandatory}.day-strip button{flex:0 0 auto;padding:6px 10px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);scroll-snap-align:start;min-width:68px;text-align:left;line-height:1.15;transition:background-color .15s ease,border-color .15s ease}.day-strip button.live{border-color:var(--go);background:var(--tint-go)}.day-strip button.done{color:var(--muted)}.day-strip button.locked{opacity:.55;cursor:not-allowed}.day-strip button[aria-current=true]{outline:2px solid var(--accent);outline-offset:2px}.day-strip .day-num{display:block;font-family:var(--font-display);font-weight:700;font-size:.85rem;letter-spacing:.02em}.day-strip .day-num .lock{font-size:.7em;margin-left:4px;opacity:.75}.day-strip .day-count{display:block;font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:.85rem;color:var(--muted);margin-top:2px}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);display:grid;place-items:end center;padding:16px;z-index:100}.sheet{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;width:min(560px,100%);box-shadow:var(--shadow-2)}.sheet h2{font-family:var(--font-display);margin:0 0 8px}.sheet .actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}@media (min-width: 640px){.sheet-backdrop{place-items:center}}@media (min-width: 640px){.gate{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px;padding:20px}.gate>.pad-column{grid-column:1}.gate>.side-column{grid-column:2}.number-pad button{min-height:72px}}@media (min-width: 1024px){.live-dashboard{display:grid;grid-template-columns:1.2fr 1fr;gap:24px}.live-dashboard .col-a{grid-column:1}.live-dashboard .col-b{grid-column:2}}.nav{display:flex;gap:12px;padding:12px clamp(12px,3vw,28px);border-top:1px solid var(--border);flex-wrap:wrap;background:var(--surface)}.nav a{color:var(--muted);font-weight:600;padding:6px 10px;border-radius:var(--radius-sm)}.nav a.active{color:var(--text);background:var(--surface-2)}.hero-grid{display:grid;gap:20px;grid-template-columns:1fr}@media (min-width: 900px){.hero-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}.stat{display:grid;gap:4px}.stat .value{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--accent)}.stat .label{font-size:.85rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.table th{color:var(--muted);font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.08em}.sparkline{width:100%;height:96px;display:block}.offline-banner{background:var(--tint-warn);color:var(--warn);border-bottom:1px solid var(--tint-warn-border);padding:6px 14px;font-size:.85rem;text-align:center}.center{display:grid;place-items:center;min-height:60dvh;padding:24px}.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px clamp(12px,3vw,24px);background:var(--topbar-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);min-height:52px}.topbar-brand{display:inline-flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-family:var(--font-display);font-weight:700;letter-spacing:.02em;padding:4px 6px;border-radius:var(--radius-sm)}.topbar-brand:hover,.topbar-brand:focus-visible{text-decoration:none;background:var(--surface-2)}.topbar-logo{color:var(--accent);font-size:.85rem;line-height:1;transform:translateY(-1px)}.topbar-name{font-size:.95rem;letter-spacing:.02em}.topbar-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:transparent;border:1px solid transparent;transition:background-color .15s ease,border-color .15s ease}.topbar-menu-btn:hover{background:var(--surface-2);border-color:var(--border)}.hamburger{display:inline-flex;flex-direction:column;justify-content:space-between;width:20px;height:14px}.hamburger span{display:block;height:2px;width:100%;background:var(--text);border-radius:2px}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:var(--backdrop);display:flex;justify-content:flex-end;animation:fade-in .15s ease}.drawer{width:min(320px,88%);height:100dvh;background:var(--surface);border-left:1px solid var(--border);padding:18px;display:flex;flex-direction:column;gap:14px;animation:slide-in .2s cubic-bezier(.25,1,.35,1);box-shadow:var(--shadow-2)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid var(--border)}.drawer-close{width:36px;height:36px;border-radius:var(--radius-md);background:transparent;border:1px solid var(--border);font-size:1rem;line-height:1}.drawer-nav{display:flex;flex-direction:column;gap:4px;padding-top:4px}.drawer-link{display:block;padding:12px 14px;border-radius:var(--radius-md);color:var(--muted);text-decoration:none;font-weight:600;font-size:1rem;transition:background-color .15s ease,color .15s ease}.drawer-link:hover,.drawer-link:focus-visible{background:var(--surface-2);color:var(--text);text-decoration:none}.drawer-link.active{background:var(--tint-accent);color:var(--accent);border:1px solid var(--tint-accent-border)}.drawer-footer{padding-top:12px;border-top:1px solid var(--border)}.theme-picker{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.theme-picker-label{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}.theme-picker-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md)}.theme-btn{padding:8px 10px;border-radius:var(--radius-sm);background:transparent;border:1px solid transparent;font-size:.85rem;font-weight:600;color:var(--muted);transition:background-color .15s ease,color .15s ease,border-color .15s ease}.theme-btn:hover{color:var(--text)}.theme-btn.active{background:var(--surface);color:var(--accent);border-color:var(--tint-accent-border)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}@media (prefers-reduced-motion: reduce){.drawer-backdrop,.drawer{animation:none}}.admin-shell{display:grid;gap:20px;grid-template-columns:1fr;min-height:calc(100dvh - 220px)}@media (min-width: 900px){.admin-shell{grid-template-columns:300px minmax(0,1fr);align-items:start}}.admin-sidebar{display:flex;flex-direction:column;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;position:sticky;top:12px;align-self:start;max-height:calc(100dvh - 40px)}.admin-sidebar-header{display:flex;align-items:baseline;justify-content:space-between;padding:4px 4px 8px;border-bottom:1px solid var(--border)}.admin-sidebar-header h2{margin:0;font-family:var(--font-display);font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.admin-event-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;overflow-y:auto;min-height:40px}.admin-event-item button{width:100%;text-align:left;padding:10px 12px;border-radius:var(--radius-md);background:transparent;border:1px solid transparent;display:flex;flex-direction:column;gap:4px;transition:background-color .15s ease,border-color .15s ease}.admin-event-item button:hover{background:var(--surface-2)}.admin-event-item button[aria-current=true]{background:var(--surface-2);border-color:var(--accent)}.admin-event-item .name{font-weight:600;color:var(--text)}.admin-event-item .meta{display:flex;gap:8px;font-size:.8rem;color:var(--muted)}.admin-event-item .status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--muted);align-self:center}.admin-event-item .status-dot.active{background:var(--go)}.admin-event-item .status-dot.completed{background:var(--muted)}.admin-event-item .status-dot.archived{background:var(--surface-3)}.admin-detail{display:flex;flex-direction:column;gap:16px;min-width:0}.admin-empty{padding:48px 20px;text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--surface)}.admin-empty h2{font-family:var(--font-display);margin:12px 0 6px;color:var(--text)}.admin-detail-header{display:flex;gap:16px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}.admin-detail-header h1{font-family:var(--font-display);margin:0;font-size:clamp(1.5rem,3vw,2rem)}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.admin-section h3{margin:0 0 12px;font-family:var(--font-display);font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.share-link{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:10px 12px;background:var(--ink);border:1px solid var(--border);border-radius:var(--radius-md)}.share-link+.share-link{margin-top:8px}.share-link .label{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;min-width:44px}.share-link .url{font-family:var(--font-display);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.share-link .copy{padding:6px 10px;min-height:36px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);font-size:.85rem}.share-link .copy.ok{border-color:var(--go);color:var(--go)}.gk-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.gk-item{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:12px;background:var(--ink);border:1px solid var(--border);border-radius:var(--radius-md)}.gk-item .name{font-weight:600}.gk-item .role{font-size:.8rem;color:var(--muted)}.gk-item .actions{display:flex;gap:6px}.gk-item .actions .btn{padding:6px 10px;min-height:34px;font-size:.85rem;font-weight:500;text-transform:none;letter-spacing:0}.gk-item.inactive{opacity:.6}.section-cta{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-form{display:flex;flex-direction:column;gap:14px}.modal-form label{display:flex;flex-direction:column;gap:4px}.modal-form .radio-row{display:flex;gap:12px;flex-wrap:wrap}.modal-form .radio-row label{flex-direction:row;gap:6px;align-items:center;cursor:pointer}.hint{font-size:.8rem;color:var(--muted);margin:0}.hint code{background:var(--surface-2);padding:1px 6px;border-radius:4px;font-size:.85em}.inline-error{color:var(--stop);font-size:.85rem;margin:0}.inline-ok{color:var(--go);font-size:.85rem;margin:0}.danger-zone{border:1px solid var(--tint-stop-border);background:var(--tint-stop)}.danger-zone h3{color:var(--stop)}
