: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)}
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-supporter-command-banner.png") center top / min(100vw, 1920px) auto 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}
.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%}
.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);
  }
}
@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);
}
.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)}
@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}
  .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:18px;
  align-content:start;
}
.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));
}
.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 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}
  .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{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);
}
.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;
}
@media (max-width:680px){
  .signin-title{
    font-size:clamp(2.8rem,17vw,4.2rem);
  }
  .signin-flow,
  .provider-grid,
  .compact-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .signin-submit,
  .provider-button,
  .compact-actions .small-button{
    width:100%;
  }
}

.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(185px,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);
}
.access-choice-grid legend{
  padding:0 6px;
  color:var(--rf-yellow);
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.access-choice-grid label{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:10px;
  border:1px solid rgba(217,199,236,.16);
  border-radius:12px;
  background:rgba(255,255,255,.035);
}
.access-choice-grid input{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color:var(--rf-yellow);
}
.access-choice-grid small{
  display:block;
  color:var(--rf-text-muted);
  line-height:1.3;
  margin-top:3px;
}
.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;
}
