/*
 * ClikRank Agency — Design System v2.0
 * CSS limpio: tokens → base → componentes con clases kebab-case
 */

/* ─── TOKENS ─────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Manrope:wght@600;700;800&family=DM+Sans:wght@400;500&display=swap');

:root {
  --brand-400: #FF8632; --brand-500: #FF640A;
  --brand-600: #FF4D00; --brand-700: #CC3502;

  --color-bg:        #0A0B0F;
  --color-bg-subtle: #111318;
  --color-surface:   rgba(255,255,255,0.04);
  --color-surface-2: rgba(255,255,255,0.07);
  --color-border:    rgba(255,255,255,0.08);
  --color-border-2:  rgba(255,255,255,0.14);
  --color-primary:   #FF4D00;
  --color-text:      #F1F5F9;
  --color-muted:     #94A3B8;
  --color-faint:     #475569;

  --font-display: 'Manrope', system-ui, sans-serif;
  --font-body:    'DM Sans', 'Inter', system-ui, sans-serif;

  --text-xs:  0.75rem;  --text-sm:  0.875rem; --text-base: 1rem;
  --text-lg:  1.125rem; --text-xl:  1.25rem;  --text-2xl:  1.5rem;
  --text-3xl: 1.875rem; --text-4xl: 2.25rem;  --text-5xl: clamp(2.25rem,4vw,3rem);
  --text-6xl: clamp(2.75rem,5vw,3.75rem);
  --text-7xl: clamp(3rem,6vw,4.5rem);

  --sp-1:.25rem; --sp-2:.5rem;  --sp-3:.75rem; --sp-4:1rem;
  --sp-5:1.25rem; --sp-6:1.5rem; --sp-8:2rem;  --sp-10:2.5rem;
  --sp-12:3rem; --sp-16:4rem;  --sp-20:5rem;  --sp-24:6rem;

  --r-sm:.375rem; --r:.625rem; --r-md:.875rem;
  --r-lg:1.25rem; --r-xl:1.75rem; --r-full:9999px;

  --shadow-md: 0 10px 25px rgba(0,0,0,.45);
  --shadow-lg: 0 25px 50px rgba(0,0,0,.55);
  --shadow-glow: 0 0 40px rgba(255,77,0,.25);
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --t: 200ms;
  --nav-h: 72px;
  --container: 1200px;
}

/* ─── RESET ──────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
  background: var(--color-bg);
  overflow-x: hidden;
}
img,svg,video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font:inherit; }
ul,ol { list-style:none; }
input,textarea,select { font:inherit; }

/* ─── TYPOGRAPHY ─────────────────────────────────── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
h1 { font-size: var(--text-6xl); font-weight:800; letter-spacing:-0.04em; }
h2 { font-size: var(--text-5xl); font-weight:700; }
h3 { font-size: var(--text-3xl); font-weight:700; }
h4 { font-size: var(--text-xl);  font-weight:600; }

.display-xl {
  font-family: var(--font-display);
  font-size: var(--text-7xl);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 1.05;
}
.display-gradient {
  background: linear-gradient(135deg, #fff 0%, rgba(255,255,255,.55) 100%);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}
.text-brand { color: var(--brand-400); }
.text-muted { color: var(--color-muted); }

/* ─── LAYOUT ─────────────────────────────────────── */
.container {
  width:100%; max-width:var(--container);
  margin-inline:auto; padding-inline:var(--sp-6);
}
.section      { padding-block: var(--sp-24); }
.section-sm   { padding-block: var(--sp-16); }
.section-dark { background: var(--color-bg-subtle); }
.section-header { text-align:center; margin-bottom:var(--sp-16); }
.section-title  {
  font-family:var(--font-display); font-size:var(--text-5xl);
  font-weight:800; line-height:1.1; letter-spacing:-0.04em; margin-bottom:var(--sp-4);
}
.section-subtitle { font-size:var(--text-lg); color:var(--color-muted); max-width:58ch; margin-inline:auto; }

.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--sp-6); }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-6); }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-6); }

/* ─── BUTTONS ────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:var(--sp-2); padding:.75rem 1.75rem;
  border-radius:var(--r-full); font-size:var(--text-sm);
  font-weight:600; letter-spacing:.01em;
  transition:all var(--t) var(--ease); white-space:nowrap; border:1px solid transparent;
}
.btn-primary {
  background:var(--color-primary); color:#fff;
  box-shadow:0 4px 20px rgba(255,77,0,.35);
}
.btn-primary:hover {
  background:var(--brand-700);
  box-shadow:0 8px 30px rgba(255,77,0,.5);
  transform:translateY(-1px);
}
.btn-secondary {
  background:var(--color-surface); color:var(--color-text);
  border-color:var(--color-border); backdrop-filter:blur(8px);
}
.btn-secondary:hover { background:var(--color-surface-2); border-color:var(--color-border-2); transform:translateY(-1px); }
.btn-ghost { color:var(--color-muted); }
.btn-ghost:hover { color:var(--color-text); background:var(--color-surface); }
.btn-sm { padding:.5rem 1.25rem;  font-size:var(--text-xs); }
.btn-lg { padding:1rem 2.5rem;    font-size:var(--text-base); }
.btn-xl { padding:1.1rem 2.75rem; font-size:var(--text-lg); }

/* ─── CARDS ──────────────────────────────────────── */
.card {
  background:var(--color-surface); border:1px solid var(--color-border);
  border-radius:var(--r-lg); padding:var(--sp-6);
  transition:all 350ms var(--ease-out);
}
.card:hover {
  border-color:var(--color-border-2); background:var(--color-surface-2);
  transform:translateY(-2px); box-shadow:var(--shadow-md);
}
.card-glass {
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);
}

/* ─── NAVIGATION ─────────────────────────────────── */
.nav {
  position:fixed; top:0; left:0; right:0;
  height:var(--nav-h); z-index:300;
  display:flex; align-items:center;
  transition:background var(--t) var(--ease), border-color var(--t) var(--ease);
}
.nav.scrolled {
  background:rgba(10,11,15,.88);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--color-border);
}
.nav-inner {
  display:flex; align-items:center; gap:var(--sp-8);
  width:100%; max-width:var(--container);
  margin-inline:auto; padding-inline:var(--sp-6);
}
.nav-logo {
  font-family:var(--font-display); font-size:1.3rem;
  font-weight:800; letter-spacing:-0.04em;
  color:var(--color-text); flex-shrink:0;
}
.nav-logo span { color:var(--color-primary); }
.nav-links {
  display:flex; align-items:center; gap:var(--sp-1); margin-left:auto;
}
.nav-link {
  padding:var(--sp-2) var(--sp-4); border-radius:var(--r-full);
  font-size:var(--text-sm); font-weight:500; color:var(--color-muted);
  transition:color var(--t) var(--ease), background var(--t) var(--ease);
  display:flex; align-items:center; gap:.375rem;
}
.nav-link:hover { color:var(--color-text); background:var(--color-surface); }
.nav-link.active { color:var(--color-text); }
.nav-link svg { transition:transform .2s var(--ease); }
.nav-cta { margin-left:var(--sp-4); flex-shrink:0; }
.nav-hamburger {
  display:none; flex-direction:column; gap:5px;
  padding:var(--sp-2); border-radius:var(--r-sm); margin-left:auto;
}
.nav-hamburger span { display:block; width:22px; height:2px; background:var(--color-text); border-radius:2px; transition:all .3s; }

/* Mobile menu */
.mobile-menu {
  position:fixed; inset:0; background:var(--color-bg);
  z-index:400; padding:var(--sp-6) var(--sp-6) var(--sp-8);
  transform:translateX(-100%); transition:transform .28s var(--ease-out);
  display:flex; flex-direction:column;
}
.mobile-menu.open { transform:translateX(0); }
.mobile-menu-inner { padding-top:var(--sp-16); flex:1; }
.mobile-menu-inner ul { display:flex; flex-direction:column; gap:var(--sp-2); }
.mobile-menu-inner ul a {
  display:block; padding:var(--sp-4) 0;
  font-size:var(--text-2xl); font-weight:700;
  border-bottom:1px solid var(--color-border);
  color:var(--color-text);
}
.mobile-menu-close {
  position:absolute; top:var(--sp-5); right:var(--sp-6);
  font-size:1.5rem; color:var(--color-muted);
}
.mobile-menu-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.7);
  z-index:399; backdrop-filter:blur(4px);
}
.skip-link {
  position:absolute; top:-100px; left:var(--sp-4);
  padding:var(--sp-2) var(--sp-4); background:var(--color-primary);
  color:#fff; border-radius:var(--r); font-size:var(--text-sm); z-index:999;
}
.skip-link:focus { top:var(--sp-4); }

/* ─── MEGAMENU ───────────────────────────────────── */
.mega-parent { position:static; }
.megamenu {
  position:fixed; top:var(--nav-h);
  left:50%; transform:translateX(-50%) translateY(-6px);
  width:min(700px,92vw);
  background:#111318;
  border:1px solid rgba(255,255,255,.1);
  border-top:none;
  border-radius:0 0 var(--r-lg) var(--r-lg);
  box-shadow:0 30px 70px rgba(0,0,0,.7);
  opacity:0; visibility:hidden;
  transition:opacity .2s var(--ease), transform .2s var(--ease), visibility .2s;
  z-index:299; pointer-events:none;
}
.mega-parent:hover .megamenu,
.mega-parent:focus-within .megamenu {
  opacity:1; visibility:visible;
  transform:translateX(-50%) translateY(0); pointer-events:auto;
}
.mega-parent:hover > .nav-link svg { transform:rotate(180deg); }
.megamenu-inner {
  display:grid; grid-template-columns:1fr 230px;
  gap:1.5rem; padding:1.5rem;
}
.megamenu-heading {
  font-size:.7rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--color-faint); margin-bottom:.875rem;
}
.megamenu-services { display:grid; grid-template-columns:1fr 1fr; gap:.375rem; }
.megamenu-service-item {
  display:flex; align-items:flex-start; gap:.75rem;
  padding:.75rem; border-radius:var(--r-md);
  transition:background .15s;
}
.megamenu-service-item:hover { background:rgba(255,255,255,.05); }
.megamenu-service-icon {
  width:36px; height:36px; flex-shrink:0;
  background:rgba(255,77,0,.12); border:1px solid rgba(255,77,0,.2);
  border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center;
  color:var(--color-primary);
}
.megamenu-service-info strong { display:block; font-size:.825rem; font-weight:600; color:var(--color-text); margin-bottom:.15rem; }
.megamenu-service-info span   { font-size:.72rem; color:var(--color-faint); line-height:1.4; }
.megamenu-col--cta { border-left:1px solid var(--color-border); padding-left:1.5rem; display:flex; flex-direction:column; gap:1rem; }
.megamenu-cta-box { background:rgba(255,77,0,.06); border:1px solid rgba(255,77,0,.15); border-radius:var(--r-md); padding:1.25rem; }
.megamenu-cta-icon { width:44px; height:44px; background:rgba(255,77,0,.15); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; color:var(--color-primary); margin-bottom:.875rem; }
.megamenu-cta-box h4 { font-size:.85rem; font-weight:700; color:var(--color-text); margin-bottom:.4rem; line-height:1.3; }
.megamenu-cta-box p  { font-size:.75rem; color:var(--color-faint); margin-bottom:1rem; line-height:1.5; }
.megamenu-cta-btn { display:inline-flex; align-items:center; gap:.375rem; font-size:.8rem; font-weight:600; color:var(--color-primary); transition:gap .15s; }
.megamenu-cta-btn:hover { gap:.625rem; }
.megamenu-stats { display:flex; justify-content:space-between; padding:.75rem; background:rgba(255,255,255,.03); border-radius:var(--r-sm); }
.megamenu-stats > div { text-align:center; }
.megamenu-stats strong { display:block; font-size:.95rem; font-weight:700; color:var(--color-primary); }
.megamenu-stats span   { font-size:.65rem; color:var(--color-faint); }

/* ─── HERO ───────────────────────────────────────── */
.hero {
  min-height: 100vh;
  display: flex; align-items: center;
  padding-top: var(--nav-h);
  position: relative; overflow: hidden;
}
.hero-bg {
  position:absolute; inset:0;
  pointer-events:none; z-index:0; overflow:hidden;
}
.hero-orb {
  position:absolute; border-radius:50%;
  filter:blur(80px); opacity:.13; pointer-events:none;
}
.hero-orb-1 { width:600px; height:600px; background:var(--brand-600); top:-200px; right:-100px; animation:orbFloat 8s ease-in-out infinite; }
.hero-orb-2 { width:380px; height:380px; background:var(--brand-800,#A12A0B); bottom:-80px; left:-80px; animation:orbFloat 11s ease-in-out infinite reverse; }
@keyframes orbFloat { 0%,100%{transform:translate(0,0)} 50%{transform:translate(20px,-28px)} }
.hero-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);
}
.hero-content { position:relative; z-index:1; max-width:820px; }
.hero-subtitle { font-size:var(--text-lg); color:var(--color-muted); line-height:1.7; margin-top:var(--sp-5); max-width:58ch; }
.hero-actions  { display:flex; flex-wrap:wrap; gap:var(--sp-4); margin-top:var(--sp-8); }
.hero-trust    { display:flex; flex-wrap:wrap; gap:var(--sp-6); margin-top:var(--sp-8); }
.trust-badge   { display:flex; align-items:center; gap:var(--sp-2); font-size:var(--text-sm); color:var(--color-muted); }
.trust-badge svg { color:var(--color-primary); flex-shrink:0; }

/* ─── EYEBROW ────────────────────────────────────── */
.eyebrow {
  display:inline-flex; align-items:center; gap:var(--sp-2);
  font-size:var(--text-xs); font-weight:700;
  text-transform:uppercase; letter-spacing:.12em;
  color:var(--brand-400); margin-bottom:var(--sp-4);
}
.eyebrow-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--color-primary);
  animation:pulse 2.2s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.55;transform:scale(.75)} }

/* ─── STATS ──────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-4); }
.stat-card {
  background:var(--color-surface); border:1px solid var(--color-border);
  border-radius:var(--r-lg); padding:var(--sp-8) var(--sp-6);
  text-align:center; transition:all 350ms var(--ease-out);
}
.stat-card:hover { background:var(--color-surface-2); border-color:var(--color-border-2); transform:translateY(-3px); }
.stat-icon   { color:var(--brand-400); display:flex; justify-content:center; margin-bottom:var(--sp-4); }
.stat-icon svg { stroke:var(--brand-400); }
.stat-number { font-family:var(--font-display); font-size:2.75rem; font-weight:800; color:var(--brand-400); line-height:1; display:block; }
.stat-label  { font-size:var(--text-sm); color:var(--color-muted); margin-top:var(--sp-2); display:block; }

/* ─── SERVICE CARDS ──────────────────────────────── */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-6); }
.service-card {
  background:var(--color-surface); border:1px solid var(--color-border);
  border-radius:var(--r-xl); padding:var(--sp-8);
  transition:all 350ms var(--ease-out);
}
.service-card:hover { background:var(--color-surface-2); border-color:rgba(255,77,0,.3); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.service-card-icon {
  width:52px; height:52px; flex-shrink:0;
  background:rgba(255,77,0,.12); border:1px solid rgba(255,77,0,.2);
  border-radius:var(--r-md); display:flex; align-items:center;
  justify-content:center; color:var(--color-primary); margin-bottom:var(--sp-5);
}
.service-card-icon svg { stroke:var(--color-primary); }
.service-card-title { font-size:var(--text-xl); font-weight:700; margin-bottom:var(--sp-3); }
.service-card-desc  { font-size:var(--text-sm); color:var(--color-muted); line-height:1.65; margin-bottom:var(--sp-6); flex:1; }
.service-card-link  { display:inline-flex; align-items:center; gap:var(--sp-2); font-size:var(--text-sm); font-weight:600; color:var(--brand-400); transition:gap var(--t) var(--ease); }
.service-card-link:hover { gap:var(--sp-3); }

/* ─── PROCESS ────────────────────────────────────── */
.process-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-8); }
.process-num  { font-family:var(--font-display); font-size:3.5rem; font-weight:900; color:var(--color-primary); opacity:.22; line-height:1; margin-bottom:var(--sp-4); display:block; }
.process-title { font-size:var(--text-lg); font-weight:700; margin-bottom:var(--sp-3); }
.process-desc  { font-size:var(--text-sm); color:var(--color-muted); line-height:1.7; }

/* ─── PORTFOLIO ──────────────────────────────────── */
.portfolio-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-6); }
.portfolio-card { border-radius:var(--r-xl); overflow:hidden; background:var(--color-surface); border:1px solid var(--color-border); transition:transform 350ms var(--ease-out); }
.portfolio-card:hover { transform:translateY(-4px); }
.portfolio-img  { aspect-ratio:16/9; overflow:hidden; }
.portfolio-img img { width:100%; height:100%; object-fit:cover; transition:transform 400ms var(--ease-out); }
.portfolio-card:hover .portfolio-img img { transform:scale(1.05); }
.portfolio-info { padding:var(--sp-6); }
.portfolio-info h2,.portfolio-info h3 { font-size:var(--text-lg); margin:var(--sp-3) 0 var(--sp-4); }

/* ─── TESTIMONIALS ───────────────────────────────── */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-6); }
.testimonial-card  { padding:var(--sp-8); border-radius:var(--r-xl); }
.testimonial-stars  { display:flex; gap:4px; margin-bottom:var(--sp-4); }
.star       { font-size:1rem; color:var(--color-border); }
.star.filled { color:#FBB700; }
.testimonial-text   { font-size:var(--text-base); color:var(--color-muted); line-height:1.75; margin-bottom:var(--sp-6); font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:var(--sp-3); }
.testimonial-avatar { width:40px; height:40px; border-radius:50%; background:var(--color-primary); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:var(--text-sm); color:#fff; flex-shrink:0; }
.testimonial-photo  { width:40px; height:40px; border-radius:50%; object-fit:cover; }
.testimonial-name   { font-weight:600; font-size:var(--text-sm); display:block; }
.testimonial-company { font-size:var(--text-xs); color:var(--color-faint); display:block; }

/* ─── CTA SECTION ────────────────────────────────── */
.cta-section { background:radial-gradient(ellipse at center,rgba(255,77,0,.09) 0%,transparent 70%); }
.cta-inner   { text-align:center; padding:var(--sp-24) 0; position:relative; }
.cta-orb { position:absolute; width:400px; height:400px; background:var(--color-primary); border-radius:50%; filter:blur(100px); opacity:.08; top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; }
.cta-title    { font-family:var(--font-display); font-size:var(--text-6xl); font-weight:800; line-height:1.1; margin-bottom:var(--sp-5); }
.cta-subtitle { font-size:var(--text-lg); color:var(--color-muted); margin-bottom:var(--sp-8); max-width:56ch; margin-inline:auto; }
.cta-actions  { display:flex; justify-content:center; flex-wrap:wrap; gap:var(--sp-4); }

/* ─── FOOTER ─────────────────────────────────────── */
.footer { background:var(--color-bg-subtle); border-top:1px solid var(--color-border); padding:var(--sp-20) 0 var(--sp-8); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:var(--sp-12); margin-bottom:var(--sp-12); }
.footer-brand p { font-size:var(--text-sm); color:var(--color-muted); margin-top:var(--sp-4); line-height:1.7; }
.footer-brand-text { font-family:var(--font-display); font-size:1.5rem; font-weight:800; letter-spacing:-0.04em; display:block; margin-bottom:var(--sp-4); }
.footer-brand-text span { color:var(--color-primary); }
.footer-heading { font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--color-faint); margin-bottom:var(--sp-5); display:block; }
.footer-links   { display:flex; flex-direction:column; gap:var(--sp-3); }
.footer-links a { font-size:var(--text-sm); color:var(--color-muted); transition:color var(--t) var(--ease); }
.footer-links a:hover { color:var(--color-text); }
.footer-contact { display:flex; flex-direction:column; gap:var(--sp-4); font-style:normal; }
.footer-contact-link { display:flex; align-items:center; gap:var(--sp-3); font-size:var(--text-sm); color:var(--color-muted); transition:color var(--t) var(--ease); }
.footer-contact-link:hover { color:var(--brand-400); }
.footer-social   { display:flex; gap:var(--sp-3); margin-top:var(--sp-6); }
.footer-social a { display:flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:50%; background:var(--color-surface); border:1px solid var(--color-border); color:var(--color-muted); transition:all var(--t) var(--ease); }
.footer-social a:hover { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }
.footer-bottom   { display:flex; align-items:center; justify-content:space-between; padding-top:var(--sp-8); border-top:1px solid var(--color-border); font-size:var(--text-xs); color:var(--color-faint); flex-wrap:wrap; gap:var(--sp-4); }
.footer-bottom a { color:var(--color-muted); transition:color var(--t) var(--ease); }
.footer-bottom a:hover { color:var(--brand-400); }

/* ─── FORMS ──────────────────────────────────────── */
.form-label { display:block; font-size:var(--text-sm); font-weight:500; color:var(--color-muted); margin-bottom:.5rem; }
.form-input,
.form-select,
.form-textarea {
  display:block; width:100%;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r); padding:.75rem 1rem;
  color:var(--color-text); font-size:var(--text-sm);
  font-family:var(--font-body); outline:none;
  transition:border-color var(--t) var(--ease), background var(--t) var(--ease);
  box-sizing:border-box;
}
.form-input:focus,.form-select:focus,.form-textarea:focus {
  border-color:var(--color-primary); background:rgba(255,255,255,.09);
}
.form-input::placeholder,.form-textarea::placeholder { color:var(--color-faint); }
.form-input.error,.form-textarea.error { border-color:rgba(239,68,68,.5); }
.form-textarea { resize:vertical; min-height:120px; }
.form-select { cursor:pointer; }
.form-group   { margin-bottom:var(--sp-5); }
.form-row     { display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-5); }
.form-check   { display:flex; align-items:flex-start; gap:var(--sp-3); }
.form-checkbox { width:18px; height:18px; margin-top:2px; accent-color:var(--color-primary); flex-shrink:0; }
.form-check-label { font-size:var(--text-sm); color:var(--color-muted); }
.form-check-label a { color:var(--brand-400); }
.form-error   { display:block; font-size:var(--text-xs); color:#f87171; margin-top:.25rem; }
.form-errors  { background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.2); border-radius:var(--r); padding:var(--sp-4); margin-bottom:var(--sp-5); color:#f87171; font-size:var(--text-sm); }
.required { color:var(--color-primary); }

/* ─── FAQ ────────────────────────────────────────── */
.faq-list { display:flex; flex-direction:column; gap:var(--sp-3); }
.faq-item { border:1px solid var(--color-border); border-radius:var(--r-md); overflow:hidden; transition:border-color var(--t) var(--ease); }
.faq-item:has(.faq-question[aria-expanded="true"]) { border-color:rgba(255,77,0,.3); }
.faq-question { width:100%; display:flex; align-items:center; justify-content:space-between; padding:1.25rem 1.5rem; background:var(--color-surface); text-align:left; color:var(--color-text); font-size:var(--text-base); font-weight:500; gap:var(--sp-4); transition:background var(--t) var(--ease); }
.faq-question:hover { background:var(--color-surface-2); }
.faq-icon { width:24px; height:24px; border-radius:50%; background:rgba(255,77,0,.12); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--color-primary); font-size:1.1rem; font-weight:700; transition:transform .25s var(--ease); }
.faq-question[aria-expanded="true"] .faq-icon { transform:rotate(45deg); }
.faq-answer { padding:0 1.5rem; }
.faq-answer p { padding:1rem 0 1.25rem; color:var(--color-muted); line-height:1.75; }

/* ─── CONTACT ────────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1fr 380px; gap:var(--sp-12); }
.contact-info-header h2 { font-size:var(--text-3xl); margin-bottom:var(--sp-3); }
.contact-info-header p  { color:var(--color-muted); }
.contact-items { display:flex; flex-direction:column; gap:var(--sp-5); margin-top:var(--sp-8); }
.contact-item  { display:flex; align-items:flex-start; gap:var(--sp-4); }
.contact-item-icon { width:40px; height:40px; border-radius:var(--r); background:var(--color-surface); border:1px solid var(--color-border); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--brand-400); }
.contact-item div strong { display:block; font-size:var(--text-sm); font-weight:600; margin-bottom:2px; }
.contact-item div a,.contact-item div span { font-size:var(--text-sm); color:var(--color-muted); }
.contact-item div a:hover { color:var(--brand-400); }
.contact-guarantees h3 { font-size:var(--text-base); font-weight:700; margin-bottom:var(--sp-4); }
.guarantees-list li { font-size:var(--text-sm); color:var(--color-muted); margin-bottom:var(--sp-3); }

/* ─── BADGE ──────────────────────────────────────── */
.badge { display:inline-flex; align-items:center; padding:.2rem .65rem; border-radius:var(--r-full); font-size:var(--text-xs); font-weight:600; }
.badge-brand { background:rgba(255,77,0,.15); color:var(--brand-400); border:1px solid rgba(255,77,0,.2); }

/* ─── FLASH ──────────────────────────────────────── */
.flash-container { position:fixed; top:var(--sp-5); right:var(--sp-5); z-index:500; display:flex; flex-direction:column; gap:var(--sp-3); }
.flash { display:flex; align-items:center; gap:var(--sp-3); padding:var(--sp-4) var(--sp-5); border-radius:var(--r-md); font-size:var(--text-sm); font-weight:500; min-width:280px; box-shadow:var(--shadow-md); }
.flash-success { background:rgba(16,185,129,.15); border:1px solid rgba(16,185,129,.3); color:#34d399; }
.flash-error   { background:rgba(239,68,68,.15);  border:1px solid rgba(239,68,68,.3);  color:#f87171; }
.flash-info    { background:rgba(59,130,246,.15);  border:1px solid rgba(59,130,246,.3);  color:#60a5fa; }
.flash-close { margin-left:auto; opacity:.7; }

/* ─── BREADCRUMBS ────────────────────────────────── */
.breadcrumbs ol { display:flex; align-items:center; flex-wrap:wrap; gap:var(--sp-2); margin-bottom:var(--sp-6); }
.breadcrumbs li { font-size:var(--text-xs); color:var(--color-muted); }
.breadcrumbs a  { color:var(--color-muted); transition:color var(--t) var(--ease); }
.breadcrumbs a:hover { color:var(--brand-400); }
.separator { opacity:.4; }

/* ─── PAGINATION ─────────────────────────────────── */
.pagination { display:flex; align-items:center; justify-content:center; gap:var(--sp-2); margin-top:var(--sp-12); flex-wrap:wrap; }
.page-btn   { display:flex; align-items:center; justify-content:center; min-width:40px; height:40px; padding:0 var(--sp-3); border-radius:var(--r); background:var(--color-surface); border:1px solid var(--color-border); font-size:var(--text-sm); color:var(--color-muted); transition:all var(--t) var(--ease); }
.page-btn:hover   { background:var(--color-surface-2); color:var(--color-text); }
.page-btn.active  { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }

/* ─── VARIABLE ALIASES (backward compat) ─────────── */
:root {
  --neutral-950:#020617; --neutral-900:#0F172A; --neutral-800:#1E293B;
  --neutral-700:#334155; --neutral-600:#475569; --neutral-500:#64748B;
  --neutral-400:#94A3B8; --neutral-300:#CBD5E1; --neutral-200:#E2E8F0;
  --neutral-100:#F1F5F9; --neutral-50:#F8FAFC;
}

/* ─── RESPONSIVE ─────────────────────────────────── */
@media (max-width:1024px) {
  .stats-grid      { grid-template-columns:repeat(2,1fr); }
  .services-grid   { grid-template-columns:repeat(2,1fr); }
  .process-grid    { grid-template-columns:repeat(2,1fr); }
  .portfolio-grid  { grid-template-columns:repeat(2,1fr); }
  .testimonials-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid     { grid-template-columns:1fr 1fr; }
  .contact-grid    { grid-template-columns:1fr; }
  .nav-links, .nav-cta { display:none; }
  .nav-hamburger { display:flex; }
  .megamenu { display:none; }
}
@media (max-width:768px) {
  .services-grid   { grid-template-columns:1fr; }
  .process-grid    { grid-template-columns:1fr 1fr; }
  .portfolio-grid  { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .footer-grid     { grid-template-columns:1fr; gap:var(--sp-8); }
  .grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; }
  .form-row        { grid-template-columns:1fr; }
  .container       { padding-inline:var(--sp-4); }
  .section         { padding-block:var(--sp-16); }
  .stats-grid      { grid-template-columns:1fr 1fr; }
  .cta-title       { font-size:var(--text-4xl); }
}
@media (max-width:480px) {
  .stats-grid { grid-template-columns:1fr; }
  .process-grid { grid-template-columns:1fr; }
}
