/* Avanya Fresh — editorial-heritage landing.
   Type: Young Serif (display) + Hanken Grotesk (text).
   Colour: OKLCH warm-cream paper, espresso ink, copper foil, leaf green. */

:root {
  /* Palette — OKLCH, neutrals tinted toward the wax-seal copper hue (~55). */
  --paper:        oklch(0.963 0.014 74);
  --paper-raised: oklch(0.983 0.010 74);
  --ink:          oklch(0.285 0.028 52);
  --ink-soft:     oklch(0.455 0.030 52);
  --copper:       oklch(0.560 0.112 52);
  --copper-deep:  oklch(0.470 0.104 48);
  --leaf:         oklch(0.585 0.086 138);
  --line:         oklch(0.888 0.018 74);
  --line-strong:  oklch(0.820 0.024 70);
  --espresso:     oklch(0.262 0.028 52);
  --on-espresso:  oklch(0.915 0.020 74);

  /* Fluid type scale (≥1.25 steps). */
  --t-display: clamp(2.9rem, 1.4rem + 6.2vw, 5.4rem);
  --t-h2:      clamp(1.95rem, 1.2rem + 2.7vw, 3.05rem);
  --t-h3:      clamp(1.2rem, 1.05rem + 0.6vw, 1.45rem);
  --t-lead:    clamp(1.12rem, 1rem + 0.55vw, 1.34rem);
  --t-body:    1.0625rem;

  /* 4pt spacing. */
  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px; --sp-6: 24px;
  --sp-8: 32px; --sp-12: 48px; --sp-16: 64px; --sp-24: 96px;

  --maxw: 1120px;
  --shadow: 0 22px 60px -30px oklch(0.42 0.06 52 / 0.55);
  --stamp: 0 3px 0 oklch(0.42 0.06 52 / 0.10);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: var(--t-body);
  line-height: 1.62;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3 {
  font-family: "Young Serif", Georgia, serif;
  font-weight: 400;
  line-height: 1.06;
  margin: 0;
  color: var(--ink);
}
p { margin: 0; }
img { display: block; max-width: 100%; height: auto; }
a { color: var(--copper-deep); text-underline-offset: 3px; }

.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(20px, 5vw, 56px); }

/* Eyebrow label with a hand-drawn rule. */
.eyebrow {
  font-size: 0.8rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--copper); display: inline-flex; align-items: center; gap: 12px;
}
.eyebrow::before { content: ""; width: 30px; height: 1px; background: currentColor; opacity: 0.65; }

/* Buttons — squared "stamp" corners, not pill. */
.btn {
  display: inline-flex; align-items: center; gap: 0.55em;
  font-family: inherit; font-weight: 600; font-size: 1rem;
  padding: 0.85em 1.6em; border-radius: 3px;
  background: var(--copper); color: oklch(0.98 0.012 74);
  text-decoration: none; border: 1px solid var(--copper-deep);
  box-shadow: var(--shadow);
  transition: transform .28s cubic-bezier(.2,.7,.2,1), background .28s;
}
.btn:hover { background: var(--copper-deep); transform: translateY(-2px); }
.btn:focus-visible { outline: 2px solid var(--leaf); outline-offset: 3px; }
.btn .arw { transition: transform .28s cubic-bezier(.2,.7,.2,1); }
.btn:hover .arw { transform: translateX(3px); }
.textlink {
  font-weight: 600; color: var(--ink); text-decoration: none;
  border-bottom: 1px solid var(--line-strong); padding-bottom: 2px; transition: border-color .2s;
}
.textlink:hover { border-color: var(--copper); }

/* Masthead */
.masthead {
  position: sticky; top: 0; z-index: 20;
  background: color-mix(in oklch, var(--paper) 86%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.masthead .wrap { display: flex; align-items: center; justify-content: space-between; padding-block: 13px; }
.wordmark { display: flex; align-items: center; gap: 12px; text-decoration: none; color: var(--ink); }
.wordmark img { width: 38px; height: 38px; }
.wordmark b { font-family: "Young Serif", serif; font-weight: 400; font-size: 1.25rem; letter-spacing: 0.02em; line-height: 1; }
.wordmark small { display: block; font-size: 0.6rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-soft); margin-top: 3px; }
.masthead .btn { padding: 0.55em 1.15em; font-size: 0.92rem; }

/* Hero — left-aligned, asymmetric. */
.hero { padding-block: clamp(44px, 7vw, 96px); }
.hero .wrap { display: grid; gap: clamp(36px, 5vw, 64px); align-items: center; }
.hero h1 { font-size: var(--t-display); margin-top: 20px; max-width: 15ch; letter-spacing: -0.012em; }
.hero .lead { font-size: var(--t-lead); color: var(--ink-soft); max-width: 50ch; margin-top: 22px; }
.hero .cta-row { display: flex; flex-wrap: wrap; align-items: center; gap: 22px; margin-top: 34px; }
.hero-figure { position: relative; justify-self: center; }
.hero-figure img { width: min(340px, 74vw); border-radius: 8px; box-shadow: var(--shadow); }
.hero-figure figcaption {
  position: absolute; right: -6px; bottom: 20px;
  background: var(--paper-raised); border: 1px solid var(--line);
  padding: 8px 14px; border-radius: 3px; box-shadow: var(--stamp);
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--copper); font-weight: 600;
}
.trust {
  display: flex; flex-wrap: wrap; gap: 10px 26px; margin-top: 38px; padding-top: 22px;
  border-top: 1px solid var(--line); color: var(--ink-soft); font-size: 0.92rem;
}
.trust span { display: inline-flex; align-items: center; gap: 9px; }
.trust span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--leaf); }

/* Section scaffolding */
.section { padding-block: clamp(48px, 7vw, 104px); }
.section-head { max-width: 46ch; margin-bottom: clamp(28px, 4vw, 52px); }
.section-head h2 { font-size: var(--t-h2); margin-top: 14px; letter-spacing: -0.01em; }
.section-head p { color: var(--ink-soft); margin-top: 14px; }

/* Offerings — brand icon-plate + editorial list (no cards, no emoji). */
.offer { border-top: 1px solid var(--line); background: var(--paper-raised); }
.offer .grid { display: grid; gap: clamp(30px, 4vw, 60px); align-items: center; }
.offer figure { margin: 0; }
.offer figure img { border-radius: 8px; box-shadow: var(--shadow); }
.range { list-style: none; margin: 0; padding: 0; }
.range li { display: grid; grid-template-columns: 92px 1fr; gap: 2px 20px; padding: 20px 0; border-top: 1px solid var(--line); }
.range li:last-child { border-bottom: 1px solid var(--line); }
.range .cadence { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--copper); padding-top: 6px; }
.range .name { font-family: "Young Serif", serif; font-size: var(--t-h3); }
.range .desc { color: var(--ink-soft); margin-top: 4px; }

/* How it works — serif numerals, no boxes. */
.steps { display: grid; gap: clamp(28px, 4vw, 44px); }
.step .n { font-family: "Young Serif", serif; font-size: clamp(2.4rem, 4vw, 3.2rem); color: var(--copper); line-height: 0.9; }
.step h3 { font-size: var(--t-h3); margin-top: 14px; }
.step p { color: var(--ink-soft); margin-top: 8px; max-width: 32ch; }

/* Finale — one intentional centred "seal" moment. */
.finale {
  text-align: center; border-top: 1px solid var(--line);
  padding-block: clamp(60px, 9vw, 128px);
  background: radial-gradient(120% 80% at 50% -10%, color-mix(in oklch, var(--copper) 9%, var(--paper)), var(--paper));
}
.finale img { width: 88px; margin: 0 auto 26px; }
.finale h2 { font-size: var(--t-h2); max-width: 17ch; margin-inline: auto; letter-spacing: -0.01em; }
.finale .btn { margin-top: 32px; }

/* Footer */
.footer { background: var(--espresso); color: var(--on-espresso); padding-block: clamp(44px, 6vw, 72px); }
.footer .grid { display: grid; gap: 30px; }
.footer .wordmark b, .footer .wordmark small { color: var(--on-espresso); }
.footer .wordmark small { color: color-mix(in oklch, var(--on-espresso) 72%, transparent); }
.footer nav { display: flex; flex-direction: column; gap: 11px; }
.footer nav a, .footer .contact a { color: var(--on-espresso); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color .2s; width: fit-content; }
.footer nav a:hover, .footer .contact a:hover { border-color: color-mix(in oklch, var(--copper) 70%, var(--on-espresso)); }
.footer .colhead { font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: color-mix(in oklch, var(--on-espresso) 60%, transparent); margin-bottom: 14px; }
.footer .fine { color: color-mix(in oklch, var(--on-espresso) 62%, transparent); font-size: 0.9rem; margin-top: 6px; }

/* Legal pages */
.legal { max-width: 68ch; margin-inline: auto; padding-block: clamp(40px, 6vw, 72px); }
.legal h1 { font-size: clamp(2.1rem, 1.5rem + 2vw, 3rem); }
.legal .updated { color: var(--ink-soft); font-size: 0.92rem; margin-top: 8px; margin-bottom: 34px; }
.legal h2 { font-size: var(--t-h3); margin-top: 36px; margin-bottom: 10px; }
.legal p, .legal li { color: oklch(0.36 0.028 52); }
.legal ul { padding-left: 1.15rem; }
.legal li { margin-bottom: 8px; }
.legal a { font-weight: 600; }
.back { display: inline-flex; gap: 8px; margin-bottom: 24px; text-decoration: none; font-weight: 600; color: var(--copper-deep); }

/* Load motion */
@media (prefers-reduced-motion: no-preference) {
  .rise { opacity: 0; transform: translateY(18px); animation: rise .85s cubic-bezier(.2,.7,.2,1) forwards; animation-delay: var(--d, 0s); }
  @keyframes rise { to { opacity: 1; transform: none; } }
}

/* Desktop */
@media (min-width: 860px) {
  .hero .wrap { grid-template-columns: 1.12fr 0.88fr; }
  .offer .grid { grid-template-columns: 0.86fr 1.14fr; }
  .steps { grid-template-columns: repeat(3, 1fr); gap: clamp(28px, 3vw, 48px); }
  .footer .grid { grid-template-columns: 1.5fr 1fr 1fr; align-items: start; }
}
