/* Good Weed Co - theme system
   Two switchable base themes share component styles; only variables + a few
   accents change. Everything wraps; nothing overflows its box. */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Familjen+Grotesk:wght@400;500;600;700&display=swap');

:root {
  --font-display: 'Syne', 'Familjen Grotesk', system-ui, sans-serif;
  --font-body: 'Familjen Grotesk', system-ui, -apple-system, sans-serif;
  --radius: 16px;
  --radius-sm: 11px;
  --maxw: 1240px;

  /* ---------- DARK (default): cannabis green on charcoal/black ---------- */
  --bg0: #0a0e0b;
  --bg1: #10160f;
  --bg-radial: radial-gradient(1100px 620px at 80% -14%, rgba(38,86,48,.22), transparent 60%),
               radial-gradient(820px 560px at 8% 112%, rgba(28,60,36,.16), transparent 55%);
  --panel: rgba(255,255,255,.045);
  --panel-2: rgba(255,255,255,.075);
  --panel-solid: #161d16;
  --stroke: rgba(255,255,255,.10);
  --stroke-strong: rgba(124,211,137,.42);
  --text: #e9f1ea;
  --muted: #9aab9d;
  --field-bg: rgba(0,0,0,.30);
  --accent: #4caf50;        /* green */
  --accent-2: #7bd389;      /* light green */
  --accent-3: #b8e6c0;      /* lighter green */
  --on-accent: #06140a;     /* text on green */
  --glow: 0 14px 44px -24px rgba(76,175,80,.55);
  --card-glow: 0 20px 52px -30px rgba(76,175,80,.5);
  --sativa: #9ccc65;        /* light green */
  --indica: #3f7d54;        /* deep green */
  --hybrid: #5cc98a;        /* medium green */
  --topbar-bg: linear-gradient(to bottom, rgba(0,0,0,.62), rgba(0,0,0,.2));
  --overlay: rgba(4,8,5,.74);
  --price-bg: #2f8f3e;
  --price-text: #ffffff;
}

/* ---------- LIGHT MODE ---------- */
body[data-mode="light"] {
  --bg0: #eef3ec;
  --bg1: #f8faf6;
  --bg-radial: radial-gradient(1100px 620px at 80% -14%, rgba(120,200,140,.18), transparent 60%),
               radial-gradient(820px 560px at 8% 112%, rgba(150,210,165,.14), transparent 55%);
  --panel: #ffffff;
  --panel-2: #ffffff;
  --panel-solid: #ffffff;
  --stroke: #dde6dd;
  --stroke-strong: #9bd3a6;
  --text: #13251a;
  --muted: #5c6b60;
  --field-bg: #f1f5ef;
  --accent: #2f8f3e;
  --accent-2: #43a64f;
  --accent-3: #6cc47a;
  --on-accent: #ffffff;
  --glow: 0 14px 40px -26px rgba(47,143,62,.4);
  --card-glow: 0 16px 42px -30px rgba(47,143,62,.32);
  --sativa: #5a8f2e;
  --indica: #2f6e45;
  --hybrid: #2f8f5a;
  --topbar-bg: linear-gradient(to bottom, rgba(255,255,255,.92), rgba(255,255,255,.62));
  --overlay: rgba(20,40,28,.5);
  --price-bg: #2f8f3e;
  --price-text: #ffffff;
}

/* ---------- base ---------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background: var(--bg-radial), linear-gradient(160deg, var(--bg1), var(--bg0));
  background-attachment: fixed;
  color: var(--text);
  min-height: 100vh;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-wrap: break-word;
  word-break: break-word;
}
a { color: var(--accent); text-decoration: none; }
h1,h2,h3 { font-family: var(--font-display); line-height: 1.08; margin: 0 0 .4em; letter-spacing: -.01em; }
p { margin: 0 0 .8em; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }

/* ---------- top bar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; gap: 14px;
  padding: 12px 22px;
  background: var(--topbar-bg);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--stroke);
}
/* circular logo (white-bg artwork clipped to a circle) */
.logo {
  width: 42px; height: 42px; flex: none; border-radius: 50%;
  object-fit: cover; background: #fff; border: 1px solid var(--stroke-strong);
  box-shadow: var(--glow);
}
.logo-sm { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; background: #fff;
  border: 1px solid var(--stroke-strong); vertical-align: middle; flex: none; }
.title-row { display: inline-flex; align-items: center; gap: 12px; justify-content: center; }
.brand {
  font-family: var(--font-display); font-weight: 800; font-size: 1.35rem;
  letter-spacing: .02em;
  background: linear-gradient(92deg, var(--accent), var(--accent-2) 60%, var(--accent-3));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  filter: drop-shadow(0 0 16px color-mix(in srgb, var(--accent) 45%, transparent));
}
.brand small { display:block; font-family: var(--font-body); font-weight:500; font-size:.62rem;
  letter-spacing:.32em; text-transform:uppercase; color: var(--muted); -webkit-text-fill-color: var(--muted); }
.topbar .spacer { flex: 1; }
.navlink { color: var(--muted); font-weight: 600; padding: 8px 12px; border-radius: 10px; }
.navlink:hover { color: var(--text); background: var(--panel); }

/* ---------- hero ---------- */
.hero { padding: 40px 0 22px; text-align: center; }
.hero h1 {
  font-size: clamp(1.5rem, 3.4vw, 2.4rem); font-weight: 800; text-transform: uppercase;
  color: var(--text); letter-spacing: .01em; margin: 0;
}
.hero p { color: var(--muted); font-size: .98rem; max-width: 600px; margin: 10px auto 0; }

/* ---------- buttons ---------- */
.btn {
  font-family: var(--font-body); font-weight: 700; font-size: .92rem;
  border: 1px solid var(--stroke-strong); border-radius: 12px;
  padding: 11px 18px; cursor: pointer; color: var(--text);
  background: var(--panel-2); transition: transform .12s, box-shadow .2s, background .2s;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--glow); }
.btn.primary {
  border: none; color: var(--on-accent);
  background: linear-gradient(95deg, var(--accent), var(--accent-2));
}
.btn.ghost { background: transparent; }
.btn.danger { border-color: #ff6b6b66; color: #ff9a9a; }
.btn.sm { padding: 7px 12px; font-size: .82rem; }
.btn:disabled { opacity: .5; cursor: not-allowed; }
/* light/dark mode toggle */
.modetoggle {
  flex: none; display: inline-flex; align-items: center; gap: 7px;
  background: var(--panel-2); border: 1px solid var(--stroke); color: var(--text);
  border-radius: 999px; padding: 7px 13px; cursor: pointer; font-weight: 700; font-size: .82rem;
}
.modetoggle:hover { box-shadow: var(--glow); }
.modetoggle .dot { width: 12px; height: 12px; border-radius: 50%;
  background: linear-gradient(120deg, var(--accent-3), var(--accent)); box-shadow: 0 0 8px var(--accent); }

/* ---------- glass cards / grid ---------- */
.grid { display: grid; gap: 20px; grid-template-columns: repeat(auto-fill, minmax(248px, 1fr)); padding: 16px 0 60px; }
.card {
  position: relative; border-radius: var(--radius); overflow: hidden;
  background: var(--panel); border: 1px solid var(--stroke);
  backdrop-filter: blur(12px); transition: transform .16s, box-shadow .25s, border-color .25s;
  display: flex; flex-direction: column;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--card-glow); border-color: var(--stroke-strong); }
.card .thumb {
  position: relative;
  aspect-ratio: 4/3; background: #00000040 center/cover no-repeat;
  display: grid; place-items: center; border-bottom: 1px solid var(--stroke);
}
.card .thumb .flavor-sticker {
  position: absolute; right: 8px; bottom: 8px; height: 44px; width: auto;
  border-radius: 8px; border: 1px solid var(--stroke); background: #ffffffcc; padding: 2px;
  box-shadow: 0 4px 14px -6px #000;
}
.card .thumb .noimg { color: var(--muted); font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; }
.card .body { padding: 14px 15px 50px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.card .body .row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.card .name { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; color: var(--text); }
.card .brand { color: var(--muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; }
/* uniform price tag — base look (also used inline in the product modal) */
.pricebox {
  background: var(--price-bg); color: var(--price-text);
  font-weight: 800; font-size: .98rem; line-height: 1;
  padding: 7px 11px; border-radius: 10px; white-space: nowrap; display: inline-block;
}
/* pinned to the bottom-right corner of every card */
.card .pricebox {
  position: absolute; right: 12px; bottom: 12px; z-index: 2;
  box-shadow: 0 6px 16px -8px rgba(0,0,0,.6);
}
.card .desc { color: var(--muted); font-size: .86rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card .pills { display: flex; flex-wrap: wrap; gap: 6px; }

/* type + stat pills */
.pill { font-size: .7rem; font-weight: 700; padding: 4px 9px; border-radius: 999px; letter-spacing: .06em; text-transform: uppercase; border: 1px solid var(--stroke); }
.pill.sativa { color: var(--sativa); border-color: color-mix(in srgb, var(--sativa) 45%, transparent); box-shadow: 0 0 14px -4px var(--sativa); }
.pill.indica { color: var(--indica); border-color: color-mix(in srgb, var(--indica) 45%, transparent); box-shadow: 0 0 14px -4px var(--indica); }
.pill.hybrid { color: var(--hybrid); border-color: color-mix(in srgb, var(--hybrid) 45%, transparent); box-shadow: 0 0 14px -4px var(--hybrid); }
.pill.thc { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 40%, transparent); }
.pill.muted { color: var(--muted); }
.rating { color: var(--sativa); font-weight: 700; font-size: .82rem; }
.rating small { color: var(--muted); font-weight: 500; }

/* ---------- modal ---------- */
.modal-back {
  position: fixed; inset: 0; z-index: 90; display: none;
  background: var(--overlay); backdrop-filter: blur(6px);
  align-items: center; justify-content: center; padding: 20px;
}
.modal-back.open { display: flex; }
.modal {
  width: min(720px, 100%); max-height: 88vh; overflow: auto;
  background: linear-gradient(170deg, var(--panel-2), var(--panel));
  border: 1px solid var(--stroke-strong); border-radius: var(--radius);
  box-shadow: var(--card-glow); padding: 0;
}
.modal .mhead { display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
  padding: 20px 22px 0; }
.modal .mhead h2 { font-size: 1.7rem; }
.modal .mbody { padding: 16px 22px 24px; }
.modal .x { background: var(--panel); border: 1px solid var(--stroke); color: var(--text);
  width: 34px; height: 34px; border-radius: 10px; cursor: pointer; font-size: 1.1rem; line-height: 1; flex: none; }
.modal .x:hover { box-shadow: var(--glow); }
/* product image in modal: show the WHOLE image, never cropped/zoomed */
.modal .hero-win {
  width: 100%; border-radius: var(--radius-sm); border: 1px solid var(--stroke);
  background: var(--field-bg); margin-bottom: 12px; overflow: hidden;
  display: grid; place-items: center;
}
.modal .hero-img {
  display: block; max-width: 100%; max-height: 62vh; width: auto; height: auto;
  object-fit: contain; cursor: zoom-in;
}
.budbtn { margin-bottom: 12px; }
/* full-resolution lightbox: image at natural size in a scrollable window */
.imglb-back {
  position: fixed; inset: 0; z-index: 120; display: none;
  background: rgba(0,0,0,.9); padding: 24px;
}
.imglb-back.open { display: flex; align-items: center; justify-content: center; }
.imglb-win { max-width: 96vw; max-height: 92vh; overflow: auto; border-radius: 12px;
  box-shadow: 0 30px 80px -20px #000; background: #0a0e0b; }
.imglb-win img { display: block; max-width: none; } /* native resolution */
.imglb-cap { position: fixed; top: 16px; left: 50%; transform: translateX(-50%);
  color: #fff; font-weight: 700; font-size: .9rem; background: rgba(0,0,0,.5);
  padding: 6px 14px; border-radius: 999px; }
.imglb-x { position: fixed; top: 14px; right: 18px; width: 40px; height: 40px; border-radius: 12px;
  background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.25);
  font-size: 1.3rem; cursor: pointer; line-height: 1; }
.imglb-fit img { max-width: 92vw; max-height: 88vh; width: auto; height: auto; } /* fit-to-screen mode */
.kv { display: grid; grid-template-columns: 130px 1fr; gap: 6px 14px; margin: 10px 0; }
.kv dt { color: var(--muted); font-size: .82rem; }
.kv dd { margin: 0; font-weight: 600; }
.chips { display: flex; flex-wrap: wrap; gap: 7px; margin: 4px 0 2px; }
.chip { font-size: .76rem; padding: 5px 11px; border-radius: 999px; background: var(--panel);
  border: 1px solid var(--stroke); color: var(--text); }
.section-label { font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin: 16px 0 6px; }

/* ---------- bag / cart ---------- */
.card .addrow { position: absolute; left: 12px; bottom: 12px; right: 64px; z-index: 2; }
.addbtn { width: 100%; padding: 8px 10px; font-size: .82rem; font-weight: 800; border: none; border-radius: 10px;
  background: linear-gradient(95deg, var(--accent), var(--accent-2)); color: var(--on-accent); cursor: pointer; }
.addbtn:hover { box-shadow: var(--glow); }
.stepper { display: inline-flex; align-items: center; gap: 0; border: 1px solid var(--stroke-strong);
  border-radius: 10px; overflow: hidden; background: var(--panel-2); }
.stepper button { width: 32px; height: 34px; border: none; background: transparent; color: var(--text);
  font-size: 1.1rem; cursor: pointer; line-height: 1; }
.stepper button:hover { background: var(--accent); color: var(--on-accent); }
.stepper .q { min-width: 30px; text-align: center; font-weight: 800; font-size: .9rem; }
.cart-btn { position: relative; }
.cart-badge { position: absolute; top: -6px; right: -8px; min-width: 18px; height: 18px; padding: 0 5px;
  border-radius: 999px; background: var(--accent); color: var(--on-accent); font-size: .68rem; font-weight: 800;
  display: none; align-items: center; justify-content: center; line-height: 18px; }
.cart-badge.show { display: inline-flex; }

.bag-back { position: fixed; inset: 0; z-index: 100; display: none; background: var(--overlay); }
.bag-back.open { display: block; }
.bag {
  position: absolute; top: 0; right: 0; height: 100%; width: min(420px, 100%);
  background: linear-gradient(180deg, var(--panel-2), var(--panel)); border-left: 1px solid var(--stroke-strong);
  display: flex; flex-direction: column; box-shadow: -20px 0 60px -30px #000;
  transform: translateX(100%); transition: transform .22s ease;
}
.bag-back.open .bag { transform: translateX(0); }
.bag header { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px;
  border-bottom: 1px solid var(--stroke); }
.bag header h2 { margin: 0; font-size: 1.25rem; }
.bag .bag-items { flex: 1; overflow: auto; padding: 8px 18px; }
.bag-item { display: grid; grid-template-columns: 52px 1fr auto; gap: 10px; align-items: center; padding: 11px 0;
  border-bottom: 1px solid var(--stroke); }
.bag-item .bi-thumb { width: 52px; height: 52px; border-radius: 9px; background: var(--field-bg) center/cover no-repeat;
  border: 1px solid var(--stroke); }
.bag-item .bi-name { font-weight: 700; font-size: .92rem; }
.bag-item .bi-sub { color: var(--muted); font-size: .78rem; }
.bag-foot { border-top: 1px solid var(--stroke); padding: 14px 18px 18px; }
.bag-foot .ln { display: flex; justify-content: space-between; font-size: .9rem; margin: 4px 0; color: var(--muted); }
.bag-foot .ln.total { color: var(--text); font-weight: 800; font-size: 1.1rem; margin-top: 8px;
  border-top: 1px solid var(--stroke); padding-top: 10px; }
.bag-empty { text-align: center; color: var(--muted); padding: 50px 16px; }
.seg { display: inline-flex; border: 1px solid var(--stroke-strong); border-radius: 10px; overflow: hidden; }
.seg button { border: none; background: transparent; color: var(--text); padding: 9px 14px; cursor: pointer; font-weight: 700; font-size: .85rem; }
.seg button.on { background: var(--accent); color: var(--on-accent); }

/* ---------- forms / admin ---------- */
.panel { background: var(--panel); border: 1px solid var(--stroke); border-radius: var(--radius);
  backdrop-filter: blur(12px); padding: 20px 22px; margin-bottom: 18px; }
.panel h2 { font-size: 1.25rem; }
label { display: block; font-size: .82rem; color: var(--muted); margin: 12px 0 5px; font-weight: 600; }
input, select, textarea {
  width: 100%; font-family: var(--font-body); font-size: .95rem; color: var(--text);
  background: var(--field-bg); border: 1px solid var(--stroke); border-radius: 11px; padding: 11px 13px;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); box-shadow: var(--glow); }
textarea { resize: vertical; min-height: 84px; }
.field-row { display: grid; gap: 14px; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.checks { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 6px; }
.check { display: flex; align-items: center; gap: 8px; font-size: .9rem; color: var(--text); cursor: pointer; }
.check input { width: auto; }

table.tbl { width: 100%; border-collapse: collapse; }
table.tbl th { text-align: left; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); padding: 10px 12px; border-bottom: 1px solid var(--stroke); }
table.tbl td { padding: 11px 12px; border-bottom: 1px solid var(--stroke); vertical-align: middle; }
table.tbl tr:hover td { background: var(--panel); }
.tag-off { color: #ff9a9a; } .tag-on { color: var(--hybrid); }

.toggle { position: relative; width: 44px; height: 24px; flex: none; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle .tr { position: absolute; inset: 0; background: rgba(255,255,255,.12); border-radius: 999px; transition: .2s; }
.toggle .tr:before { content: ''; position: absolute; height: 18px; width: 18px; left: 3px; top: 3px;
  background: #fff; border-radius: 50%; transition: .2s; }
.toggle input:checked + .tr { background: linear-gradient(95deg, var(--accent), var(--accent-2)); }
.toggle input:checked + .tr:before { transform: translateX(20px); }

.notice { padding: 11px 14px; border-radius: 11px; font-size: .88rem; margin: 10px 0;
  border: 1px solid var(--stroke); background: var(--panel); }
.notice.err { border-color: #ff6b6b66; color: #ffb3b3; }
.notice.ok { border-color: color-mix(in srgb, var(--hybrid) 45%, transparent); color: var(--hybrid); }

.age-card { width: min(440px, 100%); text-align: center; }
.spin { display:inline-block; width:16px; height:16px; border:2px solid rgba(255,255,255,.3);
  border-top-color: var(--accent); border-radius:50%; animation: sp .7s linear infinite; vertical-align:-3px; }
@keyframes sp { to { transform: rotate(360deg); } }

.muted { color: var(--muted); }
.flex { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.right { margin-left: auto; }
.empty { text-align:center; color: var(--muted); padding: 50px 0; }

/* ---------- mobile: no overlap, everything wraps ---------- */
@media (max-width: 640px) {
  .topbar { padding: 12px 14px; gap: 8px; flex-wrap: wrap; }
  .brand { font-size: 1.1rem; }
  .wrap { padding: 0 14px; }
  .hero { padding: 34px 0 18px; }
  .grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 13px; }
  .kv { grid-template-columns: 1fr; gap: 2px 0; }
  .kv dt { margin-top: 8px; }
  .modal .mhead h2 { font-size: 1.3rem; }
  .field-row { grid-template-columns: 1fr 1fr; }
  table.tbl thead { display: none; }
  table.tbl, table.tbl tbody, table.tbl tr, table.tbl td { display: block; width: 100%; }
  table.tbl tr { border: 1px solid var(--stroke); border-radius: 12px; margin-bottom: 12px; padding: 6px 4px; }
  table.tbl td { border: none; padding: 6px 12px; }
  table.tbl td::before { content: attr(data-l); display: block; font-size: .68rem;
    letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
}

/* ============================================================
   PHASE 2 — page renderer elements (shared editor + storefront)
   ============================================================ */
.gw-scaler { width: 100%; overflow: hidden; }
.gw-stage { position: relative; margin: 0 auto; }
.gw-el { position: absolute; box-sizing: border-box; }
.gw-text-inner {
  width: 100%; height: 100%; overflow: hidden;
  overflow-wrap: anywhere; word-break: break-word; white-space: pre-wrap;
  display: flex; flex-direction: column; justify-content: center;
}
.gw-pagebtn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%; height: 100%; padding: 0 18px; text-align: center;
  cursor: pointer; border: none; text-decoration: none; line-height: 1.1;
  overflow-wrap: anywhere; transition: transform .15s, filter .15s;
}
.gw-pagebtn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.gw-el-empty {
  display: flex; align-items: center; justify-content: center;
  border: 1px dashed var(--stroke-strong); border-radius: 12px;
  color: var(--muted); background: var(--panel);
}
.gw-el-menu { box-sizing: border-box; }
.gw-menu-grid { display: grid; gap: 16px; align-content: start; }
.gw-menu-placeholder {
  width: 100%; height: 100%; display: flex; flex-direction: column;
  align-items: center; justify-content: center; text-align: center;
  border: 1px dashed var(--stroke-strong); border-radius: 16px;
  color: var(--muted); background: var(--panel); font-family: var(--font-display);
}
.gw-modal-canvas { position: relative; margin: 0 auto; max-width: 100%; }

/* ============================================================
   PHASE 2 — editor chrome
   ============================================================ */
.editor-body { overflow: hidden; height: 100vh; }
.ed-top {
  display: flex; align-items: center; gap: 12px; padding: 10px 16px;
  background: linear-gradient(to bottom, rgba(0,0,0,.6), rgba(0,0,0,.25));
  border-bottom: 1px solid var(--stroke); backdrop-filter: blur(12px);
  position: sticky; top: 0; z-index: 50;
}
.ed-title { font-family: var(--font-display); font-weight: 800; font-size: 1.05rem; display: flex; flex-direction: column; }
.ed-title small { font-weight: 500; color: var(--muted); font-size: .7rem; }
.ed-spacer { flex: 1; }
.ed-seg { display: inline-flex; border: 1px solid var(--stroke); border-radius: 10px; overflow: hidden; }
.ed-seg button {
  background: transparent; color: var(--muted); border: none; padding: 7px 14px;
  font: inherit; font-size: .82rem; cursor: pointer;
}
.ed-seg button.active { background: var(--panel-2); color: var(--text); }
.ed-zoom { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); font-size: .8rem; }
.ed-zoom button {
  width: 26px; height: 26px; border: 1px solid var(--stroke); background: var(--panel);
  color: var(--text); border-radius: 7px; cursor: pointer; font-size: .9rem;
}
.ed-zoom #zFit { width: auto; padding: 0 10px; }
.ed-zoom #zLabel { min-width: 34px; text-align: center; }

.ed-main { display: grid; grid-template-columns: 230px 1fr 290px; height: calc(100vh - 53px); }
.ed-rail, .ed-props { overflow-y: auto; background: rgba(0,0,0,.22); }
.ed-rail { border-right: 1px solid var(--stroke); padding: 14px; }
.ed-props { border-left: 1px solid var(--stroke); padding: 14px; }
.ed-group { margin-bottom: 18px; }
.ed-grouphd { font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.ed-add { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ed-add button {
  padding: 10px 8px; border: 1px solid var(--stroke); background: var(--panel);
  color: var(--text); border-radius: 10px; cursor: pointer; font: inherit; font-size: .82rem;
}
.ed-add button:hover { border-color: var(--accent); }
.ed-layers { display: flex; flex-direction: column; gap: 6px; }
.ed-layer {
  display: flex; align-items: center; gap: 8px; padding: 7px 9px;
  border: 1px solid var(--stroke); border-radius: 9px; background: var(--panel); font-size: .8rem;
}
.ed-layer.sel { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.ed-ltype { font-size: .6rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); cursor: pointer; }
.ed-lname { flex: 1; cursor: pointer; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ed-lacts button {
  width: 22px; height: 22px; border: none; background: transparent; color: var(--muted);
  cursor: pointer; border-radius: 5px; font-size: .8rem;
}
.ed-lacts button:hover { background: var(--panel-2); color: var(--text); }

.ed-stagewrap { overflow: auto; padding: 32px; background:
  repeating-linear-gradient(45deg, rgba(255,255,255,.012) 0 10px, transparent 10px 20px), rgba(0,0,0,.15); }
.ed-scaler { margin: 0 auto; }
.ed-stage.ed-stage {
  background: var(--bg-radial), linear-gradient(160deg, var(--bg1), var(--bg0));
  outline: 1px solid var(--stroke); box-shadow: 0 40px 120px -50px #000;
}
.ed-stage.is-modal { background: var(--panel-2); border-radius: 16px; outline: 1px solid var(--stroke-strong); }
.ed-stage .gw-el { cursor: move; }
.ed-stage .gw-el.selected { outline: 1.5px solid var(--accent); outline-offset: 1px; }
.ed-stage .gw-el .gw-pagebtn { cursor: move; }
.ed-handle { position: absolute; background: var(--accent); border: 2px solid #04140f; }
.ed-resize { width: 14px; height: 14px; right: -7px; bottom: -7px; border-radius: 3px; cursor: nwse-resize; }
.ed-rot { width: 14px; height: 14px; left: 50%; top: -26px; margin-left: -7px; border-radius: 50%; cursor: grab; }
.ed-rot::after { content: ''; position: absolute; left: 50%; top: 14px; width: 1px; height: 12px; background: var(--accent); }

.ed-phd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.ed-pacts button {
  border: 1px solid var(--stroke); background: var(--panel); color: var(--text);
  border-radius: 7px; padding: 4px 9px; font-size: .72rem; cursor: pointer; margin-left: 5px;
}
.ed-pacts button:hover { border-color: var(--accent); }
.ed-field { display: flex; flex-direction: column; gap: 4px; margin-bottom: 10px; font-size: .78rem; color: var(--muted); }
.ed-field > span { font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; }
.ed-field input, .ed-field select, .ed-field textarea {
  width: 100%; background: var(--panel); border: 1px solid var(--stroke); color: var(--text);
  border-radius: 8px; padding: 7px 9px; font: inherit; font-size: .82rem;
}
.ed-field textarea { resize: vertical; }
.ed-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ed-grid2 > input { width: 100%; background: var(--panel); border: 1px solid var(--stroke); color: var(--text); border-radius: 8px; padding: 7px 9px; font: inherit; font-size: .82rem; margin-bottom: 10px; }
.ed-color { display: flex; gap: 6px; align-items: center; }
.ed-color input[type=color] { width: 34px; height: 34px; padding: 2px; flex: 0 0 auto; }
.ed-color input[type=text] { flex: 1; }
.ed-thumb { height: 90px; border-radius: 10px; background-size: cover; background-position: center; border: 1px solid var(--stroke); margin-bottom: 10px; }
.btn.full, .full { width: 100%; }

@media (max-width: 900px) {
  .ed-main { grid-template-columns: 1fr; grid-template-rows: auto 1fr; }
  .ed-rail { display: none; }
  .ed-props { position: fixed; right: 0; top: 53px; bottom: 0; width: 280px; z-index: 30; }
}

/* import-from-URL results list */
.imp-list { display: flex; flex-direction: column; gap: 8px; max-height: 340px; overflow-y: auto; padding-right: 4px; }
.imp-item { display: flex; align-items: center; gap: 10px; padding: 8px; border: 1px solid var(--stroke); border-radius: 10px; background: var(--panel); }
.imp-thumb { width: 46px; height: 46px; flex: 0 0 auto; border-radius: 8px; background-size: cover; background-position: center; background-color: var(--panel-2); }
.imp-thumb.noimg { display: flex; align-items: center; justify-content: center; color: var(--muted); }
.imp-fields { flex: 1; display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.imp-name { width: 100%; }

/* ============================================================
   PHASE 3 — point of sale / kiosk
   ============================================================ */
.pos-grid { display: grid; grid-template-columns: 1fr 380px; gap: 18px; max-width: var(--maxw); margin: 0 auto; padding: 18px 18px 40px; align-items: start; }
.pos-catalog { min-width: 0; }
.pos-tools { position: sticky; top: 64px; z-index: 5; padding-bottom: 10px; background: linear-gradient(to bottom, var(--bg0) 70%, transparent); }
.pos-search { width: 100%; font-size: 1rem; padding: 12px 14px; border-radius: 12px; background: var(--panel); border: 1px solid var(--stroke); color: var(--text); }
.pos-cats { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.pos-chip { padding: 8px 14px; border-radius: 999px; border: 1px solid var(--stroke); background: var(--panel); color: var(--muted); cursor: pointer; font: inherit; font-size: .85rem; }
.pos-chip.on { background: var(--accent); color: #06120f; border-color: transparent; font-weight: 700; }

.pos-products { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; margin-top: 6px; }
.pos-card { text-align: left; padding: 0; overflow: hidden; border-radius: 16px; border: 1px solid var(--stroke); background: var(--panel); color: var(--text); cursor: pointer; transition: transform .12s, border-color .12s, box-shadow .12s; display: flex; flex-direction: column; }
.pos-card:hover { transform: translateY(-2px); border-color: var(--accent); box-shadow: var(--card-glow); }
.pos-card:active { transform: scale(.98); }
.pos-card-img { height: 96px; background-size: cover; background-position: center; background-color: var(--panel-2); position: relative; display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: .75rem; }
.pos-incart { position: absolute; top: 6px; right: 6px; background: var(--accent); color: #06120f; font-weight: 800; min-width: 24px; height: 24px; border-radius: 12px; display: flex; align-items: center; justify-content: center; padding: 0 6px; font-size: .85rem; }
.pos-card-body { padding: 10px 12px; display: flex; flex-direction: column; gap: 6px; }
.pos-card-name { font-family: var(--font-display); font-weight: 700; font-size: .98rem; line-height: 1.15; }
.pos-card-meta { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pos-card-price { font-weight: 800; color: var(--accent); }
.pos-card-stock { font-size: .72rem; color: var(--muted); }

.pos-cart { position: sticky; top: 64px; background: var(--panel); border: 1px solid var(--stroke); border-radius: 18px; padding: 16px; display: flex; flex-direction: column; }
.pos-cart h2 { margin: 0 0 10px; }
.pos-lines { display: flex; flex-direction: column; gap: 8px; max-height: 42vh; overflow-y: auto; }
.pos-line { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center; padding: 8px; border: 1px solid var(--stroke); border-radius: 12px; background: var(--panel-2); }
.pos-line-name { font-size: .9rem; display: flex; flex-direction: column; }
.pos-line-name small { color: var(--muted); font-size: .72rem; }
.pos-qty { display: inline-flex; align-items: center; gap: 8px; }
.pos-qty button { width: 30px; height: 30px; border-radius: 8px; border: 1px solid var(--stroke); background: var(--panel); color: var(--text); font-size: 1.1rem; cursor: pointer; }
.pos-qty button:hover { border-color: var(--accent); }
.pos-line-tot { font-weight: 700; min-width: 60px; text-align: right; }

.pos-totals { margin-top: 12px; border-top: 1px solid var(--stroke); padding-top: 10px; }
.pos-trow { display: flex; justify-content: space-between; align-items: center; padding: 4px 0; color: var(--muted); }
.pos-trow.pos-grand { color: var(--text); font-size: 1.3rem; font-weight: 800; border-top: 1px solid var(--stroke); margin-top: 6px; padding-top: 10px; }
.pos-disc input, .pos-tender { width: 110px; text-align: right; padding: 6px 8px; border-radius: 8px; background: var(--panel-2); border: 1px solid var(--stroke); color: var(--text); }
.pos-change { color: var(--text); font-weight: 700; }

.pos-pay { margin-top: 12px; }
.pos-methods { display: grid; grid-template-columns: repeat(auto-fit, minmax(70px, 1fr)); gap: 8px; }
.pos-method { padding: 12px 6px; border-radius: 12px; border: 1px solid var(--stroke); background: var(--panel-2); color: var(--text); cursor: pointer; font: inherit; font-weight: 600; }
.pos-method.on { background: var(--accent); color: #06120f; border-color: transparent; }
.pos-cashlabel { display: block; font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin: 10px 0 4px; }
.pos-tender { width: 100%; font-size: 1.1rem; }
.pos-charge { width: 100%; margin-top: 14px; font-size: 1.15rem; padding: 14px; }

/* receipt */
.receipt { background: #fff; color: #111; border-radius: 12px; padding: 16px; font-family: 'Courier New', monospace; }
.rc-head { display: flex; flex-direction: column; gap: 2px; text-align: center; margin-bottom: 8px; }
.rc-items { border-top: 1px dashed #999; border-bottom: 1px dashed #999; padding: 8px 0; margin: 8px 0; }
.rc-row { display: flex; justify-content: space-between; padding: 2px 0; font-size: .9rem; }
.rc-total { font-weight: 800; border-top: 1px dashed #999; margin-top: 6px; padding-top: 6px; }

@media (max-width: 820px) {
  .pos-grid { grid-template-columns: 1fr; }
  .pos-cart { position: static; }
  .pos-tools { position: static; }
}

/* reports summary cards */
.rep-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin-bottom: 18px; }
.rep-card { padding: 14px 16px; border: 1px solid var(--stroke); border-radius: 14px; background: var(--panel); display: flex; flex-direction: column; gap: 4px; }
.rep-k { font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); }
.rep-v { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; }
.rep-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 720px) { .rep-grid { grid-template-columns: 1fr; } }

/* ============================================================
   PHASE 4 — subscriptions, plans, crypto checkout
   ============================================================ */
.plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; max-width: var(--maxw); margin: 8px auto 0; }
.plan { position: relative; border: 1px solid var(--stroke); border-radius: 18px; background: var(--panel); padding: 22px; display: flex; flex-direction: column; }
.plan-hi { border-color: var(--accent); box-shadow: var(--card-glow); }
.plan-badge { position: absolute; top: -11px; left: 22px; background: var(--accent); color: #06120f; font-size: .7rem; font-weight: 800; padding: 3px 10px; border-radius: 999px; text-transform: uppercase; letter-spacing: .06em; }
.plan h3 { margin: 0 0 6px; font-family: var(--font-display); }
.plan-price { font-family: var(--font-display); font-weight: 800; font-size: 2rem; }
.plan-price span { font-size: .9rem; color: var(--muted); font-weight: 500; }
.plan-desc { color: var(--muted); font-size: .9rem; margin: 8px 0; }
.plan-feats { list-style: none; padding: 0; margin: 8px 0 16px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.plan-feats li { font-size: .88rem; padding-left: 20px; position: relative; }
.plan-feats li:before { content: '+'; position: absolute; left: 0; color: var(--accent); font-weight: 800; }

.plan-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 12px; border: 1px solid var(--stroke); border-radius: 12px; background: var(--panel-2); margin-bottom: 10px; }
.chain-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }
.chain-card { border: 1px solid var(--stroke); border-radius: 14px; background: var(--panel-2); padding: 14px; }
.chain-card input { width: 100%; }

.quote { border: 1px solid var(--stroke); border-radius: 12px; background: var(--panel-2); padding: 12px 14px; }
.quote .mono { font-size: .82rem; }
.small { font-size: .8rem; }
.wallet-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.notice.ok { border-color: var(--accent); }

/* ============================================================
   PHASE 5 — loyalty, promotions, budtender widget, marketing
   ============================================================ */
.pos-extras { display: flex; flex-direction: column; gap: 8px; margin: 10px 0; }
.pos-extra { border: 1px solid var(--stroke); border-radius: 12px; background: var(--panel-2); padding: 10px; }
.pos-extra-row { display: flex; gap: 8px; align-items: center; }
.pos-extra-row input { flex: 1; }
.pos-loy { font-size: .85rem; margin-top: 8px; color: var(--text); }
.pos-redeem { display: inline-flex; align-items: center; gap: 6px; font-size: .85rem; }
.pos-redeem input { width: auto; }

/* Budtender floating chat widget */
#bt-root { position: fixed; right: 18px; bottom: 18px; z-index: 60; }
#bt-fab { background: var(--accent); color: var(--on-accent); border: none; border-radius: 999px; padding: 12px 18px; font-weight: 700; font-family: var(--font-display); cursor: pointer; box-shadow: var(--card-glow); }
#bt-panel { width: min(360px, calc(100vw - 36px)); height: 460px; max-height: calc(100vh - 120px); display: flex; flex-direction: column; background: var(--panel-solid); color: var(--text); border: 1px solid var(--stroke); border-radius: 16px; overflow: hidden; box-shadow: 0 18px 50px rgba(0,0,0,.5); }
#bt-panel[hidden] { display: none !important; }
.bt-head { display: flex; justify-content: space-between; align-items: center; padding: 12px 14px; border-bottom: 1px solid var(--stroke); font-family: var(--font-display); font-weight: 700; background: var(--panel-solid); }
.bt-head button { background: none; border: none; color: var(--text); font-size: 1.6rem; cursor: pointer; line-height: 1; padding: 0 4px; }
#bt-msgs { flex: 1; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 8px; background: var(--panel-solid); }
.bt-msg { padding: 9px 12px; border-radius: 12px; font-size: .9rem; line-height: 1.4; max-width: 85%; word-wrap: break-word; }
.bt-bot { background: var(--field-bg); color: var(--text); border: 1px solid var(--stroke); align-self: flex-start; border-bottom-left-radius: 4px; }
.bt-me { background: var(--accent); color: var(--on-accent); align-self: flex-end; border-bottom-right-radius: 4px; }
.bt-chips { display: flex; flex-wrap: wrap; gap: 6px; align-self: flex-start; }
.bt-chip { font-size: .78rem; padding: 4px 9px; border-radius: 999px; border: 1px solid var(--accent); color: var(--accent); }
.bt-input { display: flex; gap: 6px; padding: 10px; border-top: 1px solid var(--stroke); background: var(--panel-solid); }
.bt-input input { flex: 1; }
.bt-input button { background: var(--accent); color: var(--on-accent); border: none; border-radius: 10px; padding: 0 14px; font-weight: 700; cursor: pointer; }

/* Mobile: the panel is a solid bottom sheet that only appears when the button is tapped. */
@media (max-width: 640px) {
  #bt-root { right: 14px; bottom: 14px; left: auto; }
  #bt-panel {
    position: fixed; left: 12px; right: 12px; bottom: 12px; width: auto;
    height: min(70vh, 540px); max-height: 78vh; border-radius: 16px;
    box-shadow: 0 24px 60px rgba(0,0,0,.6);
  }
}
.bt-admin { height: 260px; overflow-y: auto; border: 1px solid var(--stroke); border-radius: 12px; background: var(--panel-2); padding: 12px; display: flex; flex-direction: column; gap: 8px; }
.mk-out { width: 100%; resize: vertical; font-family: var(--font-display); }
