/* ═══════════════════════════════════════════════════════════════
   EL CONCEPTO — DESIGN SYSTEM v2.0
   elconcepto.org · Premium Digital Ecosystem
   ═══════════════════════════════════════════════════════════════ */

/* ── 1. THEME TOKENS ── */
:root {
  --accent:        #B8975A;
  --accent-light:  #D4B47A;
  --accent-dark:   #8A6F3E;
  --accent-glow:   rgba(184,151,90,.15);
  --accent-dim:    rgba(184,151,90,.08);

  --font-display:  'Cormorant Garamond', Georgia, serif;
  --font-body:     'Syne', system-ui, sans-serif;
  --font-mono:     'DM Mono', 'Courier New', monospace;

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

  /* type scale */
  --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:  3rem;     --text-6xl:  3.75rem;

  /* transitions */
  --t-fast:   150ms ease;
  --t-normal: 280ms ease;
  --t-slow:   500ms ease;

  /* nav height */
  --nav-h: 72px;
}

/* ── DARK MODE (default) ── */
:root, [data-theme="dark"] {
  --bg:       #080808;
  --bg2:      #0E0E0E;
  --bg3:      #141414;
  --bg4:      #1A1A1A;
  --txt:      #F0EDE8;
  --txt2:     rgba(240,237,232,.55);
  --txt3:     rgba(240,237,232,.28);
  --border:   rgba(255,255,255,.06);
  --border2:  rgba(184,151,90,.2);
  --shadow:   rgba(0,0,0,.5);
  --nav-bg:   rgba(8,8,8,.92);
  --overlay:  rgba(8,8,8,.85);
}

/* ── LIGHT MODE ── */
[data-theme="light"] {
  --bg:       #FAFAF8;
  --bg2:      #F2F0EC;
  --bg3:      #E8E5DF;
  --bg4:      #DEDAD3;
  --txt:      #0A0908;
  --txt2:     rgba(10,9,8,.55);
  --txt3:     rgba(10,9,8,.35);
  --border:   rgba(0,0,0,.08);
  --border2:  rgba(184,151,90,.3);
  --shadow:   rgba(0,0,0,.12);
  --nav-bg:   rgba(250,250,248,.94);
  --overlay:  rgba(250,250,248,.9);
}

/* ── 2. RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100%; }
body {
  background: var(--bg);
  color: var(--txt);
  font-family: var(--font-body);
  line-height: 1.6;
  overflow-x: hidden;
  transition: background var(--t-slow), color var(--t-slow);
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button,input,select,textarea { font-family:inherit; }
ul,ol { list-style:none; }
::selection { background:var(--accent); color:#000; }
:focus-visible { outline:2px solid var(--accent); outline-offset:4px; }

/* ── 3. TYPOGRAPHY ── */
.display-xl {
  font-family:var(--font-display);
  font-size:clamp(3.5rem,9vw,8rem);
  font-weight:300;
  line-height:.95;
  letter-spacing:-.03em;
}
.display-lg {
  font-family:var(--font-display);
  font-size:clamp(2.5rem,6vw,5.5rem);
  font-weight:300;
  line-height:1;
  letter-spacing:-.02em;
}
.display-md {
  font-family:var(--font-display);
  font-size:clamp(1.75rem,4vw,3rem);
  font-weight:300;
  line-height:1.1;
}
.eyebrow {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
}
.eyebrow-line {
  display:flex;
  align-items:center;
  gap:var(--space-3);
}
.eyebrow-line::before {
  content:'';
  display:block;
  width:36px;
  height:1px;
  background:var(--accent);
  flex-shrink:0;
}

/* ── 4. LAYOUT ── */
.container {
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--space-6);
}
.container--narrow { max-width:900px; }
.container--wide   { max-width:1440px; }

.section { padding:var(--space-20) 0; }
.section--lg { padding:var(--space-24) 0; }
.section--sm { padding:var(--space-12) 0; }
.section--alt { background:var(--bg2); }
.section--dark { background:var(--bg3); }

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

@media(max-width:1024px){ .grid-4{grid-template-columns:repeat(2,1fr);} }
@media(max-width:768px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .section{padding:var(--space-16) 0;}
}

/* ── 5. NAVIGATION ── */
.nav {
  position:fixed;
  top:0;left:0;right:0;
  z-index:200;
  height:var(--nav-h);
  background:var(--nav-bg);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid transparent;
  transition:border-color var(--t-normal), background var(--t-slow);
}
.nav.scrolled { border-bottom-color:var(--border); }
.nav__inner {
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-6);
}
.nav__logo {
  display:flex;
  align-items:center;
  gap:var(--space-3);
  flex-shrink:0;
}
.nav__logo-mark {
  width:34px;height:34px;
  border:1px solid rgba(184,151,90,.5);
  border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.04em;
  color:var(--accent);
  transition:background var(--t-fast);
}
.nav__logo:hover .nav__logo-mark { background:var(--accent-dim); }
.nav__logo-text {
  font-family:var(--font-body);
  font-size:var(--text-sm);
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.nav__links {
  display:flex;
  align-items:center;
  gap:var(--space-1);
  margin:0 auto;
}
.nav__link {
  font-size:var(--text-sm);
  font-weight:500;
  padding:var(--space-2) var(--space-3);
  border-radius:4px;
  color:var(--txt2);
  transition:color var(--t-fast), background var(--t-fast);
  white-space:nowrap;
}
.nav__link:hover { color:var(--txt); background:var(--border); }
.nav__link--active { color:var(--accent); }
.nav__link--unit {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  letter-spacing:.08em;
  text-transform:uppercase;
}

.nav__right {
  display:flex;
  align-items:center;
  gap:var(--space-3);
  flex-shrink:0;
}

/* Theme toggle */
.theme-toggle {
  width:40px;height:40px;
  border:1px solid var(--border);
  border-radius:50%;
  background:transparent;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--txt2);
  transition:all var(--t-fast);
  font-size:16px;
}
.theme-toggle:hover { border-color:var(--accent); color:var(--accent); }
.theme-toggle .icon-sun { display:none; }
.theme-toggle .icon-moon { display:block; }
[data-theme="light"] .theme-toggle .icon-sun { display:block; }
[data-theme="light"] .theme-toggle .icon-moon { display:none; }

/* Mobile burger */
.nav__burger {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:var(--space-2);
}
.nav__burger span {
  display:block;
  width:22px;height:1.5px;
  background:var(--txt);
  transition:all var(--t-normal);
  transform-origin:center;
}
.nav__burger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav__burger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav__burger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

.nav__cta { display:none; }

@media(min-width:769px){ .nav__cta{display:flex;} }

@media(max-width:900px){
  .nav__links {
    position:fixed;
    top:var(--nav-h);left:0;right:0;
    background:var(--nav-bg);
    backdrop-filter:blur(20px);
    flex-direction:column;
    gap:0;
    padding:var(--space-4) 0 var(--space-6);
    border-bottom:1px solid var(--border);
    transform:translateY(-110%);
    opacity:0;
    pointer-events:none;
    transition:transform var(--t-normal), opacity var(--t-normal);
    margin:0;
  }
  .nav__links.open { transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav__link { width:100%; text-align:center; padding:var(--space-3) var(--space-6); border-radius:0; }
  .nav__burger { display:flex; }
}

/* ── 6. BUTTONS ── */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--space-2);
  font-family:var(--font-body);
  font-size:var(--text-sm);
  font-weight:600;
  letter-spacing:.04em;
  padding:14px 28px;
  border-radius:3px;
  border:1px solid transparent;
  cursor:pointer;
  transition:all var(--t-fast);
  white-space:nowrap;
  text-decoration:none;
}
.btn--primary {
  background:var(--accent);
  color:#000;
  border-color:var(--accent);
}
.btn--primary:hover {
  background:var(--accent-light);
  border-color:var(--accent-light);
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(184,151,90,.3);
}
.btn--outline {
  background:transparent;
  color:var(--txt);
  border-color:var(--border2);
}
.btn--outline:hover {
  border-color:var(--accent);
  color:var(--accent);
  background:var(--accent-dim);
}
.btn--ghost {
  background:transparent;
  color:var(--txt2);
  border-color:var(--border);
}
.btn--ghost:hover { color:var(--txt); border-color:var(--border2); }
.btn--full { width:100%; }
.btn--lg { padding:16px 36px; font-size:var(--text-base); }
.btn--sm { padding:10px 20px; font-size:var(--text-xs); letter-spacing:.1em; }
.btn--icon { gap:var(--space-2); }
.btn svg { width:16px;height:16px;flex-shrink:0; }

/* ── 7. HERO ── */
.hero {
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--bg);
  padding-top:var(--nav-h);
}
.hero__bg {
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
}
/* Grid overlay */
.hero__bg::after {
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:80px 80px;
  opacity:.5;
}
.hero__glow {
  position:absolute;
  border-radius:50%;
  background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);
  pointer-events:none;
  transition:transform .12s ease;
}
.hero__glow--center {
  width:800px;height:800px;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
}
.hero__noise {
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
  opacity:.025;
}
.hero__content {
  position:relative;z-index:1;
  padding:var(--space-16) 0;
}
.hero__eyebrow { margin-bottom:var(--space-5); }
.hero__title {
  margin-bottom:var(--space-6);
  color:var(--txt);
}
.hero__title em { font-style:italic; color:var(--accent); }
.hero__subtitle {
  font-size:var(--text-lg);
  color:var(--txt2);
  max-width:560px;
  line-height:1.7;
  margin-bottom:var(--space-8);
}
.hero__actions { display:flex; gap:var(--space-4); flex-wrap:wrap; }

/* ── 8. SECTION HEADER ── */
.sh { margin-bottom:var(--space-12); }
.sh__eyebrow { margin-bottom:var(--space-4); }
.sh__title {
  font-family:var(--font-display);
  font-size:clamp(2rem,5vw,3.75rem);
  font-weight:300;
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--txt);
  margin-bottom:var(--space-4);
}
.sh__title em { font-style:italic; color:var(--accent); }
.sh__body {
  font-size:var(--text-lg);
  color:var(--txt2);
  max-width:580px;
  line-height:1.7;
}
.sh--center { text-align:center; }
.sh--center .sh__body { margin:0 auto; }
.sh--center .eyebrow-line { justify-content:center; }
.sh--center .eyebrow-line::before { display:none; }

/* ── 9. STATS BAR ── */
.stats {
  background:var(--bg2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:var(--space-8) 0;
}
.stats__inner {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  divide-x:1px solid var(--border);
}
.stats__item {
  text-align:center;
  padding:var(--space-6) var(--space-4);
  border-right:1px solid var(--border);
  position:relative;
}
.stats__item:last-child { border-right:none; }
.stats__value {
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:300;
  color:var(--accent);
  line-height:1;
  display:block;
  letter-spacing:-.02em;
}
.stats__label {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  color:var(--txt3);
  text-transform:uppercase;
  letter-spacing:.15em;
  margin-top:var(--space-2);
  display:block;
}
@media(max-width:768px){
  .stats__inner{grid-template-columns:repeat(2,1fr);}
  .stats__item:nth-child(2){border-right:none;}
  .stats__item:nth-child(3){border-top:1px solid var(--border);}
  .stats__item:nth-child(4){border-top:1px solid var(--border);border-right:none;}
}

/* ── 10. SERVICE CARD ── */
.service-card {
  padding:var(--space-8);
  border:1px solid var(--border);
  background:var(--bg);
  position:relative;
  overflow:hidden;
  transition:border-color var(--t-normal), transform var(--t-normal);
  cursor:default;
}
.service-card::before {
  content:'';
  position:absolute;
  top:0;left:0;width:3px;height:0;
  background:var(--accent);
  transition:height var(--t-slow);
}
.service-card:hover { border-color:var(--border2); transform:translateY(-3px); }
.service-card:hover::before { height:100%; }
.service-card__num {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  color:var(--txt3);
  letter-spacing:.15em;
  margin-bottom:var(--space-5);
}
.service-card__icon {
  width:40px;height:40px;
  color:var(--accent);
  margin-bottom:var(--space-4);
}
.service-card__title {
  font-family:var(--font-display);
  font-size:var(--text-2xl);
  font-weight:300;
  color:var(--txt);
  margin-bottom:var(--space-3);
  line-height:1.2;
}
.service-card__desc {
  font-size:var(--text-sm);
  color:var(--txt2);
  line-height:1.7;
}
.service-card__tags {
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
  margin-top:var(--space-5);
}
.tag {
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--txt3);
  border:1px solid var(--border);
  padding:3px 8px;
  border-radius:2px;
  transition:color var(--t-fast),border-color var(--t-fast);
}
.tag:hover { color:var(--accent); border-color:var(--border2); }

/* ── 11. BLOG CARDS ── */
.blog-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-6);
}
@media(max-width:900px){ .blog-grid{grid-template-columns:repeat(2,1fr);} }
@media(max-width:600px){ .blog-grid{grid-template-columns:1fr;} }

.blog-card {
  background:var(--bg);
  border:1px solid var(--border);
  overflow:hidden;
  transition:border-color var(--t-normal),transform var(--t-normal);
  display:flex;
  flex-direction:column;
}
.blog-card:hover { border-color:var(--border2); transform:translateY(-4px); }
.blog-card__image {
  height:200px;
  background:var(--bg2);
  overflow:hidden;
  flex-shrink:0;
}
.blog-card__image svg { width:100%;height:100%;display:block; }
.blog-card__body {
  padding:var(--space-6);
  flex:1;
  display:flex;
  flex-direction:column;
}
.blog-card__cat {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  color:var(--accent);
  letter-spacing:.15em;
  text-transform:uppercase;
  margin-bottom:var(--space-3);
}
.blog-card__title {
  font-family:var(--font-display);
  font-size:var(--text-2xl);
  font-weight:300;
  color:var(--txt);
  line-height:1.2;
  margin-bottom:var(--space-3);
  flex:1;
}
.blog-card__excerpt {
  font-size:var(--text-sm);
  color:var(--txt2);
  line-height:1.7;
  margin-bottom:var(--space-4);
}
.blog-card__meta {
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-top:1px solid var(--border);
  padding-top:var(--space-4);
  margin-top:auto;
}
.blog-card__date {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  color:var(--txt3);
  letter-spacing:.08em;
}
.blog-card__read {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  color:var(--accent);
  letter-spacing:.1em;
  text-transform:uppercase;
}
.blog-card__read:hover { text-decoration:underline; }

/* ── 12. TEAM CARDS ── */
.team-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-6);
}
@media(max-width:900px){ .team-grid{grid-template-columns:repeat(2,1fr);} }
@media(max-width:550px){ .team-grid{grid-template-columns:1fr;} }

.team-card {
  background:var(--bg);
  border:1px solid var(--border);
  overflow:hidden;
  transition:border-color var(--t-normal);
}
.team-card:hover { border-color:var(--border2); }
.team-card__avatar {
  height:220px;
  background:var(--bg2);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.team-card__avatar svg { width:100%;height:100%; }
.team-card__body { padding:var(--space-5); }
.team-card__name {
  font-family:var(--font-display);
  font-size:var(--text-xl);
  font-weight:300;
  color:var(--txt);
  margin-bottom:var(--space-1);
}
.team-card__role {
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  color:var(--accent);
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:var(--space-3);
}
.team-card__bio {
  font-size:var(--text-sm);
  color:var(--txt2);
  line-height:1.6;
}

/* ── 13. CASE STUDY CARDS ── */
.case-card {
  background:var(--bg);
  border:1px solid var(--border);
  overflow:hidden;
  transition:border-color var(--t-normal),transform var(--t-normal);
}
.case-card:hover { border-color:var(--border2); transform:translateY(-4px); }
.case-card__visual {
  height:260px;
  overflow:hidden;
}
.case-card__visual svg { width:100%;height:100%;display:block;transition:transform var(--t-slow); }
.case-card:hover .case-card__visual svg { transform:scale(1.03); }
.case-card__body { padding:var(--space-6); }
.case-card__cat {
  font-family:var(--font-mono);font-size:var(--text-xs);
  color:var(--accent);letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:var(--space-3);
}
.case-card__title {
  font-family:var(--font-display);font-size:var(--text-2xl);
  font-weight:300;color:var(--txt);line-height:1.2;margin-bottom:var(--space-3);
}
.case-card__desc { font-size:var(--text-sm);color:var(--txt2);line-height:1.7;margin-bottom:var(--space-5); }
.case-card__results { display:flex;gap:var(--space-6); }
.case-card__stat-value {
  font-family:var(--font-display);font-size:var(--text-2xl);
  color:var(--accent);font-weight:300;
}
.case-card__stat-label {
  font-family:var(--font-mono);font-size:10px;
  color:var(--txt3);letter-spacing:.1em;text-transform:uppercase;
}

/* ── 14. TESTIMONIALS ── */
.testimonial-card {
  padding:var(--space-8);
  border:1px solid var(--border);
  background:var(--bg);
  transition:border-color var(--t-normal);
}
.testimonial-card:hover { border-color:var(--border2); }
.testimonial-card__quote {
  font-family:var(--font-display);font-size:4rem;
  color:var(--accent);opacity:.4;line-height:1;margin-bottom:var(--space-3);
}
.testimonial-card__body {
  font-size:var(--text-base);color:var(--txt2);
  line-height:1.8;font-style:italic;margin-bottom:var(--space-6);
}
.testimonial-card__author { border-top:1px solid var(--border);padding-top:var(--space-4); }
.testimonial-card__name {
  font-weight:600;font-size:var(--text-sm);color:var(--txt);
  text-transform:uppercase;letter-spacing:.06em;
}
.testimonial-card__role {
  font-family:var(--font-mono);font-size:var(--text-xs);
  color:var(--txt3);letter-spacing:.1em;margin-top:var(--space-1);
}

/* ── 15. CONTACT FORM ── */
.contact { padding:var(--space-20) 0;background:var(--bg); }
.contact__inner { display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:start; }
@media(max-width:768px){ .contact__inner{grid-template-columns:1fr;gap:var(--space-8);} }
.contact__body { font-size:var(--text-lg);color:var(--txt2);line-height:1.7;margin-bottom:var(--space-6); }
.contact__list { display:flex;flex-direction:column;gap:var(--space-3); }
.contact__list-item {
  display:flex;align-items:center;gap:var(--space-3);
  font-size:var(--text-sm);color:var(--txt2);
}
.contact__list-icon { color:var(--accent);flex-shrink:0; }
.form-group { margin-bottom:var(--space-5); }
.form-label {
  display:block;
  font-family:var(--font-mono);font-size:var(--text-xs);
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--txt3);margin-bottom:var(--space-2);
}
.form-input {
  width:100%;padding:var(--space-3) var(--space-4);
  background:var(--bg2);
  border:1px solid var(--border);
  color:var(--txt);
  font-family:var(--font-body);font-size:var(--text-sm);
  border-radius:3px;
  transition:border-color var(--t-fast);
  outline:none;
  -webkit-appearance:none;
}
.form-input::placeholder { color:var(--txt3); }
.form-input:focus { border-color:var(--accent); }
.form-textarea { min-height:140px;resize:vertical;line-height:1.6; }
.form-feedback {
  margin-top:var(--space-4);
  font-family:var(--font-mono);font-size:var(--text-xs);
  letter-spacing:.1em;min-height:1.2em;
}

/* WhatsApp CTA */
.contact__wa-btn {
  display:inline-flex;
  align-items:center;gap:var(--space-3);
  padding:16px 28px;
  background:#25D366;
  color:#fff;
  border-radius:3px;
  font-weight:600;
  font-size:var(--text-sm);
  margin-top:var(--space-6);
  transition:background var(--t-fast),transform var(--t-fast);
}
.contact__wa-btn:hover { background:#1DA851;transform:translateY(-1px); }
.contact__wa-btn svg { width:20px;height:20px; }

/* ── 16. FOOTER ── */
.footer {
  background:var(--bg2);
  border-top:1px solid var(--border);
  padding:var(--space-16) 0 var(--space-8);
}
.footer__inner {
  display:grid;
  grid-template-columns:1.5fr repeat(3,1fr);
  gap:var(--space-12);
  margin-bottom:var(--space-12);
}
@media(max-width:900px){ .footer__inner{grid-template-columns:1fr 1fr;gap:var(--space-8);} }
@media(max-width:550px){ .footer__inner{grid-template-columns:1fr;} }

.footer__brand {}
.footer__logo {
  display:inline-flex;align-items:center;gap:var(--space-3);
  margin-bottom:var(--space-4);
}
.footer__tagline { font-size:var(--text-sm);color:var(--txt2);margin-bottom:var(--space-4);line-height:1.6; }
.footer__social { display:flex;gap:var(--space-2); }
.social-btn {
  width:36px;height:36px;
  border:1px solid var(--border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--txt2);
  transition:all var(--t-fast);
}
.social-btn:hover { border-color:var(--accent);color:var(--accent);background:var(--accent-dim); }
.social-btn svg { width:16px;height:16px; }

.footer__col-title {
  font-family:var(--font-mono);font-size:var(--text-xs);
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--txt3);margin-bottom:var(--space-4);
}
.footer__links { display:flex;flex-direction:column;gap:var(--space-2); }
.footer__link {
  font-size:var(--text-sm);color:var(--txt2);
  transition:color var(--t-fast);
}
.footer__link:hover { color:var(--accent); }

.footer__bottom {
  border-top:1px solid var(--border);
  padding-top:var(--space-6);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:var(--space-4);
}
.footer__copy {
  font-family:var(--font-mono);font-size:var(--text-xs);
  color:var(--txt3);letter-spacing:.08em;
}
.footer__legal-links { display:flex;gap:var(--space-4); }
.footer__legal-link {
  font-family:var(--font-mono);font-size:var(--text-xs);
  color:var(--txt3);letter-spacing:.08em;
  transition:color var(--t-fast);
}
.footer__legal-link:hover { color:var(--accent); }

/* ── 17. WHATSAPP FLOATING BUTTON ── */
.wa-float {
  position:fixed;
  bottom:var(--space-6);
  right:var(--space-6);
  z-index:300;
  width:56px;height:56px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  transition:transform var(--t-fast),box-shadow var(--t-fast);
  animation:waPulse 3s ease-in-out infinite;
}
.wa-float:hover {
  transform:scale(1.1);
  box-shadow:0 8px 32px rgba(37,211,102,.5);
  animation:none;
}
.wa-float svg { width:28px;height:28px;color:#fff; }
.wa-float__tooltip {
  position:absolute;
  right:68px;
  background:var(--bg2);
  color:var(--txt);
  font-size:var(--text-xs);
  font-weight:600;
  padding:8px 14px;
  border-radius:4px;
  white-space:nowrap;
  border:1px solid var(--border);
  opacity:0;
  transform:translateX(8px);
  transition:all var(--t-fast);
  pointer-events:none;
}
.wa-float:hover .wa-float__tooltip { opacity:1;transform:translateX(0); }
@keyframes waPulse {
  0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4);}
  50%{box-shadow:0 4px 32px rgba(37,211,102,.65);}
}

/* ── 18. COOKIE BANNER ── */
.cookie-banner {
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:400;
  background:var(--bg2);
  border-top:1px solid var(--border);
  padding:var(--space-5) var(--space-6);
  transform:translateY(100%);
  transition:transform var(--t-slow);
}
.cookie-banner.show { transform:translateY(0); }
.cookie-banner__inner {
  max-width:1280px;margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-6);
  flex-wrap:wrap;
}
.cookie-banner__text {
  font-size:var(--text-sm);color:var(--txt2);flex:1;min-width:280px;line-height:1.6;
}
.cookie-banner__text a { color:var(--accent);text-decoration:underline; }
.cookie-banner__actions { display:flex;gap:var(--space-3);flex-shrink:0; }

/* ── 19. TICKER ── */
.ticker {
  overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--bg2);
  padding:var(--space-3) 0;
}
.ticker__track {
  display:flex;
  gap:0;
  animation:tickerScroll 30s linear infinite;
  width:max-content;
}
.ticker__item {
  display:flex;align-items:center;gap:var(--space-4);
  padding:0 var(--space-6);
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--txt3);
  white-space:nowrap;
}
.ticker__item::after {
  content:'✦';
  color:var(--accent);
  font-size:8px;
}
@keyframes tickerScroll {
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}
.ticker:hover .ticker__track { animation-play-state:paused; }

/* ── 20. UNIT CARDS ── */
.unit-card {
  position:relative;
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--bg);
  padding:var(--space-10) var(--space-8);
  transition:border-color var(--t-normal),transform var(--t-normal);
  display:flex;flex-direction:column;
}
.unit-card::after {
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;height:3px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform var(--t-slow);
}
.unit-card:hover { border-color:var(--border2);transform:translateY(-4px); }
.unit-card:hover::after { transform:scaleX(1); }
.unit-card__label {
  font-family:var(--font-mono);font-size:var(--text-xs);
  color:var(--accent);letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:var(--space-4);
}
.unit-card__title {
  font-family:var(--font-display);font-size:var(--text-4xl);
  font-weight:300;color:var(--txt);line-height:1.1;margin-bottom:var(--space-3);
}
.unit-card__desc { font-size:var(--text-sm);color:var(--txt2);line-height:1.7;margin-bottom:var(--space-8);flex:1; }
.unit-card__link {
  font-family:var(--font-mono);font-size:var(--text-xs);
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);
  display:flex;align-items:center;gap:var(--space-2);
  transition:gap var(--t-fast);
}
.unit-card:hover .unit-card__link { gap:var(--space-4); }

/* ── 21. PROCESS STEPS ── */
.process-steps {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:0;
  position:relative;
}
.process-steps::before {
  content:'';
  position:absolute;
  top:30px;left:10%;right:10%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--border) 20%,var(--border) 80%,transparent);
}
@media(max-width:900px){
  .process-steps{grid-template-columns:1fr 1fr;gap:var(--space-6);}
  .process-steps::before{display:none;}
}
@media(max-width:550px){ .process-steps{grid-template-columns:1fr;} }

.process-step { padding:var(--space-6);text-align:center;position:relative; }
.process-step__num {
  width:60px;height:60px;
  border:1px solid var(--border);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto var(--space-4);
  font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);
  background:var(--bg);
  position:relative;z-index:1;
  transition:border-color var(--t-fast),background var(--t-fast);
}
.process-step:hover .process-step__num { border-color:var(--accent);background:var(--accent-dim); }
.process-step__title {
  font-size:var(--text-sm);font-weight:600;
  color:var(--txt);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2);
}
.process-step__desc { font-size:var(--text-xs);color:var(--txt3);line-height:1.6; }

/* ── 22. COMING SOON ── */
.cs-scene {
  position:fixed;inset:0;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;z-index:0;
}
.cs-rings { position:relative;width:min(80vw,600px);height:min(80vw,600px); }
.cs-ring {
  position:absolute;inset:0;border-radius:50%;
  border:1px solid var(--accent);
  animation:ringPulse 4s ease-in-out infinite;
}
.cs-ring:nth-child(1){--s:1;animation-delay:0s;}
.cs-ring:nth-child(2){--s:.75;animation-delay:.6s;}
.cs-ring:nth-child(3){--s:.5;animation-delay:1.2s;}
.cs-ring:nth-child(4){--s:.25;animation-delay:1.8s;}
@keyframes ringPulse{
  0%,100%{opacity:.08;transform:scale(var(--s));}
  50%{opacity:.2;transform:scale(calc(var(--s)*1.02));}
}
.cs-form__input {
  flex:1;background:var(--bg2);border:1px solid var(--border);
  border-right:none;color:var(--txt);
  font-family:var(--font-body);font-size:var(--text-sm);
  padding:14px var(--space-4);outline:none;
  transition:border-color var(--t-fast);
}
.cs-form__input:focus { border-color:rgba(184,151,90,.5); }
.cs-form__btn {
  background:var(--accent);color:#000;
  font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  padding:14px var(--space-6);border:1px solid var(--accent);
  cursor:pointer;transition:opacity var(--t-fast);white-space:nowrap;
}
.cs-form__btn:hover { opacity:.85; }

/* ── 23. SCROLL REVEAL ── */
.reveal {
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.visible { opacity:1;transform:translateY(0); }
.reveal-d1{transition-delay:.1s;}
.reveal-d2{transition-delay:.2s;}
.reveal-d3{transition-delay:.3s;}
.reveal-d4{transition-delay:.4s;}
.reveal-d5{transition-delay:.5s;}
.reveal-d6{transition-delay:.6s;}

/* ── 24. PORTFOLIO FILTER ── */
.portfolio-filter { display:flex;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-8); }
.pf-btn {
  font-family:var(--font-mono);font-size:var(--text-xs);
  letter-spacing:.12em;text-transform:uppercase;
  padding:var(--space-2) var(--space-4);
  border:1px solid var(--border);
  background:transparent;color:var(--txt3);
  cursor:pointer;border-radius:2px;
  transition:all var(--t-fast);
}
.pf-btn:hover,.pf-btn.active {
  border-color:var(--accent);color:var(--accent);background:var(--accent-dim);
}

/* ── 25. PORTFOLIO GRID ── */
.portfolio-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
}
@media(max-width:900px){.portfolio-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:550px){.portfolio-grid{grid-template-columns:1fr;}}
.portfolio-item {
  position:relative;overflow:hidden;
  background:var(--bg2);
  aspect-ratio:4/3;cursor:pointer;
}
.portfolio-item svg { width:100%;height:100%;display:block;transition:transform var(--t-slow); }
.portfolio-item:hover svg { transform:scale(1.05); }
.portfolio-item__overlay {
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,8,8,.95) 0%,transparent 55%);
  opacity:0;
  transition:opacity var(--t-normal);
  display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-5);
}
[data-theme="light"] .portfolio-item__overlay {
  background:linear-gradient(to top,rgba(10,9,8,.92) 0%,transparent 55%);
}
.portfolio-item:hover .portfolio-item__overlay { opacity:1; }
.portfolio-item__cat {
  font-family:var(--font-mono);font-size:var(--text-xs);
  color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:var(--space-2);
}
.portfolio-item__title {
  font-family:var(--font-display);font-size:var(--text-xl);
  color:#F0EDE8;font-weight:300;
}

/* ── 26. INSIGHTS LIST ── */
.insight-item {
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:var(--space-6);
  align-items:center;
  padding:var(--space-6) 0;
  border-bottom:1px solid var(--border);
  transition:background var(--t-fast);
}
.insight-item:hover { margin:0 calc(-1 * var(--space-6));padding-left:var(--space-6);padding-right:var(--space-6);background:var(--bg2); }
.insight-item__num {
  font-family:var(--font-mono);font-size:var(--text-xs);
  color:var(--txt3);letter-spacing:.1em;width:24px;
}
.insight-item__title {
  font-family:var(--font-display);font-size:var(--text-xl);
  font-weight:300;color:var(--txt);
}
.insight-item:hover .insight-item__title { color:var(--accent); }
.insight-item__arrow { color:var(--txt3);transition:color var(--t-fast),transform var(--t-fast); }
.insight-item:hover .insight-item__arrow { color:var(--accent);transform:translate(4px,-4px); }

/* ── 27. PAGE HERO (sub-pages) ── */
.page-hero {
  padding:calc(var(--nav-h) + var(--space-16)) 0 var(--space-16);
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:relative;
  overflow:hidden;
}
.page-hero::after {
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:80px 80px;
  opacity:.4;
  pointer-events:none;
}

/* ── 28. MISC UTILITIES ── */
.text-accent { color:var(--accent); }
.text-muted  { color:var(--txt3); }
.mt-auto { margin-top:auto; }
.divider { height:1px;background:var(--border);margin:var(--space-8) 0; }
.badge {
  display:inline-flex;align-items:center;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.15em;text-transform:uppercase;
  padding:4px 10px;border:1px solid var(--border2);
  color:var(--accent);border-radius:20px;
  background:var(--accent-dim);
}
.img-placeholder {
  width:100%;height:100%;
  background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
}

/* ═══════════════════════════════════════════════════════
   AUTO THEME — OS preference (no JS flash)
   ═══════════════════════════════════════════════════════ */

/* Default = dark (matches dark OS) */
@media (prefers-color-scheme: light) {
  :root:not([data-theme="dark"]) {
    --bg:       #FAFAF8;
    --bg2:      #F2F0EC;
    --bg3:      #E8E5DF;
    --bg4:      #DEDAD3;
    --txt:      #0A0908;
    --txt2:     rgba(10,9,8,.58);
    --txt3:     rgba(10,9,8,.35);
    --border:   rgba(0,0,0,.08);
    --border2:  rgba(184,151,90,.3);
    --shadow:   rgba(0,0,0,.12);
    --nav-bg:   rgba(250,250,248,.95);
    --overlay:  rgba(250,250,248,.9);
  }
}

/* ═══════════════════════════════════════════════════════
   MOBILE OVERHAUL — fully responsive
   ═══════════════════════════════════════════════════════ */

/* Base mobile resets */
@media (max-width: 480px) {
  :root { --nav-h: 60px; }
  .container { padding: 0 var(--space-4); }
  .section { padding: var(--space-12) 0; }
  .section--lg { padding: var(--space-16) 0; }

  /* Typography scale down */
  .display-xl { font-size: clamp(2.5rem,12vw,4rem); }
  .display-lg { font-size: clamp(2rem,10vw,3rem); }
  .display-md { font-size: clamp(1.5rem,8vw,2rem); }
  .sh__title  { font-size: clamp(1.75rem,8vw,2.5rem); }

  /* Stats — 2 columns on mobile */
  .stats__inner { grid-template-columns: 1fr 1fr; }
  .stats__item:nth-child(2) { border-right: none; }
  .stats__item:nth-child(3),
  .stats__item:nth-child(4) { border-top: 1px solid var(--border); }
  .stats__value { font-size: 2rem; }

  /* Hero actions stack */
  .hero__actions,
  .sh-hero__actions,
  .cap-hero__actions,
  .hero-home__actions { flex-direction: column; gap: var(--space-3); }
  .hero__actions .btn,
  .sh-hero__actions .btn,
  .cap-hero__actions .btn,
  .hero-home__actions .btn { width: 100%; justify-content: center; }

  /* Nav */
  .nav__logo-text { font-size: 11px; }
  .nav__cta { display: none; }

  /* Footer */
  .footer__inner { grid-template-columns: 1fr; gap: var(--space-6); }
  .footer__bottom { flex-direction: column; text-align: center; gap: var(--space-3); }

  /* Cards */
  .service-card { padding: var(--space-5); }
  .unit-card    { padding: var(--space-6) var(--space-5); }
  .case-card__results { gap: var(--space-4); }

  /* Blog grid */
  .blog-grid { grid-template-columns: 1fr; }

  /* Team grid */
  .team-grid { grid-template-columns: 1fr; }

  /* Contact */
  .contact__inner { gap: var(--space-6); }

  /* WA float position */
  .wa-float { bottom: var(--space-4); right: var(--space-4); width: 48px; height: 48px; }
  .wa-float svg { width: 24px; height: 24px; }

  /* Cookie banner */
  .cookie-banner__inner { flex-direction: column; gap: var(--space-3); }
  .cookie-banner__actions { width: 100%; justify-content: stretch; }
  .cookie-banner__actions .btn { flex: 1; }

  /* Process steps */
  .process-steps { grid-template-columns: 1fr; }
  .process-steps::before { display: none; }

  /* Industries */
  .industries-grid { grid-template-columns: repeat(2, 1fr); }

  /* Why grid */
  .why-grid { grid-template-columns: 1fr; }

  /* Ticker */
  .ticker__item { padding: 0 var(--space-4); }

  /* Forms */
  .form-input { font-size: 16px; } /* prevents iOS zoom */
}

/* Tablet */
@media (max-width: 768px) {
  /* Nav mobile menu improvements */
  .nav__links {
    position: fixed;
    top: var(--nav-h);
    left: 0; right: 0;
    background: var(--nav-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    flex-direction: column;
    gap: 0;
    padding: var(--space-3) 0 var(--space-6);
    border-bottom: 1px solid var(--border);
    transform: translateY(-110%);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.3s ease, opacity 0.3s ease;
    z-index: 199;
    max-height: calc(100svh - var(--nav-h));
    overflow-y: auto;
  }
  .nav__links.open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  .nav__link {
    width: 100%;
    padding: var(--space-3) var(--space-6);
    border-radius: 0;
    border-bottom: 1px solid var(--border);
    font-size: var(--text-base);
  }
  .nav__link:last-child { border-bottom: none; }
  .nav__burger { display: flex; }

  /* Hero grids → single column */
  .sh-hero__content { grid-template-columns: 1fr; }
  .sh-hero__right   { display: none; }
  .cap-hero__indicators { flex-wrap: wrap; gap: var(--space-6); }
  .hero-home__content { padding: var(--space-12) 0; }

  /* About */
  .about-split   { grid-template-columns: 1fr; }
  .sa-about__inner { grid-template-columns: 1fr; }
  .sa-about__visual { display: none; }

  /* Contact */
  .contact__inner { grid-template-columns: 1fr; }

  /* Case studies */
  .grid-3 { grid-template-columns: 1fr; }

  /* Ecosystem */
  .ecosystem-grid { grid-template-columns: 1fr; }

  /* Newsletter strip */
  .newsletter-strip { flex-direction: column; gap: var(--space-5); }
  .newsletter-strip__form { width: 100%; }

  /* Featured post */
  .featured-post { grid-template-columns: 1fr; }

  /* Capital hero indicators */
  .cap-indicator__val { font-size: var(--text-2xl); }

  /* Shop countdown */
  .shop-countdown { gap: var(--space-4); }
  .shop-countdown__val { font-size: clamp(1.5rem,6vw,3rem); }

  /* Footer */
  .footer__inner { grid-template-columns: 1fr 1fr; gap: var(--space-6); }

  /* Sector grid */
  .sectors-grid { grid-template-columns: 1fr 1fr; }

  /* Process grid */
  .process-grid { grid-template-columns: 1fr 1fr; }
  .process-cell { border-bottom: 1px solid var(--border); }
  .process-cell:nth-child(even) { border-right: none; }

  /* Capital service layout */
  .cap-service__content { grid-template-columns: 1fr; padding-left: 0; }
  .cap-service__header { grid-template-columns: auto 1fr auto; }
  .cap-service__timeline { display: none; }
  .cap-service__name { font-size: clamp(1.25rem,4vw,2rem); }

  /* Studio services */
  .ss-item__content { grid-template-columns: 1fr; padding-left: 0; }
  .ss-item__name { font-size: clamp(1.25rem,4vw,2rem); }

  /* Personal brand grid */
  .pb-grid { grid-template-columns: 1fr 1fr; }

  /* Why rows */
  .why-row { grid-template-columns: auto 1fr; }
  .why-row__tag { display: none; }

  /* Portfolio grid */
  .sp-grid { grid-template-columns: 1fr 1fr; }
  .sp-item--featured { grid-row: span 1; min-height: 200px; }

  /* Metrics */
  .sm-results__inner { grid-template-columns: 1fr; }

  /* Testimonials */
  .st-grid { grid-template-columns: 1fr; }

  /* Blog filters wrap nicely */
  .blog-filters, .portfolio-filter { gap: var(--space-2); }
  .blog-filter-btn, .pf-btn { padding: 6px 12px; font-size: 10px; }

  /* Form inputs - prevent iOS zoom */
  .form-input { font-size: 16px; }

  /* contact way grid */
  .contact-ways { grid-template-columns: 1fr; }

  /* About pillars */
  .sa-about__pillars { grid-template-columns: 1fr 1fr; }

  /* Hero unit badges */
  .hero-home__units { gap: var(--space-2); }
  .hero-unit-badge { font-size: 10px; padding: 5px 10px; }
}

/* Large mobile / small tablet */
@media (min-width: 481px) and (max-width: 768px) {
  .stats__inner { grid-template-columns: repeat(2, 1fr); }
  .blog-grid    { grid-template-columns: 1fr; }
}

/* Touch device improvements */
@media (hover: none) {
  /* Disable hover effects that don't work on touch */
  .service-card:hover,
  .unit-card:hover,
  .blog-card:hover,
  .case-card:hover,
  .team-card:hover { transform: none; }

  /* Larger tap targets */
  .btn { min-height: 48px; }
  .nav__link { min-height: 48px; display: flex; align-items: center; }
  .sidebar__item { min-height: 44px; }

  /* WA float always visible pulse on touch */
  .wa-float { animation: waPulse 3s ease-in-out infinite; }
}

/* Fix for iOS safe areas */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .cookie-banner { padding-bottom: calc(var(--space-5) + env(safe-area-inset-bottom)); }
  .wa-float { bottom: calc(var(--space-6) + env(safe-area-inset-bottom)); }
}

/* Landscape phone */
@media (max-height: 500px) and (max-width: 900px) {
  .hero-home, .sh-hero, .cap-hero {
    min-height: auto;
    padding-top: calc(var(--nav-h) + var(--space-8));
    padding-bottom: var(--space-8);
  }
  .shop-content { min-height: auto; padding: calc(var(--nav-h) + 20px) var(--space-4) 60px; }
}

/* Print */
@media print {
  .nav, .wa-float, .cookie-banner, .hero-home__bg, .sh-hero__bg { display: none !important; }
  body { background: white !important; color: black !important; }
}

/* Focus styles for accessibility */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
  border-radius: 2px;
}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1 !important; transform: none !important; }
}
