*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0C0A12;
  --bg2:#14111E;
  --surface:#1C1828;
  --text:#F3F0FA;
  --muted:#9A93AE;
  --text-secondary:#CFC8E0;
  --gold:#A488D9;
  --gold2:#C4B0EC;
  --gold3:#7C5CB8;
  --gold-soft:#9678C9;
  --accent-security:#6366F1;
  --accent-text:#14B8A6;
  --accent-dev:#F97316;
  --accent-math:#8B5CF6;
  --accent-design:#EC4899;
  --accent-games:#10B981;
  --accent-network:#06B6D4;
  --accent-productivity:#F59E0B;
  --accent-generators:#F43F5E;
  --glow:rgba(164,136,217,0.18);
  --border:rgba(180,160,235,0.12);
  --border-strong:rgba(180,160,235,0.20);
  --glass:rgba(255,255,255,0.06);
  --glow2:rgba(196,176,236,0.12);
  --shadow:0 2px 16px rgba(0,0,0,0.4);
  --shadow-lg:0 12px 48px rgba(0,0,0,0.6);
  --shadow-card:0 4px 24px rgba(0,0,0,0.35);
  --glow-security:rgba(99,102,241,0.12);
  --glow-text-tools:rgba(20,184,166,0.12);
  --glow-dev:rgba(249,115,22,0.12);
  --glow-math:rgba(139,92,246,0.12);
  --glow-design:rgba(236,72,153,0.12);
  --glow-games:rgba(16,185,129,0.12);
  --glow-network:rgba(6,182,212,0.12);
  --glow-productivity:rgba(245,158,11,0.12);
  --glow-generators:rgba(244,63,94,0.12);
  --font:'Inter',sans-serif;
  --font-display:'Playfair Display',serif;
  --radius:14px;
  --radius-sm:8px;
  --radius-lg:20px;
  --radius-full:100px;
  --space-xs:4px;
  --space-sm:8px;
  --space-md:16px;
  --space-lg:24px;
  --space-xl:32px;
  --space-2xl:48px;
  --space-3xl:64px;
  --space-4xl:80px;
}
html{scroll-behavior:smooth;overflow-x:hidden;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--font);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
@media(pointer:fine){body{cursor:none}input,textarea,select,[contenteditable]{cursor:text}a,button,label,[role="button"]{cursor:pointer}}
.skip-link{position:absolute;top:-100px;left:16px;background:var(--gold);color:#080808;padding:12px 24px;font-size:.75rem;font-weight:600;border-radius:0 0 8px 8px;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}

/* ── Custom Cursor ─────────────────────────────────────── */
#cur,#cur-ring{display:none}
@media(pointer:fine){
  #cur{display:block;position:fixed;width:6px;height:6px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s,background .15s}
  #cur-ring{display:block;position:fixed;width:28px;height:28px;border:1px solid rgba(164,136,217,0.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s}
}
body.hov #cur{width:12px;height:12px;background:var(--gold2)}
body.hov #cur-ring{width:40px;height:40px;border-color:rgba(196,176,236,0.5)}
body.clk #cur{transform:translate(-50%,-50%) scale(.4)}

/* ── Gold spotlight ────────────────────────────────────── */
#spl{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;background:radial-gradient(900px circle at var(--mx,50%) var(--my,50%),rgba(164,136,217,0.05) 0%,transparent 70%)}

/* ── Particle dots pattern ─────────────────────────────── */
#dots{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;opacity:.35;background-image:radial-gradient(circle,rgba(164,136,217,0.18) 1px,transparent 1px);background-size:40px 40px}

/* ── Mobile: disable heavy overlays & blur for clarity ── */
@media(max-width:800px){
  #spl{display:none}
  #dots{opacity:.12}

  nav{background:rgba(8,8,8,0.98)}
  nav.scrolled{background:rgba(6,6,6,0.98)}
  #drawer-backdrop,.cmd-backdrop,.col-backdrop,.shortcuts-backdrop{
    background:rgba(0,0,0,0.78);
  }
  .btm-nav{background:rgba(10,10,10,0.98)}
}

section,nav,footer,main{position:relative;z-index:1}

/* ── NAV ───────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 64px;
  border-bottom:1px solid var(--border);
  background:rgba(8,8,8,0.88);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  transition:background .3s,box-shadow .3s,padding .3s;
}
nav.scrolled{
  background:rgba(6,6,6,0.96);
  box-shadow:0 1px 32px rgba(0,0,0,0.5),0 1px 0 rgba(255,255,255,0.04);
  padding-top:14px;padding-bottom:14px;
}
.logo{
  font-family:var(--font);font-size:.78rem;font-weight:700;
  letter-spacing:5px;color:var(--gold);text-decoration:none;text-transform:uppercase;
}
.nav-r{display:flex;align-items:center;gap:24px}
.nl{
  font-size:.8rem;font-weight:400;letter-spacing:.5px;
  color:var(--muted);text-decoration:none;
  transition:color .2s;position:relative;padding-bottom:4px;
}
.nl::after{
  content:'';position:absolute;left:0;bottom:0;
  width:0;height:1px;background:var(--gold);transition:width .25s;
}
.nl:hover,.nl.active{color:var(--text)}
.nl:hover::after,.nl.active::after{width:100%}
.nb{
  font-size:.78rem;font-weight:600;letter-spacing:.5px;
  color:#080808;background:var(--gold);
  padding:9px 22px;text-decoration:none;border-radius:100px;
  transition:background .2s,box-shadow .2s,transform .15s;
}
.nb:hover{background:var(--gold2);box-shadow:0 4px 20px rgba(164,136,217,0.3);transform:translateY(-1px)}

/* ── Nav Dropdown ──────────────────────────────────────── */
.nav-dropdown-wrap{position:relative;display:flex;align-items:center}
.nav-dropdown-wrap::after{content:'';position:absolute;top:100%;left:-16px;right:-16px;height:28px;pointer-events:none}
.nav-dropdown-wrap:hover::after{pointer-events:auto}
.nav-dropdown-wrap:hover .nav-dropdown,
.nav-dropdown-wrap:focus-within .nav-dropdown{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;
  transform:translateX(-50%) translateY(-8px);
  background:rgba(14,14,14,0.98);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:0 24px 64px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.04);
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .22s,transform .22s;
  z-index:250;
  min-width:540px;max-width:calc(100vw - 32px);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
/* Small dropdown (single column) */
.nav-dropdown-sm{min-width:280px;padding:14px}
.nav-dropdown-single{display:block}
.nav-dropdown-single .nav-dd-col{padding:0}
/* Medium dropdown (two column but narrower) */
.nav-dropdown-md{min-width:480px;padding:16px}
/* Wide dropdown (three columns for games) */
.nav-dropdown-lg{min-width:680px;padding:18px}
.nav-dropdown-lg .nav-dropdown-inner{grid-template-columns:1fr 1fr 1fr}
.nav-dropdown-inner{display:grid;grid-template-columns:1fr 1fr}
.nav-dd-col{padding:4px 8px}
.nav-dd-label{
  font-size:.6rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(190,183,170,0.4);margin-bottom:10px;padding:0 8px;
}
.nav-dd-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 10px;border-radius:10px;text-decoration:none;color:inherit;
  transition:background .18s;
}
.nav-dd-item:hover{background:rgba(164,136,217,0.07)}
.nav-dd-icon{font-size:1rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,0.04);border-radius:7px;border:1px solid var(--border)}
.nav-dd-text{display:flex;flex-direction:column;gap:2px}
.nav-dd-name{font-size:.85rem;font-weight:600;color:var(--text);line-height:1.2}
.nav-dd-desc{font-size:.72rem;color:var(--muted);font-weight:300;line-height:1.4}
.nav-dd-footer{
  grid-column:1/-1;border-top:1px solid var(--border);
  margin-top:12px;padding-top:14px;text-align:center;
}
.nav-dd-all{
  font-size:.68rem;font-weight:500;letter-spacing:.5px;
  color:var(--gold);text-decoration:none;
  transition:gap .2s;display:inline-flex;align-items:center;gap:6px;
}
.nav-dd-all:hover{gap:10px}
/* Prevent rightmost dropdowns from overflowing viewport */
.nav-dropdown-wrap:nth-last-child(-n+5) .nav-dropdown{left:auto;right:-16px;transform:translateY(-8px)}
.nav-dropdown-wrap:nth-last-child(-n+5):hover .nav-dropdown,
.nav-dropdown-wrap:nth-last-child(-n+5):focus-within .nav-dropdown{transform:translateY(0)}

/* ── Hamburger (mobile only) ───────────────────────────── */
.burger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;width:44px;height:44px;
  background:rgba(164,136,217,0.08);border:1px solid rgba(164,136,217,0.2);
  border-radius:10px;cursor:pointer;transition:background .2s;
  flex-shrink:0;touch-action:manipulation;
}
.burger:hover{background:rgba(164,136,217,0.15)}
.burger span{
  display:block;width:20px;height:2px;background:var(--gold);
  border-radius:2px;transition:transform .3s,opacity .3s,width .3s;
}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;width:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── Left Drawer ───────────────────────────────────────── */
#drawer{
  position:fixed;top:0;left:0;bottom:0;width:min(280px,85vw);
  background:#0e0e0e;
  border-right:1px solid var(--border);
  z-index:300;
  transform:translateX(-100%);
  transition:transform .35s cubic-bezier(.16,1,.3,1);
  display:flex;flex-direction:column;
  padding:0;
  box-shadow:8px 0 40px rgba(0,0,0,0.7);
}
#drawer.open{transform:translateX(0)}

.drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;
  border-bottom:1px solid var(--border);
}
.drawer-logo{
  font-family:var(--font);font-size:.78rem;font-weight:700;
  letter-spacing:5px;color:var(--gold);text-decoration:none;
}
.drawer-close{
  width:36px;height:36px;border-radius:8px;
  border:1px solid var(--border);background:transparent;
  color:var(--muted);font-size:1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;
}
.drawer-close:hover{border-color:rgba(164,136,217,0.4);color:var(--gold)}

.drawer-links{
  display:flex;flex-direction:column;padding:20px 0;flex:1;overflow-y:auto;
}
.drawer-link{
  display:flex;align-items:center;gap:14px;
  padding:15px 28px;
  font-size:.95rem;font-weight:400;
  color:var(--muted);text-decoration:none;
  border-left:2px solid transparent;
  transition:color .2s,border-color .2s,background .2s;
  position:relative;
}
.drawer-link:hover,.drawer-link.active{
  color:var(--text);
  border-left-color:var(--gold);
  background:rgba(164,136,217,0.05);
}
.drawer-link .d-icon{font-size:1rem;width:22px;text-align:center;flex-shrink:0}
.drawer-sub{padding-left:28px;font-size:.85rem}
.drawer-sub .d-icon{font-size:.85rem;margin-left:10px}

.drawer-bottom{
  padding:20px 24px;
  border-top:1px solid var(--border);
}
.drawer-cta{
  display:block;width:100%;text-align:center;
  font-size:.75rem;font-weight:600;
  background:var(--gold);color:#080808;
  padding:14px;border-radius:100px;text-decoration:none;
  transition:background .2s;
}
.drawer-cta:hover{background:var(--gold2)}

/* ── Drawer backdrop ───────────────────────────────────── */
#drawer-backdrop{
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:250;
  background:rgba(0,0,0,0.6);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;
  transition:opacity .3s;
}
#drawer-backdrop.open{opacity:1;pointer-events:all}

/* ── FOOTER ────────────────────────────────────────────── */
footer{
  border-top:none;
  padding:0 var(--space-3xl) var(--space-xl);
  background:var(--bg);
  position:relative;
}
footer::before{
  content:'';display:block;height:1px;margin-bottom:var(--space-3xl);
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.foot-top{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;
  gap:var(--space-xl);margin-bottom:var(--space-xl);
  align-items:start;
}
.foot-brand{}
.fl{font-size:.78rem;font-weight:700;letter-spacing:4px;color:var(--gold);text-transform:uppercase}
.fl-sub{font-size:.72rem;color:var(--muted);margin-top:8px;max-width:240px;line-height:1.7}
.foot-socials{display:flex;gap:10px;margin-top:16px}
.foot-social{
  width:34px;height:34px;border-radius:8px;
  background:var(--glass);border:1px solid var(--border);
  color:var(--muted);display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;
}
.foot-social:hover{border-color:rgba(164,136,217,0.4);color:var(--gold)}
.foot-col{display:flex;flex-direction:column;gap:0}
.foot-col-head{
  font-size:.65rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(190,183,170,0.4);margin-bottom:14px;
}
.flink{
  font-size:.8rem;letter-spacing:.3px;color:var(--muted);text-decoration:none;
  transition:color .2s,padding-left .2s;padding:6px 0;line-height:1.5;
  position:relative;display:inline-block;
}
.flink::before{
  content:'';position:absolute;bottom:4px;left:0;right:0;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .25s;
}
.flink:hover{color:var(--gold)}
.flink:hover::before{transform:scaleX(1)}
.foot-bottom{
  border-top:1px solid var(--border);padding-top:28px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.fcopy{font-size:.7rem;letter-spacing:.5px;color:rgba(190,183,170,0.35)}
.foot-bottom-links{display:flex;gap:24px}
.foot-main-domain{margin-top:22px;text-align:center}
.foot-main-domain-link{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 26px;border-radius:100px;text-decoration:none;
  font-size:.8rem;font-weight:600;letter-spacing:.4px;color:var(--gold2);
  background:linear-gradient(135deg,rgba(164,136,217,0.14),rgba(124,92,184,0.10));
  border:1px solid rgba(164,136,217,0.32);
  transition:background .2s,border-color .2s,box-shadow .2s,transform .15s,color .2s;
}
.foot-main-domain-link:hover{
  color:#0C0A12;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  border-color:transparent;
  box-shadow:0 6px 26px rgba(164,136,217,0.32);
  transform:translateY(-1px);
}
.foot-main-domain-icon{font-size:.95rem;line-height:1}
.foot-donate{
  border-top:1px solid var(--border);
  margin-top:22px;
  padding-top:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.foot-donate-title{
  font-size:.75rem;
  letter-spacing:1px;
  text-transform:uppercase;
  color:rgba(190,183,170,0.6);
  font-weight:600;
}

/* ── Container ────────────────────────────────────────── */
.container{max-width:1280px;margin:0 auto;padding:0 var(--space-4xl)}

/* ── Global Utilities ──────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1)}
.reveal.on{opacity:1;transform:none}

.btn-fill{
  font-size:.8rem;font-weight:600;letter-spacing:.5px;
  background:var(--gold);color:#080808;border:none;
  padding:14px 36px;text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;
  border-radius:var(--radius-full);min-height:44px;
  transition:background .2s,box-shadow .2s,transform .15s;
  cursor:pointer;
}
.btn-fill:hover{background:var(--gold2);box-shadow:0 8px 32px rgba(164,136,217,0.25);transform:translateY(-2px)}

.btn-line{
  font-size:.8rem;font-weight:500;letter-spacing:.5px;
  background:rgba(255,255,255,0.04);color:var(--text);
  border:1px solid var(--border);
  padding:14px 36px;text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;
  border-radius:var(--radius-full);min-height:44px;
  transition:border-color .2s,background .2s,transform .15s;
  cursor:pointer;
}
.btn-line:hover{border-color:rgba(164,136,217,0.45);background:rgba(164,136,217,0.06);transform:translateY(-2px)}

/* ── Focus-visible (keyboard accessibility) ───────────── */
*:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
*:focus:not(:focus-visible){outline:none}
.btn-fill:focus-visible,.btn-line:focus-visible,.nb:focus-visible,.nl:focus-visible,
.theme-toggle:focus-visible,.lang-btn:focus-visible,.burger:focus-visible,
.drawer-link:focus-visible,.drawer-cta:focus-visible,.drawer-close:focus-visible,
.nav-dd-item:focus-visible,.flink:focus-visible,.foot-social:focus-visible,
.submit-btn:focus-visible,#back-to-top:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;
}
/* ── Minimum touch targets (44px) ────────────────────── */
@media(pointer:coarse){
  .tp-cat-tab,.tp-filter,.lang-option,.drawer-link{min-height:44px}
  input,select,textarea{font-size:16px}
}

.page-wrap{padding-top:74px;min-height:100vh}
@media(max-width:800px){.page-wrap{padding-top:0}}

/* ── Light Theme ───────────────────────────────────────── */
body.light{
  --bg:#F7F5F1;--bg2:#EFECE6;--surface:#FFFFFF;
  --text:#1A1714;--muted:#5A5650;--text-secondary:#4A453F;
  --border:rgba(0,0,0,0.08);--border-strong:rgba(0,0,0,0.15);
  --glass:rgba(0,0,0,0.03);
  --shadow:0 2px 16px rgba(0,0,0,0.06);--shadow-lg:0 12px 48px rgba(0,0,0,0.10);
  --shadow-card:0 4px 24px rgba(0,0,0,0.07);
}
body.light #spl{background:radial-gradient(700px circle at var(--mx,50%) var(--my,50%),rgba(164,136,217,0.06) 0%,transparent 70%)}
body.light nav{background:rgba(245,243,239,0.92)}
body.light #drawer{background:#f0ede8}
body.light .nb{color:#1a1a1a}
body.light .submit-btn{color:#1a1a1a}
body.light .dl-btn{color:#1a1a1a}
body.light .drawer-cta{color:#1a1a1a}
body.light .btn-fill{color:#1a1a1a}
body.light .card-num{-webkit-text-stroke-color:rgba(0,0,0,0.04)}
body.light .specr{border-bottom-color:rgba(0,0,0,0.05)}
body.light .pill{background:rgba(0,0,0,0.03)}
body.light .faq-q{color:var(--text)}
body.light #back-to-top{color:#1a1a1a}
body.light .lang-dropdown{background:var(--surface);border-color:var(--border);box-shadow:0 8px 32px rgba(0,0,0,0.15)}

/* ── Nav Search Button ─────────────────────────────────── */
.nav-search-btn{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--border);background:var(--glass);
  color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;flex-shrink:0;
  position:relative;z-index:201;
  -webkit-tap-highlight-color:rgba(164,136,217,0.2);
  touch-action:manipulation;
}
.nav-search-btn:hover{border-color:rgba(164,136,217,0.4);color:var(--gold)}
.nav-search-btn:active{background:rgba(164,136,217,0.15);color:var(--gold)}
/* ── Drawer Search ────────────────────────────────────── */
.drawer-search-btn{
  display:flex;align-items:center;gap:10px;
  width:calc(100% - 48px);margin:4px 24px 8px;
  padding:10px 14px;border-radius:10px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  color:var(--muted);font-family:var(--font);font-size:.82rem;
  cursor:pointer;transition:border-color .2s,color .2s;
  touch-action:manipulation;
}
.drawer-search-btn:hover,.drawer-search-btn:active{border-color:rgba(164,136,217,0.4);color:var(--gold)}

/* ── Theme Toggle ──────────────────────────────────────── */
.theme-toggle{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--border);background:var(--glass);
  color:var(--muted);font-size:.9rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s,background .2s;
  flex-shrink:0;
}
.theme-toggle:hover{border-color:rgba(164,136,217,0.4);color:var(--gold)}

/* ── Back to Top ───────────────────────────────────────── */
#back-to-top{
  position:fixed;bottom:90px;right:24px;z-index:190;
  width:44px;height:44px;border-radius:50%;
  background:var(--gold);color:#080808;
  border:none;font-size:1.1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(16px);pointer-events:none;
  transition:opacity .3s,transform .3s,background .2s,box-shadow .2s;
  box-shadow:0 4px 20px rgba(164,136,217,0.25);
}
#back-to-top.show,#back-to-top.visible{opacity:1;transform:none;pointer-events:all}
#back-to-top:hover{background:var(--gold2);box-shadow:0 8px 32px rgba(164,136,217,0.35);transform:translateY(-2px)}

/* ── Language Selector ──────────────────────────────────── */
.lang-selector{position:relative}
.lang-btn{
  font-family:var(--font);font-size:.68rem;font-weight:600;letter-spacing:1px;
  background:var(--glass);border:1px solid var(--border);
  color:var(--muted);padding:7px 14px;border-radius:100px;
  cursor:pointer;transition:border-color .2s,color .2s;
  display:flex;align-items:center;gap:4px;
}
.lang-btn:hover{border-color:rgba(164,136,217,0.4);color:var(--gold)}
.lang-dropdown{
  position:absolute;bottom:100%;left:0;margin-bottom:6px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:6px;min-width:130px;
  box-shadow:0 8px 32px rgba(0,0,0,0.5);
  opacity:0;pointer-events:none;transform:translateY(6px);
  transition:opacity .2s,transform .2s;z-index:400;
}
.nav-lang .lang-dropdown{bottom:auto;top:100%;margin-bottom:0;margin-top:6px;transform:translateY(-6px);right:0;left:auto}
.lang-dropdown.open{opacity:1;pointer-events:all;transform:none}
.lang-option{
  display:block;width:100%;text-align:left;
  font-family:var(--font);font-size:.8rem;font-weight:400;
  background:none;border:none;color:var(--muted);
  padding:9px 14px;border-radius:6px;cursor:pointer;
  transition:background .15s,color .15s;
}
.lang-option:hover{background:rgba(164,136,217,0.08);color:var(--gold)}

/* ── RTL Support (Hebrew / Arabic) ─────────────────────── */

/* Hebrew font */
html[dir="rtl"] body{font-family:'Heebo',sans-serif}

/* Skip link */
html[dir="rtl"] .skip-link{left:auto;right:16px}

/* Nav — underline animation flips */
html[dir="rtl"] .nl::after{left:auto;right:0;transform-origin:right}

/* Nav-right stays LTR (icons, lang-btn) */
html[dir="rtl"] .nav-r{direction:ltr}

/* Nav dropdown: center relative to trigger */
html[dir="rtl"] .nav-dropdown{left:auto;right:50%;transform:translateX(50%) translateY(-8px)}
html[dir="rtl"] .nav-dropdown-wrap:hover .nav-dropdown,
html[dir="rtl"] .nav-dropdown-wrap:focus-within .nav-dropdown{transform:translateX(50%) translateY(0)}
/* Override right-edge rule for RTL (now left-edge items) */
html[dir="rtl"] .nav-dropdown-wrap:nth-last-child(-n+5) .nav-dropdown{right:auto;left:-16px;transform:translateY(-8px)}
html[dir="rtl"] .nav-dropdown-wrap:nth-last-child(-n+5):hover .nav-dropdown,
html[dir="rtl"] .nav-dropdown-wrap:nth-last-child(-n+5):focus-within .nav-dropdown{transform:translateY(0)}

/* Drawer — slides in from right in RTL */
html[dir="rtl"] #drawer{left:auto;right:0;border-right:none;border-left:1px solid var(--border);transform:translateX(100%);box-shadow:-8px 0 40px rgba(0,0,0,0.7)}
html[dir="rtl"] #drawer.open{transform:translateX(0)}

/* Drawer links border indicator */
html[dir="rtl"] .drawer-link{border-left:none;border-right:2px solid transparent}
html[dir="rtl"] .drawer-link:hover,html[dir="rtl"] .drawer-link.active{border-right-color:var(--gold);border-left-color:transparent}

/* Drawer sub-items indentation */
html[dir="rtl"] .drawer-sub{padding-left:0;padding-right:28px}
html[dir="rtl"] .drawer-sub .d-icon{margin-left:0;margin-right:10px}
html[dir="rtl"] .drawer-sub2{padding-left:0!important;padding-right:40px!important}
html[dir="rtl"] .drawer-expandable .drawer-submenu{padding-left:0;padding-right:12px}

/* Drawer chevron moves to left side */
html[dir="rtl"] .drawer-chevron{margin-left:0;margin-right:auto}

/* Drawer expand button text aligns right */
html[dir="rtl"] .drawer-expand-btn{text-align:right}

/* Footer — underline originates from right */
html[dir="rtl"] .flink::before{transform-origin:right}

/* Back-to-top moves to bottom-left (above gemini-btn which moves to left:24px in RTL) */
html[dir="rtl"] #back-to-top{right:auto;left:24px}

/* Language selector dropdown flips */
html[dir="rtl"] .nav-lang .lang-dropdown{right:auto;left:0}
html[dir="rtl"] .lang-option{text-align:right}

/* Command palette */
html[dir="rtl"] .cmd-result-cat{margin-left:0;margin-right:auto}
html[dir="rtl"] .cmd-quick-action{text-align:right}
html[dir="rtl"] .cmd-result-new-tag{margin-left:0;margin-right:4px}

/* Collections modal */
html[dir="rtl"] .col-picker-check{margin-left:0;margin-right:auto}
html[dir="rtl"] .col-picker-item{text-align:right}

/* Shortcuts table */
html[dir="rtl"] .shortcuts-table td:first-child{padding-right:0;padding-left:20px}

/* Hamburger stays LTR */
html[dir="rtl"] .burger{direction:ltr}

/* ── Animations ────────────────────────────────────────── */
@keyframes up{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.15}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes grow{to{width:36px}}

/* ── Page fade-in ─────────────────────────────────────── */
@keyframes pageFade{from{opacity:0}to{opacity:1}}
body{animation:pageFade .25s ease-out}

/* ── Scroll-triggered reveal ──────────────────────────── */
.reveal-on-scroll{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-on-scroll.visible{opacity:1;transform:none}
.reveal-fade{opacity:0;transition:opacity .6s ease}
.reveal-fade.visible{opacity:1}
.reveal-scale{opacity:0;transform:scale(.96);transition:opacity .6s ease,transform .6s cubic-bezier(.16,1,.3,1)}
.reveal-scale.visible{opacity:1;transform:none}

/* ── Button ripple ────────────────────────────────────── */
.ripple-container{position:relative;overflow:hidden}
.ripple{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,0.15);
  transform:scale(0);animation:rippleAnim .6s linear;
  pointer-events:none;
}
@keyframes rippleAnim{to{transform:scale(4);opacity:0}}

/* ── Command Palette ──────────────────────────────────── */
.cmd-palette{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:500;display:none;align-items:flex-start;justify-content:center;padding-top:20vh;box-sizing:border-box}
.cmd-palette.open{display:flex!important}
.cmd-backdrop{
  position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;
  background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:0;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.cmd-palette.open .cmd-backdrop{opacity:1;pointer-events:auto}
.cmd-box{
  position:relative;z-index:1;width:580px;max-width:92vw;
  background:rgba(14,14,14,0.98);border:1px solid var(--border);
  border-radius:16px;box-shadow:0 24px 80px rgba(0,0,0,0.8);
  overflow:hidden;animation:cmdIn .18s ease-out;
}
@keyframes cmdIn{from{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:none}}
.cmd-search{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}
.cmd-search-icon{color:var(--muted);flex-shrink:0}
.cmd-input{
  flex:1;background:none;border:none;outline:none;
  font-family:var(--font);font-size:.95rem;color:var(--text);
  cursor:text;
}
.cmd-input::placeholder{color:rgba(190,183,170,0.4)}
.cmd-kbd{font-family:var(--font);font-size:.6rem;font-weight:600;letter-spacing:1px;color:var(--muted);background:rgba(255,255,255,0.06);border:1px solid var(--border);padding:3px 8px;border-radius:5px;flex-shrink:0}
.cmd-results{max-height:min(50vh,400px);overflow-y:auto;padding:8px}
.cmd-results:empty{display:none}
.cmd-results::-webkit-scrollbar{width:4px}
.cmd-results::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:4px}
.cmd-result{
  display:flex;align-items:center;gap:12px;padding:10px 14px;
  border-radius:10px;text-decoration:none;color:inherit;cursor:pointer;
  transition:background .12s;
}
.cmd-result:hover,.cmd-result.active{background:rgba(164,136,217,0.08)}
.cmd-result-icon{font-size:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;flex-shrink:0}
.cmd-result-text{display:flex;flex-direction:column;gap:1px;min-width:0}
.cmd-result-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmd-result-desc{font-size:.7rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmd-result-cat{font-size:.55rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-left:auto;flex-shrink:0}
.cmd-hint{padding:12px 20px;font-size:.65rem;color:rgba(190,183,170,0.35);text-align:center;border-top:1px solid var(--border)}
body.light .cmd-box{background:rgba(245,243,239,0.98);border-color:rgba(0,0,0,0.12);box-shadow:0 24px 80px rgba(0,0,0,0.25)}
body.light .cmd-backdrop{background:rgba(0,0,0,0.4)}
body.light .cmd-result:hover,body.light .cmd-result.active{background:rgba(164,136,217,0.12)}
body.light .cmd-result-icon{background:rgba(0,0,0,0.04);border-color:rgba(0,0,0,0.1)}
body.light .cmd-kbd{background:rgba(0,0,0,0.06);border-color:rgba(0,0,0,0.1)}

/* ── Mobile ────────────────────────────────────────────── */
/* ── Drawer helpers ────────────────────────────────────── */
.drawer-divider{height:1px;background:var(--border);margin:8px 24px}
.drawer-group-label{
  font-size:.55rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(190,183,170,0.35);padding:12px 28px 4px;
}
.drawer-expandable .drawer-submenu{display:none;padding-left:12px}
.drawer-expandable.open .drawer-submenu{display:block}
.drawer-expand-btn{width:100%;border:none;background:none;text-align:left;cursor:pointer;font-family:inherit;color:inherit}
.drawer-chevron{transition:transform .2s;margin-left:auto;opacity:0.5}
.drawer-expandable.open .drawer-chevron{transform:rotate(180deg)}
.drawer-sub2{padding-left:40px !important;font-size:.82rem !important}

@media(max-width:800px){
  nav{display:none}
  .container{padding:0 var(--space-lg)}
  footer{padding:0 var(--space-lg) var(--space-lg)}
  footer::before{margin-bottom:var(--space-2xl)}
  .foot-top{grid-template-columns:1fr 1fr;gap:var(--space-lg)}
  .foot-brand{grid-column:1/-1}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .foot-donate{align-items:flex-start}
}
@media(max-width:640px){
  .foot-top{grid-template-columns:1fr;gap:var(--space-lg)}
}

/* Touch target enforcement */
@media(pointer:coarse){
  .nl,.flink,.drawer-link,.nav-dd-item{min-height:44px;display:flex;align-items:center}
}

/* ── Reduced Motion ───────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
}

/* ── High Contrast ────────────────────────────────────── */
@media(prefers-contrast:more){
  :root{--muted:#E0DAD0;--border:rgba(255,255,255,0.2);--border-strong:rgba(255,255,255,0.3);--glass:rgba(255,255,255,0.1)}
  body.light{--muted:#3d3935;--border:rgba(0,0,0,0.25);--border-strong:rgba(0,0,0,0.35);--glass:rgba(0,0,0,0.08)}
}

/* ── Page Progress Bar ─────────────────────────────────── */
#page-progress{
  position:fixed;top:0;left:0;height:2px;
  background:linear-gradient(90deg,var(--gold3),var(--gold),var(--gold2));
  z-index:9999;width:0%;
  transition:width .1s linear,opacity .3s;
  pointer-events:none;opacity:0;
}
#page-progress.active{opacity:1}

/* ═══════════════════════════════════════════════════════
   NEW FEATURES — Tool Collections · Smart Search · Quick Wins
   ═══════════════════════════════════════════════════════ */

/* ── Nav "New" badge ─────────────────────────────────── */
.nav-new-badge{
  position:absolute;top:-6px;right:-10px;
  background:var(--gold);color:#080808;
  font-size:.45rem;font-weight:800;letter-spacing:.5px;
  padding:2px 5px;border-radius:100px;
  pointer-events:none;line-height:1.4;
}

/* ── Command Palette — chips & sections ──────────────── */
.cmd-chips{
  display:flex;gap:6px;padding:10px 16px;
  border-bottom:1px solid var(--border);
  overflow-x:auto;scrollbar-width:none;
}
.cmd-chips::-webkit-scrollbar{display:none}
.cmd-chip{
  flex-shrink:0;
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:100px;padding:4px 12px;
  font-size:.68rem;font-weight:500;color:var(--muted);
  cursor:pointer;transition:border-color .15s,color .15s,background .15s;
  font-family:var(--font);
}
.cmd-chip:hover{border-color:rgba(164,136,217,0.35);color:var(--text)}
.cmd-chip.active{background:rgba(164,136,217,0.12);border-color:var(--gold);color:var(--gold)}
.cmd-section-label{
  padding:10px 16px 4px;
  font-size:.58rem;font-weight:600;letter-spacing:2px;
  text-transform:uppercase;color:rgba(190,183,170,0.4);
}
.cmd-quick-action{
  width:100%;text-align:left;background:none;border:none;
  font-family:var(--font);cursor:pointer;color:inherit;
}
.cmd-result-new-tag{
  font-size:.5rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  background:rgba(164,136,217,0.15);color:var(--gold);
  border:1px solid rgba(164,136,217,0.25);border-radius:4px;
  padding:2px 5px;margin-left:4px;flex-shrink:0;
}
body.light .cmd-chip{background:rgba(0,0,0,0.04);border-color:rgba(0,0,0,0.1);color:#6b6560}
body.light .cmd-chip:hover{border-color:rgba(164,136,217,0.5);color:var(--gold)}
body.light .cmd-chip.active{background:rgba(164,136,217,0.1)}
body.light .cmd-section-label{color:rgba(60,55,50,0.45)}

/* ── Collections Modal ───────────────────────────────── */
.collections-modal{
  position:fixed;top:0;left:0;right:0;bottom:0;
  z-index:490;display:none;align-items:center;justify-content:center;
  padding:20px;box-sizing:border-box;
}
.collections-modal.open{display:flex!important}
.col-backdrop{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);z-index:0;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.collections-modal.open .col-backdrop{opacity:1;pointer-events:auto}
.collections-box{
  position:relative;z-index:1;
  width:460px;max-width:94vw;max-height:88vh;
  background:rgba(14,14,14,0.98);border:1px solid var(--border);
  border-radius:18px;box-shadow:0 24px 80px rgba(0,0,0,0.8);
  display:flex;flex-direction:column;overflow:hidden;
  animation:cmdIn .18s ease-out;
}
.col-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px 0;flex-shrink:0;
}
.col-header-title{font-size:1rem;font-weight:700;margin:0}
.col-close-btn{
  background:none;border:none;color:var(--muted);cursor:pointer;
  font-size:.9rem;padding:4px 8px;border-radius:6px;
  transition:color .15s,background .15s;
}
.col-close-btn:hover{color:var(--text);background:rgba(255,255,255,0.06)}
.col-desc{
  padding:8px 24px 12px;font-size:.72rem;color:var(--muted);
  border-bottom:1px solid var(--border);flex-shrink:0;
}
.col-content{overflow-y:auto;flex:1;padding:12px 16px;scrollbar-width:thin}
.col-empty{
  padding:32px 20px;text-align:center;color:var(--muted);
}
.col-card{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:10px;
  border:1px solid var(--border);margin-bottom:8px;
  background:rgba(255,255,255,0.02);
  transition:border-color .15s,background .15s;
}
.col-card:hover{border-color:rgba(164,136,217,0.2);background:rgba(164,136,217,0.04)}
.col-card-icon{font-size:1.3rem;width:36px;text-align:center;flex-shrink:0}
.col-card-info{flex:1;min-width:0}
.col-card-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.col-card-count{font-size:.68rem;color:var(--muted);margin-top:2px}
.col-card-actions{display:flex;gap:6px;flex-shrink:0}
.col-icon-btn{
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:7px;padding:5px 8px;font-size:.75rem;
  color:var(--muted);cursor:pointer;transition:border-color .15s,color .15s;
}
.col-icon-btn:hover{border-color:rgba(164,136,217,0.3);color:var(--text)}
.col-delete-btn:hover{border-color:rgba(239,68,68,0.3);color:#EF4444}
.col-form{
  display:flex;gap:8px;padding:14px 16px;
  border-top:1px solid var(--border);flex-shrink:0;
}
.col-name-input{
  flex:1;background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:8px;padding:9px 12px;font-family:var(--font);
  font-size:.82rem;color:var(--text);outline:none;
  transition:border-color .2s;
}
.col-name-input::placeholder{color:rgba(190,183,170,0.35)}
.col-name-input:focus{border-color:rgba(164,136,217,0.4)}
.col-create-btn{
  background:var(--gold);color:#080808;border:none;
  border-radius:8px;padding:9px 16px;font-family:var(--font);
  font-size:.8rem;font-weight:600;cursor:pointer;
  white-space:nowrap;transition:opacity .15s;flex-shrink:0;
}
.col-create-btn:hover{opacity:.85}

/* Light theme */
body.light .collections-box{background:rgba(245,243,239,0.98);border-color:rgba(0,0,0,0.12)}
body.light .col-card{background:rgba(0,0,0,0.02);border-color:rgba(0,0,0,0.08)}
body.light .col-card:hover{background:rgba(164,136,217,0.06)}
body.light .col-icon-btn{background:rgba(0,0,0,0.04);border-color:rgba(0,0,0,0.1)}
body.light .col-name-input{background:rgba(0,0,0,0.03);border-color:rgba(0,0,0,0.12);color:#1a1a1a}

/* ── Collection Detail View ──────────────────────────── */
.col-detail-header{
  display:flex;align-items:center;gap:10px;
  padding:4px 0 12px;border-bottom:1px solid var(--border);margin-bottom:10px;
}
.col-back-btn{
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:7px;padding:5px 10px;font-size:.75rem;
  color:var(--muted);cursor:pointer;font-family:var(--font);
  transition:border-color .15s,color .15s;white-space:nowrap;flex-shrink:0;
}
.col-back-btn:hover{border-color:rgba(164,136,217,0.3);color:var(--text)}
.col-detail-title{
  display:flex;align-items:center;gap:8px;
  font-size:.88rem;font-weight:600;color:var(--text);
  min-width:0;overflow:hidden;
}
.col-detail-title span:first-child{font-size:1.1rem;flex-shrink:0}
.col-detail-title span:last-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.col-detail-list{display:flex;flex-direction:column;gap:6px}
.col-tool-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:9px;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.02);
  text-decoration:none;color:var(--text);
  transition:border-color .15s,background .15s;
}
.col-tool-item:hover{
  border-color:rgba(164,136,217,0.25);background:rgba(164,136,217,0.04);
  text-decoration:none;
}
.col-tool-icon{font-size:1.1rem;width:28px;text-align:center;flex-shrink:0}
.col-tool-info{flex:1;min-width:0}
.col-tool-name{font-size:.83rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.col-tool-desc{font-size:.68rem;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
body.light .col-back-btn{background:rgba(0,0,0,0.04);border-color:rgba(0,0,0,0.1)}
body.light .col-tool-item{background:rgba(0,0,0,0.02);border-color:rgba(0,0,0,0.08)}
body.light .col-tool-item:hover{background:rgba(164,136,217,0.06)}

/* ── Collection Picker (tool page dropdown) ───────────── */
.col-picker{
  background:rgba(14,14,14,0.98);border:1px solid var(--border);
  border-radius:12px;box-shadow:0 16px 48px rgba(0,0,0,0.7);
  min-width:220px;max-width:260px;
  padding:8px;overflow:hidden;animation:cmdIn .15s ease-out;
}
.col-picker-label{
  padding:6px 10px 2px;font-size:.6rem;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;color:rgba(190,183,170,0.4);
}
.col-picker-item{
  display:flex;align-items:center;gap:8px;width:100%;
  padding:9px 10px;border-radius:8px;border:none;
  background:none;font-family:var(--font);font-size:.82rem;
  color:var(--text);cursor:pointer;text-align:left;
  transition:background .12s;
}
.col-picker-item:hover{background:rgba(164,136,217,0.08)}
.col-picker-item.active{color:var(--gold)}
.col-picker-check{margin-left:auto;color:var(--gold);font-weight:700;font-size:.8rem}
.col-picker-empty{padding:12px 10px;font-size:.78rem;color:var(--muted);text-align:center}
.col-picker-create-btn{
  display:block;width:100%;margin:6px 0 2px;
  background:rgba(164,136,217,0.1);border:1px solid rgba(164,136,217,0.2);
  border-radius:8px;padding:8px;font-family:var(--font);
  font-size:.75rem;color:var(--gold);cursor:pointer;
  transition:background .15s;
}
.col-picker-create-btn:hover{background:rgba(164,136,217,0.18)}
body.light .col-picker{background:rgba(245,243,239,0.98);border-color:rgba(0,0,0,0.12)}
body.light .col-picker-item:hover{background:rgba(164,136,217,0.1)}

/* ── Collections Toast ───────────────────────────────── */
.col-toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(10px);
  background:rgba(30,30,30,0.96);color:var(--text);
  padding:10px 20px;border-radius:100px;font-size:.8rem;font-weight:500;
  border:1px solid var(--border);box-shadow:0 8px 24px rgba(0,0,0,0.5);
  z-index:600;opacity:0;transition:opacity .25s,transform .25s;
  pointer-events:none;white-space:nowrap;
}
.col-toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
body.light .col-toast{background:rgba(250,248,244,0.97);border-color:rgba(0,0,0,0.1)}

/* ── Keyboard Shortcuts Modal ────────────────────────── */
.shortcuts-modal{
  position:fixed;top:0;left:0;right:0;bottom:0;
  z-index:510;display:none;align-items:center;justify-content:center;
  padding:20px;box-sizing:border-box;
}
.shortcuts-modal.open{display:flex!important}
.shortcuts-backdrop{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,0.55);backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);z-index:0;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.shortcuts-modal.open .shortcuts-backdrop{opacity:1;pointer-events:auto}
.shortcuts-box{
  position:relative;z-index:1;
  background:rgba(14,14,14,0.98);border:1px solid var(--border);
  border-radius:16px;padding:28px;width:400px;max-width:90vw;
  box-shadow:0 24px 80px rgba(0,0,0,0.8);animation:cmdIn .18s ease-out;
}
.shortcuts-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;
}
.shortcuts-title{font-size:.95rem;font-weight:700;margin:0}
.shortcuts-close{
  background:none;border:none;color:var(--muted);cursor:pointer;
  font-size:.9rem;padding:4px 8px;border-radius:6px;
  transition:color .15s,background .15s;
}
.shortcuts-close:hover{color:var(--text);background:rgba(255,255,255,0.06)}
.shortcuts-table{width:100%;border-collapse:collapse}
.shortcuts-table tr{border-bottom:1px solid var(--border)}
.shortcuts-table tr:last-child{border-bottom:none}
.shortcuts-table td{padding:10px 6px;font-size:.82rem}
.shortcuts-table td:first-child{padding-right:20px;width:40%;white-space:nowrap}
.shortcuts-table td:last-child{color:var(--muted)}
.shortcuts-table kbd{
  display:inline-block;background:rgba(255,255,255,0.07);
  border:1px solid var(--border);border-radius:5px;
  padding:3px 8px;font-size:.7rem;font-weight:600;
  font-family:var(--font);color:var(--text);
}
.shortcuts-hint{
  margin:20px 0 0;font-size:.68rem;color:rgba(190,183,170,0.4);
  text-align:center;
}
body.light .shortcuts-box{background:rgba(245,243,239,0.98);border-color:rgba(0,0,0,0.12)}
body.light .shortcuts-table kbd{background:rgba(0,0,0,0.06);border-color:rgba(0,0,0,0.12)}

/* ── Reduced motion for new modals ───────────────────── */
@media(prefers-reduced-motion:reduce){
  .collections-box,.shortcuts-box,.col-picker,.col-toast{animation:none!important;transition:none!important}
}

/* ═══════════════════════════════════════════════════════
   Mobile Bottom Navigation Bar
   ═══════════════════════════════════════════════════════ */
.btm-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:199;
  background:rgba(10,10,10,0.97);
  border-top:1px solid var(--border);
  padding:6px 0 calc(6px + env(safe-area-inset-bottom));
  max-height:80px;overflow:hidden;
}
.btm-nav-inner{
  display:flex;justify-content:space-around;align-items:center;
  max-width:480px;margin:0 auto;
}
.btm-nav-item{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:6px 12px;border-radius:10px;
  border:none;background:none;font-family:var(--font);cursor:pointer;
  text-decoration:none;color:var(--muted);
  font-size:.58rem;font-weight:500;letter-spacing:.3px;
  transition:color .2s;min-width:56px;
  -webkit-tap-highlight-color:transparent;
}
.btm-nav-item svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.btm-nav-item.active,.btm-nav-item:hover{color:var(--gold)}
.btm-nav-item.active svg{stroke:var(--gold)}
body.light .btm-nav{background:rgba(245,243,239,0.92)}
@media(max-width:800px){
  .btm-nav{display:block;backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(10,10,10,0.97)}
  footer{padding-bottom:calc(72px + env(safe-area-inset-bottom)) !important}
  main.page-wrap{padding-bottom:80px}
}

/* ── Footer Newsletter ──────────────────────────────── */
.foot-newsletter{
  grid-column:1/-1;padding:24px 0;margin-top:8px;
  border-top:1px solid var(--border);
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
}
.foot-newsletter-text{font-size:.78rem;color:var(--muted);max-width:300px;line-height:1.5}
.foot-newsletter-text strong{color:var(--text);font-weight:600}
.foot-newsletter-form{display:flex;gap:8px;flex:1;max-width:400px}
.foot-newsletter-input{
  flex:1;padding:10px 16px;border-radius:var(--radius-full);
  border:1px solid var(--border);background:var(--glass);
  color:var(--text);font-size:.78rem;font-family:var(--font);
  outline:none;transition:border-color .2s;min-width:0;
}
.foot-newsletter-input:focus{border-color:var(--gold)}
.foot-newsletter-input::placeholder{color:rgba(154,148,136,0.6)}
.foot-newsletter-btn{
  padding:10px 20px;border-radius:var(--radius-full);
  border:none;background:var(--gold);color:#080808;
  font-size:.72rem;font-weight:600;font-family:var(--font);
  cursor:pointer;transition:background .2s;white-space:nowrap;
}
.foot-newsletter-btn:hover{background:var(--gold2)}
body.light .foot-newsletter-input{background:rgba(0,0,0,0.04);border-color:rgba(0,0,0,0.12)}
@media(max-width:640px){
  .foot-newsletter{flex-direction:column;align-items:flex-start}
  .foot-newsletter-form{width:100%;max-width:none}
}
