/* 412Toring — "where it finally clicks" · warm one-on-one tutoring
   Type: Fraunces (display) + Figtree (body). Palette: cream + coral + teal + marigold. */
:root{
  --cream:#FBF6EE; --cream2:#F4EADB; --paper:#FFFDF9;
  --ink:#2A2620; --muted:#7C7264;
  --coral:#D9532A; --coral-deep:#B84420; --coral-soft:#F0805A;
  --teal:#2E6E5E; --teal-deep:#22564A; --marigold:#E6A93C;
  --line:#EADFCD; --line2:#E0D3BC;
  --maxw:1200px;
  --shadow:0 24px 60px -34px rgba(64,42,20,.55);
  --shadow-sm:0 14px 34px -22px rgba(64,42,20,.5);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Figtree',system-ui,-apple-system,sans-serif;background:var(--cream);color:var(--ink);
  line-height:1.7;font-weight:400;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.container{max-width:var(--maxw);margin:0 auto;padding:0 32px}
h1,h2,h3,h4,.brandtext,.display{font-family:'Fraunces','Georgia',serif;font-weight:600;letter-spacing:-.01em;line-height:1.05}
img{display:block;max-width:100%}
a{color:inherit}
.ph{filter:saturate(1.06) contrast(1.03) brightness(1.02)}
.eyebrow{font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--coral-deep);font-family:'Figtree',sans-serif;display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--coral);border-radius:2px}
.center .eyebrow::before{display:none}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;text-decoration:none;font-family:'Figtree',sans-serif;font-weight:700;
  font-size:.98rem;padding:15px 30px;border-radius:40px;transition:transform .2s,box-shadow .2s,background .2s,color .2s;cursor:pointer;border:0}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 12px 24px -12px rgba(217,83,42,.7)}
.btn-primary:hover{background:var(--coral-deep);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(217,83,42,.8)}
.btn-ghost{background:transparent;border:1.5px solid var(--teal);color:var(--teal-deep)}
.btn-ghost:hover{background:var(--teal);color:#fff;transform:translateY(-2px)}
.btn-cream{background:var(--cream);color:var(--teal-deep)}
.btn-cream:hover{background:#fff;transform:translateY(-2px)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}

/* nav */
nav{position:sticky;top:0;z-index:70;background:rgba(251,246,238,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s,background .3s}
nav.scrolled{border-bottom-color:var(--line);box-shadow:0 8px 26px -22px rgba(64,42,20,.6);background:rgba(251,246,238,.96)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand img{width:34px;height:34px;border-radius:9px}
.brandtext{font-size:1.5rem;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.brandtext .n{color:var(--coral)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{text-decoration:none;color:var(--ink);font-weight:600;font-size:.98rem;transition:color .2s}
.nav-links a:hover{color:var(--coral)}
.nav-links a.navcta{background:var(--coral);color:#fff;padding:11px 22px;border-radius:40px;box-shadow:0 12px 22px -14px rgba(217,83,42,.75)}
.nav-links a.navcta:hover{background:var(--coral-deep);color:#fff}
.navtoggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px;line-height:0}
@media(max-width:860px){
  .navtoggle{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:6px 0;display:none;box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{padding:15px 32px;font-size:1.02rem;border-top:1px solid var(--line)}
  .nav-links a:first-child{border-top:0}
  .nav-links a.navcta{margin:10px 24px 12px;border-radius:40px;text-align:center;justify-content:center;padding:14px}
}

/* HERO — asymmetric overlapping cluster */
.hero{position:relative;padding:60px 0 46px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-160px;right:-140px;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,169,60,.24),transparent 68%);z-index:0}
.hero::after{content:"";position:absolute;bottom:-180px;left:-160px;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(46,110,94,.10),transparent 70%);z-index:0}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:60px;align-items:center}
.hero-copy .eyebrow{margin-bottom:20px}
.hero-copy h1{font-size:clamp(2.7rem,6.2vw,5rem);margin-bottom:22px;line-height:1.03}
.hero-copy h1 .clicks{color:var(--coral);font-style:italic;position:relative;white-space:nowrap;padding-bottom:.02em}
.hero-copy h1 .clicks svg{position:absolute;left:2%;width:96%;height:.3em;bottom:-.12em}
.hero-copy .lede{font-size:1.2rem;color:var(--muted);max-width:46ch;margin-bottom:28px;line-height:1.55}
.hero-copy .btn-row{margin-bottom:26px}
.trustchip{display:inline-flex;align-items:center;gap:12px;background:var(--paper);border:1px solid var(--line);
  border-radius:40px;padding:9px 20px 9px 15px;box-shadow:var(--shadow-sm)}
.trustchip .stars{color:var(--marigold);letter-spacing:.06em;font-size:1rem}
.trustchip .tx{font-size:.9rem;color:var(--ink);font-weight:700}
.trustchip .tx span{color:var(--muted);font-weight:500}

.hero-art{position:relative;max-width:460px;margin-left:auto}
.hero-art .main{position:relative;aspect-ratio:4/5;border-radius:28px;overflow:hidden;box-shadow:var(--shadow);
  background:linear-gradient(150deg,#e9c9a3,#caa06f);z-index:1}
.hero-art .main img{width:100%;height:100%;object-fit:cover}
.hero-art .sub{position:absolute;left:-30px;bottom:-30px;width:46%;aspect-ratio:1/1;border-radius:20px;overflow:hidden;
  border:6px solid var(--cream);box-shadow:var(--shadow);z-index:2;background:linear-gradient(150deg,#cfe0d4,#2E6E5E)}
.hero-art .sub img{width:100%;height:100%;object-fit:cover}
.hero-art .revcard{position:absolute;top:22px;right:-24px;z-index:3;background:var(--paper);border:1px solid var(--line);
  border-radius:16px;padding:14px 16px;max-width:206px;box-shadow:var(--shadow)}
.hero-art .revcard .stars{color:var(--marigold);font-size:.82rem;letter-spacing:.05em;margin-bottom:6px}
.hero-art .revcard p{font-size:.85rem;line-height:1.45;color:var(--ink);margin:0;font-weight:500}
.hero-art .revcard .who{margin-top:7px;font-size:.72rem;color:var(--muted);font-weight:700}

/* stat strip (its own band under hero) */
.statband{padding:8px 0 8px}
.statstrip{background:var(--paper);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-sm);
  display:grid;grid-template-columns:repeat(3,1fr);text-align:center;overflow:hidden}
.statstrip .s{padding:26px 20px}
.statstrip .s+.s{border-left:1px solid var(--line)}
.statstrip .s b{display:block;font-family:'Fraunces',serif;font-size:2rem;color:var(--teal);line-height:1;margin-bottom:7px}
.statstrip .s span{font-size:.92rem;color:var(--muted);font-weight:500}

/* section base */
section{position:relative}
.sec{padding:96px 0}
.sec-tight{padding:60px 0}
.sec-cream2{background:var(--cream2)}
.sec-paper{background:var(--paper)}
.sechead{max-width:760px;margin-bottom:52px}
.sechead.center{margin-left:auto;margin-right:auto;text-align:center}
.sechead h2{font-size:clamp(2rem,4.6vw,3.3rem);margin-top:14px}
.sechead p{color:var(--muted);font-size:1.14rem;margin-top:16px;line-height:1.6}
.sechead h2 em{font-style:italic;color:var(--coral)}

/* statement */
.statement{text-align:center;padding:104px 0 84px}
.statement h2{font-size:clamp(1.9rem,4.2vw,3.05rem);max-width:22ch;margin:16px auto 0;line-height:1.2;font-weight:500}
.statement h2 em{font-style:italic;color:var(--coral)}

/* editorial alternating rows */
.rows{padding:20px 0 40px}
.erow{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:56px;margin:64px 0}
.erow-img{position:relative;aspect-ratio:5/4;border-radius:22px;overflow:hidden;background:linear-gradient(150deg,#e9c9a3,#caa06f);box-shadow:var(--shadow)}
.erow-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.erow:hover .erow-img img{transform:scale(1.045)}
.erow.rev .erow-img{order:2}
.erow .no{font-family:'Fraunces',serif;font-style:italic;font-size:1.1rem;color:var(--coral)}
.erow h3{font-size:clamp(1.6rem,3vw,2.3rem);margin:6px 0 14px}
.erow p{color:var(--muted);font-size:1.08rem;line-height:1.6;margin-bottom:14px;max-width:44ch}
.erow .mini{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.erow .mini li{font-size:.86rem;font-weight:600;color:var(--teal-deep);background:rgba(46,110,94,.09);
  border:1px solid rgba(46,110,94,.18);padding:6px 13px;border-radius:30px}

/* subjects */
.subjects{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.subj{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:34px 30px;transition:transform .25s,box-shadow .25s,border-color .25s}
.subj:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line2)}
.subj .k{font-family:'Fraunces',serif;font-style:italic;color:var(--marigold);font-size:1.05rem;margin-bottom:6px}
.subj h3{font-size:1.5rem;margin-bottom:10px}
.subj p{color:var(--muted);font-size:1rem;line-height:1.6}

/* cards */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:32px}
.card .num{font-family:'Fraunces',serif;font-size:1.4rem;color:var(--coral);font-style:italic;margin-bottom:10px;display:block}
.card h3{font-size:1.35rem;margin-bottom:9px}
.card p{color:var(--muted);font-size:1.02rem;line-height:1.6}

/* credentials panel (About) */
.credpanel{background:linear-gradient(160deg,var(--teal),var(--teal-deep));color:#fff;border-radius:24px;padding:38px;box-shadow:var(--shadow)}
.credpanel .eyebrow{color:var(--marigold)}
.credpanel .eyebrow::before{background:var(--marigold)}
.credpanel h3{color:#fff;font-size:1.5rem;margin:14px 0 22px}
.credrow{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-top:1px solid rgba(255,255,255,.16)}
.credrow:first-of-type{border-top:0}
.credrow b{font-family:'Fraunces',serif;font-size:1.7rem;color:var(--marigold);line-height:1;min-width:92px}
.credrow span{color:rgba(255,255,255,.9);font-size:1rem;font-weight:500}

/* quote band */
.band{position:relative;min-height:56vh;display:flex;align-items:center;text-align:center;overflow:hidden;background:var(--teal-deep)}
.band-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;filter:saturate(1.05) contrast(1.03)}
.band-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,44,38,.64),rgba(24,40,34,.8))}
.band .container{position:relative;z-index:2;padding:96px 32px}
.band .stars{color:var(--marigold);letter-spacing:.3em;font-size:1.1rem;margin-bottom:22px}
.band .q{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1.5rem,3.4vw,2.5rem);line-height:1.38;color:#fff;max-width:24ch;margin:0 auto;font-weight:500}
.band .who{margin-top:26px;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.82);font-weight:700}

/* testimonials */
.tgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.tcard{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:32px;display:flex;flex-direction:column}
.tcard .stars{color:var(--marigold);letter-spacing:.16em;margin-bottom:14px;font-size:1rem}
.tcard .body{font-size:1.08rem;line-height:1.62;color:var(--ink);margin-bottom:18px}
.tcard .body::before{content:"\201C";font-family:'Fraunces',serif;color:var(--coral-soft);font-size:2.4rem;line-height:0;vertical-align:-.4em;margin-right:4px}
.tcard .who{margin-top:auto;font-weight:700;color:var(--teal-deep)}
.tcard .who span{display:block;font-weight:500;color:var(--muted);font-size:.9rem}

/* CTA */
.cta{background:linear-gradient(150deg,var(--teal),var(--teal-deep));color:#fff;text-align:center;padding:92px 0}
.cta h2{font-size:clamp(2rem,4.4vw,3.1rem);max-width:20ch;margin:0 auto 16px;color:#fff}
.cta h2 em{font-style:italic;color:var(--marigold)}
.cta p{color:rgba(255,255,255,.86);max-width:48ch;margin:0 auto 30px;font-size:1.12rem}

/* contact */
.contact{padding:92px 0}
.cwrap{display:grid;grid-template-columns:.92fr 1.08fr;gap:64px;align-items:start}
.cinfo h2{font-size:clamp(2rem,4.2vw,3rem);margin:14px 0 16px}
.cinfo>p{color:var(--muted);font-size:1.12rem;margin-bottom:26px;max-width:44ch}
.crow{display:block;text-decoration:none;padding:18px 20px;border:1px solid var(--line);border-radius:16px;margin-bottom:12px;
  background:var(--paper);transition:transform .2s,box-shadow .2s,border-color .2s}
a.crow:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line2)}
.crow b{font-family:'Fraunces',serif;font-size:1.15rem;color:var(--teal-deep);display:block;margin-bottom:2px;font-weight:600}
.crow span{color:var(--muted);font-size:1rem}
.socials{display:flex;gap:12px;margin-top:8px}
.socials a{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  color:var(--teal-deep);background:var(--paper);transition:transform .2s,background .2s,color .2s,border-color .2s}
.socials a:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:translateY(-2px)}
.form{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:36px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;padding:14px 15px;border:1px solid var(--line2);background:var(--cream);
  color:var(--ink);font-family:inherit;font-size:1rem;border-radius:12px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--coral);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.form .btn-primary{width:100%;justify-content:center;margin-top:6px}
.hp{position:absolute;left:-9999px;opacity:0}
.thanks{display:none;text-align:center;padding:30px 12px}
.thanks.show{display:block}
.thanks h3{font-size:1.9rem;color:var(--teal-deep);margin-bottom:10px}
.thanks p{color:var(--muted)}

/* footer */
footer{background:var(--teal-deep);color:#d8e6e0;padding:64px 0 40px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:44px}
.fbrand-lock{display:flex;align-items:center;gap:11px;margin-bottom:16px}
.fbrand-lock img{width:38px;height:38px;border-radius:10px}
.fbrand-lock .brandtext{color:#fff}
.fbrand-lock .brandtext .n{color:var(--marigold)}
footer .fabout{color:rgba(255,255,255,.72);font-size:.98rem;max-width:34ch;line-height:1.6}
footer h4{font-family:'Figtree',sans-serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--marigold);font-weight:700;margin-bottom:16px}
footer .fcol a{display:block;text-decoration:none;color:rgba(255,255,255,.82);padding:6px 0;font-size:.98rem;transition:color .2s}
footer .fcol a:hover{color:#fff}
.fbar{border-top:1px solid rgba(255,255,255,.14);padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  color:rgba(255,255,255,.6);font-size:.86rem}
.fbar a{color:var(--marigold);text-decoration:none}
.fsoc{display:flex;gap:10px}
.fsoc a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s,border-color .2s}
.fsoc a:hover{background:rgba(255,255,255,.14)}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.erow-img img{transition:none}}

/* PAGE HERO (subpages) */
.pagehero{position:relative;background:linear-gradient(180deg,var(--cream),var(--cream2));border-bottom:1px solid var(--line);overflow:hidden;padding:60px 0}
.pagehero::before{content:"";position:absolute;top:-140px;right:-120px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(232,169,60,.22),transparent 68%)}
.pagehero .container{position:relative;z-index:1}
.pagehero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:52px;align-items:center}
.pagehero-copy .eyebrow{margin-bottom:16px}
.pagehero-copy h1{font-size:clamp(2.4rem,5.4vw,3.9rem);max-width:15ch}
.pagehero-copy h1 .clicks{color:var(--coral);font-style:italic}
.pagehero-copy .lede{font-size:1.2rem;color:var(--muted);max-width:50ch;margin-top:18px;line-height:1.55}
.pagehero-art{aspect-ratio:5/4;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);background:linear-gradient(150deg,#e9c9a3,#caa06f)}
.pagehero-art img{width:100%;height:100%;object-fit:cover}
.pagehero.solo .pagehero-grid{grid-template-columns:1fr;text-align:center;max-width:820px;margin:0 auto}
.pagehero.solo .eyebrow{justify-content:center}
.pagehero.solo h1,.pagehero.solo .lede{margin-left:auto;margin-right:auto}

/* gallery */
.gal3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gal3 figure{aspect-ratio:4/3;border-radius:18px;overflow:hidden;background:linear-gradient(150deg,#e9c9a3,#caa06f)}
.gal3 figure img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease}
.gal3 figure:hover img{transform:scale(1.05)}

/* responsive */
@media(max-width:900px){
  .cwrap{grid-template-columns:1fr;gap:36px}
  .grid3,.subjects{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr;gap:30px}
  .fbrand{grid-column:1 / -1}
}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-art{margin:0 auto;max-width:400px}
  .pagehero-grid{grid-template-columns:1fr;gap:34px}
  .pagehero-art{max-width:520px}
  .erow{grid-template-columns:1fr;gap:26px;margin:44px 0}
  .erow.rev .erow-img{order:0}
  .statstrip{grid-template-columns:1fr}
  .statstrip .s+.s{border-left:0;border-top:1px solid var(--line)}
  .tgrid,.grid2{grid-template-columns:1fr}
  .sec{padding:70px 0}
}
@media(max-width:520px){
  body{font-size:16px}
  .container{padding:0 22px}
  .frow{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .hero-art .sub{left:-6px;bottom:-14px;width:40%;border-width:5px}
  .hero-art .revcard{right:-6px;top:10px;max-width:168px;padding:11px 13px}
  .hero{padding:44px 0 40px}
}

/* about — Katie portrait in the page hero */
.pagehero.haspt .pagehero-art{aspect-ratio:4/5;max-width:400px;margin-left:auto}
@media(max-width:860px){.pagehero.haspt .pagehero-art{max-width:320px;margin:0 auto}}
