:root{
  color-scheme: dark;
  --bg:#070014;
  --bg-2:#120023;
  --panel:#150323cc;
  --panel-2:#220537d9;
  --ink:#fff7ff;
  --muted:#d9c7ec;
  --pink:#ff3fd7;
  --hot:#ff00a8;
  --purple:#8b5cff;
  --violet:#4c1fa8;
  --cyan:#00f0ff;
  --lime:#cbff2e;
  --yellow:#ffe94f;
  --good:#3df6b8;
  --danger:#ff5e9d;
  --line:#ff4ce544;
  --glass:rgba(21,2,39,.74);
  --shadow:0 0 24px rgba(255,63,215,.35),0 0 60px rgba(139,92,255,.18);
  --radius:24px;
  --radius-sm:16px;
  --max:1240px;
  --font:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-display:"Trebuchet MS", Inter, ui-sans-serif, system-ui, sans-serif;
  /* Foxxo Quest functional token layer. Existing short tokens remain as compatibility aliases. */
  --rf-bg:var(--bg);
  --rf-bg-deep:var(--bg-2);
  --rf-panel:var(--panel);
  --rf-panel-strong:var(--panel-2);
  --rf-border:rgba(139,92,255,.34);
  --rf-border-soft:rgba(217,199,236,.16);
  --rf-text:var(--ink);
  --rf-text-muted:var(--muted);
  --rf-pink:var(--pink);
  --rf-pink-glow:rgba(255,63,215,.42);
  --rf-cyan:var(--cyan);
  --rf-lime:var(--lime);
  --rf-yellow:var(--yellow);
  --rf-purple:var(--purple);
  --rf-danger:var(--danger);
  --rf-warning:#ff9f43;
  --rf-radius-sm:var(--radius-sm);
  --rf-radius-md:18px;
  --rf-radius-lg:var(--radius);
  --rf-shadow-glow:var(--shadow);
  --rf-shadow-panel:0 16px 40px rgba(0,0,0,.34), inset 0 0 0 1px rgba(255,255,255,.05);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
*{
  scrollbar-width:thin;
  scrollbar-color:rgba(0,240,255,.78) rgba(8,0,18,.9);
}
::-webkit-scrollbar{
  width:14px;
  height:14px;
}
::-webkit-scrollbar-track{
  background:
    linear-gradient(180deg, rgba(8,0,18,.94), rgba(28,4,48,.9)),
    var(--bg);
  border-left:1px solid rgba(255,63,215,.2);
}
::-webkit-scrollbar-thumb{
  min-height:56px;
  border:3px solid rgba(8,0,18,.94);
  border-radius:999px;
  background:
    linear-gradient(180deg, var(--rf-pink), var(--rf-cyan) 58%, var(--rf-lime));
  box-shadow:
    0 0 14px rgba(0,240,255,.42),
    0 0 20px rgba(255,63,215,.28);
}
::-webkit-scrollbar-thumb:hover{
  background:
    linear-gradient(180deg, #ff7be6, #3cf7ff 58%, #dfff5c);
  box-shadow:
    0 0 18px rgba(0,240,255,.62),
    0 0 24px rgba(255,63,215,.42);
}
::-webkit-scrollbar-corner{
  background:var(--bg);
}
body{
  margin:0;
  min-height:100vh;
  color:var(--ink);
  font-family:var(--font);
  background:
    linear-gradient(180deg, rgba(5,0,14,.84), rgba(5,0,14,.7) 42%, rgba(5,0,14,.92)),
    url("/assets/img/foxxoquest-page-background.png") center top / cover no-repeat fixed,
    linear-gradient(90deg, rgba(255,63,215,.11) 0%, transparent 18%, transparent 82%, rgba(0,240,255,.08) 100%),
    linear-gradient(180deg,#06000f 0%,#10001f 46%,#05000e 100%);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.32;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:radial-gradient(circle at center, #000 0 58%, transparent 100%);
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.03) 0 1px, transparent 1px 4px);
  mix-blend-mode:screen;
  opacity:.1;
}
a{color:inherit;text-decoration:none}
button,input{font:inherit;color:inherit}
img{max-width:100%;display:block}
main:focus,main:focus-visible,#app:focus,#app:focus-visible{outline:none!important}
.skip-link{position:absolute;left:12px;top:12px;transform:translateX(-160vw);background:#fff;color:#000;padding:.6rem .8rem;border-radius:999px;z-index:9999}
.skip-link:focus{transform:none}
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.sparkle-layer{position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.9;background-image:
  linear-gradient(90deg, rgba(255,63,215,.16) 0 1px, transparent 1px 120px),
  linear-gradient(0deg, rgba(0,240,255,.1) 0 1px, transparent 1px 120px),
  repeating-linear-gradient(135deg, rgba(139,92,255,.08) 0 1px, transparent 1px 18px),
  radial-gradient(circle, rgba(255,255,255,.95) 0 1px, transparent 1px),
  radial-gradient(circle, rgba(255,63,215,.9) 0 1px, transparent 1px),
  radial-gradient(circle, rgba(255,233,79,.9) 0 1px, transparent 1px),
  radial-gradient(circle, rgba(0,240,255,.9) 0 1px, transparent 1px);
  background-size: 120px 120px, 120px 120px, 240px 240px, 127px 127px, 191px 191px, 223px 223px, 281px 281px;
  background-position: 0 0, 0 0, center top, 13px 9px, 48px 67px, 99px 11px, 0 0;
  animation:drift 30s linear infinite;
}
@keyframes drift{from{transform:translate3d(0,0,0)}to{transform:translate3d(-60px,-90px,0)}}
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  width:min(calc(100% - 24px),var(--max));
  margin:10px auto 0;
  min-height:88px;
  display:grid;
  grid-template-columns:auto minmax(420px,1fr) minmax(180px,260px) auto;
  align-items:center;
  gap:16px;
  padding:10px 18px;
  border:1px solid rgba(255,63,215,.54);
  border-radius:0 0 24px 24px;
  background:linear-gradient(180deg, rgba(14,0,27,.94), rgba(22,4,38,.86));
  box-shadow:var(--shadow), inset 0 -1px 0 rgba(255,255,255,.1);
  backdrop-filter:blur(18px);
}
.brand{display:flex;align-items:center;gap:8px;min-width:0}
.brand-logo{display:block;width:clamp(150px,19vw,260px);height:auto;max-height:68px;object-fit:contain;filter:drop-shadow(0 0 16px rgba(255,63,215,.72))}
.brand-mascot{width:56px;height:48px;object-fit:contain;filter:drop-shadow(0 0 14px rgba(255,63,215,.8))}
.brand-title,.logo-word{
  font-family:var(--font-display);
  font-weight:1000;
  letter-spacing:-.045em;
  line-height:.9;
  font-size:clamp(1.55rem,2.5vw,2.25rem);
  color:#fff;
  -webkit-text-stroke: 1.5px #2c053b;
  text-shadow:0 0 2px #fff,0 0 13px var(--pink),0 0 26px var(--purple),3px 3px 0 #12001e;
}
.brand-title::first-letter,.logo-word::first-letter{color:#ff5fdc}
.main-nav{display:flex;justify-content:center;gap:4px;align-items:center;min-width:0}
.main-nav a{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  min-width:0;
  flex:1 1 0;
  padding:8px 6px 7px;
  border-radius:12px;
  text-transform:uppercase;
  font-size:clamp(.62rem,.78vw,.72rem);
  font-weight:900;
  letter-spacing:.035em;
  color:var(--muted);
  position:relative;
  transition:.18s transform,.18s color,.18s background;
  white-space:nowrap;
  line-height:1.05;
  text-align:center;
}
.main-nav a:hover,.main-nav a[aria-current="page"]{color:white;background:rgba(255,63,215,.12);transform:translateY(-1px)}
.main-nav a[aria-current="page"]::after{content:"";position:absolute;bottom:3px;left:20%;right:20%;height:3px;border-radius:999px;background:var(--pink);box-shadow:0 0 12px var(--pink)}
.nav-icon{font-size:clamp(1rem,1.3vw,1.25rem);line-height:1;color:var(--pink);text-shadow:0 0 12px var(--pink),0 0 20px var(--purple)}
.site-search{height:44px;display:flex;align-items:center;padding:0 9px;border:1px solid rgba(255,63,215,.44);border-radius:999px;background:rgba(43,6,72,.65);box-shadow:inset 0 0 16px rgba(255,63,215,.14)}
.site-search input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:white;padding:0 8px}.site-search input::placeholder{color:#c9b4db}.site-search button{border:0;background:transparent;color:white;font-size:1.45rem;cursor:pointer;min-width:40px;height:40px;display:grid;place-items:center;border-radius:999px}.site-search button img{width:28px;height:28px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(0,240,255,.45)) drop-shadow(0 0 8px rgba(255,63,215,.32))}
.account-menu{position:relative;display:grid;place-items:center}
.profile-orb{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 35% 25%,#7336ff,#2c064e 60%,#090012);border:2px solid rgba(255,63,215,.7);box-shadow:0 0 22px rgba(255,63,215,.55),inset 0 0 18px rgba(255,255,255,.12);font-weight:1000;color:#fff;cursor:pointer;white-space:nowrap}.profile-orb span{filter:drop-shadow(0 0 8px var(--pink))}
.profile-orb.auth-signin{width:auto;min-width:104px;height:46px;padding:0 16px;border-radius:999px;background:linear-gradient(180deg, rgba(0,240,255,.18), rgba(43,6,72,.62));border-color:rgba(0,240,255,.48);box-shadow:0 0 18px rgba(0,240,255,.24), inset 0 0 16px rgba(255,255,255,.08);font-size:.9rem;text-transform:uppercase;letter-spacing:.04em}
.profile-orb.auth-signin span{filter:none}
.profile-orb.auth-initials{width:48px;min-width:48px;padding:0;border-radius:50%}
.account-heart-icon{width:22px;height:22px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(255,63,215,.5))}
.profile-orb.auth-signin{display:flex;align-items:center;justify-content:center;gap:8px}
.profile-orb.auth-initials{position:relative;overflow:hidden}
.profile-orb.auth-initials .account-heart-icon{position:absolute;inset:5px;width:34px;height:34px;opacity:.44}
.profile-orb.auth-initials span{position:relative;z-index:1}
.profile-orb:hover,.profile-orb:focus-visible{box-shadow:0 0 28px rgba(255,63,215,.85),0 0 48px rgba(0,240,255,.2),inset 0 0 18px rgba(255,255,255,.16);outline:0}
.account-popover{position:absolute;right:0;top:calc(100% + 12px);z-index:80;width:min(310px,calc(100vw - 28px));padding:14px;border:1px solid rgba(255,63,215,.58);border-radius:18px;background:linear-gradient(180deg,rgba(19,1,36,.98),rgba(8,0,18,.96));box-shadow:0 18px 42px rgba(0,0,0,.42),0 0 28px rgba(255,63,215,.36),inset 0 0 24px rgba(255,63,215,.08);opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:.16s opacity,.16s transform}
.account-popover::before{content:"";position:absolute;right:20px;top:-7px;width:14px;height:14px;transform:rotate(45deg);background:rgba(19,1,36,.98);border-left:1px solid rgba(255,63,215,.58);border-top:1px solid rgba(255,63,215,.58)}
.account-menu:hover .account-popover,.account-menu:focus-within .account-popover,.account-menu.is-open .account-popover{opacity:1;transform:none;pointer-events:auto}
.account-card-head{display:grid;gap:4px;padding:4px 4px 12px;border-bottom:1px solid rgba(255,63,215,.18)}
.account-kicker{text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:1000;color:var(--cyan)}
.account-card-head strong{font-size:1rem;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-card-head small{color:var(--muted);line-height:1.35}
.account-menu-actions{display:grid;gap:8px;padding-top:10px}
.account-menu-actions a,.account-menu-actions button{width:100%;display:flex;align-items:center;justify-content:space-between;min-height:38px;padding:9px 11px;border:1px solid rgba(255,63,215,.24);border-radius:12px;background:rgba(255,255,255,.04);color:#fff;font-weight:900;text-transform:lowercase;cursor:pointer}
.account-menu-actions a::after,.account-menu-actions button::after{content:"›";color:var(--pink);font-size:1.1rem}
.account-menu-actions a:hover,.account-menu-actions button:hover,.account-menu-actions a:focus-visible,.account-menu-actions button:focus-visible{border-color:rgba(255,63,215,.72);box-shadow:0 0 18px rgba(255,63,215,.28);outline:0}
.menu-toggle{display:none;background:rgba(255,63,215,.12);border:1px solid var(--line);border-radius:14px;padding:10px;gap:5px;flex-direction:column}.menu-toggle span{display:block;width:24px;height:3px;border-radius:9px;background:#fff;box-shadow:0 0 10px var(--pink)}
#app{width:min(calc(100% - 24px),var(--max));margin:22px auto 0;padding-bottom:28px}
.page{display:grid;gap:22px;animation:rise .28s ease both}@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.neon-panel,.hero,.footer,.card,.quest-row,.creator-card,.library-card,.stat-card,.page-hero,.form-card{
  position:relative;
  border:1px solid rgba(255,63,215,.55);
  background:
    linear-gradient(135deg, rgba(255,255,255,.05), transparent 30%),
    radial-gradient(circle at 20% 0%, rgba(255,63,215,.16), transparent 26rem),
    linear-gradient(180deg, rgba(29,6,56,.82), rgba(8,1,20,.84));
  border-radius:var(--radius);
  box-shadow:var(--shadow), inset 0 0 0 1px rgba(255,255,255,.06);
  overflow:hidden;
}
.neon-panel::before,.hero::before,.footer::before,.card::before,.page-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.46;background-image:
    linear-gradient(90deg, transparent 0 84%, rgba(255,255,255,.75) 84% 86%, transparent 86%),
    linear-gradient(0deg, transparent 0 84%, rgba(255,255,255,.75) 84% 86%, transparent 86%);
  background-size:34px 34px;
  mix-blend-mode:screen;
  mask-image:radial-gradient(circle at 82% 24%, #000 0 12rem, transparent 22rem);
}
.hero{
  min-height:430px;
  display:grid;
  grid-template-columns:minmax(260px,.92fr) 1.25fr;
  gap:18px;
  padding:28px;
  border-radius:28px;
  background:
    radial-gradient(circle at 18% 30%, rgba(255,63,215,.22), transparent 26rem),
    radial-gradient(circle at 72% 35%, rgba(139,92,255,.25), transparent 24rem),
    linear-gradient(135deg, rgba(18,1,42,.95), rgba(7,0,18,.92));
}
.hero::after,.page-hero::after{content:"";position:absolute;inset:12px;border-radius:20px;border:2px solid rgba(255,63,215,.45);pointer-events:none;box-shadow:inset 0 0 26px rgba(255,63,215,.18)}
.hero-art{display:grid;place-items:center;position:relative;min-height:320px}.hero-art::before{content:"";position:absolute;width:330px;height:330px;border-radius:50%;background:radial-gradient(circle, rgba(255,63,215,.28), transparent 64%);filter:blur(8px)}
.hero-art img{max-height:350px;filter:drop-shadow(0 0 18px rgba(255,63,215,.82)) drop-shadow(0 0 44px rgba(139,92,255,.6));z-index:1}
.hero-copy{align-self:center;padding:24px;position:relative;z-index:1}.eyebrow{text-transform:uppercase;font-weight:900;letter-spacing:.18em;color:var(--yellow);text-shadow:0 0 12px var(--yellow);font-size:.83rem;margin:0 0 12px}.hero h1{margin:0}.hero-title{font-family:var(--font-display);font-size:clamp(3.8rem,10vw,8rem);line-height:.82;font-weight:1000;letter-spacing:-.08em;background:linear-gradient(90deg,#ff4fdc 0%,#ff7bed 30%,#a875ff 68%,#ffffff 100%);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-stroke:2px #1b002c;text-shadow:0 0 8px rgba(255,255,255,.18),0 0 18px rgba(255,63,215,.72),0 0 42px rgba(139,92,255,.52)}
.tagline{margin:18px 0 0;color:#fff;font-size:clamp(1.05rem,2.2vw,1.35rem);line-height:1.55}.tag-pill{display:inline-flex;align-items:center;gap:10px;margin:20px 0 0;padding:14px 22px;border-radius:18px;border:1px solid rgba(255,63,215,.45);background:rgba(8,1,17,.55);box-shadow:inset 0 0 20px rgba(255,63,215,.16);color:#fff;font-weight:800}.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px}.button,.small-button{border:1px solid rgba(255,63,215,.7);background:linear-gradient(180deg, rgba(255,63,215,.38), rgba(139,92,255,.18));box-shadow:0 0 20px rgba(255,63,215,.42), inset 0 0 22px rgba(255,255,255,.08);border-radius:16px;padding:15px 24px;display:inline-flex;align-items:center;gap:10px;font-weight:1000;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:.18s transform,.18s filter}.button:hover,.small-button:hover{transform:translateY(-2px);filter:brightness(1.15)}.button.alt{border-color:rgba(139,92,255,.85);background:linear-gradient(180deg, rgba(139,92,255,.42), rgba(50,16,108,.25))}.button img{width:46px;height:36px;object-fit:contain}.small-button{padding:10px 14px;border-radius:12px;font-size:.9rem}.ghost-button{background:rgba(255,255,255,.03);border:1px solid rgba(255,63,215,.45);border-radius:12px;padding:9px 14px;color:#fff;cursor:pointer}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:6px 0 12px}.section-title{display:flex;align-items:center;gap:10px;margin:0;font-size:clamp(1.25rem,2vw,1.75rem);font-weight:1000;text-transform:uppercase;letter-spacing:.03em;text-shadow:0 0 12px rgba(255,63,215,.55)}.section-title .spark{color:var(--yellow);text-shadow:0 0 12px var(--yellow)}.view-link{font-weight:900;text-transform:uppercase;font-size:.85rem;color:#ffc9f5}
.grid{display:grid;gap:18px}.two-col{grid-template-columns:1.1fr .9fr}.three-col{grid-template-columns:repeat(3,1fr)}.four-col{grid-template-columns:repeat(4,1fr)}.five-col{grid-template-columns:repeat(5,1fr)}
.welcome-row{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}.welcome-card{display:grid;grid-template-columns:160px 1fr;align-items:center;gap:20px;padding:22px}.welcome-card img{filter:drop-shadow(0 0 18px rgba(255,63,215,.65))}.welcome-card h2{margin:0 0 8px;font-size:1.65rem;text-transform:uppercase}.welcome-card p{margin:.35rem 0;color:var(--muted);line-height:1.6}.stats{display:grid;grid-template-columns:repeat(3,1fr);padding:18px;align-items:stretch}.stat-card{padding:20px;text-align:center;border-radius:18px;background:rgba(22,4,40,.64)}.stat-card strong{display:block;font-size:2rem;color:#ff8ee9;text-shadow:0 0 12px var(--pink)}.stat-card span{display:block;text-transform:uppercase;font-weight:900;font-size:.8rem;color:#fff}.stat-card small{color:var(--muted)}
.creator-strip,.library-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.creator-card{padding:16px;min-height:150px}.creator-card .avatar{width:76px;height:76px;border-radius:50%;display:grid;place-items:center;margin-bottom:10px;background:radial-gradient(circle,#421577,#08000f);border:2px solid rgba(255,63,215,.58);box-shadow:0 0 20px rgba(255,63,215,.28);overflow:hidden}.creator-card .avatar img{width:100%;height:100%;object-fit:cover}.creator-card h3,.library-card h3{margin:0 0 3px}.creator-card p,.library-card p{margin:0;color:var(--muted);font-size:.9rem}.chip-row{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}.chip{padding:4px 9px;border-radius:999px;border:1px solid rgba(255,63,215,.45);background:rgba(255,63,215,.09);font-size:.72rem;color:#ffd6f6}.follow{margin-top:12px;width:100%;display:flex;justify-content:center;border:1px solid rgba(255,63,215,.65);background:rgba(255,63,215,.12);border-radius:10px;padding:8px;font-weight:800}
.progress-grid{display:grid;grid-template-columns:1.5fr .8fr;gap:18px}.quest-progress{display:grid;grid-template-columns:220px 1fr;gap:18px;padding:20px}.progress-ring{width:190px;height:190px;border-radius:50%;display:grid;place-items:center;margin:auto;background:conic-gradient(var(--pink) var(--progress,64%), rgba(255,255,255,.08) 0);box-shadow:0 0 25px rgba(255,63,215,.48);position:relative}.progress-ring::after{content:"";position:absolute;inset:18px;border-radius:50%;background:linear-gradient(180deg,#1b0730,#0a0015);border:1px solid rgba(255,63,215,.38)}.progress-ring b{position:relative;z-index:1;font-size:2.7rem}.progress-ring span{position:relative;z-index:1;display:block;font-size:.72rem;text-transform:uppercase;text-align:center;color:var(--muted)}.quest-list{display:grid;gap:10px}.quest-row{padding:12px;display:grid;grid-template-columns:46px 1fr auto;align-items:center;gap:12px;border-radius:14px}.quest-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(255,63,215,.12);font-size:1.5rem;border:1px solid rgba(255,63,215,.4)}.quest-row h3{font-size:1rem;margin:0}.quest-row p{margin:2px 0 0;color:var(--muted);font-size:.85rem}.quest-meta{display:flex;align-items:center;gap:12px}.bar{height:8px;min-width:120px;border-radius:999px;background:#2a0d46;overflow:hidden}.bar i{display:block;height:100%;width:var(--bar,50%);background:linear-gradient(90deg,var(--pink),var(--purple));box-shadow:0 0 14px var(--pink)}.xp{color:var(--yellow);font-weight:1000}.complete{border:0;width:36px;height:36px;border-radius:50%;background:rgba(61,246,184,.15);color:var(--good);cursor:pointer;font-weight:1000;display:grid;place-items:center}.level-card{padding:20px;display:grid;gap:15px}.level-badge{width:180px;height:180px;margin:auto;display:grid;place-items:center;clip-path:polygon(25% 5%,75% 5%,100% 50%,75% 95%,25% 95%,0 50%);background:radial-gradient(circle,#3d1473,#11011f 70%);border:3px solid var(--pink);box-shadow:0 0 28px rgba(255,63,215,.6)}.level-badge strong{font-size:3.3rem}.level-badge span{text-transform:uppercase;color:#fff;font-weight:900}.library-card{padding:0;overflow:hidden}.library-art{height:132px;display:grid;place-items:center;background:radial-gradient(circle at 50% 30%, rgba(255,63,215,.18), transparent 60%),linear-gradient(135deg,#2b0747,#080014)}.library-art img{height:120px;object-fit:contain;filter:drop-shadow(0 0 16px rgba(255,63,215,.72))}.library-card .body{padding:14px}
.page-hero{padding:34px;min-height:260px;display:grid;grid-template-columns:1fr 280px;align-items:center;gap:18px}.page-hero h1{margin:0;font-family:var(--font-display);font-size:clamp(3rem,8vw,6rem);line-height:.85;text-transform:uppercase;background:linear-gradient(90deg,#fff,#ff66dd 40%,#a978ff);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-stroke:1.2px #270038;text-shadow:0 0 20px rgba(255,63,215,.72)}.page-hero p{max-width:620px;line-height:1.6;color:var(--muted);font-size:1.1rem}.page-hero img{max-height:230px;margin:auto;filter:drop-shadow(0 0 22px rgba(255,63,215,.75))}.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.select,.input{background:rgba(21,3,38,.75);border:1px solid rgba(255,63,215,.45);border-radius:12px;padding:12px 14px;color:#fff;min-height:46px;outline:0}.input{flex:1;min-width:220px}.leaderboard{padding:20px}.leader-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,63,215,.14)}.rank{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:rgba(255,63,215,.13);font-weight:1000;color:#ff8ee9}.leader-name{font-weight:900}.leader-score{font-weight:1000;color:var(--yellow)}.achievement-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.achievement{padding:14px;border-radius:14px;border:1px solid rgba(255,63,215,.34);background:rgba(255,255,255,.03);text-align:center}.achievement .big{font-size:2rem}.form-card{padding:22px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid label{display:grid;gap:7px;color:var(--muted);font-weight:800}.form-grid input,.form-grid select{background:rgba(8,1,18,.7);border:1px solid rgba(255,63,215,.42);border-radius:12px;padding:12px;color:#fff}.path-card{padding:20px;display:grid;grid-template-columns:1fr 120px;gap:12px;align-items:center}.path-card img{max-height:115px;object-fit:contain}.checklist{display:grid;gap:10px;padding:18px}.checkline{display:flex;align-items:center;gap:12px;padding:11px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,63,215,.18)}.checkline input{accent-color:var(--pink);width:20px;height:20px}.profile-grid{display:grid;grid-template-columns:350px 1fr;gap:18px}.profile-card{text-align:center;padding:22px}.profile-card img{width:180px;height:180px;margin:auto;object-fit:contain;filter:drop-shadow(0 0 18px rgba(255,63,215,.7))}.timeline{padding:20px}.timeline-item{display:grid;grid-template-columns:22px 1fr;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,63,215,.14)}.dot{width:14px;height:14px;border-radius:50%;background:var(--pink);box-shadow:0 0 14px var(--pink);margin-top:5px}.admin-warning{padding:16px;border:1px solid rgba(255,233,79,.55);background:rgba(255,233,79,.08);border-radius:16px;color:#ffeeb0}.footer{margin-top:26px;padding:26px;display:grid;grid-template-columns:1.1fr repeat(3,.65fr) 1.2fr;gap:22px}.footer h3{margin:0 0 12px;text-transform:uppercase;font-size:.9rem;color:#fff}.footer p,.footer a{color:var(--muted);line-height:1.8}.footer .mini-brand{display:flex;align-items:center;gap:10px}.footer .mini-brand img{width:66px}.socials{display:flex;gap:12px;margin-top:14px}.socials span{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;border:1px solid rgba(255,63,215,.32);background:rgba(255,255,255,.05)}.newsletter{border:1px solid rgba(255,63,215,.5);border-radius:18px;padding:18px;background:rgba(255,63,215,.08)}.newsletter .inline{display:flex;gap:10px;margin-top:12px}.newsletter input{flex:1;min-width:0;background:rgba(8,1,18,.72);border:1px solid rgba(255,63,215,.45);border-radius:12px;padding:12px}.toast{position:fixed;right:20px;bottom:20px;max-width:360px;padding:14px 18px;border-radius:16px;background:rgba(22,3,39,.92);border:1px solid rgba(255,63,215,.55);box-shadow:var(--shadow);transform:translateY(20px);opacity:0;pointer-events:none;transition:.2s;z-index:90}.toast.show{opacity:1;transform:none}
@media (max-width:1120px){
  .topbar{grid-template-columns:auto auto minmax(0,1fr) auto;gap:10px}
  .menu-toggle{display:flex;grid-column:2}
  .main-nav{display:none;position:absolute;top:92px;left:0;right:0;margin:auto;width:calc(100% - 18px);border:1px solid rgba(255,63,215,.44);border-radius:20px;background:rgba(12,1,24,.96);padding:12px;grid-template-columns:repeat(3,1fr);box-shadow:var(--shadow)}
  .main-nav.open{display:grid}
  .site-search{grid-column:3;min-width:0}
}
@media (max-width:980px){
  .topbar{grid-template-columns:auto auto 1fr auto;gap:10px}.menu-toggle{display:flex;grid-column:2}.main-nav{display:none;position:absolute;top:92px;left:0;right:0;margin:auto;width:calc(100% - 18px);border:1px solid rgba(255,63,215,.44);border-radius:20px;background:rgba(12,1,24,.96);padding:12px;grid-template-columns:repeat(2,1fr);box-shadow:var(--shadow)}.main-nav.open{display:grid}.site-search{grid-column:3;min-width:0}.hero,.page-hero{grid-template-columns:1fr}.hero-copy{text-align:center}.hero-actions{justify-content:center}.welcome-row,.progress-grid,.two-col,.profile-grid{grid-template-columns:1fr}.creator-strip,.library-strip{grid-template-columns:repeat(2,1fr)}.quest-progress{grid-template-columns:1fr}.footer{grid-template-columns:1fr 1fr}.page-hero img{max-height:190px}.stats{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:680px){
  body{font-size:15px}.topbar{width:calc(100% - 16px);grid-template-columns:auto auto minmax(0,1fr);min-height:76px;gap:6px;padding:8px}.brand{gap:5px}.brand-logo{width:clamp(118px,32vw,160px);max-height:50px}.brand-title{font-size:1.05rem}.brand-mascot{width:42px}.menu-toggle{padding:9px}.account-menu,.profile-orb,.account-popover{display:none!important}.site-search{display:flex;grid-column:3;min-width:0;max-width:100%;height:42px;padding:0 6px;overflow:hidden}.site-search input{font-size:.9rem;padding:0 5px}.site-search button{min-width:32px;height:32px;font-size:.9rem;text-transform:uppercase;font-weight:1000}.hero{padding:16px}.hero-art{min-height:230px}.hero-art img{max-height:240px}.tag-pill{font-size:.9rem}.welcome-card{grid-template-columns:1fr;text-align:center}.stats,.creator-strip,.library-strip,.three-col,.four-col,.five-col,.achievement-grid,.form-grid,.footer{grid-template-columns:1fr}.page-hero{padding:22px}.page-hero h1{font-size:3rem}.quest-row{grid-template-columns:42px 1fr}.quest-meta{grid-column:2;justify-content:space-between}.bar{min-width:80px}.footer{padding:18px}.newsletter .inline{flex-direction:column}.profile-card img{width:140px;height:140px}}
@media (max-width:380px){
  .topbar{
    grid-template-columns:minmax(0,1fr) auto;
    grid-template-areas:"brand menu" "search search";
  }
  .brand{
    grid-area:brand;
    min-width:0;
  }
  .brand-logo{
    width:min(62vw,190px);
    max-height:54px;
  }
  .menu-toggle{
    grid-area:menu;
    grid-column:auto;
  }
  .site-search{
    grid-area:search;
    grid-column:1 / -1;
    width:100%;
  }
  .main-nav{
    top:calc(100% + 8px);
  }
}

/* Shared Foxxo Quest beta title treatment */
.beta-badge{
  display:inline-flex;
  align-items:center;
  width:max-content;
  margin:12px auto 0;
  padding:7px 12px;
  border:1px solid rgba(203,255,46,.7);
  border-radius:999px;
  color:#cbff2e;
  background:rgba(12,22,0,.48);
  box-shadow:0 0 14px rgba(203,255,46,.42), inset 0 0 14px rgba(203,255,46,.08);
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.72rem;
}
.eyebrow,
.page-hero .eyebrow,
.signin-copy .eyebrow,
.dashboard-hero-copy .eyebrow{
  color:#a9ff1f;
  letter-spacing:.18em;
  text-shadow:0 0 10px rgba(169,255,31,.9),0 0 22px rgba(169,255,31,.38);
}
.hero-title,
.page-hero h1,
.signin-title,
.game-portal-title{
  background:none!important;
  -webkit-background-clip:initial!important;
  background-clip:initial!important;
  color:#fff!important;
  -webkit-text-stroke:1.35px #230039;
  text-shadow:
    3px 0 0 rgba(0,223,255,.9),
    -3px 0 0 rgba(255,42,211,.88),
    0 3px 0 rgba(255,42,211,.32),
    0 0 18px rgba(255,42,211,.78),
    0 0 34px rgba(0,223,255,.32);
  letter-spacing:.02em!important;
}
.page-hero h1,
.signin-title{
  line-height:.9;
}

.vault-flow-grid,
.vault-request-layout{
  display:grid;
  gap:16px;
}
.vault-flow-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.upload-path-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.upload-path-strip .form-card{
  min-height:132px;
  align-content:center;
}
.media-upload-form{
  max-width:1040px;
  margin-inline:auto;
}
.media-upload-form .wide-field{
  grid-column:1 / -1;
}
.media-upload-form .hero-actions{
  margin-top:18px;
}
.media-upload-hero img{
  max-height:180px;
}
.upload-form-step,
.upload-optional-panel{
  margin-top:18px;
  padding:16px;
  border:1px solid rgba(0,240,255,.26);
  border-radius:18px;
  background:
    linear-gradient(135deg, rgba(0,240,255,.055), rgba(255,63,215,.035)),
    rgba(255,255,255,.025);
  box-shadow:inset 0 0 24px rgba(0,240,255,.05);
}
.upload-step-title{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:14px;
}
.upload-step-title span{
  flex:0 0 auto;
  display:grid;
  place-items:center;
  width:40px;
  height:40px;
  border-radius:14px;
  background:linear-gradient(135deg, var(--rf-pink), var(--rf-cyan));
  color:#11001f;
  font-family:var(--font-mono);
  font-weight:1000;
  box-shadow:0 0 20px rgba(255,63,215,.34);
}
.upload-step-title h3{
  margin:0;
  font-size:1.25rem;
  text-transform:uppercase;
}
.upload-step-title p{
  margin:4px 0 0;
  color:var(--rf-text-muted);
  line-height:1.35;
}
.media-upload-form .form-grid label:nth-last-child(-n+3){
  grid-column:auto;
}
.media-upload-form .wide-field{
  grid-column:1 / -1!important;
}
.upload-kind-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.storage-source-panel{
  grid-column:1 / -1;
  display:grid;
  gap:12px;
  padding:14px;
  border:1px solid rgba(0,240,255,.24);
  border-radius:18px;
  background:linear-gradient(135deg, rgba(0,240,255,.07), rgba(255,63,215,.035));
}
.storage-source-panel .upload-step-title{
  margin-bottom:0;
}
.storage-source-panel .upload-step-title span{
  width:42px;
  height:30px;
  border-radius:999px;
  font-size:.72rem;
}
.storage-source-panel .upload-step-title h3{
  font-size:1rem;
}
.storage-choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.storage-choice-grid label{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px;
  border:1px solid rgba(217,199,236,.16);
  border-radius:14px;
  background:rgba(255,255,255,.035);
  cursor:pointer;
}
.storage-choice-grid input{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color:var(--rf-cyan);
}
.storage-choice-grid label:has(input:checked){
  border-color:rgba(0,240,255,.7);
  box-shadow:0 0 18px rgba(0,240,255,.14);
}
.storage-choice-grid b{
  display:block;
  color:#fff;
}
.storage-choice-grid small{
  display:block;
  margin-top:3px;
  color:var(--rf-text-muted);
  line-height:1.3;
}
.storage-details-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.upload-optional-panel summary{
  cursor:pointer;
  color:var(--rf-lime);
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.upload-optional-panel summary::marker{
  color:var(--rf-cyan);
}
.upload-optional-panel .form-grid{
  margin-top:16px;
}
.vault-request-layout{
  grid-template-columns:minmax(0,1fr) minmax(290px,390px);
  align-items:start;
}
.vault-side-stack,
.vault-request-list{
  display:grid;
  gap:14px;
}
.vault-request-form .form-grid textarea,
.vault-request-form .form-grid input[type="file"]{
  min-height:48px;
  border:1px solid rgba(255,63,215,.42);
  border-radius:12px;
  background:rgba(8,1,18,.7);
  color:#fff;
  padding:12px;
}
.vault-request-form .form-grid textarea{
  min-height:120px;
  resize:vertical;
}
.vault-request-form .form-grid label:nth-last-child(-n+3){
  grid-column:1 / -1;
}
.wide-field{
  grid-column:1 / -1;
}
.vault-checkbox-grid,
.vault-tag-grid{
  display:grid;
  gap:10px;
  margin:16px 0 0;
  padding:14px;
  border:1px solid rgba(0,240,255,.26);
  border-radius:var(--rf-radius-md);
  background:rgba(0,240,255,.045);
}
.vault-checkbox-grid{
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
}
.vault-tag-grid{
  grid-template-columns:repeat(auto-fit,minmax(110px,1fr));
}
.vault-checkbox-grid legend,
.vault-tag-grid legend{
  padding:0 6px;
  color:var(--rf-lime);
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.vault-checkbox-grid label,
.vault-tag-grid label{
  display:flex;
  gap:10px;
  align-items:flex-start;
  min-height:54px;
  padding:11px;
  border:1px solid rgba(217,199,236,.16);
  border-radius:12px;
  background:rgba(255,255,255,.04);
  cursor:pointer;
}
.vault-checkbox-grid label:has(input:checked),
.vault-tag-grid label:has(input:checked){
  border-color:rgba(203,255,46,.68);
  background:linear-gradient(135deg, rgba(203,255,46,.13), rgba(0,240,255,.055));
}
.vault-checkbox-grid input,
.vault-tag-grid input{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color:var(--rf-lime);
}
.vault-checkbox-grid b,
.vault-tag-grid span{
  color:#fff;
  font-weight:1000;
}
.vault-checkbox-grid small{
  display:block;
  margin-top:3px;
  color:var(--rf-text-muted);
  line-height:1.3;
}
.vault-step-list{
  display:grid;
  gap:8px;
  margin-top:12px;
}
.vault-step-link{
  display:grid;
  gap:3px;
  padding:10px;
  border:1px solid rgba(0,240,255,.24);
  border-radius:12px;
  background:rgba(0,240,255,.045);
}
.vault-step-link b{
  color:#fff;
  text-transform:uppercase;
}
.vault-step-link span{
  color:var(--rf-text-muted);
  font-size:.86rem;
}
.vault-preview-mini{
  display:grid;
  gap:3px;
  padding:10px;
  margin-top:10px;
  border:1px solid rgba(255,233,79,.26);
  border-radius:12px;
  background:rgba(255,233,79,.055);
}
.vault-preview-mini b{
  color:var(--rf-yellow);
  text-transform:uppercase;
}
.vault-preview-mini span{
  color:var(--rf-text-muted);
}
.vault-guided-panels{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:14px;
}
.vault-guided-panels article{
  scroll-margin-top:110px;
  padding:12px;
  border:1px solid rgba(0,240,255,.24);
  border-radius:12px;
  background:rgba(0,240,255,.045);
}
.vault-guided-panels b{
  display:block;
  color:#fff;
  text-transform:uppercase;
}
.vault-guided-panels span{
  display:block;
  margin-top:4px;
  color:var(--rf-text-muted);
  line-height:1.35;
}
#vault-source,
#vault-needs,
#vault-tags{
  scroll-margin-top:110px;
}
.vault-request-card .badge-row{
  margin-top:8px;
}
.vault-admin-note{
  border-color:rgba(255,233,79,.34);
}
@media (max-width:980px){
  .vault-flow-grid,
  .vault-request-layout,
  .upload-path-strip{
    grid-template-columns:1fr;
  }
}
@media (max-width:680px){
  .vault-request-form .form-grid{
    grid-template-columns:1fr;
  }
  .vault-checkbox-grid,
  .vault-tag-grid{
    grid-template-columns:1fr;
  }
  .storage-choice-grid,
  .storage-details-grid{
    grid-template-columns:1fr;
  }
  .vault-guided-panels{
    grid-template-columns:1fr;
  }
}
.small-button.is-static{
  cursor:default;
  opacity:.72;
  pointer-events:none;
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
.muted{color:var(--muted)}

/* Foxxo Quest shared public modules */
.neon-panel,
.card,
.quest-row,
.creator-card,
.library-card,
.stat-card,
.form-card,
.footer{
  border-color:var(--rf-border);
  box-shadow:var(--rf-shadow-panel);
}
.hero,
.page-hero,
.first-quest-card{
  border-color:rgba(255,63,215,.55);
  box-shadow:var(--rf-shadow-glow), inset 0 0 0 1px rgba(255,255,255,.06);
}
.first-quest-card{
  gap:18px;
  align-items:center;
}
.first-quest-meter{
  display:flex;
  align-items:center;
  gap:12px;
  max-width:420px;
  margin-top:14px;
}
.first-quest-meter span{
  min-width:52px;
  color:var(--rf-lime);
  font-family:var(--font-display);
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.first-quest-meter .bar{
  flex:1;
}
.hero,
.page-hero{
  --hero-accent:rgba(255,63,215,.45);
  --hero-glow:rgba(255,63,215,.18);
}
.hero::after,
.page-hero::after{
  border:2px solid var(--hero-accent)!important;
  box-shadow:inset 0 0 26px var(--hero-glow)!important;
}
.page-hero.start-hero,
.page-hero.search-hero{
  --hero-accent:rgba(255,233,79,.48);
  --hero-glow:rgba(255,233,79,.17);
}
.page-hero.library-hero{
  --hero-accent:rgba(0,240,255,.48);
  --hero-glow:rgba(0,240,255,.15);
}
.page-hero.levels-hero{
  --hero-accent:rgba(203,255,46,.48);
  --hero-glow:rgba(203,255,46,.14);
}
.people-hero{
  --hero-accent:rgba(139,92,255,.5);
  --hero-glow:rgba(139,92,255,.16);
}
.profile-page .page-hero{
  --hero-accent:rgba(0,240,255,.44);
  --hero-glow:rgba(0,240,255,.13);
}
.admin-page .page-hero{
  --hero-accent:rgba(255,159,67,.54);
  --hero-glow:rgba(255,159,67,.16);
}
.main-nav a{
  --nav-accent:var(--rf-pink);
  --nav-accent-bg:rgba(255,63,215,.12);
  --nav-accent-glow:rgba(255,63,215,.64);
}
.main-nav a.accent-cyan{--nav-accent:var(--rf-cyan);--nav-accent-bg:rgba(0,240,255,.1);--nav-accent-glow:rgba(0,240,255,.56)}
.main-nav a.accent-lime{--nav-accent:var(--rf-lime);--nav-accent-bg:rgba(203,255,46,.1);--nav-accent-glow:rgba(203,255,46,.52)}
.main-nav a.accent-yellow{--nav-accent:var(--rf-yellow);--nav-accent-bg:rgba(255,233,79,.1);--nav-accent-glow:rgba(255,233,79,.52)}
.main-nav a.accent-purple{--nav-accent:var(--rf-purple);--nav-accent-bg:rgba(139,92,255,.12);--nav-accent-glow:rgba(139,92,255,.56)}
.main-nav a.accent-warning{--nav-accent:var(--rf-warning);--nav-accent-bg:rgba(255,159,67,.12);--nav-accent-glow:rgba(255,159,67,.5)}
.main-nav a:hover,
.main-nav a[aria-current="page"]{
  background:var(--nav-accent-bg);
}
.main-nav a[aria-current="page"]::after{
  background:var(--nav-accent);
  box-shadow:0 0 12px var(--nav-accent-glow);
}
.main-nav .nav-icon{
  color:var(--nav-accent);
  text-shadow:0 0 12px var(--nav-accent-glow),0 0 20px rgba(139,92,255,.36);
}
.button,
.small-button{
  --button-border:rgba(255,63,215,.58);
  --button-bg-a:rgba(255,63,215,.34);
  --button-bg-b:rgba(139,92,255,.18);
  --button-glow:rgba(255,63,215,.36);
  border-color:var(--button-border);
  background:linear-gradient(180deg,var(--button-bg-a),var(--button-bg-b));
  box-shadow:0 0 18px var(--button-glow), inset 0 0 20px rgba(255,255,255,.075);
}
.button.alt,
.small-button.alt{
  --button-border:rgba(139,92,255,.72);
  --button-bg-a:rgba(139,92,255,.32);
  --button-bg-b:rgba(50,16,108,.22);
  --button-glow:rgba(139,92,255,.26);
}
.button.cyan,
.small-button.cyan{
  --button-border:rgba(0,240,255,.64);
  --button-bg-a:rgba(0,240,255,.2);
  --button-bg-b:rgba(43,6,72,.18);
  --button-glow:rgba(0,240,255,.28);
}
.button.lime,
.small-button.lime{
  --button-border:rgba(203,255,46,.58);
  --button-bg-a:rgba(203,255,46,.18);
  --button-bg-b:rgba(0,240,255,.08);
  --button-glow:rgba(203,255,46,.25);
}
.button.yellow,
.small-button.yellow{
  --button-border:rgba(255,233,79,.62);
  --button-bg-a:rgba(255,233,79,.2);
  --button-bg-b:rgba(255,63,215,.1);
  --button-glow:rgba(255,233,79,.26);
}
.button.warning,
.small-button.warning{
  --button-border:rgba(255,159,67,.68);
  --button-bg-a:rgba(255,159,67,.2);
  --button-bg-b:rgba(255,94,157,.1);
  --button-glow:rgba(255,159,67,.24);
}
.button.quiet,
.small-button.quiet{
  --button-border:rgba(217,199,236,.2);
  --button-bg-a:rgba(255,255,255,.04);
  --button-bg-b:rgba(69,38,96,.18);
  --button-glow:rgba(0,0,0,0);
  color:var(--rf-text-muted);
}
.button.danger,
.small-button.danger{
  --button-border:rgba(255,94,122,.72);
  --button-bg-a:rgba(255,94,122,.22);
  --button-bg-b:rgba(255,63,215,.09);
  --button-glow:rgba(255,94,122,.24);
}
.button.locked-button,
.small-button.locked-button,
.button:disabled,
.small-button:disabled{
  --button-border:rgba(217,199,236,.24);
  --button-bg-a:rgba(69,38,96,.36);
  --button-bg-b:rgba(18,7,31,.24);
  --button-glow:rgba(0,0,0,0);
  color:var(--rf-text-muted);
  cursor:not-allowed;
}
a.locked-button{
  cursor:pointer;
}
a.button.locked-button,
a.small-button.locked-button{
  cursor:pointer;
}
.site-search{
  border-color:var(--rf-border);
  box-shadow:inset 0 0 16px rgba(139,92,255,.08);
}
.site-search:focus-within{
  border-color:rgba(0,240,255,.7);
  box-shadow:0 0 0 3px rgba(0,240,255,.1),0 0 18px rgba(0,240,255,.16);
}
.select,
.input,
.form-grid input,
.form-grid select,
.newsletter input{
  border-color:var(--rf-border);
  box-shadow:inset 0 0 16px rgba(139,92,255,.08);
}
.select:focus,
.input:focus,
.form-grid input:focus,
.form-grid select:focus,
.newsletter input:focus{
  border-color:rgba(0,240,255,.7);
  box-shadow:0 0 0 3px rgba(0,240,255,.12),0 0 18px rgba(0,240,255,.16);
}
.checkline,
.leader-row,
.timeline-item{
  border-color:var(--rf-border-soft);
}
.accent-cyan{border-color:rgba(0,240,255,.42)!important}
.accent-lime{border-color:rgba(203,255,46,.38)!important}
.accent-yellow{border-color:rgba(255,233,79,.44)!important}
.accent-warning{border-color:rgba(255,159,67,.54)!important}
.accent-pink{border-color:rgba(255,63,215,.54)!important}
.accent-purple{border-color:rgba(139,92,255,.54)!important}
.badge-row{display:flex;flex-wrap:wrap;gap:7px;margin:0 0 7px}
.rave-badge{
  display:inline-flex;
  align-items:center;
  width:max-content;
  max-width:100%;
  min-height:24px;
  padding:4px 9px;
  border:1px solid var(--rf-border-soft);
  border-radius:999px;
  background:rgba(139,92,255,.12);
  color:var(--rf-text-muted);
  font-size:.68rem;
  font-weight:1000;
  letter-spacing:.08em;
  line-height:1;
  text-transform:uppercase;
}
.badge-new{color:var(--rf-yellow);border-color:rgba(255,233,79,.36);background:rgba(255,233,79,.08)}
.badge-locked{color:var(--rf-text-muted);border-color:rgba(217,199,236,.2);background:rgba(69,38,96,.28)}
.badge-xp{color:var(--rf-lime);border-color:rgba(203,255,46,.32);background:rgba(203,255,46,.08)}
.badge-status{color:var(--rf-cyan);border-color:rgba(0,240,255,.32);background:rgba(0,240,255,.08)}
.quest-empty-state{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  align-items:center;
  border-color:rgba(255,233,79,.42);
  background:
    radial-gradient(circle at 92% 12%, rgba(255,233,79,.1), transparent 18rem),
    linear-gradient(180deg, rgba(29,6,56,.82), rgba(8,1,20,.84));
}
.quest-empty-state h2{margin:.1rem 0 .45rem;color:var(--rf-text);font-size:clamp(1.5rem,2.4vw,2.15rem)}
.quest-empty-state .hero-actions{margin:0;justify-content:flex-end}
.locked-button{border-color:rgba(217,199,236,.28);background:linear-gradient(180deg, rgba(69,38,96,.44), rgba(18,7,31,.3));box-shadow:none}
.empty-state{
  min-height:120px;
  display:grid;
  align-content:center;
  gap:10px;
  padding:18px;
  border:1px solid var(--rf-border-soft);
  border-radius:var(--rf-radius-md);
  background:rgba(255,255,255,.035);
  color:var(--rf-text-muted);
}
.empty-state h2{margin:0;color:var(--rf-text);font-size:1.15rem;text-transform:uppercase}
.empty-state p{margin:0;line-height:1.55}
.empty-state .hero-actions{margin-top:4px}
.empty-state .small-button{justify-content:center}
.search-panel{display:grid;gap:8px}
.search-panel .toolbar{margin:0}
.search-results-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.search-result-card{
  min-height:190px;
  display:grid;
  align-content:start;
  gap:12px;
  padding:18px;
  border-color:var(--rf-border);
  box-shadow:var(--rf-shadow-panel);
}
.search-result-card h2{margin:0;color:var(--rf-text);font-size:1.25rem;line-height:1.15}
.search-result-card p{margin:0;color:var(--rf-text-muted);line-height:1.55}
.search-badge{
  width:max-content;
  max-width:100%;
  padding:5px 9px;
  border-radius:999px;
  border:1px solid var(--rf-border-soft);
  background:rgba(139,92,255,.12);
  color:var(--rf-text);
  font-size:.72rem;
  font-weight:1000;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.search-result-card.accent-cyan{border-color:rgba(0,240,255,.48)}
.search-result-card.accent-lime{border-color:rgba(203,255,46,.46)}
.search-result-card.accent-yellow{border-color:rgba(255,233,79,.5)}
.search-result-card.accent-warning{border-color:rgba(255,159,67,.58)}
.search-result-card.accent-purple{border-color:rgba(139,92,255,.58)}
.search-result-card.accent-pink{border-color:rgba(255,63,215,.58)}
.search-result-card.accent-cyan .search-badge{color:var(--rf-cyan);border-color:rgba(0,240,255,.36)}
.search-result-card.accent-lime .search-badge{color:var(--rf-lime);border-color:rgba(203,255,46,.34)}
.search-result-card.accent-yellow .search-badge,.search-result-card.accent-warning .search-badge{color:var(--rf-yellow);border-color:rgba(255,233,79,.34)}
.path-card small{display:block;margin:8px 0 12px;color:var(--rf-text-muted);font-weight:900;line-height:1.4}
.mission-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(240px,340px);
  align-items:center;
  gap:22px;
  padding:28px;
  border-color:rgba(255,233,79,.34);
  background:
    radial-gradient(circle at 88% 16%, rgba(255,233,79,.08), transparent 16rem),
    linear-gradient(135deg, rgba(25,4,48,.88), rgba(8,0,18,.82));
}
.mission-panel .eyebrow{
  color:var(--rf-yellow);
  text-shadow:0 0 12px rgba(255,233,79,.45);
}
.mission-panel h2{
  margin:.1rem 0 .55rem;
  color:var(--rf-text);
  font-family:var(--display);
  font-size:clamp(1.65rem,3vw,2.5rem);
  line-height:1;
  text-transform:uppercase;
}
.mission-panel p{
  max-width:68rem;
  margin:0;
  color:var(--rf-text);
  font-size:clamp(1rem,1.6vw,1.18rem);
  line-height:1.6;
}
.mission-status-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.mission-status{
  min-height:78px;
  display:grid;
  place-items:center;
  border:1px solid var(--rf-border);
  border-radius:var(--rf-radius-md);
  background:rgba(255,255,255,.045);
  color:var(--rf-text);
  font-family:var(--display);
  font-weight:1000;
  letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow:var(--rf-shadow-panel);
}
.mission-status.accent-yellow{border-color:rgba(255,233,79,.46);color:var(--rf-yellow)}
.mission-status.accent-pink{border-color:rgba(255,63,215,.5);color:var(--rf-pink)}
.mission-status.accent-cyan{border-color:rgba(0,240,255,.44);color:var(--rf-cyan)}
.mission-status.accent-lime{border-color:rgba(203,255,46,.42);color:var(--rf-lime)}
.home-divider{
  position:relative;
  display:grid;
  gap:6px;
  padding:18px 22px;
  border:1px solid rgba(0,240,255,.28);
  border-radius:var(--rf-radius-md);
  background:
    linear-gradient(90deg, rgba(0,240,255,.08), rgba(255,63,215,.05), rgba(203,255,46,.05)),
    rgba(6,0,17,.72);
  box-shadow:0 0 24px rgba(0,240,255,.1), inset 0 0 26px rgba(255,63,215,.06);
}
.home-divider::before{
  content:"";
  position:absolute;
  left:22px;
  right:22px;
  top:-12px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,63,215,.5),rgba(0,240,255,.42),transparent);
}
.home-divider h2{
  margin:0;
  color:#fff;
  text-transform:uppercase;
  font-size:clamp(1.45rem,3vw,2.25rem);
  line-height:1;
}
.home-divider p:last-child{
  margin:0;
  max-width:780px;
  color:var(--rf-text-muted);
  line-height:1.5;
}
@media (max-width:980px){.mission-panel{grid-template-columns:1fr}.mission-status-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width:680px){
  .home-page .hero{min-height:auto;padding:14px;gap:10px}
  .home-page .hero-art{min-height:170px}
  .home-page .hero-art::before{width:210px;height:210px}
  .home-page .hero-art img{max-height:190px}
  .home-page .hero-copy{padding:12px 10px 16px}
  .home-page .hero-title{font-size:clamp(3rem,16vw,4rem);letter-spacing:-.05em}
  .home-page .tagline{margin-top:12px}
  .home-page .tag-pill{margin-top:14px;padding:10px 14px}
  .home-page .hero-actions{display:grid;gap:12px;margin-top:18px}
  .home-page .hero-actions .button{width:100%;justify-content:center;padding:13px 16px}
  .home-page .auth-nudge{margin:12px 0 0}
  .home-divider{padding:16px}
  .mission-panel{padding:20px}
  .mission-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .mission-status{min-height:58px}
}
@media (max-width:980px){.search-results-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:980px){.quest-empty-state{grid-template-columns:1fr}.quest-empty-state .hero-actions{justify-content:flex-start}}
@media (max-width:680px){.search-results-grid{grid-template-columns:1fr}.search-panel .toolbar{display:grid}.search-panel .button{justify-content:center}.quest-empty-state .hero-actions,.empty-state .hero-actions{display:grid}.quest-empty-state .button,.quest-empty-state .small-button{justify-content:center}}

/* start page polish */
.start-page{gap:28px}
.start-page .eyebrow{
  color:var(--yellow);
  text-shadow:0 0 12px var(--yellow),0 0 28px rgba(255,233,79,.42);
}
.start-hero{
  min-height:300px;
  overflow:hidden;
}
.start-hero img{
  max-height:255px;
}
.start-setup{
  align-items:stretch;
}
.start-setup .form-card{
  display:grid;
  gap:16px;
  align-content:start;
}
.setup-form-title{
  padding-bottom:4px;
}
.start-setup .form-card h2,
.start-checklist h2{
  margin:.1rem 0 0;
  font-size:clamp(1.45rem,2.3vw,2rem);
}
.start-setup .form-card .button{
  margin-top:8px;
  justify-self:start;
}
.start-checklist{
  align-content:start;
  gap:12px;
  background:
    radial-gradient(circle at 85% 12%, rgba(255,233,79,.09), transparent 16rem),
    linear-gradient(135deg, rgba(35,4,58,.82), rgba(12,0,26,.76));
}
.setup-step{
  display:grid;
  gap:12px;
  padding:14px;
  border:1px solid rgba(217,199,236,.16);
  border-radius:var(--rf-radius-md);
  background:
    linear-gradient(135deg, rgba(255,255,255,.055), rgba(255,255,255,.02)),
    rgba(8,0,18,.36);
  box-shadow:inset 0 0 24px rgba(255,63,215,.05);
}
.setup-step-head{
  display:grid;
  grid-template-columns:38px 1fr;
  gap:11px;
  align-items:start;
}
.setup-step-head>span{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:12px;
  color:#13001d;
  background:linear-gradient(135deg,var(--rf-yellow),var(--rf-pink));
  font-weight:1000;
  box-shadow:0 0 18px rgba(255,63,215,.35);
}
.setup-step-head h3{
  margin:0;
  color:#fff;
  text-transform:uppercase;
  font-size:1rem;
}
.setup-step-head p{
  margin:3px 0 0;
  color:var(--rf-text-muted);
  line-height:1.45;
}
.setup-social-links{
  grid-column:1 / -1;
  margin-top:2px;
  padding:12px;
  border:1px solid rgba(0,240,255,.2);
  border-radius:14px;
  background:rgba(0,240,255,.045);
}
.setup-social-links summary{
  cursor:pointer;
  color:#fff;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.setup-social-links summary::marker{
  color:var(--rf-cyan);
}
.setup-social-links p{
  margin:8px 0 12px;
}
.username-status{
  display:block;
  margin-top:6px;
  font-size:.82rem;
  line-height:1.35;
  color:var(--rf-text-muted);
}
.username-status[data-state="available"]{color:var(--rf-lime)}
.username-status[data-state="taken"]{color:#ff9fcf}
.username-status[data-state="checking"]{color:var(--rf-cyan)}
.verified-account-field{
  min-height:48px;
  display:grid;
  gap:4px;
  justify-content:start;
  align-content:center;
  padding:12px 14px;
  border-radius:12px;
  border:1px dashed rgba(0,240,255,.36);
  background:rgba(0,240,255,.055);
}
.verified-account-field strong{
  color:#fff;
  overflow-wrap:anywhere;
}
.verified-account-field small{
  color:var(--rf-text-muted);
  font-size:.82rem;
}
.checklist-head{
  display:flex;
  align-items:start;
  justify-content:space-between;
  gap:18px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,63,215,.18);
}
.checklist-head strong{
  flex:0 0 auto;
  display:grid;
  place-items:center;
  min-width:58px;
  min-height:42px;
  border-radius:14px;
  color:#160018;
  background:linear-gradient(135deg,var(--yellow),#ff9af0);
  box-shadow:0 0 18px rgba(255,233,79,.45);
  font-weight:1000;
}
.checkline.is-complete{
  border-color:rgba(61,246,184,.42);
  background:rgba(61,246,184,.09);
}
.checkline.is-pending{
  border-color:rgba(255,233,79,.35);
  background:rgba(255,233,79,.06);
}
.checkline span small{
  display:block;
  margin-top:3px;
  color:var(--muted);
  line-height:1.35;
  font-size:.82rem;
}
.checkline input:checked{
  accent-color:var(--good);
}
.checklist-next{
  justify-self:start;
  margin-top:4px;
}
.path-section{
  display:grid;
  gap:12px;
}
.path-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.path-card{
  min-height:250px;
  padding:28px;
  grid-template-columns:minmax(0,1fr) minmax(120px,180px);
  gap:24px;
  align-items:center;
  overflow:hidden;
  background:
    radial-gradient(circle at 82% 36%, rgba(255,63,215,.2), transparent 12rem),
    linear-gradient(135deg, rgba(45,6,72,.82), rgba(8,0,18,.84));
}
.path-card::after{
  content:"";
  position:absolute;
  inset:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
}
.path-copy{
  position:relative;
  z-index:1;
  display:grid;
  gap:12px;
  align-content:center;
}
.path-copy h2{
  margin:0;
  font-size:clamp(1.45rem,2.4vw,2rem);
}
.path-copy p{
  max-width:36rem;
  margin:0 0 6px;
  line-height:1.55;
}
.path-detail-list{
  display:grid;
  gap:10px;
  margin:2px 0 0;
}
.path-detail-list div{
  display:grid;
  gap:4px;
  padding:10px 12px;
  border:1px solid rgba(217,199,236,.14);
  border-radius:12px;
  background:rgba(255,255,255,.035);
}
.path-detail-list dt{
  color:var(--yellow);
  font-size:.68rem;
  font-weight:1000;
  letter-spacing:.08em;
  line-height:1;
  text-transform:uppercase;
}
.path-detail-list dd{
  margin:0;
  color:var(--muted);
  font-size:.9rem;
  line-height:1.45;
}
.path-copy .button{
  justify-self:start;
  margin-top:14px;
}
.path-badge{
  justify-self:start;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid rgba(255,233,79,.45);
  color:var(--yellow);
  background:rgba(255,233,79,.08);
  text-transform:uppercase;
  font-size:.72rem;
  font-weight:1000;
  letter-spacing:.09em;
}
.path-card img{
  position:relative;
  z-index:1;
  max-height:150px;
  justify-self:center;
  filter:drop-shadow(0 0 18px rgba(255,63,215,.72));
}
.path-card.accent-supporter{
  border-color:rgba(0,240,255,.42);
}
.path-card.accent-promoter{
  border-color:rgba(255,233,79,.44);
}
.path-card.accent-exploring{
  border-color:rgba(61,246,184,.34);
}
.path-card.accent-supporter .path-badge{
  color:var(--cyan);
  border-color:rgba(0,240,255,.44);
  background:rgba(0,240,255,.08);
}
.path-card.accent-promoter .path-badge,
.path-card.accent-exploring .path-badge{
  color:var(--yellow);
}
.portal-lock-grid{
  margin-top:14px;
}
.portal-lock-grid .social-button{
  justify-self:start;
}
.footer-divider{
  position:relative;
  display:grid;
  place-items:center;
  margin:34px 0 4px;
  min-height:44px;
  color:var(--yellow);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:1000;
  font-size:.72rem;
  text-shadow:0 0 12px var(--yellow);
}
.footer-divider::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:50%;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,63,215,.5),rgba(255,233,79,.55),rgba(255,63,215,.5),transparent);
}
.footer-divider span{
  position:relative;
  z-index:1;
  padding:8px 14px;
  border:1px solid rgba(255,233,79,.34);
  border-radius:999px;
  background:rgba(8,0,18,.88);
}
.footer{
  margin-top:0;
  align-items:start;
  gap:28px;
}
.footer p,
.footer a{
  line-height:1.65;
}
.footer .newsletter{
  align-self:stretch;
}
.footer .newsletter p{
  max-width:28rem;
}

@media (max-width:980px){
  .path-grid{grid-template-columns:1fr}
  .path-card{min-height:220px}
}
@media (max-width:680px){
  .start-setup,.path-grid{grid-template-columns:1fr}
  .start-setup .form-grid{grid-template-columns:1fr}
  .setup-step{padding:12px}
  .path-card{grid-template-columns:1fr;padding:20px;text-align:left}
  .path-card img{max-height:125px;justify-self:start}
  .footer-divider{margin-top:24px}
}

/* library and levels OS polish */
.library-page,
.levels-page{
  gap:30px;
}
.library-hero{
  border-color:rgba(0,240,255,.5);
  background:
    radial-gradient(circle at 82% 22%, rgba(0,240,255,.14), transparent 18rem),
    linear-gradient(135deg, rgba(15,4,42,.9), rgba(5,0,18,.82));
}
.library-hero .eyebrow,
.library-guide-card.accent-cyan h2{
  color:var(--rf-cyan);
  text-shadow:0 0 14px rgba(0,240,255,.42);
}
.library-hero img{
  filter:drop-shadow(0 0 22px rgba(0,240,255,.55));
}
.library-guide-grid,
.level-loop-grid{
  align-items:stretch;
}
.library-guide-card,
.level-loop-card{
  min-height:178px;
  display:grid;
  align-content:start;
  gap:10px;
  padding:20px;
}
.library-guide-card h2,
.level-loop-card h2{
  margin:.1rem 0 0;
  color:var(--rf-text);
  font-size:clamp(1.25rem,2vw,1.65rem);
}
.library-guide-card p,
.level-loop-card p{
  margin:0;
  color:var(--rf-text-muted);
  line-height:1.55;
}
.library-control-panel{
  display:grid;
  gap:16px;
  border-color:rgba(0,240,255,.38);
  background:
    radial-gradient(circle at 88% 12%, rgba(0,240,255,.08), transparent 18rem),
    linear-gradient(180deg, rgba(20,4,46,.86), rgba(7,0,20,.82));
}
.library-control-panel .toolbar{
  margin:2px 0 0;
}
.library-page .library-strip{
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
}
.library-card{
  position:relative;
  min-height:360px;
  display:grid;
  grid-template-rows:150px 1fr;
  border-color:rgba(0,240,255,.28);
  background:linear-gradient(180deg, rgba(13,4,33,.88), rgba(5,0,16,.84));
}
.library-card.is-open{
  box-shadow:0 18px 38px rgba(0,0,0,.32), inset 0 0 0 1px rgba(0,240,255,.08);
}
.library-card.is-locked{
  border-color:rgba(255,159,67,.38);
  background:linear-gradient(180deg, rgba(25,7,39,.86), rgba(8,1,18,.88));
}
.library-card.is-locked::after{
  content:"LOCKED";
  position:absolute;
  top:14px;
  right:14px;
  z-index:2;
  padding:6px 9px;
  border:1px solid rgba(255,233,79,.38);
  border-radius:999px;
  background:rgba(18,7,31,.78);
  color:var(--rf-yellow);
  font-size:.68rem;
  font-weight:1000;
  letter-spacing:.08em;
}
.library-card.is-locked .library-art img{
  filter:blur(2px) saturate(.62) drop-shadow(0 0 12px rgba(255,159,67,.35));
  opacity:.62;
}
.library-card.is-locked .library-art::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:repeating-linear-gradient(135deg, rgba(255,233,79,.08) 0 2px, transparent 2px 12px);
  pointer-events:none;
}
.library-art{
  position:relative;
  height:150px;
  background:radial-gradient(circle at 50% 30%, rgba(0,240,255,.14), transparent 62%),linear-gradient(135deg,#17063b,#070014);
}
.library-art img{
  height:132px;
  filter:drop-shadow(0 0 16px rgba(0,240,255,.5));
}
.library-card .body{
  display:grid;
  align-content:start;
  gap:10px;
  padding:16px;
}
.library-card h3{
  color:var(--rf-text);
  text-transform:uppercase;
  line-height:1.1;
}
.library-card p{
  color:var(--rf-text-muted);
  line-height:1.48;
}
.library-card .access-note{
  margin-top:2px;
  color:var(--rf-cyan);
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.library-card.is-locked .access-note{
  color:var(--rf-yellow);
}
.library-card .small-button{
  justify-self:start;
  margin-top:auto;
}
.levels-hero{
  border-color:rgba(203,255,46,.46);
  background:
    radial-gradient(circle at 82% 20%, rgba(203,255,46,.11), transparent 18rem),
    linear-gradient(135deg, rgba(14,35,7,.36), rgba(8,0,20,.86));
}
.levels-hero .eyebrow,
.levels-page .section-title .spark{
  color:var(--rf-lime);
  text-shadow:0 0 14px rgba(203,255,46,.42);
}
.levels-hero img{
  filter:drop-shadow(0 0 22px rgba(203,255,46,.42));
}
.level-control-panel{
  border-color:rgba(203,255,46,.42);
  background:
    radial-gradient(circle at 90% 15%, rgba(203,255,46,.1), transparent 17rem),
    linear-gradient(180deg, rgba(18,38,8,.24), rgba(9,0,22,.86));
}
.levels-page .level-badge{
  border-color:var(--rf-lime);
  box-shadow:0 0 28px rgba(203,255,46,.34), inset 0 0 24px rgba(203,255,46,.08);
}
.level-status-copy{
  display:grid;
  gap:14px;
  align-content:center;
}
.level-status-copy h2{
  margin:0;
  color:var(--rf-lime);
}
.level-bar i{
  background:linear-gradient(90deg,var(--rf-lime),var(--rf-cyan));
  box-shadow:0 0 14px rgba(203,255,46,.58);
}
.level-status-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.level-status-grid span{
  min-height:86px;
  display:grid;
  align-content:center;
  gap:3px;
  padding:12px;
  border:1px solid rgba(203,255,46,.22);
  border-radius:var(--rf-radius-sm);
  background:rgba(203,255,46,.06);
}
.level-status-grid b{
  color:var(--rf-text);
  text-transform:uppercase;
}
.level-status-grid small{
  color:var(--rf-text-muted);
  line-height:1.35;
}
.level-loop-card.accent-lime{
  border-color:rgba(203,255,46,.42);
}
.level-loop-card.accent-cyan{
  border-color:rgba(0,240,255,.38);
}
.level-loop-card.accent-yellow{
  border-color:rgba(255,233,79,.42);
}
.level-milestone-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.level-milestone{
  min-height:174px;
  display:grid;
  grid-template-columns:76px 1fr;
  gap:14px;
  align-items:start;
  padding:18px;
  border:1px solid rgba(203,255,46,.3);
  border-radius:var(--rf-radius-md);
  background:linear-gradient(180deg, rgba(12,27,8,.28), rgba(255,255,255,.025));
  box-shadow:var(--rf-shadow-panel);
}
.level-milestone.is-locked{
  border-color:rgba(217,199,236,.16);
  background:linear-gradient(180deg, rgba(69,38,96,.18), rgba(255,255,255,.02));
}
.level-milestone.is-locked h3,
.level-milestone.is-locked p{
  filter:blur(.45px);
}
.level-number{
  width:66px;
  height:66px;
  display:grid;
  place-items:center;
  border:1px solid rgba(203,255,46,.38);
  border-radius:18px;
  color:var(--rf-lime);
  background:rgba(203,255,46,.07);
  font-size:1.45rem;
  font-weight:1000;
  box-shadow:0 0 18px rgba(203,255,46,.2);
}
.level-milestone.is-locked .level-number{
  color:var(--rf-text-muted);
  border-color:rgba(217,199,236,.18);
  background:rgba(69,38,96,.22);
  box-shadow:none;
}
.level-milestone h3{
  margin:2px 0 5px;
  color:var(--rf-text);
  line-height:1.18;
}
.level-milestone p{
  margin:0;
  color:var(--rf-text-muted);
  line-height:1.5;
}

@media (max-width:980px){
  .level-milestone-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:680px){
  .library-control-panel .toolbar{display:grid}
  .library-page .library-strip,
  .level-milestone-grid,
  .level-status-grid{grid-template-columns:1fr}
  .library-card{min-height:unset}
  .level-milestone{grid-template-columns:58px 1fr;padding:15px}
  .level-number{width:52px;height:52px;border-radius:15px}
}


/* portal page */
.portal-page{--portal-hot:#ff38d1;--portal-violet:#8b5cff;--portal-cyan:#00f0ff;}
.portal-hero{
  min-height:560px;
  display:grid;
  grid-template-columns:1fr minmax(300px,520px);
  gap:24px;
  align-items:center;
  padding:32px;
  border-radius:32px;
  overflow:hidden;
  background:
    radial-gradient(circle at 74% 45%, rgba(255,63,215,.32), transparent 24rem),
    radial-gradient(circle at 16% 28%, rgba(0,240,255,.12), transparent 22rem),
    linear-gradient(135deg, rgba(10,0,24,.98), rgba(22,4,48,.9));
}
.portal-hero::after{content:"";position:absolute;inset:14px;border-radius:24px;border:2px solid rgba(255,63,215,.38);box-shadow:inset 0 0 38px rgba(255,63,215,.22);pointer-events:none}
.portal-hero-copy{position:relative;z-index:2;max-width:720px}.portal-hero-copy .hero-title{font-size:clamp(4.5rem,10vw,9rem);text-transform:uppercase;letter-spacing:-.06em}.portal-image-wrap{position:relative;display:grid;place-items:center;min-height:460px;z-index:1}.portal-image-wrap::before{content:"";position:absolute;width:86%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle, rgba(255,63,215,.45), transparent 65%);filter:blur(18px);animation:portalPulse 3.6s ease-in-out infinite}.portal-image{width:min(100%,520px);aspect-ratio:1;object-fit:cover;border-radius:50%;border:2px solid rgba(255,255,255,.45);box-shadow:0 0 28px rgba(255,63,215,.75),0 0 70px rgba(139,92,255,.5);position:relative;z-index:2}.portal-status-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.portal-stat{padding:20px;text-align:center;border-radius:22px}.portal-stat span{display:block;font-size:1.9rem;text-shadow:0 0 18px var(--pink)}.portal-stat strong{display:block;font-size:2.45rem;color:#ff8ee9;text-shadow:0 0 14px var(--pink)}.portal-stat small{text-transform:uppercase;color:var(--muted);font-weight:900;letter-spacing:.08em}.portal-gate-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.portal-card{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:14px;padding:18px;border-radius:22px;min-height:112px;transition:.2s transform,.2s border-color,.2s box-shadow}.portal-card:hover{transform:translateY(-4px) scale(1.01);border-color:rgba(255,255,255,.8);box-shadow:0 0 28px rgba(255,63,215,.45),0 0 55px rgba(139,92,255,.24)}.portal-card-icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg, rgba(255,63,215,.24), rgba(139,92,255,.2));border:1px solid rgba(255,63,215,.5);font-size:1.5rem;text-shadow:0 0 14px var(--pink)}.portal-card b{display:block;text-transform:uppercase;font-size:1.08rem}.portal-card small{display:block;color:var(--muted);line-height:1.35;margin-top:3px}.portal-card i{font-style:normal;color:#fff;font-size:1.5rem;text-shadow:0 0 14px var(--pink)}.portal-console{display:grid;grid-template-columns:1fr minmax(280px,430px);gap:22px;align-items:center;padding:24px;border-radius:26px}.portal-console h2{font-size:clamp(1.7rem,3vw,2.7rem);margin:.2rem 0}.portal-terminal{display:grid;gap:10px;padding:18px;border-radius:20px;background:rgba(5,0,14,.58);border:1px solid rgba(255,63,215,.3);box-shadow:inset 0 0 28px rgba(255,63,215,.12)}.portal-terminal div{display:grid;grid-template-columns:22px 44px 1fr;gap:10px;align-items:center;padding:10px;border-bottom:1px solid rgba(255,63,215,.12)}.portal-terminal div:last-child{border-bottom:0}.portal-terminal b{color:var(--yellow)}@keyframes portalPulse{0%,100%{opacity:.62;transform:scale(.96)}50%{opacity:1;transform:scale(1.04)}}
@media (max-width:980px){.portal-hero,.portal-console{grid-template-columns:1fr}.portal-hero-copy{text-align:center}.portal-image-wrap{min-height:360px}.portal-status-grid,.portal-gate-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.portal-hero{padding:18px;min-height:unset}.portal-hero-copy .hero-title{font-size:3.8rem}.portal-image-wrap{min-height:260px}.portal-image{width:min(100%,320px)}.portal-status-grid,.portal-gate-grid{grid-template-columns:1fr}.portal-card{min-height:96px}}



/* sign-in page */
.signin-page{
  --signin-hot:#ff35ca;
  --signin-cyan:#00eaff;
  --signin-lime:#92ff00;
}
.signin-hero{
  min-height:430px;
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);
  gap:24px;
  align-items:center;
  padding:32px;
  border-radius:32px;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(5,0,10,.92), rgba(17,0,31,.7)),
    url('/assets/foxxoquest-portal/backgrounds/bg-portal-grid-1920x1080.png') center/cover;
}
.signin-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(255,53,202,.16), transparent 42%, rgba(0,234,255,.12));pointer-events:none}
.signin-hero::after{content:"";position:absolute;inset:14px;border:1px solid rgba(255,53,202,.45);box-shadow:inset 0 0 34px rgba(255,53,202,.28),0 0 32px rgba(255,53,202,.16);border-radius:24px;pointer-events:none}.signin-copy{position:relative;z-index:2}.signin-title{font-family:var(--font-display);font-size:clamp(4rem,9vw,8rem);line-height:.84;text-transform:uppercase;margin:.05em 0;background:linear-gradient(90deg,#fff,#ff6fe1 45%,#9bfffb);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-stroke:1.4px #120021;text-shadow:0 0 18px rgba(255,53,202,.72),8px 0 0 rgba(0,234,255,.16)}.signin-art{position:relative;z-index:2;display:grid;place-items:center;min-height:330px}.signin-orb{position:relative;width:min(92%,360px);aspect-ratio:1;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 50% 45%, rgba(255,53,202,.25), transparent 54%),rgba(7,0,20,.65);border:2px solid rgba(255,53,202,.6);box-shadow:0 0 30px rgba(255,53,202,.7),0 0 70px rgba(0,234,255,.18),inset 0 0 42px rgba(255,53,202,.22)}.signin-orb::before{content:"";position:absolute;inset:20px;border-radius:50%;border:1px dashed rgba(0,234,255,.55);box-shadow:0 0 22px rgba(0,234,255,.24)}.signin-orb img{width:72%;height:72%;object-fit:contain;filter:drop-shadow(0 0 18px rgba(255,53,202,.85))}.access-stamp{position:absolute;right:6%;bottom:9%;font-family:var(--font-mono);font-size:1.05rem;text-transform:uppercase;color:var(--signin-lime);border:1px solid currentColor;border-radius:8px;padding:8px 11px;line-height:1.05;background:rgba(4,12,0,.74);box-shadow:0 0 18px rgba(146,255,0,.45);transform:rotate(-4deg)}.signin-already{margin-top:16px;padding:12px 14px;border-radius:16px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}.signin-already span{color:var(--muted)}.signin-layout{display:grid;grid-template-columns:minmax(360px,1fr) minmax(300px,420px);gap:18px}.signin-card{padding:24px;border-radius:26px}.terminal-title{display:flex;justify-content:space-between;gap:12px;margin-bottom:14px;font-family:var(--font-mono);font-size:.86rem;color:var(--signin-hot);text-transform:uppercase;letter-spacing:.08em}.terminal-title b{color:var(--signin-lime);text-shadow:0 0 12px rgba(146,255,0,.65)}.signin-card h2{margin:.2rem 0 8px;font-size:clamp(1.7rem,3vw,2.5rem)}.role-switch{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0}.role-pill{border:1px solid rgba(255,53,202,.4);background:rgba(255,53,202,.06);color:#fff;border-radius:13px;min-height:44px;text-transform:uppercase;font-weight:1000;letter-spacing:.06em;cursor:pointer;box-shadow:inset 0 0 18px rgba(255,53,202,.08)}.role-pill.active{background:linear-gradient(135deg,rgba(255,53,202,.28),rgba(0,234,255,.12));border-color:rgba(255,255,255,.78);box-shadow:0 0 22px rgba(255,53,202,.36),inset 0 0 20px rgba(255,53,202,.2)}.signin-form{display:grid;gap:14px}.signin-form label{display:grid;gap:7px;color:var(--muted);font-weight:900;text-transform:lowercase}.signin-form input{background:rgba(2,0,10,.78);border:1px solid rgba(255,53,202,.42);border-radius:14px;min-height:48px;padding:12px 14px;color:#fff;outline:0}.signin-form input:focus{border-color:rgba(0,234,255,.85);box-shadow:0 0 0 3px rgba(0,234,255,.12),0 0 18px rgba(0,234,255,.22)}.signin-options{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.mini-check{display:flex!important;align-items:center;gap:8px;text-transform:none!important}.mini-check input{width:18px;height:18px;min-height:0;accent-color:var(--signin-hot)}.signin-submit{width:100%;justify-content:center}.auth-divider{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;margin:20px 0 12px;color:var(--muted);font-size:.85rem;text-transform:uppercase;font-weight:900;letter-spacing:.08em}.auth-divider::before,.auth-divider::after{content:"";height:1px;background:linear-gradient(90deg,transparent,rgba(255,53,202,.6),transparent)}.provider-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.provider-button{display:flex;align-items:center;justify-content:center;gap:9px;min-height:46px;border-radius:14px;border:1px solid rgba(0,234,255,.42);background:rgba(0,234,255,.05);color:#fff;font-weight:900;text-transform:lowercase}.provider-button:hover{box-shadow:0 0 18px rgba(0,234,255,.32);border-color:rgba(0,234,255,.8)}.access-stack{display:grid;gap:14px}.mini-terminal{padding:18px;border-radius:22px;background:linear-gradient(135deg, rgba(4,0,12,.92), rgba(15,0,32,.72));box-shadow:inset 0 0 26px rgba(255,53,202,.08)}.mini-terminal h3{font-family:var(--font-mono);text-transform:uppercase;color:var(--signin-hot);letter-spacing:.06em;margin:.1rem 0 12px}.mini-terminal a{display:flex;align-items:center;gap:12px;padding:11px;border-radius:13px;border:1px solid rgba(255,53,202,.18);background:rgba(255,255,255,.03);margin:9px 0;color:#fff;font-weight:900}.mini-terminal a:hover{border-color:rgba(255,53,202,.6);box-shadow:0 0 18px rgba(255,53,202,.24)}.mini-terminal img{width:42px;height:42px;object-fit:contain}.mini-terminal p{font-family:var(--font-mono);line-height:1.55;color:var(--muted)}.green{color:var(--signin-lime)}.pink{color:var(--signin-hot)}.cyan{color:var(--signin-cyan)}.quote-terminal{background:linear-gradient(135deg, rgba(255,53,202,.12), rgba(5,0,14,.92))}.quote-terminal p{font-size:1.15rem;color:#fff}.profile-page .hero-actions .button{margin-top:10px}
@media (max-width:980px){.signin-hero,.signin-layout{grid-template-columns:1fr}.signin-art{min-height:260px}.signin-orb{width:min(82%,300px)}}
@media (max-width:680px){.signin-hero{padding:18px}.signin-title{font-size:3.8rem}.role-switch,.provider-grid,.signin-provider-grid{grid-template-columns:1fr}.signin-options{align-items:flex-start}.terminal-title{flex-direction:column}.signin-card{padding:18px}}

/* Public Microsoft sign-in gateway */
.signin-page{
  --signin-hot:var(--rf-pink);
  --signin-cyan:var(--rf-cyan);
  --signin-lime:var(--rf-lime);
  --signin-panel:rgba(10,0,26,.82);
}
.signin-page .neon-panel{
  border-color:var(--rf-border);
  box-shadow:var(--rf-shadow-panel);
}
.signin-hero{
  min-height:clamp(420px,52vw,560px);
  border-color:rgba(0,240,255,.34);
  background:
    radial-gradient(circle at 78% 42%, rgba(255,63,215,.22), transparent 22rem),
    linear-gradient(90deg, rgba(5,0,10,.94), rgba(17,0,31,.78)),
    url('/assets/foxxoquest-portal/backgrounds/bg-portal-grid-1920x1080.png') center/cover;
}
.signin-hero::after{
  border-color:rgba(0,240,255,.28);
  box-shadow:inset 0 0 30px rgba(0,240,255,.14),0 0 28px rgba(139,92,255,.18);
}
.signin-copy{
  max-width:760px;
}
.signin-title{
  font-size:clamp(3.5rem,8vw,7.8rem);
  letter-spacing:0;
}
.signin-page .tagline{
  max-width:710px;
  color:var(--rf-text);
}
.signin-flow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.signin-flow span{
  display:inline-flex;
  align-items:center;
  gap:9px;
  min-height:42px;
  padding:8px 12px;
  border:1px solid rgba(0,240,255,.32);
  border-radius:999px;
  background:rgba(0,240,255,.06);
  color:#fff;
  font-weight:900;
}
.signin-flow b{
  display:grid;
  place-items:center;
  width:24px;
  height:24px;
  border-radius:50%;
  background:rgba(203,255,46,.16);
  color:var(--rf-lime);
  font-family:var(--font-mono);
}
.signin-layout{
  align-items:start;
}
.signin-card{
  border-color:rgba(0,240,255,.28);
  background:linear-gradient(135deg, rgba(9,0,23,.92), rgba(20,2,42,.78));
}
.signin-card h2{
  color:var(--rf-text);
}
.role-switch{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.role-pill{
  border-color:var(--rf-border);
  background:rgba(139,92,255,.1);
  color:var(--rf-text);
  box-shadow:inset 0 0 18px rgba(139,92,255,.08);
}
.role-pill.active{
  border-color:rgba(0,240,255,.72);
  background:linear-gradient(135deg, rgba(0,240,255,.18), rgba(255,63,215,.12));
  box-shadow:0 0 20px rgba(0,240,255,.24),inset 0 0 18px rgba(0,240,255,.08);
}
.auth-status{
  display:grid;
  gap:5px;
  padding:14px 16px;
  border:1px solid rgba(0,240,255,.32);
  border-radius:16px;
  background:rgba(0,240,255,.07);
  color:var(--rf-text);
  line-height:1.45;
}
.auth-status b{
  color:#fff;
}
.auth-status span{
  color:var(--rf-text-muted);
}
.auth-status.success{
  border-color:rgba(203,255,46,.5);
  background:rgba(203,255,46,.08);
  box-shadow:inset 0 0 22px rgba(203,255,46,.06);
}
.auth-status.success b{
  color:var(--rf-lime);
}
.auth-status.warn{
  border-color:rgba(255,159,67,.58);
  background:rgba(255,159,67,.08);
}
.auth-status.warn b{
  color:var(--rf-warning);
}
.auth-divider::before,
.auth-divider::after{
  background:linear-gradient(90deg,transparent,rgba(0,240,255,.48),transparent);
}
.provider-button{
  border-color:rgba(217,199,236,.22);
  background:rgba(255,255,255,.035);
  text-transform:none;
}
.provider-button span{
  display:grid;
  place-items:center;
  width:30px;
  height:30px;
  border-radius:10px;
  border:1px solid rgba(0,240,255,.36);
  color:var(--rf-cyan);
  font-family:var(--font-mono);
  font-size:.82rem;
}
.provider-button.primary-provider{
  border-color:rgba(0,240,255,.48);
  background:rgba(0,240,255,.08);
}
.signin-provider-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.provider-status-card{
  min-height:78px;
  display:grid;
  gap:4px;
  align-content:center;
  padding:12px;
  border:1px solid rgba(217,199,236,.22);
  border-radius:14px;
  background:rgba(255,255,255,.035);
}
.provider-status-card b{
  color:#fff;
  text-transform:uppercase;
}
.provider-status-card span{
  color:var(--rf-text-muted);
  font-size:.88rem;
  line-height:1.25;
}
.provider-status-card.is-active{
  border-color:rgba(0,240,255,.58);
  background:rgba(0,240,255,.08);
  box-shadow:0 0 18px rgba(0,240,255,.18);
}
.provider-status-card.is-active span{
  color:#d8fbff;
}
.mini-terminal{
  border-color:var(--rf-border);
  background:linear-gradient(135deg, rgba(4,0,12,.94), rgba(15,0,32,.76));
}
.mini-terminal h3{
  color:var(--rf-cyan);
}
.mini-terminal a{
  border-color:rgba(217,199,236,.17);
}
.quote-terminal{
  border-color:rgba(255,233,79,.26);
  background:linear-gradient(135deg, rgba(255,233,79,.08), rgba(5,0,14,.92));
}
.compact-actions{
  margin-top:14px;
  gap:10px;
}
.compact-actions .small-button{
  justify-content:center;
}
.signin-simple-hero{
  min-height:clamp(520px,64vw,720px);
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,470px);
  gap:26px;
  align-items:center;
  padding:clamp(22px,4vw,44px);
  border-radius:32px;
  overflow:hidden;
  background:
    radial-gradient(circle at 74% 28%, rgba(0,240,255,.18), transparent 18rem),
    radial-gradient(circle at 22% 72%, rgba(255,63,215,.24), transparent 20rem),
    linear-gradient(90deg, rgba(5,0,14,.94), rgba(20,2,42,.78)),
    url('/assets/foxxoquest-portal/backgrounds/bg-portal-grid-1920x1080.png') center/cover;
}
.signin-simple-hero::after{
  content:"";
  position:absolute;
  inset:14px;
  border:1px solid rgba(0,240,255,.32);
  border-radius:24px;
  box-shadow:inset 0 0 34px rgba(255,63,215,.18),0 0 28px rgba(0,240,255,.16);
  pointer-events:none;
}
.signin-simple-hero .signin-copy,
.signin-simple-card{
  position:relative;
  z-index:1;
}
.signin-simple-card{
  padding:clamp(20px,3vw,30px);
  border-color:rgba(0,240,255,.44);
  background:linear-gradient(145deg, rgba(8,0,22,.96), rgba(35,4,58,.86));
  box-shadow:0 0 28px rgba(0,240,255,.18),0 0 44px rgba(255,63,215,.18),inset 0 0 26px rgba(255,63,215,.08);
}
.signin-simple-card h2{
  margin:.25rem 0 14px;
  font-size:clamp(1.6rem,3vw,2.35rem);
  text-transform:uppercase;
}
.signin-primary-action{
  min-height:62px;
  margin-top:12px;
  font-size:1.05rem;
  border-radius:18px;
  box-shadow:0 0 24px rgba(0,240,255,.36),0 0 30px rgba(255,63,215,.22);
}
.signin-primary-action:disabled{
  cursor:not-allowed;
  opacity:.76;
  color:var(--rf-text-muted);
  border-color:rgba(217,199,236,.24);
  background:linear-gradient(135deg, rgba(69,38,96,.28), rgba(0,240,255,.04));
  box-shadow:inset 0 0 18px rgba(255,255,255,.04);
}
.member-login-form{
  display:grid;
  gap:12px;
}
.signin-member-actions{
  display:grid;
  gap:12px;
}
.signup-primary-button{
  background:linear-gradient(135deg, rgba(255,63,215,.92), rgba(0,240,255,.62));
  border-color:rgba(255,255,255,.78);
  box-shadow:0 0 28px rgba(255,63,215,.54),0 0 34px rgba(0,240,255,.28),inset 0 0 20px rgba(255,255,255,.16);
}
.credential-login-disabled input:disabled{
  opacity:.62;
  cursor:not-allowed;
  border-color:rgba(217,199,236,.22);
  background:rgba(20,10,32,.58);
}
.credential-login-disabled .signin-primary-action{
  border-color:rgba(255,63,215,.62);
}
.signup-prompt{
  margin:0;
  text-align:center;
  color:var(--rf-text-muted);
  font-weight:900;
  text-transform:lowercase;
}
.signup-prompt a{
  color:var(--rf-cyan);
  text-decoration:underline;
  text-underline-offset:4px;
  text-shadow:0 0 12px rgba(0,240,255,.42);
}
.signin-member-panel{
  display:grid;
  gap:12px;
}
.signin-other-options,
.signin-crew-fold{
  border:1px solid rgba(217,199,236,.16);
  border-radius:16px;
  padding:10px 12px;
  background:rgba(255,255,255,.035);
}
.signin-other-options summary,
.signin-crew-fold summary{
  cursor:pointer;
  color:#fff;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.signin-option-links{
  display:grid;
  gap:9px;
  margin-top:10px;
}
.signin-crew-fold p{
  margin:9px 0;
  color:var(--rf-text-muted);
}
.signin-flow-strip{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.public-mission-snapshot{
  padding:clamp(18px,3vw,26px);
}
.public-mission-snapshot h2{
  margin:.1rem 0 8px;
  font-size:clamp(1.65rem,4vw,2.7rem);
}
.public-mission-snapshot p:not(.eyebrow){
  max-width:760px;
  margin:0;
  color:var(--rf-text-muted);
  font-size:clamp(1rem,1.9vw,1.22rem);
  line-height:1.45;
}
.public-how-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.public-how-strip article{
  min-height:92px;
  display:grid;
  align-content:center;
  gap:5px;
  padding:14px;
  border-radius:16px;
}
.public-how-strip b{
  color:#fff;
  text-transform:uppercase;
  font-size:.96rem;
}
.public-how-strip span{
  color:var(--rf-text-muted);
  line-height:1.3;
}
.google-provider-button{
  min-height:52px;
  border-radius:16px;
}
.signin-admin-link{
  margin-top:2px;
  justify-content:center;
  border-color:rgba(255,233,79,.36);
  color:var(--rf-yellow);
}
.signin-helper-text{
  margin:12px 0 0;
  color:var(--rf-text-muted);
  line-height:1.5;
}
.signin-action-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-top:12px;
}
.signin-action-grid .small-button{
  justify-content:center;
}
.signin-next-steps{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.signin-next-steps article{
  min-height:108px;
  display:grid;
  align-content:center;
  gap:6px;
  padding:18px;
}
.signin-next-steps b{
  color:#fff;
  text-transform:uppercase;
}
.signin-next-steps span{
  color:var(--rf-text-muted);
  line-height:1.42;
}
@media (max-width:680px){
  .signin-title{
    font-size:clamp(2.8rem,17vw,4.2rem);
  }
  .signin-flow,
  .provider-grid,
  .signin-provider-grid,
  .compact-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .signin-submit,
  .provider-button,
  .compact-actions .small-button{
    width:100%;
  }
}
@media (max-width:860px){
  .signin-simple-hero,
  .signin-next-steps{
    grid-template-columns:1fr;
  }
}
@media (max-width:520px){
  .signin-simple-hero{
    min-height:auto;
    padding:18px;
  }
  .signin-primary-action{
    min-height:58px;
  }
}

.hero-body{
  margin:14px 0 0;
  max-width:760px;
  color:var(--rf-text-muted);
  font-size:1.02rem;
  line-height:1.62;
}

.portal-command-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,360px);
  gap:18px;
}
.portal-command-main{min-width:0}
.portal-command-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.portal-command-tile{
  min-height:112px;
  display:grid;
  grid-template-columns:58px 1fr;
  align-items:center;
  gap:13px;
  padding:14px;
  border:1px solid var(--rf-border);
  border-radius:var(--rf-radius-md);
  background:rgba(255,255,255,.045);
  box-shadow:var(--rf-shadow-panel);
}
.portal-command-tile:hover,
.portal-command-tile:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.7);
}
.portal-command-tile img{
  width:54px;
  height:54px;
  object-fit:contain;
  filter:drop-shadow(0 0 12px rgba(255,63,215,.42));
}
.portal-command-tile b{
  display:block;
  color:#fff;
  text-transform:uppercase;
  font-size:.96rem;
}
.portal-command-tile small{
  display:block;
  color:var(--rf-text-muted);
  line-height:1.35;
  margin-top:3px;
}
.portal-command-tile.accent-cyan{border-color:rgba(0,240,255,.35)}
.portal-command-tile.accent-lime{border-color:rgba(203,255,46,.35)}
.portal-command-tile.accent-yellow{border-color:rgba(255,233,79,.35)}
.portal-command-tile.accent-purple{border-color:rgba(139,92,255,.45)}
.portal-command-side{
  display:grid;
  gap:14px;
  align-content:start;
}
.portal-status-line{
  display:flex;
  gap:10px;
  align-items:center;
  padding:10px 0;
  border-bottom:1px solid rgba(217,199,236,.14);
}
.portal-status-line:last-child{border-bottom:0}
.portal-lock-summary p,
.portal-feature-strip p{
  color:var(--rf-text-muted);
  line-height:1.55;
}

.access-choice-grid{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:10px;
  min-width:0;
  margin:0;
  padding:14px;
  border:1px solid rgba(255,233,79,.35);
  border-radius:var(--rf-radius-md);
  background:rgba(255,233,79,.055);
}
.goal-choice-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:10px;
  margin:0;
  padding:0;
  border:0;
}
.access-choice-grid legend{
  padding:0 6px;
  color:var(--rf-yellow);
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.goal-choice-grid legend{
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
}
.access-choice-grid label{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:10px;
  min-height:104px;
  border:1px solid rgba(217,199,236,.16);
  border-radius:12px;
  background:rgba(255,255,255,.035);
}
.goal-choice-grid label{
  display:flex;
  gap:10px;
  align-items:flex-start;
  min-height:86px;
  padding:12px;
  border:1px solid rgba(0,240,255,.22);
  border-radius:14px;
  background:rgba(0,240,255,.04);
  cursor:pointer;
  transition:.16s transform,.16s border-color,.16s background,.16s box-shadow;
}
.access-choice-grid label:has(input:checked),
.goal-choice-grid label:has(input:checked){
  border-color:rgba(203,255,46,.72);
  background:linear-gradient(135deg, rgba(203,255,46,.13), rgba(0,240,255,.055));
  box-shadow:0 0 18px rgba(203,255,46,.18), inset 0 0 18px rgba(203,255,46,.06);
}
.goal-choice-grid label:hover,
.goal-choice-grid label:focus-within,
.access-choice-grid label:hover,
.access-choice-grid label:focus-within{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.5);
}
.access-choice-grid input{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color:var(--rf-yellow);
}
.goal-choice-grid input{
  width:19px;
  height:19px;
  margin-top:2px;
  accent-color:var(--rf-lime);
}
.goal-choice-grid b,
.access-choice-grid b{
  display:block;
  color:#fff;
}
.access-choice-grid small{
  display:block;
  color:var(--rf-text-muted);
  line-height:1.3;
  margin-top:3px;
}
.goal-choice-grid small{
  display:block;
  margin-top:4px;
  color:var(--rf-text-muted);
  line-height:1.35;
}
.optional-note{
  display:grid;
  gap:7px;
  color:var(--rf-text-muted);
  font-weight:900;
}
.optional-note input{
  width:100%;
  min-height:46px;
  border:1px solid rgba(255,63,215,.42);
  border-radius:12px;
  padding:12px;
  color:#fff;
  background:rgba(8,1,18,.7);
}
.setup-form input[readonly]{
  background:rgba(8,1,18,.58);
}
.setup-form input[readonly]{
  color:var(--rf-text-muted);
  border-style:dashed;
}
.profile-approval-note{
  margin-top:14px;
  padding:12px 14px;
  border:1px solid rgba(255,233,79,.34);
  border-radius:var(--rf-radius-md);
  background:rgba(255,233,79,.07);
  display:grid;
  gap:4px;
}
.profile-approval-note.is-ready{
  border-color:rgba(203,255,46,.42);
  background:rgba(203,255,46,.08);
}
.profile-approval-note span{color:var(--rf-text-muted)}
.provider-coming-soon{
  opacity:.74;
  border-color:rgba(217,199,236,.24)!important;
  background:rgba(69,38,96,.22)!important;
  cursor:not-allowed;
}

.approval-board,
.notification-layout,
.message-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:16px;
}
.approval-card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.approval-flow-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.approval-flow-grid>div,
.message-recipient-note{
  padding:14px;
  border:1px solid rgba(255,63,215,.22);
  border-radius:var(--rf-radius-md);
  background:rgba(255,255,255,.045);
}
.approval-flow-grid b,
.message-recipient-note b{
  display:block;
  color:#fff;
  text-transform:uppercase;
}
.approval-card,
.approval-lane,
.notification-item,
.message-card{
  padding:14px;
  border:1px solid rgba(217,199,236,.18);
  border-radius:var(--rf-radius-md);
  background:rgba(255,255,255,.045);
  box-shadow:var(--rf-shadow-panel);
}
.approval-card.is-ready,
.approval-summary.is-ready{
  border-color:rgba(203,255,46,.42);
  background:rgba(203,255,46,.07);
}
.approval-status{
  display:inline-grid;
  place-items:center;
  min-height:28px;
  padding:4px 9px;
  border-radius:999px;
  color:var(--rf-yellow);
  border:1px solid rgba(255,233,79,.38);
  background:rgba(255,233,79,.08);
  font-size:.78rem;
  font-weight:1000;
  text-transform:uppercase;
}
.approval-card h3,
.message-card h3{
  margin:.7rem 0 .35rem;
  color:#fff;
  text-transform:uppercase;
}
.approval-lane{
  display:grid;
  grid-template-columns:minmax(120px,.35fr) 1fr;
  gap:12px;
  align-items:start;
  margin-top:10px;
}
.approval-lane b{color:#fff;text-transform:uppercase}
.approval-lane span,
.notification-item p,
.message-card p,
.privacy-rules-card p,
.message-recipient-note span{
  color:var(--rf-text-muted);
  line-height:1.5;
  margin:.25rem 0 0;
}
.approval-action-bar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:10px;
}
.approval-action-bar button{
  min-height:32px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(217,199,236,.2);
  background:rgba(255,255,255,.06);
  color:var(--rf-text-muted);
  font-weight:900;
  text-transform:lowercase;
}
.notification-layout,
.message-layout{
  grid-template-columns:minmax(0,1fr) minmax(320px,430px);
  align-items:start;
}
.message-layout .privacy-rules-card,
.message-layout .message-service-card,
.notification-layout .notification-routing-card{
  grid-column:1 / -1;
}
.notification-list,
.message-list{
  display:grid;
  gap:10px;
}
.notification-item{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:12px;
}
.notification-item>span{
  color:var(--rf-cyan);
  font-weight:1000;
  text-transform:uppercase;
}
.messages-page textarea,
.notifications-page input,
.notifications-page select,
.messages-page input,
.messages-page select,
.messages-page textarea{
  width:100%;
  min-height:46px;
  background:rgba(8,1,18,.7);
  border:1px solid rgba(255,63,215,.42);
  border-radius:12px;
  padding:12px;
  color:#fff;
}
.messages-page textarea{min-height:130px;resize:vertical}
.notifications-page form>label,
.messages-page form>label{
  display:grid;
  gap:7px;
  color:var(--rf-text-muted);
  font-weight:800;
  margin-top:12px;
}
.alert-trigger-list{
  display:grid;
  gap:8px;
  margin:14px 0;
}
.message-recipient-note{
  margin:12px 0;
  border-color:rgba(0,240,255,.3);
  background:rgba(0,240,255,.06);
}

@media (max-width:900px){
  .portal-command-layout,
  .portal-command-grid,
  .approval-flow-grid,
  .notification-layout,
  .message-layout,
  .approval-lane{
    grid-template-columns:1fr;
  }
}

/* Foxxo Quest keyboard focus ring. Keep this late so it beats older outline resets. */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible,
[tabindex]:not([tabindex="-1"]):focus-visible{
  outline:3px solid var(--rf-cyan)!important;
  outline-offset:3px!important;
  box-shadow:0 0 0 5px rgba(0,240,255,.14),0 0 24px rgba(0,240,255,.3)!important;
}

.site-search:focus-within{
  outline:3px solid var(--rf-cyan);
  outline-offset:3px;
  box-shadow:0 0 0 5px rgba(0,240,255,.14),0 0 24px rgba(0,240,255,.3),inset 0 0 16px rgba(255,63,215,.14)!important;
}
.site-search input:focus,
.site-search input:focus-visible,
.site-search button:focus,
.site-search button:focus-visible{
  outline:0!important;
  box-shadow:none!important;
}

/* Foxxo Quest dashboard skin */
:root{
  --fq-dash-pink:#ff21b8;
  --fq-dash-purple:#963bff;
  --fq-dash-blue:#00ceff;
  --fq-dash-lime:#c3ff00;
  --fq-dash-yellow:#ffdd2f;
  --fq-dash-panel:rgba(7,0,18,.78);
}
body{
  background:
    linear-gradient(180deg, rgba(5,0,12,.62), rgba(5,0,12,.84) 54%, rgba(5,0,12,.96)),
    url("/assets/foxxo-quest/dashboard/backgrounds/fq_page_background_starfield_1920x1080.png") center top / cover no-repeat fixed,
    linear-gradient(180deg,#05000c,#10001f 52%,#05000c)!important;
}
.sparkle-layer{opacity:.42}
.topbar{
  min-height:76px;
  border-radius:0 0 18px 18px;
  background:
    linear-gradient(180deg, rgba(67,11,63,.76), rgba(14,0,32,.78)),
    rgba(7,0,18,.72);
  border-color:rgba(255,33,184,.62);
}
.brand-logo{
  width:clamp(165px,18vw,270px);
  max-height:76px;
  filter:drop-shadow(0 0 14px rgba(255,33,184,.86)) drop-shadow(0 0 22px rgba(0,206,255,.3));
}
.nav-icon-img{
  width:24px;
  height:24px;
  object-fit:contain;
  filter:drop-shadow(0 0 8px rgba(255,33,184,.86));
}
.main-nav a{
  border:1px solid transparent;
  text-shadow:0 2px 0 rgba(0,0,0,.72),0 0 10px rgba(255,255,255,.28);
}
.main-nav a:hover,
.main-nav a[aria-current="page"]{
  border-color:rgba(255,33,184,.42);
  background:rgba(255,33,184,.13);
}
.dashboard-hero{
  min-height:auto;
  grid-template-columns:1fr;
  gap:10px;
  padding:18px 18px 24px;
  border-radius:28px;
  background:
    radial-gradient(circle at 16% 32%, rgba(255,33,184,.2), transparent 26rem),
    radial-gradient(circle at 82% 24%, rgba(0,206,255,.16), transparent 24rem),
    rgba(5,0,14,.72);
}
.dashboard-hero::after{inset:10px;border-radius:24px}
.dashboard-hero-stage{
  display:grid;
  place-items:center;
  position:relative;
  z-index:1;
  overflow:visible;
  padding:10px 18px 30px;
  margin-bottom:-14px;
  isolation:isolate;
}
.dashboard-hero-stage::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:13px;
  width:min(82%,900px);
  height:60px;
  transform:translateX(-50%);
  border-radius:999px;
  background:
    radial-gradient(ellipse at center, rgba(255,33,184,.5), rgba(0,206,255,.18) 48%, transparent 74%);
  filter:blur(18px);
  opacity:.9;
  z-index:0;
  pointer-events:none;
}
.dashboard-hero-stage img{
  position:relative;
  z-index:1;
  width:min(100%,1120px);
  max-height:360px;
  object-fit:contain;
  overflow:visible;
  filter:
    drop-shadow(0 0 18px rgba(255,33,184,.75))
    drop-shadow(0 14px 24px rgba(255,33,184,.42))
    drop-shadow(0 0 28px rgba(0,206,255,.25));
}
.dashboard-hero-copy{
  position:relative;
  z-index:1;
  width:min(100%,920px);
  margin:-12px auto 0;
  text-align:center;
}
.dashboard-hero .hero-title{
  font-size:clamp(2.5rem,7vw,5.5rem);
  letter-spacing:0;
}
.dashboard-hero .hero-meta-line{
  display:inline-flex;
  gap:10px;
  justify-content:center;
  align-items:center;
  margin:0 auto 8px;
  color:#f6eaff;
  letter-spacing:.12em;
  line-height:1.2;
  text-shadow:0 0 10px rgba(255,63,215,.38);
}
.dashboard-hero .hero-meta-line small{
  padding:3px 8px;
  border:1px solid rgba(169,255,31,.34);
  border-radius:999px;
  color:#dfff88;
  background:rgba(169,255,31,.07);
  box-shadow:0 0 8px rgba(169,255,31,.12);
  font-size:.66rem;
  letter-spacing:.08em;
  white-space:nowrap;
}
.dashboard-hero .tagline{
  margin-top:12px;
  font-size:clamp(1.05rem,2vw,1.45rem);
  font-weight:1000;
}
.dashboard-hero .hero-body{
  margin:10px auto 0;
  max-width:760px;
}
.dashboard-hero .hero-actions{
  justify-content:center;
  margin-top:18px;
}
.dashboard-upload-lane .hero-actions .button,
.dashboard-hero .hero-actions .button{
  min-height:52px;
  border-radius:999px;
  padding:13px 24px;
  border-width:2px;
}
.dashboard-button{
  min-height:52px;
  border-radius:999px;
  padding:13px 24px;
  border:2px solid rgba(255,255,255,.72);
  box-shadow:0 0 0 3px rgba(255,33,184,.25),0 0 18px rgba(255,33,184,.65),inset 0 0 16px rgba(255,255,255,.18);
}
.dashboard-button.pink{background:linear-gradient(90deg,#ff21b8,#a54cff)}
.dashboard-button.cyan{background:linear-gradient(90deg,#824cff,#00ceff)}
.dashboard-rail{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  padding:18px 20px;
  border:1px solid rgba(255,33,184,.72);
  border-radius:22px;
  background:
    linear-gradient(rgba(5,0,14,.82),rgba(5,0,14,.82)),
    url("/assets/foxxo-quest/dashboard/ui/fq_nav_panel_frame_1440x132.png") center / 100% 100% no-repeat;
  box-shadow:0 0 24px rgba(255,33,184,.42),0 0 40px rgba(0,206,255,.14);
}
.dashboard-rail-item{
  display:grid;
  justify-items:center;
  gap:4px;
  min-height:104px;
  padding:10px 8px;
  border-radius:16px;
  border:1px solid transparent;
  text-align:center;
  transition:.18s transform,.18s border-color,.18s background;
}
.dashboard-rail-item:hover,
.dashboard-rail-item:focus-visible{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.56);
  background:rgba(255,255,255,.06);
}
.dashboard-rail-item img{
  width:48px;
  height:48px;
  object-fit:contain;
  filter:drop-shadow(0 0 10px rgba(255,33,184,.82));
}
.dashboard-rail-item span{
  font-weight:1000;
  text-transform:uppercase;
  font-size:.78rem;
  text-shadow:0 0 8px rgba(255,33,184,.72),0 2px 0 #000;
}
.dashboard-rail-item small{
  color:var(--muted);
  font-size:.68rem;
  line-height:1.25;
}
.dashboard-drop-section{
  display:grid;
  grid-template-columns:250px 1fr 230px;
  gap:18px;
  align-items:stretch;
}
.dashboard-drop-copy,
.dashboard-mini-card,
.dashboard-drop-card{
  position:relative;
  border:1px solid rgba(255,33,184,.58);
  border-radius:18px;
  background:rgba(5,0,14,.78);
  box-shadow:0 0 18px rgba(255,33,184,.3),inset 0 0 0 1px rgba(255,255,255,.05);
  overflow:hidden;
}
.dashboard-drop-copy{
  padding:18px;
}
.dashboard-drop-copy h2,
.dashboard-gallery-title h2,
.dashboard-section-title h2{
  margin:.2rem 0 .65rem;
  font-size:clamp(1.65rem,3vw,2.4rem);
  line-height:.95;
  text-transform:uppercase;
  text-shadow:0 0 14px rgba(255,33,184,.68),2px 2px 0 #000;
}
.dashboard-drop-copy p{
  color:var(--muted);
  line-height:1.5;
}
.dashboard-drop-cards{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.dashboard-drop-card{
  min-height:210px;
  display:grid;
  align-content:end;
  justify-items:start;
  padding:16px;
  background-size:100% 100%;
  background-position:center;
  background-repeat:no-repeat;
}
.dashboard-drop-card.frame-pink{background-image:linear-gradient(rgba(5,0,14,.55),rgba(5,0,14,.55)),url("/assets/foxxo-quest/dashboard/ui/fq_product_card_frame_only_pink_420x260.png")}
.dashboard-drop-card.frame-lime{background-image:linear-gradient(rgba(5,0,14,.55),rgba(5,0,14,.55)),url("/assets/foxxo-quest/dashboard/ui/fq_product_card_frame_only_lime_420x260.png")}
.dashboard-drop-card.frame-blue{background-image:linear-gradient(rgba(5,0,14,.55),rgba(5,0,14,.55)),url("/assets/foxxo-quest/dashboard/ui/fq_product_card_frame_only_blue_420x260.png")}
.dashboard-drop-card img{
  position:absolute;
  top:36px;
  left:50%;
  width:92px;
  height:92px;
  object-fit:contain;
  transform:translateX(-50%);
  filter:drop-shadow(0 0 12px rgba(255,33,184,.85));
}
.dashboard-card-badge{
  position:absolute;
  top:12px;
  left:14px;
  padding:5px 9px;
  border-radius:8px;
  background:linear-gradient(90deg,#ff21b8,#963bff);
  border:1px solid rgba(255,255,255,.66);
  font-size:.68rem;
  font-weight:1000;
  text-transform:uppercase;
}
.dashboard-drop-card b{
  position:relative;
  z-index:1;
  display:block;
  text-transform:uppercase;
  font-size:1rem;
}
.dashboard-drop-card small{
  position:relative;
  z-index:1;
  margin-top:6px;
  color:var(--muted);
  line-height:1.35;
}
.dashboard-upload-lane{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);
  gap:18px;
  align-items:stretch;
  padding:20px;
  border:1px solid rgba(0,206,255,.46);
  border-radius:24px;
  background:
    radial-gradient(circle at 14% 26%, rgba(255,33,184,.16), transparent 18rem),
    radial-gradient(circle at 86% 80%, rgba(195,255,0,.1), transparent 16rem),
    rgba(5,0,14,.78);
  box-shadow:0 0 24px rgba(0,206,255,.18),0 0 34px rgba(255,33,184,.18),inset 0 0 0 1px rgba(255,255,255,.04);
}
.dashboard-upload-copy{
  display:grid;
  align-content:center;
  gap:10px;
  padding:8px;
}
.dashboard-upload-copy h2{
  margin:.1rem 0;
  font-size:clamp(2rem,5vw,3.8rem);
  line-height:.92;
  text-transform:uppercase;
  text-shadow:0 0 18px rgba(255,33,184,.72),2px 2px 0 #000;
}
.dashboard-upload-copy p{
  max-width:680px;
  margin:0;
  color:var(--muted);
  line-height:1.55;
}
.dashboard-upload-steps{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.dashboard-upload-steps article{
  display:grid;
  grid-template-columns:48px 1fr;
  gap:4px 12px;
  align-content:center;
  min-height:96px;
  padding:14px;
  border:1px solid rgba(255,33,184,.34);
  border-radius:16px;
  background:
    linear-gradient(135deg, rgba(255,33,184,.08), rgba(0,206,255,.055)),
    rgba(255,255,255,.035);
}
.dashboard-upload-steps span{
  grid-row:1 / span 2;
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(135deg,#ff21b8,#00ceff);
  color:#120020;
  font-family:var(--font-mono);
  font-weight:1000;
  box-shadow:0 0 18px rgba(0,206,255,.3);
}
.dashboard-upload-steps b{
  color:#fff;
  text-transform:uppercase;
}
.dashboard-upload-steps small{
  color:var(--muted);
  line-height:1.35;
}
.dashboard-mini-card{
  display:grid;
  align-content:center;
  justify-items:center;
  gap:8px;
  padding:18px;
  text-align:center;
}
.dashboard-mini-card span{
  font-weight:1000;
  text-transform:uppercase;
  color:#fff;
}
.dashboard-mini-card img{
  width:94px;
  height:94px;
  object-fit:contain;
  filter:drop-shadow(0 0 12px rgba(195,255,0,.6));
}
.dashboard-mini-card p{
  margin:0;
  color:var(--muted);
  line-height:1.4;
}
.dashboard-vibe-section,
.dashboard-gallery{
  display:grid;
  grid-template-columns:210px 1fr;
  gap:14px;
  align-items:center;
}
.dashboard-section-title,
.dashboard-gallery-title{
  min-height:112px;
  display:grid;
  align-content:center;
  padding:14px;
}
.dashboard-vibe-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.dashboard-vibe-tile{
  display:grid;
  grid-template-rows:92px auto;
  border-radius:14px;
  border:1px solid rgba(255,33,184,.46);
  background:rgba(5,0,14,.72);
  overflow:hidden;
  box-shadow:0 0 16px rgba(255,33,184,.2);
  transition:.16s transform,.16s border-color,.16s box-shadow;
}
.dashboard-vibe-tile:hover,
.dashboard-vibe-tile:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.68);
  box-shadow:0 0 22px rgba(255,33,184,.34),0 0 24px rgba(0,206,255,.14);
}
.dashboard-vibe-tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
}
.dashboard-vibe-tile span{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:58px;
  padding:10px 12px;
  border-top:1px solid rgba(255,255,255,.1);
  background:linear-gradient(135deg, rgba(255,33,184,.12), rgba(0,206,255,.06));
}
.dashboard-vibe-tile b{
  color:#fff;
  text-transform:uppercase;
  font-size:.86rem;
  line-height:1.1;
  text-shadow:0 0 10px rgba(255,33,184,.65);
}
.dashboard-vibe-tile small{
  flex:0 0 auto;
  min-height:28px;
  display:grid;
  place-items:center;
  padding:5px 10px;
  border:1px solid rgba(203,255,46,.48);
  border-radius:999px;
  color:var(--rf-lime);
  background:rgba(203,255,46,.08);
  font-weight:1000;
  text-transform:uppercase;
  font-size:.66rem;
  line-height:1;
  box-shadow:0 0 12px rgba(203,255,46,.2);
}
.dashboard-gallery{
  padding:16px;
  border:1px solid rgba(255,33,184,.66);
  border-radius:20px;
  background:
    linear-gradient(rgba(5,0,14,.82),rgba(5,0,14,.82)),
    url("/assets/foxxo-quest/dashboard/ui/fq_gallery_strip_frame_1440x112.png") center / 100% 100% no-repeat;
}
.dashboard-gallery-strip{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:12px;
}
.dashboard-gallery-strip span{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:1px solid rgba(255,33,184,.42);
  border-radius:14px;
  background:rgba(255,255,255,.04);
  text-align:center;
}
.dashboard-gallery-strip img{
  width:42px;
  height:42px;
  object-fit:contain;
}
.dashboard-gallery-strip b{
  font-size:.78rem;
  text-transform:uppercase;
}
.footer .mini-brand img{
  content:url("/assets/foxxo-quest/dashboard/category_icons/png_256/fq_category_fox_face_icon_256.png");
}
.footer .newsletter{
  background:
    linear-gradient(rgba(5,0,14,.78),rgba(5,0,14,.78)),
    url("/assets/foxxo-quest/dashboard/ui/fq_newsletter_frame_1440x120.png") center / 100% 100% no-repeat;
}
.admin-help-desk{
  padding:22px;
}
.admin-help-grid{
  display:grid;
  grid-template-columns:minmax(260px,.9fr) minmax(320px,1.1fr);
  gap:18px;
  margin-top:16px;
}
.help-request-types{
  display:grid;
  gap:10px;
}
.admin-help-form{
  display:grid;
  gap:12px;
}
.admin-help-form label{
  display:grid;
  gap:7px;
  color:var(--muted);
  font-weight:900;
}
.admin-help-form input,
.admin-help-form select,
.admin-help-form textarea{
  width:100%;
  border:1px solid rgba(255,63,215,.42);
  border-radius:12px;
  background:rgba(8,1,18,.78);
  color:#fff;
  padding:12px;
  resize:vertical;
}
@media (max-width:1120px){
  .dashboard-rail{grid-template-columns:repeat(4,minmax(0,1fr))}
  .dashboard-drop-section{grid-template-columns:1fr}
  .dashboard-upload-lane{grid-template-columns:1fr}
  .dashboard-drop-cards{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:820px){
  .dashboard-hero{padding:12px}
  .dashboard-hero-copy{margin-top:0}
  .dashboard-hero-stage{
    padding:8px 8px 24px;
    margin-bottom:-10px;
  }
  .dashboard-hero-stage::after{
    bottom:9px;
    height:48px;
  }
  .dashboard-hero-stage img{max-height:245px}
  .dashboard-rail{grid-template-columns:repeat(2,minmax(0,1fr));padding:12px}
  .dashboard-drop-cards,
  .dashboard-vibe-grid,
  .dashboard-gallery-strip,
  .admin-help-grid{grid-template-columns:1fr}
  .dashboard-vibe-section,
  .dashboard-gallery{grid-template-columns:1fr}
  .dashboard-section-title,
  .dashboard-gallery-title{min-height:auto}
}
@media (max-width:520px){
  .brand-logo{width:150px}
  .dashboard-rail-item{min-height:94px}
  .dashboard-drop-card{min-height:190px}
  .dashboard-vibe-tile{grid-template-rows:84px auto}
  .dashboard-vibe-tile span{align-items:flex-start;flex-direction:column}
  .dashboard-vibe-tile small{width:100%}
}

/* Final title override: match Access Portal title style */
.beta-badge{
  display:inline-flex;
  align-items:center;
  width:max-content;
  margin:12px auto 0;
  padding:7px 12px;
  border:1px solid rgba(203,255,46,.7);
  border-radius:999px;
  color:#cbff2e;
  background:rgba(12,22,0,.48);
  box-shadow:0 0 14px rgba(203,255,46,.42), inset 0 0 14px rgba(203,255,46,.08);
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.72rem;
}
.eyebrow,
.page-hero .eyebrow,
.signin-copy .eyebrow,
.dashboard-hero-copy .eyebrow{
  color:#a9ff1f;
  letter-spacing:.18em;
  text-shadow:0 0 10px rgba(169,255,31,.9),0 0 22px rgba(169,255,31,.38);
}
.hero-title,
.page-hero h1,
.signin-title,
.game-portal-title{
  background:none!important;
  -webkit-background-clip:initial!important;
  background-clip:initial!important;
  color:#fff!important;
  -webkit-text-stroke:1.35px #230039;
  text-shadow:
    3px 0 0 rgba(0,223,255,.9),
    -3px 0 0 rgba(255,42,211,.88),
    0 3px 0 rgba(255,42,211,.32),
    0 0 18px rgba(255,42,211,.78),
    0 0 34px rgba(0,223,255,.32);
  letter-spacing:.02em!important;
}
.page-hero h1,
.signin-title{
  line-height:.9;
}


.signup-flow-tracker{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}
.signup-flow-tracker span{
  min-height:34px;
  display:grid;
  place-items:center;
  padding:7px 12px;
  border:1px solid rgba(217,199,236,.22);
  border-radius:999px;
  color:var(--rf-text-muted);
  background:rgba(255,255,255,.045);
  font-weight:1000;
  text-transform:uppercase;
  font-size:.72rem;
  letter-spacing:.05em;
}
.signup-flow-tracker span.is-active{
  color:var(--rf-lime);
  border-color:rgba(203,255,46,.56);
  background:rgba(203,255,46,.09);
  box-shadow:0 0 16px rgba(203,255,46,.2);
}
.setup-email-note{
  display:grid;
  gap:4px;
  min-height:72px;
  padding:12px;
  border:1px dashed rgba(0,240,255,.45);
  border-radius:12px;
  background:rgba(0,240,255,.055);
}
.setup-email-note b,
.setup-account-step b,
.signup-public-note b{
  color:#fff;
  text-transform:uppercase;
}
.setup-email-note span,
.signup-public-note span{
  color:var(--rf-text-muted);
  line-height:1.42;
}
.setup-form label small{
  display:block;
  margin-top:4px;
  color:var(--rf-text-muted);
  line-height:1.35;
  text-transform:none;
  font-weight:700;
}
.signup-account-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.signup-account-actions .small-button{
  justify-content:center;
}
.signup-public-note{
  margin-top:18px;
}
.signup-public-note article{
  min-height:112px;
  display:grid;
  align-content:center;
  gap:6px;
  padding:18px;
}
.level-up-strip{
  display:grid;
  grid-template-columns:minmax(220px,420px) 1fr;
  align-items:center;
  gap:18px;
  padding:16px 20px;
  overflow:visible;
}
.level-up-strip img{
  width:100%;
  max-height:150px;
  object-fit:contain;
  filter:drop-shadow(0 0 10px rgba(255,63,215,.32));
}
.level-up-strip h2{
  margin:.1rem 0 6px;
  font-size:clamp(1.35rem,2.8vw,2.05rem);
}
.level-up-strip p:not(.eyebrow){
  margin:0;
  color:var(--rf-text-muted);
  line-height:1.45;
}
.signin-member-actions .small-button{
  justify-content:center;
}
@media (max-width:720px){
  .level-up-strip{
    grid-template-columns:1fr;
    text-align:center;
  }
  .level-up-strip img{
    max-height:112px;
  }
  .signup-flow-tracker span,
  .signup-account-actions .small-button{
    width:100%;
  }
}

.setup-form .setup-step:first-of-type{
  gap:10px;
  padding:12px;
}
.setup-form .setup-step:first-of-type .form-grid{
  align-items:end;
  grid-template-columns:minmax(0,1fr) minmax(240px,.82fr);
  gap:12px;
}
.setup-form .setup-step:first-of-type label{
  gap:6px;
  font-size:.9rem;
}
.setup-form .setup-step:first-of-type .form-grid input,
.setup-form .setup-step:first-of-type .form-grid select{
  min-height:46px;
  padding:10px 12px;
  border-radius:12px;
  font-size:1rem;
  line-height:1.2;
}
.setup-form .setup-step:first-of-type .setup-email-note{
  min-height:0;
  align-self:end;
  padding:10px 12px;
  border-radius:12px;
}
.setup-form .setup-step:first-of-type .setup-email-note b{
  font-size:.86rem;
  line-height:1.1;
}
.setup-form .setup-step:first-of-type .setup-email-note span{
  font-size:.9rem;
  line-height:1.35;
}
.setup-form .setup-step:first-of-type .setup-step-head{
  grid-template-columns:34px minmax(0,1fr);
}
.setup-form .setup-step:first-of-type .setup-step-head>span{
  width:32px;
  height:32px;
}
.setup-form .setup-step:first-of-type .setup-step-head p{
  font-size:.95rem;
  line-height:1.35;
  max-width:820px;
}
@media (max-width:760px){
  .setup-form .setup-step:first-of-type .form-grid{
    grid-template-columns:1fr;
  }
}

.auth-modal-shell{
  position:fixed;
  inset:0;
  z-index:120;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.auth-modal-shell.is-open{
  display:flex;
}
.auth-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(6,0,16,.76);
  backdrop-filter:blur(10px);
}
.auth-modal{
  position:relative;
  z-index:1;
  width:min(560px,100%);
  max-height:min(720px,calc(100vh - 34px));
  overflow:auto;
  padding:22px;
  border-radius:22px;
  background:
    linear-gradient(135deg, rgba(61,7,84,.94), rgba(9,0,22,.96)),
    url("/assets/foxxo-quest/dashboard/backgrounds/fq_page_background_starfield_1920x1080.png") center / cover;
  box-shadow:0 0 46px rgba(255,63,215,.44),0 0 34px rgba(0,240,255,.16),inset 0 0 28px rgba(255,255,255,.05);
}
.auth-modal-close{
  position:absolute;
  top:12px;
  right:12px;
  width:38px;
  height:38px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-weight:1000;
  text-transform:uppercase;
  cursor:pointer;
}
.auth-modal-head{
  display:grid;
  gap:8px;
  padding-right:38px;
}
.auth-modal-head h2{
  margin:0;
  color:#fff;
  font-family:var(--font-display);
  font-size:clamp(2rem,7vw,3.4rem);
  line-height:.92;
  text-transform:uppercase;
  -webkit-text-stroke:1px #230039;
  text-shadow:2px 0 0 rgba(0,223,255,.9),-2px 0 0 rgba(255,42,211,.86),0 0 18px rgba(255,42,211,.72);
}
.auth-modal-head p:not(.eyebrow),
.auth-modal-note span,
.auth-modal-crew p{
  margin:0;
  color:var(--rf-text-muted);
  line-height:1.45;
}
.auth-modal-actions{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.auth-modal-actions .button,
.auth-modal-actions .small-button{
  width:100%;
  justify-content:center;
}
.auth-choice-card{
  display:grid;
  grid-template-columns:52px minmax(0,1fr);
  align-items:center;
  gap:14px;
  width:100%;
  padding:14px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:18px;
  text-decoration:none;
  background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(12,0,26,.42));
  box-shadow:inset 0 0 18px rgba(255,255,255,.04);
  transition:.16s transform,.16s border-color,.16s box-shadow,.16s filter;
}
.auth-choice-card b{
  display:block;
  color:#fff;
  text-transform:uppercase;
  letter-spacing:.02em;
  font-size:1rem;
  line-height:1.1;
}
.auth-choice-card small{
  display:block;
  margin-top:4px;
  color:var(--rf-text-muted);
  line-height:1.35;
  font-weight:800;
  text-transform:none;
}
.auth-choice-icon{
  width:52px;
  height:52px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.2);
  font-weight:1000;
  color:#fff;
  box-shadow:inset 0 0 16px rgba(255,255,255,.06);
}
.auth-choice-icon img{
  width:34px;
  height:34px;
  object-fit:contain;
}
.auth-choice-card.is-primary{
  border-color:rgba(255,63,215,.72);
  background:linear-gradient(135deg, rgba(255,63,215,.5), rgba(0,240,255,.18));
  box-shadow:0 0 24px rgba(255,63,215,.34), inset 0 0 18px rgba(255,255,255,.08);
}
.auth-choice-card.is-google{
  border-color:rgba(0,240,255,.58);
}
.auth-choice-card.is-secondary{
  border-color:rgba(255,233,79,.5);
  background:linear-gradient(135deg, rgba(255,233,79,.14), rgba(255,63,215,.09));
}
.auth-choice-card:hover,
.auth-choice-card:focus-visible{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.72);
  filter:brightness(1.08);
}
.auth-modal-note{
  display:grid;
  gap:4px;
  margin-top:14px;
  padding:12px;
  border:1px dashed rgba(0,240,255,.4);
  border-radius:14px;
  background:rgba(0,240,255,.055);
}
.auth-modal-note b{
  color:#fff;
  text-transform:uppercase;
}
.auth-modal-crew{
  margin-top:14px;
  padding:12px;
  border:1px solid rgba(255,233,79,.28);
  border-radius:14px;
  background:rgba(255,233,79,.045);
}
.auth-modal-crew summary{
  color:var(--rf-yellow);
  font-weight:1000;
  text-transform:uppercase;
  cursor:pointer;
}
.auth-modal-open{
  overflow:hidden;
}

@media (min-width:1121px){
  .topbar.is-simple-public-header{
    grid-template-columns:minmax(220px,360px) minmax(300px,520px) minmax(220px,320px) auto;
  }
  .main-nav.is-simple-public-nav{
    justify-self:center;
    width:100%;
    max-width:520px;
    gap:10px;
  }
  .main-nav.is-simple-public-nav a{
    min-height:62px;
    border-radius:20px;
    padding:10px 14px 9px;
  }
  .topbar.is-simple-public-header .site-search{
    opacity:.82;
  }
}

.footer{
  grid-template-columns:minmax(220px,1.15fr) repeat(3,minmax(120px,.65fr)) minmax(260px,1fr);
}
.footer>form.newsletter{
  min-width:0;
}
@media (max-width:1100px){
  .footer{
    grid-template-columns:1fr 1fr;
    align-items:start;
  }
  .footer>form.newsletter{
    grid-column:1 / -1;
  }
}
@media (max-width:640px){
  .footer{
    grid-template-columns:1fr;
    padding:18px;
    gap:18px;
  }
  .footer .newsletter{
    width:100%;
  }
.footer .newsletter .inline{
    flex-direction:column;
  }
}

/* FOX QUESTR public page scale tuned to the coming-soon mock */
.fox-questr-launch-preview{
  gap:22px;
}
.fox-questr-launch-preview article{
  min-height:124px;
  padding:18px 22px;
}
.fox-questr-launch-preview b{
  font-size:clamp(1.12rem,1.55vw,1.65rem);
  line-height:1;
}
.fox-questr-launch-preview span{
  font-size:clamp(.86rem,1vw,1rem);
  line-height:1.35;
}
.public-how-strip b{
  font-size:.88rem;
  line-height:1.05;
}
.public-how-strip span{
  font-size:.82rem;
}
.footer-divider{
  font-size:.64rem;
}
.footer{
  gap:22px;
}
.footer h3{
  font-size:.76rem;
  margin-bottom:8px;
  line-height:1.15;
}
.footer p,
.footer a{
  font-size:.84rem;
  line-height:1.45;
}
.footer .brand-title{
  font-size:1.2rem;
}
.footer .mini-brand img{
  width:54px;
}
.footer .newsletter p{
  max-width:24rem;
}

@media (max-width:820px){
  .signin-simple-hero{
    grid-template-columns:1fr;
    padding:22px;
  }
  .signin-next-steps{
    grid-template-columns:1fr;
    gap:12px;
  }
}

/* Glow tuning: keep the neon mood, let the artwork breathe. */
.brand-logo{
  filter:drop-shadow(0 0 8px rgba(255,33,184,.48)) drop-shadow(0 0 10px rgba(0,206,255,.16))!important;
}
.brand-mascot,
.nav-icon-img{
  filter:drop-shadow(0 0 5px rgba(255,33,184,.46))!important;
}
.hero-art::before{
  opacity:.42;
  filter:blur(6px);
}
.hero-art img{
  filter:drop-shadow(0 0 10px rgba(255,63,215,.44)) drop-shadow(0 0 18px rgba(139,92,255,.26))!important;
}
.welcome-card img,
.page-hero img,
.profile-card img,
.library-art img,
.signin-orb img,
.dashboard-drop-card img,
.dashboard-mini-card img{
  filter:drop-shadow(0 0 8px rgba(255,63,215,.34))!important;
}
.dashboard-mini-card img{
  filter:drop-shadow(0 0 8px rgba(195,255,0,.28))!important;
}
.dashboard-hero-stage::after{
  bottom:-2px;
  width:min(96%,1040px);
  height:96px;
  opacity:.38;
  filter:blur(30px);
  background:
    radial-gradient(ellipse at center, rgba(255,33,184,.42), rgba(0,206,255,.16) 50%, transparent 78%);
}
.dashboard-hero-stage img{
  filter:
    drop-shadow(0 0 10px rgba(255,33,184,.42))
    drop-shadow(0 16px 34px rgba(255,33,184,.18))
    drop-shadow(0 0 14px rgba(0,206,255,.14))!important;
}
.portal-image-wrap::before{
  opacity:.38;
  filter:blur(12px);
}
.portal-image{
  box-shadow:0 0 18px rgba(255,63,215,.42),0 0 34px rgba(139,92,255,.24)!important;
}
.auth-modal{
  box-shadow:0 0 30px rgba(255,63,215,.28),0 0 22px rgba(0,240,255,.1),inset 0 0 22px rgba(255,255,255,.04);
}
