/* ============================================================
   AICamps.ai — AI Explorers Lab
   Consolidated stylesheet (home + enrollment + schedule-call)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --paper:#F2ECDF;
  --paper-2:#EBE3D2;
  --ink:#10151B;
  --ink-soft:#2A323B;
  --ink-mute:#5A6470;
  --rule:#1B2027;
  --coral:#E54B2C;
  --coral-deep:#B83617;
  --chart:#D5E04A;
  --sky:#9CC7DE;
  --mustard:#E2B23F;
  --plum:#3A2540;
  --grain: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.06 0 0 0 0 0.08 0 0 0 0 0.10 0 0 0 0.22 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  --max:1240px;
}
body.narrow{--max:1100px}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Manrope",ui-sans-serif,system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;inset:0;
  background-image:var(--grain);
  opacity:.35;
  pointer-events:none;
  z-index:1;
  mix-blend-mode:multiply;
}

img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}

/* ---------- Type ---------- */
.display{
  font-family:"Fraunces","Iowan Old Style",Georgia,serif;
  font-variation-settings:"opsz" 144,"SOFT" 30;
  font-weight:500;
  letter-spacing:-0.02em;
  line-height:.95;
}
.display em{font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100;color:var(--coral)}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;letter-spacing:.02em}
.eyebrow{
  font-family:"JetBrains Mono",ui-monospace,monospace;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.eyebrow .dot{display:inline-block;width:7px;height:7px;background:var(--coral);border-radius:50%;margin-right:.55em;transform:translateY(-1px)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px;position:relative;z-index:2}
section{position:relative;z-index:2}
.rule{height:1px;background:var(--ink);opacity:.85}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1px solid var(--ink)}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;max-width:1240px;margin:0 auto;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:"Fraunces",serif;font-weight:600;font-size:22px;letter-spacing:-0.01em;
}
.brand-mark{width:30px;height:30px;border-radius:50%;background:var(--ink);position:relative;display:inline-block}
.brand-mark::after{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--coral)}
.brand-mark::before{
  content:"";position:absolute;left:-3px;top:-3px;
  width:36px;height:36px;border-radius:50%;
  border:1px dashed var(--ink);animation:spin 22s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:14px;font-weight:500}
.nav-links a:hover{color:var(--coral)}
.nav-cta{
  background:var(--ink);color:var(--paper);
  padding:10px 18px;border-radius:999px;
  font-size:13px;font-weight:600;letter-spacing:.02em;
  border:1px solid var(--ink);
  transition:transform .2s ease,background .2s ease;
}
.nav-cta:hover{background:var(--coral);border-color:var(--coral);transform:translateY(-1px);color:#fff}
@media (max-width:880px){.nav-links{display:none}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-weight:600;font-size:14.5px;letter-spacing:.01em;
  border:1px solid var(--ink);
  transition:all .2s ease;cursor:pointer;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--coral);border-color:var(--coral);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- Hero ---------- */
.hero{padding:90px 0 70px;position:relative;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.35fr .9fr;gap:60px;align-items:end}
.hero h1{font-size:clamp(54px,8.4vw,128px);margin:24px 0 0}
.hero h1 .strike{position:relative;display:inline-block}
.hero h1 .strike::after{
  content:"";position:absolute;left:-4%;right:-4%;top:55%;
  height:14px;background:var(--chart);z-index:-1;transform:rotate(-1.2deg);border-radius:6px;
}
.hero-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:36px}
.hero-meta .chip{border:1px solid var(--ink);padding:7px 14px;border-radius:999px;font-size:13px;font-weight:600;background:var(--paper)}
.hero-meta .chip.filled{background:var(--ink);color:var(--paper)}

.hero-right{position:relative}
.hero-card{
  background:#fff;border:1px solid var(--ink);
  padding:26px 26px 22px;border-radius:4px;
  box-shadow:10px 12px 0 0 var(--ink);
  position:relative;transform:rotate(1.4deg);
}
.hero-card .tape{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%) rotate(-3deg);
  width:120px;height:28px;background:rgba(229,75,44,.55);
  border-left:1px dashed rgba(255,255,255,.5);border-right:1px dashed rgba(255,255,255,.5);
}
.hero-card h3{font-family:"Fraunces",serif;font-weight:500;font-size:22px;margin:0 0 14px;letter-spacing:-.01em}
.hero-card ul{list-style:none;padding:0;margin:0;font-size:14.5px}
.hero-card li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dotted rgba(0,0,0,.25)}
.hero-card li:last-child{border-bottom:0}
.hero-card li b{font-weight:700}
.hero-card .stamp{
  position:absolute;bottom:-26px;right:-22px;
  width:96px;height:96px;border-radius:50%;
  background:var(--coral);color:#fff;
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:"Fraunces",serif;font-style:italic;font-size:15px;line-height:1.05;font-weight:500;
  transform:rotate(-12deg);box-shadow:4px 4px 0 var(--ink);
}
.scribble-arrow{position:absolute;left:-90px;top:38%;width:140px;opacity:.7}
.hero-cta-row{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
@media (max-width:920px){
  .hero{padding:60px 0 50px}
  .hero .wrap{grid-template-columns:1fr;gap:50px}
  .hero-card{transform:none}
  .scribble-arrow{display:none}
}

/* ---------- Marquee ---------- */
.marquee{background:var(--ink);color:var(--paper);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);overflow:hidden;padding:18px 0}
.marquee-track{
  display:flex;gap:48px;white-space:nowrap;
  animation:slide 38s linear infinite;
  font-family:"Fraunces",serif;font-style:italic;font-weight:400;font-size:30px;
}
.marquee-track span{display:inline-flex;align-items:center;gap:48px}
.marquee-track .star{display:inline-block;width:14px;height:14px;background:var(--coral);border-radius:50%}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Section heads ---------- */
.section-head{display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:start;padding:90px 0 30px}
.section-head h2{font-size:clamp(36px,5vw,64px);margin:18px 0 0}
.section-head .lead{font-size:18px;color:var(--ink-soft);max-width:540px;padding-top:14px}
.section-num{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--ink-mute);letter-spacing:.18em}
@media (max-width:820px){.section-head{grid-template-columns:1fr;gap:18px;padding-top:70px}}

/* ---------- Why ---------- */
.why{padding-bottom:30px}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.why-card{background:var(--paper-2);border:1px solid var(--ink);padding:26px 24px 28px;border-radius:4px;position:relative}
.why-card .num{font-family:"Fraunces",serif;font-style:italic;font-size:54px;color:var(--coral);line-height:1;margin-bottom:10px}
.why-card h4{font-family:"Fraunces",serif;font-weight:500;font-size:22px;margin:0 0 8px;letter-spacing:-.01em}
.why-card p{margin:0;color:var(--ink-soft);font-size:15px}
@media (max-width:820px){.why-grid{grid-template-columns:1fr}}

/* ---------- Build / outcomes ---------- */
.build{padding:60px 0 30px;border-top:1px solid var(--ink);margin-top:80px}
.build-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:50px}
.build-card{
  border:1px solid var(--ink);background:#fff;
  padding:22px 22px 24px;border-radius:4px;position:relative;min-height:160px;
  display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .25s ease,box-shadow .25s ease;
}
.build-card:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--ink)}
.build-card .tag{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}
.build-card h5{font-family:"Fraunces",serif;font-weight:500;font-size:21px;margin:14px 0 0;letter-spacing:-.01em;line-height:1.15}
.build-card.size-a{grid-column:span 5;background:var(--chart)}
.build-card.size-b{grid-column:span 4}
.build-card.size-c{grid-column:span 3;background:var(--sky)}
.build-card.size-d{grid-column:span 4}
.build-card.size-e{grid-column:span 4;background:var(--coral);color:#fff}
.build-card.size-e .tag{color:rgba(255,255,255,.85)}
.build-card.size-f{grid-column:span 4}
.build-card.size-g{grid-column:span 5}
.build-card.size-h{grid-column:span 4;background:var(--mustard)}
.build-card.size-i{grid-column:span 3;background:var(--ink);color:var(--paper)}
.build-card.size-i .tag{color:rgba(242,236,223,.7)}
@media (max-width:980px){.build-card{grid-column:span 6 !important}}
@media (max-width:600px){.build-card{grid-column:span 12 !important}}

/* ---------- Curriculum ---------- */
.curriculum{padding:60px 0 30px;border-top:1px solid var(--ink);margin-top:80px}
.session{display:grid;grid-template-columns:120px 1fr 1.2fr;gap:36px;padding:42px 0;border-bottom:1px solid var(--ink);align-items:start}
.session:hover .session-num-big{color:var(--coral)}
.session-num-big{font-family:"Fraunces",serif;font-size:96px;line-height:.9;font-weight:400;transition:color .3s ease}
.session h3{font-family:"Fraunces",serif;font-weight:500;font-size:30px;line-height:1.1;margin:6px 0 12px;letter-spacing:-.01em}
.session .qbox{font-style:italic;color:var(--ink-soft);font-size:15.5px;font-family:"Fraunces",serif;border-left:3px solid var(--coral);padding-left:14px;margin:0}
.session-detail h6{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 8px}
.session-detail p{margin:0 0 16px;font-size:15.5px;color:var(--ink-soft)}
.pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.pill{font-family:"JetBrains Mono",monospace;font-size:11px;border:1px solid var(--ink);padding:4px 10px;border-radius:999px;background:var(--paper)}
@media (max-width:880px){.session{grid-template-columns:1fr;gap:14px;padding:30px 0}.session-num-big{font-size:64px}}

/* ---------- Session shape ---------- */
.shape{padding:90px 0;border-top:1px solid var(--ink);margin-top:80px;background:var(--paper-2)}
.shape-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.shape h2{font-size:clamp(36px,5vw,60px);margin:0 0 20px}
.shape p.lead{font-size:17px;color:var(--ink-soft);max-width:480px}
.timetable{background:#fff;border:1px solid var(--ink);border-radius:4px;overflow:hidden}
.timetable .row{display:grid;grid-template-columns:110px 1fr;gap:0;border-bottom:1px solid var(--ink)}
.timetable .row:last-child{border-bottom:0}
.timetable .t{font-family:"JetBrains Mono",monospace;font-size:12px;background:var(--ink);color:var(--paper);padding:14px 14px;display:flex;align-items:center}
.timetable .d{padding:14px 18px;font-size:15px}
.timetable .d b{font-family:"Fraunces",serif;font-weight:500;font-size:16px;display:block}
@media (max-width:820px){.shape-grid{grid-template-columns:1fr;gap:40px}}

/* ---------- Summer ---------- */
.summer{padding:80px 0;border-top:1px solid var(--ink)}
.summer-card{
  background:var(--ink);color:var(--paper);border-radius:6px;padding:50px 50px 46px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:50px;margin-top:40px;position:relative;overflow:hidden;
}
.summer-card::after{
  content:"SUMMER 2026";position:absolute;right:-30px;bottom:-40px;
  font-family:"Fraunces",serif;font-weight:500;font-style:italic;font-size:160px;
  color:rgba(255,255,255,.05);letter-spacing:-.04em;line-height:1;pointer-events:none;
}
.summer-card h3{font-family:"Fraunces",serif;font-weight:500;font-size:38px;margin:0 0 18px;letter-spacing:-.01em}
.summer-card .small{color:rgba(255,255,255,.7);font-size:15px}
.day-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 22px;font-size:14px;position:relative;z-index:2}
.day-grid .d{display:flex;gap:10px;align-items:baseline;padding:6px 0;border-bottom:1px dotted rgba(255,255,255,.18)}
.day-grid .d span{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--chart);min-width:48px}
@media (max-width:820px){.summer-card{grid-template-columns:1fr;padding:32px 26px}.day-grid{grid-template-columns:1fr}}

/* ---------- Pathway ---------- */
.pathway{padding:90px 0;border-top:1px solid var(--ink)}
.path-track{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px;position:relative}
.path-step{border:1px solid var(--ink);padding:28px;border-radius:4px;background:var(--paper);position:relative}
.path-step.active{background:var(--coral);color:#fff;border-color:var(--coral)}
.path-step .grade{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.7}
.path-step h4{font-family:"Fraunces",serif;font-weight:500;font-size:26px;margin:10px 0 12px;letter-spacing:-.01em;line-height:1.1}
.path-step p{margin:0;font-size:14.5px;line-height:1.5}
.path-step.active p{color:rgba(255,255,255,.92)}
.path-step .arrow{
  position:absolute;right:-22px;top:50%;width:32px;height:32px;transform:translateY(-50%);
  background:var(--paper);border:1px solid var(--ink);border-radius:50%;
  display:flex;align-items:center;justify-content:center;z-index:2;
  font-family:"Fraunces",serif;font-weight:500;
}
.path-step:last-child .arrow{display:none}
@media (max-width:820px){.path-track{grid-template-columns:1fr}.path-step .arrow{display:none}}

/* ---------- Tools ---------- */
.tools{padding:80px 0;border-top:1px solid var(--ink);background:var(--paper-2)}
.tools h2{font-size:clamp(34px,4.5vw,54px);margin:0 0 12px}
.tools .lead{max-width:540px;color:var(--ink-soft);font-size:16.5px;margin:0 0 40px}
.tool-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.tool{
  border:1px solid var(--ink);background:var(--paper);padding:20px 16px;border-radius:4px;text-align:center;
  font-family:"Fraunces",serif;font-weight:500;font-size:17px;transition:all .2s ease;
}
.tool:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.tool .k{display:block;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.16em;color:var(--ink-mute);margin-bottom:6px;text-transform:uppercase}
.tool:hover .k{color:var(--chart)}
@media (max-width:900px){.tool-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.tool-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- FAQ ---------- */
.faq{padding:90px 0;border-top:1px solid var(--ink)}
.faq-list{margin-top:40px;border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--ink)}
.faq-q{
  display:flex;justify-content:space-between;gap:30px;align-items:center;
  padding:24px 4px;cursor:pointer;
  font-family:"Fraunces",serif;font-weight:500;font-size:22px;letter-spacing:-.01em;list-style:none;
}
.faq-q::-webkit-details-marker{display:none}
.faq-q .plus{
  font-family:"JetBrains Mono",monospace;font-size:22px;
  width:32px;height:32px;border:1px solid var(--ink);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .25s ease;
}
details[open] .faq-q .plus{background:var(--coral);color:#fff;border-color:var(--coral);transform:rotate(45deg)}
.faq-a{padding:0 4px 28px;max-width:780px;color:var(--ink-soft);font-size:16px;line-height:1.6}
details[open] .faq-q{color:var(--coral)}

/* ---------- Pricing ---------- */
.pricing{padding:90px 0;border-top:1px solid var(--ink);background:var(--ink);color:var(--paper);overflow:hidden;position:relative}
.pricing::before{content:"";position:absolute;inset:0;background-image:var(--grain);opacity:.5;pointer-events:none;mix-blend-mode:overlay}
.pricing .wrap{position:relative;z-index:2}
.pricing-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.pricing h2{font-size:clamp(40px,5vw,72px);margin:18px 0 18px;color:var(--paper)}
.pricing h2 em{color:var(--chart);font-style:italic}
.pricing .lead{font-size:17px;color:rgba(242,236,223,.78);max-width:480px;margin-bottom:30px}
.price-card{background:var(--paper);color:var(--ink);border-radius:6px;padding:36px 34px;position:relative}
.price-card .ribbon{
  position:absolute;top:-12px;right:24px;background:var(--coral);color:#fff;font-size:11px;
  font-family:"JetBrains Mono",monospace;letter-spacing:.18em;padding:6px 12px;border-radius:3px;text-transform:uppercase;
}
.price-card h3{font-family:"Fraunces",serif;font-weight:500;font-size:24px;margin:0 0 6px;letter-spacing:-.01em}
.price-card .sub{color:var(--ink-mute);font-size:13.5px;margin-bottom:22px}
.price-row{display:flex;align-items:baseline;gap:10px;margin-bottom:22px;border-bottom:1px solid var(--ink);padding-bottom:22px}
.price-old{font-family:"Fraunces",serif;font-size:32px;text-decoration:line-through;color:var(--ink-mute)}
.price-new{font-family:"Fraunces",serif;font-size:64px;font-weight:500;line-height:1;color:var(--coral);letter-spacing:-.02em}
.price-card ul{list-style:none;padding:0;margin:0 0 26px;font-size:14.5px}
.price-card li{padding:6px 0;display:flex;gap:10px;align-items:start}
.price-card li::before{content:"→";color:var(--coral);font-weight:700}
.pricing .btn-primary{background:var(--coral);border-color:var(--coral);color:#fff}
.pricing .btn-primary:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
@media (max-width:820px){.pricing-grid{grid-template-columns:1fr}}

/* ---------- Final CTA ---------- */
.final{padding:120px 0 110px;text-align:center;border-top:1px solid var(--ink)}
.final h2{font-size:clamp(48px,8vw,108px);margin:0 auto;max-width:980px}
.final h2 .scribble{position:relative;display:inline-block}
.final h2 .scribble svg{position:absolute;left:-6%;right:-6%;bottom:-8%;width:112%;height:auto;z-index:-1}
.final p{font-size:17px;color:var(--ink-soft);max-width:580px;margin:30px auto 36px}
.final .hero-cta-row{justify-content:center}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:var(--paper);padding:60px 0 40px;border-top:1px solid var(--ink)}
footer .wrap{max-width:1240px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
footer h6{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(242,236,223,.5);margin:0 0 14px}
footer a{display:block;font-size:14.5px;padding:5px 0;color:rgba(242,236,223,.88)}
footer a:hover{color:var(--chart)}
.foot-brand p{color:rgba(242,236,223,.65);font-size:14px;max-width:300px}
.foot-bottom{
  border-top:1px solid rgba(242,236,223,.15);margin-top:40px;padding-top:24px;
  display:flex;justify-content:space-between;font-size:12.5px;color:rgba(242,236,223,.55);
  font-family:"JetBrains Mono",monospace;letter-spacing:.05em;flex-wrap:wrap;gap:10px;
}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   FORM PAGES — enrollment + schedule-a-call
   ============================================================ */

.page-head{padding:70px 0 50px;position:relative}
.page-head .wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:50px;align-items:end}
.page-head h1{font-size:clamp(48px,7vw,96px);margin:18px 0 0}
.page-head .lead{color:var(--ink-soft);font-size:17.5px;max-width:480px;margin-top:18px}
@media (max-width:880px){.page-head .wrap{grid-template-columns:1fr;gap:30px}}

/* Enrollment summary card */
.summary-card{
  background:#fff;border:1px solid var(--ink);padding:22px;border-radius:4px;
  box-shadow:8px 8px 0 var(--ink);transform:rotate(.6deg);position:relative;
}
.summary-card .tape{position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-2deg);width:110px;height:24px;background:rgba(213,224,74,.7)}
.summary-card h3{font-family:"Fraunces",serif;font-weight:500;font-size:20px;margin:0 0 12px;letter-spacing:-.01em}
.summary-card .price{font-family:"Fraunces",serif;font-size:54px;font-weight:500;color:var(--coral);line-height:1;letter-spacing:-.02em}
.summary-card .price small{display:block;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-mute);letter-spacing:.16em;text-transform:uppercase;margin-top:6px}
.summary-card ul{list-style:none;padding:0;margin:18px 0 0;font-size:13.5px}
.summary-card li{padding:5px 0;border-top:1px dotted rgba(0,0,0,.2);display:flex;justify-content:space-between}
.summary-card li:first-child{border-top:0}
.summary-card li b{font-weight:700}
@media (max-width:880px){.summary-card{transform:none}}

/* Schedule-call sticky note */
.meta-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.meta-pills .chip{border:1px solid var(--ink);padding:7px 14px;border-radius:999px;font-size:13px;font-weight:600;background:var(--paper)}
.meta-pills .chip.filled{background:var(--ink);color:var(--paper)}
.stickynote{
  background:#fff;border:1px solid var(--ink);border-radius:4px;padding:24px 26px 26px;
  box-shadow:8px 8px 0 var(--ink);transform:rotate(-1deg);position:relative;
}
.stickynote .tape{position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(2deg);width:120px;height:24px;background:rgba(229,75,44,.5)}
.stickynote h3{font-family:"Fraunces",serif;font-weight:500;font-size:22px;margin:0 0 14px;letter-spacing:-.01em}
.stickynote ul{list-style:none;padding:0;margin:0;font-size:14.5px;line-height:1.6}
.stickynote li{padding:6px 0;border-top:1px dotted rgba(0,0,0,.2);display:flex;gap:10px;align-items:start}
.stickynote li:first-child{border-top:0}
.stickynote li::before{content:"✓";color:var(--coral);font-weight:700}
@media (max-width:880px){.stickynote{transform:none}}

/* Form layout */
.form-section{padding:30px 0 110px}
.form-wrap{padding:50px 0 110px}
form{max-width:880px;margin:0 auto}
.form-head{text-align:center;margin-bottom:40px}
.form-head h2{font-family:"Fraunces",serif;font-weight:500;font-size:40px;margin:8px 0 10px;letter-spacing:-.02em}
.form-head p{color:var(--ink-soft);font-size:15.5px;max-width:540px;margin:0 auto}

.group{margin-top:54px;border-top:1px solid var(--ink);padding-top:30px}
.group:first-child{margin-top:30px;border-top:0;padding-top:0}
.group-head{display:grid;grid-template-columns:140px 1fr;gap:30px;align-items:start;margin-bottom:24px}
.group-num{font-family:"Fraunces",serif;font-size:54px;line-height:.9;color:var(--coral);letter-spacing:-.02em}
.group-head h2{font-family:"Fraunces",serif;font-weight:500;font-size:30px;margin:0 0 6px;letter-spacing:-.01em;line-height:1.05}
.group-head p{color:var(--ink-soft);font-size:14.5px;margin:0;max-width:520px}
@media (max-width:680px){.group-head{grid-template-columns:1fr;gap:6px}.group-num{font-size:36px}}

.row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:680px){.row{grid-template-columns:1fr}}

.field{margin-bottom:20px;position:relative}
.field label{display:block;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.field label .req{color:var(--coral);font-weight:700;margin-left:3px}
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=number],
.field select,
.field textarea{
  width:100%;background:#fff;border:1px solid var(--ink);border-radius:3px;
  padding:13px 14px;font:inherit;color:var(--ink);
  transition:border-color .15s ease,box-shadow .15s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(229,75,44,.18);
}
.field textarea{min-height:96px;resize:vertical;font-family:inherit}
.field select{
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%2310151B' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;cursor:pointer;
}
.field .hint{font-size:12.5px;color:var(--ink-mute);margin-top:6px}

.radio-grid{display:flex;flex-wrap:wrap;gap:10px}
.radio-grid label{
  display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--ink);
  padding:10px 16px;border-radius:999px;font-family:"Manrope",sans-serif;font-size:14.5px;
  letter-spacing:0;text-transform:none;color:var(--ink);cursor:pointer;margin:0;transition:all .15s ease;
}
.radio-grid label:hover{background:var(--paper-2)}
.radio-grid input{appearance:none;width:16px;height:16px;border:1.5px solid var(--ink);border-radius:50%;margin:0;position:relative;cursor:pointer}
.radio-grid input:checked{background:var(--coral);border-color:var(--coral)}
.radio-grid input:checked::after{content:"";position:absolute;inset:3px;background:#fff;border-radius:50%}
.radio-grid label:has(input:checked){background:var(--ink);color:var(--paper);border-color:var(--ink)}

.checkbox{
  display:flex;gap:12px;align-items:start;background:var(--paper-2);border:1px solid var(--ink);
  padding:16px 18px;border-radius:4px;cursor:pointer;transition:background .15s ease;
}
.checkbox:hover{background:#fff}
.checkbox input{
  appearance:none;width:20px;height:20px;border:1.5px solid var(--ink);background:#fff;
  border-radius:3px;margin:0;flex-shrink:0;cursor:pointer;position:relative;margin-top:1px;
}
.checkbox input:checked{background:var(--coral);border-color:var(--coral)}
.checkbox input:checked::after{content:"";position:absolute;left:5px;top:1px;width:6px;height:11px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.checkbox span{font-size:14.5px;line-height:1.5}
.checkbox a{color:var(--coral);font-weight:600;border-bottom:1px solid var(--coral)}

#otherField{display:none;margin-top:14px;animation:fade .2s ease}
#otherField.show{display:block}
@keyframes fade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

.submit-row{
  margin-top:50px;padding-top:30px;border-top:1px solid var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
}
.form-wrap .submit-row{margin-top:32px;padding-top:0;border-top:0}
.submit-row .note{color:var(--ink-mute);font-size:13px;max-width:380px}
.btn-lg{padding:16px 28px;font-size:15px}

/* Form messages */
.formerror{
  background:#fdecea;border:1px solid var(--coral);color:var(--coral-deep);
  padding:14px 18px;border-radius:4px;font-size:14.5px;margin-bottom:24px;font-weight:600;
}
.success{display:none;background:var(--ink);color:var(--paper);padding:60px 50px;border-radius:6px;text-align:center;position:relative;overflow:hidden}
.success.show{display:block}
.success::before{content:"";position:absolute;inset:0;background-image:var(--grain);opacity:.5;pointer-events:none;mix-blend-mode:overlay}
.success h2{font-family:"Fraunces",serif;font-size:48px;font-weight:500;margin:0 0 14px;letter-spacing:-.02em;position:relative;z-index:2}
.success h2 em{color:var(--chart);font-style:italic}
.success p{color:rgba(242,236,223,.85);font-size:16px;max-width:480px;margin:0 auto 24px;position:relative;z-index:2}
@media (max-width:680px){.success{padding:40px 26px}}

/* ---------- Legal / content pages ---------- */
.legal{padding:40px 0 100px}
.legal .wrap{max-width:820px}
.legal h2{font-family:"Fraunces",serif;font-weight:500;font-size:25px;margin:38px 0 10px;letter-spacing:-.01em}
.legal h2:first-of-type{margin-top:6px}
.legal p,.legal li{font-size:16px;color:var(--ink-soft);line-height:1.65}
.legal ul{padding-left:22px;margin:8px 0}
.legal a{color:var(--coral);font-weight:600}
.legal .updated{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.1em;color:var(--ink-mute);text-transform:uppercase}

/* ---------- Blog list ---------- */
.blog-list{padding:20px 0 90px}
.blog-list .wrap{max-width:880px}
.post-card{border-bottom:1px solid var(--ink);padding:32px 0;display:block;color:inherit}
.post-card:last-child{border-bottom:0}
.post-card .pdate{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.post-card h2{font-family:"Fraunces",serif;font-weight:500;font-size:30px;margin:8px 0 10px;letter-spacing:-.01em;line-height:1.12}
.post-card:hover h2{color:var(--coral)}
.post-card p{margin:0;color:var(--ink-soft);font-size:16px}
.post-card .more{display:inline-block;margin-top:10px;font-weight:600;color:var(--coral);font-size:14px}
.blog-empty{padding:50px 0 80px;color:var(--ink-mute);font-size:16px}

/* ---------- Single post ---------- */
.post{padding:46px 0 90px}
.post .wrap{max-width:760px}
.post .pmeta{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:12px}
.post h1{font-size:clamp(34px,5.2vw,58px);margin:0 0 26px}
.post-body{font-size:17px;line-height:1.75;color:var(--ink-soft)}
.post-body h2{font-family:"Fraunces",serif;font-weight:500;font-size:28px;color:var(--ink);margin:36px 0 12px;letter-spacing:-.01em}
.post-body h3{font-family:"Fraunces",serif;font-weight:500;font-size:22px;color:var(--ink);margin:28px 0 10px}
.post-body p{margin:0 0 18px}
.post-body ul,.post-body ol{margin:0 0 18px;padding-left:24px}
.post-body li{margin:6px 0}
.post-body a{color:var(--coral);font-weight:600}
.post-body img{border-radius:6px;margin:18px 0}
.post-body blockquote{border-left:3px solid var(--coral);margin:18px 0;padding:4px 0 4px 18px;font-family:"Fraunces",serif;font-style:italic;font-size:19px;color:var(--ink)}
.post-cta{margin-top:46px;padding:30px;background:var(--ink);color:var(--paper);border-radius:8px;text-align:center}
.post-cta h3{font-family:"Fraunces",serif;font-weight:500;font-size:24px;margin:0 0 16px;color:var(--paper)}
.post-back{display:inline-block;margin-top:30px;font-size:14px;color:var(--coral);font-weight:600}
