/* ══════════════════════════════════════════
   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;
}

* { margin:0; padding:0; box-sizing:border-box; }
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; }

@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);
}
.nav-logo {
  font-family:var(--h1);
  font-size:28px; letter-spacing:4px;
  text-decoration:none;
  display:flex; align-items:baseline; gap:0;
}
.nav-logo .L { color:var(--teal); }
.nav-logo .O { color:var(--magenta); }
.nav-logo .U { color:var(--sky); }
.nav-logo .D { color:var(--white); }
.nav-logo .sep { color:var(--charcoal); margin:0 10px; font-size:20px; letter-spacing:0; }
.nav-logo .fullname { color:var(--gray); font-size:18px; letter-spacing:5px; }

.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:44px;
  height:44px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.03);
  border-radius:2px;
  padding:0;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
}

.nav-toggle span {
  width:18px;
  height:1px;
  background:var(--white);
  transition:transform .2s ease, opacity .2s ease;
}

nav.is-open .nav-toggle span:nth-child(1) {
  transform:translateY(6px) rotate(45deg);
}

nav.is-open .nav-toggle span:nth-child(2) {
  opacity:0;
}

nav.is-open .nav-toggle span:nth-child(3) {
  transform:translateY(-6px) rotate(-45deg);
}

/* 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;
}
.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:hover > :not(.port-card-video):not(.port-actions):not(.port-info-link):not(.port-sound-toggle) {
  opacity:0;
  transform:translateY(8px);
}

.port-sound-toggle {
  position:absolute;
  right:18px;
  top:18px;
  z-index:7;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  padding:0;
  overflow:visible;
  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);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  cursor:pointer;
  transition:opacity .2s ease, visibility .2s ease, transform .2s ease, background .2s ease;
}
.port-card:hover .port-sound-toggle,
.port-sound-toggle:focus-visible {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.port-sound-toggle:hover,
.port-sound-toggle:focus-visible {
  background:rgba(27,157,192,0.88);
  transform:translateY(-2px);
  outline:none;
}
.port-sound-label {
  position:absolute;
  left:50%;
  bottom:100%;
  display:inline-flex;
  align-items:flex-end;
  justify-content:center;
  gap:2px;
  min-width:max-content;
  padding-bottom:4px;
  font-family:var(--mono);
  font-size:9px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--white);
  transform:translateX(-50%);
  pointer-events:none;
  white-space:nowrap;
  overflow:hidden;
}
.port-sound-letter {
  display:inline-block;
  opacity:0;
  transform:translate3d(0, 16px, 0);
  will-change:transform, opacity;
}
.port-card:hover .port-sound-letter,
.port-sound-toggle:hover .port-sound-letter,
.port-sound-toggle:focus-visible .port-sound-letter {
  animation:port-sound-letter-rise .42s cubic-bezier(.22,1,.36,1) forwards;
  animation-delay:calc(var(--letter-index) * 55ms);
}
.port-sound-icon {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
}
.port-sound-icon img {
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
}
.port-sound-icon-on {
  display:none;
}
.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-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;
}

@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 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;
}
.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 { background:var(--black2); }

.svc-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url('../Images/branding_bg.png');
  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: url('../Images/motion_design_bg.png');
}

.svc-card:nth-child(2)::before {
  background-image: url('../Images/Video_editing_bg.png');
}

.svc-card:nth-child(3)::before {
  background-position: calc(50% - 20px) center;
}

.svc-card:nth-child(4)::before {
  background-image: url('../Images/3d_printing_bg.png');
}

.svc-card:nth-child(5)::before {
  background-image: url('../Images/social_media_bg.png');
}

.svc-card:nth-child(6)::before {
  background-image: url('../Images/illustration_bg.png');
}

.svc-card:hover::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 { 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 { 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;
}
.svc-badge.mg {
  background:rgba(204,34,120,0.08);
  border-color:rgba(204,34,120,0.25);
  color:var(--magenta);
}
.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 { color:var(--teal);    text-shadow:0 0 40px rgba(27,157,192,0.5); }
.svc-card:nth-child(2):hover .svc-num { color:var(--magenta); text-shadow:0 0 40px rgba(204,34,120,0.5); }
.svc-card:nth-child(3):hover .svc-num { color:var(--sky);     text-shadow:0 0 40px rgba(82,184,212,0.5); }
.svc-card:nth-child(4):hover .svc-num { color:var(--navy);    text-shadow:0 0 40px rgba(41,56,128,0.6); }
.svc-card:nth-child(5):hover .svc-num { color:var(--magenta); text-shadow:0 0 40px rgba(204,34,120,0.5); }
.svc-card:nth-child(6):hover .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 { 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 { background:var(--black2); box-shadow:inset 0 0 80px rgba(27,157,192,0.04); }
.svc-card:nth-child(2):hover { background:var(--black2); box-shadow:inset 0 0 80px rgba(204,34,120,0.04); }
.svc-card:nth-child(3):hover { background:var(--black2); box-shadow:inset 0 0 80px rgba(82,184,212,0.04); }
.svc-card:nth-child(4):hover { background:var(--black2); box-shadow:inset 0 0 80px rgba(41,56,128,0.06); }
.svc-card:nth-child(5):hover { background:var(--black2); box-shadow:inset 0 0 80px rgba(204,34,120,0.04); }
.svc-card:nth-child(6):hover { background:var(--black2); box-shadow:inset 0 0 80px rgba(27,157,192,0.04); }

/* portfolio grid */
.port-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);
}
.port-card {
  background:var(--black2);
  padding:36px 32px;
  position:relative; overflow:hidden;
  isolation:isolate;
  text-decoration:none;
  display:flex; flex-direction:column; justify-content:flex-end;
  transition:background .25s;
  aspect-ratio:20 / 9;
  min-height:0;
}
.port-card.wide { grid-column:span 2; }
.port-card::before {
  content:'';
  position:absolute; inset:0;
  z-index:1;
  opacity:0; transition:opacity .35s;
}
.port-card:nth-child(1)::before { background:linear-gradient(135deg,rgba(27,157,192,0.1),transparent); }
.port-card:nth-child(2)::before { background:linear-gradient(135deg,rgba(204,34,120,0.1),transparent); }
.port-card:nth-child(3)::before { background:linear-gradient(135deg,rgba(82,184,212,0.08),transparent); }
.port-card:nth-child(4)::before { background:linear-gradient(225deg,rgba(41,56,128,0.12),transparent); }
.port-card:nth-child(5)::before { background:linear-gradient(135deg,rgba(204,34,120,0.08),transparent); }
.port-card:nth-child(6)::before { background:linear-gradient(135deg,rgba(27,157,192,0.08),transparent); }
.port-card:nth-child(7)::before { background:linear-gradient(135deg,rgba(82,184,212,0.08),transparent); }
.port-card:nth-child(8)::before { 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:1; }

.port-card > * {
  position:relative;
  z-index:2;
}

.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-video {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  background:var(--black);
  opacity:0;
  z-index:0;
  pointer-events:none;
  transition:opacity .7s ease;
  filter:saturate(1.05) contrast(1.05) brightness(0.7);
}

.port-card:hover .port-card-video {
  opacity:1;
}

.port-card:hover > :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;
}
.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: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;
}

/* ══════════════════════════════════════════
   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-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:11px;
  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(--charcoal); text-decoration:none;
  transition:color .2s;
}
.contact-meta a:hover { color:var(--sky); }

/* ══════════════════════════════════════════
   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(max-width:960px){
  nav {
    padding:14px 24px;
    align-items:center;
  }
  .nav-toggle { display:flex; }
  .nav-panel {
    position:absolute;
    top:100%; left:0; right:0;
    padding:18px 24px 24px;
    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 24px 64px; }
  .section { padding:72px 24px; }
  #about { grid-template-columns:1fr; gap:48px; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .svc-card.full { grid-column:span 2; }
  .port-grid { grid-template-columns:1fr 1fr; }
  .port-card.wide { grid-column:span 2; }
  footer { flex-direction:column; align-items:flex-start; padding:24px; }
  #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:80px 24px; }
}
@media(max-width:640px){
  .nav-logo .fullname { display:none; }
  .hero-name-row { flex-direction:column; gap:20px; align-items:flex-start; }
  .hero-scroll { margin:0; }
  .services-grid { grid-template-columns:1fr; }
  #services .s-title { margin-bottom:20px; }
  .svc-card.full { grid-column:span 1; grid-template-columns:1fr; }
  .rates-grid > .rate-div:nth-child(4) { display:none; }
  .port-grid { grid-template-columns:1fr; }
  .port-card.wide { grid-column:span 1; }
}
