*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--amber:#F59E0B;--orange:#F97316;--coral:#FB923C;--cream:#FFFBF0;--pale:#FEF9ED;--yellow-light:#FEF3C7;--charcoal:#1C1917;--mid:#44403C;--muted:#5C5652;--muted-light:#78716C;--white:#FFFFFF;--radius:16px;--bg-primary:#FFFBF0;--bg-secondary:#FFFFFF;--bg-tertiary:#FEF9ED;--bg-card:#FFFFFF;--bg-sidebar:#F3EBDD;--bg-input:#FFFFFF;--bg-hover:#FEF9ED;--text-primary:#1C1917;--text-secondary:#44403C;--text-muted:#5C5652;--text-on-accent:#1C1917;--border-default:rgba(0,0,0,0.06);--border-subtle:rgba(0,0,0,0.04);--border-input:rgba(0,0,0,0.12);--shadow-sm:0 2px 8px rgba(0,0,0,0.04);--shadow-md:0 4px 16px rgba(0,0,0,0.08);--shadow-lg:0 8px 32px rgba(0,0,0,0.12);--sidebar-border:#E7D9BF;--sidebar-nav-bg:rgba(255,251,240,0.92);--sidebar-text:#5B4A3B;--sidebar-text-hover:#7C5A10;--sidebar-section-hover:#FFF7E6;--sidebar-section-active:#F59E0B;--sidebar-icon:#8B7355;--sidebar-icon-muted:#9CA3AF;--nav-bg:rgba(255,251,240,0.92);--nav-bg-solid:rgba(255,251,240,0.98);--nav-border:rgba(245,158,11,0.15)}[data-theme=dark]{--bg-primary:#1C1917;--bg-secondary:#292524;--bg-tertiary:#44403C;--bg-card:#292524;--bg-sidebar:#1C1917;--bg-input:#292524;--bg-hover:#44403C;--text-primary:#FFFBF0;--text-secondary:#D6D3D1;--text-muted:#A8A29E;--text-on-accent:#1C1917;--border-default:rgba(255,255,255,0.08);--border-subtle:rgba(255,255,255,0.04);--border-input:rgba(255,255,255,0.15);--shadow-sm:0 2px 8px rgba(0,0,0,0.3);--shadow-md:0 4px 16px rgba(0,0,0,0.4);--shadow-lg:0 8px 32px rgba(0,0,0,0.5);--sidebar-border:#44403C;--sidebar-nav-bg:rgba(41,37,36,0.92);--sidebar-text:#D6D3D1;--sidebar-text-hover:#FBBF24;--sidebar-section-hover:rgba(255,255,255,0.06);--sidebar-section-active:#FBBF24;--sidebar-icon:#D6D3D1;--sidebar-icon-muted:#A8A29E;--nav-bg:rgba(28,25,23,0.92);--nav-bg-solid:rgba(28,25,23,0.98);--nav-border:rgba(251,191,36,0.2);--amber:#FBBF24;--cream:#1C1917;--pale:#292524;--white:#292524;--charcoal:#FFFBF0;--mid:#D6D3D1;--muted:#A8A29E;--yellow-light:#44403C}.skip-link{position:absolute;top:-100px;left:50%;transform:translateX(-50%);background:var(--charcoal);color:var(--cream);padding:.75rem 1.5rem;border-radius:0 0 12px 12px;font-weight:700;font-size:.9rem;text-decoration:none;z-index:9999;transition:top .2s ease}.skip-link:focus{top:0;outline:3px solid var(--amber);outline-offset:2px}html{scroll-behavior:smooth}body{font-family:var(--font-nunito),"Nunito",sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden}body>nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1.5px solid var(--nav-border);padding:0 5%;display:flex;align-items:center;justify-content:space-between;height:68px}.nav-logo{display:flex;flex-direction:column;line-height:1.1}.nav-logo .brand{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.25rem;font-weight:700;color:var(--charcoal);letter-spacing:-.02em}.nav-logo .sub{font-size:.7rem;color:var(--muted);font-weight:600;letter-spacing:.08em;text-transform:uppercase}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{text-decoration:none;color:var(--mid);font-weight:600;font-size:.88rem;transition:color .2s}.nav-links a:hover{color:var(--orange)}.nav-cta{background:var(--amber);color:var(--text-on-accent);font-weight:800;font-size:.85rem;padding:.55rem 1.3rem;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s;white-space:nowrap}.nav-cta:hover{background:var(--orange);color:white;transform:translateY(-1px)}.nav-actions{display:flex;align-items:center;gap:.6rem}.nav-theme-toggle{width:38px;height:38px;border-radius:999px;border:1.5px solid var(--nav-border);background:var(--bg-secondary);color:var(--charcoal);font-size:1rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,border-color .2s,background .2s}.nav-theme-toggle:hover{transform:translateY(-1px);border-color:var(--amber);background:var(--bg-hover)}.nav-burger{display:none;background:none;border:none;color:var(--charcoal);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1}.nav-mobile-menu{display:none;position:absolute;top:68px;left:0;right:0;background:var(--nav-bg-solid);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1.5px solid var(--nav-border);padding:1rem 5% 1.5rem;z-index:99}.nav-mobile-menu ul{list-style:none;display:flex;flex-direction:column;gap:.25rem}.nav-mobile-menu li{border-bottom:1px solid rgba(0,0,0,.05)}.nav-mobile-menu li:last-child{border-bottom:none;margin-top:.5rem}.nav-mobile-menu a{display:block;padding:.85rem .25rem;text-decoration:none;color:var(--charcoal);font-weight:600;font-size:1rem}.nav-mobile-menu a:hover{color:var(--orange)}.nav-mobile-cta{background:var(--amber);color:var(--text-on-accent)!important;border-radius:100px;padding:.85rem 1rem!important;text-align:center;font-weight:800!important}.nav-mobile-theme-toggle{width:100%;text-align:left;padding:.85rem .25rem;background:none;border:none;color:var(--charcoal);font-weight:600;font-size:1rem;cursor:pointer}.nav-mobile-theme-toggle:hover{color:var(--orange)}#hero{position:relative;min-height:92vh;display:flex;align-items:center;padding:6rem 5% 4rem;overflow:hidden;gap:4rem;justify-content:space-between}.hero-blobs{position:absolute;inset:0;pointer-events:none;z-index:0}.blob{position:absolute;border-radius:60% 40% 55% 45%/45% 55% 45% 55%;opacity:.18;animation:blobFloat 8s ease-in-out infinite alternate}.blob-1{width:600px;height:600px;background:var(--amber);top:-150px;right:-100px;animation-duration:9s}.blob-2{width:350px;height:350px;background:var(--coral);bottom:-80px;left:-60px;animation-duration:11s;animation-delay:-3s}.blob-3{width:200px;height:200px;background:var(--orange);top:40%;left:30%;opacity:.1;animation-duration:13s;animation-delay:-5s}@keyframes blobFloat{0%{transform:translate(0) rotate(0deg) scale(1)}to{transform:translate(20px,30px) rotate(8deg) scale(1.05)}}#hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(245,158,11,.15) 1px,transparent 0);background-size:32px 32px;z-index:0}.hero-content{max-width:680px;flex:1 1 auto;animation:fadeUp .8s ease both}.hero-content,.hero-logo{position:relative;z-index:1}.hero-logo{flex:0 0 auto;align-self:center;animation:fadeUp .8s ease .5s both}.hero-logo:before{content:"";position:absolute;width:430px;height:430px;border-radius:50%;background:#FFFBF0;left:50%;top:56%;transform:translate(-50%,-50%);z-index:0;box-shadow:0 14px 44px rgba(0,0,0,.18)}.hero-logo img{position:relative;z-index:1;width:280px;height:auto;filter:drop-shadow(0 8px 32px rgba(245,158,11,.18))}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--yellow-light);border:1.5px solid rgba(245,158,11,.35);border-radius:100px;padding:.35rem 1rem;font-size:.8rem;font-weight:700;color:var(--orange);margin-bottom:1.5rem;letter-spacing:.03em;animation:fadeUp .8s ease .1s both}#hero h1{font-family:var(--font-fraunces),"Fraunces",serif;font-size:clamp(2.6rem,6vw,4.2rem);line-height:1.1;letter-spacing:-.03em;color:var(--charcoal);margin-bottom:1.25rem;animation:fadeUp .8s ease .2s both}#hero h1 em{font-style:italic;color:var(--orange)}.hero-sub{font-size:1.15rem;color:var(--mid);line-height:1.65;max-width:520px;margin-bottom:2.5rem;font-weight:500;animation:fadeUp .8s ease .3s both}.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .8s ease .4s both}.btn-primary{background:var(--charcoal);color:white;font-family:var(--font-nunito),"Nunito",sans-serif;font-weight:800;font-size:.95rem;padding:.85rem 1.8rem;border-radius:100px;text-decoration:none;border:none;cursor:pointer;transition:background .2s,transform .15s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover{background:var(--orange);transform:translateY(-2px)}.btn-secondary{background:transparent;color:var(--charcoal);font-family:var(--font-nunito),"Nunito",sans-serif;font-weight:800;font-size:.95rem;padding:.85rem 1.8rem;border-radius:100px;text-decoration:none;border:2px solid rgba(28,25,19,.2);cursor:pointer;transition:border-color .2s,color .2s,transform .15s;display:inline-flex;align-items:center;gap:.5rem}.btn-secondary:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-2px)}.hero-stats{display:flex;gap:2.5rem;margin-top:3.5rem;padding-top:2rem;border-top:1.5px solid rgba(245,158,11,.2);animation:fadeUp .8s ease .5s both}.stat-num{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.8rem;font-weight:700;color:var(--orange);display:block}.stat-label{font-size:.78rem;color:var(--muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase}section{padding:6rem 5%}.section-tag{display:inline-block;background:var(--yellow-light);color:var(--orange);font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:.35rem .9rem;border-radius:100px;margin-bottom:1rem}h2{font-size:clamp(2rem,4vw,2.8rem);line-height:1.15;letter-spacing:-.025em;margin-bottom:1rem}h2,h3{font-family:var(--font-fraunces),"Fraunces",serif;color:var(--charcoal)}h3{font-size:1.35rem;font-weight:600;margin-bottom:.5rem;letter-spacing:-.015em}p{line-height:1.7;color:var(--mid);font-size:1rem}#about{background:var(--white);border-radius:32px;margin:0 3%;padding:5rem 6%}.about-grid{display:grid;grid-template-columns:1fr 1.4fr;grid-gap:5rem;gap:5rem;align-items:center}.about-visual,.avatar-frame{position:relative}.avatar-frame{width:100%;max-width:340px;aspect-ratio:3/4;border-radius:24px 24px 80px 24px;overflow:hidden;box-shadow:0 20px 60px rgba(245,158,11,.2)}.avatar-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.avatar-name-tag{position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);background:white;border-radius:12px;padding:.5rem 1.2rem;font-weight:800;font-size:.85rem;color:var(--charcoal);white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.1);z-index:2}.accent-circle{position:absolute;width:90px;height:90px;background:var(--amber);border-radius:50%;bottom:-20px;right:-15px;z-index:-1;opacity:.6}.accent-star{position:absolute;top:-16px;left:-16px;font-size:2.5rem}.about-text .credentials{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.5rem 0 1.8rem}.cred-pill{border:1.5px solid rgba(245,158,11,.25);font-size:.78rem;font-weight:700;padding:.3rem .85rem;border-radius:100px}.about-quote,.cred-pill{background:var(--pale);color:var(--mid)}.about-quote{border-left:4px solid var(--amber);padding:.8rem 1.2rem;border-radius:0 12px 12px 0;font-style:italic;margin-top:1.5rem;font-size:.95rem;line-height:1.7}.about-text p,.about-text ul{margin-bottom:.9rem}.about-text .about-benefits{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-top:.4rem}.about-text .about-benefits li{line-height:1.6;color:var(--mid);font-size:1rem}.about-text .about-benefits strong{color:var(--charcoal)}#resource{background:var(--charcoal);border-radius:32px;margin:2rem 3%;padding:5rem 6%;color:white;position:relative;overflow:hidden}[data-theme=dark] #resource{background:#171412;color:var(--text-primary)}#resource:before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:var(--amber);border-radius:50%;opacity:.08}.resource-grid{grid-template-columns:1fr 1fr;grid-gap:4rem;gap:4rem;align-items:center}.resource-text h2{color:white}.resource-text p{color:rgba(255,255,255,.65)}.resource-text .section-tag{background:rgba(245,158,11,.2);color:var(--amber)}.resource-perks{list-style:none;margin:1.5rem 0 2rem;display:flex;flex-direction:column;gap:.75rem}.resource-perks li{gap:.75rem;color:rgba(255,255,255,.8);font-size:.95rem;font-weight:600}.perk-icon,.resource-perks li{display:flex;align-items:center}.perk-icon{width:28px;height:28px;background:var(--amber);border-radius:8px;justify-content:center;font-size:.85rem;flex-shrink:0}.resource-form{background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:24px;padding:2.5rem}.resource-form h3{color:white;font-size:1.5rem;margin-bottom:.5rem}.resource-form p{color:rgba(255,255,255,.5);font-size:.85rem;margin-bottom:1.5rem}.form-field{margin-bottom:1rem}.form-field input,.form-field select{width:100%;padding:.85rem 1rem;border-radius:12px;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:white;font-family:var(--font-nunito),"Nunito",sans-serif;font-size:.9rem;font-weight:600;outline:none;transition:border-color .2s}.form-field input::placeholder{color:rgba(255,255,255,.35)}.form-field input:focus,.form-field select:focus{border-color:var(--amber)}.form-field select option{background:var(--charcoal);color:white}[data-theme=dark] .resource-text h2{color:var(--text-primary)}[data-theme=dark] .resource-text p{color:rgba(255,255,255,.78)}[data-theme=dark] .resource-perks li{color:rgba(255,255,255,.88)}[data-theme=dark] .resource-form{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.16)}[data-theme=dark] .resource-form h3{color:var(--text-primary)}[data-theme=dark] .resource-form p{color:rgba(255,255,255,.72)}[data-theme=dark] .form-field input,[data-theme=dark] .form-field select{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.18);color:var(--text-primary)}[data-theme=dark] .form-field input::placeholder{color:rgba(255,255,255,.55)}[data-theme=dark] .form-field select option{background:#1f1a17;color:#fff}.btn-amber{width:100%;background:var(--amber);color:var(--charcoal);font-family:var(--font-nunito),"Nunito",sans-serif;font-weight:800;font-size:.95rem;padding:.95rem 1.5rem;border-radius:12px;border:none;cursor:pointer;transition:background .2s,transform .15s;margin-top:.5rem}.btn-amber:hover{background:var(--orange);transform:translateY(-1px)}.btn-amber:active{transform:translateY(0);box-shadow:inset 0 2px 4px rgba(0,0,0,.15)}#courses{padding-top:5rem;padding-bottom:5rem}.courses-header{text-align:center;max-width:560px;margin:0 auto 3.5rem}.courses-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1.5rem;gap:1.5rem;max-width:1200px;margin:0 auto}.course-card{background:var(--white);border-radius:24px;padding:2.5rem;border:1.5px solid rgba(245,158,11,.15);position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s}.course-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(245,158,11,.15)}.course-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--amber),var(--coral));border-radius:4px 4px 0 0}.course-badge{display:inline-block;background:var(--yellow-light);color:var(--orange);font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .8rem;border-radius:100px;margin-bottom:1.2rem}.course-card h3{font-size:1.5rem;margin-bottom:.6rem}.course-price{font-family:var(--font-fraunces),"Fraunces",serif;font-size:2rem;font-weight:700;color:var(--orange);margin:1.2rem 0}.course-price span{font-family:var(--font-nunito),"Nunito",sans-serif;font-size:.85rem;color:var(--muted);font-weight:600}.course-modules{list-style:none;margin:1rem 0 2rem;display:flex;flex-direction:column;gap:.5rem}.course-modules li{font-size:.85rem;color:var(--mid);font-weight:600;display:flex;gap:.5rem;align-items:flex-start}.course-modules li:before{content:"→";color:var(--amber);flex-shrink:0;margin-top:.05em}.btn-outline-amber{display:block;text-align:center;width:100%;padding:.85rem;border:2px solid var(--amber);border-radius:12px;color:var(--charcoal);font-family:var(--font-nunito),"Nunito",sans-serif;font-weight:800;font-size:.9rem;text-decoration:none;transition:background .2s,color .2s,transform .15s;cursor:pointer;background:transparent}.btn-outline-amber:hover{background:var(--amber);transform:translateY(-1px)}.coming-soon-chip{display:inline-block;background:#FEF3C7;color:#92400E;font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .7rem;border-radius:100px;margin-left:.5rem;vertical-align:middle}#blog{background:var(--pale);border-radius:32px;margin:2rem 3%;padding:5rem 6%}.blog-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem}.blog-header a{color:var(--orange);font-weight:800;text-decoration:none;font-size:.9rem;transition:gap .2s}.blog-header a:hover{text-decoration:underline}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1.5rem;gap:1.5rem}.blog-card{background:var(--white);border-radius:20px;overflow:hidden;transition:transform .25s,box-shadow .25s;cursor:pointer}.blog-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.08)}.blog-thumb{height:160px;display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative;overflow:hidden}.thumb-1{background:linear-gradient(135deg,#FEF3C7,#FED7AA)}.thumb-2{background:linear-gradient(135deg,#E0F2FE,#BAE6FD)}.thumb-3{background:linear-gradient(135deg,#F0FDF4,#BBF7D0)}.blog-body{padding:1.5rem}.blog-tag{font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);margin-bottom:.6rem;display:block}.blog-card h3{font-size:1.05rem;line-height:1.35;margin-bottom:.6rem}.blog-meta{font-size:.78rem;color:var(--muted);font-weight:600}#social{text-align:center;padding:5rem 5%}#social h2{margin-bottom:.75rem}#social>p{max-width:480px;margin:0 auto 2.5rem}.social-links{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.social-pill{display:flex;align-items:center;gap:.6rem;padding:.75rem 1.4rem;border-radius:100px;font-weight:800;font-size:.88rem;text-decoration:none;transition:transform .2s,box-shadow .2s;border:1.5px solid transparent}.social-pill:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.12)}.sp-instagram{background:#FFF0F5;color:#C4336A;border-color:#FBCFE8}.sp-tiktok{background:#F0FFFE;color:#010101;border-color:#CCFBF1}.sp-facebook{background:#EEF2FF;color:#3B5BDB;border-color:#C7D2FE}.sp-youtube{background:#FFF5F5;color:#DC2626;border-color:#FECACA}.sp-linkedin{background:#EFF6FF;color:#1D4ED8;border-color:#BFDBFE}.social-icon{font-size:1.2rem}footer{background:var(--charcoal);color:rgba(255,255,255,.6);padding:3rem 5%;text-align:center}[data-theme=dark] footer{background:#171412;color:rgba(255,255,255,.72)}.footer-logo{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.4rem;font-weight:700;color:white;margin-bottom:.3rem}.footer-tagline{font-size:.85rem;color:rgba(255,255,255,.4);margin-bottom:2rem}.footer-nav{display:flex;justify-content:center;gap:2rem;list-style:none;margin-bottom:1.5rem}.footer-nav a{text-decoration:none;color:rgba(255,255,255,.55);font-size:.85rem;font-weight:600;transition:color .2s}.footer-nav a:hover{color:var(--amber)}.footer-newsletter{display:flex;justify-content:center;gap:.75rem;margin:2rem 0;flex-wrap:wrap}.footer-newsletter input{padding:.75rem 1.2rem;border-radius:10px;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:white;font-family:var(--font-nunito),"Nunito",sans-serif;font-size:.88rem;font-weight:600;outline:none;min-width:240px;transition:border-color .2s}.footer-newsletter input::placeholder{color:rgba(255,255,255,.3)}.footer-newsletter input:focus{border-color:var(--amber)}.footer-newsletter button{padding:.75rem 1.4rem;border-radius:10px;border:none;background:var(--amber);color:var(--charcoal);font-family:var(--font-nunito),"Nunito",sans-serif;font-weight:800;font-size:.88rem;cursor:pointer;transition:background .2s}.footer-newsletter button:hover{background:var(--orange);color:white}.footer-copy{font-size:.78rem;color:rgba(255,255,255,.25);margin-top:1rem}.footer-copy a{color:rgba(255,255,255,.4);text-decoration:none}.footer-coming-soon{color:rgba(255,255,255,.35);font-style:italic}[data-theme=dark] .footer-logo{color:var(--text-primary)}[data-theme=dark] .footer-tagline{color:rgba(255,255,255,.66)}[data-theme=dark] .footer-nav a{color:rgba(255,255,255,.86)}[data-theme=dark] .footer-newsletter input{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.18);color:var(--text-primary)}[data-theme=dark] .footer-newsletter input::placeholder{color:rgba(255,255,255,.55)}[data-theme=dark] .footer-copy{color:rgba(255,255,255,.6)}[data-theme=dark] .footer-copy a{color:rgba(255,255,255,.78)}[data-theme=dark] .footer-coming-soon{color:rgba(255,255,255,.68)}.blog-coming-soon{color:var(--muted);font-style:italic;font-size:.9rem}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--amber);outline-offset:2px;border-radius:4px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:1px;border-radius:inherit}.toast{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem calc(.75rem + 3px);background:var(--white);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.12);border:1px solid rgba(0,0,0,.06);z-index:300;max-width:360px;animation:toast-slide .25s cubic-bezier(.4,0,.2,1);overflow:hidden}.toast:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--amber);transform-origin:left;animation:toast-progress 4s linear forwards}.toast-error:after{background:#DC2626}@keyframes toast-progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}@keyframes toast-slide{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem}.toast-success .toast-icon{background:#D1FAE5;color:#065F46}.toast-error .toast-icon{background:#FEE2E2;color:#991B1B}.toast-message{flex:1 1;font-size:.875rem;color:var(--charcoal)}.toast-close{background:none;border:none;color:var(--muted);font-size:.85rem;cursor:pointer;padding:.2rem .4rem}.toast-close:hover{color:var(--charcoal)}.class-resources{margin-top:2.5rem}.class-resources h2{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.4rem;color:var(--charcoal);margin-bottom:1rem}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:.85rem;gap:.85rem}.resource-card{display:flex;align-items:stretch;align-self:stretch;background:var(--white);border-radius:14px;box-shadow:0 2px 12px rgba(0,0,0,.05);transition:box-shadow .2s,transform .2s;overflow:hidden;animation:card-enter .3s ease both;min-height:72px;height:100%}.resource-card:hover{box-shadow:0 4px 18px rgba(0,0,0,.08);transform:translateY(-1px)}.resource-grid .resource-card:first-child{animation-delay:.03s}.resource-grid .resource-card:nth-child(2){animation-delay:.06s}.resource-grid .resource-card:nth-child(3){animation-delay:.09s}.resource-grid .resource-card:nth-child(4){animation-delay:.12s}.resource-grid .resource-card:nth-child(5){animation-delay:.15s}.resource-grid .resource-card:nth-child(n+6){animation-delay:.18s}.resource-card-body{flex:1 1;display:flex;align-items:center;gap:.85rem;padding:.95rem 1rem;text-decoration:none;color:inherit;min-width:0}.resource-card-icon{flex-shrink:0;font-size:1.4rem}.resource-card-thumb{flex-shrink:0;width:56px;height:40px;object-fit:cover;border-radius:6px;background:var(--cream);border:1px solid rgba(0,0,0,.06)}.resource-card-info{flex:1 1;min-width:0}.resource-card-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.resource-card-name,.resource-card-name-input{font-size:.92rem;font-weight:700;color:var(--charcoal);margin:0 0 .2rem}.resource-card-name-input{width:100%;padding:.2rem .4rem;border:1.5px solid var(--amber);border-radius:6px;font-family:inherit}.resource-card-meta{font-size:.78rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:.3rem}.resource-card-class{color:var(--amber);font-weight:700}.resource-card-actions{display:flex;align-items:center;gap:.1rem;padding:0 .35rem;border-left:1px solid rgba(0,0,0,.05)}.resource-action{width:30px;height:30px;border:none;background:none;cursor:pointer;color:var(--muted);font-size:.9rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,transform .1s}.resource-action:active{transform:scale(.95)}.resource-action:hover{background:var(--pale);color:var(--charcoal)}.resource-action-delete:hover{background:#FEE2E2;color:#DC2626}.resource-action-confirm{color:#DC2626}.resource-empty{text-align:center;padding:4rem 2rem;background:var(--white);border-radius:14px;box-shadow:0 2px 12px rgba(0,0,0,.04)}.resource-empty-icon{font-size:3rem;margin-bottom:1rem}.resource-empty h2{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.4rem;color:var(--charcoal);margin-bottom:.5rem}.resource-empty p{color:var(--muted);max-width:400px;margin:0 auto 1.5rem}.resource-empty .btn-amber{display:inline-block;padding:.75rem 1.5rem;text-decoration:none}.resources-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.resources-header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.resources-controls{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}.resources-search{flex:1 1;min-width:200px;padding:.55rem .85rem;border:1.5px solid rgba(0,0,0,.12);border-radius:10px;font-size:.88rem;font-family:inherit;background:var(--white);transition:border-color .2s}.resources-search:focus{outline:none;border-color:var(--amber)}.resources-filter{padding:.55rem .85rem;border:1.5px solid rgba(0,0,0,.12);border-radius:10px;font-size:.85rem;font-family:inherit;background:var(--white);cursor:pointer;transition:border-color .2s}.resources-filter:focus{outline:none;border-color:var(--amber)}.resources-count{font-size:.8rem;color:var(--muted);margin-left:auto;white-space:nowrap}.resources-bulk-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.75rem 1rem;background:var(--pale);border:1px solid rgba(245,158,11,.2);border-radius:12px;margin-bottom:1rem}.resources-select-all{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--charcoal);cursor:pointer}.resources-select-all input[type=checkbox]{accent-color:var(--amber);width:16px;height:16px}.resources-bulk-count{font-size:.82rem;color:var(--muted)}.resources-bulk-actions{display:flex;gap:.5rem;margin-left:auto;flex-wrap:wrap}.resource-card-checkbox{display:flex;align-items:center;padding:0 0 0 1rem;cursor:pointer}.resource-card-checkbox input[type=checkbox]{accent-color:var(--amber);width:18px;height:18px}.resource-card-selected{border:1.5px solid var(--amber);box-shadow:0 2px 16px rgba(245,158,11,.18)}.resource-view-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.resource-view-title{display:flex;align-items:center;gap:.75rem;flex:1 1;min-width:0}.resource-view-title h1{margin:0}.resource-view-name-input,.resource-view-title h1{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.6rem;color:var(--charcoal)}.resource-view-name-input{flex:1 1;padding:.25rem .5rem;border:1.5px solid var(--amber);border-radius:8px;background:var(--white)}.resource-view-actions{display:flex;gap:.5rem;flex-wrap:wrap}.resource-view-btn{padding:.5rem .9rem;background:var(--white);border:1px solid rgba(0,0,0,.1);border-radius:8px;font-size:.82rem;font-weight:600;color:var(--charcoal);font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s}.resource-view-btn:hover{background:var(--pale);border-color:var(--amber)}.resource-view-btn-danger{color:#DC2626;border-color:#FECACA}.resource-view-btn-danger:hover{background:#FEF2F2;border-color:#DC2626}.loading-shell{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:2rem}.loading-spinner{width:36px;height:36px;border:3px solid rgba(245,158,11,.2);border-top:3px solid var(--amber);border-radius:50%;animation:spin .8s linear infinite}.loading-shell-skeleton{padding:1rem 0}.skeleton-line{background:linear-gradient(90deg,#f0ebe3 25%,#e8e3db 50%,#f0ebe3 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:6px}[data-theme=dark] .skeleton-line{background-image:linear-gradient(90deg,#3d3836 25%,#4a4543 50%,#3d3836 75%);background-size:200% 100%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:var(--white);border-radius:16px;padding:1.25rem;box-shadow:0 2px 12px rgba(0,0,0,.04)}.skeleton-icon{border-radius:10px;flex-shrink:0}.skeleton-badge{border-radius:100px}.skeleton-tool-card{display:flex;gap:1rem;align-items:flex-start;min-height:100px}.skeleton-tool-content{flex:1 1;display:flex;flex-direction:column;gap:.5rem}.skeleton-tool-header{display:flex;align-items:center;gap:.5rem}.skeleton-class-card{display:flex;flex-direction:column;gap:.75rem;min-height:120px;padding:1.25rem}.skeleton-badges{display:flex;gap:.5rem}.skeleton-resource-card{display:flex;align-items:center;gap:.85rem;border-radius:14px;padding:1rem 1.25rem}.skeleton-resource-content{flex:1 1;display:flex;flex-direction:column;gap:.4rem}.skeleton-resource-meta{display:flex;gap:.5rem}@media (max-width:768px){.nav-cta,.nav-links{display:none}.nav-burger{display:block}.nav-theme-toggle{width:36px;height:36px}.nav-mobile-menu{display:block}.about-grid,.blog-grid,.courses-grid,.resource-grid{grid-template-columns:1fr}#about,#blog,#resource{margin:1rem;padding:3rem 5%}.hero-stats{gap:1.5rem;flex-wrap:wrap;justify-content:center}.blog-header{flex-direction:column;align-items:flex-start;gap:.75rem}.hero-logo{display:none}.footer-nav{flex-wrap:wrap;gap:1rem}.spec-locked{flex-direction:column;align-items:stretch}.spec-locked-badges{flex-wrap:wrap}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}body:has(.construction-login)>footer,body:has(.construction-shell)>footer{display:none}.construction-login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{background:var(--white);border-radius:24px;padding:3rem;max-width:400px;width:100%;text-align:center;box-shadow:0 8px 40px rgba(0,0,0,.08)}.login-icon{font-size:3rem;margin-bottom:1rem}.login-card h1{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.6rem;margin-bottom:.5rem;color:var(--charcoal)}.login-card>p{color:var(--muted);font-size:.9rem;margin-bottom:1.5rem}.login-field{margin-bottom:.75rem}.login-field input{width:100%;padding:.75rem 1rem;border:1.5px solid rgba(0,0,0,.12);border-radius:12px;font-size:.95rem;font-family:inherit;transition:border-color .2s}.login-field input:focus{outline:none;border-color:var(--amber)}.login-error{color:#DC2626;font-size:.85rem;margin-bottom:.75rem}.login-button{width:100%;padding:.75rem;background:var(--charcoal);color:var(--white);border:none;border-radius:12px;font-size:.95rem;font-weight:700;font-family:inherit;cursor:pointer;transition:background .2s}.login-button:hover{background:var(--mid)}.login-field--password{position:relative}.login-pw-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;color:var(--muted);border-radius:6px;transition:color .15s}.login-pw-toggle:hover{color:var(--charcoal)}.login-pw-toggle svg{width:18px;height:18px}.construction-dashboard{max-width:1100px;margin:0 auto;padding:.6rem 5% 2rem;position:relative}.construction-dashboard:before{content:"";position:absolute;top:0;right:-120px;width:360px;height:360px;background:radial-gradient(circle,rgba(245,158,11,.12),transparent 70%);border-radius:50%;pointer-events:none;z-index:0}.construction-dashboard>*{position:relative;z-index:1}.construction-header{margin-bottom:1.25rem}.construction-header h1{font-family:var(--font-fraunces),"Fraunces",serif;font-size:2rem;color:var(--charcoal);margin-bottom:.5rem}.construction-header p{color:var(--muted)}.construction-dashboard h2{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.4rem;color:var(--charcoal);margin:0}.construction-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1rem}.stat-card{background:var(--white);border-radius:16px;padding:1.25rem;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.06)}.stat-value{display:block;font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.8rem;font-weight:700;color:var(--amber)}.stat-desc{display:block;font-size:.8rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1rem;gap:1rem}.tools-section{margin-top:1rem;padding:0}.tools-section+.tools-section{margin-top:1.75rem}.tools-section+.tools-section:before{content:"";display:block;height:1px;background:linear-gradient(90deg,transparent,#D4C4A8 20%,#D4C4A8 80%,transparent);margin-bottom:1.5rem}.tools-section-head{margin-bottom:.5rem}.tools-section-head h2{margin:0;font-size:1.1rem}.tools-section-head p{margin:.25rem 0 0;color:var(--muted);font-size:.88rem}.tools-section-batch{border:3px solid rgba(245,158,11,.75);border-radius:16px;background:rgba(255,255,255,.35);background:color-mix(in srgb,var(--bg-primary) 88%,var(--bg-secondary) 12%);padding:1rem;box-shadow:0 3px 14px rgba(245,158,11,.14)}[data-theme=dark] .tools-section-batch{background:rgba(255,255,255,.03);border-color:rgba(251,191,36,.85);box-shadow:0 3px 14px rgba(0,0,0,.35)}.tools-section-batch .tools-section-head h2{color:var(--amber)}.tools-section-batch .tool-card{border:1px solid rgba(245,158,11,.25);box-shadow:0 2px 12px rgba(245,158,11,.1)}.tools-section-batch .tool-card:hover{box-shadow:0 6px 22px rgba(245,158,11,.18)}.tool-card{display:flex;gap:1rem;align-items:flex-start;align-self:stretch;background:var(--white);border-radius:16px;padding:1.25rem;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:box-shadow .2s,transform .2s;min-height:100px;height:100%;animation:card-enter .35s ease both}.tool-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.1);transform:translateY(-2px)}@keyframes card-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.tools-grid .tool-card:first-child{animation-delay:.05s}.tools-grid .tool-card:nth-child(2){animation-delay:.1s}.tools-grid .tool-card:nth-child(3){animation-delay:.15s}.tools-grid .tool-card:nth-child(4){animation-delay:.2s}.tools-grid .tool-card:nth-child(5){animation-delay:.25s}.tools-grid .tool-card:nth-child(6){animation-delay:.3s}.tools-grid .tool-card:nth-child(n+7){animation-delay:.35s}.tool-icon{font-size:1.6rem;flex-shrink:0;margin-top:.1rem}.tool-info{flex:1 1}.tool-name-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.tool-name-row h3{font-size:1rem;font-weight:700;color:var(--charcoal);margin:0}.tool-status{font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:100px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.status-live{background:#D1FAE5;color:#065F46}.status-building{background:#FEF3C7;color:#92400E}.status-planned{background:#F3F4F6;color:#6B7280}.form-error{color:#DC2626;font-size:.85rem;margin:.5rem 0}.form-success{color:var(--amber);font-weight:600}.tool-card p{font-size:.85rem;color:var(--muted);line-height:1.4;margin:0}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:16px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06)}.data-table td,.data-table th{padding:.75rem 1.25rem;text-align:left;font-size:.9rem}.data-table th{background:var(--charcoal);color:var(--white);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.data-table td{border-bottom:1px solid rgba(0,0,0,.06);color:var(--mid)}.data-table .total-row td{font-weight:700;color:var(--charcoal);border-top:2px solid var(--amber)}.spec-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:.75rem;gap:.75rem;margin-bottom:1.5rem}.spec-field label{display:block;font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem}.spec-field input[type=text],.spec-field select{width:100%;padding:.6rem .8rem;border:1.5px solid rgba(0,0,0,.12);border-radius:10px;font-size:.9rem;font-family:inherit;background:var(--white);cursor:pointer;transition:border-color .2s}.spec-field input[type=text]:focus,.spec-field select:focus{outline:none;border-color:var(--amber)}.spec-field input[type=text]:disabled,.spec-field select:disabled{opacity:.5;cursor:not-allowed}.tool-page{max-width:1200px;margin:0 auto;padding:2rem 5%}.tool-page-header{margin-bottom:2rem}.tool-back-btn{display:inline-block;text-decoration:none;color:var(--muted);font-weight:600;font-size:.9rem;margin-bottom:1rem;transition:color .2s}.tool-back-btn:hover{color:var(--amber)}.tool-page-title{display:flex;align-items:center;gap:.75rem}.tool-page-icon{font-size:2rem}.tool-page-title h1{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.8rem;color:var(--charcoal);margin:0}.tool-page-desc{color:var(--muted);margin-top:.5rem}.tool-form{background:var(--white);border-radius:20px;padding:2rem;box-shadow:0 2px 16px rgba(0,0,0,.06)}.tool-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin:1.5rem 0}.tool-field label{display:block;font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem}.tool-field input[type=number],.tool-field input[type=text],.tool-field select,.tool-field textarea{width:100%;padding:.6rem .8rem;border:1.5px solid rgba(0,0,0,.12);border-radius:10px;font-size:.9rem;font-family:inherit;background:var(--white);transition:border-color .2s}.tool-field input:focus,.tool-field select:focus,.tool-field textarea:focus{outline:none;border-color:var(--amber)}.tool-field textarea{resize:vertical;min-height:80px}.tool-field-full{grid-column:1/-1}.tool-field-hint{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.tool-checkboxes{display:flex;flex-wrap:wrap;gap:1rem}.tool-checkboxes-vertical{display:flex;flex-direction:column;gap:.5rem;padding-top:.2rem}.tool-checkbox label{display:flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:500;color:var(--mid);text-transform:none;letter-spacing:0;cursor:pointer}.tool-checkbox input[type=checkbox]{width:auto;accent-color:var(--amber)}.tool-generate-btn{width:100%;padding:.85rem;background:var(--amber);color:var(--charcoal);border:none;border-radius:12px;font-size:1rem;font-weight:800;font-family:inherit;cursor:pointer;transition:background .2s,transform .15s;margin-top:.5rem}.tool-generate-btn:hover:not(:disabled){background:var(--orange);color:var(--white);transform:translateY(-1px)}.tool-generate-btn:active:not(:disabled){transform:translateY(0);box-shadow:inset 0 2px 4px rgba(0,0,0,.15)}.tool-generate-btn:disabled{opacity:.5;cursor:not-allowed;background:#D4B896}.tool-generate-btn--loading{position:relative;padding-left:2.75rem}.btn-spinner{position:absolute;left:1rem;width:18px;height:18px;border:2px solid rgba(0,0,0,.2);border-top:2px solid var(--charcoal);border-radius:50%;animation:spin .8s linear infinite}.tool-file-upload{margin-top:.5rem}.tool-upload-btn{padding:.5rem 1rem;background:var(--cream);border:1px dashed var(--mid);border-radius:8px;font-size:.85rem;font-weight:600;color:var(--mid);cursor:pointer;transition:background .15s,border-color .15s}.tool-upload-btn:hover{background:var(--light);border-color:var(--amber);color:var(--charcoal)}.tool-error{background:#FEF2F2;border:1px solid #fecaca;color:#991B1B;border-radius:12px;padding:1rem 1.25rem;margin-top:1.5rem;font-size:.9rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.tool-retry-btn{background:#991B1B;color:#fff;border:none;border-radius:8px;padding:.35rem .9rem;font-size:.82rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s;flex-shrink:0}.tool-retry-btn:hover{background:#7F1D1D}.tool-retry-btn:disabled{opacity:.5;cursor:not-allowed}.tool-loading{text-align:center;padding:3rem 1rem;margin-top:1.5rem;background:var(--white);border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,.04)}.tool-spinner{width:36px;height:36px;border:3px solid rgba(245,158,11,.2);border-top:3px solid var(--amber);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.tool-progress{width:100%;max-width:280px;height:6px;background:rgba(245,158,11,.15);border-radius:3px;overflow:hidden;margin:0 auto 1.25rem}.tool-progress-bar{height:100%;background:linear-gradient(90deg,var(--amber),var(--orange));border-radius:3px;animation:progress-indeterminate 1.8s ease-in-out infinite}@keyframes progress-indeterminate{0%{width:0;margin-left:0}50%{width:60%;margin-left:20%}to{width:0;margin-left:100%}}@keyframes spin{to{transform:rotate(1turn)}}.tool-loading p{color:var(--charcoal);font-size:.95rem;font-weight:600}.tool-loading-hint{color:var(--muted)!important;font-size:.85rem!important;font-weight:400!important;margin-top:.5rem;opacity:.8}.tool-image-status{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#FEF3C7,#FDE68A);border-radius:12px;margin-top:1rem}.tool-image-status-icon{font-size:1.5rem;animation:pulse 2s ease-in-out infinite}.tool-image-status p{color:var(--charcoal);font-size:.9rem;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stream-ticker{margin:1rem auto 0;max-width:640px;height:1.8em;overflow:hidden;white-space:nowrap;mask-image:linear-gradient(90deg,transparent,#000 30%,#000);-webkit-mask-image:linear-gradient(90deg,transparent,#000 30%,#000)}.stream-ticker__track{display:flex;justify-content:flex-end;align-items:center;gap:.45rem;height:100%;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;line-height:1;color:var(--muted)}.stream-ticker__token{display:inline-block;flex-shrink:0;animation:stream-token-slide .45s cubic-bezier(.22,.61,.36,1) both}@keyframes stream-token-slide{0%{opacity:0;transform:translateX(28px)}to{opacity:1;transform:translateX(0)}}.slide-image-selector{margin-top:1.5rem;background:var(--white);border-radius:16px;padding:1.5rem 1.75rem;box-shadow:0 2px 12px rgba(0,0,0,.04)}.slide-image-selector h3{margin:0 0 .4rem;font-size:1.1rem;font-weight:700;color:var(--charcoal)}.slide-image-selector .text-muted{margin:0 0 .5rem;font-size:.85rem;color:var(--muted)}.slide-image-selector__notice{margin:0 0 1rem;padding:.55rem .8rem;background:rgba(245,158,11,.08);border-left:3px solid var(--amber);border-radius:6px;color:var(--charcoal);font-size:.8rem;line-height:1.4}.slide-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:.6rem;gap:.6rem;margin:0 0 1.25rem}.slide-option{display:flex;align-items:flex-start;gap:.65rem;padding:.7rem .9rem;background:var(--cream);border:1.5px solid rgba(0,0,0,.06);border-radius:10px;cursor:pointer;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease;font-size:.88rem;line-height:1.4;color:var(--charcoal)}.slide-option:hover{border-color:var(--amber);background:var(--white)}.slide-option:has(input:checked){background:rgba(245,158,11,.08);border-color:var(--amber);box-shadow:0 0 0 1px var(--amber)}.slide-option:has(input:disabled:not(:checked)){opacity:.45;cursor:not-allowed}.slide-option input[type=checkbox]{margin:.15rem 0 0;width:1rem;height:1rem;accent-color:var(--amber);cursor:pointer;flex-shrink:0}.slide-option span{flex:1 1;min-width:0}.slide-image-selector .error-message{margin:0 0 .75rem;padding:.6rem .85rem;background:#FEF2F2;border:1px solid #fecaca;border-radius:8px;color:#991B1B;font-size:.85rem}.slide-image-selector .progress-message{margin:0 0 .75rem;font-size:.85rem;color:var(--muted)}.slide-image-selector .btn-primary{padding:.6rem 1.25rem;background:linear-gradient(135deg,var(--amber),var(--orange));color:var(--white);font-weight:600;font-size:.9rem;border:none;border-radius:10px;cursor:pointer;transition:opacity .15s ease,transform .15s ease}.slide-image-selector .btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.slide-image-selector .btn-primary:disabled{opacity:.45;cursor:not-allowed}.tool-output{margin-top:2rem;background:var(--white);border-radius:20px;box-shadow:0 2px 16px rgba(0,0,0,.06);overflow:hidden;animation:output-success .5s ease}@keyframes output-success{0%{opacity:0;transform:translateY(16px);box-shadow:0 0 0 0 rgba(16,185,129,.4)}50%{box-shadow:0 0 0 8px rgba(16,185,129,0)}to{opacity:1;transform:translateY(0);box-shadow:0 2px 16px rgba(0,0,0,.06)}}.tool-output-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.06)}.tool-output-header h3{font-size:1rem;font-weight:700;color:var(--charcoal);margin:0}.tool-output-actions{display:flex;align-items:center;gap:1rem}.tool-output-meta{font-size:.75rem;color:var(--muted)}.tool-copy-btn{background:var(--pale);border:1px solid rgba(245,158,11,.2);color:var(--mid);font-size:.8rem;font-weight:600;padding:.3rem .8rem;border-radius:8px;cursor:pointer;font-family:inherit;transition:background .2s}.tool-copy-btn:hover{background:var(--yellow-light)}.tool-copy-btn.copied{background:#D1FAE5;border-color:#10B981;color:#065F46}.tool-copy-btn.error{background:#FEE2E2;border-color:#DC2626;color:#991B1B}.tool-copy-btn--classroom{background:var(--pale);border-width:1.5px;border-color:rgba(245,158,11,.35)}.tool-copy-btn--classroom:hover{background:var(--yellow-light)}.tool-output-content{padding:1.5rem 2rem 2rem;font-size:.95rem;line-height:1.7;color:var(--mid)}.tool-output-content h1{font-size:1.6rem;margin:0 0 1rem}.tool-output-content h1,.tool-output-content h2{font-family:var(--font-fraunces),"Fraunces",serif;color:var(--charcoal)}.tool-output-content h2{font-size:1.25rem;margin:1.5rem 0 .5rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}.tool-output-content h3{font-size:1.05rem;font-weight:700;color:var(--charcoal);margin:1.2rem 0 .4rem}.tool-output-content p{margin:.5rem 0}.tool-output-content ol,.tool-output-content ul{margin:.5rem 0;padding-left:1.5rem}.tool-output-content li{margin:.3rem 0;list-style:disc}.tool-output-content ol li{list-style:decimal}.tool-output-content strong{color:var(--charcoal)}.tool-output-content table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem}.tool-output-content td,.tool-output-content th{padding:.5rem .75rem;border:1px solid rgba(0,0,0,.1);text-align:left}.tool-output-content th{background:var(--pale);font-weight:700;color:var(--charcoal)}.tool-output-content hr{border:none;border-top:1px solid rgba(0,0,0,.08);margin:1.5rem 0}.tool-output-content blockquote{border-left:3px solid var(--amber);padding-left:1rem;margin:1rem 0;color:var(--muted);font-style:italic}.mark-section{margin:1.5rem 0;padding:1.25rem;background:var(--pale);border-radius:14px;border:1px solid rgba(245,158,11,.12)}.mark-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.mark-section-title{font-size:1rem;font-weight:700;color:var(--charcoal);margin:0 0 .25rem}.mark-section-desc{font-size:.82rem;color:var(--muted);margin:0 0 .75rem}.tool-add-btn{background:var(--amber);color:var(--charcoal);border:none;font-size:.82rem;font-weight:700;padding:.4rem .9rem;border-radius:8px;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .2s}.tool-add-btn:hover{background:var(--orange);color:var(--white)}.tool-file-input{font-size:.85rem;color:var(--mid)}.tool-file-badge{display:inline-block;font-size:.8rem;color:var(--mid);margin-top:.4rem}.student-work-card{background:var(--white);border-radius:12px;padding:1rem;margin-bottom:.75rem;border:1px solid rgba(0,0,0,.06)}.student-work-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.student-work-label{font-size:.85rem;font-weight:700;color:var(--charcoal)}.student-work-remove{background:none;border:none;color:#DC2626;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit}.student-work-toggle{display:flex;gap:0;margin-bottom:.75rem}.toggle-btn{flex:1 1;padding:.4rem .6rem;border:1.5px solid rgba(0,0,0,.12);background:var(--white);color:var(--muted);font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.toggle-btn:first-child{border-radius:8px 0 0 8px}.toggle-btn:last-child{border-radius:0 8px 8px 0;border-left:none}.toggle-active{background:var(--amber);color:var(--charcoal);border-color:var(--amber)}.student-work-textarea{width:100%;padding:.6rem .8rem;border:1.5px solid rgba(0,0,0,.12);border-radius:10px;font-size:.9rem;font-family:inherit;resize:vertical;min-height:120px;transition:border-color .2s}.student-work-textarea:focus{outline:none;border-color:var(--amber)}.student-work-upload{display:flex;flex-direction:column;gap:.5rem}.student-work-preview{max-width:100%;max-height:200px;border-radius:8px;border:1px solid rgba(0,0,0,.08);object-fit:contain}.mark-guide-btn{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--amber);background:var(--yellow-light);color:var(--amber);font-weight:800;font-size:.85rem;cursor:pointer;flex-shrink:0;font-family:inherit;transition:background .2s}.mark-guide-btn:hover{background:var(--amber);color:var(--white)}.mark-guide{background:var(--white);border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1rem}.mark-guide pre{white-space:pre-wrap;font-family:inherit;font-size:.82rem;color:var(--mid);line-height:1.6;margin:0}.student-row{display:flex;align-items:center;gap:.6rem;padding:.6rem .8rem;background:var(--white);border:1px solid rgba(0,0,0,.06);border-radius:10px;margin-bottom:.5rem}.student-row-icon{font-size:.9rem;flex-shrink:0}.student-row-name{font-weight:700;font-size:.88rem;color:var(--charcoal)}.student-row-meta{font-size:.78rem;color:var(--muted);margin-left:auto}.student-row-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;padding:.2rem;transition:color .15s}.student-row-remove:hover{color:#DC2626}.add-student-row{display:flex;gap:.5rem;margin-top:.5rem}.add-student-btn{flex:1 1;padding:.65rem 1rem;background:var(--white);border:1.5px dashed rgba(245,158,11,.35);border-radius:10px;color:var(--mid);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .2s,color .2s}.add-student-btn:hover{border-color:var(--amber);color:var(--charcoal)}.student-name-input{flex:1 1;border:none;border-bottom:1.5px solid rgba(0,0,0,.12);padding:.3rem 0;font-size:.9rem;font-family:inherit;font-weight:600;color:var(--charcoal);background:transparent;border-radius:0}.student-name-input:focus{outline:none;border-bottom-color:var(--amber)}.student-name-input::placeholder{font-weight:400;color:var(--muted)}.mark-gdpr-notice{margin:1.5rem 0;padding:1rem 1.25rem;background:var(--yellow-light);border:1.5px solid rgba(245,158,11,.35);border-radius:12px}.mark-gdpr-text{font-size:.85rem;color:var(--mid);margin:0 0 .75rem;line-height:1.5}.mark-gdpr-label{display:flex;align-items:flex-start;gap:.6rem;font-size:.85rem;font-weight:600;color:var(--charcoal);cursor:pointer;line-height:1.4}.mark-gdpr-checkbox{margin-top:.15rem;accent-color:var(--amber);flex-shrink:0;width:16px;height:16px}.construction-shell{display:flex;min-height:calc(100vh - 68px);background:var(--cream);position:relative}.construction-main{flex:1 1;min-width:0;overflow-x:hidden;padding:1rem 2rem 2rem}.class-form .btn-amber,.construction-dashboard .btn-amber{width:auto;margin-top:0}.sidebar{width:260px;min-width:260px;background:var(--bg-sidebar);display:flex;flex-direction:column;flex-shrink:0;transition:width .22s cubic-bezier(.4,0,.2,1),min-width .22s cubic-bezier(.4,0,.2,1);position:-webkit-sticky;position:sticky;top:68px;height:calc(100vh - 68px);overflow:hidden;z-index:50;border-right:1px solid var(--sidebar-border);border-radius:0 20px 20px 0}.sidebar.collapsed{width:64px;min-width:64px;border-radius:0 16px 16px 0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 0 1.1rem;height:56px;border-bottom:1px solid var(--sidebar-border);flex-shrink:0;gap:.5rem}.sidebar.collapsed .sidebar-header{padding-left:0;justify-content:center}.sidebar-brand{font-family:var(--font-fraunces),"Fraunces",serif;font-weight:600;font-size:1.2rem;color:var(--text-primary);white-space:nowrap;overflow:hidden}.sidebar-toggle{background:none;border:none;color:var(--text-muted);font-size:1rem;line-height:1;cursor:pointer;padding:0;width:40px;height:56px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s}.sidebar-toggle:hover{color:var(--text-primary)}.sidebar.collapsed .sidebar-brand{display:none}.sidebar.collapsed .sidebar-toggle{width:56px}.sidebar-nav{display:flex;flex-direction:column;padding:1rem .75rem;gap:.4rem;background:var(--sidebar-nav-bg);flex:1 1;min-height:0;overflow-y:auto;scrollbar-gutter:stable}.sidebar-nav::-webkit-scrollbar{width:8px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(245,158,11,.45);border-radius:999px}.sidebar-nav:hover::-webkit-scrollbar-thumb{background:rgba(245,158,11,.7)}.sidebar-section{display:flex;align-items:center;gap:.85rem;width:100%;padding:.85rem 1rem;border:none;background:transparent;color:var(--sidebar-text);text-decoration:none;font-size:1rem;font-weight:600;font-family:var(--font-fraunces),"Fraunces",serif;white-space:nowrap;overflow:hidden;cursor:pointer;text-align:left;border-radius:14px;transition:background .15s,color .15s}.sidebar-section-icon{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#F5EFE6;border-radius:8px;transition:background .15s}.sidebar-section.active .sidebar-section-icon,.sidebar-section:hover .sidebar-section-icon{background:#EDE5D8}.sidebar-section-icon svg{width:18px;height:18px}.sidebar-icon{color:var(--sidebar-icon);transition:color .15s}.sidebar-icon-muted{color:var(--sidebar-icon-muted);transition:color .15s}.sidebar-section.active .sidebar-icon,.sidebar-section.active .sidebar-icon-muted,.sidebar-section:hover .sidebar-icon,.sidebar-section:hover .sidebar-icon-muted{color:inherit}.sidebar-section-label{flex:1 1}.sidebar-section-abbr{font-size:.7rem;font-weight:700;color:var(--sidebar-text)}.sidebar-section:hover{background:var(--sidebar-section-hover);color:var(--sidebar-text-hover)}.sidebar-section.active{background:#FDE7B0;color:#A16207;font-weight:700;box-shadow:0 1px 2px rgba(161,98,7,.08)}.sidebar-classes-section{display:flex;flex-direction:column}.sidebar-classes-section .sidebar-section{display:flex;align-items:center;padding-right:.5rem}.sidebar-classes-link{display:flex;align-items:center;gap:.65rem;flex:1 1;text-decoration:none;color:inherit;min-width:0}.sidebar-expand-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;padding:.3rem;margin-left:auto;border-radius:6px;cursor:pointer;color:#8B7355;transition:background .15s,color .15s}.sidebar-expand-btn:hover{background:rgba(139,115,85,.12);color:#5B4A3B}.sidebar-chevron{width:16px;height:16px;transition:transform .2s ease}.sidebar-chevron.expanded{transform:rotate(90deg)}.sidebar-classes-list{list-style:none;margin:0;padding:.25rem 0 .5rem;display:flex;flex-direction:column;gap:.15rem}.sidebar-class-item{display:block;padding:.4rem .9rem .4rem 2.6rem;font-size:.85rem;color:#6B5D4D;text-decoration:none;border-radius:10px;transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-class-item:hover{background:#FFF7E6;color:#7C5A10}.sidebar-class-item.active{background:#FEF3C7;color:#92400E;font-weight:600}.sidebar-tool-icon{margin-right:.4rem;font-size:.9rem}.sidebar-tools-grouped{padding-top:.1rem}.sidebar-tool-group,.sidebar-tools-grouped{display:flex;flex-direction:column}.sidebar-tool-group-header{display:flex;align-items:center;justify-content:space-between;padding:.3rem .6rem .2rem 1.2rem;cursor:pointer;border-radius:6px;transition:background .15s}.sidebar-tool-group-header:hover{background:#F5EFE6}.sidebar-tool-group-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#A08A72}.sidebar-tool-group-chevron{width:14px;height:14px;color:#A08A72;transition:transform .2s}.sidebar-tool-group-chevron.expanded{transform:rotate(90deg)}.sidebar-tool-group .sidebar-classes-list{padding:0}.sidebar-tool-group+.sidebar-tool-group{margin-top:.2rem}.sidebar.collapsed .sidebar-section{justify-content:center;padding-left:0;padding-right:0;gap:0}.sidebar.collapsed .sidebar-classes-link{justify-content:center;gap:0}.sidebar.collapsed .sidebar-section-abbr{display:none}.sidebar.collapsed .sidebar-classes-link[title],.sidebar.collapsed .sidebar-logout-btn[title],.sidebar.collapsed .sidebar-section[title]{position:relative}.sidebar.collapsed .sidebar-classes-link[title]:after,.sidebar.collapsed .sidebar-logout-btn[title]:after,.sidebar.collapsed .sidebar-section[title]:after{content:attr(title);position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--charcoal);color:var(--cream);padding:.4rem .75rem;border-radius:6px;font-size:.82rem;font-weight:600;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.15);pointer-events:none}.sidebar.collapsed .sidebar-classes-link[title]:before,.sidebar.collapsed .sidebar-logout-btn[title]:before,.sidebar.collapsed .sidebar-section[title]:before{content:"";position:absolute;left:calc(100% + 2px);top:50%;transform:translateY(-50%);border:5px solid transparent;border-right:5px solid var(--charcoal);opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;z-index:100}.sidebar.collapsed .sidebar-classes-link[title]:hover:after,.sidebar.collapsed .sidebar-classes-link[title]:hover:before,.sidebar.collapsed .sidebar-logout-btn[title]:hover:after,.sidebar.collapsed .sidebar-logout-btn[title]:hover:before,.sidebar.collapsed .sidebar-section[title]:hover:after,.sidebar.collapsed .sidebar-section[title]:hover:before{opacity:1;visibility:visible}.sidebar-footer{margin-top:auto;flex-shrink:0;border-top:1px solid #e8dcc7;padding:.75rem;display:flex;flex-direction:column;gap:.4rem}.sidebar-logout-btn{color:#8B7355;font-weight:500}.sidebar-logout-btn:hover{background:#FEF2F2;color:#B91C1C}.sidebar-burger{display:none;position:fixed;top:calc(68px + .75rem);left:.75rem;z-index:200;background:var(--bg-sidebar);color:var(--sidebar-text);border:1px solid var(--sidebar-border);border-radius:10px;padding:.45rem .65rem;font-size:1.1rem;line-height:1;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s}.sidebar-burger:hover{background:var(--sidebar-section-hover)}.sidebar-overlay{display:none}@media (max-width:768px){.construction-shell{min-height:calc(100vh - 68px)}.sidebar{position:fixed;top:68px;left:-240px;height:calc(100vh - 68px);width:220px!important;min-width:220px!important;transition:left .25s cubic-bezier(.4,0,.2,1);z-index:150;overflow:hidden;border-radius:0 20px 20px 0}.sidebar.mobile-open{left:0}.sidebar.collapsed{width:220px!important;min-width:220px!important}.sidebar.collapsed .sidebar-brand{display:block}.sidebar.collapsed .sidebar-header{padding-left:1.1rem;justify-content:space-between}.sidebar.collapsed .sidebar-toggle{width:40px}.sidebar.collapsed .sidebar-section{justify-content:flex-start;padding-left:.9rem;padding-right:.9rem}.sidebar-burger{display:flex;align-items:center;justify-content:center}.construction-shell:has(.sidebar.mobile-open) .sidebar-burger{display:none}.sidebar-overlay{display:block;position:fixed;inset:0;top:68px;background:rgba(28,25,23,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:140}.construction-main{padding:4.5rem 1.25rem 2rem}.sidebar-burger{min-width:48px;min-height:48px;font-size:1.4rem}.spec-field input[type=text],.spec-field select,.tool-field input,.tool-field select,.tool-field textarea{font-size:16px}.resource-card-actions{padding:0 .25rem;gap:.05rem}.resource-action{width:34px;height:34px}.toast{left:1rem;right:1rem;max-width:none}}.spec-locked{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap}.spec-locked-badges{display:flex;gap:.5rem;align-items:center;padding-bottom:.3rem}.spec-badge{display:inline-block;background:var(--pale);color:var(--charcoal);font-size:.82rem;font-weight:700;padding:.35rem .75rem;border-radius:8px;border:1px solid rgba(245,158,11,.15);white-space:nowrap}.spec-field-topic{flex:1 1;min-width:200px}.class-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.class-header-row h1{font-family:var(--font-fraunces),"Fraunces",serif!important;font-size:2rem;color:var(--charcoal)}.class-add-btn{flex-shrink:0;padding:.6rem 1.25rem;font-size:.9rem}.class-form{background:var(--white);border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.06);margin-bottom:1.5rem}.class-form-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1rem}.class-form-field label{display:block;font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem}.class-form-field input,.class-form-field select{width:100%;padding:.6rem .8rem;border:1.5px solid rgba(0,0,0,.12);border-radius:10px;font-size:.9rem;font-family:inherit;background:var(--white);transition:border-color .2s}.class-form-field input:focus,.class-form-field select:focus{outline:none;border-color:var(--amber)}.class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem}.class-card{position:relative;background:var(--white);border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:box-shadow .2s,transform .2s;overflow:hidden;animation:card-enter .35s ease both}.class-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.1);transform:translateY(-2px)}.class-grid .class-card:first-child{animation-delay:.05s}.class-grid .class-card:nth-child(2){animation-delay:.1s}.class-grid .class-card:nth-child(3){animation-delay:.15s}.class-grid .class-card:nth-child(4){animation-delay:.2s}.class-grid .class-card:nth-child(n+5){animation-delay:.25s}.class-card-link{display:block;padding:1.25rem;text-decoration:none;color:inherit}.class-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.class-card-header h3{font-size:1.05rem;font-weight:700;color:var(--charcoal);margin:0}.class-card-level{font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:100px;background:var(--pale);color:var(--amber);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.class-card-meta{display:flex;gap:.5rem;flex-wrap:wrap}.class-card-meta span{font-size:.82rem;color:var(--muted)}.class-card-delete{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--muted);font-size:.85rem;cursor:pointer;padding:.2rem .4rem;border-radius:4px;transition:color .15s,background .15s;opacity:0}.class-card .class-card-delete:focus,.class-card:hover .class-card-delete{opacity:1}@media (max-width:768px){.class-card .class-card-delete{opacity:.6}}.class-card-delete:hover{color:#DC2626;background:rgba(220,38,38,.08)}.class-card-confirm{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem .75rem;font-size:.82rem;color:var(--muted)}.class-confirm-no,.class-confirm-yes{background:none;border:1px solid rgba(0,0,0,.12);border-radius:6px;padding:.2rem .6rem;font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer}.class-confirm-yes{color:#DC2626;border-color:#FECACA}.class-confirm-yes:hover{background:#FEF2F2}.class-confirm-no:hover{background:var(--pale)}.class-empty{text-align:center;padding:4rem 2rem}.class-empty-icon{font-size:3rem;margin-bottom:1rem}.class-empty h2{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.4rem;color:var(--charcoal);margin-bottom:.5rem}.class-empty p{color:var(--muted);max-width:400px;margin:0 auto 1.5rem}.class-empty .btn-amber{display:inline-block;padding:.75rem 1.5rem}.class-detail-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.25rem}.class-detail-header h1{margin:0}.class-detail-badges{display:flex;gap:.4rem}.settings-section{background:var(--white);border-radius:16px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 12px rgba(0,0,0,.04)}.settings-section h2{font-family:var(--font-fraunces),"Fraunces",serif;font-size:1.2rem;color:var(--charcoal);margin-bottom:.25rem}.settings-section-desc{color:var(--muted);font-size:.9rem;margin-bottom:1rem}.settings-section-muted{opacity:.6}.theme-toggle{display:flex;gap:.5rem;flex-wrap:wrap}.theme-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--pale);border:2px solid transparent;border-radius:12px;font-size:.9rem;font-weight:600;color:var(--mid);cursor:pointer;transition:all .15s ease;font-family:inherit}.theme-toggle-btn:hover{background:var(--yellow-light);color:var(--text-on-accent)}.theme-toggle-btn.active{background:var(--amber);color:var(--text-on-accent);border-color:var(--orange)}.theme-toggle-icon{font-size:1.1rem}.theme-toggle-placeholder{height:48px;max-width:300px;width:100%;background:var(--pale);border-radius:12px}.theme-system-note{margin-top:.75rem;font-size:.85rem;color:var(--muted);font-style:italic}.storage-bar-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.5rem}.storage-label{font-size:.88rem;color:var(--mid)}.storage-pct{font-size:.82rem;font-weight:700;color:var(--charcoal)}.storage-bar-track{width:100%;height:8px;background:var(--pale);border-radius:99px;overflow:hidden}.storage-bar-fill{height:100%;background:var(--amber);border-radius:99px;transition:width .4s ease}.storage-bar-fill--warn{background:var(--coral)}.storage-warning{margin-top:.5rem;font-size:.82rem;color:var(--coral);font-weight:600}.storage-bar-placeholder{height:8px;background:var(--pale);border-radius:99px;width:100%}.document-editor{margin-top:2rem;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius);background:var(--white);overflow:hidden}.editor-toolbar{display:flex;align-items:center;gap:2px;padding:.5rem .75rem;border-bottom:1px solid rgba(0,0,0,.06);background:var(--pale);flex-wrap:wrap}.toolbar-btn{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:2rem;padding:0 .4rem;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--mid);font-size:.85rem;cursor:pointer;transition:background .15s ease,color .15s ease}.toolbar-btn:hover:not(:disabled){background:rgba(0,0,0,.06);color:var(--charcoal)}.toolbar-btn--active{background:rgba(245,158,11,.15);color:var(--amber);border-color:rgba(245,158,11,.3)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn--export{font-size:.8rem;font-weight:600;color:var(--charcoal);border-color:rgba(0,0,0,.12)}.toolbar-btn--export:hover:not(:disabled){background:var(--amber);color:var(--charcoal);border-color:var(--amber)}.toolbar-divider{width:1px;height:1.25rem;background:rgba(0,0,0,.1);margin:0 4px}.toolbar-spacer{flex:1 1}.editor-body{padding:1.5rem 2rem;min-height:200px;max-height:70vh;overflow-y:auto}.editor-body--streaming .ProseMirror{caret-color:var(--amber)}.document-editor-content{outline:none;font-size:.95rem;line-height:1.7;color:var(--charcoal)}.document-editor-content h1{font-size:1.5rem;font-weight:700;margin:1.2rem 0 .6rem}.document-editor-content h2{font-size:1.2rem;font-weight:600;margin:1rem 0 .5rem}.document-editor-content h3{font-size:1rem;font-weight:600;margin:.9rem 0 .4rem}.document-editor-content p{margin:0 0 .75rem}.document-editor-content ol,.document-editor-content ul{padding-left:1.5rem;margin-bottom:.75rem}.document-editor-content li{margin-bottom:.25rem}.document-editor-content strong{font-weight:700}.document-editor-content em{font-style:italic}.document-editor-content u{text-decoration:underline}.document-editor-content .slide-image{display:block;max-width:100%;height:auto;margin:1.5rem auto;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.document-editor-content figure.slide-image{margin:1.5rem 0;text-align:center}.document-editor-content figure.slide-image img{max-width:100%;height:auto;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.document-editor-content figure.slide-image figcaption{margin-top:.5rem;font-size:.85rem;color:var(--muted);font-style:italic}.document-editor-content figure.standalone-image{margin:0;text-align:center}.document-editor-content figure.standalone-image img{max-width:100%;height:auto;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.08)}.document-editor-content p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--muted);pointer-events:none;float:left;height:0}.tool-abort-btn{margin-top:.5rem;padding:.4rem 1rem;border:1px solid rgba(0,0,0,.15);border-radius:8px;background:transparent;color:var(--mid);font-size:.85rem;cursor:pointer}.tool-abort-btn:hover{background:rgba(0,0,0,.05)}@media print{.editor-toolbar,.tool-error,.tool-form,.tool-loading,.tool-page-header{display:none!important}.document-editor{border:none;margin:0}.editor-body{max-height:none;overflow:visible;padding:0}}.migration-banner{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:var(--yellow-light);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius);margin-bottom:1.25rem;font-size:.9rem;flex-wrap:wrap}.migration-banner--success{background:#d1fae5;border-color:rgba(16,185,129,.3);color:#065f46}.migration-banner p{margin:0;color:var(--charcoal)}.migration-banner-error{color:var(--coral)!important;font-size:.85rem}.migration-banner-actions{display:flex;gap:.5rem;align-items:center}.migration-banner-import{font-size:.85rem;padding:.35rem .9rem}.migration-banner-skip{background:transparent;border:none;color:var(--muted);font-size:.85rem;cursor:pointer;text-decoration:underline}.sidebar-user-btn{cursor:default}.sidebar-user-btn .cl-userButtonBox{gap:0}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}