/* ==========================================================================
   AD-VENTURES — Premium Redesign Design System
   ========================================================================== */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

/* ---- Design Tokens ---- */
:root{
  /* Brand */
  --c-primary:        #BD1D32;
  --c-primary-dark:   #8C1526;
  --c-primary-light:  #E14258;
  --c-primary-tint:   #FBE7EA;

  /* Neutrals */
  --c-ink:            #14151A;
  --c-ink-soft:       #2C2E36;
  --c-slate:          #65767E;
  --c-slate-light:    #A7B0B4;
  --c-paper:          #FAF8F7;
  --c-paper-alt:      #F1EEEC;
  --c-white:          #FFFFFF;
  --c-line:           rgba(20,21,26,0.09);
  --c-line-light:     rgba(255,255,255,0.14);

  /* Typography */
  --font-display: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;

  --fs-display: clamp(2.8rem, 7vw, 6.6rem);
  --fs-h1: clamp(2.4rem, 5vw, 4.4rem);
  --fs-h2: clamp(1.9rem, 3.4vw, 3rem);
  --fs-h3: clamp(1.3rem, 2vw, 1.8rem);
  --fs-lead: clamp(1.05rem, 1.4vw, 1.35rem);
  --fs-body: 1rem;
  --fs-small: 0.85rem;
  --fs-micro: 0.72rem;

  /* Spacing */
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: 6rem;
  --space-3xl: 9rem;

  /* Layout */
  --container: 1320px;
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 28px;
  --radius-pill: 100px;

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --t-fast: .25s;
  --t-med: .55s;
  --t-slow: .9s;
}

/* ---- Reset ---- */
*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  margin:0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: 400;
  color: var(--c-ink);
  background: var(--c-paper);
  line-height: 1.65;
  overflow-x: hidden;
}
img,svg,video,canvas{ display:block; max-width:100%; }
a{ color: inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4,p{ margin:0; }
button{ font-family: inherit; cursor:pointer; }

h1,h2,h3,h4,.font-display{ font-family: var(--font-display); font-weight:600; letter-spacing:-0.01em; line-height:1.08; }

.container{ max-width: var(--container); margin:0 auto; padding: 0 6vw; }
@media (min-width: 1600px){ .container{ padding: 0 4vw; } }

section{ position: relative; }

/* ---- Selection / focus ---- */
::selection{ background: var(--c-primary); color: var(--c-white); }
:focus-visible{ outline: 2px solid var(--c-primary); outline-offset: 3px; }

/* ---- Utility ---- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family: var(--font-display);
  font-size: var(--fs-micro);
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--c-primary);
  font-weight: 600;
}
.eyebrow::before{
  content:''; display:block; width:28px; height:2px; background: var(--c-primary);
}
.lead{ font-size: var(--fs-lead); color: var(--c-slate); font-weight:300; max-width: 46ch; }
.text-center{ text-align:center; margin-left:auto; margin-right:auto; }

.section-head{ margin-bottom: var(--space-2xl); max-width: 760px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2{ margin-top: var(--space-sm); }

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  font-family: var(--font-display); font-weight:600; font-size: .9rem;
  letter-spacing:.04em; text-transform:uppercase;
  padding: 1.05rem 2.1rem;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  white-space: nowrap;
}
.btn-primary{ background: var(--c-primary); color: var(--c-white); }
.btn-primary:hover{ background: var(--c-ink); transform: translateY(-2px); }
.btn-outline{ background: transparent; color: var(--c-ink); border-color: var(--c-line); }
.btn-outline:hover{ border-color: var(--c-ink); transform: translateY(-2px); }
.btn-outline.on-dark{ color: var(--c-white); border-color: var(--c-line-light); }
.btn-outline.on-dark:hover{ background: var(--c-white); color: var(--c-ink); }
.btn-arrow{ transition: transform var(--t-fast) var(--ease); }
.btn:hover .btn-arrow{ transform: translateX(4px); }

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */
.site-header{
  position: fixed; top:0; left:0; right:0; z-index: 1000;
  display:flex; align-items:center; justify-content:space-between;
  padding: 1.6rem 6vw;
  transition: padding var(--t-med) var(--ease), background var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease);
  mix-blend-mode: normal;
}
.site-header.scrolled{
  padding: 1rem 6vw;
  background: rgba(250,248,247,0.82);
  backdrop-filter: blur(14px) saturate(160%);
  box-shadow: 0 1px 0 var(--c-line);
}
.site-header .logo{ display:flex; align-items:center; gap:.7rem; }
.site-header .logo img{ height: 34px; width:auto; transition: filter var(--t-med); }
.is-dark .site-header .logo img.logo-dark{ display:none; }
.is-dark .site-header .logo img.logo-light{ display:block; }
.site-header .logo img.logo-light{ display:none; }
.site-header.scrolled .logo img.logo-light{ display:none; }
.site-header.scrolled .logo img.logo-dark{ display:block; }

.nav-main{ display:flex; align-items:center; gap: 2.4rem; }
.nav-main a{
  font-family: var(--font-display); font-size:.82rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  position:relative; padding: .3rem 0; color: var(--c-ink);
  transition: color var(--t-fast);
}
.is-dark .nav-main a{ color: var(--c-white); }
.site-header.scrolled .nav-main a{ color: var(--c-ink); }
.nav-main a::after{
  content:''; position:absolute; left:0; bottom:-4px; width:0; height:2px;
  background: var(--c-primary); transition: width var(--t-med) var(--ease);
}
.nav-main a:hover::after, .nav-main a.active::after{ width:100%; }
.nav-main a.active{ color: var(--c-primary); }

.nav-toggle{
  display:none; width:46px; height:46px; border-radius:50%; border:1px solid var(--c-line);
  background: transparent; align-items:center; justify-content:center; position:relative;
  z-index: 1001;
}
.is-dark .nav-toggle{ border-color: var(--c-line-light); }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after{
  content:''; display:block; width:18px; height:2px; background: currentColor; position:relative; transition: all .3s var(--ease);
}
.nav-toggle span::before{ position:absolute; top:-6px; }
.nav-toggle span::after{ position:absolute; top:6px; }
.is-dark .nav-toggle{ color:#fff; }
.site-header.scrolled .nav-toggle{ color: var(--c-ink); border-color: var(--c-line); }

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position: relative; min-height: 100vh; display:flex; flex-direction:column;
  justify-content:center; overflow:hidden; background: var(--c-ink); color: var(--c-white);
  padding-top: 8rem; padding-bottom: 4rem;
}
.hero-canvas{ position:absolute; inset:0; z-index:1; opacity:1; }
.hero-canvas canvas{ width:100% !important; height:100% !important; }
.hero::after{
  content:''; position:absolute; inset:0; z-index:2; pointer-events:none;
  background: linear-gradient(180deg, rgba(20,21,26,.05) 0%, rgba(20,21,26,.55) 75%, rgba(20,21,26,.95) 100%);
}
.hero-content{ position:relative; z-index:3; }
.hero .eyebrow{ color: var(--c-primary-light); }
.hero h1{ color: var(--c-white); margin-top: var(--space-md); font-size: var(--fs-display); }
.hero h1 em{ font-style:normal; color: var(--c-primary-light); }
.hero .lead{ color: rgba(255,255,255,.7); margin-top: var(--space-md); }
.hero-actions{ display:flex; gap: 1.2rem; margin-top: var(--space-xl); flex-wrap:wrap; }
.hero-meta{
  position:relative; z-index:3; display:flex; justify-content:space-between;
  align-items:flex-end; margin-top: var(--space-3xl); gap: 2rem; flex-wrap:wrap;
  border-top: 1px solid var(--c-line-light); padding-top: var(--space-md);
}
.hero-meta .scroll-cue{ display:flex; align-items:center; gap:.8rem; font-family:var(--font-display); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color: rgba(255,255,255,.6); }
.scroll-cue .line{ width:46px; height:1px; background: rgba(255,255,255,.35); position:relative; overflow:hidden; }
.scroll-cue .line::after{ content:''; position:absolute; left:-100%; top:0; width:100%; height:100%; background: var(--c-primary-light); animation: cueMove 2.4s linear infinite; }
@keyframes cueMove{ 0%{ left:-100%; } 100%{ left:100%; } }
.hero-stats{ display:flex; gap: var(--space-2xl); flex-wrap:wrap; }
.hero-stats .stat strong{ display:block; font-family:var(--font-display); font-size: 1.8rem; color:var(--c-white); }
.hero-stats .stat span{ font-size: var(--fs-small); color: rgba(255,255,255,.55); letter-spacing:.05em; }

/* Page hero (subpages) */
.page-hero{
  background: var(--c-ink); color: var(--c-white); padding: 11rem 0 5rem;
  position:relative; overflow:hidden;
}
.page-hero .container{ position:relative; z-index:2; }
.page-hero h1{ color:var(--c-white); margin-top: var(--space-md); }
.page-hero .lead{ color: rgba(255,255,255,.7); margin-top: var(--space-md); }
.page-hero-canvas{ position:absolute; inset:0; opacity:.55; z-index:1; }

/* ==========================================================================
   GENERAL SECTIONS
   ========================================================================== */
.section{ padding: var(--space-3xl) 0; }
.section-sm{ padding: var(--space-2xl) 0; }
.bg-ink{ background: var(--c-ink); color: var(--c-white); }
.bg-ink .c-slate-text, .bg-ink p{ color: rgba(255,255,255,.65); }
.bg-ink h2, .bg-ink h3{ color: var(--c-white); }
.bg-alt{ background: var(--c-paper-alt); }

/* Grid helpers */
.grid{ display:grid; gap: var(--space-lg); }
.grid-2{ grid-template-columns: repeat(2,1fr); }
.grid-3{ grid-template-columns: repeat(3,1fr); }
.grid-4{ grid-template-columns: repeat(4,1fr); }
.grid-12{ display:grid; grid-template-columns: repeat(12,1fr); gap: var(--space-lg); }

@media (max-width: 1000px){
  .grid-2,.grid-3,.grid-4{ grid-template-columns: 1fr; }
  .grid-12{ grid-template-columns: 1fr; }
}

/* ---- Reveal animation ---- */
.reveal{ opacity:0; transform: translateY(36px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.is-visible{ opacity:1; transform: translateY(0); }
.reveal-stagger > *{ opacity:0; transform: translateY(36px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal-stagger.is-visible > *{ opacity:1; transform: translateY(0); }
.reveal-stagger.is-visible > *:nth-child(1){ transition-delay:.05s; }
.reveal-stagger.is-visible > *:nth-child(2){ transition-delay:.12s; }
.reveal-stagger.is-visible > *:nth-child(3){ transition-delay:.19s; }
.reveal-stagger.is-visible > *:nth-child(4){ transition-delay:.26s; }
.reveal-stagger.is-visible > *:nth-child(5){ transition-delay:.33s; }
.reveal-stagger.is-visible > *:nth-child(6){ transition-delay:.4s; }

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

/* Service / competence cards */
.card{
  background: var(--c-white); border:1px solid var(--c-line); border-radius: var(--radius-md);
  padding: var(--space-lg); transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease), border-color var(--t-med) var(--ease);
  height:100%;
}
.card:hover{ transform: translateY(-6px); box-shadow: 0 24px 48px -24px rgba(20,21,26,.18); border-color: transparent; }
.card .num{ font-family: var(--font-display); font-size: .8rem; color: var(--c-primary); letter-spacing:.2em; }
.card h3{ margin-top: var(--space-sm); }
.card p{ color: var(--c-slate); margin-top: .6rem; }
.card ul{ margin-top: var(--space-md); display:flex; flex-direction:column; gap:.5rem; }
.card ul li{ font-size: var(--fs-small); color: var(--c-ink-soft); padding-left: 1.1rem; position:relative; }
.card ul li::before{ content:''; position:absolute; left:0; top:.55em; width:6px; height:6px; border-radius:50%; background: var(--c-primary); }

/* Icon badge */
.badge-icon{
  width:56px; height:56px; border-radius: var(--radius-sm); background: var(--c-primary-tint);
  display:flex; align-items:center; justify-content:center; color: var(--c-primary);
}
.badge-icon svg{ width:26px; height:26px; }

/* Marquee */
.marquee{ overflow:hidden; border-top:1px solid var(--c-line); border-bottom:1px solid var(--c-line); padding: var(--space-md) 0; }
.marquee-track{ display:flex; gap: 0; white-space:nowrap; animation: marquee 38s linear infinite; }
.marquee-track span{ font-family: var(--font-display); font-size: 1.4rem; color: var(--c-slate-light); text-transform:uppercase; letter-spacing:.1em; }
.marquee-track span strong{ color: var(--c-ink); font-weight:600; }
@keyframes marquee{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }
@media (max-width: 1000px){ .marquee-track{ animation-duration: 24s; } }

/* Work / portfolio cards */
.work-grid{ display:grid; grid-template-columns: repeat(2,1fr); gap: var(--space-md); }
.work-card{
  position:relative; border-radius: var(--radius-md); overflow:hidden; aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--c-ink) 0%, var(--c-ink-soft) 100%);
  display:flex; align-items:flex-end; padding: var(--space-lg); color: var(--c-white);
  isolation:isolate;
}
.work-card::before{
  content:''; position:absolute; inset:0; opacity:.5; mix-blend-mode: overlay;
  background: radial-gradient(circle at 30% 20%, var(--c-primary), transparent 60%);
  transition: transform 1.2s var(--ease), opacity var(--t-med);
}
.work-card:hover::before{ transform: scale(1.25); opacity:.85; }
.work-card .tag{ font-family: var(--font-display); font-size:.72rem; letter-spacing:.25em; text-transform:uppercase; color: var(--c-primary-light); }
.work-card h3{ margin-top:.5rem; color: var(--c-white); font-size: var(--fs-h3); }
.work-card .yr{ position:absolute; top: var(--space-md); right: var(--space-md); font-family: var(--font-display); font-size:.78rem; letter-spacing:.2em; color: rgba(255,255,255,.55); }
@media (max-width: 900px){ .work-grid{ grid-template-columns:1fr; } }

/* Timeline (Milestones) */
.timeline-dial{
  display:flex; flex-wrap:wrap; gap:.5rem; padding: var(--space-md) 0; border-bottom:1px solid var(--c-line); border-top:1px solid var(--c-line); margin-bottom: var(--space-2xl);
  position: sticky; top: 84px; background: var(--c-paper); z-index: 50;
}
.timeline-dial::-webkit-scrollbar{ display:none; }
.timeline-dial button{
  font-family: var(--font-display); font-size:.85rem; font-weight:600; letter-spacing:.04em;
  padding:.5rem 1rem; border-radius: var(--radius-pill); border:1px solid transparent; background:transparent; color: var(--c-slate-light);
  transition: all var(--t-fast) var(--ease);
}
.timeline-dial button:hover{ color: var(--c-ink); }
.timeline-dial button.active{ background: var(--c-primary); color:var(--c-white); }

.year-block{ display:none; }
.year-block.active{ display:block; animation: fadeIn .5s var(--ease); }
@keyframes fadeIn{ from{ opacity:0; transform: translateY(14px);} to{opacity:1; transform:translateY(0);} }
.year-head{ display:flex; align-items:baseline; gap: var(--space-md); margin-bottom: var(--space-lg); }
.year-head .big-year{ font-family: var(--font-display); font-size: clamp(3rem,8vw,7rem); color: var(--c-primary); line-height:1; }
.year-head .count{ color: var(--c-slate); font-size: var(--fs-small); letter-spacing:.1em; text-transform:uppercase; }
.milestone-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap: var(--space-md); }
.milestone-item{ border:1px solid var(--c-line); border-radius: var(--radius-md); padding: var(--space-md); background:var(--c-white); transition: border-color var(--t-fast), transform var(--t-fast); }
.milestone-item:hover{ border-color: var(--c-primary); transform: translateY(-3px); }
.milestone-item h4{ font-family:var(--font-display); font-size:1rem; color: var(--c-ink); letter-spacing:.02em; margin-bottom:.5rem; }
.milestone-item p{ color: var(--c-slate); font-size: var(--fs-small); }
@media (max-width: 1000px){ .milestone-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px){ .milestone-grid{ grid-template-columns: 1fr; } .timeline-dial{ position:relative; top:auto; overflow-x:auto; flex-wrap:nowrap; } }

/* Team cards */
.team-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap: var(--space-md); }
.team-card{ text-align:left; }
.team-card .photo{
  aspect-ratio: 3/4; border-radius: var(--radius-md); background: linear-gradient(150deg, var(--c-paper-alt), var(--c-line));
  display:flex; align-items:center; justify-content:center; overflow:hidden; position:relative; margin-bottom: var(--space-sm);
  background-size: cover; background-position: center top;
}
.team-card .photo::after{ content:''; position:absolute; inset:0; background: linear-gradient(180deg, transparent 60%, rgba(20,21,26,.55)); opacity:0; transition: opacity var(--t-med); }
.team-card:hover .photo::after{ opacity:1; }
.team-card .initials{ font-family:var(--font-display); font-size:3rem; color: var(--c-slate-light); }
.team-card h3{ font-size: 1.05rem; }
.team-card .role{ color: var(--c-primary); font-size: var(--fs-small); letter-spacing:.06em; text-transform:uppercase; font-family:var(--font-display); font-weight:600; margin-top:.2rem; }
@media (max-width: 1000px){ .team-grid{ grid-template-columns: repeat(2,1fr); } }

/* Process / numbered list */
.process-list{ display:flex; flex-direction:column; }
.process-item{
  display:grid; grid-template-columns: 90px 1fr 1fr; gap: var(--space-lg); align-items:start;
  padding: var(--space-lg) 0; border-bottom:1px solid var(--c-line);
}
.process-item .pnum{ font-family: var(--font-display); font-size: 1.4rem; color: var(--c-primary); }
.process-item h3{ font-size: var(--fs-h3); }
.process-item p{ color: var(--c-slate); }
@media (max-width: 900px){ .process-item{ grid-template-columns: 1fr; gap: .8rem; } }

/* Quote / CTA band */
.cta-band{
  border-radius: var(--radius-lg); background: var(--c-ink); color: var(--c-white);
  padding: var(--space-2xl) var(--space-2xl); text-align:center; position:relative; overflow:hidden;
}
.cta-band h2{ color:var(--c-white); }
.cta-band .lead{ color: rgba(255,255,255,.65); margin: var(--space-md) auto var(--space-lg); }
.cta-band-canvas{ position:absolute; inset:0; opacity:.5; }
.cta-band .container-inner{ position:relative; z-index:2; }

/* Logo strip */
.logo-mark-big{
  display:flex; align-items:center; justify-content:center; padding: var(--space-2xl) 0;
}
.logo-mark-big img{ max-width: 360px; }

/* Stats row */
.stats-row{ display:grid; grid-template-columns: repeat(4,1fr); gap: var(--space-lg); text-align:left; }
.stats-row .stat strong{ display:block; font-family:var(--font-display); font-size: clamp(2.2rem,4vw,3.4rem); color: var(--c-primary); }
.stats-row .stat span{ color: var(--c-slate); font-size: var(--fs-small); letter-spacing:.04em; }
@media (max-width:900px){ .stats-row{ grid-template-columns: repeat(2,1fr); } }

/* ==========================================================================
   LIGHTBOX
   ========================================================================== */
.lb-overlay{
  position:fixed; inset:0; z-index:9500;
  background: rgba(20,21,26,.88);
  backdrop-filter: blur(8px);
  display:flex; align-items:center; justify-content:center;
  padding: 2rem;
  opacity:0; visibility:hidden;
  transition: opacity var(--t-med) var(--ease), visibility 0s var(--t-med);
}
.lb-overlay.open{
  opacity:1; visibility:visible;
  transition: opacity var(--t-med) var(--ease), visibility 0s 0s;
}
.lb-inner{
  position:relative; width:100%; max-width:440px;
  transform: translateY(24px);
  transition: transform var(--t-med) var(--ease);
}
.lb-overlay.open .lb-inner{ transform: translateY(0); }

.lb-img{
  display:block; width:100%; border-radius: var(--radius-md);
  aspect-ratio: 3/4; object-fit:cover; object-position: center top;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,.6);
}
.lb-caption{
  margin-top: 1.2rem; text-align:center;
}
.lb-name{
  font-family: var(--font-display); font-size: 1.15rem; font-weight:600;
  color: var(--c-white); margin:0;
}
.lb-role{
  font-family: var(--font-display); font-size: var(--fs-small);
  letter-spacing:.08em; text-transform:uppercase; font-weight:600;
  color: var(--c-primary-light); margin-top:.3rem; display:block;
}
.lb-close{
  position:absolute; top:-.9rem; right:-.9rem;
  width:38px; height:38px; border-radius:50%;
  background: var(--c-white); color: var(--c-ink); border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; z-index:1;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  box-shadow: 0 4px 12px rgba(0,0,0,.25);
}
.lb-close:hover{ background: var(--c-primary); color: var(--c-white); transform:scale(1.1); }
.lb-close svg{ width:15px; height:15px; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{ background: var(--c-ink); color: var(--c-white); padding: var(--space-2xl) 0 var(--space-lg); }
.footer-top{ display:flex; justify-content:space-between; gap: var(--space-2xl); flex-wrap:wrap; padding-bottom: var(--space-2xl); border-bottom:1px solid var(--c-line-light); }
.footer-cta h2{ color: var(--c-white); max-width: 14ch; }
.footer-cols{ display:flex; gap: var(--space-2xl); flex-wrap:wrap; }
.footer-col h4{ font-family:var(--font-display); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color: var(--c-primary-light); margin-bottom: var(--space-sm); }
.footer-col a, .footer-col p{ display:block; color: rgba(255,255,255,.65); font-size:.92rem; margin-bottom:.5rem; transition: color var(--t-fast); }
.footer-col a:hover{ color: var(--c-white); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top: var(--space-lg); flex-wrap:wrap; gap: var(--space-md); }
.footer-bottom .logo img{ height: 30px; }
.footer-legal{ display:flex; gap: var(--space-lg); font-size: var(--fs-small); color: rgba(255,255,255,.5); }
.footer-legal a:hover{ color: var(--c-white); }
.socials{ display:flex; gap:.8rem; }
.socials a{ width:38px; height:38px; border:1px solid var(--c-line-light); border-radius:50%; display:flex; align-items:center; justify-content:center; transition: all var(--t-fast); }
.socials a:hover{ background: var(--c-primary); border-color: var(--c-primary); }
.socials svg{ width:16px; height:16px; }

/* ==========================================================================
   CUSTOM CURSOR (decent, subtle)
   ========================================================================== */
.cursor-dot{
  position: fixed; top:0; left:0; width:10px; height:10px; border-radius:50%;
  background: var(--c-primary); pointer-events:none; z-index: 9999; mix-blend-mode: difference;
  transform: translate(-50%,-50%); transition: width .25s var(--ease), height .25s var(--ease), opacity .25s;
  opacity: 0;
}
.cursor-dot.active{ opacity:1; }
.cursor-dot.is-link{ width:46px; height:46px; background: rgba(255,255,255,0.9); }
@media (max-width: 1000px){ .cursor-dot{ display:none; } }

/* ==========================================================================
   RESPONSIVE NAV
   ========================================================================== */
@media (max-width: 1000px){
  .nav-toggle{ display:flex; }
  .nav-main{
    position: fixed; inset:0; background: var(--c-ink); flex-direction:column; justify-content:center;
    gap: 2rem; transform: translateY(-100%); z-index:999;
    transition: transform var(--t-med) var(--ease), visibility 0s var(--t-med);
    visibility: hidden; overflow: hidden;
  }
  .nav-main.open{ transform: translateY(0); visibility: visible; transition: transform var(--t-med) var(--ease), visibility 0s 0s; }
  .nav-main a{ color: var(--c-white); font-size: 1.4rem; }
  .nav-main .socials{ margin-top: 2rem; }
}

/* Page-specific helpers */
.split{ display:grid; grid-template-columns: 1fr 1fr; gap: var(--space-2xl); align-items:center; }
@media (max-width: 1000px){ .split{ grid-template-columns: 1fr; gap: var(--space-lg); } }
.tag-list{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top: var(--space-md); }
.tag-list span{ border:1px solid var(--c-line); border-radius: var(--radius-pill); padding:.4rem 1rem; font-size: var(--fs-small); color: var(--c-slate); }
.bg-ink .tag-list span{ border-color: var(--c-line-light); color: rgba(255,255,255,.7); }

.kicker-divider{ height:1px; background: var(--c-line); margin: var(--space-2xl) 0; }
.bg-ink .kicker-divider{ background: var(--c-line-light); }
