:root{--color-primary: #824bc5;--color-primary-light: #9b5fc0;--color-primary-dark: #6a3aa3;--color-primary-bg: #f3eef8;--color-primary-gradient: linear-gradient(135deg, #6a3aa3 0%, #824bc5 100%);--color-accent: #C8973E;--color-accent-light: #D4A853;--color-accent-dark: #A67B2E;--color-accent-bg: #FBF5E8;--color-olive: #6B7A3A;--color-olive-light: #8A9B5A;--color-terracotta: #B0522D;--color-terracotta-light: #C86A45;--color-terracotta-bg: #fdf0eb;--color-sky: #6E9ECF;--color-sky-light: #8BB4DB;--color-sky-bg: #eef4fa;--color-bronze: #8B6914;--color-bg: #f8f6fa;--color-bg-alt: #f3eef8;--color-surface: #FFFFFF;--color-text: #333333;--color-text-light: #666666;--color-text-muted: #999999;--color-border: #ddd0e8;--color-border-light: #e8e0f0;--color-success: #28a745;--color-success-bg: #d4edda;--color-warning: #C8973E;--color-warning-bg: #FBF5E8;--color-error: #dc3545;--color-error-bg: #f8d7da;--color-info: #824bc5;--color-info-bg: #f3eef8;--font-heading: "Cormorant Garamond", Georgia, "Times New Roman", serif;--font-body: "DM Sans", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.25rem;--text-xl: 1.563rem;--text-2xl: 1.953rem;--text-3xl: 2.441rem;--text-4xl: 3.052rem;--text-5xl: 3.815rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-8: 3rem;--space-10: 4rem;--space-12: 6rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--radius: 8px;--shadow-sm: 0 1px 2px rgba(46, 53, 70, .06);--shadow-md: 0 4px 6px rgba(46, 53, 70, .08);--shadow-lg: 0 10px 15px rgba(46, 53, 70, .1);--shadow-xl: 0 20px 25px rgba(46, 53, 70, .12);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--max-width: 1080px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--color-primary-dark);line-height:1.2;letter-spacing:-.02em}h1{font-size:var(--text-4xl);font-weight:600}h2{font-size:var(--text-3xl);font-weight:600}h3{font-size:var(--text-2xl);font-weight:500}h4{font-size:var(--text-xl);font-weight:500}a{color:var(--color-primary);text-decoration:none}.app-logo{height:44px;width:auto}a:hover{color:var(--color-primary-light)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button,.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-5);font-size:var(--text-base);font-weight:600;font-family:var(--font-body);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background:var(--color-primary-gradient);color:#fff}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-secondary:hover{background:var(--color-primary);color:#fff}.btn-large{padding:var(--space-4) var(--space-6);font-size:1.125rem;border-radius:var(--radius-lg)}input,textarea,select{font-family:var(--font-body);font-size:var(--text-base);padding:var(--space-3);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #824bc526}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-5)}.sales-page{color:var(--color-text)}.sales-nav{padding:1rem 0;border-bottom:1px solid var(--color-border)}.sales-nav-inner{display:flex;justify-content:space-between;align-items:center}.sales-logo-group{display:flex;align-items:center;gap:.75rem}.sales-logo-img{height:56px;width:auto}.sales-tagline{font-size:.875rem;color:var(--color-text-muted);font-style:italic}.sales-hero{padding:4rem 0;background:linear-gradient(180deg,var(--color-primary-bg) 0%,var(--color-bg) 100%)}.sales-hero-split{display:flex;align-items:center;gap:3.5rem}.sales-hero-left{flex:1}.sales-hero-right{flex-shrink:0;width:380px}.sales-hero h1{font-size:3rem;color:var(--color-primary);margin-bottom:1.25rem;letter-spacing:-.03em}.sales-hero-sub{font-size:1.15rem;color:var(--color-text-light);line-height:1.7;margin-bottom:1.5rem}.sales-hero-note{font-size:.9rem;color:var(--color-text-muted)}.sales-hero-image-wrap{max-width:1080px;margin:0 auto;padding:0 1.5rem}.sales-hero-image{width:100%;height:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:block}.hero-auth-panel{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-lg)}.hero-auth-title{text-align:center;margin-bottom:1.25rem;font-size:1.2rem}.hero-auth-error{color:var(--color-error);font-size:.875rem;text-align:center;margin-bottom:.75rem}.hero-auth-form{display:flex;flex-direction:column;gap:.75rem}.hero-auth-submit{width:100%;margin-top:.25rem}.hero-auth-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--color-text-muted);font-size:.85rem}.hero-auth-divider:before,.hero-auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.hero-auth-google{display:flex;justify-content:center}.hero-auth-toggle{text-align:center;margin-top:1rem;font-size:.875rem;color:var(--color-text-muted)}.hero-auth-toggle-btn{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;padding:0;font-size:.875rem}.hero-auth-toggle-btn:hover{color:var(--color-primary-light)}.hero-auth-forgot-btn{background:none;border:none;color:var(--color-text-muted);font-size:.8125rem;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;align-self:flex-end}.hero-auth-forgot-btn:hover{color:var(--color-primary)}.hero-auth-success{color:var(--color-success);font-size:.9rem;line-height:1.6;margin-bottom:1rem}.sales-section{padding:4.5rem 0}.sales-section-alt{background:var(--color-bg-alt)}.sales-section-title{text-align:center;margin-bottom:.75rem}.sales-section-sub{text-align:center;max-width:600px;margin:0 auto 2.5rem;color:var(--color-text-muted);font-size:1.05rem;line-height:1.6}.sales-flagship-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.sales-flagship-card{padding:2rem 1.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:box-shadow .15s ease,border-color .15s ease}.sales-flagship-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.sales-flagship-emoji{font-size:2rem;display:block;margin-bottom:1rem}.sales-flagship-card h3{font-size:1.25rem;margin-bottom:.5rem}.sales-flagship-card p{color:var(--color-text-light);font-size:.925rem;line-height:1.6}.sales-more-section{margin-top:3rem;text-align:center}.sales-more-heading{font-family:var(--font-body);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:1.25rem}.sales-more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem 1.5rem;max-width:720px;margin:0 auto;text-align:left}.sales-more-item{display:flex;flex-direction:column;gap:.125rem;padding:.75rem 0;border-bottom:1px solid var(--color-border-light)}.sales-more-item strong{font-size:.875rem;font-weight:600;color:var(--color-text)}.sales-more-item span{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.sales-difference-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.sales-difference-card{padding:1.75rem;border-top:3px solid var(--color-accent);background:var(--color-surface);border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-sm)}.sales-difference-card h3{font-size:1.15rem;margin-bottom:.5rem;color:var(--color-primary-dark)}.sales-difference-card p{color:var(--color-text-light);font-size:.925rem;line-height:1.6}.sales-steps{max-width:640px;margin:2rem auto 0;display:flex;flex-direction:column;gap:2rem}.sales-step{display:flex;gap:1.25rem;align-items:flex-start}.sales-step-num{flex-shrink:0;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:var(--color-sky);color:#fff;border-radius:50%;font-size:1.25rem;font-weight:700}.sales-step h3{margin-bottom:.25rem}.sales-step p{color:var(--color-text-muted);font-size:.95rem}.sales-cta-section{text-align:center}.sales-cta-section h2{margin-bottom:1rem}.sales-cta-section p{max-width:540px;margin:0 auto 2rem;color:var(--color-text-muted);font-size:1.05rem;line-height:1.6}.sales-footer{padding:2rem 0;text-align:center;border-top:1px solid var(--color-border);color:var(--color-text-muted);font-size:.875rem}@media(max-width:820px){.sales-tagline{display:none}.sales-hero-split{flex-direction:column;text-align:center}.sales-hero-right{width:100%;max-width:400px}.sales-hero h1{font-size:2.25rem}.sales-hero-sub{font-size:1.05rem}.sales-section{padding:3rem 0}.sales-flagship-grid{grid-template-columns:1fr}.sales-more-grid{grid-template-columns:1fr 1fr}.sales-difference-grid{grid-template-columns:1fr}}@media(max-width:480px){.sales-more-grid{grid-template-columns:1fr}}.auth-container{max-width:400px;margin:var(--space-10) auto;padding:var(--space-6)}.auth-container h1{margin-bottom:var(--space-4)}.auth-container p{color:var(--color-text-light);margin-bottom:var(--space-4)}.auth-error{color:var(--color-error);background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);margin-bottom:var(--space-4)}.auth-form-group{margin-bottom:var(--space-4)}.auth-form-group label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--color-text);margin-bottom:var(--space-1)}.auth-submit{width:100%;margin-bottom:var(--space-4)}.auth-link{color:var(--color-primary);font-size:var(--text-sm)}.auth-link:hover{color:var(--color-primary-light)}.auth-toggle{text-align:center;margin-top:var(--space-5);color:var(--color-text-muted)}.auth-toggle-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;text-decoration:underline;text-underline-offset:2px;font-weight:500;padding:0}.auth-toggle-btn:hover{color:var(--color-primary-light)}.auth-divider{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-5) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-google{display:flex;justify-content:center}.auth-footer{text-align:center}.auth-forgot-link{text-align:right;margin:0 0 var(--space-2)}.my-units-container{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.my-units-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.my-units-header-left{display:flex;align-items:center;gap:.75rem}.my-units-header h1{font-size:1.75rem}.my-units-header-right{display:flex;align-items:center;gap:1rem}.credit-badge{background:var(--color-accent-bg);color:var(--color-accent-dark);font-weight:600;padding:.375rem .75rem;border-radius:20px;font-size:.875rem}.logout-btn{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);padding:.375rem 1rem;font-size:.875rem}.logout-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}.my-units-error{color:var(--color-error);margin-bottom:1rem}.create-card{padding:1.5rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-alt);margin-bottom:2rem}.create-card h3{margin-bottom:.5rem}.create-card-subtitle{font-size:.875rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:1rem}.create-field{margin-bottom:1.5rem}.create-field-label{display:block;font-size:.9375rem;font-weight:600;color:var(--color-text);margin-bottom:.5rem}.create-field-hint{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:.5rem;line-height:1.4}.create-field-row{display:flex;gap:1.5rem;margin-bottom:1.5rem}.create-field-half{flex:1;margin-bottom:0}.age-input{width:5rem;text-align:center;font-size:1.125rem;padding:.5rem}.create-submit{width:100%;padding:.875rem;font-size:1rem}@media(max-width:600px){.create-field-row{flex-direction:column;gap:1.5rem}}.duration-picker{display:flex;gap:.5rem}.duration-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);cursor:pointer;transition:border-color .15s ease,background .15s ease;text-align:center}.duration-option strong{font-size:.9375rem}.duration-option span{font-size:.8125rem;color:var(--color-text-muted)}.duration-option:hover{border-color:var(--color-primary)}.duration-active{border-color:var(--color-primary);background:var(--color-accent-bg)}.duration-active strong{color:var(--color-primary)}.no-credits-msg{color:var(--color-text-muted);font-size:.875rem;margin-top:.75rem}.empty-state{text-align:center;padding:3rem;color:var(--color-text-muted)}.unit-list{display:flex;flex-direction:column;gap:.5rem}.unit-card{padding:1rem 1.25rem;border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.unit-card:hover{border-color:var(--color-primary);box-shadow:0 1px 4px #824bc51f}.unit-card-top{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.unit-status{font-size:.8125rem;color:var(--color-text-muted);background:var(--color-bg-alt);padding:.2rem .5rem;border-radius:4px;flex-shrink:0}.status-complete{color:var(--color-success);background:var(--color-success-bg)}.unit-card-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem}.unit-card-meta{font-size:.8125rem;color:var(--color-text-muted);cursor:pointer}.unit-delete-btn{background:transparent;border:none;color:var(--color-text-muted);font-size:.75rem;cursor:pointer;padding:.125rem .5rem;border-radius:4px}.unit-delete-btn:hover{color:var(--color-error);background:var(--color-error-bg, #fef2f2)}.unit-delete-confirm{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.unit-delete-confirm-text{color:var(--color-error);font-weight:500}.unit-delete-yes{background:var(--color-error);color:#fff;border:none;font-size:.75rem;padding:.2rem .625rem;border-radius:4px;cursor:pointer}.unit-delete-yes:hover{opacity:.9}.unit-delete-no{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);font-size:.75rem;padding:.2rem .625rem;border-radius:4px;cursor:pointer}.unit-delete-no:hover{border-color:var(--color-text-muted)}.collab-badge{display:inline-block;font-size:.6875rem;font-weight:600;padding:.125rem .5rem;border-radius:999px;background:var(--color-accent-bg);color:var(--color-accent-dark);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.side-panel-backdrop{position:fixed;inset:0;background:#0000004d;z-index:999;opacity:0;pointer-events:none;transition:opacity .35s ease}.side-panel-backdrop.open{opacity:1;pointer-events:auto}.side-panel{position:fixed;top:0;right:0;width:400px;max-width:90vw;height:100vh;background:var(--color-bg, #fff);box-shadow:-4px 0 24px #00000026;z-index:1000;transform:translate(100%);transition:transform .35s ease;display:flex;flex-direction:column}.side-panel.open{transform:translate(0)}.side-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border, #e5e7eb)}.side-panel-header h3{margin:0;font-size:1rem;font-weight:600}.side-panel-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--color-text-muted, #6b7280);padding:.25rem;line-height:1}.side-panel-close:hover{color:var(--color-text, #111)}.side-panel-body{flex:1;overflow-y:auto;padding:1.25rem}.wizard-container{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.wizard-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.wizard-back{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;padding:.5rem 0}.wizard-back:hover{color:var(--color-primary-light)}.wizard-step-count{color:var(--color-text-muted);font-size:.875rem}.wizard-breadcrumb{display:flex;gap:.375rem;overflow-x:auto;padding:.5rem 0;margin-bottom:.5rem;scrollbar-width:thin}.wizard-breadcrumb::-webkit-scrollbar{height:4px}.wizard-breadcrumb::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.breadcrumb-step{flex-shrink:0;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .15s;white-space:nowrap}.breadcrumb-not-started{background:var(--color-bg-alt);color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.breadcrumb-not-started:disabled{cursor:not-allowed}.breadcrumb-started{background:var(--color-accent-bg);color:var(--color-accent-dark);border-color:var(--color-accent)}.breadcrumb-in-progress{background:var(--color-primary-bg);color:var(--color-primary-dark);border-color:var(--color-primary)}.breadcrumb-completed{background:var(--color-success);color:#fff}.breadcrumb-completed:hover{opacity:.85}.breadcrumb-skipped{background:transparent;color:var(--color-text-muted);border:1px dashed var(--color-text-muted);text-decoration:line-through}.breadcrumb-skipped:hover{border-color:var(--color-primary);color:var(--color-primary)}.breadcrumb-missed{background:transparent;color:var(--color-text-muted);border:1px dashed var(--color-border);cursor:pointer}.breadcrumb-missed:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-bg)}.breadcrumb-viewing{background:var(--color-primary);color:#fff;font-weight:700;text-decoration:none}.breadcrumb-group{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.breadcrumb-group .breadcrumb-sub-row{display:flex;gap:.25rem;justify-content:center;flex-wrap:wrap;margin-top:0;padding-top:6px;position:relative}.breadcrumb-group .breadcrumb-sub-row:before{content:"";position:absolute;top:0;left:50%;width:1px;height:6px;background:var(--color-border)}.breadcrumb-sub-pill{flex-shrink:0;padding:.125rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:500;white-space:nowrap;display:inline-flex;align-items:center;gap:.25rem;border:1px solid transparent;background:none;cursor:default;font-family:inherit}button.breadcrumb-sub-pill{cursor:pointer}button.breadcrumb-sub-pill:hover{opacity:.85}.breadcrumb-sub-pill-done{background:var(--color-success);color:#fff}.breadcrumb-sub-pill-viewing{background:var(--color-primary);color:#fff;font-weight:700}.breadcrumb-sub-pill-current{background:var(--color-primary-bg);color:var(--color-primary-dark);border-color:var(--color-primary)}.breadcrumb-sub-pill-pending{background:var(--color-bg-alt);color:var(--color-text-muted);border:1px solid var(--color-border)}.breadcrumb-sub-check{font-size:.625rem;line-height:1}.save-status{font-size:.75rem;color:var(--color-text-muted);margin-top:.5rem}.save-status-saving{color:var(--color-accent)}.save-status-saved{color:var(--color-success)}.wizard-title{margin-bottom:.25rem}.wizard-impetus{color:var(--color-text-light);font-size:var(--text-sm);line-height:1.5;margin-bottom:.25rem}.wizard-progress{background:var(--color-border);border-radius:4px;height:8px;margin-top:.5rem;margin-bottom:2rem}.wizard-progress-bar{background:var(--color-success);border-radius:4px;height:8px;transition:width .3s}.step-section{margin-top:.5rem}.step-section h3{margin-bottom:.5rem}.step-section p{color:var(--color-text-muted);margin-bottom:1.5rem}.step-error{color:var(--color-error);margin-bottom:1rem;font-size:.875rem}.step-skipped-banner{background:var(--color-primary-bg);border-left:3px solid var(--color-primary);padding:.75rem 1rem;margin-bottom:1rem;border-radius:0 6px 6px 0;font-size:.875rem;color:var(--color-text)}.process-banner{background:var(--color-primary-bg);border-left:3px solid var(--color-primary);padding:.75rem 1rem;margin-bottom:1.25rem;border-radius:0 6px 6px 0;font-size:.875rem;color:var(--color-text);line-height:1.6}.stale-content-banner{background:var(--color-terracotta-bg);border-left:3px solid var(--color-terracotta);padding:.75rem 1rem;margin-bottom:1rem;border-radius:0 6px 6px 0;font-size:.875rem;color:var(--color-text)}.stale-content-banner p{margin:0 0 .5rem}.stale-content-banner .step-actions{margin-top:.5rem}.step-actions{display:flex;gap:1rem;margin-top:1.5rem}.step-generate-btn{padding:.75rem 2rem;background:var(--color-primary);color:#fff}.step-generate-btn:hover{background:var(--color-primary-light)}.step-generate-btn:disabled{opacity:.6;cursor:not-allowed}.step-regen-btn{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.step-regen-btn:hover{background:var(--color-primary-bg)}.step-regen-btn:disabled{opacity:.6;cursor:not-allowed}.step-skip-btn{padding:.75rem 2rem;background:transparent;color:var(--color-text-muted);border:2px solid var(--color-border)}.step-skip-btn:hover{border-color:var(--color-text-muted);color:var(--color-text)}.step-skip-btn:disabled{opacity:.6;cursor:not-allowed}.step-approve-btn{padding:.75rem 2rem;background:var(--color-success);color:#fff}.step-approve-btn:hover{background:#1e8e3e}.step-approve-btn:disabled{opacity:.6;cursor:not-allowed}.step-generating{display:flex;flex-direction:column;align-items:center;padding:3rem 1rem;gap:1rem;color:var(--color-text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.step-placeholder{text-align:center;padding:3rem 1rem;border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-alt)}.step-placeholder h3{color:var(--color-text);margin-bottom:.75rem}.step-placeholder p{color:var(--color-text-muted);max-width:400px;margin:0 auto}.step-placeholder .step-icon{font-size:2.5rem;margin-bottom:1rem;display:block}.editor-toolbar{position:sticky;top:0;z-index:10;padding:.5rem;display:flex;gap:.25rem;background:#fff;border-bottom:1px solid var(--color-border-light);border-radius:var(--radius-md) var(--radius-md) 0 0}.ProseMirror{color:var(--color-text);font-family:var(--font-body);font-size:var(--text-base);line-height:1.7}.ProseMirror h1,.ProseMirror h2,.ProseMirror h3{font-family:var(--font-heading);color:var(--color-primary-dark);margin-top:1.5rem;margin-bottom:.75rem}.ProseMirror h1{font-size:var(--text-2xl)}.ProseMirror h2{font-size:var(--text-xl)}.ProseMirror h3{font-size:var(--text-lg)}.ProseMirror p{color:var(--color-text);margin-bottom:1rem}.ProseMirror ul,.ProseMirror ol{padding-left:1.5rem;margin-bottom:1rem}.ProseMirror li{margin-bottom:.25rem}.ProseMirror strong{font-weight:700}.ProseMirror blockquote{border-left:3px solid var(--color-accent);background:var(--color-warning-bg);margin:1rem 0;padding:.75rem 1rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:var(--text-sm);color:var(--color-text)}.ProseMirror blockquote p{margin-bottom:0;color:var(--color-text)}.ProseMirror hr{border:none;border-top:1px solid var(--color-border);margin:1.5rem 0}.ProseMirror img{max-width:100%;height:auto;border-radius:var(--radius-md);margin:1rem 0}.ProseMirror:focus{outline:none}.bubble-menu{display:flex;gap:2px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;padding:4px}.bubble-menu-btn{padding:.375rem .75rem;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--color-text);white-space:nowrap}.bubble-menu-btn:hover{background:var(--color-primary-bg);color:var(--color-primary-dark)}.image-panel-grid{display:grid;grid-template-columns:1fr;gap:.75rem}.image-panel-card{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;cursor:grab;transition:box-shadow .15s,border-color .15s}.image-panel-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a}.image-panel-card:active{cursor:grabbing}.image-panel-card img{width:100%;height:140px;object-fit:cover;display:block}.image-panel-card-info{padding:.5rem .625rem;display:flex;flex-direction:column;gap:.125rem}.image-panel-card-title{font-size:.75rem;font-weight:500;color:var(--color-text);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.image-panel-card-license{font-size:.6875rem;color:var(--color-text-muted)}.research-results a{color:var(--color-primary);text-decoration:underline}.research-results p{margin-bottom:.75rem;color:var(--color-text)}.research-results ul,.research-results ol{padding-left:1.25rem;margin-bottom:.75rem}.research-results strong{font-weight:600}.step-review-note{font-style:italic;color:var(--color-text-muted)!important;font-size:.875rem;margin-bottom:1rem!important}.step-readonly-content{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem 1.25rem;color:var(--color-text);line-height:1.6;white-space:pre-wrap}.section-status{display:inline-block;font-size:.6875rem;font-weight:600;padding:.125rem .5rem;border-radius:999px;margin-left:.5rem;vertical-align:middle;text-transform:uppercase;letter-spacing:.03em}.section-status-completed{background:var(--color-success);color:#fff}.section-status-started{background:var(--color-accent-bg);color:var(--color-accent-dark)}.section-status-not-started{background:var(--color-bg-alt);color:var(--color-text-muted);border:1px solid var(--color-border)}.section-link{color:var(--color-primary);text-decoration:underline;cursor:pointer}.section-link:hover{color:var(--color-primary-light)}.coloring-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}@media(max-width:600px){.coloring-grid{grid-template-columns:1fr}}.coloring-card{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:box-shadow .15s}.coloring-card:hover{box-shadow:0 2px 8px #0000001a}.coloring-card img{width:100%;height:auto;display:block}.coloring-card-label{padding:.5rem .75rem;font-size:.8125rem;font-weight:500;color:var(--color-text-muted);background:var(--color-bg-alt);text-align:center}.coloring-remove-btn{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:1.125rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.coloring-card:hover .coloring-remove-btn,.vocab-card:hover .coloring-remove-btn{opacity:1}.coloring-remove-btn:hover{background:var(--color-error)}.vocab-term-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.vocab-term-row{display:flex;gap:.5rem;align-items:flex-start}.vocab-term-input{flex:0 0 180px;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:600}.vocab-definition-input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-family:inherit;resize:vertical;line-height:1.4}.vocab-term-input:focus,.vocab-definition-input:focus{outline:none;border-color:var(--color-primary)}.vocab-term-remove{flex-shrink:0;margin-top:.375rem;width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:var(--color-text-muted);font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.vocab-term-remove:hover{background:var(--color-error);color:#fff}.vocab-add-btn{background:transparent;border:1px dashed var(--color-border);color:var(--color-text-muted);padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem}.vocab-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.vocab-card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}@media(max-width:600px){.vocab-card-grid{grid-template-columns:1fr}}.vocab-card{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:box-shadow .15s}.vocab-card:hover{box-shadow:0 2px 8px #0000001a}.vocab-card img{width:100%;height:auto;display:block}.vocab-card-placeholder{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt)}.vocab-card-text{padding:.5rem .75rem;background:var(--color-bg-alt);display:flex;flex-direction:column;gap:.125rem}.vocab-card-text strong{font-size:.875rem;color:var(--color-text)}.vocab-card-text span{font-size:.75rem;color:var(--color-text-muted);line-height:1.4}.podcast-episode-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.podcast-episode{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-alt);transition:box-shadow .15s}.podcast-episode:hover{box-shadow:0 2px 8px #00000014}.podcast-episode-info{display:flex;align-items:center;gap:.5rem;flex-shrink:0;min-width:0}.podcast-episode-number{width:28px;height:28px;border-radius:50%;background:var(--color-sky);color:#fff;font-size:.8125rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.podcast-episode-title{font-size:.875rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.podcast-audio-player{flex:1;min-width:0;height:36px}.podcast-episode-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.podcast-download-link{font-size:.75rem;color:var(--color-primary);text-decoration:none;white-space:nowrap}.podcast-download-link:hover{text-decoration:underline}.podcast-remove-btn{position:static;opacity:0;transition:opacity .15s}.podcast-episode:hover .podcast-remove-btn{opacity:1}@media(max-width:600px){.podcast-episode{flex-wrap:wrap}.podcast-audio-player{width:100%;order:3}.podcast-episode-title{max-width:140px}}.timeline-preview{margin-top:1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.timeline-preview img{width:100%;height:auto;display:block}.lapbook-picker-section{margin-bottom:1.5rem}.lapbook-picker-section h4{font-size:.9375rem;font-weight:600;color:var(--color-text);margin-bottom:.75rem}.lapbook-picker-grid{display:flex;flex-direction:column;gap:.5rem}.lapbook-picker-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s,background .15s;width:100%;box-sizing:border-box}.lapbook-picker-item:hover{border-color:var(--color-primary);background:var(--color-primary-bg)}.lapbook-picker-item input[type=checkbox]{margin-top:.125rem;flex-shrink:0;width:16px;height:16px}.lapbook-picker-thumb{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.lapbook-picker-info{display:flex;flex-direction:column;min-width:0;flex:1;gap:.125rem}.lapbook-picker-label{font-size:.875rem;font-weight:600;color:var(--color-text)}.lapbook-picker-desc{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.lapbook-reused-section{margin-bottom:1.5rem}.lapbook-reused-section h4{font-size:.9375rem;font-weight:600;color:var(--color-text);margin-bottom:.5rem}.lapbook-reused-card{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg-alt);border-radius:var(--radius-md);margin-bottom:.375rem}.lapbook-reused-check{color:var(--color-success);font-weight:700;font-size:1rem}.lapbook-reused-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.lapbook-new-section h4{font-size:.9375rem;font-weight:600;color:var(--color-text);margin-bottom:.75rem}.lapbook-component-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem 1.25rem;margin-bottom:1rem}.lapbook-component-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.lapbook-component-header h5{font-size:.9375rem;font-weight:600;color:var(--color-text);margin:0}.lapbook-approved-badge{font-size:.75rem;font-weight:600;color:var(--color-success);background:#1e8e3e1a;padding:.125rem .625rem;border-radius:999px}.lock-readings-summary{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.lock-readings-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-alt)}.lock-readings-number{width:28px;height:28px;border-radius:50%;background:var(--color-sky);color:#fff;font-size:.8125rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lock-readings-title{font-size:.9375rem;font-weight:500;color:var(--color-text)}.lock-readings-confirm{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem 1.25rem;background:var(--color-bg-alt);margin-top:1rem}.lock-readings-warning{color:var(--color-text);font-size:.875rem;line-height:1.5;margin-bottom:1rem!important}.lock-readings-warning-banner{background:var(--color-terracotta-bg);border:1px solid var(--color-terracotta);border-radius:var(--radius-md);padding:.75rem 1rem;font-size:.875rem;color:var(--color-terracotta);margin-bottom:1rem;line-height:1.5}.reading-subject-title{margin-bottom:.5rem}.reading-title-display{display:inline-flex;align-items:center;gap:.375rem;font-size:1rem;font-weight:600;color:var(--color-primary-dark)}.reading-title-edit-btn{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);display:inline-flex;align-items:center;opacity:.4;transition:opacity .15s,color .15s}.reading-title-display:hover .reading-title-edit-btn{opacity:1}.reading-title-edit-btn:hover{color:var(--color-primary);opacity:1}.reading-title-edit{display:flex;align-items:center;gap:.5rem}.reading-title-input{font-size:1rem;font-weight:600;color:var(--color-primary-dark);font-family:inherit;border:1px solid var(--color-primary);border-radius:var(--radius-md);padding:.25rem .5rem;width:100%;max-width:500px;outline:none}.invite-section{position:relative}.invite-toggle-btn{background:#6e9ecf1a;border:1px solid var(--color-sky);color:var(--color-sky);padding:.25rem .75rem;font-size:.8125rem;font-weight:600;border-radius:999px;cursor:pointer;white-space:nowrap;transition:all .15s}.invite-toggle-btn:hover{background:var(--color-sky);color:#fff}.invite-panel{position:absolute;top:100%;right:0;margin-top:.5rem;width:340px;background:var(--color-surface);border:1px solid var(--color-sky);border-top:3px solid var(--color-sky);border-radius:var(--radius-lg);box-shadow:0 8px 24px #6e9ecf2e;padding:1.25rem;z-index:20}.invite-panel h4{font-size:.9375rem;font-weight:600;color:var(--color-sky);margin-bottom:.5rem}.invite-description{font-size:.8125rem;color:var(--color-text-light);line-height:1.5;margin-bottom:.875rem}.invite-form{display:flex;gap:.5rem;margin-bottom:.75rem}.invite-email-input{flex:1;padding:.375rem .625rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8125rem;font-family:inherit}.invite-email-input:focus{outline:none;border-color:var(--color-sky);box-shadow:0 0 0 3px #6e9ecf26}.invite-send-btn{padding:.375rem .75rem;background:var(--color-sky);color:#fff;border:none;border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.invite-send-btn:hover{background:#5a8abb}.invite-send-btn:disabled{opacity:.6;cursor:not-allowed}.invite-error{color:var(--color-error);font-size:.75rem;margin-bottom:.5rem}.invite-success{color:var(--color-success);font-size:.75rem;margin-bottom:.5rem}.collab-list{display:flex;flex-direction:column;gap:.375rem;max-height:200px;overflow-y:auto}.collab-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;background:var(--color-bg-alt);border-radius:var(--radius-sm);font-size:.8125rem}.collab-name{color:var(--color-text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.collab-status{font-size:.6875rem;font-weight:600;padding:.0625rem .375rem;border-radius:999px;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.collab-status-pending{background:var(--color-accent-bg);color:var(--color-accent-dark)}.collab-status-accepted{background:var(--color-success-bg, rgba(30, 142, 62, .1));color:var(--color-success)}
