/* ═══════════════════════════════════════════════════════
   creer-ton-site.fr — Design System CSS
   Based on Apple HIG · v1.0.0
   ═══════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  /* Colors */
  --c-900: #0D0D0D;
  --c-700: #1E2028;
  --c-500: #3C4257;
  --c-300: #8C93A8;
  --c-100: #E8EAF0;
  --c-50:  #F4F5F7;
  --accent: #C9A96E;
  --accent-dark: #B0884F;
  --accent-light: rgba(201,169,110,0.12);
  --success: #2D7D46;
  --error: #C0392B;

  /* Typography */
  --font-display: "DM Serif Display", Georgia, serif;
  --font-ui: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;

  /* Spacing (8px base) */
  --s-1: 4px;  --s-2: 8px;   --s-3: 12px; --s-4: 16px;
  --s-6: 24px; --s-8: 32px;  --s-12: 48px;--s-16: 64px;
  --s-24: 96px;--s-32: 128px;

  /* Radius */
  --r-sm: 4px; --r-md: 8px; --r-lg: 12px; --r-xl: 16px;
  --r-2xl: 24px; --r-full: 9999px;

  /* Shadows */
  --sh-sm: 0 1px 3px rgba(13,13,13,.08),0 1px 2px rgba(13,13,13,.06);
  --sh-md: 0 4px 12px rgba(13,13,13,.08),0 2px 4px rgba(13,13,13,.05);
  --sh-lg: 0 10px 30px rgba(13,13,13,.12),0 4px 8px rgba(13,13,13,.06);
  --sh-xl: 0 24px 48px rgba(13,13,13,.14);
  --sh-accent: 0 8px 32px rgba(201,169,110,.28);

  /* Motion */
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --dur-fast: 150ms;
  --dur: 220ms;
  --dur-slow: 350ms;
}

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-ui);
  font-size:1.0625rem;
  line-height:1.6;
  color:var(--c-900);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:color var(--dur-fast) var(--ease)}
a:hover{color:var(--accent-dark)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
*:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:var(--r-sm)}

/* ── SKIP LINK ── */
.skip-link{position:absolute;top:-100%;left:0;background:var(--accent);color:var(--c-900);padding:var(--s-2) var(--s-4);z-index:9999;font-weight:600}
.skip-link:focus{top:0}

/* ── LAYOUT ── */
.container{
  width:100%;
  max-width:1280px;
  margin-inline:auto;
  padding-inline:var(--s-8);
}
.container--narrow{max-width:760px}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--s-2);
  padding:13px var(--s-6);
  border-radius:var(--r-md);
  font-size:1rem;
  font-weight:600;
  font-family:var(--font-ui);
  letter-spacing:-0.01em;
  min-height:48px;
  transition:all var(--dur) var(--ease);
  text-decoration:none;
  white-space:nowrap;
  cursor:pointer;
}
.btn-primary{background:var(--accent);color:var(--c-900);}
.btn-primary:hover{background:var(--accent-dark);color:var(--c-900);box-shadow:var(--sh-accent);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0);box-shadow:none}
.btn-outline{background:transparent;color:var(--c-900);border:1.5px solid var(--c-900)}
.btn-outline:hover{background:var(--c-900);color:#fff}
.btn-ghost{background:transparent;color:var(--accent);border:none}
.btn-ghost:hover{background:var(--accent-light)}
.btn-lg{padding:16px 32px;font-size:1.0625rem;min-height:56px}
.btn-full{width:100%}
.btn--loading{position:relative;color:transparent;pointer-events:none}
.btn--loading::after{
  content:"";position:absolute;inset:0;margin:auto;
  width:18px;height:18px;border-radius:50%;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  animation:spin .6s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeLeft{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
@keyframes countUp{from{opacity:0}to{opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.animate-fade-up{opacity:0;animation:fadeUp var(--dur-slow) var(--ease-spring) forwards}
.animate-fade-left{opacity:0;animation:fadeLeft var(--dur-slow) var(--ease-spring) forwards}

/* ── HEADER ── */
.header{
  position:fixed;top:0;left:0;right:0;
  height:68px;
  display:flex;align-items:center;justify-content:space-between;
  padding-inline:var(--s-8);
  z-index:100;
  transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.header.scrolled{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:var(--sh-sm);
}
.header__logo{
  display:flex;align-items:center;gap:var(--s-2);
  text-decoration:none;flex-shrink:0;
}
.logo-mark{display:flex;animation:float 4s ease-in-out infinite}
.logo-text{
  font-family:var(--font-ui);font-weight:700;font-size:1.125rem;
  color:var(--c-900);letter-spacing:-0.03em;
}
.logo-accent{color:var(--accent)}
.header__nav{display:flex;align-items:center;gap:var(--s-1)}
.header__nav-link{
  padding:var(--s-2) var(--s-3);
  border-radius:var(--r-md);
  font-size:.9375rem;font-weight:500;
  color:var(--c-500);
  text-decoration:none;
  transition:all var(--dur-fast) var(--ease);
}
.header__nav-link:hover{color:var(--c-900);background:var(--c-100)}
.header__actions{display:flex;align-items:center;gap:var(--s-2)}
.header__burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center}
.header__burger span{display:block;width:22px;height:2px;background:var(--c-900);border-radius:2px;transition:all var(--dur) var(--ease)}
.header__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.header__burger.open span:nth-child(2){opacity:0}
.header__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{
  position:fixed;top:68px;left:0;right:0;bottom:0;
  background:#fff;z-index:99;padding:var(--s-8) var(--s-6);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform var(--dur) var(--ease);
}
.mobile-menu:not([hidden]){transform:translateX(0)}
.mobile-menu[hidden]{display:flex}/* override hidden for animation */
.mobile-menu__link{
  display:block;padding:var(--s-4) 0;
  font-size:1.375rem;font-weight:600;color:var(--c-900);
  border-bottom:1px solid var(--c-100);
  text-decoration:none;transition:color var(--dur-fast) var(--ease);
}
.mobile-menu__link:hover{color:var(--accent)}

/* ── HERO ── */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;align-items:center;
  padding-top:100px;
  padding-bottom:var(--s-24);
  overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:-1}
.hero__bg-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--c-100) 1px,transparent 1px),
    linear-gradient(90deg,var(--c-100) 1px,transparent 1px);
  background-size:60px 60px;
  opacity:.4;
}
.hero__bg-glow{
  position:absolute;top:-20%;right:-10%;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,169,110,.12) 0%,transparent 70%);
}
.hero__inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--s-16);
  align-items:center;
}
.hero__badge{
  display:inline-flex;align-items:center;gap:var(--s-2);
  background:var(--accent-light);
  border:1px solid rgba(201,169,110,.3);
  color:var(--accent-dark);
  font-size:.8125rem;font-weight:600;letter-spacing:.04em;
  padding:var(--s-1) var(--s-3);border-radius:var(--r-full);
  text-transform:uppercase;
  width:fit-content;margin-bottom:var(--s-6);
}
.badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--success);
  box-shadow:0 0 0 3px rgba(45,125,70,.2);
  animation:pulse 2s ease infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(45,125,70,.2)}50%{box-shadow:0 0 0 6px rgba(45,125,70,.1)}}
.hero__title{
  font-family:var(--font-display);
  font-size:clamp(2.5rem,5vw,4.5rem);
  line-height:1.08;
  letter-spacing:-2px;
  color:var(--c-900);
  margin-bottom:var(--s-6);
}
.hero__title em{
  font-style:italic;
  background:linear-gradient(135deg,var(--accent) 0%,#E8C98A 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero__body{
  font-size:1.125rem;line-height:1.7;
  color:var(--c-500);
  max-width:480px;
  margin-bottom:var(--s-8);
}
.hero__actions{display:flex;flex-wrap:wrap;gap:var(--s-3);margin-bottom:var(--s-8)}
.hero__trust{display:flex;align-items:center;gap:var(--s-3)}
.trust-avatars{display:flex}
.trust-avatar{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.875rem;
  border:2px solid #fff;
  margin-left:-10px;
  flex-shrink:0;
}
.trust-avatars .trust-avatar:first-child{margin-left:0}
.trust-text{font-size:.875rem;color:var(--c-500)}
.trust-text strong{color:var(--c-900)}

/* Hero Mockup */
.hero__visual{display:flex;justify-content:center}
.hero__mockup{position:relative}
.mockup__browser{
  background:#fff;
  border-radius:var(--r-xl);
  box-shadow:var(--sh-xl);
  overflow:hidden;
  width:460px;
  border:1px solid var(--c-100);
}
.mockup__bar{
  height:40px;
  background:var(--c-50);
  display:flex;align-items:center;
  padding:0 var(--s-4);
  gap:var(--s-3);
  border-bottom:1px solid var(--c-100);
}
.mockup__dot{width:12px;height:12px;border-radius:50%}
.mockup__dot.red{background:#FF5F57}
.mockup__dot.yellow{background:#FFBD2E}
.mockup__dot.green{background:#28C840}
.mockup__url{
  flex:1;height:24px;background:var(--c-100);border-radius:var(--r-full);
  font-size:.75rem;color:var(--c-300);
  display:flex;align-items:center;padding:0 var(--s-3);
  max-width:240px;margin-inline:auto;
}
.mockup__screen{padding:var(--s-4)}
.mockup__hero-img{
  width:100%;height:120px;border-radius:var(--r-lg);
  background:linear-gradient(135deg,var(--c-700) 0%,var(--c-500) 100%);
  margin-bottom:var(--s-4);
}
.mockup__content{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-4)}
.mockup__line{height:10px;border-radius:var(--r-full);background:var(--c-100)}
.mockup__line.accent{background:var(--accent);height:16px}
.mockup__line.tall{height:14px}
.w-60{width:60%}.w-70{width:70%}.w-80{width:80%}.w-100{width:100%}
.mockup__btn{
  width:120px;height:36px;border-radius:var(--r-md);
  background:var(--accent);margin-top:var(--s-2);
}
.mockup__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-2)}
.mockup__card{height:60px;border-radius:var(--r-md);background:var(--c-50);border:1px solid var(--c-100)}
.mockup__badge{
  position:absolute;
  background:#fff;border-radius:var(--r-md);
  padding:var(--s-2) var(--s-3);
  display:flex;align-items:center;gap:var(--s-1);
  box-shadow:var(--sh-lg);
  font-size:.8125rem;font-weight:600;color:var(--c-900);
  border:1px solid var(--c-100);
  animation:float 3s ease-in-out infinite;
}
.mockup__badge--perf{bottom:-16px;right:20px;animation-delay:.5s}
.mockup__badge--mobile{top:48px;left:-20px;animation-delay:1s}

/* ── CLIENTS ── */
.clients{
  padding-block:var(--s-12);
  border-top:1px solid var(--c-100);
  border-bottom:1px solid var(--c-100);
  background:var(--c-50);
}
.clients__label{
  text-align:center;font-size:.8125rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--c-300);margin-bottom:var(--s-8);
}
.clients__logos{
  display:flex;justify-content:center;align-items:center;
  flex-wrap:wrap;gap:var(--s-12);
}
.client-logo{
  font-size:.9375rem;font-weight:600;color:var(--c-300);
  text-align:center;line-height:1.2;
  transition:color var(--dur) var(--ease);
  cursor:default;
}
.client-logo:hover{color:var(--c-500)}

/* ── SECTIONS ── */
.section{padding-block:var(--s-24)}
.section--dark{background:linear-gradient(135deg,var(--c-900) 0%,var(--c-700) 100%)}
.section--pearl{background:var(--c-50)}
.section__header{text-align:center;margin-bottom:var(--s-16);max-width:640px;margin-inline:auto;margin-bottom:var(--s-16)}
.section__header--light .section__title,
.section__header--light .section__subtitle{color:#fff}
.section__eyebrow{
  display:inline-block;
  font-size:.8125rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);margin-bottom:var(--s-3);
}
.section__eyebrow.light{color:rgba(201,169,110,.8)}
.section__title{
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.25rem);
  line-height:1.1;letter-spacing:-1.5px;
  color:var(--c-900);margin-bottom:var(--s-4);
}
.section__title.light{color:#fff}
.section__subtitle{font-size:1.0625rem;color:var(--c-500);line-height:1.7}
.section__subtitle.light{color:rgba(255,255,255,.6)}

/* ── SERVICES GRID ── */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s-6);
}
.service-card{
  background:#fff;
  border-radius:var(--r-2xl);
  padding:var(--s-8);
  border:1px solid var(--c-100);
  box-shadow:var(--sh-sm);
  transition:transform var(--dur-slow) var(--ease),box-shadow var(--dur-slow) var(--ease);
}
.card-hover:hover{transform:translateY(-6px);box-shadow:var(--sh-xl)}
.service-card__icon{
  width:48px;height:48px;border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  background:var(--c-100);color:var(--c-500);
  margin-bottom:var(--s-6);
}
.service-card__icon.accent{background:var(--accent-light);color:var(--accent)}
.service-card__icon.green{background:rgba(45,125,70,.1);color:var(--success)}
.service-card__title{font-size:1.25rem;font-weight:600;color:var(--c-900);margin-bottom:var(--s-3)}
.service-card__desc{font-size:.9375rem;color:var(--c-500);line-height:1.7;margin-bottom:var(--s-4)}
.service-card__list{display:flex;flex-direction:column;gap:var(--s-2)}
.service-card__list li{
  font-size:.875rem;color:var(--c-500);
  padding-left:var(--s-4);position:relative;
}
.service-card__list li::before{
  content:"✓";position:absolute;left:0;
  color:var(--accent);font-weight:700;
}

/* ── PROCESS ── */
.process-steps{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr;
  align-items:start;gap:var(--s-6);
  max-width:900px;margin-inline:auto;
  padding-top:var(--s-8);
}
.process-step{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--s-4)}
.step-number{
  font-family:var(--font-display);font-size:3rem;
  color:rgba(201,169,110,.2);line-height:1;
  font-weight:400;
}
.step-title{font-size:1.125rem;font-weight:600;color:#fff;margin-bottom:var(--s-2)}
.step-desc{font-size:.9375rem;color:rgba(255,255,255,.6);line-height:1.7}
.process-divider{
  width:1px;height:60px;
  background:linear-gradient(to bottom,transparent,rgba(201,169,110,.4),transparent);
  margin-top:60px;
  flex-shrink:0;
}

/* ── FEATURE BLOCKS ── */
.feature-block{
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--s-16);align-items:center;
  padding-block:var(--s-16);
}
.feature-block+.feature-block{border-top:1px solid var(--c-100)}
.feature-block--reverse .feature-block__visual{order:2}
.feature-block--reverse .feature-block__content{order:1}
.feature-label{
  display:inline-block;
  font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);margin-bottom:var(--s-3);
}
.feature-title{
  font-family:var(--font-display);
  font-size:clamp(1.75rem,3vw,2.5rem);
  line-height:1.12;letter-spacing:-1px;
  color:var(--c-900);margin-bottom:var(--s-4);
}
.feature-desc{font-size:1.0625rem;color:var(--c-500);line-height:1.7;margin-bottom:var(--s-6)}
.feature-checklist{display:flex;flex-direction:column;gap:var(--s-3)}
.feature-checklist li{
  display:flex;align-items:center;gap:var(--s-3);
  font-size:.9375rem;color:var(--c-700);
}
.feature-checklist li::before{
  content:"✓";
  width:24px;height:24px;border-radius:50%;
  background:var(--accent-light);color:var(--accent);
  font-weight:700;font-size:.75rem;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}

/* Feature previews */
.feature-preview{
  background:#fff;border-radius:var(--r-2xl);
  box-shadow:var(--sh-xl);
  border:1px solid var(--c-100);
  overflow:hidden;
}
.feature-preview__header{
  background:var(--c-50);padding:var(--s-3) var(--s-4);
  display:flex;gap:var(--s-2);border-bottom:1px solid var(--c-100);
}
.fp-dot{width:10px;height:10px;border-radius:50%;background:var(--c-100)}
.feature-preview__body{padding:var(--s-6);display:flex;flex-direction:column;gap:var(--s-3)}
.feature-preview__badge{
  position:absolute;bottom:-12px;right:24px;
  background:var(--accent);color:var(--c-900);
  font-weight:700;font-size:.8125rem;
  padding:var(--s-2) var(--s-3);border-radius:var(--r-full);
}
.feature-preview{position:relative}
.fp-bar{height:12px;border-radius:var(--r-full);background:var(--c-100)}
.fp-bar.tall{height:20px}.fp-bar.accent-bar{background:var(--accent)}
.fp-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3)}
.fp-card{height:80px;border-radius:var(--r-lg);background:var(--c-50);border:1px solid var(--c-100)}

/* SEO preview */
.feature-preview--seo{padding:var(--s-6)}
.seo-card{background:var(--c-50);border-radius:var(--r-lg);padding:var(--s-4);border:1px solid var(--c-100)}
.seo-card__icon{font-size:1.5rem;margin-bottom:var(--s-3)}
.seo-card__query{font-size:.875rem;color:var(--c-500);margin-bottom:var(--s-4)}
.seo-result{
  display:flex;align-items:flex-start;gap:var(--s-3);
  padding:var(--s-3) 0;border-top:1px solid var(--c-100);
}
.seo-result.dimmed{opacity:.4}
.seo-result__pos{
  width:24px;height:24px;border-radius:50%;
  background:var(--accent);color:var(--c-900);
  font-size:.75rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.seo-result.dimmed .seo-result__pos{background:var(--c-100);color:var(--c-300)}
.seo-result__title{font-size:.875rem;font-weight:600;color:var(--c-900)}
.seo-result__url{font-size:.75rem;color:var(--success)}

/* ── TESTIMONIALS ── */
.testimonials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s-6);
}
.testimonial-card{
  background:#fff;border-radius:var(--r-2xl);
  padding:var(--s-8);border:1px solid var(--c-100);
  box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;gap:var(--s-4);
}
.testimonial-card--featured{
  background:var(--c-900);border-color:var(--c-700);
  box-shadow:var(--sh-xl);transform:translateY(-8px);
}
.testimonial-card--featured .testimonial-quote{color:rgba(255,255,255,.8)}
.testimonial-card--featured .testimonial-name{color:#fff}
.testimonial-card--featured .testimonial-role{color:rgba(255,255,255,.5)}
.stars{color:var(--accent);font-size:1.125rem;letter-spacing:2px}
.testimonial-quote{
  font-size:1rem;line-height:1.7;
  color:var(--c-500);font-style:italic;
  flex:1;
}
.testimonial-author{display:flex;align-items:center;gap:var(--s-3)}
.testimonial-avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--accent);color:var(--c-900);
  font-weight:700;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.testimonial-name{font-weight:600;font-size:.9375rem;color:var(--c-900)}
.testimonial-role{font-size:.8125rem;color:var(--c-300)}

/* ── STATS ── */
.stats-section{
  padding-block:var(--s-16);
  background:linear-gradient(135deg,var(--c-900) 0%,var(--c-700) 100%);
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:var(--s-8);text-align:center;
}
.stat__value{
  font-size:clamp(2.5rem,5vw,3.5rem);
  font-weight:700;color:#fff;
  letter-spacing:-1px;line-height:1;
  display:inline;
}
.stat__suffix{
  font-size:1.5rem;font-weight:700;color:var(--accent);
  display:inline;vertical-align:top;margin-top:.25em;line-height:1;
}
.stat__label{
  font-size:.9375rem;color:rgba(255,255,255,.5);
  margin-top:var(--s-2);
}

/* ── PRICING ── */
.pricing-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s-6);align-items:start;
}
.pricing-card{
  background:#fff;border-radius:var(--r-2xl);
  padding:var(--s-8);border:1px solid var(--c-100);
  box-shadow:var(--sh-sm);
  position:relative;
  transition:transform var(--dur-slow) var(--ease),box-shadow var(--dur-slow) var(--ease);
}
.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.pricing-card--featured{
  border:2px solid var(--accent);
  box-shadow:var(--sh-accent);
  transform:translateY(-4px);
}
.pricing-card--featured:hover{transform:translateY(-8px)}
.pricing-card__badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:var(--c-900);
  font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:4px 14px;border-radius:var(--r-full);
  white-space:nowrap;
}
.pricing-card__header{margin-bottom:var(--s-8)}
.pricing-plan{font-size:1.125rem;font-weight:600;color:var(--c-500);margin-bottom:var(--s-4)}
.pricing-price{display:flex;align-items:baseline;gap:4px;line-height:1}
.pricing-amount{font-size:clamp(2rem,3.5vw,2.75rem);font-weight:700;color:var(--c-900);letter-spacing:-1px}
.pricing-currency{font-size:1.25rem;font-weight:600;color:var(--c-500)}
.pricing-billing{font-size:.8125rem;color:var(--c-300);margin-top:var(--s-2)}
.pricing-features{display:flex;flex-direction:column;gap:var(--s-3);margin-bottom:var(--s-8)}
.pricing-features li{display:flex;align-items:center;gap:var(--s-3);font-size:.9375rem;color:var(--c-700)}
.check{
  width:20px;height:20px;border-radius:50%;
  background:var(--accent-light);color:var(--accent);
  font-size:.625rem;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.pricing-note{text-align:center;font-size:.9375rem;color:var(--c-300);margin-top:var(--s-8)}
.pricing-note a{color:var(--accent)}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-100)}
.faq-question{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  gap:var(--s-4);
  padding:var(--s-6) 0;
  font-size:1.0625rem;font-weight:600;color:var(--c-900);
  text-align:left;cursor:pointer;
  transition:color var(--dur-fast) var(--ease);
}
.faq-question:hover{color:var(--accent)}
.faq-icon{flex-shrink:0;transition:transform var(--dur) var(--ease);color:var(--c-300)}
.faq-question[aria-expanded="true"] .faq-icon{transform:rotate(180deg);color:var(--accent)}
.faq-answer{
  padding-bottom:var(--s-6);max-height:0;overflow:hidden;
  transition:max-height var(--dur-slow) var(--ease),padding var(--dur-slow) var(--ease);
}
.faq-answer:not([hidden]){max-height:400px}
.faq-answer[hidden]{display:block!important;max-height:0;overflow:hidden;padding-bottom:0}
.faq-answer p{font-size:1rem;color:var(--c-500);line-height:1.7}

/* ── CTA SECTION ── */
.cta-section{
  position:relative;
  padding-block:var(--s-32);
  overflow:hidden;
}
.cta-section__bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--c-900) 0%,var(--c-700) 50%,#3C4257 100%);
  z-index:-1;
}
.cta-section__bg::before{
  content:"";position:absolute;top:-30%;right:-10%;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,169,110,.15) 0%,transparent 65%);
}
.cta-inner{max-width:600px;margin-inline:auto;text-align:center}
.cta-title{
  font-family:var(--font-display);
  font-size:clamp(2.25rem,4vw,3.5rem);
  line-height:1.08;letter-spacing:-1.5px;
  color:#fff;margin-bottom:var(--s-4);
}
.cta-title em{font-style:italic;color:var(--accent)}
.cta-subtitle{font-size:1.125rem;color:rgba(255,255,255,.6);margin-bottom:var(--s-12)}

/* Form */
.cta-form{display:flex;flex-direction:column;gap:var(--s-4);text-align:left}
.cta-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4)}
.field-wrapper{display:flex;flex-direction:column;gap:var(--s-1)}
.field-label{font-size:.8125rem;font-weight:600;color:rgba(255,255,255,.8)}
.field-input{
  height:52px;padding:0 var(--s-4);
  background:rgba(255,255,255,.08);
  border:1.5px solid rgba(255,255,255,.15);
  border-radius:var(--r-md);
  font-size:1rem;color:#fff;
  font-family:var(--font-ui);
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
  outline:none;
}
.field-input::placeholder{color:rgba(255,255,255,.3)}
.field-input:hover{border-color:rgba(255,255,255,.3)}
.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(201,169,110,.2)}
.field-input[aria-invalid="true"]{border-color:var(--error)}
.cta-form__privacy{font-size:.8125rem;color:rgba(255,255,255,.4);text-align:center}
.cta-form__privacy a{color:rgba(201,169,110,.7)}

/* Success state */
.cta-success{text-align:center;padding:var(--s-12)}
.cta-success__icon{
  width:64px;height:64px;border-radius:50%;
  background:var(--success);color:#fff;
  font-size:1.75rem;
  display:flex;align-items:center;justify-content:center;
  margin-inline:auto;margin-bottom:var(--s-4);
}
.cta-success h3{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:var(--s-2)}
.cta-success p{color:rgba(255,255,255,.6)}

/* ── FOOTER ── */
.footer{
  background:var(--c-900);
  padding-block:var(--s-16) var(--s-8);
  border-top:1px solid rgba(255,255,255,.06);
}
.footer__inner{
  display:grid;grid-template-columns:280px 1fr;
  gap:var(--s-16);
  padding-bottom:var(--s-12);
  border-bottom:1px solid rgba(255,255,255,.08);
  margin-bottom:var(--s-6);
}
.footer__tagline{font-size:.9375rem;color:rgba(255,255,255,.4);line-height:1.6;margin-top:var(--s-4)}
.footer__social{display:flex;gap:var(--s-3);margin-top:var(--s-6)}
.social-link{
  width:40px;height:40px;border-radius:var(--r-md);
  background:rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.4);
  transition:all var(--dur-fast) var(--ease);
}
.social-link:hover{background:var(--accent-light);color:var(--accent)}
.footer__nav{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s-8);
}
.footer__col{display:flex;flex-direction:column;gap:var(--s-3)}
.footer__col-title{
  font-size:.8125rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-bottom:var(--s-2);
}
.footer__link{font-size:.9375rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color var(--dur-fast) var(--ease)}
.footer__link:hover{color:#fff}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--s-4)}
.footer__copy{font-size:.875rem;color:rgba(255,255,255,.3)}
.footer__legal{display:flex;gap:var(--s-6)}
.footer__legal .footer__link{font-size:.875rem}

/* Scroll to top */
.scroll-top{
  position:fixed;bottom:var(--s-6);right:var(--s-6);
  width:48px;height:48px;border-radius:var(--r-full);
  background:var(--accent);color:var(--c-900);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--sh-lg);cursor:pointer;
  transform:translateY(120%);opacity:0;
  transition:all var(--dur) var(--ease);
  z-index:50;
}
.scroll-top.visible{transform:translateY(0);opacity:1}
.scroll-top:hover{transform:translateY(-3px);box-shadow:var(--sh-accent)}

/* ── RESPONSIVE ── */
@media(max-width:1199px){
  .container{padding-inline:var(--s-12)}
  .hero__inner{gap:var(--s-8)}
  .mockup__browser{width:380px}
  .services-grid{grid-template-columns:1fr 1fr;gap:var(--s-4)}
  .services-grid .service-card:nth-child(3){grid-column:1/-1}
  .testimonials-grid{grid-template-columns:1fr 1fr}
  .testimonials-grid .testimonial-card:nth-child(3){grid-column:1/-1}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--s-12)}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-card--featured{transform:none}
  .footer__nav{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:767px){
  .container{padding-inline:var(--s-6)}
  .section{padding-block:var(--s-12)}
  .header__nav,.header__actions{display:none}
  .header__burger{display:flex}
  .header{padding-inline:var(--s-4)}
  .hero{padding-top:80px;padding-bottom:var(--s-12)}
  .hero__inner{grid-template-columns:1fr;gap:var(--s-8)}
  .hero__visual{order:-1}
  .mockup__browser{width:100%;max-width:360px;margin-inline:auto}
  .hero__body{max-width:100%}
  .hero__actions{flex-direction:column}
  .hero__actions .btn{width:100%;text-align:center}
  .clients__logos{gap:var(--s-6)}
  .services-grid{grid-template-columns:1fr}
  .services-grid .service-card:nth-child(3){grid-column:auto}
  .process-steps{
    grid-template-columns:1fr;
    text-align:left;
    gap:var(--s-4);
  }
  .process-step{flex-direction:row;text-align:left;align-items:flex-start}
  .step-number{font-size:2rem;flex-shrink:0;width:60px}
  .process-divider{display:none}
  .feature-block{grid-template-columns:1fr;gap:var(--s-8)}
  .feature-block--reverse .feature-block__visual{order:0}
  .feature-block--reverse .feature-block__content{order:0}
  .testimonials-grid{grid-template-columns:1fr}
  .testimonial-card--featured{transform:none}
  .stats-grid{grid-template-columns:1fr 1fr;gap:var(--s-8)}
  .pricing-grid{grid-template-columns:1fr}
  .cta-form__row{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr}
  .footer__nav{grid-template-columns:1fr;gap:var(--s-6)}
  .footer__bottom{flex-direction:column;align-items:flex-start}
  .section__header{margin-bottom:var(--s-8)}
}

@media(max-width:375px){
  .container{padding-inline:var(--s-4)}
  .hero__title{font-size:2.25rem}
  .stats-grid{grid-template-columns:1fr}
}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}
