/* =========================================================================
   INK IMPRESSION — editorial gallery storefront
   Design system + components. Self-contained, no build step.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,300..600&family=Hanken+Grotesk:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --paper:        #f5f1e8;
  --paper-2:      #efe9dc;
  --ink:          #1a1814;
  --ink-soft:     #4a463d;
  --ink-faint:    #8b8576;
  --line:         #ddd6c6;
  --line-strong:  #c8c0ac;
  --accent:       #8a3324;   /* oxblood ink */
  --accent-soft:  #b5614f;
  --white:        #fbf9f4;

  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:  'Hanken Grotesk', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:  'IBM Plex Mono', ui-monospace, monospace;

  --gut: clamp(20px, 5vw, 64px);   /* page side gutter */
  --maxw: 1360px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-weight:400; line-height:1.6;
  font-size:16px; letter-spacing:.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---- typography ---------------------------------------------------------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; line-height:1.04;
  letter-spacing:-.015em; margin:0; }
.display{ font-size:clamp(3rem, 9vw, 7.5rem); font-weight:340;
  font-optical-sizing:auto; }
.eyebrow{ font-family:var(--sans); font-weight:600; font-size:.7rem;
  letter-spacing:.28em; text-transform:uppercase; color:var(--ink-faint); }
.serif-italic{ font-style:italic; }
.plate{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-faint); }

/* ---- layout helpers ------------------------------------------------------ */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.rule{ height:1px; background:var(--line); border:0; margin:0; }
.section{ padding-block:clamp(56px, 9vw, 130px); }
.center{ text-align:center; }
.muted{ color:var(--ink-soft); }
.flow > * + *{ margin-top:1rem; }

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:90;
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:blur(10px) saturate(1.1);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between;
  height:72px; gap:24px; }
.brand{ display:flex; align-items:baseline; gap:.55rem; }
.brand .mark{ font-family:var(--serif); font-weight:380; font-size:1.45rem;
  letter-spacing:-.02em; line-height:1; }
.brand .mark em{ font-style:italic; color:var(--accent); }
.brand .tag{ font-family:var(--mono); font-size:.6rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ink-faint); }
.nav-links{ display:flex; gap:34px; list-style:none; margin:0; padding:0; }
.nav-links a{ font-size:.82rem; letter-spacing:.06em; position:relative;
  padding-block:6px; color:var(--ink-soft); transition:color .25s; }
.nav-links a::after{ content:""; position:absolute; left:0; right:100%; bottom:0;
  height:1px; background:var(--ink); transition:right .35s var(--ease); }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after, .nav-links a.active::after{ right:0; }
.nav-links a.active{ color:var(--ink); }
.nav-right{ display:flex; align-items:center; gap:18px; }
.cart-btn{ background:none; border:0; display:flex; align-items:center; gap:7px;
  font-size:.82rem; letter-spacing:.06em; color:var(--ink); padding:6px 0; }
.cart-btn .count{ font-family:var(--mono); font-size:.7rem;
  background:var(--ink); color:var(--paper); border-radius:99px;
  min-width:19px; height:19px; display:inline-flex; align-items:center;
  justify-content:center; padding:0 5px; transition:transform .3s var(--ease); }
.cart-btn .count.bump{ transform:scale(1.35); }
.burger{ display:none; background:none; border:0; width:26px; height:18px;
  position:relative; }
.burger span{ position:absolute; left:0; right:0; height:1.5px; background:var(--ink);
  transition:.3s var(--ease); }
.burger span:nth-child(1){ top:0; } .burger span:nth-child(2){ top:50%; transform:translateY(-50%);} .burger span:nth-child(3){ bottom:0; }

@media (max-width:860px){
  .nav-links{ position:fixed; inset:72px 0 auto 0; flex-direction:column;
    background:var(--paper); gap:0; padding:8px var(--gut) 24px;
    border-bottom:1px solid var(--line); transform:translateY(-120%);
    transition:transform .4s var(--ease); }
  .nav-links.open{ transform:translateY(0); }
  .nav-links li{ border-top:1px solid var(--line); }
  .nav-links a{ display:block; padding:18px 0; font-size:1rem; }
  .burger{ display:block; }
}

/* =========================================================================
   HERO (home)
   ========================================================================= */
.hero{ position:relative; padding-top:clamp(40px,7vw,90px);
  padding-bottom:clamp(30px,5vw,60px); }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr;
  gap:clamp(24px,4vw,60px); align-items:end; }
.hero-copy .display{ margin-block:.1em .35em; }
.hero-copy .display .ln{ display:block; overflow:hidden; }
.hero-copy .display .ln span{ display:block; transform:translateY(108%);
  animation:rise 1s var(--ease) forwards; }
.hero-copy .display .ln:nth-child(2) span{ animation-delay:.09s; }
.hero-copy .display .ln:nth-child(3) span{ animation-delay:.18s; }
.hero-lead{ max-width:46ch; color:var(--ink-soft); font-size:1.05rem;
  opacity:0; animation:fade .9s ease .5s forwards; }
.hero-actions{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap;
  opacity:0; animation:fade .9s ease .66s forwards; }
.hero-art{ position:relative; }
.hero-art figure{ margin:0; position:relative; overflow:hidden;
  border:1px solid var(--line-strong); background:var(--white);
  aspect-ratio:4/5; box-shadow:0 30px 60px -40px rgba(26,24,20,.5);
  opacity:0; animation:fade 1.1s ease .35s forwards; }
.hero-art img{ width:100%; height:100%; object-fit:cover;
  transform:scale(1.04); }
.hero-art figcaption{ display:flex; justify-content:space-between;
  margin-top:12px; }
@keyframes rise{ to{ transform:translateY(0); } }
@keyframes fade{ to{ opacity:1; } }
@media (max-width:860px){ .hero-grid{ grid-template-columns:1fr; align-items:start; } }

/* marquee strip */
.marquee{ border-block:1px solid var(--line); overflow:hidden;
  background:var(--paper-2); }
.marquee-track{ display:flex; gap:64px; white-space:nowrap; padding-block:14px;
  animation:scroll 38s linear infinite; width:max-content; }
.marquee span{ font-family:var(--mono); font-size:.74rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-soft); }
.marquee span::before{ content:"✦"; margin-right:64px; color:var(--accent); }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn{ display:inline-flex; align-items:center; gap:9px;
  font-family:var(--sans); font-size:.8rem; font-weight:500; letter-spacing:.08em;
  text-transform:uppercase; padding:15px 28px; border:1px solid var(--ink);
  background:var(--ink); color:var(--paper); transition:.3s var(--ease);
  position:relative; }
.btn:hover{ background:transparent; color:var(--ink); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); }
.btn--block{ width:100%; justify-content:center; }
.btn:disabled{ opacity:.4; cursor:not-allowed; }
.link-underline{ font-size:.82rem; letter-spacing:.04em; border-bottom:1px solid var(--line-strong);
  padding-bottom:2px; transition:border-color .3s; }
.link-underline:hover{ border-color:var(--ink); }

/* =========================================================================
   SECTION HEADERS
   ========================================================================= */
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between;
  gap:20px; margin-bottom:clamp(28px,4vw,52px); flex-wrap:wrap; }
.sec-head h2{ font-size:clamp(1.9rem,4vw,3.1rem); }
.sec-head .eyebrow{ display:block; margin-bottom:14px; }

/* =========================================================================
   PRODUCT GRID + CARDS
   ========================================================================= */
.grid{ display:grid; gap:clamp(22px,3vw,42px) clamp(18px,2.4vw,32px); }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:1040px){ .grid--4{ grid-template-columns:repeat(3,1fr);} }
@media (max-width:860px){ .grid--3,.grid--4{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:520px){ .grid--3,.grid--4{ grid-template-columns:1fr 1fr; gap:18px 14px; } }

.card{ display:block; opacity:0; transform:translateY(18px);
  animation:fade .7s var(--ease) forwards; }
.card.reveal{ animation:cardrise .8s var(--ease) forwards; }
@keyframes cardrise{ to{ opacity:1; transform:translateY(0);} }
.card-frame{ position:relative; overflow:hidden; background:var(--white);
  border:1px solid var(--line); aspect-ratio:4/5; }
.card-frame img{ width:100%; height:100%; object-fit:cover;
  transition:transform 1.1s var(--ease), filter .6s; }
.card:hover .card-frame img{ transform:scale(1.06); }
.card-frame .plate-tag{ position:absolute; top:12px; left:12px;
  background:color-mix(in srgb,var(--paper) 80%, transparent);
  backdrop-filter:blur(4px); padding:5px 9px; }
.card-frame .quick{ position:absolute; inset:auto 0 0 0; padding:14px;
  display:flex; justify-content:center;
  transform:translateY(120%); transition:transform .4s var(--ease); }
.card:hover .card-frame .quick{ transform:translateY(0); }
.quick .btn{ padding:11px 20px; font-size:.72rem; }
.badge{ position:absolute; top:12px; right:12px; background:var(--accent);
  color:var(--white); font-family:var(--mono); font-size:.6rem; letter-spacing:.14em;
  text-transform:uppercase; padding:5px 9px; }
.card-meta{ padding-top:14px; display:flex; justify-content:space-between;
  align-items:baseline; gap:12px; }
.card-meta h3{ font-size:1.18rem; letter-spacing:-.01em; }
.card-meta .artist{ font-size:.76rem; color:var(--ink-faint); margin-top:3px;
  letter-spacing:.02em; }
.price{ font-family:var(--serif); font-size:1.1rem; white-space:nowrap; }
.price small{ font-family:var(--mono); font-size:.62rem; color:var(--ink-faint);
  display:block; text-align:right; letter-spacing:.1em; text-transform:uppercase; }

/* =========================================================================
   SHOP TOOLBAR (filters / sort / search)
   ========================================================================= */
.toolbar{ display:flex; align-items:center; gap:20px; flex-wrap:wrap;
  padding-block:22px; border-bottom:1px solid var(--line); margin-bottom:36px; }
.filters{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{ border:1px solid var(--line-strong); background:transparent;
  padding:8px 16px; border-radius:99px; font-size:.76rem; letter-spacing:.05em;
  color:var(--ink-soft); transition:.25s var(--ease); }
.chip:hover{ border-color:var(--ink); color:var(--ink); }
.chip.active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.toolbar-right{ margin-left:auto; display:flex; align-items:center; gap:14px;
  flex-wrap:wrap; }
.search{ display:flex; align-items:center; gap:8px; border:1px solid var(--line-strong);
  border-radius:99px; padding:8px 16px; background:var(--white); }
.search input{ border:0; background:none; outline:none; font-family:var(--sans);
  font-size:.84rem; width:150px; color:var(--ink); }
select.sort{ border:1px solid var(--line-strong); background:var(--white);
  padding:9px 14px; font-family:var(--sans); font-size:.8rem; border-radius:99px;
  color:var(--ink); outline:none; }
.result-count{ font-family:var(--mono); font-size:.72rem; color:var(--ink-faint);
  letter-spacing:.1em; }

/* =========================================================================
   PRODUCT DETAIL
   ========================================================================= */
.pd{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,5vw,80px);
  align-items:start; padding-top:36px; }
@media (max-width:920px){ .pd{ grid-template-columns:1fr; } }
.pd-gallery{ position:sticky; top:100px; display:flex; flex-direction:column; gap:14px; }
@media (max-width:920px){ .pd-gallery{ position:static; } }
.pd-main{ position:relative; border:1px solid var(--line-strong); background:var(--white);
  aspect-ratio:4/5; overflow:hidden; }
.pd-main img{ width:100%; height:100%; object-fit:cover; transition:opacity .4s; }
.pd-thumbs{ display:flex; gap:10px; }
.pd-thumbs button{ width:74px; aspect-ratio:1; border:1px solid var(--line);
  background:var(--white); padding:0; overflow:hidden; opacity:.6; transition:.25s; }
.pd-thumbs button.active,.pd-thumbs button:hover{ opacity:1; border-color:var(--ink); }
.pd-thumbs img{ width:100%; height:100%; object-fit:cover; }

.pd-info .plate{ margin-bottom:14px; display:block; }
.pd-info h1{ font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:.15em; }
.pd-info .artist{ color:var(--ink-soft); font-size:1rem; margin-bottom:26px; }
.pd-info .artist em{ font-family:var(--serif); font-style:italic; }
.pd-price{ font-family:var(--serif); font-size:2rem; display:flex; align-items:baseline;
  gap:12px; margin-bottom:6px; }
.pd-price .was{ font-size:1.1rem; color:var(--ink-faint); text-decoration:line-through; }
.pd-tax{ font-family:var(--mono); font-size:.68rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-faint); margin-bottom:28px; }
.pd-desc{ color:var(--ink-soft); margin-bottom:30px; max-width:52ch; }

.opt-group{ margin-bottom:26px; }
.opt-group .opt-label{ display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-faint); margin-bottom:12px; }
.opt-group .opt-label .val{ color:var(--ink); }
.opts{ display:flex; gap:10px; flex-wrap:wrap; }
.opt{ border:1px solid var(--line-strong); background:var(--white); padding:11px 18px;
  font-size:.84rem; letter-spacing:.02em; color:var(--ink-soft); transition:.2s var(--ease);
  display:flex; flex-direction:column; align-items:flex-start; gap:2px; }
.opt small{ font-family:var(--mono); font-size:.62rem; color:var(--ink-faint); }
.opt:hover{ border-color:var(--ink); color:var(--ink); }
.opt.active{ border-color:var(--ink); background:var(--ink); color:var(--paper); }
.opt.active small{ color:color-mix(in srgb,var(--paper) 70%, transparent); }

.qty-add{ display:flex; gap:12px; margin-block:8px 26px; }
.qty{ display:flex; align-items:center; border:1px solid var(--ink); }
.qty button{ width:46px; height:100%; background:none; border:0; font-size:1.1rem;
  color:var(--ink); }
.qty input{ width:46px; text-align:center; border:0; background:none; outline:none;
  font-family:var(--mono); font-size:.9rem; }
.pd-meta-list{ border-top:1px solid var(--line); margin-top:6px; }
.pd-meta-list div{ display:flex; justify-content:space-between; padding:14px 0;
  border-bottom:1px solid var(--line); font-size:.85rem; }
.pd-meta-list dt{ color:var(--ink-faint); font-family:var(--mono); font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase; }

.assurance{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
  margin-top:26px; }
.assurance div{ font-size:.78rem; color:var(--ink-soft); line-height:1.45; }
.assurance strong{ display:block; font-family:var(--serif); font-size:.95rem;
  color:var(--ink); margin-bottom:3px; font-weight:500; }
@media (max-width:520px){ .assurance{ grid-template-columns:1fr; } }

/* =========================================================================
   CART (page + drawer share styles)
   ========================================================================= */
.cart-page{ display:grid; grid-template-columns:1.6fr .9fr; gap:clamp(28px,4vw,60px);
  padding-top:30px; align-items:start; }
@media (max-width:860px){ .cart-page{ grid-template-columns:1fr; } }
.cart-line{ display:grid; grid-template-columns:96px 1fr auto; gap:20px;
  padding:22px 0; border-bottom:1px solid var(--line); align-items:center; }
.cart-line .thumb{ border:1px solid var(--line); aspect-ratio:4/5; overflow:hidden;
  background:var(--white); }
.cart-line .thumb img{ width:100%; height:100%; object-fit:cover; }
.cart-line h4{ font-family:var(--serif); font-size:1.2rem; font-weight:400; }
.cart-line .variant{ font-family:var(--mono); font-size:.7rem; color:var(--ink-faint);
  letter-spacing:.08em; margin-top:5px; }
.cart-line .ln-bottom{ display:flex; align-items:center; gap:18px; margin-top:12px; }
.cart-line .remove{ background:none; border:0; font-size:.74rem; letter-spacing:.05em;
  color:var(--ink-faint); text-decoration:underline; text-underline-offset:3px; }
.cart-line .remove:hover{ color:var(--accent); }
.cart-line .ln-price{ font-family:var(--serif); font-size:1.2rem; text-align:right; }
.qty.sm button{ width:34px; height:34px; } .qty.sm input{ width:38px; }

.summary{ border:1px solid var(--line-strong); padding:30px; background:var(--white);
  position:sticky; top:100px; }
.summary h3{ font-size:1.5rem; margin-bottom:22px; }
.summary .row{ display:flex; justify-content:space-between; padding:9px 0;
  font-size:.9rem; color:var(--ink-soft); }
.summary .row.total{ border-top:1px solid var(--line); margin-top:10px; padding-top:18px;
  font-family:var(--serif); font-size:1.4rem; color:var(--ink); }
.summary .note{ font-family:var(--mono); font-size:.66rem; color:var(--ink-faint);
  letter-spacing:.06em; line-height:1.5; margin-top:18px; }
.checkout-opts{ display:flex; flex-direction:column; gap:10px; margin-top:22px; }

.empty-state{ text-align:center; padding:90px 0; }
.empty-state h2{ font-size:2rem; margin-bottom:12px; }

/* toast */
.toast{ position:fixed; bottom:26px; left:50%; transform:translate(-50%,140%);
  background:var(--ink); color:var(--paper); padding:14px 24px; font-size:.84rem;
  letter-spacing:.03em; z-index:200; transition:transform .45s var(--ease);
  display:flex; align-items:center; gap:12px; }
.toast.show{ transform:translate(-50%,0); }
.toast a{ color:var(--paper); text-decoration:underline; text-underline-offset:3px; }

/* =========================================================================
   EDITORIAL BLOCKS (about / home)
   ========================================================================= */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,80px);
  align-items:center; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } }
.split figure{ margin:0; border:1px solid var(--line-strong); background:var(--white);
  aspect-ratio:4/5; overflow:hidden; }
.split figure img{ width:100%; height:100%; object-fit:cover; }
.split .body p{ color:var(--ink-soft); margin-bottom:1.1em; }
.bigquote{ font-family:var(--serif); font-size:clamp(1.6rem,4vw,2.8rem);
  line-height:1.18; letter-spacing:-.02em; max-width:24ch; }
.bigquote em{ color:var(--accent); }

.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,48px);
  counter-reset:step; }
@media (max-width:760px){ .steps{ grid-template-columns:1fr; } }
.steps .step{ border-top:2px solid var(--ink); padding-top:18px; }
.steps .step::before{ counter-increment:step; content:"0" counter(step);
  font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; color:var(--accent); }
.steps .step h4{ font-size:1.35rem; margin:8px 0 8px; }
.steps .step p{ color:var(--ink-soft); font-size:.92rem; }

/* =========================================================================
   FORMS (contact)
   ========================================================================= */
.field{ margin-bottom:22px; }
.field label{ display:block; font-family:var(--mono); font-size:.7rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:9px; }
.field input,.field textarea,.field select{ width:100%; border:0; border-bottom:1px solid var(--line-strong);
  background:transparent; padding:11px 0; font-family:var(--sans); font-size:1rem;
  color:var(--ink); outline:none; transition:border-color .3s; }
.field input:focus,.field textarea:focus,.field select:focus{ border-color:var(--ink); }
.field textarea{ resize:vertical; min-height:130px; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:0 28px; }
@media (max-width:600px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-meta dt{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-faint); margin-top:24px; }
.contact-meta dd{ margin:6px 0 0; font-size:1.05rem; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{ border-top:1px solid var(--line); background:var(--paper-2);
  margin-top:40px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px;
  padding-block:clamp(48px,7vw,86px); }
@media (max-width:860px){ .footer-top{ grid-template-columns:1fr 1fr; gap:36px; } }
@media (max-width:520px){ .footer-top{ grid-template-columns:1fr; } }
.footer-top h4{ font-family:var(--mono); font-weight:500; font-size:.7rem;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint);
  margin-bottom:18px; }
.footer-top ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer-top a{ font-size:.9rem; color:var(--ink-soft); transition:color .25s; }
.footer-top a:hover{ color:var(--ink); }
.footer-brand .mark{ font-family:var(--serif); font-size:2rem; }
.footer-brand .mark em{ font-style:italic; color:var(--accent); }
.footer-brand p{ color:var(--ink-soft); max-width:34ch; margin-top:14px; font-size:.92rem; }
.subscribe{ display:flex; border-bottom:1px solid var(--line-strong); margin-top:16px; }
.subscribe input{ flex:1; border:0; background:none; outline:none; padding:10px 0;
  font-family:var(--sans); font-size:.92rem; }
.subscribe button{ background:none; border:0; font-family:var(--mono); font-size:.7rem;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink); }
.footer-bottom{ border-top:1px solid var(--line); padding-block:22px;
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.footer-bottom span{ font-family:var(--mono); font-size:.68rem; letter-spacing:.08em;
  color:var(--ink-faint); }

/* =========================================================================
   PAGE HEADER (interior pages)
   ========================================================================= */
.page-head{ padding-block:clamp(40px,6vw,80px) clamp(24px,3vw,40px); }
.page-head .eyebrow{ display:block; margin-bottom:18px; }
.page-head h1{ font-size:clamp(2.6rem,7vw,5.5rem); }
.breadcrumb{ font-family:var(--mono); font-size:.7rem; letter-spacing:.1em;
  color:var(--ink-faint); margin-bottom:26px; }
.breadcrumb a:hover{ color:var(--ink); }

/* reveal-on-scroll utility — only hides when JS is active (progressive enhancement) */
html.js [data-reveal]{ opacity:0; transform:translateY(24px);
  transition:opacity .8s var(--ease), transform .8s var(--ease); }
html.js [data-reveal].in{ opacity:1; transform:none; }

::selection{ background:var(--accent); color:var(--white); }
