/* ============================================
   WILLA — Design Tokens
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --cream:#F7F2EA;
  --white:#FFFFFF;
  --sand:#E7DAC8;
  --dusty-rose:#C9A29A;
  --sage:#8C9A80;
  --ink:#2E2A25;
  --ink-soft:#6B6459;
  --gold:#AC8A54;
  --line:#E1D6C6;

  /* collection colors */
  --c-coastal:#5B7FA6;
  --c-watermelon:#B23A3A;
  --c-palmbeach:#6E8F5C;
  --c-orangecrush:#D97B3F;
  --c-hibiscus:#D9748F;
  --c-lemon:#E3B94D;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Jost', -apple-system, sans-serif;

  --max: 1360px;
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit; cursor:pointer;}
input{font-family:inherit;}

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

h1,h2,h3,h4{font-family:var(--serif); font-weight:500; line-height:1.15; letter-spacing:.01em;}
.eyebrow{
  font-family:var(--sans); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-soft); font-weight:500;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important; transition-duration:.001ms !important;}
}

/* ============================================
   Announcement bar
   ============================================ */
.announce{
  background:var(--ink); color:var(--cream);
  text-align:center; font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  padding:9px 12px; font-family:var(--sans);
}
.announce span{color:var(--gold); margin-left:6px;}

/* ============================================
   Header / nav
   ============================================ */
header.site{
  position:sticky; top:0; z-index:100;
  background:rgba(247,242,234,.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 40px; max-width:var(--max); margin:0 auto;
}
.nav-links{display:flex; gap:34px;}
.nav-links a{
  font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
  position:relative; padding-bottom:4px;
}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--ink);
  transition:width .25s ease;
}
.nav-links a:hover::after{width:100%;}
.logo{
  font-family:var(--serif); font-size:30px; letter-spacing:.32em; font-weight:500; text-align:center;
  padding-left:.32em; /* balance letter-spacing */
}
.nav-icons{display:flex; gap:20px; align-items:center; font-size:12px; letter-spacing:.08em;}
.nav-collections{display:none;}
.mobile-toggle{display:none; background:none; border:0; font-size:22px;}

@media(max-width:960px){
  .nav-links{
    position:fixed; top:0; left:0; height:100vh; width:78%; max-width:320px;
    background:var(--cream); flex-direction:column; gap:0; padding:100px 36px 40px;
    transform:translateX(-100%); transition:transform .35s ease; box-shadow:8px 0 30px rgba(0,0,0,.08);
  }
  .nav-links.open{transform:translateX(0);}
  .nav-links a{padding:16px 0; border-bottom:1px solid var(--line); width:100%;}
  .mobile-toggle{display:block;}
  .nav-row{padding:16px 20px;}
  .logo{font-size:22px;}
}

/* ============================================
   Buttons
   ============================================ */
.btn{
  display:inline-block; padding:15px 34px; font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  font-weight:500; border:1px solid var(--ink); transition:all .25s ease; text-align:center;
}
.btn-dark{background:var(--ink); color:var(--cream);}
.btn-dark:hover{background:transparent; color:var(--ink);}
.btn-outline{background:transparent; color:var(--ink);}
.btn-outline:hover{background:var(--ink); color:var(--cream);}
.btn-ghost{border-color:var(--white); color:var(--white);}
.btn-ghost:hover{background:var(--white); color:var(--ink);}
.btn-full{width:100%;}
.btn[disabled], .btn.disabled{opacity:.55; cursor:not-allowed;}

/* ============================================
   Hero
   ============================================ */
.hero{
  display:grid; grid-template-columns:1fr 1.15fr; min-height:88vh; align-items:stretch;
}
.hero-copy{
  display:flex; flex-direction:column; justify-content:center; padding:60px 60px 60px 40px; gap:26px;
}
.hero-copy h1{font-size:clamp(38px,4.4vw,58px); max-width:520px;}
.hero-copy p{font-size:16px; color:var(--ink-soft); max-width:420px; font-weight:300;}
.hero-btns{display:flex; gap:14px; margin-top:8px; flex-wrap:wrap;}
.hero-img{position:relative; overflow:hidden; background:var(--sand);}
.hero-img img{width:100%; height:100%; object-fit:cover; object-position:top;}

@media(max-width:960px){
  .hero{grid-template-columns:1fr; min-height:auto;}
  .hero-img{aspect-ratio:4/5; order:-1;}
  .hero-copy{padding:44px 24px;}
}

/* ============================================
   Section shells
   ============================================ */
.section{padding:100px 0;}
.section-tight{padding:60px 0;}
.section-head{text-align:center; max-width:640px; margin:0 auto 56px;}
.section-head h2{font-size:clamp(28px,3vw,40px); margin-top:10px;}
.section-head p{color:var(--ink-soft); margin-top:14px; font-size:15px;}
.section-alt{background:var(--white);}

@media(max-width:768px){
  .section{padding:64px 0;}
  .wrap{padding:0 20px;}
}

/* ============================================
   Category circles (homepage)
   ============================================ */
.circle-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:36px; text-align:center;
}
.circle-item img{
  width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:50%; margin-bottom:18px;
  border:1px solid var(--line); transition:transform .4s ease;
}
.circle-item:hover img{transform:scale(1.03);}
.circle-item span{font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:500;}

/* ============================================
   Collection strip (color-story signature)
   ============================================ */
.collection-strip{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:2px;
  background:var(--line);
}
.collection-card{
  background:var(--white); position:relative; aspect-ratio:3/4; overflow:hidden; display:block;
}
.collection-card img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease;}
.collection-card:hover img{transform:scale(1.06);}
.collection-card .tag{
  position:absolute; top:18px; left:18px; display:flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.88); padding:6px 12px; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase;
}
.dot{width:8px; height:8px; border-radius:50%; display:inline-block; flex-shrink:0;}
.collection-card .cap{
  position:absolute; bottom:0; left:0; right:0; padding:22px 20px;
  background:linear-gradient(to top, rgba(0,0,0,.55), transparent);
  color:var(--white);
}
.collection-card .cap h3{font-size:22px; color:var(--white);}
.collection-card .cap small{font-size:11px; letter-spacing:.12em; text-transform:uppercase; opacity:.85;}
.collection-card.soon .cap{background:linear-gradient(to top, rgba(46,42,37,.75), rgba(46,42,37,.25));}

/* ============================================
   Product grid & cards
   ============================================ */
.product-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:34px 26px;
}
.product-card{display:block;}
.product-thumb{
  position:relative; aspect-ratio:3/4; overflow:hidden; background:var(--sand); margin-bottom:14px;
}
.product-thumb img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease, opacity .3s ease;}
.product-card:hover .product-thumb img{transform:scale(1.045);}
.product-badge{
  position:absolute; top:12px; left:12px; background:var(--white); font-size:10px; letter-spacing:.1em;
  text-transform:uppercase; padding:5px 10px; font-weight:500;
}
.product-meta .eyebrow{display:flex; align-items:center; gap:6px; margin-bottom:4px;}
.product-meta h4{font-family:var(--sans); font-weight:500; font-size:14.5px; margin-bottom:4px; letter-spacing:.01em;}
.product-meta .price{font-size:13.5px; color:var(--ink-soft);}

/* ============================================
   Filters
   ============================================ */
.filter-bar{
  display:flex; flex-wrap:wrap; gap:10px; margin-bottom:44px; align-items:center;
}
.filter-bar .flabel{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-right:6px;}
.chip{
  padding:9px 18px; border:1px solid var(--line); font-size:12px; letter-spacing:.06em;
  background:var(--white); transition:all .2s ease;
}
.chip.active, .chip:hover{border-color:var(--ink); background:var(--ink); color:var(--cream);}

/* ============================================
   Instagram strip
   ============================================ */
.insta-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:4px;}
.insta-grid img{aspect-ratio:1/1; object-fit:cover; transition:opacity .3s ease;}
.insta-grid a:hover img{opacity:.8;}
@media(max-width:768px){.insta-grid{grid-template-columns:repeat(3,1fr);}}

/* ============================================
   Countdown block
   ============================================ */
.countdown-block{
  background:var(--ink); color:var(--cream); padding:80px 0; text-align:center;
}
.countdown-block .eyebrow{color:var(--gold);}
.countdown-block h2{font-size:clamp(26px,3vw,36px); margin:12px 0 40px; color:var(--cream);}
.countdown-timer{display:flex; justify-content:center; gap:28px; flex-wrap:wrap;}
.ct-unit{min-width:84px;}
.ct-unit .num{font-family:var(--serif); font-size:clamp(34px,5vw,54px); font-weight:500;}
.ct-unit .lab{font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:#B9AFA0; margin-top:6px;}

/* ============================================
   Email signup
   ============================================ */
.signup-block{text-align:center; padding:90px 0;}
.signup-form{
  display:flex; max-width:440px; margin:30px auto 0; border:1px solid var(--ink);
}
.signup-form input{
  flex:1; border:0; background:transparent; padding:15px 18px; font-size:13px; outline:none;
}
.signup-form button{border:0; background:var(--ink); color:var(--cream); padding:0 26px; font-size:11px; letter-spacing:.14em; text-transform:uppercase;}
.form-note{font-size:12px; color:var(--ink-soft); margin-top:14px;}

/* ============================================
   Footer
   ============================================ */
footer.site{background:var(--ink); color:#CFC7B8; padding:70px 0 26px;}
.footer-grid{display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:40px; margin-bottom:60px;}
.footer-grid h5{font-family:var(--sans); color:var(--cream); font-size:12px; letter-spacing:.14em; text-transform:uppercase; margin-bottom:18px; font-weight:500;}
.footer-grid ul li{margin-bottom:11px; font-size:13.5px;}
.footer-grid ul a:hover{color:var(--cream);}
.footer-logo{font-family:var(--serif); font-size:26px; color:var(--cream); letter-spacing:.28em; margin-bottom:14px;}
.footer-grid p{font-size:13px; line-height:1.7; max-width:280px; color:#B9AFA0;}
.footer-bottom{
  border-top:1px solid #43403A; padding-top:24px; display:flex; justify-content:space-between;
  font-size:11.5px; color:#8B8477; flex-wrap:wrap; gap:10px;
}
@media(max-width:860px){
  .footer-grid{grid-template-columns:1fr 1fr; gap:36px 20px;}
}

/* ============================================
   Page header (interior pages)
   ============================================ */
.page-head{padding:64px 0 44px; text-align:center; border-bottom:1px solid var(--line);}
.page-head .eyebrow{margin-bottom:10px;}
.page-head h1{font-size:clamp(30px,4vw,46px);}
.breadcrumb{font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); margin-top:14px;}
.breadcrumb a:hover{color:var(--ink);}

/* ============================================
   Product detail
   ============================================ */
.pdp{display:grid; grid-template-columns:1fr 1fr; gap:70px; padding:60px 0 100px;}
.pdp-gallery{position:relative; overflow:hidden; background:var(--sand); aspect-ratio:3/4;}
.pdp-gallery img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease;}
.pdp-gallery:hover img{transform:scale(1.08);}
.pdp-info .eyebrow{display:flex; align-items:center; gap:8px; margin-bottom:10px;}
.pdp-info h1{font-size:clamp(28px,3vw,38px); margin-bottom:10px;}
.pdp-price{font-size:18px; color:var(--ink-soft); margin-bottom:26px;}
.pdp-desc{font-size:14.5px; color:var(--ink-soft); line-height:1.75; margin-bottom:30px; max-width:460px;}
.pdp-block{border-top:1px solid var(--line); padding:22px 0;}
.pdp-block .flabel{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:12px;}
.swatches{display:flex; gap:10px; flex-wrap:wrap;}
.swatch{width:30px; height:30px; border-radius:50%; border:2px solid transparent; cursor:default;}
.swatch.selected{border-color:var(--ink);}
.size-row{display:flex; gap:10px; flex-wrap:wrap;}
.size-pill{
  border:1px solid var(--line); padding:10px 16px; font-size:12.5px; letter-spacing:.04em; background:var(--white);
}
.pdp-cta{display:flex; flex-direction:column; gap:12px; margin:30px 0;}
.pdp-note{font-size:12px; color:var(--ink-soft); text-align:center;}
.accordion{border-top:1px solid var(--line);}
.accordion summary{
  padding:18px 0; font-size:12px; letter-spacing:.12em; text-transform:uppercase; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center; font-weight:500;
}
.accordion[open] summary{color:var(--gold);}
.accordion .acc-body{padding-bottom:20px; font-size:13.5px; color:var(--ink-soft); line-height:1.8;}

@media(max-width:900px){
  .pdp{grid-template-columns:1fr; gap:30px; padding:30px 0 70px;}
}

/* ============================================
   About / Contact
   ============================================ */
.prose{max-width:700px; margin:0 auto; font-size:15.5px; line-height:1.9; color:var(--ink-soft);}
.prose p{margin-bottom:22px;}
.prose h2{color:var(--ink); font-size:26px; margin:44px 0 16px;}
.split{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;}
@media(max-width:860px){.split{grid-template-columns:1fr;}}
.contact-form{display:flex; flex-direction:column; gap:16px; max-width:520px;}
.contact-form input, .contact-form textarea{
  border:1px solid var(--line); background:var(--white); padding:14px 16px; font-size:14px; outline:none;
}
.contact-form textarea{min-height:140px; resize:vertical;}
.contact-form label{font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:-8px;}

/* toast */
.toast{
  position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(120%);
  background:var(--ink); color:var(--cream); padding:14px 26px; font-size:13px; letter-spacing:.04em;
  transition:transform .35s ease; z-index:999;
}
.toast.show{transform:translateX(-50%) translateY(0);}

/* fade-in on scroll */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease;}
.reveal.in{opacity:1; transform:translateY(0);}

.empty-state{text-align:center; padding:80px 20px; color:var(--ink-soft);}
