/* ============================================================
   MAGIC HOUR STUDIO — EVENTS · editorial magazine
   ============================================================ */

:root {
  --paper: #F6F1E7;        /* magazine paper */
  --paper-2: #EFE9DA;
  --paper-tint: #FBF8F0;
  --ink: #14110D;
  --ink-2: #3A332A;
  --ink-mute: #8C8473;
  --line: rgba(20, 17, 13, 0.16);
  --line-strong: rgba(20, 17, 13, 0.42);
  --rule-soft: rgba(20, 17, 13, 0.10);

  /* logo palette — used very sparingly */
  --c-red:    #B83232;
  --c-orange: #DC5E26;
  --c-amber:  #D89236;
  --c-mint:   #94C7A4;
  --c-brown:  #3F2715;

  --f-disp: "Bodoni Moda", "Didot", "Noto Serif TC", serif;
  --f-italic: "Cormorant Garamond", "EB Garamond", serif;
  --f-han: "Noto Serif TC", "Source Han Serif TC", serif;
  --f-body: "Manrope", "DM Sans", "Noto Sans TC", sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, monospace;

  --pad: clamp(20px, 3.2vw, 56px);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--paper); color: var(--ink); }
body {
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }

::selection { background: var(--ink); color: var(--paper); }

.mono { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.smallcaps { font-family: var(--f-disp); font-feature-settings: "smcp", "c2sc"; letter-spacing: 0.18em; text-transform: uppercase; }

/* paper grain */
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 1; mix-blend-mode: multiply;
  opacity: 0.5;
  background-image:
    radial-gradient(rgba(20, 17, 13, 0.04) 1px, transparent 1px),
    radial-gradient(rgba(20, 17, 13, 0.03) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
}

/* ============================================================
   MAST / NAV
   ============================================================ */
.mast {
  position: sticky; top: 0; z-index: 50;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  padding: 12px var(--pad);
  background: rgba(246, 241, 231, 0.9);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-2);
}
.mast a:hover { color: var(--c-red); }
.mast__nav { display: flex; gap: 22px; justify-self: center; }
.mast__date { justify-self: end; opacity: 0.75; }
.mast__brand { display: flex; align-items: center; gap: 10px; }
.mast__brand img { height: 22px; width: auto; }

@media (max-width: 760px) {
  .mast { grid-template-columns: 1fr 1fr; }
  .mast__nav { display: none; }
  .mast__date { font-size: 10px; }
}

/* ============================================================
   COVER / HERO
   ============================================================ */
.cover {
  position: relative;
  padding: 28px var(--pad) 80px;
  min-height: calc(100vh - 50px);
  display: flex; flex-direction: column;
}
.cover__topbar {
  display: flex; justify-content: space-between; align-items: center;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 12px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
}
.cover__topbar .l { display: flex; gap: 22px; }
.cover__topbar .barcode {
  display: inline-block;
  width: 78px; height: 18px;
  background: repeating-linear-gradient(90deg, var(--ink) 0 1px, transparent 1px 3px, var(--ink) 3px 4px, transparent 4px 6px, var(--ink) 6px 8px, transparent 8px 9px);
}

.cover__masthead {
  position: relative;
  margin-top: 28px;
  display: grid;
  grid-template-columns: 1fr;
}
.cover__issue {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
  display: flex; gap: 22px; align-items: center;
  margin-bottom: 8px;
}
.cover__issue span:first-child { color: var(--ink); }

.cover__title {
  position: relative;
  font-family: var(--f-disp);
  font-weight: 400;
  font-size: clamp(96px, 22vw, 360px);
  line-height: 0.82;
  letter-spacing: -0.04em;
  color: var(--ink);
  z-index: 4;
}
.cover__title .em {
  font-family: var(--f-italic);
  font-style: italic;
  font-weight: 500;
  letter-spacing: -0.02em;
  display: inline-block;
  transform: translateY(-0.04em);
}
.cover__title .amp {
  font-family: var(--f-italic);
  font-style: italic;
  color: var(--c-red);
}

.cover__subtitle {
  margin-top: 24px;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 48px;
  align-items: end;
  border-top: 1px solid var(--line);
  padding-top: 18px;
  position: relative; z-index: 4;
}
.cover__lede {
  font-family: var(--f-italic);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(20px, 2.4vw, 32px);
  line-height: 1.3;
  max-width: 760px;
  color: var(--ink);
}
.cover__lede::first-letter {
  font-family: var(--f-disp);
  font-style: normal;
  font-size: 1.6em;
  font-weight: 700;
  float: left;
  line-height: 0.9;
  margin: 0.05em 0.08em 0 0;
  color: var(--c-red);
}
.cover__byline {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-2);
  display: flex; flex-direction: column; gap: 6px;
}
.cover__byline strong { color: var(--ink); font-weight: 500; }

/* ----- interactive photo stack ----- */
.cover__stack {
  position: absolute;
  right: var(--pad);
  top: 200px;
  width: clamp(260px, 30vw, 420px);
  height: clamp(340px, 40vw, 560px);
  z-index: 3;
  pointer-events: none;
}
.cover-card {
  position: absolute;
  inset: 0;
  background: var(--paper-tint);
  border: 1px solid var(--ink);
  box-shadow: 0 24px 48px -28px rgba(20,17,13,0.5);
  cursor: grab;
  pointer-events: auto;
  transition: transform 0.5s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
  display: flex; flex-direction: column;
  user-select: none;
}
.cover-card:active { cursor: grabbing; }
.cover-card__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 16px;
  border-bottom: 1px solid var(--ink);
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
}
.cover-card__head .num { color: var(--c-red); }
.cover-card__photo {
  flex: 1;
  position: relative;
  overflow: hidden;
}
.cover-card__photo image-slot {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  background-image: repeating-linear-gradient(
    -45deg,
    rgba(20, 17, 13, 0.04) 0 16px,
    rgba(20, 17, 13, 0.07) 16px 32px
  );
}
.cover-card__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.cover-card__caption {
  position: absolute; left: 14px; right: 14px; bottom: 14px;
  font-family: var(--f-italic); font-style: italic; font-weight: 500;
  font-size: 20px; line-height: 1.1; color: var(--paper);
  pointer-events: none; z-index: 2;
  text-shadow: 0 1px 4px rgba(20,17,13,0.5);
}
.cover-card__hint {
  position: absolute; top: 12px; right: 12px;
  background: var(--ink); color: var(--paper);
  font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 4px 8px; border-radius: 999px;
  pointer-events: none; opacity: 0; transition: opacity .25s;
  z-index: 3;
}
.cover-card[data-front="1"] .cover-card__hint { opacity: 1; }
.cover-card__foot {
  padding: 12px 16px;
  border-top: 1px solid var(--ink);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute);
}

/* color washes per card */
.cover-card.c1 .cover-card__photo { background-color: rgba(184, 50, 50, 0.10); }
.cover-card.c2 .cover-card__photo { background-color: rgba(216, 146, 54, 0.16); }
.cover-card.c3 .cover-card__photo { background-color: rgba(148, 199, 164, 0.28); }
.cover-card.c4 .cover-card__photo { background-color: rgba(63, 39, 21, 0.10); }

/* cover lines (magazine sticker text) */
.cover__lines {
  position: absolute;
  pointer-events: none;
  z-index: 5;
  font-family: var(--f-italic);
  font-style: italic;
  font-weight: 500;
}
.cline {
  position: absolute;
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--paper);
  padding: 4px 10px;
  border: 1px solid var(--ink);
  font-family: var(--f-mono); font-style: normal; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink);
  box-shadow: 2px 2px 0 var(--ink);
}
.cline.red    { background: var(--c-red);    color: var(--paper); border-color: var(--c-red); }
.cline.amber  { background: var(--c-amber);  color: var(--ink); border-color: var(--c-amber); }
.cline.mint   { background: var(--c-mint);   color: var(--ink); border-color: var(--c-mint); }
.cline.ink    { background: var(--ink);      color: var(--paper); border-color: var(--ink); }

.cline.l1 { top: 250px; left: var(--pad); transform: rotate(-4deg); }
.cline.l2 { top: 312px; left: calc(var(--pad) + 24px); transform: rotate(2deg); }
.cline.l3 { top: 380px; left: var(--pad); transform: rotate(-1deg); }

@media (max-width: 1100px) {
  .cover__stack { display: none; }
  .cover__subtitle { grid-template-columns: 1fr; gap: 24px; }
  .cline { display: none; }
}

/* ============================================================
   SECTION SHELL (editorial)
   ============================================================ */
section { padding: 110px var(--pad); position: relative; z-index: 2; }
.eyebrow {
  display: flex; justify-content: space-between; align-items: end;
  border-top: 1px solid var(--ink);
  padding-top: 14px;
  margin-bottom: 36px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
}
.eyebrow .l { display: flex; gap: 18px; align-items: baseline; }
.eyebrow .num { color: var(--c-red); }
.eyebrow .title { color: var(--ink); }

.editorial-h2 {
  font-family: var(--f-disp); font-weight: 400;
  font-size: clamp(48px, 7.2vw, 120px);
  line-height: 0.92; letter-spacing: -0.03em;
  margin-bottom: 48px;
  max-width: 1100px;
}
.editorial-h2 em {
  font-family: var(--f-italic); font-weight: 500; font-style: italic;
}
.editorial-h2 .red { color: var(--c-red); }

/* ============================================================
   SERVICES — editorial table of contents
   ============================================================ */
.services {}
.svc-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--ink);
}
.svc-card {
  background: var(--paper);
  padding: 24px 22px 22px;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 280px;
  cursor: default;
  transition: background .3s, transform .3s;
  position: relative;
}
.svc-card:hover { background: var(--paper-tint); }
.svc-card__head {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}
.svc-card__num { color: var(--c-red); }
.svc-card__pg  { color: var(--ink-mute); }
.svc-card__name {
  font-family: var(--f-disp); font-weight: 400;
  font-size: clamp(28px, 2.6vw, 38px);
  line-height: 1; letter-spacing: -0.02em;
  margin-top: 4px;
}
.svc-card__name em {
  font-family: var(--f-italic); font-style: italic; font-weight: 500;
  margin-right: 8px;
  color: var(--ink-2);
}
.svc-card:nth-child(2n) .svc-card__name em { color: var(--c-red); }
.svc-card__desc {
  font-family: var(--f-italic); font-style: italic; font-weight: 500;
  font-size: 15px; line-height: 1.5;
  color: var(--ink-2);
  flex: 1;
}
.svc-card__foot {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute);
  padding-top: 10px;
  border-top: 1px dotted var(--line-strong);
}
.svc-card__foot span:last-child {
  font-family: var(--f-disp); font-size: 16px; letter-spacing: 0;
  color: var(--ink); transition: transform .3s, color .3s;
}
.svc-card:hover .svc-card__foot span:last-child {
  transform: translateX(6px); color: var(--c-red);
}

@media (max-width: 1100px) { .svc-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .svc-cards { grid-template-columns: 1fr; } }

/* ============================================================
   SHOWREEL
   ============================================================ */
.showreel { padding: 100px var(--pad); }
.reel-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
/* top row: 4 portrait tiles */
.reel-tile--portrait .reel-tile__vimeo { aspect-ratio: 4 / 5; }
/* bottom row: 2 landscape tiles spanning 2 cols each */
.reel-tile--landscape { grid-column: span 2; }
.reel-tile--landscape .reel-tile__vimeo { aspect-ratio: 16 / 10; }
.reel-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
  cursor: pointer;
  transition: transform .35s ease;
}
.reel-tile:hover { transform: translateY(-6px); }

/* The clickable image box */
.reel-tile__vimeo {
  position: relative;
  display: block;
  background: var(--ink);
  border: 1px solid var(--ink);
  overflow: hidden;
  cursor: pointer;
}
.reel-tile image-slot {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  background-image: repeating-linear-gradient(
    -45deg,
    rgba(246, 241, 231, 0.05) 0 16px,
    rgba(246, 241, 231, 0.10) 16px 32px
  );
  background-color: rgba(20,17,13,0.85);
}
.reel-tile__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.reel-tile__vimeo .reel-tile__play {
  position: absolute; inset: 0; margin: auto;
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--paper); color: var(--ink);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  transition: transform .3s, background .3s;
}
.reel-tile:hover .reel-tile__play { transform: scale(1.12); background: var(--c-amber); }
.reel-tile__play::before {
  content: ""; width: 0; height: 0;
  border-left: 14px solid currentColor;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  margin-left: 4px;
}
.reel-tile__meta {
  display: flex; justify-content: space-between;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink); opacity: 0.55;
  margin-top: 10px;
  pointer-events: none;
}
.reel-tile__cap {
  color: var(--ink);
  font-family: var(--f-disp); font-weight: 400;
  font-size: 20px; letter-spacing: -0.01em; line-height: 1.2;
  margin-top: 4px;
  pointer-events: none;
  display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
}
.reel-tile__cap em { font-family: var(--f-italic); font-style: italic; font-weight: 500; opacity: 0.9; }
.reel-tile__cap span {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  opacity: 0.5;
}

@media (max-width: 900px) {
  .reel-grid { grid-template-columns: repeat(2, 1fr); }
  .reel-tile--landscape { grid-column: span 1; }
}
@media (max-width: 540px) {
  .reel-grid { grid-template-columns: 1fr; }
  .reel-tile--landscape { grid-column: span 1; }
}

/* 3-col 16:9 row */
.reel-grid--wide { grid-template-columns: repeat(3, 1fr); }
.reel-tile--wide .reel-tile__vimeo { aspect-ratio: 16 / 9; }
@media (max-width: 900px) { .reel-grid--wide { grid-template-columns: 1fr; } }

/* recent events strip beneath showreel */
.reel-credits {
  margin-top: 24px;
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 24px;
  border-top: 1px solid var(--line);
  padding-top: 18px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute);
}
.reel-credits dt { color: var(--ink); margin-bottom: 4px; }
@media (max-width: 760px) { .reel-credits { grid-template-columns: 1fr 1fr; } }

/* ============================================================
   CLIENTS
   ============================================================ */
.clients { background: var(--paper-2); }
.cl-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border-top: 1px solid var(--ink);
}
.cl-grid > div {
  aspect-ratio: 5/3;
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 16px;
  font-family: var(--f-disp);
  font-size: 22px;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  transition: color .25s, background .25s;
  position: relative;
}
.cl-grid > div::before {
  content: attr(data-tag);
  position: absolute; top: 8px; left: 10px;
  font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.18em; color: var(--ink-mute);
  text-transform: uppercase;
}
.cl-grid > div:hover { color: var(--ink); background: var(--paper-tint); }
.cl-grid > div:nth-child(6n) { border-right: 0; }

@media (max-width: 900px) {
  .cl-grid { grid-template-columns: repeat(3, 1fr); }
  .cl-grid > div:nth-child(6n) { border-right: 1px solid var(--line); }
  .cl-grid > div:nth-child(3n) { border-right: 0; }
}
@media (max-width: 480px) {
  .cl-grid { grid-template-columns: repeat(2, 1fr); }
  .cl-grid > div { border-right: 1px solid var(--line); }
  .cl-grid > div:nth-child(2n) { border-right: 0; }
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list { border-top: 1px solid var(--ink); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q {
  display: grid; grid-template-columns: 80px 1fr 60px;
  align-items: baseline; gap: 24px;
  padding: 24px 0;
  cursor: pointer;
  width: 100%; text-align: left;
}
.faq-q__num { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--ink-mute); }
.faq-q__text {
  font-family: var(--f-disp); font-weight: 400;
  font-size: clamp(20px, 2.4vw, 32px); line-height: 1.2;
  letter-spacing: -0.01em;
  transition: color .25s;
}
.faq-q__text em { font-family: var(--f-italic); font-style: italic; font-weight: 500; }
.faq-item.open .faq-q__text { color: var(--c-red); }
.faq-q__icon {
  align-self: center; justify-self: end;
  font-family: var(--f-disp); font-size: 28px; line-height: 1;
  width: 28px; text-align: center;
  transition: transform .3s, color .25s;
}
.faq-item.open .faq-q__icon { transform: rotate(45deg); color: var(--c-red); }

.faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s ease; }
.faq-a > div { overflow: hidden; }
.faq-a__inner {
  display: grid; grid-template-columns: 80px 1fr 60px; gap: 24px;
  padding: 0 0 28px;
}
.faq-a__inner > p {
  grid-column: 2;
  max-width: 720px;
  color: var(--ink-2);
  font-family: var(--f-italic); font-style: italic;
  font-size: 18px; line-height: 1.6;
}
.faq-item.open .faq-a { grid-template-rows: 1fr; }

@media (max-width: 760px) {
  .faq-q, .faq-a__inner { grid-template-columns: 32px 1fr 32px; gap: 12px; }
}

/* ============================================================
   CONTACT — letter / cover-back
   ============================================================ */
.contact {
  padding: 130px var(--pad);
  background: var(--paper);
}
.contact__inner {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  border-top: 1px solid var(--ink);
  padding-top: 36px;
}
.contact__lead {
  font-family: var(--f-disp); font-weight: 400;
  font-size: clamp(40px, 5.6vw, 88px); line-height: 0.95; letter-spacing: -0.03em;
}
.contact__lead em { font-family: var(--f-italic); font-style: italic; font-weight: 500; color: var(--c-red); }
.contact__byline {
  margin-top: 40px;
  font-family: var(--f-italic); font-style: italic;
  font-size: 22px; line-height: 1.5; color: var(--ink-2);
  max-width: 480px;
}

.contact__meta {
  margin-top: 40px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 28px;
}
.contact__meta dt { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; }
.contact__meta dd { font-family: var(--f-disp); font-size: 22px; }
.contact__meta a:hover { color: var(--c-red); }

.form { display: flex; flex-direction: column; }
.form__row {
  display: grid; grid-template-columns: 140px 1fr;
  gap: 24px; align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.form__row label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.form__row input, .form__row select, .form__row textarea {
  background: transparent; border: 0; color: var(--ink);
  font-family: var(--f-disp); font-size: 22px;
  outline: none; padding: 4px 0; width: 100%;
}
.form__row input::placeholder, .form__row textarea::placeholder { color: var(--ink-mute); font-style: italic; font-family: var(--f-italic); }
.form__row textarea { resize: vertical; min-height: 60px; font-family: var(--f-italic); font-style: italic; font-size: 19px; line-height: 1.5; }
.form__row select { appearance: none; cursor: pointer; }

.form__submit {
  margin-top: 32px;
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 12px;
  padding: 18px 32px; border-radius: 999px;
  background: #25D366; color: #0d2a17;
  font-family: var(--f-disp); font-size: 22px; letter-spacing: 0.02em; font-weight: 500;
  transition: transform .25s, background .25s;
}
.form__submit:hover { transform: translateX(8px); background: #2ee876; }
.form__submit svg { width: 22px; height: 22px; }

@media (max-width: 900px) {
  .contact__inner { grid-template-columns: 1fr; gap: 48px; }
  .form__row { grid-template-columns: 1fr; gap: 4px; padding: 12px 0; }
}

/* ============================================================
   COLOPHON / FOOTER
   ============================================================ */
.colophon {
  padding: 60px var(--pad) 40px;
  border-top: 1px solid var(--ink);
}
.colophon__big {
  font-family: var(--f-disp); font-weight: 400;
  font-size: clamp(64px, 13vw, 200px);
  line-height: 0.9; letter-spacing: -0.04em;
}
.colophon__big em { font-family: var(--f-italic); font-style: italic; font-weight: 500; color: var(--c-red); }
.colophon__bot {
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--ink-mute); text-transform: uppercase;
}
.colophon__bot .links { display: flex; gap: 22px; }
.colophon__bot a:hover { color: var(--c-red); }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-fab {
  position: fixed; right: 22px; bottom: 22px; z-index: 100;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 18px 14px 14px; border-radius: 999px;
  background: #25D366; color: #0d2a17;
  box-shadow: 0 12px 30px -10px rgba(37, 211, 102, 0.6), 0 4px 14px rgba(0,0,0,0.18);
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  font-weight: 600;
  transition: transform .25s, box-shadow .25s;
}
.wa-fab:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -10px rgba(37, 211, 102, 0.7), 0 6px 18px rgba(0,0,0,0.22); }
.wa-fab svg { width: 22px; height: 22px; }
@media (max-width: 540px) {
  .wa-fab__label { display: none; }
  .wa-fab { padding: 14px; }
}
