/* =========================================================
   ANTINORI STUDIO
   Palette : warm-neutral paper, near-black ink, muted slate-blue accent
   Type    : Space Grotesk (display) + Inter (body)
   ========================================================= */

:root{
  --paper:#F4F1EA;
  --surface:#FFFFFF;
  --surface-2:#FAF8F3;
  --ink:#0D0D0F;          /* near-black, matches logo field */
  --ink-2:#3A3A3E;
  --ink-3:#6B6B70;
  --line:#E6E2D7;
  --line-2:#D8D3C5;

  /* gold sampled from the logo ring */
  --accent:#C7973F;       /* primary metallic gold */
  --accent-600:#A87C2C;   /* deeper gold, hover */
  --accent-bright:#E2B560;/* highlight gold */
  --accent-tint:#F4EAD3;  /* warm tint for icon pads / bullets */
  --accent-ink:#7E5E1E;   /* accessible gold text on light backgrounds */
  --on-gold:#1A1407;      /* text that sits on a gold button */

  --maxw:1120px;
  --pad:24px;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 1px 2px rgba(25,27,31,.04), 0 12px 32px rgba(25,27,31,.06);
  --shadow-lg:0 2px 6px rgba(25,27,31,.06), 0 24px 60px rgba(25,27,31,.12);

  --font-display:"Space Grotesk", system-ui, sans-serif;
  --font-body:"Inter", system-ui, -apple-system, sans-serif;
}

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

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

.skip-link{
  position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;
  padding:10px 16px;border-radius:0 0 8px 0;z-index:200;
}
.skip-link:focus{left:0}

/* ---------- shared type ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-display);
  font-size:.76rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-ink);margin-bottom:20px;
}
.eyebrow::before{
  content:"";width:26px;height:1.5px;background:var(--accent);flex:none;
}
.h2{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.7vw,2.7rem);
  font-weight:600;line-height:1.1;letter-spacing:-.02em;color:var(--ink);max-width:18ch;
}
.lede{max-width:680px;margin-bottom:46px}
.lede__text{margin-top:20px;color:var(--ink-2);font-size:1.08rem;line-height:1.65;max-width:600px}
.note{margin-top:34px;color:var(--ink-3);font-size:.95rem}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:.96rem;
  padding:13px 22px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .15s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
  white-space:nowrap;
}
.btn:focus-visible{outline:3px solid var(--accent);outline-offset:2px}
.btn--solid{background:var(--accent);color:var(--on-gold)}
.btn--solid:hover{background:var(--accent-bright);transform:translateY(-1px);box-shadow:0 10px 24px rgba(199,151,63,.35)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-1px)}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn--ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.08);transform:translateY(-1px)}
.btn--small{padding:9px 16px;font-size:.88rem}
.btn--block{display:flex;width:100%}

/* ===================== NAV ===================== */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(243,242,238,.82);
  backdrop-filter:saturate(150%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav__inner{display:flex;align-items:center;gap:24px;height:64px}
.brand{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600}
.brand__logo{
  width:36px;height:36px;border-radius:50%;display:block;object-fit:cover;
  background:var(--ink);box-shadow:0 0 0 1px var(--line-2);
}
.brand__mark{
  width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
  background:var(--ink);color:var(--paper);font-size:1rem;font-weight:700;
}
.brand__name{font-size:1.04rem;letter-spacing:-.01em}
.nav__links{display:flex;gap:26px;margin-left:auto;font-size:.95rem}
.nav__links a{color:var(--ink-2);transition:color .15s}
.nav__links a:hover{color:var(--ink)}
.nav__cta{margin-left:4px}
.nav__toggle{
  display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;
  padding:8px;margin-left:auto;
}
.nav__toggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}
.nav__toggle[aria-expanded="true"] span:first-child{transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:last-child{transform:translateY(-7px) rotate(-45deg)}
.nav__mobile{display:none;flex-direction:column;gap:4px;padding:14px var(--pad) 22px;border-bottom:1px solid var(--line);background:var(--paper)}
.nav__mobile a{padding:12px 4px;color:var(--ink-2);border-bottom:1px solid var(--line)}
.nav__mobile a:last-child{border:0;margin-top:10px}

/* ===================== HERO ===================== */
.hero{
  background:var(--ink);color:var(--paper);
  padding:clamp(52px,7vw,92px) 0;
  position:relative;overflow:hidden;
}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 70% at 78% 18%, rgba(199,151,63,.22), transparent 70%);
}
.hero__grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.08fr .92fr;gap:60px;align-items:center;
}
.hero__inner{position:relative;z-index:1;max-width:820px;margin:0 auto;text-align:center}
.hero__copy{max-width:580px}
.hero .eyebrow{color:var(--accent-bright)}
.hero__title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.04;letter-spacing:-.022em;
  max-width:20ch;margin-left:auto;margin-right:auto;
}
.hero__sub{margin:24px auto 0;color:#C9C8C2;font-size:1.14rem;line-height:1.6;max-width:600px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;justify-content:center}
.hero__cta--center{justify-content:center}
.hero__trust{margin-top:24px;font-size:.9rem;color:#8C9098;font-family:var(--font-display)}
.frame--hero{max-width:380px;margin-left:auto}
.hero__industries{margin-top:10px;font-size:.86rem;color:#74787F;max-width:560px}

/* hero browser mock */
.hero__demo{display:flex;justify-content:center}
.frame{
  width:100%;max-width:380px;background:var(--surface);border-radius:16px;
  box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid rgba(255,255,255,.08);
}
.frame__bar{
  display:flex;align-items:center;gap:6px;padding:11px 14px;
  background:#EDECE7;border-bottom:1px solid var(--line);
}
.frame__bar .dot{width:9px;height:9px;border-radius:50%;background:#C9C8C2}
.frame__url{
  margin-left:10px;font-size:.72rem;color:var(--ink-3);
  background:#fff;border-radius:6px;padding:4px 12px;flex:1;text-align:center;
}
.frame__body{padding:20px}
.m-hero{text-align:left}
.m-eyebrow{font-family:var(--font-display);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600}
.m-title{font-family:var(--font-display);font-weight:700;font-size:1.15rem;margin-top:6px;color:var(--ink)}
.m-text{font-size:.78rem;color:var(--ink-2);margin-top:4px}
.m-row{display:flex;gap:8px;margin-top:14px}
.m-btn{
  font-family:var(--font-display);font-size:.7rem;font-weight:600;
  padding:8px 12px;border-radius:8px;
}
.m-btn--solid{background:var(--accent);color:var(--on-gold)}
.m-btn--call{background:#EEF0EF;color:var(--ink)}
.m-btn--full{display:block;text-align:center;margin-top:12px}
.m-chips{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0}
.m-chips span{font-size:.66rem;padding:5px 10px;border-radius:999px;background:#F1F0EC;color:var(--ink-2)}
.m-form{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:14px}
.m-form__title{font-family:var(--font-display);font-weight:600;font-size:.78rem;margin-bottom:10px;color:var(--ink)}
.m-field{height:9px;border-radius:5px;background:#E7E6E1;margin-bottom:8px}
.m-field--tall{height:26px}
.m-input{
  font-size:.72rem;color:var(--ink-3);background:#fff;border:1px solid var(--line);
  border-radius:7px;padding:7px 10px;margin-bottom:8px;
}
.m-input--tall{padding-bottom:22px}

/* ===================== EXAMPLE SYSTEM (demo) ===================== */
.section--demo{padding-top:clamp(52px,7vw,90px)}
.section--demo .lede{margin-bottom:36px}
.demo{
  position:relative;
  display:grid;grid-template-columns:minmax(0,400px) 1fr;gap:40px;align-items:center;
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:22px;
  padding:clamp(28px,4vw,52px);
}
.demo__label{
  grid-column:1 / -1;justify-self:start;
  font-family:var(--font-display);font-size:.7rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent-ink);
  background:var(--accent-tint);padding:5px 12px;border-radius:999px;
  margin-bottom:6px;
}
.demo__device,.demo__tracker{margin:0}
.demo figcaption{
  margin-top:18px;font-family:var(--font-body);
  font-size:.9rem;color:var(--ink-3);line-height:1.5;max-width:34ch;
}
.demo__device{display:flex;flex-direction:column;align-items:flex-start}
.demo__device .frame{max-width:400px;margin:0}
.demo__device figcaption{text-align:left}

.tracker{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.tracker__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--line);background:var(--surface-2);
}
.tracker__title{font-family:var(--font-display);font-weight:600;font-size:1rem}
.tracker__count{font-size:.78rem;color:var(--accent-ink);background:var(--accent-tint);padding:3px 10px;border-radius:999px;font-weight:600}
.tracker__row--head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 20px 12px;font-family:var(--font-display);font-weight:600;color:var(--ink);
}
.tracker__fields{padding:0 20px 4px;display:grid;gap:0}
.tracker__fields > div{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:11px 0;border-top:1px solid var(--line);
}
.tracker__fields dt{color:var(--ink-3);font-size:.9rem}
.tracker__fields dd{color:var(--ink);font-size:.95rem;font-weight:500;text-align:right}
.tracker__foot{padding:12px 20px 18px;color:var(--ink-3);font-size:.86rem}
.badge{
  display:inline-block;font-family:var(--font-display);font-weight:600;font-size:.72rem;
  letter-spacing:.02em;padding:3px 10px;border-radius:999px;
}
.badge--new{background:var(--accent-tint);color:var(--accent-ink)}

/* ===================== SECTIONS ===================== */
.section{padding:clamp(58px,8vw,102px) 0}
.section--tint{background:var(--surface-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section--problem{background:var(--paper)}

/* problem leaks */
.leaks{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 32px;max-width:760px}
.leaks li{
  position:relative;padding-left:30px;color:var(--ink-2);font-size:1rem;
}
.leaks li::before{
  content:"";position:absolute;left:0;top:9px;width:16px;height:16px;border-radius:50%;
  background:var(--accent-tint);
  box-shadow:inset 0 0 0 1.5px var(--accent);
}
.leaks li::after{
  content:"";position:absolute;left:5px;top:14px;width:6px;height:6px;border-radius:50%;background:var(--accent);
}

/* solution cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;box-shadow:0 1px 2px rgba(13,13,15,.03);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.card__icon{
  display:inline-grid;place-items:center;width:46px;height:46px;border-radius:12px;
  background:var(--accent-tint);color:var(--accent-ink);margin-bottom:20px;
}
.card__icon svg{width:22px;height:22px}
.card__title{font-family:var(--font-display);font-weight:600;font-size:1.1rem;margin-bottom:7px}
.card__text{color:var(--ink-2);font-size:.96rem}

/* who it helps tags */
.tags{display:flex;flex-wrap:wrap;gap:12px;max-width:840px}
.tags span{
  font-family:var(--font-display);font-weight:500;font-size:.96rem;
  padding:11px 18px;border-radius:999px;background:var(--surface);
  border:1px solid var(--line-2);color:var(--ink-2);
  transition:border-color .15s, color .15s, transform .15s;
}
.tags span:hover{border-color:var(--accent);color:var(--accent-ink);transform:translateY(-2px)}

/* free preview band */
.section--preview{background:var(--ink);color:#fff;border:0;position:relative;overflow:hidden}
.section--preview::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(55% 80% at 15% 20%, rgba(199,151,63,.20), transparent 70%);
}
.section--preview .wrap{position:relative;z-index:1}
.section--preview .eyebrow{color:var(--accent-bright)}
.section--preview .h2{color:#fff}
.section--preview .lede__text{color:#D7D4CC}
.section--preview .btn--ghost{color:#fff;border-color:rgba(255,255,255,.45)}
.section--preview .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.10)}
.preview{max-width:760px}

/* process steps */
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;position:relative;
  counter-reset:step;
}
.steps::before{
  content:"";position:absolute;top:18px;left:8%;right:8%;height:2px;
  background:linear-gradient(90deg,var(--line-2),var(--accent),var(--line-2));
  opacity:.5;
}
.step{position:relative;padding-top:0}
.step__num{
  position:relative;z-index:1;
  display:grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:var(--ink);color:var(--paper);font-family:var(--font-display);font-weight:700;
  margin-bottom:18px;box-shadow:0 0 0 5px var(--paper);
}
.step__title{font-family:var(--font-display);font-weight:600;font-size:1.06rem;margin-bottom:6px}
.step__text{color:var(--ink-2);font-size:.95rem}

/* example mockups */
.mocks{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.mock figcaption{
  margin-top:14px;text-align:center;font-family:var(--font-display);font-weight:500;
  font-size:.92rem;color:var(--ink-2);
}
.mock__screen{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease;
}
.mock:hover .mock__screen{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.mock__bar{display:flex;gap:5px;padding:10px 12px;background:#EDECE7;border-bottom:1px solid var(--line)}
.mock__bar span{width:8px;height:8px;border-radius:50%;background:#CFCEC8}
.mock__pad{padding:20px;min-height:240px}

/* skeleton blocks */
.sk{background:#E7E6E1;border-radius:6px}
.sk-title{height:18px;width:62%;margin-bottom:12px;background:#D9D8D2}
.sk-subtitle{height:14px;width:46%;margin-bottom:16px;background:#D9D8D2}
.sk-line{height:9px;margin-bottom:14px}
.w70{width:70%}.w50{width:50%}
.sk-row{display:flex;gap:8px;margin-bottom:16px}
.sk-pill{height:26px;width:96px;border-radius:999px}
.sk-pill--accent{background:var(--accent);width:110px}
.sk-block{height:60px;border-radius:10px;margin-bottom:16px}
.sk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.sk-tile{height:50px;border-radius:8px}
.sk-input{height:30px;border-radius:8px;margin-bottom:12px}
.sk-input--tall{height:54px}
.sk-submit{height:34px;width:60%;border-radius:8px;background:var(--accent)}

/* lead sheet mock */
.sheet{border:1px solid var(--line);border-radius:10px;overflow:hidden}
.sheet__head,.sheet__row{display:grid;grid-template-columns:1.4fr 1fr .7fr;gap:10px;padding:11px 12px;align-items:center}
.sheet__head{background:#EFEEE9}
.sheet__head span{height:8px;border-radius:4px;background:#CFCEC8}
.sheet__row{border-top:1px solid var(--line)}
.sheet__row span{height:8px;border-radius:4px;background:#E7E6E1}
.tag{height:16px!important;border-radius:999px!important}
.tag--new{background:var(--accent-tint)!important;box-shadow:inset 0 0 0 1px var(--accent)}
.tag--done{background:#E7E6E1!important}

/* pricing */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.plan{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow);position:relative;
}
.plan--feature{border-color:var(--accent);box-shadow:var(--shadow-lg)}
.plan__flag{
  display:inline-block;margin-bottom:14px;
  font-family:var(--font-display);font-size:.7rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;
  background:var(--accent-tint);color:var(--accent-ink);padding:4px 11px;border-radius:999px;
}
.plan__name{font-family:var(--font-display);font-weight:600;font-size:1.15rem}
.plan__price{font-family:var(--font-display);font-weight:700;font-size:2rem;margin:14px 0 4px;letter-spacing:-.02em}
.plan__from{display:block;font-size:.74rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.plan__cur{font-size:.9rem;font-weight:500;color:var(--ink-3)}
.plan__list{margin:22px 0 26px;display:grid;gap:11px}
.plan__list li{position:relative;padding-left:26px;color:var(--ink-2);font-size:.96rem}
.plan__list li::before{
  content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border-radius:50%;
  background:var(--accent-tint);
}
.plan__list li::after{
  content:"";position:absolute;left:4px;top:10px;width:6px;height:3px;
  border-left:1.6px solid var(--accent-ink);border-bottom:1.6px solid var(--accent-ink);
  transform:rotate(-45deg);
}

/* about */
.about{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:start;max-width:900px}
.about__mark{
  width:120px;height:120px;border-radius:50%;display:block;object-fit:cover;
  background:var(--ink);box-shadow:0 0 0 1px var(--line-2), var(--shadow);
}
.about__copy .lede__text:first-of-type{margin-top:18px}

/* ===================== REVIEWS ===================== */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 24px;box-shadow:var(--shadow);display:flex;flex-direction:column;
}
.stars{display:inline-flex;gap:3px;margin-bottom:14px}
.stars svg{width:18px;height:18px;color:var(--accent);fill:var(--accent)}
.review__text{color:var(--ink-2);font-size:1rem;line-height:1.6;flex:1}
.review__by{
  margin-top:18px;padding-top:16px;border-top:1px solid var(--line);
  font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--ink);
}
.review__by span{display:block;font-family:var(--font-body);font-weight:400;font-size:.86rem;color:var(--ink-3);margin-top:2px}
.review__flag{
  align-self:flex-start;margin-bottom:14px;
  font-family:var(--font-display);font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-ink);background:var(--accent-tint);padding:3px 9px;border-radius:999px;
}
.rating-summary{
  display:inline-flex;align-items:center;gap:12px;margin-top:6px;
  font-family:var(--font-display);color:var(--ink-2);font-size:.96rem;
}
.rating-summary .stars{margin-bottom:0}


/* mockup request form */
.section--mockup-request{background:var(--surface-2)}
.mockup-request{
  display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:44px;align-items:start;
}
.mockup-request__copy{max-width:460px}
.mockup-form{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(22px,3vw,32px);box-shadow:var(--shadow);
}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-grid label{display:grid;gap:7px}
.form-grid span{
  font-family:var(--font-display);font-size:.78rem;font-weight:600;color:var(--ink-2);
}
.form-grid input,.form-grid textarea{
  width:100%;border:1px solid var(--line-2);border-radius:10px;background:var(--surface-2);
  color:var(--ink);font:inherit;padding:12px 13px;outline:none;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.form-grid input:focus,.form-grid textarea:focus{
  border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(199,151,63,.18);
}
.form-grid textarea{resize:vertical;min-height:130px}
.form-grid__full{grid-column:1 / -1}
.mockup-form .btn{margin-top:20px}

/* final cta */
.finalcta{background:var(--ink);color:var(--paper);padding:clamp(60px,9vw,110px) 0;text-align:center;position:relative;overflow:hidden}
.finalcta::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(50% 80% at 50% 0%, rgba(199,151,63,.22), transparent 70%);
}
.finalcta__inner{position:relative;z-index:1;max-width:680px;margin:0 auto}
.finalcta__title{font-family:var(--font-display);font-weight:600;font-size:clamp(1.7rem,3.6vw,2.5rem);line-height:1.12;letter-spacing:-.015em}
.finalcta__text{margin-top:18px;color:#C9C8C2;font-size:1.08rem}

/* footer */
.footer{background:var(--paper);border-top:1px solid var(--line);padding:54px 0 26px}
.footer__inner{display:flex;justify-content:space-between;gap:32px;flex-wrap:wrap}
.brand--footer .brand__mark{background:var(--ink)}
.footer__tag{margin-top:14px;color:var(--ink-3);font-size:.95rem;max-width:320px}
.footer__contact{display:grid;gap:8px;font-size:.96rem;color:var(--ink-2)}
.footer__contact a:hover{color:var(--accent-ink)}
.footer__links{display:grid;gap:9px;align-content:start;font-size:.96rem;font-family:var(--font-display);font-weight:500}
.footer__links a{color:var(--ink-2);transition:color .15s}
.footer__links a:hover{color:var(--accent-ink)}
.footer__base{margin-top:40px;padding-top:20px;border-top:1px solid var(--line);color:var(--ink-3);font-size:.86rem}

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

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.card,.mock__screen,.tags span{transition:none}
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:980px){
  .mockup-request{grid-template-columns:1fr;gap:28px}

  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__demo{max-width:360px;margin:0 auto}
  .frame--hero{margin:0 auto}
  .demo{grid-template-columns:1fr;gap:32px}
  .demo__device{align-items:center}
  .demo__device .frame{margin:0 auto}
  .demo__device figcaption{text-align:center}
  .demo figcaption{max-width:none;text-align:center}
  .cards{grid-template-columns:repeat(2,1fr)}
  .mocks{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .reviews{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .steps{grid-template-columns:repeat(2,1fr);gap:30px 22px}
  .steps::before{display:none}
  .plans{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .plan--feature{transform:none}
}
@media (max-width:680px){
  .form-grid{grid-template-columns:1fr}
  .mockup-form .btn{width:100%}

  .nav__links,.nav__cta{display:none}
  .nav__toggle{display:flex}
  .nav__mobile[data-open="true"]{display:flex}
  .cards{grid-template-columns:1fr}
  .leaks{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .about{grid-template-columns:1fr;gap:24px}
  .hero__cta .btn{flex:1}
}
