/* ============================================================
   CheapCoffeeSites — glossy, earthy "coffee glass" aesthetic
   Fonts: EB Garamond (elegant serif) + Archivo Narrow (condensed)
   ============================================================ */

:root{
  /* warm, earthy sky */
  --sky-1:#f4e7d3;
  --sky-2:#e8d2b1;
  --sky-3:#f1e2c8;
  --sky-4:#e4cda7;

  --ink:#2c1a0f;        /* espresso text */
  --ink-soft:#6b5240;   /* milky coffee text */

  /* earthy accents (warm, glossy) */
  --espresso:#3a2417;
  --coffee:#86512e;     /* primary accent */
  --coffee-deep:#6f4126;
  --caramel:#b9763f;
  --latte:#c99a6a;
  --olive:#8a8a4e;      /* earthy green */
  --gold:#d9a544;
  --cream:#f6ecdd;

  --blur:22px;
  --glass-bg:rgba(250,242,228,.46);
  --glass-bg-strong:rgba(252,245,233,.66);
  --glass-brd:rgba(255,250,238,.8);
  --glass-shadow:0 24px 60px -24px rgba(58,36,23,.5), inset 0 1px 0 rgba(255,250,240,.9);
  --gloss:1;
  --orb-vis:.7;
  --aurora-vis:.66;
  --reveal-shift:42px;
  --reveal-time:.9s;
  --radius:22px;
  --serif:"EB Garamond", Garamond, "Times New Roman", serif;
  --cond:"Archivo Narrow", "Arial Narrow", "Helvetica Neue", Arial, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  font-family:var(--cond);
  color:var(--ink);
  background:
    radial-gradient(1200px 700px at 80% -5%, var(--sky-3), transparent 60%),
    radial-gradient(1100px 800px at 10% 5%, var(--sky-4), transparent 55%),
    linear-gradient(180deg, var(--sky-1) 0%, var(--sky-2) 40%, #f3e7d2 72%, #efe0c8 100%);
  background-attachment:fixed;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}

/* ---------- ambient atmosphere ---------- */
.atmosphere{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.aurora{
  position:absolute;inset:-20% -10%;
  background:
    radial-gradient(40% 40% at 20% 30%, rgba(138,138,78,.34), transparent 60%),
    radial-gradient(45% 45% at 80% 25%, rgba(185,118,63,.32), transparent 60%),
    radial-gradient(35% 35% at 60% 80%, rgba(201,154,106,.34), transparent 60%);
  filter:blur(40px);
  opacity:var(--aurora-vis);
  animation:drift 26s ease-in-out infinite alternate;
}
@keyframes drift{
  0%{transform:translate3d(-3%,-2%,0) scale(1.05)}
  50%{transform:translate3d(4%,2%,0) scale(1.12)}
  100%{transform:translate3d(-2%,3%,0) scale(1.04)}
}
.orb{
  position:absolute;border-radius:50%;
  background:
    radial-gradient(circle at 32% 28%, rgba(255,249,238,.95), rgba(255,249,238,.25) 38%, transparent 60%),
    radial-gradient(circle at 70% 75%, rgba(134,81,46,.5), transparent 55%),
    linear-gradient(135deg, rgba(201,154,106,.6), rgba(185,118,63,.45));
  box-shadow:inset 0 -6px 18px rgba(58,36,23,.2), 0 18px 50px -10px rgba(58,36,23,.42);
  opacity:var(--orb-vis);
  filter:saturate(1.05);
  animation:float 18s ease-in-out infinite;
}
.orb-1{width:140px;height:140px;left:6%;top:18%;animation-delay:-2s}
.orb-2{width:90px;height:90px;left:84%;top:12%;animation-delay:-7s}
.orb-3{width:200px;height:200px;left:72%;top:62%;animation-delay:-4s}
@keyframes float{
  0%,100%{transform:translateY(0) translateX(0)}
  33%{transform:translateY(-26px) translateX(14px)}
  66%{transform:translateY(18px) translateX(-12px)}
}

/* ---------- shared glass ---------- */
.glass{
  background:var(--glass-bg);
  border:1px solid var(--glass-brd);
  border-radius:var(--radius);
  box-shadow:var(--glass-shadow);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(1.3);
  backdrop-filter:blur(var(--blur)) saturate(1.3);
  position:relative;
}
.glass::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(180deg, rgba(255,250,240,calc(.55*var(--gloss))) 0%, rgba(255,250,240,0) 42%);
  mix-blend-mode:screen;
}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(18px,4vw,54px);
  transition:padding .3s ease, background .3s ease, backdrop-filter .3s ease;
}
.nav.scrolled{
  padding:10px clamp(18px,4vw,54px);
  background:rgba(250,242,228,.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);
  backdrop-filter:blur(16px) saturate(1.3);
  box-shadow:0 10px 30px -18px rgba(58,36,23,.5);
}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink)}
/* logo png is a square canvas with transparent vertical padding;
   object-fit:cover in a wide box crops that padding to a tight badge */
.brand-logo{
  display:block;height:30px;width:50px;object-fit:cover;object-position:center;
  filter:drop-shadow(0 4px 10px rgba(134,81,46,.4));
}
.brand-name{font-family:var(--cond);font-weight:700;letter-spacing:.01em;font-size:19px;line-height:1;color:var(--espresso)}
.brand-name em{font-style:normal;color:var(--coffee)}
/* legacy gradient mark kept for any page still using it */
.brand-mark{
  position:relative;width:26px;height:26px;border-radius:9px;
  background:
    radial-gradient(circle at 32% 28%, #fff6e9, transparent 45%),
    linear-gradient(135deg, var(--caramel), var(--coffee) 55%, var(--espresso));
  box-shadow:inset 0 -3px 6px rgba(58,36,23,.3), 0 6px 16px -4px rgba(134,81,46,.7);
}
.brand-mark::after{
  content:"";position:absolute;top:5px;left:50%;width:4px;height:4px;border-radius:50%;
  transform:translateX(-50%);background:rgba(255,246,233,.9);
}
.nav-links{display:flex;align-items:center;gap:clamp(12px,2.4vw,30px)}
.nav-links a{
  text-decoration:none;color:var(--ink-soft);font-weight:600;
  font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  transition:color .2s ease;
}
.nav-links a:hover{color:var(--coffee)}
.nav-cta{
  color:#3a2417 !important;
  padding:9px 18px;border-radius:999px;
  background:linear-gradient(180deg, rgba(255,250,240,.92), rgba(224,196,158,.92));
  border:1px solid rgba(255,250,240,.9);
  box-shadow:0 8px 20px -8px rgba(134,81,46,.75), inset 0 1px 0 #fff;
}
.nav-cta:hover{color:#3a2417 !important;transform:translateY(-1px)}

/* ---------- hero ---------- */
.hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:130px 22px 90px;z-index:1;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:-1;will-change:transform,filter}
.hero-sky{
  position:absolute;inset:-5%;
  background:
    radial-gradient(60% 50% at 50% 8%, rgba(255,249,238,.85), transparent 60%),
    radial-gradient(50% 40% at 18% 30%, rgba(201,154,106,.5), transparent 60%),
    radial-gradient(50% 45% at 82% 22%, rgba(185,118,63,.5), transparent 62%),
    linear-gradient(180deg, #f4e6d0, #ecd6b4 45%, #e7ceaa 100%);
  animation:hue 24s ease-in-out infinite alternate;
}
@keyframes hue{0%{filter:hue-rotate(0) saturate(1)}100%{filter:hue-rotate(8deg) saturate(1.1)}}
.skyline{position:absolute;left:0;right:0;bottom:0;width:100%;height:42vh;min-height:260px;opacity:.85}

.hero-inner{
  position:relative;max-width:1180px;width:100%;z-index:2;
  display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,5vw,64px);align-items:center;
}
.hero-copy{text-align:left}
.eyebrow{
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.28em;
  font-weight:600;font-size:13px;color:var(--coffee);margin-bottom:20px;
}
.hero-title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(44px,7vw,96px);line-height:.98;letter-spacing:-.01em;color:var(--espresso);
  text-shadow:0 2px 0 rgba(255,249,238,.6), 0 30px 60px rgba(58,36,23,.16);
}
.hero-title span{
  font-style:italic;
  background:linear-gradient(120deg, var(--caramel), var(--coffee) 48%, var(--espresso));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-deal{
  font-family:var(--serif);font-weight:500;line-height:1.1;
  font-size:clamp(22px,3vw,34px);color:var(--espresso);margin:22px 0 0;
}
.hero-deal em{
  font-style:italic;
  background:linear-gradient(120deg, var(--caramel), var(--coffee) 48%, var(--espresso));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{margin:16px 0 0;max-width:560px;font-size:clamp(16px,2vw,20px);color:var(--ink-soft);font-weight:500;line-height:1.6}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-incl{
  list-style:none;display:flex;flex-wrap:wrap;gap:8px 10px;margin-top:26px;
}
.hero-incl li{
  font-family:var(--cond);font-weight:600;font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--coffee-deep);padding:6px 13px;border-radius:999px;
  background:rgba(255,250,240,.5);border:1px solid rgba(255,250,240,.8);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.hero-incl li::before{content:"✓ ";color:var(--olive);font-weight:700}

/* hero figure (glossy framed photo) */
.hero-figure{position:relative;justify-self:end;width:100%;max-width:460px}
.hf-frame{
  position:relative;border-radius:26px;overflow:hidden;padding:10px;
  transform:rotate(1.4deg);transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.hf-frame:hover{transform:rotate(0deg) translateY(-4px)}
.hf-frame img{
  display:block;width:100%;height:clamp(360px,52vh,560px);object-fit:cover;object-position:center 62%;
  border-radius:18px;box-shadow:0 18px 40px -22px rgba(58,36,23,.6);
}
.hf-price{
  position:absolute;left:-10px;top:26px;z-index:3;
  font-family:var(--serif);font-weight:600;font-size:16px;color:#3a2417;
  padding:10px 18px;border-radius:14px;transform:rotate(-4deg);
  background:linear-gradient(180deg,#ffe7b3,var(--gold));
  box-shadow:0 12px 26px -10px rgba(217,165,68,.9), inset 0 1px 0 #fff4d6;
}
.hf-price strong{font-size:26px;display:inline-block;margin-left:2px}
.hf-chip{
  position:absolute;right:14px;bottom:24px;z-index:3;
  font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px;
  color:var(--cream);padding:9px 15px 9px 32px;border-radius:999px;
  background:linear-gradient(135deg, rgba(58,36,23,.92), rgba(134,81,46,.92));
  border:1px solid rgba(255,250,240,.25);box-shadow:0 10px 24px -10px rgba(58,36,23,.8);
}
.hf-chip::before{ /* tiny coffee cup */
  content:"";position:absolute;left:13px;top:50%;width:11px;height:9px;transform:translateY(-50%);
  border:1.6px solid var(--cream);border-top:0;border-radius:0 0 6px 6px;
}

/* hero brand card: the logo + a big "from €50" */
.hf-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  gap:clamp(8px,1.5vw,16px);padding:clamp(24px,3.4vw,40px) clamp(20px,3vw,34px);
  border-radius:26px;transform:rotate(1.2deg);transition:transform .4s cubic-bezier(.2,.8,.2,1);
  background:radial-gradient(120% 95% at 50% 16%, #fff8ec, #f1ddbd 70%, #e7cda4);
}
.hf-card:hover{transform:rotate(0deg) translateY(-4px)}
.hf-logo-img{
  display:block;width:100%;height:clamp(212px,30vh,270px);
  object-fit:cover;object-position:center;border-radius:14px;
  filter:drop-shadow(0 14px 24px rgba(58,36,23,.26));
}
.hf-card .hf-price{
  position:static;transform:none;background:none;box-shadow:none;padding:0;border-radius:0;
  display:flex;align-items:baseline;gap:10px;
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.2em;font-weight:700;font-size:14px;color:var(--coffee);
}
.hf-card .hf-price strong{
  font-family:var(--serif);font-weight:600;font-size:clamp(66px,8.4vw,108px);line-height:.82;margin-left:0;
  color:var(--espresso);text-shadow:0 2px 0 rgba(255,249,238,.6);
}
.hf-card .hf-chip{position:relative;left:auto;right:auto;bottom:auto;transform:none}

/* buttons */
.btn{
  display:inline-block;text-decoration:none;cursor:pointer;border:0;
  font-family:var(--cond);font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  font-size:15px;padding:15px 30px;border-radius:999px;
  transition:transform .2s cubic-bezier(.2,.8,.2,1), box-shadow .2s ease, filter .2s ease;
}
.btn-coffee{
  color:#fff6ea;
  background:linear-gradient(180deg, #b9763f 0%, #95592f 52%, #6f4126 100%);
  box-shadow:0 14px 30px -10px rgba(111,65,38,.85), inset 0 2px 1px rgba(255,240,222,.5), inset 0 -8px 14px rgba(40,22,10,.35);
  position:relative;overflow:hidden;
}
.btn-coffee::after{
  content:"";position:absolute;top:2px;left:8%;right:8%;height:42%;border-radius:999px;
  background:linear-gradient(180deg, rgba(255,247,235,.55), rgba(255,247,235,0));
  opacity:var(--gloss);pointer-events:none;
}
.btn-coffee:hover{transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(111,65,38,.95), inset 0 2px 1px rgba(255,240,222,.55)}
.btn-ghost{
  color:var(--espresso);background:rgba(255,250,240,.4);
  border:1px solid rgba(255,250,240,.85);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}
.btn-ghost:hover{transform:translateY(-2px);background:rgba(255,250,240,.62)}
.btn-big{font-size:clamp(16px,2.6vw,24px);padding:18px 40px}

/* ---------- sections ---------- */
.section{position:relative;z-index:1;padding:clamp(72px,11vh,140px) clamp(18px,5vw,40px);max-width:1180px;margin:0 auto}
.section-head{font-family:var(--serif);text-align:center;font-weight:500;font-size:clamp(36px,6vw,72px);line-height:1;letter-spacing:-.01em;color:var(--espresso)}
.section-sub{text-align:center;color:var(--ink-soft);margin-top:14px;font-size:clamp(15px,1.8vw,19px);font-weight:500}
.section-sub strong{color:var(--coffee)}

/* ---------- why us ---------- */
.quote-rotator{margin:46px auto 0;max-width:840px;text-align:center}
.quote-track{position:relative;min-height:130px;display:grid;place-items:center}
.quote{
  grid-area:1/1;font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(26px,4.6vw,52px);line-height:1.12;color:var(--coffee-deep);
  opacity:0;transform:translateY(18px) scale(.98);transition:opacity .7s ease, transform .7s ease;
  pointer-events:none;padding:0 8px;
}
.quote.is-active{opacity:1;transform:none}
.quote-dots{display:flex;gap:10px;justify-content:center;margin-top:26px}
.dot{width:10px;height:10px;border-radius:50%;border:0;cursor:pointer;background:rgba(58,36,23,.2);transition:transform .2s ease, background .3s ease;padding:0}
.dot.is-active{background:linear-gradient(135deg,var(--caramel),var(--coffee));transform:scale(1.4)}

.why-lead{max-width:760px;margin:54px auto 0;text-align:center;font-size:clamp(17px,2.1vw,22px);line-height:1.7;color:var(--ink-soft);font-weight:500}
.why-lead em{font-family:var(--serif);font-style:italic;color:var(--coffee);font-size:1.08em}

/* coffee story band */
.coffee-band{
  margin:64px auto 0;max-width:1000px;
  display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(22px,4vw,48px);align-items:center;
}
.cb-figure{margin:0;border-radius:var(--radius);overflow:hidden;padding:8px}
.cb-figure img{display:block;width:100%;height:100%;max-height:420px;object-fit:cover;border-radius:16px}
.cb-kicker{display:block;text-transform:uppercase;letter-spacing:.26em;font-size:12px;font-weight:700;color:var(--coffee);margin-bottom:10px}
.cb-head{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4vw,46px);line-height:1.04;color:var(--espresso);margin-bottom:16px}
.cb-copy p{color:var(--ink-soft);font-size:clamp(15px,1.8vw,18px);line-height:1.65;margin-bottom:12px}
.cb-copy strong{color:var(--coffee-deep)}
.cb-rate{
  display:inline-flex;align-items:center;gap:12px;margin-top:8px;padding:10px 18px;border-radius:14px;
  background:rgba(255,250,240,.5);border:1px solid rgba(255,250,240,.8);box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.cb-rate-num{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--espresso)}
.cb-rate-eq{font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:var(--coffee)}

/* ============================================================
   WHY US — big, left, scroll-revealed (one quality per screen)
   ============================================================ */
.why{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:clamp(36px,7vh,80px) clamp(18px,5vw,40px) clamp(56px,9vh,110px)}

/* intro panel: "why us" big, with a keep-scrolling cue + skip-ahead */
.why-head{min-height:76vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left}
.why-kicker{text-transform:uppercase;letter-spacing:.34em;font-size:13px;font-weight:700;color:var(--coffee);margin-bottom:18px}
.why-bigtitle{font-family:var(--serif);font-weight:500;text-align:left;font-size:clamp(44px,9vw,116px);line-height:.94;letter-spacing:-.015em;color:var(--espresso);text-shadow:0 2px 0 rgba(255,249,238,.5)}
.why-bigtitle span{font-style:italic;background:linear-gradient(120deg,var(--caramel),var(--coffee) 48%,var(--espresso));-webkit-background-clip:text;background-clip:text;color:transparent}
.why-leadline{margin:28px 0 0;max-width:560px;font-size:clamp(16px,2vw,21px);line-height:1.6;color:var(--ink-soft);font-weight:500}
.why-cue-row{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:34px}
.why-cue{display:inline-flex;align-items:center;gap:12px;font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:13.5px;color:var(--coffee)}
.why-cue-arrow{width:11px;height:11px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);animation:cueBounce 1.6s ease-in-out infinite}
@keyframes cueBounce{0%,100%{transform:rotate(45deg) translate(0,0);opacity:.5}50%{transform:rotate(45deg) translate(4px,4px);opacity:1}}

/* quality panels: big quality left, framed image right */
.quality{min-height:82vh;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center;padding:clamp(20px,4vh,40px) 0}
.q-text{max-width:560px}
.q-no{font-family:var(--serif);font-weight:600;font-size:clamp(22px,2.4vw,30px);color:var(--coffee);display:block;letter-spacing:.04em}
.q-title{font-family:var(--serif);font-weight:500;font-size:clamp(40px,6.6vw,84px);line-height:.98;letter-spacing:-.01em;color:var(--espresso);margin:6px 0 0;overflow-wrap:break-word}
.q-title-long{font-size:clamp(34px,4.8vw,60px);line-height:1.02}
.q-desc{margin-top:22px;font-size:clamp(16px,1.95vw,20px);line-height:1.62;color:var(--ink-soft);font-weight:500}
.q-figure{margin:0;justify-self:end;width:100%;max-width:520px;border-radius:var(--radius);overflow:hidden;padding:9px}
.q-figure img{display:block;width:100%;height:clamp(320px,50vh,520px);object-fit:cover;border-radius:16px;box-shadow:0 18px 40px -22px rgba(58,36,23,.6)}

/* per-element fade-in as each panel scrolls into view */
.q-no,.q-title,.q-desc{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.q-figure{opacity:0;transform:translateX(48px) rotate(3deg);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.quality.in .q-no{opacity:.55;transform:none;transition-delay:.04s}
.quality.in .q-title{opacity:1;transform:none;transition-delay:.14s}
.quality.in .q-desc{opacity:1;transform:none;transition-delay:.26s}
.quality.in .q-figure{opacity:1;transform:rotate(1.3deg);transition-delay:.1s}

/* outro: straight to the menu */
.why-outro{min-height:56vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left;border-top:1px solid rgba(111,65,38,.16);margin-top:18px;padding-top:clamp(40px,7vh,78px)}
.why-outro-h{font-family:var(--serif);font-weight:500;font-size:clamp(34px,5.4vw,64px);line-height:1.02;color:var(--espresso)}
.why-outro-sub{margin:16px 0 28px;max-width:520px;font-size:clamp(16px,1.9vw,20px);color:var(--ink-soft);font-weight:500;line-height:1.6}

/* ============================================================
   FROM €50 teaser band (links to the dedicated pricing page)
   ============================================================ */
.price-cta{max-width:1000px}
.price-cta-card{display:flex;align-items:center;gap:clamp(20px,4vw,46px);padding:clamp(26px,4vw,46px);flex-wrap:wrap}
.pc-price{display:flex;align-items:baseline;gap:10px}
.pc-from{font-family:var(--cond);text-transform:uppercase;letter-spacing:.18em;font-size:13px;font-weight:700;color:var(--coffee)}
.pc-amt{font-family:var(--serif);font-weight:600;font-size:clamp(78px,13vw,138px);line-height:.82;color:var(--espresso);text-shadow:0 2px 0 rgba(255,249,238,.5)}
.pc-text{flex:1 1 280px;min-width:230px}
.pc-head{font-family:var(--serif);font-weight:500;font-size:clamp(25px,3.2vw,38px);line-height:1.05;color:var(--espresso)}
.pc-sub{margin-top:10px;font-size:clamp(15px,1.8vw,18px);color:var(--ink-soft);font-weight:500;line-height:1.55}
.price-cta-card .btn{flex:0 0 auto}

/* ============================================================
   WHERE TO NEXT — the closing path picker
   ============================================================ */
.next-grid{margin:44px auto 0;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.next-card{display:flex;flex-direction:column;padding:clamp(26px,3vw,38px);text-decoration:none;color:var(--ink);transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s ease}
.next-card:hover{transform:translateY(-5px)}
.next-no{font-family:var(--serif);font-weight:600;font-size:24px;color:var(--coffee);opacity:.6}
.next-h{font-family:var(--serif);font-weight:600;font-size:clamp(26px,3.2vw,38px);line-height:1.02;color:var(--espresso);margin:6px 0 10px}
.next-p{font-size:15.5px;line-height:1.55;color:var(--ink-soft);margin-bottom:22px}
.next-go{margin-top:auto;display:inline-flex;align-items:center;gap:9px;font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:13.5px;color:var(--coffee)}
.next-arrow{width:8px;height:8px;border-right:2px solid currentColor;border-top:2px solid currentColor;transform:rotate(45deg);transition:transform .25s ease}
.next-card:hover .next-arrow{transform:rotate(45deg) translate(3px,-3px)}
.next-card-cta{border:1px solid rgba(217,165,68,.55);box-shadow:0 30px 70px -28px rgba(58,36,23,.5),0 0 0 1px rgba(217,165,68,.25),inset 0 1px 0 rgba(255,250,240,.9)}
.next-card-cta .next-no,.next-card-cta .next-go{color:var(--coffee-deep)}

/* ============================================================
   PROCESS / SUGGESTED PRICING — click to open (shared collapse)
   ============================================================ */
.process-section{max-width:1040px;padding-top:clamp(40px,7vh,90px);padding-bottom:clamp(40px,7vh,90px)}
.process-teaser,.price-teaser{display:flex;justify-content:center}
.price-teaser{margin-top:42px}
.process-toggle{
  width:100%;max-width:840px;cursor:pointer;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  padding:clamp(24px,3.6vw,38px) clamp(26px,4vw,46px);border-radius:var(--radius);
  background:var(--glass-bg);border:1px solid var(--glass-brd);box-shadow:var(--glass-shadow);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(1.3);backdrop-filter:blur(var(--blur)) saturate(1.3);
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease;
}
.process-toggle:hover{transform:translateY(-2px)}
.pt-kicker{display:block;text-transform:uppercase;letter-spacing:.28em;font-size:12px;font-weight:700;color:var(--coffee);margin-bottom:8px}
.pt-head{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4.4vw,46px);line-height:1.02;color:var(--espresso)}
.pt-cta{display:inline-flex;align-items:center;gap:10px;font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:13.5px;color:var(--coffee);white-space:nowrap}
.pt-chev{width:11px;height:11px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.process-toggle[aria-expanded="true"] .pt-chev{transform:rotate(-135deg)}

/* shared collapse: display:none when closed → zero leftover space */
.js-collapse{overflow:hidden}
.js-collapse[hidden]{display:none}
.js-collapse.opening .collapse-in{animation:stepsIn .55s cubic-bezier(.2,.8,.2,1)}
.js-collapse.closing .collapse-in{animation:stepsOut .42s cubic-bezier(.2,.8,.2,1)}
@keyframes stepsIn{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:none}}
@keyframes stepsOut{from{opacity:1;transform:none}to{opacity:0;transform:translateY(-12px)}}
.process{list-style:none;display:grid;gap:16px;grid-template-columns:repeat(5,1fr);max-width:840px;margin:0 auto;padding-top:24px}
.step{padding:24px 20px 26px}
.step-no{font-family:var(--serif);font-size:30px;color:var(--coffee);font-weight:600;display:block;opacity:.85}
.step h3{font-family:var(--cond);text-transform:uppercase;letter-spacing:.08em;font-size:15px;margin:8px 0 10px;color:var(--espresso)}
.step p{font-size:14px;color:var(--ink-soft);line-height:1.55}

/* ============================================================
   PRICING — featured + page-type cards
   ============================================================ */
.offers{max-width:1160px}
@keyframes qfade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* shared card visual */
.offer-visual{
  position:relative;width:100%;aspect-ratio:16/10;border-radius:16px;overflow:hidden;
  background:linear-gradient(160deg,#f1e2c8,#e6cda6 55%,#ddc59a);
  border:1px solid rgba(255,250,240,.7);box-shadow:inset 0 1px 0 rgba(255,250,240,.9), inset 0 -30px 50px -30px rgba(58,36,23,.28);
}
.offer-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* featured "every site includes" */
.offer-feature{
  margin:50px auto 0;display:grid;grid-template-columns:1fr 1.15fr;gap:0;overflow:visible;
  border:1px solid rgba(217,165,68,.55);
  box-shadow:0 30px 70px -28px rgba(58,36,23,.5), 0 0 0 1px rgba(217,165,68,.25), inset 0 1px 0 rgba(255,250,240,.9);
}
.offer-feature .offer-visual{aspect-ratio:auto;height:100%;min-height:300px;border:0;border-radius:var(--radius) 0 0 var(--radius)}
.feature-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg, rgba(58,36,23,.18), transparent 55%)}
.offer-feature .offer-body{padding:clamp(28px,3.6vw,46px)}
.offer-badge{
  display:inline-block;font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.16em;
  font-size:11.5px;color:#5a4209;padding:6px 14px;border-radius:999px;margin-bottom:16px;
  background:linear-gradient(180deg,#ffe9a8,var(--gold));box-shadow:0 6px 16px -6px rgba(217,165,68,.9), inset 0 1px 0 #fff5d6;
}
.offer-name{font-family:var(--serif);font-weight:600;font-size:clamp(30px,4.4vw,48px);line-height:1;color:var(--espresso)}
.offer-price{font-family:var(--cond);margin:8px 0 4px;display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.offer-price>span{font-family:var(--serif);font-weight:600;font-size:clamp(48px,7vw,74px);color:var(--espresso);line-height:1}
.offer-price small{font-size:13px;text-transform:uppercase;letter-spacing:.14em;color:var(--coffee);font-weight:700;order:-1}
.mgmt-card .offer-price{flex-direction:row;align-items:baseline;gap:8px}
.mgmt-card .offer-price small{order:0}
.offer-tag{font-family:var(--serif);font-style:italic;font-size:clamp(17px,2.2vw,22px);color:var(--coffee);margin-bottom:14px}
.offer-points{list-style:none;display:flex;flex-direction:column;gap:10px;margin:10px 0 22px}
.offer-points li{position:relative;padding-left:26px;font-size:15px;color:var(--ink);line-height:1.45}
.offer-points li::before{
  content:"";position:absolute;left:0;top:3px;width:16px;height:16px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%, #fff, var(--gold) 60%, #c4882f);
  box-shadow:0 2px 6px -1px rgba(217,165,68,.8);
}

/* the three standard cards */
.offer-grid{margin:18px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.offer-card{padding:0;overflow:visible;display:flex;flex-direction:column;transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease}
.offer-card:hover{transform:translateY(-5px)}
.offer-card .offer-visual{border-radius:var(--radius) var(--radius) 0 0;border:0;border-bottom:1px solid rgba(255,250,240,.6);aspect-ratio:16/11}
.offer-card .photo-visual img{transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.offer-card:hover .photo-visual img{transform:scale(1.05)}
.offer-card .offer-inner{padding:24px 24px 28px;display:flex;flex-direction:column;flex:1}
.offer-card .offer-name{font-size:clamp(24px,3vw,30px)}
.offer-card .btn{margin-top:auto;text-align:center}
.offer-desc{font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin-bottom:18px}

/* featured price block (fills the headline space) */
.feat-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px 28px;flex-wrap:wrap;margin-bottom:6px}
.feat-head{flex:1 1 260px}
.feat-price{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;text-align:right;line-height:1}
.feat-from{font-family:var(--cond);text-transform:uppercase;letter-spacing:.18em;font-size:13px;font-weight:700;color:var(--coffee)}
.feat-amt{font-family:var(--serif);font-weight:600;font-size:clamp(64px,9.5vw,112px);color:var(--espresso);text-shadow:0 2px 0 rgba(255,249,238,.5)}
.feat-allin{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-size:13px;font-weight:700;color:var(--coffee-deep);margin-top:8px}

/* price asterisk + hover tooltip */
.pstar{position:relative;display:inline-block;color:var(--coffee);font-weight:700;cursor:help;font-size:.46em;vertical-align:super;margin-left:2px;outline:none}
.ptip{
  position:absolute;left:50%;bottom:160%;transform:translateX(-50%) translateY(6px);
  width:220px;max-width:64vw;padding:12px 14px;border-radius:12px;
  background:linear-gradient(180deg, rgba(58,36,23,.97), rgba(111,65,38,.97));color:var(--cream);
  font-family:var(--cond);font-weight:500;font-size:13px;line-height:1.5;letter-spacing:.01em;text-transform:none;text-align:left;
  opacity:0;visibility:hidden;transition:opacity .2s ease, transform .2s ease;
  box-shadow:0 18px 40px -16px rgba(58,36,23,.7);z-index:30;pointer-events:none;
}
.ptip::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:7px solid transparent;border-top-color:rgba(111,65,38,.97)}
.pstar:hover .ptip,.pstar:focus .ptip{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* suggested pricing panel */
.price-inner{margin:18px auto 0;max-width:900px;padding:clamp(24px,3.6vw,40px)}
.price-note{font-size:clamp(15px,1.9vw,18px);color:var(--ink-soft);line-height:1.65;margin-bottom:22px}
.price-note em{font-family:var(--serif);font-style:italic;color:var(--coffee)}
.price-note strong{color:var(--coffee-deep)}
.price-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:14px}
.price-table{width:100%;border-collapse:collapse;min-width:520px;font-family:var(--cond)}
.price-table th,.price-table td{text-align:left;padding:13px 14px;border-bottom:1px solid rgba(111,65,38,.16);font-size:15px}
.price-table thead th{text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--coffee);font-weight:700}
.price-table tbody tr:last-child td{border-bottom:0}
.price-table .pt-amt{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--espresso);white-space:nowrap}
.price-incl{margin-top:18px;font-size:14.5px;color:var(--ink-soft);line-height:1.6}
.price-incl strong{color:var(--coffee-deep)}
.addons{margin-top:20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.addons-label{text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:700;color:var(--coffee)}
.addons ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px}
.addons li{
  font-family:var(--cond);font-weight:600;font-size:13px;color:var(--coffee-deep);
  padding:6px 13px;border-radius:999px;background:rgba(255,250,240,.55);border:1px solid rgba(255,250,240,.8);
}

/* management / yearly coffee subscription card */
.mgmt-card{
  margin:18px auto 0;display:grid;grid-template-columns:1.16fr .84fr;gap:0;overflow:hidden;
  border:1px solid rgba(134,81,46,.4);
  box-shadow:0 30px 70px -30px rgba(58,36,23,.5), 0 0 0 1px rgba(134,81,46,.16), inset 0 1px 0 rgba(255,250,240,.9);
}
.mgmt-body{padding:clamp(26px,3.4vw,44px);display:flex;flex-direction:column}
.mgmt-badge{background:linear-gradient(180deg,#d8b58a,var(--coffee));color:#fff6ea;box-shadow:0 6px 16px -6px rgba(134,81,46,.8), inset 0 1px 0 rgba(255,250,240,.5)}
.mgmt-card .offer-price span{font-size:clamp(34px,5vw,52px)}
.mgmt-card .offer-price small{text-transform:none;letter-spacing:.01em;font-size:14px;font-weight:600}
.mgmt-card .offer-points{margin-bottom:16px}
.mgmt-card .offer-points li::before{background:radial-gradient(circle at 32% 30%, #fff, var(--latte) 60%, var(--coffee));box-shadow:0 2px 6px -1px rgba(134,81,46,.7)}
.mgmt-foot{margin-top:auto;font-size:14.5px;color:var(--ink-soft);line-height:1.55}
.mgmt-foot strong{color:var(--coffee-deep)}
.mgmt-visual{position:relative;margin:0;min-height:280px;overflow:hidden}
.mgmt-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.mgmt-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(300deg, rgba(58,36,23,.16), transparent 55%)}

/* ============================================================
   COMPARE table
   ============================================================ */
.compare{max-width:1080px}
.compare-scroll{margin-top:48px;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius)}
.compare-table{
  width:100%;border-collapse:separate;border-spacing:0;min-width:680px;
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(1.3);backdrop-filter:blur(var(--blur)) saturate(1.3);
  border:1px solid var(--glass-brd);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--glass-shadow);font-family:var(--cond);
}
.compare-table th,.compare-table td{padding:16px 18px;text-align:left;border-bottom:1px solid rgba(111,65,38,.14);font-size:15px;color:var(--ink);vertical-align:middle}
.compare-table thead th{font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:var(--ink-soft);background:rgba(255,250,240,.3)}
.compare-table tbody th{font-weight:700;color:var(--espresso);font-size:14px}
.compare-table tbody tr:last-child th,.compare-table tbody tr:last-child td{border-bottom:0}
.compare-table small{display:block;font-size:11.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.compare-table .ct-brand{font-family:var(--serif);font-weight:600;font-size:17px;color:var(--coffee-deep);text-transform:none;letter-spacing:0}
/* highlighted "us" column */
.compare-table .ct-us{
  background:linear-gradient(180deg, rgba(217,165,68,.16), rgba(217,165,68,.07));
  box-shadow:inset 1px 0 0 rgba(217,165,68,.4), inset -1px 0 0 rgba(217,165,68,.4);
}
.compare-table thead .ct-us{background:linear-gradient(180deg, rgba(217,165,68,.32), rgba(217,165,68,.16))}
.compare-table .ct-us strong{font-family:var(--serif);font-size:20px;color:var(--espresso)}
.yes,.no,.mid{display:inline-block;font-weight:700;margin-right:4px}
.yes{color:var(--olive)}
.no{color:#b15a4a}
.mid{color:var(--caramel)}

/* ---------- contact ---------- */
.contact{max-width:820px}
.contact-card{padding:clamp(40px,6vw,72px) clamp(26px,5vw,60px);text-align:center}
.contact-kicker{text-transform:uppercase;letter-spacing:.3em;font-size:12.5px;font-weight:700;color:var(--coffee)}
.contact-head{font-family:var(--serif);font-size:clamp(34px,5.6vw,60px);line-height:1.04;margin:14px 0 6px;color:var(--espresso);font-weight:500}
.contact-body{color:var(--ink-soft);font-size:clamp(15px,1.9vw,19px);font-weight:500;max-width:560px;margin:0 auto 28px}

/* ---------- footer ---------- */
.footer{
  position:relative;z-index:1;text-align:center;padding:40px 20px 60px;
  color:var(--ink-soft);font-size:13px;text-transform:uppercase;letter-spacing:.14em;font-weight:600;
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;align-items:center;
}
.footer-dot{color:var(--coffee)}
.footer-link{color:var(--coffee);text-decoration:none;border-bottom:1px solid rgba(134,81,46,.45);transition:color .2s ease,border-color .2s ease}
.footer-link:hover{color:var(--coffee-deep);border-color:var(--coffee-deep)}

/* scroll progress bar */
.progress{
  position:fixed;left:0;top:0;height:3px;width:0;z-index:60;
  background:linear-gradient(90deg,var(--caramel),var(--coffee),var(--espresso));
  box-shadow:0 0 12px rgba(134,81,46,.7);transition:width .1s linear;
}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(var(--reveal-shift));transition:opacity var(--reveal-time) cubic-bezier(.2,.8,.2,1), transform var(--reveal-time) cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   FIRST-LOAD SPLASH  →  buttery load-in
   ============================================================ */
#splash{
  position:fixed;inset:0;z-index:200;background:#f6ecdd;
  display:grid;place-items:center;text-align:center;padding:24px;
  transition:opacity 1s cubic-bezier(.4,0,.2,1), visibility 1s;
}
#splash.gone{opacity:0;visibility:hidden;pointer-events:none}
.splash-inner{max-width:760px}
.splash-line{font-family:var(--serif);font-weight:500;line-height:1.1;color:var(--coffee-deep);font-size:clamp(28px,6vw,64px);opacity:0;will-change:opacity,transform}
.splash-1{animation:splashIn 1s cubic-bezier(.2,.8,.2,1) .35s forwards}
.splash-2{
  margin-top:.35em;font-style:italic;
  background:linear-gradient(120deg,var(--caramel),var(--coffee) 48%,var(--espresso));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:splashIn 1s cubic-bezier(.2,.8,.2,1) 1.15s forwards;
}
@keyframes splashIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

.load{opacity:0;transform:translateY(26px)}
body.loaded .load{opacity:1;transform:none;transition:opacity 1s cubic-bezier(.2,.8,.2,1), transform 1s cubic-bezier(.2,.8,.2,1)}
body.loaded .hero-title{transition-delay:.16s}
body.loaded .hero-sub{transition-delay:.28s}
body.loaded .hero-actions{transition-delay:.4s}
body.loaded .hero-incl{transition-delay:.5s}
body.loaded .hero-figure{transition-delay:.32s}

#scroll{will-change:transform}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .splash-line{opacity:1}
  .load{opacity:1;transform:none}
  .q-no,.q-title,.q-desc,.q-figure{opacity:1;transform:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .hero{min-height:auto;padding-top:120px}
  .hero-inner{grid-template-columns:1fr;gap:38px}
  .hero-copy{text-align:center}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-actions,.hero-incl{justify-content:center}
  .hero-figure{justify-self:center;max-width:420px;order:-1}
  .coffee-band{grid-template-columns:1fr;max-width:560px}
  .cb-copy{text-align:center}
  .cb-kicker{margin-top:4px}
  .process{grid-template-columns:repeat(3,1fr)}
  .offer-feature{grid-template-columns:1fr}
  .offer-feature .offer-visual{min-height:220px;border-radius:var(--radius) var(--radius) 0 0}
  .mgmt-card{grid-template-columns:1fr}
  .mgmt-visual{min-height:200px;order:-1}
  .offer-grid{grid-template-columns:1fr 1fr}
  .offer-grid .offer-card:last-child{grid-column:1/-1}
  /* why us → stack, image on top, no horizontal slide */
  .why-head{min-height:64vh}
  .why-bigtitle{font-size:clamp(40px,11vw,82px)}
  .quality{grid-template-columns:1fr;gap:24px;min-height:auto;padding:46px 0}
  .q-text{max-width:none}
  .q-figure{justify-self:stretch;max-width:none;order:-1;transform:translateY(30px) rotate(2deg)}
  .q-figure img{height:clamp(220px,42vh,360px)}
  .quality.in .q-figure{transform:none}
  .next-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  .nav-links{gap:10px}
  .nav-links a:not(.nav-cta){display:none}
  .process{grid-template-columns:1fr}
  .process-toggle{flex-direction:column;align-items:flex-start;gap:16px}
  .offer-grid{grid-template-columns:1fr}
  .offer-grid .offer-card:last-child{grid-column:auto}
  .cb-rate{width:100%;justify-content:center}
  .feat-top{flex-direction:column;gap:14px}
  .feat-head{flex:0 0 auto}
  .feat-price{align-items:flex-start;text-align:left}
}

/* ============================================================
   LANGUAGE SWITCHER + i18n (RTL + non-Latin fonts)
   ============================================================ */
.lang{position:relative;display:inline-flex}
.lang-btn{
  display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:0;background:transparent;
  font-family:var(--cond);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);padding:8px 8px;border-radius:999px;transition:color .2s ease;
}
.lang-btn:hover{color:var(--coffee)}
.lang-globe{display:block;color:currentColor}
.lang-caret{width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-1px)}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;min-width:168px;list-style:none;margin:0;padding:7px;
  border-radius:14px;z-index:70;
}
.lang-menu[hidden]{display:none}
.lang-menu li{
  padding:9px 14px;border-radius:9px;font-family:var(--cond);font-weight:600;font-size:14px;
  color:var(--ink);cursor:pointer;text-transform:none;letter-spacing:0;line-height:1.3;
  transition:background .15s ease,color .15s ease;
}
.lang-menu li:hover{background:rgba(134,81,46,.12);color:var(--coffee-deep)}
.lang-menu li[aria-selected="true"]{background:linear-gradient(180deg,rgba(217,165,68,.28),rgba(217,165,68,.12));color:var(--coffee-deep)}

/* keep build-name column bold across languages (translations drop the <strong>) */
.price-table tbody td:first-child{font-weight:700;color:var(--espresso)}

/* non-Latin fonts, loaded on demand by i18n.js and swapped via the lang attribute */
html[lang="ar"]{--serif:"Noto Naskh Arabic","EB Garamond",serif;--cond:"Noto Sans Arabic","Archivo Narrow",sans-serif}
html[lang="ja"]{--serif:"Noto Serif JP","EB Garamond",serif;--cond:"Noto Sans JP","Archivo Narrow",sans-serif}
html[lang="zh"]{--serif:"Noto Serif SC","EB Garamond",serif;--cond:"Noto Sans SC","Archivo Narrow",sans-serif}

/* right-to-left (Arabic) */
[dir="rtl"] .hero-copy,[dir="rtl"] .cb-copy{text-align:right}
[dir="rtl"] .hero-sub{margin-left:auto;margin-right:0}
[dir="rtl"] .hero-actions,[dir="rtl"] .hero-incl{justify-content:flex-start}
[dir="rtl"] .offer-points li,[dir="rtl"] .policy-card li{padding-left:0;padding-right:26px}
[dir="rtl"] .offer-points li::before,[dir="rtl"] .policy-card li::before{left:auto;right:0}
[dir="rtl"] .process-toggle,[dir="rtl"] .pt-text,[dir="rtl"] .price-note,[dir="rtl"] .price-incl{text-align:right}
[dir="rtl"] .price-table th,[dir="rtl"] .price-table td,[dir="rtl"] .compare-table th,[dir="rtl"] .compare-table td{text-align:right}
[dir="rtl"] .yes,[dir="rtl"] .no,[dir="rtl"] .mid{margin-right:0;margin-left:4px}
[dir="rtl"] .lang-menu{right:auto;left:0}
@media (max-width:1000px){
  [dir="rtl"] .hero-copy,[dir="rtl"] .cb-copy{text-align:center}
}

/* ============================================================
   PHONES — tighter type and rhythm on small screens
   ============================================================ */
@media (max-width:560px){
  .nav{padding:12px 15px}
  .brand-name{font-size:16px}
  .brand-logo{height:26px;width:42px}
  .nav-links{gap:8px}

  .hero{min-height:auto;padding:104px 18px 60px}
  .hero-title{font-size:clamp(31px,8.6vw,46px);line-height:1.02}
  .hero-deal{font-size:clamp(18px,5.2vw,24px);margin-top:18px}
  .hero-sub{font-size:15.5px;margin-top:14px}
  .hero-actions{margin-top:24px}
  .hero-actions .btn{flex:1 1 auto;text-align:center}
  .hero-figure{max-width:340px}
  .hf-logo-img{height:clamp(168px,42vw,220px)}
  .hf-card .hf-price strong{font-size:clamp(58px,17vw,86px)}

  .section{padding:clamp(48px,8vh,72px) 18px}
  .why{padding:24px 18px 52px}
  .why-head{min-height:56vh}
  .why-kicker{margin-bottom:14px}
  .quality{padding:32px 0}
  .q-no{font-size:20px}
  .q-desc{margin-top:16px}
  .q-figure img{height:clamp(196px,40vh,300px)}
  .why-outro{min-height:auto;padding-top:38px;margin-top:8px}

  .price-cta-card{gap:12px 18px}
  .next-grid{margin-top:30px;gap:14px}
  .next-card{padding:24px 22px}
  .next-h{margin-bottom:8px}
  .contact-card{padding:38px 22px}
  .btn-big{font-size:clamp(15px,4.6vw,22px);padding:16px 20px;overflow-wrap:anywhere;max-width:100%}
  .footer{gap:10px;padding:34px 18px 48px}
}

/* very small phones */
@media (max-width:360px){
  .brand-name{font-size:15px}
  .hero-title{font-size:clamp(28px,8vw,40px)}
  .hf-card .hf-price strong{font-size:clamp(52px,16vw,74px)}
  .nav-cta{padding:8px 14px}
}

/* ============================================================
   PRODUCT PAGES  —  "view our service" detail pages
   ============================================================ */
.product main{position:relative;z-index:1}
/* keep the bar glassy the whole way down (no hero image behind it) */
.product .nav{
  background:rgba(250,242,228,.55);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3);
  box-shadow:0 10px 30px -18px rgba(58,36,23,.5);
}

/* hero */
.prod-hero{
  max-width:1080px;margin:0 auto;
  padding:clamp(120px,18vh,190px) clamp(18px,5vw,40px) clamp(40px,7vh,80px);
  text-align:center;
}
.prod-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.2em;font-weight:700;font-size:12.5px;
  color:var(--coffee-deep);background:rgba(255,250,240,.5);
  border:1px solid var(--glass-brd);padding:7px 15px;border-radius:999px;
}
.prod-title{
  font-family:var(--serif);font-weight:500;line-height:1;letter-spacing:-.01em;
  font-size:clamp(38px,7vw,84px);color:var(--espresso);margin:22px 0 0;
}
.prod-tag{
  color:var(--ink-soft);font-weight:500;max-width:620px;margin:18px auto 0;
  font-size:clamp(16px,2.1vw,21px);
}
.prod-pricerow{
  display:flex;align-items:baseline;justify-content:center;gap:10px;margin:30px 0 6px;flex-wrap:wrap;
}
.prod-from{font-family:var(--cond);text-transform:uppercase;letter-spacing:.18em;font-weight:700;font-size:14px;color:var(--coffee)}
.prod-amt{
  font-family:var(--serif);font-weight:600;font-size:clamp(46px,9vw,76px);line-height:1;
  background:linear-gradient(120deg,var(--caramel),var(--coffee) 48%,var(--espresso));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.prod-amt .prod-cur{-webkit-text-fill-color:var(--coffee)}
.prod-pricenote{color:var(--ink-soft);font-size:14px;font-weight:600;margin-top:2px}
.prod-spots{
  display:inline-flex;align-items:center;gap:9px;margin:16px auto 0;
  font-family:var(--cond);font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--cream);background:linear-gradient(120deg,var(--caramel),var(--coffee));
  padding:8px 16px;border-radius:999px;box-shadow:0 12px 26px -14px rgba(111,65,38,.95);
}
.prod-spots::before{
  content:"";width:9px;height:9px;border-radius:50%;background:#86e08a;
  box-shadow:0 0 0 0 rgba(134,224,138,.6);animation:spotPulse 2.1s ease-out infinite;
}
@keyframes spotPulse{
  0%{box-shadow:0 0 0 0 rgba(134,224,138,.55)}
  70%{box-shadow:0 0 0 8px rgba(134,224,138,0)}
  100%{box-shadow:0 0 0 0 rgba(134,224,138,0)}
}
@media (prefers-reduced-motion:reduce){.prod-spots::before{animation:none}}
.prod-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:26px 0 0}

/* quick facts strip */
.prod-facts{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  max-width:760px;margin:34px auto 0;
}
.prod-fact{
  flex:1 1 200px;min-width:170px;padding:16px 18px;border-radius:16px;text-align:left;
}
.prod-fact b{display:block;font-family:var(--serif);font-size:20px;color:var(--espresso);font-weight:600;line-height:1.1}
.prod-fact span{display:block;color:var(--ink-soft);font-size:13.5px;font-weight:600;margin-top:4px;letter-spacing:.01em}

/* live demo / try it out */
.prod-demo{max-width:1180px;margin:0 auto;padding:clamp(40px,7vh,90px) clamp(18px,5vw,40px)}
.prod-demo-head{text-align:center;margin-bottom:30px}
.demo-kicker{text-transform:uppercase;letter-spacing:.3em;font-size:12.5px;font-weight:700;color:var(--coffee)}
.demo-window{
  padding:14px;border-radius:26px;overflow:hidden;
}
.demo-bar{
  display:flex;align-items:center;gap:8px;padding:4px 8px 14px;
}
.demo-dots{display:flex;gap:7px}
.demo-dots i{width:12px;height:12px;border-radius:50%;display:block;background:rgba(134,81,46,.4)}
.demo-dots i:nth-child(1){background:#d98b6a}
.demo-dots i:nth-child(2){background:#dcb463}
.demo-dots i:nth-child(3){background:#9aa66a}
.demo-url{
  flex:1;font-family:var(--cond);font-size:13px;font-weight:600;color:var(--coffee-deep);
  background:rgba(255,250,240,.55);border-radius:999px;padding:6px 14px;text-align:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
/* tall enough that each demo's full-height hero fits its content below
   the fixed nav (no nav/headline overlap), scrollable for the rest */
.demo-frame-wrap{
  position:relative;border-radius:16px;overflow:hidden;
  box-shadow:0 18px 50px -20px rgba(58,36,23,.6);background:#fff;
  height:clamp(620px,86vh,860px);
}
.demo-frame-wrap iframe{width:100%;height:100%;border:0;display:block}
.demo-foot{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:22px;align-items:center}
.demo-foot small{color:var(--ink-soft);font-size:13px;font-weight:600}

/* features / qualities grid */
.prod-features{max-width:1100px;margin:0 auto;padding:clamp(20px,5vh,60px) clamp(18px,5vw,40px) clamp(50px,8vh,100px)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.feat-item{padding:26px 24px;border-radius:18px}
.feat-ic{
  width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:22px;margin-bottom:14px;
  background:linear-gradient(135deg,var(--caramel),var(--coffee));color:var(--cream);
  box-shadow:0 10px 22px -10px rgba(111,65,38,.8);
}
.feat-item h3{font-family:var(--serif);font-size:21px;font-weight:600;color:var(--espresso);margin-bottom:7px;line-height:1.15}
.feat-item p{color:var(--ink-soft);font-size:14.5px;font-weight:500;line-height:1.5}
@media (max-width:880px){.feat-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.feat-grid{grid-template-columns:1fr}}

/* delivery / add-on toggle */
.prod-toggle{
  max-width:780px;margin:0 auto;padding:0 clamp(18px,5vw,40px) clamp(40px,7vh,80px);
}
.toggle-card{padding:clamp(24px,4vw,38px);border-radius:22px}
.toggle-row{display:flex;align-items:center;gap:18px;justify-content:space-between;flex-wrap:wrap}
.toggle-row h3{font-family:var(--serif);font-size:clamp(22px,3vw,30px);font-weight:600;color:var(--espresso);line-height:1.1}
.toggle-row p{color:var(--ink-soft);font-weight:500;font-size:14.5px;margin-top:6px;max-width:42ch}
.switch{position:relative;display:inline-block;width:62px;height:34px;flex:0 0 auto}
.switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:2}
.switch .track{
  position:absolute;inset:0;border-radius:999px;background:rgba(134,81,46,.28);
  transition:background .25s ease;
}
.switch .track::before{
  content:"";position:absolute;top:4px;left:4px;width:26px;height:26px;border-radius:50%;
  background:var(--cream);box-shadow:0 3px 8px rgba(58,36,23,.4);transition:transform .25s ease;
}
.switch input:checked + .track{background:linear-gradient(120deg,var(--caramel),var(--coffee))}
.switch input:checked + .track::before{transform:translateX(28px)}
.switch input:focus-visible + .track{outline:2px solid var(--coffee-deep);outline-offset:2px}
.toggle-result{
  margin-top:22px;padding-top:20px;border-top:1px solid rgba(134,81,46,.22);
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.toggle-result .tr-amt{font-family:var(--serif);font-weight:600;font-size:34px;color:var(--espresso)}
.toggle-result .tr-note{color:var(--ink-soft);font-weight:600;font-size:14px}
.toggle-extra{margin-top:10px;color:var(--coffee-deep);font-weight:600;font-size:14px;display:none}
.toggle-extra.on{display:block}

/* bundle note */
.prod-bundle{max-width:820px;margin:0 auto;padding:0 clamp(18px,5vw,40px) clamp(50px,8vh,90px);text-align:center}
.prod-bundle .glass{padding:clamp(24px,4vw,40px);border-radius:22px}
.prod-bundle h3{font-family:var(--serif);font-size:clamp(24px,3.4vw,34px);font-weight:600;color:var(--espresso);margin-bottom:10px}
.prod-bundle p{color:var(--ink-soft);font-weight:500;font-size:clamp(15px,1.9vw,17px);max-width:56ch;margin:0 auto}
.prod-bundle .bundle-price{color:var(--coffee-deep);font-weight:700}

.prod-back{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin:0 0 70px}

@media (max-width:600px){
  .demo-frame-wrap{height:78vh}
  .prod-fact{flex:1 1 100%}
  .toggle-row{flex-direction:row}
}
