/* ── TOKENS ── */
:root{
  --bg:#030303;
  --surface:rgba(255,255,255,0.03);
  --border:rgba(255,255,255,0.08);
  --glow:rgba(0,170,255,0.28);
  --blur:blur(24px) saturate(180%);
  --ac:#00aaff;
  --ag:#50ffb0;
  --tp:#f1f5f9;
  --tm:#94a3b8;
  --td:#020617;
  --rlg:24px;
  --rmd:16px;
  --rp:9999px;
  --sh:0 4px 24px rgba(0,0,0,0.55),0 16px 64px rgba(0,0,0,0.65);
  --spec:inset 1px 1px 0 rgba(255,255,255,0.08),inset -1px -1px 0 rgba(0,0,0,0.4);
  --e:cubic-bezier(0.16,1,0.3,1);
  --cmax:1400px;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-family:'Montserrat',sans-serif;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{background:var(--bg);color:var(--tp);min-height:100vh;overflow-x:hidden}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#000}
::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:10px}
::selection{background:rgba(0,170,255,0.22);color:var(--ac)}
a{color:inherit;text-decoration:none}
button{border:none;background:none;font:inherit;cursor:pointer;color:inherit}
input,textarea,select{font:inherit;color:inherit;background:none;border:none}
input:focus,textarea:focus,select:focus{outline:none}

/* ── STAR CANVAS ── */
#sc{
  position:fixed;inset:0;z-index:0;
  background:
    radial-gradient(circle at 5% 50%,rgba(0,170,255,0.11),transparent 50%),
    radial-gradient(circle at 95% 50%,rgba(0,170,255,0.11),transparent 50%),
    linear-gradient(180deg,#060608,#000);
}

/* ─── CENTRE COLUMN ─── */
.vw{position:relative;z-index:10;width:100%;display:flex;justify-content:center}
.col{
  width:100%;
  max-width:var(--cmax);
  padding:0 24px;
  min-width:0;
}

/* ─── NAV ─── */
.nav-wrap{
  position:fixed;top:24px;left:50%;transform:translateX(-50%);
  width:calc(100% - 48px);
  max-width:calc(var(--cmax) - 48px);
  padding:0;
  z-index:100;
}
.nav-dock{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:14px;
  padding:8px 14px;
  background:rgba(5,8,15,0.55);
  border:1px solid var(--border);
  backdrop-filter:blur(22px) saturate(200%);
  -webkit-backdrop-filter:blur(22px) saturate(200%);
  border-radius:var(--rp);
  box-shadow:var(--sh),var(--spec);
  transition:border-color .4s;
}
.nav-dock:hover{border-color:rgba(255,255,255,0.11)}

.nav-brand{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;color:inherit;flex-shrink:0;
}
.nav-name{font-size:15px;font-weight:800;letter-spacing:-.3px}

.nav-search{position:relative;width:100%;}
.nav-search-icon{
  position:absolute;left:16px;top:50%;transform:translateY(-50%);
  color:var(--tm);pointer-events:none;flex-shrink:0;
}
.nav-search-input{
  width:100%;
  padding:10px 16px 10px 46px;
  background:rgba(0,0,0,0.28);
  border:1px solid var(--border);
  border-radius:var(--rp);
  color:var(--tp);font-size:13px;font-weight:500;
  transition:border-color .3s,background .3s,box-shadow .3s;
}
.nav-search-input:focus{
  border-color:var(--glow);
  background:rgba(0,0,0,0.42);
  box-shadow:0 0 14px rgba(0,170,255,0.08);
  outline:none;
}
.nav-search-input::placeholder{color:var(--tm)}

.nav-cta{
  padding:9px 22px;border-radius:var(--rp);
  background:linear-gradient(135deg,var(--ac),#0077cc);
  color:#fff;font-size:13px;font-weight:700;
  transition:all .3s var(--e);
  box-shadow:0 4px 16px rgba(0,170,255,0.25);
  white-space:nowrap;flex-shrink:0;
}
@media(hover:hover){.nav-cta:hover{transform:scale(1.05);box-shadow:0 6px 24px rgba(0,170,255,0.4)}}

/* ── HERO ── */
.hero{
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  padding:140px 0 60px;
  position:relative;z-index:10;
}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;background:rgba(0,170,255,0.05);
  border:1px solid rgba(0,170,255,0.15);border-radius:var(--rp);
  font-family:'Fira Code',monospace;font-size:11px;color:var(--ac);
  text-transform:uppercase;letter-spacing:1px;margin-bottom:28px;
}
.dot{width:6px;height:6px;background:var(--ag);border-radius:50%;animation:pulse 1.8s infinite}
@keyframes pulse{
  0%,100%{transform:scale(1);opacity:.5;box-shadow:0 0 0 0 rgba(80,255,176,0)}
  50%{transform:scale(1.2);opacity:1;box-shadow:0 0 8px 3px rgba(80,255,176,0.4)}
}
.h1{
  font-size:clamp(30px,5vw,60px);font-weight:900;line-height:1.05;
  letter-spacing:-2.5px;margin-bottom:22px;
  background:linear-gradient(175deg,var(--tp) 25%,rgba(241,245,249,0.5));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  max-width:720px;
}
.h1 .aw{background:linear-gradient(90deg,var(--ac),var(--ag));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-p{font-size:16px;line-height:1.7;color:var(--tm);margin-bottom:40px;max-width:500px;font-weight:400}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:56px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:13px 28px;border-radius:var(--rmd);font-size:14px;font-weight:700;
  transition:all .4s var(--e);
}
.btn.prim{background:linear-gradient(135deg,var(--ac),var(--ag));color:var(--td);box-shadow:0 10px 30px rgba(0,170,255,0.2)}
@media(hover:hover){.btn.prim:hover{transform:scale(1.05);box-shadow:0 14px 38px rgba(0,170,255,0.34)}}
.btn.glass{background:rgba(255,255,255,0.03);border:1px solid var(--border);color:var(--tp)}
@media(hover:hover){.btn.glass:hover{background:rgba(255,255,255,0.07);border-color:rgba(255,255,255,0.18);transform:scale(1.05)}}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:560px}
.stat{
  background:var(--surface);border:1px solid var(--border);padding:16px 12px;
  border-radius:var(--rmd);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
  box-shadow:var(--spec);position:relative;overflow:hidden;
}
.stat::before{content:'';position:absolute;inset:0;background:rgba(0,170,255,0.04);opacity:0;pointer-events:none}
.sn{display:block;font-size:22px;font-weight:800;color:var(--ac);font-family:'Fira Code',monospace;margin-bottom:3px}
.sl{font-size:11px;color:var(--tm);text-transform:uppercase;letter-spacing:.5px;font-weight:600}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(14px);filter:blur(8px);transition:opacity .7s var(--e),transform .7s var(--e),filter .7s var(--e)}
.rv.in{opacity:1;transform:translateY(0);filter:blur(0)}
.card-rv{opacity:0;filter:blur(5px);transition:opacity .5s var(--e),filter .5s var(--e)}
.card-rv.in{opacity:1;filter:blur(0)}

/* ── CATALOG SECTION ── */
.catalog-area{position:relative;z-index:50;padding-top:40px}
.sec-hd{margin-bottom:32px;text-align:center;padding:0 8px}
.stag{font-family:'Fira Code',monospace;font-size:11px;text-transform:uppercase;color:var(--ac);letter-spacing:2px;margin-bottom:10px;display:block}
.sh2{font-size:clamp(24px,3.5vw,40px);font-weight:800;letter-spacing:-1.2px;line-height:1.1;margin-bottom:12px}
.sd{color:var(--tm);font-size:14px;line-height:1.65;max-width:480px;margin:0 auto;font-weight:400}

.catalog-wrap{padding:0 0 80px}
.catalog-frame{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--rlg);
  padding:24px 22px 28px;
  backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
  box-shadow:var(--sh);
  transition:border-color .4s,box-shadow .4s;
  overflow:hidden;
}
@media(hover:hover){.catalog-frame:hover{border-color:var(--glow);box-shadow:0 0 28px rgba(0,170,255,0.06),var(--sh)}}

/* ── FILTER STRIP ── */
.filter-strip{
  display:flex;gap:5px;padding-bottom:4px;
  scrollbar-width:none;
  justify-content:center;
  flex-wrap:wrap;
  overflow:visible;
  margin-bottom:24px;
  min-width:0;
}
.filter-strip::-webkit-scrollbar{display:none}
.filter-btn-all{flex-shrink:0;}
.filter-btn{
  display:inline-flex;align-items:center;gap:4px;
  padding:7px 9px;border-radius:var(--rp);
  border:1px solid var(--border);background:rgba(255,255,255,0.03);
  color:var(--tm);font-size:clamp(9px,1.1vw,11.5px);font-weight:600;
  white-space:nowrap;flex-shrink:1;min-width:0;
  transition:color .25s,background .25s,border-color .25s;
  cursor:pointer;
}
@media(hover:hover){
  .filter-btn:hover{color:var(--tp);background:rgba(255,255,255,0.07);border-color:rgba(255,255,255,0.15)}
}
.filter-btn.act{color:var(--ac);background:rgba(0,170,255,0.08);border-color:rgba(0,170,255,0.25)}

/* Category blocks */
.cat-block{margin-bottom:28px}
.cat-block:last-child{margin-bottom:0}
.cat-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border);
}
.cat-title{font-size:14px;font-weight:800;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}
.cat-count{
  font-family:'Fira Code',monospace;font-size:10px;color:var(--tm);
  background:rgba(255,255,255,0.05);padding:2px 7px;
  border-radius:var(--rp);border:1px solid var(--border);
}

/* Card grid */
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}

/* Cards */
.promo-card{
  background:rgba(4,6,12,0.8);border:1px solid var(--border);
  border-radius:var(--rlg);padding:13px 11px;
  position:relative;overflow:hidden;
  backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
  box-shadow:var(--sh),var(--spec);
  transition:border-color .4s,box-shadow .4s;
  display:flex;flex-direction:column;gap:8px;width:100%;
}
.promo-card::after{
  content:'';position:absolute;inset:-1px;border-radius:calc(var(--rlg) + 1px);
  border:1px solid rgba(0,170,255,0);transition:border-color .4s;pointer-events:none;
}
@media(hover:hover){
  .promo-card:hover{border-color:rgba(0,170,255,0.3);box-shadow:0 0 20px rgba(0,170,255,0.1),var(--sh);}
  .promo-card:hover::after{border-color:rgba(0,170,255,0.18)}
}
.promo-top{display:flex;align-items:flex-start;justify-content:space-between;gap:4px}
.icon-badge{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-weight:800;font-size:8px;font-family:'Fira Code',monospace;border:1px solid rgba(255,255,255,0.1);flex-shrink:0}
.slot-code{font-family:'Fira Code',monospace;font-size:9px;padding:2px 6px;border-radius:var(--rp);background:rgba(255,255,255,0.05);border:1px solid var(--border);color:var(--tm)}
.promo-body h3{font-size:11px;font-weight:700;letter-spacing:-.1px;margin-bottom:2px;line-height:1.3}
.promo-body p{font-size:10px;color:var(--tm);line-height:1.5;font-weight:400}
.promo-cta{
  margin-top:auto;padding:7px 0;border-radius:var(--rmd);
  background:rgba(0,170,255,0.1);border:1px solid rgba(0,170,255,0.2);
  color:var(--ac);font-size:10px;font-weight:700;
  transition:background .3s,border-color .3s,box-shadow .3s;
  text-align:center;width:100%;cursor:pointer;
}
@media(hover:hover){
  .promo-cta:hover{
    background:rgba(0,170,255,0.18);
    border-color:rgba(0,170,255,0.5);
    box-shadow:0 0 12px rgba(0,170,255,0.3);
  }
}

.empty-state{
  padding:36px 16px;text-align:center;
  border:1px dashed rgba(255,255,255,0.1);border-radius:var(--rlg);
  color:var(--tm);font-size:13px;display:none;
}

/* ── ADVERTISE OVERLAY ── */
#adv-overlay{
  position:fixed;inset:0;z-index:500;
  display:flex;align-items:center;justify-content:center;padding:16px;
  background:rgba(0,0,0,0.6);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
#adv-overlay.on{opacity:1;pointer-events:all}

.adv-box{
  width:min(640px,100%);max-height:90vh;overflow-y:auto;
  background:rgba(10,10,12,0.82);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--rlg);box-shadow:0 8px 48px rgba(0,0,0,0.8),var(--sh);
  padding:36px;position:relative;
  backdrop-filter:blur(32px) saturate(130%);
  -webkit-backdrop-filter:blur(32px) saturate(130%);
  opacity:0;
  transition:opacity .35s ease;
  text-align:center;
}
#adv-overlay.on .adv-box{opacity:1}
.adv-box::-webkit-scrollbar{width:4px}
.adv-box::-webkit-scrollbar-track{background:transparent}
.adv-box::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:10px}

.adv-close{
  position:absolute;top:14px;right:14px;width:30px;height:30px;
  border-radius:50%;border:1px solid var(--border);background:rgba(255,255,255,0.04);
  display:grid;place-items:center;font-size:13px;color:var(--tm);
  transition:background .3s,color .3s;cursor:pointer;
}
@media(hover:hover){.adv-close:hover{background:rgba(255,255,255,0.1);color:var(--tp)}}
.adv-stag{font-family:'Fira Code',monospace;font-size:11px;text-transform:uppercase;color:var(--ac);letter-spacing:2px;margin-bottom:8px;display:block;text-align:center}
.adv-title{font-size:clamp(20px,3vw,28px);font-weight:800;letter-spacing:-.8px;margin-bottom:8px;text-align:center}
.adv-desc{font-size:13px;color:var(--tm);margin-bottom:24px;line-height:1.6;font-weight:400;text-align:center}

/* Form */
.adv-body{position:relative;overflow:hidden;transition:height 0.6s cubic-bezier(0.16,1,0.3,1)}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:left}
.fg .full{grid-column:1/-1}
.fi{
  width:100%;padding:12px 14px;background:rgba(0,0,0,0.3);
  border:1px solid var(--border);border-radius:var(--rmd);
  color:var(--tp);font-size:13px;font-weight:500;
  transition:border-color .3s,background .3s,box-shadow .3s;
}
.fi:focus{border-color:var(--glow);background:rgba(0,0,0,0.45);box-shadow:0 0 12px rgba(0,170,255,0.06)}
@media(hover:hover){.fi:hover{border-color:rgba(255,255,255,0.15)}}
.fi::placeholder{color:var(--tm)}
textarea.fi{min-height:110px;resize:none}
.fl-label{display:block;font-size:11px;font-weight:700;color:var(--tm);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.fgroup{display:flex;flex-direction:column}

.csel-wrap{position:relative;grid-column:1/-1}
.csel-btn{
  width:100%;padding:12px 14px;background:rgba(0,0,0,0.3);
  border:1px solid var(--border);border-radius:var(--rmd);
  color:var(--tp);font-size:13px;font-weight:500;
  display:flex;justify-content:space-between;align-items:center;cursor:pointer;
  transition:border-color .3s;
}
@media(hover:hover){.csel-btn:hover{border-color:rgba(255,255,255,0.15)}}
.csel-arrow{font-size:11px;color:var(--tm);transition:transform .3s var(--e)}
.csel-arrow.open{transform:rotate(180deg)}

.csel-menu{
  position:absolute;top:calc(100% + 8px);left:0;width:100%;
  background:rgba(8,8,10,0.97);border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--rmd);z-index:60;
  max-height:0;opacity:0;transform:translateY(-6px) scale(.99);pointer-events:none;
  transition:max-height .3s var(--e),opacity .25s var(--e),transform .25s var(--e);
  box-shadow:0 8px 32px rgba(0,0,0,0.8);
  overflow:hidden;
}
.csel-menu.open{max-height:220px;opacity:1;transform:translateY(0) scale(1);pointer-events:all}

.csel-scroll{
  max-height:220px;overflow-y:auto;border-radius:var(--rmd);
  scrollbar-width:thin;scrollbar-color:#333 transparent;
}
.csel-scroll::-webkit-scrollbar{width:4px}
.csel-scroll::-webkit-scrollbar-track{background:transparent}
.csel-scroll::-webkit-scrollbar-thumb{background:#333;border-radius:10px}

.dopt{padding:10px 14px;font-size:12px;font-weight:500;color:rgba(255,255,255,0.7);cursor:pointer;transition:background .2s,color .2s;margin:3px;border-radius:10px}
@media(hover:hover){.dopt:hover{background:rgba(0,170,255,0.12);color:#fff}}
.dopt.sel{color:var(--ac)}

.sub-btn{
  width:100%;padding:13px;border-radius:var(--rmd);
  background:linear-gradient(135deg,var(--ac),var(--ag));
  color:var(--td);font-size:14px;font-weight:800;
  transition:opacity .4s,box-shadow .4s;
  box-shadow:0 8px 24px rgba(0,170,255,0.2);
  cursor:pointer;border:none;
  position:relative;z-index:1;overflow:hidden;
}
@media(hover:hover){.sub-btn:hover{opacity:0.9;box-shadow:0 12px 32px rgba(0,170,255,0.35)}}

.catalog-pick-btn{
  width:100%;grid-column:1/-1;
  padding:10px 14px;border-radius:var(--rmd);
  border:1px dashed rgba(0,170,255,0.3);
  background:rgba(0,170,255,0.05);
  color:var(--ac);font-size:12px;font-weight:600;
  cursor:pointer;transition:background .3s,border-color .3s;
  text-align:center;
}
@media(hover:hover){.catalog-pick-btn:hover{background:rgba(0,170,255,0.1);border-color:rgba(0,170,255,0.5)}}

/* ── CATALOG GUIDE ── */
#catalogGuide{
  position:fixed;inset:0;z-index:600;
  pointer-events:none;
}
#cgFull{display:none;}
#cgPinned{
  position:fixed;top:88px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,0.82);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(0,170,255,0.3);border-radius:var(--rp);
  padding:10px 24px;font-size:13px;font-weight:700;color:var(--ac);
  white-space:nowrap;box-shadow:0 4px 24px rgba(0,170,255,0.15);
  opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:601;
}
#cgPinned.show{opacity:1;}

/* ── TICKET OVERLAY ── */
#ticketOverlay{
  position:absolute;inset:-12px;
  background:rgba(0,0,0,0.94);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity 0.5s ease;
  z-index:10;border-radius:calc(var(--rlg) + 12px);
}
#ticketOverlay.on{opacity:1;pointer-events:all}
#ticketSent{font-size:22px;font-weight:800;color:white;letter-spacing:-0.3px;opacity:0;transition:opacity 0.4s ease 0.2s}

#postChat{display:none;flex-direction:column;height:420px;opacity:0}
#postChatMsgs{
  flex:1;overflow-y:auto;padding:4px 0 16px;
  display:flex;flex-direction:column;gap:10px;
  scrollbar-width:thin;scrollbar-color:#333 transparent;
}
#postChatMsgs::-webkit-scrollbar{width:3px}
#postChatMsgs::-webkit-scrollbar-thumb{background:#333;border-radius:10px}
.pc-msg{
  max-width:75%;padding:11px 16px;font-size:14px;
  line-height:1.45;word-wrap:break-word;
  animation:msgIn 0.3s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
@keyframes msgIn{from{opacity:0;transform:translateY(8px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.pc-msg.them{align-self:flex-start;background:rgba(255,255,255,0.07);color:#c8d4e0;border-radius:18px 18px 18px 4px}
.pc-msg.me{align-self:flex-end;background:var(--ac);color:white;border-radius:18px 18px 4px 18px}
#postChatInputRow{
  display:flex;gap:10px;align-items:flex-end;
  padding-top:16px;border-top:1px solid rgba(255,255,255,0.1);
}
#postChatInput{
  flex:1;padding:12px 16px;background:rgba(0,0,0,0.28);
  border:1px solid rgba(255,255,255,0.09);border-radius:22px;
  color:white;font-size:14px;font-family:'Montserrat',sans-serif;
  resize:none;outline:none;max-height:120px;overflow-y:auto;
  line-height:1.4;transition:border-color 0.3s;scrollbar-width:none;
}
#postChatInput::-webkit-scrollbar{display:none}
#postChatInput:focus{border-color:rgba(0,170,255,0.4)}
#postChatInput::placeholder{color:rgba(255,255,255,0.25)}
#postChatSend{
  width:42px;height:42px;min-width:42px;min-height:42px;
  border-radius:50%;flex-shrink:0;
  background:var(--ac);border:none;cursor:pointer;
  display:grid;place-items:center;
  transition:transform 0.2s,background 0.2s;
  box-shadow:0 4px 14px rgba(0,170,255,0.35);
}
#postChatSend:hover{transform:scale(1.08);background:#22bbff}
#postChatSend:active{transform:scale(0.96)}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:1000;
  background:rgba(6,12,24,0.95);border:1px solid var(--glow);
  padding:14px 20px;border-radius:var(--rmd);box-shadow:var(--sh);
  transform:translateY(80px) scale(.95);opacity:0;pointer-events:none;
  transition:all .4s cubic-bezier(0.175,0.885,0.32,1.275);
  display:flex;align-items:center;gap:10px;backdrop-filter:blur(12px);
  font-size:13px;font-weight:600;max-width:300px;
}
.toast.on{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.ti{color:var(--ag);font-weight:800;font-size:15px}

/* ── FOOTER ── */
footer{
  position:relative;z-index:60;
  width:100%;
  padding:2.5rem 0 2rem;
  margin-top:2rem;
  display:flex;flex-direction:row;justify-content:space-between;align-items:center;
  border-top:1px solid var(--border);
  flex-wrap:wrap;gap:12px;
}
.fl{
  color:rgba(255,255,255,0.3);font-weight:700;
  font-size:clamp(9px,1.8vw,0.9rem);
  white-space:nowrap;
}
.footer-right-group{display:flex;gap:3rem;align-items:center;}
.flink-texcme{
  text-decoration:none;color:rgba(255,255,255,0.3);font-weight:700;
  font-size:clamp(9px,1.8vw,0.9rem);text-transform:uppercase;letter-spacing:1px;
  transition:color .3s;cursor:pointer;white-space:nowrap;
}
@media(hover:hover){.flink-texcme:hover{color:white}}
@media(max-width:600px){
  footer{flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1rem;}
  .fl{order:1;width:100%;text-align:center;}
  .footer-right-group{order:0;width:100%;justify-content:center;}
}

/* ── RESPONSIVE ── */
@media(max-width:1500px){:root{--cmax:1200px}}
@media(max-width:1300px){:root{--cmax:1000px}}
@media(max-width:1100px){:root{--cmax:860px}}
@media(max-width:900px) {:root{--cmax:700px}}

@media(orientation:portrait),(max-width:760px){
  :root{--cmax:100%;}
  .vw{padding-left:8px;padding-right:8px;}
  .col{padding:0 4px;}
  .nav-wrap{width:calc(100% - 16px);max-width:none;left:50%;padding:0;}

  .catalog-frame{padding:14px 10px 18px}
  .filter-btn{padding:9px 12px;font-size:11px}
  .card-grid{grid-template-columns:repeat(2,1fr);gap:7px}
  .hero{padding:110px 0 40px;min-height:auto}
  .h1{font-size:clamp(24px,6vw,38px);letter-spacing:-1.3px}
  .hero-p{font-size:13px}
  .stats{grid-template-columns:repeat(3,1fr);gap:8px}
  .promo-body p{display:none}
  .promo-body h3{font-size:11px}
  .icon-badge{width:26px;height:26px;font-size:7px;border-radius:6px}
  .slot-code{font-size:8px;padding:2px 5px}
  .promo-cta{font-size:10px;padding:6px 0}
  .nav-search-input{font-size:12px;padding:9px 14px 9px 40px}
  .nav-search-icon{left:14px}
  .nav-name{display:none}
  .nav-cta{padding:8px 14px;font-size:12px}
  .nav-dock{gap:10px;padding:6px 10px}
}

@media(max-width:480px){
  .nav-wrap{width:calc(100% - 12px);}
  .filter-btn{padding:8px 10px;font-size:11px}
}

@media(orientation:landscape) and (max-height:500px){
  .hero{padding-top:90px;min-height:auto}
  .card-grid{grid-template-columns:repeat(4,1fr)}
}

@media(max-width:360px){
  .nav-wrap{width:calc(100% - 8px);}
  .filter-btn{padding:6px 7px;font-size:9px;gap:3px}
  .h1{font-size:clamp(20px,6vw,32px)}
  .stats{gap:5px}
  .sn{font-size:16px}
  .card-grid{gap:5px}
}

/* Touch — disable ALL hover effects AND reveal animations */
@media(hover:none),(pointer:coarse){
  .rv{opacity:1!important;transform:none!important;filter:none!important;transition:none!important}
  .rv.in{opacity:1;transform:none;filter:none}
  .card-rv{opacity:1!important;filter:none!important;transition:none!important}
  .card-rv.in{opacity:1;filter:none}
  .promo-card:hover{
    border-color:var(--border)!important;
    box-shadow:var(--sh),var(--spec)!important;
    transform:none!important;
  }
  .promo-card:hover::after{border-color:rgba(0,170,255,0)!important}
  .btn.prim:hover,.btn.glass:hover,.nav-cta:hover,.stat:hover,
  .sub-btn:hover,.promo-cta:hover,.adv-close:hover,.dopt:hover,
  .fi:hover,.csel-btn:hover,.flink-texcme:hover,.catalog-pick-btn:hover,
  .filter-btn:hover,.catalog-frame:hover{
    transform:none!important;box-shadow:inherit!important;
    background:inherit!important;border-color:inherit!important;
    color:inherit!important;opacity:inherit!important;
  }
}