/* v1 — OBSIDIAN GOLD : dark cinematic + brushed gold (Yeti / Filson energy) */

body {
  background: #07080a;
  color: #f4f1ea;
  font-family: 'Inter', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
}
em { font-style: italic; color: #f1c14a; }

.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 14px 28px;
  background: rgba(7,8,10,.78);
  backdrop-filter: blur(10px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.brand img { height: 72px; }
.topnav { display: flex; gap: 22px; }
.topnav a { font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: #b6b2a8; transition: color .15s; }
.topnav a:hover { color: #f1c14a; }
.cta-mini { background: #d4a017; color: #111; padding: 10px 16px; border-radius: 4px; font: 700 12px/1 'Inter'; letter-spacing: .08em; text-transform: uppercase; }
.cta-mini:hover { background: #f1c14a; }
@media (max-width: 760px) { .topnav { display: none; } }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 16px 26px; border-radius: 4px; font: 700 13px/1 'Inter'; letter-spacing: .1em; text-transform: uppercase; border: 1px solid transparent; transition: transform .15s, background .15s, border-color .15s, color .15s; }
.btn--primary { background: linear-gradient(180deg, #f1c14a, #d4a017); color: #111; box-shadow: 0 12px 30px -10px rgba(212,160,23,.55); }
.btn--primary:hover { transform: translateY(-1px); }
.btn--ghost { color: #f4f1ea; border-color: rgba(255,255,255,.18); }
.btn--ghost:hover { color: #f1c14a; border-color: #d4a017; }

.kicker { display: inline-block; font: 700 11px/1 'Inter'; letter-spacing: .26em; text-transform: uppercase; color: #7a766d; margin: 0; }
.kicker.accent { color: #f1c14a; }
.eyebrow { font: 700 13px/1 'Inter'; letter-spacing: .26em; text-transform: uppercase; color: #f1c14a; padding: 8px 13px; border: 1px solid rgba(212,160,23,.4); border-radius: 999px; background: rgba(212,160,23,.06); display: inline-block; margin-bottom: 18px; }

h2 { font: 400 clamp(30px,4.4vw,54px)/1 'Anton', Impact, sans-serif; letter-spacing: 0; text-transform: uppercase; margin: 8px 0 18px; }
h3 { font: 400 22px/1 'Bebas Neue', Impact, sans-serif; letter-spacing: .04em; text-transform: uppercase; margin: 0 0 6px; }
.lede { font-size: 18px; color: #b6b2a8; max-width: 56ch; }
.sub  { color: #b6b2a8; max-width: 60ch; margin-top: 8px; }

/* HERO */
.hero {
  position: relative; isolation: isolate;
  min-height: clamp(640px, 92vh, 980px);
  display: grid; grid-template-columns: 1.1fr 1fr; align-items: center;
  background: radial-gradient(1100px 600px at 70% 30%, rgba(212,160,23,.08), transparent 60%), linear-gradient(180deg, #0a0c10, #07080a 70%);
  overflow: hidden;
}
.hero__media { position: absolute; inset: 0; z-index: -1; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; object-position: 80% center; opacity: .45; filter: contrast(1.05) saturate(.9); }
.hero__media::after { content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(7,8,10,.95) 0%, rgba(7,8,10,.78) 40%, rgba(7,8,10,.2) 70%, transparent 100%), linear-gradient(180deg, rgba(7,8,10,.4), transparent 30%, rgba(7,8,10,.85)); }
.hero__content { padding: 96px 24px 96px 64px; max-width: 760px; }
.tagline { margin: 0 0 22px; font: 400 clamp(22px,2.8vw,36px)/1 'Anton', Impact, sans-serif; letter-spacing: .04em; text-transform: uppercase; color: #f4f1ea; text-align: center; }
.tagline span { display: inline; }
.tagline span + span { margin-left: .35em; }
.tagline .accent { color: #f1c14a; }
.hero__title { margin: 0 0 26px; }
.hero__title span { display: block; font: 400 clamp(44px,8vw,104px)/.92 'Anton', Impact, sans-serif; letter-spacing: -.005em; text-transform: uppercase; }
.hero__title .accent { background: linear-gradient(180deg, #f4d784, #d4a017 60%, #8a6510); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; margin: 28px 0 22px; }
.trust { display: flex; gap: 26px; padding: 0; margin: 0; list-style: none; font: 18px/1 'Bebas Neue', sans-serif; letter-spacing: .12em; color: #b6b2a8; }
.trust li { position: relative; padding-left: 16px; }
.trust li::before { content:""; position:absolute; left:0; top:.55em; width:8px; height:8px; background:#d4a017; transform: rotate(45deg); }
@media (max-width: 900px) { .hero { grid-template-columns: 1fr; min-height: 760px; } .hero__content { padding: 80px 24px 64px; } .hero__media img { object-position: center; opacity:.3; } }

/* MODES */
.modes { padding: 112px 0 88px; background: #07080a; border-top: 1px solid #1e242c; }
.mode-grid { margin-top: 36px; display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.mode-card { background: linear-gradient(180deg, #0e1115, #07080a); border: 1px solid #1e242c; border-radius: 4px; padding: 36px 28px; position: relative; overflow: hidden; transition: transform .15s, border-color .15s; }
.mode-card::before { content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background: linear-gradient(180deg,#d4a017, transparent); opacity:0; transition: opacity .15s; }
.mode-card:hover { transform: translateY(-4px); border-color: rgba(212,160,23,.4); }
.mode-card:hover::before { opacity: 1; }
.mode-num { font: 56px/1 'Anton', sans-serif; color: rgba(212,160,23,.18); margin-bottom: 18px; }
.mode-card p { color: #b6b2a8; margin: 0; }
@media (max-width: 800px) { .mode-grid { grid-template-columns: 1fr; } }

/* BIGSHOT */
.bigshot { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; padding: 112px 24px; max-width: 1200px; margin: 0 auto; }
.bigshot.feature { max-width: none; padding: 120px 64px; background: radial-gradient(900px 500px at 30% 50%, rgba(212,160,23,.08), transparent 60%), #08090c; border-top: 1px solid #1e242c; border-bottom: 1px solid #1e242c; }
.bigshot.feature > * { max-width: 580px; }
.bigshot.feature { justify-items: center; }
.bigshot--right .bigshot__copy { order: 1; } .bigshot--right .bigshot__img { order: 2; }
.bigshot--left  .bigshot__copy { order: 2; } .bigshot--left  .bigshot__img { order: 1; }
.bigshot__img img { border-radius: 4px; box-shadow: 0 30px 80px -20px rgba(0,0,0,.85); }
.checks { padding:0; margin: 18px 0 0; list-style: none; }
.checks li { position: relative; padding: 8px 0 8px 30px; border-bottom: 1px solid rgba(255,255,255,.06); color: #b6b2a8; }
.checks li::before { content:""; position:absolute; left:0; top:14px; width:14px; height:8px; border-left:2px solid #d4a017; border-bottom: 2px solid #d4a017; transform: rotate(-45deg); }
@media (max-width: 900px) { .bigshot, .bigshot.feature { grid-template-columns: 1fr; padding: 80px 24px; gap: 36px; } .bigshot--right .bigshot__copy, .bigshot--left .bigshot__copy { order: 1; } .bigshot--right .bigshot__img, .bigshot--left .bigshot__img { order: 2; } }

/* ANY */
.any { padding: 96px 0; background: linear-gradient(180deg, #060709, #0b0d11); border-top: 1px solid #1e242c; }
.any__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.any__img img { border-radius: 4px; box-shadow: 0 30px 80px -20px rgba(0,0,0,.85); }
@media (max-width: 900px) { .any__inner { grid-template-columns: 1fr; gap: 32px; } }

/* KIT */
.kit { padding: 112px 0; background: radial-gradient(800px 500px at 80% 20%, rgba(200,51,42,.08), transparent 60%), #07080a; border-top: 1px solid #1e242c; }
.kit-grid { margin-top: 36px; display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center; }
.kit-feature img { border-radius: 4px; box-shadow: 0 30px 80px -20px rgba(0,0,0,.85); }
.kit-list { list-style: none; padding: 0; margin: 0; }
.kit-list li { padding: 18px 0; border-bottom: 1px solid #1e242c; display: grid; gap: 4px; }
.kit-list li:last-child { border-bottom: none; }
.kit-list strong { font: 400 20px/1 'Bebas Neue', sans-serif; letter-spacing: .04em; color: #f1c14a; }
.kit-list span { color: #b6b2a8; }
@media (max-width: 900px) { .kit-grid { grid-template-columns: 1fr; gap: 32px; } }

/* SIGNUP */
.signup { position: relative; padding: 132px 24px; background: radial-gradient(900px 600px at 50% 0%, rgba(212,160,23,.18), transparent 70%), linear-gradient(180deg, #0a0c10, #050608); text-align: center; border-top: 1px solid #1e242c; overflow: hidden; }
.signup::after { content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background: linear-gradient(90deg, transparent, #d4a017, transparent); }
.signup__inner { max-width: 720px; margin: 0 auto; }
.signup .sub { margin: 14px auto 0; }
.signup__form { margin-top: 28px; display: grid; grid-template-columns: 1fr auto; gap: 10px; background: #0e1115; border: 1px solid #1e242c; border-radius: 6px; padding: 8px; transition: border-color .15s, box-shadow .15s; }
.signup__form:focus-within { border-color: #d4a017; box-shadow: 0 0 0 4px rgba(212,160,23,.18); }
.signup__form input[type="email"] { background: transparent; border: 0; color: #f4f1ea; padding: 14px; font-size: 16px; }
.signup__form input::placeholder { color: #7a766d; }
.signup__form .btn { padding: 14px 22px; }
.btn__spinner { width: 14px; height: 14px; border: 2px solid rgba(0,0,0,.3); border-top-color: #111; border-radius: 50%; display: none; animation: spin .7s linear infinite; }
.btn.is-loading .btn__label { opacity: .55; } .btn.is-loading .btn__spinner { display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }
.signup__msg { margin: 16px 0 0; min-height: 22px; font-size: 14px; color: #b6b2a8; }
.signup__msg.is-ok { color: #6fdc8c; } .signup__msg.is-error { color: #ff8181; }
.fineprint { margin-top: 10px; font-size: 12px; color: #7a766d; letter-spacing: .04em; }
@media (max-width: 600px) { .signup__form { grid-template-columns: 1fr; } }

/* FAQ */
.faq { padding: 112px 0; background: #07080a; border-top: 1px solid #1e242c; }
.faq-grid { margin-top: 32px; max-width: 820px; }
.faq details { border-bottom: 1px solid #1e242c; padding: 22px 0; }
.faq summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; font: 400 22px/1 'Bebas Neue', sans-serif; letter-spacing: .04em; color: #f4f1ea; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: #f1c14a; font-size: 28px; font-weight: 300; transition: transform .15s; font-family: 'Inter'; line-height: 1; }
.faq details[open] summary::after { content: "−"; }
.faq details p { color: #b6b2a8; margin: 12px 0 0; max-width: 64ch; }

/* FOOT */
.foot { padding: 56px 0 36px; background: #050608; border-top: 1px solid #1e242c; }
.foot__inner { display: grid; grid-template-columns: 2fr 1fr; gap: 32px; align-items: start; }
.foot__brand img { height: 56px; margin-bottom: 12px; }
.foot__brand p { margin: 0; color: #7a766d; font-size: 13px; max-width: 50ch; }
.foot__links { display: flex; gap: 18px; flex-wrap: wrap; justify-content: flex-end; }
.foot__links a { font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: #b6b2a8; }
.foot__links a:hover { color: #f1c14a; }
.foot__legal { grid-column: 1 / -1; margin: 24px 0 0; padding-top: 18px; border-top: 1px solid #1e242c; color: #7a766d; font-size: 11px; max-width: 90ch; }
@media (max-width: 700px) { .foot__inner { grid-template-columns: 1fr; } .foot__links { justify-content: flex-start; } }
