:root{--accent: #f49b01;--accent-bright: #ffb84d;--accent-dim: #c47d01;--accent-glow: rgba(244, 155, 1, .45);--accent-soft: rgba(244, 155, 1, .12);--bg-deep: #08080b;--bg: #0e0e12;--bg-elevated: #14141a;--glass-bg: rgba(255, 255, 255, .04);--glass-bg-strong: rgba(255, 255, 255, .07);--glass-border: rgba(255, 255, 255, .1);--glass-border-accent: rgba(244, 155, 1, .25);--glass-blur: 24px;--text: #f4f4f8;--text-muted: #9a9aad;--success: #5ee9b5;--warn: #fbbf24;--danger: #ff6b6b;--radius: 16px;--radius-sm: 10px;--mobile-header: 0px;--touch-min: 44px;--shadow-glass: 0 8px 32px rgba(0, 0, 0, .4), inset 0 1px 0 rgba(255, 255, 255, .06);--shadow-glow: 0 0 40px rgba(244, 155, 1, .15);font-family:SF Pro Display,Inter,system-ui,-apple-system,sans-serif;line-height:1.5;color:var(--text)}*,*:before,*:after{box-sizing:border-box}html{overflow-x:hidden}body{margin:0;min-height:100vh;background:var(--bg-deep);overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 120% 70% at 50% -20%,rgba(244,155,1,.07) 0%,transparent 55%),linear-gradient(180deg,var(--bg) 0%,var(--bg-deep) 100%)}#root{position:relative;z-index:1;min-height:100vh;overflow-x:hidden}.readonly-banner-short,.btn-start-short{display:none}.status-strip{display:contents}@media(prefers-reduced-motion:reduce){.section-card,.progress-fill,.live-dot{animation:none!important}}.app{position:relative;z-index:1;display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar-heading{min-width:0}.meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:.65rem}.role-chip{font-size:.65rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.2rem .5rem;border-radius:6px;border:1px solid var(--glass-border);background:var(--glass-bg)}.role-chip--admin{color:var(--accent-bright);border-color:var(--glass-border-accent);background:var(--accent-soft)}.role-chip--viewer{color:#a8c4ff;border-color:#78a0ff40;background:#5078ff14}.live-pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--success);padding:.2rem .45rem;border-radius:999px;border:1px solid rgba(94,233,181,.25);background:#5ee9b514}.live-pill--sync .live-dot{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.live-dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 8px #5ee9b599;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.progress-panel{display:flex;align-items:center;gap:.85rem;margin-bottom:.75rem}.progress-ring{--progress: 0;position:relative;width:52px;height:52px;flex-shrink:0;border-radius:50%;background:conic-gradient(var(--accent) calc(var(--progress) * 1%),rgba(255,255,255,.06) 0);box-shadow:0 0 20px #f49b0133}.progress-ring:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:#08080ce6;border:1px solid var(--glass-border)}.progress-ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--accent-bright);font-variant-numeric:tabular-nums;z-index:1}.progress-panel .progress-wrap{flex:1;margin-bottom:0;min-width:0}.sidebar{position:sticky;top:0;align-self:start;height:100vh;max-height:100vh;overflow-y:auto;display:flex;flex-direction:column;background:#0e0e12b8;backdrop-filter:blur(var(--glass-blur)) saturate(1.5);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.5);border-right:1px solid var(--glass-border);box-shadow:var(--shadow-glass),inset -1px 0 #f49b010d}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:#f49b0140;border-radius:99px}.sidebar-top{padding:1.25rem;border-bottom:1px solid var(--glass-border)}.sidebar-top h1{margin:0;font-size:1.15rem;font-weight:600;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text) 0%,var(--accent-bright) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.subtitle{margin:.25rem 0 1rem;color:var(--text-muted);font-size:.85rem}.progress-wrap{margin-bottom:.75rem}.progress-bar{height:8px;background:#ffffff0f;border-radius:99px;overflow:hidden;border:1px solid var(--glass-border);box-shadow:inset 0 2px 6px #0000004d}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-dim),var(--accent),var(--accent-bright));box-shadow:0 0 12px #f49b0159;transition:width .4s cubic-bezier(.4,0,.2,1)}.progress-summary{display:none;align-items:baseline;justify-content:space-between;margin-bottom:.5rem}.progress-percent{font-size:1.75rem;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums;line-height:1;text-shadow:0 0 24px var(--accent-glow)}.progress-count{font-size:.9rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.progress-text{display:block;margin-top:.35rem;font-size:.8rem;color:var(--text-muted)}.progress-text-desktop{display:block}.timer{margin:0;font-size:.9rem;color:var(--accent-bright);font-variant-numeric:tabular-nums;text-shadow:0 0 12px var(--accent-glow)}.nav{flex:1;overflow-y:auto;padding:.5rem 0}.nav ul{list-style:none;margin:0;padding:0}.nav-link{width:100%;display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;background:transparent;color:var(--text-muted);font-size:.78rem;text-align:left;cursor:pointer;border-left:2px solid transparent;transition:background .2s,color .2s,border-color .2s}.nav-item.active .nav-link,.nav-link:hover{color:var(--text);background:var(--accent-soft);border-left-color:var(--accent)}.nav-progress{font-variant-numeric:tabular-nums;font-size:.7rem;color:var(--accent-bright);opacity:.9}.sidebar-actions{padding:1rem;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:.75rem}.toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted);cursor:pointer}.main{padding:1.5rem 2rem 4rem;max-width:900px}.main-header{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;margin-bottom:2rem;padding:1.25rem 1.5rem;border-radius:var(--radius);background:var(--glass-bg);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border:1px solid var(--glass-border);box-shadow:var(--shadow-glass)}.main-header h2{margin:0 0 .25rem;font-weight:600;letter-spacing:-.02em}.main-header p{margin:0;color:var(--text-muted);font-size:.9rem}.duration-table{font-size:.75rem;border-collapse:separate;border-spacing:0;border-radius:var(--radius-sm);overflow:hidden}.duration-table th,.duration-table td{padding:.35rem .65rem;border:1px solid var(--glass-border);text-align:left}.duration-table th{background:var(--glass-bg-strong);color:var(--accent-bright);font-weight:500}.total-row td{font-weight:600;color:var(--accent)}.section-card{position:relative;background:var(--glass-bg);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1.25rem;scroll-margin-top:1rem;box-shadow:var(--shadow-glass);animation:card-in .45s ease backwards;transition:border-color .25s,box-shadow .25s,transform .25s}.section-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(244,155,1,.2),transparent 40%,transparent 60%,rgba(255,255,255,.06));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.section-card:hover{transform:translateY(-1px)}@keyframes card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.section-card.section-complete{border-color:var(--glass-border-accent);box-shadow:var(--shadow-glass),0 0 28px #f49b011a}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.section-header h2{margin:.25rem 0 0;font-size:1.2rem;font-weight:600;letter-spacing:-.01em}.step-badge{display:inline-block;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-bright);background:var(--accent-soft);border:1px solid var(--glass-border-accent);padding:.2rem .55rem;border-radius:6px;box-shadow:0 0 12px #f49b0126}.duration{font-size:.8rem;color:var(--text-muted);white-space:nowrap;padding:.2rem .5rem;border-radius:6px;background:#ffffff08;border:1px solid var(--glass-border)}.goal{color:var(--text-muted);font-size:.9rem;margin:0 0 .75rem}.note{font-size:.85rem;color:var(--text-muted);margin:.25rem 0}.alert-warn{background:#f49b0114;border:1px solid var(--glass-border-accent);color:var(--accent-bright);padding:.65rem .9rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.numbered-steps{margin:0 0 1rem;padding-left:1.25rem;font-size:.9rem}.numbered-steps li{margin-bottom:.35rem}.ext-link{display:inline-block;color:var(--accent-bright);font-size:.85rem;margin-bottom:.75rem;text-decoration:none;transition:text-shadow .2s}.ext-link:hover{text-shadow:0 0 12px var(--accent-glow)}.subsection{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--glass-border)}.subsection h3{margin:0 0 .5rem;font-size:1rem;color:var(--text)}.checklist{list-style:none;margin:.75rem 0 0;padding:0}.checklist li{border-radius:var(--radius-sm);margin-bottom:.35rem}.checklist li.done .check-label{text-decoration:line-through;color:var(--text-muted)}.check-row{display:flex;align-items:flex-start;gap:.65rem;padding:.55rem .65rem;cursor:pointer;border-radius:var(--radius-sm);border:1px solid transparent;transition:background .2s,border-color .2s}.check-row:hover{background:var(--glass-bg-strong);border-color:var(--glass-border)}.check-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.check-ui{width:1.25rem;height:1.25rem;flex-shrink:0;margin-top:.1rem;border-radius:6px;border:1.5px solid rgba(255,255,255,.2);background:#00000040;box-shadow:inset 0 1px 2px #0006;transition:background .2s,border-color .2s,box-shadow .2s}.check-input:checked+.check-ui{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),var(--accent-bright));border-color:#ffc86480;box-shadow:0 0 12px var(--accent-glow)}.check-input:checked+.check-ui:after{content:"";display:block;width:5px;height:9px;border:solid #0a0a0f;border-width:0 2px 2px 0;transform:rotate(45deg)}.check-label{flex:1;line-height:1.4}.code-block{margin:.75rem 0;border:1px solid var(--glass-border);border-radius:var(--radius-sm);overflow:hidden;background:#00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:inset 0 1px #ffffff0a}.code-block-header{display:flex;align-items:center;gap:.5rem;padding:.45rem .65rem;background:#ffffff08;border-bottom:1px solid var(--glass-border)}.code-block-title{font-size:.75rem;font-weight:600;color:var(--accent-bright)}.code-block-lang{font-size:.7rem;color:var(--text-muted);margin-right:auto}.code-block pre{margin:0;padding:.75rem 1rem;overflow-x:auto;font-size:.72rem;line-height:1.45;max-height:280px;background:#00000040;color:#c8c8d4}.btn{border:none;border-radius:var(--radius-sm);padding:.5rem .9rem;font-size:.8rem;cursor:pointer;font-weight:500;transition:transform .15s,box-shadow .2s,background .2s}.btn:active{transform:scale(.98)}.btn-primary{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,var(--accent-dim),var(--accent));color:#0a0a0f;border:1px solid rgba(255,200,100,.3);box-shadow:0 4px 20px var(--accent-glow);font-weight:600}.btn-spinner{width:1rem;height:1rem;border:2px solid rgba(10,10,15,.25);border-top-color:#0a0a0f;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-primary:hover{background:linear-gradient(135deg,var(--accent),var(--accent-bright));box-shadow:0 6px 28px var(--accent-glow)}.btn-danger{width:100%;background:#ff6b6b1a;color:var(--danger);border:1px solid rgba(255,107,107,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-ghost{background:var(--glass-bg);color:var(--accent-bright);margin-left:auto;border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-ghost:hover{border-color:var(--glass-border-accent);box-shadow:0 0 16px #f49b011f}.btn-sm{padding:.25rem .55rem;font-size:.72rem}.login-page{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}.login-card{position:relative;z-index:1;width:100%;max-width:400px;background:#0c0c128c;backdrop-filter:blur(var(--glass-blur)) saturate(1.6);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.6);border:1px solid var(--glass-border);border-radius:22px;padding:2rem;box-shadow:var(--shadow-glass),var(--shadow-glow);overflow:hidden}.login-card-shine{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(244,155,1,.8),transparent)}.login-eyebrow{margin:0 0 .5rem;text-align:center;font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}.login-card h1{margin:0 0 .25rem;text-align:center;font-weight:600;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text),var(--accent-bright));-webkit-background-clip:text;background-clip:text;color:transparent}.login-subtitle{color:var(--text-muted);font-size:.9rem;margin:0 0 1.5rem;text-align:center}.login-card form{display:flex;flex-direction:column;gap:.75rem}.login-card label{font-size:.85rem;color:var(--text-muted)}.login-card input[type=password]{padding:.7rem .9rem;border-radius:var(--radius-sm);border:1px solid var(--glass-border);background:#00000059;color:var(--text);font-size:1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .2s,box-shadow .2s}.login-card input[type=password]:focus{outline:none;border-color:var(--glass-border-accent);box-shadow:0 0 0 3px var(--accent-soft),0 0 20px #f49b0126}.login-error{color:var(--danger);font-size:.85rem;margin:0}.login-hint{margin:1.25rem 0 0;font-size:.78rem;color:var(--text-muted);line-height:1.45}.loading-text{color:var(--text-muted);text-align:center}.sidebar-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.readonly-banner{background:var(--accent-soft);border:1px solid var(--glass-border-accent);color:var(--accent-bright);padding:.55rem .7rem;border-radius:var(--radius-sm);font-size:.78rem;margin-bottom:.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 0 20px #f49b0114}.last-updated{margin:.5rem 0 0;font-size:.75rem;color:var(--text-muted)}.sync-error{margin:.5rem 0 0;font-size:.78rem;color:var(--danger)}.role-hint{margin:0;font-size:.72rem;color:var(--text-muted);text-align:center}.app-readonly .checklist-readonly-row{display:flex;align-items:flex-start;gap:.65rem;padding:.55rem .65rem;border-radius:var(--radius-sm);border:1px solid transparent}.app-readonly .checklist li.done .checklist-readonly-row{border-color:#5ee9b526;background:#5ee9b50d}.status-icon{width:1.25rem;height:1.25rem;flex-shrink:0;margin-top:.1rem;border-radius:50%;border:2px solid rgba(244,155,1,.45);background:#f49b0114;box-shadow:0 0 10px #f49b0126}.status-icon--done{border-color:var(--success);background:#5ee9b526;box-shadow:0 0 12px #5ee9b559}.status-icon--done{display:flex;align-items:center;justify-content:center}.status-icon--done:after{content:"";display:block;width:5px;height:9px;border:solid var(--success);border-width:0 2px 2px 0;transform:rotate(45deg)}.app-readonly li.done .checklist-readonly-row .check-label{color:var(--text-muted)}.loading-text:after{content:"";display:block;width:28px;height:28px;margin:1rem auto 0;border:2px solid var(--glass-border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.app-readonly .code-block{display:none}@media(max-width:768px){:root{--mobile-header: 10.5rem}.progress-panel .progress-ring{display:none}.progress-panel{flex-direction:row;align-items:center;gap:.65rem;margin-bottom:.45rem}.progress-panel .progress-wrap{display:grid;grid-template-columns:auto 1fr;align-items:center;column-gap:.65rem;flex:1;width:auto;min-width:0;margin-bottom:0}.progress-summary{display:flex;flex-direction:column;align-items:flex-start;gap:0;margin-bottom:0;grid-row:1;grid-column:1}.progress-bar{grid-row:1;grid-column:2;align-self:center}.progress-percent{font-size:1.25rem}.progress-count{font-size:.72rem}.progress-text-desktop{display:none}.progress-bar{height:8px}.readonly-banner-short{display:inline}.readonly-banner-long,.btn-start-long{display:none}.btn-start-short{display:inline}.status-strip{display:flex;flex-wrap:wrap;align-items:baseline;gap:.2rem .65rem;margin:0 0 .35rem}.status-strip .timer,.status-strip .last-updated{margin:0;font-size:.78rem}.app{display:flex;flex-direction:column;width:100%;max-width:100vw;min-height:100dvh;overflow-x:hidden;padding-bottom:env(safe-area-inset-bottom,0)}.sidebar{position:sticky;top:0;z-index:200;align-self:stretch;width:100%;max-width:100vw;height:auto;max-height:none;flex-shrink:0;overflow-x:hidden;border-right:none;border-bottom:1px solid var(--glass-border);padding-top:env(safe-area-inset-top,0);background:#0e0e12eb}.sidebar-top{padding:.65rem .85rem .5rem}.sidebar-top h1{font-size:.95rem;line-height:1.2}.subtitle{display:none}.meta-row{margin-bottom:.4rem}.sidebar-title-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.35rem .5rem;margin-bottom:.4rem}.sidebar-heading{min-width:0}.btn-logout{min-height:36px;min-width:auto;padding:.35rem .55rem;font-size:.75rem;margin-left:0}.readonly-banner{font-size:.75rem;padding:.35rem .55rem;margin-bottom:.4rem;line-height:1.25}.sidebar-top .btn-start{min-height:40px;font-size:.85rem;padding:.5rem .75rem;margin-bottom:.25rem}.sync-error{margin:.25rem 0 0;font-size:.75rem}.btn-primary{min-height:var(--touch-min);font-size:.95rem;padding:.65rem 1rem}.section-card:hover{transform:none}.nav-steps{flex:none;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.35rem .75rem .65rem;border-top:1px solid var(--glass-border)}.nav-steps::-webkit-scrollbar{display:none}.nav-steps ul{display:flex;flex-direction:row;gap:.45rem;width:max-content;padding-bottom:2px}.nav-steps .nav-item{flex-shrink:0}.nav-steps .nav-link{border-left:none;border-radius:999px;border:1px solid var(--glass-border);padding:.55rem .9rem;min-height:var(--touch-min);font-size:.8rem;white-space:nowrap;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);-webkit-tap-highlight-color:transparent}.nav-steps .nav-item.active .nav-link{background:linear-gradient(135deg,var(--accent-dim),var(--accent));border-color:#ffc86466;color:#0a0a0f;font-weight:600;box-shadow:0 4px 16px var(--accent-glow)}.nav-steps .nav-item.active .nav-progress{color:#0a0a0fbf}.nav-steps .nav-label{max-width:9rem;overflow:hidden;text-overflow:ellipsis}.nav-steps .nav-progress{margin-left:.35rem;font-size:.72rem;opacity:.9}.sidebar-actions{display:none}.app:not(.app-readonly) .sidebar-actions{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem 1rem .75rem;border-top:1px solid var(--glass-border)}.app:not(.app-readonly) .sidebar-actions .btn-danger{width:auto;flex:1;min-height:var(--touch-min)}.app:not(.app-readonly) .toggle-label{min-height:var(--touch-min);flex:1}.app:not(.app-readonly) .role-hint{width:100%}.main{flex:1;width:100%;min-width:0;max-width:none;overflow-x:hidden;padding:1rem .85rem 2rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0))}.main-header{flex-direction:column;gap:.75rem;margin-bottom:1.25rem;padding:1rem}.main-header h2{font-size:1.1rem}.main-header p{font-size:.85rem}.duration-table-wrap{display:none}.app-readonly .main-header p{font-size:.9rem}.section-card{padding:1rem;margin-bottom:1rem;scroll-margin-top:calc(var(--mobile-header) + .5rem)}.section-header{flex-direction:column;gap:.35rem}.section-header h2{font-size:1.05rem;line-height:1.3}.duration{align-self:flex-start}.goal,.note,.numbered-steps{font-size:.9rem}.check-row,.app-readonly .checklist-readonly-row{min-height:var(--touch-min);padding:.65rem .5rem;align-items:center}.check-ui,.status-icon{width:1.35rem;height:1.35rem;margin-top:0}.code-block pre{font-size:.68rem;max-height:200px}.code-block-header .btn-sm{min-height:36px;min-width:4rem;padding:.35rem .6rem}.login-page{padding:1rem;padding-top:max(1rem,env(safe-area-inset-top))}.login-card{padding:1.5rem}.login-card input[type=password]{font-size:16px;min-height:var(--touch-min)}.login-card .btn-primary{min-height:48px;font-size:1rem}}@media(min-width:769px){.app{align-items:start}.progress-summary{display:none!important}}
