@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700;800;900&family=Cinzel+Decorative:wght@400;700;900&family=Lato:ital,wght@0,300;0,400;0,700;1,300;1,400&display=swap');

:root {
  --bg:      #06030a;
  --bg1:     #0d0810;
  --bg2:     #120c18;
  --bg3:     #1a1020;
  --crimson: #8b0000;
  --red:     #c41e3a;
  --redL:    #e63950;
  --gold:    #c9a84c;
  --goldL:   #f0d080;
  --goldD:   #8a6a1f;
  --silver:  #c0c8d8;
  --b:       rgba(201,168,76,.12);
  --bHi:     rgba(201,168,76,.3);
  --txt:     #f0e8d8;
  --sub:     #7a6a55;
  --dim:     #2a1a2e;
  --r:14px;--rs:8px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Lato',sans-serif;
  background:var(--bg);color:var(--txt);
  min-height:100vh;overflow-x:hidden;
}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--crimson);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--red)}

/* ─── BG ─────────────────────────────────────────────── */
.bg-wrap{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}

.bg-fog{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 120% 60% at 50% 0%,   rgba(139,0,0,.18) 0%,transparent 60%),
    radial-gradient(ellipse 80%  80% at 0%   100%, rgba(100,0,80,.12)  0%,transparent 60%),
    radial-gradient(ellipse 60%  60% at 100% 50%,  rgba(80,0,100,.08) 0%,transparent 60%);
}

.bg-stars{position:absolute;inset:0}

.bg-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 100% 100% at 50% 50%, transparent 40%, rgba(0,0,0,.8) 100%);
}

/* ─── Sparks canvas ──────────────────────────────────── */
#sparks{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.7}

/* ─── Ornament lines ─────────────────────────────────── */
.orn-line{
  position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),var(--goldL),var(--gold),transparent);
  opacity:.25;
}

/* ─── NAV ────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  height:64px;display:flex;align-items:center;
  background:rgba(6,3,10,.92);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--b);
}
.nav::after{
  content:'';position:absolute;bottom:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.3;
}
.nav-in{max-width:1280px;margin:0 auto;padding:0 32px;width:100%;display:flex;align-items:center;gap:14px}

.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--txt)}
.logo-crest{
  width:38px;height:38px;border-radius:50%;
  background:radial-gradient(circle,#3a0a0a,#1a0000);
  border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel Decorative',serif;font-size:.75rem;font-weight:900;
  color:var(--gold);
  box-shadow:0 0 16px rgba(201,168,76,.3), inset 0 0 8px rgba(201,168,76,.1);
}
.logo-txt{
  font-family:'Cinzel',serif;font-size:.9rem;font-weight:700;
  color:var(--goldL);letter-spacing:.06em;
}
.nsp{flex:1}
.nav-r{display:flex;align-items:center;gap:10px}

/* ─── BUTTONS ────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 22px;border-radius:6px;
  font-family:'Cinzel',serif;font-size:.75rem;font-weight:600;
  cursor:pointer;border:none;text-decoration:none;
  transition:all .2s;white-space:nowrap;letter-spacing:.06em;
  position:relative;overflow:hidden;
}
.btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.08),transparent);
  opacity:0;transition:opacity .2s;
}
.btn:hover::before{opacity:1}

.btn-gold{
  background:linear-gradient(135deg,var(--crimson),#5a0010);
  color:var(--gold);
  border:1px solid var(--goldD);
  box-shadow:0 0 12px rgba(139,0,0,.4);
}
.btn-gold:hover{border-color:var(--gold);box-shadow:0 0 20px rgba(201,168,76,.3);transform:translateY(-1px)}

.btn-dc{background:#5865f2;color:#fff;font-family:'Lato',sans-serif;font-size:.82rem}
.btn-dc:hover{background:#4752c4;transform:translateY(-1px);box-shadow:0 6px 20px rgba(88,101,242,.4)}

.btn-ghost{
  background:transparent;
  color:var(--gold);
  border:1px solid var(--b);
  font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.06em;
}
.btn-ghost:hover{border-color:var(--bHi);background:rgba(201,168,76,.06)}

.btn-out{
  background:transparent;color:var(--sub);
  border:1px solid rgba(255,255,255,.07);
  font-family:'Lato',sans-serif;font-size:.82rem;
}
.btn-out:hover{color:var(--txt);border-color:rgba(255,255,255,.15)}

/* ─── HERO ───────────────────────────────────────────── */
.hero{
  position:relative;z-index:1;
  padding:110px 32px 60px;
  max-width:1280px;margin:0 auto;
  text-align:center;
}

.hero-sigil{
  display:inline-flex;align-items:center;gap:14px;
  margin-bottom:32px;
  animation:fadeUp .6s ease both;
}
.hero-sigil-line{width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.hero-sigil-text{
  font-family:'Cinzel',serif;font-size:.68rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
}

.hero-h1{
  font-family:'Cinzel Decorative',serif;
  font-size:clamp(2.5rem,7vw,6.5rem);
  font-weight:900;line-height:.9;letter-spacing:-.01em;
  margin-bottom:12px;
  animation:fadeUp .6s .1s ease both;
}
.hero-h1-main{
  display:block;
  background:linear-gradient(180deg,#ffffff 0%,#f0e8d8 40%,var(--goldL) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  text-shadow:none;
  filter:drop-shadow(0 0 40px rgba(201,168,76,.3));
}
.hero-h1-sub{
  display:block;
  font-size:.45em;letter-spacing:.15em;
  background:linear-gradient(135deg,var(--gold),var(--goldL),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-top:12px;
}

.hero-scroll{
  width:60px;height:4px;border-radius:2px;
  background:linear-gradient(90deg,var(--crimson),var(--red));
  margin:0 auto 16px;
  box-shadow:0 0 12px rgba(196,30,58,.5);
  animation:fadeUp .6s .15s ease both;
}

.hero-p{
  font-size:1rem;color:var(--sub);line-height:1.8;
  max-width:520px;margin:0 auto;font-style:italic;
  animation:fadeUp .6s .2s ease both;
}

/* ─── CREST divider ──────────────────────────────────── */
.crest-div{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:20px;
  max-width:1280px;margin:48px auto;padding:0 32px;
}
.crest-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--b),transparent)}
.crest-sym{
  display:flex;align-items:center;gap:8px;
  font-family:'Cinzel',serif;font-size:.65rem;font-weight:700;
  letter-spacing:.2em;color:var(--gold);text-transform:uppercase;
}
.crest-diamond{
  width:8px;height:8px;background:var(--gold);
  transform:rotate(45deg);
  box-shadow:0 0 8px rgba(201,168,76,.5);
}

/* ─── STATS ──────────────────────────────────────────── */
.stats-wrap{position:relative;z-index:1;max-width:1280px;margin:0 auto 56px;padding:0 32px}
.stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));
  background:var(--bg1);
  border:1px solid var(--b);
  border-radius:var(--r);overflow:hidden;
  position:relative;
}
.stats::before,.stats::after{
  content:'';position:absolute;
  left:16px;right:16px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.2;
}
.stats::before{top:0}.stats::after{bottom:0}

.stat{
  padding:24px 16px;text-align:center;
  border-right:1px solid var(--b);
  position:relative;
}
.stat:last-child{border-right:none}
.stat-n{
  font-family:'Cinzel Decorative',serif;
  font-size:2.2rem;line-height:1;
  color:var(--goldL);
  text-shadow:0 0 20px rgba(201,168,76,.4);
}
.stat-l{
  font-family:'Cinzel',serif;
  font-size:.55rem;color:var(--sub);
  margin-top:6px;letter-spacing:.12em;text-transform:uppercase;
}

/* ─── SECTION ────────────────────────────────────────── */
.section{position:relative;z-index:1;max-width:1280px;margin:0 auto;padding:0 32px 80px}

/* ─── FILTER TABS ────────────────────────────────────── */
.tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:40px}
.tab{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 18px;border-radius:4px;
  font-family:'Cinzel',serif;font-size:.65rem;font-weight:600;cursor:pointer;
  background:transparent;border:1px solid var(--b);color:var(--sub);
  transition:all .2s;letter-spacing:.08em;text-transform:uppercase;
}
.tab:hover{border-color:var(--bHi);color:var(--gold)}
.tab.on{
  background:linear-gradient(135deg,rgba(139,0,0,.4),rgba(80,0,0,.2));
  border-color:var(--goldD);color:var(--gold);
  box-shadow:0 0 12px rgba(201,168,76,.1);
}
.tdot{width:6px;height:6px;border-radius:50%;box-shadow:0 0 4px currentColor}

/* ─── GRADE BLOCK ────────────────────────────────────── */
.gblock{margin-bottom:52px}
.ghdr{
  display:flex;align-items:center;gap:14px;
  margin-bottom:22px;padding:14px 20px;
  background:linear-gradient(135deg,rgba(139,0,0,.2),transparent);
  border:1px solid var(--b);border-radius:8px;
  position:relative;overflow:hidden;
}
.ghdr::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--gc,var(--gold)),transparent);
}
.ghdr::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--gc,var(--gold)),transparent);
  opacity:.4;
}
.gico{font-size:1.3rem}
.gname{
  font-family:'Cinzel',serif;font-size:.85rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--gc,var(--gold));
}
.gcnt{
  margin-left:auto;
  font-family:'Cinzel',serif;font-size:.62rem;color:var(--sub);
  background:rgba(0,0,0,.3);border:1px solid var(--b);
  padding:3px 12px;border-radius:4px;letter-spacing:.06em;
}

/* ─── GRID ───────────────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}

/* ─── CARD ───────────────────────────────────────────── */
.card{
  background:var(--bg1);
  border:1px solid var(--b);
  border-radius:var(--r);
  padding:28px 16px 20px;
  display:flex;flex-direction:column;align-items:center;gap:11px;
  cursor:pointer;text-decoration:none;color:inherit;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
  --gc:#c9a84c;
}
/* corner ornaments */
.card::before,.card::after{
  content:'';position:absolute;
  width:16px;height:16px;
  border-color:var(--gc);border-style:solid;
  opacity:0;transition:opacity .3s;
}
.card::before{top:6px;left:6px;border-width:1px 0 0 1px}
.card::after{bottom:6px;right:6px;border-width:0 1px 1px 0}
.card:hover{
  border-color:var(--gc);
  background:var(--bg2);
  transform:translateY(-5px);
  box-shadow:
    0 16px 48px rgba(0,0,0,.6),
    0 0 0 1px var(--b),
    0 0 30px color-mix(in srgb,var(--gc) 8%,transparent);
}
.card:hover::before,.card:hover::after{opacity:.5}

/* magic shimmer */
.card-shim{
  position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 40%,rgba(201,168,76,.04) 50%,transparent 60%);
  transform:translateX(-100%);transition:none;
}
.card:hover .card-shim{transform:translateX(200%);transition:transform .7s ease}

.cav{position:relative;width:72px;height:72px;flex-shrink:0}
.cav img{
  width:72px;height:72px;border-radius:50%;
  border:2px solid var(--b);object-fit:cover;
  transition:all .3s;
}
.card:hover .cav img{
  border-color:var(--gc);
  box-shadow:0 0 20px color-mix(in srgb,var(--gc) 30%,transparent);
}
.cav-rune{
  position:absolute;inset:-7px;border-radius:50%;
  border:1px solid var(--gc);opacity:0;
  transition:opacity .3s;
  animation:runespin 8s linear infinite;
  background:conic-gradient(from 0deg,transparent 0%,transparent 75%,var(--gc) 85%,transparent 100%);
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 1.5px),#000 0);
}
.card:hover .cav-rune{opacity:.6}
@keyframes runespin{to{transform:rotate(360deg)}}

.cname{
  font-family:'Cinzel',serif;font-weight:700;font-size:.85rem;
  text-align:center;line-height:1.3;letter-spacing:.02em;
  color:var(--txt);
}
.cnick{font-size:.68rem;color:var(--sub);margin-top:-5px;text-align:center;font-style:italic}

.ctag{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 12px;border-radius:4px;
  font-family:'Cinzel',serif;font-size:.6rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  background:color-mix(in srgb,var(--gc) 12%,transparent);
  color:var(--gc);
  border:1px solid color-mix(in srgb,var(--gc) 28%,transparent);
}

.cbg{
  margin-top:6px;
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:4px;
  font-family:'Cinzel',serif;font-size:.55rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  background:rgba(201,168,76,.08);
  color:var(--gold);
  border:1px solid rgba(201,168,76,.25);
}

/* ─── DRAWER ─────────────────────────────────────────── */
.ov{
  position:fixed;inset:0;background:rgba(0,0,0,.8);
  backdrop-filter:blur(16px);z-index:500;
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;transition:all .25s;
}
.ov.on{opacity:1;visibility:visible}
.drawer{
  background:linear-gradient(160deg,#100810,#080510);
  border:1px solid var(--b);
  border-radius:16px;max-width:460px;width:100%;
  padding:36px;position:relative;overflow:hidden;
  transform:translateY(28px) scale(.96);
  transition:transform .28s cubic-bezier(.34,1.2,.64,1);
  box-shadow:0 40px 100px rgba(0,0,0,.9),0 0 60px rgba(139,0,0,.15);
}
.ov.on .drawer{transform:none}
/* ornate top border */
.drawer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--goldD),var(--gold),var(--goldL),var(--gold),var(--goldD),transparent);
}
.drawer::after{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%,rgba(139,0,0,.12),transparent),
    radial-gradient(ellipse 60% 60% at 0% 100%,rgba(80,0,60,.06),transparent);
  pointer-events:none;
}

.dx{
  position:absolute;top:14px;right:14px;z-index:1;
  width:30px;height:30px;border-radius:50%;
  background:rgba(201,168,76,.08);border:1px solid var(--b);
  color:var(--sub);cursor:pointer;display:flex;align-items:center;
  justify-content:center;font-size:.85rem;transition:all .2s;
}
.dx:hover{background:rgba(201,168,76,.15);color:var(--gold)}

.dh{display:flex;gap:18px;align-items:center;margin-bottom:28px;position:relative;z-index:1}
.dh img{
  width:76px;height:76px;border-radius:50%;
  border:2px solid var(--gc,var(--gold));
  box-shadow:0 0 24px color-mix(in srgb,var(--gc,var(--gold)) 30%,transparent),
             inset 0 0 8px rgba(0,0,0,.5);
}
.dname{
  font-family:'Cinzel',serif;font-size:1.2rem;font-weight:700;
  color:var(--txt);letter-spacing:.04em;
}
.dnick{font-size:.75rem;color:var(--sub);margin-top:4px;font-style:italic}
.drows{position:relative;z-index:1}
.drow{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;border-bottom:1px solid var(--b);font-size:.85rem;
}
.drow:last-child{border:none}
.dl{color:var(--sub);font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.08em;text-transform:uppercase}
.dv{font-weight:700;color:var(--txt)}
.dlink{
  color:var(--gold);text-decoration:none;font-weight:700;
  display:flex;align-items:center;gap:5px;font-size:.82rem;
  font-family:'Cinzel',serif;letter-spacing:.04em;
  transition:all .2s;
}
.dlink:hover{color:var(--goldL);text-shadow:0 0 8px rgba(201,168,76,.4)}
.dbio{
  margin-top:18px;padding:16px;
  background:rgba(201,168,76,.04);
  border:1px solid var(--b);border-radius:8px;
  font-size:.85rem;color:var(--sub);line-height:1.75;font-style:italic;
  position:relative;z-index:1;
}

/* ─── LOGIN ──────────────────────────────────────────── */
.login{
  max-width:400px;margin:0 auto 52px;
  background:linear-gradient(160deg,var(--bg1),var(--bg));
  border:1px solid var(--b);border-radius:var(--r);
  padding:44px 36px;text-align:center;position:relative;overflow:hidden;
}
.login::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.4;
}
.login-ico{font-size:3rem;display:block;margin-bottom:20px;
  filter:drop-shadow(0 0 20px rgba(201,168,76,.4))}
.login-t{
  font-family:'Cinzel Decorative',serif;font-size:1.2rem;
  color:var(--goldL);margin-bottom:12px;letter-spacing:.04em;
}
.login-s{font-size:.88rem;color:var(--sub);line-height:1.75;margin-bottom:28px;font-style:italic}

/* ─── USER PILL ──────────────────────────────────────── */
.upill{
  display:flex;align-items:center;gap:8px;
  background:rgba(201,168,76,.06);
  border:1px solid var(--b);border-radius:8px;
  padding:5px 14px 5px 5px;
}
.upill img{width:26px;height:26px;border-radius:50%;border:1px solid var(--goldD)}
.upill span{
  font-family:'Cinzel',serif;font-size:.72rem;font-weight:600;
  color:var(--gold);letter-spacing:.04em;
}

/* ─── ALERT ──────────────────────────────────────────── */
.alert{
  max-width:500px;margin:0 auto 24px;
  padding:14px 20px;border-radius:var(--rs);
  background:rgba(139,0,0,.1);border:1px solid rgba(196,30,58,.25);
  color:#ff8080;font-size:.85rem;text-align:center;font-style:italic;
}

/* ─── ERROR BOX ──────────────────────────────────────── */
.errbox{
  background:var(--bg1);border:1px solid rgba(196,30,58,.2);border-radius:var(--r);
  padding:36px;text-align:center;max-width:600px;margin:0 auto;
}
.errbox h3{color:#ff8080;margin-bottom:12px;font-family:'Cinzel',serif;letter-spacing:.08em}
.errbox code{display:block;background:rgba(0,0,0,.4);border-radius:8px;padding:12px;font-size:.78rem;color:var(--sub);margin-top:12px;font-family:monospace;text-align:left;word-break:break-all}

/* ─── LOADING ────────────────────────────────────────── */
.loader{
  position:fixed;inset:0;background:var(--bg);z-index:9999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;
  transition:opacity .6s,visibility .6s;
}
.loader.off{opacity:0;visibility:hidden}
.lring{
  width:48px;height:48px;border-radius:50%;
  border:2px solid rgba(139,0,0,.3);border-top-color:var(--gold);
  animation:spin 1.2s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.ltxt{
  font-family:'Cinzel',serif;font-size:.7rem;color:var(--sub);
  letter-spacing:.2em;text-transform:uppercase;
}

/* ─── PROFILE PAGE ───────────────────────────────────── */
.ppage{max-width:680px;margin:0 auto;padding:96px 28px 80px;position:relative;z-index:1}
.phero{
  background:linear-gradient(160deg,var(--bg1),var(--bg));
  border:1px solid var(--b);border-radius:var(--r);
  padding:40px;display:flex;gap:24px;align-items:center;
  margin-bottom:14px;position:relative;overflow:hidden;
}
.phero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.5;
}
.phero img{
  width:88px;height:88px;border-radius:50%;
  border:2px solid var(--gold);
  box-shadow:0 0 24px rgba(201,168,76,.25);flex-shrink:0;
}
.pname{font-family:'Cinzel',serif;font-size:1.6rem;font-weight:700;letter-spacing:.04em;color:var(--goldL)}
.pid{font-size:.68rem;color:var(--sub);font-family:monospace;margin-top:8px}
.fcard{background:linear-gradient(160deg,var(--bg1),var(--bg));border:1px solid var(--b);border-radius:var(--r);padding:32px;margin-bottom:14px}
.fsec{font-family:'Cinzel',serif;font-size:.65rem;font-weight:700;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-bottom:24px;display:flex;align-items:center;gap:10px}
.fg{margin-bottom:22px}
.fl{font-family:'Cinzel',serif;display:block;font-size:.62rem;font-weight:700;color:var(--sub);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.fi,.fta{width:100%;background:rgba(0,0,0,.3);border:1px solid var(--b);border-radius:6px;color:var(--txt);font-family:'Lato',sans-serif;font-size:.9rem;outline:none;transition:all .2s}
.fi{padding:12px 16px}.fta{padding:12px 16px;resize:vertical;min-height:88px;line-height:1.7}
.fi:focus,.fta:focus{border-color:var(--goldD);box-shadow:0 0 0 3px rgba(201,168,76,.08)}
.fhint{font-size:.7rem;color:var(--sub);margin-top:6px;font-style:italic}
.frow{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}

/* ─── TOAST ──────────────────────────────────────────── */
.toast{
  position:fixed;bottom:28px;right:28px;z-index:999;
  background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.25);
  color:var(--goldL);padding:13px 20px;border-radius:8px;
  font-family:'Cinzel',serif;font-size:.72rem;font-weight:600;letter-spacing:.06em;
  display:flex;align-items:center;gap:8px;
  transform:translateY(80px);opacity:0;
  transition:all .4s cubic-bezier(.34,1.5,.64,1);
}
.toast.on{transform:none;opacity:1}
.toast-err{background:rgba(139,0,0,.12);border-color:rgba(196,30,58,.3);color:#ff8080}

/* ─── REVEAL ─────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ─── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:768px){
  .nav-in,.section,.crest-div,.stats-wrap,.hero{padding-left:16px;padding-right:16px}
  .hero{padding-top:90px}
  .hero-h1{font-size:clamp(2rem,12vw,4rem)}
  .phero{flex-direction:column;text-align:center}
  .stat{padding:18px 10px}.stat-n{font-size:1.8rem}
}
