/* ============================================================
   PHOS OPUS — style.css
   ============================================================ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

:root {
  --bg:      #080807;
  --bg2:     #101010;
  --fg:      #f2ede4;
  --cream:   #e8e2d6;
  --acc:     #e8401c;
  --acc2:    #f5a623;
  --mid:     #1a1a18;
  --border:  #2a2a27;
  --muted:   #6a6a65;
  --font-d:  'Bebas Neue', sans-serif;
  --font-c:  'Barlow Condensed', sans-serif;
  --font-s:  'Cormorant Garamond', serif;
  --font-m:  'DM Mono', monospace;
}

body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-c);
  overflow-x: hidden;
  cursor: none;
}
a { color: inherit; text-decoration: none; }

/* ── NOISE ── */
.noise {
  position: fixed; inset: 0; z-index: 9000; pointer-events: none;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 160px;
}

/* ── CURSOR ── */
#cursor-dot {
  position: fixed; width: 9px; height: 9px;
  background: var(--acc); border-radius: 50%;
  pointer-events: none; z-index: 9001;
  transform: translate(-50%, -50%);
  transition: width .15s, height .15s, background .15s;
}
#cursor-ring {
  position: fixed; width: 36px; height: 36px;
  border: 1.5px solid rgba(232,64,28,.5);
  border-radius: 50%; pointer-events: none; z-index: 9000;
  transform: translate(-50%, -50%);
  transition: width .3s cubic-bezier(.25,.46,.45,.94),
              height .3s cubic-bezier(.25,.46,.45,.94),
              border-color .3s;
}
body.hovering #cursor-dot  { width: 14px; height: 14px; background: var(--acc2); }
body.hovering #cursor-ring { width: 54px; height: 54px; border-color: rgba(245,166,35,.7); }

/* ── LOADER ── */
#loader {
  position: fixed; inset: 0; z-index: 8000;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  transition: opacity .7s ease, visibility .7s;
}
#loader.done { opacity: 0; visibility: hidden; }
.loader-inner { text-align: center; }
.loader-logo {
  font-family: var(--font-d); font-size: clamp(3rem,10vw,7rem);
  letter-spacing: .1em; color: var(--fg); margin-bottom: 2rem;
}
.loader-logo span { color: var(--acc); }
.loader-bar { width: 240px; height: 2px; background: var(--border); margin: 0 auto; overflow: hidden; }
.loader-fill { height: 100%; width: 0; background: var(--acc); animation: fillBar 1.8s cubic-bezier(.77,0,.18,1) forwards; }
@keyframes fillBar { to { width: 100%; } }

/* ── LIGHTBOX ── */
#lightbox {
  position: fixed; inset: 0; z-index: 7000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity .4s, visibility .4s;
}
#lightbox.open { opacity: 1; visibility: visible; }
#lightbox-backdrop {
  position: absolute; inset: 0;
  background: rgba(4,4,4,.96);
  backdrop-filter: blur(8px);
}
#lightbox-box {
  position: relative; z-index: 1;
  width: min(92vw, 1000px);
  transform: scale(.92) translateY(20px);
  transition: transform .4s cubic-bezier(.34,1.56,.64,1);
}
#lightbox.open #lightbox-box { transform: scale(1) translateY(0); }
#lightbox-close {
  position: absolute; top: -3rem; right: 0;
  background: none; border: none; cursor: none;
  color: var(--fg); opacity: .6; transition: opacity .2s, transform .2s;
  padding: .5rem;
}
#lightbox-close:hover { opacity: 1; transform: rotate(90deg); }
#lightbox-video-wrap {
  position: relative; width: 100%; padding-bottom: 56.25%;
  background: #000; border: 1px solid var(--border);
}
#yt-iframe {
  position: absolute; inset: 0; width: 100%; height: 100%;
}
#lightbox-info {
  padding: 1.2rem 0 0;
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem;
}
#lightbox-title {
  font-family: var(--font-d); font-size: 1.5rem;
  letter-spacing: .06em; color: var(--fg);
}
#lightbox-sub {
  font-family: var(--font-m); font-size: .6rem;
  letter-spacing: .15em; text-transform: uppercase; color: var(--muted);
  white-space: nowrap;
}

/* ── NAV ── */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.4rem 3rem;
  background: rgba(8,8,7,.9);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  transition: padding .3s;
}
#nav.scrolled { padding: 1rem 3rem; }
.nav-logo { font-family: var(--font-d); font-size: 1.7rem; letter-spacing: .1em; }
.nav-logo .acc { color: var(--acc); }
.nav-links { display: flex; align-items: center; gap: 2.5rem; list-style: none; }
.nav-link {
  font-family: var(--font-c); font-size: .78rem;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--muted); transition: color .2s;
}
.nav-link:hover, .nav-link.active { color: var(--fg); }
.nav-cta {
  font-family: var(--font-c); font-weight: 700;
  font-size: .72rem; letter-spacing: .2em; text-transform: uppercase;
  padding: .55rem 1.5rem;
  background: var(--acc); color: #fff;
  transition: background .2s;
}
.nav-cta:hover { background: var(--acc2); color: var(--bg); }
.nav-toggle { display: none; background: none; border: none; cursor: none; flex-direction: column; gap: 5px; padding: .5rem; }
.nav-toggle span { display: block; width: 26px; height: 1.5px; background: var(--fg); transition: transform .3s, opacity .3s; }
.nav-toggle.open span:first-child { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle.open span:last-child  { transform: translateY(-6.5px) rotate(-45deg); }

/* ── HERO ── */
#hero {
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 9rem 3rem 0;
  position: relative; overflow: hidden;
}
.hero-bg-reel {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: center; gap: 1rem;
  overflow: hidden; pointer-events: none;
}
.reel-strip {
  display: flex; gap: 2rem; white-space: nowrap;
  font-family: var(--font-d);
  font-size: clamp(5rem, 12vw, 10rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(242,237,228,.055);
  letter-spacing: .04em;
}
.reel-1 { animation: reelL 30s linear infinite; }
.reel-2 { animation: reelR 24s linear infinite; }
@keyframes reelL { 0%{transform:translateX(0)}   100%{transform:translateX(-50%)} }
@keyframes reelR { 0%{transform:translateX(-50%)} 100%{transform:translateX(0)} }

.hero-eyebrow {
  display: flex; align-items: center; gap: .65rem;
  font-family: var(--font-m); font-size: .63rem;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 1.5rem;
  position: relative; z-index: 1;
}
.avail-dot {
  display: inline-block; width: 7px; height: 7px;
  border-radius: 50%; background: #4caf50;
  box-shadow: 0 0 8px #4caf50;
  animation: pulseGreen 2.2s ease-in-out infinite;
}
@keyframes pulseGreen { 0%,100%{box-shadow:0 0 6px #4caf50} 50%{box-shadow:0 0 20px #4caf50} }

.hero-title {
  font-family: var(--font-d);
  font-size: clamp(4rem, 13vw, 12rem);
  line-height: .88; letter-spacing: .02em;
  margin-bottom: 3rem; position: relative; z-index: 1;
}
.line-wrap { display: block; overflow: hidden; }
.line { display: block; }
.reveal-line { transform: translateY(110%); animation: slideUp .95s cubic-bezier(.77,0,.18,1) forwards; opacity: 0; }
.line-wrap:nth-child(1) .reveal-line { animation-delay: 1.9s; }
.line-wrap:nth-child(2) .reveal-line { animation-delay: 2.05s; }
.line-wrap:nth-child(3) .reveal-line { animation-delay: 2.2s; }
@keyframes slideUp { to { transform: translateY(0); opacity: 1; } }

.italic-line {
  font-family: var(--font-s); font-style: italic; font-weight: 300;
  font-size: clamp(4.5rem, 14vw, 13rem);
  color: var(--acc); line-height: .85; letter-spacing: .01em;
}
.stroke-line { -webkit-text-stroke: 2px var(--fg); color: transparent; }

.hero-content { position: relative; z-index: 1; }
.hero-bottom {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 2rem;
  padding: 2rem 0;
  border-top: 1px solid var(--border);
}
.hero-desc {
  font-family: var(--font-c); font-weight: 300; font-size: 1rem;
  color: var(--muted); line-height: 1.75; max-width: 480px; letter-spacing: .03em;
}

/* ── BUTTONS ── */
.btn-primary {
  display: inline-flex; align-items: center; gap: .75rem;
  padding: 1rem 2.2rem; white-space: nowrap;
  font-family: var(--font-d); font-size: 1.15rem; letter-spacing: .1em;
  background: var(--fg); color: var(--bg);
  transition: background .25s, color .25s, gap .2s;
}
.btn-primary:hover { background: var(--acc); color: #fff; gap: 1.1rem; }
.btn-primary svg { transition: transform .2s; }
.btn-primary:hover svg { transform: translateX(4px); }

.btn-white {
  display: inline-flex; align-items: center; gap: .75rem;
  padding: 1rem 2.2rem; white-space: nowrap;
  font-family: var(--font-d); font-size: 1.15rem; letter-spacing: .1em;
  background: #fff; color: var(--acc);
  transition: background .25s, color .25s, gap .2s;
}
.btn-white:hover { background: var(--bg); color: var(--fg); gap: 1.1rem; }

/* ── HERO STATS ── */
.hero-stats {
  display: flex; border-top: 1px solid var(--border);
  position: relative; z-index: 1;
}
.stat-item {
  flex: 1; padding: 1.5rem 2rem;
  display: flex; flex-wrap: wrap; align-items: baseline; gap: .2rem;
}
.stat-num { font-family: var(--font-d); font-size: clamp(2.5rem,5vw,4rem); line-height: 1; }
.stat-unit { font-family: var(--font-d); font-size: 1.3rem; color: var(--acc); }
.stat-label {
  width: 100%; font-family: var(--font-m); font-size: .57rem;
  letter-spacing: .2em; text-transform: uppercase; color: var(--muted); margin-top: .2rem;
}
.stat-divider { width: 1px; background: var(--border); align-self: stretch; flex-shrink: 0; }

/* ── MARQUEE ── */
.marquee-band {
  overflow: hidden; background: var(--acc);
  border-top: 1px solid rgba(0,0,0,.15);
  border-bottom: 1px solid rgba(0,0,0,.15);
  padding: .65rem 0;
}
.marquee-track { display: flex; animation: marquee 20s linear infinite; white-space: nowrap; }
.marquee-track span { font-family: var(--font-d); font-size: 1.1rem; letter-spacing: .2em; color: #fff; padding: 0 2rem; }
.marquee-track .sep { color: rgba(255,255,255,.4); padding: 0 .25rem; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── SECTIONS ── */
.section { padding: 8rem 3rem; }
.section--dark { background: var(--bg2); }
.section--accent { background: var(--acc); }

.section-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 1.5rem;
  margin-bottom: 4rem;
  padding-bottom: 2rem; border-bottom: 1px solid var(--border);
}
.section--accent .section-header { border-color: rgba(255,255,255,.2); }

.section-label {
  font-family: var(--font-m); font-size: .62rem;
  letter-spacing: .25em; text-transform: uppercase;
  color: var(--acc); margin-bottom: .6rem;
  display: flex; align-items: center; gap: .75rem;
}
.section-label::before { content:''; width: 22px; height: 1.5px; background: currentColor; }
.section-title {
  font-family: var(--font-d);
  font-size: clamp(3rem, 6vw, 5.5rem); line-height: .92; letter-spacing: .04em;
}
.section-title em {
  font-family: var(--font-s); font-style: italic; font-weight: 300;
  color: var(--acc); letter-spacing: .02em;
}
.section-sub {
  font-family: var(--font-c); font-weight: 300; font-size: .95rem;
  color: var(--muted); line-height: 1.75; max-width: 300px; letter-spacing: .03em;
}

/* ── FILTER TABS ── */
.filter-tabs { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 3rem; }
.tab {
  font-family: var(--font-c); font-size: .72rem;
  letter-spacing: .2em; text-transform: uppercase; font-weight: 600;
  padding: .55rem 1.4rem;
  border: 1.5px solid var(--border);
  background: transparent; color: var(--muted);
  cursor: none; transition: border-color .2s, color .2s, background .2s;
}
.tab:hover { border-color: var(--muted); color: var(--fg); }
.tab.active { border-color: var(--acc); background: var(--acc); color: #fff; }

/* ── WORK GRID ── */
.work-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5px; background: var(--border);
}
.work-card { background: var(--bg); overflow: hidden; cursor: none; }
.work-card--wide { grid-column: span 2; }
.work-card.hidden { display: none; }

.work-thumb {
  position: relative; aspect-ratio: 4/3;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  overflow: hidden;
}
.work-card--wide .work-thumb { aspect-ratio: 16/7; }
.photo-thumb { cursor: default; }

.thumb-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(8,8,7,.85) 0%, rgba(8,8,7,.1) 60%, transparent 100%);
  opacity: 0; transition: opacity .4s;
}
.work-card:hover .thumb-overlay { opacity: 1; }

/* play button */
.play-btn {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%) scale(.85);
  width: 64px; height: 64px;
  opacity: 0; transition: opacity .35s, transform .35s;
}
.play-btn svg { width: 64px; height: 64px; }
.work-card:hover .play-btn { opacity: 1; transform: translate(-50%,-50%) scale(1); }

/* photo icon */
.photo-icon {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  opacity: 0; transition: opacity .35s;
}
.work-card:hover .photo-icon { opacity: .9; }

.work-cat-tag {
  position: absolute; top: 1rem; left: 1rem;
  font-family: var(--font-m); font-size: .57rem;
  letter-spacing: .18em; text-transform: uppercase;
  padding: .32rem .75rem;
  background: rgba(8,8,7,.8); border: 1px solid var(--border);
  color: var(--muted); backdrop-filter: blur(4px);
  transition: color .2s, border-color .2s;
}
.work-card:hover .work-cat-tag { color: var(--acc); border-color: var(--acc); }

.work-info {
  padding: 1.3rem 1.5rem 1.5rem;
  border-top: 1px solid var(--border);
}
.work-title {
  font-family: var(--font-d); font-size: 1.3rem; letter-spacing: .06em;
  margin-bottom: .3rem; transition: color .2s;
}
.work-card:hover .work-title { color: var(--acc); }
.work-sub { font-family: var(--font-m); font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }

/* ── SERVICES ── */
.services-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.5px; background: var(--border); }
.service-card {
  background: var(--bg2); padding: 3.5rem;
  display: flex; gap: 2rem;
  position: relative; overflow: hidden;
  transition: background .3s;
}
.service-card::before {
  content:''; position: absolute; top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--acc); transform: scaleX(0); transform-origin: left;
  transition: transform .45s cubic-bezier(.77,0,.18,1);
}
.service-card:hover::before { transform: scaleX(1); }
.service-card:hover { background: #141413; }
.service-num {
  font-family: var(--font-d); font-size: 4.5rem; line-height: 1;
  color: var(--border); flex-shrink: 0; transition: color .3s;
}
.service-card:hover .service-num { color: var(--acc); opacity: .4; }
.service-name { font-family: var(--font-d); font-size: 1.9rem; letter-spacing: .05em; margin-bottom: .9rem; }
.service-desc { font-family: var(--font-c); font-weight: 300; font-size: .9rem; color: var(--muted); line-height: 1.85; margin-bottom: 1.2rem; }
.service-list { list-style: none; display: flex; flex-direction: column; gap: .35rem; }
.service-list li {
  font-family: var(--font-m); font-size: .6rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--muted); padding-left: 1rem; position: relative; transition: color .2s;
}
.service-list li::before { content:'—'; position: absolute; left: 0; color: var(--acc); }
.service-card:hover .service-list li { color: var(--cream); }

/* ── ABOUT ── */
.about-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: start; }
.about-title {
  font-family: var(--font-d); font-size: clamp(2.8rem,5vw,4.8rem);
  line-height: .9; letter-spacing: .03em; margin: 1.2rem 0 2rem;
}
.about-title em { font-family: var(--font-s); font-style: italic; font-weight: 300; color: var(--acc); }
.about-accent-line { width: 56px; height: 3px; background: var(--acc); }
.about-lead { font-family: var(--font-s); font-style: italic; font-weight: 300; font-size: 1.35rem; line-height: 1.65; color: var(--cream); margin-bottom: 1.5rem; }
.about-body { font-family: var(--font-c); font-weight: 300; font-size: .9rem; color: var(--muted); line-height: 1.9; margin-bottom: 1.1rem; }
.about-body strong { color: var(--fg); font-weight: 600; }
.about-pills { display: flex; flex-wrap: wrap; gap: .4rem; margin: 1.8rem 0; }
.about-pills span {
  font-family: var(--font-m); font-size: .57rem; letter-spacing: .15em; text-transform: uppercase;
  padding: .38rem 1rem; border: 1px solid var(--border); color: var(--muted);
  transition: border-color .2s, color .2s;
}
.about-pills span:hover { border-color: var(--acc); color: var(--acc); }
.about-socials { display: flex; gap: 1.5rem; margin-top: 2rem; flex-wrap: wrap; }
.social-link {
  display: flex; align-items: center; gap: .5rem;
  font-family: var(--font-m); font-size: .63rem; letter-spacing: .12em;
  color: var(--muted); border-bottom: 1px solid var(--border); padding-bottom: .25rem;
  transition: color .2s, border-color .2s;
}
.social-link:hover { color: var(--acc); border-color: var(--acc); }

/* ── CONTACT ── */
.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; }
.contact-title {
  font-family: var(--font-d); font-size: clamp(3rem, 7vw, 6.5rem);
  line-height: .88; letter-spacing: .03em; color: #fff; margin-top: 1rem;
}
.contact-title em { font-family: var(--font-s); font-style: italic; font-weight: 300; color: rgba(255,255,255,.6); }
.contact-details { display: flex; flex-direction: column; gap: 0; margin-bottom: 2.5rem; }
.contact-item {
  display: flex; flex-direction: column; gap: .2rem;
  padding: 1.2rem 0; border-bottom: 1px solid rgba(255,255,255,.15);
  transition: padding-left .25s;
}
a.contact-item:hover { padding-left: .75rem; }
.contact-item-label { font-family: var(--font-m); font-size: .56rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.4); }
.contact-item-val { font-family: var(--font-d); font-size: 1.6rem; letter-spacing: .05em; color: #fff; }

/* ── FOOTER ── */
footer { padding: 2.5rem 3rem; border-top: 1px solid var(--border); }
.footer-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.footer-logo { font-family: var(--font-d); font-size: 1.5rem; letter-spacing: .1em; }
.footer-logo .acc { color: var(--acc); }
.footer-copy { font-family: var(--font-m); font-size: .57rem; letter-spacing: .12em; color: var(--muted); }
.footer-links { display: flex; gap: 1.5rem; }
.footer-links a {
  font-family: var(--font-m); font-size: .6rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--muted); border-bottom: 1px solid transparent;
  transition: color .2s, border-color .2s;
}
.footer-links a:hover { color: var(--acc); border-color: var(--acc); }

/* ── REVEAL ── */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .75s ease, transform .75s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ── MOBILE ── */
@media (max-width: 960px) {
  #nav { padding: 1.2rem 1.5rem; }
  .nav-toggle { display: flex; }
  .nav-links {
    display: none; flex-direction: column; gap: 2rem;
    position: fixed; inset: 0;
    background: #080807;
    padding: 7rem 2rem 3rem;
    align-items: flex-start; z-index: 490;
  }
  .nav-links.open { display: flex; background: #080807; }
  .nav-link { font-size: 1.1rem; }
  #hero { padding: 7rem 1.5rem 0; }
  .hero-stats { flex-wrap: wrap; }
  .stat-divider { display: none; }
  .stat-item { flex: 1 1 40%; }
  .hero-bottom { flex-direction: column; align-items: flex-start; }
  .section { padding: 5rem 1.5rem; }
  .section-header { flex-direction: column; align-items: flex-start; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .work-card--wide { grid-column: span 2; }
  .services-grid { grid-template-columns: 1fr; }
  .service-card { flex-direction: column; gap: 1rem; padding: 2.5rem; }
  .service-num { font-size: 3rem; }
  .about-layout { grid-template-columns: 1fr; gap: 3rem; }
  .contact-layout { grid-template-columns: 1fr; gap: 3rem; }
  footer { padding: 2rem 1.5rem; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 540px) {
  .work-grid { grid-template-columns: 1fr; }
  .work-card--wide { grid-column: span 1; }
  .work-card--wide .work-thumb { aspect-ratio: 4/3; }
  #lightbox-box { width: 96vw; }
  #lightbox-info { flex-direction: column; gap: .3rem; }
}

/* ── CONTACT FORM ── */
.contact-form { display: flex; flex-direction: column; gap: 1rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: .4rem; }
.form-group label {
  font-family: var(--font-m); font-size: .55rem;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.45);
}
.form-group input,
.form-group select,
.form-group textarea {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  font-family: var(--font-c); font-size: 1rem; font-weight: 300;
  padding: .85rem 1rem;
  outline: none; width: 100%;
  transition: border-color .2s, background .2s;
  appearance: none; -webkit-appearance: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: rgba(255,255,255,.3); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.12);
}
.form-group select option { background: #1a1a18; color: #fff; }
.form-group textarea { resize: vertical; min-height: 110px; }
.form-submit {
  display: inline-flex; align-items: center; gap: .75rem;
  padding: 1rem 2.2rem; align-self: flex-start;
  font-family: var(--font-d); font-size: 1.15rem; letter-spacing: .1em;
  background: #fff; color: var(--acc); border: none;
  cursor: none; transition: background .25s, color .25s, gap .2s;
}
.form-submit:hover { background: var(--bg); color: var(--fg); gap: 1.1rem; }
.form-submit svg { transition: transform .2s; }
.form-submit:hover svg { transform: translateX(4px); }
.form-success {
  display: none; padding: 2rem 0;
  font-family: var(--font-d); font-size: 1.8rem; letter-spacing: .05em; color: #fff;
}
.form-success span { display: block; font-family: var(--font-m); font-size: .65rem; letter-spacing: .15em; color: rgba(255,255,255,.5); margin-top: .5rem; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }
