/* Summer-course landing styles (nav is theme-owned via .j-nav) */

/* Crest sizing + wordmark spacing (theme normally supplies these) */
.j-fold__crest{ width:80px; height:80px; }
.j-fold__crest svg{ width:100%; height:100%; display:block; }
.j-fold__wordmark{ margin-bottom:30px; }

/* Summer hero CTA block (replaces the login doors) */
.sv-hero{ max-width:760px; margin:8px auto 0; text-align:center; position:relative; z-index:2; }
.sv-hero__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:8px; }
.sv-hero__chips{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:28px; }
.sv-chip{
	background:rgba(255,252,247,.82); border:1px solid var(--color-line);
	border-radius:var(--radius-pill); padding:9px 18px;
	font-size:.9rem; font-weight:500; color:var(--color-deep);
	box-shadow:var(--shadow-1); backdrop-filter:blur(4px);
}
.sv-chip b{ color:var(--color-coral); font-weight:700; }
.j-cta{ cursor:pointer; border:none; font-family:var(--font-body); }

/* Cohort cards */
.sv-cohorts{ background:var(--color-paper-warm); }
.sv-cohort-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; max-width:var(--container-max); margin:0 auto; padding:0 var(--container-pad); }
.sv-cohort{
	background:var(--color-paper); border:1px solid var(--color-line);
	border-radius:var(--radius-lg); padding:30px; box-shadow:var(--shadow-2);
	position:relative; overflow:hidden;
}
.sv-cohort::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--color-coral); }
.sv-cohort--semi::before{ background:var(--color-meadow); }
.sv-cohort__tag{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.14em; font-size:.74rem; color:var(--color-ember); font-weight:700; }
.sv-cohort__price{ font-family:var(--font-display); font-size:2.6rem; color:var(--color-deep); line-height:1; margin:14px 0 4px; }
.sv-cohort__price span{ font-size:1rem; color:var(--color-ink-soft); font-style:italic; }
.sv-cohort__meta{ color:var(--color-ink-soft); font-size:.95rem; margin-bottom:14px; }
.sv-cohort__levels{ display:flex; gap:10px; flex-wrap:wrap; }
.sv-level{ border:1px solid var(--color-line); border-radius:var(--radius-md); padding:10px 14px; flex:1; min-width:120px; }
.sv-level b{ display:block; font-family:var(--font-display); color:var(--color-deep); font-size:1.05rem; }
.sv-level span{ font-size:.84rem; color:var(--color-ink-soft); }

/* Plazas restantes */
.sv-places{ display:flex; flex-direction:column; align-items:flex-start; gap:5px; margin-top:10px; }
.sv-places__dots{ display:inline-flex; gap:4px; }
.sv-places__dots i{ width:8px; height:8px; border-radius:50%; background:var(--color-line); display:inline-block; }
.sv-places__dots i.free{ background:var(--color-meadow); }
.sv-places__txt{ font-size:.78rem; color:var(--color-ink-soft); white-space:nowrap; }
.sv-places__txt b{ color:var(--color-deep); display:inline; }

/* Animated countdown to first class */
.sv-countdown{ display:flex; flex-direction:column; align-items:center; gap:8px; margin:0 auto 26px; }
.sv-countdown__label{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.14em; font-size:.72rem; color:var(--color-ink-soft); }
.sv-countdown__units{ display:flex; gap:10px; }
.sv-cd-unit{ display:flex; flex-direction:column; align-items:center; min-width:66px; padding:10px 6px; background:rgba(255,252,247,.9); border:1px solid var(--color-line); border-radius:var(--radius-md); box-shadow:var(--shadow-1); backdrop-filter:blur(4px); }
.sv-cd-num{ font-family:var(--font-display); font-weight:600; font-size:1.9rem; line-height:1; color:var(--color-deep); font-variant-numeric:tabular-nums; }
.sv-cd-unit small{ font-size:.64rem; text-transform:uppercase; letter-spacing:.1em; color:var(--color-ink-soft); margin-top:5px; }
.sv-cd-num.tick{ animation:cd-tick .45s var(--ease-out); }
@keyframes cd-tick{ 0%{ transform:translateY(-3px); opacity:.45; } 100%{ transform:none; opacity:1; } }
.sv-countdown__date{ font-family:var(--font-display); font-style:italic; font-size:.95rem; color:var(--color-coral); }

/* Vertical six-weeks timeline */
.sv-weeks{ background:linear-gradient(180deg,var(--color-paper) 0%,var(--color-paper-warm) 100%); padding:clamp(48px,8vw,90px) 0 clamp(60px,9vw,104px); }
.sv-weeks__timeline{ position:relative; max-width:680px; margin:0 auto; padding:10px var(--container-pad) 10px 64px; }
.sv-weeks__line{ position:absolute; left:24px; top:14px; bottom:14px; width:3px; background:rgba(60,60,120,.12); border-radius:999px; }
.sv-weeks__fill{ position:absolute; left:24px; top:14px; width:3px; height:0; background:linear-gradient(180deg,#FC3C30,#FC780C,#FCC000); border-radius:999px; box-shadow:0 0 12px rgba(252,120,12,.35); }
.sv-weeks__lantern{ position:absolute; left:25.5px; top:14px; width:24px; height:24px; transform:translate(-50%,-50%); border-radius:50%; background:radial-gradient(circle at 40% 35%,#FFE08A,#FC780C); box-shadow:0 0 18px rgba(252,180,90,.7),0 0 0 5px rgba(252,192,0,.16); z-index:3; }
.sv-week{ position:relative; margin-bottom:26px; opacity:0; transform:translateY(22px); transition:opacity .55s var(--ease-out),transform .55s var(--ease-out); }
.sv-week:last-child{ margin-bottom:0; }
.sv-week.is-in{ opacity:1; transform:none; }
.sv-week__node{ position:absolute; left:-48px; top:8px; width:16px; height:16px; border-radius:50%; background:var(--color-paper); border:2px solid var(--color-line); z-index:2; transition:.4s var(--ease-out); }
.sv-week.is-lit .sv-week__node{ background:radial-gradient(circle at 35% 30%,#FFD63B,#FC780C); border-color:#FCC000; box-shadow:0 0 0 5px rgba(252,192,0,.16); }
.sv-week__card{ background:var(--color-paper); border:1px solid var(--color-line); border-radius:var(--radius-lg); padding:20px 24px; box-shadow:var(--shadow-1); transition:box-shadow .4s,border-color .4s; }
.sv-week.is-lit .sv-week__card{ box-shadow:var(--shadow-2); border-color:rgba(252,120,12,.28); }
.sv-week__num{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.16em; font-size:.7rem; color:var(--color-ember); font-weight:700; }
.sv-week__title{ font-size:1.3rem; margin:4px 0 6px; }
.sv-week__desc{ color:var(--color-ink-soft); font-size:.96rem; margin:0 0 12px; }
.sv-week__tags{ display:flex; flex-wrap:wrap; gap:6px; }
.sv-week__tags span{ font-size:.74rem; font-weight:600; color:var(--color-deep); background:var(--color-paper-warm); border:1px solid var(--color-line); border-radius:var(--radius-pill); padding:4px 11px; }
@media(max-width:560px){ .sv-weeks__timeline{ padding-left:44px; } .sv-weeks__line,.sv-weeks__fill{ left:14px; } .sv-weeks__lantern{ left:15.5px; } .sv-week__node{ left:-38px; } }

/* Teacher Comment capture proof */
.sv-capture{ max-width:760px; margin:0 auto clamp(36px,6vw,56px); padding:0 var(--container-pad); }
.sv-capture__card{ background:var(--color-paper); border:1px solid var(--color-line); border-radius:var(--radius-lg); padding:22px 26px; box-shadow:var(--shadow-2); }
.sv-capture__head{ display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.sv-capture__app{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.14em; font-size:.72rem; font-weight:700; color:var(--color-deep); }
.sv-capture__live{ font-size:.72rem; color:var(--color-ink-soft); }
.sv-capture__live::before{ content:""; display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--color-meadow); margin-right:6px; vertical-align:middle; }
.sv-capture__mistake{ font-size:1.12rem; line-height:1.7; }
.sv-wrong{ color:var(--color-coral-dark); text-decoration:line-through; text-decoration-color:rgba(200,54,42,.5); }
.sv-right{ color:var(--color-moss-deep); font-weight:600; }
.sv-x{ color:var(--color-coral); font-weight:700; }
.sv-ok{ color:var(--color-meadow); font-weight:700; }
.sv-arrow{ color:var(--color-ink-soft); margin:0 6px; }
.sv-capture__why{ margin:10px 0 0; font-style:italic; color:var(--color-ink-soft); font-size:.96rem; }
.sv-capture__why b{ font-style:normal; color:var(--color-deep); }
.sv-capture__streams{ display:flex; flex-wrap:wrap; gap:8px; margin:16px 0 10px; }
.sv-stream{ font-size:.82rem; font-weight:600; color:var(--color-deep); background:var(--color-paper); border:1px solid var(--color-line); border-radius:var(--radius-pill); padding:6px 14px; border-left-width:3px; }
.sv-stream small{ font-weight:400; color:var(--color-ink-soft); }
.sv-stream--coral{ border-left-color:var(--color-coral); }
.sv-stream--ember{ border-left-color:var(--color-ember); }
.sv-stream--indigo{ border-left-color:var(--color-indigo); }
.sv-stream--moss{ border-left-color:var(--color-moss); }
.sv-capture__note{ font-size:.88rem; color:rgba(255,252,247,.66); margin:0; }

/* Una sola memoria — the loop */
.sv-loop{ background:linear-gradient(180deg,var(--color-paper-warm) 0%,var(--color-paper) 100%); padding:clamp(48px,8vw,96px) 0; }
.sv-loop__stage{ max-width:600px; margin:0 auto; padding:0 var(--container-pad); }
.sv-loop__stage svg{ width:100%; height:auto; display:block; overflow:visible; }
.sv-loop__ring{ fill:none; stroke:rgba(60,60,120,.16); stroke-width:2; }
.sv-loop__spoke{ stroke:rgba(252,60,48,.4); stroke-width:2.5; stroke-dasharray:2 7; stroke-linecap:round; animation:sv-spoke 1s linear infinite; }
@keyframes sv-spoke{ to{ stroke-dashoffset:-18; } }
.sv-loop__node{ fill:var(--color-paper); stroke:var(--color-line); stroke-width:1.5; }
.sv-loop__label{ font-family:var(--font-lesson-overline); font-size:12px; letter-spacing:.1em; text-transform:uppercase; fill:var(--color-deep); font-weight:700; }
.sv-loop__sub{ font-family:var(--font-body); font-size:10.5px; fill:var(--color-ink-soft); }
.sv-loop__core-label{ font-family:var(--font-lesson-overline); font-size:10.5px; letter-spacing:.16em; fill:#FFFCF7; font-weight:700; }
.sv-loop__note{ text-align:center; max-width:520px; margin:18px auto 0; font-size:.92rem; color:var(--color-ink-soft); }
.sv-loop__note strong{ color:var(--color-coral-dark); }
@media(prefers-reduced-motion:reduce){ .sv-loop__spoke{ animation:none; } }

/* Seed-grow contact form (the new build) */
.sv-form-wrap{ max-width:600px; margin:0 auto; }
.sv-form-card{
	background:var(--color-paper); border:1px solid var(--color-line);
	border-radius:var(--radius-xl); padding:clamp(24px,4vw,44px);
	box-shadow:var(--shadow-3); position:relative; overflow:hidden;
}
.sv-form-card__kicker{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.16em; font-size:.76rem; color:var(--color-ember); font-weight:700; }
.sv-form-card h2{ margin:8px 0 6px; }
.sv-form-card__sub{ color:var(--color-ink-soft); margin-bottom:22px; }
.sv-form .j-field{ margin-bottom:14px; }
.sv-form label{ display:block; font-size:.78rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--color-ink-soft); margin-bottom:6px; }
.sv-form input, .sv-form select, .sv-form textarea{
	width:100%; padding:12px 14px; border:1px solid var(--color-line);
	border-radius:var(--radius-md); background:var(--color-paper-warm);
	font-family:var(--font-body); font-size:1rem; color:var(--color-ink); box-sizing:border-box;
}
.sv-form textarea{ min-height:84px; resize:vertical; }
.sv-form input:focus,.sv-form select:focus,.sv-form textarea:focus{ outline:2px solid var(--color-coral); outline-offset:1px; border-color:transparent; }

/* the grow moment */
.sv-grow{ display:none; text-align:center; padding:20px 0 6px; }
.sv-form-card.is-planted .sv-form{ display:none; }
.sv-form-card.is-planted .sv-grow{ display:block; }
.sv-grow__svg{ width:160px; height:200px; margin:0 auto; display:block; }
.sv-grow__title{ font-family:var(--font-display); font-style:italic; font-size:1.8rem; color:var(--color-deep); margin:6px 0 10px; }
.sv-grow__msg{ color:var(--color-ink-soft); max-width:420px; margin:0 auto; }
.sv-grow.is-on .gx-stem{ animation:gx-stem 1.1s var(--ease-out) forwards; }
.sv-grow.is-on .gx-leaf{ animation:gx-pop .5s var(--ease-bounce) .8s forwards; }
.sv-grow.is-on .gx-leaf2{ animation:gx-pop .5s var(--ease-bounce) 1s forwards; }
.sv-grow.is-on .gx-bloom{ animation:gx-pop .6s var(--ease-bounce) 1.25s forwards; }
.sv-grow.is-on .gx-title, .sv-grow.is-on .gx-fade{ animation:gx-fade .6s var(--ease-out) 1.5s forwards; }
.gx-stem{ stroke-dasharray:120; stroke-dashoffset:120; }
.gx-leaf,.gx-leaf2,.gx-bloom{ transform:scale(0); transform-box:fill-box; transform-origin:center; }
.gx-title,.gx-fade{ opacity:0; }
@keyframes gx-stem{ to{ stroke-dashoffset:0; } }
@keyframes gx-pop{ to{ transform:scale(1); } }
@keyframes gx-fade{ to{ opacity:1; } }

/* small section framing helper */
.sv-section-pad{ padding:clamp(56px,9vw,104px) 0; }
.sv-center-intro{ text-align:center; max-width:760px; margin:0 auto clamp(28px,5vw,48px); padding:0 var(--container-pad); }

/* Lead-form inline message */
.sv-form__msg{ margin:0 0 12px; font-size:.9rem; color:var(--color-ink-soft); }
.sv-form__msg.is-err{ color:var(--color-coral-dark); }

/* ===== Three pillars overview ===== */
.sv-pillars{ padding:clamp(48px,8vw,90px) 0; background:var(--color-paper); }
.sv-pillars__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(262px,1fr)); gap:20px; max-width:var(--container-max); margin:0 auto; padding:0 var(--container-pad); }
.sv-pillar{ position:relative; background:var(--color-paper); border:1px solid var(--color-line); border-radius:var(--radius-lg); padding:30px 28px; box-shadow:var(--shadow-2); overflow:hidden; }
.sv-pillar::before{ content:""; position:absolute; left:0; top:0; right:0; height:4px; background:var(--color-coral); }
.sv-pillar--platform::before{ background:var(--color-indigo); }
.sv-pillar--pack::before{ background:var(--color-meadow); }
.sv-pillar__n{ position:absolute; top:18px; right:22px; font-family:var(--font-display); font-size:1.1rem; color:var(--color-line); font-weight:600; }
.sv-pillar__icon{ width:52px; height:52px; display:flex; align-items:center; justify-content:center; border-radius:var(--radius-md); background:var(--color-paper-warm); border:1px solid var(--color-line); margin-bottom:16px; }
.sv-pillar__icon svg{ width:28px; height:28px; }
.sv-pillar h3{ font-size:1.22rem; margin:4px 0 10px; }
.sv-pillar p{ color:var(--color-ink-soft); font-size:.95rem; margin:0 0 14px; }
.sv-pillar__more{ font-weight:600; font-size:.9rem; color:var(--color-coral); background:none; cursor:pointer; }
.sv-pillar--platform .sv-pillar__more{ color:var(--color-indigo); }
.sv-pillar--pack .sv-pillar__more{ color:var(--color-moss-deep); }

/* ===== PDF pack — book covers ===== */
.sv-pack{ padding:clamp(48px,8vw,90px) 0; background:linear-gradient(180deg,var(--color-paper-warm),var(--color-paper)); }
.sv-pack__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(216px,1fr)); gap:22px; max-width:var(--container-max); margin:0 auto; padding:0 var(--container-pad); }
.sv-book{ display:flex; flex-direction:column; transition:transform .35s var(--ease-out); }
.sv-book:hover{ transform:translateY(-5px); }
.sv-book__cover{ position:relative; border-radius:5px 12px 12px 5px; padding:24px 22px 22px 32px; min-height:286px; display:flex; flex-direction:column; box-shadow:var(--shadow-3); overflow:hidden; color:#FFFCF7; }
.sv-book__cover::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:11px; background:rgba(0,0,0,.20); box-shadow:inset -2px 0 3px rgba(0,0,0,.18); }
.sv-book__cover::after{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 78% 16%, rgba(255,255,255,.20), transparent 58%); pointer-events:none; }
.sv-book--grammar  .sv-book__cover{ background:linear-gradient(155deg,#4C7E57,#2A4F33); }
.sv-book--vocab    .sv-book__cover{ background:linear-gradient(155deg,#ED93B1,#C04C82); }
.sv-book--writing  .sv-book__cover{ background:linear-gradient(155deg,#5460A8,#33356E); }
.sv-book--speaking .sv-book__cover{ background:linear-gradient(155deg,#FC8A2A,#C8362A); }
.sv-book__skill{ position:relative; font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.16em; font-size:.7rem; font-weight:700; opacity:.95; }
.sv-book__title{ position:relative; font-family:var(--font-display); font-style:italic; font-weight:500; font-size:1.45rem; line-height:1.12; color:#FFFCF7; margin:auto 0 8px; }
.sv-book__sub{ position:relative; font-size:.85rem; opacity:.88; margin:0; line-height:1.4; }
.sv-book__meta{ display:flex; justify-content:space-between; align-items:center; margin-top:12px; font-size:.8rem; color:var(--color-ink-soft); }
.sv-book__pdf{ font-weight:700; color:var(--color-moss-deep); display:inline-flex; align-items:center; gap:6px; }
.sv-book__pdf::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--color-meadow); }
.sv-pack__note{ text-align:center; max-width:560px; margin:28px auto 0; color:var(--color-ink-soft); font-size:.92rem; padding:0 var(--container-pad); }
@media(max-width:560px){ .sv-book__cover{ min-height:228px; } }

/* ===== PDF pack — tiles that open with a slow page-turn on hover ===== */
.sv-book{ display:flex; flex-direction:column; }
.sv-book:hover{ transform:none; }              /* override earlier lift */
.sv-book__tile{ position:relative; min-height:266px; perspective:1500px; }
.sv-book__inside{ position:absolute; inset:0; background:#FFFCF7; color:var(--color-ink); border-radius:5px 10px 10px 5px; padding:22px 20px 20px 30px; box-shadow:var(--shadow-2); display:flex; flex-direction:column; overflow:hidden; }
.sv-book__inside::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:8px; background:rgba(43,37,48,.07); }
.sv-book__inside-skill{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.14em; font-size:.64rem; font-weight:700; color:var(--color-ember); }
.sv-book__toc{ list-style:none; margin:11px 0 0; padding:0; display:flex; flex-direction:column; gap:9px; }
.sv-book__toc li{ font-family:var(--font-display); font-style:italic; font-size:.9rem; color:var(--color-deep); padding-left:14px; position:relative; line-height:1.22; }
.sv-book__toc li::before{ content:""; position:absolute; left:0; top:.5em; width:5px; height:5px; border-radius:50%; background:var(--color-coral); }
.sv-book__inside-foot{ margin-top:auto; padding-top:10px; font-size:.74rem; color:var(--color-ink-soft); font-style:italic; }
.sv-book__leaf{ position:absolute; inset:0; border-radius:5px 12px 12px 5px; padding:24px 22px 22px 32px; display:flex; flex-direction:column; color:#FFFCF7; overflow:hidden; transform-origin:left center; transition:transform 1.15s var(--ease-in-out), box-shadow .5s var(--ease-out); box-shadow:var(--shadow-3); backface-visibility:hidden; will-change:transform; }
.sv-book__leaf::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:11px; background:rgba(0,0,0,.20); box-shadow:inset -2px 0 3px rgba(0,0,0,.18); }
.sv-book__leaf::after{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 78% 16%, rgba(255,255,255,.20), transparent 58%); pointer-events:none; }
.sv-book--grammar  .sv-book__leaf{ background:linear-gradient(155deg,#4C7E57,#2A4F33); }
.sv-book--vocab    .sv-book__leaf{ background:linear-gradient(155deg,#ED93B1,#C04C82); }
.sv-book--writing  .sv-book__leaf{ background:linear-gradient(155deg,#5460A8,#33356E); }
.sv-book--speaking .sv-book__leaf{ background:linear-gradient(155deg,#FC8A2A,#C8362A); }
.sv-book:hover .sv-book__leaf,
.sv-book:focus-within .sv-book__leaf{ transform:rotateY(-162deg); box-shadow:-20px 14px 36px rgba(0,0,0,.24); }
.sv-book__skill{ position:relative; font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.16em; font-size:.7rem; font-weight:700; opacity:.95; }
.sv-book__title{ position:relative; font-family:var(--font-display); font-style:italic; font-weight:500; font-size:1.42rem; line-height:1.12; color:#FFFCF7; margin:auto 0 8px; }
.sv-book__sub{ position:relative; font-size:.84rem; opacity:.88; margin:0; line-height:1.4; }
.sv-book__hint{ position:relative; margin-top:12px; font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; opacity:.66; }
@media(max-width:560px){ .sv-book__tile{ min-height:232px; } }
@media(prefers-reduced-motion:reduce){
  .sv-book__leaf{ transition:opacity .35s var(--ease-out); }
  .sv-book:hover .sv-book__leaf, .sv-book:focus-within .sv-book__leaf{ transform:none; opacity:0; }
}

/* ===== PDF guides — 4-step page-turn (JS-driven .is-turned) ===== */
.sv-book__tile .sv-book__inside{ display:none; }                          /* old single page retired */
.sv-book:hover .sv-book__leaf, .sv-book:focus-within .sv-book__leaf{ transform:none; }  /* neutralise old instant flip */
.sv-book .sv-book__leaf.is-turned, .sv-book .sv-book__page.is-turned{ transform:rotateY(-166deg) !important; box-shadow:-16px 12px 30px rgba(0,0,0,.2); }
.sv-book__page{ position:absolute; inset:0; background:#FFFCF7; color:var(--color-ink); border-radius:5px 10px 10px 5px; padding:18px 16px 16px 26px; box-shadow:var(--shadow-2); display:flex; flex-direction:column; overflow:hidden; transform-origin:left center; transition:transform .82s var(--ease-in-out), box-shadow .4s; backface-visibility:hidden; }
.sv-book__page::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:7px; background:rgba(43,37,48,.07); }
.sv-book__page--1{ z-index:3; } .sv-book__page--2{ z-index:2; } .sv-book__page--3{ z-index:1; }
.sv-book__leaf{ z-index:4; }
.sv-book__tag{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.14em; font-size:.62rem; font-weight:700; color:var(--color-ember); }
.sv-book__toc{ list-style:none; margin:9px 0 0; padding:0; display:flex; flex-direction:column; gap:8px; }
.sv-book__toc li{ font-family:var(--font-display); font-style:italic; font-size:.86rem; color:var(--color-deep); padding-left:13px; position:relative; line-height:1.2; }
.sv-book__toc li::before{ content:""; position:absolute; left:0; top:.5em; width:5px; height:5px; border-radius:50%; background:var(--color-coral); }
.sv-book__h{ font-family:var(--font-display); font-style:italic; font-size:1.04rem; color:var(--color-deep); margin:10px 0 6px; }
.sv-book__p{ font-size:.84rem; color:var(--color-ink-soft); margin:0 0 10px; line-height:1.4; }
.sv-book__ex{ font-family:var(--font-mono); font-size:.78rem; color:var(--color-deep); background:var(--color-paper-warm); border-radius:6px; padding:7px 9px; margin:auto 0 0; }
.sv-book__q{ font-family:var(--font-display); font-style:italic; font-size:.96rem; color:var(--color-deep); margin:12px 0 8px; }
.sv-book__a{ font-size:.85rem; font-weight:600; color:var(--color-moss-deep); margin:0; }
.sv-book__no{ position:absolute; bottom:12px; right:14px; font-family:var(--font-display); color:var(--color-line); font-size:.95rem; font-weight:600; }

/* ===== Keynote tile + capture-on-light ===== */
.sv-keynote__stage{ position:relative; margin-top:14px; border-radius:var(--radius-md); overflow:hidden; aspect-ratio:1280/828; background:#11101a; box-shadow:var(--shadow-2); cursor:pointer; }
.sv-keynote__vid{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.sv-keynote__play{ position:absolute; inset:0; margin:auto; width:56px; height:56px; display:flex; align-items:center; justify-content:center; transition:opacity .3s, transform .3s; pointer-events:none; }
.sv-keynote__play svg{ width:56px; height:56px; filter:drop-shadow(0 4px 12px rgba(0,0,0,.45)); }
.sv-keynote:hover .sv-keynote__play, .sv-keynote:focus-within .sv-keynote__play{ opacity:0; transform:scale(.8); }
.sv-keynote__badge{ position:absolute; left:10px; bottom:10px; font-size:.7rem; font-weight:600; letter-spacing:.03em; color:#FFFCF7; background:rgba(43,37,48,.55); padding:5px 11px; border-radius:var(--radius-pill); backdrop-filter:blur(4px); }
.s-human__cap-lead{ text-align:center; max-width:680px; margin:36px auto 14px; font-family:var(--font-display); font-style:italic; color:var(--color-ink-soft); font-size:1.06rem; }
.sv-capture--light .sv-capture__note{ color:var(--color-ink-soft); }

/* ===== Keynote lightbox (pop-up player) ===== */
.sv-modal{ position:fixed; inset:0; z-index:var(--z-overlay,1000); display:flex; align-items:center; justify-content:center; padding:clamp(16px,4vw,56px); background:rgba(20,16,31,.76); backdrop-filter:blur(9px); opacity:0; transition:opacity .35s var(--ease-out); }
.sv-modal[hidden]{ display:none; }
.sv-modal.is-open{ opacity:1; }
.sv-modal__frame{ position:relative; width:min(1100px,94vw); max-height:88vh; aspect-ratio:1280/828; border-radius:14px; overflow:hidden; background:#11101a; box-shadow:0 50px 150px rgba(0,0,0,.62), 0 0 0 1px rgba(255,255,255,.06); transform:scale(.93); transition:transform .42s var(--ease-bounce); }
.sv-modal.is-open .sv-modal__frame{ transform:scale(1); }
.sv-modal__vid{ width:100%; height:100%; object-fit:contain; display:block; background:#11101a; }
.sv-modal__close{ position:absolute; top:16px; right:20px; z-index:2; width:42px; height:42px; border-radius:50%; border:none; background:rgba(255,252,247,.94); color:var(--color-ink); font-size:1.55rem; line-height:1; cursor:pointer; box-shadow:var(--shadow-2); }
.sv-modal__close:hover{ background:#fff; transform:scale(1.05); }
@media(prefers-reduced-motion:reduce){ .sv-book__page,.sv-book__leaf,.sv-modal__frame{ transition:opacity .2s; } }

/* ===== Hero "¿Primera vez?" — pill so the coral link reads against the green ===== */
.lwl-verano .j-newhere{
	width:fit-content; max-width:92%;
	margin-left:auto; margin-right:auto;
	padding:9px 20px;
	background:rgba(255,252,247,.94);
	border:1px solid var(--color-line);
	border-radius:var(--radius-pill);
	box-shadow:var(--shadow-2);
	backdrop-filter:blur(5px);
}

/* ===== 4-step page-turn — CSS :hover / :focus-within / .is-open, staggered (robust) ===== */
.sv-book__leaf, .sv-book__page--1, .sv-book__page--2{ transition:transform .72s var(--ease-in-out), box-shadow .4s; }
.sv-book:hover .sv-book__leaf, .sv-book:focus-within .sv-book__leaf, .sv-book.is-open .sv-book__leaf{ transform:rotateY(-166deg); transition-delay:0s; box-shadow:-16px 12px 30px rgba(0,0,0,.2); }
.sv-book:hover .sv-book__page--1, .sv-book:focus-within .sv-book__page--1, .sv-book.is-open .sv-book__page--1{ transform:rotateY(-166deg); transition-delay:.62s; box-shadow:-16px 12px 30px rgba(0,0,0,.18); }
.sv-book:hover .sv-book__page--2, .sv-book:focus-within .sv-book__page--2, .sv-book.is-open .sv-book__page--2{ transform:rotateY(-166deg); transition-delay:1.24s; box-shadow:-16px 12px 30px rgba(0,0,0,.18); }
@media(prefers-reduced-motion:reduce){ .sv-book__leaf,.sv-book__page--1,.sv-book__page--2{ transition:opacity .3s; transition-delay:0s !important; } }

/* ===== Teacher Comment as a Pillar-1 card ===== */
.s-human-card--capture .sv-capture__card{ padding:16px 18px; margin-top:2px; box-shadow:var(--shadow-1); }
.s-human-card--capture .sv-capture__mistake{ font-size:1rem; line-height:1.65; }
.s-human-card--capture .sv-capture__why{ font-size:.9rem; }
.s-human-card--capture .sv-capture__streams{ margin:14px 0 0; }

/* ===== Zoom "after class" card (transcript · summary · infinite chat) ===== */
.sv-zoom{ margin-top:14px; border-radius:var(--radius-md); overflow:hidden; border:1px solid var(--color-line); box-shadow:var(--shadow-1); background:var(--color-paper); }
.sv-zoom__bar{ display:flex; align-items:center; justify-content:space-between; padding:9px 13px; background:#2D8CFF; color:#fff; }
.sv-zoom__logo{ display:inline-flex; align-items:center; gap:7px; font-weight:600; font-size:.92rem; }
.sv-zoom__logo svg{ width:26px; height:16px; }
.sv-zoom__time{ font-size:.78rem; opacity:.92; font-variant-numeric:tabular-nums; }
.sv-zoom__body{ padding:14px 14px 16px; }
.sv-zoom__sumtag{ font-family:var(--font-lesson-overline); text-transform:uppercase; letter-spacing:.14em; font-size:.62rem; font-weight:700; color:#1E6FD9; }
.sv-zoom__line{ display:block; height:7px; border-radius:4px; background:var(--color-line); margin-top:9px; }
.sv-zoom__line.short{ width:60%; }
.sv-zoom__chips{ display:flex; flex-wrap:wrap; gap:7px; margin-top:14px; }
.sv-zoom__chips span{ font-size:.74rem; font-weight:600; color:#1E6FD9; background:rgba(45,140,255,.10); border:1px solid rgba(45,140,255,.24); border-radius:var(--radius-pill); padding:4px 11px; }

/* ===== WhatsApp click-to-chat ===== */
.sv-wa{ display:inline-flex; align-items:center; gap:9px; background:#25D366; color:#fff!important; border:none; padding:13px 22px; border-radius:var(--radius-pill); font-family:var(--font-body); font-weight:600; font-size:1rem; line-height:1; cursor:pointer; box-shadow:var(--shadow-1); transition:background .2s var(--ease-out), transform .2s var(--ease-out); background-image:none; }
.sv-wa:hover,.sv-wa:focus-visible{ background:#1FB855; color:#fff!important; transform:translateY(-1px); }
.sv-wa svg{ width:20px; height:20px; flex:none; }
.sv-wa-alt{ display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; margin-top:20px; padding-top:20px; border-top:1px dashed var(--color-line); }
.sv-wa-alt > span{ font-family:var(--font-display); font-style:italic; color:var(--color-ink-soft); }

/* ===== Testimonials ===== */
.sv-testi{ padding:clamp(48px,8vw,90px) 0; background:linear-gradient(180deg,var(--color-paper) 0%,var(--color-paper-warm) 100%); }
.sv-testi__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; max-width:var(--container-max); margin:0 auto; padding:0 var(--container-pad); }
.sv-testi-card{ position:relative; background:var(--color-paper); border:1px solid var(--color-line); border-radius:var(--radius-lg); padding:30px 28px 24px; box-shadow:var(--shadow-2); display:flex; flex-direction:column; }
.sv-testi-card__mark{ font-family:var(--font-display); font-size:3.4rem; line-height:.6; color:var(--color-sakura); height:28px; }
.sv-testi-card__quote{ font-family:var(--font-display); font-style:italic; font-size:1.06rem; line-height:1.5; color:var(--color-deep); margin:6px 0 20px; }
.sv-testi-card__who{ display:flex; align-items:center; gap:10px; margin-top:auto; }
.sv-testi-card__name{ font-weight:600; color:var(--color-ink); }
.sv-testi-card__level{ font-size:.7rem; font-weight:700; letter-spacing:.08em; color:#fff; border-radius:var(--radius-pill); padding:3px 11px; }
.sv-lvl--b1{ background:var(--color-meadow); }
.sv-lvl--b2{ background:var(--color-coral); }
.sv-lvl--c1{ background:var(--color-indigo); }

/* ===== Memory loop — node flashes as the orbiting pulse passes ===== */
.sv-loop__halo{ fill:none; stroke:#FCC000; stroke-width:2.5; opacity:0; transform-box:fill-box; transform-origin:center; }
.sv-loop__node-g.is-hit .sv-loop__halo{ animation:sv-halo .75s var(--ease-out) forwards; }
@keyframes sv-halo{ 0%{ transform:scale(1); opacity:.75; } 100%{ transform:scale(2.2); opacity:0; } }
.sv-loop__node-g.is-hit .sv-loop__node{ animation:sv-nodeglow .75s var(--ease-out); }
@keyframes sv-nodeglow{ 0%{ filter:none; } 28%{ filter:drop-shadow(0 0 10px rgba(252,192,0,.95)); } 100%{ filter:none; } }
.sv-loop__dot{ transform-box:fill-box; transform-origin:center; }
.sv-loop__node-g.is-hit .sv-loop__dot{ animation:sv-dotpop .75s var(--ease-bounce,cubic-bezier(.34,1.56,.64,1)); }
@keyframes sv-dotpop{ 0%{ transform:scale(1); } 35%{ transform:scale(1.75); } 100%{ transform:scale(1); } }
@media(prefers-reduced-motion:reduce){ .sv-loop__node-g.is-hit *{ animation:none!important; } }
