/* ============================================================
   L TONTON STUDIO — original site styles
   Palette: noir profond / orange brûlé / ivoire
   ============================================================ */
:root{
  --ink:#0a0807;
  --ink-2:#15110f;
  --ink-3:#1f1916;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.18);
  --paper:#f4ede2;
  --paper-2:#ece2d2;
  --orange:#ff7a18;
  --orange-2:#ffa14a;
  --orange-deep:#c54a00;
  --text:#1a1512;
  --text-soft:#6b5e54;
  --on-dark:#f8efe2;
  --on-dark-soft:rgba(248,239,226,.65);
  --ring:rgba(255,122,24,.35);
  --r-lg:22px;
  --r-md:14px;
  --r-sm:8px;
  --container:1240px;
  --grad-orange:linear-gradient(135deg,#ff7a18 0%,#ff9d3a 60%,#ffb764 100%);
  --grad-ink:radial-gradient(120% 80% at 50% 0%, #221814 0%, #0a0807 60%);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--paper);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
  cursor:none;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
em{font-family:"Playfair Display",serif;font-style:italic;font-weight:600;color:var(--orange-deep)}
.container{max-width:var(--container);margin:0 auto;padding:0 28px}

/* ----- Custom cursor ----- */
.cursor-dot,.cursor-ring,.cursor-label{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
}
.cursor-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);
  transition:transform .15s ease,opacity .2s;mix-blend-mode:difference;}
.cursor-ring{width:40px;height:40px;border:1.5px solid var(--orange);border-radius:50%;
  transition:width .25s,height .25s,border-color .25s,background .25s,opacity .25s;}
.cursor-ring.is-hover{width:90px;height:90px;background:var(--orange);border-color:var(--orange);}
.cursor-ring.is-section{width:120px;height:120px;background:transparent;border-color:var(--orange);opacity:.6}
.cursor-label{
  font-family:"Bebas Neue",sans-serif;letter-spacing:.05em;font-size:13px;
  color:#fff;background:transparent;padding:0;opacity:0;transition:opacity .2s;
  white-space:nowrap;font-weight:600;
}
.cursor-label.is-on{opacity:1}
@media (max-width:900px){
  body{cursor:auto}
  .cursor-dot,.cursor-ring,.cursor-label{display:none}
}

/* ----- Buttons ----- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 22px;border-radius:999px;font-weight:600;font-size:14px;
  border:1px solid transparent;cursor:none;transition:transform .25s,background .25s,color .25s,box-shadow .25s;
  letter-spacing:.01em;
}
.btn--lg{padding:18px 28px;font-size:15px}
.btn--block{display:flex;width:100%}
.btn--orange{background:var(--grad-orange);color:#1a0c00;box-shadow:0 10px 30px -10px rgba(255,122,24,.6)}
.btn--orange:hover{transform:translateY(-2px);box-shadow:0 14px 40px -10px rgba(255,122,24,.8)}
.btn--white{background:#fff;color:var(--ink)}
.btn--white:hover{transform:translateY(-2px)}
.btn--ghost{background:transparent;border-color:var(--line-strong);color:var(--on-dark)}
.btn--ghost:hover{background:rgba(255,255,255,.08)}

/* ----- Navigation ----- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:14px 28px;background:rgba(10,8,7,.78);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);color:var(--on-dark);
}
.nav__logo{display:flex;align-items:center;gap:10px;font-family:"Bebas Neue",sans-serif;font-size:20px;letter-spacing:.08em}
.nav__logo img{width:36px;height:36px;border-radius:6px;object-fit:cover;background:#fff}
.nav__logo em{color:var(--orange);font-family:"Bebas Neue",sans-serif;font-style:normal}
.nav__links{display:flex;gap:6px}
.nav__links a{
  padding:10px 14px;border-radius:999px;font-size:14px;font-weight:500;color:var(--on-dark-soft);
  transition:color .2s,background .2s;
}
.nav__links a:hover,.nav__links a.is-active{color:var(--on-dark);background:rgba(255,255,255,.06)}
.nav__cta{padding:11px 18px;font-size:13px}
.nav__burger{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:none}
.nav__burger span{width:22px;height:2px;background:var(--on-dark);display:block}
@media (max-width:960px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__links.is-open{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--ink);padding:20px;border-bottom:1px solid var(--line);
  }
}

/* ----- Eyebrow / section title ----- */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:"Bebas Neue",sans-serif;letter-spacing:.18em;
  font-size:13px;color:var(--orange);margin:0 0 14px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--orange)}
.section-title{
  font-family:"Bebas Neue",sans-serif;letter-spacing:.01em;
  font-size:clamp(34px,5vw,64px);line-height:1.02;margin:0 0 18px;font-weight:400;
}
.lead{font-size:17px;line-height:1.6;color:var(--text-soft);max-width:62ch}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;background:var(--grad-ink);color:var(--on-dark);
  padding:100px 28px 80px;overflow:hidden;isolation:isolate;
}
.hero__bg{
  position:absolute;inset:0;z-index:0;overflow:hidden;
  background:
    radial-gradient(60% 50% at 80% 30%, rgba(255,122,24,.25), transparent 70%),
    radial-gradient(40% 40% at 10% 80%, rgba(255,122,24,.18), transparent 70%);
}
.hero__photo{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center 30%;
  opacity:.32;
  filter:grayscale(.15) contrast(1.1) saturate(1.05);
  mix-blend-mode:luminosity;
  transform:scale(1.04);
  animation:heroDrift 18s ease-in-out infinite alternate;
}
.hero__veil{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(10,8,7,.92) 0%, rgba(10,8,7,.65) 45%, rgba(10,8,7,.35) 70%, rgba(10,8,7,.7) 100%),
    linear-gradient(180deg, rgba(10,8,7,.4) 0%, transparent 30%, transparent 70%, rgba(10,8,7,.9) 100%);
}
@keyframes heroDrift{
  from{transform:scale(1.04) translate(0,0)}
  to  {transform:scale(1.1)  translate(-1.5%, -1%)}
}
.hero__grain{
  position:absolute;inset:0;opacity:.08;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>");
}
.hero__content{position:relative;z-index:2;max-width:var(--container);margin:0 auto}
.hero__pill{
  display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;
  border:1px solid var(--line-strong);font-size:13px;color:var(--on-dark-soft);
  background:rgba(255,255,255,.03);
}
.hero__pill .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(255,122,24,.2)}
.hero__title{
  font-family:"Bebas Neue",sans-serif;font-weight:400;letter-spacing:.005em;
  font-size:clamp(54px,9vw,140px);line-height:.92;margin:24px 0 24px;
}
.hero__title .line{display:block}
.hero__title .line--accent{color:var(--orange);font-family:"Playfair Display",serif;font-style:italic;font-weight:500}
.hero__sub{max-width:60ch;font-size:18px;line-height:1.55;color:var(--on-dark-soft);margin:0 0 32px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:60px}
.hero__meta{display:flex;gap:48px;flex-wrap:wrap}
.hero__meta>div{display:flex;flex-direction:column}
.hero__meta strong{font-family:"Bebas Neue",sans-serif;font-size:48px;color:var(--on-dark);line-height:1}
.hero__meta span{font-size:13px;color:var(--on-dark-soft);margin-top:4px}
.hero__marquee{
  position:absolute;bottom:0;left:0;right:0;overflow:hidden;
  border-top:1px solid var(--line);padding:18px 0;
  font-family:"Bebas Neue",sans-serif;font-size:22px;letter-spacing:.1em;color:rgba(255,255,255,.45);
}
.marquee{display:flex;gap:36px;white-space:nowrap;animation:marquee 40s linear infinite}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   REFS
   ============================================================ */
.refs{padding:90px 0;background:var(--paper)}
.refs__grid{
  margin-top:40px;display:grid;
  grid-template-columns:repeat(6,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
}
.ref-logo{
  background:var(--paper);
  padding:34px 12px;text-align:center;
  font-family:"Bebas Neue",sans-serif;letter-spacing:.1em;font-size:18px;
  color:var(--text-soft);transition:background .25s,color .25s,transform .25s;
}
.ref-logo:hover{background:#fff;color:var(--ink);transform:scale(1.04)}
@media (max-width:900px){.refs__grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.refs__grid{grid-template-columns:repeat(2,1fr)}}

/* ============================================================
   SERVICES
   ============================================================ */
.services{padding:120px 0;background:var(--ink);color:var(--on-dark);position:relative}
.services .section-title em{color:var(--orange-2)}
.services__grid{margin-top:60px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.service{
  position:relative;padding:34px 26px 30px;border-radius:var(--r-lg);
  background:var(--ink-2);border:1px solid var(--line);
  transition:transform .35s,background .35s,border-color .35s;
}
.service::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(160deg,rgba(255,122,24,.18),transparent 60%);
  opacity:0;transition:opacity .35s;pointer-events:none;
}
.service:hover{transform:translateY(-6px);background:var(--ink-3);border-color:var(--orange-deep)}
.service:hover::after{opacity:1}
.service--hl{background:linear-gradient(180deg,#2a1206,#1a0d07);border-color:rgba(255,122,24,.35)}
.service__num{
  font-family:"Bebas Neue",sans-serif;font-size:14px;letter-spacing:.18em;
  color:var(--orange);margin-bottom:18px;
}
.service h3{font-family:"Bebas Neue",sans-serif;font-size:32px;letter-spacing:.02em;margin:0 0 12px;font-weight:400}
.service p{margin:0 0 16px;color:var(--on-dark-soft);font-size:15px;line-height:1.55}
.service ul{list-style:none;padding:0;margin:0;border-top:1px solid var(--line);padding-top:16px}
.service li{font-size:13px;padding:6px 0;color:var(--on-dark-soft);display:flex;gap:8px;align-items:center}
.service li::before{content:"●";color:var(--orange);font-size:8px}
@media (max-width:1000px){.services__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:580px){.services__grid{grid-template-columns:1fr}}

/* ============================================================
   WHY
   ============================================================ */
.why{padding:120px 0;background:var(--paper-2)}
.why__inner{display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center}
.why__media{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;background:var(--ink)}
.why__media img{width:100%;height:100%;object-fit:cover;filter:saturate(1.1)}
.why__badge{
  position:absolute;left:18px;bottom:18px;padding:14px 18px;border-radius:var(--r-md);
  background:rgba(10,8,7,.85);color:var(--on-dark);font-family:"Bebas Neue",sans-serif;
  letter-spacing:.06em;backdrop-filter:blur(8px);
}
.why__badge strong{display:block;font-size:22px}
.why__badge span{font-size:12px;color:var(--orange)}
.why__list{margin:24px 0 32px;display:grid;gap:18px}
.why__item{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
.why__item span{
  font-family:"Bebas Neue",sans-serif;font-size:14px;color:var(--orange);
  border:1px solid var(--orange);border-radius:50%;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
}
.why__item strong{display:block;font-size:17px;margin-bottom:4px}
.why__item p{margin:0;color:var(--text-soft);font-size:14px;line-height:1.55}
@media (max-width:900px){.why__inner{grid-template-columns:1fr;gap:50px}}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.portfolio{padding:120px 0;background:var(--ink);color:var(--on-dark)}
.portfolio .section-title em{color:var(--orange-2)}
.portfolio__filters{margin:28px 0 36px;display:flex;flex-wrap:wrap;gap:8px}
.chip{
  padding:10px 18px;border-radius:999px;border:1px solid var(--line-strong);
  background:transparent;color:var(--on-dark-soft);font-size:13px;cursor:none;font-weight:500;
  transition:background .2s,color .2s,border-color .2s;
}
.chip:hover{color:var(--on-dark)}
.chip.is-active{background:var(--orange);color:#1a0c00;border-color:var(--orange)}
.portfolio__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  grid-auto-rows:240px;grid-auto-flow:dense;
}
.portfolio__cell{
  position:relative;overflow:hidden;border-radius:var(--r-md);background:var(--ink-2);
  transition:transform .35s;
}
.portfolio__cell img{width:100%;height:100%;object-fit:cover;transition:transform .8s,filter .35s;filter:saturate(.95)}
.portfolio__cell:hover img{transform:scale(1.06);filter:saturate(1.2)}
.portfolio__cell::after{
  content:attr(data-cat);position:absolute;left:14px;bottom:14px;
  background:rgba(10,8,7,.7);padding:6px 12px;border-radius:999px;
  font-family:"Bebas Neue",sans-serif;letter-spacing:.1em;font-size:12px;color:var(--on-dark);
  opacity:0;transform:translateY(8px);transition:opacity .25s,transform .25s;
}
.portfolio__cell:hover::after{opacity:1;transform:translateY(0)}
.portfolio__cell.tall{grid-row:span 2}
.portfolio__cell.wide{grid-column:span 2}
@media (max-width:1000px){.portfolio__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.portfolio__grid{grid-template-columns:1fr;grid-auto-rows:280px}.portfolio__cell.wide,.portfolio__cell.tall{grid-column:auto;grid-row:auto}}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{padding:120px 0;background:var(--paper)}
.testi__grid{margin-top:50px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.t{
  margin:0;padding:26px;border-radius:var(--r-lg);background:#fff;border:1px solid rgba(0,0,0,.06);
  display:flex;flex-direction:column;gap:18px;transition:transform .3s,box-shadow .3s;
}
.t:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(0,0,0,.18)}
.t p{margin:0;font-size:15px;line-height:1.55;color:var(--text)}
.t footer{display:block;font-size:13px}
.t footer strong{display:block;color:var(--ink)}
.t footer span{color:var(--text-soft)}
.t--hl{background:var(--ink);color:var(--on-dark);border-color:transparent}
.t--hl p{color:var(--on-dark)}
.t--hl footer strong{color:var(--orange)}
.t--hl footer span{color:var(--on-dark-soft)}
@media (max-width:1000px){.testi__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.testi__grid{grid-template-columns:1fr}}

/* ============================================================
   PRICING
   ============================================================ */
.pricing{padding:120px 0;background:var(--paper-2)}
.pricing__grid{margin-top:50px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.plan{
  position:relative;background:#fff;border-radius:var(--r-lg);padding:32px 28px;
  border:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;gap:18px;
  transition:transform .3s,box-shadow .3s;
}
.plan:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(0,0,0,.25)}
.plan header h3{font-family:"Bebas Neue",sans-serif;font-size:30px;letter-spacing:.04em;margin:0;font-weight:400}
.plan header span{color:var(--text-soft);font-size:13px}
.plan__price{display:flex;align-items:baseline;gap:8px}
.plan__price strong{font-family:"Bebas Neue",sans-serif;font-size:56px;line-height:1;color:var(--ink)}
.plan__price span{font-size:14px;color:var(--text-soft)}
.plan ul{list-style:none;padding:0;margin:0;border-top:1px solid rgba(0,0,0,.06);padding-top:16px;display:grid;gap:8px}
.plan li{font-size:14px;color:var(--text);display:flex;gap:10px;align-items:center}
.plan li::before{content:"✓";color:var(--orange);font-weight:700}
.plan--featured{background:var(--ink);color:var(--on-dark);border-color:transparent}
.plan--featured .plan__price strong,.plan--featured header h3{color:var(--on-dark)}
.plan--featured .plan__price span,.plan--featured header span{color:var(--on-dark-soft)}
.plan--featured ul{border-color:var(--line)}
.plan--featured li{color:var(--on-dark-soft)}
.plan__tag{
  position:absolute;top:18px;right:18px;background:var(--orange);color:#1a0c00;
  padding:6px 12px;border-radius:999px;font-family:"Bebas Neue",sans-serif;letter-spacing:.08em;font-size:11px;
}
@media (max-width:900px){.pricing__grid{grid-template-columns:1fr}}

/* ============================================================
   FAQ
   ============================================================ */
.faq{padding:120px 0;background:var(--paper)}
.faq__inner{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:start}
.faq__list{display:grid;gap:10px}
.faq__list details{
  background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--r-md);
  padding:18px 22px;transition:background .25s;
}
.faq__list details[open]{background:var(--ink);color:var(--on-dark);border-color:transparent}
.faq__list summary{
  cursor:none;font-weight:600;font-size:15px;display:flex;justify-content:space-between;align-items:center;list-style:none;
}
.faq__list summary::-webkit-details-marker{display:none}
.faq__list summary::after{content:"+";font-size:22px;color:var(--orange);transition:transform .25s}
.faq__list details[open] summary::after{content:"−"}
.faq__list p{margin:14px 0 0;color:var(--on-dark-soft);font-size:14px;line-height:1.6}
.faq__list details:not([open]) p{display:none}
@media (max-width:900px){.faq__inner{grid-template-columns:1fr}}

/* ============================================================
   CTA
   ============================================================ */
.cta{padding:120px 0;background:var(--grad-ink);color:var(--on-dark);text-align:center;position:relative;overflow:hidden}
.cta::before{
  content:"";position:absolute;inset:-50%;
  background:radial-gradient(40% 40% at 50% 50%, rgba(255,122,24,.3), transparent 70%);
  animation:pulse 6s ease-in-out infinite;
}
@keyframes pulse{50%{transform:scale(1.15)}}
.cta__inner{position:relative;z-index:2}
.cta h2{font-family:"Bebas Neue",sans-serif;font-size:clamp(40px,7vw,92px);margin:0 0 16px;font-weight:400;line-height:1}
.cta p{color:var(--on-dark-soft);margin:0 0 28px;font-size:17px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#060504;color:var(--on-dark);padding:80px 0 30px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:50px;padding-bottom:50px;border-bottom:1px solid var(--line)}
.footer h4{font-family:"Bebas Neue",sans-serif;letter-spacing:.1em;font-size:16px;color:var(--orange);margin:0 0 16px}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer a{color:var(--on-dark-soft);font-size:14px;transition:color .2s}
.footer a:hover{color:var(--orange)}
.footer p{color:var(--on-dark-soft);font-size:14px;line-height:1.6;margin:12px 0 0;max-width:30ch}
.socials{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.socials a{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--line-strong);
  display:inline-flex;align-items:center;justify-content:center;font-family:"Bebas Neue",sans-serif;font-size:13px;
}
.socials a:hover{background:var(--orange);color:#1a0c00;border-color:var(--orange)}
.footer__bottom{display:flex;justify-content:space-between;padding-top:24px;font-size:12px;color:var(--on-dark-soft)}
@media (max-width:900px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer__grid{grid-template-columns:1fr};.footer__bottom{flex-direction:column;gap:8px;text-align:center}}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-hero{background:var(--grad-ink);color:var(--on-dark);padding:90px 0 70px}
.contact-hero h1{font-family:"Bebas Neue",sans-serif;font-size:clamp(50px,8vw,120px);margin:14px 0 18px;font-weight:400;line-height:1}
.contact-grid{padding:80px 0;background:var(--paper)}
.contact-grid__inner{display:grid;grid-template-columns:1.4fr 1fr;gap:40px}
.contact-form{
  background:#fff;padding:32px;border-radius:var(--r-lg);border:1px solid rgba(0,0,0,.06);
  display:grid;gap:16px;
}
.field{display:grid;gap:6px}
.field label{font-size:13px;color:var(--text-soft);font-weight:500}
.field input,.field select,.field textarea,
.book__form input,.book__form select,.book__form textarea{
  width:100%;padding:12px 14px;border:1px solid rgba(0,0,0,.12);border-radius:10px;font:inherit;color:var(--text);
  background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;cursor:none;
}
.field input:focus,.field select:focus,.field textarea:focus,
.book__form input:focus,.book__form select:focus,.book__form textarea:focus{
  border-color:var(--orange);box-shadow:0 0 0 4px var(--ring);
}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form__status{margin:0;font-size:13px;color:var(--orange-deep);min-height:1em}
.contact-side{display:grid;gap:14px;align-content:start}
.contact-card{background:#fff;padding:22px;border-radius:var(--r-md);border:1px solid rgba(0,0,0,.06)}
.contact-card h3{font-family:"Bebas Neue",sans-serif;font-size:18px;letter-spacing:.08em;margin:0 0 8px;color:var(--orange-deep)}
.contact-card p{margin:0;font-size:14px;color:var(--text);line-height:1.55}
.contact-card--accent{background:var(--ink);color:var(--on-dark);border-color:transparent}
.contact-card--accent h3{color:var(--orange)}
@media (max-width:900px){.contact-grid__inner{grid-template-columns:1fr}.row{grid-template-columns:1fr}}

/* ============================================================
   BOOK PAGE
   ============================================================ */
.book-page{background:var(--paper-2)}
.book{padding:60px 0 100px}
.book__inner{max-width:980px;margin:0 auto}
.book__head{text-align:center;padding:30px 0 50px}
.book__head h1{font-family:"Bebas Neue",sans-serif;font-size:clamp(40px,6vw,80px);margin:10px 0 12px;font-weight:400;line-height:1}
.book__head .lead{margin:0 auto}
.book__form{display:grid;gap:24px;background:#fff;border-radius:var(--r-lg);padding:34px;border:1px solid rgba(0,0,0,.06)}
.book__group{border:0;padding:0;margin:0;display:grid;gap:14px}
.book__group legend{
  font-family:"Bebas Neue",sans-serif;font-size:20px;letter-spacing:.06em;
  color:var(--orange-deep);padding:0;margin-bottom:4px;
}
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.opt{
  position:relative;border:1.5px solid rgba(0,0,0,.1);border-radius:var(--r-md);padding:18px 18px 18px 48px;
  cursor:none;transition:border-color .25s,background .25s;display:block;
}
.opt input{position:absolute;left:18px;top:22px;accent-color:var(--orange)}
.opt strong{display:block;color:var(--ink);font-size:15px;margin-bottom:4px}
.opt span{color:var(--text-soft);font-size:13px;line-height:1.5}
.opt:has(input:checked){border-color:var(--orange);background:#fff7ef}
.opt-row{display:flex;flex-wrap:wrap;gap:10px}
.opt--pill{padding:10px 18px 10px 38px}
.opt--pill input{left:14px;top:13px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field--full{grid-column:1 / -1}
.field small{font-size:12px;color:var(--orange-deep)}
.book__summary{background:#fff7ef;border:1px dashed rgba(255,122,24,.4);border-radius:var(--r-md);padding:22px}
.muted{color:var(--text-soft);margin:0 0 14px;font-size:13px}
.summary{list-style:none;padding:0;margin:0 0 12px;display:grid;gap:8px;font-size:14px}
.summary li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed rgba(0,0,0,.08)}
.summary li:last-child{border-bottom:0}
.summary--incl li b{color:var(--orange-deep);font-weight:600}
.total{
  display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-radius:var(--r-md);
  background:var(--ink);color:var(--on-dark);margin-top:14px;
}
.total strong{font-family:"Bebas Neue",sans-serif;font-size:26px;color:var(--orange)}
.legal{font-size:12px;color:var(--orange-deep);line-height:1.55;text-align:center;margin:0}
.book__ok{margin-top:18px;padding:24px;background:#0a3a1a;color:#dff7e3;border-radius:var(--r-md);text-align:center}
.book__ok h3{margin:0 0 6px}
@media (max-width:700px){.opt-grid,.grid-2{grid-template-columns:1fr}}

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