/* ===================================================================
   William Allott Workshop — shared styles for every page
   Edit colours, type and spacing here once; it applies site-wide.
   =================================================================== */

/* ============================== TOKENS ============================== */
:root{
  --ink:#221C15;        /* warm near-black — text & buttons   */
  --paper:#F4F0E7;      /* warm off-white — page background    */
  --surface:#FFFFFF;    /* cards                              */
  --placeholder:#ECE6D8;/* image placeholders                 */
  --accent:#9A6A3D;     /* cognac — single restrained accent  */
  --muted:#6E645A;      /* warm grey — secondary text         */
  --soft:#4A4036;       /* body-on-paper, softer than ink     */
  --line:#E0D9CA;       /* warm hairline — borders & rules    */

  --sans:"Jost","Times New Roman",Times,serif;

  --maxw:1160px;
  --reading:680px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
img{max-width:100%;display:block}
a{color:inherit}

/* shared type */
h1,h2,h3{margin:0;font-weight:400;line-height:1.1;letter-spacing:-.005em}
.eyebrow{
  text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;font-weight:500;
  color:var(--muted);margin:0 0 1.1rem;display:flex;align-items:center;gap:.85em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent)}
.rule{height:1px;background:var(--line);border:0;margin:0}

/* ============================== ANNOUNCEMENT BANNER ============================== */
.banner{background:var(--ink);color:var(--paper)}
.banner[hidden]{display:none}
.banner .wrap{display:flex;align-items:center;justify-content:center;gap:.7em;
  min-height:44px;padding-block:9px;text-align:center}
.banner p{margin:0;font-size:.82rem;letter-spacing:.04em}
.banner a{color:#fff;text-underline-offset:3px}

/* ============================== NAV ============================== */
.nav{position:sticky;top:0;z-index:50;background:rgba(244,240,231,.88);
  backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);
  border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;
  gap:18px;min-height:66px}
.brand{text-transform:uppercase;letter-spacing:.18em;font-size:.92rem;font-weight:600;
  text-decoration:none;white-space:nowrap}
.brand span{color:var(--muted);font-weight:400;margin-left:.5em}
.links{display:flex;align-items:center;gap:30px}
.links a{text-transform:uppercase;letter-spacing:.15em;font-size:.74rem;font-weight:500;
  text-decoration:none;color:var(--ink);transition:color .2s ease}
.links a:hover,.links a:focus-visible{color:var(--accent)}
.menu-btn{display:none}

/* ============================== BUTTONS ============================== */
.btn{display:inline-flex;align-items:center;justify-content:center;
  text-transform:uppercase;letter-spacing:.14em;font-size:.76rem;font-weight:500;
  font-family:var(--sans);text-decoration:none;color:var(--paper);
  background:var(--ink);border:1px solid var(--ink);border-radius:2px;
  padding:1.02em 1.7em;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}
.btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.sm{padding:.78em 1.3em;font-size:.72rem}

/* ============================== HERO ============================== */
.hero{padding-top:clamp(52px,8vw,104px);padding-bottom:clamp(40px,6vw,72px)}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,72px);
  align-items:center}
.hero h1{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:300;line-height:1.08;
  letter-spacing:-.015em;margin:.1em 0 .6em}
.hero h1 .hl{color:var(--accent);font-weight:500}
.lede{font-size:1.12rem;max-width:36ch;color:var(--soft)}
.lede a{color:var(--accent);text-underline-offset:3px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.9em}

/* ============================== IMAGE PLACEHOLDER / SHOT ============================== */
.shot{position:relative;aspect-ratio:4/3;background:var(--placeholder);
  border:1px solid var(--line);border-radius:2px;overflow:hidden;
  display:grid;place-items:center}
.shot::after{content:"WA";font-weight:500;font-size:1.35rem;letter-spacing:.28em;
  text-indent:.28em;color:rgba(110,100,90,.42)}
.shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero-shot{aspect-ratio:5/4}

/* image area that opens a gallery (it's a <button>) */
button.shot{padding:0;font:inherit;color:inherit;text-align:left;
  -webkit-appearance:none;appearance:none;cursor:zoom-in;width:100%}
.shot .count{position:absolute;z-index:2;right:10px;bottom:10px;
  background:rgba(34,28,21,.74);color:#fff;font-size:.64rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;padding:.34em .62em;border-radius:2px;
  display:inline-flex;align-items:center;gap:.45em;transition:background .2s ease}
button.shot:hover .count{background:var(--accent)}
button.shot:hover img{transform:scale(1.03)}
.shot img{transition:transform .4s ease}

/* ============================== LIGHTBOX ============================== */
#lb{position:fixed;inset:0;z-index:100;display:none;
  background:rgba(20,15,11,.93)}
#lb.open{display:grid;place-items:center}
.lb-stage{position:relative;display:grid;place-items:center;width:100%;height:100%;
  padding:clamp(48px,6vw,64px)}
.lb-img{max-width:min(1100px,90vw);max-height:80vh;object-fit:contain;border-radius:2px;
  box-shadow:0 24px 70px -16px rgba(0,0,0,.65);background:var(--placeholder)}
.lb-btn{position:absolute;background:rgba(255,255,255,.1);color:#fff;
  border:1px solid rgba(255,255,255,.25);border-radius:50%;width:46px;height:46px;
  display:grid;place-items:center;cursor:pointer;font-size:1.15rem;line-height:1;
  transition:background .2s ease}
.lb-btn:hover{background:rgba(255,255,255,.24)}
.lb-close{top:20px;right:22px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}
.lb-meta{position:absolute;bottom:20px;left:0;right:0;text-align:center;
  color:rgba(255,255,255,.85);font-size:.85rem;padding-inline:20px}
.lb-meta .lb-count{display:block;text-transform:uppercase;letter-spacing:.2em;
  font-size:.66rem;color:rgba(255,255,255,.55);margin-bottom:.3em}

/* ============================== SECTIONS ============================== */
.section{padding-block:clamp(60px,9vw,112px)}
section[id]{scroll-margin-top:86px}
.sec-head{max-width:var(--reading);margin-bottom:clamp(34px,5vw,56px)}
.sec-head h2{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:400}
.sec-head .note{margin:1em 0 0;color:var(--soft);max-width:58ch}
.sec-head .note a{color:var(--accent)}

/* ============================== PRODUCTS ============================== */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(282px,1fr));gap:24px}
.card{display:flex;flex-direction:column;background:var(--surface);
  border:1px solid var(--line);border-radius:2px;overflow:hidden;
  transition:box-shadow .25s ease}
.card:hover{box-shadow:0 16px 36px -24px rgba(34,28,21,.5)}
.card .shot{border:0;border-bottom:1px solid var(--line);border-radius:0;aspect-ratio:4/3}
.card-body{display:flex;flex-direction:column;gap:.6rem;padding:22px 22px 24px;flex:1}
.card-top{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.name{font-size:1.18rem;font-weight:500;line-height:1.15;letter-spacing:0}
.price{font-weight:500;font-size:1rem;white-space:nowrap;color:var(--ink)}
.price .from{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.desc{font-size:.95rem;color:var(--soft);margin:0}
.spec{text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:500;
  color:var(--muted);margin:.1rem 0 0}
.card .btn{margin-top:auto;align-self:flex-start}

/* ============================== GIFT BAND ============================== */
.gift{background:var(--ink);color:var(--paper)}
.gift-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);
  align-items:center;padding-block:clamp(50px,7vw,88px)}
.gift h2{color:var(--paper);font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:400}
.gift .eyebrow{color:rgba(244,240,231,.55)}
.gift .eyebrow::before{background:var(--accent)}
.gift p{color:rgba(244,240,231,.85);max-width:48ch;margin:1em 0 0}
.gift ul{list-style:none;padding:0;margin:1.4em 0 0;display:flex;flex-direction:column;gap:.7em}
.gift li{position:relative;padding-left:1.4em;color:rgba(244,240,231,.85);font-size:.97rem}
.gift li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;
  background:var(--accent);border-radius:50%}
.gift-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.9em}
.gift .btn{background:var(--paper);border-color:var(--paper);color:var(--ink)}
.gift .btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.gift .btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.gift .btn.ghost:hover{border-color:#fff;color:#fff}
.gift-img{aspect-ratio:4/3;border-radius:2px;overflow:hidden;background:rgba(255,255,255,.06)}
.gift-img img{width:100%;height:100%;object-fit:cover}

/* ============================== ABOUT ============================== */
.about-figure{margin:0 0 clamp(34px,5vw,56px);border-radius:2px;overflow:hidden;
  border:1px solid var(--line);aspect-ratio:16/7;background:var(--placeholder)}
.about-figure img{width:100%;height:100%;object-fit:cover}
.about-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(34px,6vw,76px);
  align-items:start}
.about-main p{margin:0 0 1.15em;max-width:60ch}
.about-main a{color:var(--accent);text-underline-offset:3px}
.about-main .sign{font-size:1.18rem;font-weight:500;color:var(--accent);margin-top:.3em}
.notes{border-top:1px solid var(--line)}
.note-item{padding:18px 0;border-bottom:1px solid var(--line)}
.note-item h3{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:600;
  color:var(--muted);margin:0 0 .55em}
.note-item p{margin:0;font-size:.95rem;color:var(--soft)}
.note-item a{color:var(--accent)}

/* ============================== CONTACT ============================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(34px,6vw,64px);
  align-items:start}
.contact-intro p{max-width:46ch;color:var(--soft)}
.methods{list-style:none;padding:0;margin:1.7em 0 0;display:flex;flex-direction:column;gap:16px}
.methods li{display:flex;align-items:baseline;gap:1.2em}
.methods .ic{text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;font-weight:500;
  color:var(--muted);min-width:84px}
.methods a{text-decoration:none;font-weight:500;color:var(--ink);
  border-bottom:1px solid transparent;transition:border-color .2s ease}
.methods a:hover{border-color:var(--accent)}

/* forms */
form{background:var(--surface);border:1px solid var(--line);border-radius:2px;
  padding:clamp(24px,4vw,34px)}
.field{margin-bottom:20px}
.field:last-of-type{margin-bottom:0}
label{display:block;text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;
  font-weight:500;color:var(--muted);margin-bottom:.6em}
input,textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);
  background:#FBF9F4;border:1px solid var(--line);border-radius:2px;padding:.75em .9em;
  transition:border-color .18s ease,box-shadow .18s ease}
textarea{resize:vertical;min-height:124px}
input:focus,textarea:focus{outline:none;border-color:var(--ink);
  box-shadow:0 0 0 3px rgba(154,106,61,.16)}
.honey{position:absolute;left:-9999px}
form .btn{margin-top:24px;width:100%}
.form-fine{font-size:.82rem;color:var(--muted);margin:1.1em 0 0}
.form-fine a{color:var(--accent)}

/* ============================== NEWSLETTER ============================== */
.news{border-top:1px solid var(--line)}
.news-inner{padding-block:clamp(46px,6vw,76px);max-width:540px;margin-inline:auto;text-align:center}
.news h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400}
.news p{color:var(--soft);margin:.8em 0 1.6em;max-width:42ch;margin-inline:auto}
.news form{display:flex;gap:10px;background:none;border:0;padding:0;max-width:440px;margin-inline:auto}
.news input{flex:1}
.news .btn{margin:0;width:auto;white-space:nowrap}
.news .form-fine{margin-top:1.1em}
@media(max-width:480px){.news form{flex-direction:column}.news .btn{width:100%}}

/* ============================== ACCORDIONS (privacy + FAQ) ============================== */
.privacy-wrap{max-width:var(--reading)}
details.privacy,details.qa{border-bottom:1px solid var(--line)}
details.privacy{border-top:1px solid var(--line)}
.qa-list{border-top:1px solid var(--line)}
details.privacy summary,details.qa summary{cursor:pointer;list-style:none;padding:22px 0;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-size:1.1rem;font-weight:500}
details.privacy summary::-webkit-details-marker,
details.qa summary::-webkit-details-marker{display:none}
details.privacy summary .chev,details.qa summary .chev{color:var(--muted);font-size:1.5rem;
  line-height:1;flex:none;transition:transform .2s ease}
details.privacy[open] summary .chev,details.qa[open] summary .chev{transform:rotate(45deg)}
.policy,.answer{padding:0 0 26px;font-size:.95rem;color:var(--soft)}
.policy h4{font-weight:600;font-size:.95rem;color:var(--ink);margin:1.5em 0 .3em}
.policy p,.answer p{margin:.3em 0}
.policy ul,.answer ul{margin:.3em 0;padding-left:1.2em}
.policy a,.answer a{color:var(--accent)}

/* ============================== INFO PAGES ============================== */
.page-head{padding-top:clamp(40px,6vw,76px);padding-bottom:clamp(20px,3vw,32px)}
.crumbs{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);
  margin-bottom:1.5em}
.crumbs a{text-decoration:none;color:var(--muted)}
.crumbs a:hover{color:var(--accent)}
.crumbs span{color:var(--line);margin:0 .5em}
.page-head h1{font-size:clamp(2.1rem,4.6vw,3.2rem);font-weight:300;letter-spacing:-.015em}
.page-head .lead{font-size:1.1rem;color:var(--soft);max-width:56ch;margin-top:.7em}
.prose{max-width:var(--reading);padding-bottom:clamp(60px,8vw,100px)}
.prose h2{font-size:1.5rem;font-weight:500;margin:2.1em 0 .5em}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.08rem;font-weight:600;margin:1.7em 0 .3em}
.prose p{margin:0 0 1.1em;color:var(--soft)}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.3em;color:var(--soft)}
.prose li{margin:.35em 0}
.prose a{color:var(--accent);text-underline-offset:3px}
.prose strong{color:var(--ink);font-weight:600}
.prose .rule{margin:2.6em 0}
.callout{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:2px;padding:18px 22px;margin:1.7em 0}
.callout p{margin:.3em 0}
.callout p:first-child{margin-top:0}
.callout p:last-child{margin-bottom:0}
.diagram{border:1px solid var(--line);border-radius:2px;background:var(--surface);
  padding:22px;margin:1.7em 0}
.diagram svg{width:100%;height:auto;display:block}

/* ============================== FOOTER ============================== */
.foot{padding:46px 0;border-top:1px solid var(--line)}
.foot-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:36px}
.foot-cols h4{text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;font-weight:600;
  color:var(--muted);margin:0 0 1.1em}
.foot-cols .brand{font-size:1rem;display:inline-block;margin-bottom:.9em}
.foot-cols .blurb{font-size:.92rem;color:var(--soft);max-width:34ch;margin:0}
.foot-nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.7em}
.foot-nav a{text-decoration:none;font-size:.92rem;color:var(--soft);
  transition:color .2s ease}
.foot-nav a:hover{color:var(--accent)}
.foot-base{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  border-top:1px solid var(--line);padding-top:22px}
.copy{font-size:.76rem;color:var(--muted);margin:0}
.foot-social{display:flex;gap:20px}
.foot-social a{text-transform:uppercase;letter-spacing:.13em;font-size:.72rem;font-weight:500;
  text-decoration:none;color:var(--ink);transition:color .2s ease}
.foot-social a:hover{color:var(--accent)}
@media(max-width:680px){.foot-cols{grid-template-columns:1fr 1fr}.foot-cols .about-col{grid-column:1/-1}}

/* ============================== 404 ============================== */
.notfound{min-height:58vh;display:grid;place-items:center;text-align:center;padding:64px 24px}
.notfound .big{font-size:clamp(3.4rem,12vw,7rem);font-weight:300;color:var(--accent);line-height:1}
.notfound h1{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:400;margin:.4em 0 0}
.notfound p{color:var(--soft);margin:.7em 0 1.7em;max-width:40ch}
.notfound .btn{margin:6px}

/* ============================== A11Y ============================== */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
.lb-btn:focus-visible{outline-color:#fff}

/* ============================== MOTION ============================== */
.rise{opacity:0;transform:translateY(14px)}
@media (prefers-reduced-motion:no-preference){
  .rise{animation:rise .65s cubic-bezier(.2,.7,.2,1) forwards}
  .d1{animation-delay:.04s}.d2{animation-delay:.14s}.d3{animation-delay:.24s}.d4{animation-delay:.34s}
}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  button.shot:hover img{transform:none}
}

/* ============================== RESPONSIVE ============================== */
@media (max-width:860px){
  .hero-inner{grid-template-columns:1fr}
  .hero-shot{order:-1;max-width:440px}
  .about-grid,.contact-grid,.gift-inner{grid-template-columns:1fr}
  .gift-img{max-width:460px}
  .about-figure{aspect-ratio:16/9}
}
@media (max-width:600px){
  body{font-size:16px}
  .links{display:none}
  .links.open{display:flex;position:absolute;top:66px;right:0;left:0;
    flex-direction:column;align-items:flex-start;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:6px 24px 14px}
  .links.open a{padding:13px 0;width:100%;border-bottom:1px solid var(--line)}
  .menu-btn{display:inline-flex;align-items:center;justify-content:center;
    background:transparent;border:1px solid var(--line);border-radius:2px;
    width:42px;height:38px;cursor:pointer;color:var(--ink);font-size:1.1rem}
  .hero-cta .btn{flex:1}
  .lb-prev{left:8px}.lb-next{right:8px}
}

/* ============================== ETHICS STATEMENT ============================== */
.ethos{max-width:var(--reading);margin-top:clamp(34px,5vw,52px);
  padding-top:clamp(28px,4vw,40px);border-top:1px solid var(--line)}
.ethos p:not(.eyebrow){margin:0;color:var(--soft);max-width:64ch}

/* ============================== FORM STATUS ============================== */
.form-status{margin:.2rem 0 0;font-size:.92rem;line-height:1.55}
.form-status.ok{color:#3f6b46}
.form-status.err{color:#9a3b2f}
