/* ═══════════════════════════════════════════════════════
   NEEV — Artisanal Jewellery
   Alabaster / Warm Taupe / Soft Charcoal
   Cormorant Garamond (display) + Work Sans (body)
═══════════════════════════════════════════════════════ */

/* ── Tokens ─────────────────────────────────────────── */
:root, [data-theme='light'] {
  --bg:            #F8F6F1;
  --surface:       #FAF8F4;
  --surface-off:   #F0EDE6;
  --surface-deep:  #E8E3D8;
  --border:        #E0DAD0;
  --divider:       #E8E3DB;
  --text:          #2E2B25;
  --text-muted:    #7A7570;
  --text-faint:    #B8B3AA;
  --text-inv:      #FAF8F4;
  --accent:        #9C7B55;
  --accent-h:      #7A5F3E;
  --accent-light:  #EDE5D6;
  --success:       #4A7C59;
  --error:         #8B3A3A;

  --text-xs:   clamp(0.75rem,  0.7rem + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.2rem + 2.5vw, 3.5rem);
  --text-3xl:  clamp(2.5rem,   1rem + 4vw, 5rem);
  --text-hero: clamp(3.5rem,   1rem + 7vw, 8rem);

  --sp-1:0.25rem; --sp-2:0.5rem; --sp-3:0.75rem; --sp-4:1rem;
  --sp-5:1.25rem; --sp-6:1.5rem; --sp-8:2rem;    --sp-10:2.5rem;
  --sp-12:3rem;   --sp-16:4rem;  --sp-20:5rem;   --sp-24:6rem;

  --font-display:'Cormorant Garamond','Georgia',serif;
  --font-body:   'Work Sans','Helvetica Neue',sans-serif;

  --radius-sm:2px; --radius-md:4px; --radius-lg:8px;
  --shadow-sm:0 1px 3px rgba(46,43,37,.06);
  --shadow-md:0 6px 20px rgba(46,43,37,.10);
  --shadow-lg:0 16px 48px rgba(46,43,37,.15);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-in: cubic-bezier(0.4,0,1,1);
  --t:180ms; --t-med:300ms;
}

[data-theme='dark'] {
  --bg:           #1A1814;
  --surface:      #1F1D19;
  --surface-off:  #26231E;
  --surface-deep: #2E2B24;
  --border:       #3A3530;
  --divider:      #2E2B26;
  --text:         #D4CFC7;
  --text-muted:   #7D786F;
  --text-faint:   #514E48;
  --text-inv:     #1A1814;
  --accent:       #C49B6E;
  --accent-h:     #E0BC8A;
  --accent-light: #2C261E;
  --success:      #6DAA7A;
  --error:        #C47070;
  --shadow-sm:0 1px 3px rgba(0,0,0,.2);
  --shadow-md:0 6px 20px rgba(0,0,0,.35);
  --shadow-lg:0 16px 48px rgba(0,0,0,.5);
}

/* ── Reset ────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:var(--sp-16);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{font-family:var(--font-body);font-size:var(--text-base);
  font-weight:300;color:var(--text);background:var(--bg);
  min-height:100dvh;line-height:1.65;overflow-x:hidden;}
img,video,canvas,svg{display:block;max-width:100%;height:auto;}
ul,ol{list-style:none;}
input,button,textarea,select{font:inherit;color:inherit;}
h1,h2,h3,h4,h5,h6{text-wrap:balance;line-height:1.1;}
p,li{text-wrap:pretty;}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;background:none;border:none;}
::selection{background:var(--accent-light);color:var(--text);}
:focus-visible{outline:1.5px solid var(--accent);outline-offset:3px;border-radius:var(--radius-sm);}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important;}}

.skip-link{position:absolute;top:-100%;left:var(--sp-4);padding:var(--sp-2) var(--sp-4);
  background:var(--accent);color:var(--text-inv);font-size:var(--text-sm);
  border-radius:var(--radius-md);z-index:1000;}
.skip-link:focus{top:var(--sp-4);}

/* ── Fade-in ─────────────────────────────────────────── */
.fade-in{opacity:1;}
.js-fade .fade-in{opacity:0;transition:opacity .75s var(--ease-out) var(--delay,0s);}
.js-fade .fade-in.is-visible{opacity:1;}

/* ═══════════════════════════════════════════════════════
   NAV — centred logo, left/right groups
═══════════════════════════════════════════════════════ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:var(--sp-4) var(--sp-8);
}
.site-nav::before{content:'';position:absolute;inset:0;
  background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--divider);z-index:-1;}

.nav-left{display:flex;align-items:center;gap:var(--sp-6);justify-content:flex-start;}
.nav-right{display:flex;align-items:center;gap:var(--sp-3);justify-content:flex-end;}
.nav-link{font-size:var(--text-xs);font-weight:400;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text-muted);
  transition:color var(--t) var(--ease-out);position:relative;}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:1px;background:var(--accent);
  transition:width var(--t) var(--ease-out);}
.nav-link:hover{color:var(--text);}
.nav-link:hover::after{width:100%;}

.nav-logo{display:flex;align-items:center;justify-content:center;}
.logo-svg{width:72px;height:auto;color:var(--text);
  transition:color var(--t) var(--ease-out);}
.logo-svg:hover{color:var(--accent);}

.nav-icon-btn{display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;position:relative;
  color:var(--text-muted);transition:color var(--t) var(--ease-out),background var(--t) var(--ease-out);}
.nav-icon-btn:hover{color:var(--text);background:var(--surface-off);}
.basket-btn{position:relative;}
.basket-count{position:absolute;top:2px;right:2px;min-width:16px;height:16px;
  background:var(--accent);color:var(--text-inv);font-size:10px;font-weight:500;
  border-radius:99px;display:flex;align-items:center;justify-content:center;
  padding:0 3px;pointer-events:none;
  transition:transform var(--t) var(--ease-out);}
.basket-count[data-bounce]{animation:bounce .3s var(--ease-out);}
@keyframes bounce{0%,100%{transform:scale(1);}50%{transform:scale(1.4);}}

.theme-toggle{display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;color:var(--text-faint);
  transition:color var(--t) var(--ease-out);}
.theme-toggle:hover{color:var(--text-muted);}

/* ═══════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════ */
.hero{position:relative;width:100%;height:100svh;min-height:560px;overflow:hidden;}
.hero-image-wrap{position:absolute;inset:0;}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center 30%;}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(26,24,20,.08) 0%,rgba(26,24,20,.52) 100%);}
[data-theme='light'] .hero-overlay{
  background:linear-gradient(to bottom,rgba(248,246,241,.04) 0%,rgba(248,246,241,.42) 100%);}
.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;
  align-items:flex-start;justify-content:flex-end;height:100%;
  padding:var(--sp-24) var(--sp-16) var(--sp-20);max-width:900px;}
[data-theme='light'] .hero-content{color:#2E2B25;}
[data-theme='dark']  .hero-content{color:#F0EDE6;}
.hero-eyebrow{font-size:var(--text-xs);font-weight:400;letter-spacing:.22em;
  text-transform:uppercase;margin-bottom:var(--sp-4);opacity:.75;}
.hero-headline{font-family:var(--font-display);font-size:var(--text-hero);
  font-weight:300;line-height:.95;letter-spacing:-.02em;margin-bottom:var(--sp-10);}
.hero-headline em{font-style:italic;font-weight:300;}

/* ── Buttons ──────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:var(--sp-4) var(--sp-8);background:var(--accent);color:#FAF8F4;
  font-size:var(--text-sm);font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--accent);border-radius:0;
  transition:background var(--t) var(--ease-out),transform var(--t) var(--ease-out);}
.btn-primary:hover{background:var(--accent-h);border-color:var(--accent-h);transform:translateY(-1px);}
.btn-primary:active{transform:translateY(0);}
.btn-primary.btn-full{width:100%;justify-content:center;}
.btn-primary.btn-sm{padding:var(--sp-2) var(--sp-5);font-size:var(--text-xs);}
.btn-ghost{display:inline-flex;align-items:center;font-size:var(--text-sm);font-weight:400;
  letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border);
  padding-bottom:var(--sp-1);
  transition:color var(--t) var(--ease-out),border-color var(--t) var(--ease-out);}
.btn-ghost:hover{color:var(--text);border-color:var(--accent);}
.btn-outline{display:inline-flex;padding:var(--sp-3) var(--sp-6);border:1px solid var(--border);
  font-size:var(--text-sm);font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-muted);
  transition:color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),background var(--t) var(--ease-out);}
.btn-outline:hover{color:var(--text);border-color:var(--accent);background:var(--accent-light);}

/* ═══════════════════════════════════════════════════════
   MARQUEE
═══════════════════════════════════════════════════════ */
.marquee-strip{overflow:hidden;border-top:1px solid var(--divider);border-bottom:1px solid var(--divider);
  padding:var(--sp-3) 0;background:var(--surface-off);}
.marquee-track{display:flex;align-items:center;gap:var(--sp-5);white-space:nowrap;
  animation:marquee 30s linear infinite;font-size:var(--text-xs);
  font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);}
.mdot{color:var(--accent);}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;}}

/* ═══════════════════════════════════════════════════════
   COLLECTION
═══════════════════════════════════════════════════════ */
.collection{padding-block:clamp(var(--sp-16),8vw,var(--sp-24));
  padding-inline:var(--sp-8);max-width:1360px;margin:0 auto;}
.collection-header{display:flex;flex-direction:column;gap:var(--sp-4);
  margin-bottom:clamp(var(--sp-10),5vw,var(--sp-16));}
.section-label{font-size:var(--text-xs);font-weight:400;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);}
.collection-header h2{font-family:var(--font-display);font-size:var(--text-3xl);
  font-weight:300;letter-spacing:-.01em;}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);align-items:start;}

/* Product card */
.product-card{display:flex;flex-direction:column;cursor:pointer;}
.product-card:nth-child(2){margin-top:clamp(var(--sp-8),4vw,var(--sp-16));}
.product-img-wrap{position:relative;overflow:hidden;background:var(--surface-off);aspect-ratio:3/4;}
.product-img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out);}
.product-card:hover .product-img{transform:scale(1.04);}
.product-card-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:stretch;
  padding:var(--sp-4);opacity:0;transition:opacity var(--t-med) var(--ease-out);}
.product-card:hover .product-card-overlay{opacity:1;}
.product-card-overlay .btn-primary{flex:1;justify-content:center;font-size:var(--text-xs);}
.product-info{padding:var(--sp-4) var(--sp-1) 0;display:flex;flex-direction:column;gap:var(--sp-1);}
.product-info h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;letter-spacing:-.01em;}
.product-type{font-size:var(--text-xs);font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.product-price{font-size:var(--text-sm);font-weight:400;color:var(--text);margin-top:var(--sp-2);}
.product-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6;max-width:38ch;}
.collection-cta{margin-top:clamp(var(--sp-10),5vw,var(--sp-16));display:flex;justify-content:center;}

/* ═══════════════════════════════════════════════════════
   CRAFT
═══════════════════════════════════════════════════════ */
.craft{background:var(--surface-off);border-top:1px solid var(--divider);border-bottom:1px solid var(--divider);
  padding-block:clamp(var(--sp-16),8vw,var(--sp-24));padding-inline:var(--sp-8);}
.craft-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(var(--sp-10),6vw,var(--sp-20));align-items:center;}
.craft-img{width:100%;aspect-ratio:4/5;object-fit:cover;}
.craft-img-caption{margin-top:var(--sp-3);font-size:var(--text-xs);color:var(--text-faint);letter-spacing:.08em;}
.craft-text-col{display:flex;flex-direction:column;gap:var(--sp-6);padding-left:var(--sp-8);}
.craft-text-col h2{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:300;letter-spacing:-.01em;}
.craft-body{display:flex;flex-direction:column;gap:var(--sp-4);}
.craft-body p{font-size:var(--text-base);color:var(--text-muted);line-height:1.7;max-width:46ch;}

.quote-band{padding-block:clamp(var(--sp-20),10vw,var(--sp-24));padding-inline:var(--sp-8);
  display:flex;justify-content:center;text-align:center;}
.brand-quote p{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;
  font-style:italic;letter-spacing:-.01em;line-height:1.15;}

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.site-footer{background:var(--surface-off);border-top:1px solid var(--divider);
  padding-block:clamp(var(--sp-12),6vw,var(--sp-20));padding-inline:var(--sp-8);}
.footer-inner{max-width:1160px;margin:0 auto;display:grid;
  grid-template-columns:1.5fr 2fr 1fr;gap:var(--sp-12);align-items:start;
  padding-bottom:var(--sp-10);border-bottom:1px solid var(--divider);}
.logo-svg--footer{width:64px;}
.footer-tagline{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7;margin-top:var(--sp-4);}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);}
.footer-col{display:flex;flex-direction:column;gap:var(--sp-3);}
.footer-col h4{font-size:var(--text-xs);font-weight:400;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-faint);margin-bottom:var(--sp-1);}
.footer-col a{font-size:var(--text-sm);color:var(--text-muted);transition:color var(--t) var(--ease-out);}
.footer-col a:hover{color:var(--text);}
.footer-social{display:flex;flex-direction:column;gap:var(--sp-4);align-items:flex-end;}
.social-link{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-sm);
  color:var(--text-muted);transition:color var(--t) var(--ease-out);}
.social-link:hover{color:var(--accent);}
.footer-base{max-width:1160px;margin:var(--sp-6) auto 0;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-4);}
.footer-base p{font-size:var(--text-xs);color:var(--text-faint);}
.theme-toggle--sm{display:flex;align-items:center;gap:var(--sp-2);
  font-size:var(--text-xs);color:var(--text-faint);
  transition:color var(--t) var(--ease-out);}
.theme-toggle--sm:hover{color:var(--text-muted);}

/* ═══════════════════════════════════════════════════════
   MODAL (product + checkout shared shell)
═══════════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb,var(--text) 55%,transparent);
  padding:var(--sp-4);}
.modal-overlay[hidden]{display:none;}
.modal-panel{position:relative;background:var(--surface);border:1px solid var(--border);
  max-width:820px;width:100%;max-height:90svh;overflow-y:auto;
  box-shadow:var(--shadow-lg);}
.modal-close{position:absolute;top:var(--sp-4);right:var(--sp-4);z-index:2;
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);border-radius:50%;
  transition:color var(--t) var(--ease-out),background var(--t) var(--ease-out);}
.modal-close:hover{color:var(--text);background:var(--surface-off);}

/* Product modal body */
.modal-body{display:grid;grid-template-columns:1fr 1fr;}
.modal-img-wrap{background:var(--surface-off);}
.modal-img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/4;}
.modal-info{padding:var(--sp-10) var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-4);}
.modal-info h2{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;}
.modal-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7;}
.modal-price{font-size:var(--text-lg);font-weight:400;color:var(--text);}
.modal-actions{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap;}
.qty-control{display:flex;align-items:center;gap:var(--sp-3);
  border:1px solid var(--border);padding:var(--sp-2) var(--sp-4);}
.qty-btn{font-size:var(--text-lg);color:var(--text-muted);width:24px;text-align:center;
  transition:color var(--t) var(--ease-out);}
.qty-btn:hover{color:var(--text);}
.qty-val{min-width:24px;text-align:center;font-size:var(--text-base);}
.btn-add-basket{flex:1;}
.modal-shipping{font-size:var(--text-xs);color:var(--text-faint);letter-spacing:.05em;}

/* ═══════════════════════════════════════════════════════
   BASKET DRAWER
═══════════════════════════════════════════════════════ */
.drawer-overlay{position:fixed;inset:0;z-index:300;
  background:color-mix(in srgb,var(--text) 30%,transparent);
  opacity:0;pointer-events:none;transition:opacity var(--t-med) var(--ease-out);}
.drawer-overlay.active{opacity:1;pointer-events:all;}
.basket-drawer{position:fixed;top:0;right:0;bottom:0;z-index:350;width:min(420px,100vw);
  background:var(--surface);border-left:1px solid var(--border);
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform var(--t-med) var(--ease-out);
  box-shadow:var(--shadow-lg);}
.basket-drawer:not([hidden]).open{transform:translateX(0);}
.drawer-header{display:flex;align-items:center;justify-content:space-between;
  padding:var(--sp-6) var(--sp-6) var(--sp-4);border-bottom:1px solid var(--divider);}
.drawer-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;}
.drawer-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);border-radius:50%;transition:color var(--t) var(--ease-out),background var(--t) var(--ease-out);}
.drawer-close:hover{color:var(--text);background:var(--surface-off);}
.drawer-body{flex:1;overflow-y:auto;padding:var(--sp-4) var(--sp-6);}

/* Basket items */
.basket-item{display:grid;grid-template-columns:72px 1fr auto;gap:var(--sp-4);
  padding:var(--sp-4) 0;border-bottom:1px solid var(--divider);}
.basket-item-img{width:72px;height:90px;object-fit:cover;background:var(--surface-off);}
.basket-item-info{display:flex;flex-direction:column;justify-content:center;gap:var(--sp-1);}
.basket-item-name{font-family:var(--font-display);font-size:var(--text-base);font-weight:400;}
.basket-item-meta{font-size:var(--text-xs);color:var(--text-muted);}
.basket-item-controls{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;}
.basket-item-price{font-size:var(--text-sm);font-weight:400;}
.basket-item-qty{display:flex;align-items:center;gap:var(--sp-2);}
.basket-item-qty .qty-btn{font-size:var(--text-base);}
.basket-item-qty .qty-val{font-size:var(--text-xs);}
.basket-remove{font-size:var(--text-xs);color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;
  border-bottom:1px solid transparent;transition:color var(--t) var(--ease-out),border-color var(--t) var(--ease-out);}
.basket-remove:hover{color:var(--error);border-color:var(--error);}
.basket-empty{display:flex;flex-direction:column;align-items:center;gap:var(--sp-4);
  padding:var(--sp-16) var(--sp-8);text-align:center;color:var(--text-muted);}
.basket-empty svg{color:var(--text-faint);}

.drawer-footer{border-top:1px solid var(--divider);padding:var(--sp-5) var(--sp-6);
  display:flex;flex-direction:column;gap:var(--sp-4);}
.promo-row{display:flex;gap:var(--sp-3);}
.promo-input{flex:1;padding:var(--sp-3) var(--sp-4);border:1px solid var(--border);
  background:var(--bg);font-size:var(--text-sm);
  transition:border-color var(--t) var(--ease-out);}
.promo-input:focus{outline:none;border-color:var(--accent);}
.promo-btn{padding:var(--sp-3) var(--sp-5);border:1px solid var(--border);
  font-size:var(--text-xs);font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-muted);transition:all var(--t) var(--ease-out);}
.promo-btn:hover{border-color:var(--accent);color:var(--text);}
.promo-msg{font-size:var(--text-xs);min-height:1rem;}
.promo-msg.ok{color:var(--success);}
.promo-msg.err{color:var(--error);}
.basket-totals{display:flex;flex-direction:column;gap:var(--sp-2);}
.total-row{display:flex;justify-content:space-between;font-size:var(--text-sm);color:var(--text-muted);}
.total-row--discount{color:var(--success);}
.total-row--shipping{}
.total-row--grand{font-size:var(--text-base);font-weight:400;color:var(--text);
  padding-top:var(--sp-3);border-top:1px solid var(--divider);}
.btn-checkout{width:100%;justify-content:center;}

/* ═══════════════════════════════════════════════════════
   CHECKOUT MODAL
═══════════════════════════════════════════════════════ */
.modal-panel--checkout{max-width:1000px;}
.checkout-layout{display:grid;grid-template-columns:360px 1fr;}
.checkout-summary{background:var(--surface-off);padding:var(--sp-10) var(--sp-8);
  border-right:1px solid var(--divider);}
.checkout-form-col{padding:var(--sp-10) var(--sp-8);}
.checkout-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;margin-bottom:var(--sp-6);}
.checkout-section-title{font-size:var(--text-xs);font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent);margin-bottom:var(--sp-5);}
.checkout-totals{margin-top:var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-2);}
.checkout-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;
  border-bottom:1px solid var(--divider);}
.checkout-item-img{width:52px;height:64px;object-fit:cover;background:var(--surface);}
.checkout-item-info{flex:1;}
.checkout-item-name{font-family:var(--font-display);font-size:var(--text-base);font-weight:400;}
.checkout-item-sub{font-size:var(--text-xs);color:var(--text-muted);}
.checkout-item-price{font-size:var(--text-sm);}

/* Delivery form */
.form-group{display:flex;flex-direction:column;gap:var(--sp-2);}
.form-group label{font-size:var(--text-xs);font-weight:400;letter-spacing:.08em;
  text-transform:uppercase;color:var(--text-muted);}
.form-group input{padding:var(--sp-3) var(--sp-4);border:1px solid var(--border);
  background:var(--bg);font-size:var(--text-sm);
  transition:border-color var(--t) var(--ease-out);}
.form-group input:focus{outline:none;border-color:var(--accent);}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);}
.checkout-step{display:flex;flex-direction:column;gap:var(--sp-5);}

/* Payment */
.payment-methods{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);}
.payment-option{cursor:pointer;}
.payment-option input{display:none;}
.payment-option-inner{display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-4) var(--sp-5);border:1px solid var(--border);
  font-size:var(--text-sm);color:var(--text-muted);
  transition:all var(--t) var(--ease-out);}
.payment-option input:checked ~ .payment-option-inner{border-color:var(--accent);
  background:var(--accent-light);color:var(--text);}
.payment-option-inner:hover{border-color:var(--accent);}
.card-form{display:flex;flex-direction:column;gap:var(--sp-4);}
.secure-badge{display:flex;align-items:center;gap:var(--sp-2);
  font-size:var(--text-xs);color:var(--text-faint);letter-spacing:.05em;}
.checkout-nav{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);}

/* Order confirm */
.order-confirm{display:flex;flex-direction:column;align-items:center;gap:var(--sp-5);
  text-align:center;padding:var(--sp-8) 0;}
.confirm-icon{width:64px;height:64px;border-radius:50%;background:var(--accent-light);
  display:flex;align-items:center;justify-content:center;color:var(--accent);}
.order-confirm h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;}
.order-confirm p{font-size:var(--text-sm);color:var(--text-muted);max-width:40ch;line-height:1.7;}

/* ═══════════════════════════════════════════════════════
   CHATBOT
═══════════════════════════════════════════════════════ */
.chat-fab{position:fixed;bottom:var(--sp-6);right:var(--sp-6);z-index:500;
  width:52px;height:52px;border-radius:50%;background:var(--accent);color:#FAF8F4;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);
  transition:background var(--t) var(--ease-out),transform var(--t) var(--ease-out);}
.chat-fab:hover{background:var(--accent-h);transform:scale(1.08);}
.chat-fab:active{transform:scale(0.96);}
.chat-fab-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;
  border-radius:50%;background:#5DA96B;border:2px solid var(--accent);}

.chat-widget{position:fixed;bottom:calc(var(--sp-6) + 60px);right:var(--sp-6);z-index:500;
  width:min(360px,calc(100vw - 2rem));background:var(--surface);
  border:1px solid var(--border);box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;overflow:hidden;}
.chat-widget[hidden]{display:none;}
.chat-header{padding:var(--sp-4) var(--sp-5);background:var(--surface-off);
  border-bottom:1px solid var(--divider);display:flex;align-items:center;justify-content:space-between;}
.chat-header-info{display:flex;align-items:center;gap:var(--sp-3);}
.chat-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);
  color:var(--text-inv);display:flex;align-items:center;justify-content:center;
  font-size:var(--text-sm);font-weight:500;}
.chat-name{font-size:var(--text-sm);font-weight:400;color:var(--text);}
.chat-status{font-size:var(--text-xs);color:var(--text-faint);}
.chat-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);border-radius:50%;
  transition:color var(--t) var(--ease-out),background var(--t) var(--ease-out);}
.chat-close:hover{color:var(--text);background:var(--surface-deep);}
.chat-messages{height:260px;overflow-y:auto;padding:var(--sp-4) var(--sp-5);
  display:flex;flex-direction:column;gap:var(--sp-3);}
.chat-msg{max-width:82%;font-size:var(--text-sm);line-height:1.55;}
.chat-msg.bot{align-self:flex-start;}
.chat-msg.user{align-self:flex-end;}
.chat-msg-bubble{padding:var(--sp-3) var(--sp-4);}
.chat-msg.bot .chat-msg-bubble{background:var(--surface-off);color:var(--text);}
.chat-msg.user .chat-msg-bubble{background:var(--accent);color:#FAF8F4;}
.chat-msg-time{font-size:10px;color:var(--text-faint);margin-top:2px;text-align:right;}
.chat-msg.bot .chat-msg-time{text-align:left;}

.chat-quick-replies{display:flex;flex-wrap:wrap;gap:var(--sp-2);padding:0 var(--sp-5) var(--sp-3);}
.chat-qr{padding:var(--sp-2) var(--sp-3);border:1px solid var(--border);
  font-size:var(--text-xs);color:var(--text-muted);
  transition:all var(--t) var(--ease-out);cursor:pointer;}
.chat-qr:hover{border-color:var(--accent);color:var(--text);}

.chat-input-row{display:flex;align-items:center;border-top:1px solid var(--divider);}
.chat-input{flex:1;padding:var(--sp-4) var(--sp-5);border:none;background:transparent;
  font-size:var(--text-sm);}
.chat-input:focus{outline:none;}
.chat-send{padding:var(--sp-4) var(--sp-5);color:var(--accent);
  transition:color var(--t) var(--ease-out);}
.chat-send:hover{color:var(--accent-h);}

/* Typing indicator */
.typing-indicator{display:flex;align-items:center;gap:4px;padding:var(--sp-2);}
.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);
  animation:typing-pulse 1.2s ease-in-out infinite;}
.typing-dot:nth-child(2){animation-delay:.2s;}
.typing-dot:nth-child(3){animation-delay:.4s;}
@keyframes typing-pulse{0%,100%{opacity:.3;transform:scale(.8);}50%{opacity:1;transform:scale(1.2);}}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media(max-width:960px){
  .product-grid{grid-template-columns:1fr 1fr;gap:var(--sp-5);}
  .product-card:nth-child(2){margin-top:0;}
  .product-card:last-child{grid-column:1/-1;max-width:460px;margin-inline:auto;}
  .craft-grid{grid-template-columns:1fr;gap:var(--sp-10);}
  .craft-text-col{padding-left:0;}
  .footer-inner{grid-template-columns:1fr;gap:var(--sp-8);}
  .footer-social{align-items:flex-start;flex-direction:row;}
  .checkout-layout{grid-template-columns:1fr;}
  .checkout-summary{border-right:none;border-bottom:1px solid var(--divider);}
}

@media(max-width:640px){
  .site-nav{padding:var(--sp-3) var(--sp-4);}
  .nav-link{display:none;}
  .hero-content{padding:var(--sp-20) var(--sp-5) var(--sp-12);}
  .hero-headline{font-size:clamp(2.8rem,14vw,5rem);}
  .collection,.craft,.quote-band{padding-inline:var(--sp-5);}
  .product-grid{grid-template-columns:1fr;}
  .product-card:last-child{max-width:100%;grid-column:auto;}
  .modal-body{grid-template-columns:1fr;}
  .modal-img-wrap{aspect-ratio:16/9;}
  .payment-methods{grid-template-columns:1fr;}
  .footer-links{grid-template-columns:1fr 1fr;}
  .brand-quote p{font-size:var(--text-xl);}
}
