/* ===========================================================
   Shepherd Energy — site stylesheet (charcoal/gold refresh)
   Charcoal #2C2920 · Espresso #1A1410 · Crimson #8B0E20
   Lux Solar Gold #E0AD2B · Cream #F8F3E8 · EB Garamond
   =========================================================== */

:root{
  --charcoal:#2C2920;
  --espresso:#1A1410;
  --crimson:#8B0E20;
  --crimson-deep:#6E0A19;
  --gold:#E0AD2B;
  --gold-tint:#EFC659;
  --gold-soft:#F3D88A;
  --cream:#F8F3E8;
  --cream-2:#FAF6EE;
  --paper:#ffffff;
  --ink:#38322A;
  --ink-soft:#6f6657;
  --line:#e8dfcd;
  --maxw:1180px;
  --serif:'EB Garamond', Garamond, 'Times New Roman', Georgia, serif;
  --cdn:'';
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--serif);color:var(--ink);background:var(--cream-2);
  font-size:19px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-weight:400;line-height:1.12;margin:0 0 .4em;letter-spacing:.005em}
h1{font-size:clamp(2.5rem,5.2vw,3.9rem)}
h2{font-size:clamp(1.9rem,3.4vw,2.7rem)}
h3{font-size:1.45rem}
p{margin:0 0 1.05em}
.lead{font-size:1.2rem;line-height:1.55;color:var(--ink-soft)}
.gold{color:var(--gold)}
.crimson{color:var(--crimson)}

/* eyebrow with leading gold dash */
.eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;
  color:var(--gold);margin:0 0 1.1em;
}
.eyebrow::before{content:"";width:28px;height:1.5px;background:var(--gold);display:inline-block}
.eyebrow.plain::before{display:none}
.eyebrow.center-dash{justify-content:center}

.maxw-prose{max-width:62ch}
.center{text-align:center}
.mt0{margin-top:0}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:var(--charcoal)}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:15px 32px}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none}
.orb{
  width:26px;height:26px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 33% 30%, var(--gold-soft), var(--gold) 56%, #b9881d 100%);
  box-shadow:0 0 14px rgba(224,173,43,.45);
}
.wordmark{color:#f4ead3;font-size:1rem;letter-spacing:.34em;text-transform:uppercase}
.menu{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0}
.menu a{
  color:#d8cfbc;text-decoration:none;font-size:1.02rem;letter-spacing:.02em;
  transition:color .2s;
}
.menu a:hover{color:#fff}
.menu a.active{color:var(--gold)}
.nav-cta{
  background:var(--gold);color:var(--espresso);text-decoration:none;
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  padding:11px 22px;border-radius:2px;transition:.2s;
}
.nav-cta:hover{background:var(--gold-tint)}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.menu-toggle span{display:block;width:24px;height:1.5px;background:var(--gold-tint);margin:6px 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-family:var(--serif);
  font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  padding:15px 30px;border-radius:2px;transition:.2s;border:1px solid transparent;cursor:pointer;
}
.btn-gold{background:var(--gold);color:var(--espresso)}
.btn-gold:hover{background:var(--gold-tint)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-outline-dark{background:transparent;color:var(--crimson);border-color:rgba(139,14,32,.4)}
.btn-outline-dark:hover{border-color:var(--crimson);background:rgba(139,14,32,.05)}
.btn-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}

/* ---------- Sections ---------- */
section{padding:92px 0}
.sec-cream{background:var(--cream)}
.sec-paper{background:var(--cream-2)}
.sec-espresso{background:var(--espresso);color:#f3e9d6}
.sec-espresso h2{color:#fff}
.tight{padding:64px 0}

/* ---------- HERO: photo (home) ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff;background:#1A1410}
.hero .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background-size:cover;background-position:center;z-index:0;transition:opacity .6s ease}
.hero .scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(26,20,16,.10) 0%, rgba(26,20,16,.05) 40%, rgba(26,20,16,.45) 100%);}
.hero .wrap{position:relative;z-index:2;padding-bottom:90px;padding-top:80px;width:100%}
.hero h1{color:#fff;max-width:18ch;font-size:clamp(2.6rem,5.4vw,4.1rem)}
.hero .lead{color:#f1e7d6;max-width:54ch}
.hero .eyebrow{color:var(--gold-tint)}
.hero .eyebrow::before{background:var(--gold-tint)}
.hero-orb{position:absolute;top:54px;right:64px;width:46px;height:46px;border-radius:50%;z-index:2;
  background:radial-gradient(circle at 35% 32%, var(--gold-soft), var(--gold) 60%, #b9881d 100%);
  box-shadow:0 0 30px rgba(224,173,43,.55);}

/* ---------- HERO: crimson (interior pages) ---------- */
.hero-band-page{position:relative;color:#fff;overflow:hidden}
.hero-band-page .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background-size:cover;background-position:center;opacity:.28;z-index:0}
.hero-band-page .tint{position:absolute;inset:0;z-index:1;
  background:linear-gradient(120deg, var(--crimson) 0%, var(--crimson-deep) 70%, #4e0712 100%);opacity:.9}
.hero-band-page .wrap{position:relative;z-index:2;padding:120px 32px 96px}
.hero-band-page h1{color:#fff;max-width:20ch}
.hero-band-page .lead{color:#f3dcc6;max-width:56ch}
.hero-band-page .eyebrow{color:var(--gold-tint)}
.hero-band-page .eyebrow::before{background:var(--gold-tint)}
.hero-band-page.espresso .tint{background:linear-gradient(120deg, var(--espresso) 0%, #2a2018 100%);opacity:.94}
.hero-watermark{position:absolute;z-index:1;bottom:6%;left:0;right:0;text-align:center;
  font-size:9vw;letter-spacing:.12em;color:rgba(224,173,43,.06);text-transform:uppercase;white-space:nowrap;overflow:hidden}

/* ---------- Home dark band (gallery + stats) ---------- */
.darkband{background:var(--espresso);color:#f3e9d6}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid rgba(224,173,43,.18)}
.gtile{display:flex;align-items:center;gap:14px;padding:20px 26px;border-left:1px solid rgba(255,255,255,.06);position:relative;cursor:pointer;transition:background .2s}
.gtile:hover{background:rgba(255,255,255,.04)}
.gtile:first-child{border-left:0}
.gtile.active::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold)}
.gtile img{width:46px;height:34px;object-fit:cover;border-radius:2px;flex:none}
.gtile span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#e8dcc4}
.statrow{display:grid;grid-template-columns:repeat(4,1fr)}
.statrow .st{padding:40px 26px;text-align:center;border-left:1px solid rgba(255,255,255,.06)}
.statrow .st:first-child{border-left:0}
.statrow .num{font-size:2.3rem;color:var(--gold-tint);line-height:1}
.statrow .lbl{margin-top:12px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#b9ad95}

/* ---------- Stat cards (white, crimson numbers) ---------- */
.cardstats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.scard{background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:30px 26px;box-shadow:0 1px 3px rgba(40,20,12,.05)}
.scard .num{font-size:2.1rem;color:var(--crimson);line-height:1}
.scard .lbl{margin-top:10px;font-size:.95rem;color:var(--ink-soft)}

/* ---------- Model cards (crimson left border) ---------- */
.grid{display:grid;gap:26px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.mcard{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--crimson);border-radius:4px;padding:32px 30px}
.mcard .eyebrow{margin-bottom:.7em}
.mcard h3{color:var(--ink);margin-bottom:.4em}
.mcard p{color:var(--ink-soft);margin:0}

/* ---------- Steps (numbered) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.step .n{font-size:2.6rem;color:var(--gold);line-height:1;display:block;margin-bottom:.2em}
.step h3{color:var(--ink);font-size:1.25rem}
.step p{color:var(--ink-soft);margin:0}
.steps-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Image block with caption ---------- */
.imgblock{position:relative;border-radius:6px;overflow:hidden;margin-top:8px}
.imgblock img{width:100%;height:auto;display:block}
.imgblock .cap{position:absolute;left:24px;bottom:18px;color:#fff;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.6)}

/* ---------- Split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.l{grid-template-columns:.95fr 1.05fr}

/* ---------- Pills (best fit) ---------- */
.pills{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}
.pill{background:var(--paper);border:1px solid var(--line);border-radius:40px;padding:11px 22px;
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}

/* ---------- Pull quote ---------- */
.quote{max-width:60ch;margin:0 auto;text-align:center;font-size:1.6rem;line-height:1.45;font-style:italic;color:var(--ink)}
.sec-espresso .quote{color:#f3e9d6}

/* ---------- Spec table (about) ---------- */
.spec{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.spec td{padding:15px 22px;border-bottom:1px solid var(--line);vertical-align:top}
.spec tr:last-child td{border-bottom:0}
.spec td:first-child{color:var(--ink-soft);width:34%;font-size:.95rem}
.spec td:last-child{color:var(--ink)}

/* ---------- News ---------- */
.featured{display:grid;grid-template-columns:1.1fr .9fr;gap:0;background:var(--paper);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.featured .pic{background-size:cover;background-position:center;min-height:300px;width:100%;height:100%;object-fit:cover;display:block}
.featured .body{padding:42px 40px}
.tag{display:inline-block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.newsgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.ncard{background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:30px 28px}
.ncard h3{font-size:1.3rem;margin:.2em 0 .4em}
.ncard .date{color:var(--ink-soft);font-size:.95rem}
.ncard p{color:var(--ink-soft)}
.news-layout{display:grid;grid-template-columns:1fr 300px;gap:46px;align-items:start}
.side h4{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 16px}
.side .li{padding:14px 0;border-bottom:1px solid var(--line)}
.side .li:last-child{border-bottom:0}
.side .li .date{font-size:.9rem;color:var(--ink-soft)}
.cat{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);color:var(--ink-soft);font-size:.98rem}

/* ---------- Contact ---------- */
.contact-layout{display:grid;grid-template-columns:380px 1fr;gap:56px;align-items:start}
.reach{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.reach .ic{width:42px;height:42px;border-radius:50%;background:rgba(139,14,32,.10);color:var(--crimson);display:flex;align-items:center;justify-content:center;flex:none;font-size:1.1rem}
.reach .k{font-size:.95rem;color:var(--ink-soft)}
.reach a.v{color:var(--crimson);text-decoration:none;border-bottom:1px solid rgba(139,14,32,.3)}
.reach a.v:hover{border-color:var(--crimson)}
.callout{background:var(--cream);border:1px solid var(--line);border-left:3px solid var(--crimson);border-radius:4px;padding:26px 24px;margin-top:8px}
.callout h4{color:var(--crimson);margin:0 0 .5em;font-size:1.15rem}
.callout p{color:var(--ink-soft);margin:0;font-size:.98rem}
.form{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:40px 38px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{margin-bottom:20px}
.field label{display:block;font-size:.92rem;color:var(--ink);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--serif);font-size:1rem;color:var(--ink);
  background:var(--cream-2);border:1px solid var(--line);border-radius:3px;padding:12px 14px;
}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}

/* ---------- Footer ---------- */
.site-footer{background:var(--charcoal);color:#cfc6b4;padding:60px 0 32px;font-size:.98rem}
.footer-top{display:flex;justify-content:space-between;gap:44px;flex-wrap:wrap}
.footer-cols{display:flex;gap:58px;flex-wrap:wrap}
.footer-cols h4{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 14px}
.footer-cols a{color:#cfc6b4;text-decoration:none;display:block;margin-bottom:9px}
.footer-cols a:hover{color:#fff}
.footer-legal{margin-top:42px;padding-top:22px;border-top:1px solid rgba(224,173,43,.2);font-size:.82rem;color:#a99e88;line-height:1.6}
.footer-legal .entity{color:var(--gold-tint);letter-spacing:.04em}

.note{font-size:.86rem;color:var(--ink-soft);font-style:italic}
.sec-espresso .note{color:#cabda3}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  body{font-size:18px}
  .menu-toggle{display:block}
  .menu{position:absolute;top:100%;left:0;right:0;background:var(--charcoal);flex-direction:column;align-items:flex-start;
    gap:0;padding:0 32px;max-height:0;overflow:hidden;transition:max-height .3s ease}
  .menu.open{max-height:420px;padding:8px 32px 22px}
  .menu li{width:100%}
  .menu a{display:block;padding:13px 0;width:100%}
  .nav-cta{display:none}
  .gallery,.statrow,.cardstats{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3,.steps,.steps-4{grid-template-columns:1fr}
  .split,.split.l{grid-template-columns:1fr;gap:36px}
  .featured{grid-template-columns:1fr}
  .featured .pic{min-height:200px}
  .newsgrid{grid-template-columns:1fr}
  .news-layout{grid-template-columns:1fr;gap:36px}
  .contact-layout{grid-template-columns:1fr;gap:36px}
  .form-row{grid-template-columns:1fr}
  section{padding:64px 0}
  .hero{min-height:78vh}
  .hero-orb{right:32px;top:40px}
}
@media (max-width:520px){
  .gallery,.statrow,.cardstats{grid-template-columns:1fr}
  .wordmark{font-size:.86rem;letter-spacing:.26em}
  .quote{font-size:1.3rem}
}
