:root{
  --ink:#0A0A0A;
  --green:#2E3D22;
  --plum:#5B2A57;
  --paper:#F4F3F0;
  --muted:#B9B9B4;
  --line:rgba(255,255,255,0.16);
  --serif:"Cinzel",serif;
  --serif-body:"Cormorant Garamond",serif;
  --sans:"Lato","Helvetica Neue",Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html,body{max-width:100%;overflow-x:hidden;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
}
img{max-width:100%;height:auto;display:block;}
svg{overflow:visible;}
a{color:inherit;text-decoration:none;}

.skip-link{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--plum);color:#fff;padding:.7rem 1.2rem;border-radius:0;
}
.skip-link:focus{left:.5rem;top:.5rem;}

:focus-visible{outline:2px solid var(--plum);outline-offset:3px;}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  text-align:center;font-family:var(--sans);font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  border:1px solid transparent;border-radius:0;cursor:pointer;
  transition:background-color .25s ease,color .25s ease,border-color .25s ease;
  min-height:44px;
}
.btn-sm{font-size:.66rem;padding:.6rem 1rem;}
.btn-lg{font-size:.74rem;padding:1.05rem 1.6rem;}
.btn-plum{background:var(--plum);color:#fff;border-color:var(--plum);}
.btn-plum:hover{background:#74386f;border-color:#74386f;}
.btn-outline{background:transparent;color:var(--paper);border-color:var(--line);}
.btn-outline:hover{background:rgba(244,243,240,.08);border-color:rgba(244,243,240,.5);}
.btn-ghost{background:transparent;color:var(--muted);border-color:transparent;}
.btn-ghost:hover{color:var(--paper);}

/* ---- Promo strip ---- */
.promo-strip{
  background:var(--green);color:var(--paper);
  text-align:center;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.55rem 1rem;font-weight:400;
}

/* ---- Header ---- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(10,10,10,.55);
  border-bottom:1px solid transparent;
  transition:background-color .3s ease,border-color .3s ease;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.site-header.scrolled{
  background:rgba(10,10,10,.95);
  border-bottom:1px solid var(--line);
}
.header-inner{
  max-width:1240px;margin:0 auto;padding:.85rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-width:0;
}
.brand-logo{height:42px;width:auto;flex-shrink:0;display:block;}
.header-actions{
  display:flex;align-items:center;gap:.5rem;
  flex-shrink:0;min-width:0;
}
.header-social{
  display:flex;gap:.1rem;list-style:none;margin:0;padding:0;
}
.header-social a{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:color .2s ease;
}
.header-social svg{width:17px;height:17px;flex-shrink:0;}
.header-social a:hover{color:var(--paper);}

/* ---- Hero ---- */
.hero{
  position:relative;overflow:hidden;
  padding:5.5rem 1.25rem 4.5rem;
  min-height:min(92vh,860px);
  display:flex;flex-direction:column;justify-content:center;
}
.hero-tree{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:min(720px,130%);max-width:none;
  opacity:.18;z-index:0;
  filter:saturate(1.2) brightness(.88);
  pointer-events:none;
  animation:drift 26s ease-in-out infinite alternate;
}
@keyframes drift{
  from{transform:translate(-50%,-52%) scale(1);}
  to{transform:translate(-50%,-48%) scale(1.05);}
}
.hero-veil{
  position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse 72% 68% at center,rgba(10,10,10,.16) 0%,rgba(10,10,10,.7) 58%,var(--ink) 100%);
}
.hero-inner{
  position:relative;z-index:2;
  max-width:880px;margin:0 auto;text-align:center;
}
.kicker{
  font-family:var(--serif);font-size:.7rem;letter-spacing:.44em;
  text-transform:uppercase;color:var(--muted);margin:0 0 1.4rem;
}

/* KEY CHANGE: text-transform:uppercase turns Cinzel into full engraved caps */
.hero h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2rem,7vw,4.4rem);
  line-height:1.08;letter-spacing:.04em;
  text-transform:uppercase;
  margin:0 0 1.8rem;color:var(--paper);
}
.hero-sub{
  font-family:var(--serif-body);
  font-size:clamp(1rem,2.4vw,1.35rem);
  line-height:1.65;color:var(--muted);
  max-width:52ch;margin:0 auto 2.5rem;font-weight:400;
}
.hero-cta{
  display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;align-items:center;
  margin-bottom:2.4rem;
}
.hero-social{
  display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap;
  list-style:none;margin:0;padding:0;
}
.hero-social a{
  width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  color:var(--muted);border:1px solid var(--line);
  transition:color .2s ease,border-color .2s ease,background-color .2s ease;
}
/* No fill:currentColor here — SVG attributes handle fill/stroke */
.hero-social svg{width:20px;height:20px;flex-shrink:0;}
.hero-social a:hover{color:var(--paper);border-color:rgba(244,243,240,.4);background:rgba(244,243,240,.05);}
.hero-rule{
  position:relative;z-index:2;
  height:1px;background:var(--line);
  max-width:1240px;width:100%;margin:3.5rem auto 0;
}

/* ---- Statement ---- */
.statement{
  max-width:960px;margin:0 auto;
  padding:4.5rem 1.25rem 4rem;
  text-align:center;
}
/* Decorative vertical needle above the eyebrow */
.statement-rule{
  width:1px;height:52px;
  background:var(--line);
  margin:0 auto 2.2rem;
}
.statement-eyebrow{
  font-family:var(--serif);font-size:.7rem;letter-spacing:.4em;
  text-transform:uppercase;color:var(--plum);margin:0 0 1.3rem;
  filter:brightness(1.8);
}
.statement-lead{
  font-family:var(--serif-body);font-weight:400;
  font-size:clamp(1.35rem,3.4vw,2.15rem);line-height:1.48;
  color:var(--paper);max-width:34ch;margin:0 auto;
}

/* ---- Brands ---- */
.brands{
  border-top:1px solid var(--line);
  padding:4.5rem 1.25rem 5.5rem;
  max-width:1100px;margin:0 auto;
}
.brands-head{text-align:center;margin-bottom:2.8rem;}
/* Short plum accent bar above BRANDS heading */
.brands-accent{
  width:36px;height:2px;
  background:var(--plum);filter:brightness(1.8);
  margin:0 auto 1.4rem;
}
.brands h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(1.8rem,5vw,3rem);letter-spacing:.18em;
  text-transform:uppercase;margin:0 0 .8rem;color:var(--paper);
}
.brands-sub{
  font-family:var(--serif-body);font-size:clamp(1rem,2.2vw,1.25rem);
  color:var(--muted);margin:0;font-weight:400;
}
.brands-frame{
  margin:0;border:1px solid var(--line);
  background:#000;padding:clamp(.6rem,2vw,1.4rem);
  box-shadow:0 0 80px rgba(0,0,0,.5);
}
.brands-frame img{width:100%;display:block;}

/* ---- Contact ---- */
.contact{
  position:relative;overflow:hidden;
  border-top:1px solid var(--line);
  background:linear-gradient(180deg,var(--ink) 0%,#0e1409 52%,var(--ink) 100%);
  padding:6rem 1.25rem;text-align:center;
}
.contact-tree{
  position:absolute;top:50%;right:-6%;transform:translateY(-50%);
  width:min(480px,72%);max-width:none;opacity:.1;z-index:0;pointer-events:none;
  height:auto;display:block;
}
.contact-inner{position:relative;z-index:1;max-width:720px;margin:0 auto;}
/* Uppercase to match page's engraved register */
.contact h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(1.8rem,5.5vw,3.2rem);
  letter-spacing:.06em;text-transform:uppercase;
  line-height:1.1;margin:0 0 1rem;color:var(--paper);
}
.contact-body{
  font-family:var(--serif-body);font-size:clamp(1rem,2.4vw,1.35rem);
  color:var(--muted);margin:0 0 2.4rem;font-weight:400;
}
.contact-cta{
  display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;align-items:center;
  margin-bottom:1.8rem;
}
.contact-mail{
  display:inline-block;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:.25rem;
  transition:color .2s ease,border-color .2s ease;
}
.contact-mail:hover{color:var(--paper);border-color:rgba(244,243,240,.55);}

/* ---- Footer ---- */
.site-footer{
  border-top:1px solid var(--line);padding:3.2rem 1.25rem;
}
.footer-inner{
  max-width:1240px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:1.3rem;text-align:center;
}
.footer-logo{height:40px;width:auto;display:block;}
.footer-social{display:flex;gap:.3rem;list-style:none;margin:0;padding:0;}
.footer-social a{
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:color .2s ease;
}
/* No fill:currentColor — SVG attributes handle fill/stroke for both stroke and fill icons */
.footer-social svg{width:17px;height:17px;flex-shrink:0;}
.footer-social a:hover{color:var(--paper);}
.footer-mail{margin:0;}
.footer-mail a{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);}
.footer-mail a:hover{color:var(--paper);}
.footer-copy{
  margin:0;font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(185,185,180,.48);
}

/* ---- Reveal ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease;}
.reveal.is-in{opacity:1;transform:none;}

/* ---- Responsive ---- */
@media (max-width:900px){
  .header-social{display:none;}
}
@media (max-width:780px){
  .brand-logo{height:34px;}
  .hero{min-height:auto;padding-top:4.5rem;}
  /* Reduce statement vertical padding on mobile — less empty space */
  .statement{padding:3.2rem 1.25rem 3rem;}
  .statement-rule{height:36px;margin-bottom:1.8rem;}
}
@media (max-width:430px){
  .header-actions .btn-ghost{display:none;}
  .header-inner{padding:.7rem 1rem;}
  .hero-cta .btn,.contact-cta .btn{width:100%;}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important;}
  .reveal{opacity:1;transform:none;transition:none;}
  .hero-tree{animation:none !important;}
}