/* ============================================================
   BOOK DESIGN CO — bookdesignco.com
   Design system: warm ink black + paper cream + logo tri-color
   Display: Fraunces · Body: Source Sans 3
   ============================================================ */

:root{
  --ink:#0c0b09;          /* warm ink black background */
  --ink-2:#14120e;        /* raised surface */
  --card:#1a1712;         /* cards */
  --paper:#f4efe6;        /* cream paper text */
  --muted:#a99f8f;        /* secondary text */
  --line:rgba(244,239,230,.13);

  --flame:#f05123;        /* logo red-orange droplet */
  --amber:#f59e0b;        /* logo orange droplet */
  --leaf:#7cb518;         /* logo green droplet */

  --display:"Fraunces",Georgia,serif;
  --body:"Source Sans 3",-apple-system,Segoe UI,Roboto,sans-serif;

  --max:1180px;
  --r:14px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}

/* ---------- Typography ---------- */
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5.6vw,4.3rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h3{font-size:1.25rem}
.eyebrow{
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--amber);font-weight:600;display:flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--flame),var(--amber),var(--leaf))}
.lede{color:var(--muted);font-size:1.08rem;max-width:62ch}

/* ---------- Tri-droplet brand mark ---------- */
.drops{display:inline-flex;gap:5px;align-items:center;vertical-align:middle}
.drops i{width:9px;height:13px;border-radius:50% 50% 50% 0;display:inline-block;transform:rotate(-45deg)}
.drops i:nth-child(1){background:var(--flame)}
.drops i:nth-child(2){background:var(--amber)}
.drops i:nth-child(3){background:var(--leaf)}

/* ---------- Header ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(12,11,9,.88);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo img{height:34px;width:auto}
.nav ul{display:flex;gap:30px;align-items:center}
.nav ul a{font-size:.95rem;color:var(--muted);transition:color .2s}
.nav ul a:hover,.nav ul a.active{color:var(--paper)}
.nav ul a.btn-flame{color:#ffffff}
.nav ul a.btn-flame:hover{color:#ffffff}
.btn{
  display:inline-block;padding:13px 26px;border-radius:999px;
  font-weight:600;font-size:.95rem;transition:transform .15s,box-shadow .2s;
  border:none;cursor:pointer;
}
.btn-flame{background:linear-gradient(100deg,var(--flame),var(--amber));color:#ffffff !important;font-weight:700;text-shadow:none;-webkit-font-smoothing:antialiased}
.btn-flame:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(240,81,35,.35)}
.btn-ghost{border:1px solid var(--line);color:var(--paper)}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber)}
.burger{display:none;background:none;border:none;color:var(--paper);font-size:1.7rem;cursor:pointer}

/* ---------- Hero ---------- */
.hero{padding:110px 0 80px;position:relative;overflow:hidden}
.hero::after{
  content:"";position:absolute;right:-180px;top:-120px;width:560px;height:560px;
  background:radial-gradient(circle,rgba(240,81,35,.14),transparent 65%);pointer-events:none;
}
.hero .eyebrow{justify-content:flex-start;margin-bottom:1.2rem}
.hero h1 em{font-style:italic;color:var(--amber)}
.hero p{margin:1.4rem 0 2.2rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- Stats strip ---------- */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-2)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:34px 22px}
.stat b{font-family:var(--display);font-size:2rem;display:block}
.stat:nth-child(1) b{color:var(--flame)}
.stat:nth-child(2) b{color:var(--amber)}
.stat:nth-child(3) b{color:var(--leaf)}
.stat:nth-child(4) b{color:var(--paper)}
.stat span{color:var(--muted);font-size:.92rem}

/* ---------- Sections ---------- */
section{padding:90px 0}
.sec-head{margin-bottom:48px;display:flex;flex-direction:column;gap:14px}

/* ---------- Packages ---------- */
.packs{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pack{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:30px 26px;display:flex;flex-direction:column;gap:14px;position:relative;
  transition:transform .2s,border-color .2s;
}
.pack:hover{transform:translateY(-5px);border-color:rgba(245,158,11,.5)}
.pack.featured{border-color:var(--amber);background:linear-gradient(180deg,rgba(245,158,11,.07),var(--card))}
.pack .tag{
  position:absolute;top:-13px;left:24px;background:var(--amber);color:#1a1200;
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;
}
.pack h3{font-size:1.1rem}
.pack .price{font-family:var(--display);font-size:2.3rem}
.pack .price small{font-size:.95rem;color:var(--muted);font-family:var(--body)}
.pack .time{font-size:.85rem;color:var(--leaf);font-weight:600}
.pack ul{display:flex;flex-direction:column;gap:9px;flex:1}
.pack li{font-size:.93rem;color:var(--muted);padding-left:22px;position:relative}
.pack li::before{content:"✓";position:absolute;left:0;color:var(--leaf);font-weight:700}
.pack .btn{text-align:center;margin-top:8px}

/* ---------- Services grid ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:26px;transition:border-color .2s,transform .2s;
}
.svc:hover{border-color:rgba(124,181,24,.5);transform:translateY(-4px)}
.svc .ico{font-size:1.6rem;margin-bottom:12px}
.svc h3{margin-bottom:8px;font-size:1.05rem}
.svc p{color:var(--muted);font-size:.92rem;margin-bottom:14px}
.svc .sp{display:flex;justify-content:space-between;align-items:center}
.svc .sp b{font-family:var(--display);font-size:1.35rem;color:var(--amber)}
.svc .sp a{font-size:.85rem;color:var(--paper);border-bottom:1px solid var(--amber)}

/* ---------- Process (the three droplets as stages) ---------- */
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{padding:28px;border:1px solid var(--line);border-radius:var(--r);background:var(--ink-2)}
.step .dot{width:14px;height:20px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);margin-bottom:18px}
.step:nth-child(1) .dot{background:var(--flame)}
.step:nth-child(2) .dot{background:var(--amber)}
.step:nth-child(3) .dot{background:var(--leaf)}
.step h3{margin-bottom:10px}
.step p{color:var(--muted);font-size:.95rem}

/* ---------- Portfolio ---------- */
.folio{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.shelf{
  aspect-ratio:3/2;border-radius:10px;border:1px solid var(--line);
  background:linear-gradient(160deg,var(--card),var(--ink-2));
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:.85rem;text-align:center;padding:14px;
  transition:transform .2s,border-color .2s;overflow:hidden;
}
.shelf img{width:100%;height:100%;object-fit:cover}
.shelf:hover{transform:translateY(-5px) rotate(-.5deg);border-color:var(--amber)}

/* ---------- Reviews slider ---------- */
.reviews{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.slider{overflow:hidden;position:relative}
.track{display:flex;gap:18px;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.review{
  min-width:calc(33.333% - 12px);background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:26px;display:flex;flex-direction:column;gap:14px;
}
.review .stars{color:var(--amber);letter-spacing:3px}
.review p{color:var(--paper);font-size:.95rem;font-style:italic}
.review .who{color:var(--muted);font-size:.85rem}
.slider-nav{display:flex;gap:10px;justify-content:center;margin-top:28px}
.slider-nav button{
  width:44px;height:44px;border-radius:50%;border:1px solid var(--line);
  background:none;color:var(--paper);font-size:1.1rem;cursor:pointer;transition:all .2s;
}
.slider-nav button:hover{border-color:var(--amber);color:var(--amber)}

/* ---------- Platforms ---------- */
.plats{display:flex;flex-wrap:wrap;gap:12px}
.plat{
  border:1px solid var(--line);border-radius:999px;padding:10px 22px;
  color:var(--muted);font-size:.92rem;font-weight:600;background:var(--ink-2);
}

/* ---------- Tools teaser ---------- */
.tools{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tool{
  border:1px dashed rgba(245,158,11,.4);border-radius:var(--r);padding:28px;
  background:linear-gradient(180deg,rgba(245,158,11,.04),transparent);
}
.tool .soon{
  display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--leaf);border:1px solid var(--leaf);
  border-radius:999px;padding:3px 10px;margin-bottom:14px;
}
.tool h3{margin-bottom:8px}
.tool p{color:var(--muted);font-size:.92rem}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(110deg,rgba(240,81,35,.16),rgba(245,158,11,.1),rgba(124,181,24,.1));
  border:1px solid var(--line);border-radius:20px;padding:60px 40px;text-align:center;
}
.cta-band h2{margin-bottom:14px}
.cta-band p{color:var(--muted);margin-bottom:28px}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);background:var(--ink-2);padding:60px 0 30px}
.f-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
.f-grid img{height:30px;margin-bottom:16px}
.f-grid p{color:var(--muted);font-size:.9rem}
.f-grid h4{font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--paper);margin-bottom:14px}
.f-grid ul{display:flex;flex-direction:column;gap:9px}
.f-grid ul a{color:var(--muted);font-size:.92rem}
.f-grid ul a:hover{color:var(--amber)}
.f-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;color:var(--muted);font-size:.85rem;flex-wrap:wrap;gap:10px}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{padding:80px 0 50px;border-bottom:1px solid var(--line)}
.page-hero .eyebrow{margin-bottom:1rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed;bottom:24px;left:24px;z-index:60;
  width:56px;height:56px;border-radius:50%;background:#25d366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(0,0,0,.4);transition:transform .2s;
}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .packs{grid-template-columns:repeat(2,1fr)}
  .svc-grid,.process,.tools{grid-template-columns:repeat(2,1fr)}
  .folio{grid-template-columns:repeat(2,1fr)}
  .review{min-width:calc(50% - 9px)}
  .f-grid{grid-template-columns:1fr 1fr}
  .stats .wrap{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .nav ul{
    display:none;position:absolute;top:74px;left:0;right:0;
    background:var(--ink);border-bottom:1px solid var(--line);
    flex-direction:column;padding:24px;gap:18px;
  }
  .nav ul.open{display:flex}
  .burger{display:block}
  .packs,.svc-grid,.process,.tools{grid-template-columns:1fr}
  .folio{grid-template-columns:1fr}
  .review{min-width:100%}
  .f-grid{grid-template-columns:1fr}
  .hero{padding:70px 0 60px}
  section{padding:64px 0}
}


/* ---------- Lead capture popup ---------- */
.popup-overlay{
  position:fixed;inset:0;background:rgba(5,4,3,.78);backdrop-filter:blur(4px);
  z-index:80;display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;transition:opacity .35s;
}
.popup-overlay.show{opacity:1;pointer-events:auto}
.popup{
  background:var(--card);border:1px solid rgba(245,158,11,.45);border-radius:18px;
  max-width:480px;width:100%;padding:38px 34px;position:relative;
  transform:translateY(24px) scale(.97);transition:transform .35s;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.popup-overlay.show .popup{transform:none}
.popup .px{
  position:absolute;top:14px;right:16px;background:none;border:none;
  color:var(--muted);font-size:1.5rem;cursor:pointer;line-height:1;
}
.popup .px:hover{color:var(--paper)}
.popup .gift{font-size:2rem;margin-bottom:10px}
.popup h3{font-family:var(--display);font-size:1.5rem;margin-bottom:10px;line-height:1.2}
.popup h3 em{color:var(--amber);font-style:italic}
.popup p{color:var(--muted);font-size:.95rem;margin-bottom:20px}
.popup form{display:flex;flex-direction:column;gap:12px}
.popup input[type=email]{
  background:var(--ink);border:1px solid var(--line);border-radius:10px;
  padding:14px 16px;color:var(--paper);font-size:1rem;font-family:var(--body);
}
.popup input[type=email]:focus{outline:none;border-color:var(--amber)}
.popup .btn{width:100%}
.popup .fine{font-size:.78rem;color:var(--muted);text-align:center;margin:8px 0 0}
.popup .done{display:none;text-align:center;padding:10px 0}
.popup .done .tick{font-size:2.4rem;color:var(--leaf);margin-bottom:10px}


/* ---------- Portfolio filters ---------- */
.folio-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px;justify-content:center}
.fbtn{
  background:var(--ink-2);border:1px solid var(--line);color:var(--muted);
  padding:9px 20px;border-radius:999px;font-family:var(--body);font-size:.9rem;
  font-weight:600;cursor:pointer;transition:all .2s;
}
.fbtn:hover{border-color:var(--amber);color:var(--paper)}
.fbtn.active{background:linear-gradient(100deg,var(--flame),var(--amber));color:#fff;border-color:transparent}
.shelf{position:relative}
.shelf .cap{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(transparent,rgba(5,4,3,.92));
  color:var(--paper);font-size:.82rem;font-weight:600;
  padding:26px 12px 12px;opacity:0;transition:opacity .25s;text-align:center;
}
.shelf:hover .cap{opacity:1}
.shelf.hide{display:none}
@media(max-width:680px){
  .folio-filters{gap:8px}
  .fbtn{padding:8px 15px;font-size:.82rem}
  .shelf .cap{opacity:1;font-size:.72rem;padding:20px 8px 8px}
}


/* ---------- Order form ---------- */
.order-form{display:flex;flex-direction:column;gap:18px}
.order-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.order-form label{display:flex;flex-direction:column;gap:7px;font-size:.9rem;font-weight:600;color:var(--paper)}
.order-form input,.order-form select,.order-form textarea{
  background:var(--ink-2);border:1px solid var(--line);border-radius:10px;
  padding:13px 15px;color:var(--paper);font-family:var(--body);font-size:1rem;font-weight:400;
}
.order-form input:focus,.order-form select:focus,.order-form textarea:focus{outline:none;border-color:var(--amber)}
.order-form textarea{resize:vertical}
.order-form select{cursor:pointer}
.order-form .fineprint{font-size:.82rem;color:var(--muted);font-weight:400;margin-top:-2px}
.order-form .btn{margin-top:6px;align-self:flex-start}
.order-done{display:none;text-align:center;background:var(--card);border:1px solid rgba(124,181,24,.4);border-radius:18px;padding:50px 34px}
.order-done .tick{font-size:3rem;color:var(--leaf);margin-bottom:14px}
.order-done h2{margin-bottom:12px}
.order-done p{color:var(--muted);max-width:52ch;margin:0 auto}
@media(max-width:680px){.order-form .row2{grid-template-columns:1fr}}


/* ---------- Review avatars ---------- */
.review .rwho{display:flex;align-items:center;gap:11px;margin-top:auto}
.review .ravatar{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid rgba(245,158,11,.5);flex-shrink:0}
.review .rwho .who{margin:0}


/* ---------- FAQ accordion ---------- */
.faq{display:flex;flex-direction:column;gap:12px}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:4px 20px;transition:border-color .2s}
.faq details[open]{border-color:rgba(245,158,11,.4)}
.faq summary{cursor:pointer;font-weight:600;font-size:1.02rem;padding:16px 0;list-style:none;position:relative;padding-right:30px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:14px;font-size:1.4rem;color:var(--amber);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--muted);padding:0 0 18px;font-size:.96rem;margin:0}
