/* Laser Lady Designs — shared design system */
:root{
  --ink:#1a1a1a; --ink-soft:#4a4446; --laser:#e11d2a; --laser-dark:#c01320;
  --blush:#f7d9e0; --blush-soft:#fdeef2; --rose:#f2b8c6; --cream:#fffdfb;
  --line:#efe2e6; --shadow:0 10px 34px rgba(180,120,135,.18); --radius:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Nunito Sans',system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.6;overflow-x:hidden}
h1,h2,h3{font-family:'Playfair Display',serif;font-weight:600;line-height:1.15}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.script{font-family:'Sacramento',cursive;color:var(--laser);font-weight:400}

/* announcement */
.announce{background:var(--ink);color:#fff;text-align:center;font-size:.84rem;letter-spacing:1.5px;text-transform:uppercase;padding:9px 12px}
.announce b{color:var(--rose)}

/* header */
header{position:sticky;top:0;z-index:40;background:rgba(255,253,251,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:10px 0}
.brand img{height:104px;width:auto}
nav.links{display:flex;gap:30px;font-weight:700;font-size:.96rem}
nav.links a{position:relative;padding:4px 0;transition:color .2s}
nav.links a:hover,nav.links a.active{color:var(--laser)}
nav.links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--laser);transition:width .25s}
nav.links a:hover::after,nav.links a.active::after{width:100%}
.actions{display:flex;align-items:center;gap:18px}
.icon-btn{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:.92rem;cursor:pointer;background:none;border:none;font-family:inherit;color:inherit}
.cart-dot{background:var(--laser);color:#fff;border-radius:999px;font-size:.72rem;padding:1px 7px;font-weight:800;min-width:20px;text-align:center}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:800;font-size:1rem;padding:14px 26px;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:transform .15s,box-shadow .2s,background .2s;font-family:inherit}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--laser);color:#fff;box-shadow:0 10px 24px rgba(225,29,42,.32)}
.btn-primary:hover{background:var(--laser-dark)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--ink)}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* page intro */
.page-head{background:radial-gradient(900px 360px at 85% -20%,var(--blush) 0%,transparent 60%),linear-gradient(180deg,var(--blush-soft),var(--cream));padding:48px 0 36px;border-bottom:1px solid var(--line)}
.page-head .script{font-size:2rem;display:block}
.page-head h1{font-size:2.6rem;margin-top:2px}
.page-head p{color:var(--ink-soft);margin-top:8px;max-width:560px}
.crumb{font-size:.85rem;color:var(--ink-soft);margin-bottom:8px}
.crumb a:hover{color:var(--laser)}

/* shop layout */
.shop{padding:34px 0 70px}
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px;align-items:center}
.filter{padding:9px 18px;border:1.5px solid var(--line);border-radius:999px;font-weight:700;font-size:.92rem;cursor:pointer;background:#fff;transition:.18s}
.filter:hover{border-color:var(--rose)}
.filter.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.count{margin-left:auto;color:var(--ink-soft);font-size:.9rem;font-weight:600}

.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px)}
.card .pic{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;position:relative}
.cat-keyrings .pic{background:linear-gradient(160deg,#fdeef2,#f7d9e0)}
.cat-gifts .pic{background:linear-gradient(160deg,#fbe6ec,#f2b8c6)}
.cat-letters .pic{background:linear-gradient(160deg,#f6f1ee,#ecd7dd)}
.cat-shapes .pic{background:linear-gradient(160deg,#fdeef2,#efd9e9)}
.tile{width:58%;aspect-ratio:1/1;border-radius:50%;background:linear-gradient(160deg,#fbe3ea,#f4bcca);box-shadow:inset 0 4px 18px rgba(0,0,0,.08),0 8px 20px rgba(180,120,135,.25);display:flex;align-items:center;justify-content:center;position:relative}
.tile::before{content:"";position:absolute;top:-13px;width:22px;height:22px;border:4px solid #d7a8b6;border-radius:50%}
.tile span{font-family:'Sacramento',cursive;font-size:1.7rem;color:var(--ink);text-align:center;line-height:1;padding:0 6px}
.shape-tile{border-radius:14px}
.badge{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;font-size:.66rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.badge.photo{background:var(--laser)}
.card .info{padding:15px 17px;display:flex;flex-direction:column;gap:4px;flex:1}
.card .info b{font-family:'Playfair Display',serif;font-size:1.04rem;line-height:1.25}
.stars{color:var(--laser);font-size:.82rem;letter-spacing:2px}
.card .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:10px}
.price{font-weight:800;font-size:1.1rem}
.mini{background:var(--ink);color:#fff;font-weight:800;font-size:.82rem;padding:9px 15px;border-radius:999px;cursor:pointer;border:none;font-family:inherit;transition:background .2s}
.mini:hover{background:var(--laser)}
.wish{position:absolute;bottom:10px;right:10px;z-index:3;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.05rem;line-height:1;color:#c9b3b9;box-shadow:0 2px 8px rgba(0,0,0,.08);transition:transform .12s}
.wish.on{color:var(--laser)}
.wish:hover{transform:scale(1.1)}

/* product page */
.pdp{padding:36px 0 70px}
.pdp-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.gallery{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:24px;position:sticky;top:130px}
.gallery .main{aspect-ratio:1/1;border-radius:18px;background:repeating-linear-gradient(45deg,var(--blush-soft) 0 14px,#fff 14px 28px);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.gallery .main .tile{width:50%}
.gallery .main img.preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:none}
.pdp h1{font-size:2.2rem;margin:4px 0 6px}
.pdp .price-lg{font-size:1.8rem;font-weight:800;color:var(--ink);margin:6px 0 4px}
.pdp .rating{color:var(--laser);font-weight:700;font-size:.92rem;margin-bottom:18px}
.pdp .desc{color:var(--ink-soft);margin-bottom:22px}
.opt{margin-bottom:20px}
.opt label{font-weight:800;font-size:.92rem;display:block;margin-bottom:8px}
.opt .req{color:var(--laser);font-size:.8rem;font-weight:700}
.opt input[type=text]{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:1rem}
.opt input[type=text]:focus{outline:none;border-color:var(--laser)}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{padding:8px 16px;border:1.5px solid var(--line);border-radius:999px;font-weight:700;font-size:.9rem;cursor:pointer;background:#fff;transition:.15s}
.chip.on{border-color:var(--laser);background:#fff0f1;color:var(--laser)}
.chip.script-chip{font-family:'Sacramento',cursive;font-size:1.25rem;padding:3px 18px}
.dropzone{border:2.5px dashed var(--rose);border-radius:16px;background:var(--blush-soft);padding:26px;text-align:center;cursor:pointer;transition:.2s}
.dropzone:hover{background:#fff;border-color:var(--laser)}
.dropzone.has{border-style:solid;border-color:var(--laser);background:#fff}
.dropzone svg{width:38px;height:38px;margin:0 auto 10px}
.dropzone b{display:block;font-size:1rem;margin-bottom:3px}
.dropzone small{color:var(--ink-soft)}
.upload-name{margin-top:10px;font-weight:700;color:var(--laser);font-size:.9rem;word-break:break-all}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;overflow:hidden}
.qty button{width:40px;height:42px;border:none;background:#fff;font-size:1.2rem;cursor:pointer;font-family:inherit}
.qty button:hover{background:var(--blush-soft)}
.qty input{width:44px;text-align:center;border:none;font-size:1rem;font-weight:800;font-family:inherit}
.addbar{display:flex;gap:14px;align-items:center;margin-top:8px}
.trust-line{display:flex;gap:18px;flex-wrap:wrap;margin-top:22px;color:var(--ink-soft);font-size:.86rem;font-weight:600}
.trust-line span{display:inline-flex;align-items:center;gap:6px}

/* cart drawer */
.drawer-mask{position:fixed;inset:0;background:rgba(26,26,26,.42);opacity:0;visibility:hidden;transition:.25s;z-index:60}
.drawer-mask.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:400px;max-width:92vw;background:var(--cream);box-shadow:-12px 0 40px rgba(0,0,0,.18);transform:translateX(100%);transition:transform .28s;z-index:61;display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer .dh{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.drawer .dh h3{font-size:1.3rem}
.drawer .close{background:none;border:none;font-size:1.6rem;cursor:pointer;line-height:1}
.drawer .items{flex:1;overflow-y:auto;padding:8px 22px}
.ci{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid var(--line)}
.ci .thumb{width:60px;height:60px;border-radius:12px;background:linear-gradient(160deg,#fbe3ea,#f4bcca);flex:none;display:flex;align-items:center;justify-content:center;font-family:'Sacramento',cursive;font-size:1rem}
.ci .meta{flex:1;font-size:.9rem}
.ci .meta b{display:block;font-family:'Playfair Display',serif;font-size:.98rem}
.ci .meta small{color:var(--ink-soft);display:block}
.ci .rm{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-size:.8rem;text-decoration:underline;padding:4px 0}
.ci .lineprice{font-weight:800}
.empty{text-align:center;color:var(--ink-soft);padding:50px 20px}
.drawer .df{padding:20px 22px;border-top:1px solid var(--line)}
.drawer .total{display:flex;justify-content:space-between;font-weight:800;font-size:1.15rem;margin-bottom:14px}
.note{font-size:.78rem;color:var(--ink-soft);text-align:center;margin-top:10px}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 22px;border-radius:999px;font-weight:700;opacity:0;visibility:hidden;transition:.25s;z-index:80;box-shadow:var(--shadow)}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* footer */
footer{background:var(--cream);border-top:1px solid var(--line);padding:50px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.foot-grid img{height:58px;margin-bottom:14px}
.foot-grid p{color:var(--ink-soft);font-size:.92rem;max-width:260px}
.foot-col b{font-family:'Playfair Display',serif;font-size:1.05rem;display:block;margin-bottom:14px}
.foot-col a{display:block;color:var(--ink-soft);padding:5px 0;font-size:.94rem}
.foot-col a:hover{color:var(--laser)}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);margin-top:36px;padding-top:20px;flex-wrap:wrap;gap:12px;color:var(--ink-soft);font-size:.86rem}
.pays{display:flex;gap:8px;flex-wrap:wrap}
.pays span{background:#fff;border:1px solid var(--line);border-radius:6px;padding:4px 9px;font-size:.72rem;font-weight:800}

.draft{display:none}
.draft b{color:var(--rose)}

@media(max-width:920px){
  .grid{grid-template-columns:1fr 1fr}
  .pdp-grid{grid-template-columns:1fr;gap:28px}
  .gallery{position:static}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav{flex-wrap:wrap}
  nav.links{order:3;width:100%;justify-content:center;flex-wrap:wrap;gap:10px 16px;font-size:.92rem;padding-bottom:6px}
  .brand img{height:74px}
}
@media(max-width:560px){
  .wrap{padding:0 16px}
  .grid{grid-template-columns:1fr 1fr;gap:14px}
  .foot-grid{grid-template-columns:1fr}
  .page-head h1{font-size:2rem}
  .page-head .script{font-size:1.7rem}
  .pdp h1{font-size:1.7rem}
  .addbar{flex-wrap:wrap}
  .trust-line{gap:12px}
  .card .foot{flex-direction:column;align-items:stretch;gap:8px}
  .card .mini{width:100%;text-align:center}
  .card .info{padding:13px 13px}
  .badge{font-size:.55rem;letter-spacing:.3px;padding:3px 7px;top:8px;left:8px}
}
