/* ════════════════════════════════════════════════════════════
   OzSaaS Master — shared site styles (nav, footer, shell, tokens)
   Brand: deep forest green + rich gold gradient (from logo)
   ════════════════════════════════════════════════════════════ */
:root {
  --g950: #060E0A;
  --g900: #0B1912;
  --g800: #10241A;
  --g700: #163022;
  --g600: #1C3D2C;
  --g500: #245038;
  --gold-deep:  #9B6F0E;
  --gold-main:  #C8971A;
  --gold-mid:   #DCA93A;
  --gold-light: #ECC55A;
  --gold-pale:  #F5DC8A;
  --white:      #FFFFFF;
  --cream:      #F8F7F4;
  --cream2:     #F1F0EC;
  --neutral-100:#E8E7E3;
  --neutral-200:#D4D2CC;
  --neutral-500:#7A7872;
  --neutral-700:#3D3C39;
  --neutral-900:#1A1918;

  --grad-gold:  linear-gradient(135deg, #ECC55A 0%, #C8971A 45%, #9B6F0E 100%);
  --grad-hero:  radial-gradient(ellipse 90% 80% at 65% 20%, #1C4030 0%, #0F2218 50%, #060E0A 100%);
  --grad-dark:  linear-gradient(160deg, #10241A 0%, #060E0A 100%);

  --font-d: 'Space Grotesk', system-ui, sans-serif;
  --font-b: 'Inter', system-ui, sans-serif;
  --font-m: 'JetBrains Mono', monospace;

  --r-sm: 8px;  --r-md: 12px;  --r-lg: 16px;
  --r-xl: 22px; --r-2xl: 32px; --r-pill: 999px;

  --sh-xs: 0 1px 3px rgba(0,0,0,.07);
  --sh-sm: 0 2px 8px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --sh-md: 0 6px 20px rgba(0,0,0,.10),0 2px 6px rgba(0,0,0,.05);
  --sh-lg: 0 16px 48px rgba(0,0,0,.13),0 4px 12px rgba(0,0,0,.06);
  --sh-gold: 0 8px 28px rgba(200,151,26,.30);
  --sh-gold-lg: 0 14px 44px rgba(200,151,26,.40);

  --ease: cubic-bezier(.22,.61,.36,1);
  --dur: 200ms;

  --max-w: 1160px;
  --px: clamp(20px, 5vw, 72px);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-b);
  background: var(--white);
  color: var(--neutral-900);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
a { text-decoration: none; }

/* ─── NAV ───────────────────────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  padding: 14px var(--px);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  background: rgba(6,14,10,.88);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.nav-logo img { height: 44px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 28px; list-style: none; }
.nav-links a {
  font-size: 14px; font-weight: 500; letter-spacing: .01em;
  color: rgba(255,255,255,.62);
  transition: color var(--dur) var(--ease);
}
.nav-links a:hover, .nav-links a.active { color: var(--white); }
.nav-cta {
  font-family: var(--font-d); font-size: 14px; font-weight: 700;
  padding: 10px 22px; border-radius: var(--r-pill);
  background: var(--grad-gold); color: var(--g900);
  box-shadow: var(--sh-gold);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur);
  white-space: nowrap;
}
.nav-cta:hover { transform: translateY(-1px); box-shadow: var(--sh-gold-lg); }

/* Mobile menu toggle (hidden on desktop) */
.nav-toggle {
  display: none;
  flex-direction: column; align-items: center; justify-content: center; gap: 5px;
  width: 42px; height: 42px; padding: 0;
  border: 1px solid rgba(255,255,255,.14); border-radius: var(--r-md);
  background: rgba(255,255,255,.04); cursor: pointer;
}
.nav-toggle span {
  display: block; width: 20px; height: 2px; border-radius: 2px;
  background: rgba(255,255,255,.85);
  transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ─── BUTTONS ───────────────────────────────────────────── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-d); font-weight: 700; font-size: 16px;
  padding: 16px 32px; border-radius: var(--r-lg);
  background: var(--grad-gold); color: var(--g900);
  box-shadow: var(--sh-gold);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: var(--sh-gold-lg); }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-d); font-weight: 600; font-size: 15px;
  padding: 15px 26px; border-radius: var(--r-lg);
  color: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.18);
  transition: border-color var(--dur), background var(--dur);
}
.btn-ghost:hover { border-color: rgba(255,255,255,.38); background: rgba(255,255,255,.05); }

/* ─── PAGE HERO (inner pages) ───────────────────────────── */
.page-hero {
  background: var(--grad-hero);
  padding: 150px var(--px) 80px;
  position: relative; overflow: hidden;
}
.page-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px);
  background-size: 72px 72px;
}
.page-hero::after {
  content: ''; position: absolute; top: -160px; right: -80px;
  width: 720px; height: 720px;
  background: radial-gradient(circle, rgba(200,151,26,.13) 0%, transparent 68%);
  pointer-events: none;
}
.page-hero-inner { max-width: var(--max-w); margin: 0 auto; position: relative; z-index: 1; }
.breadcrumb {
  font-family: var(--font-m); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: rgba(255,255,255,.4);
  display: flex; align-items: center; gap: 8px; margin-bottom: 26px;
}
.breadcrumb a { color: var(--gold-mid); transition: color var(--dur); }
.breadcrumb a:hover { color: var(--gold-light); }
.breadcrumb .sep { color: rgba(255,255,255,.25); }
.eyebrow {
  font-family: var(--font-m); font-size: 11px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold-mid);
  display: flex; align-items: center; gap: 10px; margin-bottom: 20px;
}
.eyebrow-line { display: inline-block; width: 28px; height: 1px; background: var(--gold-mid); flex-shrink: 0; }
.page-h1 {
  font-family: var(--font-d); font-weight: 700;
  font-size: clamp(38px, 5.4vw, 70px);
  line-height: 1.06; letter-spacing: -.03em;
  color: var(--white); max-width: 880px; margin-bottom: 22px;
}
.page-h1 .gold-txt {
  background: var(--grad-gold);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.page-lead {
  font-size: clamp(16px, 1.8vw, 19px); line-height: 1.68;
  color: rgba(255,255,255,.55); max-width: 640px;
}

/* ─── SECTION SHELL ─────────────────────────────────────── */
.sec { padding: 88px var(--px); }
.sec-inner { max-width: var(--max-w); margin: 0 auto; }
.sec-eyebrow {
  font-family: var(--font-m); font-size: 10.5px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold-main); margin-bottom: 14px;
}
.sec-eyebrow.on-dark { color: var(--gold-mid); }
.sec-h2 {
  font-family: var(--font-d); font-weight: 700;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.1; letter-spacing: -.022em;
  color: var(--neutral-900); margin-bottom: 14px;
}
.sec-h2.on-dark { color: var(--white); }
.sec-sub { font-size: 17px; line-height: 1.68; color: var(--neutral-500); max-width: 540px; }
.sec-sub.on-dark { color: rgba(255,255,255,.48); }

/* ─── CTA BAND ──────────────────────────────────────────── */
.cta-band { background: var(--g700); padding: 92px var(--px); position: relative; overflow: hidden; }
.cta-band::before {
  content: ''; position: absolute; bottom: -220px; left: 50%; transform: translateX(-50%);
  width: 900px; height: 480px;
  background: radial-gradient(ellipse, rgba(200,151,26,.14) 0%, transparent 65%); pointer-events: none;
}
.cta-inner { max-width: 680px; margin: 0 auto; text-align: center; position: relative; z-index: 1; }
.cta-h2 {
  font-family: var(--font-d); font-weight: 700;
  font-size: clamp(32px, 4.2vw, 52px); line-height: 1.1; letter-spacing: -.02em;
  color: var(--white); margin-bottom: 18px;
}
.cta-sub { font-size: 17px; color: rgba(255,255,255,.48); line-height: 1.68; margin-bottom: 38px; }
.cta-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ─── FOOTER ────────────────────────────────────────────── */
footer {
  background: var(--g950);
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 64px var(--px) 36px;
}
.footer-inner { max-width: var(--max-w); margin: 0 auto; }
.footer-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 40px; margin-bottom: 52px; flex-wrap: wrap;
}
.footer-brand { display: flex; flex-direction: column; gap: 14px; }
.footer-logo img { height: 44px; }
.footer-tagline { font-size: 13.5px; color: rgba(255,255,255,.34); max-width: 240px; line-height: 1.62; }
.footer-nav { display: flex; gap: 52px; flex-wrap: wrap; }
.footer-col h5 {
  font-family: var(--font-m); font-size: 10px; letter-spacing: .16em;
  text-transform: uppercase; color: rgba(255,255,255,.26); margin-bottom: 16px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.footer-col a { font-size: 13.5px; color: rgba(255,255,255,.48); transition: color var(--dur); }
.footer-col a:hover { color: var(--white); }
.footer-bottom {
  padding-top: 28px; border-top: 1px solid rgba(255,255,255,.06);
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 14px;
}
.footer-copy { font-size: 12.5px; color: rgba(255,255,255,.26); }
.social-links { display: flex; gap: 10px; }
.social-btn {
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.09);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.44);
  transition: background var(--dur), border-color var(--dur), color var(--dur);
}
.social-btn:hover { background: rgba(200,151,26,.15); border-color: rgba(200,151,26,.28); color: var(--gold-mid); }
.social-btn svg { width: 15px; height: 15px; }

/* ─── SCROLL REVEAL ─────────────────────────────────────── */
@keyframes rise { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: translateY(0); } }
.reveal { opacity: 0; }
.reveal.visible { animation: rise .6s var(--ease) both; }
.reveal-d1 { animation-delay: .05s; }
.reveal-d2 { animation-delay: .12s; }
.reveal-d3 { animation-delay: .19s; }
.hero-eyebrow { animation: rise .6s var(--ease) .1s both; }
.hero-h1-anim { animation: rise .7s var(--ease) .2s both; }
.hero-lead-anim { animation: rise .7s var(--ease) .32s both; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .hero-eyebrow, .hero-h1-anim, .hero-lead-anim { opacity: 1 !important; animation: none !important; }
}
/* Fallback: when JS can't guarantee a running animation (hidden tab, print,
   PDF export, reduced motion) show every animated element at its end-state. */
html.show-all .reveal,
html.show-all .hero-eyebrow,
html.show-all .hero-h1-anim,
html.show-all .hero-lead-anim {
  opacity: 1 !important; transform: none !important; animation: none !important;
}

/* ─── RESPONSIVE ────────────────────────────────────────── */
@media (max-width: 700px) {
  .nav-toggle { display: flex; }
  .nav > .nav-cta { display: none; }
  .nav-links {
    position: fixed; top: 71px; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    padding: 8px var(--px) 16px;
    background: rgba(6,14,10,.97); backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(255,255,255,.08);
    transform: translateY(-12px); opacity: 0; pointer-events: none;
    transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
  }
  .nav-links.open { transform: none; opacity: 1; pointer-events: auto; }
  .nav-links a {
    padding: 13px 4px; font-size: 16px;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .footer-nav { gap: 32px; }
}
