:root{
  --bg:#e7dac6; --ink:#161616; --ink2:#3a3a3a; --line:#d6cab6; --card:#f4e9d8; --black:#0b0b0b;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);font-family:ui-sans-serif,-apple-system,Segoe UI,Roboto,Helvetica,Arial;}
.container{max-width:1160px;margin:0 auto;padding:28px}
.brand h1{font-size:clamp(42px,7vw,92px);line-height:.95;letter-spacing:-.02em;margin:0 0 10px}
.brand p{font-size:clamp(16px,2.5vw,20px);color:var(--ink2);margin:0 0 14px}
.badge{display:inline-block;border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:12px;letter-spacing:.06em}
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero-img img{width:100%;border-radius:16px;border:1px solid var(--line);background:#f3eadc}
.controls button, .controls a{border:1px solid var(--ink);background:#111;color:#fff;border-radius:12px;padding:10px 14px;font-size:14px;text-decoration:none;display:inline-block}
.controls a{background:transparent;color:inherit;border-color:var(--line);margin-left:8px}
.section{padding:36px 0}
.section h2{font-size:clamp(28px,4vw,44px);letter-spacing:-.02em;margin:0 0 12px}
.lead{color:#5b5246}
.preview{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.viewer{background:#f3eadc;border:1px solid var(--line);border-radius:18px;padding:12px}
.viewer img{width:100%;border-radius:12px;display:block}
fieldset{border:1px solid var(--line);border-radius:14px;padding:8px 10px;background:#f6ecde;margin:8px 0}
legend{padding:0 6px;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#6b5f4f}
select, input[type=number]{appearance:none;border:1px solid var(--line);border-radius:12px;padding:10px 14px;background:#fff;font-size:15px;width:100%}
.swatches{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.swatch{width:28px;height:28px;border-radius:50%;border:1px solid var(--line);cursor:pointer;box-shadow:inset 0 0 0 2px #fff}
.divider{height:1px;background:var(--line);margin:38px 0}
.sombre{background:#0b0b0b;color:#eee;border:1px solid #242424;border-radius:20px;padding:22px}
.sombre-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:center}
.footer{padding:40px 0 60px;color:#6a5f4f;font-size:12px}
@media (max-width:900px){
  .hero,.preview,.sombre-grid{grid-template-columns:1fr}
}
.sticky-bar{position:fixed; left:0; right:0; bottom:0; z-index:50; background:rgba(12,12,12,.92); color:#fff; backdrop-filter:blur(6px); border-top:1px solid #2a2a2a;}
.sticky-inner{max-width:1160px;margin:0 auto;padding:10px 16px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.sticky-inner .meta{display:flex;gap:12px;align-items:center;flex:1}
.thumb{width:56px;height:56px;border-radius:10px;overflow:hidden;border:1px solid #2a2a2a;background:#1a1a1a}
.thumb img{width:100%;height:100%;object-fit:cover}
.sticky-inner select, .sticky-inner input{background:#111;border:1px solid #333;color:#fff}
.sticky-inner button{background:#fff;color:#000;border:1px solid #fff;border-radius:10px;padding:10px 14px;font-weight:600}
.cart-drawer{position:fixed; top:0; right:-380px; width:360px; height:100%; background:#111; color:#eee; border-left:1px solid #2a2a2a; transition:right .25s ease; z-index:60; padding:18px;}
.cart-drawer.open{ right:0; }
.cart-line{display:flex; gap:10px; align-items:center; margin:12px 0; }
.cart-line img{width:64px; height:auto; border-radius:8px; border:1px solid #2a2a2a;}
.cart-drawer h3{margin:0 0 12px}
.cart-drawer .close{position:absolute; top:12px; right:12px; background:#222; border:1px solid #2a2a2a; color:#fff; padding:6px 10px; border-radius:8px; cursor:pointer;}


/* Toast + cart bubble + pulse */
.toast{
  position:fixed; bottom:16px; left:50%; transform:translateX(-50%) translateY(20px);
  background:#111; color:#fff; padding:10px 14px; border-radius:12px; border:1px solid #333;
  opacity:0; pointer-events:none; transition:opacity .2s ease, transform .2s ease; z-index:70;
}
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
#openCart{ position:relative; }
#cartBubble{
  position:absolute; top:-8px; right:-8px; min-width:20px; height:20px; padding:0 6px;
  background:#fff; color:#000; border:1px solid #ccc; border-radius:999px;
  font-size:12px; line-height:20px; text-align:center; display:none;
}
.pulse{ animation:pulse .25s ease; }
@keyframes pulse{ 0%{transform:scale(1)} 50%{transform:scale(1.06)} 100%{transform:scale(1)} }


/* Cart line delete button + checkout */
.cart-line .trash{
  margin-left:auto; background:#1a1a1a; border:1px solid #2a2a2a; color:#ccc;
  width:34px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; cursor:pointer;
}
.cart-line .trash:hover{ background:#222; color:#fff; }
.cart-actions{ display:flex; gap:10px; margin-top:12px; }
.cart-actions .checkout{ background:#fff; color:#000; border:1px solid #fff; border-radius:10px; padding:10px 14px; font-weight:600; }
.cart-actions .view{ background:#000; color:#fff; border:1px solid #444; border-radius:10px; padding:10px 14px; }
.checkout-wrap{ max-width:900px; margin:0 auto; padding:28px; }
.checkout-grid{ display:grid; grid-template-columns: 1fr 380px; gap:28px; }
.checkout-card{ background:#f4e9d8; border:1px solid #d6cab6; border-radius:16px; padding:16px; }
.checkout-card h3{ margin:0 0 12px; }
.checkout-line{ display:flex; gap:10px; align-items:center; margin:10px 0; }
.checkout-line img{ width:60px; height:auto; border-radius:8px; border:1px solid #d6cab6; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.form-row input{ padding:10px 12px; border-radius:10px; border:1px solid #d6cab6; background:#fff; }
.pay-btn{ width:100%; background:#111; color:#fff; border:1px solid #111; padding:12px 16px; border-radius:12px; font-weight:700; }
.small-note{ font-size:12px; color:#6b5f4f; margin-top:8px; }
@media (max-width:900px){ .checkout-grid{ grid-template-columns:1fr; } }


/* ===== Mobile/iPhone polish ===== */
html{ -webkit-text-size-adjust:100%; }
img,video{ max-width:100%; height:auto; display:block; }
input,select,textarea,button{ font-size:16px; } /* prevent iOS zoom on focus */
.container{ padding:clamp(16px,4vw,28px); }

/* Stack primary grids on small screens */
@media (max-width: 860px){
  .hero{ grid-template-columns:1fr; gap:20px; }
  .sombre-grid{ grid-template-columns:1fr; gap:20px; }
  .controls{ display:grid; grid-auto-flow:row; gap:10px; }
  .controls > *{ width:100%; }
  fieldset select, fieldset input{ width:100%; }
}

/* Cart drawer full width on phones + safe-area padding */
@media (max-width: 520px){
  .cart-drawer{ right:-100%; width:100%; max-width:none; border-left:0; }
  .cart-drawer.open{ right:0; }
  .sticky-bar{ padding-bottom:calc(10px + env(safe-area-inset-bottom)); }
  .footer{ padding-bottom:calc(12px + env(safe-area-inset-bottom)); }
}


/* ===== Modal for Sombre size picker ===== */
.modal{ position:fixed; inset:0; display:none; z-index:80; }
.modal.open{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.45); }
.modal-card{ position:relative; max-width:420px; margin:8vh auto; background:#fff; color:#111; border-radius:14px; padding:18px; box-shadow:0 15px 60px rgba(0,0,0,.35); }
.modal-close{ position:absolute; top:8px; right:10px; background:#eee; border:1px solid #ddd; border-radius:8px; padding:4px 10px; cursor:pointer; }
.size-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:12px; }
.size-pill{ border:1px solid #ccc; background:#fafafa; border-radius:999px; padding:10px; cursor:pointer; font-weight:600; }
.size-pill.selected{ outline:2px solid #111; background:#fff; }
.modal-actions{ display:flex; gap:10px; margin-top:14px; }
.modal-actions .primary{ border:1px solid #111; background:#111; color:#fff; border-radius:10px; padding:10px 14px; font-weight:700; }
.modal-actions .primary:disabled{ opacity:.5; cursor:not-allowed; }
.modal-actions .secondary{ border:1px solid #ccc; background:#fff; border-radius:10px; padding:10px 14px; }

/* Notify form */
.notify-form{ display:flex; gap:8px; margin-top:10px; flex-wrap:wrap; }
.notify-form input[type="email"]{ flex:1; min-width:220px; border:1px solid var(--line); background:#fff; color:#111; border-radius:10px; padding:10px 12px; }
.notify-btn{ border:1px solid var(--ink); background:var(--ink); color:#fff; border-radius:10px; padding:10px 12px; font-weight:600; }
@media(max-width:520px){
  .modal-card{ margin:12vh 16px; }
}


/* === Fly-to-cart animation === */ 
.flyer{
  position:fixed;
  width:44px; height:44px;
  border-radius:8px;
  background:#fff;
  background-size:cover; background-position:center;
  border:2px solid #fff;
  box-shadow:0 6px 18px rgba(0,0,0,.35);
  opacity:.98;
  z-index:9999;
  transform:translate(0,0) scale(1);
  transition:transform .7s cubic-bezier(.22,.61,.36,1), opacity .7s;
  pointer-events:none;
}

/* Cart bubble bounce */
@keyframes cart-bounce { 
  0%{transform:scale(1);} 
  40%{transform:scale(1.3);} 
  100%{transform:scale(1);} 
}
#cartBubble.bounce{ animation: cart-bounce .6s ease; }

/* Added banner inside modal */
.added-banner{
  display:flex; align-items:center; justify-content:center;
  gap:8px; margin-top:8px;
  background:#e8f8ec; color:#0a7f3b;
  border:1px solid #b7e6c7; border-radius:10px;
  padding:8px 12px; font-weight:700;
  animation: added-pop .35s ease;
}
@keyframes added-pop { 0%{transform:scale(.9); opacity:0} 100%{transform:scale(1); opacity:1} }


/* Inline Sombre picker */
.inline-size-picker{ margin-top:10px; }
.inline-size-picker .size-grid{ margin-top:8px; }

/* Inline added banner */
.inline-added-banner{
  display:flex; align-items:center; justify-content:center;
  margin-top:8px; padding:8px 12px;
  border:1px solid #b7e6c7; background:#e8f8ec; color:#0a7f3b;
  border-radius:10px; font-weight:700;
  animation: added-pop .35s ease;
}
@keyframes added-pop { 0%{transform:scale(.9); opacity:0} 100%{transform:scale(1); opacity:1} }

/* Chip ripple feedback */
.size-pill{ position:relative; overflow:hidden; }
.size-pill.ripple::after{
  content:''; position:absolute; left:50%; top:50%;
  width:0; height:0; border-radius:999px; background:rgba(0,0,0,.08);
  transform:translate(-50%,-50%); animation:ripple .45s ease-out forwards;
}
@keyframes ripple { 
  0%{ width:0; height:0; opacity:.7; } 
  100%{ width:180%; height:180%; opacity:0; } 
}
