/* ============================================================
   Ember Exteriors — coming-soon splash (above the fold)
   Palette sampled from the brand mark: ember gold → red → crimson
   over a near-black field (the logo's native ground).
   ============================================================ */

:root{
  --ink:    #0b0b0d;
  --ink-2:  #111216;
  --ink-3:  #15161a;
  --line:   #26272c;
  --line-2: #34353c;

  --bone:   #f4f1ea;
  --smoke:  #b7b9c1;
  --dim:    #82848d;

  --gold:    #fdaa04;
  --orange:  #f14139;
  --crimson: #e5185c;
  --ember:   linear-gradient(100deg, var(--gold) 0%, var(--orange) 52%, var(--crimson) 100%);

  --d-display: "Archivo", system-ui, sans-serif;
  --d-body:    "Hanken Grotesk", system-ui, sans-serif;
  --d-mono:    "Spline Sans Mono", ui-monospace, monospace;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--ink); color:var(--smoke);
  font-family:var(--d-body); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; height:auto; }

.skip{
  position:absolute; left:-999px; top:0; z-index:100;
  background:var(--bone); color:var(--ink); padding:10px 16px; border-radius:0 0 10px 0;
  font:600 14px/1 var(--d-body);
}
.skip:focus{ left:0; }

.eyebrow{
  font-family:var(--d-mono); font-size:11.5px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--dim); margin:0 0 14px;
}
.eyebrow--ember{ background:var(--ember); -webkit-background-clip:text; background-clip:text; color:transparent; }
.mono{ font-family:var(--d-mono); letter-spacing:.04em; }
.ember-word{ background:var(--ember); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ---- buttons ----------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--d-display); font-weight:700; font-size:1rem; letter-spacing:.01em;
  padding:15px 26px; border-radius:11px; cursor:pointer; border:1px solid transparent;
  transition:transform .18s ease, box-shadow .25s ease;
}
.btn--ember{ color:#1a0a02; background:var(--ember); box-shadow:0 8px 30px -10px rgba(241,65,57,.6); }
.btn--ember:hover{ transform:translateY(-2px); box-shadow:0 14px 40px -10px rgba(241,65,57,.85); }
.btn--block{ width:100%; }
.btn:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }

/* ============================================================ SPLASH (one screen) */
.splash{
  position:relative; isolation:isolate; overflow:hidden;
  min-height:100vh; min-height:100svh;
  display:flex; align-items:center;
  padding:clamp(20px,4vh,48px) clamp(20px,5vw,56px);
}
.splash__bg{
  position:absolute; inset:0; z-index:-2;
  background:url("/assets/img/hero.jpg") center 26% / cover no-repeat;
}
.splash__scrim{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(90deg, rgba(11,11,13,.95) 0%, rgba(11,11,13,.80) 46%, rgba(11,11,13,.42) 100%),
    linear-gradient(0deg, var(--ink) 1%, rgba(11,11,13,.18) 38%, rgba(11,11,13,.62) 100%);
}

.badge{
  position:absolute; top:clamp(16px,3vh,26px); right:clamp(20px,5vw,56px); z-index:3;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--bone);
  padding:8px 14px; border:1px solid var(--line-2); border-radius:999px;
  background:rgba(11,11,13,.5); backdrop-filter:blur(6px);
}

.panel{
  position:relative; width:100%; max-width:1120px; margin-inline:auto;
  display:grid; gap:clamp(28px,4vw,56px); align-items:center;
  grid-template-columns:1fr;
}

/* ---- left: brand + pitch ---- */
.lede__logo{ width:clamp(190px,26vw,300px); height:auto; margin:0 0 22px -6px; }
.lede__title{
  font-family:var(--d-display); font-weight:900; color:var(--bone);
  font-size:clamp(2.5rem,1.2rem + 5.6vw,4.6rem); line-height:.95; letter-spacing:-.035em;
  margin:0 0 18px;
}
.lede__sub{
  max-width:46ch; font-size:clamp(1rem,.96rem + .3vw,1.16rem); color:var(--smoke); margin:0 0 18px;
}
.lede__svc{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); margin:0; }

/* ---- right: form card ---- */
.formcard{
  background:
    radial-gradient(130% 90% at 100% 0%, rgba(229,24,92,.12), transparent 55%),
    rgba(17,18,22,.86);
  border:1px solid var(--line); border-radius:18px;
  padding:clamp(22px,3vw,32px); backdrop-filter:blur(8px);
  box-shadow:0 30px 80px -40px rgba(0,0,0,.9);
}
.formcard__h{
  font-family:var(--d-display); font-weight:800; color:var(--bone);
  font-size:1.45rem; letter-spacing:-.015em; margin:0 0 18px;
}
.form{ display:grid; gap:15px; }
.row{ display:grid; gap:15px; grid-template-columns:1fr; }
@media (min-width:480px){ .row{ grid-template-columns:1fr 1fr; } }

.field{ display:grid; gap:6px; }
.field label{ font:600 13px/1.3 var(--d-body); color:var(--bone); }
.field .opt{ color:var(--dim); font-weight:500; }
.field input, .field textarea, .field select{
  width:100%; font-family:var(--d-body); font-size:16px; color:var(--bone);
  background:var(--ink-3); border:1px solid var(--line-2); border-radius:10px;
  padding:12px 14px; transition:border-color .18s ease, box-shadow .18s ease;
}
.field textarea{ resize:vertical; min-height:64px; line-height:1.5; }
.field input::placeholder, .field textarea::placeholder{ color:#62646c; }
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(253,170,4,.18);
}
.select{ position:relative; }
.select::after{
  content:""; position:absolute; right:16px; top:50%; width:9px; height:9px;
  border-right:2px solid var(--gold); border-bottom:2px solid var(--gold);
  transform:translateY(-65%) rotate(45deg); pointer-events:none;
}
.field select{ appearance:none; -webkit-appearance:none; padding-right:40px; cursor:pointer; }
.field select option{ background:var(--ink-2); color:var(--bone); }

.err{ font:600 12.5px/1.3 var(--d-body); color:#ff8a7a; }
.form__fine{ margin:2px 0 0; font-size:12px; color:var(--dim); text-align:center; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

.alert{ border-radius:12px; padding:14px 16px; font-size:.95rem; line-height:1.5; margin-bottom:16px; }
.alert--err{ background:rgba(229,24,92,.08); border:1px solid #4a1f30; color:#ffb3b3; }

/* success state */
.done{ text-align:center; padding:18px 6px; }
.done__mark{
  width:60px; height:60px; margin:0 auto 16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:30px; color:#1a0a02; background:var(--ember);
  box-shadow:0 10px 34px -10px rgba(241,65,57,.7);
}
.done h2{ font-family:var(--d-display); font-weight:800; color:var(--bone); font-size:1.5rem; margin:0 0 8px; }
.done p{ margin:0; color:var(--smoke); }

/* ---- the ridgeline signature ---- */
.ridge{
  position:absolute; left:0; right:0; bottom:0; height:3px; z-index:2;
  background:var(--ember);
  box-shadow:0 0 22px 1px rgba(241,65,57,.5), 0 0 60px 4px rgba(229,24,92,.22);
}
.ridge__glow{
  position:absolute; top:-1px; bottom:-1px; width:40%;
  background:linear-gradient(90deg, transparent, rgba(255,236,200,.95), transparent);
  filter:blur(2px); animation:ignite 4.6s ease-in-out .4s infinite;
}
@keyframes ignite{
  0%{ left:-42%; opacity:0; } 18%{ opacity:1; } 60%{ opacity:1; } 100%{ left:103%; opacity:0; }
}

/* ============================================================ DESKTOP: two-up, one screen */
@media (min-width:880px){
  .panel{ grid-template-columns:1.05fr .95fr; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
}
