
:root{
  --bg:#ffffff;
  --text:#191919;
  --muted:#5f5f67;
  --orange:#ff6b00;
  --orange-2:#ff8f1f;
  --red:#ef3d23;
  --yellow:#ffcf3f;
  --cream:#fff7ef;
  --line:#ececec;
  --shadow:0 16px 40px rgba(0,0,0,.10);
  --radius:24px;
  --container:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{width:min(var(--container), calc(100% - 40px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:20; backdrop-filter:saturate(180%) blur(12px);
  background:rgba(255,255,255,.88); border-bottom:1px solid rgba(0,0,0,.06);
}
.nav{display:grid; grid-template-columns:auto 1fr auto auto; gap:20px; align-items:center; padding:16px 0}
.brand{display:flex; align-items:center; gap:12px; font-size:1.5rem; font-weight:900; color:#9e2400}
.brand-mark{width:42px; height:42px; object-fit:cover; border-radius:12px}
.menu{display:flex; justify-content:center; gap:28px; color:#444; font-weight:600}
.menu a{position:relative}
.menu a:after{content:""; position:absolute; left:0; right:0; bottom:-6px; height:3px; border-radius:999px; background:linear-gradient(90deg,var(--orange),var(--red)); transform:scaleX(0); transform-origin:left; transition:.2s ease}
.menu a:hover:after{transform:scaleX(1)}
.menu-toggle{display:none; background:none; border:none; font-size:1.9rem}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border:none; border-radius:16px; padding:14px 22px; font-weight:800; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  box-shadow:0 12px 24px rgba(0,0,0,.08);
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--orange),var(--red)); color:white}
.btn-secondary{background:#fff2e5; color:#9d3300}

.hero{
  position:relative; overflow:hidden; padding:54px 0 48px;
  background:
    radial-gradient(circle at 12% 18%, rgba(255,143,31,.10), transparent 26%),
    radial-gradient(circle at 88% 10%, rgba(255,107,0,.10), transparent 22%),
    linear-gradient(180deg,#fff 0%, #fffaf5 100%);
}
.hero-bg{
  position:absolute; inset:0; background:
    linear-gradient(110deg, rgba(255,255,255,0) 55%, rgba(255,207,63,.08) 56%, rgba(255,107,0,.08) 100%);
  pointer-events:none;
}
.hero-grid{position:relative; display:grid; grid-template-columns:1.02fr .98fr; gap:32px; align-items:center}
.eyebrow,.section-kicker{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:999px; background:#fff3e0; color:#9a3f00; font-weight:900; letter-spacing:.02em; font-size:.88rem;
}
.section-kicker.dark{background:rgba(255,255,255,.18); color:#fff4d0}
.hero h1{
  margin:16px 0 14px; font-size:clamp(2.8rem, 6vw, 5.6rem); line-height:.93; letter-spacing:-.04em;
}
.hero h1 span{color:var(--orange)}
.lead{font-size:1.16rem; line-height:1.7; color:var(--muted); max-width:620px}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin:28px 0}
.hero-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:18px}
.hero-stats div{
  background:#fff; border:1px solid var(--line); border-radius:18px; padding:16px; box-shadow:var(--shadow)
}
.hero-stats strong{display:block; font-size:1rem}
.hero-stats span{display:block; color:var(--muted); font-size:.92rem; margin-top:6px}
.hero-card{
  border-radius:34px; overflow:hidden; background:#fff; box-shadow:var(--shadow); border:1px solid rgba(0,0,0,.06);
}
.hero-card img{width:100%; height:620px; object-fit:cover; object-position:center}

.section{padding:72px 0}
.split-grid,.money-grid,.systems-grid,.traction-grid,.interest-grid,.problem-grid{
  display:grid; gap:28px; align-items:center;
}
.split-grid{grid-template-columns:1fr 1fr}
.problem-grid{grid-template-columns:1.05fr .95fr}
.money-grid,.systems-grid,.interest-grid{grid-template-columns:.95fr 1.05fr}
.traction-grid{grid-template-columns:1fr 1fr}
.copy h2{font-size:clamp(2rem, 4vw, 3.4rem); line-height:1.02; margin:14px 0}
.copy p{font-size:1.06rem; line-height:1.8; color:var(--muted); margin:0 0 16px}
.check-list{list-style:none; padding:0; margin:22px 0 0}
.check-list li{
  padding:0 0 0 28px; margin:0 0 14px; position:relative; font-weight:700
}
.check-list li:before{
  content:"✓"; position:absolute; left:0; top:0; width:18px; height:18px; color:#fff; background:linear-gradient(135deg,var(--orange),var(--red));
  border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.72rem; line-height:1.2; padding-top:2px
}
.rounded{border-radius:28px}
.shadow{box-shadow:var(--shadow)}
.media-stack{position:relative; min-height:680px}
.media-stack > img:first-child{width:100%; height:520px; object-fit:cover}
.small-float{
  position:absolute; right:0; bottom:0; width:58%; height:280px; object-fit:cover; border:10px solid #fff
}

.panel{
  border-radius:28px; overflow:hidden; box-shadow:var(--shadow)
}
.panel-accent{
  padding:36px; background:
    radial-gradient(circle at 100% 0%, rgba(255,207,63,.25), transparent 28%),
    linear-gradient(135deg, #ff6b00 0%, #ef3d23 100%);
  color:white;
}
.panel-accent h2{font-size:clamp(2rem,4vw,3.1rem); line-height:1.04; margin:16px 0}
.panel-accent p{font-size:1.08rem; line-height:1.75; color:rgba(255,255,255,.92)}
.pill-row{display:flex; gap:10px; flex-wrap:wrap; margin:22px 0}
.pill-row span{
  padding:12px 14px; border-radius:999px; background:rgba(255,255,255,.18); color:#fff; font-weight:800; backdrop-filter:blur(8px)
}
.big-line{margin-top:20px; font-weight:900; font-size:1.28rem}
.image-panel img{width:100%; height:520px; object-fit:cover}

.money-cards{display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:20px}
.money-cards article{
  background:var(--cream); border-radius:22px; padding:20px; border:1px solid #ffe3c8
}
.money-cards strong{display:block; font-size:1.03rem; margin-bottom:8px}
.money-cards span{display:block; color:var(--muted); line-height:1.6}

.note{font-weight:800; color:#933900 !important}
.quote-box{
  margin-top:18px; padding:18px 20px; border-radius:20px; background:#111; color:#fff; font-weight:800; line-height:1.6
}
.visuals{position:relative; min-height:620px}
.visuals img:first-child{width:100%; height:360px; object-fit:cover}
.visuals .offset{
  position:absolute; right:0; bottom:0; width:62%; height:280px; object-fit:cover; border:10px solid #fff
}
.section-head{text-align:center; max-width:820px; margin:0 auto 30px}
.gallery-grid{display:grid; grid-template-columns:1.15fr .85fr .85fr; gap:18px}
.gallery-grid img{width:100%; height:420px; object-fit:cover}
.gallery-grid img:first-child{height:420px}

.interest{
  background:
    radial-gradient(circle at 10% 0%, rgba(255,143,31,.12), transparent 24%),
    linear-gradient(180deg, #fff8f2 0%, #fff 100%);
}
.interest-form{
  background:#fff; border-radius:28px; box-shadow:var(--shadow); padding:28px; border:1px solid rgba(0,0,0,.06)
}
.interest-form h3{margin:0 0 16px; font-size:1.6rem}
.interest-form label{display:block; font-weight:700; margin:0 0 14px}
.interest-form input,.interest-form textarea{
  width:100%; margin-top:8px; padding:14px 16px; border-radius:16px; border:1px solid #e6e6e6; font:inherit
}
.form-note{color:var(--muted); font-size:.92rem}

.site-footer{padding:34px 0 50px; border-top:1px solid #eee}
.footer-wrap{display:flex; justify-content:space-between; gap:20px; align-items:center}
.footer-wrap p{margin:6px 0 0; color:var(--muted)}
.footer-wrap nav{display:flex; gap:20px; color:#555; font-weight:700}

.reveal{opacity:0; transform:translateY(28px); transition:all .8s cubic-bezier(.2,.65,.2,1)}
.reveal.in-view{opacity:1; transform:none}

@media (max-width: 980px){
  .nav{grid-template-columns:auto 1fr auto}
  .menu{display:none}
  .menu-toggle{display:block}
  .hero-grid,.split-grid,.problem-grid,.money-grid,.systems-grid,.traction-grid,.interest-grid{grid-template-columns:1fr}
  .hero-card img,.image-panel img{height:420px}
  .media-stack,.visuals{min-height:auto}
  .small-float,.visuals .offset{position:static; width:100%; height:240px; border:0; margin-top:16px}
  .hero-stats{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-grid img,.gallery-grid img:first-child{height:300px}
  .money-cards{grid-template-columns:1fr}
  .footer-wrap{flex-direction:column; align-items:flex-start}
}
