/* wbTrue Bonus Platform — Marketplace / Bonus System */
:root{
  --bg:#f7f8ff;
  --card:#ffffffcc;
  --text:#0e1220;
  --muted:#5f667a;
  --border:#e6e8f2;
  --shadow: 0 18px 45px rgba(18,28,80,.08);
  --r:18px;
  --orange:#ff7a18;
  --orange2:#ff9b3d;
  --blue:#2b6bff;
  --blue2:#58a8ff;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color:var(--text);
  background: radial-gradient(900px 500px at 20% 10%, rgba(88,168,255,.18), transparent 60%),
              radial-gradient(900px 500px at 80% 0%, rgba(255,122,24,.14), transparent 55%),
              linear-gradient(180deg, #f7f8ff, #fbfbff);
  min-height:100vh;
}

a{color:inherit;text-decoration:none}

/* shared container for header/footer + pages */
.container{max-width:1180px;margin:0 auto;padding:0 16px}
.container-pad{padding-top:22px;padding-bottom:80px}

.topbar{
  position:sticky;top:0;z-index:20;
  padding:14px 0;
  backdrop-filter: blur(12px);
  background: rgba(247,248,255,.7);
  border-bottom: 1px solid rgba(230,232,242,.7);
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:baseline;gap:8px;font-weight:800;letter-spacing:.2px}
.brand-dot{width:10px;height:10px;border-radius:50%;background: linear-gradient(135deg,var(--orange),var(--blue));box-shadow:0 8px 18px rgba(0,0,0,.12)}
.brand span{opacity:.9}
.brand b{font-weight:900}
.brand-sub{opacity:.6;font-weight:700}
.nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.nav a{padding:8px 10px;border-radius:12px;color:var(--muted)}
.nav a:hover{background:rgba(255,255,255,.6);color:var(--text)}

.card{
  background: var(--card);
  border: 1px solid rgba(230,232,242,.9);
  border-radius: var(--r);
  box-shadow: var(--shadow);
}
.pad{padding:18px 18px}
.row{display:flex;gap:12px;align-items:center;justify-content:space-between}
.w100{width:100%}
.muted{color:var(--muted)}

/* ===== Claim UX (product + status) ===== */
.small{font-size:12px}
.field-err{margin-top:6px;color:#b91c1c;font-size:12px;line-height:1.35}
.field-err:empty{display:none}

.mini-steps{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.ms{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid rgba(15,23,42,.08);border-radius:14px;background:rgba(248,250,252,.7)}
.msn{width:26px;height:26px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(99,102,241,.12);border:1px solid rgba(99,102,241,.18);color:#4f46e5;font-weight:1000;flex:0 0 26px}

.dz{margin-top:8px;border:1.5px dashed rgba(15,23,42,.22);border-radius:16px;padding:12px;background:rgba(248,250,252,.7);transition:.15s}
.dz.drag{background:rgba(99,102,241,.08);border-color:rgba(99,102,241,.45)}
.dz-inp{display:none}
.dz-top{display:flex;gap:10px;align-items:center;justify-content:space-between}
.dz-title{font-weight:1000}
.dz-preview img{width:100%;max-height:240px;object-fit:contain;border-radius:14px;margin-top:10px;box-shadow:0 10px 30px rgba(0,0,0,.08)}

.claim-ok{margin-top:12px;padding:14px;border-radius:16px;background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.18)}
.claim-ok-title{font-weight:1000;font-size:18px}

.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:1000;border:1px solid rgba(15,23,42,.12);background:rgba(248,250,252,.7)}
.status-pending{background:rgba(250,204,21,.14);border-color:rgba(250,204,21,.30)}
.status-approved{background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.30)}
.status-rejected{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.25)}
.status-shipped{background:rgba(168,85,247,.14);border-color:rgba(168,85,247,.30)}
.status-completed{background:rgba(34,197,94,.14);border-color:rgba(34,197,94,.30)}

.badge-ok{background:rgba(34,197,94,.14);border-color:rgba(34,197,94,.28)}
.badge-bad{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.25)}

/* Status timeline on /status */
.timeline{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}
.tl-step{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:14px;border:1px solid rgba(15,23,42,.10);background:rgba(248,250,252,.65)}
.tl-dot{width:10px;height:10px;border-radius:999px;background:rgba(15,23,42,.25)}
.tl-txt{font-size:12px;font-weight:900;opacity:.85}
.tl-off{opacity:.55}
.tl-done{background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.22)}
.tl-done .tl-dot{background:rgba(34,197,94,.70)}
.tl-active{background:rgba(59,130,246,.10);border-color:rgba(59,130,246,.22)}
.tl-active .tl-dot{background:rgba(59,130,246,.75)}

.claim-item{margin-top:12px}
.claim-thumb{width:74px;height:74px;border-radius:16px;overflow:hidden;background:rgba(15,23,42,.06);flex:0 0 74px;display:flex;align-items:center;justify-content:center}
.claim-thumb img{width:100%;height:100%;object-fit:cover}
.claim-thumb-ph{font-weight:1000;color:rgba(15,23,42,.35)}
.claim-title{font-weight:1000;font-size:16px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.comment-box{border-radius:14px;padding:10px 12px;background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.15)}
.comment-title{font-weight:900;font-size:12px;color:rgba(15,23,42,.75)}
.comment-text{margin-top:4px;font-size:13px;line-height:1.45}
.track-box{border-radius:14px;padding:10px 12px;background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.15);font-size:13px}

@media (max-width:560px){
  .row{flex-wrap:wrap}
}
.small{font-size:12px}
.h3{font-weight:800}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid transparent;
  font-weight:800;
  cursor:pointer;
}
.btn-lg{padding:12px 16px;border-radius:16px}
.btn-primary{
  color:#fff;
  background: linear-gradient(135deg,var(--orange),var(--orange2));
  box-shadow: 0 16px 30px rgba(255,122,24,.25);
}
.btn-secondary{
  color:#fff;
  background: linear-gradient(135deg,var(--blue),var(--blue2));
  box-shadow: 0 16px 30px rgba(43,107,255,.22);
}
.btn-ghost{
  background: rgba(255,255,255,.65);
  border-color: rgba(230,232,242,.9);
  color: var(--text);
}
.btn.sec{ /* legacy alias used in admin views */
  background: rgba(255,255,255,.65);
  border-color: rgba(230,232,242,.9);
  color: var(--text);
}
.btn:hover{transform: translateY(-1px)}
.btn:active{transform: translateY(0px)}

.btn-sm{padding:8px 12px;border-radius:12px;font-weight:800}

.ic{width:16px;height:16px;opacity:.9;display:inline-block}

.pill{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;
  font-weight:800;font-size:12px;
  background: rgba(255,255,255,.75);
  border:1px solid rgba(230,232,242,.9);
  color: var(--muted);
}

.badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 10px;border-radius:999px;
  font-size:12px;font-weight:800;
  background: rgba(255,255,255,.75);
  border:1px solid rgba(230,232,242,.9);
}

.badge-soft{background:rgba(255,255,255,.55);border-color:rgba(230,232,242,.9)}
.badge-warn{background:rgba(255,122,24,.10);border-color:rgba(255,122,24,.20);color:#8b3d00}

.filters{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px;align-items:flex-end}
.pager{display:flex;align-items:center;justify-content:center;gap:8px;margin:18px 0 6px}

/* promo cards */
.promo-card{display:flex;flex-direction:column;gap:10px}
.promo-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.shop-chip{display:flex;align-items:center;gap:10px}
.shop-avatar{width:34px;height:34px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:800;
  background: linear-gradient(135deg, rgba(43,107,255,.18), rgba(255,122,24,.16));
  border:1px solid rgba(230,232,242,.9);
  overflow:hidden;
}
.shop-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.shop-chip-name{font-weight:900;line-height:1.1}

/* shop logos / avatars */
.shop-card{display:flex;align-items:center;gap:12px;padding:16px}
.shop-card:hover{transform: translateY(-1px)}
.shop-logo{
  width:44px;height:44px;border-radius:16px;flex:0 0 44px;
  display:flex;align-items:center;justify-content:center;
  font-weight:1000;color:rgba(14,18,32,.72);
  background: linear-gradient(135deg, rgba(43,107,255,.18), rgba(255,122,24,.16));
  border:1px solid rgba(230,232,242,.9);
  overflow:hidden;
}
.shop-logo img{width:100%;height:100%;object-fit:cover;display:block}
.shop-logo.sm{width:34px;height:34px;border-radius:12px;flex-basis:34px}
.shop-logo.big{width:56px;height:56px;border-radius:18px;flex-basis:56px}

.trust-line{font-size:12px;line-height:1.35;opacity:.9}
.trust-pill{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;
  font-size:12px;font-weight:800;
  background:rgba(255,255,255,.65);
  border:1px solid rgba(230,232,242,.9);
  color:var(--muted);
}
.promo-title a{font-weight:900;font-size:18px}
.promo-gift{font-size:13px}
.clamp2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.promo-reqs{display:flex;gap:10px;flex-wrap:wrap}
.req{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;color:var(--muted)}
.promo-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}

/* promo page */
.promo-hero{display:flex;gap:18px;align-items:stretch}
.promo-hero-left{flex:1;min-width:0}
.promo-hero-right{width:340px;max-width:40%;display:flex;align-items:center;justify-content:center}
.promo-hero-right img{width:100%;height:auto;border-radius:16px;border:1px solid rgba(230,232,242,.8)}
.promo-kicker{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.promo-h1{margin:10px 0 0;font-size:32px;line-height:1.12}
.promo-lead{margin-top:10px;font-size:15px;color:var(--muted)}
.promo-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.promo-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.steps{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.step{display:flex;gap:12px;align-items:flex-start}
.step-ic{width:36px;height:36px}
.step-title{font-weight:900}
.req-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.req-line{display:flex;gap:10px;align-items:flex-start}

/* share modal */
.modal-scrim{position:fixed;inset:0;background:rgba(14,18,32,.55);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:100}
.modal-scrim.on{display:flex}
.modal{width:min(560px,92vw);background:rgba(255,255,255,.92);border:1px solid rgba(230,232,242,.95);
  border-radius:20px;box-shadow:0 26px 70px rgba(0,0,0,.25);padding:16px}
.modal h3{margin:4px 0 10px}
.share-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.share-links a{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.65);border:1px solid rgba(230,232,242,.9);font-weight:800}

@media (max-width: 860px){
  .promo-hero{flex-direction:column}
  .promo-hero-right{width:100%;max-width:none}
  .promo-grid{grid-template-columns:1fr}
}
.hero{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
  align-items:center;
  padding:22px;
  border-radius: 24px;
  border:1px solid rgba(230,232,242,.9);
  background: linear-gradient(180deg, rgba(255,255,255,.75), rgba(255,255,255,.5));
  box-shadow: var(--shadow);
}
.hero-v2{position:relative;overflow:hidden}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-weight:900;
  letter-spacing:.2px;
  color: rgba(12,16,32,.72);
  background: rgba(255,255,255,.6);
  border:1px solid rgba(230,232,242,.95);
}
.trust-pill{
  display:inline-flex;align-items:center;
  padding:8px 12px;
  border-radius:999px;
  font-weight:900;
  color: rgba(12,16,32,.74);
  background: rgba(255,255,255,.65);
  border:1px solid rgba(230,232,242,.92);
}
.hero-side{background: linear-gradient(135deg, rgba(43,107,255,.10), rgba(255,122,24,.10))}
.hero-side-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.hero-side-title{font-weight:950;font-size:16px}
.hero-side-img{width:96px;opacity:.95;flex:0 0 auto}
.trust-lines{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.trust-line{font-weight:900;color:rgba(12,16,32,.78)}

.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 12px}
.tab{border:1px solid rgba(230,232,242,.95);background:rgba(255,255,255,.62);padding:10px 12px;border-radius:14px;font-weight:900;cursor:pointer}
.tab.is-active{background:rgba(43,107,255,.10);border-color:rgba(43,107,255,.22)}
.tab-panes{width:100%}
.tab-pane{display:none}
.tab-pane.is-active{display:block}

.cards2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.stat{text-align:center}
.stat-num{font-size:34px;font-weight:950;letter-spacing:-.6px}

.promo-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.badge-warn{background: rgba(255, 198, 0, .14); border:1px solid rgba(255, 198, 0, .32)}

.shop-logo img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}

.doc{line-height:1.6}
.doc h2{margin-top:18px}
.doc ul{margin:10px 0 10px 20px}
.doc-toc{display:grid;gap:6px;padding:12px 14px;border-radius:16px;border:1px solid rgba(230,232,242,.95);background:rgba(255,255,255,.55);margin-bottom:14px}
.doc-toc-title{font-weight:950;margin-bottom:4px}
.doc-toc a{font-weight:800;color:rgba(12,16,32,.78)}
.doc-toc a:hover{color:var(--blue)}
.hero h1{margin:12px 0 10px;font-size:42px;line-height:1.1}
.lead{font-size:16px;color:var(--muted);max-width:56ch}
.hero-cta{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.hero-img{width:100%;max-width:420px;display:block;margin-left:auto}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.step{padding:18px}
.step-ic{width:44px;height:44px}
.section{margin-top:22px}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}
.link{color:var(--blue);font-weight:800}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.shop-card{display:flex;gap:12px;align-items:center;padding:14px}
.shop-logo{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;font-weight:900;color:#fff;
  background: linear-gradient(135deg,var(--blue),var(--orange));
}
.shop-logo.big{width:58px;height:58px;border-radius:18px;font-size:24px}
.shop-name{font-weight:900}
.clamp2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-card{padding:14px}
.product-thumb{height:120px;border-radius:14px;background: rgba(255,255,255,.65);
  border:1px dashed rgba(230,232,242,.95);display:grid;place-items:center;margin-bottom:10px;
}
.product-thumb img{width:74px;opacity:.85}
.product-title{font-weight:900;margin-bottom:4px}

.cta-wide{
  margin-top:22px;
  padding:18px 18px;
  border-radius:22px;
  border:1px solid rgba(230,232,242,.9);
  background: linear-gradient(135deg, rgba(255,122,24,.14), rgba(43,107,255,.12));
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.partners{margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.logos{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-weight:800}

.footer{border-top:1px solid rgba(230,232,242,.9);background:rgba(255,255,255,.5)}
.footer-inner{padding:18px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.footer-title{font-weight:900}
.footer-col{max-width:560px}
.footer-text{margin-top:6px}
.footer-copy{margin-top:10px;font-size:12px}
.footer-links{display:flex;gap:12px;flex-wrap:wrap}

.page-head h1{margin:0 0 6px}
.page-head{margin:6px 0 14px}
.auth{display:grid;place-items:center;min-height:60vh}
.auth-card{max-width:420px;width:100%}
.auth-links{display:flex;justify-content:space-between;margin-top:10px}

.inp{
  width:100%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(230,232,242,.95);
  background: rgba(255,255,255,.7);
  outline:none;
}
.lbl{display:block;margin:10px 0 6px;font-weight:800;color:var(--muted);font-size:13px}
.chk{display:flex;align-items:center;gap:10px;margin:10px 0;font-weight:800;color:var(--muted)}
textarea.inp{resize:vertical}
.alert{padding:12px 14px;border-radius:16px;margin:10px 0;font-weight:800}
.alert.error{background: rgba(255,122,24,.12); border:1px solid rgba(255,122,24,.25)}
.alert.ok{background: rgba(43,107,255,.10); border:1px solid rgba(43,107,255,.22)}
.alert.warn{background: rgba(255, 198, 0, .12); border:1px solid rgba(255, 198, 0, .28)}

.two-col{display:grid;grid-template-columns: 1.2fr .8fr; gap:14px}

/* dashboard QR builder */
.grid2{display:grid;grid-template-columns: 1.05fr .95fr; gap:14px}
.row-inline{display:flex;gap:10px;align-items:center}
.color{width:54px;height:44px;border-radius:14px;border:1px solid rgba(230,232,242,.95);background: rgba(255,255,255,.7);padding:0}
.checks{display:flex;flex-direction:column;gap:6px}
.qr-preview{display:grid;place-items:center;padding:10px;border-radius:18px;border:1px dashed rgba(230,232,242,.95);background: rgba(255,255,255,.55)}
.qr-preview img{max-width:100%;height:auto;border-radius:14px}
@media (max-width: 960px){
  .grid2{grid-template-columns:1fr}
}
.sticky{position:sticky; top:92px}
.gallery{display:flex;gap:10px;flex-wrap:wrap}
.gal-img{width:140px;height:100px;object-fit:cover;border-radius:14px;border:1px solid rgba(230,232,242,.95);background:#fff}

/* Product gallery */
.pg{display:grid;gap:10px}
.pg-main{border-radius:18px;border:1px solid rgba(230,232,242,.95);background:rgba(255,255,255,.7);overflow:hidden}
.pg-main-img{width:100%;height:auto;display:block;aspect-ratio:4/5;object-fit:cover}
.pg-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;align-items:stretch}
.pg-thumb{padding:0;border:1px solid rgba(230,232,242,.95);border-radius:14px;background:rgba(255,255,255,.7);cursor:pointer;overflow:hidden;transition:transform .12s ease, box-shadow .12s ease}
.pg-thumb img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;display:block}
.pg-thumb:hover{transform: translateY(-1px) scale(1.02)}
.pg-thumb.active{outline:3px solid rgba(43,107,255,.25)}

/* Product lightbox */
.pglb{position:fixed;inset:0;z-index:10050;display:none;align-items:center;justify-content:center}
.pglb.on{display:flex}
.pglb-scrim{position:absolute;inset:0;background:rgba(12,16,32,.55);backdrop-filter: blur(8px);opacity:0;transition:opacity .16s ease}
.pglb.on .pglb-scrim{opacity:1}
.pglb-panel{position:relative;z-index:1;max-width:min(920px,92vw);max-height:84vh;
  border-radius:22px;border:1px solid rgba(230,232,242,.9);
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow);
  padding:14px;
  opacity:0;transform: translateY(10px) scale(.98);
  transition: opacity .18s ease, transform .18s ease;
}
.pglb.on .pglb-panel{opacity:1;transform: translateY(0) scale(1)}
.pglb-img{max-width:100%;max-height:calc(84vh - 58px);display:block;margin:0 auto;border-radius:18px;border:1px solid rgba(230,232,242,.9);
  background: rgba(255,255,255,.85);
  transition: opacity .15s ease;
}
.pglb-close{position:absolute;top:10px;right:10px;width:40px;height:40px;border-radius:14px;border:1px solid rgba(230,232,242,.9);
  background: rgba(255,255,255,.8);font-weight:900;cursor:pointer
}
.pglb-nav{position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:16px;border:1px solid rgba(230,232,242,.9);
  background: rgba(255,255,255,.8);font-weight:1000;font-size:22px;cursor:pointer
}
.pglb-prev{left:10px}
.pglb-next{right:10px}
.pglb-meta{margin-top:10px;text-align:center;color:var(--muted);font-weight:900;font-size:12px}

.pglb-ghost{position:fixed;z-index:10051;object-fit:cover;border-radius:14px;border:1px solid rgba(230,232,242,.95);
  box-shadow: var(--shadow);
  transition: left .22s cubic-bezier(.2,.8,.2,1), top .22s cubic-bezier(.2,.8,.2,1), width .22s cubic-bezier(.2,.8,.2,1), height .22s cubic-bezier(.2,.8,.2,1), border-radius .22s cubic-bezier(.2,.8,.2,1);
}

/* Mini steps + confirmation */
.mini-steps{display:grid;gap:8px;margin:10px 0 12px}
.ms{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.6);border:1px solid rgba(230,232,242,.9)}
.msn{width:26px;height:26px;border-radius:999px;display:grid;place-items:center;font-weight:900;color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue2))}
.claim-ok{margin-top:10px;padding:14px;border-radius:18px;background:rgba(43,107,255,.10);border:1px solid rgba(43,107,255,.22)}
.claim-ok-title{font-weight:1000;font-size:18px;margin-bottom:4px}

/* Field errors */
.field-err{margin:6px 0 2px;color:#b54800;font-weight:900;font-size:12px}

/* Dropzone */
.dz{margin-top:6px;border-radius:18px;border:1px dashed rgba(230,232,242,.95);background:rgba(255,255,255,.55);padding:12px}
.dz.drag{background:rgba(88,168,255,.10);border-color:rgba(43,107,255,.35)}
.dz-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.dz-title{font-weight:1000}
.dz-inp{display:none}
.dz-preview{margin-top:10px}
.dz-img{max-width:100%;height:auto;border-radius:16px;border:1px solid rgba(230,232,242,.95);display:block}

/* Status badges */
.b-pending{background:rgba(250,204,21,.14);border:1px solid rgba(250,204,21,.30)}
.b-approved{background:rgba(59,130,246,.14);border:1px solid rgba(59,130,246,.30)}
.b-approved-blue{background:rgba(59,130,246,.14);border:1px solid rgba(59,130,246,.30)}
.b-shipped{background:rgba(168,85,247,.14);border:1px solid rgba(168,85,247,.30)}
.b-completed{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.30)}
.b-rejected{background:rgba(239,68,68,.14);border:1px solid rgba(239,68,68,.30)}
.b-declined{background:rgba(239,68,68,.14);border:1px solid rgba(239,68,68,.30)}
.b-done{background:rgba(168,85,247,.14);border:1px solid rgba(168,85,247,.30)}

/* Inbox KPI tiles */
.kpi-row{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}
.kpi-tile{display:block;min-width:130px;flex:1;max-width:190px;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);text-decoration:none;color:inherit;box-shadow:0 10px 30px rgba(0,0,0,.18);transition:transform .12s ease, background .12s ease, border-color .12s ease}
.kpi-tile:hover{transform:translateY(-1px)}
.kpi-tile.is-active{border-color:rgba(255,255,255,.24);background:rgba(255,255,255,.06)}
.kpi-tile.kpi-ghost{opacity:.85}
.kpi-num{font-size:22px;font-weight:900;line-height:1}
.kpi-lbl{margin-top:6px;font-size:12px;opacity:.85}

/* Toast */
.toast{position:fixed;right:18px;bottom:18px;z-index:9999;max-width:520px;padding:12px 14px;border-radius:14px;background:rgba(16,185,129,.14);border:1px solid rgba(16,185,129,.28);box-shadow:0 18px 45px rgba(0,0,0,.28)}
.toast.hide{opacity:0;transform:translateY(8px);transition:all .25s ease}
.st-item{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:center}
.st-thumb{width:72px;height:72px;border-radius:18px;overflow:hidden;border:1px solid rgba(230,232,242,.95);background:rgba(255,255,255,.7)}
.st-thumb img{width:100%;height:100%;object-fit:cover;display:block}

.dash{display:grid;grid-template-columns: 220px 1fr; gap:14px}
.dash-nav{display:flex;flex-direction:column;gap:8px}
.dn{padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.55);border:1px solid rgba(230,232,242,.9);font-weight:900;color:var(--muted)}
.dn:hover{color:var(--text);background:rgba(255,255,255,.8)}
.dash-main{min-width:0}


/* Premium Dashboard 14.1 */
.page-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.page-head-left{min-width:240px}
.page-head-right{display:flex;align-items:flex-end;justify-content:flex-end}
.dash-filter{display:flex;flex-direction:column;gap:6px}
.df-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.inp-sm{padding:8px 10px;border-radius:12px}
.df-id{max-width:180px}

.card-header{padding:14px 16px;border-bottom:1px solid rgba(230,232,242,.9);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-body{padding:14px 16px}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:12px 0 14px}
.kpi-card{background:rgba(255,255,255,.62)
  padding:18px 18px;
}
.kpi-label{font-size:12px;color:var(--muted);font-weight:900}
.kpi-value{font-size:30px;font-weight:1000;line-height:1.05;margin-top:8px}
.kpi-sub{margin-top:8px;font-size:12px;color:var(--muted)}
.kpi-card .kpi-value{ margin:0 0 6px 0; }
.kpi-card .kpi-sub{ margin:0; }


.actions-row{display:flex;flex-wrap:wrap;gap:10px}
.actions-row .btn{flex:1;min-width:180px;justify-content:center}

/* Settings 14.2 */
.form{display:block}
.form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-start}
.form-col{flex:1;min-width:240px}
.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}
.hint{margin-top:6px;font-size:12px;color:var(--muted);font-weight:800}
.toggle-link{font-weight:900;color:var(--blue);text-decoration:none;cursor:pointer}
.toggle-link:hover{text-decoration:underline}
.section-title{font-weight:1000;margin:2px 0 10px 0}
.divider{height:1px;background:rgba(230,232,242,.9);margin:14px 0}
.api-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.api-key{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  padding:10px 12px;border-radius:14px;border:1px solid rgba(230,232,242,.9);background:rgba(255,255,255,.55);font-weight:900}

.table-dashboard .tr{grid-template-columns: 140px 1.1fr 1.6fr 170px 120px}

@media (max-width: 980px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .table-dashboard .tr{grid-template-columns: 1fr 1fr; grid-auto-rows:auto}
  .table-dashboard .tr.th{display:none}
  .table-dashboard .tr>div:nth-child(1)::before{content:'Дата: ';font-weight:900;color:var(--muted)}
  .table-dashboard .tr>div:nth-child(2)::before{content:'Магазин: ';font-weight:900;color:var(--muted)}
  .table-dashboard .tr>div:nth-child(3)::before{content:'Акция/товар: ';font-weight:900;color:var(--muted)}
  .table-dashboard .tr>div:nth-child(4)::before{content:'Статус: ';font-weight:900;color:var(--muted)}
}
.kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:12px}
.kpi-n{font-size:28px;font-weight:1000;margin-top:6px}
.table{display:flex;flex-direction:column;gap:8px}
.tr{display:grid;grid-template-columns: 80px 1.4fr 1fr 1fr 1fr; gap:10px;align-items:center;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.55);border:1px solid rgba(230,232,242,.9)}
.tr.th{font-weight:900;color:var(--muted);background:rgba(255,255,255,.8)}
.list{display:flex;flex-direction:column;gap:10px}
.list-item{padding:12px 12px;border-radius:16px;background:rgba(255,255,255,.6);border:1px solid rgba(230,232,242,.9)}

.checklist{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;border:1px solid rgba(230,232,242,.9);border-radius:16px;padding:10px;background:rgba(255,255,255,.55)}

@media (max-width: 980px){
  .hero{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  .grid3{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .cards2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .sticky{position:static}
  .dash{grid-template-columns:1fr}
  .dash-nav{flex-direction:row;flex-wrap:wrap}
  .kpi{grid-template-columns:repeat(2,1fr)}
  .tr{grid-template-columns: 70px 1fr 1fr; grid-auto-rows:auto}
}

.bg-blobs{position:fixed;inset:0;pointer-events:none;z-index:0}
.blob{position:absolute;border-radius:999px;filter: blur(32px);opacity:.35}
.b1{width:360px;height:360px;left:-120px;top:120px;background:rgba(43,107,255,.6)}
.b2{width:420px;height:420px;right:-140px;top:40px;background:rgba(255,122,24,.55)}
.b3{width:300px;height:300px;left:40%;bottom:-140px;background:rgba(88,168,255,.5)}
main, header, footer{position:relative;z-index:1}

/* Clipboard copy + toast */
.copy-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;line-height:1;border-radius:10px;padding:6px 8px;border:1px solid rgba(230,232,242,.9);background:rgba(255,255,255,.55);color:var(--muted);cursor:pointer;text-decoration:none;font-weight:900}
.copy-btn:hover{background:rgba(255,255,255,.85);color:var(--text)}
.copy-btn svg{width:14px;height:14px;display:block}
.copy-wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(12px);opacity:0;pointer-events:none;z-index:9999;
  background:rgba(15,17,22,.92);color:#fff;padding:10px 12px;border-radius:14px;font-weight:900;border:1px solid rgba(255,255,255,.14);
  transition: opacity .18s ease, transform .18s ease;max-width:92vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* Product media manager */
.media-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.media-item{border-radius:16px;overflow:hidden;border:1px solid rgba(230,232,242,.9);background:rgba(255,255,255,.55)}
.media-thumb{display:block;width:100%;aspect-ratio:1/1;object-fit:cover}
.media-bar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:8px}
.media-actions{display:flex;gap:6px;flex-wrap:wrap}
.badge-cover{padding:4px 8px;border-radius:999px;font-weight:900;font-size:12px;background:rgba(46,204,113,.14);border:1px solid rgba(46,204,113,.24)}
.btn-mini{padding:6px 8px;border-radius:12px;font-size:12px;font-weight:900}
.btn-danger{background:rgba(255,80,80,.12);border:1px solid rgba(255,80,80,.22);color:var(--text)}
.btn-danger:hover{background:rgba(255,80,80,.18)}

.ph{border-radius:14px;background:rgba(255,255,255,.08);border:1px dashed rgba(230,232,242,.6);display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:900}
.ph.square{aspect-ratio:1/1;width:100%}

@media (max-width: 980px){
  .media-grid{grid-template-columns:repeat(2,1fr)}
}

/* ===== CRM v1 (/dashboard/claims) ===== */
.crm-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.crm-filters{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;}
.crm-search{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;}
.crm-toolbar .form-col{min-width:160px;}
.crm-toolbar .inp-q{min-width:320px;}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.table-crm{min-width:1120px;}
.table.table-crm .tr{grid-template-columns:44px 160px 1.1fr 1.8fr 160px 160px 120px;}
.table.table-crm .tr.is-open{outline:2px solid rgba(43,107,255,.25);box-shadow:0 0 0 6px rgba(43,107,255,.08);border-radius:16px;}

/* CRM v2 bulk actions */
.bulkbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid rgba(0,0,0,.10);border-radius:14px;background:rgba(255,255,255,.06);margin-bottom:10px}
.bulkbar-left{display:flex;align-items:center;gap:10px}
.bulkbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bulkbar-comment{margin:10px 0 14px;padding:10px 12px;border:1px dashed rgba(0,0,0,.16);border-radius:14px;background:rgba(255,255,255,.04)}
.table-checkbox{width:18px;height:18px;cursor:pointer}

@media (max-width: 820px){
  .bulkbar{flex-direction:column;align-items:stretch}
  .bulkbar-left{justify-content:space-between}
}

.pager{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:14px;}
.pager a,.pager span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:36px;padding:0 10px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.06);color:var(--muted);text-decoration:none;font-weight:900;}
.pager a:hover{background:rgba(255,255,255,.10);color:var(--text);}
.pager .is-active{color:var(--text);border-color:rgba(43,107,255,.35);background:rgba(88,168,255,.10);}
.pager .is-disabled{opacity:.45;pointer-events:none;}
.pager .dots{border:0;background:transparent;min-width:auto;padding:0 4px;}

@media (max-width: 980px){
  .crm-toolbar .inp-q{min-width:260px;}
}
@media (max-width: 720px){
  .crm-toolbar{gap:10px;}
  .crm-toolbar .form-col{min-width:140px;}
  .crm-toolbar .inp-q{min-width:220px;}
}

/* ===== CRM v3 Quick View Modal (/dashboard/claims) ===== */
.crm-modal-scrim{position:fixed;inset:0;background:rgba(10,12,20,.55);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}
.crm-modal{width:min(1100px,100%);max-height:90vh;background:#fff;border-radius:18px;box-shadow:0 18px 55px rgba(20,20,40,.25);overflow:hidden;display:flex;flex-direction:column}
.crm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(20,20,30,.08)}
.crm-modal-title{font-size:16px;font-weight:900}
.crm-modal-body{padding:14px;overflow:auto}
.crm-modal-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:12px}
.crm-modal-col{min-width:0}
@media (max-width: 900px){.crm-modal-grid{grid-template-columns:1fr}}

.crm-kv{display:flex;gap:10px;padding:6px 0;border-bottom:1px dashed rgba(20,20,30,.08)}
.crm-kv:last-child{border-bottom:none}
.crm-kv .k{width:140px;flex:0 0 140px;color:#6e6c78;font-size:12px}
.crm-kv .v{flex:1 1 auto;font-size:13px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}

.thumb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width: 540px){.thumb-grid{grid-template-columns:repeat(2,1fr)}}
.thumb{display:block;border-radius:14px;overflow:hidden;border:1px solid rgba(20,20,30,.10);background:#fff}
.thumb img{width:100%;height:110px;object-fit:cover;display:block}

.crm-timeline{display:flex;flex-direction:column;gap:10px}
.crm-timeline-item{display:grid;grid-template-columns:120px 1fr;gap:10px}
.crm-timeline-ts{font-size:12px;color:#6e6c78}
.crm-timeline-action{font-size:13px;font-weight:900}
.crm-timeline-note{margin-top:2px}

.crm-lightbox{position:fixed;inset:0;z-index:10000;background:rgba(10,12,20,.80);display:flex;align-items:center;justify-content:center;padding:16px}
.crm-lightbox-inner{width:min(1100px,100%);max-height:90vh;display:flex;align-items:center;justify-content:center}
.crm-lightbox img{max-width:100%;max-height:90vh;border-radius:16px;box-shadow:0 18px 55px rgba(0,0,0,.35);background:#fff}

.crm-skeleton{padding:8px 2px}
.crm-skel-line{height:12px;border-radius:10px;background:rgba(20,20,30,.07);margin:10px 0}
.crm-skel-line:nth-child(2){width:85%}
.crm-skel-line:nth-child(3){width:70%}

body.modal-open{ overflow:hidden; }
