/*
Theme Name: Hack The SEO — Prime
Theme URI: https://hacktheseo.com/
Author: Hack The SEO
Author URI: https://hacktheseo.com/
Description: Thème vitrine FSE (Full Site Editing) reprenant l'offre Prime de Hack The SEO — build + run + preuve. Style néo-brutaliste, polices DM Sans / DM Serif Text, palette corail / crème, patterns prêts à l'emploi. Compatible WordPress 7.
Requires at least: 7.0
Tested up to: 7.0
Requires PHP: 7.4
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hacktheseo-prime
Tags: full-site-editing, block-patterns, one-column, business, custom-colors, custom-logo, custom-menu, editor-style, translation-ready
*/

/* ===== Hack The SEO — Prime : tokens + composants ===== */
/* =============================================================
   Hack The SEO — Design Tokens (canonical)
   Source: hacktheseo.com CSS audit (uploads/tokens.css + DESIGN_SYSTEM.md)
   ============================================================= */

/* DM Sans stays on Google Fonts (no local files supplied) */
/* latin-ext */
/* latin */
/* latin-ext */
/* latin */
/* latin-ext */
/* latin */
/* latin-ext */
/* latin */
/* DM Serif Text — brand-supplied local TTFs */
:root {
  /* ---------- COLOR ---------- */
  --color-primary:   #FF9966;
  --color-secondary: #EDA6E6;
  --color-accent:    #FFC127;
  --color-headline:  #1B1C1D;
  --color-body:      #1B1C1D;
  --color-light:     #F5F3EA;
  --color-border:    #E1DFD6;
  --color-white:     #FFFFFF;

  /* Semantic */
  --color-success:   #2E7D4F;
  --color-warning:   #FFC127;
  --color-error:     #D94A4A;
  --color-info:      #1B1C1D;

  /* ---------- TYPOGRAPHY ---------- */
  --font-display: "DM Serif Text", Georgia, serif;
  --font-ui:      "DM Sans", system-ui, -apple-system, sans-serif;

  --fs-h1: clamp(34px, 5vw, 56px);
  --fs-h2: clamp(26px, 4vw, 46px);
  --fs-h3: clamp(19px, 2vw, 26px);
  --fs-h4: clamp(16px, 1.5vw, 20px);
  --fs-h5: clamp(14px, 1vw, 16px);
  --fs-h6: clamp(12px, 0.9vw, 14px);
  --fs-body: clamp(16px, 1.1vw, 18px);
  --fs-small: 14px;
  --fs-button: 17px;

  --lh-display: 1.2;
  --lh-h1: 1.5;
  --lh-body: 1.7;

  --ls-tight:   -0.027em;
  --ls-display: -0.015em;

  /* ---------- SPACE ---------- */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-9:  36px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;
  --space-32: 128px;

  /* ---------- LAYOUT ---------- */
  --container-max:    1170px;
  --container-gutter: max(5%, 16px);

  /* ---------- RADIUS ---------- */
  --radius-xs:  3px;
  --radius-sm:  6px;
  --radius-md:  12px;
  --radius-lg:  16px;
  --radius-xl:  20px;
  --radius-2xl: 24px;
  --radius-pill: 100px;
  --radius-asymmetric-1: 24px 0 15px 0;
  --radius-asymmetric-2: 32px 0 19px 0;
  --radius-asymmetric-top: 16px 16px 0 0;

  /* ---------- SHADOW ---------- */
  --shadow-brutal-sm: 4px 4px 0 0 #000;
  --shadow-brutal-md: 5px 5px 0 0 #1B1E21;
  --shadow-brutal-lg: 8px 8px 0 0 #1B1E21;
  --shadow-soft-sm:   0 0 18px -13px #252525;
  --shadow-soft-md:   0 10px 35px -5px rgba(0, 0, 0, 0.1);

  /* ---------- MOTION ---------- */
  --ease-snappy:   cubic-bezier(.68, .01, .58, .75);
  --duration-fast: 150ms;
  --duration-base: 200ms;
  --duration-slow: 400ms;
}

/* =============================================================
   BASE
   ============================================================= */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

body {
  margin: 0;
  font-family: var(--font-ui);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--color-body);
  background: var(--color-white);
}

h1, .h1 { font-family: var(--font-display); font-size: var(--fs-h1); line-height: var(--lh-h1); font-weight: 400; color: var(--color-headline); margin: 0 0 .5em; }
h2, .h2 { font-family: var(--font-display); font-size: var(--fs-h2); line-height: var(--lh-display); font-weight: 400; color: var(--color-headline); margin: 0 0 .5em; }
h3, .h3 { font-family: var(--font-ui); font-size: var(--fs-h3); line-height: var(--lh-display); font-weight: 500; letter-spacing: var(--ls-tight); color: var(--color-headline); margin: 0 0 .5em; }
h4, .h4 { font-family: var(--font-ui); font-size: var(--fs-h4); line-height: var(--lh-display); font-weight: 500; letter-spacing: var(--ls-tight); color: var(--color-headline); margin: 0 0 .5em; }
h5, .h5 { font-family: var(--font-display); font-size: var(--fs-h5); line-height: var(--lh-display); font-weight: 400; letter-spacing: var(--ls-display); color: var(--color-accent); margin: 0 0 .5em; }
h6, .h6 { font-family: var(--font-display); font-size: var(--fs-h6); line-height: var(--lh-display); font-weight: 400; letter-spacing: var(--ls-tight); text-transform: uppercase; color: var(--color-headline); margin: 0 0 .5em; }

a { color: var(--color-primary); text-decoration: none; transition: color var(--duration-base) var(--ease-snappy); }
a:hover { color: var(--color-headline); }

/* =============================================================
   COMPONENTS
   ============================================================= */

.container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--container-gutter); }

/* Button */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--font-ui); font-size: var(--fs-button); font-weight: 700;
  line-height: 1; text-decoration: none;
  border-radius: var(--radius-sm); border: 2px solid var(--color-headline);
  padding: 18px 33px; cursor: pointer;
  transition: all var(--duration-base) var(--ease-snappy);
}
.btn-primary { background: var(--color-primary); color: var(--color-headline); box-shadow: var(--shadow-brutal-sm); }
.btn-primary:hover  { background: var(--color-secondary); transform: translate(2px, 2px); box-shadow: 2px 2px 0 0 #000; }
.btn-primary:active { transform: translate(4px, 4px); box-shadow: 0 0 0 0 #000; }
.btn-dark  { background: var(--color-headline); color: var(--color-white); padding: 13px 20px; font-size: 16px; }
.btn-dark:hover { background: var(--color-primary); color: var(--color-headline); }
.btn-ghost { background: transparent; color: var(--color-headline); box-shadow: var(--shadow-brutal-sm); }
.btn-ghost:hover { background: var(--color-primary); transform: translate(2px, 2px); box-shadow: 2px 2px 0 0 #000; }
.btn-hero  { background: var(--color-primary); color: var(--color-headline); font-size: 18px; font-weight: 900; padding: 20px 36px; box-shadow: var(--shadow-brutal-lg); }
.btn-hero:hover { background: var(--color-secondary); transform: translate(4px, 4px); box-shadow: 4px 4px 0 0 #1B1E21; }

/* Card */
.card          { background: var(--color-white); border: 2px solid var(--color-headline); border-radius: var(--radius-lg); box-shadow: var(--shadow-brutal-md); padding: var(--space-8); }
.card--light   { background: var(--color-light); }
.card--accent  { background: var(--color-secondary); }
.card--soft    { border: 1px solid var(--color-border); box-shadow: var(--shadow-soft-md); }

/* Eyebrow / Badge / Input / Section */
.eyebrow { display: block; font-family: var(--font-display); font-size: var(--fs-h5); color: var(--color-accent); letter-spacing: var(--ls-display); margin-bottom: var(--space-3); }
.badge { display: inline-flex; align-items: center; gap: 6px; background: var(--color-accent); color: var(--color-headline); border: 1.5px solid var(--color-headline); border-radius: var(--radius-pill); padding: 6px 14px; font-family: var(--font-ui); font-size: 13px; font-weight: 700; line-height: 1; text-transform: uppercase; letter-spacing: 0.03em; }
.input { background: var(--color-white); border: 2px solid var(--color-headline); border-radius: var(--radius-sm); padding: 14px 16px; font-family: var(--font-ui); font-size: 16px; line-height: 1.2; color: var(--color-headline); transition: box-shadow var(--duration-base) var(--ease-snappy); width: 100%; }
.input:focus { outline: none; box-shadow: var(--shadow-brutal-sm); }
.section { padding-block: var(--space-20); }
.section--alt { background: var(--color-light); }

/* ===== Prime — styles de page ===== */
:root { --ink: #1B1C1D; }
  * { box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body { margin: 0; background: var(--color-white); color: var(--ink); font-family: var(--font-ui); overflow-x: hidden; }
  img { max-width: 100%; display: block; }
  .wrap { max-width: 1170px; margin-inline: auto; padding-inline: max(5%, 18px); }
  em { font-style: italic; color: var(--color-primary); }
  section { position: relative; }

  /* ---------- HEADER ---------- */
  .nav {
    position: sticky; top: 0; z-index: 50;
    background: var(--color-white);
    border-bottom: 2px solid var(--ink);
  }
  .nav__in { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 14px max(5%,18px); max-width: 1170px; margin-inline: auto; }
  .nav__logo img { height: 40px; }
  .nav__links { display: flex; gap: 30px; }
  .nav__links a { font-size: 15px; font-weight: 500; color: var(--ink); letter-spacing: -0.01em; padding-bottom: 3px; border-bottom: 2px solid transparent; transition: border-color .2s var(--ease-snappy); }
  .nav__links a:hover { border-bottom-color: var(--color-primary); }

  /* ---------- BUTTONS ---------- */
  .btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-ui); font-weight: 700; line-height: 1; border: 2px solid var(--ink); border-radius: var(--radius-sm); cursor: pointer; text-decoration: none; transition: all .2s var(--ease-snappy); white-space: nowrap; }
  .btn--dark { background: var(--ink); color: #fff; padding: 13px 22px; font-size: 15px; }
  .btn--dark:hover { background: var(--color-primary); color: var(--ink); }
  .btn--primary { background: var(--color-primary); color: var(--ink); padding: 18px 32px; font-size: 17px; box-shadow: var(--shadow-brutal-sm); }
  .btn--primary:hover { background: var(--color-secondary); transform: translate(2px,2px); box-shadow: 2px 2px 0 0 #000; }
  .btn--primary:active { transform: translate(4px,4px); box-shadow: 0 0 0 0 #000; }
  .btn--hero { background: var(--color-primary); color: var(--ink); padding: 21px 38px; font-size: 18px; font-weight: 900; box-shadow: var(--shadow-brutal-lg); }
  .btn--hero:hover { background: var(--color-secondary); transform: translate(4px,4px); box-shadow: 4px 4px 0 0 #1B1E21; }
  .btn--ghost { background: transparent; color: var(--ink); padding: 18px 30px; font-size: 17px; box-shadow: var(--shadow-brutal-sm); }
  .btn--ghost:hover { background: #fff; transform: translate(2px,2px); box-shadow: 2px 2px 0 0 #000; }
  .btn--light { background: var(--color-primary); color: var(--ink); padding: 21px 38px; font-size: 18px; font-weight: 900; box-shadow: 8px 8px 0 0 #fff; }
  .btn--light:hover { background: var(--color-secondary); transform: translate(4px,4px); box-shadow: 4px 4px 0 0 #fff; }

  /* ---------- TYPE ---------- */
  .eyebrow { display: inline-block; font-family: var(--font-display); font-size: 16px; color: var(--color-accent); letter-spacing: -0.015em; margin-bottom: 16px; }
  .eyebrow--tag { background: var(--ink); color: var(--color-accent); font-family: var(--font-ui); font-weight: 700; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; padding: 7px 14px; border-radius: var(--radius-pill); }
  h1, h2 { font-family: var(--font-display); font-weight: 400; }
  .display { font-size: clamp(38px, 6vw, 66px); line-height: 1.06; letter-spacing: -0.01em; margin: 0; }
  .h-sec { font-size: clamp(30px, 4.4vw, 50px); line-height: 1.12; letter-spacing: -0.01em; margin: 0 0 18px; }
  .lead { font-size: clamp(17px, 1.4vw, 21px); line-height: 1.65; color: var(--ink); }
  .muted { color: #5b5b57; }

  /* ---------- SECTION RHYTHM ---------- */
  .sec { padding-block: clamp(64px, 9vw, 116px); }
  .sec--cream { background: var(--color-light); }
  .sec--ink { background: var(--ink); color: #fff; }
  .sec--ink h2 { color: #fff; }
  .sec--ink .muted { color: #b9b8b1; }
  .sec--bord { border-bottom: 2px solid var(--ink); }

  /* ---------- HERO ---------- */
  .hero { background: var(--color-light); border-bottom: 2px solid var(--ink); padding-block: clamp(56px, 7vw, 92px); position: relative; }
  .hero__grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 56px; align-items: center; }
  .hero__sig { font-family: var(--font-display); font-size: clamp(16px,1.5vw,20px); line-height: 1.5; margin: 22px 0 30px; padding-left: 18px; border-left: 4px solid var(--color-primary); }
  .hero__cta { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
  .hero__ticks { display: flex; gap: 22px; flex-wrap: wrap; margin-top: 30px; font-size: 14px; font-weight: 500; color: #4a4a46; }
  .hero__ticks span { display: inline-flex; align-items: center; gap: 8px; }
  .hero__ticks b { font-weight: 700; color: var(--ink); }
  .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--color-primary); border: 1.5px solid var(--ink); flex: none; }

  /* AI answer mock card */
  .ai { background: #fff; border: 2px solid var(--ink); border-radius: var(--radius-lg); box-shadow: var(--shadow-brutal-lg); padding: 24px; }
  .ai__bar { display: flex; align-items: center; gap: 10px; padding-bottom: 14px; border-bottom: 1.5px solid var(--color-border); margin-bottom: 16px; }
  .ai__glyph { width: 30px; height: 30px; border-radius: 8px; background: var(--ink); color: var(--color-accent); display: grid; place-items: center; font-family: var(--font-display); font-size: 16px; flex: none; }
  .ai__bar b { font-size: 14px; }
  .ai__bar span { font-size: 12px; color: #8a8a85; margin-left: auto; }
  .ai__txt { font-size: 15px; line-height: 1.6; color: #2a2a28; margin: 0; }
  .cited { background: var(--color-primary); border: 1.5px solid var(--ink); border-radius: 5px; padding: 1px 6px; font-weight: 700; white-space: nowrap; }
  .ai__foot { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-top: 18px; padding-top: 16px; border-top: 1.5px solid var(--color-border); }
  .ai__metric { font-family: var(--font-display); font-size: 40px; line-height: 1; }
  .ai__delta { font-size: 13px; font-weight: 700; color: var(--color-success); }
  .pill-ava { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; background: var(--color-light); border: 1.5px solid var(--ink); border-radius: var(--radius-pill); padding: 6px 12px; }

  /* ---------- PROBLEME ---------- */
  .split { display: grid; grid-template-columns: 1fr auto 1fr; gap: 0; align-items: stretch; margin-top: 14px; }
  .split__card { background: #fff; border: 2px solid var(--ink); padding: 34px; }
  .split__card:first-child { border-radius: var(--radius-lg) 0 0 var(--radius-lg); border-right: none; }
  .split__card:last-child { border-radius: 0 var(--radius-lg) var(--radius-lg) 0; border-left: none; }
  .split__vs { display: grid; place-items: center; width: 64px; background: var(--ink); color: #fff; font-family: var(--font-display); font-size: 22px; z-index: 2; }
  .split__card h3 { font-family: var(--font-ui); font-weight: 700; font-size: 20px; letter-spacing: -0.02em; margin: 0 0 6px; }
  .split__card p { font-size: 15px; line-height: 1.6; color: #4a4a46; margin: 0; }
  .split__tag { display: inline-block; font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--color-primary); margin-bottom: 14px; }
  .invis { margin-top: 30px; background: var(--ink); color: #fff; border-radius: var(--radius-lg); padding: 38px 40px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 34px; align-items: center; }
  .invis p { margin: 0; font-size: clamp(19px,2vw,26px); line-height: 1.4; font-family: var(--font-display); }
  .invis__list { display: flex; flex-direction: column; gap: 12px; }
  .invis__list div { display: flex; align-items: center; gap: 12px; font-size: 15px; color: #d8d7d0; }
  .x { width: 22px; height: 22px; flex: none; border: 1.5px solid var(--color-primary); border-radius: 6px; display: grid; place-items: center; color: var(--color-primary); font-weight: 700; font-size: 13px; }

  /* ---------- FLYWHEEL ---------- */
  .fly { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: stretch; gap: 0; margin-top: 8px; }
  .fly__node { background: #fff; border: 2px solid var(--ink); border-radius: var(--radius-lg); box-shadow: var(--shadow-brutal-md); padding: 30px 26px; text-align: left; }
  .fly__num { font-family: var(--font-display); font-size: 16px; width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--ink); display: grid; place-items: center; margin-bottom: 16px; }
  .fly__node:nth-child(1) .fly__num { background: var(--color-primary); }
  .fly__node:nth-child(3) .fly__num { background: var(--color-accent); }
  .fly__node:nth-child(5) .fly__num { background: var(--color-secondary); }
  .fly__node h3 { font-family: var(--font-display); font-weight: 400; font-size: 26px; margin: 0 0 8px; }
  .fly__node p { font-size: 14px; line-height: 1.55; color: #4a4a46; margin: 0; }
  .fly__node .k { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--color-primary); display: block; margin-top: 14px; }
  .fly__arrow { display: grid; place-items: center; width: 58px; font-size: 30px; color: var(--ink); }
  .fly__loop { margin-top: 18px; display: flex; align-items: center; justify-content: center; gap: 12px; font-size: 15px; font-weight: 600; color: #4a4a46; background: var(--color-light); border: 2px dashed var(--ink); border-radius: var(--radius-pill); padding: 13px 26px; width: fit-content; margin-inline: auto; }
  .fly__loop b { color: var(--ink); font-weight: 700; }

  /* ---------- 3 BRIQUES ---------- */
  .grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 8px; }
  .brick { background: #fff; border: 2px solid var(--ink); border-radius: var(--radius-lg); box-shadow: var(--shadow-brutal-md); padding: 32px; display: flex; flex-direction: column; }
  .brick__ic { width: 56px; height: 56px; border-radius: 50%; border: 2px solid var(--ink); display: grid; place-items: center; font-family: var(--font-display); font-size: 26px; margin-bottom: 20px; box-shadow: var(--shadow-brutal-sm); }
  .brick:nth-child(1) .brick__ic { background: var(--color-primary); }
  .brick:nth-child(2) .brick__ic { background: var(--color-accent); }
  .brick:nth-child(3) .brick__ic { background: var(--color-secondary); }
  .brick h3 { font-family: var(--font-display); font-weight: 400; font-size: 27px; margin: 0 0 4px; }
  .brick .sub { font-size: 13px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--color-primary); margin-bottom: 14px; }
  .brick p { font-size: 15px; line-height: 1.62; color: #45453f; margin: 0 0 16px; }
  .brick ul { list-style: none; margin: auto 0 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
  .brick li { display: flex; gap: 10px; font-size: 14px; line-height: 1.45; }
  .brick li::before { content: "→"; color: var(--color-primary); font-weight: 700; flex: none; }

  /* ---------- AVA PROOF ---------- */
  .ava { display: grid; grid-template-columns: 1fr 1.05fr; gap: 60px; align-items: center; }
  .ava__quote { font-family: var(--font-display); font-size: clamp(28px,3.4vw,46px); line-height: 1.18; margin: 0 0 20px; }
  .ava__board { background: #232425; border: 2px solid #3a3b3c; border-radius: var(--radius-lg); padding: 34px; }
  .ava__row { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
  .ava__cell { flex: 1; }
  .ava__cap { font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #8a8b8c; margin-bottom: 8px; }
  .ava__big { font-family: var(--font-display); font-size: clamp(62px,8vw,104px); line-height: .9; }
  .ava__big.before { color: #6c6d6e; }
  .ava__big.after { color: var(--color-primary); }
  .ava__arrow { font-size: 38px; color: var(--color-accent); padding-bottom: 14px; }
  .ava__bars { display: flex; align-items: flex-end; gap: 6px; height: 64px; margin-top: 26px; }
  .ava__bars i { flex: 1; background: #3a3b3c; border-radius: 3px 3px 0 0; transition: height 1.1s var(--ease-snappy), background .6s; }
  .ava__bars i.on { background: var(--color-primary); }
  .ava__foot { display: flex; align-items: center; gap: 10px; margin-top: 24px; font-size: 13px; color: #b9b8b1; }

  /* ---------- DIFFERENCE / 4 briques ---------- */
  .roof { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 8px; border: 2px solid var(--ink); border-radius: var(--radius-lg); overflow: hidden; background: var(--ink); }
  .roof__cell { background: #fff; padding: 30px 26px; border-right: 2px solid var(--ink); }
  .roof__cell:last-child { border-right: none; }
  .roof__n { font-family: var(--font-display); font-size: 15px; color: var(--color-primary); margin-bottom: 14px; }
  .roof__cell h3 { font-family: var(--font-ui); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; line-height: 1.2; margin: 0 0 10px; }
  .roof__cell p { font-size: 14px; line-height: 1.55; color: #4a4a46; margin: 0; }
  .roof__banner { text-align: center; margin-top: 22px; font-family: var(--font-display); font-size: clamp(18px,2vw,24px); }

  /* ---------- PRICING ---------- */
  .price { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 10px; align-items: stretch; }
  .col { background: #fff; border: 2px solid var(--ink); border-left: none; padding: 28px 22px; display: flex; flex-direction: column; }
  .col:first-child { border-left: 2px solid var(--ink); border-radius: var(--radius-lg) 0 0 var(--radius-lg); }
  .col:last-child { border-radius: 0 var(--radius-lg) var(--radius-lg) 0; }
  .col--reco { background: var(--ink); color: #fff; border-color: var(--ink); transform: translateY(-14px); box-shadow: var(--shadow-brutal-lg); border-radius: var(--radius-lg) !important; z-index: 3; }
  .col--reco .price__feat { color: #d8d7d0; border-color: #3a3b3c; }
  .col--reco .price__feat b { color: #fff; }
  .reco-tag { display: inline-block; background: var(--color-primary); color: var(--ink); border: 1.5px solid #000; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 5px 10px; border-radius: var(--radius-pill); margin-bottom: 12px; }
  .col__name { font-family: var(--font-display); font-size: 23px; line-height: 1.1; margin: 0 0 4px; min-height: 52px; }
  .col__price { font-family: var(--font-display); font-size: 40px; line-height: 1; }
  .col__price small { font-family: var(--font-ui); font-size: 14px; font-weight: 500; color: #8a8a85; }
  .col--reco .col__price small { color: #9a9b9c; }
  .col__setup { font-size: 13px; color: #6a6a66; margin: 6px 0 18px; }
  .col--reco .col__setup { color: #b9b8b1; }
  .price__feat { font-size: 13.5px; line-height: 1.4; padding: 11px 0; border-top: 1px solid var(--color-border); display: flex; flex-direction: column; gap: 2px; }
  .price__feat .lbl { font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: #9a9a95; font-weight: 700; }
  .col--reco .price__feat .lbl { color: #8a8b8c; }
  .price__feat b { font-weight: 700; }
  .price__feat.guar { color: var(--color-success); font-weight: 700; }
  .col--reco .price__feat.guar { color: var(--color-primary); }
  .col .btn { margin-top: 18px; justify-content: center; }
  .col--reco .btn--ghost { color: #fff; border-color: #fff; box-shadow: 4px 4px 0 0 var(--color-primary); }
  .col--reco .btn--ghost:hover { background: var(--color-primary); color: var(--ink); box-shadow: 2px 2px 0 0 #fff; }
  .yes { color: var(--color-success); font-weight: 700; }
  .col--reco .yes { color: var(--color-primary); }
  .dash { color: #c3c2bb; }
  .price__extra { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 14px 28px; align-items: center; justify-content: space-between; }
  .addons { display: flex; flex-wrap: wrap; gap: 10px; }
  .addon { font-size: 13px; font-weight: 600; background: #fff; border: 1.5px solid var(--ink); border-radius: var(--radius-pill); padding: 7px 14px; }
  .addon b { color: var(--color-primary); }
  .bespoke { font-size: 14px; font-weight: 600; }
  .bespoke b { font-family: var(--font-display); font-weight: 400; }
  .ht { text-align: right; font-size: 12px; color: #8a8a85; margin-top: 10px; }

  /* ---------- TRUST ---------- */
  .trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 2px solid var(--ink); border-radius: var(--radius-lg); overflow: hidden; background: var(--ink); }
  .trust__cell { background: var(--color-light); padding: 40px 28px; text-align: center; border-right: 2px solid var(--ink); }
  .trust__cell:last-child { border-right: none; }
  .trust__num { font-family: var(--font-display); font-size: clamp(40px,5vw,62px); line-height: 1; }
  .trust__num em { color: var(--color-primary); }
  .trust__lbl { font-size: 15px; color: #4a4a46; margin-top: 10px; line-height: 1.4; }

  /* ---------- CTA FINAL ---------- */
  .cta { text-align: center; }
  .cta h2 { max-width: 880px; margin-inline: auto; }
  .cta .lead { max-width: 600px; margin: 0 auto 36px; }
  .cta__re { display: flex; gap: 14px 28px; flex-wrap: wrap; justify-content: center; margin-top: 30px; font-size: 14px; color: #b9b8b1; }
  .cta__re span { display: inline-flex; align-items: center; gap: 8px; }
  .check { color: var(--color-primary); font-weight: 700; }

  /* ---------- FOOTER ---------- */
  .foot { background: #111213; color: #fff; padding: 56px max(5%,18px) 30px; }
  .foot__in { max-width: 1170px; margin-inline: auto; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; }
  .foot__brand img { height: 40px; margin-bottom: 16px; }
  .foot__brand p { font-size: 14px; line-height: 1.6; color: #b9b8b1; max-width: 340px; margin: 0; }
  .foot h5 { font-family: var(--font-display); font-weight: 400; font-size: 14px; text-transform: uppercase; letter-spacing: -0.02em; color: var(--color-accent); margin: 0 0 14px; }
  .foot a { display: block; font-size: 14px; color: #d8d7d0; padding: 4px 0; }
  .foot a:hover { color: var(--color-primary); }
  .foot__bar { max-width: 1170px; margin: 36px auto 0; padding-top: 18px; border-top: 1px solid #2a2b2c; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; font-size: 12px; color: #8a8a85; }

  .js .reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease-snappy), transform .6s var(--ease-snappy); }
  .js .reveal.in { opacity: 1; transform: none; }
  @media (prefers-reduced-motion: reduce) { .js .reveal { opacity: 1; transform: none; } }

  /* ---------- RESPONSIVE ---------- */
  @media (max-width: 940px) {
    .nav__links { display: none; }
    .hero__grid { grid-template-columns: 1fr; gap: 38px; }
    .ava { grid-template-columns: 1fr; gap: 34px; }
    .invis { grid-template-columns: 1fr; gap: 22px; }
    .fly { grid-template-columns: 1fr; }
    .fly__arrow { width: auto; height: 46px; transform: rotate(90deg); }
    .roof { grid-template-columns: 1fr 1fr; }
    .roof__cell:nth-child(2) { border-right: none; }
    .roof__cell:nth-child(1), .roof__cell:nth-child(2) { border-bottom: 2px solid var(--ink); }
    .price { grid-template-columns: 1fr 1fr; gap: 16px; }
    .col, .col:first-child, .col:last-child { border: 2px solid var(--ink) !important; border-radius: var(--radius-lg) !important; }
    .col--reco { transform: none; }
    .trust { grid-template-columns: 1fr; }
    .trust__cell { border-right: none; border-bottom: 2px solid var(--ink); }
    .trust__cell:last-child { border-bottom: none; }
    .foot__in { grid-template-columns: 1fr 1fr; }
  }
  @media (max-width: 600px) {
    .grid3 { grid-template-columns: 1fr; }
    .split { grid-template-columns: 1fr; }
    .split__card, .split__card:first-child, .split__card:last-child { border-radius: var(--radius-lg); border: 2px solid var(--ink); }
    .split__vs { width: 100%; height: 48px; }
    .roof { grid-template-columns: 1fr; }
    .roof__cell { border-right: none; border-bottom: 2px solid var(--ink); }
    .roof__cell:last-child { border-bottom: none; }
    .price { grid-template-columns: 1fr; }
    .foot__in { grid-template-columns: 1fr; gap: 28px; }
    .ai__foot { flex-direction: column; align-items: flex-start; }
  }
