/* =========================================================
   Steve Partello — site styles
   Palette: sage green base, warm gold accent, deep slate text
   ========================================================= */
:root{
  --sage-bg:#dfe6d6;        /* soft sage page background */
  --sage-bg-2:#d3ddc6;      /* slightly deeper sage */
  --sage-deep:#5d6e51;      /* deep sage for headings/nav */
  --sage-mid:#7e9069;       /* mid sage accents */
  --cream:#f7f8f3;          /* card / panel background */
  --gold:#b9933f;           /* refined gold accent (nods to BC + his tie) */
  --gold-soft:#cdb06a;
  --ink:#2b2f28;            /* primary text */
  --ink-soft:#4d5347;       /* secondary text */
  --line:#c3cdb4;           /* hairlines */
  --shadow:0 8px 28px rgba(54,64,44,.14);
  --radius:14px;
  --maxw:1080px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Georgia","Times New Roman",serif;
  color:var(--ink);
  background:var(--sage-bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.nav-name{font-family:"Helvetica Neue",Arial,sans-serif;letter-spacing:.2px;}
img{max-width:100%;display:block;}
a{color:var(--sage-deep);}

/* ---------- top navigation ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(93,110,81,.96);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.nav-name{color:#fff;font-weight:700;font-size:1.05rem;}
.nav-name span{color:var(--gold-soft);font-weight:400;}
.nav-links{display:flex;gap:22px;flex-wrap:wrap;}
.nav-links a{
  color:#eef2e6;text-decoration:none;font-family:"Helvetica Neue",Arial,sans-serif;
  font-size:.9rem;text-transform:uppercase;letter-spacing:1px;opacity:.9;
  padding-bottom:3px;border-bottom:2px solid transparent;transition:.2s;
}
.nav-links a:hover{opacity:1;border-color:var(--gold);}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:1.6rem;cursor:pointer;}

/* ---------- hero ---------- */
.hero{
  background:
    linear-gradient(180deg,rgba(93,110,81,.05),rgba(93,110,81,.18)),
    radial-gradient(1200px 400px at 70% -10%,rgba(185,147,63,.18),transparent),
    var(--sage-bg-2);
  border-bottom:1px solid var(--line);
}
.hero-inner{
  max-width:var(--maxw);margin:0 auto;padding:64px 22px 56px;
  display:grid;grid-template-columns:300px 1fr;gap:48px;align-items:center;
}
.hero-photo{
  width:280px;height:280px;border-radius:50%;
  background:var(--sage-mid) center/cover no-repeat;
  border:6px solid var(--cream);box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:4rem;font-family:"Helvetica Neue",Arial,sans-serif;
  overflow:hidden;
}
.hero-photo img{width:100%;height:100%;object-fit:cover;}
.hero h1{font-size:2.9rem;margin:0 0 6px;color:var(--sage-deep);line-height:1.1;}
.hero .credential{color:var(--gold);font-weight:700;font-family:"Helvetica Neue",Arial,sans-serif;font-size:.95rem;letter-spacing:.5px;}
.hero .tagline{font-size:1.18rem;color:var(--ink-soft);margin:14px 0 22px;font-style:italic;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.btn{
  display:inline-block;text-decoration:none;font-family:"Helvetica Neue",Arial,sans-serif;
  font-size:.92rem;letter-spacing:.6px;padding:12px 24px;border-radius:30px;transition:.2s;
}
.btn-primary{background:var(--sage-deep);color:#fff;}
.btn-primary:hover{background:#4c5b42;}
.btn-ghost{border:2px solid var(--sage-deep);color:var(--sage-deep);}
.btn-ghost:hover{background:var(--sage-deep);color:#fff;}

/* ---------- sections ---------- */
section{padding:64px 22px;}
.wrap{max-width:var(--maxw);margin:0 auto;}
.section-tag{
  font-family:"Helvetica Neue",Arial,sans-serif;text-transform:uppercase;
  letter-spacing:3px;font-size:.78rem;color:var(--gold);font-weight:700;margin-bottom:8px;
}
.section-title{font-size:2rem;color:var(--sage-deep);margin:0 0 22px;}
.alt{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.lead{font-size:1.12rem;color:var(--ink-soft);}

/* about layout */
.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:start;}
.fact-card{
  background:var(--sage-bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 26px;box-shadow:var(--shadow);
}
.fact-card h3{margin:0 0 14px;color:var(--sage-deep);font-size:1.05rem;
  text-transform:uppercase;letter-spacing:1.5px;}
.fact-list{list-style:none;margin:0;padding:0;}
.fact-list li{padding:9px 0;border-bottom:1px dashed var(--line);display:flex;gap:10px;}
.fact-list li:last-child{border-bottom:0;}
.fact-list .k{color:var(--gold);font-weight:700;min-width:18px;}

/* credential pills */
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.pill{
  background:var(--sage-bg);border:1px solid var(--sage-mid);color:var(--sage-deep);
  font-family:"Helvetica Neue",Arial,sans-serif;font-size:.82rem;letter-spacing:.4px;
  padding:7px 15px;border-radius:24px;
}

/* expertise cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px;}
.card{
  background:var(--sage-bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 24px;box-shadow:var(--shadow);transition:.2s;
}
.card:hover{transform:translateY(-4px);}
.card .ico{font-size:1.7rem;color:var(--gold);margin-bottom:10px;}
.card h3{margin:0 0 8px;color:var(--sage-deep);font-size:1.12rem;}
.card p{margin:0;color:var(--ink-soft);font-size:.98rem;}

/* timeline */
.timeline{position:relative;margin-top:24px;padding-left:30px;}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--sage-mid);}
.tl-item{position:relative;padding:0 0 30px 26px;}
.tl-item::before{content:"";position:absolute;left:-25px;top:5px;width:14px;height:14px;
  border-radius:50%;background:var(--gold);border:3px solid var(--cream);box-shadow:0 0 0 1px var(--sage-mid);}
.tl-item h3{margin:0 0 2px;color:var(--sage-deep);font-size:1.15rem;}
.tl-item .org{font-family:"Helvetica Neue",Arial,sans-serif;color:var(--gold);font-weight:700;font-size:.9rem;letter-spacing:.4px;}
.tl-item p{margin:8px 0 0;color:var(--ink-soft);}

/* gallery */
.gallery-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;margin-top:10px;
}
.gallery-grid figure{margin:0;border-radius:var(--radius);overflow:hidden;background:var(--sage-bg);
  box-shadow:var(--shadow);cursor:pointer;position:relative;}
.gallery-grid img{width:100%;height:200px;object-fit:cover;transition:.35s;}
.gallery-grid figure:hover img{transform:scale(1.06);}
.gallery-grid figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:18px 12px 10px;color:#fff;
  font-family:"Helvetica Neue",Arial,sans-serif;font-size:.82rem;letter-spacing:.3px;
  background:linear-gradient(180deg,transparent,rgba(40,46,34,.85));
}
.gallery-empty{background:var(--sage-bg);border:1px dashed var(--sage-mid);border-radius:var(--radius);
  padding:30px;color:var(--ink-soft);text-align:center;}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(30,36,26,.92);display:none;
  align-items:center;justify-content:center;z-index:100;padding:30px;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5);}
.lightbox .lb-close{position:absolute;top:20px;right:28px;color:#fff;font-size:2.4rem;cursor:pointer;
  font-family:Arial,sans-serif;line-height:1;}
.lightbox .lb-cap{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:#eef2e6;
  font-family:"Helvetica Neue",Arial,sans-serif;font-size:.95rem;}

/* contact */
.contact-card{background:var(--sage-deep);color:#eef2e6;border-radius:var(--radius);
  padding:40px;text-align:center;box-shadow:var(--shadow);}
.contact-card h2{color:#fff;margin-top:0;}
.contact-card a{color:var(--gold-soft);}

/* footer */
.footer{background:#3f4a37;color:#cdd6c2;text-align:center;padding:28px 22px;font-size:.9rem;
  font-family:"Helvetica Neue",Arial,sans-serif;}
.footer span{color:var(--gold-soft);}

/* responsive */
@media (max-width:860px){
  .hero-inner{grid-template-columns:1fr;text-align:center;justify-items:center;gap:26px;}
  .hero-cta{justify-content:center;}
  .about-grid{grid-template-columns:1fr;}
  .cards{grid-template-columns:1fr;}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--sage-deep);
    flex-direction:column;padding:14px 22px;gap:14px;}
  .nav-links.open{display:flex;}
  .nav-toggle{display:block;}
  .hero h1{font-size:2.2rem;}
}
