/* ============================================================
   WEDDERS — refined men's bands
   Palette: warm bone paper, ink charcoal, brushed-brass accent
   Type: Fraunces (display serif) + Hanken Grotesk (body)
   ============================================================ */

:root{
  --paper:   #f3efe7;
  --paper-2: #ebe5d9;
  --ink:     #1c1916;
  --ink-2:   #4a443d;
  --brass:   #9a7b4f;
  --brass-d: #7e6340;
  --line:    #d8cfbf;
  --white:   #fbf9f4;
  --maxw:    1180px;
  --r:       4px;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:"Hanken Grotesk", system-ui, sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,.serif{ font-family:"Fraunces", Georgia, serif; font-weight:500; }

a{ color:inherit; text-decoration:none; }

img,svg{ display:block; max-width:100%; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* ---------- Top announcement ---------- */
.announce{
  background:var(--ink); color:var(--paper);
  text-align:center; font-size:.74rem; letter-spacing:.18em;
  text-transform:uppercase; padding:9px 16px;
}

/* ---------- Header ---------- */
header.site{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  position:sticky; top:0; z-index:50;
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand{
  font-family:"Fraunces", serif; font-weight:600; font-size:1.7rem;
  letter-spacing:.02em; line-height:1;
}
.brand span{ color:var(--brass); }
.nav-links{ display:flex; gap:30px; }
.nav-links a{
  font-size:.82rem; letter-spacing:.13em; text-transform:uppercase;
  color:var(--ink-2); padding:6px 0; position:relative;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--brass); transition:width .25s ease;
}
.nav-links a:hover::after{ width:100%; }
.cart-link{
  font-size:.82rem; letter-spacing:.1em; text-transform:uppercase;
  border:1px solid var(--ink); padding:9px 16px; border-radius:var(--r);
  transition:background .2s,color .2s;
}
.cart-link:hover{ background:var(--ink); color:var(--paper); }

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(120% 90% at 80% 0%, rgba(154,123,79,.18), transparent 60%),
    var(--ink);
  color:var(--paper); padding:96px 0 104px; position:relative; overflow:hidden;
}
.hero .wrap{ position:relative; z-index:2; max-width:760px; }
.hero .eyebrow{
  font-size:.78rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--brass); margin-bottom:22px;
}
.hero h1{ font-size:clamp(2.6rem,6vw,4.6rem); line-height:1.04; font-weight:400; }
.hero h1 em{ font-style:italic; color:var(--brass); }
.hero p{ margin:24px 0 36px; max-width:520px; color:#cfc7b8; font-size:1.05rem; }
.btn{
  display:inline-block; font-size:.82rem; letter-spacing:.14em;
  text-transform:uppercase; padding:14px 30px; border-radius:var(--r);
  border:1px solid var(--brass); background:var(--brass); color:var(--ink);
  font-weight:600; transition:transform .15s, background .2s;
}
.btn:hover{ background:#b3925e; transform:translateY(-1px); }
.btn.ghost{ background:transparent; color:var(--paper); border-color:#56504700; border:1px solid #6b6253; margin-left:10px; }
.btn.ghost:hover{ border-color:var(--paper); background:transparent; }
.hero-rings{ position:absolute; right:-60px; top:50%; transform:translateY(-50%);
  width:480px; opacity:.16; z-index:1; }

/* ---------- Section headings ---------- */
.section{ padding:78px 0; }
.section-head{ text-align:center; max-width:640px; margin:0 auto 50px; }
.section-head .eyebrow{
  font-size:.76rem; letter-spacing:.3em; text-transform:uppercase;
  color:var(--brass); margin-bottom:14px;
}
.section-head h2{ font-size:clamp(2rem,4vw,2.8rem); line-height:1.1; }
.section-head p{ color:var(--ink-2); margin-top:14px; }

/* ---------- Collection split cards ---------- */
.collections{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.coll-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r);
  padding:46px 40px; position:relative; overflow:hidden; transition:border-color .2s, transform .2s;
}
.coll-card:hover{ border-color:var(--brass); transform:translateY(-3px); }
.coll-card .ring-svg{ width:120px; margin-bottom:26px; }
.coll-card h3{ font-size:1.7rem; margin-bottom:8px; }
.coll-card .tag{ color:var(--ink-2); margin-bottom:22px; }
.coll-card .more{
  font-size:.8rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brass-d); font-weight:600;
}
.coll-card .more::after{ content:" →"; }

/* ---------- Product grid ---------- */
.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden; transition:transform .2s, box-shadow .2s, border-color .2s;
}
.card:hover{ transform:translateY(-4px); box-shadow:0 18px 40px -24px rgba(28,25,22,.4); border-color:var(--brass); }
.card .thumb{
  background:linear-gradient(160deg,var(--paper-2),var(--white));
  aspect-ratio:1/1; display:flex; align-items:center; justify-content:center;
  border-bottom:1px solid var(--line);
}
.card .thumb .ring-svg{ width:62%; }
.card .thumb .ring-photo{ width:100%; height:100%; object-fit:cover; }
.card .body{ padding:22px 22px 26px; }
.card .meta{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--brass-d); margin-bottom:8px; }
.card h3{ font-size:1.3rem; margin-bottom:6px; }
.card .spec{ font-size:.86rem; color:var(--ink-2); }
.card .price{ margin-top:14px; font-weight:600; font-size:1.05rem; }

/* ---------- Filters bar ---------- */
.filters{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:42px; }
.filters a{
  font-size:.78rem; letter-spacing:.08em; text-transform:uppercase;
  padding:8px 16px; border:1px solid var(--line); border-radius:40px; color:var(--ink-2);
  transition:all .2s;
}
.filters a:hover, .filters a.active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* ---------- Product detail ---------- */
.pd{ display:grid; grid-template-columns:1fr 1fr; gap:56px; padding:64px 0; }
.pd .gallery{
  background:linear-gradient(160deg,var(--paper-2),var(--white));
  border:1px solid var(--line); border-radius:var(--r);
  display:flex; align-items:center; justify-content:center; padding:48px; min-height:440px;
}
.pd .gallery .ring-svg{ width:70%; }
.pd .gallery .ring-photo{ width:100%; height:100%; max-height:440px; object-fit:contain; }
.pd .crumb{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); margin-bottom:18px; }
.pd .crumb a{ color:var(--brass-d); }
.pd h1{ font-size:2.4rem; line-height:1.1; }
.pd .price-lg{ font-size:1.6rem; font-weight:600; margin:14px 0 22px; }
.pd .desc{ color:var(--ink-2); margin-bottom:26px; }
.spec-table{ width:100%; border-top:1px solid var(--line); margin-bottom:28px; }
.spec-table div{ display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--line); font-size:.9rem; }
.spec-table div span:first-child{ color:var(--ink-2); letter-spacing:.04em; text-transform:uppercase; font-size:.74rem; }

.field{ margin-bottom:22px; }
.field label{ display:block; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); margin-bottom:9px; }
select, input[type=text]{
  width:100%; padding:13px 14px; border:1px solid var(--line); border-radius:var(--r);
  background:var(--white); font-family:inherit; font-size:.95rem; color:var(--ink);
}
select:focus, input:focus{ outline:none; border-color:var(--brass); }
.engrave-toggle{ display:flex; align-items:center; gap:10px; cursor:pointer; user-select:none; }
.engrave-toggle input{ width:18px; height:18px; accent-color:var(--brass); }
.engrave-fee{ color:var(--ink-2); font-size:.85rem; }
#engraveWrap{ margin-top:14px; display:none; }
.btn-full{ width:100%; text-align:center; padding:16px; font-size:.9rem; }

/* ---------- Cart ---------- */
.cart-row{
  display:grid; grid-template-columns:90px 1fr auto; gap:20px; align-items:center;
  padding:22px 0; border-bottom:1px solid var(--line);
}
.cart-row .thumb-sm{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); padding:10px; }
.cart-row h3{ font-size:1.2rem; }
.cart-row .sub{ color:var(--ink-2); font-size:.86rem; margin-top:4px; }
.cart-row .line-price{ font-weight:600; white-space:nowrap; }
.cart-total{ display:flex; justify-content:flex-end; gap:40px; align-items:baseline; padding:26px 0; font-size:1.3rem; }
.cart-total .label{ font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-2); }
.empty{ text-align:center; padding:80px 0; color:var(--ink-2); }
.checkout-form{ max-width:460px; margin-left:auto; }
.notice{ background:#e7efe4; border:1px solid #b9d3ad; color:#33532a; padding:16px 18px; border-radius:var(--r); margin-bottom:26px; font-size:.92rem; }
.remove{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--brass-d); margin-top:8px; display:inline-block; }

/* ---------- Trust strip ---------- */
.trust{ background:var(--ink); color:var(--paper); }
.trust .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding:30px 28px; text-align:center; }
.trust .t-item{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:#cfc7b8; }
.trust .t-item strong{ display:block; color:var(--brass); font-size:.92rem; margin-bottom:4px; letter-spacing:.1em; }

/* ---------- Footer ---------- */
footer.site{ background:var(--paper-2); border-top:1px solid var(--line); padding:48px 0 30px; margin-top:20px; }
footer.site .cols{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:30px; }
footer.site .brand{ font-size:1.4rem; }
footer.site .fnav{ display:flex; gap:26px; flex-wrap:wrap; }
footer.site .fnav a{ font-size:.84rem; color:var(--ink-2); }
footer.site .fnav a:hover{ color:var(--ink); }
footer.site .copy{ margin-top:34px; font-size:.76rem; color:var(--ink-2); letter-spacing:.04em; }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .grid{ grid-template-columns:1fr 1fr; }
  .pd{ grid-template-columns:1fr; gap:32px; }
  .collections{ grid-template-columns:1fr; }
  .trust .wrap{ grid-template-columns:1fr 1fr; gap:18px; }
  .nav-links{ display:none; }
}
@media (max-width:560px){
  .grid{ grid-template-columns:1fr; }
  .cart-total{ justify-content:space-between; }
}

/* ---------- Product media (gallery + thumbs + video) ---------- */
.pd .media{ display:flex; flex-direction:column; gap:14px; }
.thumbs{ display:flex; gap:10px; }
.thumb-btn{ width:74px; height:74px; padding:0; border:1px solid var(--line); border-radius:var(--r);
  background:var(--white); cursor:pointer; overflow:hidden; transition:border-color .2s; }
.thumb-btn img{ width:100%; height:100%; object-fit:cover; }
.thumb-btn.active{ border-color:var(--brass); }
.video{ position:relative; padding-top:56.25%; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.video iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ---------- Option radios (metal / width) ---------- */
.radios{ display:flex; flex-wrap:wrap; gap:10px; }
.opt{ cursor:pointer; }
.opt input{ position:absolute; opacity:0; width:0; height:0; }
.opt-box{ display:flex; flex-direction:column; gap:2px; min-width:96px;
  border:1px solid var(--line); border-radius:var(--r); padding:10px 14px; background:var(--white);
  transition:border-color .15s, background .15s; }
.opt-box .opt-name{ font-size:.92rem; font-weight:600; color:var(--ink); }
.opt-box .opt-price{ font-size:.78rem; color:var(--ink-2); }
.opt input:checked + .opt-box{ border-color:var(--brass); background:#f6efe3; }
.opt input:focus-visible + .opt-box{ outline:2px solid var(--brass); }
