:root {
  --black: #000;
  --white: #fff;
  --gray-dark: #111;
  --fg: #0ea5e9;
  --muted: #a3a3a3;
  --border: rgba(255, 255, 255, .12);
  --radius: 16px;
  --maxw: 1200px;
  --purple: #a855f7;
  --blue: #3b82f6;
  --green: #22c55e;
  --glow: #a855f7;
}

/* Base */
html {
  background: linear-gradient(135deg, var(--black), var(--gray-dark));
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--white);
  overflow-x: hidden;
  min-height: 100vh;
  position: relative;
}

:focus-visible {
  outline: 2px solid var(--fg);
  outline-offset: 2px;
  border-radius: 6px;
}

/* Nav */
.nav {
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(6px);
  background: linear-gradient(to bottom, rgba(0, 0, 0, .65), rgba(0, 0, 0, .25));
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1.5rem;
}

.nav .brand {
  font-weight: 800;
  letter-spacing: .5px;
}

.nav a {
  color: #fff;
  text-decoration: none;
  opacity: .85;
}

.nav .links {
  display: flex;
  gap: 1rem;
  align-items: center;
}


/* Sections (do NOT touch .formular) */
section:not(.formular) {
  width: 100vw;
  min-height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  position: relative;
}

.section-inner {
  max-width: var(--maxw);
  padding: 2rem;
  text-align: center;
  margin-inline: auto;
}

/* Hero */
.hero {
  display: grid;
  place-items: center;
  text-align: center;
  position: relative;
  isolation: isolate;
}

.hero-text {
  display: grid;
  gap: 1.25rem;
  place-items: center;
}

.agency-name {
  font-size: clamp(3rem, 12vw, 10rem);
  font-weight: 900;
  margin: 0 auto;
  line-height: 1;
  color: #fff;
  position: relative;
  display: inline-block;
  overflow: hidden;
  letter-spacing: -.04em;
}

.agency-name::before {
  content: "UPLYNE";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, var(--glow) 50%, transparent 70%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: name-shine 6s infinite linear reverse;
}

@keyframes name-shine {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.agency-slogan {
  font-family: 'Great Vibes', cursive;
  font-size: clamp(1.5rem, 4vw, 3rem);
  margin: .25rem auto 1.5rem;
  color: #e5e5e5;
  letter-spacing: 1px;
}

.agency-name,
.agency-slogan {
  transition: transform .1s linear, opacity .1s linear;
  transform-origin: center center;
  will-change: transform, opacity;
}

h2 {
  font-size: clamp(28px, 5vw, 42px);
  margin: 0 0 16px;
  letter-spacing: .5px;
}

p {
  color: #ddd;
  line-height: 1.7;
  margin: 0 auto;
  max-width: 65ch;
}

/* Work grid (scoped to #work only, so it won't hit .formular .row) */
#work .row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
  text-align: left;
}

#work .row + .row { margin-top: 56px; }

@media (min-width: 768px) {
  #work .row { grid-template-columns: 1fr 1fr; }
  #work .row.alt .media { order: 2; }
  #work .row.alt .copy  { order: 1; }
}

#work .thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: 0 10px 40px rgba(0, 0, 0, .25);
  border: 1px solid var(--border);
}

#work .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform .6s ease;
}

#work .thumb:hover img { transform: scale(1.05); }

#work .play-pill {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

#work .play-pill button {
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(6px);
  cursor: pointer;
  font-weight: 700;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .25);
}

#work .copy h3 {
  font-size: clamp(20px, 3.2vw, 28px);
  margin: 0;
}

#work .copy p {
  margin: 10px 0 0;
  color: #cfcfcf;
}

/* Utility */
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid var(--fg);
  background: var(--fg);
  color: #fff;
  font-size: 14px;
  cursor: pointer;
}
.btn.secondary { background: transparent; color: #fff; border-color: #fff; }
.btn:hover { opacity: .9; }

.muted { color: var(--muted); }

/* Reveal helper */
[data-reveal] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal-visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Modal */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .75);
  display: grid;
  place-items: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
  z-index: 20;
  padding: 2rem;
}
.modal.open { opacity: 1; pointer-events: auto; }

.modal-dialog {
  width: min(100%, 900px);
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 10px 40px rgba(0, 0, 0, .5);
  border: 1px solid var(--border);
}
.modal video { width: 100%; height: 100%; display: block; }

.modal .close {
  position: absolute;
  top: 8px;
  right: 8px;
  border: 0;
  background: rgba(255, 255, 255, .9);
  border-radius: 999px;
  width: 40px;
  height: 40px;
  font-size: 20px;
  font-weight: 900;
  display: grid;
  place-items: center;
  cursor: pointer;
}

/* Footer */
footer {
  border-top: 1px solid var(--border);
  padding: 24px;
  text-align: center;
  color: #cfcfcf;
}

/* Motion prefs */
@media (prefers-reduced-motion: reduce) {
  .shine-overlay,
  .agency-name::before { animation: none; }
  .agency-name,
  .agency-slogan { transition: none; }
}

/* Dimmer */
[data-fade] {
  transition: opacity .2s linear, transform .2s linear;
  will-change: opacity, transform;
}

/* Work anchor offset (safe) */
section#work { scroll-margin-top: 2rem; }

/* Center the Work CTA under the content */
#work .section-cta {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

/* =========================
   RESPONSIVE HEADER (MOBILE TOGGLE)
   Paste at the END of style.css
   ========================= */

/* Optional: make brand look like a logo */
.nav .brand {
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* Hamburger button (hidden on desktop) */
.nav .nav-toggle {
  display: none;
  appearance: none;
  border: 1px solid var(--border);
  background: rgba(0, 0, 0, .25);
  color: #fff;
  border-radius: 12px;
  padding: 10px 12px;
  cursor: pointer;
  line-height: 0;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(6px);
}

/* Hamburger icon lines */
.nav .nav-toggle .bar {
  display: block;
  width: 22px;
  height: 2px;
  background: #fff;
  border-radius: 999px;
  position: relative;
  opacity: .92;
}

.nav .nav-toggle .bar::before,
.nav .nav-toggle .bar::after {
  content: "";
  position: absolute;
  left: 0;
  width: 22px;
  height: 2px;
  background: #fff;
  border-radius: 999px;
  opacity: .92;
}

.nav .nav-toggle .bar::before { top: -7px; }
.nav .nav-toggle .bar::after  { top: 7px; }

/* Mobile breakpoint */
@media (max-width: 820px) {
  /* Keep header compact */
  .nav {
    padding: .75rem 1rem;
  }

  /* Show burger */
  .nav .nav-toggle {
    display: inline-flex;
  }

  /* Turn the links nav into a dropdown panel */
  .nav .links {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    display: grid;
    gap: 10px;
    padding: 14px 16px;

    background: linear-gradient(to bottom, rgba(0, 0, 0, .92), rgba(0, 0, 0, .72));
    border-bottom: 1px solid var(--border);
    backdrop-filter: blur(10px);

    transform: translateY(-8px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease, transform .2s ease;
  }

  /* Make links tap-friendly */
  .nav .links a {
    padding: 12px 10px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, .08);
    background: rgba(255, 255, 255, .03);
    opacity: .95;
  }

  .nav .links a:active {
    transform: scale(.99);
  }

  /* When open */
  .nav.is-open .links {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* Animate burger -> X when open */
  .nav.is-open .nav-toggle .bar {
    background: transparent;
  }
  .nav.is-open .nav-toggle .bar::before {
    top: 0;
    transform: rotate(45deg);
  }
  .nav.is-open .nav-toggle .bar::after {
    top: 0;
    transform: rotate(-45deg);
  }
}

/* Desktop: keep normal links */
@media (min-width: 821px) {
  .nav .links {
    position: static;
    transform: none;
    opacity: 1;
    pointer-events: auto;
    background: none;
    border: 0;
    padding: 0;
    display: flex;
    gap: 1rem;
    align-items: center;
  }
}

@media (max-width: 820px){
  .agency-name {
    font-size: clamp(2.5rem, 20vw, 6rem);
  }
}
@media (max-width: 820px){
  section:not(.formular) {
    padding-block: clamp(-20rem, 1vh, 1rem);
  }
}
