/* ═══════════════════════════════════════════════════════
   StickerStudio — Design System v2
   Palette: #0D0D0D · #FFFFFF · #F4F1EC · #FF3D57 · #1A1A2E
   Type: Plus Jakarta Sans (UI) + DM Serif Display (headings)
═══════════════════════════════════════════════════════ */
@import url('https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@3/tabler-icons.min.css');
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=DM+Serif+Display:ital@0;1&display=swap');

/* ── Reset & Base ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:#F4F1EC;color:#0D0D0D;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── Design Tokens ────────────────────────────────── */
:root{
  --ink:#0D0D0D;
  --ink-mid:#3A3A3A;
  --ink-soft:#6B6B6B;
  --white:#FFFFFF;
  --surface:#F4F1EC;
  --surface-alt:#EDE8DF;
  --surface-card:#FFFFFF;
  --border:#E0D9D0;
  --border-mid:#C8BFB3;
  --accent:#FF3D57;
  --accent-hover:#E83350;
  --accent-light:rgba(255,61,87,.10);
  --gold:#C8922A;
  --gold-light:#D9A840;
  --gold-bg:rgba(200,146,42,.10);
  --success:#18A058;
  --success-bg:rgba(24,160,88,.10);
  --danger:#E5253C;
  --danger-bg:rgba(229,37,60,.09);
  --info:#2563EB;
  --r-xs:3px;
  --r-sm:6px;
  --r-md:10px;
  --r-lg:16px;
  --r-xl:22px;
  --r-2xl:32px;
  --shadow-xs:0 1px 3px rgba(13,13,13,.06);
  --shadow-sm:0 2px 8px rgba(13,13,13,.08);
  --shadow-md:0 6px 24px rgba(13,13,13,.10);
  --shadow-lg:0 16px 48px rgba(13,13,13,.13);
  --nav-h:62px;
  --page-shell:1380px;
  --paper-bg:#FFFFFF;
  --paper-line:#E0D9D0;
  --paper-line-strong:#C8BFB3;
  --paper-shadow:0 8px 28px rgba(13,13,13,.08);
  --paper-shadow-soft:0 4px 16px rgba(13,13,13,.06);
  --paper-radius:16px;

  /* Legacy aliases used by admin and older templates */
  --black:var(--ink);
  --graphite:var(--ink-soft);
  --cream:var(--surface);
  --beige:var(--border);
  --beige-mid:var(--border-mid);
}

/* ── Announcement bar ─────────────────────────────── */
.ann-bar{
  background:var(--ink);
  color:rgba(255,255,255,.85);
  text-align:center;
  font-size:12px;
  letter-spacing:.06em;
  padding:8px 16px;
  font-weight:500;
}
.ann-bar span{display:inline-block}

/* ── Navigation ───────────────────────────────────── */
.site-nav{
  background:var(--ink);
  color:#fff;
  position:sticky;
  top:0;
  z-index:200;
  height:var(--nav-h);
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow:0 2px 12px rgba(13,13,13,.18);
}
.site-nav .inner{
  display:flex;
  align-items:center;
  height:100%;
  max-width:var(--page-shell);
  margin:0 auto;
  padding:0 24px;
  gap:24px;
}
.nav-logo{
  font-family:'DM Serif Display',serif;
  font-size:22px;
  font-weight:400;
  color:#fff;
  letter-spacing:-.01em;
  white-space:nowrap;
  flex-shrink:0;
}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:2px;flex:1}
.nav-item{position:relative}
.nav-link{
  font-size:13px;
  font-weight:500;
  color:rgba(255,255,255,.70);
  padding:8px 13px;
  border-radius:var(--r-sm);
  transition:color .18s,background .18s;
  white-space:nowrap;
  cursor:pointer;
  display:block;
  letter-spacing:.01em;
}
.nav-link:hover,.nav-item:hover .nav-link,.nav-link.is-current{
  color:#fff;
  background:rgba(255,255,255,.08);
}
.nav-link-compact{padding:8px 12px}
/* dropdown */
.nav-dropdown{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  background:var(--ink);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--r-md);
  padding:6px 0;
  min-width:200px;
  opacity:0;
  visibility:hidden;
  transform:translateY(-4px);
  transition:all .16s;
  z-index:300;
  box-shadow:var(--shadow-lg);
}
.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown a{
  display:block;
  padding:9px 18px;
  font-size:13px;
  color:rgba(255,255,255,.68);
  transition:color .14s,background .14s;
}
.nav-dropdown a:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-sep{flex:1}
.nav-actions{display:flex;align-items:center;gap:6px}
.nav-icon-btn{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border:none;background:transparent;
  color:rgba(255,255,255,.65);
  cursor:pointer;
  border-radius:var(--r-sm);
  transition:color .18s,background .18s;
  position:relative;
  font-size:18px;
}
.nav-icon-btn:hover{color:#fff;background:rgba(255,255,255,.10)}
.cart-count{
  position:absolute;top:-3px;right:-3px;
  background:var(--accent);color:#fff;
  border-radius:50%;width:16px;height:16px;
  font-size:9px;font-weight:700;
  display:none;
  align-items:center;justify-content:center;
}

/* ── Breadcrumb ───────────────────────────────────── */
.breadcrumb{
  max-width:var(--page-shell);
  margin:0 auto;
  padding:12px 24px;
  font-size:12px;
  color:var(--ink-soft);
  display:flex;gap:6px;align-items:center;
}
.breadcrumb a{color:var(--ink-soft);transition:color .15s}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb-sep{opacity:.4}

/* ── Hero ─────────────────────────────────────────── */
.hero{
  position:relative;
  min-height:580px;
  background:var(--ink);
  overflow:hidden;
  display:flex;
  align-items:center;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(125deg,#0D0D0D 0%,#1A1A2E 55%,#0D0D0D 100%);
}
.hero::after{
  content:'';
  position:absolute;inset:0;
  background-image:radial-gradient(ellipse at 75% 50%,rgba(255,61,87,.14) 0%,transparent 55%),
    radial-gradient(ellipse at 20% 80%,rgba(200,146,42,.08) 0%,transparent 45%);
}
.hero-banner{
  min-height:660px;
  background:#f5f0e9;
  border-bottom:1px solid rgba(13,13,13,.06);
}
.hero-banner::before,
.hero-banner::after{display:none}
.hero-banner-media{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-banner-media > .home-banner-slot{
  position:absolute;
  inset:0;
}
.hero-banner-media > .home-banner-slot .home-banner-track,
.hero-banner-media > .home-banner-slot .home-banner-slide,
.hero-banner-media > .home-banner-slot .home-banner-slide img{
  width:100%;
  height:100%;
}
.hero-banner-media::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,.94) 0%,rgba(255,255,255,.9) 26%,rgba(255,255,255,.56) 44%,rgba(255,255,255,.12) 62%,rgba(255,255,255,.04) 100%);
  pointer-events:none;
}
.hero-banner-image{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center right;
}
.hero-content{
  position:relative;z-index:2;
  max-width:var(--page-shell);
  margin:0 auto;
  padding:72px 24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:56px;
  width:100%;
}
.hero-banner .hero-content{
  grid-template-columns:minmax(0,1.02fr) minmax(340px,.98fr);
}
.hero-copy{
  max-width:620px;
  padding:18px 0;
}
.hero-eyebrow{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:600;
  margin-bottom:16px;
}
.hero-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(36px,5vw,64px);
  font-weight:400;
  color:#fff;
  line-height:1.08;
  margin-bottom:20px;
  letter-spacing:-.02em;
}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-sub{
  font-size:15px;
  color:rgba(255,255,255,.60);
  max-width:440px;
  line-height:1.75;
  margin-bottom:36px;
  font-weight:400;
}
.hero-banner .hero-title{color:#121212}
.hero-banner .hero-title em{color:#F57C00}
.hero-banner .hero-sub{
  color:rgba(13,13,13,.72);
  max-width:560px;
}
.hero-points{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:-8px 0 28px;
}
.hero-point{
  display:inline-flex;
  align-items:center;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(13,13,13,.08);
  color:rgba(13,13,13,.78);
  font-size:12px;
  font-weight:600;
  box-shadow:0 8px 24px rgba(13,13,13,.06);
}
.hero-banner .btn-outline{
  color:#121212;
  border-color:rgba(18,18,18,.22);
  background:rgba(255,255,255,.5);
}
.hero-banner .btn-outline:hover{
  border-color:#F57C00;
  color:#F57C00;
  background:rgba(255,255,255,.82);
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-canvas-preview{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--r-2xl);
  padding:28px;
  backdrop-filter:blur(8px);
}
.hero-highlight-card{
  justify-self:end;
  width:100%;
  max-width:500px;
  background:transparent;
  border:none;
  padding:0;
  backdrop-filter:none;
}
.hero-canvas-preview canvas{border-radius:var(--r-lg);box-shadow:0 24px 64px rgba(0,0,0,.45)}

.home-banner-grid-section{padding:28px 0 8px}
.home-banner-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.home-banner-horizontal-section{padding:24px 0}
.home-banner-horizontal-section--footer{padding-top:12px;padding-bottom:64px}
.home-banner-slot{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  background:linear-gradient(180deg,#fff,#f7f2ea);
  border:1px solid rgba(13,13,13,.08);
  box-shadow:0 18px 48px rgba(13,13,13,.10);
}
.home-banner-slot--card{aspect-ratio:16/10;min-height:260px}
.home-banner-slot--wide{aspect-ratio:21/6;min-height:210px}
.home-banner-slot--hero{
  border:none;
  border-radius:0;
  box-shadow:none;
  background:transparent;
}
.home-banner-track{
  position:relative;
  width:100%;
  height:100%;
}
.home-banner-slide{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity .45s ease;
  pointer-events:none;
}
.home-banner-slide.is-active{
  opacity:1;
  pointer-events:auto;
}
.home-banner-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.home-banner-caption{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:16px 18px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(13,13,13,.72),rgba(13,13,13,.56));
  color:#fff;
  backdrop-filter:blur(8px);
}
.home-banner-caption strong{
  font-family:'DM Serif Display',serif;
  font-size:26px;
  font-weight:400;
  line-height:1.08;
}
.home-banner-caption small{
  font-size:13px;
  color:rgba(255,255,255,.78);
  line-height:1.5;
}
.home-banner-dots{
  position:absolute;
  left:50%;
  bottom:14px;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:3;
}
.home-banner-dot{
  width:9px;
  height:9px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,.46);
  cursor:pointer;
  padding:0;
}
.home-banner-dot.is-active{background:#fff}

/* ── Buttons ──────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 24px;
  border-radius:var(--r-sm);
  font-size:13px;font-weight:600;
  letter-spacing:.02em;
  cursor:pointer;border:none;
  transition:all .18s;
  white-space:nowrap;
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px rgba(255,61,87,.30)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.28)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-mid)}
.btn-secondary{background:var(--surface-alt);color:var(--ink-mid);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--border);color:var(--ink)}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#159047;transform:translateY(-1px)}
.btn-danger{background:var(--danger);color:#fff}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-lg{padding:14px 30px;font-size:14px}
.btn-xl{padding:15px 38px;font-size:14px;letter-spacing:.04em}
.btn-block{width:100%;justify-content:center}

/* ── Section headers ──────────────────────────────── */
.section{padding:72px 0}
.section-inner{max-width:var(--page-shell);margin:0 auto;padding:0 24px}
.section-header{margin-bottom:40px}
.section-eyebrow{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);font-weight:600;margin-bottom:10px;
}
.section-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(26px,3.5vw,42px);
  font-weight:400;
  color:var(--ink);
  line-height:1.15;
  letter-spacing:-.02em;
}
.section-title em{font-style:italic;color:var(--ink-mid)}
.section-sub{font-size:15px;color:var(--ink-soft);margin-top:10px;max-width:520px;font-weight:400;line-height:1.7}
.section-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}

/* ── Dark sections ────────────────────────────────── */
.section-dark{background:var(--ink)}
.section-dark .section-eyebrow{color:var(--accent)}
.section-dark .section-title{color:#fff}
.section-dark .section-sub{color:rgba(255,255,255,.55)}

/* ── Category Grid ────────────────────────────────── */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat-card{
  position:relative;overflow:hidden;
  cursor:pointer;aspect-ratio:3/4;
  background:var(--ink-mid);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-sm);
}
.cat-card-bg{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
  background:var(--ink-mid);
}
.cat-card:hover .cat-card-bg{transform:scale(1.06)}
.cat-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(13,13,13,.88) 0%,rgba(13,13,13,.22) 50%,transparent 100%);
}
.cat-card-body{position:absolute;bottom:0;left:0;right:0;padding:24px 20px;color:#fff}
.cat-card-name{font-family:'DM Serif Display',serif;font-size:20px;font-weight:400;margin-bottom:4px}
.cat-card-count{font-size:11px;letter-spacing:.05em;opacity:.55}
.cat-card-arrow{
  position:absolute;bottom:22px;right:18px;
  width:34px;height:34px;
  background:var(--accent);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transform:translateY(8px);opacity:0;transition:all .22s;
  font-size:13px;color:#fff;
}
.cat-card:hover .cat-card-arrow{transform:translateY(0);opacity:1}

/* ── Product Grid ─────────────────────────────────── */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.prod-card{
  background:var(--surface-card);
  border-radius:var(--r-xl);
  overflow:hidden;
  cursor:pointer;
  transition:transform .22s,box-shadow .22s;
  border:1px solid var(--paper-line);
  box-shadow:var(--paper-shadow-soft);
}
.prod-card:hover{transform:translateY(-4px);box-shadow:var(--paper-shadow)}
.prod-thumb{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#F8F5EF,#EEE6D8);
  aspect-ratio:1;
}
.prod-thumb-inner{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:4rem;
  transition:transform .38s;
  padding:10px;
}
.prod-card:hover .prod-thumb-inner{transform:scale(1.06)}
.prod-thumb-overlay{
  position:absolute;inset:0;
  background:rgba(13,13,13,.60);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  opacity:0;transition:opacity .22s;
}
.prod-card:hover .prod-thumb-overlay{opacity:1}
.prod-badge{
  position:absolute;top:12px;left:12px;
  background:var(--accent);color:#fff;
  font-size:10px;font-weight:700;
  letter-spacing:.05em;padding:4px 10px;
  border-radius:999px;
}
.prod-body{padding:16px 18px 20px}
.prod-cat{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:4px}
.prod-name{
  font-family:'DM Serif Display',serif;
  font-size:17px;font-weight:400;
  color:var(--ink);margin-bottom:6px;line-height:1.25;
}
.prod-price{font-size:18px;font-weight:700;color:var(--ink)}
.prod-price-from{font-size:11px;font-weight:400;color:var(--ink-soft);margin-right:3px;letter-spacing:.05em;text-transform:uppercase}
.prod-colors{display:flex;gap:5px;margin-top:8px}
.prod-color-dot{width:12px;height:12px;border-radius:50%;border:1px solid rgba(13,13,13,.14)}

/* ── AI Banner ────────────────────────────────────── */
.ai-banner{
  background:var(--ink);padding:72px 0;
  position:relative;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.05);
}
.ai-banner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 28% 50%,rgba(255,61,87,.12) 0%,transparent 55%);
}
.ai-banner-inner{
  max-width:var(--page-shell);margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
}
.ai-banner-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,3.5vw,46px);font-weight:400;
  color:#fff;line-height:1.15;
  margin-bottom:14px;letter-spacing:-.02em;
}
.ai-banner-title em{font-style:italic;color:var(--gold)}
.ai-banner-sub{color:rgba(255,255,255,.55);font-size:15px;font-weight:400;margin-bottom:28px;line-height:1.7}
.ai-features{display:flex;flex-direction:column;gap:14px}
.ai-feature{display:flex;align-items:flex-start;gap:14px}
.ai-feature-icon{
  width:36px;height:36px;
  background:rgba(255,61,87,.12);
  border:1px solid rgba(255,61,87,.22);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:14px;color:var(--accent);font-weight:700;
}
.ai-feature-text h4{font-size:13px;font-weight:600;color:#fff;margin-bottom:2px}
.ai-feature-text p{font-size:12px;color:rgba(255,255,255,.48)}

/* ── Trust bar ────────────────────────────────────── */
.trust-bar{
  background:linear-gradient(180deg,#EDE8DE,#E6DED3);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:22px 0;
}
.trust-items{
  max-width:var(--page-shell);margin:0 auto;padding:0 24px;
  display:flex;justify-content:space-around;flex-wrap:wrap;gap:14px;
}
.trust-item{
  display:flex;align-items:center;gap:12px;font-size:13px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(200,146,42,.18);
  border-radius:var(--r-lg);
  padding:14px 18px;min-width:200px;
}
.trust-icon{font-size:20px;color:var(--gold)}
.trust-label{font-weight:600;color:var(--ink)}
.trust-sub{font-size:11px;color:var(--ink-soft);margin-top:1px}

/* ── Editor page ──────────────────────────────────── */
.editor-page{max-width:var(--page-shell);margin:0 auto;padding:24px}
.editor-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}
.editor-left{display:flex;flex-direction:column;gap:16px}

/* AI panel */
.ai-gen-panel{
  background:var(--ink);border-radius:var(--r-xl);
  padding:24px;position:relative;overflow:hidden;
}
.ai-gen-panel::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:180px;height:180px;
  background:radial-gradient(circle,rgba(255,61,87,.14),transparent);
  pointer-events:none;
}
.ai-gen-label{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);font-weight:600;margin-bottom:8px;
  display:flex;align-items:center;gap:7px;
}
.ai-gen-title{
  font-family:'DM Serif Display',serif;font-size:20px;
  color:#fff;margin-bottom:16px;
}
.ai-textarea{
  width:100%;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-md);color:#fff;
  font-size:14px;padding:12px 14px;resize:vertical;min-height:80px;
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  line-height:1.6;transition:border-color .18s;
}
.ai-textarea::placeholder{color:rgba(255,255,255,.28)}
.ai-textarea:focus{outline:none;border-color:rgba(255,61,87,.45)}
.ai-type-row{display:flex;gap:8px;margin:12px 0;flex-wrap:wrap}
.ai-type-btn{
  padding:6px 14px;border:1px solid rgba(255,255,255,.14);
  border-radius:999px;font-size:11.5px;cursor:pointer;
  background:transparent;color:rgba(255,255,255,.55);
  transition:all .16s;font-weight:500;
}
.ai-type-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.ai-gen-btn{
  background:var(--accent);color:#fff;border:none;
  border-radius:var(--r-sm);padding:11px 22px;
  font-size:13px;font-weight:600;cursor:pointer;
  letter-spacing:.04em;display:flex;align-items:center;gap:8px;
  transition:all .18s;
}
.ai-gen-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}
.ai-gen-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.ai-result-msg{margin-top:10px;padding:10px 14px;border-radius:var(--r-sm);font-size:13px;display:none}
.ai-result-msg.show-ok{display:block;background:var(--success-bg);color:var(--success);border:1px solid rgba(24,160,88,.25)}
.ai-result-msg.show-err{display:block;background:var(--danger-bg);color:var(--danger);border:1px solid rgba(229,37,60,.22)}
.ai-result-msg.show-info{display:block;background:var(--gold-bg);color:var(--gold);border:1px solid rgba(200,146,42,.25)}

/* canvas wrap */
.canvas-wrap{
  background:var(--white);border-radius:var(--r-xl);
  padding:20px;display:flex;flex-direction:column;
  align-items:center;gap:12px;box-shadow:var(--shadow-sm);
}
.view-tabs{display:flex;gap:6px}
.view-tab{
  padding:6px 16px;border:1px solid var(--border);
  border-radius:var(--r-sm);font-size:12px;cursor:pointer;
  background:var(--surface-alt);color:var(--ink-mid);
  transition:all .16s;font-weight:500;
}
.view-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
canvas#editor{
  border-radius:var(--r-md);max-width:100%;
  background:var(--surface-alt);cursor:crosshair;
}
.editor-toolbar{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.tool-pill{
  padding:7px 14px;border:1px solid var(--border);
  border-radius:999px;font-size:12px;cursor:pointer;
  background:var(--white);color:var(--ink-mid);
  transition:all .16s;white-space:nowrap;font-weight:500;
}
.tool-pill:hover{border-color:var(--accent);color:var(--ink)}
.tool-pill.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.canvas-hint{font-size:11px;color:var(--ink-soft);letter-spacing:.02em}

/* props panel */
.props-section{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-xs);
}
.props-section h3{
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:12px;
}
.prop-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px}
.prop-row label{color:var(--ink-soft);min-width:44px;font-size:12px;font-weight:500}
.prop-row input[type=range]{flex:1;accent-color:var(--accent)}
.prop-row input[type=color]{
  width:30px;height:26px;border:1px solid var(--border);
  cursor:pointer;border-radius:var(--r-xs);background:transparent;
}
.prop-row select,.prop-row input[type=text]{
  flex:1;padding:6px 10px;border:1px solid var(--border);
  border-radius:var(--r-sm);font-size:13px;
  background:var(--surface);color:var(--ink);
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
}
.prop-row select:focus,.prop-row input[type=text]:focus{outline:none;border-color:var(--accent)}
.prop-val{min-width:26px;font-weight:700;font-size:12px;text-align:right;color:var(--ink)}

/* right panel */
.editor-panel{display:flex;flex-direction:column;gap:14px}
.panel-card{
  background:var(--white);border-radius:var(--r-lg);
  padding:18px;box-shadow:var(--shadow-xs);
  border:1px solid var(--paper-line);
}
.panel-card h3{
  font-size:11px;letter-spacing:.10em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;margin-bottom:12px;
}
.swatches{display:flex;flex-wrap:wrap;gap:7px}
.color-swatch{
  width:26px;height:26px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;transition:transform .14s;position:relative;
}
.color-swatch:hover{transform:scale(1.15)}
.color-swatch.active{
  border-color:var(--accent);
  box-shadow:0 0 0 2px #fff,0 0 0 4px var(--accent);
}
.size-btns{display:flex;flex-wrap:wrap;gap:7px}
.size-btn{
  padding:7px 13px;border:1.5px solid var(--border);
  border-radius:var(--r-sm);font-size:12px;cursor:pointer;
  background:var(--surface);color:var(--ink-mid);
  font-weight:500;transition:all .16s;
}
.size-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.layers-list{
  display:flex;flex-direction:column;gap:4px;
  max-height:130px;overflow-y:auto;
}
.layer-row{
  display:flex;align-items:center;gap:8px;
  padding:6px 8px;border-radius:var(--r-sm);
  cursor:pointer;font-size:12px;color:var(--ink-mid);
  transition:background .14s;
}
.layer-row:hover,.layer-row.sel{background:var(--surface-alt)}
.layer-del{
  margin-left:auto;cursor:pointer;font-size:13px;padding:2px 4px;
  color:var(--border-mid);transition:color .14s;
}
.layer-del:hover{color:var(--danger)}
.qty-row{display:flex;align-items:center;gap:12px}
.qty-btn{
  width:32px;height:32px;border:1.5px solid var(--border);
  border-radius:var(--r-sm);background:var(--surface);
  cursor:pointer;font-size:16px;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:all .14s;
}
.qty-btn:hover{border-color:var(--accent);background:var(--surface-alt)}
#qty-val{
  font-family:'DM Serif Display',serif;
  font-size:20px;font-weight:400;
  min-width:30px;text-align:center;
}

/* prod info in editor */
.prod-editor-info h2{font-family:'DM Serif Display',serif;font-size:20px;font-weight:400;margin-bottom:4px}
.prod-editor-price{font-size:24px;font-weight:700;color:var(--ink);margin-top:8px}
.prod-editor-price span{font-size:13px;font-weight:400;color:var(--ink-soft);margin-right:4px}

/* Manual text add */
.text-add-wrap input{
  width:100%;padding:9px 12px;border:1px solid var(--border);
  border-radius:var(--r-sm);font-size:14px;
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  background:var(--surface);color:var(--ink);
  transition:border-color .18s;margin-bottom:8px;
}
.text-add-wrap input:focus{outline:none;border-color:var(--accent)}
.text-add-wrap select{
  width:100%;padding:8px 12px;border:1px solid var(--border);
  border-radius:var(--r-sm);font-size:13px;
  background:var(--surface);color:var(--ink);margin-bottom:8px;
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  min-height:46px;
}
.text-size-row{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:var(--ink-soft);margin-bottom:8px;
}
.text-size-row input[type=range]{flex:1;accent-color:var(--accent)}
.text-size-row span{min-width:24px;font-weight:700;color:var(--ink)}
.text-color-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.tc-dot{
  width:22px;height:22px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;transition:transform .14s;
}
.tc-dot:hover{transform:scale(1.15)}
.tc-dot.active{
  border-color:var(--accent);
  box-shadow:0 0 0 1px #fff,0 0 0 3px var(--accent);
}

/* ── Cart drawer ──────────────────────────────────── */
#cart-drawer{
  position:fixed;top:0;right:-460px;width:460px;
  height:100vh;background:var(--white);z-index:500;
  transition:right .32s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  box-shadow:-6px 0 36px rgba(13,13,13,.16);
}
#cart-drawer.open{right:0}
.drawer-header{
  padding:20px 22px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.drawer-header h2{font-family:'DM Serif Display',serif;font-size:20px;font-weight:400}
.drawer-close{
  background:none;border:none;font-size:18px;cursor:pointer;
  color:var(--ink-mid);width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--r-sm);transition:background .14s;
}
.drawer-close:hover{background:var(--surface-alt)}
.drawer-body{flex:1;overflow-y:auto;padding:14px 22px}
.drawer-footer{padding:16px 22px;border-top:1px solid var(--border)}
.overlay{
  position:fixed;inset:0;
  background:rgba(13,13,13,.45);
  z-index:499;display:none;
  backdrop-filter:blur(2px);
}
.overlay.show{display:block}
.cart-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.cart-item-thumb{
  width:62px;height:62px;background:var(--surface-alt);
  border-radius:var(--r-md);display:flex;align-items:center;
  justify-content:center;font-size:1.6rem;flex-shrink:0;
  overflow:hidden;border:1px solid var(--border);
}
.cart-item-thumb img{width:100%;height:100%;object-fit:cover}
.cart-item-thumb-fallback{
  width:100%;height:100%;display:flex;align-items:center;
  justify-content:center;font-size:11px;color:var(--ink-soft);
}
.cart-item-info{flex:1}
.cart-item-info h4{font-size:14px;font-weight:600;margin-bottom:3px}
.cart-item-info .meta{font-size:12px;color:var(--ink-soft)}
.cart-item-qty{display:flex;align-items:center;gap:8px;margin-top:8px}
.ci-qty-btn{
  width:24px;height:24px;border:1px solid var(--border);
  border-radius:4px;background:var(--surface);cursor:pointer;
  font-size:13px;display:flex;align-items:center;justify-content:center;
}
.ci-qty-val{font-size:13px;font-weight:600;min-width:18px;text-align:center}
.cart-item-price{font-weight:700;font-size:14px;white-space:nowrap;align-self:flex-start}
.totals-row{display:flex;justify-content:space-between;font-size:14px;margin-bottom:8px;color:var(--ink-soft)}
.totals-discount{color:var(--success)}
.totals-row.grand{
  font-size:17px;font-weight:700;color:var(--ink);
  border-top:1px solid var(--border);
  padding-top:10px;margin-top:6px;
  font-family:'DM Serif Display',serif;
}

/* ── Cart Page ────────────────────────────────────── */
.cart-page-wrap{
  max-width:1100px;margin:0 auto;
  padding:44px 24px 56px;
}
.cart-page-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(32px,4vw,46px);
  font-weight:400;
  letter-spacing:-.02em;
  color:var(--ink);margin-bottom:28px;
}
.cart-table{
  width:100%;border-collapse:collapse;
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);
  border-radius:var(--paper-radius);
  overflow:hidden;box-shadow:var(--paper-shadow-soft);
}
.cart-table th{
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.75);padding:11px 16px;text-align:left;
  background:var(--ink);font-weight:500;border-bottom:none;
}
.cart-table td{padding:16px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.cart-table tr:hover td{background:rgba(255,61,87,.03)}
.prod-td-name{font-weight:600;font-size:14px}
.prod-td-meta{font-size:12px;color:var(--ink-soft);margin-top:2px}
.order-summary-card{
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);
  border-radius:var(--paper-radius);
  padding:26px;
  box-shadow:var(--paper-shadow-soft);
  position:sticky;
  top:calc(var(--nav-h) + 20px);
}
.os-row{display:flex;justify-content:space-between;margin-bottom:10px;font-size:14px;color:var(--ink-soft)}
.os-grand{
  font-family:'DM Serif Display',serif;
  font-size:18px;font-weight:400;color:var(--ink);
  border-top:2px solid var(--border);
  padding-top:12px;margin-top:6px;
}

/* ── Checkout ─────────────────────────────────────── */
.checkout-wrap{
  max-width:1100px;margin:0 auto;
  padding:44px 24px 56px;
}
.checkout-grid{display:grid;grid-template-columns:1fr 380px;gap:34px;align-items:start}
.checkout-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,3vw,40px);
  font-weight:400;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:22px;
}
.checkout-section{
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);
  border-radius:var(--paper-radius);
  padding:26px;margin-bottom:16px;
  box-shadow:var(--paper-shadow-soft);
}
.checkout-section h3{
  font-size:13px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:18px;
  padding-bottom:10px;border-bottom:1px solid var(--border);
}
.form-group{margin-bottom:14px}
.form-group label{
  display:block;font-size:12px;font-weight:600;
  color:var(--ink-soft);margin-bottom:5px;letter-spacing:.02em;
}
.form-group input,.form-group select{
  width:100%;padding:11px 14px;
  border:1px solid var(--paper-line-strong);
  border-radius:var(--r-sm);font-size:14px;color:var(--ink);
  background:#FCFBF8;
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  transition:border-color .18s;
  min-height:46px;
}
.form-group input:focus,.form-group select:focus{
  outline:none;border-color:var(--accent);
  background:var(--white);
  box-shadow:0 0 0 3px rgba(255,61,87,.10);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stripe-placeholder{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:14px;
  font-size:13px;color:var(--ink-soft);margin-top:4px;
}
#payment-element{min-height:80px}
.pay-secure-note{
  display:flex;align-items:center;gap:8px;
  font-size:12px;color:var(--ink-soft);margin-top:12px;opacity:.7;
}
.payment-method-btn{
  display:flex;align-items:center;gap:8px;
  padding:10px 20px;border:1.5px solid var(--border);
  border-radius:var(--r-md);background:var(--surface);
  cursor:pointer;font-size:13px;font-weight:600;
  color:var(--ink-soft);transition:all .16s;
}
.payment-method-btn:hover{border-color:var(--accent);color:var(--ink)}
.payment-method-btn.active{
  border-color:var(--accent);
  background:rgba(255,61,87,.06);
  color:var(--ink);
}

/* Checkout legal */
.checkout-legal{
  background:linear-gradient(180deg,var(--white),#F8F4EC);
  border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 18px 8px;
}
.checkout-check{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}
.checkout-check input{margin-top:4px;accent-color:var(--accent)}
.checkout-check label{font-size:13px;color:var(--ink-soft);line-height:1.6}
.checkout-check a{color:var(--gold);font-weight:600}

/* ── Thank you ────────────────────────────────────── */
.ty-wrap{
  text-align:center;padding:80px 24px 80px;
  max-width:1180px;margin:0 auto;
}
.ty-icon{font-size:3.5rem;margin-bottom:18px;color:var(--success)}
.ty-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(32px,4vw,48px);
  font-weight:400;letter-spacing:-.03em;
  margin-bottom:12px;
}
.ty-sub{
  font-size:16px;color:var(--ink-soft);
  margin-bottom:32px;font-weight:400;
  max-width:720px;margin-left:auto;margin-right:auto;
}
.ty-card{
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);
  border-radius:var(--paper-radius);
  padding:26px;text-align:left;
  margin-bottom:26px;box-shadow:var(--paper-shadow-soft);
}
.ty-row{
  display:flex;justify-content:space-between;
  padding:9px 0;font-size:14px;
  border-bottom:1px solid var(--border);
}
.ty-row:last-child{border-bottom:none}
.ty-row-label{color:var(--ink-soft)}
.ty-row-val{font-weight:600}
.ty-hero{margin-bottom:32px}
.ty-item{padding:14px 0 !important}
.ty-item-thumb{border-radius:var(--r-md) !important}

/* ── Badges ───────────────────────────────────────── */
.badge{display:inline-block;padding:3px 9px;border-radius:var(--r-sm);font-size:11px;font-weight:600;letter-spacing:.03em}
.badge-gold{background:var(--gold-bg);color:var(--gold)}
.badge-success{background:var(--success-bg);color:var(--success)}
.badge-danger{background:var(--danger-bg);color:var(--danger)}
.badge-info{background:rgba(37,99,235,.10);color:var(--info)}
.badge-warning{background:rgba(245,158,11,.12);color:#B45309}

/* ── Alerts ───────────────────────────────────────── */
.alert{padding:11px 16px;border-radius:var(--r-md);font-size:13px;margin-bottom:12px}
.alert-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(24,160,88,.22)}
.alert-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(229,37,60,.20)}
.alert-info{background:var(--gold-bg);color:var(--gold);border:1px solid rgba(200,146,42,.25)}

/* ── Admin ────────────────────────────────────────── */
.admin-wrap{display:flex;min-height:100vh;background:var(--surface)}
.admin-sidebar{width:230px;background:var(--ink);flex-shrink:0;padding:0}
.admin-sidebar .brand{padding:22px 20px;font-family:'DM Serif Display',serif;font-size:17px;color:#fff;border-bottom:1px solid rgba(255,255,255,.06)}
.admin-sidebar .brand span{color:var(--accent)}
.admin-sidebar a{display:flex;align-items:center;gap:10px;padding:12px 20px;color:rgba(255,255,255,.55);font-size:13px;transition:all .14s}
.admin-sidebar a:hover,.admin-sidebar a.active{background:rgba(255,61,87,.10);color:#fff}
.admin-main{flex:1;padding:28px 32px;overflow-x:hidden}
.admin-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.admin-stat{background:var(--white);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-xs);border:1px solid var(--border)}
.admin-stat-lbl{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px}
.admin-stat-val{font-family:'DM Serif Display',serif;font-size:28px;font-weight:400;color:var(--ink)}
.data-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs);border:1px solid var(--border)}
.data-table th{background:var(--ink);color:rgba(255,255,255,.70);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:12px 16px;text-align:left;font-weight:500}
.data-table td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(255,61,87,.03)}
.status-select{padding:5px 9px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:12px;background:var(--surface);cursor:pointer}

/* ── Footer ───────────────────────────────────────── */
.site-footer{
  background:radial-gradient(circle at top left,rgba(255,61,87,.08),transparent 24%),var(--ink);
  color:rgba(255,255,255,.50);
  padding:60px 0 28px;
  margin-top:48px;
  border-top:1px solid rgba(255,255,255,.05);
}
.footer-inner{max-width:var(--page-shell);margin:0 auto;padding:0 24px}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{
  font-family:'DM Serif Display',serif;
  font-size:22px;color:#fff;margin-bottom:12px;
}
.footer-brand span{color:var(--accent)}
.footer-tagline{font-size:13px;line-height:1.75;font-weight:400;max-width:240px}
.footer-heading{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;font-weight:700;margin-bottom:16px;
}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:13px;transition:color .14s}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:22px;
  display:flex;justify-content:space-between;align-items:center;font-size:12px;
}

/* ── Legal pages ──────────────────────────────────── */
.legal-hero{
  position:relative;
  background:linear-gradient(135deg,#0D0D0D 0%,#1A1A2E 60%,#2D1A0E 100%);
  color:#fff;padding:88px 0 72px;overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.legal-hero::after{
  content:'';position:absolute;inset:auto -10% -35% auto;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,61,87,.18),transparent 65%);
}
.legal-hero .section-inner{position:relative;z-index:1}
.legal-kicker{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.legal-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(34px,5vw,58px);line-height:1.02;max-width:760px;letter-spacing:-.03em;
}
.legal-sub{max-width:700px;margin-top:14px;color:rgba(255,255,255,.70);font-size:15px}
.legal-shell{
  max-width:var(--page-shell);margin:-36px auto 0;
  padding:0 24px 88px;position:relative;z-index:2;
}
.legal-layout{display:grid;grid-template-columns:1fr;gap:26px;align-items:start}
.legal-nav,.legal-card{
  background:var(--white);border-radius:var(--r-2xl);
  box-shadow:var(--paper-shadow);border:1px solid var(--paper-line);
}
.legal-nav{
  padding:22px 24px;max-width:980px;margin:0 auto;width:100%;
  display:flex;gap:22px;align-items:flex-start;justify-content:center;flex-wrap:wrap;
}
.legal-nav-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center}
.legal-nav h3{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin:0 6px 0 0;white-space:nowrap}
.legal-nav a{
  display:block;padding:9px 14px;border-radius:999px;color:var(--ink-soft);
  font-size:12px;transition:all .16s;background:var(--surface);border:1px solid var(--border);
}
.legal-nav a:hover,.legal-nav a.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.legal-card{padding:40px 44px;max-width:820px;margin:0 auto;width:100%}
.legal-card h2{font-family:'DM Serif Display',serif;font-size:28px;margin:0 0 16px;letter-spacing:-.02em}
.legal-card h3{font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin:28px 0 10px}
.legal-card-intro{font-size:15px;color:var(--ink-soft);line-height:1.9;margin-bottom:18px;max-width:680px}
.legal-card p,.legal-card li{font-size:14px;color:var(--ink-soft);line-height:1.85}
.legal-card p + p{margin-top:12px}
.legal-card ul{padding-left:20px;display:flex;flex-direction:column;gap:8px}
.legal-card .legal-note{
  margin-top:20px;padding:14px 16px;
  background:var(--gold-bg);
  border:1px solid rgba(200,146,42,.24);
  border-radius:var(--r-md);color:var(--gold);
}
.legal-card a{color:var(--gold);font-weight:600}
.legal-card a:hover{text-decoration:underline}
.legal-card section + section{margin-top:28px;padding-top:22px;border-top:1px solid var(--border)}
.legal-card section:first-of-type h3{margin-top:0}
.legal-quickfacts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0 6px}
.legal-fact{
  padding:16px;border-radius:var(--r-lg);
  background:linear-gradient(180deg,var(--white),#F8F3EA);
  border:1px solid var(--border);
}
.legal-fact strong{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px}
.legal-fact span{font-family:'DM Serif Display',serif;font-size:20px;color:var(--ink)}

/* ── Cookie banner ────────────────────────────────── */
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:700}
.cookie-banner__inner{
  max-width:980px;margin:0 auto;
  background:rgba(13,13,13,.95);color:#fff;
  border:1px solid rgba(255,61,87,.22);
  border-radius:22px;padding:20px 22px;
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;
  box-shadow:0 18px 50px rgba(0,0,0,.28);
  backdrop-filter:blur(10px);
}
.cookie-banner__eyebrow{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.cookie-banner__title{font-family:'DM Serif Display',serif;font-size:22px;margin-bottom:6px}
.cookie-banner__text{font-size:13px;color:rgba(255,255,255,.68);max-width:640px}
.cookie-banner__text a{color:var(--gold)}
.cookie-banner__actions{display:flex;align-items:center;gap:10px;justify-content:flex-end;flex-wrap:wrap}

/* ── Sticker editor ───────────────────────────────── */
.sticker-editor-shell{padding:40px 0 80px}
.sticker-editor-grid{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(340px,.95fr);
  gap:28px;align-items:start;
}
.sticker-editor-stage{
  background:var(--white);border:1px solid var(--paper-line);
  border-radius:var(--paper-radius);padding:22px;
  box-shadow:var(--paper-shadow);
}
.sticker-editor-stage canvas{
  width:100%;height:auto;border-radius:var(--r-lg);
  background:linear-gradient(180deg,#F8F2E8,#EDE1D0);
}
.sticker-editor-tools,.sticker-editor-panel{display:grid;gap:16px}
.sticker-card{
  background:var(--white);border:1px solid var(--paper-line);
  border-radius:var(--r-xl);padding:18px;
}
.sticker-card h3{
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:10px;font-weight:700;
}
.sticker-card p{font-size:12px;color:var(--ink-soft);line-height:1.7}
.sticker-catalog{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:10px;
}
.sticker-catalog button{
  border:1.5px solid var(--paper-line-strong);
  background:var(--white);border-radius:var(--r-lg);
  padding:8px;text-align:left;cursor:pointer;
  transition:transform .16s,box-shadow .16s,border-color .16s;
}
.sticker-catalog button:hover{
  transform:translateY(-2px);border-color:var(--ink);
  box-shadow:var(--paper-shadow-soft);
}
.sticker-catalog img{width:100%;height:94px;object-fit:cover;border-radius:var(--r-md);background:var(--surface-alt)}
.sticker-catalog strong{display:block;font-size:12px;margin-top:8px;font-weight:600}
.sticker-catalog span{display:block;font-size:11px;color:var(--ink-soft);margin-top:4px}
.sticker-assets{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:10px;
}
.sticker-assets button{
  border:1.5px solid var(--paper-line-strong);
  background:var(--white);border-radius:var(--r-md);
  padding:8px;cursor:pointer;
  transition:transform .16s,border-color .16s;
}
.sticker-assets button:hover{transform:translateY(-2px);border-color:var(--ink)}
.sticker-assets img{width:100%;height:70px;object-fit:contain}
.tool-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tool-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.tool-field label{
  display:block;font-size:11px;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:6px;
}
.tool-field input,.tool-field select,.tool-field textarea{width:100%}
.size-note{font-size:11px;color:var(--ink-soft)}
.tool-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ── Catalog page ─────────────────────────────────── */
.catalog-page .catalog-hero{
  background:radial-gradient(circle at top right,rgba(255,61,87,.16),transparent 22%),
    linear-gradient(135deg,#0D0D0D 0%,#1A1A2E 55%,#0D1020 100%);
  color:#fff;padding:80px 0 60px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.catalog-page .catalog-hero-grid{
  max-width:1400px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:end;
}
.catalog-page .hero-title{
  font-size:clamp(40px,5vw,70px);
  letter-spacing:-.04em;max-width:820px;
}
.catalog-page .hero-sub{max-width:690px;font-size:16px;color:rgba(255,255,255,.70)}
.catalog-page .catalog-shell{
  max-width:1400px;margin:0 auto;padding:40px 24px 84px;
  display:grid;grid-template-columns:300px minmax(0,1fr);gap:26px;align-items:start;
}
.catalog-page .catalog-filters{
  position:relative;top:auto;max-height:none;overflow:visible;
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);
  border-radius:var(--r-2xl);padding:24px;
  box-shadow:var(--paper-shadow);
}
.catalog-page .catalog-filters-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;padding-bottom:16px;margin-bottom:20px;
  border-bottom:1px solid var(--border);
}
.catalog-page .catalog-filters-kicker{
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:5px;
}
.catalog-page .catalog-filters-title{
  font-family:'DM Serif Display',serif;font-size:26px;
  line-height:1.05;letter-spacing:-.02em;color:var(--ink);
}
.catalog-page .catalog-filters-sub{
  font-size:13px;line-height:1.7;color:var(--ink-soft);margin-top:6px;
}
.catalog-page .catalog-reset-top{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:46px;height:46px;border-radius:var(--r-md);
  background:var(--surface-alt);border:1px solid var(--border);
  color:var(--ink);font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;
  transition:all .16s;
}
.catalog-page .catalog-reset-top:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.catalog-page .catalog-filter-stack{display:grid;gap:12px}
.catalog-page .catalog-filter-block{
  padding:14px 14px 12px;border:1px solid var(--border);
  border-radius:var(--r-lg);background:linear-gradient(180deg,var(--white),#FAF8F4);
}
.catalog-page .catalog-filter-title{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:10px;
}
.catalog-page .catalog-filter-note{font-size:12px;line-height:1.6;color:var(--ink-soft);margin:-2px 0 10px}
.catalog-page .catalog-search,
.catalog-page .catalog-select,
.catalog-page .catalog-price-input{
  width:100%;padding:12px 14px;
  border:1px solid var(--border-mid);border-radius:var(--r-md);
  background:#FCFBF8;font-size:14px;
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  min-height:46px;
  transition:border-color .16s;
}
.catalog-page .catalog-search:focus,
.catalog-page .catalog-select:focus,
.catalog-page .catalog-price-input:focus{
  outline:none;border-color:var(--ink);
  box-shadow:0 0 0 3px rgba(13,13,13,.08);
}
.catalog-page .catalog-price-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.catalog-page .catalog-range-group{display:grid;gap:10px}
.catalog-page .catalog-range-row{display:grid;gap:6px}
.catalog-page .catalog-range-head{
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;font-size:12px;color:var(--ink-soft);
}
.catalog-page .catalog-range-value{font-weight:700;color:var(--ink)}
.catalog-page .catalog-range-input{width:100%;accent-color:var(--ink)}
.catalog-page .catalog-check-list{
  display:grid;gap:8px;max-height:260px;overflow:auto;padding-right:4px;
  scrollbar-width:thin;
}
.catalog-page .catalog-check-list.is-chips{display:grid;grid-template-columns:1fr;gap:7px}
.catalog-page .catalog-check{
  display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft);
  padding:9px 12px;border-radius:var(--r-md);
  background:#FCFAF6;border:1px solid var(--border);
  transition:border-color .14s,background .14s;line-height:1.3;cursor:pointer;
}
.catalog-page .catalog-check:hover{border-color:var(--border-mid);background:var(--surface-alt)}
.catalog-page .catalog-check input{margin:0}
.catalog-page .catalog-check input[type="radio"],
.catalog-page .catalog-check input[type="checkbox"]{accent-color:var(--ink)}
.catalog-page .catalog-check span:last-child{flex:1}
.catalog-page .catalog-color-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}
.catalog-page .catalog-color-pill{
  display:flex;align-items:center;gap:8px;
  padding:9px 12px;border:1px solid var(--border);
  border-radius:999px;background:#FCFBF8;
  font-size:12px;transition:border-color .14s,transform .14s;cursor:pointer;
}
.catalog-page .catalog-color-pill:hover{border-color:var(--ink);transform:translateY(-1px)}
.catalog-page .catalog-color-dot{
  width:15px;height:15px;border-radius:50%;
  border:1px solid rgba(0,0,0,.14);flex-shrink:0;
}
.catalog-page .catalog-review-pills{display:grid;gap:7px}
.catalog-page .catalog-actions{display:grid;gap:10px}
.catalog-page .catalog-apply-btn{height:46px;padding:0 18px;border-radius:var(--r-md);width:100%}
.catalog-page .catalog-results-panel{
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);
  border-radius:var(--r-2xl);padding:26px;
  box-shadow:var(--paper-shadow);
}
.catalog-page .catalog-results-wrap{position:relative;min-height:320px}
.catalog-page .catalog-results-wrap.is-loading{opacity:.6}
.catalog-page .catalog-loader{
  position:absolute;inset:0;display:none;
  align-items:center;justify-content:center;
  background:rgba(244,241,236,.75);
  backdrop-filter:blur(2px);z-index:5;border-radius:var(--r-2xl);
}
.catalog-page .catalog-loader.is-visible{display:flex}
.catalog-page .catalog-loader-card{
  display:flex;align-items:center;gap:10px;padding:14px 18px;
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-md);
  font-size:13px;color:var(--ink-soft);
}
.catalog-page .catalog-spinner{
  width:17px;height:17px;border:2px solid rgba(0,0,0,.12);
  border-top-color:var(--accent);border-radius:50%;
  animation:catalogSpin .8s linear infinite;
}
@keyframes catalogSpin{to{transform:rotate(360deg)}}
.catalog-page .catalog-results-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:16px;margin-bottom:22px;padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.catalog-page .catalog-stats{display:flex;gap:12px;flex-wrap:wrap}
.catalog-page .catalog-stat{
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--border);border-radius:var(--r-xl);
  padding:12px 15px;min-width:140px;box-shadow:var(--shadow-xs);
}
.catalog-page .catalog-stat-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.catalog-page .catalog-stat-value{
  font-size:26px;font-family:'DM Serif Display',serif;
  color:var(--ink);margin-top:3px;
}
.catalog-page .catalog-active-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.catalog-page .catalog-chip{
  padding:7px 13px;border-radius:999px;
  background:var(--surface-alt);font-size:12px;
  color:var(--ink-mid);border:1px solid var(--border);
}
.catalog-page .catalog-empty{
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--border);border-radius:var(--r-2xl);
  padding:42px;text-align:center;box-shadow:var(--shadow-xs);
}
.catalog-page .catalog-products-grid .prod-card{height:100%}
.catalog-page .catalog-page-link{border-radius:var(--r-md) !important}

/* ── Catalog render pane from catalog-render.php ── */
.catalog-search,
.catalog-select,
.catalog-price-input{
  min-height:46px;
  border-color:var(--paper-line-strong) !important;
  background:#FCFBF8 !important;
}
.catalog-check-list{scrollbar-width:thin}
.catalog-color-pill{
  border-color:var(--paper-line-strong) !important;
  border-radius:14px !important;
  background:#FCFBF8 !important;
}
.catalog-results-wrap{border-radius:var(--r-2xl)}
.catalog-loader{border-radius:var(--r-2xl) !important}
.catalog-loader-card{border-radius:var(--r-lg) !important}
.catalog-stat{
  border:1px solid var(--paper-line) !important;
  border-radius:var(--r-xl) !important;
  box-shadow:var(--paper-shadow-soft);
  background:linear-gradient(180deg,var(--white),#FAFAF7) !important;
}
.catalog-stat-value{font-size:26px !important}
.catalog-chip{background:var(--surface-alt) !important;color:var(--ink-mid) !important}
.catalog-empty{
  border-radius:var(--r-2xl) !important;
  border-color:var(--paper-line) !important;
  box-shadow:var(--paper-shadow-soft);
  background:linear-gradient(180deg,var(--white),#FAFAF7) !important;
}
.catalog-page-link{border-radius:var(--r-md) !important}
.catalog-products-grid .prod-card{height:100%}

/* ── Account / order pages ────────────────────────── */
.account-layout{
  gap:28px !important;margin-top:40px !important;margin-bottom:54px !important;
}
.account-sidebar{
  border-radius:var(--paper-radius);padding:10px 0 !important;
  position:sticky;top:calc(var(--nav-h) + 22px);
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);box-shadow:var(--paper-shadow-soft);
}
.acc-card{
  border-radius:var(--paper-radius);padding:26px !important;
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  border:1px solid var(--paper-line);box-shadow:var(--paper-shadow-soft);
}
.acc-nav-link{border-left:3px solid transparent}
.acc-nav-link:hover,.acc-nav-link.active{background:var(--surface-alt) !important}
.addr-card{
  background:linear-gradient(180deg,var(--surface),var(--surface-alt)) !important;
  border:1px solid var(--paper-line);border-radius:var(--r-lg) !important;
}
.order-row{padding:16px 0 !important}
.order-preview{border-radius:var(--r-md) !important}
.order-detail-item{padding:16px 0 !important}
.order-detail-thumb{
  border-radius:var(--r-md) !important;
  background:linear-gradient(180deg,var(--surface),var(--surface-alt)) !important;
}
.order-detail-name{font-size:15px !important}

/* Shared panel card */
.panel-card{
  border:1px solid var(--paper-line);border-radius:var(--paper-radius);
  background:linear-gradient(180deg,var(--white),#FAFAF7);
  box-shadow:var(--paper-shadow-soft);
}
.panel-card h3{color:var(--ink-soft)}

/* ── Utilities ────────────────────────────────────── */
.hidden{display:none!important}
.loading{opacity:.6;pointer-events:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.text-gold{color:var(--gold)}
.text-muted{color:var(--ink-soft)}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}

/* ── Spinner ──────────────────────────────────────── */
.spinner{
  display:inline-block;width:15px;height:15px;
  border:2px solid rgba(13,13,13,.15);
  border-top-color:var(--ink);
  border-radius:50%;animation:spin .7s linear infinite;
}
.spinner-light{border-color:rgba(255,255,255,.18);border-top-color:#fff}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Responsive ───────────────────────────────────── */
@media(max-width:1100px){
  .prod-grid{grid-template-columns:repeat(3,1fr)}
  .editor-layout{grid-template-columns:1fr 300px}
  .checkout-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .legal-quickfacts{grid-template-columns:1fr}
  .order-summary-card,.account-sidebar{position:static;top:auto}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .trust-items{justify-content:flex-start}
  .ai-banner-inner{grid-template-columns:1fr}
  .catalog-page .catalog-shell{grid-template-columns:1fr;padding-top:0}
  .catalog-page .catalog-filters{border-radius:var(--r-xl)}
  .home-banner-slot--wide{aspect-ratio:18/7}
}
@media(max-width:768px){
  .hero{min-height:auto}
  .hero-content{grid-template-columns:1fr;padding:56px 20px}
  .hero-banner-media::after{
    background:linear-gradient(180deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.9) 38%,rgba(255,255,255,.7) 100%);
  }
  .hero-banner-image{object-position:68% center}
  .hero-banner .hero-content{grid-template-columns:1fr;gap:24px}
  .home-banner-grid{grid-template-columns:1fr;gap:14px}
  .home-banner-slot--card,
  .home-banner-slot--wide{min-height:200px;aspect-ratio:auto}
  .home-banner-caption strong{font-size:22px}
  .hero-canvas-preview{display:none}
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .editor-layout{grid-template-columns:1fr}
  .admin-stat-grid{grid-template-columns:repeat(2,1fr)}
  .site-nav{height:auto}
  .site-nav .inner{
    height:auto;flex-wrap:wrap;
    padding-top:10px;padding-bottom:10px;gap:12px;
  }
  .nav-links{
    display:flex;order:3;width:100%;
    overflow-x:auto;padding-bottom:2px;scrollbar-width:none;
  }
  .nav-actions{margin-left:auto}
  .cookie-banner{left:12px;right:12px;bottom:12px}
  .cookie-banner__inner{grid-template-columns:1fr}
  .legal-shell{margin-top:-20px;padding-bottom:48px}
  .legal-nav{justify-content:flex-start;padding:16px}
  .legal-card{padding:26px 20px}
  .sticker-editor-grid{grid-template-columns:1fr}
  .trust-item{min-width:unset;width:calc(50% - 7px)}
}
@media(max-width:480px){
  .prod-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  #cart-drawer{width:100%}
  .trust-item{width:100%}
}
