/* ═══════════════════════════════════════════════════════════
   Makeight — shared design system
   Palette: cream / coral / mint / periwinkle / deep purple
   ═══════════════════════════════════════════════════════════ */

:root{
  /* surfaces — deep purple base */
  --bg:        #0E0820;
  --bg-2:      #160E2C;
  --bg-3:      #1F143D;
  --bg-elev:   #281852;
  --line:      rgba(250,251,243,0.09);
  --line-2:    rgba(250,251,243,0.16);

  /* foreground — cream-led */
  --fg:        #FAFBF3;
  --fg-2:      #C9C2D8;
  --fg-mute:   #837C95;
  --fg-faint:  #4F4863;

  /* brand accents */
  --coral:     #F2655B;        /* primary action, logo red */
  --coral-d:   #D9483E;        /* hover */
  --mint:      #37CCA4;        /* positive / growth */
  --mint-d:    #28A685;
  --peri:      #717FC6;        /* atmospheric / secondary */
  --peri-d:    #5663A3;
  --deep:      #1A1332;        /* punctuation dark */

  /* primary accent role */
  --accent:    var(--coral);
  --accent-2:  var(--peri);
  --accent-3:  var(--mint);

  /* type */
  --serif:   "Instrument Serif", "Times New Roman", serif;
  --display: "Bricolage Grotesque", "Helvetica Neue", sans-serif;
  --sans:    "Geist", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, monospace;

  /* motion */
  --ease:       cubic-bezier(.2,.7,.2,1);
  --ease-heavy: cubic-bezier(.7,0,.2,1);

  --pad: clamp(20px, 4vw, 56px);
  --maxw: 1440px;
}

/* ───────────────────────── reset ───────────────────────── */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg); color:var(--fg);
  font-family:var(--sans); font-weight:400;
  line-height:1.45; letter-spacing:-0.005em;
  overflow-x:hidden; min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
::selection{ background:var(--coral); color:var(--fg); }

/* ───────────────────── overlays: grain + cursor ───────────────────── */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:1000;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.05; mix-blend-mode:overlay;
}
.cursor-dot,.cursor-ring{
  position:fixed; top:0; left:0; pointer-events:none; z-index:9999;
  border-radius:50%; transform:translate3d(-50%,-50%,0); mix-blend-mode:difference;
}
.cursor-dot{ width:6px; height:6px; background:#fff; }
.cursor-ring{
  width:36px; height:36px; border:1px solid rgba(255,255,255,.7);
  transition: width .25s var(--ease), height .25s var(--ease), background .25s, border-color .25s;
}
.cursor-ring.is-hover{ width:64px; height:64px; background:rgba(255,255,255,.08); }
.cursor-ring.is-drag { width:80px; height:80px; background:var(--coral); border-color:var(--coral); }
@media (hover:none){ .cursor-dot,.cursor-ring{ display:none; } }

/* ───────────────────────── navigation ───────────────────────── */
.nav{
  position:fixed; top:14px; left:50%; transform:translateX(-50%); z-index:200;
  width:min(1320px, calc(100% - 24px));
  display:flex; align-items:center; gap:18px;
  padding:10px 10px 10px 18px;
  background:rgba(14,8,32,0.55);
  border:1px solid var(--line);
  border-radius:999px;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  transition: background .3s var(--ease), border-color .3s;
}
.nav.is-scrolled{ background:rgba(14,8,32,0.82); border-color:var(--line-2); }
.nav__brand{ display:flex; align-items:center; gap:10px; }
.nav__brand img{ height:24px; width:auto; }
.nav__links{ display:flex; gap:2px; margin-left:14px; }
.nav__links a{
  font-size:13px; letter-spacing:-0.005em; padding:8px 14px; border-radius:999px;
  color:var(--fg-2); transition:color .25s, background .25s; position:relative;
}
.nav__links a:hover{ color:var(--fg); background:var(--line); }
.nav__links a.is-active{ color:var(--fg); }
.nav__links a.is-active::after{
  content:""; position:absolute; left:14px; right:14px; bottom:3px;
  height:1px; background:var(--coral);
}
.nav__right{ margin-left:auto; display:flex; align-items:center; gap:8px; }
.nav__search{
  width:36px; height:36px; border-radius:50%; display:grid; place-items:center;
  border:1px solid var(--line); color:var(--fg-2); transition:.25s;
}
.nav__search:hover{ color:var(--fg); border-color:var(--line-2); background:var(--line); }

.btn{
  display:inline-flex; align-items:center; gap:10px; padding:11px 18px 11px 20px;
  font-size:13px; font-weight:500; letter-spacing:-0.005em;
  border-radius:999px; transition: transform .3s var(--ease), background .3s, color .3s, border-color .3s;
  position:relative; cursor:pointer; white-space:nowrap;
}
.btn-primary{ background:var(--coral); color:#fff; }
.btn-primary:hover{ background:var(--coral-d); }
.btn-cream{ background:var(--fg); color:var(--bg); }
.btn-cream:hover{ background:var(--coral); color:#fff; }
.btn-ghost{ border:1px solid var(--line-2); color:var(--fg); }
.btn-ghost:hover{ background:var(--line); border-color:var(--fg-mute); }
.btn-mint{ background:var(--mint); color:var(--bg); }
.btn-mint:hover{ background:var(--mint-d); }
.btn .arrow{ width:14px; height:14px; transition: transform .35s var(--ease-heavy); }
.btn:hover .arrow{ transform: translateX(3px) rotate(-45deg); }

.mag{ display:inline-block; transition: transform .3s var(--ease); }

@media (max-width:900px){
  .nav__links{ display:none; }
  .nav__brand img{ height:22px; }
}

/* ───────────────────────── sections ───────────────────────── */
section{ position:relative; padding-left:var(--pad); padding-right:var(--pad); }
.section-head{
  display:flex; align-items:baseline; gap:24px; padding:18px 0; border-top:1px solid var(--line);
  font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase;
}
.section-num{ color:var(--coral); }
.section-meta{ margin-left:auto; }
@media (max-width:600px){
  .section-meta{ display:none; }
}

/* ─────────────────────────── hero ─────────────────────────── */
.hero{
  min-height:100vh; padding-top:140px; padding-bottom:60px;
  display:flex; flex-direction:column; justify-content:space-between;
  position:relative; overflow:hidden;
}
#hero-canvas{ position:absolute; inset:0; z-index:0; }
.hero__title{
  position:relative; z-index:2;
  font-family:var(--display); font-weight:500; letter-spacing:-0.035em; line-height:0.92;
  font-size: clamp(56px, 11.5vw, 196px);
  font-variation-settings: "wdth" 92;
  max-width: 1400px; margin-top:auto;
}
.hero__title em{
  font-family:var(--serif); font-style:italic; font-weight:400;
  letter-spacing:-0.015em; color:var(--coral);
  display:inline-block; padding:0 0.04em;
}
.hero__title .grow{ color:var(--mint); font-style:normal; font-family:var(--display); }

.hero__bottom{
  position:relative; z-index:2;
  display:grid; grid-template-columns: 1.1fr 0.9fr; gap:64px; align-items:end; margin-top:48px;
}
.hero__sub{ font-size: clamp(15px, 1.15vw, 17px); color:var(--fg-2); max-width: 46ch; line-height:1.55; }
.hero__sub strong{ color:var(--fg); font-weight:500; }
.hero__ctas{ display:flex; gap:12px; margin-top:24px; flex-wrap:wrap; }
.hero__btn-primary{
  background:var(--coral); color:#fff; padding:14px 22px; border-radius:999px;
  font-size:14px; font-weight:500; display:inline-flex; align-items:center; gap:12px;
  transition: background .3s var(--ease);
}
.hero__btn-primary:hover{ background:var(--coral-d); }
.hero__btn-primary .arrow{ transition:transform .35s var(--ease-heavy); }
.hero__btn-primary:hover .arrow{ transform:translateX(4px) rotate(-45deg); }
.hero__btn-ghost{
  padding:14px 22px; border:1px solid var(--line-2); border-radius:999px;
  font-size:14px; display:inline-flex; align-items:center; gap:10px;
  transition: background .25s;
}
.hero__btn-ghost:hover{ background:var(--line); }

/* STATS — now centered, balanced row */
.hero__stats{
  position:relative; z-index:2;
  display:grid; grid-template-columns: repeat(4, 1fr); gap:24px;
  padding:32px 0 8px; margin-top:48px; border-top:1px solid var(--line);
  text-align:center;
}
.hero__stat{ text-align:center; }
.hero__stat .v{
  font-family:var(--display); font-weight:500; letter-spacing:-0.02em;
  font-size: clamp(28px, 3vw, 44px); color:var(--fg);
  display:inline-flex; align-items:baseline; justify-content:center; gap:2px;
}
.hero__stat .v .accent{ color:var(--coral); }
.hero__stat .v .mintc{ color:var(--mint); }
.hero__stat .l{
  font-family:var(--mono); font-size:10px; text-transform:uppercase;
  color:var(--fg-mute); letter-spacing:0.1em; margin-top:8px;
}
@media (max-width:900px){
  .hero__bottom{ grid-template-columns: 1fr; gap:32px; }
  .hero__stats{ grid-template-columns: repeat(2, 1fr); gap:32px 18px; }
}

.scroll-cue{
  position:absolute; bottom:18px; left:50%; transform:translateX(-50%);
  font-family:var(--mono); font-size:10px; color:var(--fg-mute); letter-spacing:0.12em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px; z-index:2;
}
.scroll-cue .line{
  width:1px; height:36px;
  background:linear-gradient(to bottom, var(--coral), transparent);
  animation: scrollLine 2.2s var(--ease) infinite; transform-origin:top;
}
@keyframes scrollLine{
  0%{ transform:scaleY(0); }
  50%{ transform:scaleY(1); }
  100%{ transform:scaleY(0); transform-origin:bottom; }
}

/* compact hero for subpages */
.hero--sub{ min-height: 62vh; padding-top:160px; padding-bottom:60px; }
.hero--sub .hero__title{ font-size: clamp(48px, 8vw, 130px); margin-top:0; }
.hero--sub .hero__bottom{ grid-template-columns: 1fr 1fr; }
.hero--sub .hero__sub{ font-size:16px; }
.hero__crumbs{
  position:relative; z-index:2; display:flex; gap:10px; align-items:center;
  font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase;
  margin-bottom:32px;
}
.hero__crumbs a{ color:var(--fg-mute); transition: color .25s; }
.hero__crumbs a:hover{ color:var(--coral); }
.hero__crumbs .sep{ opacity:.5; }
.hero__tag{
  display:inline-flex; align-items:center; gap:6px; padding:5px 12px;
  border:1px solid var(--line-2); border-radius:999px;
  font-family:var(--mono); font-size:11px; color:var(--fg-2); letter-spacing:0.08em; text-transform:uppercase;
}
.hero__tag .dot{ width:6px; height:6px; border-radius:50%; background:var(--mint); }

/* ─────────────────────── marquee ─────────────────────── */
.marquee{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  overflow:hidden; padding:32px 0; margin-top:8px;
}
.marquee__track{
  display:flex; gap:0; white-space:nowrap; animation: scroll 38s linear infinite;
  font-family:var(--display); font-weight:500;
  font-size: clamp(28px, 4vw, 56px); letter-spacing:-0.025em; align-items:center;
}
.marquee__track > span{ display:inline-flex; align-items:center; }
.marquee__sep{
  display:inline-flex; align-items:center; justify-content:center;
  margin: 0 56px; color:var(--coral); font-size: .5em; font-family:var(--sans);
}
.marquee__sep::before{ content:"●"; }
@keyframes scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ─────────────────────── manifesto / approach ─────────────────────── */
.manifesto{ padding-top:120px; padding-bottom:140px; }
.manifesto__lead{
  font-family:var(--display); font-weight:400; letter-spacing:-0.025em; line-height:1.05;
  font-size: clamp(34px, 5.2vw, 76px); max-width: 18ch;
}
.manifesto__lead em{ font-family:var(--serif); font-style:italic; color:var(--coral); font-weight:400; }
.manifesto__lead .mint{ color:var(--mint); }
.manifesto__grid{
  display:grid; grid-template-columns: 1.4fr 1fr; gap:64px; margin-top:60px; align-items:start;
}
.manifesto__body{ color:var(--fg-2); font-size: clamp(15px, 1.15vw, 17px); max-width: 56ch; line-height:1.6; }
.manifesto__body p + p{ margin-top:18px; }
.manifesto__pillars{
  display:grid; gap:1px; background:var(--line); border:1px solid var(--line);
  border-radius:14px; overflow:hidden;
}
.manifesto__pillar{
  padding:22px 24px; background:var(--bg);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  transition: background .3s;
}
.manifesto__pillar:hover{ background:var(--bg-2); }
.manifesto__pillar .k{ font-family:var(--mono); font-size:10px; color:var(--coral); letter-spacing:0.08em; text-transform:uppercase; }
.manifesto__pillar .v{ font-family:var(--display); font-size:22px; letter-spacing:-0.02em; }
.manifesto__pillar .v em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
@media (max-width:900px){ .manifesto__grid{ grid-template-columns:1fr; gap:36px; } }

/* ─────────────────────── services rows ─────────────────────── */
.services{ padding-top:40px; padding-bottom:140px; }
.services__header{
  display:grid; grid-template-columns: 1.3fr 1fr; gap:60px; align-items:end;
  padding:28px 0; border-top:1px solid var(--line); margin-bottom:24px;
}
.services__title{
  font-family:var(--display); font-weight:500; letter-spacing:-0.03em; line-height:0.96;
  font-size: clamp(40px, 6.5vw, 100px);
}
.services__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.services__rhs{
  border-left:1px solid var(--line); padding-left:32px;
  display:flex; flex-direction:column; gap:24px;
}
.services__intro{ color:var(--fg-2); font-size:15px; line-height:1.6; max-width:42ch; }
.services__index{
  display:grid; grid-template-columns: repeat(2, 1fr); gap:8px 24px;
  font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase;
}
.services__index a{
  display:flex; justify-content:space-between; padding:6px 0; color:var(--fg-mute);
  border-bottom:1px dashed var(--line); transition: color .25s, border-color .25s;
}
.services__index a:hover{ color:var(--coral); border-color:var(--coral); }
.services__index a span:first-child{ color:var(--fg-2); }

.s-row{
  display:grid; grid-template-columns: 80px 1fr 1.1fr 60px;
  align-items:center; gap:24px; padding:30px 8px; border-top:1px solid var(--line);
  position:relative; transition: background .4s var(--ease);
  text-decoration:none; color:inherit;
}
.s-row:last-child{ border-bottom:1px solid var(--line); }
.s-row::after{
  content:""; position:absolute; left:0; right:0; top:0; bottom:0;
  background: linear-gradient(90deg, rgba(242,101,91,0.08), transparent 60%);
  opacity:0; transition: opacity .5s var(--ease); pointer-events:none;
}
.s-row:hover::after{ opacity:1; }
.s-row__num{ font-family:var(--mono); font-size:12px; color:var(--coral); letter-spacing:0.08em; }
.s-row__name{
  font-family:var(--display); font-weight:500; letter-spacing:-0.025em;
  font-size: clamp(28px, 3.4vw, 50px); line-height:1.02;
  transition: transform .6s var(--ease-heavy);
}
.s-row__name em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.s-row:hover .s-row__name{ transform:translateX(8px); }
.s-row__desc{ color:var(--fg-2); font-size:15px; max-width:46ch; line-height:1.55; }
.s-row__desc b{ color:var(--fg); font-weight:500; }
.s-row__chevron{
  width:48px; height:48px; border-radius:50%; border:1px solid var(--line-2);
  display:grid; place-items:center; justify-self:end;
  transition: background .4s var(--ease), border-color .4s, transform .4s, color .4s;
  color:var(--fg);
}
.s-row:hover .s-row__chevron{ background:var(--coral); border-color:var(--coral); transform:rotate(-45deg); color:#fff; }
.s-row__chevron svg{ width:16px; height:16px; }
@media (max-width:900px){
  .s-row{ grid-template-columns: 50px 1fr 40px; padding:24px 4px; }
  .s-row__desc{ grid-column: 2 / span 2; }
  .services__header{ grid-template-columns:1fr; gap:24px; }
  .services__rhs{ border-left:0; padding-left:0; border-top:1px solid var(--line); padding-top:24px; }
}

/* ─────────────────────── results ─────────────────────── */
.results{ padding-top:80px; padding-bottom:140px; }
.results__inner{
  border:1px solid var(--line); border-radius:24px;
  padding: clamp(28px, 4vw, 60px); position:relative; overflow:hidden;
  background: radial-gradient(circle at 20% 0%, rgba(113,127,198,0.10), transparent 50%),
              radial-gradient(circle at 90% 100%, rgba(242,101,91,0.08), transparent 50%),
              var(--bg-2);
}
.results__label{ font-family:var(--mono); font-size:11px; color:var(--coral); letter-spacing:0.1em; text-transform:uppercase; }
.results__title{
  margin-top:16px;
  font-family:var(--display); font-weight:500; letter-spacing:-0.03em; line-height:0.98;
  font-size: clamp(36px, 5.5vw, 84px); max-width: 18ch;
}
.results__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.results__grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:36px;
  margin-top:60px; padding-top:36px; border-top:1px solid var(--line);
  position:relative;
}
.metric .v{
  font-family:var(--display); font-weight:500; letter-spacing:-0.04em; line-height:0.95;
  font-size: clamp(48px, 7vw, 110px); color:var(--fg);
  display:flex; align-items:baseline;
}
.metric .suffix{ font-size:.55em; color:var(--coral); margin-left:4px; }
.metric .mint{ color:var(--mint); }
.metric .l{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase; margin-top:14px; max-width:18ch; line-height:1.4; }
@media (max-width:900px){ .results__grid{ grid-template-columns:repeat(2,1fr); gap:28px; } }

/* ─────────────────────── work ─────────────────────── */
.work{ padding-top:120px; padding-bottom:140px; }
.work__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:32px; margin-bottom:42px; flex-wrap:wrap; }
.work__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.03em; font-size:clamp(36px,5vw,76px); line-height:0.95; }
.work__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.work__filters{ display:flex; gap:6px; flex-wrap:wrap; }
.work__filter{
  padding:8px 14px; border-radius:999px; border:1px solid var(--line);
  font-size:12px; color:var(--fg-2); transition:.25s; cursor:pointer;
}
.work__filter:hover{ background:var(--line); }
.work__filter.is-active{ background:var(--fg); color:var(--bg); border-color:var(--fg); }

.work__grid{ display:grid; grid-template-columns: 1.15fr 1fr; gap:24px; }
.case{
  position:relative; border-radius:18px; overflow:hidden;
  background:var(--bg-2); border:1px solid var(--line);
  aspect-ratio: 4 / 3.2; min-height:360px;
  display:flex; flex-direction:column; justify-content:space-between;
  padding: clamp(20px, 2.4vw, 32px);
  transition: transform .6s var(--ease-heavy), border-color .4s;
  will-change: transform; color:inherit;
}
.case:hover{ border-color:var(--line-2); }
.case__visual{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.case__visual svg{ width:100%; height:100%; display:block; }
.case__overlay{
  position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, transparent 30%, rgba(14,8,32,0.85) 100%);
}
.case__top, .case__bot{ position:relative; z-index:2; display:flex; justify-content:space-between; align-items:flex-end; gap:16px; }
.case__top{ align-items:flex-start; }
.case__tag{ font-family:var(--mono); font-size:11px; color:var(--fg); letter-spacing:0.08em; text-transform:uppercase; }
.case__tag em{ color:var(--coral); font-style:normal; }
.case__year{ font-family:var(--mono); font-size:11px; color:var(--fg-2); }
.case__name{
  font-family:var(--display); font-weight:500; letter-spacing:-0.025em; line-height:1;
  font-size: clamp(28px, 3.4vw, 48px);
}
.case__name em{ font-family:var(--serif); font-style:italic; color:#FAFBF3; }
.case__sum{ color:var(--fg-2); font-size:14px; max-width:34ch; margin-top:10px; line-height:1.5; }
.case__btn{
  width:44px; height:44px; border-radius:50%; display:grid; place-items:center;
  background:var(--fg); color:var(--bg); transition: transform .4s var(--ease);
  flex-shrink:0;
}
.case:hover .case__btn{ transform:rotate(-45deg) scale(1.06); }
@media (max-width:900px){
  .work__grid{ grid-template-columns:1fr; }
  .work__head{ flex-direction:column; align-items:flex-start; }
}

/* full work grid for /work page */
.work__full{ display:grid; grid-template-columns: repeat(2, 1fr); gap:24px; }
@media (max-width:900px){ .work__full{ grid-template-columns:1fr; } }

/* ─────────────────────── process ─────────────────────── */
.process{ padding-top:80px; padding-bottom:140px; }
.process__head{ display:grid; grid-template-columns: 1fr 1fr; gap:48px; padding-top:28px; border-top:1px solid var(--line); margin-bottom:48px; }
.process__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.03em; line-height:0.96; font-size:clamp(36px, 5vw, 76px); }
.process__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.process__sub{ color:var(--fg-2); max-width:44ch; padding-top:18px; line-height:1.55; font-size:15px; }
.process__line{ position:relative; display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.process__line::before{ content:""; position:absolute; left:0; right:0; top:48px; height:1px; background:var(--line); }
.step{ padding:0 20px; position:relative; }
.step:first-child{ padding-left:0; }
.step:last-child{ padding-right:0; }
.step__dot{
  width:14px; height:14px; border-radius:50%; background:var(--bg); border:1px solid var(--line-2);
  position:absolute; top:42px; left:20px; z-index:2;
}
.step:first-child .step__dot{ left:0; }
.step__dot::after{
  content:""; position:absolute; inset:3px; border-radius:50%; background:var(--coral);
  transform:scale(0); transition:transform .5s var(--ease);
}
.step.is-in .step__dot::after{ transform:scale(1); }
.step__num{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.08em; }
.step__name{ font-family:var(--display); font-weight:500; letter-spacing:-0.02em; font-size:28px; margin-top:80px; }
.step__name em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.step__desc{ color:var(--fg-2); font-size:14px; margin-top:12px; max-width:24ch; line-height:1.55; }
@media (max-width:900px){
  .process__head{ grid-template-columns:1fr; gap:16px; }
  .process__line{ grid-template-columns:1fr 1fr; gap:24px; padding-left:0; }
  .step{ padding:0; }
  .process__line::before{ display:none; }
  .step__dot{ position:relative; top:0; left:0; margin-bottom:18px; }
  .step__name{ margin-top:0; }
}

/* ─────────────────────── industries ─────────────────────── */
.industries{ padding-top:60px; padding-bottom:140px; }
.industries__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:32px; padding-top:28px; border-top:1px solid var(--line); margin-bottom:42px; flex-wrap:wrap; }
.industries__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.03em; font-size:clamp(36px, 5vw, 76px); line-height:0.96; }
.industries__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.industries__sub{ color:var(--fg-2); max-width:38ch; line-height:1.55; font-size:15px; }
.industries__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:18px; overflow:hidden; }
.ind{
  background:var(--bg); padding:30px 28px 28px; position:relative; overflow:hidden;
  transition: background .4s var(--ease); min-height: 240px;
  display:flex; flex-direction:column; justify-content:space-between;
  text-decoration:none; color:inherit;
}
.ind:hover{ background:var(--bg-2); }
.ind__num{ font-family:var(--mono); font-size:11px; color:var(--coral); letter-spacing:0.08em; }
.ind__name{ font-family:var(--display); font-weight:500; letter-spacing:-0.025em; font-size:32px; line-height:1; margin-top:20px; }
.ind__name em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.ind__desc{ color:var(--fg-2); font-size:13px; margin-top:12px; line-height:1.55; max-width:34ch; }
.ind__arrow{ position:absolute; top:24px; right:24px; opacity:0; transform:translate(-6px,6px); transition:.4s var(--ease); color:var(--coral); }
.ind:hover .ind__arrow{ opacity:1; transform:translate(0,0); }
@media (max-width:900px){ .industries__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .industries__grid{ grid-template-columns:1fr; } }

/* ─────────────────────── why makeight ─────────────────────── */
.why{ padding-top:60px; padding-bottom:140px; }
.why__inner{ display:grid; grid-template-columns: 1fr 1.2fr; gap:60px; padding-top:28px; border-top:1px solid var(--line); }
.why__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.03em; line-height:0.96; font-size:clamp(36px, 5vw, 80px); position:sticky; top:120px; align-self:start; }
.why__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.why__title .mint{ color:var(--mint); }
.why__row{ padding:30px 0; border-top:1px solid var(--line); display:grid; grid-template-columns: 60px 1fr; gap:24px; }
.why__row:last-child{ border-bottom:1px solid var(--line); }
.why__row .k{ font-family:var(--mono); font-size:11px; color:var(--coral); letter-spacing:0.08em; padding-top:6px; }
.why__row h3{ font-family:var(--display); font-weight:500; letter-spacing:-0.02em; font-size: clamp(22px, 2vw, 30px); line-height:1.1; }
.why__row h3 em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.why__row p{ color:var(--fg-2); margin-top:10px; line-height:1.6; max-width:52ch; font-size:15px; }
@media (max-width:900px){ .why__inner{ grid-template-columns:1fr; gap:24px; } .why__title{ position:static; } }

/* ─────────────────────── testimonial ─────────────────────── */
.testi{ padding-top:60px; padding-bottom:140px; }
.testi__wrap{
  border:1px solid var(--line); border-radius:24px;
  padding: clamp(40px, 6vw, 96px) clamp(28px, 5vw, 80px);
  background: radial-gradient(circle at 80% 10%, rgba(113,127,198,0.12), transparent 50%),
              radial-gradient(circle at 10% 90%, rgba(55,204,164,0.07), transparent 50%),
              var(--bg-2);
  position:relative; overflow:hidden;
}
.testi__quote{
  font-family:var(--display); font-weight:400; letter-spacing:-0.025em; line-height:1.1;
  font-size: clamp(26px, 3.5vw, 52px); max-width: 22ch;
}
.testi__quote em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.testi__quote .mark{ color:var(--coral); }
.testi__meta{ display:flex; align-items:center; gap:18px; margin-top:48px; padding-top:24px; border-top:1px solid var(--line); flex-wrap:wrap; }
.testi__avatar{
  width:48px; height:48px; border-radius:50%;
  background:linear-gradient(135deg, var(--coral), var(--peri));
  display:grid; place-items:center; font-family:var(--display); font-weight:600; color:#fff;
}
.testi__name{ font-family:var(--display); font-weight:500; font-size:17px; letter-spacing:-0.015em; }
.testi__role{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase; margin-top:2px; }
.testi__link{ margin-left:auto; font-family:var(--mono); font-size:11px; color:var(--coral); letter-spacing:.08em; text-transform:uppercase; transition: color .25s; }
.testi__link:hover{ color:var(--fg); }

/* ─────────────────────── insights ─────────────────────── */
.insights{ padding-top:60px; padding-bottom:140px; }
.insights__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:32px; padding-top:28px; border-top:1px solid var(--line); margin-bottom:36px; flex-wrap:wrap; }
.insights__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.03em; font-size:clamp(34px,4.8vw,70px); line-height:0.96; }
.insights__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.insights__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.post{ display:flex; flex-direction:column; gap:18px; padding-top:20px; border-top:1px solid var(--line); cursor:pointer; text-decoration:none; color:inherit; }
.post__cover{
  aspect-ratio: 4/3; border-radius:14px; overflow:hidden; border:1px solid var(--line); position:relative;
  transition: transform .5s var(--ease-heavy);
}
.post:hover .post__cover{ transform: translateY(-4px); }
.post__cover svg{ width:100%; height:100%; display:block; }
.post__meta{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase; display:flex; gap:14px; }
.post__meta .cat{ color:var(--coral); }
.post__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.02em; font-size: 22px; line-height:1.2; }
.post__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.post:hover .post__title{ color:var(--coral); }
.post__sum{ color:var(--fg-2); font-size:14px; line-height:1.55; margin-top:-4px; }
@media (max-width:900px){ .insights__grid{ grid-template-columns:1fr; } }

/* ─────────────────────── founder ─────────────────────── */
.founder{ padding-top:60px; padding-bottom:160px; }
.founder__inner{ display:grid; grid-template-columns: 1fr 1fr; gap:60px; padding-top:28px; border-top:1px solid var(--line); align-items:center; }
.founder__visual{ aspect-ratio: 4/5; border-radius:20px; overflow:hidden; position:relative; background:linear-gradient(160deg, var(--bg-3), var(--bg-2)); border:1px solid var(--line); }
.founder__visual svg{ width:100%; height:100%; }
.founder__label{ font-family:var(--mono); font-size:11px; color:var(--coral); letter-spacing:0.08em; text-transform:uppercase; }
.founder__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.03em; line-height:0.98; font-size:clamp(34px,4.8vw,72px); margin-top:18px; }
.founder__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.founder__body{ color:var(--fg-2); font-size:16px; margin-top:24px; line-height:1.65; max-width:46ch; }
.founder__body p + p{ margin-top:14px; }
.founder__body em{ font-family:var(--serif); font-style:italic; color:var(--fg); }
.founder__sig{ margin-top:32px; padding-top:24px; border-top:1px solid var(--line); display:flex; align-items:center; gap:14px; }
.founder__sig-name{ font-family:var(--serif); font-style:italic; font-size:32px; color:var(--coral); letter-spacing:-0.01em; }
.founder__sig-role{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase; }
@media (max-width:900px){ .founder__inner{ grid-template-columns:1fr; gap:32px; } }

/* ─────────────────────── final cta ─────────────────────── */
.final{ padding-top:60px; padding-bottom:60px; }
.final__inner{
  border:1px solid var(--line); border-radius:28px; overflow:hidden;
  padding: clamp(48px, 8vw, 140px) clamp(28px, 5vw, 80px); position:relative;
  background: radial-gradient(circle at 20% 30%, rgba(242,101,91,0.16), transparent 50%),
              radial-gradient(circle at 80% 70%, rgba(113,127,198,0.10), transparent 50%),
              radial-gradient(circle at 50% 110%, rgba(55,204,164,0.08), transparent 40%),
              var(--bg-2);
}
.final__label{ font-family:var(--mono); font-size:11px; color:var(--coral); letter-spacing:0.1em; text-transform:uppercase; }
.final__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.04em; line-height:0.92; font-size: clamp(48px, 9vw, 156px); margin-top:24px; max-width: 14ch; }
.final__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.final__cta{ margin-top:48px; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.final__cta .btn{ padding:16px 24px; font-size:14px; }
.final__cta .availability{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase; display:inline-flex; align-items:center; gap:8px; margin-left:8px; }
.final__cta .availability .dot{ width:6px; height:6px; border-radius:50%; background:var(--mint); box-shadow:0 0 8px var(--mint); }

/* ─────────────────────── footer ─────────────────────── */
.footer{ border-top:1px solid var(--line); padding: 80px var(--pad) 32px; background: var(--bg); position:relative; }
.footer__top{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap:48px; }
.footer__brand img{ height:32px; width:auto; }
.footer__brand p{ color:var(--fg-2); font-size:14px; margin-top:18px; max-width:32ch; line-height:1.6; }
.footer__news{ margin-top:24px; }
.footer__news label{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase; }
.footer__news .field{ display:flex; align-items:center; margin-top:10px; border:1px solid var(--line-2); border-radius:999px; padding:6px 6px 6px 18px; transition: border-color .25s; }
.footer__news .field:focus-within{ border-color:var(--coral); }
.footer__news input{ background:none; border:0; outline:none; color:var(--fg); flex:1; font:inherit; font-size:14px; font-family:var(--sans); }
.footer__news input::placeholder{ color:var(--fg-faint); }
.footer__news button{ width:36px; height:36px; border-radius:50%; background:var(--coral); color:#fff; display:grid; place-items:center; transition: background .25s; }
.footer__news button:hover{ background:var(--coral-d); }
.footer__col h5{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase; }
.footer__col ul{ list-style:none; margin-top:16px; display:flex; flex-direction:column; gap:10px; }
.footer__col a{ color:var(--fg-2); font-size:14px; transition:color .2s; }
.footer__col a:hover{ color:var(--coral); }
.footer__bottom{ margin-top:64px; padding-top:24px; border-top:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase; }
.footer__socials{ display:flex; gap:8px; }
.footer__socials a{ width:36px; height:36px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--fg-2); transition: .25s var(--ease); }
.footer__socials a:hover{ color:var(--coral); border-color:var(--coral); background:var(--line); transform: translateY(-2px); }
.footer__tag{
  font-family:var(--display); font-weight:500; letter-spacing:-0.04em; line-height:0.9;
  font-size: clamp(64px, 16vw, 240px); white-space:nowrap; overflow:hidden;
  margin: 60px calc(var(--pad) * -1) 32px; padding: 0 var(--pad);
  color: transparent; -webkit-text-stroke: 1px var(--line-2); user-select:none;
}
.footer__tag em{ font-family:var(--serif); font-style:italic; color:transparent; -webkit-text-stroke:1px var(--coral); }
@media (max-width:900px){ .footer__top{ grid-template-columns: 1fr 1fr; gap:32px; } }

/* ─────────────────────── reveal animation ─────────────────────── */
.reveal{ opacity:0; transform: translateY(28px); transition: opacity .9s var(--ease), transform .9s var(--ease); will-change:transform,opacity; }
.reveal.is-in{ opacity:1; transform: translateY(0); }
.reveal-d-1{ transition-delay:.06s; }
.reveal-d-2{ transition-delay:.12s; }
.reveal-d-3{ transition-delay:.18s; }
.reveal-d-4{ transition-delay:.24s; }
.reveal-d-5{ transition-delay:.30s; }

/* ═══════════════════════════════════════════════════════════
   SUBPAGE-specific components
   ═══════════════════════════════════════════════════════════ */

/* split sections with sticky title */
.split{ display:grid; grid-template-columns: 1fr 1.4fr; gap:60px; padding:80px 0; border-top:1px solid var(--line); }
.split__label{ font-family:var(--mono); font-size:11px; color:var(--coral); letter-spacing:0.08em; text-transform:uppercase; }
.split__title{ font-family:var(--display); font-weight:500; letter-spacing:-0.03em; line-height:0.98; font-size:clamp(32px,4vw,56px); margin-top:14px; position:sticky; top:120px; }
.split__title em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.split__body{ color:var(--fg-2); font-size:16px; line-height:1.7; max-width: 62ch; }
.split__body p + p{ margin-top:18px; }
.split__body strong{ color:var(--fg); font-weight:500; }
.split__body em{ font-family:var(--serif); font-style:italic; color:var(--coral); font-size:1.05em; }
.split__body ul{ list-style:none; padding:0; margin:24px 0; display:grid; gap:12px; }
.split__body ul li{ padding-left:28px; position:relative; color:var(--fg); font-size:15px; line-height:1.55; }
.split__body ul li::before{ content:""; position:absolute; left:0; top:.7em; width:16px; height:1px; background:var(--coral); }
@media (max-width:900px){ .split{ grid-template-columns:1fr; gap:24px; padding:48px 0; } .split__title{ position:static; } }

/* deliverables grid */
.deliv{ display:grid; grid-template-columns: repeat(2, 1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.deliv__item{ background:var(--bg); padding:24px; display:flex; gap:14px; align-items:flex-start; }
.deliv__item .icn{ width:32px; height:32px; border-radius:8px; background:rgba(242,101,91,0.12); color:var(--coral); display:grid; place-items:center; flex-shrink:0; }
.deliv__item h4{ font-family:var(--display); font-weight:500; font-size:16px; letter-spacing:-0.01em; }
.deliv__item p{ color:var(--fg-2); font-size:13px; line-height:1.55; margin-top:4px; }
@media (max-width:700px){ .deliv{ grid-template-columns:1fr; } }

/* FAQ */
.faq{ display:grid; gap:0; }
.faq__item{ border-top:1px solid var(--line); padding:24px 0; cursor:pointer; }
.faq__item:last-child{ border-bottom:1px solid var(--line); }
.faq__q{ display:flex; align-items:center; justify-content:space-between; gap:24px; font-family:var(--display); font-weight:500; font-size:clamp(18px, 1.6vw, 22px); letter-spacing:-0.015em; }
.faq__q em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.faq__plus{ width:32px; height:32px; flex-shrink:0; position:relative; }
.faq__plus::before,.faq__plus::after{
  content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  background:var(--fg); transition:transform .35s var(--ease-heavy), background .25s;
}
.faq__plus::before{ width:16px; height:1px; }
.faq__plus::after{ width:1px; height:16px; }
.faq__item.is-open .faq__plus::after{ transform: translate(-50%,-50%) scaleY(0); }
.faq__item.is-open .faq__plus::before{ background:var(--coral); }
.faq__a{
  max-height:0; overflow:hidden; transition: max-height .5s var(--ease-heavy), margin-top .35s;
  color:var(--fg-2); font-size:15px; line-height:1.65;
}
.faq__item.is-open .faq__a{ max-height:300px; margin-top:14px; }
.faq__a p{ max-width:60ch; }

/* case study — challenge / approach / result blocks */
.cs-meta{ display:grid; grid-template-columns: repeat(4, 1fr); gap:24px; padding:32px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:60px; }
.cs-meta__k{ font-family:var(--mono); font-size:10px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase; }
.cs-meta__v{ font-family:var(--display); font-weight:500; font-size:18px; margin-top:8px; letter-spacing:-0.01em; }
.cs-meta__v em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
@media (max-width:700px){ .cs-meta{ grid-template-columns: 1fr 1fr; gap:18px; } }

.cs-hero-visual{ width:100%; aspect-ratio: 21/10; border-radius:18px; overflow:hidden; border:1px solid var(--line); margin-bottom:60px; }
.cs-hero-visual svg{ width:100%; height:100%; display:block; }

.cs-results{ display:grid; grid-template-columns: repeat(4,1fr); gap:24px; padding:48px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin: 60px 0; }
.cs-result .v{ font-family:var(--display); font-weight:500; font-size: clamp(40px, 5.5vw, 88px); letter-spacing:-0.03em; line-height:0.95; color:var(--fg); }
.cs-result .v .suf{ font-size:.5em; color:var(--coral); margin-left:2px; }
.cs-result .v .mint{ color:var(--mint); }
.cs-result .l{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.06em; text-transform:uppercase; margin-top:12px; max-width:18ch; line-height:1.4; }
@media (max-width:900px){ .cs-results{ grid-template-columns:repeat(2,1fr); gap:20px; } }

.cs-next{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding:48px 0; border-top:1px solid var(--line); }
.cs-next__label{ font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase; }
.cs-next__name{ font-family:var(--display); font-weight:500; font-size:clamp(28px,3.5vw,48px); letter-spacing:-0.025em; margin-top:8px; }
.cs-next__name em{ font-family:var(--serif); font-style:italic; color:var(--coral); }

/* article body for blog posts */
.article{
  max-width: 720px; margin: 0 auto; padding: 60px 0 100px;
  color: var(--fg-2); font-size: 17px; line-height: 1.75;
}
.article h2{ font-family:var(--display); font-weight:500; color:var(--fg); font-size: clamp(26px,3vw,38px); letter-spacing:-0.02em; line-height:1.15; margin:48px 0 16px; }
.article h2 em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.article h3{ font-family:var(--display); font-weight:500; color:var(--fg); font-size:22px; letter-spacing:-0.015em; margin:32px 0 12px; }
.article p{ margin-bottom: 20px; }
.article p strong{ color:var(--fg); font-weight:500; }
.article p em{ font-family:var(--serif); font-style:italic; color:var(--fg); font-size:1.05em; }
.article ul, .article ol{ margin: 16px 0 24px 24px; }
.article ul li, .article ol li{ margin-bottom: 8px; }
.article blockquote{
  border-left:2px solid var(--coral); padding:6px 24px; margin: 32px 0;
  font-family:var(--serif); font-style:italic; font-size: 22px; color:var(--fg); line-height:1.4;
}
.article hr{ border:0; height:1px; background:var(--line); margin: 48px 0; }
.article a{ color:var(--coral); text-decoration:underline; text-underline-offset:3px; }

/* contact form */
.contact-form{ display:grid; gap:18px; max-width: 680px; }
.contact-form .row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.contact-form label{ display:block; font-family:var(--mono); font-size:11px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase; margin-bottom:8px; }
.contact-form input, .contact-form textarea, .contact-form select{
  width:100%; padding:14px 16px; background:var(--bg-2); border:1px solid var(--line);
  border-radius:12px; color:var(--fg); font:inherit; font-size:15px; font-family:var(--sans);
  transition: border-color .25s, background .25s;
}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus{ outline:none; border-color:var(--coral); background:var(--bg-3); }
.contact-form textarea{ min-height: 140px; resize:vertical; }
@media (max-width:600px){ .contact-form .row{ grid-template-columns:1fr; } }

/* contact info grid */
.cinfo{ display:grid; grid-template-columns: repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; margin-bottom:48px; }
.cinfo__cell{ background:var(--bg); padding:22px 24px; }
.cinfo__k{ font-family:var(--mono); font-size:10px; color:var(--fg-mute); letter-spacing:0.08em; text-transform:uppercase; }
.cinfo__v{ font-family:var(--display); font-weight:500; font-size:18px; margin-top:8px; letter-spacing:-0.01em; }
.cinfo__v a{ color:var(--fg); transition: color .25s; }
.cinfo__v a:hover{ color:var(--coral); }
@media (max-width:700px){ .cinfo{ grid-template-columns:1fr; } }

/* ─────────────────────── WhatsApp chat widget ─────────────────────── */
.chat{ position:fixed; right:22px; bottom:22px; z-index:500; font-family:var(--sans); display:flex; flex-direction:column; align-items:flex-end; gap:14px; }
.chat__card{
  width: 320px; padding:18px; border-radius:18px;
  background: rgba(14,8,32,0.92); border:1px solid var(--line-2);
  backdrop-filter: blur(18px) saturate(160%); -webkit-backdrop-filter: blur(18px) saturate(160%);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6);
  transform: translateY(20px) scale(.96); opacity:0; pointer-events:none;
  transition: transform .5s var(--ease-heavy), opacity .35s var(--ease);
}
.chat__card.is-open{ transform:translateY(0) scale(1); opacity:1; pointer-events:auto; }
.chat__head{ display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.chat__avatar{
  width:38px; height:38px; border-radius:50%; flex:0 0 38px;
  background:linear-gradient(135deg, var(--coral), var(--coral-d));
  display:grid; place-items:center; color:#fff;
  font-family:var(--display); font-weight:600; font-size:15px; position:relative;
}
.chat__avatar::after{
  content:""; position:absolute; right:-2px; bottom:-2px; width:12px; height:12px; border-radius:50%;
  background:#25D366; border:2px solid #0E0820;
}
.chat__name{ font-family:var(--display); font-weight:500; font-size:14px; letter-spacing:-0.01em; }
.chat__status{ font-family:var(--mono); font-size:10px; color:var(--fg-mute); letter-spacing:.06em; text-transform:uppercase; margin-top:1px; display:flex; align-items:center; gap:6px; }
.chat__status::before{ content:""; width:6px; height:6px; border-radius:50%; background:#25D366; box-shadow:0 0 6px #25D366; }
.chat__close{ margin-left:auto; width:24px; height:24px; border-radius:50%; display:grid; place-items:center; color:var(--fg-mute); transition:.2s; cursor:pointer; }
.chat__close:hover{ color:var(--fg); background:var(--line); }
.chat__bubble{ background:var(--bg-3); padding:12px 14px; border-radius:14px 14px 14px 4px; color:var(--fg); font-size:13px; line-height:1.55; border:1px solid var(--line); }
.chat__bubble em{ font-family:var(--serif); font-style:italic; color:var(--coral); }
.chat__bubble + .chat__bubble{ margin-top:6px; }
.chat__cta{ margin-top:14px; display:flex; align-items:center; justify-content:center; gap:10px; background:#25D366; color:#0a0a0c; padding:12px 16px; border-radius:12px; font-weight:600; font-size:13px; transition: transform .3s var(--ease), background .3s; }
.chat__cta:hover{ background:#1ebe57; transform:translateY(-1px); }
.chat__cta svg{ width:16px; height:16px; }
.chat__foot{ font-family:var(--mono); font-size:9.5px; color:var(--fg-faint); letter-spacing:.08em; text-transform:uppercase; margin-top:10px; text-align:center; }
.chat__btn{
  width:56px; height:56px; border-radius:50%; background:#25D366; color:#0a0a0c;
  display:grid; place-items:center; cursor:pointer; position:relative;
  box-shadow: 0 12px 30px -8px rgba(37,211,102,0.5), 0 0 0 4px rgba(37,211,102,0.08);
  transition: transform .35s var(--ease-heavy);
}
.chat__btn:hover{ transform: translateY(-2px) scale(1.04); }
.chat__btn::before{ content:""; position:absolute; inset:-6px; border-radius:50%; border:1px solid rgba(37,211,102,.4); animation: chatpulse 2.2s ease-out infinite; }
@keyframes chatpulse{ 0%{ transform:scale(.85); opacity:.9; } 100%{ transform:scale(1.4); opacity:0; } }
.chat__btn svg{ width:26px; height:26px; }
@media (max-width:560px){ .chat__card{ width: calc(100vw - 44px); } }
