/* ===========================================================
   Dried Sea Harvest — Design System
   Palette: ink navy / salt white / kraft tan / rust accent
   Type: Fraunces (display, ledger character) + Inter (body/utility)
   =========================================================== */

:root{
  --ink:#1B2A33;
  --ink-soft:#28394384;
  --salt:#F7F4ED;
  --salt-dim:#EDE8DA;
  --kraft:#C9A86A;
  --kraft-dark:#a6824a;
  --rust:#A8462F;
  --rust-dark:#8a3823;
  --charcoal:#2B2B2B;
  --line:#d8d0bc;
  --green-ok:#3f6b4a;
  --radius:2px;
  --maxw:1180px;
  --serif:'Fraunces',"Iowan Old Style","Palatino Linotype",serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,Menlo,monospace;
}

@font-face{
  font-family:'Fraunces';
  src:local('Fraunces');
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--charcoal);
  background:var(--salt);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:600;
  line-height:1.1;
  margin:0 0 .5em;
  color:var(--ink);
}
h1{font-size:clamp(2.1rem,4vw,3.4rem); font-weight:560; letter-spacing:-0.01em;}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem);}
h3{font-size:1.25rem;}
p{margin:0 0 1em;}
.container{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
.section{padding:64px 0;}
.section--tight{padding:36px 0;}
.section--ink{background:var(--ink); color:var(--salt-dim);}
.section--ink h2, .section--ink h3{color:var(--salt);}
.section--kraft{background:var(--salt-dim);}

/* Eyebrow / labels: used only where they encode real info (category, origin) */
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--rust);
  display:inline-block;
  margin-bottom:.6em;
}
.section--ink .eyebrow{color:var(--kraft);}

/* ---------- Header / Nav ---------- */
.site-header{
  border-bottom:1px solid var(--line);
  background:var(--salt);
  position:sticky; top:0; z-index:50;
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{
  font-family:var(--serif); font-size:1.35rem; font-weight:600; color:var(--ink);
  display:flex; align-items:center; gap:10px;
}
.brand .mark{
  width:30px;height:30px; border-radius:50%;
  background:var(--ink); color:var(--kraft);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:.85rem;
}
.main-nav{display:flex; gap:26px; align-items:center; flex-wrap:wrap;}
.main-nav a{
  font-size:.92rem; color:var(--ink); position:relative; padding:4px 0;
}
.main-nav a:hover{color:var(--rust);}
.nav-cta{
  background:var(--rust); color:#fff !important; padding:9px 18px;
  border-radius:var(--radius); font-weight:600; font-size:.88rem;
}
.nav-cta:hover{background:var(--rust-dark);}
.nav-toggle{display:none; background:none; border:none; font-size:1.6rem; cursor:pointer;}

@media (max-width:860px){
  .main-nav{
    position:fixed; top:0; right:-100%; height:100vh; width:78%;
    background:var(--ink); flex-direction:column; padding:90px 28px 28px;
    transition:right .25s ease; align-items:flex-start;
  }
  .main-nav.open{right:0;}
  .main-nav a{color:var(--salt); font-size:1.05rem;}
  .nav-toggle{display:block;}
}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(180deg,var(--ink) 0%, #233741 100%);
  color:var(--salt);
  padding:84px 0 70px;
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background-image:repeating-linear-gradient(90deg, rgba(201,168,106,.06) 0 1px, transparent 1px 80px);
  pointer-events:none;
}
.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center;}
.hero h1{color:var(--salt); margin-bottom:.4em;}
.hero .lede{font-size:1.15rem; color:#d8d6cd; max-width:46ch;}
.hero-cta-row{display:flex; gap:14px; margin-top:28px; flex-wrap:wrap;}
.btn{
  display:inline-block; padding:13px 24px; border-radius:var(--radius);
  font-weight:600; font-size:.95rem; border:1.5px solid transparent; cursor:pointer;
}
.btn-primary{background:var(--rust); color:#fff;}
.btn-primary:hover{background:var(--rust-dark);}
.btn-outline{border-color:var(--salt-dim); color:var(--salt);}
.btn-outline:hover{background:rgba(255,255,255,.08);}
.btn-dark{background:var(--ink); color:var(--salt);}
.btn-dark:hover{background:#0f1a20;}
.hero-manifest{
  background:var(--salt); color:var(--ink); border-radius:3px;
  padding:22px 24px; font-family:var(--mono); font-size:.82rem;
  box-shadow:0 18px 40px rgba(0,0,0,.35);
}
.hero-manifest .row{display:flex; justify-content:space-between; padding:7px 0; border-bottom:1px dashed var(--line);}
.hero-manifest .row:last-child{border-bottom:none;}
.hero-manifest .label{color:var(--ink-soft); }
.hero-manifest .head{font-family:var(--sans); font-weight:700; text-transform:uppercase; letter-spacing:.06em; font-size:.7rem; color:var(--rust); margin-bottom:6px;}

@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;}
}

/* ---------- Trust strip ---------- */
.trust-strip{
  display:flex; gap:32px; flex-wrap:wrap; justify-content:space-between;
  padding:22px 0; border-bottom:1px solid var(--line); font-size:.85rem; color:var(--ink-soft);
}
.trust-strip span{font-family:var(--mono);}

/* ---------- Category / Product grid ---------- */
.grid{
  display:grid; gap:22px;
  grid-template-columns:repeat(auto-fill,minmax(250px,1fr));
}
.card{
  background:#fff; border:1px solid var(--line); border-radius:3px;
  overflow:hidden; transition:transform .15s ease, box-shadow .15s ease;
}
.card:hover{transform:translateY(-3px); box-shadow:0 14px 28px rgba(27,42,51,.12);}
.card img{aspect-ratio:4/3; object-fit:cover; width:100%; background:var(--salt-dim);}
.card-body{padding:16px 18px 20px;}
.card-cat{font-family:var(--mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--rust);}
.card h3{font-size:1.05rem; margin:.3em 0 .35em;}
.card p{font-size:.88rem; color:var(--ink-soft); margin-bottom:.8em;}
.card-link{font-size:.85rem; font-weight:600; color:var(--ink); border-bottom:1.5px solid var(--kraft);}

/* ---------- Product detail page ---------- */
.product-hero{display:grid; grid-template-columns:1fr 1fr; gap:48px; padding:48px 0;}
.product-gallery .main-image{
  width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:3px; border:1px solid var(--line); background:var(--salt-dim);
}
.swatch-row{display:flex; gap:10px; margin-top:14px; flex-wrap:wrap;}
.swatch{
  border:1.5px solid var(--line); border-radius:2px; cursor:pointer;
  width:74px; padding:0; background:#fff; overflow:hidden;
}
.swatch img{aspect-ratio:1/1; object-fit:cover;}
.swatch .swatch-label{
  display:block; font-size:.66rem; text-align:center; padding:4px 2px;
  font-family:var(--mono); color:var(--ink-soft); border-top:1px solid var(--line);
}
.swatch.active{border-color:var(--rust);}
.swatch.active .swatch-label{color:var(--rust); font-weight:700;}

.product-info .eyebrow{margin-bottom:.3em;}
.product-info h1{font-size:clamp(1.8rem,3vw,2.4rem);}
.lede-product{font-size:1.04rem; color:var(--ink-soft);}

.order-box{
  background:var(--salt-dim); border:1px solid var(--line); border-radius:3px;
  padding:24px; margin-top:24px;
}
.field-label{
  font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.07em;
  color:var(--ink-soft); display:block; margin-bottom:6px;
}
select.qty-select{
  width:100%; padding:12px 14px; font-size:.95rem; border:1.5px solid var(--line);
  border-radius:2px; background:#fff; font-family:var(--sans); margin-bottom:18px;
}
.price-readout{
  display:flex; justify-content:space-between; align-items:baseline;
  border-top:1px dashed var(--line); padding-top:14px; margin-bottom:18px;
}
.price-readout .amount{font-family:var(--mono); font-size:1.6rem; color:var(--ink); font-weight:700;}
.price-readout .note{font-size:.76rem; color:var(--ink-soft); max-width:22ch; text-align:right;}
.btn-order{width:100%; text-align:center; padding:16px; font-size:1rem;}

.manifest-table{width:100%; border-collapse:collapse; margin:18px 0; font-size:.9rem;}
.manifest-table caption{text-align:left; font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-soft); margin-bottom:8px;}
.manifest-table th,.manifest-table td{padding:10px 12px; border-bottom:1px solid var(--line); text-align:left;}
.manifest-table th{font-family:var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.05em; color:var(--rust); background:var(--salt-dim);}
.manifest-table td.num{font-family:var(--mono); text-align:right;}

@media (max-width:860px){
  .product-hero{grid-template-columns:1fr;}
}

/* ---------- Related / internal links ---------- */
.related-row{display:flex; gap:16px; flex-wrap:wrap;}
.related-pill{
  border:1px solid var(--line); border-radius:30px; padding:9px 16px; font-size:.85rem; background:#fff;
}
.related-pill:hover{border-color:var(--rust); color:var(--rust);}

/* ---------- Forms (Order / Contact) ---------- */
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px;}
.form-grid .full{grid-column:1/-1;}
label{font-size:.85rem; font-weight:600; display:block; margin-bottom:6px; color:var(--ink);}
input,textarea,select{
  width:100%; padding:12px 13px; border:1.5px solid var(--line); border-radius:2px;
  font-family:var(--sans); font-size:.95rem; background:#fff;
}
input:focus,textarea:focus,select:focus{outline:2px solid var(--rust); outline-offset:1px;}
.summary-banner{
  background:var(--ink); color:var(--salt); border-radius:3px; padding:20px 24px; margin-bottom:30px;
  font-family:var(--mono); font-size:.9rem;
}
.summary-banner .label{color:var(--kraft); text-transform:uppercase; font-size:.68rem; letter-spacing:.08em;}
.summary-banner .big{font-size:1.3rem; margin-top:4px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink); color:#b9bfc2; padding:54px 0 28px; margin-top:64px;}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px;}
.footer-grid h4{color:var(--salt); font-family:var(--sans); font-size:.85rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:14px;}
.footer-grid a{display:block; font-size:.88rem; padding:5px 0; color:#b9bfc2;}
.footer-grid a:hover{color:var(--kraft);}
.footer-bottom{border-top:1px solid #324049; margin-top:36px; padding-top:20px; font-size:.8rem; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;}}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid var(--line); padding:18px 0;}
.faq-item summary{font-weight:600; cursor:pointer; font-size:1.02rem; color:var(--ink);}
.faq-item p{margin-top:10px; color:var(--ink-soft);}

/* ---------- Utility ---------- */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.flex-between{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;}
.tag-list{display:flex; gap:8px; flex-wrap:wrap; margin:10px 0;}
.tag{font-family:var(--mono); font-size:.7rem; background:var(--salt-dim); border:1px solid var(--line); padding:4px 9px; border-radius:20px; color:var(--ink-soft);}
.skip-link{position:absolute; left:-9999px;}
.skip-link:focus{left:8px; top:8px; background:var(--rust); color:#fff; padding:8px 14px; z-index:999;}
@media (prefers-reduced-motion: reduce){*{animation:none !important; transition:none !important;}}
:focus-visible{outline:2px solid var(--rust); outline-offset:2px;}
