/* SN Sticker Sheet Designer */
.snss-app{--l:#e3e9f0;--ink:#1a2534;--mut:#67788c;--ac:#0aa3c2;--ac2:#0876a8;max-width:1000px;margin:0 auto 26px;font-family:inherit;color:var(--ink)}
.snss-app *{box-sizing:border-box}
.snss-head{text-align:center;margin:0 0 14px}
.snss-head h2{margin:0 0 4px;font-size:1.7rem;font-weight:800}
.snss-head p{margin:0;color:var(--mut);font-size:.95rem}
.snss-bar,.snss-textbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:#f6f9fc;border:1px solid var(--l);border-radius:12px;padding:9px 12px;margin:0 0 12px}
.snss-seg{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--mut)}
.snss-sp{flex:1}
.snss-price{font-size:1.15rem;font-weight:800;color:#0a8a4f}
.snss-warn{color:#c47f00;font-size:.8rem;display:none}
.snss-btn{background:#fff;border:1px solid var(--l);border-radius:9px;padding:9px 13px;font-weight:650;font-size:.86rem;cursor:pointer;color:var(--ink);line-height:1}
.snss-btn:hover{border-color:var(--ac)}
.snss-btn.pri{background:linear-gradient(135deg,var(--ac),var(--ac2));border:0;color:#fff}
.snss-btn.lg{padding:12px 22px;font-size:1rem;font-weight:800}
.snss-app select,.snss-app input[type=number]{border:1px solid var(--l);border-radius:7px;padding:6px 8px;font-size:.85rem;background:#fff}
.snss-app input[type=number]{width:64px}
.snss-app input[type=color]{width:30px;height:26px;border:1px solid var(--l);border-radius:6px;padding:0;background:none;cursor:pointer}
.snss-stage{position:relative;display:flex;align-items:center;justify-content:center;background:#eef3f8 repeating-conic-gradient(#e7edf4 0 25%,transparent 0 50%) 0 0/26px 26px;border:1px solid var(--l);border-radius:14px;padding:22px;min-height:360px}
.snss-stage canvas{max-width:100%;box-shadow:0 18px 50px -22px rgba(20,40,70,.5);border-radius:4px}
.snss-empty{position:absolute;background:linear-gradient(135deg,var(--ac),var(--ac2));color:#fff;border:0;border-radius:999px;padding:16px 30px;font-size:1.05rem;font-weight:800;cursor:pointer;box-shadow:0 14px 30px -12px rgba(10,120,168,.7)}
.snss-tray{display:flex;gap:8px;padding:10px;overflow-x:auto;min-height:72px;align-items:center;background:#f6f9fc;border:1px solid var(--l);border-radius:12px;margin-top:12px}
.snss-tray-empty{color:var(--mut);font-size:.82rem}
.snss-thumb{width:54px;height:54px;flex:0 0 54px;border:1px solid var(--l);border-radius:8px;padding:2px;cursor:pointer;object-fit:contain;background:#fff}
.snss-thumb:hover{border-color:var(--ac)}
/* modal */
.snss-modal{position:fixed;inset:0;background:rgba:(10,20,35,.55);background:rgba(10,20,35,.55);display:flex;align-items:center;justify-content:center;z-index:99999;padding:16px}
.snss-modal-box{background:#fff;border-radius:16px;width:380px;max-width:100%;max-height:92vh;overflow:auto;box-shadow:0 30px 80px -20px #000}
.snss-modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--l)}
.snss-modal-head b{font-size:1.05rem}
.snss-x{background:none;border:0;font-size:18px;cursor:pointer;color:var(--mut)}
.snss-modal-body{padding:16px 18px}
.snss-drop{border:2px dashed var(--l);border-radius:10px;padding:20px;text-align:center;color:var(--mut);cursor:pointer}
.snss-drop:hover,.snss-drop.hot{border-color:var(--ac);color:var(--ink);background:#f0fbff}
.snss-drop span{font-size:11px}
.snss-tools{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}
.snss-modes{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin:6px 0}
.snss-mode{border:1px solid var(--l);background:#fff;border-radius:8px;padding:7px 2px;text-align:center;font-size:15px;cursor:pointer;line-height:1.1}
.snss-mode.on{border-color:var(--ac);background:#eafaff;box-shadow:0 0 0 1px var(--ac) inset}
.snss-mode small{display:block;font-size:9px;color:var(--mut);margin-top:2px}
.snss-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;margin:8px 0 2px}
.snss-row b{color:var(--ac)}
.snss-modal input[type=range]{width:100%}
.snss-prev{background:repeating-conic-gradient(#eef3f8 0 25%,#fff 0 50%) 0 0/18px 18px;border:1px solid var(--l);border-radius:10px;display:flex;align-items:center;justify-content:center;min-height:170px;margin:10px 0}
.snss-pv{max-width:100%;max-height:210px}
/* marketing */
.snss-info{max-width:1000px;margin:26px auto 0}
.snss-info h2{font-size:1.4rem;font-weight:800;margin:22px 0 12px}
.snss-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.snss-steps>div{background:#f6f9fc;border:1px solid var(--l);border-radius:12px;padding:18px}
.snss-steps span{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:#0aa3c2;color:#fff;font-weight:800;margin-bottom:8px}
.snss-steps b{display:block;margin-bottom:4px}
.snss-steps p{margin:0;color:#67788c;font-size:.9rem}
.snss-specs{list-style:none;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.snss-specs li{background:#f6f9fc;border:1px solid #e3e9f0;border-radius:10px;padding:12px 14px;font-size:.92rem}
@media(max-width:700px){.snss-steps,.snss-specs{grid-template-columns:1fr}}
/* on designer products, quieten the theme's default gallery/price duplication if present */
body.snss-on .woocommerce-product-gallery{opacity:.9}

/* ---- footer price summary (sticky) ---- */
.snss-footer{position:sticky;bottom:0;z-index:6;display:flex;flex-wrap:wrap;align-items:center;gap:16px;background:#fff;border:1px solid var(--l);border-radius:14px;box-shadow:0 -8px 30px -18px rgba(20,40,70,.4);padding:12px 16px;margin-top:12px}
.snss-fseg{display:flex;flex-direction:column;gap:3px}
.snss-flabel{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mut);font-weight:700}
.snss-fseg .snss-turntxt{font-size:.86rem;font-weight:600;color:var(--ink)}
.snss-orient{display:inline-flex;border:1px solid var(--l);border-radius:8px;overflow:hidden}
.snss-obtn{background:#fff;border:0;padding:7px 12px;font-size:.82rem;font-weight:650;cursor:pointer;color:var(--mut)}
.snss-obtn.on{background:var(--ac);color:#fff}
.snss-footer .snss-qty{width:70px}
.snss-fsp{flex:1}
.snss-ftotal{text-align:right}.snss-ftotal .snss-price{font-size:1.5rem;font-weight:800;color:#0a8a4f;display:block}
@media(max-width:640px){.snss-footer{gap:10px}.snss-fsp{flex-basis:100%}}

/* ---- SEO content ---- */
.snss-seo{max-width:1000px;margin:28px auto 0;color:var(--ink)}
.snss-seo section{margin:0 0 40px}
.snss-seo h2{font-size:1.5rem;font-weight:800;margin:0 0 14px}
.snss-seo-hero{display:flex;gap:28px;align-items:center;background:linear-gradient(135deg,#eef8fc,#f4fbff);border:1px solid var(--l);border-radius:20px;padding:28px}
.snss-seo-hero-text{flex:1}
.snss-seo-hero-text h2{font-size:2rem;max-width:18ch}
.snss-seo-hero-text p{color:#33475f;font-size:1.08rem;line-height:1.6;max-width:60ch}
.snss-seo-hero-img{flex:0 0 300px;max-width:44%}
.snss-seo-hero-img img{width:100%;border-radius:14px;box-shadow:0 18px 40px -18px rgba(20,40,70,.5)}
.snss-seo-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.snss-seo-badges span{background:#fff;border:1px solid var(--l);border-radius:999px;padding:7px 13px;font-size:.82rem;font-weight:700}
.snss-seo-story{background:#fbfdff;border:1px solid var(--l);border-left:5px solid #ff7a59;border-radius:16px;padding:26px 30px}
.snss-seo-cols{column-count:2;column-gap:40px}
.snss-seo-cols p{margin:0 0 12px;color:#33475f;line-height:1.7;break-inside:avoid}
.snss-seo-uses{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.snss-seo-uses>div{display:flex;align-items:center;gap:10px;background:#f6f9fc;border:1px solid var(--l);border-radius:12px;padding:14px;font-size:1.3rem}
.snss-seo-uses b{font-size:.92rem;font-weight:650}
.snss-seo-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.snss-seo-cards>div{background:#fff;border:1px solid var(--l);border-radius:16px;padding:20px;box-shadow:0 3px 14px rgba(20,40,70,.05)}
.snss-seo-cards .i{width:46px;height:46px;border-radius:12px;background:#eaf6fb;display:grid;place-items:center;font-size:22px;margin-bottom:10px}
.snss-seo-cards h3{margin:0 0 5px;font-size:1.04rem;font-weight:800}
.snss-seo-cards p{margin:0;color:var(--mut);font-size:.92rem;line-height:1.55}
.snss-seo-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:s}
.snss-seo-steps>div{position:relative;background:#f6f9fc;border:1px solid var(--l);border-radius:14px;padding:22px 16px 16px}
.snss-seo-steps>div::before{counter-increment:s;content:counter(s);position:absolute;top:-14px;left:16px;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0aa3c2,#0876a8);color:#fff;font-weight:800;display:grid;place-items:center}
.snss-seo-steps b{display:block;margin:6px 0 3px}
.snss-seo-steps span{color:var(--mut);font-size:.88rem}
.snss-seo-sizes{background:#f6f9fc;border:1px solid var(--l);border-radius:14px;padding:20px 24px}
.snss-seo-sizes h2{margin-bottom:6px}
.snss-seo-faq details{border:1px solid var(--l);border-radius:12px;margin-bottom:10px;background:#fff;overflow:hidden}
.snss-seo-faq summary{list-style:none;cursor:pointer;padding:15px 18px;font-weight:700;display:flex;justify-content:space-between;gap:14px}
.snss-seo-faq summary::-webkit-details-marker{display:none}
.snss-seo-faq summary span{flex:0 0 24px;height:24px;border-radius:50%;background:#eaf6fb;color:#0876a8;display:grid;place-items:center;font-weight:800;transition:transform .2s}
.snss-seo-faq details[open] summary span{transform:rotate(45deg);background:#0aa3c2;color:#fff}
.snss-seo-faq div>div,.snss-seo-faq .a{padding:0 18px 16px;color:var(--mut);line-height:1.6}
.snss-seo-faq details>div{padding:0 18px 16px;color:var(--mut);line-height:1.6}
.snss-seo-trust{background:#f6f9fc;border:1px solid var(--l);border-radius:16px;padding:24px;text-align:center}
.snss-seo-trust p{margin:6px auto 0;max-width:60ch;color:var(--mut)}
@media(max-width:820px){.snss-seo-hero{flex-direction:column-reverse}.snss-seo-hero-img{max-width:100%;flex-basis:auto}.snss-seo-uses{grid-template-columns:repeat(2,1fr)}.snss-seo-steps{grid-template-columns:repeat(2,1fr)}.snss-seo-cols{column-count:1}}

/* ---- colour trigger button + swatch ---- */
.snss-cbtn{width:34px;height:28px;border:1px solid var(--l);border-radius:7px;background:#fff;padding:3px;cursor:pointer;vertical-align:middle}
.snss-cbtn:hover{border-color:var(--ac)}
.snss-csw{display:block;width:100%;height:100%;border-radius:4px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}

/* ---- WYSIWYG font picker ---- */
.snss-fontpick{position:relative;display:inline-block}
.snss-fontbtn{min-width:150px;text-align:left;border:1px solid var(--l);border-radius:7px;background:#fff;padding:6px 10px;font-size:.9rem;cursor:pointer;color:var(--ink)}
.snss-fontbtn:hover{border-color:var(--ac)}
.snss-fontbtn i{float:right;font-style:normal;color:var(--mut);font-family:system-ui,sans-serif}
.snss-fontlist{display:none;position:absolute;top:calc(100% + 4px);left:0;z-index:1000;width:230px;max-height:300px;overflow-y:auto;background:#fff;border:1px solid var(--l);border-radius:10px;box-shadow:0 20px 50px -18px rgba(20,40,70,.5);padding:5px}
.snss-fontpick.open .snss-fontlist{display:block}
.snss-fontopt{padding:8px 11px;border-radius:7px;font-size:1.18rem;line-height:1.15;cursor:pointer;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.snss-fontopt:hover{background:#eafaff}

/* ---- colour-wheel popover ---- */
.snss-cpick{width:214px;background:#fff;border:1px solid var(--l);border-radius:14px;box-shadow:0 30px 80px -20px rgba(10,20,35,.6);padding:14px;z-index:100000}
.snss-cpv{height:26px;border-radius:8px;margin-bottom:12px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1)}
.snss-cwrap{position:relative;width:150px;height:150px;margin:0 auto 12px}
.snss-cwheel{border-radius:50%;cursor:crosshair;touch-action:none;display:block}
.snss-cmark{position:absolute;width:14px;height:14px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.5),0 1px 4px rgba(0,0,0,.5);transform:translate(-50%,-50%);pointer-events:none}
.snss-crow{display:flex;align-items:center;gap:8px;margin:8px 0}
.snss-crow span{width:26px;font-size:.74rem;color:var(--mut);font-weight:700}
.snss-crow input[type=range]{flex:1}
.snss-chex{flex:1;border:1px solid var(--l);border-radius:6px;padding:5px 7px;font-family:monospace;font-size:.85rem;text-transform:lowercase}
.snss-cswatches{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;margin:10px 0}
.snss-cswatch{width:100%;aspect-ratio:1;border:1px solid rgba(0,0,0,.12);border-radius:5px;cursor:pointer;padding:0}
.snss-cswatch:hover{transform:scale(1.12)}
.snss-cpick .snss-cdone{width:100%;margin-top:4px}

/* ---- shared palette for sections rendered outside #snss-app (hero, specs, seo) ---- */
body.snss-on{--l:#e3e9f0;--ink:#1a2534;--mut:#67788c;--ac:#0aa3c2;--ac2:#0876a8}
/* hide the stock WooCommerce summary (title/price/short-desc) but keep the cart form submittable */
body.snss-on .entry-summary{position:absolute!important;left:-9999px;top:0;width:1px;height:1px;overflow:hidden;padding:0!important;margin:0!important}

/* ---- title + lead hero (school-labels style) ---- */
.snss-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#eaf4ff 0%,#f3f9ff 55%,#fff6ee 100%);border:1px solid var(--l);border-radius:22px;padding:34px 32px;margin:0 auto 24px;max-width:1000px}
.snss-hero__media{position:absolute;top:0;right:0;bottom:0;width:52%;background-size:cover;background-position:center right;-webkit-mask-image:linear-gradient(to right,transparent,#000 45%);mask-image:linear-gradient(to right,transparent,#000 45%);z-index:1;pointer-events:none}
.snss-hero__body{position:relative;z-index:2;max-width:62%}
.snss-hero h1{font-size:2.4rem;line-height:1.08;margin:0 0 12px;font-weight:800;color:var(--ink)}
.snss-hero p{color:#33475f;max-width:58ch;margin:0 0 18px;font-size:1.12rem;line-height:1.55}
.snss-hero__badges{display:flex;flex-wrap:wrap;gap:8px}
.snss-hero__badges span{background:#fff;border:1px solid var(--l);border-radius:999px;padding:7px 13px;font-size:.82rem;font-weight:700}
@media(max-width:720px){.snss-hero__body{max-width:100%}.snss-hero__media{display:none}.snss-hero h1{font-size:1.7rem}}

/* ---- specs strip ---- */
.snss-seo-specs{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.snss-seo-specs>div{background:#f6f9fc;border:1px solid var(--l);border-radius:12px;padding:16px 12px;text-align:center}
.snss-seo-specs .ic{font-size:22px;margin-bottom:6px}
.snss-seo-specs b{display:block;font-size:1rem;color:var(--ink)}
.snss-seo-specs span{font-size:.76rem;color:var(--mut);line-height:1.25;display:block}
@media(max-width:820px){.snss-seo-specs{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.snss-seo-specs{grid-template-columns:repeat(2,1fr)}}

/* ---- pack price grid ---- */
.snss-seo-sub{color:var(--mut);margin:0 0 6px}
.snss-pricegrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-top:14px}
.snss-pricecard{background:#fff;border:1px solid var(--l);border-radius:14px;padding:16px 18px}
.snss-pricecard__h{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--l);padding-bottom:8px;margin-bottom:8px}
.snss-pricecard__h b{font-size:1.2rem;color:var(--ink)}
.snss-pricecard__h span{font-size:.78rem;color:var(--mut)}
.snss-pricecard ul{list-style:none;margin:0;padding:0}
.snss-pricecard li{display:flex;justify-content:space-between;padding:5px 0;font-size:.92rem}
.snss-pricecard li span{color:var(--mut)}
.snss-pricecard li b{color:#0a8a4f}

/* ---- zoom control ---- */
.snss-zoom{display:inline-flex;align-items:center;gap:4px;margin-left:auto}
.snss-zbtn{border:1px solid var(--l);background:#fff;border-radius:7px;width:28px;height:28px;font-size:1rem;line-height:1;cursor:pointer;color:var(--ink);display:inline-grid;place-items:center;padding:0}
.snss-zbtn:hover{border-color:var(--ac)}
.snss-zlvl{min-width:46px;text-align:center;font-size:.8rem;color:var(--mut);font-weight:700}

/* ---- measurements caption ---- */
.snss-dimcap{text-align:center;color:var(--mut);font-size:.88rem;margin:0 0 8px}
.snss-dimcap b{color:var(--ink);font-weight:700}

/* ---- stage: scroll wrapper + zoomable canvas ---- */
.snss-stage{position:relative}
.snss-scroll{max-width:100%;max-height:78vh;overflow:auto;display:flex;align-items:safe center;justify-content:safe center}
.snss-scroll canvas,.snss-scroll .canvas-container{max-width:none!important}
.snss-empty{top:50%;left:50%;transform:translate(-50%,-50%)}

/* ---- text format bar as an overlay (doesn't push the stage down) ---- */
.snss-stage .snss-textbar{position:absolute;top:8px;left:8px;right:8px;z-index:30;margin:0;box-shadow:0 10px 28px -12px rgba(20,40,70,.55)}

/* ---- watermarked preview modal ---- */
.snss-pvmodal{position:fixed;inset:0;background:rgba(10,20,35,.6);display:flex;align-items:center;justify-content:center;z-index:100000;padding:20px}
.snss-pvbox{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px -20px #000}
.snss-pvbody{padding:16px 18px;overflow:auto}
.snss-pvstage{background:repeating-conic-gradient(#eef3f8 0 25%,#fff 0 50%) 0 0/22px 22px;border:1px solid var(--l);border-radius:10px;padding:14px;display:flex;justify-content:center}
.snss-pvimg{max-width:100%;max-height:62vh;box-shadow:0 10px 30px -12px rgba(20,40,70,.5)}
.snss-pvnote{color:var(--mut);font-size:.85rem;margin:12px 0;text-align:center}
.snss-pvbody .snss-btn.lg{width:100%}

/* ---- overlap warning as a stage overlay (doesn't reflow the layout) ---- */
.snss-stage .snss-warn{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);z-index:40;display:none;align-items:center;gap:6px;background:#fff4e0;border:1px solid #f0c674;color:#8a5a00;padding:8px 15px;border-radius:999px;font-size:.82rem;font-weight:700;box-shadow:0 10px 28px -12px rgba(0,0,0,.4);max-width:calc(100% - 24px);text-align:center}
/* disabled add-to-basket when stickers are too close */
.snss-btn[disabled],.snss-btn.is-off{opacity:.45;cursor:not-allowed;filter:grayscale(.3)}
.snss-surnote{display:block;font-size:.7rem;color:var(--mut);font-weight:600;margin-top:1px}

/* ---- proof approval ---- */
.snss-approve{display:flex;gap:10px;align-items:flex-start;background:#f6f9fc;border:1px solid var(--l);border-radius:10px;padding:12px 14px;margin:4px 0 12px;font-size:.86rem;line-height:1.45;color:var(--ink);cursor:pointer;text-align:left}
.snss-approve input{margin-top:2px;flex:0 0 auto;width:18px;height:18px;cursor:pointer}

/* ---- guide legend in the measurements caption ---- */
.snss-legend{display:inline-flex;flex-wrap:wrap;gap:14px;margin-left:12px;font-size:.78rem;color:var(--mut)}
.snss-legend i.snss-lg{display:inline-block;width:11px;height:11px;border-radius:2px;vertical-align:middle;margin-right:4px;outline:1px dashed rgba(0,0,0,.3)}
@media(max-width:640px){.snss-legend{margin-left:0;margin-top:4px;width:100%;justify-content:center}}

/* ---- stable stage height + scroll viewport ---- */
.snss-scroll{height:min(70vh,640px);max-height:none}
.snss-stage{min-height:auto}
/* ---- text edit hint + active toolbar toggles (pan/zoom) ---- */
.snss-edithint{font-size:.76rem;color:var(--mut);font-style:italic;margin-left:auto;align-self:center;white-space:nowrap}
.snss-zbtn.on,.snss-panbtn.on{background:var(--ac);color:#fff;border-color:var(--ac)}
