/* =========================================================
   Cinematic Dark + Warm Gold Theme (NFM-inspired)
   ========================================================= */

/* ---------- CSS Variables ---------- */
:root {
  /* Base */
  --bg: #0b0b0c;            /* near-black */
  --bg-2: #121214;          /* secondary panels */
  --surface: #17171a;       /* cards */
  --border: #2a2a2e;

  /* Text */
  --text: #F2F2F2;
  --muted: #A0A0A3;

  /* Accent (bold premium red) */
  --accent:   #C2182B;  /* vibrant crimson */
  --accent-2: #E11D2E;  /* hover/active pop */
  --accent-3: #8E0F22;  /* deep base for gradients */

  /* Utility */
  --danger: #E44545;
  --ok: #3ECF8E;

  /* Header height hint (used by mobile overlay sizing) */
  --header-h: 64px;

  /* Typographic scale */
  --font-sans: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-display: "Cinzel", Georgia, "Times New Roman", serif;
  --step--1: clamp(0.85rem, 0.81rem + 0.2vw, 1rem);
  --step-0:  clamp(1rem,  0.94rem + 0.3vw, 1.2rem);
  --step-1:  clamp(1.25rem, 1.15rem + 0.6vw, 1.6rem);
  --step-2:  clamp(1.6rem, 1.35rem + 1.2vw, 2.2rem);
  --step-3:  clamp(2.1rem, 1.7rem + 2.2vw, 3rem);
  --step-4:  clamp(2.8rem, 2.2rem + 3.2vw, 4.2rem);

  /* Link system palette (single source of truth) */
  --link: white;
  --link-hover: #E11D2E;
  --link-underline: currentColor; /* underline follows text color */

  /* --- Section background palette (subtle steps) --- */
  --section-hero:     #0b0b0c; /* base */
  --section-work:     #0e0e10; /* slightly lifted */
  --section-services: #121214; /* matches --bg-2 */
  --section-about:    #151518; /* between --bg-2 and --surface */
  --section-pricing:  #17171a; /* matches --surface */
  --section-feedback: #0f1012; /* alternate tint */
  --section-cta:      #0b0b0c; /* return to base under gradient */
}

/* ---------- Resets ---------- */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: var(--font-sans); line-height: 1.5; -webkit-font-smoothing: antialiased;
}

/* ---------- Helpers ---------- */
.container { width: min(1200px, 92vw); margin-inline: auto; }
.center { text-align: center; }
.muted { color: var(--muted); }
.eyebrow { color: var(--accent); text-transform: uppercase; letter-spacing: .12em; font-weight: 700; font-size: var(--step--1); }
.section-title { font-size: var(--step-2); font-weight: 800; letter-spacing: -0.02em; }
.display { font-family: var(--font-display); font-weight: 800; font-size: var(--step-4); letter-spacing: .02em; }
.highlight { color: var(--accent-2); }
.underline { position: relative; }
.underline::after {
  content: ""; position: absolute; left: 0; bottom: -.15em; width: 100%; height: .18em;
  background: linear-gradient(90deg, var(--accent-3), var(--accent));
}

/* Subtle film-grain */
.noise {
  pointer-events: none; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,&lt;svg xmlns='http://www.w3.org/2000/svg' width='256' height='256' viewBox='0 0 256 256'&gt;&lt;filter id='n'&gt;&lt;feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch' /&gt;&lt;feColorMatrix type='saturate' values='0' /&gt;&lt;feComponentTransfer&gt;&lt;feFuncA type='table' tableValues='0 0 .05 .08 .12 .08 .05 0' /&gt;&lt;/feComponentTransfer&gt;&lt;/filter&gt;&lt;rect width='100%' height='100%' filter='url(%23n)' opacity='0.18'/&gt;&lt;/svg&gt;");
  opacity: .18; mix-blend-mode: overlay;
}
.vignette { position: absolute; inset: 0; background: radial-gradient(80% 60% at 50% 40%, transparent 0 60%, rgba(0,0,0,.7) 100%); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: .6rem; padding: .8rem 1.1rem; border-radius: 999px;
  font-weight: 700; letter-spacing: .02em; transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  border: 1px solid var(--border); color: var(--text);
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn-accent {
  background: linear-gradient(135deg, var(--accent-3), var(--accent));
  color: #101010; border-color: transparent; text-shadow: 0 1px 0 rgba(255,255,255,.25);
}
.btn-accent:hover { background: linear-gradient(135deg, var(--accent), var(--accent-2)); }

.btn-ghost {
  background: transparent; color: var(--text);
  border-color: var(--border);
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent-2); }

.btn-lg { padding: 1rem 1.4rem; font-size: var(--step-0); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 1000;
  backdrop-filter: blur(8px);
  background: color-mix(in oklab, #000 70%, transparent);
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: background .25s ease, border-color .25s ease, transform .25s ease;
}
.site-header[data-scrolled="true"] {
  background: rgba(10,10,12,.85);
  border-color: rgba(255,255,255,.08);
}

.nav { display: flex; align-items: center; justify-content: space-between; padding: .9rem 0; }
.brand { display: inline-flex; align-items: center; gap: .6rem; color: var(--text); text-decoration: none; font-weight: 800; }
.brand-text { letter-spacing: .2em; }
.brand-mark { display: none; }

/* Logo */
.brand-logo {
  display: block;
  width: 80px;
  height: 80px;
  object-fit: contain;
  filter: drop-shadow(0 0 0 2px rgba(0,0,0,.5));
}

.primary-nav { display: none; gap: 1.2rem; align-items: center; }
.primary-nav a { color: var(--text); text-decoration: none; font-weight: 600; }
.primary-nav a:hover { color: var(--accent-2); }

/* Keep accent buttons white in the header, including hover/focus */
.primary-nav .btn-accent,
.primary-nav .btn-accent:hover,
.primary-nav .btn-accent:focus {
  color: #fff;
}

.nav-toggle { display: inline-flex; flex-direction: column; gap: 4px; background: transparent; border: 0; cursor: pointer; }
.nav-toggle span { width: 22px; height: 2px; background: var(--text); display: block; }

/* lg+ */
@media (min-width: 960px) {
  .primary-nav { display: flex; }
  .nav-toggle { display: none; }
}

/* ---------- Hero ---------- */
.hero { position: relative; min-height: 88vh; display: grid; align-items: center; }
.hero-media { position: absolute; inset: 0; overflow: hidden; }
.hero-video { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.85) contrast(1.05) brightness(0.8); }
.hero-content { position: relative; z-index: 1; padding: 8vh 0; }
.cta-row { display: flex; gap: .8rem; margin-top: 1.2rem; flex-wrap: wrap; }
.meta { margin-top: .8rem; color: var(--muted); display: flex; align-items: center; gap: .6rem; }
.badge { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.07); padding: .25rem .5rem; border-radius: .4rem; }
.hero-scroll-indicator { position: absolute; left: 50%; bottom: 2rem; transform: translateX(-50%); letter-spacing: .3em; font-size: .8rem; color: var(--muted); }

/* ---------- Work / Gallery ---------- */
.work { padding: 4.5rem 0; }

/* ---------- Services ---------- */
.services { padding: 4.5rem 0; }
.service-grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 1rem; }
.service {
  background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 1.1rem;
}
.service h3 { margin-top: 0; }
.service li { color: var(--muted); }

@media (min-width: 900px) { .service-grid { grid-template-columns: repeat(3, 1fr); } }

/* ---------- About ---------- */
.about { padding: 4.5rem 0; }
.about-inner { display: grid; gap: 1.2rem; align-items: center; }
.about-media img { width: 100%; height: auto; border-radius: 16px; border: 1px solid var(--border); display: block; }
.about-copy .stats { display: grid; gap: .4rem; padding: 0; margin: 1rem 0 0; list-style: none; color: var(--muted); }
.about-copy .stats strong { color: var(--accent-2); font-family: var(--font-display); }

@media (min-width: 960px) {
  .about-inner { grid-template-columns: 1.2fr 1fr; }
}

/* ---------- Pricing ---------- */
.pricing { padding: 4.5rem 0; }
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2rem; /* improved spacing */
}

.price-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 1.1rem;
}

.price-card.featured { border-color: color-mix(in oklab, var(--accent) 40%, var(--border)); }

@media (min-width: 900px) {
  .pricing-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ---------- Client Feedback (testimonials) ---------- */
.feedback { padding: 4.5rem 0; }
.testimonial {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.1rem;
  margin-bottom: 1rem;
}
.testimonial blockquote {
  margin: 0 0 .6rem;
  font-size: var(--step-0);
  line-height: 1.6;
}
.testimonial-meta {
  margin: 0;
  color: var(--muted);
  font-size: var(--step--1);
}

/* ---------- CTA ---------- */
.cta { 
  padding: 5rem 0;
  /* keep your gradient but anchor it to the section base color for consistency */
  background:
    radial-gradient(60% 80% at 50% 40%, rgba(255,215,130,.08), transparent 60%),
    linear-gradient(180deg, transparent, rgba(255,215,130,.03)),
    var(--section-cta);
}

/* Fix: center the contact buttons row */
#contact .cta-row {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

/* ---------- Footer ---------- */
.site-footer { padding: 2.2rem 0; border-top: 1px solid rgba(255,255,255,.07); background: var(--bg-2); }
.footer-nav { display: flex; gap: 1rem; flex-wrap: wrap; }
.footer-nav a { color: var(--muted); text-decoration: none; }
.footer-nav a:hover { color: var(--accent-2); }

/* Footer columns: brand | explore | legal | social */
.footer-grid {
  display: grid;
  gap: 1rem;
  align-items: start;
  grid-template-columns: 1.7fr 1fr 1fr 1fr 1fr; /* Controls spacing of the columns in footer */
}

.site-footer .tagline {
  margin-top: .25rem;
  color: var(--muted);
  opacity: .8;
  font-size: var(--step--1);
}

/* Manipulates Company name (only top left section) next to logo -- Footer section */
.footer-brand {
  display: flex;
  align-items: center;
  gap: 0.5rem; /* space between logo and name */
}

.footer-logo {
  height: 80px; /* adjust to match your footer */
  width: auto;
}

.footer-company-name {
  font-size: 1rem;
  font-weight: 500;
  color: #e5e7eb; /* light gray for dark footer */
  letter-spacing: 0.02em;
}

/* Stack columns on small screens */
@media (max-width: 800px) {
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
}

/* ---------- SR-only helper ---------- */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  border: 0; white-space: nowrap;
}

/* =========================================================
   GLOBAL LINK NORMALIZATION (final, single source of truth)
   ========================================================= */

/* Baseline: make :link and :visited identical (LVHA order) */
a:link,
a:visited {
  color: var(--link);
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-color: var(--link-underline);
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1px;
  transition:
    color 0.15s ease,
    text-decoration-color 0.15s ease;
  cursor: pointer;
}

/* Hover/active/focus feedback */
a:hover,
a:active,
a:focus-visible {
  color: var(--link-hover);
  text-decoration-color: currentColor;
}

/* Button-like anchors should NOT look like links */
a.btn,
a.btn-ghost,
a.btn-accent {
  color: inherit;
  text-decoration: none !important;
}

/* Accessible focus ring */
a:focus-visible {
  outline: 2px solid color-mix(in oklab, var(--link-hover) 65%, #ffffff 10%);
  outline-offset: 2px;
  border-radius: 4px;
}

/* Header navigation — neutral at rest, brand on hover; no special visited color */
.primary-nav a {
  color: var(--text);
  text-decoration: none; /* nav shouldn't be underlined at rest */
}
.primary-nav a:hover,
.primary-nav a:focus-visible {
  color: var(--link-hover);
  text-decoration: underline;
  text-decoration-color: var(--link-hover);
  text-underline-offset: 0.18em;
}
/* remove any prior visited-only nav color rules */
.site-header .primary-nav a:not(.btn):not(.btn-accent):not(.btn-ghost):link,
.site-header .primary-nav a:not(.btn):not(.btn-accent):not(.btn-ghost):visited {
  color: var(--text);
  text-decoration: none;
}

/* Footer links — muted at rest, brand on hover (still underlined) */
.site-footer nav a:link,
.site-footer nav a:visited {
  color: var(--muted);
  text-decoration-line: underline;
  text-decoration-color: rgba(255,255,255,0.20);
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1px;
}
.site-footer nav a:hover,
.site-footer nav a:focus-visible {
  color: var(--link-hover);
  text-decoration-color: currentColor;
}

/* Inline CTA (e.g., “Learn more →”) — slightly stronger affordance */
.text-link:link,
.text-link:visited {
  color: var(--link);
  font-weight: 600;
  text-decoration-line: underline;
  text-decoration-color: color-mix(in oklab, var(--link) 40%, #ffffff 5%);
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1.5px;
  transition:
    color 0.15s ease,
    text-decoration-color 0.15s ease;
}
.text-link:hover,
.text-link:focus-visible {
  color: var(--link-hover);
  text-decoration-color: currentColor;
  text-decoration-thickness: 2px;
}
.text-link::after {
  content: " →";
  transition: transform .15s ease;
}
.text-link:hover::after,
.text-link:focus-visible::after {
  transform: translateX(2px);
}

/* =========================================================
   ADDITIONS: Mobile menu open state + backlink/divider + flatten buttons
   ========================================================= */

/* === Mobile menu open state === */
@media (max-width: 959px) {
  /* lock scroll when nav is open */
  body.nav-open {
    overflow: hidden;
  }

  /* anchor dropdown to header container */
  .site-header .container.nav {
    position: relative;
  }

  body.nav-open #site-menu {
    display: flex;                 /* override the default display:none */
    position: absolute;
    top: 100%;                     /* directly below the header container */
    left: 0;
    right: 0;
    flex-direction: column;
    gap: 0.75rem;
    padding: 0.75rem 1rem 1rem;
    background: rgba(10,10,12,0.96);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    z-index: 1001;                 /* above page content */
  }

  /* touch-friendly link spacing */
  body.nav-open #site-menu a {
    padding: 0.25rem 0;
  }
}

/* Flatten button-style links in the primary nav on mobile */
@media (max-width: 959px) {
  .site-header .primary-nav a.btn,
  .site-header .primary-nav a.btn-accent,
  .site-header .primary-nav a.btn-ghost {
    background: transparent !important;
    border: 0 !important;
    color: var(--text) !important;
    text-decoration: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
  }
  .site-header .primary-nav a.btn:hover,
  .site-header .primary-nav a.btn-accent:hover,
  .site-header .primary-nav a.btn-ghost:hover {
    color: var(--link-hover) !important;
    text-decoration: underline !important;
    text-decoration-color: var(--link-hover) !important;
  }
}

/* Backlink + divider styling (appears only on mobile) */
.site-header .primary-nav .nav-backlink {
  color: var(--muted);
  text-decoration: none;
  font-weight: 600;
  display: inline-block;
}
.site-header .primary-nav .nav-backlink:hover,
.site-header .primary-nav .nav-backlink:focus-visible {
  color: var(--link-hover);
  text-decoration: underline;
  text-decoration-color: var(--link-hover);
  text-underline-offset: 0.18em;
}

/* Divider line in the dropdown */
.site-header .primary-nav .nav-divider {
  width: 100%;
  border: 0;
  border-top: 1px solid rgba(255,255,255,0.12);
  margin: 0.5rem 0 0.75rem;
}

/* Show backlink/divider ONLY on mobile */
@media (min-width: 960px) {
  .site-header .primary-nav .mobile-only {
    display: none !important;
  }
}

/* Optional: hamburger bars animate into an “X” when open */
@media (max-width: 959px) {
  .nav-toggle span {
    transition: transform .2s ease, opacity .2s ease;
  }
  /* Only affect the last 3 spans (the bars), not the sr-only label */
  .nav-toggle span:nth-last-of-type(3),
  .nav-toggle span:nth-last-of-type(2),
  .nav-toggle span:nth-last-of-type(1) {
    display: block;
  }
  body.nav-open .nav-toggle[aria-expanded="true"] span:nth-last-of-type(2) {
    opacity: 0; /* middle bar fades */
  }
  body.nav-open .nav-toggle[aria-expanded="true"] span:nth-last-of-type(3) {
    transform: translateY(6px) rotate(45deg);
  }
  body.nav-open .nav-toggle[aria-expanded="true"] span:nth-last-of-type(1) {
    transform: translateY(-6px) rotate(-45deg);
  }
}

.is-hidden { display: none !important; } /* For JS show/hide functionality */


/* =========================================================
   SECTION-BASED BACKGROUND APPLICATION + POLISH
   ========================================================= */

/* Apply to existing sections */
.hero     { background: var(--section-hero); }
.work     { background: var(--section-work); }
.services { background: var(--section-services); }
.about    { background: var(--section-about); }
.pricing  { background: var(--section-pricing); }
.feedback { background: var(--section-feedback); }
/* .cta background is defined above to include the gradient + base */

/* Optional: section separator treatment */
.section { position: relative; }
.section + .section::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.06),
    rgba(255,255,255,.02) 30%,
    transparent 60%
  );
  pointer-events: none;
  opacity: .8;
}

/* Optional: gentle transition polish */
section { transition: background-color .4s ease; will-change: background-color; }

/* Optional utilities for manual alternation if needed */
.bg-1 { background: #0c0c0e; }
.bg-2 { background: #101014; }
.bg-3 { background: #121214; }
.bg-4 { background: #151518; }
.bg-5 { background: #17171a; }

/* Expand home business page section to full width if prods/srvc only one -- else, adjust to columns */
/* Keep your grid responsive */
.services .service-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

/* When only one service card is visible, center the grid content */
.services .service-grid:has(> .service:only-child) {
  justify-content: center;  /* centers the grid item */
}

/* --- Auto-sized card rules --- */
.services .service-grid > .service.service--autosize {
  /* override any theme rule that forces width:100% */
  width: auto !important;
  max-width: none;
  justify-self: center;                 /* center the card in the grid cell */
  inline-size: fit-content;             /* shrink to content width */
  max-inline-size: min(72ch, 92vw);     /* readable cap + mobile safety */
  margin-inline: auto;                  /* extra safety in non-grid fallbacks */
}

/* Make inner content respect the same readable width */
.services .service-grid > .service.service--autosize .service-list {
  max-inline-size: 72ch;
}

/* Tidy list spacing/appearance */
.bundles .bundle-item { margin-top: 1.1rem; }
.bundles .bundle-item:first-child { margin-top: 0; }
.bundles .sub {
  display: block;
  margin-top: 0.25rem;
  color: var(--text-muted, #9aa3ab);
  font-size: 0.95em;
  line-height: 1.45;
}