/* Framer-style theme tokens and components */
:root {
  --fr-bg: #0a0a0a;
  --fr-surface: #0f0f10;
  --fr-elev: #141416;
  --fr-text: #f5f5f7;
  --fr-muted: #b8b8bf;
  --fr-border: rgba(255,255,255,0.08);
  --fr-border-strong: rgba(255,255,255,0.14);
  --fr-accent: #d8ac0e; /* brand yellow */
  --fr-radius: 16px;
  --fr-radius-lg: 20px;
  --fr-gap: 24px;
  --fr-gap-lg: 40px;
  --fr-shadow: 0 10px 30px rgba(0,0,0,0.35);
}

/* Base surface + subtle gradient backdrop */
body {
  background: radial-gradient(1200px 600px at 80% -10%, rgba(216,172,14,0.08), transparent),
              radial-gradient(900px 600px at -10% 20%, rgba(74,74,90,0.25), transparent),
              var(--fr-bg);
  color: var(--fr-text);
}

/* Container + sections */
.fr-container, .vh-container { max-width: 1160px; margin: 0 auto; padding: 0 24px; }
.fr-section, .vh-section { padding: 88px 0; }
.fr-hero { padding: 120px 0 72px; }

/* Typography */
.fr-eyebrow, .vh-eyebrow { color: var(--fr-muted); letter-spacing: .02em; font-weight: 600; margin: 0 0 8px 0; }
.fr-h1, .vh-title-xl { font-weight: 900; letter-spacing: -0.02em; line-height: 1.06; color: var(--fr-text); }
.fr-lead, .vh-lead { color: #d7d7dc; line-height: 1.65; font-size: clamp(1rem, 2.2vw, 1.15rem); }

/* Grid */
.fr-grid { display: grid; gap: var(--fr-gap); }
.fr-grid-2 { grid-template-columns: 1fr; }
.fr-grid-3 { grid-template-columns: 1fr; }
@media (min-width: 900px) {
  .fr-grid-2 { grid-template-columns: 1.1fr 0.9fr; align-items: center; }
  .fr-grid-3, .vh-cols-3 { grid-template-columns: repeat(3, 1fr); }
}

/* Glassy nav (Framer-like) */
header.burger-header {
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  background: rgba(10,10,10,0.55);
  border-bottom: 1px solid var(--fr-border);
}

/* Cards */
.fr-card, .vh-card, .work-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid var(--fr-border);
  border-radius: var(--fr-radius);
  padding: 22px;
  box-shadow: var(--fr-shadow);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.fr-card:hover, .vh-card:hover, .work-card:hover { transform: translateY(-4px); border-color: var(--fr-border-strong); }
.work-card h3 { margin: 8px 0 6px; }
.work-card p { color: var(--fr-muted); }

/* Media in cards */
.work-card img, .fr-card img, img.vh-img {
  border-radius: calc(var(--fr-radius) - 4px);
  border: 1px solid var(--fr-border);
}

/* Buttons */
.fr-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.fr-button, .vh-btn {
  display: inline-flex; align-items: center; justify-content: center;
  height: 44px; padding: 0 16px;
  border-radius: 999px; font-weight: 800; text-decoration: none; cursor: pointer;
  background: #f7f7f7; color: #000; border: 1px solid rgba(0,0,0,0.12);
}
.fr-button--secondary, .vh-btn.vh-btn-alt { background: transparent; color: var(--fr-text); border: 1px solid var(--fr-border-strong); }
.fr-button--primary, .vh-btn-cta { background: var(--fr-accent); color: #000; border: 1px solid rgba(0,0,0,0.2); }
.fr-button--primary, .vh-btn-cta { color: #000 !important; }
.fr-button--primary:hover, .vh-btn-cta:hover { color: #000 !important; text-decoration: none; }
.fr-button:hover, .vh-btn:hover { transform: translateY(-1px); opacity: .95; }

/* Hero image treatment */
.fr-hero-media { border-radius: var(--fr-radius-lg); overflow: hidden; border: 1px solid var(--fr-border); box-shadow: var(--fr-shadow); }
.fr-hero-media img { width: 100%; height: auto; display: block; }

/* Footer */
.vh-footer { border-top: 1px solid var(--fr-border); background: rgba(10,10,10,0.6); backdrop-filter: blur(6px); }
.vh-tiny { color: var(--fr-muted); font-size: .875rem; }

/* Footer layout */
.fr-footer { padding: 48px 0 28px; }
.fr-footer .fr-footer-grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 900px){ .fr-footer .fr-footer-grid { grid-template-columns: 1.3fr .9fr .9fr; } }
.fr-footer h4 { margin: 0 0 10px 0; font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 1rem; color: var(--fr-text); }
.fr-footer p, .fr-footer a, .fr-footer li { color: var(--fr-muted); font-family: 'Satoshi', sans-serif; }
.fr-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.fr-footer a:hover { color: var(--fr-accent); }

/* Newsletter */
.fr-news { display: grid; gap: 10px; }
.fr-footer .fr-buttons { margin-top: 10px; }
.fr-footer .fr-news { margin-top: 18px; }
.fr-footer .fr-footer-grid > section:first-child { text-align: left; }
.fr-footer .fr-news label { display: block; margin: 6px 0 8px; text-align: left; }
.fr-footer .fr-news > div { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.fr-footer .fr-news .fr-input { flex: 1 1 260px; max-width: 420px; }
.fr-input { background: #151517; border: 1px solid var(--fr-border-strong); color: var(--fr-text); border-radius: 10px; height: 42px; padding: 0 12px; width: 100%; }
.fr-submit { height: 42px; padding: 0 16px; border-radius: 999px; border: 1px solid rgba(0,0,0,0.2); background: var(--fr-accent); color: #000; font-weight: 800; cursor: pointer; }
.fr-submit:hover { opacity: .95; transform: translateY(-1px); }

/* (footer CTA sizes reverted to defaults) */

.fr-footer-bottom { border-top: 1px solid var(--fr-border); margin-top: 28px; padding-top: 16px; display: flex; gap: 12px; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.fr-socials { display: flex; gap: 12px; align-items: center; }
.fr-socials img { width: 22px; height: 22px; opacity: .85; }
.fr-socials a:hover img { opacity: 1; }

/* Simple reveal utility (works alongside AOS) */
.fr-reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.fr-reveal.is-inview { opacity: 1; transform: translateY(0); }

/* Tighter, consistent spacing for section subtitles */
.vh-subtitle { color: var(--fr-accent); letter-spacing: .01em; }

/* Make site title feel like Framer hero text scale */
.site-title.site-title--xl { letter-spacing: -0.02em; }

/* Adjust the main progress bar to accent color */
#scroll-progress { background: var(--fr-accent); }

/* Keep content offset appropriate for glassy header */
@media (min-width: 641px){ body { padding-top: 96px; } }
@media (max-width: 640px){ body { padding-top: 84px; } }

/* Trusted-by strip */
.fr-trust { padding: 28px 0 18px; border-top: 1px solid var(--fr-border); }
.fr-trust-eyebrow { color: var(--fr-muted); text-transform: uppercase; letter-spacing: .14em; font-size: .78rem; margin: 0 0 14px 0; text-align: center; }
.fr-trust-logos { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 24px 28px; align-items: center; justify-content: center; }
.fr-trust-logos li { display: flex; align-items: center; justify-content: center; opacity: .85; filter: grayscale(100%) contrast(1.05); transition: opacity .2s ease, filter .2s ease; }
.fr-trust-logos li:hover { opacity: 1; filter: grayscale(0%); }
.fr-trust-logo { height: 28px; width: auto; max-width: 140px; display: block; }
@media (max-width: 600px){
  .fr-trust { padding: 22px 0 14px; }
  .fr-trust-eyebrow { font-size: .72rem; margin-bottom: 10px; }
  .fr-trust-logos { gap: 16px 20px; }
  .fr-trust-logo { height: 22px; max-width: 110px; }
}
