:root{--bg:#F7F8FB;--surface:#FFFFFF;--surface-2:#F1F3F8;--border:#E6E9F0;--border-strong:#D5DAE4;--text:#1A2236;--text-2:#4A5578;--text-3:#6C7592;--text-muted:#8A92A8;--sidebar-bg:#1E2A4A;--sidebar-bg-2:#18213A;--sidebar-text:#B8C0D9;--sidebar-text-active:#FFFFFF;--sidebar-hover:#28345A;--accent:#14B8A6;--accent-soft:#CCFBF1;--accent-text:#0F766E;--accent-2:#3B82F6;--success:#10B981;--success-soft:#D1FAE5;--success-text:#065F46;--warning:#F59E0B;--warning-soft:#FEF3C7;--warning-text:#92540C;--danger:#EF4444;--danger-soft:#FEE2E2;--danger-text:#B91C1C;--info:var(--accent-2);--type-email:#14B8A6;--type-email-bg:#CCFBF1;--type-email-text:#0D6B63;--type-announce:#8B5CF6;--type-announce-bg:#EDE4FE;--type-announce-text:#5B3BA8;--type-note:#F59E0B;--type-note-bg:#FEF3C7;--type-note-text:#92540C;--type-landing:#EC4899;--type-landing-bg:#FCE7F3;--type-landing-text:#9D1D5C;--stage-warmup:#3B82F6;--stage-sales:#14B8A6;--stage-close:#F59E0B;--shadow-sm:0 1px 2px rgba(26,34,54,.04);--shadow-md:0 2px 8px rgba(26,34,54,.06),0 1px 2px rgba(26,34,54,.04);--shadow-lg:0 10px 30px rgba(26,34,54,.08),0 4px 8px rgba(26,34,54,.04);--shadow-drag:0 16px 40px rgba(20,184,166,.22),0 4px 12px rgba(26,34,54,.08);--overlay-bg:rgba(15,23,42,.42);--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--sidebar-w:236px;--sidebar-w-collapsed:64px;--topbar-h:64px;--ease:cubic-bezier(.4,.2,.2,1);--t-fast:.12s ease;--t-base:.22s var(--ease)}@supports (color:color-mix(in srgb,red 1%,blue)){:root,body[data-theme=coral],body[data-theme=forest],body[data-theme=indigo]{--shadow-drag:0 16px 40px color-mix(in srgb,var(--accent) 22%,transparent),0 4px 12px rgba(26,34,54,.08)}}body[data-theme=indigo]{--accent:#6366F1;--accent-soft:#E0E7FF;--accent-text:#4338CA;--accent-2:#8B5CF6;--type-email:#6366F1;--type-email-bg:#E0E7FF;--type-email-text:#3730A3;--type-announce:#8B5CF6;--type-announce-bg:#EDE4FE;--type-announce-text:#5B3BA8;--type-note:#0EA5E9;--type-note-bg:#E0F2FE;--type-note-text:#075985;--type-landing:#EC4899;--type-landing-bg:#FCE7F3;--type-landing-text:#9D1D5C;--stage-warmup:#8B5CF6;--stage-sales:#6366F1;--stage-close:#EC4899;--sidebar-bg:#1F1B3A;--sidebar-bg-2:#15122A;--sidebar-hover:#2B2650}body[data-theme=coral]{--accent:#F97066;--accent-soft:#FEE4E2;--accent-text:#B42318;--accent-2:#F59E0B;--type-email:#F97066;--type-email-bg:#FEE4E2;--type-email-text:#8B1C12;--type-announce:#F59E0B;--type-announce-bg:#FEF3C7;--type-announce-text:#92540C;--type-note:#EAB308;--type-note-bg:#FEF9C3;--type-note-text:#854D0E;--type-landing:#EC4899;--type-landing-bg:#FCE7F3;--type-landing-text:#9D1D5C;--stage-warmup:#F59E0B;--stage-sales:#F97066;--stage-close:#B42318;--sidebar-bg:#3A1F1A;--sidebar-bg-2:#2A1512;--sidebar-hover:#4D2823}body[data-theme=forest]{--accent:#10B981;--accent-soft:#D1FAE5;--accent-text:#065F46;--accent-2:#0EA5E9;--type-email:#10B981;--type-email-bg:#D1FAE5;--type-email-text:#065F46;--type-announce:#0EA5E9;--type-announce-bg:#E0F2FE;--type-announce-text:#075985;--type-note:#F59E0B;--type-note-bg:#FEF3C7;--type-note-text:#92540C;--type-landing:#84CC16;--type-landing-bg:#ECFCCB;--type-landing-text:#3F6212;--stage-warmup:#0EA5E9;--stage-sales:#10B981;--stage-close:#F59E0B;--sidebar-bg:#1A2E28;--sidebar-bg-2:#0F1F1A;--sidebar-hover:#24403A}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.45;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip;overscroll-behavior-x:none}a{color:var(--accent-text);text-decoration:none}a:hover{text-decoration:underline}code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.875em;background:var(--surface-2);padding:1px 6px;border-radius:4px;color:var(--text)}hr{border:0;border-top:1px solid var(--border);margin:24px 0}.app{min-height:100vh;padding-left:var(--sidebar-w);transition:padding-left var(--t-base)}.app.sidebar-collapsed{padding-left:var(--sidebar-w-collapsed)}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;left:0;top:0;width:var(--sidebar-w);height:100vh;overflow-y:auto;overflow-x:hidden;transition:width var(--t-base);z-index:15}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-toggle{position:fixed;top:26px;left:calc(var(--sidebar-w) - 11px);width:22px;height:22px;border-radius:50%;background:var(--surface);border:1px solid var(--border);color:var(--text-2);cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-sm);z-index:20;transition:left var(--t-base),color var(--t-fast),border-color var(--t-fast),box-shadow var(--t-fast);padding:0}body.app-collapsed .sidebar-toggle{left:calc(var(--sidebar-w-collapsed) - 11px)}body.app-collapsed .sidebar-toggle svg{transform:rotate(180deg)}.sidebar-toggle:hover{color:var(--text);border-color:var(--border-strong);box-shadow:var(--shadow-md)}.sidebar-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sidebar-toggle svg{transition:transform var(--t-base)}.sidebar-brand{padding:20px 22px 22px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.06)}.brand-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:white;font-weight:700;font-size:14px;letter-spacing:-.02em;box-shadow:0 4px 10px color-mix(in srgb,var(--accent) 30%,transparent);flex-shrink:0}.brand-name{font-weight:600;font-size:15px;color:white;letter-spacing:-.01em}.brand-sub{font-size:11px;color:var(--sidebar-text);opacity:.6;letter-spacing:.04em;text-transform:uppercase}.sidebar.collapsed .sidebar-brand{padding:18px 0;justify-content:center;gap:0}.sidebar.collapsed .brand-name,.sidebar.collapsed .brand-sub,.sidebar.collapsed .sidebar-brand>div:last-child{display:none}.sidebar-section-label{padding:18px 22px 8px;font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.5}.sidebar.collapsed .sidebar-section-label{display:none}.nav-item{padding:10px 22px;display:flex;align-items:center;gap:12px;cursor:pointer;color:var(--sidebar-text);font-size:13.5px;font-family:inherit;transition:background var(--t-fast),color var(--t-fast);position:relative;background:transparent;border:none;width:100%;text-align:left;text-decoration:none}.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.nav-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.nav-item.active{background:var(--sidebar-hover);color:var(--sidebar-text-active);font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.nav-item svg{width:18px;height:18px;flex-shrink:0}.nav-item .nav-badge{margin-left:auto;background:var(--accent);color:white;font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:10px;line-height:1.4}.sidebar.collapsed .nav-item{padding:10px 0;justify-content:center;gap:0}.sidebar.collapsed .nav-item>span:not(.nav-badge){display:none}.sidebar.collapsed .nav-item .nav-badge{position:absolute;top:2px;right:10px;margin:0;min-width:16px;height:16px;padding:0 4px;font-size:9.5px;line-height:16px;border:1.5px solid var(--sidebar-bg);border-radius:9px}.sidebar-foot{margin-top:auto;padding:16px 22px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px;font-size:12.5px}.sidebar.collapsed .sidebar-foot{padding:16px 0;justify-content:center}.sidebar.collapsed .foot-meta{display:none}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:white;font-weight:600;font-size:12px;display:grid;place-items:center;flex-shrink:0}.foot-meta-name{color:white;font-weight:500;line-height:1.25}.foot-meta-role{font-size:11px;opacity:.6}.main{min-height:100vh;display:flex;flex-direction:column}.topbar{height:var(--topbar-h);display:flex;align-items:center;padding:0 24px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;gap:16px}.topbar-title{font-size:16px;font-weight:600;color:var(--text)}.topbar-spacer{flex:1}.topbar-chip{padding:6px 12px;background:var(--accent-soft);color:var(--accent-text);border-radius:999px;font-size:12.5px;font-weight:500}.content{padding:32px 40px;max-width:1200px}@media (max-width:768px){.content{padding:20px 16px}}.h1{font-size:28px;font-weight:700;letter-spacing:-.02em;margin:0 0 16px;color:var(--text)}.h2{font-size:22px;letter-spacing:-.01em;margin:32px 0 16px}.h2,.h3{font-weight:600;color:var(--text)}.h3{font-size:16px;margin:24px 0 12px}.muted{color:var(--text-2)}.small{font-size:12.5px}.caption,.small{color:var(--text-3)}.caption{font-size:11px;text-transform:uppercase;letter-spacing:.08em}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;font-family:inherit;font-size:13.5px;font-weight:500;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast),transform var(--t-fast)}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn:active{transform:translateY(1px)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 11px;font-size:12.5px;gap:6px;border-radius:var(--radius-sm)}.btn-lg{padding:11px 20px;font-size:14.5px}.btn-primary{color:white;box-shadow:0 1px 2px color-mix(in srgb,var(--accent) 20%,transparent)}.btn-primary,.btn-primary:hover{background:var(--accent);border-color:transparent}.btn-primary:hover{filter:brightness(1.05)}.btn-primary:disabled,.btn-primary[disabled]{background:var(--text-muted);box-shadow:none;opacity:1}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--surface-2);color:var(--text);border-color:transparent}.btn-danger{color:white}.btn-danger,.btn-danger:hover{background:var(--danger);border-color:transparent}.btn-danger:hover{filter:brightness(.92)}.btn-icon{width:32px;height:32px;padding:0;display:grid;place-items:center;border-radius:var(--radius-sm)}.field{display:block;margin-bottom:14px}.label{display:block;font-size:12px;font-weight:500;color:var(--text-2);margin-bottom:6px}.input,.select,.textarea{width:100%;font-family:inherit;font-size:14px;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);transition:border-color var(--t-fast),box-shadow var(--t-fast)}.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(20,184,166,.22)}@supports (color:color-mix(in srgb,red 1%,blue)){.input:focus,.select:focus,.textarea:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.textarea{min-height:80px;resize:vertical;line-height:1.5}.select{appearance:none;padding-right:32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234A5578' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.hint{font-size:11.5px;color:var(--text-3);margin-top:4px}.field.error .input,.field.error .select,.field.error .textarea{border-color:var(--danger);box-shadow:0 0 0 3px rgba(239,68,68,.15)}@supports (color:color-mix(in srgb,red 1%,blue)){.field.error .input,.field.error .select,.field.error .textarea{box-shadow:0 0 0 3px color-mix(in srgb,var(--danger) 15%,transparent)}}.field.error .hint{color:var(--danger-text)}.checkbox{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none;font-size:13.5px}.checkbox input{appearance:none;width:16px;height:16px;border:1.5px solid var(--border-strong);border-radius:4px;background:var(--surface);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast);position:relative}.checkbox input:checked{background:var(--accent);border-color:var(--accent)}.checkbox input:checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;inset:0;background:var(--border-strong);border-radius:999px;transition:background var(--t-fast);cursor:pointer}.switch .slider:before{content:"";position:absolute;left:2px;top:2px;width:16px;height:16px;background:white;border-radius:50%;transition:transform var(--t-fast);box-shadow:var(--shadow-sm)}.switch input:checked+.slider{background:var(--accent)}.switch input:checked+.slider:before{transform:translateX(16px)}.switch input:focus-visible+.slider{outline:2px solid var(--accent);outline-offset:2px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--surface-2);color:var(--text-2);letter-spacing:.01em}.badge-accent{background:var(--accent-soft);color:var(--accent-text)}.badge-warning{background:var(--warning-soft);color:var(--warning-text)}.badge-danger{background:var(--danger-soft);color:var(--danger-text)}.badge-success{background:var(--success-soft);color:var(--success-text)}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--surface-2);border-radius:999px;font-size:12.5px;font-family:inherit;color:var(--text-2);cursor:pointer;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);border:1px solid transparent}.chip:hover{background:var(--border);color:var(--text)}.chip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chip.active{background:var(--accent-soft);color:var(--accent-text);border-color:var(--accent);font-weight:500}@supports (color:color-mix(in srgb,red 1%,blue)){.chip.active{border-color:color-mix(in srgb,var(--accent) 30%,transparent)}}.type-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:500;letter-spacing:.01em}.type-chip-email{background:var(--type-email-bg);color:var(--type-email-text)}.type-chip-announce{background:var(--type-announce-bg);color:var(--type-announce-text)}.type-chip-note{background:var(--type-note-bg);color:var(--type-note-text)}.type-chip-landing{background:var(--type-landing-bg);color:var(--type-landing-text)}.card-plain{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.card-plain.elevated{box-shadow:var(--shadow-md)}.card-plain h4{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--text)}.card-plain p{margin:0;color:var(--text-2)}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow-sm);cursor:grab;position:relative;transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);width:280px}.task-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-1px)}.task-card.dragging{transform:rotate(-1deg);box-shadow:var(--shadow-drag);cursor:grabbing}.task-card:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.task-card.tone-warmup:before{background:var(--stage-warmup)}.task-card.tone-sales:before{background:var(--stage-sales)}.task-card.tone-close:before{background:var(--stage-close)}.task-card-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.task-card-time{font-size:11.5px;color:var(--text-3);font-variant-numeric:tabular-nums;margin-left:auto}.task-card-title{font-size:13.5px;font-weight:500;color:var(--text);margin:4px 0 6px;line-height:1.4}.task-card-preview{font-size:12px;color:var(--text-2);line-height:1.45;max-height:36px;overflow:hidden}.task-card-foot{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:11.5px;color:var(--text-3)}.status-dot{width:6px;height:6px;border-radius:50%;display:inline-block}.status-dot.s-todo{background:var(--text-muted)}.status-dot.s-doing{background:var(--info)}.status-dot.s-done{background:var(--success)}.column{width:320px;flex-shrink:0;background:var(--surface-2);border-radius:var(--radius-lg);padding:14px;display:flex;flex-direction:column;gap:10px;max-height:600px}.column-head{display:flex;align-items:center;gap:8px;padding:0 4px 4px}.column-title{font-size:13.5px;font-weight:600;color:var(--text)}.column-count{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:1px 7px;font-size:11px;color:var(--text-2);margin-left:auto}.modal-backdrop{background:var(--overlay-bg);display:none;place-items:center;z-index:100}.modal-backdrop.open{display:grid;animation:fadeIn .18s ease}.modal-backdrop.open .modal{animation:popIn .22s var(--ease)}.modal-backdrop[hidden]{display:none!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);width:560px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden}.modal.modal-narrow{width:460px}@keyframes popIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-head{padding:18px 22px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:16px;font-weight:600;color:var(--text)}.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:transparent;display:grid;place-items:center;margin-left:auto;transition:background var(--t-fast),color var(--t-fast)}.modal-close:hover{background:var(--surface-2)}.modal-body{padding:22px;overflow-y:auto;flex:1}.modal-foot{padding:14px 22px;border-top:1px solid var(--border);background:var(--surface);display:flex;align-items:center;gap:10px}.modal-foot .spacer{flex:1}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:6px;z-index:50;display:none}.dropdown-menu.open{display:block;animation:popIn .14s var(--ease)}.dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:13.5px;color:var(--text);background:transparent;border:none;width:100%;text-align:left;font-family:inherit;transition:background var(--t-fast)}.dropdown-item:hover{background:var(--surface-2)}.dropdown-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:color-mix(in srgb,var(--danger) 8%,var(--surface))}.dropdown-divider{height:1px;background:var(--border);margin:4px 0}.toast{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:280px;max-width:380px}.toast-success{border-left-color:var(--success)}.toast-warning{border-left-color:var(--warning)}.toast-danger{border-left-color:var(--danger)}.toast-icon{width:28px;height:28px;flex-shrink:0;border-radius:50%;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-text);font-weight:700}.toast-success .toast-icon{background:var(--success-soft);color:var(--success-text)}.toast-warning .toast-icon{background:var(--warning-soft);color:var(--warning-text)}.toast-danger .toast-icon{background:var(--danger-soft);color:var(--danger-text)}.toast b{display:block;font-size:13px;font-weight:600}.toast span{font-size:11.5px;color:var(--text-2);display:block}.alert{padding:12px 14px;border-radius:var(--radius);background:var(--accent-soft);color:var(--accent-text);font-size:13px;border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);display:flex;align-items:flex-start;gap:10px}.alert-success{background:var(--success-soft);color:var(--success-text);border-color:color-mix(in srgb,var(--success) 30%,transparent)}.alert-warning{background:var(--warning-soft);color:var(--warning-text);border-color:color-mix(in srgb,var(--warning) 35%,transparent)}.alert-danger{background:var(--danger-soft);color:var(--danger-text);border-color:color-mix(in srgb,var(--danger) 35%,transparent)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px}.tab{padding:9px 14px;font-size:13.5px;font-family:inherit;color:var(--text-2);cursor:pointer;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--t-fast),border-color var(--t-fast)}.tab:hover{color:var(--text)}.tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:var(--radius-sm)}.tab.active{color:var(--accent-text);border-bottom-color:var(--accent);font-weight:500}.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.row.gap-lg{gap:20px}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.section{border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin:16px 0 32px}.section,.swatch{background:var(--surface)}.swatch{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.swatch-preview{height:70px}.swatch-meta{padding:10px 12px;display:flex;align-items:baseline;justify-content:space-between;font-size:12px;border-top:1px solid var(--border)}.swatch-meta b{font-weight:600;color:var(--text)}.swatch-meta code{font-size:10.5px;background:transparent;padding:0;color:var(--text-3)}.shadow-demo{background:var(--surface);border-radius:var(--radius);place-items:center;color:var(--text-2)}.radius-demo,.shadow-demo{height:60px;display:grid;font-size:12px}.radius-demo{width:90px;background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);place-items:center;color:var(--accent-text);font-weight:500}.bottom-sheet{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:20px 18px 28px;box-shadow:0 -10px 30px rgba(0,0,0,.12);max-height:70vh;overflow-y:auto}.bottom-sheet:before{content:"";display:block;margin:0 auto 14px;width:36px;height:4px;border-radius:2px;background:var(--border-strong)}.bottom-sheet--preview{position:static;box-shadow:var(--shadow-sm);border:1px solid var(--border);border-bottom:none;max-height:none}.mobile-burger{display:none;width:36px;height:36px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);border-radius:var(--radius-sm);cursor:pointer;padding:0;align-items:center;justify-content:center}.mobile-burger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mobile-overlay{display:none;position:fixed;inset:0;z-index:14;background:var(--overlay-bg)}.mobile-overlay.open{display:block}@media (max-width:768px){.app{padding-left:0}.sidebar{transform:translateX(-100%);transition:transform var(--t-base);z-index:16}.sidebar.mobile-open{transform:translateX(0)}.sidebar-toggle{display:none}.topbar{padding:0 16px}.mobile-burger{display:inline-flex}.modal-backdrop{padding:0;align-items:flex-end}.modal{width:100%;max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92vh}.column,.task-card{width:100%;max-width:calc(100vw - 32px)}}:root{--content-wide:1320px}body{min-height:100vh}.content{max-width:var(--content-wide)}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}.page-kicker{color:var(--text-3);font-size:12px;font-weight:700;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.shell-layout{min-height:100vh}.brand-mark{letter-spacing:0}.brand-name{line-height:1.18}.hero-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.9fr);gap:18px}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}.comment-card,.course-card,.lesson-row,.metric-card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.metric-card{padding:16px}.metric-value{color:var(--text);font-size:26px;font-weight:700;line-height:1;margin-bottom:8px}.metric-label{color:var(--text-2);font-size:12.5px}.course-card{display:grid;gap:16px;padding:20px}.course-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.progress-track{background:var(--surface-2);border-radius:999px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--accent),var(--accent-2));height:100%}.module-list{display:grid;gap:14px}.module-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.module-head{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 18px}.lesson-row{align-items:center;border:0;border-radius:0;box-shadow:none;display:grid;grid-template-columns:1fr auto;gap:16px;padding:14px 18px}.lesson-row+.lesson-row{border-top:1px solid var(--border)}.lesson-meta{color:var(--text-3);display:flex;flex-wrap:wrap;font-size:12.5px;gap:10px;margin-top:5px}.lesson-video{aspect-ratio:16/9;background:linear-gradient(135deg,var(--sidebar-bg),#101827);border-radius:var(--radius);display:grid;margin-bottom:18px;overflow:hidden;place-items:center}.hls-player,.lesson-video iframe,.lesson-video video{border:0;height:100%;width:100%}.lesson-video video{background:#050814;display:block;object-fit:contain}.hls-player{position:relative}.video-error{align-items:center;background:rgba(5,8,20,.76);color:white;display:flex;inset:0;justify-content:center;padding:24px;position:absolute;text-align:center}.video-placeholder{color:white;padding:32px;text-align:center}.two-col{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px}.panel{padding:18px}.guest-panel{display:grid;gap:14px;max-width:620px}.guest-panel .h1,.guest-panel p{margin-bottom:0}.guest-panel .btn{justify-self:start}.panel-title{font-size:16px;font-weight:700;margin:0 0 12px}.comment-list{display:grid;gap:10px}.comment-card{padding:13px}a.comment-card:hover{border-color:var(--border-strong);text-decoration:none}.comment-author{align-items:center;display:flex;gap:8px;margin-bottom:6px}.avatar-sm{align-items:center;background:var(--accent-soft);border-radius:50%;color:var(--accent-text);display:inline-flex;font-size:11px;font-weight:700;height:26px;justify-content:center;width:26px}.admin-table{border-collapse:collapse;width:100%}.admin-table td,.admin-table th{border-bottom:1px solid var(--border);padding:12px 10px;text-align:left;vertical-align:top}.admin-table th{color:var(--text-3);font-size:11px;letter-spacing:.08em;text-transform:uppercase}.form-grid{display:grid;gap:12px}.admin-stack{display:grid;gap:18px}.bunny-uploader{max-width:760px}.lesson-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.lesson-side-stack{display:grid;gap:18px}.lesson-action-stack{align-items:flex-end;display:grid;gap:6px;justify-items:end}.lesson-editor{margin-bottom:18px}.course-creator,.lesson-creator{display:flex;justify-content:flex-end}.lesson-creator{justify-content:flex-start;margin-bottom:18px}.course-builder{display:grid;gap:16px}.course-admin-stack{display:grid;gap:18px}.admin-mode-bar{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:16px;justify-content:space-between;padding:14px 18px}.admin-mode-bar .page-kicker{margin-bottom:4px}.admin-mode-bar p{margin:0}.builder-toolbar{align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:16px;justify-content:space-between;padding:18px}.builder-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.builder-module .module-head{gap:18px}.builder-lesson{grid-template-columns:minmax(0,1fr) minmax(420px,auto)}.input-sm{min-height:34px;padding:6px 10px;width:190px}.modal-backdrop{align-items:center;background:rgba(15,23,42,.42);display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.modal-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:calc(100vh - 48px);max-width:720px;overflow:auto;padding:22px;width:min(720px,100%)}.modal-header{align-items:flex-start;display:flex;gap:18px;justify-content:space-between;margin-bottom:18px}.modal-title{font-size:20px;line-height:1.2;margin:0}.modal-close{align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:50%;color:var(--text-2);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:16px;font-weight:700;height:34px;justify-content:center;line-height:1;padding:0;width:34px}.modal-close:hover{border-color:var(--border-strong);color:var(--text)}.modal-body{display:grid;gap:12px}.lesson-editor-panel{margin-top:12px;max-width:860px}.form-inline{display:grid;gap:12px;grid-template-columns:minmax(0,1fr) minmax(160px,.35fr)}.lesson-body{margin-bottom:18px}.lesson-body p{color:var(--text-2);line-height:1.7;margin:0;white-space:pre-wrap}.lesson-body-editor{min-height:180px}.markdown-editor{display:grid;gap:10px}.markdown-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.markdown-tools{display:flex;flex-wrap:wrap;gap:6px}.segmented-control{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);display:inline-flex;padding:3px}.segmented-control button{background:transparent;border:0;border-radius:var(--radius-sm);color:var(--text-2);cursor:pointer;font:inherit;font-size:12.5px;padding:6px 10px}.segmented-control button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.markdown-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-height:180px;padding:14px}.markdown-split-editor{display:grid;gap:12px;grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.markdown-pane{display:grid;gap:6px;margin:0;min-width:0}.markdown-visual-editor{color:var(--text-2);line-height:1.7;min-height:260px;overflow-wrap:anywhere}.markdown-visual-editor:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(20,184,166,.22);outline:none}.markdown-visual-editor blockquote,.markdown-visual-editor h2,.markdown-visual-editor h3,.markdown-visual-editor h4,.markdown-visual-editor p,.markdown-visual-editor ul{margin:0 0 10px}.markdown-visual-editor h2,.markdown-visual-editor h3,.markdown-visual-editor h4{color:var(--text);line-height:1.35}.markdown-visual-editor h2{font-size:20px}.markdown-visual-editor h3{font-size:17px}.markdown-visual-editor ul{padding-left:20px}.markdown-visual-editor code{background:var(--surface-2);border-radius:5px;color:var(--text);padding:2px 5px}.markdown-visual-editor blockquote{border-left:3px solid var(--accent);color:var(--text-2);padding-left:12px}.markdown-view{color:var(--text-2);display:grid;gap:10px;line-height:1.7}.markdown-view blockquote,.markdown-view h2,.markdown-view h3,.markdown-view h4,.markdown-view p,.markdown-view ul{margin:0}.markdown-view p{white-space:normal}.markdown-view h2,.markdown-view h3,.markdown-view h4{color:var(--text);line-height:1.35}.markdown-view h2{font-size:20px}.markdown-view h3{font-size:17px}.markdown-view ul{padding-left:20px}.markdown-view code{background:var(--surface-2);border-radius:5px;color:var(--text);padding:2px 5px}.markdown-view blockquote{border-left:3px solid var(--accent);color:var(--text-2);padding-left:12px}.video-current{align-items:flex-start;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);display:flex;gap:14px;justify-content:space-between;padding:14px}.video-current-id,.video-current-link{display:block;font-size:12.5px;margin-top:4px}.video-current-id{color:var(--text-2)}.video-current-link{overflow-wrap:anywhere}.lesson-attachments{margin-bottom:18px}.attachment-head{align-items:flex-start;display:flex;justify-content:space-between;gap:14px;margin-bottom:12px}.attachment-head .panel-title{margin-bottom:4px}.attachment-list{display:grid;gap:10px}.attachment-list-editor{gap:8px}.attachment-item{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);display:grid;gap:12px;grid-template-columns:auto minmax(0,1fr) auto;padding:10px}a.attachment-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);text-decoration:none}.attachment-icon{align-items:center;background:var(--accent-soft);border-radius:var(--radius-sm);color:var(--accent-text);display:inline-flex;font-size:10px;font-weight:800;height:34px;justify-content:center;letter-spacing:.04em;width:42px}.attachment-main{display:grid;min-width:0}.attachment-name{font-weight:650;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-error{color:var(--danger,#b42318)}.form-error,.form-success{font-size:12.5px;margin:8px 0 0}.form-success{color:var(--success-text)}.question-head{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:6px}.question-answer-form{display:grid;gap:10px;margin-top:12px}.transcript-panel{display:grid;gap:12px}.transcript-head{align-items:flex-start;display:flex;justify-content:space-between;gap:12px}.transcript-actions{display:grid;gap:10px}.manual-transcript-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);display:grid;gap:10px;padding:12px}.transcript-progress{animation:transcript-progress 1.2s ease-in-out infinite alternate;min-width:26%}.chapter-list,.transcript-content,.utterance-list{display:grid;gap:10px}.chapter-button,.utterance-button{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;display:grid;gap:5px;padding:10px;text-align:left;width:100%}.chapter-button{grid-template-columns:50px minmax(0,1fr)}.chapter-button:hover,.utterance-button:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.chapter-button span:first-child,.utterance-button span:first-child{color:var(--accent-text);font-size:12px;font-weight:750}.utterance-button span:last-child{color:var(--text-2);line-height:1.55}.zoom-importer{display:grid;gap:8px}.zoom-importer .form-inline{align-items:end;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto}.zoom-recording-list{display:grid;gap:10px}.zoom-recording{align-items:center;border:1px solid var(--border);border-radius:var(--radius);display:grid;gap:12px;grid-template-columns:minmax(0,1fr) auto;padding:12px}.zoom-recording-main{display:grid;gap:4px;min-width:0}.zoom-recording-main b,.zoom-recording-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.zoom-recording-main span{color:var(--text-2);font-size:12.5px}.zoom-recording-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}@keyframes transcript-progress{0%{transform:translateX(0);width:26%}to{transform:translateX(280%);width:26%}}.access-manager{display:grid;gap:16px}.access-head{align-items:flex-start;display:flex;justify-content:space-between;gap:16px}.access-grid{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.access-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);display:grid;gap:12px;padding:14px}.access-controls-row{display:grid;gap:12px;grid-template-columns:minmax(150px,190px) minmax(0,1fr)}.access-file-field,.access-role-field{min-width:0}.access-file-field input[type=file]{width:100%}.invite-row,.invite-url-box{align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);display:grid;gap:12px;grid-template-columns:minmax(0,1fr) auto;padding:10px}.invite-url-box{background:var(--surface)}.invite-row a,.invite-url-box a{overflow-wrap:anywhere}.invite-list{display:grid;gap:10px}.invite-row-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.invite-edit-form{display:grid;gap:10px;grid-template-columns:minmax(130px,180px) minmax(130px,180px) minmax(180px,1fr);margin-top:12px}@media (max-width:980px){.access-controls-row,.access-grid,.hero-grid,.metric-grid,.two-col{grid-template-columns:1fr}.page-head{display:grid}.lesson-actions{justify-content:flex-start}.admin-mode-bar,.builder-lesson,.builder-module .module-head,.builder-toolbar,.invite-edit-form,.invite-row{display:grid;grid-template-columns:1fr}.builder-actions,.course-creator,.invite-row-actions{justify-content:flex-start}.lesson-action-stack{align-items:flex-start;justify-items:start}}@media (max-width:720px){:root{--topbar-h:56px}body,html{overflow-x:hidden}.app{padding-bottom:calc(70px + env(safe-area-inset-bottom));padding-left:0}.sidebar{border-top:1px solid rgba(255,255,255,.08);bottom:0;box-shadow:0 -10px 28px rgba(15,23,42,.16);height:calc(64px + env(safe-area-inset-bottom));left:0;overflow:visible;padding-bottom:env(safe-area-inset-bottom);right:0;top:auto;transform:none;width:100%;z-index:30}.sidebar-brand,.sidebar-foot,.sidebar-section-label{display:none}.sidebar nav{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));height:64px;width:100%}.nav-item{align-items:center;border-radius:0;flex-direction:column;font-size:11px;gap:4px;justify-content:center;min-width:0;padding:8px 4px;text-align:center}.nav-item:hover{background:transparent}.nav-item svg{height:20px;width:20px}.nav-item span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar{gap:10px;min-width:0;padding:0 14px}.topbar-title{font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar .badge{display:none}.content{max-width:100%;padding:18px 14px}.h1{font-size:24px;line-height:1.16;margin-bottom:10px}.h2{font-size:19px}.page-head{gap:14px;margin-bottom:16px}.course-creator,.course-creator .btn,.lesson-creator,.lesson-creator .btn,.page-head>.btn,.page-head>.course-creator,.page-head>a.btn{width:100%}.metric-grid{gap:10px;margin-bottom:14px}.course-card,.metric-card,.panel{border-radius:8px}.course-card,.panel{padding:14px}.access-head,.attachment-head,.course-card-top,.module-head,.transcript-head,.video-current{align-items:flex-start;display:grid;grid-template-columns:1fr}.course-card .row,.lesson-row .row{align-items:stretch;display:grid;grid-template-columns:1fr;width:100%}.course-card .btn,.lesson-action-stack .btn,.lesson-actions .btn,.lesson-row .btn{justify-content:center;width:100%}.lesson-action-stack,.lesson-actions{width:100%}.lesson-row{grid-template-columns:1fr;gap:12px;padding:13px 14px}.lesson-meta{gap:8px}.lesson-video{border-radius:8px;margin-left:-2px;margin-right:-2px}.form-inline{grid-template-columns:1fr}.access-card,.form-grid,.manual-transcript-box{gap:10px}.input,.input-sm,.select,.textarea{min-height:42px;width:100%}.markdown-toolbar,.markdown-tools,.segmented-control{width:100%}.markdown-split-editor{grid-template-columns:1fr}.markdown-tools{display:grid;grid-template-columns:repeat(4,minmax(0,1fr))}.markdown-tools .btn{justify-content:center;padding-left:8px;padding-right:8px}.segmented-control button{flex:1}.modal-backdrop{align-items:flex-end;padding:0}.modal-panel{border-radius:16px 16px 0 0;max-height:92vh;max-width:100%;padding:18px 14px calc(18px + env(safe-area-inset-bottom));width:100%}.modal-header{gap:12px;margin-bottom:14px}.modal-title{font-size:18px}.attachment-item,.invite-row,.invite-url-box{grid-template-columns:1fr}.attachment-name,.zoom-recording-main b,.zoom-recording-main span{white-space:normal}.zoom-importer .form-inline,.zoom-recording{grid-template-columns:1fr}.zoom-recording-actions{justify-content:flex-start}.admin-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.builder-actions,.invite-row-actions,.zoom-recording-actions{display:grid;grid-template-columns:1fr;width:100%}.access-card .btn,.builder-actions .btn,.invite-row-actions .btn,.zoom-recording-actions .btn{justify-content:center;width:100%}}@media (max-width:420px){.content,.topbar{padding-left:12px;padding-right:12px}.topbar-title{max-width:54vw}.btn{min-height:42px}}