/* ============================================================
   Dominion Insurance Marketing LLC — site styles
   Palette pulled from the gold-on-black logo.
   ============================================================ */

:root{
  --black:#0a0a0a;
  --black-pure:#000;
  --panel:#121110;
  --panel-2:#17150f;
  --line:rgba(196,175,118,.22);
  --line-soft:rgba(196,175,118,.12);

  --gold:#c4af76;
  --gold-deep:#8f6937;
  --gold-light:#e4d994;
  --gold-bright:#f9f3aa;

  --cream:#f7f3ea;
  --cream-2:#efe8d8;
  --ink:#1a1712;
  --ink-soft:#4b463c;

  --on-dark:#d8d2c4;       /* body text on dark */
  --on-dark-dim:#9d978a;

  --gold-grad:linear-gradient(176deg,var(--gold-bright) 0%,var(--gold-light) 22%,var(--gold) 52%,var(--gold-deep) 100%);
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --serif:"Marcellus",Georgia,"Times New Roman",serif;
  --serif-text:"Cormorant Garamond",Georgia,serif;
  --sans:"Mulish","Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);background:var(--black);color:var(--on-dark);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 26px}

/* ---------- type ---------- */
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.08;margin:0;letter-spacing:.01em}
h1{font-size:clamp(2.5rem,6vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1.1em}
.eyebrow{
  font-family:var(--sans);font-weight:800;text-transform:uppercase;
  letter-spacing:.28em;font-size:.72rem;color:var(--gold);margin:0 0 1rem;
}
.gold-text{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--gold-light);
}
.lead{font-size:1.16rem;color:var(--on-dark);max-width:60ch}
.muted{color:var(--on-dark-dim)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);
  font-weight:800;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.95em 1.7em;border:1px solid transparent;cursor:pointer;transition:.3s var(--ease);
}
.btn-gold{background:var(--gold-grad);color:#1c1404;box-shadow:0 10px 30px -12px rgba(196,175,118,.6)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(196,175,118,.75)}
.btn-ghost{border-color:var(--line);color:var(--gold-light);background:transparent}
.btn-ghost:hover{border-color:var(--gold);background:rgba(196,175,118,.08)}
.btn-pill{border-radius:999px}
.btn-dark{background:var(--ink);color:var(--gold-light)}
.btn-dark:hover{background:#000}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(8,8,8,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:1.4rem}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{height:40px;width:auto}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;margin:0;padding:0}
.nav-links a{
  font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--on-dark);position:relative;padding:.3em 0;transition:.25s;
}
.nav-links a:hover,.nav-links a.active{color:var(--gold-light)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;
  background:var(--gold-grad);
}
.nav-cta{display:flex;align-items:center;gap:.9rem}
.nav-phone{font-weight:800;color:var(--gold-light);font-size:.92rem;letter-spacing:.02em;white-space:nowrap}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--gold-light);transition:.3s}

/* ---------- sections ---------- */
section{position:relative}
.pad{padding:clamp(64px,9vw,128px) 0}
.pad-sm{padding:clamp(48px,6vw,84px) 0}
.dark{background:var(--black)}
.darker{background:var(--black-pure)}
.panel{background:linear-gradient(180deg,#121110,#0c0b09)}
.cream{background:var(--cream);color:var(--ink)}
.cream h1,.cream h2,.cream h3{color:var(--ink)}
.cream .lead,.cream p{color:var(--ink-soft)}
.cream .eyebrow{color:var(--gold-deep)}
.section-head{max-width:62ch;margin-bottom:3rem}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* hairline gold rule with mountain accent */
.rule{height:1px;background:var(--line);border:0;margin:0}
.kicker-line{width:64px;height:3px;background:var(--gold-grad);margin-bottom:1.6rem}
.cream .kicker-line{margin-left:0}

/* ---------- hero ---------- */
.hero{
  position:relative;overflow:hidden;background:
   radial-gradient(1200px 520px at 78% -8%,rgba(196,175,118,.16),transparent 60%),
   radial-gradient(900px 500px at 10% 110%,rgba(143,105,55,.18),transparent 55%),
   var(--black-pure);
  border-bottom:1px solid var(--line-soft);
}
.hero-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;
  padding:clamp(70px,9vw,130px) 0}
.hero h1{margin-bottom:1.4rem}
.hero .tagline{
  font-family:var(--serif-text);font-style:italic;font-size:clamp(1.3rem,2.4vw,1.8rem);
  color:var(--gold-light);margin-bottom:1.3rem;font-weight:500;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}

/* centered home hero: big logo first, tagline under it */
.hero-center{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:clamp(64px,8vw,110px) 26px;
}
.hero-center .hero-logo{
  width:min(560px,86vw);height:auto;margin-bottom:1.8rem;
  filter:drop-shadow(0 18px 50px rgba(196,175,118,.28));
}
.hero-center .tagline{margin-bottom:1.6rem}
.hero-center h1{font-size:clamp(2rem,4.4vw,3.4rem);margin-bottom:1.2rem}
.hero-center .lead{margin-left:auto;margin-right:auto}
.hero-center .hero-cta{justify-content:center}
.hero-photo{position:relative}
.hero-photo img{
  width:100%;border:1px solid var(--line);box-shadow:0 40px 90px -40px rgba(0,0,0,.9);
  filter:saturate(1.02);
}
.hero-photo::after{
  content:"";position:absolute;inset:0;border:1px solid rgba(196,175,118,.35);
  transform:translate(14px,14px);pointer-events:none;z-index:-1;
}

/* ---------- trust strip ---------- */
.trust{background:var(--panel-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.trust-row{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.4rem;padding:22px 0;text-align:center}
.trust-row span{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--on-dark-dim)}
.trust-row b{color:var(--gold-light);font-weight:800}

/* ---------- split intro ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.reverse .split-media{order:2}
.split-media img{width:100%;border:1px solid var(--line)}
.frame{position:relative}
.frame::before{content:"";position:absolute;inset:0;transform:translate(-14px,-14px);
  border:1px solid var(--gold-deep);z-index:-1}

/* ---------- service cards ---------- */
.grid{display:grid;gap:1.4rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:linear-gradient(180deg,#141210,#0d0c0a);border:1px solid var(--line-soft);
  padding:2.1rem 1.9rem;transition:.35s var(--ease);position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold-grad);transition:.4s var(--ease)}
.card:hover{transform:translateY(-5px);border-color:var(--line);background:linear-gradient(180deg,#191611,#100e0b)}
.card:hover::before{width:100%}
.card .ico{font-family:var(--serif);font-size:1.7rem;color:var(--gold);margin-bottom:.7rem;
  width:54px;height:54px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:50%}
.card h3{color:var(--gold-light);margin-bottom:.6rem}
.card p{font-size:.96rem;color:var(--on-dark-dim);margin-bottom:1rem}
.card .more{font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}

/* value list */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:1rem}
.value .n{font-family:var(--serif);font-size:2.2rem;color:var(--gold-deep);display:block;margin-bottom:.3rem}
.value h3{margin-bottom:.4rem}
.cream .value .n{color:var(--gold-deep)}

/* ---------- service detail blocks ---------- */
.svc{padding:clamp(48px,7vw,92px) 0;border-bottom:1px solid var(--line-soft)}
.svc:last-child{border-bottom:0}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.svc-list{list-style:none;padding:0;margin:1.3rem 0 1.6rem;display:grid;gap:.6rem}
.svc-list li{padding-left:1.6rem;position:relative;color:var(--on-dark)}
.svc-list li::before{content:"▲";position:absolute;left:0;top:.15em;color:var(--gold-deep);font-size:.7rem}
.cream .svc-list li{color:var(--ink-soft)}

/* ---------- CTA band ---------- */
.cta-band{background:
  radial-gradient(700px 300px at 50% 0%,rgba(196,175,118,.16),transparent 60%),var(--black-pure);
  text-align:center}
.cta-band h2{margin-bottom:1rem}
.cta-band .btnrow{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}

/* ---------- partner / recruiting ---------- */
.feature-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:1rem}
.feature{display:flex;gap:1.1rem;padding:1.6rem;border:1px solid var(--line-soft);background:#100f0c}
.feature .fi{flex:0 0 auto;width:46px;height:46px;border:1px solid var(--line);display:flex;
  align-items:center;justify-content:center;color:var(--gold);font-family:var(--serif);font-size:1.2rem}
.feature h3{color:var(--gold-light);font-size:1.15rem;margin-bottom:.35rem}
.feature p{font-size:.95rem;color:var(--on-dark-dim);margin:0}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem)}
.contact-card{border:1px solid var(--line-soft);background:#100f0c;padding:2rem}
.contact-item{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line-soft);align-items:flex-start}
.contact-item:last-child{border-bottom:0}
.contact-item .ci{color:var(--gold);font-family:var(--serif);font-size:1.2rem;width:30px;flex:0 0 auto}
.contact-item .lbl{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-dark-dim);font-weight:800}
.contact-item .val{color:var(--gold-light);font-size:1.06rem;font-weight:600}
.contact-item a.val:hover{text-decoration:underline}
form .field{margin-bottom:1.1rem}
form label{display:block;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--on-dark-dim);margin-bottom:.5rem}
form input,form textarea,form select{
  width:100%;background:#0b0a08;border:1px solid var(--line);color:var(--on-dark);
  padding:.85em 1em;font-family:var(--sans);font-size:1rem;transition:.25s;
}
form input:focus,form textarea:focus,form select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,175,118,.12)}
.form-note{font-size:.82rem;color:var(--on-dark-dim);margin-top:.4rem}
.notice{background:rgba(196,175,118,.08);border:1px dashed var(--line);padding:1rem 1.2rem;font-size:.9rem;color:var(--on-dark-dim);margin-bottom:1.4rem}

/* ---------- compliance / disclaimer ---------- */
.tpmo{
  background:#0e0d0b;border:1px solid var(--line-soft);padding:1.4rem 1.6rem;
  font-size:.86rem;line-height:1.6;color:var(--on-dark-dim);max-width:none;
}
.tpmo strong{color:var(--on-dark)}
.cream .tpmo{background:#fff;border-color:rgba(143,105,55,.25);color:var(--ink-soft)}

/* ---------- footer ---------- */
.site-footer{background:var(--black-pure);border-top:1px solid var(--line);padding:64px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem;margin-bottom:2.4rem}
.foot-brand img{height:46px;margin-bottom:1rem}
.foot-brand p{font-size:.92rem;color:var(--on-dark-dim);max-width:34ch}
.foot-col h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 1.1rem;font-weight:800}
.foot-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.foot-col a,.foot-col li{font-size:.94rem;color:var(--on-dark-dim);transition:.2s}
.foot-col a:hover{color:var(--gold-light)}
.foot-disclaimer{border-top:1px solid var(--line-soft);padding-top:1.8rem;display:grid;gap:1rem}
.foot-disclaimer p{font-size:.8rem;line-height:1.6;color:#7d7869;margin:0}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  border-top:1px solid var(--line-soft);margin-top:1.6rem;padding-top:1.4rem;
  font-size:.8rem;color:#6f6a5d}
.foot-bottom .npn{color:var(--on-dark-dim)}

/* ---------- reveal anim ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .hero-inner{grid-template-columns:1fr;gap:2.4rem}
  .hero-photo{max-width:460px}
  .split,.svc-grid,.contact-grid{grid-template-columns:1fr}
  .split.reverse .split-media{order:0}
  .grid-3,.values,.feature-row{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:flex}
  .nav.open .nav-links{
    display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;
    gap:0;background:#0b0a08;border-bottom:1px solid var(--line);padding:8px 26px 20px;
  }
  .nav.open .nav-links a{padding:14px 0;border-bottom:1px solid var(--line-soft);width:100%}
  .grid-3,.grid-2,.values,.feature-row,.foot-grid{grid-template-columns:1fr}
  body{font-size:16px}
  .hero-cta .btn,.cta-band .btn{width:100%;justify-content:center}
}
