*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;color:#1A1825;background:#fff;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{text-decoration:none}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
[data-anim]{opacity:0;transform:translateY(32px);transition:opacity 0.65s cubic-bezier(0.22,1,0.36,1),transform 0.65s cubic-bezier(0.22,1,0.36,1)}
[data-anim="fade"]{transform:none;transition:opacity 0.65s ease}
[data-anim].in-view{opacity:1;transform:translateY(0)}
[data-anim][data-delay="1"]{transition-delay:0.1s}
[data-anim][data-delay="2"]{transition-delay:0.2s}
[data-anim][data-delay="3"]{transition-delay:0.3s}
[data-anim][data-delay="4"]{transition-delay:0.4s}
[data-anim][data-delay="5"]{transition-delay:0.5s}
/* Hero animates on load */
.hero-animate{animation:fadeUp 0.8s cubic-bezier(0.22,1,0.36,1) both}
/* Float */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes float-alt{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes check-float{0%,100%{transform:perspective(900px) rotateY(-10deg) translateY(0)}50%{transform:perspective(900px) rotateY(-10deg) translateY(-7px)}}
@keyframes wiggle{0%,100%{transform:perspective(900px) rotateY(-10deg) rotate(0deg)}20%{transform:perspective(900px) rotateY(-10deg) rotate(-0.7deg)}40%{transform:perspective(900px) rotateY(-10deg) rotate(0.7deg)}60%{transform:perspective(900px) rotateY(-10deg) rotate(-0.4deg)}80%{transform:perspective(900px) rotateY(-10deg) rotate(0.2deg)}}
.hero-app{animation:float 5s ease-in-out infinite}
.hero-ext{animation:float-alt 4.2s ease-in-out 0.6s infinite}
.claude-dk{animation:float 6s ease-in-out 1s infinite}
.beta-check{animation:check-float 5s ease-in-out infinite;transform-origin:center center}
.beta-check.wiggling{animation:wiggle 0.35s ease-in-out}

/* NAV */
.nav{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:56px;border-bottom:0.5px solid #e8e4f0;background:#fff;position:sticky;top:0;z-index:10}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:32px;width:auto;display:block}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:14px;color:#6E6A7C;font-weight:400}
.nav-links a:hover{color:#1A1825}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-login{font-size:14px;color:#6E6A7C;font-weight:400;padding-right:4px}
.nav-login:hover{color:#1A1825}
.nav-cta{background:#6B5CE7;color:#fff;font-size:14px;font-weight:500;padding:6px 14px;border-radius:6px}
.nav-cta:hover{background:#5245C8}
.nav-dd{position:relative}
.nav-dd-trigger{font-size:14px;color:#6E6A7C;font-weight:400;background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;gap:4px;font-family:inherit}
.nav-dd-trigger:hover{color:#1A1825}
.nav-dd-trigger svg{transition:transform .15s}
.nav-dd:hover .nav-dd-trigger svg,.nav-dd-trigger[aria-expanded="true"] svg{transform:rotate(180deg)}
.nav-dd-menu{display:none;position:absolute;top:100%;left:-16px;z-index:20;padding-top:10px}
.nav-dd-menu.is-open{display:block}
.nav-dd-menu-inner{background:#fff;border:0.5px solid #e8e4f0;border-radius:10px;padding:6px;box-shadow:0 8px 24px rgba(0,0,0,0.08);display:grid;grid-template-columns:1fr 1fr;min-width:520px}
.nav-dd-menu-inner--sm{grid-template-columns:1fr;min-width:0;width:300px}
.nav-dd:hover .nav-dd-menu{display:block}
.nav-dd-menu a{font-size:13px;color:#6E6A7C;padding:7px 10px;border-radius:6px;font-weight:400;display:flex;align-items:flex-start;gap:8px}
.nav-dd-menu a:hover{background:#F5F3FF;color:#6B5CE7}
.nav-dd-menu a i{width:12px;height:12px;flex-shrink:0;color:#6f6c7a;margin-top:3px}
.nav-dd-menu a:hover i{color:#6B5CE7}
.dd-label{display:block;font-size:13px;font-weight:500;color:#3D3952;line-height:1.3}
.dd-desc{display:block;font-size:11px;color:#6f6c7a;margin-top:1px;line-height:1.3}
.nav-dd-menu a:hover .dd-label{color:#5B4DD4}

/* TRUST BAR — wide logo row (pricing, extensions, …) */
.trust-static-wrap{margin-top:32px;margin-bottom:100px;padding-top:16px;border-top:0.5px solid #e8e4f0;width:min(1520px,calc(100vw - 48px));position:relative;left:50%;transform:translateX(-50%);box-sizing:border-box}
.trust-static{text-align:center}
.trust-static-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#6f6c7a;margin-bottom:10px}
.trust-logos{display:flex;align-items:center;justify-content:center;gap:40px 36px;flex-wrap:wrap}
.trust-logos img{height:44px;width:auto;object-fit:contain;opacity:0.5;filter:grayscale(100%)}

/* HERO */
.hero{display:grid;grid-template-columns:2fr 3fr;gap:48px;padding:40px 32px 96px;align-items:center;min-height:80vh;max-width:1280px;margin:0 auto}
.tag{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:#5B4DD4;background:#EEE9FF;border:0.5px solid #C5B8F5;padding:3px 10px;border-radius:20px;margin-bottom:16px}
.tag-dot{width:5px;height:5px;border-radius:50%;background:#6B5CE7;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.2}}
h1{font-family:'Instrument Serif',Georgia,serif;font-size:clamp(44px,5vw,64px);line-height:1.07;letter-spacing:-.02em;font-weight:400;color:#1A1825;margin-bottom:12px}
h1 em{font-style:italic;color:#7B7890}
.hero-sub{font-size:16px;line-height:1.72;color:#3D3952;max-width:480px;margin-bottom:22px;font-weight:400}
.cta-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.btn-primary{background:#6B5CE7;color:#fff;font-size:12px;font-weight:500;padding:10px 18px;border-radius:8px;display:inline-flex;align-items:center;gap:5px;box-shadow:0 6px 20px rgba(107,92,231,0.28)}
.btn-primary:hover{background:#5245C8}
.btn-ghost{font-size:12px;color:#6E6A7C;font-weight:400}
.fine{font-size:10px;color:#6f6c7a;font-weight:400}

/* HERO VISUAL */
.hero-visual{position:relative;display:flex;align-items:flex-start;padding-bottom:48px;transition:transform 0.5s cubic-bezier(0.22,1,0.36,1);cursor:default;transform-origin:center center}
.hero-visual:hover{transform:scale(1.02)}
.hero-app{width:100%;border-radius:12px;display:block;filter:drop-shadow(0 24px 48px rgba(0,0,0,0.12));transition:transform 0.5s cubic-bezier(0.22,1,0.36,1)}
.hero-visual:hover .hero-app{transform:scale(1.015)}
.hero-ext{position:absolute;bottom:0;left:-32px;width:32%;border-radius:12px;filter:drop-shadow(0 24px 48px rgba(0,0,0,0.12));transition:transform 0.5s cubic-bezier(0.22,1,0.36,1)}
.hero-visual:hover .hero-ext{transform:scale(1.03) translateY(-6px)}
/* CHECKLIST (shared) */
.chk-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px}
.chk-c{width:16px;height:16px;background:#EEE9FF;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.chk-c svg{width:8px;height:8px}
.chk-t{font-size:11.5px;color:#3D3952;line-height:1.45;font-weight:400}

/* LOGO MARQUEE */
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-section{background:#fff;padding:24px 0;overflow:hidden}
.marquee-eyebrow{font-size:9.5px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#6f6c7a;text-align:center;margin-bottom:16px;display:flex;align-items:center;justify-content:center;gap:10px}
.marquee-pause-btn{background:none;border:0.5px solid #e8e4f0;border-radius:4px;padding:3px 6px;cursor:pointer;color:#6f6c7a;display:inline-flex;align-items:center;line-height:1}
.marquee-pause-btn:hover{color:#6B5CE7;border-color:#C5B8F5}
.marquee-outer{overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent,black 80px,black calc(100% - 80px),transparent);mask-image:linear-gradient(to right,transparent,black 80px,black calc(100% - 80px),transparent)}
.marquee-track{display:flex;align-items:center;gap:48px;width:max-content;animation:scroll 40s linear infinite}
.marquee-track img{height:48px;width:auto;opacity:0.5;filter:grayscale(1)}

/* AUDIENCE STRIP */
.aud-band{background:#F5F3FF;border-bottom:0.5px solid #e8e4f0;padding:96px 32px;min-height:80vh;display:flex;flex-direction:column;justify-content:center}
.aud-intro{max-width:1280px;margin:0 auto 32px;width:100%}
.aud-intro h2{margin-bottom:0}
.aud-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;max-width:1280px;margin:0 auto;width:100%}
.aud-card{background:#fff;border:0.5px solid #e8e4f0;border-radius:8px;padding:16px 18px 16px 22px;position:relative;overflow:hidden}
.aud-accent{position:absolute;left:0;top:0;bottom:0;width:3px}
.aud-seg{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#5B4DD4;margin-bottom:6px}
h3.aud-who{font-family:'Inter',sans-serif;font-size:16px;font-weight:600;color:#1A1825;margin-bottom:6px;letter-spacing:0;line-height:1.3}
.aud-hook{font-size:12px;color:#6E6A7C;font-style:italic;line-height:1.45;font-weight:400}
/* For Classrooms — "Who it's for" detail cards (roman body + icon bullets) */
.aud-band--edu-cards .aud-card-body{padding-top:2px}
.aud-band--edu-cards .aud-lead{margin:0 0 14px;font-size:13.5px;line-height:1.65;color:#6E6A7C;font-weight:400}
.aud-band--edu-cards .aud-points{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.aud-band--edu-cards .aud-point{display:flex;gap:10px;align-items:flex-start}
.aud-band--edu-cards .aud-point i,.aud-band--edu-cards .aud-point svg{width:16px;height:16px;min-width:16px;min-height:16px;color:#6B5CE7;margin-top:3px;stroke-width:1.5;flex-shrink:0}
.aud-band--edu-cards .aud-point-body{min-width:0}
.aud-band--edu-cards .aud-point-title{display:block;font-size:13px;font-weight:600;color:#1A1825;line-height:1.35;margin-bottom:3px}
.aud-band--edu-cards .aud-point-desc{display:block;font-size:12.5px;line-height:1.55;color:#6E6A7C;font-weight:400}
.aud-cta{display:inline-block;font-size:11px;font-weight:500;color:#6B5CE7;margin-top:10px}
.aud-cta:hover{color:#5245C8}
.aud-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.aud-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.aud-desc{font-size:12px;color:#6E6A7C;line-height:1.6;margin-top:8px}
.aud-works{margin-top:14px;padding-top:12px;border-top:0.5px solid #e8e4f0}
.aud-works-label{display:block;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#5B4DD4;margin-bottom:3px}
.aud-works-list{font-size:11px;color:#6f6c7a;line-height:1.45}

/* SECTIONS */
.sec-center{padding:112px 32px;text-align:center;max-width:1280px;margin:0 auto;min-height:80vh;display:flex;flex-direction:column;justify-content:center}
.sec-band{background:#F5F3FF;border-top:0.5px solid #e8e4f0;border-bottom:0.5px solid #e8e4f0;padding:96px 32px;min-height:80vh;display:flex;align-items:center}
.sec-band-in{max-width:1280px;margin:0 auto;width:100%}
.sec{padding:96px 32px;max-width:1280px;margin:0 auto;min-height:80vh;display:flex;flex-direction:column;justify-content:center}
.eyebrow{font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#5B4DD4;margin-bottom:10px}
h2{font-family:'Instrument Serif',Georgia,serif;font-size:clamp(32px,3.5vw,48px);line-height:1.1;letter-spacing:-.015em;font-weight:400;color:#1A1825;margin-bottom:8px}
h2 em{font-style:italic;color:#7B7890}
h3{font-family:'Instrument Serif',Georgia,serif;font-size:clamp(22px,2.5vw,32px);line-height:1.2;letter-spacing:-.01em;font-weight:400;color:#1A1825;margin-bottom:8px}
.section-sub{font-size:13.5px;line-height:1.72;color:#3D3952;font-weight:400}
.section-sub-center{font-size:13.5px;line-height:1.72;color:#3D3952;max-width:540px;margin:0 auto 40px;font-weight:400}

/* HOW IT WORKS — alternating rows */
.steps-list{display:flex;flex-direction:column;gap:180px;margin-top:64px;text-align:left}
.step-row{display:flex;gap:64px;align-items:center}
.step-row:nth-child(even){flex-direction:row-reverse}
.step-row-text{flex:1;display:flex;gap:20px;align-items:flex-start}
.step-icon{display:flex;align-items:flex-start;flex-shrink:0;color:#6B5CE7;padding-top:3px}
.step-icon svg{width:24px;height:24px;stroke-width:1.5}
.step-text-block{flex:1}
.step-t{font-size:20px;font-weight:600;color:#1A1825;margin-bottom:10px}
.step-b{font-size:14px;color:#6E6A7C;line-height:1.72;font-weight:400}
.step-placeholder{flex:1;aspect-ratio:3/2;background:#F5F3FF;border-radius:12px;border:0.5px solid #e8e4f0;transition:scale 0.4s cubic-bezier(0.22,1,0.36,1)}
.step-placeholder:hover{scale:1.02}
.step-placeholder img{transition:scale 0.4s cubic-bezier(0.22,1,0.36,1),translate 0.4s cubic-bezier(0.22,1,0.36,1)}
.step-placeholder:hover img{scale:1.05}
/* Step layer fan — shared transition */
.layer-back,.layer-mid,.layer-front{transition:transform 0.4s cubic-bezier(0.22,1,0.36,1)}
/* capture-widget — base panel positions (CSS owns this so hover can override) */
.capture-widget .layer-back{transform:translate(0%,8%)}
.capture-widget .layer-mid{transform:translate(calc(-42% - 30px),12%)}
.capture-widget .layer-front{transform:translate(calc(42% + 30px),-12%)}
/* capture-widget — hover fan */
.capture-widget:hover .layer-back{transform:translate(0%,calc(8% + 20px))}
.capture-widget:hover .layer-mid{transform:translate(calc(-42% - 58px),12%)}
.capture-widget:hover .layer-front{transform:translate(calc(42% + 58px),-12%)}
/* Step 2 (annotate) — base state (positioned by top/left, not transform) */
.step-row:nth-child(2) .step-placeholder .layer-back,.step-row:nth-child(2) .step-placeholder .layer-mid,.step-row:nth-child(2) .step-placeholder .layer-front{transform:translate(0,0)}
/* Step 2 (annotate) — hover fan */
.step-row:nth-child(2) .step-placeholder:hover .layer-back{transform:translate(16px,-8px)}
.step-row:nth-child(2) .step-placeholder:hover .layer-mid{transform:translate(-10px,-6px)}
.step-row:nth-child(2) .step-placeholder:hover .layer-front{transform:translate(-4px,14px)}

/* STATS + QUOTE */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:64px}
.stat-cell{background:#fff;border:0.5px solid #e8e4f0;border-radius:10px;padding:24px}
.stat-num{font-family:'Instrument Serif',serif;font-style:italic;font-size:28px;color:#6B5CE7;line-height:1;margin-bottom:10px}
.stat-lbl{font-size:13px;font-weight:600;color:#1A1825;display:block;margin-bottom:4px}
.stat-sub{font-size:12px;color:#6E6A7C;line-height:1.5;font-weight:400}

/* QUOTE + TIKTOK */
.quote-two{display:grid;grid-template-columns:2fr 3fr;gap:48px;align-items:center}
.tiktok-wrap{border-radius:16px;overflow:hidden;max-width:340px;margin:0 auto}
.tiktok-wrap iframe{display:block}
.q-card{background:#fff;border:0.5px solid #e8e4f0;border-radius:12px;overflow:hidden}
.q-top{height:3px;background:#6B5CE7}
.q-body{padding:22px 24px}
.q-text{font-style:italic;color:#1A1825;margin-bottom:18px;line-height:1.6}
.q-attr{display:flex;align-items:center;gap:8px}
.q-av{width:28px;height:28px;border-radius:50%;background:#6E6A7C;color:#fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.q-name{font-size:11.5px;font-weight:600;color:#1A1825}
.q-role{font-size:10.5px;color:#6f6c7a;font-weight:400}

/* AI SECTION */
.ai-two{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@keyframes pulse-ring{0%{transform:scale(1);opacity:0.5}100%{transform:scale(1.7);opacity:0}}
.ai-pulse{position:absolute;width:67%;aspect-ratio:1;border-radius:50%;background:#EEE9FF;animation:pulse-ring 4.5s ease-out infinite;z-index:0;pointer-events:none}
.chk-list{display:flex;flex-direction:column;gap:8px;margin-top:18px}
.ai-status-row{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.ai-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;padding:4px 10px;border-radius:20px;border:0.5px solid}
.ai-pill-dot{width:5px;height:5px;border-radius:50%}

/* CLAUDE DARK PANEL */
.claude-dk{background:#1F1F1E;border-radius:12px;overflow:hidden}
.claude-top{background:#1F1F1E;padding:10px 16px 8px;display:flex;align-items:center;gap:8px;border-bottom:0.5px solid rgba(255,255,255,0.06)}
.c-dots{display:flex;gap:5px}
.c-dot{width:9px;height:9px;border-radius:50%}
.claude-body{padding:16px}
.user-bub{background:rgba(255,255,255,0.06);border:0.5px solid rgba(255,255,255,0.1);border-radius:8px;padding:10px 14px;margin-bottom:10px}
.user-txt{font-size:11px;line-height:1.6;color:rgba(255,255,255,0.65);font-weight:400}
.resp-bub{background:#2C2C2B;border:0.5px solid #2C2C2B;border-radius:8px;padding:10px 14px}
.claude-lbl{font-size:8.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#CC7C5E;margin-bottom:7px}
.resp-txt{font-size:11px;line-height:1.65;color:rgba(255,255,255,0.8);font-weight:400}
.ai-srcs{margin-top:10px;padding-top:10px;border-top:0.5px solid rgba(255,255,255,0.08);display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.ai-src-l{font-size:9px;color:rgba(255,255,255,0.28);font-weight:400}
.ai-tag{font-size:9px;background:rgba(255,255,255,0.07);border:0.5px solid rgba(255,255,255,0.1);border-radius:4px;padding:2px 7px;color:rgba(255,255,255,0.4);font-weight:400}

/* ACTIVITY LOG */
.act-two{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.act-card{background:#fff;border:0.5px solid #e8e4f0;border-radius:12px;overflow:hidden}
.act-hd{padding:12px 18px;border-bottom:0.5px solid #e8e4f0;background:#fff;display:flex;align-items:center;justify-content:space-between}
.act-ht{font-size:12.5px;font-weight:600;color:#1A1825}
.act-hs{font-size:10.5px;color:#6f6c7a;margin-top:1px;font-weight:400}
.act-ex{font-size:11px;font-weight:500;color:#6B5CE7}
.act-sec{padding:7px 18px 3px;font-size:9.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#6f6c7a;border-top:0.5px solid #f0eeff}
.act-sec:first-of-type{border-top:none}
.act-r{display:flex;gap:10px;align-items:flex-start;padding:9px 18px;border-bottom:0.5px solid #f8f6ff}
.act-r:last-child{border-bottom:none}
.act-icon{width:24px;height:24px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.act-tx{font-size:11.5px;color:#3D3952;line-height:1.45;font-weight:400}
.act-tx strong{color:#1A1825;font-weight:600}
.act-tx em{font-style:normal;color:#5B4DD4;font-weight:400}
.act-time{font-size:10px;color:#6f6c7a;margin-top:2px;font-weight:400}

/* EXTENSIONS / BETA CTA */
.ext-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:28px}
.beta-card{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;background:#F5F3FF;border:0.5px solid #C5B8F5;border-radius:16px;padding:56px 64px}
.beta-right{display:flex;justify-content:center}
.beta-badge{background:#fff;border:0.5px solid #e8e4f0;border-radius:12px;padding:32px 36px;text-align:center;box-shadow:0 8px 32px rgba(107,92,231,0.08)}
.ext-card{border:0.5px solid #e8e4f0;border-radius:8px;padding:14px 16px}
.ext-card.live{background:#EEE9FF;border-color:#C5B8F5}
.ext-status{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:500;margin-bottom:8px}
.ext-dot{width:5px;height:5px;border-radius:50%}
.ext-title{font-size:12.5px;font-weight:600;color:#1A1825;margin-bottom:5px}
.ext-body{font-size:11px;color:#6E6A7C;line-height:1.5;margin-bottom:10px;font-weight:400}
.ext-cta{font-size:11px;font-weight:500;color:#5B4DD4}

/* BOTTOM CTA */
.cta-dark{background:#1A1825;padding:128px 32px;text-align:center;min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center}
.cta-dark h2{color:rgba(255,255,255,0.92)}
.cta-dark h2 em{color:rgba(255,255,255,0.5)}
.cta-s{font-size:13px;color:rgba(255,255,255,0.6);max-width:420px;margin:12px auto 24px;line-height:1.72;font-weight:400}
.cta-btn{display:inline-block;background:#6B5CE7;color:#fff;font-size:13px;font-weight:500;padding:10px 24px;border-radius:8px;box-shadow:0 6px 24px rgba(107,92,231,0.4)}
.cta-nt{margin-top:14px;font-size:10px;color:rgba(255,255,255,0.5);font-style:italic;font-weight:400}

/* FOOTER */
footer{background:#1A1825;border-top:0.5px solid rgba(255,255,255,0.06);padding:40px 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.ft-left{display:flex;align-items:center;gap:24px}
.ft-legal{display:flex;gap:20px;align-items:center}
.ft-legal a,.ft-legal span{font-size:10.5px;color:rgba(255,255,255,0.7);font-weight:400}
.ft-legal a:hover{color:rgba(255,255,255,0.9)}
.ft-legal-sep{width:1px;height:10px;background:rgba(255,255,255,0.2)}
.ft-logo img{height:28px;width:auto;display:block;opacity:0.55}
.ft-links{display:flex;gap:20px}
.ft-links a{font-size:11px;color:rgba(255,255,255,0.7);font-weight:400}
.ft-links a:hover{color:rgba(255,255,255,0.9)}

/* FOCUS STATES — WCAG 2.1 */
:focus-visible{outline:2px solid #6B5CE7;outline-offset:2px;border-radius:2px}
.cta-dark :focus-visible{outline-color:#A99CF0}

/* REDUCED MOTION */
.marquee-outer:hover .marquee-track{animation-play-state:paused}
.marquee-track.is-paused{animation-play-state:paused}
@media(prefers-reduced-motion:reduce){.tag-dot{animation:none}.marquee-track{animation:none}}

/* SKIP LINK */
.skip-link{position:absolute;top:-40px;left:0;background:#6B5CE7;color:#fff;padding:8px 16px;z-index:100;font-size:13px;font-weight:500}
.skip-link:focus{top:0}

/* OUTCOME ROWS (For Educators + reusable) */
.outcome-list{display:flex;flex-direction:column;gap:96px;margin-top:64px;text-align:left}
.outcome-row{display:flex;gap:64px;align-items:center}
.outcome-row:nth-child(even){flex-direction:row-reverse}
/* Force copy left / visual right (overrides nth-child when needed, e.g. library + Google mock) */
.outcome-row.outcome-row--visual-end{flex-direction:row}
.outcome-row.outcome-row--visual-end .outcome-body{order:1}
.outcome-row.outcome-row--visual-end .outcome-visual-slot{order:2}
.outcome-visual-slot{flex:1;min-width:0;display:flex;align-items:center;justify-content:flex-end}
/* hero-visual embeds: absolute inner mock yields ~0 intrinsic width without explicit width */
.outcome-visual-slot>.hero-visual,.insight-visual-slot>.hero-visual{width:100%;max-width:100%;flex:1 1 auto;min-width:240px}
.hero>.academic-integrity-hero{width:100%;min-width:0;overflow:visible}
/* Academic integrity hero: single canvas, %-positioned layers (no vw on offsets — avoids gallery column push-off) */
/* Padding vars: abspos children use the padding box as origin, so to overhang the canvas border you must offset by at least these values (see .aih-google). */
.academic-integrity-hero .aih-canvas{position:relative;width:100%;aspect-ratio:3/2;min-height:260px;--aih-pt:8px;--aih-pr:40px;--aih-pb:72px;--aih-pl:32px;--aih-mock-drop:0 18px 42px rgba(0,0,0,0.13);padding:var(--aih-pt) var(--aih-pr) var(--aih-pb) var(--aih-pl);box-sizing:border-box;isolation:isolate;overflow:visible;--aih-panel-width:min(60%,600px)}
/* Lavender mat: centered, narrower/shorter than canvas, strict 3:2 (widgets stay above via z-index). */
.academic-integrity-hero .aih-canvas::before{content:"";position:absolute;z-index:0;left:50%;top:50%;transform:translate(-50%,-50%);width:44%;aspect-ratio:3/2;height:auto;box-sizing:border-box;background:#F5F3FF;border:0.5px solid #e8e4f0;border-radius:12px;box-shadow:0 8px 28px rgba(107,92,231,0.08);pointer-events:none}
.academic-integrity-hero .aih-google{position:absolute;left:calc(-1 * var(--aih-pl) + 10px);bottom:calc(-1 * var(--aih-pb) - 6px);top:auto;width:var(--aih-panel-width);max-width:100%;z-index:1;animation:float 5s ease-in-out infinite}
.academic-integrity-hero .aih-google,.academic-integrity-hero .aih-browser,.academic-integrity-hero .aih-activity{filter:drop-shadow(var(--aih-mock-drop))}
/* Pass-through wrapper — SERP is only the white inner card (no lavender plate) */
.academic-integrity-hero .aih-google-frame{background:transparent;border:none;padding:0;width:100%;box-sizing:border-box;position:relative;overflow:visible}
.academic-integrity-hero .aih-google-inner{position:relative;width:100%;left:auto;top:auto;transform:none;border-radius:10px;overflow:visible;background:#fff;box-shadow:none;font-family:arial,sans-serif}
.academic-integrity-hero .aih-browser{position:absolute;left:26%;bottom:calc(12% - 68px);width:var(--aih-panel-width);max-width:100%;z-index:2;animation:float-alt 4.2s ease-in-out 0.5s infinite}
.academic-integrity-hero .aih-browser>div:first-child{box-shadow:none!important}
.academic-integrity-hero .aih-activity{position:absolute;top:calc(-1 * var(--aih-pt) - 28px);right:calc(-1 * var(--aih-pr) - 28px);width:var(--aih-panel-width);max-width:100%;z-index:3;animation:float-alt 4.6s ease-in-out 0.2s infinite}
.academic-integrity-hero .aih-activity-inner{position:relative;width:100%;padding-right:24px;padding-bottom:20px}
.academic-integrity-hero .aih-insight{position:absolute;bottom:-10px;right:-18px;z-index:4;background:#fff;border:0.5px solid #C5B8F5;border-radius:12px;padding:16px 20px;box-shadow:0 12px 40px rgba(107,92,231,0.2);min-width:160px;text-align:center}
.insight-visual-slot{display:flex;align-items:center;justify-content:center;min-width:0}
.outcome-body{flex:0 0 42%;min-width:0;padding:20px}
.outcome-num{font-family:'Instrument Serif',serif;font-style:italic;font-size:52px;color:#e8e4f0;line-height:1;margin-bottom:6px}
.outcome-title{font-size:21px;font-weight:600;color:#1A1825;margin-bottom:10px;letter-spacing:-.01em}
.outcome-p{font-size:14px;color:#6E6A7C;line-height:1.72;margin-bottom:14px}
.outcome-mock{flex:1;min-width:0;aspect-ratio:4/3;background:#F5F3FF;border:0.5px solid #e8e4f0;border-radius:12px;overflow:visible;position:relative;box-shadow:0 12px 40px rgba(107,92,231,0.14);transition:scale 0.4s cubic-bezier(0.22,1,0.36,1)}
.outcome-mock:hover{scale:1.02}
.outcome-mock-inner{position:absolute;width:88%;top:50%;left:50%;transform:translate(-50%,-46%);border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 16px 40px rgba(0,0,0,0.12);display:flex;flex-direction:column}

/* FEATURE LIST ITEMS */
.feat-list{display:flex;flex-direction:column;gap:14px;margin-top:22px}
.feat-item{display:flex;gap:14px;align-items:flex-start}
.feat-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#6B5CE7;margin-top:3px}
.feat-icon i,.feat-icon svg{width:15px;height:15px;min-width:15px;min-height:15px;stroke-width:1.5}
.feat-title{font-size:14px;font-weight:600;color:#1A1825;margin-bottom:2px}
.feat-desc{font-size:14px;color:#6E6A7C;line-height:1.72}

/* LABELED FEATURE ITEMS (bold label + description inline) */
.feat-label-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}
.feat-label-item{font-size:13.5px;line-height:1.65;color:#6E6A7C}
.feat-label-item strong{color:#1A1825;font-weight:600}

/* QUOTE GRID */
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px}
.quote-col{display:flex;flex-direction:column;gap:16px}

/* SEGMENT NOTES */
.seg-note{font-size:11.5px;color:#6f6c7a;margin-top:18px;font-style:italic}
.seg-note a{color:#5B4DD4;font-style:normal}

/* TWO-COL SECTION GRID */
.sec-two{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;width:100%}

/* TESTIMONIAL CAROUSEL */
.t-carousel{position:relative;display:flex;align-items:center;gap:20px;margin-top:40px;max-width:1080px;margin-left:auto;margin-right:auto}
.t-carousel-wrap{flex:1;overflow:hidden}
.t-carousel-track{display:flex;transition:transform 0.45s cubic-bezier(0.22,1,0.36,1)}
.t-carousel-track .q-card{flex:0 0 100%;min-width:0}
.t-carousel-btn{width:40px;height:40px;border-radius:50%;background:#fff;border:0.5px solid #e8e4f0;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:#6E6A7C;transition:background .15s,border-color .15s,color .15s}
.t-carousel-btn:hover{background:#F5F3FF;border-color:#C5B8F5;color:#6B5CE7}
.t-carousel-btn i{width:16px;height:16px}
.t-carousel-dots{display:flex;gap:6px;justify-content:center;margin-top:20px}
.t-carousel-dot{width:6px;height:6px;border-radius:3px;background:#e8e4f0;border:none;cursor:pointer;padding:0;transition:background .2s,width .2s}
.t-carousel-dot.active{background:#6B5CE7;width:20px}

/* OUTCOME LIST ITEMS */
.outcome-item{display:flex;gap:10px;align-items:flex-start}
.outcome-item i,.outcome-item svg{width:15px;height:15px;min-width:15px;min-height:15px;color:#6B5CE7;flex-shrink:0;margin-top:3px;stroke-width:1.5}
.outcome-item-text{font-size:14px;color:#6E6A7C;line-height:1.72}

/* JOURNEY DIAGRAM */
.journey-step{border-radius:8px;padding:13px 6px;text-align:center;font-size:11px;font-weight:600;line-height:1.4;min-height:52px;display:flex;align-items:center;justify-content:center}
.step-bookend{background:transparent;border:1.5px solid #C5B8F5;color:#6f6c7a}
.step-active,.step-light,.step-edu,.step-edu-hi{background:#EEE9FF;border:0.5px solid #C5B8F5;color:#5B4DD4}

/* MOBILE NAV */
.nav-hamburger{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;color:#1a1523;margin-left:auto;padding:0;flex-shrink:0}
.nav-hamburger svg{width:22px;height:22px}
.nav-mobile{display:none;position:fixed;inset:56px 0 0 0;background:#fff;z-index:200;overflow-y:auto;padding:24px 20px 40px;border-top:1px solid #ede9f6}
.nav-mobile.is-open{display:block}
.nav-mobile-section{margin-bottom:28px}
.nav-mobile-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#6f6c7a;margin-bottom:10px;display:block}
.nav-mobile a{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:400;color:#6E6A7C;padding:9px 0;border-bottom:1px solid #f4f1fb;text-decoration:none}
.nav-mobile a i{width:16px;height:16px;flex-shrink:0;color:#6f6c7a}
.nav-mobile a:last-child{border-bottom:none}
.nav-mobile-actions{margin-top:4px;display:flex;flex-direction:column;gap:10px}
.nav-mobile-actions .btn-primary,.nav-mobile-actions .nav-login-mobile{display:block;text-align:center;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none}
.nav-mobile-actions .btn-primary{color:#fff}
.nav-mobile-actions .nav-login-mobile{border:1.5px solid #ddd8ec;color:#1a1523}

/* FAQ ACCORDION */
.faq-list{max-width:760px;margin:40px auto 0}
.faq-item{border-bottom:0.5px solid #e8e4f0}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:20px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;cursor:pointer;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;color:#1A1825;line-height:1.4;letter-spacing:-.01em}
.faq-q:hover{color:#6B5CE7}
.faq-icon{flex-shrink:0;width:18px;height:18px;color:#6f6c7a;margin-top:2px;transition:transform .2s}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{display:none;padding-bottom:20px;font-size:14px;color:#6E6A7C;line-height:1.72}
.faq-a a{color:#6B5CE7;text-decoration:underline}
.faq-item.open .faq-a{display:block}

/* Audience card accordion toggle — hidden on desktop, shown on mobile */
.aud-toggle{display:none}
/* LMS grid logos — prevent wide wordmarks from overflowing */
.lms-grid img{max-width:100%}

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:768px){
  /* Section padding */
  .sec{padding:64px 20px}
  /* Hero: single column, hide widget */
  .hero{grid-template-columns:1fr;padding:56px 20px 24px;gap:0;min-height:auto}
  .hero h1 br{display:none}
  .cta-row .btn-ghost{display:none}
  .hero>*:last-child{display:none}
  .hero-visual{display:none}
  /* Grids */
  .aud-grid{grid-template-columns:1fr !important}
  .aud-grid--3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stat-grid{grid-template-columns:1fr;gap:24px}
  /* Audience card accordion */
  .aud-card-body{display:none}
  .aud-card.is-open .aud-card-body{display:block}
  .aud-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#EEE9FF;border-radius:50%;cursor:pointer;color:#6B5CE7;padding:0;margin-top:8px;flex-shrink:0}
  .aud-toggle svg{transition:transform 0.2s ease;width:14px;height:14px}
  .aud-card.is-open .aud-toggle svg{transform:rotate(180deg)}
  /* Process graphic */
  .pn-proc-wrap,.pn-proc-toggle{display:none !important}
  /* Outcome rows */
  .outcome-row,.outcome-row:nth-child(even){flex-direction:column;gap:32px}
  .outcome-body{flex:none;width:100%;padding:0}
  /* Outcome widgets */
  .outcome-mock{display:none}
  /* WCAG callout */
  .wcag-callout{flex-direction:column;align-items:flex-start;gap:12px}
  .wcag-callout>a{white-space:normal}
  /* IB page — educator grid */
  .edu-grid{grid-template-columns:1fr !important}
  /* For Law page — testimonial, pro features, and tools grids */
  .testi-grid,.pro-grid,.law-tools-grid{grid-template-columns:1fr !important}
  /* For Database Publishers page — steps, partnership levels, and why grids */
  .pub-steps-grid,.pub-levels-grid,.pub-why-grid{grid-template-columns:1fr !important}
  /* Extensions page — AI integration cards, platform card inner, capabilities grid */
  .ext-grid-2,.ext-card-inner,.cap-grid{grid-template-columns:1fr !important}
  /* Library page — librarians card grid */
  .lib-card-grid{grid-template-columns:1fr !important}
  /* Institutions page — LMS integration grid */
  .lms-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
  /* Carousel arrows */
  .t-carousel-btn{display:none}
  /* Two-col section layouts */
  .sec-two,.ai-two,.act-two,.quote-two{grid-template-columns:1fr}
  /* Step rows */
  .steps-list{gap:48px;margin-top:40px}
  .step-row{flex-direction:column;gap:32px}
  .step-row:nth-child(even){flex-direction:column}
  .step-placeholder{display:none !important}
  /* Beta card */
  .beta-card{grid-template-columns:1fr;gap:24px;padding:36px 24px}
  .beta-right{display:none}
  .beta-form-row{flex-direction:column}
  /* Nav */
  .nav{padding:0 20px}
  .nav-links,.nav-actions{display:none}
  .nav-hamburger{display:flex}
  /* Footer */
  footer{flex-direction:column;gap:20px;padding:32px 20px;align-items:flex-start}
  .ft-left{flex-direction:row;gap:0;align-items:center}
  .ft-links{display:none}
  .ft-legal{flex-direction:column;align-items:flex-start;gap:12px}
  .ft-legal-sep{display:none}
}

@media(max-width:480px){
  .aud-grid,.aud-grid--3{grid-template-columns:1fr}
}

.pn-cookie-consent{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#fff;border-top:1px solid #ECEAF2;box-shadow:0 -8px 24px rgba(26,24,37,0.08);padding:16px 24px;font-family:'Inter',sans-serif}
.pn-cookie-consent[hidden]{display:none}
.pn-cookie-consent__inner{display:flex;max-width:1200px;margin:0 auto;gap:16px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.pn-cookie-consent__copy{font-size:13.5px;color:#1A1825;margin:0;max-width:760px;line-height:1.55}
.pn-cookie-consent__copy a{color:#5B4DD4;text-decoration:underline}
.pn-cookie-consent__actions{display:flex;gap:8px;align-items:center}
.pn-cookie-consent__actions .btn-ghost{padding:8px 14px;border:0;background:transparent;cursor:pointer;font-family:inherit}
.pn-cookie-consent__actions .btn-primary{padding:8px 16px;border:0;cursor:pointer;font-family:inherit}
@media(max-width:640px){
  .pn-cookie-consent{padding:14px 16px}
  .pn-cookie-consent__inner{flex-direction:column;align-items:stretch;gap:12px}
  .pn-cookie-consent__actions{justify-content:flex-end}
}
