/* starphotocard-go — light theme tuned to logo palette (pink → purple gradient). */
:root{
  /* Brand */
  --pink:#ff2d8f; --pink-soft:#ff80be; --pink-bg:#ffe4f1;
  --purple:#6610d4; --purple-soft:#8b3df0; --purple-bg:#ede4ff;
  --gradient: linear-gradient(90deg, var(--pink) 0%, var(--purple) 100%);
  --gradient-soft: linear-gradient(135deg, #fff5fa 0%, #faf3ff 100%);

  /* Surfaces */
  --bg:#ffffff;
  --bg-soft:#fdf7fb;
  --bg-card:#ffffff;
  --bg-elev:#f7f3fa;
  --border:#ecd9e8;
  --border-strong:#d9bbd1;
  --shadow-sm:0 1px 3px rgba(102,16,212,0.06);
  --shadow-md:0 4px 16px rgba(102,16,212,0.08);

  /* Text */
  --text:#1a0c1f;
  --text-dim:#6b5774;
  --text-faint:#a89db8;

  /* Status */
  --ok:#16a34a; --ok-bg:#dcfce7;
  --warn:#d97706; --warn-bg:#fef3c7;
  --danger:#dc2626; --danger-bg:#fee2e2;

  --accent: var(--pink);
  --accent-soft: var(--pink-bg);
  --radius:8px;
  --mono:'SF Mono','JetBrains Mono',Menlo,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background: var(--gradient-soft);
  background-attachment: fixed;
  color:var(--text);
  font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  font-size:14px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
a{color:var(--purple); text-decoration:none}
a:hover{text-decoration:underline; color:var(--pink)}
em{font-style:normal; background:var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:700}

/* --- Top bar --- */
.topbar{
  display:flex; align-items:center; gap:24px;
  padding:14px 28px;
  background:var(--bg);
  border-bottom:1px solid var(--border);
  box-shadow: var(--shadow-sm);
}
.topbar .brand{display:inline-flex; align-items:center; gap:10px; font-weight:700; color:var(--text)}
.topbar .brand img{height:36px; width:auto; display:block}
.topbar .brand-text{font-size:13px; letter-spacing:0.04em; text-transform:uppercase; background:var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:800}
.topbar nav{margin-left:auto; display:flex; gap:18px; align-items:center}
.topbar nav a{color:var(--text-dim); font-size:13px; font-weight:500; transition: color 0.15s}
.topbar nav a:hover{color:var(--pink); text-decoration:none}
.muted{color:var(--text-dim)}

.container{max-width:1200px; margin:0 auto; padding:32px 28px 80px}
.footer{padding:24px; text-align:center; color:var(--text-faint); font-size:12px; border-top:1px solid var(--border); margin-top:60px; background:var(--bg)}

/* --- Hero (home) --- */
.hero{
  padding:36px 28px 32px;
  margin-bottom:32px;
  background: linear-gradient(135deg, var(--pink-bg) 0%, var(--purple-bg) 100%);
  border-radius:var(--radius);
  border:1px solid var(--border);
}
.hero h1{font-size:38px; font-weight:300; letter-spacing:-0.02em; line-height:1.1; color:var(--text)}
.hero h1 em{font-weight:700}
.hero .lead{color:var(--text-dim); margin:10px 0 18px; font-size:15px}

h1{font-size:28px; font-weight:600; letter-spacing:-0.01em; margin-bottom:16px; color:var(--text)}
h2{font-size:20px; font-weight:600; margin:28px 0 12px; color:var(--text)}
h2.section-h{display:flex; align-items:baseline; gap:10px}
h2.section-h .count{font-size:13px; color:var(--text-faint); font-weight:400; padding:1px 10px; background:var(--bg-elev); border-radius:99px}
h3{font-size:15px; font-weight:600; color:var(--text)}
.lead{color:var(--text-dim); margin-bottom:18px}

/* --- Buttons --- */
.btn{
  display:inline-block;
  padding:9px 16px;
  background:var(--bg);
  border:1px solid var(--border-strong);
  border-radius:var(--radius);
  color:var(--text);
  font-size:13px; font-weight:500; cursor:pointer;
  font-family:inherit;
  transition: all 0.15s;
}
.btn:hover{border-color:var(--pink); color:var(--pink); text-decoration:none; box-shadow: var(--shadow-sm)}
.btn.primary{
  background: var(--gradient);
  border-color: transparent;
  color:#fff;
  font-weight:600;
  box-shadow: 0 2px 8px rgba(255,45,143,0.25);
}
.btn.primary:hover{
  color:#fff;
  filter: brightness(1.08);
  box-shadow: 0 4px 14px rgba(255,45,143,0.35);
  transform: translateY(-1px);
}
.btn.big{padding:13px 28px; font-size:15px}
.btn.small{padding:5px 10px; font-size:11px}
.btn.danger{border-color:var(--danger); color:var(--danger); background:var(--danger-bg)}
.btn.danger:hover{background:var(--danger); color:#fff; border-color:var(--danger)}
button.link{background:none; border:none; color:var(--purple); cursor:pointer; font-size:13px; font-family:inherit; padding:0}
button.link:hover{text-decoration:underline; color:var(--pink)}
button.link.danger{color:var(--danger)}

/* --- Card grid (home) --- */
.grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px}
.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow: var(--shadow-sm);
  transition: transform 0.15s, box-shadow 0.15s;
}
.card:hover{transform: translateY(-2px); box-shadow: var(--shadow-md); border-color:var(--pink-soft)}
.card.status-closing_soon{border-color:var(--warn); background: linear-gradient(180deg, var(--warn-bg) 0%, var(--bg-card) 30%)}
.card header{display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; gap:8px}
.card .code{font-family:var(--mono); font-size:11px; color:var(--text-faint)}
.card h3{margin-bottom:4px; line-height:1.3}
.card .sub{color:var(--text-dim); font-size:12px}
.card .detail{font-size:12px; color:var(--text-dim); margin-top:8px; line-height:1.5}
.card .price{
  font-weight:700; font-size:18px; margin-top:10px;
  background: var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* --- Pills --- */
.pill{display:inline-block; padding:2px 9px; border-radius:99px; font-size:10px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase}
.pill.ok, .pill.st-open{background:var(--ok-bg); color:var(--ok)}
.pill.warn, .pill.st-closing_soon{background:var(--warn-bg); color:var(--warn)}
.pill.st-closed{background:var(--danger-bg); color:var(--danger)}
.pill.st-submitted{background:var(--purple-bg); color:var(--purple)}
.pill.st-confirmed{background:var(--ok-bg); color:var(--ok)}
.pill.st-shipped{background:#dbeafe; color:#1d4ed8}
.pill.st-cancelled{background:var(--danger-bg); color:var(--danger)}
.pill.st-draft{background:var(--warn-bg); color:var(--warn)}
.pill.st-ready{background:var(--purple-bg); color:var(--purple)}
.pill.st-published{background:var(--ok-bg); color:var(--ok)}

/* --- Alerts --- */
.alert{background:var(--danger-bg); border:1px solid var(--danger); color:var(--danger); padding:10px 14px; border-radius:var(--radius); margin-bottom:16px; font-weight:500}
.empty{padding:48px 16px; text-align:center; color:var(--text-faint); background:var(--bg-card); border:1px dashed var(--border-strong); border-radius:var(--radius)}

/* --- Order rules / form --- */
.rules{background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px 20px; margin:16px 0; box-shadow: var(--shadow-sm)}
.rules h3{color:var(--purple); margin-bottom:8px}
.rules ol{padding-left:20px}
.rules li{margin-bottom:5px; color:var(--text-dim); font-size:13px}
.rules strong{color:var(--text)}

.order-form fieldset{border:1px solid var(--border); border-radius:var(--radius); padding:18px; margin-bottom:16px; background:var(--bg-card); box-shadow: var(--shadow-sm)}
.order-form legend{padding:0 8px; color:var(--pink); font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:0.05em}
.order-form label, .campaign-form label{display:block; margin-bottom:12px; color:var(--text); font-size:13px; font-weight:500}
.order-form input, .order-form textarea, .order-form select,
.campaign-form input, .campaign-form textarea, .campaign-form select{
  width:100%; padding:9px 11px;
  background:var(--bg);
  border:1px solid var(--border-strong);
  border-radius:var(--radius);
  color:var(--text);
  font-family:inherit; font-size:13px;
  margin-top:5px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.order-form input:focus, .order-form textarea:focus, .order-form select:focus,
.campaign-form input:focus, .campaign-form textarea:focus, .campaign-form select:focus{
  outline: none; border-color:var(--pink); box-shadow: 0 0 0 3px rgba(255,45,143,0.15);
}
.req{color:var(--danger)}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.check{display:flex; align-items:center; gap:8px}
.check input{width:auto; margin:0}

table.items{width:100%; border-collapse:collapse; margin-bottom:14px}
table.items th, table.items td{padding:8px; border-bottom:1px solid var(--border); text-align:left; font-size:13px; vertical-align:top}
table.items th{font-size:11px; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.04em; font-weight:700}
table.items select{min-width:300px}
.detail-cell{font-size:12px; color:var(--text-dim); max-width:280px}
.price-cell{font-family:var(--mono); font-size:12px; color:var(--purple); font-weight:600}

/* --- Success --- */
.success{padding:60px 16px; text-align:center; background:var(--bg-card); border-radius:var(--radius); box-shadow: var(--shadow-md)}
.success h1{font-size:36px; background: var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:700}
.success p{color:var(--text-dim); font-size:15px; margin:14px 0}

/* --- Login --- */
.login-body .container{max-width:420px; padding-top:40px}
.login-card{background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:36px; box-shadow: var(--shadow-md)}
.login-card .login-logo{display:block; margin:0 auto 18px; max-width:200px; height:auto}
.login-card h1{text-align:center; background: var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:700; margin-bottom:20px; font-size:22px}
.login-card label{display:block; margin-bottom:14px; font-size:13px; font-weight:500}
.login-card input{width:100%; padding:10px; background:var(--bg); border:1px solid var(--border-strong); border-radius:var(--radius); color:var(--text); font-family:inherit; font-size:13px; margin-top:5px}
.login-card input:focus{outline:none; border-color:var(--pink); box-shadow: 0 0 0 3px rgba(255,45,143,0.15)}
.login-card .btn{width:100%; margin-top:8px; padding:11px; font-size:14px}

/* --- Admin menu grid (dashboard) --- */
.admin-menu-sections{
  display:grid;
  gap:22px;
  margin-bottom:28px;
}
.admin-menu-section-header{
  display:flex; align-items:center; gap:10px;
  margin-bottom:10px;
}
.admin-menu-section-title{
  margin:0; color:var(--text-dim);
  font-size:11px; font-weight:800;
  letter-spacing:0.07em; text-transform:uppercase;
  white-space:nowrap;
}
.admin-menu-section-rule{height:1px; flex:1; background:var(--border)}
.admin-menu-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:12px;
  margin-bottom:0;
}
.admin-menu-card{
  display:flex; flex-direction:column; align-items:flex-start; gap:4px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px 14px;
  text-decoration:none;
  color:var(--text);
  box-shadow:var(--shadow-sm);
  transition:all 0.15s;
}
.admin-menu-card:hover{border-color:var(--pink-soft); box-shadow:var(--shadow-md); transform:translateY(-2px); text-decoration:none; color:var(--text)}
.admin-menu-card.accent{background:var(--gradient-soft); border-color:var(--pink-soft)}
.admin-menu-card.accent:hover{border-color:var(--pink)}
.amcard-icon{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:32px; height:22px; padding:0 7px;
  border-radius:999px; background:var(--bg-elev); color:var(--purple);
  font-size:10px; line-height:1; font-weight:800; letter-spacing:0.04em;
  margin-bottom:2px;
}
.admin-menu-card.accent .amcard-icon{background:var(--purple-bg)}
.amcard-label{font-size:13px; font-weight:700; color:var(--text)}
.amcard-desc{font-size:11px; color:var(--text-dim); line-height:1.4}
.admin-menu-more{margin-top:-6px}
.admin-menu-more > summary{
  cursor:pointer; list-style:none; user-select:none;
  display:flex; align-items:center; gap:6px;
  color:var(--text-dim); font-size:11px; font-weight:800;
  letter-spacing:0.07em; text-transform:uppercase;
  padding:6px 0; margin-bottom:10px;
}
.admin-menu-more > summary::-webkit-details-marker{display:none}
.admin-menu-more > summary::before{content:"\25B8"; font-size:10px}
.admin-menu-more[open] > summary::before{content:"\25BE"}
.admin-menu-more > summary:hover{color:var(--text)}

/* --- Admin --- */
.kpi-row{display:flex; gap:16px; margin-bottom:24px; flex-wrap:wrap}
.kpi{flex:1; min-width:160px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; box-shadow: var(--shadow-sm)}
.kpi .lbl{display:block; font-size:11px; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.05em; font-weight:600}
.kpi .val{display:block; font-size:30px; font-weight:300; margin-top:6px; color:var(--text)}
.kpi .val.ok{color:var(--ok)}
.kpi-link { text-decoration: none; color: inherit; display: block; }
.kpi-link:hover { opacity: 0.85; }
.kpi .val.warn { color: var(--warn, #f59e0b); }
.kpi .val.danger { color: var(--danger, #ef4444); }
.quick{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:24px}
.filter-row{display:flex; gap:8px; align-items:center; margin-bottom:16px; flex-wrap:wrap}
.filter-row select, .filter-row input{padding:7px 11px; background:var(--bg); border:1px solid var(--border-strong); border-radius:var(--radius); color:var(--text); font-family:inherit; font-size:13px}
.admin-utility-bar{display:flex; gap:10px; align-items:stretch; flex-wrap:wrap; margin:0 0 16px}
.admin-utility-bar.compact{gap:8px; margin-bottom:14px}
.utility-group{
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  min-height:44px; padding:8px 10px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow-sm);
}
.utility-group.filter{flex:1 1 360px}
.utility-group.status{flex:1 1 220px}
.utility-group.compose{flex:1 1 520px}
.utility-group.danger{border-color:var(--danger); background:var(--danger-bg)}
.utility-group.danger .utility-group-title{color:var(--danger)}
.utility-group-title{
  color:var(--text-faint); font-size:10px; font-weight:800;
  letter-spacing:0.06em; text-transform:uppercase; white-space:nowrap;
}
.utility-group form{margin:0; display:flex; gap:8px; align-items:center; flex-wrap:wrap}
.utility-group select, .utility-group input{
  padding:7px 11px; background:var(--bg);
  border:1px solid var(--border-strong); border-radius:var(--radius);
  color:var(--text); font-family:inherit; font-size:13px;
}
.utility-group .muted{font-size:12px}
.order-utility-row{
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  margin-top:10px; padding-top:10px; border-top:1px dashed var(--border);
}
.order-utility-row form{margin:0; display:flex; gap:6px; align-items:center; flex-wrap:wrap}
.order-utility-row input{
  padding:6px 9px; background:var(--bg);
  border:1px solid var(--border-strong); border-radius:var(--radius);
  color:var(--text); font-family:inherit; font-size:12px;
}
.order-utility-label{
  color:var(--text-faint); font-size:10px; font-weight:800;
  letter-spacing:0.06em; text-transform:uppercase;
}

table.dt{width:100%; border-collapse:collapse; margin-top:8px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; box-shadow: var(--shadow-sm)}
table.dt th, table.dt td{padding:9px 11px; border-bottom:1px solid var(--border); text-align:left; font-size:12px}
table.dt thead th{background:var(--bg-elev); color:var(--text-dim); font-size:11px; text-transform:uppercase; letter-spacing:0.04em; font-weight:700}
table.dt tbody tr:hover{background:var(--bg-soft)}
table.dt.compact th, table.dt.compact td{padding:6px 9px; font-size:11px}
table.dt .actions{font-size:11px}
table.dt .actions a, table.dt .actions form{margin-right:8px}
table.dt tr.is-closed td{opacity:0.5}
.r{text-align:right}

.order-card{background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; margin-bottom:14px; box-shadow: var(--shadow-sm)}
.order-card header{display:flex; gap:12px; align-items:center; margin-bottom:10px; flex-wrap:wrap}
.order-card .oid{font-family:var(--mono); color:var(--text-faint); font-size:12px}
.order-card > form.inline{margin-top:10px; display:flex; gap:6px; align-items:center}

.campaign-form{max-width:640px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:24px; box-shadow: var(--shadow-md)}
.campaign-form .actions{display:flex; gap:8px; justify-content:flex-end; margin-top:18px}
.campaign-form.poca-new{max-width:1000px}
.campaign-form-grid{display:grid; grid-template-columns:minmax(0,1fr) 340px; gap:18px; align-items:start}
.campaign-main-panel{min-width:0}
.campaign-mini-dashboard{background:var(--bg-soft); border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow-sm)}
.campaign-mini-dashboard h2, .campaign-calculator h2{font-size:15px; margin:0 0 12px; color:var(--purple)}
.campaign-calculator{margin-top:18px; padding:18px; background:var(--bg-elev); border:1px solid var(--border); border-radius:var(--radius)}
.campaign-calculator p{color:var(--text-dim); font-size:13px; margin-bottom:14px}
.calculator-fields{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.calculator-output{display:block; margin-top:10px; padding:12px 14px; background:var(--bg); border:1px solid var(--border-strong); border-radius:var(--radius); color:var(--purple); font-family:var(--mono); font-size:15px; font-weight:700}
.campaign-form.poca-new input[readonly]{background:var(--bg-elev); color:var(--purple); font-weight:700}
.result-list{background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px 28px; margin-top:14px; box-shadow: var(--shadow-sm)}
.result-list li.err{color:var(--danger)}
.announcement-summary{display:grid; grid-template-columns:2fr 1fr 1fr; gap:12px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; margin-bottom:14px; box-shadow:var(--shadow-sm)}
.announcement-summary div{display:flex; flex-direction:column; gap:3px; min-width:0}
.announcement-toolbar{display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-bottom:14px}
.announcement-toolbar form{margin:0}
.announcement-batch-preview{background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; margin-bottom:18px; box-shadow:var(--shadow-sm)}
.announcement-select-col{width:64px}
.announcement-checkbox{width:18px; height:18px; accent-color:var(--purple)}
.announcement-theme-input{min-width:280px; max-width:420px; width:100%; padding:7px 11px; background:var(--bg); border:1px solid var(--border-strong); border-radius:var(--radius); color:var(--text); font-family:inherit; font-size:13px}
.announcement-compose-hint{color:var(--text-dim); font-size:12px}
.announcement-preview-label{display:block; font-size:12px; font-weight:700; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.04em; margin-bottom:6px}
.announcement-preview{width:100%; min-height:430px; resize:vertical; background:var(--bg-card); border:1px solid var(--border-strong); border-radius:var(--radius); padding:16px; color:var(--text); font-family:var(--mono); font-size:13px; line-height:1.55; box-shadow:var(--shadow-sm)}
.announcement-preview-compact{min-height:300px}

@media (max-width: 720px) {
  .utility-group{width:100%}
  .utility-group.filter, .utility-group.status, .utility-group.compose{flex-basis:100%}
  .utility-group form{width:100%}
  .utility-group select, .utility-group input{flex:1 1 180px}
  .order-utility-row form{width:100%}
  .order-utility-row input{flex:1 1 160px}
}

/* Category tabs (used on /order and home page) */
.cat-tabs { display:flex; gap:6px; flex-wrap:wrap; }
.cat-tab { background:#f5f5fa; color:#3a3a44; border:1px solid #e0e0e8; border-radius:8px; padding:8px 16px; font-size:14px; font-weight:500; cursor:pointer; transition:all 0.15s; display:inline-flex; align-items:center; gap:6px; font-family:inherit; }
.cat-tab:hover { background:#ebebf2; }
.cat-tab.active { background:linear-gradient(135deg, var(--pink) 0%, var(--purple) 100%); color:#fff; border-color:transparent; }
.cat-tab.active .cat-count { background:rgba(255,255,255,0.25); color:#fff; }
.cat-count { background:#dcdce4; color:#5a5a66; font-size:11px; font-weight:600; padding:1px 7px; border-radius:10px; min-width:14px; text-align:center; }

/* Idol sub-tabs (home page, inside each .home-cat section) */
.idol-tabs { display:flex; gap:5px; flex-wrap:wrap; margin: 2px 0 18px; padding: 4px 0; }
.idol-tab { background:transparent; color:var(--text-dim); border:1px solid transparent; border-radius:6px; padding:5px 12px; font-size:12px; font-weight:500; cursor:pointer; font-family:inherit; display:inline-flex; align-items:center; gap:5px; transition: all 0.12s; }
.idol-tab:hover { background:var(--bg-elev); color:var(--text); }
.idol-tab.active { background:var(--purple-bg); color:var(--purple); border-color:rgba(102,16,212,0.18); font-weight:600; }
.idol-tab.active .idol-count { background:rgba(102,16,212,0.15); color:var(--purple); }
.idol-count { background:var(--bg-elev); color:var(--text-faint); font-size:10px; font-weight:600; padding:0 6px; border-radius:9px; min-width:14px; text-align:center; }

/* Card cart row (per-GO add to cart) */
.card-cart-row { display:flex; align-items:center; justify-content:flex-end; gap:8px; margin-top:12px; padding-top:10px; border-top:1px dashed var(--border); }
.card-cart-qty { width:54px; text-align:center; padding:5px 6px; border:1px solid var(--border-strong); border-radius:6px; font-family:var(--mono); font-size:12px; background:var(--bg); color:var(--text); }
.card-cart-qty:focus { outline:none; border-color:var(--pink); box-shadow: 0 0 0 2px rgba(255,45,143,0.15); }
.card-add-btn { padding:6px 14px; background: var(--gradient); color:#fff; border:none; border-radius:6px; font-size:12px; font-weight:600; cursor:pointer; font-family:inherit; box-shadow: 0 1px 4px rgba(255,45,143,0.2); transition: all 0.15s; }
.card-add-btn:hover { transform: translateY(-1px); box-shadow: 0 2px 10px rgba(255,45,143,0.35); }
.card-add-btn:active { transform: translateY(0); }

/* Floating cart button (FAB) */
.cart-fab { position:fixed; bottom:24px; right:24px; width:64px; height:64px; border-radius:50%; background: var(--gradient); color:#fff; border:none; box-shadow: 0 6px 20px rgba(102,16,212,0.35); display:flex; align-items:center; justify-content:center; font-size:26px; cursor:pointer; z-index:100; transition: transform 0.18s; }
.cart-fab:hover { transform: scale(1.06); }
.cart-fab.bump { animation: cartBump 0.4s ease; }
@keyframes cartBump { 0% {transform:scale(1)} 30% {transform:scale(1.18)} 100% {transform:scale(1)} }
.cart-badge { position:absolute; top:-4px; right:-4px; background:#fff; color:var(--purple); min-width:24px; height:24px; border-radius:12px; font-size:12px; font-weight:700; display:flex; align-items:center; justify-content:center; padding:0 7px; box-shadow: 0 2px 6px rgba(0,0,0,0.15); border:2px solid var(--pink); }

/* Cart drawer */
.cart-overlay { position:fixed; inset:0; background:rgba(26,12,31,0.45); z-index:150; opacity:0; pointer-events:none; transition: opacity 0.22s; }
.cart-overlay.show { opacity:1; pointer-events:auto; }
.cart-drawer { position:fixed; top:0; right:0; width:400px; max-width:92vw; height:100vh; background:var(--bg); box-shadow: -8px 0 32px rgba(102,16,212,0.15); z-index:200; transform: translateX(100%); transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1); display:flex; flex-direction:column; }
.cart-drawer.open { transform: translateX(0); }
.cart-header { padding:20px 22px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; background: var(--gradient-soft); }
.cart-close { background:none; border:none; font-size:28px; line-height:1; color:var(--text-dim); cursor:pointer; padding:0 4px; }
.cart-close:hover { color:var(--pink); }
.cart-items { flex:1; overflow-y:auto; padding:8px 18px; }
.cart-item { padding:14px 0; border-bottom:1px solid var(--border); }
.cart-item:last-child { border-bottom:none; }
.cart-item-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:4px; }
.cart-item-code { font-family:var(--mono); font-size:11px; color:var(--text-faint); }
.cart-item-remove { background:none; border:none; color:var(--text-faint); font-size:20px; cursor:pointer; padding:0 4px; line-height:1; }
.cart-item-remove:hover { color:var(--danger); }
.cart-item-name { font-size:14px; font-weight:600; color:var(--text); margin-bottom:2px; }
.cart-item-sub { font-size:11px; color:var(--text-dim); }
.cart-item-foot { display:flex; justify-content:space-between; align-items:center; margin-top:10px; }
.cart-qty-ctrl { display:inline-flex; align-items:center; gap:6px; background:var(--bg-elev); border-radius:6px; padding:2px; }
.cart-qty-ctrl button { background:var(--bg); border:1px solid var(--border); color:var(--text); width:26px; height:26px; border-radius:4px; cursor:pointer; font-size:14px; font-weight:600; display:flex; align-items:center; justify-content:center; }
.cart-qty-ctrl button:hover { border-color:var(--pink); color:var(--pink); }
.cart-qty-ctrl span { min-width:24px; text-align:center; font-family:var(--mono); font-weight:600; font-size:13px; }
.cart-item-price { font-family:var(--mono); font-weight:700; color:var(--purple); font-size:14px; }
.cart-footer { padding:18px 22px; border-top:1px solid var(--border); background:var(--bg-soft); }
.cart-total { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:14px; }
.cart-total .label { color:var(--text-dim); font-size:13px; font-weight:500; }
.cart-total .amount { font-size:22px; font-weight:700; background: var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent; font-family:var(--mono); }

@media (max-width: 640px) {
  .cart-fab { bottom:16px; right:16px; width:56px; height:56px; font-size:22px; }
  .cart-drawer { width:100vw; }
}

/* Buyer-count social-proof badge (home cards) */
.buyer-count{
  display:inline-block;
  margin-top:8px;
  padding:3px 10px;
  background: var(--pink-bg);
  color: var(--purple);
  border-radius:99px;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.02em;
}

/* FAQ */
.faq-section{margin:24px 0; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:18px 24px; box-shadow: var(--shadow-sm)}
.faq-section h2{font-size:18px; margin-bottom:10px; color:var(--purple)}
.faq-section p, .faq-section li{color:var(--text-dim); font-size:14px; line-height:1.7}
.faq-section strong{color:var(--text)}
.faq-section ul, .faq-section ol{padding-left:22px}
.faq-section li{margin-bottom:6px}
.faq-steps li{margin-bottom:10px}

/* CSV export button (admin) */
.csv-btn{display:inline-block; padding:3px 8px; background:var(--purple-bg); color:var(--purple); border:1px solid var(--purple); border-radius:4px; font-size:11px; font-weight:600; text-decoration:none}
.csv-btn:hover{background:var(--purple); color:#fff; text-decoration:none}

/* Responsive */
@media (max-width: 640px){
  .topbar{padding:10px 16px; gap:12px}
  .topbar .brand img{height:30px}
  .topbar nav{gap:12px}
  .container{padding:20px 16px 60px}
  .hero{padding:24px 18px}
  .hero h1{font-size:28px}
  table.items select{min-width:0}
  .row2{grid-template-columns:1fr}
  .campaign-form-grid{grid-template-columns:1fr}
  .calculator-fields{grid-template-columns:1fr}
  .announcement-summary{grid-template-columns:1fr}
}
