/* ============================================================
   PRIME COLLECTIONS — store.css  (storefront only)
   ============================================================ */

/* Announce bar */
.announce{background:var(--ink);color:var(--cream);text-align:center;
  font-size:.8rem;letter-spacing:.07em;padding:10px 16px;font-weight:500}
.announce b{color:var(--amber-2)}

/* Header */
.site-head{position:sticky;top:0;z-index:200;background:rgba(246,239,225,.82);
  backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;gap:22px;height:76px}
.nav{display:flex;gap:4px;margin-left:8px;flex-wrap:wrap}
.nav a{padding:8px 14px;border-radius:999px;font-weight:600;font-size:.9rem;color:var(--ink-soft);transition:.2s}
.nav a:hover,.nav a.on{color:var(--ink);background:var(--bone-2)}
.head-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.search{flex:1;max-width:270px;display:flex;align-items:center;gap:8px;background:var(--paper);
  border:1.5px solid var(--line);border-radius:999px;padding:10px 16px;color:var(--ink-soft)}
.search input{border:none;background:none;outline:none;width:100%;font-size:.9rem}
.cart-count{position:absolute;top:-7px;right:-7px;min-width:22px;height:22px;padding:0 5px;
  background:var(--rust);color:#fff;border-radius:999px;font-size:.7rem;font-weight:800;
  display:grid;place-items:center;border:2px solid var(--bone)}

/* HERO — warm gradient mesh */
.hero{position:relative;padding:70px 0 34px;overflow:hidden;
  background:
    radial-gradient(circle at 14% 18%, rgba(243,184,64,.20), transparent 42%),
    radial-gradient(circle at 88% 12%, rgba(192,73,42,.20), transparent 48%),
    radial-gradient(circle at 70% 95%, rgba(33,64,44,.14), transparent 45%),
    var(--bone)}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='600'%3E%3Cg fill='none' stroke='%23c0492a' stroke-opacity='.07' stroke-width='1.2'%3E%3Cpath d='M0 120 Q300 60 600 120 T1200 120'/%3E%3Cpath d='M0 180 Q300 120 600 180 T1200 180'/%3E%3Cpath d='M0 240 Q300 180 600 240 T1200 240'/%3E%3Cpath d='M0 300 Q300 240 600 300 T1200 300'/%3E%3Cpath d='M0 360 Q300 300 600 360 T1200 360'/%3E%3Cpath d='M0 420 Q300 360 600 420 T1200 420'/%3E%3Cpath d='M0 480 Q300 420 600 480 T1200 480'/%3E%3C/g%3E%3C/svg%3E");
  background-size:cover}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:22px}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--rust);
  box-shadow:0 0 0 4px rgba(192,73,42,.16)}
.hero h1{font-size:clamp(2.8rem,6.2vw,4.8rem);color:var(--ink)}
.hero h1 em{font-style:italic;color:var(--rust);font-weight:500}
.hero p.lede{font-size:1.13rem;color:var(--ink-soft);max-width:46ch;margin:22px 0 32px;line-height:1.65}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;gap:34px;margin-top:40px}
.hero-stats .s b{font-family:var(--serif);font-size:1.8rem;color:var(--ink);display:block;line-height:1}
.hero-stats .s span{font-size:.78rem;color:var(--ink-soft);letter-spacing:.03em}
.hero-stats .s b .star{color:var(--amber)}

/* HERO SHOWCASE SLIDER — self-contained, rotates through real products */
.hero-visual{position:relative;height:clamp(380px,44vw,470px);display:flex;align-items:center;justify-content:center}
.showcase{position:relative;width:100%;max-width:400px;height:100%}
/* ghost cards behind for depth */
.sc-ghost{position:absolute;inset:14px 0;border-radius:26px;background:var(--paper);
  border:1px solid var(--line);box-shadow:var(--shadow)}
.sc-ghost.g1{transform:rotate(-7deg) translate(-10px,8px);opacity:.45}
.sc-ghost.g2{transform:rotate(5deg) translate(12px,4px);opacity:.7}
/* main card */
.sc-card{position:absolute;inset:14px 0;border-radius:26px;overflow:hidden;border:7px solid var(--paper);
  box-shadow:var(--shadow-lg);background:var(--bone-2);cursor:pointer;transform:rotate(-2deg);
  transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.sc-card:hover{transform:rotate(-2deg) scale(1.015)}
.sc-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;display:flex;align-items:flex-end}
.sc-slide.on{opacity:1}
.sc-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.sc-fallback{position:absolute;inset:0;display:grid;place-items:center;font-size:5.2rem;
  text-shadow:0 6px 20px rgba(0,0,0,.18)}
.sc-cap{position:relative;z-index:2;width:100%;padding:22px 22px 20px;color:#fff;
  background:linear-gradient(to top,rgba(28,19,11,.82) 12%,rgba(28,19,11,.25) 60%,transparent)}
.sc-cap .c-cat{font-size:.66rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-2)}
.sc-cap .c-name{font-family:var(--serif);font-size:1.3rem;margin-top:3px;line-height:1.12}
/* floating price chip */
.sc-chip{position:absolute;z-index:6;left:-16px;top:30px;background:var(--paper);border-radius:16px;
  padding:11px 17px;box-shadow:var(--shadow-lg);animation:bob 5s ease-in-out infinite;min-width:96px}
.sc-chip .lab{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:800}
.sc-chip .val{font-family:var(--serif);font-size:1.35rem;color:var(--rust);font-weight:600;line-height:1.1}
.sc-chip .val small{font-size:.72rem;color:var(--ink-soft);text-decoration:line-through;
  font-family:var(--sans);margin-left:5px;font-weight:600}
/* rating chip bottom-right */
.sc-badge2{position:absolute;z-index:6;right:-12px;bottom:50px;background:var(--ink);color:var(--amber-2);
  border-radius:14px;padding:9px 14px;box-shadow:var(--shadow-lg);font-weight:800;font-size:.82rem;
  display:flex;align-items:center;gap:6px;animation:bob 6s ease-in-out infinite .6s}
/* dots */
.sc-dots{position:absolute;bottom:-26px;left:0;right:0;display:flex;gap:8px;justify-content:center;z-index:6}
.sc-dot{width:8px;height:8px;border-radius:999px;background:var(--line-2);transition:.35s;cursor:pointer;border:none}
.sc-dot.on{background:var(--rust);width:26px}

/* Category pills */
.cats{padding:20px 0 6px}
.cats .wrap{display:flex;gap:12px;overflow-x:auto;padding-bottom:10px;scrollbar-width:none}
.cats .wrap::-webkit-scrollbar{display:none}
.cat-pill{flex:none;display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--paper);
  border:1.5px solid var(--line);border-radius:999px;font-weight:700;font-size:.9rem;transition:.2s;color:var(--ink)}
.cat-pill .em{font-size:1.15rem}
.cat-pill:hover{transform:translateY(-2px);border-color:var(--line-2)}
.cat-pill.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* Section header */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin:50px 0 28px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem);color:var(--ink)}
.sec-head p{color:var(--ink-soft);font-size:.95rem;margin-top:6px}

/* Product grid */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.card{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s,border-color .4s;
  display:flex;flex-direction:column;position:relative}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.card-media{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--bone-2)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .card-media img{transform:scale(1.07)}
.card-cat{position:absolute;top:12px;left:12px;background:rgba(255,250,240,.92);backdrop-filter:blur(4px);
  border-radius:999px;padding:5px 12px;font-size:.66rem;font-weight:800;letter-spacing:.07em;
  text-transform:uppercase;color:var(--ink)}
.card-fav{position:absolute;top:11px;right:11px;width:38px;height:38px;border-radius:50%;
  background:rgba(255,250,240,.92);display:grid;place-items:center;color:var(--ink-soft);font-size:1.1rem;
  opacity:0;transform:translateY(-6px);transition:.25s}
.card:hover .card-fav{opacity:1;transform:none}
.card-fav:hover{color:var(--rust)}
.card-body{padding:17px 17px 19px;display:flex;flex-direction:column;gap:5px;flex:1}
.card-body h3{font-size:1.1rem;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.card-desc{font-size:.83rem;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;min-height:2.3em}
.stars{color:var(--amber);font-size:.82rem;letter-spacing:1px}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.price{font-family:var(--serif);font-size:1.3rem;color:var(--ink);font-weight:600}
.price small{font-size:.72rem;color:var(--rust);text-decoration:line-through;margin-left:6px;
  font-family:var(--sans);font-weight:600}
.add-btn{width:44px;height:44px;border-radius:13px;background:var(--ink);color:var(--cream);
  display:grid;place-items:center;font-size:1.1rem;transition:.25s}
.add-btn:hover{background:var(--rust);transform:rotate(90deg)}
.stock-out{position:absolute;inset:0;background:rgba(36,26,17,.5);display:grid;place-items:center;
  color:#fff;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:.8rem}

/* Feature banner */
.feature{margin:66px 0;background:linear-gradient(135deg,var(--forest),var(--forest-2));
  border-radius:28px;overflow:hidden;position:relative}
.feature::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 86% 22%,rgba(243,184,64,.22),transparent 52%),
             radial-gradient(circle at 10% 90%,rgba(192,73,42,.22),transparent 50%)}
.feature .wrap{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:30px;align-items:center;padding:0}
.feature-txt{padding:58px 0 58px 46px;color:var(--cream)}
.feature-txt h2{color:var(--cream);font-size:clamp(2rem,3.6vw,3rem)}
.feature-txt h2 em{color:var(--amber-2);font-style:italic;font-weight:500}
.feature-txt p{color:rgba(246,239,225,.78);margin:16px 0 28px;max-width:42ch}
.feature-img{height:380px}
.feature-img img{width:100%;height:100%;object-fit:cover}

/* Trust row */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:58px 0}
.trust .t{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--radius);padding:26px;text-align:center}
.trust .t .em{font-size:1.9rem}
.trust .t b{display:block;margin:9px 0 3px;font-family:var(--serif);font-size:1.08rem;color:var(--ink)}
.trust .t span{font-size:.82rem;color:var(--ink-soft)}

/* Footer */
.foot{background:linear-gradient(160deg,var(--forest),var(--forest-3));color:var(--cream);margin-top:74px;padding:60px 0 30px}
.foot .brand{color:var(--cream)}
.foot .brand .mark{background:var(--cream);color:var(--ink)}
.foot .wrap{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px}
.foot p.about{color:rgba(246,239,225,.62);font-size:.9rem;margin-top:16px;max-width:34ch}
.foot h4{color:var(--amber-2);font-family:var(--sans);font-size:.76rem;letter-spacing:.14em;
  text-transform:uppercase;margin-bottom:16px;font-weight:800}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot ul a{color:rgba(246,239,225,.78);font-size:.9rem;transition:.2s}
.foot ul a:hover{color:var(--amber-2)}
.foot-bottom{border-top:1px solid rgba(246,239,225,.13);margin-top:42px;padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(246,239,225,.5)}
.foot-bottom a{color:rgba(246,239,225,.72)}

/* Cart drawer */
.drawer{position:fixed;top:0;right:0;height:100%;width:min(424px,92vw);background:var(--paper);z-index:500;
  transform:translateX(100%);transition:transform .42s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;
  box-shadow:var(--shadow-lg)}
.drawer.open{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 16px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:1.4rem;color:var(--ink)}
.drawer-body{flex:1;overflow-y:auto;padding:8px 22px}
.ci{display:flex;gap:13px;padding:16px 0;border-bottom:1px solid var(--line)}
.ci img{width:76px;height:76px;border-radius:13px;object-fit:cover;flex:none;background:var(--bone-2)}
.ci-info{flex:1;min-width:0}
.ci-info h4{font-family:var(--sans);font-size:.95rem;font-weight:700}
.ci-info .cat{font-size:.74rem;color:var(--ink-soft)}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;margin-top:8px;overflow:hidden}
.qty button{width:30px;height:30px;display:grid;place-items:center;color:var(--ink);font-size:1rem}
.qty button:hover{background:var(--bone-2)}
.qty span{min-width:30px;text-align:center;font-weight:700;font-size:.9rem}
.ci-right{text-align:right;display:flex;flex-direction:column;justify-content:space-between}
.ci-right .p{font-family:var(--serif);font-weight:600;color:var(--ink)}
.ci-remove{font-size:.76rem;color:var(--danger);opacity:.85}
.ci-remove:hover{opacity:1;text-decoration:underline}
.cart-empty{text-align:center;padding:60px 20px;color:var(--ink-soft)}
.cart-empty .em{font-size:3rem;opacity:.55}
.drawer-foot{padding:20px 22px;border-top:1px solid var(--line);background:var(--bone)}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.cart-total b{font-family:var(--serif);font-size:1.55rem;color:var(--ink)}
.wa-note{font-size:.76rem;color:var(--ink-soft);text-align:center;margin-top:10px}

/* Product modal */
.modal-scrim{position:fixed;inset:0;background:rgba(36,26,17,.58);backdrop-filter:blur(4px);z-index:600;
  display:none;align-items:center;justify-content:center;padding:24px}
.modal-scrim.open{display:flex}
.modal{background:var(--paper);border-radius:24px;width:min(900px,100%);max-height:90vh;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;box-shadow:var(--shadow-lg);animation:pop .35s cubic-bezier(.2,.8,.2,1);position:relative}
.modal-media{background:var(--bone-2);display:flex;flex-direction:column}
.modal-main-img{flex:1;aspect-ratio:1;overflow:hidden}
.modal-main-img img{width:100%;height:100%;object-fit:cover}
.modal-thumbs{display:flex;gap:8px;padding:12px;background:var(--bone)}
.modal-thumbs img{width:58px;height:58px;border-radius:10px;object-fit:cover;cursor:pointer;
  border:2px solid transparent;opacity:.7;transition:.2s}
.modal-thumbs img:hover{opacity:1}
.modal-thumbs img.on{border-color:var(--rust);opacity:1}
.modal-info{padding:36px 34px;overflow-y:auto;display:flex;flex-direction:column}
.modal-info h2{font-size:1.9rem;color:var(--ink);margin:8px 0}
.modal-info .price{font-size:1.75rem;margin:10px 0}
.modal-info .desc{color:var(--ink-soft);font-size:.95rem;margin:14px 0;line-height:1.7}
.modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;
  background:var(--paper);box-shadow:var(--shadow);display:grid;place-items:center;z-index:5;font-size:1rem}
.spec{display:flex;gap:10px;font-size:.86rem;color:var(--ink-soft);padding:8px 0;border-bottom:1px solid var(--line)}
.spec b{color:var(--ink);min-width:96px}

/* Checkout modal (shares .admodal styles from admin? no — define here) */
.checkout-scrim{position:fixed;inset:0;background:rgba(36,26,17,.55);backdrop-filter:blur(4px);z-index:700;
  display:none;align-items:flex-start;justify-content:center;padding:40px 18px;overflow-y:auto}
.checkout-scrim.open{display:flex}
.checkout-card{background:var(--paper);border-radius:22px;width:min(480px,100%);box-shadow:var(--shadow-lg);animation:pop .3s ease}
.checkout-card .ch-head{display:flex;align-items:center;justify-content:space-between;padding:22px 26px;border-bottom:1px solid var(--line)}
.checkout-card .ch-head h3{font-size:1.35rem;color:var(--ink)}
.checkout-card .ch-body{padding:24px 26px}
.checkout-card .ch-foot{display:flex;gap:12px;justify-content:flex-end;padding:18px 26px;border-top:1px solid var(--line)}

.mobile-menu{display:none}

/* Responsive */
@media(max-width:1080px){.grid{grid-template-columns:repeat(3,1fr)}.trust{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){
  .hero .wrap{grid-template-columns:1fr}.hero-visual{height:340px;order:-1}
  .feature .wrap{grid-template-columns:1fr}.feature-txt{padding:40px 26px}.feature-img{height:240px;order:-1}
  .foot .wrap{grid-template-columns:1fr 1fr}.nav{display:none}.modal{grid-template-columns:1fr}.modal-media{max-height:300px}
  .mobile-menu{display:grid}
}
@media(max-width:560px){.grid{grid-template-columns:repeat(2,1fr)}.search{display:none}.wrap{padding:0 16px}}

/* ---------- AUTH MODAL + ACCOUNT DRAWER ---------- */
.auth-tabs{display:flex;gap:6px;background:var(--bone-2);border-radius:12px;padding:5px;margin-bottom:18px}
.auth-tabs button{flex:1;padding:10px;border-radius:9px;font-weight:700;font-size:.88rem;color:var(--ink-soft);transition:.2s}
.auth-tabs button.on{background:var(--paper);color:var(--ink);box-shadow:var(--shadow)}
.google-btn{gap:10px}
.google-btn .g{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-weight:800;
  background:conic-gradient(from -45deg,#ea4335,#fbbc05,#34a853,#4285f4,#ea4335);color:#fff;font-size:.8rem}
.auth-or{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--ink-soft);font-size:.8rem}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-msg{font-size:.82rem;margin:4px 0 12px;min-height:1em}
.auth-msg.err{color:var(--danger)} .auth-msg.ok{color:var(--ok)}
.acct-card{background:linear-gradient(150deg,var(--ink),var(--ink-2));color:var(--cream);border-radius:16px;
  padding:20px;margin:8px 0 22px;display:flex;align-items:center;gap:14px}
.acct-card .av{width:48px;height:48px;border-radius:50%;background:var(--amber);color:var(--ink);
  display:grid;place-items:center;font-weight:800;font-size:1.1rem;flex:none}
.acct-card .nm{font-family:var(--serif);font-size:1.2rem}
.acct-card .em{font-size:.82rem;color:rgba(246,239,225,.7);word-break:break-all}
.acct-h{font-family:var(--sans);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:800;margin:6px 0 12px}
.oh-item{border:1.5px solid var(--line);border-radius:14px;padding:14px;margin-bottom:12px;background:var(--paper)}
.oh-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.oh-top b{font-size:.95rem}
.oh-line{font-size:.82rem;color:var(--ink-soft)}
.oh-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;
  padding-top:10px;border-top:1px solid var(--line)}
.oh-foot .tot{font-family:var(--serif);font-weight:600;color:var(--ink)}
.acct-empty{text-align:center;color:var(--ink-soft);padding:30px 10px}
.acct-empty .em{font-size:2.4rem;opacity:.55;display:block;margin-bottom:6px}

/* === Product modal: mobile scroll fix ===
   Makes the popup itself the scroll area so the page behind no longer
   scrolls, and the Add-to-cart / Order buttons are always reachable. */
body.modal-open{overflow:hidden}                 /* lock background scroll */
@media(max-width:860px){
  .modal-scrim{
    align-items:flex-start;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;                 /* stop scroll "chaining" to the page */
    padding:16px;
  }
  .modal{
    grid-template-columns:1fr;
    max-height:none;                             /* let it grow; the overlay scrolls */
  }
  .modal-media{max-height:300px}
  .modal-info{
    overflow:visible;                            /* don't trap scrolling in this pane */
    padding:24px 22px 26px;
  }
}

/* === Mobile menu dropdown (hamburger) === */
.m-menu{position:fixed;top:70px;right:14px;width:min(320px,86vw);background:var(--paper);
  border:1.5px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);padding:8px;z-index:550;
  display:none;opacity:0;transform:translateY(-8px) scale(.98);transform-origin:top right;transition:.18s ease}
.m-menu.open{display:block;opacity:1;transform:none}
.m-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 14px;
  border-radius:11px;font-weight:600;font-size:.95rem;color:var(--ink);transition:.15s}
.m-item:hover,.m-item:active{background:var(--bone-2)}
.m-item .em{font-size:1.15rem;width:22px;text-align:center}
.m-sep{height:1px;background:var(--line);margin:6px 8px}
