@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;0,900;1,400;1,700&family=Jost:wght@200;300;400;500&display=swap');

:root {
  --ink:       #0d0c0b;
  --ink-soft:  #1a1816;
  --ink-mid:   #2a2825;
  --ash:       #3d3a36;
  --bone:      #f0ead8;
  --bone-dk:   #d4cbaf;
  --ivory:     #faf7f0;
  --umber:     #8c6a3f;
  --umber-lt:  #b8894f;
  --umber-dk:  #5c3f1a;
  --white:     #ffffff;
  --border:    rgba(240,234,216,0.12);
  --border-md: rgba(240,234,216,0.22);
  --green:     #4a7c59;
  --red:       #9c3d30;
  --shadow:    0 12px 60px rgba(0,0,0,0.75);
  --r:         3px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Jost',system-ui,sans-serif;
  background:var(--ink);
  color:var(--bone);
  min-height:100vh;
  overflow-x:hidden;
  font-weight:300;
}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;font-family:inherit;}

.geo-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.022;
  background-image:
    linear-gradient(var(--bone) 1px, transparent 1px),
    linear-gradient(90deg, var(--bone) 1px, transparent 1px);
  background-size:80px 80px;
}

/* HEADER */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(13,12,11,.96);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.header-inner{
  max-width:1320px;margin:0 auto;
  padding:0 2.5rem;
  display:flex;align-items:center;justify-content:space-between;
  height:76px;
}
.logo{display:flex;align-items:center;gap:1.1rem;}
.logo-img{
  width:44px;height:44px;
  object-fit:contain;
  filter:invert(1) brightness(0.9);
  transition:filter .3s;
}
.logo:hover .logo-img{filter:invert(1) brightness(1);}
.brand{
  font-family:'Playfair Display',serif;
  font-size:1.35rem;font-weight:700;
  letter-spacing:.03em;
  color:var(--ivory);
}
.tagline{
  font-size:.6rem;letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--bone-dk);opacity:.5;
  margin-top:3px;display:block;
  font-weight:400;
}
nav{display:flex;align-items:center;gap:2.8rem;}
nav a{
  font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--bone-dk);opacity:.55;
  transition:all .2s;font-weight:400;
}
nav a:hover{opacity:1;color:var(--ivory);}
.nav-actions{display:flex;align-items:center;gap:.8rem;}
.icon-btn{
  background:none;border:none;
  color:var(--bone);opacity:.6;
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:all .2s;position:relative;
}
.icon-btn:hover{opacity:1;background:rgba(240,234,216,.08);color:var(--ivory);}
#cart-badge{
  position:absolute;top:5px;right:5px;
  width:17px;height:17px;border-radius:50%;
  background:var(--umber-lt);color:var(--ivory);
  font-size:.58rem;font-weight:600;
  font-family:'Jost',sans-serif;
  display:none;align-items:center;justify-content:center;
}

/* HERO */
.hero{
  position:relative;z-index:1;
  min-height:92vh;
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;
  padding:7rem 2.5rem 5rem;
  overflow:hidden;
  max-width:1320px;margin:0 auto;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 55% 65% at 100% 50%, rgba(140,106,63,.07) 0%, transparent 65%);
  pointer-events:none;
}
.hero-content{position:relative;max-width:600px;}
.hero-eyebrow{
  font-size:.68rem;letter-spacing:.35em;
  text-transform:uppercase;color:var(--umber-lt);
  margin-bottom:1.8rem;
  display:flex;align-items:center;gap:1rem;font-weight:400;
}
.hero-eyebrow::after{content:'';flex:1;max-width:48px;height:1px;background:var(--umber-lt);opacity:.45;}
.hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(3.2rem,5.5vw,5.5rem);
  font-weight:900;line-height:1.0;
  margin-bottom:1.8rem;letter-spacing:-.01em;
}
.hero h1 em{font-style:italic;font-weight:400;color:var(--bone-dk);opacity:.65;}
.hero p{
  font-size:.98rem;line-height:1.9;
  color:var(--bone-dk);opacity:.7;
  max-width:480px;margin-bottom:2.8rem;font-weight:300;
}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;}

.hero-emblem-wrap{
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.hero-emblem{
  width:min(420px,90%);height:auto;
  opacity:.15;filter:invert(1);
  animation:floatBird 7s ease-in-out infinite;
  transition:opacity .5s;
}
.hero-emblem-wrap:hover .hero-emblem{opacity:.25;}
@keyframes floatBird{0%,100%{transform:translateY(0);}50%{transform:translateY(-16px);}}

/* BUTTONS */
.btn-primary{
  background:var(--ivory);color:var(--ink);
  border:none;padding:.9rem 2.4rem;
  font-family:'Jost',sans-serif;
  font-size:.75rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  border-radius:var(--r);transition:all .25s;
  box-shadow:0 4px 24px rgba(0,0,0,.4);
}
.btn-primary:hover{background:var(--bone);transform:translateY(-2px);box-shadow:0 8px 36px rgba(0,0,0,.55);}
.btn-secondary{
  background:transparent;color:var(--bone-dk);
  border:1px solid var(--border-md);
  padding:.9rem 2.4rem;
  font-family:'Jost',sans-serif;
  font-size:.75rem;font-weight:400;
  letter-spacing:.22em;text-transform:uppercase;
  border-radius:var(--r);transition:all .25s;
}
.btn-secondary:hover{border-color:rgba(240,234,216,.45);color:var(--ivory);}

/* SECTION HEADER */
.section-header{text-align:center;margin-bottom:4rem;}
.eyebrow{
  font-size:.68rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--umber-lt);display:block;margin-bottom:.9rem;font-weight:400;
}
.section-header h2{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.2rem,4vw,3rem);font-weight:700;letter-spacing:-.01em;
}
.section-header p{color:var(--bone-dk);opacity:.6;margin-top:.85rem;font-size:.95rem;}
.divider{width:40px;height:1px;margin:1.4rem auto 0;background:var(--umber-lt);opacity:.35;}

/* FEATURES */
.features-bar{
  position:relative;z-index:1;
  background:var(--ink-soft);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:3.5rem 2.5rem;
}
.features-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:2.5rem;text-align:center;
}
.feature-item svg{color:var(--umber-lt);margin:0 auto .9rem;}
.feature-item h4{font-family:'Playfair Display',serif;font-size:1rem;font-weight:600;margin-bottom:.4rem;color:var(--ivory);}
.feature-item p{font-size:.8rem;color:var(--bone-dk);opacity:.5;line-height:1.55;}

/* SHOP */
.shop-section{position:relative;z-index:1;padding:6rem 2.5rem;}
.shop-inner{max-width:1320px;margin:0 auto;}
.filters{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin-bottom:3.5rem;}
.filter-btn{
  background:transparent;border:1px solid var(--border);
  color:var(--bone-dk);opacity:.55;
  padding:.45rem 1.5rem;
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  border-radius:100px;transition:all .2s;
  font-family:'Jost',sans-serif;font-weight:400;
}
.filter-btn:hover{opacity:1;border-color:var(--border-md);color:var(--bone);}
.filter-btn.active{background:var(--ivory);color:var(--ink);border-color:var(--ivory);opacity:1;}

/* PRODUCT GRID */
.product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:1.5rem;
}
.product-card{
  background:var(--ink-soft);border:1px solid var(--border);
  border-radius:4px;overflow:hidden;
  transition:transform .35s,box-shadow .35s,border-color .35s;cursor:pointer;
}
.product-card:hover{
  transform:translateY(-8px);
  box-shadow:0 24px 70px rgba(0,0,0,.7),0 0 0 1px rgba(240,234,216,.18);
  border-color:rgba(240,234,216,.2);
}
.product-img{
  height:250px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink-mid);
}
.product-img-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .5s;}
.product-card:hover .product-img-inner{transform:scale(1.05);}
.product-badge{
  position:absolute;top:12px;left:12px;
  background:var(--ivory);color:var(--ink);
  font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;
  padding:.28rem .75rem;border-radius:100px;font-weight:600;
  font-family:'Jost',sans-serif;
}
.badge-oos{background:var(--ash);color:var(--bone-dk);}
.product-body{padding:1.5rem;}
.product-cat{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--umber-lt);opacity:.8;margin-bottom:.4rem;font-weight:400;}
.product-name{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:600;line-height:1.3;margin-bottom:.55rem;color:var(--ivory);}
.product-desc{font-size:.82rem;color:var(--bone-dk);opacity:.5;line-height:1.55;margin-bottom:1.3rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.product-footer{display:flex;align-items:center;justify-content:space-between;}
.product-price{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:var(--ivory);}
.add-btn{
  background:rgba(240,234,216,.06);border:1px solid var(--border);
  color:var(--bone-dk);width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.add-btn:hover{background:var(--ivory);color:var(--ink);border-color:var(--ivory);}
.out-of-stock{opacity:.4;pointer-events:none;}

/* MODAL */
.modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(5,4,3,.93);backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;padding:2rem;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{
  background:var(--ink-soft);border:1px solid var(--border-md);
  border-radius:4px;max-width:640px;width:100%;max-height:90vh;overflow-y:auto;
  transform:translateY(24px);transition:transform .3s;
  box-shadow:var(--shadow);position:relative;
}
.modal-overlay.open .modal{transform:translateY(0);}
.modal-img{height:280px;display:flex;align-items:center;justify-content:center;background:var(--ink-mid);}
.modal-body{padding:2.2rem;}
.modal-cat{font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;color:var(--umber-lt);font-weight:400;}
.modal-name{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;margin:.5rem 0 1.1rem;color:var(--ivory);}
.modal-desc{font-size:.97rem;line-height:1.75;color:var(--bone-dk);opacity:.7;margin-bottom:1.5rem;}
.modal-meta{display:flex;gap:2rem;margin-bottom:1.5rem;font-size:.82rem;color:var(--bone-dk);opacity:.5;}
.modal-price{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;color:var(--ivory);margin-bottom:1.5rem;}
.modal-actions{display:flex;gap:1rem;}
.modal-close{
  position:absolute;top:1rem;right:1rem;
  background:rgba(240,234,216,.06);border:none;color:var(--bone);
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:background .2s;
}
.modal-close:hover{background:rgba(240,234,216,.14);}

/* CART */
.cart-overlay{position:fixed;inset:0;z-index:300;pointer-events:none;}
.cart-overlay.open{pointer-events:all;}
.cart-backdrop{position:absolute;inset:0;background:rgba(5,4,3,.75);backdrop-filter:blur(6px);opacity:0;transition:opacity .3s;}
.cart-overlay.open .cart-backdrop{opacity:1;}
.cart-panel{
  position:absolute;right:0;top:0;bottom:0;width:420px;max-width:100vw;
  background:var(--ink-soft);border-left:1px solid var(--border-md);
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
  box-shadow:-24px 0 80px rgba(0,0,0,.7);
}
.cart-overlay.open .cart-panel{transform:translateX(0);}
.cart-header{padding:1.6rem 1.6rem 1.1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.cart-header h3{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:var(--ivory);}
.cart-items{flex:1;overflow-y:auto;padding:1rem 1.6rem;}
.cart-item{display:flex;gap:1rem;align-items:center;padding:1rem 0;border-bottom:1px solid var(--border);}
.cart-item-img{width:56px;height:56px;border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--ink-mid);}
.cart-item-info{flex:1;}
.cart-item-name{font-family:'Playfair Display',serif;font-size:.95rem;color:var(--ivory);}
.cart-item-price{font-size:.82rem;color:var(--umber-lt);margin-top:2px;}
.cart-item-remove{background:none;border:none;color:var(--bone-dk);opacity:.4;transition:opacity .2s;}
.cart-item-remove:hover{opacity:1;color:var(--red);}
.cart-footer{padding:1.5rem;border-top:1px solid var(--border);}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem;}
.cart-total-label{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-dk);opacity:.55;}
.cart-total-val{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--ivory);}
.cart-empty{text-align:center;padding:3rem 1rem;opacity:.3;}

/* CHECKOUT FORM */
.checkout-form{display:flex;flex-direction:column;gap:.9rem;}
.checkout-form input,.checkout-form textarea{
  background:rgba(240,234,216,.04);border:1px solid var(--border);
  color:var(--bone);padding:.7rem 1rem;border-radius:var(--r);
  font-family:'Jost',sans-serif;font-size:.93rem;font-weight:300;
  outline:none;width:100%;transition:border-color .2s;
}
.checkout-form input:focus,.checkout-form textarea:focus{border-color:rgba(240,234,216,.35);}
.checkout-form label{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--umber-lt);opacity:.85;margin-bottom:.25rem;display:block;font-weight:400;}

/* SKELETON */
.skeleton{
  background:linear-gradient(90deg,var(--ink-soft) 25%,var(--ink-mid) 50%,var(--ink-soft) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;
}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.skel-card{height:390px;border-radius:4px;}

/* TOAST */
.toast{
  position:fixed;bottom:2rem;left:50%;
  transform:translateX(-50%) translateY(100px);
  background:var(--ink-soft);border:1px solid rgba(240,234,216,.2);
  color:var(--bone);padding:.8rem 1.8rem;border-radius:100px;
  font-size:.82rem;font-weight:400;letter-spacing:.05em;
  z-index:500;transition:transform .35s;
  box-shadow:0 8px 40px rgba(0,0,0,.65);white-space:nowrap;
  font-family:'Jost',sans-serif;
}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast.toast-error{border-color:var(--red);}

/* API ERROR */
.api-error{grid-column:1/-1;text-align:center;padding:5rem 2rem;}
.api-error h3{font-family:'Playfair Display',serif;font-size:1.5rem;margin-bottom:.75rem;}
.api-error p{opacity:.45;font-size:.88rem;}

/* FOOTER */
footer{
  position:relative;z-index:1;
  background:var(--ink-soft);border-top:1px solid var(--border);
  padding:3.5rem 2.5rem 1.5rem;
}
.footer-inner{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr;
  gap:3rem;margin-bottom:2.5rem;
}
.footer-brand .brand{display:block;margin-bottom:.75rem;font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--ivory);}
.footer-brand p{font-size:.85rem;color:var(--bone-dk);opacity:.45;line-height:1.7;font-weight:300;}
.footer-col h5{font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;color:var(--umber-lt);margin-bottom:1rem;font-weight:400;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:.5rem;}
.footer-col a{font-size:.85rem;color:var(--bone-dk);opacity:.45;transition:opacity .2s;font-weight:300;}
.footer-col a:hover{opacity:1;color:var(--bone);}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;justify-content:space-between;font-size:.73rem;color:var(--bone-dk);opacity:.3;font-weight:300;}

/* RESPONSIVE */
@media(max-width:900px){.hero{grid-template-columns:1fr;min-height:auto;padding-top:5rem;}.hero-emblem-wrap{display:none;}}
@media(max-width:768px){nav{display:none;}.footer-inner{grid-template-columns:1fr;}.cart-panel{width:100vw;}.hero{padding:4rem 1.5rem 3rem;}}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
.animate-up{animation:fadeUp .75s ease both;}
.delay-1{animation-delay:.12s;}.delay-2{animation-delay:.26s;}
