/* ============================================================
   HS Baskets by Henrietta — hsbaskets.com
   Earth-tone palette:
     --sand-mid    #B0A48F   khaki
     --sand-pale   #DBD3C6   light sand
     --cream       #EBE6D2   page bg
     --olive       #B8B68F   sage / accent
     --white       #FFFFFF
     --accent      #DDA15E   CTA / link hover
     --ink         #3a2f1f   deep coffee text
     --ink-soft    #5c4f3a   secondary text
============================================================ */

:root{
  --sand-mid:#B0A48F;
  --sand-pale:#DBD3C6;
  --cream:#EBE6D2;
  --olive:#B8B68F;
  --white:#FFFFFF;
  --accent:#DDA15E;
  --ink:#3a2f1f;
  --ink-soft:#5c4f3a;
  --shadow:0 6px 24px rgba(58,47,31,.12);
  --shadow-sm:0 2px 8px rgba(58,47,31,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;border-bottom:1px solid transparent;transition:color .15s,border-color .15s}
a:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* ----------- Header / Nav ----------- */
.site-header{
  background:var(--white);
  border-bottom:1px solid var(--sand-pale);
  position:sticky;top:0;z-index:50;
}
.nav-wrap{
  max-width:1180px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
}
.brand{
  font-family:"Didot","Bodoni 72",Georgia,serif;
  font-size:1.45rem;letter-spacing:.04em;color:var(--ink);
  border:none;
}
.brand small{
  display:block;font-family:"Iowan Old Style",Georgia,serif;
  font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-soft);margin-top:2px;
}
.nav-links{
  display:flex;gap:28px;list-style:none;margin:0;padding:0;
  font-size:.92rem;letter-spacing:.05em;text-transform:uppercase;
}
.nav-links a{border:none;color:var(--ink-soft);font-weight:500}
.nav-links a.active,.nav-links a:hover{color:var(--accent)}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--ink)}
@media (max-width:820px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--white);padding:18px 28px;border-bottom:1px solid var(--sand-pale)}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
}

/* ----------- Hero ----------- */
.hero{
  position:relative;
  background:var(--sand-pale);
  overflow:hidden;
}
.hero-inner{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1.05fr 1fr;gap:56px;
  padding:80px 28px;align-items:center;
}
.hero h1{
  font-family:"Didot","Bodoni 72",Georgia,serif;
  font-size:clamp(2.2rem,4.3vw,3.4rem);
  line-height:1.1;letter-spacing:.005em;
  margin:0 0 .5em 0;color:var(--ink);
}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero p.lede{font-size:1.12rem;color:var(--ink-soft);max-width:42ch}
.hero-img{
  border-radius:6px;
  box-shadow:var(--shadow);
  background:var(--white);
  aspect-ratio:4/5;object-fit:cover;
}
.hero-cta{margin-top:24px;display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-block;padding:13px 26px;border-radius:2px;
  font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;
  font-weight:600;border:1px solid var(--ink);background:var(--ink);color:var(--white);
  transition:background .15s,color .15s,border-color .15s;cursor:pointer;
}
.btn:hover{background:var(--accent);border-color:var(--accent);color:var(--white)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--white)}
@media (max-width:820px){
  .hero-inner{grid-template-columns:1fr;padding:48px 24px;gap:32px}
}

/* ----------- Section frame ----------- */
section{padding:80px 28px}
.container{max-width:1180px;margin:0 auto}
.eyebrow{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:14px;
}
h2{
  font-family:"Didot","Bodoni 72",Georgia,serif;
  font-size:clamp(1.7rem,3vw,2.4rem);
  margin:0 0 .35em 0;color:var(--ink);line-height:1.15;
}
h3{
  font-family:"Iowan Old Style",Georgia,serif;
  font-weight:600;font-size:1.15rem;color:var(--ink);margin:0 0 .35em 0;
}
.lead{font-size:1.08rem;max-width:64ch;color:var(--ink-soft)}

/* Alt section backgrounds */
.bg-cream{background:var(--cream)}
.bg-white{background:var(--white)}
.bg-sand{background:var(--sand-pale)}
.bg-olive{background:var(--olive);color:var(--white)}
.bg-olive h2,.bg-olive h3{color:var(--white)}
.bg-olive .lead,.bg-olive p{color:rgba(255,255,255,.92)}
.bg-olive .eyebrow{color:var(--cream)}

/* ----------- Grids ----------- */
.three-up{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:42px}
.two-up{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:42px;align-items:center}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.gallery img{aspect-ratio:1/1;object-fit:cover;border-radius:4px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.gallery img:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
@media (max-width:820px){
  .three-up{grid-template-columns:1fr;gap:28px}
  .two-up{grid-template-columns:1fr;gap:32px}
  .gallery{grid-template-columns:repeat(2,1fr)}
}

/* ----------- Cards ----------- */
.card{
  background:var(--white);padding:28px;border-radius:4px;
  box-shadow:var(--shadow-sm);border:1px solid var(--sand-pale);
}
.card h3{margin-top:0}
.card .meta{font-size:.78rem;color:var(--accent);letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px}
.card a.more{display:inline-block;margin-top:10px;border:none;color:var(--accent);font-weight:600;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase}

/* ----------- Pull quote ----------- */
blockquote.pull{
  font-family:"Didot","Bodoni 72",Georgia,serif;
  font-style:italic;font-size:clamp(1.4rem,2.5vw,2rem);
  line-height:1.35;color:var(--ink);
  max-width:42ch;margin:0 auto;text-align:center;
  border:none;padding:32px 0;
}
blockquote.pull cite{
  display:block;margin-top:18px;
  font-family:"Iowan Old Style",Georgia,serif;font-style:normal;
  font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);
}

/* ----------- Timeline / lineage ----------- */
.lineage{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:36px}
.lineage .gen{background:var(--cream);padding:20px;border-radius:4px;text-align:center;border:1px solid var(--sand-pale)}
.lineage .gen .num{font-family:"Didot",Georgia,serif;font-size:2.4rem;color:var(--accent);line-height:1}
.lineage .gen .name{font-weight:600;margin:6px 0 2px;color:var(--ink)}
.lineage .gen .role{font-size:.8rem;color:var(--ink-soft);letter-spacing:.05em}
@media (max-width:820px){.lineage{grid-template-columns:repeat(2,1fr)}}

/* ----------- News list ----------- */
.news-list{display:grid;grid-template-columns:1fr;gap:18px;margin-top:36px;max-width:780px}
.news-item{
  display:grid;grid-template-columns:120px 1fr;gap:24px;
  padding:24px;background:var(--white);border:1px solid var(--sand-pale);border-radius:4px;
}
.news-item .when{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700}
.news-item h3{margin-bottom:6px}
.news-item .where{font-size:.85rem;color:var(--ink-soft);margin-bottom:10px}
@media (max-width:560px){.news-item{grid-template-columns:1fr;gap:8px}}

/* ----------- Contact form ----------- */
form.contact{display:grid;gap:18px;max-width:620px;margin-top:30px}
form.contact label{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;display:block;margin-bottom:6px}
form.contact input,form.contact select,form.contact textarea{
  width:100%;font:inherit;font-size:1rem;
  padding:13px 14px;background:var(--white);
  border:1px solid var(--sand-mid);border-radius:3px;color:var(--ink);
}
form.contact input:focus,form.contact select:focus,form.contact textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
form.contact textarea{min-height:160px;resize:vertical}
form.contact .field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){form.contact .field-row{grid-template-columns:1fr}}

/* ----------- Footer ----------- */
.site-footer{
  background:var(--ink);color:var(--sand-pale);
  padding:60px 28px 28px;margin-top:60px;
}
.site-footer a{color:var(--sand-pale);border:none}
.site-footer a:hover{color:var(--accent)}
.footer-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;
}
.footer-grid h4{
  font-family:"Iowan Old Style",Georgia,serif;
  font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--olive);margin:0 0 14px 0;
}
.footer-grid p,.footer-grid li{font-size:.92rem;color:var(--sand-pale);margin:0 0 8px 0}
.footer-grid ul{list-style:none;padding:0;margin:0}
.fineprint{
  max-width:1180px;margin:36px auto 0;padding-top:24px;
  border-top:1px solid rgba(219,211,198,.18);
  font-size:.78rem;color:var(--sand-mid);letter-spacing:.08em;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr;gap:28px}}

/* ----------- Utility ----------- */
.center{text-align:center}
.divider{display:block;width:60px;height:2px;background:var(--accent);margin:0 0 22px}
.center .divider{margin-left:auto;margin-right:auto}

/* ----------- Slideshow (rotating banner) ----------- */
.slideshow{
  position:relative;width:100%;
  aspect-ratio:4/5;
  overflow:hidden;border-radius:6px;
  box-shadow:var(--shadow);background:var(--sand-pale);
}
.slideshow.wide{aspect-ratio:4/3}
.slideshow img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity .6s ease-in-out;
}
.slideshow img.is-active{opacity:1}

/* ----------- Full-bleed page banner ----------- */
.page-banner{padding:0;background:var(--sand-pale)}
.page-banner img{
  display:block;width:100%;
  max-height:520px;object-fit:cover;
}

/* ----------- Figure with caption (fanner section, etc) ----------- */
.figure-caption{
  margin-top:10px;font-size:.82rem;letter-spacing:.06em;
  color:var(--ink-soft);font-style:italic;text-align:center;
}
.lineage .gen .name{line-height:1.45}
.lineage .gen .name a{color:var(--ink);font-weight:inherit}
.lineage .gen .name a:hover{color:var(--accent)}
