/* CicaLab virtual shopping simulation (wishlist, cart drawer, mock checkout).
   Explicitly a demo: no real sales, no real payment, no data leaves the page.
   Same design system as the site (sage-cream tokens, serif display, dark mode). */

/* ---------- header shop controls ---------- */
.shopctl{display:flex;align-items:center;gap:7px;flex:none}
.shop-hbtn{position:relative;width:38px;height:38px;display:grid;place-items:center;
  border:1px solid var(--line);color:var(--sub);background:transparent;
  transition:color .15s,border-color .15s}
.shop-hbtn:hover{color:var(--ink);border-color:var(--coral-ink)}
.shop-hbtn svg{width:17px;height:17px;fill:none;stroke:currentColor;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.shop-hbtn.on svg .hfill{fill:var(--coral-ink);stroke:var(--coral-ink)}
.shop-cnt{position:absolute;top:-7px;right:-7px;min-width:17px;height:17px;padding:0 4px;
  border-radius:99px;background:var(--coral-ink);color:#F7F6EC;font-size:.58rem;
  font-weight:800;line-height:17px;text-align:center;display:none;
  font-variant-numeric:tabular-nums}
.shop-cnt.show{display:block}
@keyframes shopPop{0%{transform:scale(.55)}55%{transform:scale(1.3)}100%{transform:scale(1)}}
.shop-cnt.pop{animation:shopPop .35s ease}
@media (pointer:coarse),(max-width:900px){.shop-hbtn{width:44px;height:44px}}
/* keep brand + shop icons + hamburger on one row, controls below */
@media (max-width:760px){
  .hdr-in{flex-wrap:wrap;row-gap:8px}
  .hdr-in .brand{order:1}
  .shopctl{order:2;margin-left:auto}
  .hdr-in .hamb{order:3;margin-left:10px}
  .hdr-in .ctrl{order:4;width:100%;justify-content:flex-start;flex-wrap:wrap}
}
@media (max-width:480px){
  .hdr-in .brand-tag{display:none}
}

/* ---------- wish heart on product figures ---------- */
.wish-fab{position:absolute;top:12px;right:12px;z-index:3;width:40px;height:40px;
  border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);
  color:var(--sage-deep);background:color-mix(in srgb,var(--cream) 86%,transparent);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  transition:color .15s,border-color .15s,transform .15s}
html[data-theme=dark] .wish-fab{color:#243A2D}
.wish-fab:hover{border-color:var(--coral-ink);transform:scale(1.06)}
.wish-fab svg{width:18px;height:18px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.wish-fab.on{border-color:var(--coral-ink)}
.wish-fab.on svg .hfill{fill:var(--coral-ink);stroke:var(--coral-ink)}
@keyframes wishBeat{0%{transform:scale(1)}35%{transform:scale(1.28)}100%{transform:scale(1)}}
.wish-fab.beat svg{animation:wishBeat .4s ease}
@media (pointer:coarse){.wish-fab{width:44px;height:44px}}

/* ---------- add-to-cart buttons ---------- */
.card-shoprow{display:flex;gap:8px;margin-top:14px}
.detail-shoprow{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap;align-items:stretch}
.addcart{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:46px;padding:11px 22px;border:1px solid var(--sage-deep);
  background:var(--sage-deep);color:#F3F4E7;font-size:.68rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;
  transition:background .2s,color .2s}
.addcart:hover{background:transparent;color:var(--sage-deep)}
html[data-theme=dark] .addcart{border-color:var(--sage);background:var(--sage);color:#18211B}
html[data-theme=dark] .addcart:hover{background:transparent;color:var(--sage)}
.card-shoprow .addcart{flex:1}
.addcart svg{width:15px;height:15px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex:none}
.addcart .ac-done{display:none;align-items:center;gap:9px}
.addcart.is-added .ac-lab,.addcart.is-added>svg{display:none}
.addcart.is-added .ac-done{display:inline-flex}
.addcart.is-added{background:var(--coral-ink);border-color:var(--coral-ink);color:#F7F6EC}
html[data-theme=dark] .addcart.is-added{background:var(--coral-ink);border-color:var(--coral-ink);color:#26140E}
.wish-side{width:46px;min-height:46px;display:grid;place-items:center;flex:none;
  border:1px solid var(--line);color:var(--sage-deep);background:var(--panel);
  transition:border-color .15s,transform .15s}
html[data-theme=dark] .wish-side{color:var(--sage)}
.wish-side:hover{border-color:var(--coral-ink);transform:scale(1.04)}
.wish-side svg{width:18px;height:18px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.wish-side.on{border-color:var(--coral-ink)}
.wish-side.on svg .hfill{fill:var(--coral-ink);stroke:var(--coral-ink)}
.wish-side.beat svg{animation:wishBeat .4s ease}

/* ---------- simulation strip (always visible on cart and checkout) ---------- */
.sim-strip{display:flex;align-items:center;gap:8px;padding:10px 18px;
  background:color-mix(in srgb,var(--coral) 14%,transparent);color:var(--coral-ink);
  font-size:.6rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  border-bottom:1px solid color-mix(in srgb,var(--coral-ink) 35%,transparent);flex:none}
.sim-strip::before{content:"";width:6px;height:6px;border-radius:50%;
  background:var(--coral-ink);flex:none}

/* ---------- cart drawer ---------- */
.shop-ovl{position:fixed;inset:0;z-index:200;background:rgba(20,28,22,.46);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility 0s .3s}
.shop-ovl.open{opacity:1;visibility:visible;transition:opacity .3s,visibility 0s}
.shop-drawer{position:fixed;top:0;right:0;bottom:0;z-index:210;width:min(432px,94vw);
  background:var(--bg);border-left:1px solid var(--line-strong);
  display:flex;flex-direction:column;transform:translateX(103%);visibility:hidden;
  transition:transform .45s cubic-bezier(.22,.9,.32,1),visibility 0s .45s}
.shop-drawer.open{transform:none;visibility:visible;
  transition:transform .45s cubic-bezier(.22,.9,.32,1),visibility 0s}
.shop-tabs{display:flex;align-items:stretch;border-bottom:1px solid var(--line-strong);flex:none}
.shop-tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 8px;font-size:.7rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--sub);border-bottom:2px solid transparent;
  transition:color .15s,border-color .15s}
.shop-tab[aria-selected="true"]{color:var(--ink);border-bottom-color:var(--coral-ink)}
.shop-tab i{min-width:19px;height:19px;padding:0 5px;border-radius:99px;line-height:19px;
  font-size:.6rem;font-weight:800;background:var(--bg2);color:var(--sub);
  border:1px solid var(--line);font-variant-numeric:tabular-nums}
.shop-tab[aria-selected="true"] i{background:var(--coral-ink);color:#F7F6EC;border-color:var(--coral-ink)}
.shop-x{flex:none;width:52px;display:grid;place-items:center;color:var(--sub);
  border-left:1px solid var(--line);transition:color .15s}
.shop-x:hover{color:var(--ink)}
.shop-x svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
.shop-body{flex:1;overflow-y:auto;padding:18px clamp(16px,4vw,24px);overscroll-behavior:contain}
.cart-list,.wish-list{list-style:none;display:flex;flex-direction:column}
.citem,.witem{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);
  align-items:flex-start}
.citem img,.witem img{width:64px;height:80px;object-fit:cover;flex:none;background:var(--bg2);
  border:1px solid var(--line)}
.ci-main{flex:1;min-width:0}
.ci-name{display:block;font-family:var(--f-disp);font-weight:500;font-size:.98rem;
  line-height:1.4;color:var(--ink);border-bottom:1px solid transparent;
  transition:border-color .15s}
.ci-name:hover{border-color:var(--coral-ink)}
.ci-price{display:block;margin-top:4px;font-size:.78rem;color:var(--sub);
  font-variant-numeric:tabular-nums}
.ci-price i{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--faint);margin-left:7px;font-weight:700}
.ci-row{display:flex;align-items:center;gap:12px;margin-top:11px;flex-wrap:wrap}
.ci-qty{display:inline-flex;align-items:center;border:1px solid var(--line);background:var(--panel)}
.ci-qty button{width:34px;height:34px;display:grid;place-items:center;color:var(--sub);
  font-size:.95rem;font-weight:700;line-height:1;transition:color .15s,background .15s}
.ci-qty button:hover{color:var(--ink);background:var(--bg2)}
.ci-qty button:disabled{opacity:.35;cursor:default}
.ci-qty button:disabled:hover{color:var(--sub);background:transparent}
.ci-qty b{min-width:30px;text-align:center;font-size:.85rem;font-weight:700;
  font-variant-numeric:tabular-nums}
.ci-rm{font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--faint);border-bottom:1px solid transparent;padding:8px 2px;
  transition:color .15s,border-color .15s}
.ci-rm:hover{color:var(--coral-ink);border-color:var(--coral-ink)}
.ci-line{flex:none;font-family:var(--f-disp);font-size:.92rem;font-weight:500;
  font-variant-numeric:tabular-nums;margin-top:2px}
.wi-add{margin-top:10px;display:inline-flex;align-items:center;gap:7px;min-height:36px;
  padding:7px 14px;border:1px solid var(--sage-deep);color:var(--sage-deep);
  font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  transition:background .2s,color .2s}
.wi-add svg{width:14px;height:14px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex:none}
.wi-add:hover{background:var(--sage-deep);color:#F3F4E7}
html[data-theme=dark] .wi-add{border-color:var(--sage);color:var(--sage)}
html[data-theme=dark] .wi-add:hover{background:var(--sage);color:#18211B}
.shop-empty{padding:44px 8px;text-align:center;color:var(--sub);font-size:.88rem}
.shop-empty .browse{display:inline-flex;align-items:center;gap:9px;margin-top:16px;
  font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--coral-ink);border-bottom:1px solid var(--coral-ink);padding-bottom:3px}
.shop-empty .browse::after{content:"\2192"}
.cart-foot{flex:none;border-top:1px solid var(--line-strong);
  padding:16px clamp(16px,4vw,24px) calc(18px + env(safe-area-inset-bottom));
  background:var(--panel)}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.cart-total span{font-size:.66rem;font-weight:800;letter-spacing:.18em;
  text-transform:uppercase;color:var(--sub)}
.cart-total b{font-family:var(--f-disp);font-weight:500;font-size:1.35rem;
  font-variant-numeric:tabular-nums}
.cart-note{margin-top:8px;font-size:.7rem;color:var(--faint);line-height:1.6}
.ck-open{width:100%;margin-top:14px;min-height:50px;display:inline-flex;align-items:center;
  justify-content:center;gap:10px;border:1px solid var(--ink);background:var(--ink);
  color:var(--bg);font-size:.72rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;transition:background .2s,color .2s}
.ck-open:hover{background:transparent;color:var(--ink)}
.ck-open:disabled{opacity:.35;cursor:default}
.ck-open:disabled:hover{background:var(--ink);color:var(--bg)}

/* ---------- checkout modal ---------- */
.ck-modal{position:fixed;inset:0;z-index:220;display:grid;place-items:center;
  padding:clamp(10px,3vw,28px);background:rgba(20,28,22,.5);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility 0s .3s}
.ck-modal.open{opacity:1;visibility:visible;transition:opacity .3s,visibility 0s}
.ck-panel{width:min(580px,100%);max-height:min(92vh,880px);overflow-y:auto;
  overscroll-behavior:contain;background:var(--bg);border:1px solid var(--line-strong);
  display:flex;flex-direction:column}
.ck-head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px clamp(18px,4vw,28px);border-bottom:1px solid var(--line)}
.ck-head h3{font-family:var(--f-disp);font-weight:500;font-size:1.25rem;letter-spacing:.02em}
.ck-sec{padding:18px clamp(18px,4vw,28px);border-bottom:1px solid var(--line)}
.ck-sec:last-child{border-bottom:0}
.ck-lab{display:block;font-size:.64rem;font-weight:800;letter-spacing:.2em;
  text-transform:uppercase;color:var(--sage);margin-bottom:12px}
.ck-sum{list-style:none;display:flex;flex-direction:column;gap:9px}
.ck-sum li{display:flex;justify-content:space-between;gap:14px;font-size:.86rem;color:var(--sub)}
.ck-sum li b{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}
.ck-sum-total{display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  margin-top:13px;padding-top:13px;border-top:1px dashed var(--line)}
.ck-sum-total span{font-size:.64rem;font-weight:800;letter-spacing:.18em;
  text-transform:uppercase;color:var(--sub)}
.ck-sum-total b{font-family:var(--f-disp);font-weight:500;font-size:1.2rem;
  font-variant-numeric:tabular-nums}
.ck-privacy{margin:0 0 14px;padding:11px 14px;font-size:.72rem;line-height:1.65;
  color:var(--sub);border:1px solid color-mix(in srgb,var(--coral-ink) 38%,transparent);
  background:color-mix(in srgb,var(--coral) 9%,transparent)}
.ck-privacy b{color:var(--coral-ink)}
.ck-field{display:block;margin-top:10px}
.ck-field span{display:block;font-size:.66rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--sub);margin-bottom:5px}
.ck-field input{width:100%;border:1px solid var(--line);background:var(--panel);
  color:var(--ink);font-family:inherit;font-size:.88rem;padding:11px 13px;outline:none;
  transition:border-color .15s}
.ck-field input:focus{border-color:var(--coral-ink)}
.ck-field input::placeholder{color:var(--faint)}
.ck-pays{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ck-pay{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;
  border:1px solid var(--line);background:var(--panel);font-size:.82rem;font-weight:600;
  transition:border-color .15s}
.ck-pay:hover{border-color:var(--coral-ink)}
.ck-pay input{accent-color:var(--coral-ink);width:15px;height:15px;flex:none}
.ck-pay:has(input:checked){border-color:var(--coral-ink);
  background:color-mix(in srgb,var(--coral) 10%,transparent)}
.ck-paybtn{width:100%;margin-top:18px;min-height:52px;display:inline-flex;align-items:center;
  justify-content:center;gap:10px;border:1px solid var(--ink);background:var(--ink);
  color:var(--bg);font-size:.74rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;transition:background .2s,color .2s}
.ck-paybtn:hover{background:transparent;color:var(--ink)}
.ck-state{padding:56px clamp(18px,4vw,28px);text-align:center}
.ck-spin{width:40px;height:40px;margin:0 auto;border-radius:50%;
  border:2px solid var(--line);border-top-color:var(--coral-ink);
  animation:ckSpin .8s linear infinite}
@keyframes ckSpin{to{transform:rotate(360deg)}}
.ck-state p{margin-top:18px;color:var(--sub);font-size:.9rem}
.ck-done-ic{width:56px;height:56px;margin:0 auto;border-radius:50%;
  border:1px solid var(--sage-deep);color:var(--sage-deep);display:grid;place-items:center}
html[data-theme=dark] .ck-done-ic{border-color:var(--sage);color:var(--sage)}
.ck-done-ic svg{width:24px;height:24px;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ck-done-t{font-family:var(--f-disp);font-weight:500;font-size:1.5rem;margin-top:18px}
.ck-done-no{margin-top:10px;font-size:.8rem;color:var(--sub);letter-spacing:.04em}
.ck-done-no b{font-family:var(--f-disp);font-size:1rem;color:var(--ink);
  letter-spacing:.1em;margin-left:8px}
.ck-done-notice{margin:16px auto 0;max-width:400px;padding:12px 16px;font-size:.78rem;
  line-height:1.7;color:var(--sub);text-align:left;
  border:1px solid color-mix(in srgb,var(--coral-ink) 38%,transparent);
  background:color-mix(in srgb,var(--coral) 9%,transparent)}
.ck-done-notice b{color:var(--coral-ink)}
.ck-done-btns{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:22px}
.ck-done-btns a,.ck-done-btns button{display:inline-flex;align-items:center;justify-content:center;
  min-height:46px;padding:11px 20px;border:1px solid var(--line-strong);color:var(--ink);
  font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  transition:background .2s,color .2s}
.ck-done-btns a:hover,.ck-done-btns button:hover{background:var(--ink);color:var(--bg)}
.ck-done-btns a.solid{background:var(--ink);color:var(--bg)}
.ck-done-btns a.solid:hover{background:transparent;color:var(--ink)}
@media (max-width:640px){
  .ck-modal{padding:0;place-items:stretch}
  .ck-panel{width:100%;max-height:none;height:100%}
  .ck-pays{grid-template-columns:1fr}
}

/* ---------- toast ---------- */
.shop-toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);z-index:230;
  background:var(--sage-deep);color:#F3F4E7;font-size:.8rem;font-weight:600;
  padding:11px 22px;border:1px solid rgba(243,244,231,.3);opacity:0;pointer-events:none;
  transition:opacity .25s,transform .25s;max-width:92vw;text-align:center}
.shop-toast.show{opacity:1;transform:translate(-50%,0)}
