/* ================================================================
   MOA DVM — Global Stylesheet
   Tokens · Reset · Typography · Layout · Components · Pages
   ================================================================ */

/* ---- TOKENS ---- */
:root {
  --void:       #0A0A0A;
  --ember:      #F4541D;
  --bone:       #F5F1EA;
  --ash:        #8C8C8C;
  --deep:       #B23A12;
  --ember-mid:  #D4410F;
  --surface:    rgba(255,255,255,0.03);
  --border:     rgba(255,255,255,0.07);

  --ff-display: 'Clash Display','Archivo Black',sans-serif;
  --ff-body:    'Satoshi','Inter','Helvetica Neue',sans-serif;
  --ff-mono:    'JetBrains Mono','Fira Code',monospace;

  --fs-hero:  clamp(3.25rem, 9vw, 7.5rem);
  --fs-h1:    clamp(2.5rem,  6vw, 5.5rem);
  --fs-h2:    clamp(1.875rem,4vw, 3.25rem);
  --fs-h3:    clamp(1.125rem,2vw, 1.625rem);
  --fs-body:  clamp(0.9375rem,1.2vw,1.0625rem);
  --fs-mono:  0.6875rem;

  --sp-1: 0.25rem;  --sp-2: 0.5rem;   --sp-3: 0.75rem;
  --sp-4: 1rem;     --sp-5: 1.25rem;  --sp-6: 1.5rem;
  --sp-8: 2rem;     --sp-10: 2.5rem;  --sp-12: 3rem;
  --sp-16: 4rem;    --sp-20: 5rem;    --sp-24: 6rem;
  --sp-32: 8rem;    --sp-40: 10rem;

  --max-w: 1180px;
  --gutter: clamp(1.25rem, 5vw, 2.5rem);

  --ease-expo:   cubic-bezier(0.16, 1, 0.3, 1);
  --ease-circ:   cubic-bezier(0.0, 0.0, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  --r-sm: 4px; --r-md: 10px; --r-lg: 16px;
  --r-xl: 24px; --r-pill: 9999px;
}

/* ---- RESET ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { background: var(--void); color: var(--bone); font-family: var(--ff-body); font-size: var(--fs-body); line-height: 1.65; overflow-x: hidden; }
img, video, svg { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul { list-style: none; }
:focus-visible { outline: 2px solid var(--ember); outline-offset: 4px; border-radius: var(--r-sm); }

/* ---- PAGE LOAD ---- */
.page-fade { animation: pageFade 0.5s var(--ease-expo) both; }
@keyframes pageFade { from { opacity: 0; } to { opacity: 1; } }
.page-fade-out { animation: pageFadeOut 0.28s var(--ease-circ) both !important; }
@keyframes pageFadeOut { from { opacity: 1; } to { opacity: 0; } }

/* ---- LAYOUT ---- */
.container { width: 100%; max-width: var(--max-w); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--sp-24); }
@media (max-width: 768px) { .section { padding-block: var(--sp-16); } }

/* ---- SCROLL PROGRESS ---- */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 2px;
  background: var(--ember); z-index: 200;
  transform-origin: left; transform: scaleX(0);
  will-change: transform; pointer-events: none;
}

/* ================================================================
   NAVIGATION
   ================================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: var(--sp-4) var(--gutter);
  display: flex; align-items: center; justify-content: space-between;
  transition: background 0.45s var(--ease-circ), backdrop-filter 0.45s var(--ease-circ);
}
.nav.scrolled {
  background: rgba(10,10,10,0.88);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(244,84,29,0.12);
}

.nav-logo {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-2) 0;
}
.nav-logo-img { width: 34px; height: 34px; object-fit: contain; }
.nav-logo-text {
  font-family: var(--ff-display); font-size: 1rem; font-weight: 700;
  letter-spacing: 0.06em; color: var(--bone);
}

.nav-list {
  display: none; gap: var(--sp-8); align-items: center;
}
@media (min-width: 768px) { .nav-list { display: flex; } }

.nav-list a {
  font-family: var(--ff-mono); font-size: var(--fs-mono);
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--ash); position: relative; padding: var(--sp-1) 0;
  transition: color 0.2s;
}
.nav-list a::after {
  content: ''; position: absolute; bottom: -2px; left: 0;
  width: 0; height: 1px; background: var(--ember);
  transition: width 0.35s var(--ease-expo);
}
.nav-list a:hover, .nav-list a.active { color: var(--bone); }
.nav-list a:hover::after, .nav-list a.active::after { width: 100%; }

/* Hamburger */
.nav-burger {
  display: flex; flex-direction: column; gap: 5px;
  padding: var(--sp-2); background: none; border: none;
}
@media (min-width: 768px) { .nav-burger { display: none; } }
.nav-burger span {
  display: block; width: 22px; height: 2px; background: var(--bone);
  border-radius: 2px; transition: transform 0.35s var(--ease-expo), opacity 0.3s;
}
.nav-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile drawer */
.nav-drawer {
  position: fixed; inset: 0; z-index: 99;
  background: var(--void); display: flex;
  flex-direction: column; align-items: center; justify-content: center;
  gap: var(--sp-8); pointer-events: none; opacity: 0;
  transition: opacity 0.3s var(--ease-circ);
}
.nav-drawer.open { opacity: 1; pointer-events: auto; }
.nav-drawer a {
  font-family: var(--ff-display); font-size: 2.75rem;
  font-weight: 700; color: var(--bone); transition: color 0.2s;
}
.nav-drawer a:hover { color: var(--ember); }

/* ================================================================
   BUTTONS
   ================================================================ */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: 0.875rem 2rem; border-radius: var(--r-pill);
  font-family: var(--ff-mono); font-size: var(--fs-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  transition: transform 0.25s var(--ease-expo), box-shadow 0.25s, background 0.2s, border-color 0.2s;
  will-change: transform;
}
.btn:active { transform: scale(0.97) !important; }

.btn-primary { background: var(--ember); color: var(--bone); }
.btn-primary:hover { background: var(--ember-mid); transform: translateY(-3px) scale(1.03); box-shadow: 0 12px 40px rgba(244,84,29,0.45); }

.btn-ghost { background: transparent; color: var(--bone); border: 1px solid rgba(245,241,234,0.22); }
.btn-ghost:hover { border-color: var(--ember); color: var(--ember); transform: translateY(-3px) scale(1.03); background: rgba(244,84,29,0.06); }

/* ================================================================
   HERO
   ================================================================ */
.hero {
  position: relative; min-height: 100svh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center; overflow: hidden;
  padding: var(--sp-32) var(--gutter) var(--sp-20);
}

#particles-canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none; z-index: 0;
}

.hero-content { position: relative; z-index: 1; max-width: 860px; }

/* Phoenix */
.phoenix-wrap {
  width: min(260px, 52vw); height: min(260px, 52vw);
  margin-inline: auto; margin-bottom: var(--sp-8);
}
.phoenix-img {
  width: 100%; height: 100%;
  object-fit: contain; display: block;
  will-change: transform, opacity, filter;
}

.hero-eyebrow {
  font-family: var(--ff-mono); font-size: var(--fs-mono);
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ember); margin-bottom: var(--sp-4);
  opacity: 0;
}
.hero-title {
  font-family: var(--ff-display); font-size: var(--fs-hero);
  font-weight: 700; letter-spacing: -0.03em; line-height: 1;
  color: var(--bone); margin-bottom: var(--sp-3); opacity: 0;
}
.hero-title .em { color: var(--ember); }
.hero-tagline {
  font-family: var(--ff-display); font-size: clamp(1.2rem, 2.5vw, 1.875rem);
  font-weight: 600; color: var(--ash); margin-bottom: var(--sp-5); opacity: 0;
}
.hero-desc {
  font-size: clamp(0.9375rem, 1.2vw, 1rem); color: var(--ash);
  max-width: 480px; margin-inline: auto; margin-bottom: var(--sp-8); opacity: 0;
  line-height: 1.7;
}
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--sp-4); justify-content: center; opacity: 0; }

.scroll-hint {
  position: absolute; bottom: var(--sp-8); left: 50%;
  transform: translateX(-50%); display: flex; flex-direction: column;
  align-items: center; gap: var(--sp-2); opacity: 0;
}
.scroll-hint-line { width: 1px; height: 36px; background: linear-gradient(to bottom, var(--ember), transparent); animation: scrollPulse 2s ease-in-out infinite; }
.scroll-hint-text { font-family: var(--ff-mono); font-size: 0.625rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ash); }
@keyframes scrollPulse { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(6px); } }

/* ================================================================
   MANIFESTO
   ================================================================ */
.manifesto { padding-block: var(--sp-20); text-align: center; overflow: hidden; }
.manifesto-text {
  font-family: var(--ff-display);
  font-size: clamp(1.5rem, 3.8vw, 3.125rem);
  font-weight: 700; line-height: 1.2; letter-spacing: -0.02em;
  max-width: 860px; margin-inline: auto; color: var(--bone);
}
.manifesto-text .em { color: var(--ember); font-style: normal; }

/* ================================================================
   SECTION LABELS
   ================================================================ */
.label {
  display: block; font-family: var(--ff-mono); font-size: var(--fs-mono);
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ember); margin-bottom: var(--sp-4);
}
.section-title {
  font-family: var(--ff-display); font-size: var(--fs-h2);
  font-weight: 700; letter-spacing: -0.02em; line-height: 1.1;
  color: var(--bone); margin-bottom: var(--sp-12);
}
.divider { width: 52px; height: 2px; background: var(--ember); margin-block: var(--sp-6); }

/* Arrow link */
.link-arrow {
  font-family: var(--ff-mono); font-size: var(--fs-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ember); display: inline-flex; align-items: center;
  gap: var(--sp-2); transition: gap 0.25s var(--ease-expo);
}
.link-arrow:hover { gap: var(--sp-4); }

/* ================================================================
   SERVICES PREVIEW (Home)
   ================================================================ */
.services-preview { border-top: 1px solid var(--border); }
.services-grid {
  display: grid; gap: var(--sp-4);
  grid-template-columns: 1fr;
  margin-bottom: var(--sp-8);
}
@media (min-width: 600px)  { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .services-grid { grid-template-columns: repeat(5, 1fr); } }

.service-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--sp-6);
  opacity: 0; transform: translateY(32px);
  transition: border-color 0.3s, background 0.3s, transform 0.3s var(--ease-expo), opacity 0.3s;
  will-change: transform, opacity;
}
.service-card:hover { border-color: rgba(244,84,29,0.35); background: rgba(244,84,29,0.05); transform: translateY(-4px) !important; box-shadow: 0 16px 48px rgba(0,0,0,0.5), 0 0 0 1px rgba(244,84,29,0.1); }

.service-icon { width: 36px; height: 36px; margin-bottom: var(--sp-4); color: var(--ember); }
.service-icon svg { width: 100%; height: 100%; }
.service-name { font-family: var(--ff-display); font-size: 0.9375rem; font-weight: 700; color: var(--bone); margin-bottom: var(--sp-2); }
.service-desc { font-size: 0.8125rem; color: var(--ash); line-height: 1.55; }

.services-cta { display: flex; justify-content: flex-end; margin-top: var(--sp-4); }

/* ================================================================
   WORK CARDS
   ================================================================ */
.work-grid {
  display: grid; gap: var(--sp-6);
  grid-template-columns: 1fr;
  margin-bottom: var(--sp-8);
}
@media (min-width: 640px)  { .work-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .work-grid { grid-template-columns: repeat(3, 1fr); } }

.work-card {
  position: relative; border-radius: var(--r-lg); overflow: hidden;
  aspect-ratio: 9/14; cursor: pointer;
  opacity: 0; transform: translateY(48px);
  transition: transform 0.4s var(--ease-expo), box-shadow 0.4s, opacity 0.4s;
  will-change: transform, opacity;
  background: #111;
}
.work-card:hover { transform: scale(1.025) !important; box-shadow: 0 24px 60px rgba(0,0,0,0.6), 0 0 0 1px rgba(244,84,29,0.15) !important; }

.work-card-bg {
  position: absolute; inset: 0;
  background: linear-gradient(150deg, var(--deep) 0%, #1a0a05 50%, var(--void) 100%);
  animation: bgShift 8s ease-in-out infinite;
}
@keyframes bgShift { 0%,100%{ opacity:1; } 50%{ opacity:0.65; } }

.work-card-noise {
  position: absolute; inset: 0; opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: cover;
}

.work-card-inner {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: var(--sp-6);
}
.work-card-play {
  width: 52px; height: 52px; border-radius: 50%;
  border: 1px solid rgba(245,241,234,0.18);
  display: flex; align-items: center; justify-content: center;
  margin: auto; opacity: 0.35;
  transition: opacity 0.3s, border-color 0.3s;
}
.work-card:hover .work-card-play { opacity: 0.7; border-color: rgba(244,84,29,0.5); }
.work-card-play svg { width: 18px; height: 18px; fill: var(--bone); margin-left: 3px; }

.work-card-meta { margin-top: auto; }
.work-card-cat {
  font-family: var(--ff-mono); font-size: 0.625rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ember); display: block; margin-bottom: var(--sp-2);
}
.work-card-title {
  font-family: var(--ff-display); font-size: 0.9375rem;
  font-weight: 700; color: var(--bone); line-height: 1.3; margin-bottom: var(--sp-2);
}
.work-card-tag {
  font-family: var(--ff-mono); font-size: 0.5625rem;
  letter-spacing: 0.15em; text-transform: uppercase; color: var(--ash);
}

/* ================================================================
   PROOF STRIP
   ================================================================ */
.proof-strip {
  padding-block: var(--sp-10);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.proof-inner { display: flex; flex-wrap: wrap; gap: var(--sp-8); align-items: center; justify-content: center; }
.proof-item { display: flex; align-items: center; gap: var(--sp-3); }
.proof-num { font-family: var(--ff-mono); font-size: 0.9rem; font-weight: 700; color: var(--ember); }
.proof-text { font-family: var(--ff-mono); font-size: 0.625rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ash); }
.proof-sep { color: rgba(255,255,255,0.12); font-size: 1rem; }

/* ================================================================
   ABOUT TEASER (Home)
   ================================================================ */
.about-teaser { border-top: 1px solid var(--border); }
.about-teaser-grid {
  display: grid; gap: var(--sp-12); align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .about-teaser-grid { grid-template-columns: 1fr 1fr; } }

.about-teaser-p { font-size: clamp(1rem, 1.3vw, 1.125rem); color: var(--ash); line-height: 1.75; }
.about-teaser-p + .about-teaser-p { margin-top: var(--sp-4); }

.about-visual {
  height: 280px; border-radius: var(--r-xl);
  background: linear-gradient(135deg, rgba(178,58,18,0.18), transparent);
  border: 1px solid rgba(244,84,29,0.14);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.about-visual-num {
  font-family: var(--ff-display); font-size: 9rem; font-weight: 700;
  color: rgba(244,84,29,0.07); line-height: 1; letter-spacing: -0.05em; user-select: none;
}

/* ================================================================
   CLOSING CTA
   ================================================================ */
.cta-block { text-align: center; border-top: 1px solid var(--border); }
.cta-title {
  font-family: var(--ff-display);
  font-size: clamp(2.75rem, 7vw, 6rem);
  font-weight: 700; letter-spacing: -0.035em; line-height: 1;
  color: var(--bone); margin-bottom: var(--sp-8);
}
.cta-title .em { color: var(--ember); }
.cta-sub { font-size: var(--fs-body); color: var(--ash); margin-bottom: var(--sp-8); }

/* ================================================================
   FOOTER
   ================================================================ */
.footer {
  padding: var(--sp-8) var(--gutter);
  border-top: 1px solid var(--border);
  display: flex; flex-wrap: wrap; gap: var(--sp-4);
  align-items: center; justify-content: space-between;
}
.footer-brand { font-family: var(--ff-display); font-size: 0.8125rem; font-weight: 600; color: var(--ash); }
.footer-nav { display: flex; gap: var(--sp-6); align-items: center; }
.footer-nav a { font-family: var(--ff-mono); font-size: 0.625rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ash); transition: color 0.2s; }
.footer-nav a:hover { color: var(--ember); }

/* ================================================================
   PAGE HEADERS (inner pages)
   ================================================================ */
.page-hero {
  padding-top: calc(80px + var(--sp-16));
  padding-bottom: var(--sp-12); text-align: center;
}
.page-hero .page-title {
  font-family: var(--ff-display); font-size: var(--fs-h1);
  font-weight: 700; letter-spacing: -0.03em; line-height: 1.05;
  color: var(--bone); margin-bottom: var(--sp-5);
}
.page-hero .page-sub {
  font-size: clamp(1rem, 1.4vw, 1.125rem); color: var(--ash);
  max-width: 520px; margin-inline: auto; line-height: 1.7;
}

/* ================================================================
   SERVICES PAGE
   ================================================================ */
.services-list { padding-bottom: var(--sp-24); }
.svc-item {
  padding-block: var(--sp-12);
  border-top: 1px solid var(--border);
  display: grid; gap: var(--sp-8);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .svc-item { grid-template-columns: 200px 1fr; align-items: start; } }

.svc-left { }
.svc-num {
  font-family: var(--ff-display); font-size: 5rem; font-weight: 700;
  color: rgba(244,84,29,0.08); line-height: 1; letter-spacing: -0.05em;
  margin-bottom: var(--sp-2);
}
.svc-label { font-family: var(--ff-mono); font-size: var(--fs-mono); letter-spacing: 0.2em; text-transform: uppercase; color: var(--ember); }

.svc-body { }
.svc-title {
  font-family: var(--ff-display); font-size: var(--fs-h3);
  font-weight: 700; color: var(--bone); margin-bottom: var(--sp-4); line-height: 1.2;
}
.svc-desc { font-size: var(--fs-body); color: var(--ash); line-height: 1.75; max-width: 540px; margin-bottom: var(--sp-5); }
.svc-tags { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.svc-tag {
  font-family: var(--ff-mono); font-size: 0.5625rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--bone); background: rgba(244,84,29,0.1); border: 1px solid rgba(244,84,29,0.22);
  padding: 3px 10px; border-radius: var(--r-pill);
}

/* ================================================================
   WORK PAGE
   ================================================================ */
.work-grid-full {
  display: grid; gap: var(--sp-6);
  grid-template-columns: 1fr;
  padding-bottom: var(--sp-24);
}
@media (min-width: 640px)  { .work-grid-full { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .work-grid-full { grid-template-columns: repeat(3, 1fr); } }

/* ================================================================
   ABOUT PAGE
   ================================================================ */
.about-body { padding-bottom: var(--sp-24); }
.about-prose { max-width: 680px; margin-inline: auto; }
.about-prose h2 {
  font-family: var(--ff-display); font-size: var(--fs-h2);
  font-weight: 700; color: var(--bone); letter-spacing: -0.02em; margin-bottom: var(--sp-6); line-height: 1.1;
}
.about-prose p { font-size: clamp(1rem, 1.3vw, 1.125rem); color: var(--ash); line-height: 1.8; margin-bottom: var(--sp-6); }
.about-prose p strong { color: var(--bone); font-weight: 600; }
.about-prose .em { color: var(--ember); }

.about-values { padding-top: var(--sp-16); border-top: 1px solid var(--border); margin-top: var(--sp-16); }
.values-grid { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; margin-top: var(--sp-8); }
@media (min-width: 600px) { .values-grid { grid-template-columns: repeat(3, 1fr); } }

.value-card {
  padding: var(--sp-6); border: 1px solid var(--border);
  border-radius: var(--r-lg); background: var(--surface);
  transition: border-color 0.3s, transform 0.3s var(--ease-expo);
  will-change: transform;
}
.value-card:hover { border-color: rgba(244,84,29,0.3) !important; transform: translateY(-3px) !important; }
.value-idx { font-family: var(--ff-mono); font-size: var(--fs-mono); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ember); display: block; margin-bottom: var(--sp-3); }
.value-name { font-family: var(--ff-display); font-size: 1.0625rem; font-weight: 700; color: var(--bone); margin-bottom: var(--sp-2); }
.value-desc { font-size: 0.8125rem; color: var(--ash); line-height: 1.6; }

/* ================================================================
   CONTACT PAGE
   ================================================================ */
.contact-hero {
  min-height: 100svh; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding-top: calc(80px + var(--sp-8)); padding-bottom: var(--sp-16);
  text-align: center;
}
.contact-sub { font-size: clamp(1rem, 1.4vw, 1.125rem); color: var(--ash); max-width: 440px; margin-inline: auto; margin-bottom: var(--sp-12); line-height: 1.7; }
.contact-options { display: flex; flex-direction: column; gap: var(--sp-4); width: 100%; max-width: 380px; margin-inline: auto; }

.contact-opt {
  display: flex; align-items: center; gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-6); border-radius: var(--r-lg);
  font-family: var(--ff-mono); font-size: var(--fs-mono);
  letter-spacing: 0.12em; text-transform: uppercase; width: 100%;
  transition: transform 0.3s var(--ease-expo), box-shadow 0.3s;
  will-change: transform;
}
.contact-opt:hover { transform: translateY(-3px); }
.contact-opt svg { width: 20px; height: 20px; flex-shrink: 0; }
.contact-opt.wa { background: #25D366; color: #fff; }
.contact-opt.wa:hover { box-shadow: 0 10px 36px rgba(37,211,102,0.35); }
.contact-opt.em { background: var(--surface); border: 1px solid var(--border); color: var(--bone); }
.contact-opt.em:hover { border-color: var(--ember); box-shadow: 0 10px 36px rgba(244,84,29,0.15); }

/* ================================================================
   TERMS PAGE
   ================================================================ */
.terms-body { padding-bottom: var(--sp-32); }
.terms-prose { max-width: 700px; margin-inline: auto; }
.terms-prose h2 {
  font-family: var(--ff-display); font-size: 1.625rem; font-weight: 700;
  color: var(--bone); margin-top: var(--sp-12); margin-bottom: var(--sp-4);
}
.terms-prose h2:first-child { margin-top: 0; }
.terms-prose p { font-size: var(--fs-body); color: var(--ash); line-height: 1.8; margin-bottom: var(--sp-4); }
.terms-prose ul { margin-bottom: var(--sp-4); padding-left: var(--sp-4); }
.terms-prose li { font-size: var(--fs-body); color: var(--ash); line-height: 1.8; padding-left: var(--sp-4); position: relative; margin-bottom: var(--sp-2); }
.terms-prose li::before { content: '→'; position: absolute; left: 0; color: var(--ember); }
.terms-date { font-family: var(--ff-mono); font-size: var(--fs-mono); letter-spacing: 0.15em; text-transform: uppercase; color: var(--ash); margin-bottom: var(--sp-12); display: block; }

/* ================================================================
   LINK-IN-BIO (flames, emmas)
   ================================================================ */
.lbio-page {
  min-height: 100svh; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: var(--sp-8) var(--gutter); text-align: center;
}
.lbio-logo { width: 84px; height: 84px; border-radius: 50%; overflow: hidden; margin-inline: auto; margin-bottom: var(--sp-5); background: linear-gradient(135deg, var(--deep), var(--ember)); display: flex; align-items: center; justify-content: center; }
.lbio-logo img { width: 100%; height: 100%; object-fit: cover; }
.lbio-name { font-family: var(--ff-display); font-size: 1.875rem; font-weight: 700; color: var(--bone); margin-bottom: var(--sp-2); }
.lbio-handle { font-family: var(--ff-mono); font-size: var(--fs-mono); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ash); margin-bottom: var(--sp-8); }
.lbio-links { display: flex; flex-direction: column; gap: var(--sp-3); width: 100%; max-width: 360px; margin-inline: auto; }
.lbio-link {
  display: block; padding: var(--sp-4) var(--sp-6); border-radius: var(--r-lg);
  font-family: var(--ff-mono); font-size: var(--fs-mono); letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--surface); border: 1px solid var(--border); color: var(--bone);
  transition: transform 0.25s var(--ease-expo), border-color 0.2s, background 0.2s;
  will-change: transform;
}
.lbio-link:hover { transform: translateY(-2px); border-color: var(--ember); background: rgba(244,84,29,0.08); }
.lbio-link.primary { background: var(--ember); border-color: var(--ember); color: var(--bone); }
.lbio-link.primary:hover { background: var(--ember-mid); }
.lbio-footer { margin-top: var(--sp-8); font-family: var(--ff-mono); font-size: var(--fs-mono); letter-spacing: 0.1em; text-transform: uppercase; color: rgba(140,140,140,0.5); }
.lbio-footer a { color: var(--ember); opacity: 0.7; transition: opacity 0.2s; }
.lbio-footer a:hover { opacity: 1; }

/* ================================================================
   REVEAL (IntersectionObserver / GSAP)
   ================================================================ */
.reveal { opacity: 0; transform: translateY(36px); will-change: opacity, transform; }
.reveal.in { opacity: 1; transform: translateY(0); transition: opacity 0.85s var(--ease-expo), transform 0.85s var(--ease-expo); }

/* ================================================================
   GRAIN TEXTURE
   ================================================================ */
body::before {
  content: ''; position: fixed; inset: 0; z-index: 1000;
  pointer-events: none; user-select: none; opacity: 0.038;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

/* ================================================================
   CUSTOM CURSOR (desktop / pointer: fine only)
   ================================================================ */
@media (pointer: fine) {
  * { cursor: none !important; }

  .cursor-dot {
    position: fixed; z-index: 9500; pointer-events: none;
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--ember); transform: translate(-50%, -50%);
    transition: width 0.25s var(--ease-expo), height 0.25s var(--ease-expo), background 0.2s, opacity 0.2s;
    will-change: left, top;
  }
  .cursor-ring {
    position: fixed; z-index: 9499; pointer-events: none;
    width: 34px; height: 34px; border-radius: 50%;
    border: 1px solid rgba(244,84,29,0.45); transform: translate(-50%, -50%);
    transition: width 0.4s var(--ease-expo), height 0.4s var(--ease-expo), border-color 0.25s, opacity 0.2s;
    will-change: left, top;
  }

  .cursor-dot.hovered  { width: 44px; height: 44px; background: rgba(244,84,29,0.12); }
  .cursor-ring.hovered { width: 48px; height: 48px; border-color: rgba(244,84,29,0.7); }
  .cursor-dot.clicking { width: 6px !important; height: 6px !important; }
}

/* ================================================================
   MAGNETIC BUTTONS — CSS variable offset applied via JS
   ================================================================ */
.btn {
  --mag-x: 0px; --mag-y: 0px;
}
.btn-primary:hover {
  transform: translate(var(--mag-x), calc(var(--mag-y) - 3px)) scale(1.03);
}
.btn-ghost:hover {
  transform: translate(var(--mag-x), calc(var(--mag-y) - 3px)) scale(1.03);
}

/* ================================================================
   DRAWER POLISH
   ================================================================ */
.nav-drawer {
  background: linear-gradient(145deg, rgba(6,2,1,0.97) 0%, rgba(20,7,2,0.98) 50%, rgba(6,2,1,0.97) 100%);
  backdrop-filter: blur(32px); -webkit-backdrop-filter: blur(32px);
  gap: var(--sp-5); justify-content: center;
}

/* Links — invisible by default, stagger in when drawer opens */
.nav-drawer > a {
  position: relative;
  opacity: 0; transform: translateY(18px);
  transition: opacity 0.45s var(--ease-expo), transform 0.45s var(--ease-expo), color 0.2s;
}
.nav-drawer.open > a:nth-child(1) { opacity: 1; transform: none; transition-delay: 0.04s; }
.nav-drawer.open > a:nth-child(2) { opacity: 1; transform: none; transition-delay: 0.09s; }
.nav-drawer.open > a:nth-child(3) { opacity: 1; transform: none; transition-delay: 0.14s; }
.nav-drawer.open > a:nth-child(4) { opacity: 1; transform: none; transition-delay: 0.19s; }
.nav-drawer.open > a:nth-child(5) { opacity: 1; transform: none; transition-delay: 0.24s; }
.nav-drawer:not(.open) > a { transition-delay: 0s; }

/* Active page dot */
.nav-drawer > a.active::before {
  content: ''; position: absolute; left: -1.2rem; top: 50%;
  transform: translateY(-50%);
  width: 5px; height: 5px; border-radius: 50%; background: var(--ember);
}

/* Tap scale feedback */
.nav-drawer > a:active { transform: scale(0.93) !important; color: var(--ember); }

/* Drawer footer CTA (injected by JS) */
.drawer-footer {
  position: absolute; bottom: var(--sp-10); left: 0; right: 0;
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-3);
  opacity: 0; transform: translateY(10px);
  transition: opacity 0.5s var(--ease-expo), transform 0.5s var(--ease-expo);
  transition-delay: 0s; pointer-events: none;
}
.nav-drawer.open .drawer-footer { opacity: 1; transform: none; transition-delay: 0.32s; pointer-events: auto; }

.drawer-cta {
  font-family: var(--ff-mono); font-size: var(--fs-mono);
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ember) !important;
  border: 1px solid rgba(244,84,29,0.35); padding: 0.6rem 1.75rem;
  border-radius: var(--r-pill);
  transition: background 0.2s, border-color 0.2s !important;
  opacity: 1 !important; transform: none !important;
}
.drawer-cta:hover { background: rgba(244,84,29,0.1); border-color: var(--ember); }

.drawer-tagline {
  font-family: var(--ff-mono); font-size: 0.5625rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(140,140,140,0.4);
}

/* ================================================================
   DEPTH SHADOWS — multi-layer (Apple/Linear style)
   ================================================================ */
.btn-primary:hover {
  box-shadow:
    0 1px 3px rgba(244,84,29,0.25),
    0 6px 18px rgba(244,84,29,0.32),
    0 18px 44px rgba(244,84,29,0.16) !important;
}
.service-card:hover {
  box-shadow:
    0 1px 3px rgba(0,0,0,0.4),
    0 6px 20px rgba(0,0,0,0.32),
    0 20px 54px rgba(0,0,0,0.22),
    0 0 0 1px rgba(244,84,29,0.12) !important;
}
.value-card:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.3), 0 12px 32px rgba(0,0,0,0.22);
}
.work-card:hover {
  box-shadow:
    0 6px 14px rgba(0,0,0,0.45),
    0 24px 60px rgba(0,0,0,0.5),
    0 0 0 1px rgba(244,84,29,0.15) !important;
}

/* ================================================================
   SECTION GRADIENT DIVIDERS
   ================================================================ */
.services-preview,
.featured-work,
.about-teaser,
.cta-block {
  border-top: 1px solid;
  border-image: linear-gradient(90deg, transparent 0%, rgba(244,84,29,0.38) 35%, rgba(244,84,29,0.15) 65%, transparent 100%) 1;
}
.proof-strip {
  border-image: linear-gradient(90deg, transparent 0%, rgba(244,84,29,0.25) 35%, rgba(244,84,29,0.1) 65%, transparent 100%) 1;
}

/* ================================================================
   GRADIENT-TINTED CARD BORDERS
   ================================================================ */
.service-card { border-color: rgba(244,84,29,0.09); }
.value-card   { border-color: rgba(244,84,29,0.09); }

/* ================================================================
   REDUCED MOTION
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
  .reveal, .reveal.in { opacity: 1 !important; transform: none !important; transition: none !important; }
  .hero-eyebrow, .hero-title, .hero-tagline, .hero-desc, .hero-cta { opacity: 1 !important; transform: none !important; }
  .scroll-hint { opacity: 1 !important; /* keep translateX(-50%) for positioning */ }
  .service-card { opacity: 1 !important; transform: none !important; }
  .work-card { opacity: 1 !important; transform: none !important; }
  #particles-canvas { display: none !important; }
  .phoenix-img { opacity: 1 !important; transform: none !important; filter: none !important; }
  body::before { display: none !important; }
  .cursor-dot, .cursor-ring { display: none !important; }
  * { cursor: auto !important; }
}
