@media (min-width:641px) and (max-width:1024px) {
  .port-card.apparel-tablet {
    grid-column: span 2;
  }
}
/* ══════════════════════════════════════════
   PALETTE — LOUD SARAULT
   ══════════════════════════════════════════ */
:root {
  --black:    #05050A;
  --black2:   #0A0A12;
  --navy:     #293880;
  --blue:     #3D5598;
  --magenta:  #CC2278;
  --teal:     #1B9DC0;
  --sky:      #52B8D4;
  --gray:     #8A8E8F;
  --charcoal: #333234;
  --white:    #F0ECF6;
  --off:      #C8C4D0;

  --h1: 'Bebas Neue', sans-serif;
  --mono: 'DM Mono', monospace;
  --body: 'DM Sans', sans-serif;

  --svc-bg-branding: url('../images/branding_bg-768.jpg');
  --svc-bg-motion: url('../images/motion_design_bg-768.jpg');
  --svc-bg-video: url('../images/Video_editing_bg-768.jpg');
  --svc-bg-3d: url('../images/3d_printing_bg-768.jpg');
  --svc-bg-social: url('../images/social_media_bg-768.jpg');
  --svc-bg-illustration: url('../images/illustration_bg-768.jpg');
}


* { margin:0; padding:0; box-sizing:border-box; }
h1, h2, h3, h4, h5, h6 { font-weight:normal; }
html { scroll-behavior:smooth; }

body {
  background: var(--black);
  color: var(--white);
  font-family: var(--body);
  font-weight: 300;
  overflow-x: hidden;
  line-height: 1.65;
}

/* ── NOISE OVERLAY ── */
body::after {
  content:'';
  position:fixed; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:9000;
}

/* ── CURSOR ── */
*, *::before, *::after { cursor:none !important; }
#cur {
  position:fixed; width:12px; height:12px;
  background:var(--magenta);
  border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .18s, height .18s, background .18s;
  mix-blend-mode:screen;
}
#cur.grow { width:44px; height:44px; background:var(--teal); opacity:.6; }

@media (hover:none), (pointer:coarse) {
  *, *::before, *::after { cursor:auto !important; }
  #cur { display:none; }
}

@keyframes vfx-burst {
  0%   { transform:translate(-50%,-50%) translate(0,0); opacity:1; }
  100% { transform:translate(-50%,-50%) translate(var(--dx),var(--dy)); opacity:0; }
}

/* ══════════════════════════════════════════
   NAV
   ══════════════════════════════════════════ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 48px;
  background:rgba(5,5,10,0.88);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.05);
  transition:padding .24s ease, background .24s ease, border-color .24s ease;
}
nav.is-scrolled {
  padding:6px 48px;
  background:rgba(5,5,10,0.94);
  border-bottom-color:rgba(255,255,255,0.08);
}
.nav-logo {
  text-decoration:none;
  display:flex; align-items:center; justify-content:flex-start;
  align-self:stretch;
  position:relative;
  padding:0 8px;
  margin:0 -8px;
  cursor:pointer;
  background:transparent;
  border:none;
  -webkit-tap-highlight-color:transparent;
  z-index:1;
}
.nav-logo:hover {
  opacity:0.8;
}
.nav-logo:active {
  opacity:0.7;
}
.nav-logo > * {
  position:relative;
  z-index:1;
  pointer-events:none;
}
.nav-logo-icon {
  display:block;
  width:52px;
  height:52px;
  object-fit:contain;
  object-position:center;
  flex:0 0 auto;
  background:transparent;
  border:none;
  box-shadow:none;
  filter:drop-shadow(-2px 3px 0 rgba(27,157,192,0.9));
  transition:width .24s ease, height .24s ease, filter .24s ease;
}
nav.is-scrolled .nav-logo-icon {
  width:38px;
  height:38px;
}

.nav-panel {
  display:flex; align-items:center; gap:28px;
}

.nav-mid {
  display:flex; gap:36px; list-style:none;
}
.nav-mid a {
  font-family:var(--mono); font-size:10px;
  letter-spacing:2.5px; text-transform:uppercase;
  color:var(--gray); text-decoration:none;
  transition:color .2s;
}
.nav-mid a:hover { color:var(--sky); }

.nav-right { display:flex; align-items:center; gap:14px; }

.nav-toggle {
  display:none;
  width:52px;
  height:52px;
  border:none;
  background:transparent;
  border-radius:2px;
  padding:0;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:visible;
  appearance:none;
  box-shadow:none;
}

.nav-toggle:focus-visible {
  outline:2px solid var(--teal);
  outline-offset:4px;
}

.nav-toggle-icon {
  position:absolute;
  inset:50% auto auto 50%;
  width:50.4px;
  height:50.4px;
  object-fit:contain;
  transform:translate(-50%, -50%);
  transition:opacity .08s ease, transform .08s ease;
}

.nav-toggle-icon-open,
.nav-toggle-icon-close {
  mix-blend-mode:screen;
}

.nav-toggle-icon-action {
  width:50.4px;
  height:50.4px;
  padding:0.79px;
  box-sizing:border-box;
  mix-blend-mode:screen;
}

.nav-toggle-icon-open,
.nav-toggle-icon-action {
  opacity:0;
  transform:translate(-50%, -50%) scale(0.92);
}

nav.is-open .nav-toggle-icon-close {
  opacity:0;
  transform:translate(-50%, -50%) scale(0.92);
}

nav.is-open .nav-toggle-icon-open {
  opacity:1;
  transform:translate(-50%, -50%) scale(1);
}

nav.is-toggle-animating-close .nav-toggle-icon-open,
nav.is-toggle-animating-close .nav-toggle-icon-close {
  opacity:0;
  transform:translate(-50%, -50%) scale(0.92);
}

nav.is-toggle-animating-close .nav-toggle-icon-action {
  opacity:1;
  transform:translate(-50%, -50%) scale(1);
}

/* language toggle */
.lang-toggle {
  display:flex; align-items:center;
  border:1px solid var(--charcoal);
  border-radius:2px; overflow:hidden;
}
.lang-btn {
  font-family:var(--mono); font-size:9.5px;
  letter-spacing:2px; text-transform:uppercase;
  padding:7px 12px;
  background:transparent; color:var(--gray);
  border:none; transition:all .2s;
}
.lang-btn.active {
  background:var(--teal); color:var(--black);
}

.nav-hire {
  font-family:var(--mono); font-size:10px;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--black); background:var(--magenta);
  padding:9px 22px; border-radius:2px;
  text-decoration:none;
  transition:background .2s, transform .15s;
}
.nav-hire:hover { background:var(--white); transform:translateY(-2px); }

/* ══════════════════════════════════════════
   HERO
   ══════════════════════════════════════════ */
#hero {
  min-height:100vh;
  display:flex; flex-direction:column;
  justify-content:flex-end;
  padding:0 48px 72px;
  position:relative; overflow:hidden;
}

/* animated diagonal gradient bg */
.hero-video-bg {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  z-index:-2;
}

html[data-media-video='reduced'] .hero-video-bg {
  display:none;
}
.hero-bg {
  position:absolute; inset:0;
  background:
    linear-gradient(135deg, rgba(41,56,128,0.22) 0%, transparent 50%),
    linear-gradient(315deg, rgba(204,34,120,0.12) 0%, transparent 50%),
    rgba(5,5,10,0.55);
  animation:hbg 12s ease-in-out infinite alternate;
  z-index:-1;
}
.hero-grid {
  position:absolute; inset:0;
  background-image: 
    linear-gradient(rgba(82,184,212,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(82,184,212,0.03) 1px, transparent 1px);
  background-size:72px 72px;
  z-index:0;
}
@keyframes hbg {
  0%  { background-position:0% 0%; }
  100%{ background-position:100% 100%; }
}

/* diagonal stripe accent */
.hero-stripe {
  position:absolute;
  top:-20%; right:-5%;
  width:60vw; height:160%;
  background:linear-gradient(135deg,
    rgba(27,157,192,0.04) 0%,
    rgba(82,184,212,0.06) 40%,
    rgba(204,34,120,0.04) 100%
  );
  transform:rotate(-12deg);
  pointer-events:none;
}
.hero-stripe2 {
  position:absolute;
  bottom:-30%; left:-10%;
  width:50vw; height:80%;
  background:linear-gradient(135deg,
    rgba(204,34,120,0.05) 0%,
    rgba(41,56,128,0.07) 100%
  );
  transform:rotate(-12deg);
  pointer-events:none;
}

.hero-grid {
  position:absolute; inset:0;
  background-image: 
    linear-gradient(rgba(82,184,212,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(82,184,212,0.03) 1px, transparent 1px);
  background-size:72px 72px;
}

.hero-content { position:relative; z-index:1; }

.hero-tag {
  font-family:var(--mono); font-size:10px;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--teal); margin-bottom:18px;
  display:flex; align-items:center; gap:14px;
  opacity:0; animation:fup .6s ease .1s forwards;
}
.hero-tag::before {
  content:'';
  width:36px; height:1px; background:var(--teal);
}

.hero-name {
  font-family:var(--h1);
  font-size:clamp(100px,16vw,220px);
  line-height:.83;
  letter-spacing:3px;
  opacity:0; animation:fup .9s ease .05s forwards;
}
.hero-name .loud { color:var(--white); display:block; }
.hero-name .G { color:var(--teal); }
.hero-name .sub {
  font-size:clamp(44px,7vw,96px);
  color:var(--charcoal); letter-spacing:10px;
  display:block;
}

.hero-bottom {
  display:flex; justify-content:space-between;
  align-items:flex-end; margin-top:36px;
  flex-wrap:wrap; gap:24px;
  opacity:0; animation:fup .7s ease .5s forwards;
}
.hero-desc {
  max-width:500px;
  font-size:15px; color:var(--gray); line-height:1.85;
}
.hero-desc strong { color:var(--white); font-weight:400; }

.hero-actions { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

.btn-mag {
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--gray); background:transparent;
  border:1px solid var(--gray);
  padding:14px 30px; border-radius:2px;
  text-decoration:none;
  transition:background .2s, color .2s, transform .15s;
  display:inline-flex; align-items:center; gap:10px;
}
.btn-mag:hover { background:var(--teal); color:var(--white); transform:translateY(-2px); }
.hero-actions .btn-mag {
  background: transparent;
  color: var(--gray);
  border-color: var(--gray);
}
.btn-ghost {
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--gray);
  border:1px solid var(--charcoal);
  padding:14px 30px; border-radius:2px;
  text-decoration:none;
  transition:border-color .2s, color .2s, transform .15s;
  display:inline-flex; align-items:center; gap:10px;
}
.btn-ghost:hover { border-color:var(--sky); color:var(--sky); transform:translateY(-2px); }
.btn-contact {
  background:var(--magenta);
  color:var(--white);
  border-color:var(--magenta);
}
.btn-contact:hover {
  background:var(--white);
  color:var(--magenta);
}

.port-card > :not(.port-card-video):not(.port-actions):not(.port-info-link):not(.port-sound-toggle) {
  transition:opacity .25s ease, transform .25s ease;
}

.port-card .port-sound-toggle,
.portfolio-mobile-fullscreen .port-sound-toggle {
  position:absolute;
  inset:auto var(--port-card-pad-x, 32px) calc(var(--port-card-pad-bottom, 36px) - var(--port-sound-offset-y, 18px)) auto;
  z-index:7;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:45px;
  min-width:45px;
  max-width:45px;
  height:45px;
  min-height:45px;
  max-height:45px;
  padding:0;
  box-sizing:border-box;
  line-height:1;
  overflow:visible;
  color:var(--white);
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  backdrop-filter:none;
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  cursor:pointer;
  transition:transform .2s ease, filter .2s ease, opacity .2s ease, visibility .2s ease;
}
.port-card .port-sound-toggle.is-playing,
.portfolio-mobile-fullscreen .port-sound-toggle.is-playing {
  width:40px;
  min-width:40px;
  max-width:40px;
  height:40px;
  min-height:40px;
  max-height:40px;
  background:rgba(10,10,10,0.82);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:999px;
  box-shadow:0 8px 18px rgba(0,0,0,0.22);
  backdrop-filter:blur(8px);
}
.port-card .port-sound-toggle,
.portfolio-mobile-fullscreen .port-sound-toggle {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
/* Idle state: always show play icon, hide sound icon and label */
.port-card:not(.is-active-mobile) .port-sound-toggle .port-play-icon,
.port-card:not(.is-active-mobile) .port-sound-toggle.is-playing .port-play-icon {
  display:block;
}
.port-card:not(.is-active-mobile) .port-sound-toggle .port-play-icon img,
.port-card:not(.is-active-mobile) .port-sound-toggle.is-playing .port-play-icon img {
  animation:play-icon-pulse 2s ease-in-out infinite !important;
}
.port-card:not(.is-active-mobile) .port-sound-toggle .port-sound-icon-on,
.port-card:not(.is-active-mobile) .port-sound-toggle .port-sound-icon-off {
  display:none;
}
.port-card:not(.is-active-mobile) .port-sound-toggle .port-sound-label {
  display:none;
}
.port-card:not(.is-active-mobile) .port-sound-toggle.is-playing {
  width:45px; min-width:45px; max-width:45px;
  height:45px; min-height:45px; max-height:45px;
  background:transparent;
  border:0; border-radius:0; box-shadow:none; backdrop-filter:none;
}
.port-sound-toggle:focus-visible {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.port-sound-toggle:hover,
.port-sound-toggle:focus-visible {
  filter:brightness(1.08);
  transform:scale(1.02);
  outline:none;
}
.port-sound-label {
  display:none;
}
.port-card .port-sound-toggle .port-sound-label,
.portfolio-mobile-fullscreen .port-sound-toggle .port-sound-label {
  position:absolute;
  left:50%;
  bottom:calc(100% + 10px);
  display:inline-flex;
  align-items:flex-end;
  justify-content:center;
  gap:0.06em;
  padding:0;
  font-family:var(--mono);
  font-size:9px;
  font-weight:700;
  letter-spacing:1.8px;
  text-transform:uppercase;
  color:var(--white);
  white-space:nowrap;
  transform:translateX(-50%);
  pointer-events:none;
}
.port-sound-letter {
  display:none;
}
.port-card .port-sound-toggle:not(.is-playing) .port-sound-letter,
.portfolio-mobile-fullscreen .port-sound-toggle:not(.is-playing) .port-sound-letter {
  display:inline-block;
  opacity:0;
  transform:translate3d(0, 16px, 0);
  animation:port-sound-letter-loop 1.8s cubic-bezier(.2, .75, .3, 1) infinite;
  animation-delay:calc(var(--letter-index, 0) * 0.06s);
}
.port-card .port-sound-toggle.is-playing .port-sound-letter,
.portfolio-mobile-fullscreen .port-sound-toggle.is-playing .port-sound-letter {
  display:inline-block;
  opacity:0;
  transform:translate3d(0, 16px, 0);
  animation:port-sound-letter-rise .4s cubic-bezier(.2, .75, .3, 1) forwards;
  animation-delay:calc(var(--letter-index, 0) * 0.035s);
}
.port-sound-icon {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:16px;
  height:16px;
  flex:0 0 16px;
  min-width:16px;
  max-width:16px;
  min-height:16px;
  max-height:16px;
}
.port-sound-icon img,
.port-sound-icon svg {
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
}
.port-play-icon {
  display:block;
  width:100%;
  height:100%;
}
@keyframes play-icon-pulse {
  0%,100% { transform:scale(1); opacity:1; }
  50%      { transform:scale(0.88); opacity:0.6; }
}
.port-play-icon img {
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  filter:drop-shadow(-2px 3px 0 rgba(27,157,192,0.9));
}
.port-sound-toggle.is-playing .port-play-icon {
  display:none;
}
.port-card:not(.is-active-mobile) .port-sound-toggle.is-playing .port-play-icon {
  display:block !important;
}
.port-sound-icon img {
  transform-origin:center;
}
.port-sound-icon-on img {
  transform:scale(1.08);
}
.port-sound-icon-off img {
  transform:scale(0.94);
}
.port-sound-icon-on {
  display:none;
}
.port-sound-toggle.is-playing .port-sound-icon-off {
  display:inline-flex;
}
.port-sound-toggle.is-enabled .port-sound-icon-on {
  display:inline-flex;
}
.port-sound-toggle.is-enabled .port-sound-icon-off {
  display:none;
}
.port-sound-toggle:not(.is-playing) .port-sound-icon-on,
.port-sound-toggle:not(.is-playing) .port-sound-icon-off {
  display:none;
}
.port-sound-toggle:not(.is-enabled) .port-sound-icon-off {
  display:inline-flex;
}
.port-sound-sr {
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
  border:0;
}

.portfolio-mobile-fullscreen {
  position:fixed;
  inset:0;
  z-index:12000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(5,5,10,0.98);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .25s ease, visibility .25s ease;
}

.portfolio-mobile-fullscreen.is-active {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.portfolio-mobile-fullscreen-video {
  position:relative;
  width:min(100vw, 100vh * 1.7778);
  max-width:100%;
  max-height:100%;
  aspect-ratio:16 / 9;
  display:flex;
  align-items:center;
  justify-content:center;
}

.portfolio-mobile-fullscreen .port-card-video {
  position:relative;
  inset:auto;
  width:100%;
  height:100%;
  object-fit:contain;
  opacity:1;
  pointer-events:auto;
  filter:none;
  background:transparent;
}

.portfolio-mobile-fullscreen .port-sound-toggle,
.portfolio-fullscreen-exit {
  position:absolute;
  top:18px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}

.portfolio-mobile-fullscreen.is-active .port-sound-toggle,
.portfolio-mobile-fullscreen.is-active .portfolio-fullscreen-exit {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.portfolio-mobile-fullscreen .port-sound-toggle {
  inset:18px 18px auto auto;
}

.portfolio-fullscreen-exit {
  left:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 18px;
  font-family:var(--mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--white);
  background:rgba(10,10,10,0.6);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:999px;
  box-shadow:0 12px 28px rgba(0,0,0,0.28);
  backdrop-filter:blur(8px);
  transition:transform .2s ease, background .2s ease, color .2s ease;
}

.portfolio-fullscreen-exit:hover,
.portfolio-fullscreen-exit:focus-visible,
.portfolio-fullscreen-exit:active {
  background:rgba(204,34,120,0.88);
  color:var(--white);
  transform:translateY(-2px);
  outline:none;
}

.portfolio-fullscreen-exit-label {
  display:inline-block;
  white-space:nowrap;
}

@keyframes port-sound-letter-rise {
  0% {
    opacity:0;
    transform:translate3d(0, 16px, 0);
  }
  60% {
    opacity:1;
    transform:translate3d(0, -3px, 0);
  }
  100% {
    opacity:1;
    transform:translate3d(0, 0, 0);
  }
}

@keyframes port-sound-letter-loop {
  0%, 18% {
    opacity:0;
    transform:translate3d(0, 16px, 0);
  }
  30%, 72% {
    opacity:1;
    transform:translate3d(0, 0, 0);
  }
  100% {
    opacity:0;
    transform:translate3d(0, -6px, 0);
  }
}

@keyframes fup {
  from { opacity:0; transform:translateY(32px); }
  to   { opacity:1; transform:translateY(0); }
}

/* scroll line */
.hero-name-row {
  display:flex; justify-content:space-between; align-items:flex-end;
}
.hero-scroll {
  text-align:center;
  font-family:var(--mono); font-size:9px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--charcoal);
  animation:pulse 2.5s ease infinite;
}
.hero-scroll::after {
  content:''; width:1px; height:48px; background:var(--charcoal);
  display:block; margin:12px auto 0;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }

/* ══════════════════════════════════════════
   MARQUEE
   ══════════════════════════════════════════ */
.marquee-wrap {
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,0.05);
  border-bottom:1px solid rgba(255,255,255,0.05);
  background:rgba(41,56,128,0.08);
  padding:12px 0;
}
.marquee-track {
  display:flex; width:max-content;
  animation:mq 30s linear infinite;
}
.mq-item {
  position:relative;
  font-family:var(--h1); font-size:16px;
  letter-spacing:5px; color:var(--blue);
  white-space:nowrap;
  display:flex; align-items:center;
}
.mq-dot {
  display:inline-block;
  width:8px; height:8px;
  border-radius:50%;
  background:var(--magenta);
  margin:0 50px;
  flex-shrink:0;
}
.mq-item:last-child .mq-dot {
  display:none;
}
@keyframes mq {
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ══════════════════════════════════════════
   SHARED SECTION STYLES
   ══════════════════════════════════════════ */
.section { padding:100px 48px; border-top:1px solid rgba(255,255,255,0.04); }

.s-head {
  display:flex; align-items:center; gap:20px;
  margin-bottom:56px;
}
.s-label {
  font-family:var(--mono); font-size:10px;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--teal); white-space:nowrap;
}
.s-line { height:1px; flex:1; background:rgba(255,255,255,0.06); }
.s-num {
  font-family:var(--mono); font-size:10px;
  color:var(--charcoal); letter-spacing:2px;
}
.s-title {
  font-family:var(--h1);
  font-size:clamp(44px,6.5vw,86px);
  line-height:.9; letter-spacing:1px;
  margin-bottom:20px;
}
.s-title em { color:var(--magenta); font-style:normal; }
.s-title .tl { color:var(--teal); }

/* reveal */
.rv {
  opacity:0; transform:translateY(26px);
  transition:opacity .7s ease, transform .7s ease;
}
.rv.on { opacity:1; transform:translateY(0); }
.rv.d1{transition-delay:.1s}
.rv.d2{transition-delay:.2s}
.rv.d3{transition-delay:.3s}
.rv.d4{transition-delay:.4s}

/* ══════════════════════════════════════════
   ABOUT
   ══════════════════════════════════════════ */
#about {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:start;
}
.about-image img,
.about-image video {
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  clip-path:inset(5px 0 5px 0);
  filter:grayscale(20%) contrast(110%);
  transition:filter .2s ease, transform .2s ease;
  cursor:pointer;
  /* Removed transform:translateX(-10%); to keep image centered */
}
.about-image video {
  width:100%;
  height:100%;
  object-fit:cover;
}
.about-image img:hover,
.about-image video:hover {
  filter:grayscale(0) contrast(115%);
}
.about-image img:hover {
  transform:translateY(-2px);
}
.about-image video:hover {
  transform:translateY(-2px);
}
.about-header {
  display: flex;
  align-items: center;
  gap: 32px;
  margin-bottom: 32px;
}
.about-image {
  width: min(320px, 100%);
  aspect-ratio: 17 / 22;
  overflow: hidden;
  flex-shrink: 0;
}
.discipline-list {
  list-style:none;
  margin-top:28px;
  display:flex; flex-direction:column; gap:0;
  border:1px solid rgba(255,255,255,0.05);
  border-radius:2px; overflow:hidden;
}
.discipline-list li {
  display:flex; align-items:center; gap:14px;
  padding:11px 18px;
  border-bottom:1px solid rgba(255,255,255,0.04);
  font-size:13px; color:var(--gray);
  font-family:var(--body);
  transition:background .2s, color .2s;
}
.discipline-list li:last-child { border-bottom:none; }
.discipline-list li:hover { background:rgba(255,255,255,0.02); color:var(--white); }
.dl-dot {
  width:7px; height:7px; border-radius:50%;
  flex-shrink:0;
}
.about-headline {
  font-family:var(--h1);
  font-size:clamp(44px,6.5vw,86px);
  line-height:.9;
  letter-spacing:1px;
}
.about-headline .wh { color:var(--white); }
.about-headline .mg { color:var(--magenta); }
.about-headline .tl { color:var(--teal); }
.about-p { font-size:14.5px; color:var(--gray); line-height:1.9; }
.about-p + .about-p { margin-top:16px; }
.about-p strong { color:var(--white); font-weight:400; }

.stat-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.05);
  margin-bottom:20px;
}
.stat {
  background:var(--black2);
  padding:24px 20px;
  position:relative; overflow:hidden;
}
.stat::before {
  content:'';
  position:absolute; top:0; left:0;
  width:100%; height:2px;
}
.stat:nth-child(1)::before { background:var(--teal); }
.stat:nth-child(2)::before { background:var(--magenta); }
.stat:nth-child(3)::before { background:var(--sky); }
.stat:nth-child(4)::before { background:var(--navy); }
.stat:nth-child(5)::before { background:var(--blue); }
.stat:nth-child(6)::before { background:var(--magenta); }

.stat-n {
  font-family:var(--h1); font-size:44px;
  line-height:1; letter-spacing:1px;
}
.stat:nth-child(1) .stat-n { color:var(--teal); }
.stat:nth-child(2) .stat-n { color:var(--magenta); }
.stat:nth-child(3) .stat-n { color:var(--sky); }
.stat:nth-child(4) .stat-n { color:var(--navy); }
.stat:nth-child(5) .stat-n { color:var(--blue); }
.stat:nth-child(6) .stat-n { color:var(--magenta); }
.stat-l {
  font-family:var(--mono); font-size:9px;
  color:var(--gray); letter-spacing:2px;
  display:inline-block;
  will-change:transform, opacity, filter;
  text-transform:uppercase; margin-top:6px;
}

/* ══════════════════════════════════════════
   REEL EMBED
   ══════════════════════════════════════════ */
.reel-wrap { margin-top: 0; }
.reel-label {
  display:flex; align-items:center; gap:14px;
  margin-bottom:12px;
  font-family:var(--mono); font-size:9.5px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--teal);
}
.reel-line { height:1px; flex:1; background:rgba(255,255,255,0.07); }
.reel-ext {
  color:var(--gray); text-decoration:none;
  font-size:9px; letter-spacing:2px;
  white-space:nowrap;
  transition:color .2s;
}
.reel-ext:hover { color:var(--teal); }
.reel-frame {
  position:relative;
  width:100%; padding-bottom:45%;
  background:var(--black2);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:2px; overflow:hidden;
}
.reel-frame iframe {
  position:absolute; inset:0;
  width:100%; height:100%;
  z-index:1;
}
.reel-thumbnail {
  position: absolute;
  inset: 0;
  z-index: 3;
  cursor: pointer;
  background: var(--black2);
}
.reel-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: opacity 0.3s;
}
.reel-thumbnail:hover img {
  opacity: 0.8;
}
/* placeholder covers iframe until real ID is set */
.reel-placeholder {
  position:absolute; inset:0; z-index:2;
  background:var(--black2);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .3s;
}
.reel-placeholder.hidden { opacity:0; pointer-events:none; }
.reel-ph-inner { text-align:center; }
.reel-play {
  font-size:36px; color:var(--teal);
  margin-bottom:12px;
  animation:rpulse 2s ease infinite;
}
@keyframes rpulse{ 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.92)} }
.reel-ph-lbl {
  font-family:var(--mono); font-size:10px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--charcoal);
}

/* ══════════════════════════════════════════
   SERVICES — 2-col 6-box + triangle corner
   ══════════════════════════════════════════ */
#services { background:var(--black2); }

#services .s-title {
  position:relative;
  z-index:1;
  margin-bottom:28px;
}

#services .s-title.rv {
  opacity:0;
  transform:translateY(54px);
  transition:opacity .85s ease, transform .85s cubic-bezier(.2,.8,.2,1);
}

#services .s-title.rv.on {
  opacity:1;
  transform:translateY(0);
}

.services-grid {
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.05);
}
.svc-card {
  /* base styles now in hover block below */
  position:relative; overflow:hidden;
  display:flex; flex-direction:column;
}
.svc-card:hover,
.svc-card.is-scroll-highlight { background:var(--black2); }

.svc-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: var(--svc-bg-branding);
  background-size: cover;
  background-position: center;
  opacity: 0.1;
  transform: scale(1.14);
  transform-origin: center;
  transition: transform 1.1s ease, opacity .35s ease;
  z-index: -1;
}

.svc-card:nth-child(1)::before {
  background-image: var(--svc-bg-motion);
}

.svc-card:nth-child(2)::before {
  background-image: var(--svc-bg-video);
}

.svc-card:nth-child(3)::before {
  background-position: calc(50% - 20px) center;
}

.svc-card:nth-child(4)::before {
  background-image: var(--svc-bg-3d);
}

.svc-card:nth-child(5)::before {
  background-image: var(--svc-bg-social);
}

.svc-card:nth-child(6)::before {
  background-image: var(--svc-bg-illustration);
}

.svc-card:hover::before,
.svc-card.is-scroll-highlight::before {
  opacity: 0.2;
  transform: scale(1);
}

/* ── triangle corner ── */
.svc-corner {
  position:absolute;
  top:0; right:0;
  width:120px; height:120px;
  pointer-events:none;
}
/* the triangle shape via border trick */
.svc-tri {
  position:absolute;
  top:0; right:0;
  width:0; height:0;
  border-style:solid;
  border-width:0 120px 120px 0;
  border-color:transparent var(--tc) transparent transparent;
  opacity:.13;
  transition:opacity .35s;
}
.svc-card:hover .svc-tri,
.svc-card.is-scroll-highlight .svc-tri { opacity:.28; }
/* icon sits on top of the triangle */
.svc-ico {
  position:absolute;
  top:14px; right:13px;
  width:32px; height:32px;
  color:var(--tc);
  opacity:.55;
  transition:opacity .3s, transform .3s;
}
.svc-card:hover .svc-ico,
.svc-card.is-scroll-highlight .svc-ico { opacity:1; transform:scale(1.1); }

/* content — svc-title now defined in hover block */
.svc-desc {
  font-size:15.63px; color:var(--gray); line-height:1.8;
  margin-bottom:20px; max-width:50%;
  text-wrap:balance;
}
.svc-includes {
  list-style:none; margin-bottom:24px; flex:1;
}
.svc-includes li {
  font-family:var(--mono); font-size:13.13px;
  color:var(--gray); letter-spacing:.3px;
  padding:5px 0; border-bottom:1px solid rgba(255,255,255,0.04);
  display:flex; align-items:flex-start; gap:8px;
  line-height:1.5;
}
.svc-includes li::before {
  content:'→';
  color:var(--tc, var(--teal));
  flex-shrink:0; font-size:13.75px; margin-top:1px;
}
.svc-price {
  margin-top:auto;
  display:flex; align-items:baseline; gap:8px;
  border-top:1px solid rgba(255,255,255,0.06);
  padding-top:18px; flex-wrap:wrap;
}
.svc-price .amt {
  font-family:var(--h1); font-size:52.5px;
  letter-spacing:1px;
  color:var(--tc, var(--teal));
}
.svc-price .unit {
  font-family:var(--mono); font-size:12.5px;
  color:var(--gray); letter-spacing:1.5px;
  text-transform:uppercase; align-self:center;
}
.svc-badge {
  font-family:var(--mono); font-size:11.25px;
  letter-spacing:1.5px; text-transform:uppercase;
  background:rgba(27,157,192,0.1);
  border:1px solid rgba(27,157,192,0.25);
  color:var(--teal); padding:3px 10px;
  border-radius:2px; margin-left:auto; align-self:center;
  white-space:nowrap;
  text-decoration:none;
  transition:color .2s ease, background .2s ease, border-color .2s ease, transform .2s ease;
}
.svc-badge.mg {
  background:rgba(204,34,120,0.08);
  border-color:rgba(204,34,120,0.25);
  color:var(--magenta);
}
.svc-badge:hover,
.svc-badge:focus-visible {
  background:rgba(27,157,192,0.16);
  border-color:rgba(27,157,192,0.4);
  color:var(--white);
  transform:translateX(2px);
  outline:none;
}
.svc-badge.mg:hover,
.svc-badge.mg:focus-visible {
  background:rgba(204,34,120,0.14);
  border-color:rgba(204,34,120,0.4);
}
.svc-mail-link {
  font-family:var(--mono);
  font-size:16.2px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--white);
  text-decoration:none;
  margin-left:12px;
  align-self:center;
  white-space:nowrap;
  transition:color .2s ease, transform .2s ease;
}
.svc-mail-link:hover,
.svc-mail-link:focus-visible {
  color:var(--tc, var(--teal));
  transform:translateX(2px);
  outline:none;
}

/* service card numbers — dim by default, light up on hover */
.svc-num {
  font-family:var(--h1);
  font-size:clamp(65px,7.5vw,102.5px);
  line-height:1; letter-spacing:2px;
  margin-bottom:20px;
  display:block;
  color:var(--charcoal);
  transition:color .35s ease, text-shadow .35s ease;
}
/* card hover: number ignites */
.svc-card:nth-child(1):hover .svc-num,
.svc-card:nth-child(1).is-scroll-highlight .svc-num { color:var(--teal);    text-shadow:0 0 40px rgba(27,157,192,0.5); }
.svc-card:nth-child(2):hover .svc-num,
.svc-card:nth-child(2).is-scroll-highlight .svc-num { color:var(--magenta); text-shadow:0 0 40px rgba(204,34,120,0.5); }
.svc-card:nth-child(3):hover .svc-num,
.svc-card:nth-child(3).is-scroll-highlight .svc-num { color:var(--sky);     text-shadow:0 0 40px rgba(82,184,212,0.5); }
.svc-card:nth-child(4):hover .svc-num,
.svc-card:nth-child(4).is-scroll-highlight .svc-num { color:var(--navy);    text-shadow:0 0 40px rgba(41,56,128,0.6); }
.svc-card:nth-child(5):hover .svc-num,
.svc-card:nth-child(5).is-scroll-highlight .svc-num { color:var(--magenta); text-shadow:0 0 40px rgba(204,34,120,0.5); }
.svc-card:nth-child(6):hover .svc-num,
.svc-card:nth-child(6).is-scroll-highlight .svc-num { color:var(--teal);    text-shadow:0 0 40px rgba(27,157,192,0.5); }
/* card title also dims slightly at rest */
.svc-title {
  font-family:var(--h1);
  font-size:clamp(22px,2.2vw,28px);
  letter-spacing:.5px; line-height:1;
  color:var(--gray); margin-bottom:12px;
  padding-right:48px;
  transition:color .3s;
}
.svc-card:hover .svc-title,
.svc-card.is-scroll-highlight .svc-title { color:var(--white); }
/* card glow on hover */
.svc-card {
  background:var(--black);
  padding:40px 36px 36px;
  position:relative; overflow:hidden;
  transition:background .3s, box-shadow .35s;
  display:flex; flex-direction:column;
}
.svc-card:nth-child(1):hover,
.svc-card:nth-child(1).is-scroll-highlight { background:var(--black2); box-shadow:inset 0 0 80px rgba(27,157,192,0.04); }
.svc-card:nth-child(2):hover,
.svc-card:nth-child(2).is-scroll-highlight { background:var(--black2); box-shadow:inset 0 0 80px rgba(204,34,120,0.04); }
.svc-card:nth-child(3):hover,
.svc-card:nth-child(3).is-scroll-highlight { background:var(--black2); box-shadow:inset 0 0 80px rgba(82,184,212,0.04); }
.svc-card:nth-child(4):hover,
.svc-card:nth-child(4).is-scroll-highlight { background:var(--black2); box-shadow:inset 0 0 80px rgba(41,56,128,0.06); }
.svc-card:nth-child(5):hover,
.svc-card:nth-child(5).is-scroll-highlight { background:var(--black2); box-shadow:inset 0 0 80px rgba(204,34,120,0.04); }
.svc-card:nth-child(6):hover,
.svc-card:nth-child(6).is-scroll-highlight { background:var(--black2); box-shadow:inset 0 0 80px rgba(27,157,192,0.04); }

/* portfolio grid */
.port-grid {
  display: grid;
  grid-template-columns: 1fr 1fr; /* Default: tablet */
  gap: 1px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.05);
}

@media (min-width: 1025px) {
  .port-grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.port-card {
  --port-card-pad-x:32px;
  --port-card-pad-bottom:36px;
  --port-sound-offset-y:18px;
  background:var(--black2);
  padding:36px 32px;
  position:relative; overflow:hidden;
  isolation:isolate;
  text-decoration:none;
  display:flex; flex-direction:column; justify-content:center;
  transition:background .25s;
  aspect-ratio:16 / 10;
  min-height:380px;
}
.port-card.wide { grid-column:span 2; }
.port-card::before {
  content:'';
  position:absolute; inset:0;
  z-index:1;
  background:linear-gradient(to top, rgba(5,5,10,0.55) 0%, rgba(5,5,10,0.25) 60%, rgba(5,5,10,0.05) 100%);
  opacity:0.5; transition:opacity .35s;
  pointer-events:none;
}
.port-card::after {
  content:'';
  position:absolute; inset:0;
  z-index:1;
  opacity:0; transition:opacity .35s;
  pointer-events:none;
}
.port-card:nth-child(1)::after { background:linear-gradient(135deg,rgba(27,157,192,0.1),transparent); }
.port-card:nth-child(2)::after { background:linear-gradient(135deg,rgba(204,34,120,0.1),transparent); }
.port-card:nth-child(3)::after { background:linear-gradient(135deg,rgba(82,184,212,0.08),transparent); }
.port-card:nth-child(4)::after { background:linear-gradient(225deg,rgba(41,56,128,0.12),transparent); }
.port-card:nth-child(5)::after { background:linear-gradient(135deg,rgba(204,34,120,0.08),transparent); }
.port-card:nth-child(6)::after { background:linear-gradient(135deg,rgba(27,157,192,0.08),transparent); }
.port-card:nth-child(7)::after { background:linear-gradient(135deg,rgba(82,184,212,0.08),transparent); }
.port-card:nth-child(8)::after { background:linear-gradient(135deg,rgba(204,34,120,0.1),transparent); }
.port-card:nth-child(odd) { --port-tab-bg: rgba(204,34,120,0.9); --port-tab-hover-bg: rgba(27,157,192,0.92); }
.port-card:nth-child(even) { --port-tab-bg: rgba(27,157,192,0.9); --port-tab-hover-bg: rgba(204,34,120,0.92); }
.port-card:hover { background:var(--black); }
.port-card:hover::before { opacity:0.35; }
.port-card:hover::after { opacity:1; }
.port-card.is-active-mobile::before { opacity:0; }

.port-card > * {
  position:relative;
  z-index:2;
}

.port-card > .port-card-video {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  z-index:0;
  opacity:0.05;
  transition:opacity .4s ease;
}
.port-card:hover > .port-card-video {
  opacity:0.2;
}
.port-card.is-active-mobile > .port-card-video {
  opacity:1;
}

.port-card > :not(.port-card-video):not(.port-actions):not(.port-info-link):not(.port-sound-toggle) {
  transition:opacity .25s ease, transform .25s ease;
}

.port-card.is-active-mobile > :not(.port-card-video):not(.port-actions):not(.port-info-link):not(.port-sound-toggle) {
  opacity:0;
  transform:translateY(8px);
}

.port-actions {
  position:relative;
  z-index:4;
  opacity:1 !important;
  visibility:visible;
  pointer-events:auto;
}

.port-actions a {
  position:relative;
  z-index:5;
  opacity:1 !important;
  visibility:visible;
  pointer-events:auto;
}

.port-card.wide { grid-column:span 2; }

.port-type {
  font-family:var(--mono); font-size:10.8px;
  letter-spacing:3px; text-transform:uppercase;
  margin-bottom:14px; display:flex; align-items:center; gap:8px;
}
.port-type::before { content:''; width:16px; height:1px; background:currentColor; }
.port-card:nth-child(1) .port-type { color:var(--teal); }
.port-card:nth-child(2) .port-type { color:var(--magenta); }
.port-card:nth-child(3) .port-type { color:var(--sky); }
.port-card:nth-child(4) .port-type { color:var(--blue); }
.port-card:nth-child(5) .port-type { color:var(--magenta); }
.port-card:nth-child(6) .port-type { color:var(--teal); }
.port-card:nth-child(7) .port-type { color:var(--sky); }
.port-card:nth-child(8) .port-type { color:var(--magenta); }

.port-title {
  font-family:var(--h1);
  font-size:clamp(24px,2.4vw,31.2px);
  line-height:1.05; letter-spacing:.3px;
  color:var(--white); margin-bottom:10px;
  transition:color .2s;
}
.port-card:hover .port-title { color:var(--sky); }
.port-desc {
  font-size:14.4px; color:var(--gray); line-height:1.75;
  margin-bottom:16px; font-weight:700;
}
.port-tags { display:flex; flex-wrap:wrap; gap:5px; }
.ptag {
  font-family:var(--mono); font-size:10.8px; letter-spacing:1px;
  color:var(--charcoal); border:1px solid var(--charcoal);
  padding:3px 9px; border-radius:2px;
  transition:color .2s, border-color .2s;
}
.port-card:hover .ptag { color:rgba(82,184,212,0.7); border-color:rgba(82,184,212,0.2); }

.port-info-link {
  position:absolute;
  top:0;
  left:50%;
  width:60%;
  height:10%;
  min-height:38px;
  max-height:56px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 16px;
  font-family:var(--h1);
  font-size:96%;
  font-weight:400;
  letter-spacing:.8px;
  text-transform:uppercase;
  text-align:center;
  color:var(--white);
  background:var(--port-tab-bg, rgba(204,34,120,0.9));
  border:1px solid var(--port-tab-bg, rgba(204,34,120,0.9));
  border-top:none;
  border-radius:0 0 20px 20px;
  text-decoration:none;
  white-space:nowrap;
  z-index:6;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  box-shadow:0 14px 28px rgba(0,0,0,0.28);
  transform:translate(-50%, -32%);
  transition:opacity .2s ease, visibility .2s ease, transform .35s cubic-bezier(.2,.8,.2,1), background .25s ease, color .25s ease, box-shadow .25s ease;
}
.port-card:hover .port-info-link {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  color:var(--white);
  background:var(--port-tab-bg, rgba(204,34,120,0.9));
  border-color:var(--port-tab-bg, rgba(204,34,120,0.9));
  transform:translate(-50%, 0);
  box-shadow:0 18px 34px rgba(0,0,0,0.34);
}
.port-card.is-active-mobile .port-info-link {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  color:var(--white);
  background:var(--port-tab-bg, rgba(204,34,120,0.9));
  border-color:var(--port-tab-bg, rgba(204,34,120,0.9));
  transform:translate(-50%, 0);
  box-shadow:0 18px 34px rgba(0,0,0,0.34);
}
.port-card:hover .port-info-link:hover,
.port-card:hover .port-info-link:focus-visible,
.port-info-link:focus-visible {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  color:var(--white);
  background:var(--port-tab-hover-bg, rgba(27,157,192,0.92));
  border-color:var(--port-tab-hover-bg, rgba(27,157,192,0.92));
  transform:translate(-50%, 0);
  box-shadow:0 18px 34px rgba(0,0,0,0.34);
  outline:none;
}

@media (hover:none), (pointer:coarse) {
  .port-card::before {
    background:linear-gradient(to top, rgba(5,5,10,1) 0%, rgba(5,5,10,0.97) 60%, rgba(5,5,10,0.88) 100%);
    opacity:1;
  }
  .port-card > .port-card-video {
    opacity:0.15;
  }
  .port-card.is-active-mobile > .port-card-video {
    opacity:1;
  }
  .port-card:hover {
    background:var(--black2);
  }
  .port-card:hover::before {
    opacity:0.5;
  }
  .port-card:hover::after {
    opacity:0;
  }
  .port-card:hover > .port-card-video {
    opacity:0.15;
  }
  .port-card:hover .port-title {
    color:var(--white);
  }
  .port-card:hover .ptag {
    color:var(--charcoal);
    border-color:var(--charcoal);
  }
  .port-card:hover .port-info-link {
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translate(-50%, -32%);
    box-shadow:0 14px 28px rgba(0,0,0,0.28);
  }
  .port-card.is-active-mobile .port-info-link {
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translate(-50%, 0);
    box-shadow:0 18px 34px rgba(0,0,0,0.34);
  }
  .svc-card::before {
    background-size:contain;
    background-repeat:no-repeat;
    transform:none;
  }
  .svc-card:hover::before,
  .svc-card.is-scroll-highlight::before {
    transform:none;
  }
}

/* ══════════════════════════════════════════
   RATES BAR
   ══════════════════════════════════════════ */
#rates {
  background:var(--navy);
  padding:56px 48px;
  border-top:1px solid rgba(82,184,212,0.2);
  border-bottom:1px solid rgba(82,184,212,0.2);
}
.rates-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:32px;
}
.rates-left {
  font-family:var(--h1);
  font-size:clamp(32px,4.5vw,58px);
  line-height:.95; letter-spacing:1px;
  color:var(--white);
}
.rates-left em { color:var(--sky); font-style:normal; }
.rates-grid {
  display:flex; gap:32px; flex-wrap:wrap;
}
.rate-item {
  text-align:center;
}
.rate-amt {
  font-family:var(--h1); font-size:48px;
  color:var(--sky); line-height:1;
  letter-spacing:1px;
}
.rate-lbl {
  font-family:var(--mono); font-size:9.5px;
  color:rgba(240,236,246,0.5); letter-spacing:2px;
  text-transform:uppercase; margin-top:4px;
}
.rate-div { width:1px; background:rgba(82,184,212,0.2); align-self:stretch; }

/* ══════════════════════════════════════════
   CONTACT / HIRE
   ══════════════════════════════════════════ */
#contact {
  padding:120px 48px;
  text-align:center;
  position:relative; overflow:hidden;
}
#contact::before {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 40% at 50% 50%,
      rgba(204,34,120,0.07) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 20% 80%,
      rgba(27,157,192,0.05) 0%, transparent 70%);
  pointer-events:none;
}
.contact-tag {
  font-family:var(--mono); font-size:10px;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--magenta); margin-bottom:24px;
}
.contact-tag-primary,
.contact-tag-secondary,
.contact-tag-sep {
  display:inline;
}
.tight-qmark {
  display:inline-block;
  margin-left:-0.14em;
  transform:translateX(-0.02em);
}
.contact-title {
  font-family:var(--h1);
  font-size:clamp(64px,10vw,150px);
  line-height:.85; letter-spacing:2px;
  margin-bottom:28px; position:relative; z-index:1;
}
.contact-title .tl { color:var(--teal); display:block; }
.contact-title .mg { color:var(--magenta); }
.contact-sub {
  font-size:15px; color:var(--gray);
  max-width:500px; margin:0 auto 44px;
  line-height:1.85; position:relative; z-index:1;
}
.contact-sub strong { color:var(--white); font-weight:400; }
.contact-btns {
  display:flex; justify-content:center;
  gap:14px; flex-wrap:wrap;
  margin-bottom:56px; position:relative; z-index:1;
}
.contact-meta {
  font-family:var(--mono); font-size:15.18px;
  color:var(--charcoal); letter-spacing:2px;
  display:flex; justify-content:center;
  gap:28px; flex-wrap:wrap;
  position:relative; z-index:1;
}
.contact-meta a {
  color:var(--teal); text-decoration:none;
  font-weight:700;
  transition:color .2s;
}
.contact-meta a:hover,
.contact-meta a:focus-visible,
.contact-meta a:active { color:var(--magenta); }

/* ══════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════ */
footer {
  border-top:1px solid rgba(255,255,255,0.05);
  padding:24px 48px;
  display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:16px;
  background:var(--black2);
}
.foot-logo {
  font-family:var(--h1); font-size:22px; letter-spacing:3px;
  color:var(--charcoal); display:flex; gap:1px;
}
.foot-logo .L{color:var(--teal);}
.foot-logo .O{color:var(--magenta);}
.foot-logo .U{color:var(--sky);}
.foot-logo .D{color:var(--charcoal);}

.foot-links {
  display:flex; gap:24px; list-style:none;
  flex-wrap:wrap;
}
.foot-links a {
  font-family:var(--mono); font-size:9.5px;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--charcoal); text-decoration:none;
  display:flex; align-items:center; gap:6px;
  transition:color .2s;
}
.foot-links a:hover { color:var(--teal); }
.foot-links .pl { color:var(--teal); font-size:8px; }
.foot-links .pl.mg { color:var(--magenta); }
.foot-links .pl.sky { color:var(--sky); }

.foot-copy {
  font-family:var(--mono); font-size:9px;
  color:var(--charcoal); letter-spacing:1.5px;
}

/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */
@media (min-width:641px) and (max-width:1024px) {
  nav {
    padding:14px 28px;
  }
  nav.is-scrolled {
    padding:8px 28px;
  }
  .nav-logo {
    padding:0 6px;
    margin:0 -6px;
  }
  .nav-logo-icon {
    width:46px;
    height:46px;
    filter:drop-shadow(-1px 2px 0 rgba(27,157,192,0.9));
  }
  nav.is-scrolled .nav-logo-icon {
    width:36px;
    height:36px;
    filter:drop-shadow(-1px 1px 0 rgba(27,157,192,0.9));
  }
  .nav-panel {
    gap:18px;
  }
  .nav-mid {
    gap:22px;
  }
  .nav-mid a {
    font-size:9px;
    letter-spacing:2px;
  }
  .nav-right {
    gap:10px;
  }
  .lang-btn {
    padding:6px 10px;
    font-size:8.5px;
    letter-spacing:1.6px;
  }
  .nav-hire {
    padding:8px 16px;
    font-size:9px;
    letter-spacing:1.7px;
  }
  #hero {
    padding:0 28px 64px;
  }
  .hero-name {
    font-size:clamp(84px, 13vw, 148px);
  }
  .hero-name .sub {
    font-size:clamp(30px, 5.1vw, 62px);
    letter-spacing:6px;
  }
  .hero-desc {
    max-width:440px;
    font-size:13.5px;
  }
  .section {
    padding:84px 28px;
  }
  #about {
    grid-template-columns:minmax(0, 1.05fr) minmax(280px, 0.95fr);
    gap:48px;
  }
  .about-header {
    align-items:flex-start;
    gap:20px;
  }
  .about-image {
    width:min(250px, 42%);
  }
  .about-p {
    font-size:13px;
  }
  .discipline-list li {
    font-size:11.5px;
  }
  .stat-grid {
    grid-template-columns:repeat(3, 1fr);
  }
  .stat-n {
    font-size:38px;
  }
  .services-grid {
    grid-template-columns:1fr 1fr;
  }
  .svc-card {
    padding:34px 26px 30px;
  }
  .svc-card.full {
    grid-column:span 1;
  }
  .svc-desc {
    max-width:72%;
    font-size:13.8px;
  }
  .svc-includes li {
    font-size:11.3px;
  }
  .svc-price .amt {
    font-size:44px;
  }
  .port-grid {
    grid-template-columns:1fr 1fr;
  }
    .port-card {
      grid-column:span 1;
    }
    .port-card.wide {
      grid-column:span 2;
    }
  .port-card {
    min-height:340px;
    padding:34px 26px;
    aspect-ratio:auto;
  }
  .port-title {
    font-size:clamp(22px, 2.9vw, 29px);
  }
  .port-desc {
    font-size:13px;
  }
  .port-info-link {
    width:calc(100% - 40px);
    max-width:320px;
    min-height:42px;
    padding:8px 14px;
    white-space:normal;
  }
  #rates {
    padding:48px 28px;
    text-align:center;
  }
  .rates-inner {
    justify-content:center;
    gap:24px;
  }
  .rates-left {
    width:100%;
    text-align:center;
  }
  .rates-grid {
    justify-content:center;
    gap:24px;
  }
  #contact {
    padding:96px 28px;
  }
  .contact-sub {
    max-width:560px;
  }
  footer {
    padding:24px 28px;
    gap:18px;
  }
}

@media(max-width:767px){
  nav {
    padding:13px 22px;
    align-items:center;
  }
  nav.is-scrolled {
    padding:6px 22px;
  }
  .nav-logo {
    display:inline-flex;
    padding:0 6px;
    margin:0 -6px;
    overflow:visible;
  }
  .nav-logo-icon {
    width:42px;
    height:42px;
    overflow:visible;
    filter:drop-shadow(-1px 1px 0 rgba(27,157,192,0.9));
  }
  nav.is-scrolled .nav-logo-icon {
    width:32px;
    height:32px;
    filter:drop-shadow(-1px 1px 0 rgba(27,157,192,0.9));
  }
  .nav-toggle { display:flex; }
  .nav-panel {
    position:absolute;
    top:100%; left:0; right:0;
    padding:16px 22px 22px;
    background:rgba(5,5,10,0.96);
    backdrop-filter:blur(20px);
    border-bottom:1px solid rgba(255,255,255,0.05);
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:20px;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(-8px);
    transition:opacity .2s ease, transform .2s ease, visibility .2s ease;
  }
  nav.is-open .nav-panel {
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0);
  }
  .nav-mid {
    display:flex;
    flex-direction:column;
    gap:18px;
  }
  .nav-right {
    width:100%;
    flex-direction:column;
    align-items:flex-start;
  }
  #hero { padding:0 22px 58px; }
  .section { padding:65px 22px; }
  #about { grid-template-columns:1fr; gap:48px; }
  .about-header {
    flex-direction:column;
    align-items:flex-start;
    gap:24px;
  }
  .about-image { width:min(100%, 420px); }
  .stat-grid { grid-template-columns:repeat(2, 1fr); }
  .services-grid { grid-template-columns:1fr 1fr; }
  .svc-card.full { grid-column:span 1; grid-template-columns:1fr; }
  .svc-card {
    padding:32px 25px 29px;
  }
  .svc-title { padding-right:0; }
  .svc-desc { max-width:none; }
  .port-grid { grid-template-columns:1fr 1fr; }
  .port-card.wide { grid-column:span 2; }
  .reel-label {
    flex-wrap:wrap;
    align-items:flex-start;
  }
  .reel-frame { padding-bottom:56.25%; }
  .port-card {
    aspect-ratio:auto;
    min-height:340px;
  }
  .port-info-link {
    width:calc(100% - 48px);
    max-width:320px;
    height:auto;
    min-height:44px;
    padding:9px 14px;
    white-space:normal;
  }
  footer { flex-direction:column; align-items:flex-start; padding:22px; }
  #rates { text-align:center; }
  .rates-inner { flex-direction:column; align-items:center; justify-content:center; }
  .rates-left { text-align:center; }
  .rates-grid { justify-content:center; }
  #contact { padding:72px 22px; }
}
@media(max-width:640px){
  #hero {
    min-height:auto;
    padding:101px 18px 50px;
  }
  .section { padding:58px 18px; }
  .hero-name,
  .hero-name .sub,
  .s-title,
  .about-headline,
  .svc-title,
  .port-title,
  .rates-left,
  .contact-title {
    font-weight:700;
  }
  .hero-tag,
  .s-label,
  .s-num,
  .contact-tag,
  .reel-ph-lbl,
  .btn-mag,
  .btn-ghost,
  .rate-lbl,
  .port-type,
  .ptag,
  .port-sound-label,
  .svc-badge,
  .svc-price .unit,
  .svc-mail-link,
  .stat-l,
  .reel-label,
  .reel-ext {
    font-size:70%;
  }
  .mq-item {
    font-size:11.2px;
  }
  .hero-name {
    font-size:clamp(50px, 18.2vw, 77px);
  }
  .hero-name .sub {
    font-size:clamp(20px, 7.7vw, 36px);
    letter-spacing:3px;
  }
  .hero-name-row { flex-direction:column; gap:20px; align-items:flex-start; }
  .hero-scroll { margin:0; }
  .hero-bottom { margin-top:28px; }
  .hero-desc {
    max-width:none;
    font-size:10.5px;
  }
  .hero-actions {
    width:100%;
  }
  .hero-actions a {
    width:100%;
    justify-content:center;
  }
  .about-header { gap:20px; }
  .about-image { width:70%; }
  #about.section {
    padding-bottom:36px;
  }
  #services.section {
    padding-top:40px;
  }
  .s-title {
    font-size:clamp(31px, 4.55vw, 60px);
  }
  .about-headline {
    font-size:clamp(25px, 9.8vw, 41px);
  }
  .about-p {
    font-size:10.15px;
  }
  .discipline-list li {
    font-size:9.1px;
  }
  .stat-grid { grid-template-columns:repeat(3, 1fr); }
  .stat-n {
    font-size:27.72px;
  }
  .stat-l {
    font-size:6.3px;
  }
  .services-grid { grid-template-columns:1fr; }
  #services .s-title { margin-bottom:20px; }
  .svc-card.full { grid-column:span 1; grid-template-columns:1fr; }
  .svc-card {
    padding:29px 18px 25px;
  }
  .svc-num {
    font-size:clamp(46px, 10vw, 72px);
  }
  .svc-title {
    font-size:clamp(15px, 5vw, 20px);
  }
  .svc-desc {
    font-size:10.1px;
    max-width:none;
  }
  .svc-includes li {
    font-size:9.2px;
  }
  .svc-includes li::before {
    font-size:9.6px;
  }
  .svc-price .amt {
    font-size:36.75px;
  }
  .svc-price {
    align-items:flex-start;
    gap:10px;
  }
  .svc-badge,
  .svc-mail-link { margin-left:0; }
  .rates-grid {
    width:100%;
    flex-direction:column;
    gap:18px;
  }
  .rate-div { display:none; }
  .rates-left {
    font-size:clamp(22px, 3.15vw, 41px);
  }
  .rate-amt {
    font-size:33.6px;
  }
  .port-grid { grid-template-columns:1fr; }
  .port-card.wide { grid-column:span 1; }
  .port-card {
    --port-card-pad-x:18px;
    --port-card-pad-bottom:22px;
    --port-sound-offset-y:12px;
    min-height:360px;
    padding:65px 18px 22px;
  }
  .port-card .port-sound-toggle {
    width:42px;
    min-width:42px;
    max-width:42px;
    height:42px;
    min-height:42px;
    max-height:42px;
    padding:0;
  }
  .port-card.is-active-mobile .port-sound-toggle.is-playing {
    width:56px;
    min-width:56px;
    max-width:56px;
    height:40px;
    min-height:40px;
    max-height:40px;
    padding:0 14px;
    border-radius:999px;
  }
  .port-card .port-sound-toggle .port-sound-label {
    bottom:calc(100% + 8px);
    font-size:8px;
    letter-spacing:1.5px;
  }
  .port-sound-icon {
    width:18px;
    height:18px;
    flex:0 0 18px;
  }
  .port-card > .port-card-video {
    object-fit:cover;
    object-position:center;
  }
  .port-title {
    font-size:clamp(17px, 5.5vw, 22px);
  }
  .port-desc {
    font-size:10.1px;
  }
  .port-info-link {
    width:calc(100% - 32px);
    font-size:67%;
  }
  .contact-title {
    font-size:clamp(45px, 7vw, 105px);
  }
  .contact-tag {
    line-height:1.7;
    margin-bottom:20px;
  }
  .contact-tag-primary,
  .contact-tag-secondary {
    display:block;
  }
  .contact-tag-sep {
    display:none;
  }
  .contact-sub {
    font-size:10.5px;
  }
  .contact-btns {
    flex-direction:column;
    align-items:center;
    gap:14px;
    margin-bottom:14px;
  }
  .contact-btns a {
    width:min(100%, 280px);
    justify-content:center;
  }
  .contact-meta {
    flex-direction:column;
    gap:12px;
  }
}

