/* =========================================================================
   CREAVIO — content studio
   Palette: warm paper + violet-ink + electric coral. Signature: 9:16 frame
   + mono "timecode" labels + one rhythm/equaliser motion moment.
   ========================================================================= */

:root{
  --paper:      #FBF9F6;
  --paper-2:    #F3EEE8;
  --cloud:      #EFEAF4;
  --ink:        #1A1530;
  --ink-soft:   #4A4361;
  --ink-faint:  #6F6886;
  --coral:      #FF5436;
  --coral-deep: #E03A1E;
  --line:       rgba(26,21,48,.12);
  --line-2:     rgba(26,21,48,.22);
  --paper-line: rgba(251,249,246,.16);

  --font-display: "Syne", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, sans-serif;
  --font-mono:    "Space Mono", ui-monospace, monospace;

  --wrap: 1180px;
  --radius: 18px;
  --radius-s: 11px;

  --sp-section: clamp(4rem, 9vw, 7.5rem);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  font-size:1.0625rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
:focus-visible{ outline:2.5px solid var(--coral); outline-offset:3px; border-radius:4px; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:800; line-height:1.04; margin:0; letter-spacing:-.01em; }
p{ margin:0; }
.eyebrow{
  font-family:var(--font-mono);
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-faint);
  display:inline-flex;
  align-items:center;
  gap:.55em;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:var(--coral); display:inline-block;
}
.eyebrow--plain::before{ display:none; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:clamp(1.15rem, 4vw, 2.6rem); }
.section{ padding-block:var(--sp-section); }
.section--tight{ padding-block:clamp(2.6rem,6vw,4.2rem); }
.ink-bg{ background:var(--ink); color:var(--paper); }
.ink-bg .eyebrow{ color:rgba(251,249,246,.6); }
.cloud-bg{ background:var(--cloud); }

/* =========================================================================
   HEADER
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(251,249,246,.82);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  height:68px;
}
.brand{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:800; font-size:1.32rem; letter-spacing:-.02em; }
.brand-mark{
  width:30px; height:30px; border-radius:9px; background:var(--coral);
  position:relative; flex:none; box-shadow:0 4px 14px rgba(255,84,54,.35);
}
.brand-mark::after{
  content:""; position:absolute; inset:0; margin:auto;
  width:0; height:0; border-style:solid; border-width:6px 0 6px 10px;
  border-color:transparent transparent transparent var(--paper);
  translate:1px 0;
}
.nav-links{ display:flex; align-items:center; gap:2.1rem; list-style:none; margin:0; padding:0; }
.nav-links a{ font-size:.96rem; font-weight:500; color:var(--ink-soft); position:relative; padding-block:.4rem; }
.nav-links a:hover{ color:var(--ink); }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:.05rem; height:2px; width:100%;
  background:var(--coral); transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after{ transform:scaleX(1); }
.nav-links a[aria-current="page"]{ color:var(--ink); }

.nav-right{ display:flex; align-items:center; gap:1rem; }

/* language switcher */
.lang{ display:inline-flex; border:1px solid var(--line-2); border-radius:999px; padding:3px; gap:2px; background:var(--paper); }
.lang button{
  border:0; background:transparent; color:var(--ink-soft);
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.06em;
  padding:.32rem .56rem; border-radius:999px; line-height:1; transition:.18s;
}
.lang button[aria-pressed="true"]{ background:var(--ink); color:var(--paper); }
.lang button:hover:not([aria-pressed="true"]){ color:var(--ink); }

.burger{ display:none; border:1px solid var(--line-2); background:var(--paper); border-radius:10px; width:42px; height:42px; padding:0; place-items:center; }
.burger span,.burger span::before,.burger span::after{
  content:""; display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; position:relative; transition:.25s;
}
.burger span::before{ position:absolute; top:-6px; }
.burger span::after{ position:absolute; top:6px; }
.burger[aria-expanded="true"] span{ background:transparent; }
.burger[aria-expanded="true"] span::before{ top:0; rotate:45deg; }
.burger[aria-expanded="true"] span::after{ top:0; rotate:-45deg; }

/* =========================================================================
   HERO
   ========================================================================= */
.hero{ padding-block:clamp(3rem,7vw,6rem) clamp(3.5rem,8vw,7rem); overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.hero h1{
  font-size:clamp(2.7rem, 6.6vw, 5.1rem);
  margin:1.2rem 0 1.4rem;
}
.hero h1 .accent{ color:var(--coral); position:relative; white-space:nowrap; }
.hero h1 .accent::after{
  content:""; position:absolute; left:0; right:0; bottom:.06em; height:.13em;
  background:var(--coral); opacity:.28; border-radius:2px;
}
.hero-lead{ font-size:clamp(1.05rem,1.7vw,1.28rem); color:var(--ink-soft); max-width:34ch; }
.hero-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:1.1rem; margin-top:2.1rem; }

.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  font-weight:600; font-size:.98rem; padding:.92rem 1.5rem; border-radius:999px; border:1px solid transparent;
  transition:transform .18s ease, background .2s ease, color .2s, border-color .2s;
}
.btn:active{ transform:translateY(1px); }
.btn--primary{ background:var(--coral); color:#fff; box-shadow:0 10px 24px -8px rgba(255,84,54,.6); }
.btn--primary:hover{ background:var(--coral-deep); transform:translateY(-2px); }
.btn--ghost{ border-color:var(--line-2); color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn--light{ background:var(--paper); color:var(--ink); }
.btn--light:hover{ transform:translateY(-2px); }
.btn .arrow{ transition:transform .2s; }
.btn:hover .arrow{ transform:translate(3px,-3px); }

.hero-meta{ display:flex; gap:2.2rem; margin-top:2.6rem; flex-wrap:wrap; }
.hero-meta .stat{ }
.hero-meta .stat b{ font-family:var(--font-display); font-size:1.55rem; display:block; line-height:1; }
.hero-meta .stat span{ font-size:.82rem; color:var(--ink-faint); }

/* the 9:16 signature frame */
.reel{
  position:relative; margin-inline:auto; width:min(300px, 78vw); aspect-ratio:9/16;
  border-radius:30px; padding:11px; background:var(--ink);
  box-shadow:0 40px 80px -30px rgba(26,21,48,.55), inset 0 0 0 1px rgba(255,255,255,.06);
  rotate:3deg; transition:rotate .5s ease;
}
.reel:hover{ rotate:0deg; }
.reel-screen{
  position:relative; width:100%; height:100%; border-radius:21px; overflow:hidden;
  background:
    radial-gradient(120% 80% at 20% 0%, #FF7A5E 0%, transparent 55%),
    radial-gradient(120% 90% at 90% 100%, #6B4DE6 0%, transparent 55%),
    linear-gradient(160deg, #2A1F4D, #140F26);
}
.reel-screen::before{ /* drifting light */
  content:""; position:absolute; inset:-30%;
  background:radial-gradient(closest-side, rgba(255,255,255,.22), transparent 70%);
  animation:drift 9s ease-in-out infinite;
}
@keyframes drift{ 0%,100%{ transform:translate(-10%,8%);} 50%{ transform:translate(18%,-12%);} }

.reel-tc{
  position:absolute; top:12px; left:12px; font-family:var(--font-mono); font-size:.66rem;
  color:#fff; background:rgba(0,0,0,.32); padding:.18rem .42rem; border-radius:6px; letter-spacing:.05em;
}
.reel-rec{ position:absolute; top:13px; right:12px; display:flex; align-items:center; gap:.32rem; font-family:var(--font-mono); font-size:.62rem; color:#fff; }
.reel-rec i{ width:7px; height:7px; border-radius:50%; background:#FF4D4D; box-shadow:0 0 0 0 rgba(255,77,77,.6); animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(255,77,77,.6);} 70%{ box-shadow:0 0 0 7px rgba(255,77,77,0);} 100%{ box-shadow:0 0 0 0 rgba(255,77,77,0);} }

.reel-caption{ position:absolute; left:14px; right:14px; bottom:60px; color:#fff; }
.reel-caption .tag{ font-family:var(--font-mono); font-size:.62rem; opacity:.85; letter-spacing:.08em; }
.reel-caption p{ font-family:var(--font-display); font-weight:700; font-size:1.05rem; line-height:1.12; margin-top:.3rem; }

/* equaliser = abstracted dance/rhythm */
.eq{ position:absolute; left:14px; right:14px; bottom:20px; height:30px; display:flex; align-items:flex-end; gap:4px; }
.eq i{ flex:1; background:rgba(255,255,255,.85); border-radius:3px; height:30%; transform-origin:bottom; animation:bounce 1.1s ease-in-out infinite; }
.eq i:nth-child(2){ animation-delay:.12s } .eq i:nth-child(3){ animation-delay:.28s }
.eq i:nth-child(4){ animation-delay:.05s } .eq i:nth-child(5){ animation-delay:.34s }
.eq i:nth-child(6){ animation-delay:.18s } .eq i:nth-child(7){ animation-delay:.42s }
.eq i:nth-child(8){ animation-delay:.09s } .eq i:nth-child(9){ animation-delay:.3s }
@keyframes bounce{ 0%,100%{ transform:scaleY(.28);} 50%{ transform:scaleY(1);} }

@media (prefers-reduced-motion: reduce){
  .reel-screen::before,.reel-rec i,.eq i{ animation:none; }
  .eq i{ height:60%; }
}

/* =========================================================================
   MARQUEE divider (one slow motion strip)
   ========================================================================= */
.ticker{ border-block:1px solid var(--line); padding-block:1rem; overflow:hidden; white-space:nowrap; }
.ticker-track{ display:inline-flex; gap:2.4rem; animation:scroll 26s linear infinite; }
.ticker:hover .ticker-track{ animation-play-state:paused; }
.ticker span{ font-family:var(--font-display); font-weight:800; font-size:1.5rem; color:var(--ink); display:inline-flex; align-items:center; gap:2.4rem; }
.ticker span::after{ content:"●"; color:var(--coral); font-size:.7rem; }
@keyframes scroll{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .ticker-track{ animation:none; } }

/* =========================================================================
   SECTION HEADER
   ========================================================================= */
.s-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:1.5rem; margin-bottom:2.6rem; flex-wrap:wrap; }
.s-head h2{ font-size:clamp(1.9rem,4vw,3rem); margin-top:.8rem; max-width:18ch; }
.s-head .link{ font-weight:600; color:var(--coral); display:inline-flex; gap:.4rem; align-items:center; white-space:nowrap; }
.s-head .link:hover{ gap:.7rem; }

/* =========================================================================
   ARTICLE CARDS
   ========================================================================= */
.cards{ display:grid; grid-template-columns:repeat(auto-fill, minmax(270px,1fr)); gap:1.4rem; }
.card{
  display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden; transition:transform .22s ease, box-shadow .22s ease, border-color .22s;
}
.card:hover{ transform:translateY(-5px); box-shadow:0 24px 40px -26px rgba(26,21,48,.4); border-color:var(--line-2); }
.card-thumb{ aspect-ratio:16/10; position:relative; }
.card-thumb .tc{ position:absolute; left:10px; bottom:10px; font-family:var(--font-mono); font-size:.62rem; color:#fff; background:rgba(0,0,0,.35); padding:.16rem .4rem; border-radius:5px; }
.g1{ background:radial-gradient(120% 120% at 20% 10%, #FF7A5E, #E03A1E); }
.g2{ background:radial-gradient(120% 120% at 80% 0%, #7C5CFF, #3A2A8C); }
.g3{ background:radial-gradient(120% 120% at 50% 100%, #28C2A8, #0E6E63); }
.g4{ background:radial-gradient(120% 120% at 10% 90%, #1A1530, #4A3F7A); }
.card-body{ padding:1.25rem 1.3rem 1.5rem; display:flex; flex-direction:column; gap:.6rem; flex:1; }
.card .cat{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--coral); }
.card h3{ font-size:1.22rem; line-height:1.15; }
.card p{ font-size:.94rem; color:var(--ink-soft); }
.card .read{ margin-top:auto; font-family:var(--font-mono); font-size:.72rem; color:var(--ink-faint); padding-top:.4rem; }

/* featured (big) card */
.featured{ display:grid; grid-template-columns:1.05fr 1fr; gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-bottom:1.4rem; background:var(--paper); transition:box-shadow .25s; }
.featured:hover{ box-shadow:0 30px 60px -34px rgba(26,21,48,.45); }
.featured-img{ min-height:280px; position:relative; }
.featured-img .tc{ position:absolute; left:14px; bottom:14px; font-family:var(--font-mono); font-size:.66rem; color:#fff; background:rgba(0,0,0,.35); padding:.2rem .46rem; border-radius:6px; }
.featured-body{ padding:clamp(1.6rem,3vw,2.8rem); display:flex; flex-direction:column; justify-content:center; gap:1rem; }
.featured-body .cat{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--coral); }
.featured-body h3{ font-size:clamp(1.6rem,3vw,2.3rem); line-height:1.08; }
.featured-body p{ color:var(--ink-soft); }
.featured-body .read{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-faint); }

/* =========================================================================
   ABOUT teaser strip
   ========================================================================= */
.about-strip{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.about-strip h2{ font-size:clamp(1.9rem,4vw,3rem); margin:.9rem 0 1.2rem; }
.about-strip p{ color:rgba(251,249,246,.82); max-width:48ch; margin-bottom:1.1rem; }
.about-visual{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.about-visual .tile{ border-radius:var(--radius-s); padding:1.3rem; border:1px solid var(--paper-line); min-height:120px; display:flex; flex-direction:column; justify-content:space-between; }
.about-visual .tile b{ font-family:var(--font-display); font-size:1.9rem; }
.about-visual .tile span{ font-size:.82rem; color:rgba(251,249,246,.65); }
.about-visual .tile:nth-child(1){ background:linear-gradient(160deg,#FF6A4A,#E03A1E); border-color:transparent; }
.about-visual .tile:nth-child(4){ background:linear-gradient(160deg,#7C5CFF,#3A2A8C); border-color:transparent; }

/* =========================================================================
   ARTICLE PAGE
   ========================================================================= */
.post{ padding-block:clamp(2.4rem,5vw,4rem) var(--sp-section); }
.post-head{ max-width:760px; margin-inline:auto; text-align:center; }
.post-head .cat{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--coral); }
.post-head h1{ font-size:clamp(2.1rem,5vw,3.6rem); margin:1rem 0 1.2rem; }
.post-head .lead{ font-size:clamp(1.1rem,2vw,1.35rem); color:var(--ink-soft); }
.post-meta{ display:flex; gap:1.4rem; justify-content:center; margin-top:1.6rem; font-family:var(--font-mono); font-size:.76rem; color:var(--ink-faint); flex-wrap:wrap; }
.post-meta span{ display:inline-flex; gap:.4rem; align-items:center; }
.post-hero{ max-width:1000px; margin:clamp(2rem,4vw,3.2rem) auto 0; aspect-ratio:21/9; border-radius:var(--radius); position:relative; overflow:hidden; }
.post-hero .tc{ position:absolute; left:16px; bottom:16px; font-family:var(--font-mono); font-size:.7rem; color:#fff; background:rgba(0,0,0,.35); padding:.2rem .5rem; border-radius:6px; }
.post-hero-grad{ background:
    radial-gradient(100% 120% at 15% 0%, #FF7A5E 0%, transparent 55%),
    radial-gradient(100% 120% at 90% 100%, #7C5CFF 0%, transparent 55%),
    linear-gradient(160deg,#2A1F4D,#140F26); }

.prose{ max-width:680px; margin:clamp(2.4rem,5vw,3.4rem) auto 0; }
.prose > * + *{ margin-top:1.4rem; }
.prose p{ color:#2b2542; }
.prose h2{ font-size:clamp(1.5rem,3vw,2.1rem); margin-top:2.6rem; }
.prose h3{ font-size:1.25rem; margin-top:1.8rem; }
.prose ul{ padding-left:0; list-style:none; display:grid; gap:.85rem; }
.prose ul li{ position:relative; padding-left:2.1rem; }
.prose ul li::before{ content:counter(li,decimal-leading-zero); counter-increment:li; position:absolute; left:0; top:.05em; font-family:var(--font-mono); font-size:.8rem; color:var(--coral); }
.prose ul{ counter-reset:li; }
.pull{ border-left:3px solid var(--coral); padding:.4rem 0 .4rem 1.4rem; font-family:var(--font-display); font-weight:700; font-size:clamp(1.3rem,2.6vw,1.7rem); line-height:1.2; color:var(--ink); }
.post-cta{ max-width:680px; margin:clamp(2.6rem,5vw,3.6rem) auto 0; background:var(--cloud); border-radius:var(--radius); padding:clamp(1.6rem,3vw,2.4rem); text-align:center; }
.post-cta h3{ font-size:1.5rem; margin-bottom:.6rem; }
.post-cta p{ color:var(--ink-soft); margin-bottom:1.3rem; }
.back-link{ display:inline-flex; gap:.5rem; align-items:center; font-family:var(--font-mono); font-size:.78rem; color:var(--ink-soft); margin-bottom:1.6rem; }
.back-link:hover{ color:var(--coral); }

/* =========================================================================
   ABOUT PAGE
   ========================================================================= */
.page-hero{ padding-block:clamp(3rem,7vw,5.5rem) clamp(2rem,4vw,3rem); }
.page-hero h1{ font-size:clamp(2.4rem,6vw,4.4rem); margin:1rem 0 1.2rem; max-width:18ch; }
.page-hero .lead{ font-size:clamp(1.1rem,2vw,1.35rem); color:var(--ink-soft); max-width:54ch; }

.cover-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.2rem; margin-top:2.4rem; }
.cover{ border:1px solid var(--line); border-radius:var(--radius-s); padding:1.6rem; background:var(--paper); }
.cover .n{ font-family:var(--font-mono); font-size:.8rem; color:var(--coral); }
.cover h3{ font-size:1.2rem; margin:.7rem 0 .5rem; }
.cover p{ font-size:.94rem; color:var(--ink-soft); }

.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:1.1rem; }
.field label{ font-size:.85rem; font-weight:600; color:var(--ink-soft); }
.field input,.field textarea{
  font:inherit; font-size:1rem; padding:.85rem 1rem; border-radius:var(--radius-s);
  border:1px solid var(--line-2); background:var(--paper); color:var(--ink); width:100%;
}
.field textarea{ min-height:130px; resize:vertical; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--coral); box-shadow:0 0 0 3px rgba(255,84,54,.15); }
.form-note{ font-size:.84rem; color:var(--ink-faint); margin-top:.4rem; }
.form-ok{ display:none; background:var(--cloud); border-radius:var(--radius-s); padding:1rem 1.2rem; font-weight:600; margin-top:1rem; }
.form-ok.show{ display:block; }

.contact-card{ background:var(--ink); color:var(--paper); border-radius:var(--radius); padding:clamp(1.6rem,3vw,2.4rem); }
.contact-card h3{ font-size:1.4rem; margin-bottom:1.4rem; }
.contact-line{ display:flex; gap:.9rem; align-items:flex-start; padding-block:.9rem; border-top:1px solid var(--paper-line); }
.contact-line:first-of-type{ border-top:0; }
.contact-line .ic{ width:38px; height:38px; border-radius:10px; background:rgba(255,255,255,.08); display:grid; place-items:center; flex:none; color:var(--coral); }
.contact-line .lbl{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(251,249,246,.55); }
.contact-line .val{ font-weight:600; font-size:1.02rem; margin-top:.15rem; }
.contact-line a.val:hover{ color:var(--coral); }

/* =========================================================================
   LEGAL pages
   ========================================================================= */
.legal{ max-width:760px; margin-inline:auto; padding-block:clamp(2.5rem,5vw,4rem) var(--sp-section); }
.legal h1{ font-size:clamp(2rem,4vw,3rem); margin-bottom:1.6rem; }
.legal h2{ font-size:1.3rem; margin:2.2rem 0 .7rem; }
.legal p,.legal li{ color:var(--ink-soft); font-size:.98rem; }
.legal ul{ padding-left:1.2rem; display:grid; gap:.4rem; }
.legal .holder{ background:var(--cloud); border-radius:8px; padding:.1rem .4rem; font-family:var(--font-mono); font-size:.85em; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.newsletter{ background:var(--coral); color:#fff; }
.newsletter .wrap{ display:grid; grid-template-columns:1fr auto; gap:2rem; align-items:center; padding-block:clamp(2.4rem,5vw,3.4rem); }
.newsletter h2{ font-size:clamp(1.6rem,3.2vw,2.4rem); color:#fff; }
.newsletter p{ color:rgba(255,255,255,.88); margin-top:.5rem; max-width:42ch; }
.nl-form{ display:flex; gap:.6rem; flex-wrap:wrap; }
.nl-form input{ font:inherit; font-size:1rem; padding:.85rem 1.1rem; border-radius:999px; border:0; min-width:240px; flex:1; color:var(--ink); }
.nl-form input:focus{ outline:3px solid rgba(255,255,255,.5); }
.nl-ok{ font-weight:600; }

.site-footer{ background:var(--ink); color:var(--paper); padding-block:clamp(3rem,6vw,4.5rem) 2rem; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1.3fr; gap:clamp(2rem,5vw,4rem); }
.foot-brand .brand{ color:#fff; }
.foot-brand p{ color:rgba(251,249,246,.6); margin-top:1rem; max-width:34ch; font-size:.95rem; }
.foot-col h4{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(251,249,246,.5); font-weight:400; margin-bottom:1.1rem; }
.foot-col ul{ list-style:none; padding:0; margin:0; display:grid; gap:.7rem; }
.foot-col a{ color:rgba(251,249,246,.82); font-size:.96rem; }
.foot-col a:hover{ color:var(--coral); }
.foot-contact .row{ display:flex; gap:.7rem; align-items:flex-start; margin-bottom:.9rem; }
.foot-contact .row .ic{ color:var(--coral); flex:none; margin-top:.15rem; }
.foot-contact .row .lbl{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(251,249,246,.45); }
.foot-contact .row .v{ color:#fff; font-weight:500; font-size:.97rem; }
.foot-contact a.v:hover{ color:var(--coral); }
.foot-bottom{ border-top:1px solid var(--paper-line); margin-top:clamp(2.4rem,5vw,3.4rem); padding-top:1.6rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.foot-bottom p,.foot-bottom a{ font-size:.82rem; color:rgba(251,249,246,.55); }
.foot-bottom a:hover{ color:var(--coral); }
.foot-legal{ display:flex; gap:1.4rem; flex-wrap:wrap; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 900px){
  .hero-grid{ grid-template-columns:1fr; text-align:left; }
  .hero-visual{ order:-1; }
  .reel{ rotate:0deg; }
  .featured{ grid-template-columns:1fr; }
  .featured-img{ min-height:200px; aspect-ratio:16/9; }
  .about-strip,.contact-grid,.cover-grid{ grid-template-columns:1fr; }
  .about-strip .about-visual{ order:-1; }
  .newsletter .wrap{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .foot-brand{ grid-column:1 / -1; }
}

@media (max-width: 720px){
  .nav-links, .nav .lang.desktop-only{ display:none; }
  .burger{ display:grid; }
  .mobile-menu{
    position:fixed; inset:68px 0 auto 0; background:var(--paper); border-bottom:1px solid var(--line);
    padding:1.4rem clamp(1.15rem,4vw,2.6rem) 2rem; display:none; flex-direction:column; gap:.4rem; z-index:55;
    box-shadow:0 20px 40px -20px rgba(26,21,48,.3);
  }
  .mobile-menu.open{ display:flex; }
  .mobile-menu a{ padding:.85rem 0; font-size:1.1rem; font-weight:600; border-bottom:1px solid var(--line); }
  .mobile-menu .lang{ margin-top:1.2rem; align-self:flex-start; }
  .hero-meta{ gap:1.6rem; }
  .foot-grid{ grid-template-columns:1fr; }
  .post-meta{ gap:1rem; }
}

@media (max-width: 420px){
  .cards{ grid-template-columns:1fr; }
  .about-visual{ grid-template-columns:1fr; }
  .nl-form input{ min-width:0; }
}

/* fade-in on scroll */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }
