/* =========================================================================
   DLTA STOREFRONT — DESIGN SYSTEM  (tactical-futuristic)
   ========================================================================= */
:root{
  --bg:#06090b;
  --bg-2:#0a1014;
  --panel:rgba(18,26,30,.72);
  --panel-solid:#0e151a;
  --glass:rgba(20,32,36,.55);
  --line:rgba(124,255,79,.14);
  --line-soft:rgba(170,200,190,.10);
  --txt:#e9f4ee;
  --txt-dim:#8da39a;
  --txt-faint:#5d716a;
  --acc:#7cff4f;        /* tactical lime */
  --acc-2:#19e3c2;      /* signal teal   */
  --acc-deep:#0f3f24;
  --danger:#ff5d57;
  --warn:#ffc24b;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 24px 60px -28px rgba(0,0,0,.85);
  --glow:0 0 0 1px rgba(124,255,79,.35), 0 0 26px -6px rgba(124,255,79,.45);
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:"Space Grotesk","Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--txt);
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(25,227,194,.10), transparent 60%),
    radial-gradient(1000px 600px at -10% 10%, rgba(124,255,79,.10), transparent 55%),
    var(--bg);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{ /* tactical grid */
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(124,255,79,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(124,255,79,.045) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%,#000,transparent 85%);
          mask-image:radial-gradient(circle at 50% 30%,#000,transparent 85%);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit}
::selection{background:rgba(124,255,79,.3);color:#fff}
.wrap{position:relative;z-index:1;max-width:1240px;margin:0 auto;padding:0 22px}
.mono{font-family:var(--mono)}
.tag{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--acc)}

/* ---------- TOP BANNER (demo / status) ---------- */
#banner{position:relative;z-index:5;display:none;align-items:center;gap:10px;justify-content:center;
  padding:8px 16px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-align:center;
  background:linear-gradient(90deg,rgba(255,194,75,.16),rgba(255,194,75,.06));
  color:#ffd886;border-bottom:1px solid rgba(255,194,75,.25)}
#banner.show{display:flex}
#banner b{color:#fff}
#banner svg{width:17px;height:17px;flex:0 0 auto;stroke:#ffd886}

/* ---------- HEADER ---------- */
header.nav{position:sticky;top:0;z-index:40;backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(6,9,11,.92),rgba(6,9,11,.55));
  border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:18px;height:66px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.04em}
.brand .logo{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--acc),var(--acc-2));color:#04140a;font-weight:800;
  font-family:var(--mono);box-shadow:var(--glow);font-size:18px}
.brand .bt{font-size:19px;line-height:1}
.brand .bs{font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--txt-dim);text-transform:uppercase}
.nav-spacer{flex:1}
.nav-search{position:relative;flex:0 1 320px;display:none}
.nav-search input{width:100%;height:42px;border-radius:12px;padding:0 14px 0 38px;color:var(--txt);
  background:var(--glass);border:1px solid var(--line-soft);outline:none;transition:.2s}
.nav-search input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(124,255,79,.12)}
.nav-search svg{position:absolute;left:12px;top:12px;width:18px;height:18px;stroke:var(--txt-dim)}
@media(min-width:880px){.nav-search{display:block}}
.cart-btn{position:relative;display:flex;align-items:center;gap:9px;height:44px;padding:0 16px;border-radius:12px;
  background:var(--glass);border:1px solid var(--line);font-weight:600;transition:.2s}
.cart-btn:hover{border-color:var(--acc);box-shadow:var(--glow)}
.cart-btn svg{width:20px;height:20px;stroke:var(--acc);fill:none}
.cart-count{min-width:20px;height:20px;padding:0 6px;border-radius:20px;display:grid;place-items:center;
  font-family:var(--mono);font-size:11px;font-weight:700;color:#04140a;background:var(--acc);
  transform:scale(0);transition:transform .25s cubic-bezier(.2,1.4,.4,1)}
.cart-count.on{transform:scale(1)}

/* ---------- HERO ---------- */
.hero{position:relative;padding:64px 0 30px;overflow:hidden}
.hero h1{font-size:clamp(34px,6vw,68px);line-height:1.02;margin:14px 0 0;font-weight:700;letter-spacing:-.02em}
.hero h1 .grad{background:linear-gradient(120deg,var(--acc),var(--acc-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{max-width:560px;color:var(--txt-dim);font-size:17px;margin:18px 0 0;line-height:1.6}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-stats{display:flex;gap:30px;margin-top:40px;flex-wrap:wrap}
.hstat .n{font-family:var(--mono);font-size:26px;font-weight:700;color:var(--acc)}
.hstat .l{font-size:12px;color:var(--txt-faint);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}
.hero-orb{position:absolute;right:-120px;top:-40px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle at 40% 40%,rgba(25,227,194,.25),transparent 60%);filter:blur(20px);
  z-index:0;pointer-events:none;animation:float 9s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(24px)}}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:50px;padding:0 26px;border-radius:13px;
  font-weight:700;letter-spacing:.01em;transition:.18s;white-space:nowrap}
.btn-primary{background:linear-gradient(120deg,var(--acc),var(--acc-2));color:#04140a;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(124,255,79,.6),0 16px 40px -12px rgba(124,255,79,.5)}
.btn-ghost{background:var(--glass);border:1px solid var(--line);color:var(--txt)}
.btn-ghost:hover{border-color:var(--acc)}
.btn[disabled]{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none}
.btn-block{width:100%}

/* ---------- MOBILE SEARCH (shown < 880px) ---------- */
.mobile-search{display:none;position:relative;margin:2px 0 20px}
.mobile-search input{width:100%;height:46px;border-radius:12px;padding:0 14px 0 42px;color:var(--txt);
  background:var(--glass);border:1px solid var(--line-soft);outline:none;transition:.2s;font-size:15px}
.mobile-search input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(124,255,79,.12)}
.mobile-search svg{position:absolute;left:13px;top:14px;width:18px;height:18px;stroke:var(--txt-dim)}
@media(max-width:879px){.mobile-search{display:block}}

/* ---------- SECTION / FILTERS ---------- */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:30px 0 18px;flex-wrap:wrap}
.section-head h2{font-size:24px;margin:6px 0 0;letter-spacing:-.01em}
.chips{display:flex;gap:9px;flex-wrap:wrap}
.chip{height:36px;padding:0 16px;border-radius:30px;font-size:13px;font-weight:600;color:var(--txt-dim);
  background:var(--glass);border:1px solid var(--line-soft);transition:.16s}
.chip:hover{color:var(--txt)}
.chip.active{color:#04140a;background:var(--acc);border-color:var(--acc)}

/* ---------- PRODUCT GRID ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:20px;padding-bottom:40px}
.card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--panel);
  border:1px solid var(--line-soft);box-shadow:var(--shadow);transition:.22s;cursor:pointer;
  display:flex;flex-direction:column;opacity:0;transform:translateY(14px)}
.card.in{opacity:1;transform:none}
.card:hover{border-color:var(--acc);transform:translateY(-5px)}
.card:hover .card-img img{transform:scale(1.07)}
.card-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:#0c1418}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.card-img .scan{position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(124,255,79,.06));
  opacity:0;transition:.3s}
.card:hover .card-img .scan{opacity:1}
.card-badge{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  padding:5px 9px;border-radius:7px;background:rgba(6,9,11,.7);border:1px solid var(--line);color:var(--acc);
  text-transform:uppercase;backdrop-filter:blur(6px)}
.card-body{padding:15px 16px 17px;display:flex;flex-direction:column;gap:4px;flex:1}
.card-name{font-weight:700;font-size:16px;letter-spacing:.01em}
.card-variants{font-size:12px;color:var(--txt-faint);font-family:var(--mono);min-height:15px}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.card-price{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--acc)}
.card-add{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:var(--glass);
  border:1px solid var(--line);transition:.16s}
.card-add svg{width:19px;height:19px;stroke:var(--acc)}
.card-add:hover{background:var(--acc)}
.card-add:hover svg{stroke:#04140a}
.skeleton{aspect-ratio:1/1;border-radius:var(--radius);background:
  linear-gradient(100deg,#0c1418 30%,#142028 50%,#0c1418 70%);background-size:200% 100%;
  animation:sh 1.3s infinite}
.sk-card{height:330px;border-radius:var(--radius);background:
  linear-gradient(100deg,#0c1418 30%,#142028 50%,#0c1418 70%);background-size:200% 100%;animation:sh 1.3s infinite}
@keyframes sh{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ---------- MODAL / DRAWER SHELL ---------- */
.scrim{position:fixed;inset:0;z-index:60;background:rgba(2,5,7,.72);backdrop-filter:blur(5px);
  opacity:0;visibility:hidden;transition:.25s}
.scrim.open{opacity:1;visibility:visible}
.modal{position:fixed;z-index:70;left:50%;top:50%;transform:translate(-50%,-46%) scale(.97);
  width:min(960px,94vw);max-height:90vh;overflow:auto;background:var(--panel-solid);
  border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);
  opacity:0;visibility:hidden;transition:.28s cubic-bezier(.2,.9,.3,1)}
.modal.open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.drawer{position:fixed;z-index:70;top:0;right:0;height:100vh;width:min(460px,100vw);
  background:var(--panel-solid);border-left:1px solid var(--line);box-shadow:var(--shadow);
  transform:translateX(102%);transition:.32s cubic-bezier(.3,.9,.3,1);display:flex;flex-direction:column}
.drawer.open{transform:none}
.x-btn{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:var(--glass);border:1px solid var(--line-soft);z-index:2;transition:.16s}
.x-btn:hover{border-color:var(--danger)}
.x-btn svg{width:18px;height:18px;stroke:var(--txt)}

/* ---------- PRODUCT MODAL ---------- */
.pm{display:grid;grid-template-columns:1fr 1fr;gap:0}
@media(max-width:760px){.pm{grid-template-columns:1fr}}
.pm-gallery{background:#0a1216;padding:24px;display:flex;flex-direction:column;gap:14px}
.pm-main{aspect-ratio:1/1;border-radius:14px;overflow:hidden;background:#0c1418;border:1px solid var(--line-soft)}
.pm-main img{width:100%;height:100%;object-fit:cover}
.pm-thumbs{display:flex;gap:9px;flex-wrap:wrap}
.pm-thumb{width:58px;height:58px;border-radius:10px;overflow:hidden;border:1px solid var(--line-soft);opacity:.6;transition:.16s;cursor:pointer}
.pm-thumb.active{opacity:1;border-color:var(--acc)}
.pm-thumb img{width:100%;height:100%;object-fit:cover}
.pm-info{padding:30px 30px 28px;display:flex;flex-direction:column}
.pm-info h3{font-size:27px;margin:8px 0 6px;letter-spacing:-.01em}
.pm-price{font-family:var(--mono);font-size:24px;font-weight:700;color:var(--acc);margin:6px 0 18px}
.pm-desc{color:var(--txt-dim);line-height:1.6;font-size:14px;margin-bottom:20px}
.opt-label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--txt-faint);margin:0 0 10px;font-family:var(--mono)}
.opt-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.opt{height:42px;padding:0 16px;border-radius:11px;font-weight:600;font-size:14px;color:var(--txt);
  background:var(--glass);border:1px solid var(--line-soft);transition:.16s}
.opt:hover{border-color:var(--acc-2)}
.opt.active{color:#04140a;background:var(--acc);border-color:var(--acc)}
.opt[disabled]{opacity:.35;cursor:not-allowed;text-decoration:line-through}
.qty{display:flex;align-items:center;gap:0;width:140px;height:46px;border-radius:12px;border:1px solid var(--line);overflow:hidden;background:var(--glass)}
.qty button{width:46px;height:100%;font-size:20px;color:var(--acc);transition:.14s}
.qty button:hover{background:var(--glass)}
.qty input{flex:1;height:100%;text-align:center;background:none;border:0;color:var(--txt);font-family:var(--mono);font-weight:700;outline:none}
.pm-actions{margin-top:auto;padding-top:22px;display:flex;gap:12px;align-items:center}

/* ---------- CART DRAWER ---------- */
.drawer-head{display:flex;align-items:center;gap:12px;padding:22px 22px 16px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:18px;margin:0;letter-spacing:.02em}
.drawer-head .tag{margin-left:auto;margin-right:34px}
.cart-items{flex:1;overflow:auto;padding:8px 16px}
.ci{display:flex;gap:13px;padding:14px 8px;border-bottom:1px solid var(--line-soft)}
.ci-img{width:66px;height:66px;border-radius:11px;overflow:hidden;flex-shrink:0;background:#0c1418;border:1px solid var(--line-soft)}
.ci-img img{width:100%;height:100%;object-fit:cover}
.ci-mid{flex:1;min-width:0}
.ci-name{font-weight:600;font-size:14px}
.ci-var{font-size:12px;color:var(--txt-faint);font-family:var(--mono);margin-top:1px}
.ci-price{font-family:var(--mono);color:var(--acc);font-size:13px;margin-top:6px}
.ci-qty{display:flex;align-items:center;gap:8px;margin-top:8px}
.ci-qty button{width:34px;height:34px;border-radius:8px;border:1px solid var(--line-soft);color:var(--acc);font-size:17px;line-height:1;transition:.14s}
.ci-qty button:hover{border-color:var(--acc)}
.ci-qty span{font-family:var(--mono);font-size:14px;min-width:22px;text-align:center}
.ci-rm{align-self:flex-start;color:var(--txt-faint);font-size:12px;transition:.14s}
.ci-rm:hover{color:var(--danger)}
.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--txt-faint);text-align:center;padding:40px}
.cart-empty svg{width:54px;height:54px;stroke:var(--line);opacity:.5}
.drawer-foot{padding:18px 22px 22px;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(124,255,79,.03))}
.drawer-foot .row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.drawer-foot .row .lbl{color:var(--txt-dim);font-size:14px}
.drawer-foot .row .val{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--acc)}

/* ---------- CHECKOUT ---------- */
.co{display:grid;grid-template-columns:1.4fr 1fr;gap:0;min-height:520px}
@media(max-width:820px){.co{grid-template-columns:1fr}}
.co-main{padding:30px 32px;border-right:1px solid var(--line)}
@media(max-width:820px){.co-main{border-right:0;border-bottom:1px solid var(--line)}}
.co-side{padding:30px 28px;background:#0a1216}
.steps{display:flex;gap:8px;margin-bottom:26px}
.step{flex:1;display:flex;flex-direction:column;gap:7px}
.step .bar{height:4px;border-radius:4px;background:var(--line-soft);transition:.3s}
.step.done .bar,.step.active .bar{background:var(--acc)}
.step .t{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--txt-faint)}
.step.active .t{color:var(--acc)}.step.done .t{color:var(--txt-dim)}
.co-pane{display:none;animation:fade .3s}
.co-pane.show{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1}}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--txt-dim);margin-bottom:7px;font-family:var(--mono)}
.field label .req{color:var(--acc)}
.field input,.field textarea,.field select{width:100%;height:48px;border-radius:12px;padding:0 14px;color:var(--txt);
  background:var(--glass);border:1px solid var(--line-soft);outline:none;transition:.18s;font-size:15px}
.field textarea{height:auto;padding:13px 14px;min-height:74px;resize:vertical;line-height:1.5}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(124,255,79,.12)}
.field .err{color:var(--danger);font-size:12px;margin-top:6px;display:none}
.field.invalid .err{display:block}
.field.invalid input,.field.invalid textarea{border-color:var(--danger)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.two{grid-template-columns:1fr}}
/* address autocomplete */
.ac{position:relative}
.ac-list{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:5;max-height:230px;overflow:auto;
  background:var(--panel-solid);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);display:none}
.ac-list.show{display:block}
.ac-item{padding:11px 14px;font-size:14px;border-bottom:1px solid var(--line-soft);transition:.12s;cursor:pointer}
.ac-item:hover,.ac-item.kb{background:rgba(124,255,79,.10)}
.ac-item small{display:block;color:var(--txt-faint);font-size:12px;margin-top:2px}
.ac-empty{padding:14px;color:var(--txt-faint);font-size:13px;text-align:center}
.selected-loc{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;background:rgba(124,255,79,.06);
  border:1px solid var(--line);font-size:14px}
.selected-loc svg{width:18px;height:18px;stroke:var(--acc);flex-shrink:0}
.selected-loc button{margin-left:auto;color:var(--txt-faint);font-size:12px}
.selected-loc button:hover{color:var(--danger)}
/* option lists (shipping / payment) */
.opt-list{display:flex;flex-direction:column;gap:11px}
.opt-card{display:flex;align-items:center;gap:14px;padding:15px 16px;border-radius:13px;background:var(--glass);
  border:1px solid var(--line-soft);transition:.16s;cursor:pointer;text-align:left;width:100%}
.opt-card:hover{border-color:var(--acc-2)}
.opt-card.active{border-color:var(--acc);background:rgba(124,255,79,.07);box-shadow:0 0 0 1px rgba(124,255,79,.25)}
.opt-radio{width:20px;height:20px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;position:relative;transition:.16s}
.opt-card.active .opt-radio{border-color:var(--acc)}
.opt-card.active .opt-radio::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--acc)}
.opt-card .oc-mid{flex:1}
.opt-card .oc-t{font-weight:600;font-size:15px}
.opt-card .oc-s{font-size:12.5px;color:var(--txt-faint);margin-top:2px;font-family:var(--mono)}
.opt-card .oc-price{font-family:var(--mono);font-weight:700;color:var(--acc)}
.pay-ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:#0c1418;border:1px solid var(--line-soft)}
.pay-ico svg{width:22px;height:22px;stroke:var(--acc);fill:none}
.muted{color:var(--txt-faint);font-size:13px;line-height:1.6}
.hint{display:flex;gap:9px;align-items:flex-start;padding:12px 14px;border-radius:11px;background:rgba(25,227,194,.07);
  border:1px solid rgba(25,227,194,.2);font-size:13px;color:#bfeee6;margin-top:4px}
.hint svg{width:17px;height:17px;stroke:var(--acc-2);flex-shrink:0;margin-top:1px}

/* summary side */
.sum-h{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--txt-faint);margin-bottom:18px}
.sum-items{display:flex;flex-direction:column;gap:12px;max-height:230px;overflow:auto;margin-bottom:18px}
.sum-it{display:flex;gap:11px}
.sum-it .si-img{width:50px;height:50px;border-radius:9px;overflow:hidden;flex-shrink:0;background:#0c1418;border:1px solid var(--line-soft);position:relative}
.sum-it .si-img img{width:100%;height:100%;object-fit:cover}
.sum-it .si-q{position:absolute;top:-7px;right:-7px;width:20px;height:20px;border-radius:50%;background:var(--acc);color:#04140a;font-family:var(--mono);font-size:11px;font-weight:700;display:grid;place-items:center}
.sum-it .si-n{font-size:13px;font-weight:600;line-height:1.3}
.sum-it .si-v{font-size:11px;color:var(--txt-faint);font-family:var(--mono)}
.sum-it .si-p{font-size:13px;font-family:var(--mono);color:var(--txt-dim);margin-left:auto;white-space:nowrap}
.sum-line{display:flex;justify-content:space-between;font-size:14px;color:var(--txt-dim);padding:7px 0}
.sum-line .v{font-family:var(--mono);color:var(--txt)}
.sum-div{height:1px;background:var(--line);margin:10px 0}
.sum-total{display:flex;justify-content:space-between;align-items:baseline;margin:6px 0 18px}
.sum-total .l{font-size:14px;color:var(--txt-dim)}
.sum-total .v{font-family:var(--mono);font-size:26px;font-weight:700;color:var(--acc);transition:opacity .2s}
.sum-total .v.loading{opacity:.45;animation:pulse 1s ease-in-out infinite}
.disc-row{display:flex;gap:8px;margin:4px 0 16px}
.disc-row input{flex:1;height:44px;border-radius:11px;padding:0 13px;background:var(--glass);border:1px solid var(--line-soft);color:var(--txt);outline:none;text-transform:uppercase;font-family:var(--mono);font-size:13px}
.disc-row button{height:44px;padding:0 16px;border-radius:11px;border:1px solid var(--line);background:var(--glass);font-weight:600;font-size:13px}
.disc-row button:hover{border-color:var(--acc)}
.disc-msg{font-size:12.5px;margin:-8px 0 14px;font-family:var(--mono)}
.disc-msg.ok{color:var(--acc)}.disc-msg.no{color:var(--danger)}

/* ---------- ORDER / PAYMENT RESULT ---------- */
.result{padding:34px 34px 38px;text-align:center;max-width:640px;margin:0 auto}
.result .seal{width:78px;height:78px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center;
  background:radial-gradient(circle,rgba(124,255,79,.25),transparent 70%);border:1px solid var(--line)}
.result .seal svg{width:40px;height:40px;stroke:var(--acc)}
.result h3{font-size:25px;margin:0 0 6px}
.result .oid{font-family:var(--mono);color:var(--txt-dim);font-size:13px;margin-bottom:22px}
.pay-box{text-align:left;background:#0a1216;border:1px solid var(--line);border-radius:16px;padding:22px;margin:18px 0}
.pay-box h4{margin:0 0 14px;font-size:14px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--acc);display:flex;align-items:center;gap:9px}
.pay-box h4 svg{width:18px;height:18px;flex:0 0 auto}
.btn svg{width:19px;height:19px;flex:0 0 auto}
.pay-kv{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.pay-kv:last-child{border-bottom:0}
.pay-kv .k{color:var(--txt-dim);font-size:13px}
.pay-kv .v{font-family:var(--mono);font-weight:700;font-size:15px;display:flex;align-items:center;gap:9px}
.copy{width:34px;height:34px;border-radius:8px;border:1px solid var(--line-soft);display:grid;place-items:center;transition:.14s}
.copy:hover{border-color:var(--acc)}
.copy svg{width:15px;height:15px;stroke:var(--acc)}
.qr-wrap{display:flex;justify-content:center;margin:8px 0}
.qr-wrap img{width:190px;height:190px;border-radius:12px;background:#fff;padding:10px}
.upload-zone{border:1.5px dashed var(--line);border-radius:13px;padding:22px;text-align:center;transition:.16s;cursor:pointer;margin-top:6px}
.upload-zone:hover{border-color:var(--acc)}
.upload-zone svg{width:30px;height:30px;stroke:var(--acc);margin-bottom:8px}
.upload-zone.has{border-style:solid;border-color:var(--acc)}
.status-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 15px;border-radius:30px;font-family:var(--mono);
  font-size:12px;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--line)}
.status-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--warn);animation:pulse 1.4s infinite}
.status-pill.paid{border-color:var(--acc);color:var(--acc)}
.status-pill.paid .dot{background:var(--acc);animation:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ---------- TOAST ---------- */
#toasts{position:fixed;z-index:90;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{display:flex;align-items:center;gap:11px;padding:13px 18px;border-radius:13px;background:var(--panel-solid);
  border:1px solid var(--line);box-shadow:var(--shadow);font-size:14px;font-weight:500;
  transform:translateY(20px);opacity:0;transition:.3s}
.toast.show{transform:none;opacity:1}
.toast svg{width:19px;height:19px;stroke:var(--acc);flex-shrink:0}
.toast.err svg{stroke:var(--danger)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);margin-top:50px;padding:34px 0;color:var(--txt-faint);font-size:13px}
.foot-in{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}
.foot-in a:hover{color:var(--acc)}

/* spinner */
.spin{width:18px;height:18px;border-radius:50%;border:2px solid rgba(124,255,79,.25);border-top-color:var(--acc);animation:rot .7s linear infinite;display:inline-block}
.spin.lg{width:34px;height:34px;border-width:3px}
@keyframes rot{to{transform:rotate(360deg)}}
.center-load{display:flex;flex-direction:column;align-items:center;gap:14px;padding:50px;color:var(--txt-dim);font-family:var(--mono);font-size:13px}
.scroll-lock{overflow:hidden}

/* WhatsApp floating button (only if configured) */
.wa-fab{position:fixed;z-index:50;right:20px;bottom:20px;width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;background:linear-gradient(135deg,#25d366,#1aa34a);color:#04140a;
  box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:.18s}
.wa-fab:hover{transform:translateY(-3px) scale(1.04)}
.wa-fab svg{width:28px;height:28px;stroke:#04140a}
