/* ================================================================
   SPHONX — IMPERIAL DIVINE v7
   The Hall of the Feline Gods. Light, Sacred, Monumental.
   Desert dawn gold · Carved sandstone · Lapis decree · Celestial ivory
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&family=Cinzel:wght@400;500;600;700&family=Crimson+Text:ital,wght@0,400;0,600;1,400&display=swap');

:root {
  /* Gold of the Gods */
  --g0: #FFF8DC;  /* Cream gilt */
  --g1: #F0C848;  /* Golden light */
  --g2: #D4A520;  /* Royal gold */
  --g3: #B08010;  /* Deep gold */
  --g4: #7A5808;  /* Dark gold */
  --g5: #3E2C04;  /* Shadow gold */

  /* Lapis Lazuli — Sacred Blue */
  --b0: #EBF0FA;  /* Lapis mist */
  --b1: #C8D8F4;  /* Sky lapis */
  --b2: #3D6AB8;  /* Lapis light */
  --b3: #1C3D7A;  /* Royal lapis */
  --b4: #0F2050;  /* Deep lapis */
  --b5: #060E28;  /* Abyss */

  /* Turquoise of Hathor */
  --t1: #E6F4F2;
  --t2: #009988;
  --t3: #006660;

  /* Papyrus & Sandstone */
  --s0: #FFFDFA;  /* Pure ivory */
  --s1: #FDF8EE;  /* Papyrus */
  --s2: #F5EDD8;  /* Parchment */
  --s3: #EAD9B8;  /* Sand */
  --s4: #D4C090;  /* Stone */
  --s5: #A8905A;  /* Deep stone */

  /* Backgrounds */
  --bg:       #FDFBF5;
  --bg-card:  #FFFFFF;
  --bg-panel: #FBF8F0;
  --bg-lift:  #F5EFE0;
  --bg-hover: #EEE6D0;

  /* Borders */
  --bd:      rgba(176,128,16,.16);
  --bd-gold: rgba(212,165,32,.45);
  --bd-lap:  rgba(28,61,122,.18);
  --bd-sand: rgba(168,144,90,.2);

  /* Text */
  --tx:   #1A1206;
  --tx-w: #382810;
  --tx-m: #6A5428;
  --tx-d: #9A8060;
  --tx-g: #C8B080;

  /* Fonts */
  --fD:'Cinzel Decorative',serif;
  --fH:'Cinzel',serif;
  --fB:'Crimson Text',Georgia,serif;

  /* Radius */
  --r:  6px;
  --rl: 14px;
  --rx: 28px;

  /* Shadows */
  --sh:   0 2px 12px rgba(56,40,16,.07);
  --sh-m: 0 6px 30px rgba(56,40,16,.11);
  --sh-l: 0 16px 60px rgba(56,40,16,.15);
  --sh-g: 0 4px 40px rgba(176,128,16,.18), 0 0 80px rgba(212,165,32,.06);
  --sh-b: 0 4px 28px rgba(28,61,122,.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}

body {
  background:var(--bg);
  background-image:
    /* Woven linen grid */
    linear-gradient(rgba(176,128,16,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(176,128,16,.03) 1px,transparent 1px),
    /* Lapis arch from top */
    radial-gradient(ellipse 100% 50% at 50% 0%,rgba(28,61,122,.05) 0%,transparent 70%);
  background-size:40px 40px,40px 40px,100% 100%;
  color:var(--tx);
  font-family:var(--fB);
  font-size:18px;
  line-height:1.75;
  overflow-x:clip;
  max-width:100vw;
  min-height:100vh;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--b3);text-decoration:none;transition:color .2s}
a:hover{color:var(--g3)}
button{cursor:pointer;font-family:inherit;border:none;background:none}

input,select,textarea{
  font-family:var(--fB);font-size:17px;
  background:var(--bg-card);border:1.5px solid var(--bd-sand);
  color:var(--tx);border-radius:var(--r);padding:11px 15px;width:100%;
  transition:border-color .2s,box-shadow .2s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--b3);
  box-shadow:0 0 0 3px rgba(28,61,122,.1),var(--sh-b);
}
select{appearance:auto;cursor:pointer;min-height:42px}
select option{background:var(--bg-card)}
textarea{resize:vertical}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ── ANIMATIONS ── */
@keyframes shimmer   {to{background-position:300%}}
@keyframes gFloat    {0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes crownGlow {0%,100%{filter:drop-shadow(0 3px 8px rgba(176,128,16,.5))}50%{filter:drop-shadow(0 3px 22px rgba(212,165,32,.85))}}
@keyframes rotateRay {to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes horizonP  {0%,100%{opacity:.7}50%{opacity:1}}
@keyframes catFloat  {0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes venAnim   {0%{transform:scale(1)}40%{transform:scale(1.5) rotate(-15deg)}70%{transform:scale(.9)}100%{transform:scale(1)}}
@keyframes slideB    {to{background-position:400%}}
@keyframes fadeUp    {from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn     {0%{transform:scale(.93);opacity:0}60%{transform:scale(1.03)}100%{transform:scale(1);opacity:1}}
@keyframes sunPulse  {0%,100%{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}
@keyframes desertDrift{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.gold-shimmer{
  background:linear-gradient(90deg,var(--g4),var(--g2),var(--g1),var(--g2),var(--g4));
  background-size:300%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:shimmer 5s linear infinite;
}
.glyph-anim{display:inline-block;animation:gFloat 4s ease-in-out infinite}

/* ────────────────────────────────────────────
   MUSIC BUTTON
──────────────────────────────────────────── */
.music-nav-btn{
  display:flex;align-items:center;gap:6px;padding:7px 14px;
  font-family:var(--fH);font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--tx-m);background:transparent;border:1.5px solid var(--bd);
  border-radius:var(--r);cursor:pointer;white-space:nowrap;transition:all .2s;
}
.music-nav-btn:hover{color:var(--b3);border-color:var(--bd-lap);background:var(--b0)}
.music-nav-btn.music-on{color:var(--b3);border-color:var(--b3);background:var(--b0);box-shadow:var(--sh-b)}
.music-nav-icon{font-size:16px}

/* ────────────────────────────────────────────
   NAVIGATION — TEMPLE PYLON GATE
──────────────────────────────────────────── */
.sticky-header-stack{
  position:sticky;top:0;z-index:900;
  box-shadow:0 2px 20px rgba(0,0,0,.15);
}
@media(max-width:900px){
  .sticky-header-stack{
    position:fixed;top:0;left:0;right:0;
    z-index:900;
  }
  /* Push page content down by the height of the stack */
  body{
    padding-top:var(--stack-h, 130px);
  }
}
.nav{
  position:relative;top:auto;z-index:auto;
  background:rgba(253,251,245,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bd-sand);
  overflow:visible;
}
/* Animated sacred border — lapis‑gold‑turquoise */
.nav::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--b4),var(--g2),var(--t2),var(--g1),var(--b4));
  background-size:400%;animation:slideB 10s linear infinite;pointer-events:none;
}
.nav-inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;height:72px;
}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo-glyph{
  font-size:27px;animation:gFloat 4s ease-in-out infinite;
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 2px 6px rgba(176,128,16,.28));
}
.logo-text{font-family:var(--fD);font-size:18px;letter-spacing:.1em;color:var(--b3)}

.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links li{list-style:none}
.nav-links a{
  display:flex;align-items:center;gap:6px;padding:9px 16px;
  font-family:var(--fH);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--b4);border-radius:var(--r);transition:all .2s;font-weight:700;
  border-bottom:2px solid transparent;
}
.nav-links a .nav-icon{font-size:15px;opacity:1}
.nav-links a:hover{color:var(--b3);background:var(--b0);border-bottom-color:var(--g2)}
.nav-cta{
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1))!important;
  color:var(--s0)!important;
  border-radius:var(--r)!important;
  box-shadow:var(--sh-m),var(--sh-g)!important;
  letter-spacing:.1em!important;
}
.nav-cta:hover{
  background:linear-gradient(135deg,var(--g3),var(--g1),var(--g0))!important;
  color:var(--g5)!important;
  transform:translateY(-2px);
  box-shadow:var(--sh-l),0 0 30px rgba(212,165,32,.25)!important;
}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;cursor:pointer;border-radius:var(--r);transition:background .2s}
.nav-toggle:hover{background:var(--b0)}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--tx-m);border-radius:2px;transition:all .2s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile right cluster */
.nav-mobile-right{display:none;align-items:center;gap:8px;margin-left:auto}
.nav-mobile-cta{
  display:flex;align-items:center;gap:5px;
  padding:9px 16px;
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1));
  color:var(--g5)!important;
  border-radius:var(--r);
  font-family:var(--fH);font-size:10px;font-weight:700;letter-spacing:.08em;
  text-decoration:none;white-space:nowrap;
  box-shadow:var(--sh-m),var(--sh-g);
  transition:all .2s;
}
.nav-mobile-cta:hover{transform:translateY(-1px);box-shadow:var(--sh-l),0 0 20px rgba(212,165,32,.25);color:var(--g5)!important}

/* ── BREADCRUMB ── */
.imperial-breadcrumb{
  background:var(--s2);border-bottom:1px solid var(--bd);padding:10px 0;
}
.breadcrumb-inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;gap:8px;
  font-family:var(--fH);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
}
.breadcrumb-inner a{color:var(--tx-m);transition:color .2s}
.breadcrumb-inner a:hover{color:var(--b3)}
.breadcrumb-sep{color:var(--g2);font-size:14px;opacity:.6}
.breadcrumb-current{color:var(--b3);font-weight:600}

/* ── PAGE NAV STRIP ── */
.page-nav-strip{
  background:linear-gradient(135deg,var(--b4),var(--b3),var(--b4));
  padding:0;margin-top:64px;
  border-top:3px solid var(--g2);
  border-bottom:3px solid var(--g2);
  position:relative;overflow:hidden;
}
/* Gold shimmer */
.page-nav-strip::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 100% at 50% 0%,rgba(212,165,32,.1) 0%,transparent 70%);
  pointer-events:none;
}
.page-nav-inner{
  max-width:1200px;margin:0 auto;padding:0;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:stretch;
}
.page-nav-link{
  display:flex;align-items:center;gap:18px;
  padding:28px 36px;
  font-family:var(--fH);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.85);text-decoration:none;
  border-right:1px solid rgba(212,165,32,.15);
  transition:all .25s;background:transparent;
  position:relative;overflow:hidden;
}
.page-nav-link::before{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,0);transition:background .25s;pointer-events:none;
}
.page-nav-link:hover{color:var(--g1)}
.page-nav-link:hover::before{background:rgba(255,255,255,.05)}
.page-nav-link.next{justify-content:flex-end;text-align:right;border-right:none;border-left:1px solid rgba(212,165,32,.15)}
.page-nav-icon{
  font-size:30px;
  width:52px;height:52px;border-radius:50%;
  background:rgba(212,165,32,.12);
  border:1.5px solid rgba(212,165,32,.35);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .25s;
}
.page-nav-link:hover .page-nav-icon{
  background:rgba(212,165,32,.22);border-color:var(--g2);
  box-shadow:0 0 20px rgba(212,165,32,.25);
}
.page-nav-label{font-size:9px;color:rgba(255,255,255,.45);display:block;margin-bottom:4px;letter-spacing:.18em;text-transform:uppercase}
.page-nav-title{display:block;font-size:14px;font-weight:600;color:rgba(255,255,255,.9)}
.page-nav-link:hover .page-nav-title{color:var(--g1)}
.page-nav-center{
  text-align:center;padding:0 32px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  border-left:1px solid rgba(212,165,32,.15);border-right:1px solid rgba(212,165,32,.15);
}
.page-nav-center-glyph{font-size:26px;color:var(--g2);opacity:.6;animation:gFloat 4s ease-in-out infinite}
.page-nav-center-text{font-family:var(--fH);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3)}

/* ────────────────────────────────────────────
   BUTTONS
──────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:12px 28px;
  font-family:var(--fH);font-size:12px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;
  border-radius:var(--r);border:none;cursor:pointer;transition:all .28s;
  text-decoration:none;white-space:nowrap;position:relative;overflow:hidden;
}
/* Shimmer sweep */
.btn::after{
  content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transform:skewX(-20deg);transition:left .55s;pointer-events:none;
}
.btn:hover::after{left:140%}

.btn-primary{
  background:linear-gradient(135deg,var(--b4),var(--b3),var(--b2));
  color:var(--s0);
  box-shadow:var(--sh-m),var(--sh-b),inset 0 1px 0 rgba(255,255,255,.14);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--sh-l),var(--sh-b);color:var(--g0)}
.btn-gold{
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g2),var(--g1));
  color:var(--s0);
  box-shadow:var(--sh-m),var(--sh-g),inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-gold:hover{transform:translateY(-3px);box-shadow:var(--sh-l),0 0 60px rgba(212,165,32,.25);color:var(--s0)}
.btn-ghost{
  background:var(--s0);color:var(--b3);
  border:2px solid var(--b3);
  box-shadow:var(--sh-m);
}
.btn-ghost:hover{background:var(--b3);color:var(--s0);border-color:var(--b3);transform:translateY(-2px);box-shadow:var(--sh-l),var(--sh-b)}
.btn-outline{background:transparent;color:var(--tx-m);border:1.5px solid var(--bd)}
.btn-outline:hover{border-color:var(--b3);color:var(--b3)}
.btn-supreme{
  display:inline-flex;align-items:center;gap:10px;padding:15px 40px;
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g2),var(--g1),var(--g2));
  background-size:200%;
  color:var(--s0);font-family:var(--fH);font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;
  border:none;border-radius:var(--r);cursor:pointer;text-decoration:none;
  transition:all .35s;box-shadow:var(--sh-m),var(--sh-g);font-weight:700;
}
.btn-supreme:hover{background-position:right;transform:translateY(-3px);box-shadow:var(--sh-l),0 0 80px rgba(212,165,32,.22)}
.btn-block{width:100%;justify-content:center}
.btn-lg{padding:14px 40px;font-size:13px}
.btn-xl{padding:17px 52px;font-size:14px}
.btn-icon{font-size:19px}

/* ────────────────────────────────────────────
   ALERTS
──────────────────────────────────────────── */
.alert{padding:14px 20px;border-radius:var(--r);margin-bottom:24px;font-size:16px}
.alert-error{background:#FEF2F2;border:1.5px solid #FECACA;color:#DC2626}
.alert-success{background:var(--t1);border:1.5px solid rgba(0,153,136,.3);color:var(--t3)}

/* ────────────────────────────────────────────
   SECTION HEADERS
──────────────────────────────────────────── */
.section-header{text-align:center;margin-bottom:64px}
.section-header::before{
  content:'⸺ 𓂀 ⸺';
  display:block;font-size:16px;letter-spacing:.5em;
  color:var(--g2);opacity:.4;margin-bottom:14px;font-family:var(--fH);
}
.section-eyebrow{
  font-family:var(--fH);font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--t2);margin-bottom:12px;
}
.section-title{
  font-family:var(--fD);font-size:clamp(26px,4vw,52px);color:var(--b3);
  margin-bottom:14px;text-shadow:0 2px 10px rgba(28,61,122,.1);
}
.section-link{font-family:var(--fH);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--g3)}
.section-link:hover{color:var(--g4)}

.page-header{text-align:center;padding:72px 0 52px}
.page-title{font-family:var(--fD);font-size:clamp(30px,5vw,72px);color:var(--b3);margin-bottom:16px}
.page-sub{color:var(--tx-m);font-size:18px}

/* ────────────────────────────────────────────
   HERO — SACRED DESERT DAWN
──────────────────────────────────────────── */
.hero{
  position:relative;overflow:hidden;
  min-height:100vh;display:flex;align-items:center;
  padding:80px 0 140px;
}

/* ── Sky: warm desert sunrise ── */
.hero-sky{
  position:absolute;inset:0;
  background:linear-gradient(
    175deg,
    #FFF8E0 0%, #FDEDC0 15%,
    #F8D880 32%, #F0BE50 52%,
    #CC8820 72%, #7A5010 100%
  );
}
/* Sun */
.hero-sky::before{
  content:'';position:absolute;top:-90px;right:16%;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,
    rgba(255,235,120,.95) 0%,
    rgba(255,205,60,.55) 28%,
    rgba(240,165,30,.2) 50%,
    transparent 68%
  );
  animation:sunPulse 7s ease-in-out infinite;pointer-events:none;
}
/* Atmospheric fade */
.hero-sky::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 40%,rgba(165,105,20,.28) 80%,rgba(120,72,10,.48) 100%);
  pointer-events:none;
}

/* ── Starfield (subtle) ── */
.hero-sky-stars{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 8% 6%,rgba(255,235,180,.6) 0%,transparent 0),
    radial-gradient(1px 1px at 22% 3%,rgba(255,255,220,.4) 0%,transparent 0),
    radial-gradient(1px 1px at 55% 8%,rgba(255,235,180,.5) 0%,transparent 0),
    radial-gradient(1px 1px at 78% 5%,rgba(255,255,220,.3) 0%,transparent 0),
    radial-gradient(1px 1px at 91% 9%,rgba(255,235,180,.4) 0%,transparent 0),
    radial-gradient(1px 1px at 38% 12%,rgba(255,255,220,.3) 0%,transparent 0);
  opacity:.5;
}

/* ── Pyramids ── */
.hero-pyramids{position:absolute;bottom:0;left:0;right:0;height:400px;pointer-events:none}
.pyramid{position:absolute;bottom:0;border-left:solid transparent;border-right:solid transparent;border-bottom:solid}
.pyramid.p-l{border-left-width:200px;border-right-width:200px;border-bottom-width:340px;left:0%;border-bottom-color:rgba(80,48,10,.75)}
.pyramid.p-bg{border-left-width:280px;border-right-width:280px;border-bottom-width:500px;left:50%;transform:translateX(-50%);border-bottom-color:rgba(52,30,6,.9);z-index:2}
.pyramid.p-sm{border-left-width:110px;border-right-width:110px;border-bottom-width:195px;right:16%;border-bottom-color:rgba(70,42,8,.65)}
.pyramid.p-r{border-left-width:145px;border-right-width:145px;border-bottom-width:260px;right:-1%;border-bottom-color:rgba(62,36,7,.6)}
.hero-horizon{
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--g2),var(--g1),var(--g2),transparent);
  animation:horizonP 5s ease-in-out infinite;pointer-events:none;z-index:3;
}
.hero-sand{position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(to top,rgba(130,85,16,.3),transparent);pointer-events:none;z-index:2}
.hero-sphonx-deity{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  font-size:210px;line-height:1;pointer-events:none;z-index:3;
  color:rgba(52,30,6,.07);filter:blur(1px);
  animation:gFloat 12s ease-in-out infinite;
}

/* ── Content ── */
.hero-content-wrap{
  display:grid;grid-template-columns:1fr 360px;
  gap:60px;align-items:center;position:relative;z-index:10;
}
.hero-eyebrow{
  font-family:var(--fH);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--b3);margin-bottom:20px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;opacity:.9;
}
.h-sep{opacity:.35}
.hero-title{
  font-family:var(--fD);font-size:clamp(36px,6vw,96px);
  line-height:.92;margin-bottom:28px;
  display:flex;flex-direction:column;gap:8px;
}
.hero-title-line1{color:var(--b3);text-shadow:0 2px 18px rgba(28,61,122,.18)}
.hero-sub{font-size:clamp(17px,2.2vw,23px);color:var(--tx-w);margin-bottom:44px;line-height:1.85;font-weight:400}
.hero-sub strong{color:var(--b4);font-weight:700;font-size:1.08em}
.yuki-name-inline{
  font-style:normal;font-family:var(--fD);font-size:1.4em;
  color:#FFF;
  -webkit-text-fill-color:#FFF;
  background:none;
  font-weight:900;
  text-shadow:0 2px 20px rgba(0,0,0,.4),0 0 40px rgba(255,255,255,.3);
  display:inline-block;
  border-bottom:3px solid var(--g2);
  padding-bottom:2px;
  letter-spacing:.04em;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

/* ── Sacred statue / icon panel ── */
.hero-statue{position:relative;text-align:center}
.statue-base{display:flex;flex-direction:column;align-items:center;padding-bottom:20px}
.statue-rays{
  position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);
  width:300px;height:300px;border-radius:50%;
  background:conic-gradient(
    from 0deg,
    rgba(176,128,16,.12) 0deg,transparent 16deg,
    rgba(0,153,136,.06) 32deg,transparent 48deg,
    rgba(176,128,16,.1) 64deg,transparent 80deg,
    rgba(28,61,122,.05) 96deg,transparent 112deg,
    rgba(176,128,16,.12) 128deg,transparent 144deg,
    rgba(0,153,136,.06) 160deg,transparent 176deg,
    rgba(176,128,16,.1) 192deg,transparent 208deg,
    rgba(28,61,122,.05) 224deg,transparent 240deg,
    rgba(176,128,16,.12) 256deg,transparent 272deg,
    rgba(0,153,136,.06) 288deg,transparent 304deg,
    rgba(176,128,16,.1) 320deg,transparent 336deg,
    rgba(176,128,16,.12) 352deg
  );
  animation:rotateRay 28s linear infinite;pointer-events:none;
}
.statue-crown{font-size:50px;margin-bottom:-16px;position:relative;z-index:3;animation:crownGlow 3s ease-in-out infinite}
.statue-cat{font-size:140px;line-height:1;position:relative;z-index:2;animation:catFloat 5s ease-in-out infinite;filter:drop-shadow(4px 10px 20px rgba(56,36,8,.3))}
.statue-hiero{font-family:var(--fH);font-size:13px;letter-spacing:.32em;color:var(--g3);opacity:.5;margin-top:10px}
.statue-pedestal{
  width:164px;height:12px;border-radius:3px;
  background:linear-gradient(90deg,var(--bd),var(--g2),var(--g1),var(--g2),var(--bd));
  margin-top:4px;box-shadow:0 2px 12px rgba(176,128,16,.2);
}
.hero-hieroglyphs{
  position:absolute;bottom:20px;left:0;right:0;text-align:center;
  font-size:22px;color:var(--g4);opacity:.55;letter-spacing:.5em;
  pointer-events:none;z-index:4;user-select:none;
  font-family:var(--fH);
  text-shadow:0 2px 6px rgba(90,56,4,.3),0 0 20px rgba(176,128,16,.2);
}

/* ────────────────────────────────────────────
   STATS BAND — THE EMPIRE'S PROCLAMATION
──────────────────────────────────────────── */
.stats-band{
  background:linear-gradient(135deg,var(--b4),var(--b3),var(--b3),var(--b4));
  border-top:3px solid var(--g2);border-bottom:3px solid var(--g2);
  position:relative;overflow:hidden;
}
/* Subtle gold wave */
.stats-band::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,transparent,transparent 80px,rgba(255,255,255,.02) 80px,rgba(255,255,255,.02) 81px);
  pointer-events:none;
}
.stats-band-inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;align-items:stretch;flex-wrap:wrap;position:relative;z-index:1;
}
.stat-pill{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;padding:34px 44px;flex:1;min-width:140px;
  border-right:1px solid rgba(255,255,255,.08);
}
.stat-pill:last-of-type{border-right:none}
.stat-pill-icon{font-size:28px;margin-bottom:4px;color:#FFF;filter:drop-shadow(0 0 8px rgba(255,255,255,.4))}
.stat-pill-num{
  font-family:var(--fH);font-size:38px;font-weight:700;line-height:1;
  background:linear-gradient(180deg,#FFFFFF,var(--g0),var(--g1));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 0 10px rgba(240,200,72,.5));
  letter-spacing:-.01em;
}
.stat-pill-lbl{
  font-family:var(--fH);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.75);
  margin-top:3px;
}
.stat-pill-divider{display:none}

/* ────────────────────────────────────────────
   YUKI — THE ETERNAL GOD PHARAOH
──────────────────────────────────────────── */
.yuki-section{
  padding:120px 0;position:relative;
  background:linear-gradient(160deg,var(--s1),var(--s2),var(--s1));
  border-top:1px solid var(--bd-sand);border-bottom:1px solid var(--bd-sand);overflow:hidden;
}
.yuki-bg-pattern{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(176,128,16,.04) 40px,rgba(176,128,16,.04) 41px),
    repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(28,61,122,.025) 40px,rgba(28,61,122,.025) 41px);
}
.yuki-sun-rays{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:900px;height:900px;border-radius:50%;
  background:radial-gradient(ellipse at center,rgba(176,128,16,.07) 0%,transparent 60%);
  pointer-events:none;
}
.yuki-throne-wrap{max-width:1060px;margin:0 auto;position:relative;z-index:2}
.yuki-throne-card{
  display:grid;grid-template-columns:420px 1fr;
  background:var(--bg-card);
  border:2px solid var(--bd-gold);
  border-radius:var(--rx);overflow:hidden;
  box-shadow:var(--sh-l),var(--sh-g),0 0 100px rgba(176,128,16,.06);
  position:relative;
}
/* Multi-colour top bar */
.yuki-throne-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--b4),var(--g2),var(--t2),var(--g1),var(--b4));
  background-size:400%;animation:slideB 8s linear infinite;z-index:4;pointer-events:none;
}
.yuki-left{position:relative}
.yuki-img-frame{height:520px;background:var(--s2);overflow:hidden;position:relative}
.yuki-photo{width:100%;height:100%;object-fit:cover}
.yuki-img-overlay{position:absolute;inset:0;pointer-events:none;background:linear-gradient(to right,transparent 52%,var(--bg-card))}
.yuki-crown-glyph{position:absolute;top:16px;left:50%;transform:translateX(-50%);font-size:40px;z-index:5;animation:crownGlow 3s ease-in-out infinite}
.yuki-lapis-bar{
  background:var(--b3);padding:11px 20px;text-align:center;
  font-family:var(--fH);font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.8);
}
.yuki-right{padding:52px 48px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.yuki-rank-badge-supreme{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--b3);border-radius:var(--rx);padding:8px 22px;
  font-family:var(--fH);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--g0);width:fit-content;box-shadow:var(--sh-b);
}
.yuki-name{
  font-family:var(--fD);font-size:78px;line-height:1;
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1),var(--g2));
  background-size:200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:shimmer 5s linear infinite;filter:drop-shadow(0 2px 8px rgba(176,128,16,.18));
}
.yuki-ven-counter{display:flex;align-items:baseline;gap:10px}
.yuki-ven-num{font-family:var(--fH);font-size:44px;color:var(--b3);font-weight:700}
.yuki-ven-lbl{color:var(--tx-m);font-size:16px}
.yuki-lore{color:var(--tx-w);font-size:16px;line-height:1.85;font-style:italic;border-left:4px solid var(--g2);padding-left:18px}
.yuki-rules{display:flex;flex-direction:column;gap:10px}
.yuki-rule{font-family:var(--fH);font-size:12px;letter-spacing:.04em;color:var(--tx-m);display:flex;align-items:flex-start;gap:10px}
.yuki-rule::before{content:'⦿';color:var(--t2);flex-shrink:0;font-size:10px;margin-top:2px}

/* ────────────────────────────────────────────
   CAT CARDS — SACRED TABLETS
──────────────────────────────────────────── */
.cats-section{padding:100px 0}
.latest-cats-section{padding-top:20px}
.cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px}

.cat-card{
  background:var(--bg-card);border:1.5px solid var(--bd);
  border-radius:var(--rl);overflow:hidden;
  transition:all .3s ease;position:relative;box-shadow:var(--sh);
}
/* Gold top flash on hover */
.cat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--g2),transparent);
  opacity:0;transition:opacity .3s;pointer-events:none;z-index:2;
}
.cat-card:hover{border-color:rgba(176,128,16,.45);transform:translateY(-8px) scale(1.01);box-shadow:var(--sh-l),var(--sh-g)}
.cat-card:hover::before{opacity:1}

.cat-card-img-link{display:block;text-decoration:none}
.cat-card-img-wrap{position:relative;aspect-ratio:1;overflow:hidden}
.cat-card-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.cat-card:hover .cat-card-img{transform:scale(1.09)}
.cat-card-rank-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 115%,color-mix(in srgb,var(--rank-color,#D4A520) 28%,transparent),transparent 55%);pointer-events:none}
.cat-card-rank-icon{
  position:absolute;top:10px;right:10px;
  width:34px;height:34px;border-radius:50%;
  border:2px solid rgba(255,255,255,.95);backdrop-filter:blur(6px);
  background:rgba(255,255,255,.88);
  display:flex;align-items:center;justify-content:center;font-size:16px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.cat-card-medal{position:absolute;top:10px;left:10px;font-size:23px;filter:drop-shadow(0 2px 5px rgba(176,128,16,.55))}
.cat-card-featured{position:absolute;bottom:10px;right:10px;font-size:22px;filter:drop-shadow(0 2px 5px rgba(212,165,32,.5))}
.cat-card-new-badge{
  position:absolute;top:10px;left:10px;
  background:var(--t2);color:#FFF;
  font-family:var(--fH);font-size:9px;font-weight:700;letter-spacing:.12em;
  padding:3px 10px;border-radius:4px;box-shadow:var(--sh);
}
.cat-card-body{padding:18px 20px 16px}
.cat-card-name-link{text-decoration:none}
.cat-card-name{font-family:var(--fH);font-size:15px;font-weight:600;color:var(--tx);margin-bottom:7px;transition:color .2s}
.cat-card:hover .cat-card-name{color:var(--b3)}
.cat-card-meta{font-size:12px;color:var(--tx-m);display:flex;align-items:center;gap:7px;margin-bottom:10px}
.cat-rank-label{font-size:11px;font-weight:600}
.cat-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;border-top:1px solid var(--bd);padding-top:10px;margin-top:4px}
.cat-card-vens{font-family:var(--fH);font-size:11px;color:var(--g3);letter-spacing:.03em}

.venerate-quick-btn{
  width:36px;height:36px;border-radius:50%;
  background:var(--b0);border:1.5px solid var(--bd-lap);
  color:var(--b3);font-size:15px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;transition:all .25s;
}
.venerate-quick-btn:hover:not(.venerated){background:var(--b3);color:var(--s0);transform:scale(1.18);box-shadow:var(--sh-b)}
.venerate-quick-btn.venerated{border-color:rgba(0,122,114,.4);color:var(--t2);background:var(--t1);cursor:default}
.venerate-quick-btn.venerating{animation:venAnim .5s ease}
.ven-btn-icon{line-height:1;display:flex;align-items:center;justify-content:center}

/* ────────────────────────────────────────────
   HIERARCHY — SACRED ORDER OF RANKS
──────────────────────────────────────────── */
.hierarchy-section{
  padding:100px 0;position:relative;
  background:linear-gradient(160deg,var(--s2),var(--s1),var(--s2));
  border-top:1px solid var(--bd-sand);
}
.hier-papyrus{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 32px,rgba(176,128,16,.1) 32px,rgba(176,128,16,.1) 33px),
    repeating-linear-gradient(90deg,transparent,transparent 80px,rgba(28,61,122,.04) 80px,rgba(28,61,122,.04) 81px);
}
.hierarchy-pyramid-wrap{max-width:720px;margin:0 auto}
.hier-pyramid{display:flex;flex-direction:column;gap:4px}
.hier-tier{
  display:flex;align-items:center;gap:16px;
  padding:16px 26px;
  background:var(--bg-card);border:1.5px solid var(--bd);
  border-left:5px solid var(--rank-clr,var(--g2));
  border-radius:var(--r);transition:all .3s;cursor:default;
  position:relative;overflow:hidden;box-shadow:var(--sh);
}
.hier-tier::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:linear-gradient(90deg,color-mix(in srgb,var(--rank-clr,var(--g2)) 9%,transparent),transparent);
  transition:width .4s;pointer-events:none;
}
.hier-tier:hover{border-color:var(--rank-clr,var(--g2));transform:translateX(6px);box-shadow:var(--sh-m),0 0 20px color-mix(in srgb,var(--rank-clr,var(--g2)) 14%,transparent)}
.hier-tier:hover::before{width:100%}
.tier-supreme{background:var(--g0)!important;border-color:var(--g2)!important;box-shadow:var(--sh-m),var(--sh-g)!important}
.tier-icon{font-size:22px;width:30px;text-align:center;flex-shrink:0}
.tier-info{flex:1}
.tier-name{font-family:var(--fH);font-size:14px;font-weight:600;display:block;color:var(--rank-clr,var(--tx))}
.tier-desc{font-size:12px;color:var(--tx-d);display:block;font-style:italic;margin-top:2px}
.tier-req{font-size:12px;color:var(--tx-d);flex-shrink:0}
.tier-eternal{color:var(--g3);font-style:italic;font-size:11px}

/* ────────────────────────────────────────────
   DUEL — ARENA OF DIVINE JUDGMENT
──────────────────────────────────────────── */
.duel-section{padding:100px 0;background:var(--s1);border-top:1px solid var(--bd-sand)}
.duel-sand-bg{display:none}
.home-duel-card{
  max-width:980px;margin:0 auto;
  background:var(--bg-card);border:2px solid var(--bd-lap);
  border-radius:var(--rx);padding:54px;
  box-shadow:var(--sh-l),var(--sh-b);position:relative;
}
.home-duel-card::before{
  content:'⚔️';position:absolute;top:-20px;left:50%;transform:translateX(-50%);
  background:var(--b3);border-radius:50%;width:50px;height:50px;
  display:flex;align-items:center;justify-content:center;font-size:22px;
  box-shadow:var(--sh-b);
}
.home-duel-question{font-family:var(--fH);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--b3);text-align:center;margin-bottom:36px}
.home-duel-arena{display:grid;grid-template-columns:1fr 140px 1fr;gap:28px;align-items:center}
.home-duel-cat{background:var(--bg-panel);border:1.5px solid var(--bd);border-radius:var(--rl);overflow:hidden;cursor:pointer;transition:all .3s}
.home-duel-cat:hover{border-color:var(--b2);box-shadow:var(--sh-m),var(--sh-b);transform:translateY(-4px)}
.home-duel-cat.duel-voted{border-color:var(--g2);background:var(--g0)}
.home-duel-img{aspect-ratio:1;overflow:hidden}
.home-duel-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.home-duel-cat:hover .home-duel-img img{transform:scale(1.07)}
.home-duel-info{padding:16px;text-align:center}
.home-duel-info h3{font-family:var(--fH);font-size:14px;color:var(--tx);margin-bottom:4px}
.home-duel-info p{font-size:12px;color:var(--tx-m)}
.duel-result-bar{height:6px;background:var(--bd);border-radius:3px;margin:0 16px 8px;overflow:hidden}
.duel-result-fill{height:100%;background:linear-gradient(90deg,var(--b3),var(--t2));border-radius:3px;transition:width .8s ease}
.duel-result-pct{display:block;text-align:center;margin-bottom:8px;font-family:var(--fH);font-size:12px;color:var(--b3)}
.home-duel-vs{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.duel-vs-circle{
  width:78px;height:78px;border-radius:50%;
  background:var(--b3);border:3px solid var(--g2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fD);font-size:13px;color:var(--g0);
  box-shadow:var(--sh-b),var(--sh-g);
}
.duel-total-votes,.duel-vote-hint{font-family:var(--fH);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-d)}
.duel-more-link{font-family:var(--fH);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--b3);opacity:.7}
.duel-more-link:hover{opacity:1}
.duel-voted-confirm{text-align:center;color:var(--g3);font-style:italic;margin-top:22px}

/* ────────────────────────────────────────────
   CTA — IMPERIAL DECREE
──────────────────────────────────────────── */
.cta-section{
  padding:80px 0 120px;
  background:var(--b3);position:relative;overflow:hidden;
}
/* Gold haze at top */
.cta-section::before{
  content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:700px;height:320px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(212,165,32,.12) 0%,transparent 70%);
  pointer-events:none;
}
/* Hieroglyph frieze at bottom */
.cta-section::after{
  content:'𓂀 𓃒 𓁀 𓃠 𓂸 𓁦 𓃒 𓂀 𓃠 𓁦 𓂸 𓃒 𓂀 𓁦 𓃒 𓂀 𓃒 𓁀 𓃠';
  position:absolute;bottom:0;left:0;right:0;padding:8px 0;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;letter-spacing:.4em;color:rgba(255,255,255,.07);
  pointer-events:none;white-space:nowrap;overflow:hidden;
}
.cta-inner{text-align:center;padding:80px 48px;position:relative;z-index:1}
.cta-glyphs{font-size:22px;color:rgba(255,255,255,.18);letter-spacing:.35em;display:block;margin-bottom:28px}
.cta-title{font-family:var(--fD);font-size:clamp(20px,4.5vw,58px);color:var(--s0);margin-bottom:22px;word-break:break-word;overflow-wrap:break-word;text-shadow:0 2px 16px rgba(0,0,0,.25)}
.cta-sub{color:rgba(255,255,255,.62);font-size:19px;margin-bottom:40px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.8}
.cta-ranks-preview{display:flex;justify-content:center;gap:14px;margin-top:32px;font-size:24px;opacity:.18}
.cta-btn-wrap{position:relative;z-index:10;display:flex;justify-content:center;margin:0 auto 28px;width:100%}
.cta-main-btn{position:relative;z-index:10;display:inline-flex!important;pointer-events:auto!important}

/* ────────────────────────────────────────────
   RANKING
──────────────────────────────────────────── */
.ranking-page{padding-bottom:80px}
.rank-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.rank-filter-btn{padding:7px 18px;border-radius:var(--rx);border:1.5px solid var(--bd);background:var(--bg-card);color:var(--tx-m);font-family:var(--fH);font-size:11px;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;text-decoration:none;transition:all .2s;box-shadow:var(--sh)}
.rank-filter-btn:hover,.rank-filter-btn.active{border-color:var(--rank-color,var(--b3));color:var(--rank-color,var(--b3));background:var(--b0)}
.ranking-table-wrap{overflow-x:auto;margin-bottom:32px;border-radius:var(--rl);-webkit-overflow-scrolling:touch}
.ranking-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh-m)}
.ranking-table th{padding:12px 14px;text-align:left;font-family:var(--fH);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--tx-m);background:var(--s2);border-bottom:2px solid var(--g2);white-space:nowrap}
.ranking-table td{padding:11px 14px;border-bottom:1px solid var(--bd);vertical-align:middle}
.ranking-table tr:last-child td{border-bottom:none}
/* ── Ranking CARDS on mobile ── */
@media(max-width:640px){
  .ranking-table thead{display:none}
  .ranking-table,.ranking-table tbody,.ranking-table tr,.ranking-table td{display:block;width:100%}
  .ranking-table tr{
    position:relative;padding:14px 16px 14px 56px;
    border-bottom:1.5px solid var(--bd);background:var(--bg-card);
  }
  .ranking-table tr:hover td{background:transparent}
  .ranking-table tr.featured-row{background:var(--g0)!important}
  /* Position number absolutely on left */
  .rank-num{
    position:absolute;left:14px;top:50%;transform:translateY(-50%);
    font-size:15px;font-weight:700;color:var(--tx-d);width:auto;
    display:block;
  }
  /* Cat name row — main info */
  .rank-cat-cell{
    display:flex!important;align-items:center;gap:10px;
    padding:0 0 8px 0!important;border:none!important;
  }
  .rank-cat-thumb{width:44px!important;height:44px!important;border-radius:50%;flex-shrink:0}
  .rank-cat-name{font-size:15px;font-weight:700}
  /* All other cells — inline chips */
  .ranking-table td:not(.rank-num):not(.rank-cat-cell){
    display:inline-flex!important;align-items:center;gap:5px;
    padding:0 10px 0 0!important;border:none!important;
    font-size:12px;vertical-align:middle;
  }
  /* Add label via data-label */
  .ranking-table td:not(.rank-num):not(.rank-cat-cell)::before{
    font-family:var(--fH);font-size:9px;letter-spacing:.1em;
    text-transform:uppercase;color:var(--tx-d);
    content:attr(data-label)": ";white-space:nowrap;
  }
}
.ranking-row:hover td{background:var(--bg-hover)}
.featured-row{background:var(--g0)!important}
.rank-num{font-family:var(--fH);font-weight:700;color:var(--tx-d);width:40px}
.rank-cat-link{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--tx)}
.rank-cat-link:hover{color:var(--b3)}
.rank-cat-thumb{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--bd-gold);flex-shrink:0}
.rank-cat-cell{min-width:180px}
.rank-cat-name{font-family:var(--fH);font-size:14px;font-weight:600}
.rank-title-badge{font-family:var(--fH);font-size:12px;font-weight:600}
.rank-vens{font-family:var(--fH);color:var(--g3);font-weight:600}
.rank-wl{color:var(--tx-d);font-size:13px}

.pagination{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;margin:32px 0}
.page-btn{padding:8px 14px;border:1.5px solid var(--bd);border-radius:var(--r);background:var(--bg-card);color:var(--tx-m);font-family:var(--fH);font-size:12px;text-decoration:none;transition:all .2s;box-shadow:var(--sh)}
.page-btn:hover,.page-btn.active{border-color:var(--b3);color:var(--b3);background:var(--b0)}
.page-ellipsis{padding:8px 4px;color:var(--tx-d);font-size:13px}

/* ────────────────────────────────────────────
   COUNTRY GRID
──────────────────────────────────────────── */
.country-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.country-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px 16px;background:var(--bg-card);border:1.5px solid var(--bd);border-radius:var(--rl);text-decoration:none;color:var(--tx);transition:all .3s;text-align:center;box-shadow:var(--sh)}
.country-card:hover{border-color:var(--b2);transform:translateY(-4px);box-shadow:var(--sh-m),var(--sh-b)}
.country-flag{font-size:40px}
.country-name{font-family:var(--fH);font-size:13px;font-weight:600;color:var(--tx)}
.country-count{font-size:11px;color:var(--t2);font-family:var(--fH)}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--tx-m);font-size:14px;margin-bottom:16px}
.back-link:hover{color:var(--b3)}

/* ────────────────────────────────────────────
   CAT PROFILE
──────────────────────────────────────────── */
.cat-profile-page{padding:60px 0 80px}
.cat-profile-grid{display:grid;grid-template-columns:380px 1fr;gap:64px;align-items:start}
.cat-photo-frame{
  position:relative;border-radius:var(--rl);overflow:hidden;
  background:var(--s2);
  border:4px solid var(--g2);
  aspect-ratio:1;
  box-shadow:
    var(--sh-l),
    var(--sh-g),
    0 0 0 8px rgba(212,165,32,.1),
    0 0 0 16px rgba(212,165,32,.04),
    0 0 0 17px rgba(28,61,122,.08);
}
.cat-photo{width:100%;height:100%;object-fit:cover}
.cat-yuki-crown{position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-size:48px;z-index:10;animation:crownGlow 3s ease-in-out infinite}
.yuki-rays-small{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(176,128,16,.08) 0%,transparent 65%);animation:sunPulse 4s ease-in-out infinite;pointer-events:none}
.share-box{margin-top:18px;padding:22px;background:var(--bg-card);border:1.5px solid var(--bd-sand);border-radius:var(--rl);box-shadow:var(--sh-m)}
.share-title{font-family:var(--fH);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--tx-d);margin-bottom:12px}
.share-buttons{display:flex;gap:8px}
.share-btn{
  flex:1;padding:12px 8px;border-radius:10px;
  border:1.5px solid var(--bd);background:var(--bg-card);
  color:var(--tx-m);font-size:13px;
  text-align:center;cursor:pointer;text-decoration:none;
  transition:all .22s;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--sh);
}
.share-btn:hover{transform:translateY(-3px);box-shadow:var(--sh-m)}
.share-fb:hover{border-color:#1877F2;color:#FFF;background:#1877F2}
.share-tw:hover{border-color:#000;color:#FFF;background:#000}
.share-wa:hover{border-color:#25D366;color:#FFF;background:#25D366}
.share-copy:hover{border-color:var(--b3);color:#FFF;background:var(--b3)}
.profile-eternal-badge{font-family:var(--fH);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--g5);background:linear-gradient(135deg,var(--g2),var(--g1));padding:6px 16px;border-radius:var(--rx);display:inline-block;margin-bottom:14px;box-shadow:0 4px 16px rgba(176,128,16,.3)}
.profile-name{
  font-family:var(--fD);font-size:clamp(32px,4.5vw,80px);
  color:var(--b3);margin-bottom:10px;
  text-shadow:0 2px 16px rgba(28,61,122,.12);
  position:relative;letter-spacing:.02em;
}
.profile-name::after{
  content:'';display:block;width:80px;height:3px;margin:14px 0 0;
  background:linear-gradient(90deg,var(--g2),var(--g1),transparent);
  border-radius:2px;
}
.profile-meta-row{display:flex;gap:20px;align-items:center;margin-bottom:20px;color:var(--tx-m);font-size:16px;flex-wrap:wrap}
.profile-meta-row a{color:var(--tx-m)}.profile-meta-row a:hover{color:var(--b3)}
.profile-rank-badge{
  display:inline-flex;align-items:center;gap:10px;padding:11px 26px;
  border:2px solid currentColor;border-radius:30px;margin-bottom:28px;
  box-shadow:0 0 20px color-mix(in srgb,currentColor 18%,transparent),0 4px 12px rgba(0,0,0,.07);
  background:color-mix(in srgb,currentColor 8%,var(--bg-card));
}
.profile-rank-name{font-size:14px!important;font-weight:700!important;letter-spacing:.05em!important}
.profile-rank-icon{font-size:22px!important}
.profile-rank-icon{font-size:19px}
.profile-rank-name{font-family:var(--fH);font-size:13px;font-weight:600;letter-spacing:.08em}
.profile-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}
.stat-box{
  background:var(--bg-card);border:1.5px solid var(--bd);border-radius:var(--r);
  padding:22px 14px;text-align:center;transition:all .25s;box-shadow:var(--sh);
  position:relative;overflow:hidden;
}
.stat-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--g2),transparent);opacity:0;transition:opacity .3s;pointer-events:none}
.stat-box:hover{border-color:var(--bd-gold);box-shadow:var(--sh-m),var(--sh-g)}
.stat-box:hover::before{opacity:.8}
.stat-num{display:block;font-family:var(--fH);font-size:28px;color:var(--b3);font-weight:700;text-shadow:0 1px 8px rgba(28,61,122,.12)}
.stat-label{font-size:10px;color:var(--tx-d);text-transform:uppercase;letter-spacing:.08em}
.profile-description{
  color:var(--tx-w);font-size:18px;line-height:1.9;margin-bottom:28px;font-style:italic;
  border-left:4px solid var(--g2);padding-left:20px;
  background:linear-gradient(135deg,rgba(212,165,32,.04),transparent);
  padding:16px 20px;border-radius:0 var(--r) var(--r) 0;
}
.profile-right-card{
  background:var(--bg-card);
  border-radius:var(--rx);
  padding:36px;
  box-shadow:var(--sh-l);
  border:1px solid var(--bd);
  margin-top:0;
  position:relative;
  overflow:hidden;
  min-width:0;
  width:100%;
  box-sizing:border-box;
}
/* Gold top accent */
.profile-right-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--b3),var(--g2),var(--t2),var(--g2),var(--b3));
  background-size:400%;animation:slideB 8s linear infinite;pointer-events:none;
}
/* Subtle hieroglyph watermark */
.profile-right-card::after{
  content:'𓂀';
  position:absolute;bottom:-10px;right:16px;
  font-size:130px;color:var(--b3);opacity:.06;
  pointer-events:none;line-height:1;
}
.profile-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.btn-venerate.venerated{opacity:.6;cursor:default;pointer-events:none}
.yuki-eternal-note{color:var(--g3);font-style:italic;font-size:16px;border-left:4px solid var(--g2);padding-left:16px}
.profile-badges{margin-bottom:30px}
.badges-title{font-family:var(--fH);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-m);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.badges-list{display:flex;flex-wrap:wrap;gap:8px}
.badge-item{
  padding:8px 18px;border:2px solid currentColor;border-radius:var(--rx);
  font-family:var(--fH);font-size:11px;letter-spacing:.04em;font-weight:600;
  transition:all .25s;
  background:color-mix(in srgb,currentColor 10%,var(--bg-card));
  display:flex;align-items:center;gap:8px;
  box-shadow:0 2px 8px color-mix(in srgb,currentColor 12%,transparent);
}
.badge-item:hover{opacity:.9;transform:translateY(-2px) scale(1.04);box-shadow:0 6px 16px color-mix(in srgb,currentColor 25%,transparent)}
.profile-upgrades{
  background:linear-gradient(160deg,var(--bg-card),var(--g0));
  border:2px solid var(--g2);border-radius:var(--rl);
  padding:28px;
  box-shadow:var(--sh-m),var(--sh-g),inset 0 1px 0 rgba(255,255,255,.8);
  position:relative;overflow:hidden;
}
.profile-upgrades::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--b3),var(--g2),var(--t2),var(--g2),var(--b3));
  background-size:400%;animation:slideB 8s linear infinite;pointer-events:none;
}
.upgrades-title{font-family:var(--fH);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx-d);margin-bottom:16px}
.upgrade-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.upgrade-card{background:var(--bg-panel);border:1.5px solid var(--bd);border-radius:var(--r);padding:18px;cursor:pointer;transition:all .25s;text-align:center;display:flex;flex-direction:column;gap:6px;text-decoration:none}
.upgrade-card:hover{border-color:var(--bd-lap);background:var(--b0);transform:translateY(-3px);box-shadow:var(--sh-m),var(--sh-b)}
.upgrade-icon{font-size:26px;transition:transform .3s}
.upgrade-card:hover .upgrade-icon{transform:scale(1.18)}
.upgrade-name{font-family:var(--fH);font-size:12px;color:var(--tx);font-weight:700}
.upgrade-benefit{font-size:11px;color:var(--tx-m);font-style:italic;line-height:1.5;text-align:center;padding:0 2px}
.upgrade-price{font-family:var(--fH);font-size:13px;color:var(--b3);font-weight:700}

/* ────────────────────────────────────────────
   DUEL PAGE
──────────────────────────────────────────── */
.duel-page{padding:60px 0 80px}
.duel-card{background:var(--bg-card);border:1.5px solid var(--bd);border-radius:var(--rx);padding:44px;margin-bottom:36px;position:relative;box-shadow:var(--sh-m)}
.duel-daily{border-color:var(--bd-gold);box-shadow:var(--sh-m),var(--sh-g)}
.duel-daily-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--g4),var(--g2));color:var(--s0);font-family:var(--fH);font-size:9px;font-weight:700;letter-spacing:.15em;padding:4px 18px;border-radius:var(--rx);white-space:nowrap;box-shadow:var(--sh)}
.duel-question{font-family:var(--fH);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-m);text-align:center;margin-bottom:32px}
.duel-page .duel-arena,.duel-arena-wrap .duel-arena{display:grid;grid-template-columns:1fr 110px 1fr;gap:24px;align-items:center}
.duel-page .duel-contestant,.duel-arena-wrap .duel-contestant{background:var(--bg-panel);border:1.5px solid var(--bd);border-radius:var(--rl);overflow:hidden;cursor:pointer;transition:all .3s}
.duel-page .duel-contestant:hover,.duel-arena-wrap .duel-contestant:hover{border-color:var(--b2);box-shadow:var(--sh-m),var(--sh-b)}
.duel-page .duel-contestant.duel-voted,.duel-arena-wrap .duel-contestant.duel-voted{border-color:var(--g2);background:var(--g0)}
.duel-page .duel-contestant .duel-img-wrap,.duel-arena-wrap .duel-contestant .duel-img-wrap{aspect-ratio:1;overflow:hidden}
.duel-page .duel-contestant .duel-img-wrap img,.duel-arena-wrap .duel-contestant .duel-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.duel-page .duel-contestant:hover .duel-img-wrap img,.duel-arena-wrap .duel-contestant:hover .duel-img-wrap img{transform:scale(1.07)}
.duel-cat-info{padding:14px;text-align:center}
.duel-cat-info h3{font-family:var(--fH);font-size:15px;font-weight:600;color:var(--tx);margin-bottom:4px}
.duel-cat-info p{font-size:12px;color:var(--tx-m)}
.duel-bar{height:6px;background:var(--bd);border-radius:3px;margin:8px 14px;overflow:hidden}
.duel-bar-fill{height:100%;background:linear-gradient(90deg,var(--b3),var(--t2));border-radius:3px;transition:width .6s}
.duel-pct{display:block;text-align:center;margin-bottom:8px;font-family:var(--fH);font-size:11px;color:var(--b3)}
.duel-page .duel-vs,.duel-arena-wrap .duel-vs{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}
.duel-page .duel-vs span:first-child,.duel-arena-wrap .duel-vs span:first-child{font-family:var(--fD);font-size:22px;color:var(--b3);display:block}
.duel-page .duel-vs small,.duel-arena-wrap .duel-vs small{font-size:11px;color:var(--tx-d)}
.duel-voted-msg{text-align:center;color:var(--g3);font-style:italic;margin-top:18px}

/* ────────────────────────────────────────────
   SUBMIT
──────────────────────────────────────────── */
.submit-page{padding:60px 0 80px}
.submit-form{max-width:640px;margin:0 auto}
.form-group{margin-bottom:26px}
.form-group label{display:block;font-family:var(--fH);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-m);margin-bottom:8px}
.req{color:var(--g2)}
.upload-zone{position:relative;border:2px dashed var(--bd-gold);border-radius:var(--rl);overflow:hidden;transition:all .2s;cursor:pointer;background:var(--bg-card)}
.upload-zone:hover{border-color:var(--b3);background:var(--b0)}
.upload-zone.drag-over{border-color:var(--b3);background:var(--b0)}
.upload-placeholder{padding:52px 24px;text-align:center}
.upload-icon{font-size:44px;display:block;margin-bottom:16px}
.upload-placeholder p{color:var(--tx-m);margin-bottom:6px}
.upload-placeholder small{color:var(--tx-d);font-size:13px}
.upload-preview{width:100%;max-height:320px;object-fit:contain;display:block}
.upload-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.hidden{display:none!important}
.form-footer{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:40px}
.submit-note{font-size:13px;color:var(--tx-d)}

/* ────────────────────────────────────────────
   CERTIFICATE
──────────────────────────────────────────── */
.cert-page{padding:60px 0 80px}
.cert-wrap{max-width:780px;margin:0 auto 32px;width:100%;box-sizing:border-box;padding:0 4px}
.cert-frame{
  background:linear-gradient(160deg,#FFFDF5,#FFF8E8,#FFFDF5);
  border:2px solid var(--bd-gold);border-radius:var(--rl);
  padding:60px;position:relative;overflow:hidden;
  box-shadow:var(--sh-l),var(--sh-g);
}
.cert-border-outer{position:absolute;inset:10px;border:1px solid rgba(176,128,16,.2);border-radius:8px;pointer-events:none}
.cert-border-inner{position:absolute;inset:18px;border:1px solid rgba(28,61,122,.08);border-radius:6px;pointer-events:none}
.cert-watermark{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none}
.cert-watermark span{font-family:var(--fH);font-size:clamp(12px,2vw,18px);letter-spacing:.18em;text-transform:uppercase;color:rgba(28,61,122,.15);border:2px solid rgba(28,61,122,.1);padding:10px 24px;border-radius:4px;transform:rotate(-22deg);white-space:nowrap}
.cert-header{text-align:center;margin-bottom:24px}
.cert-glyph{font-size:52px;display:block;margin-bottom:10px;filter:drop-shadow(0 2px 8px rgba(176,128,16,.3))}
.cert-org{font-family:var(--fD);font-size:14px;letter-spacing:.32em;color:var(--b3);margin-bottom:12px}
.cert-title{font-family:var(--fD);font-size:clamp(20px,3vw,30px);color:var(--tx);line-height:1.3}
.cert-divider{height:2px;background:linear-gradient(to right,transparent,var(--g2),var(--b3),var(--g2),transparent);margin:24px 0}
.cert-body{text-align:center}
.cert-declares{color:var(--tx-m);font-style:italic;margin-bottom:20px}
.cert-cat-photo-wrap{width:160px;height:160px;border-radius:50%;overflow:hidden;border:3px solid var(--g2);margin:0 auto 20px;box-shadow:var(--sh-m),var(--sh-g)}
.cert-cat-photo{width:100%;height:100%;object-fit:cover}
.cert-cat-name{font-family:var(--fD);font-size:clamp(22px,3vw,36px);color:var(--b3);margin-bottom:6px}
.cert-cat-owner{color:var(--tx-m);font-style:italic;margin-bottom:4px}
.cert-cat-country{color:var(--tx-d);margin-bottom:16px}
.cert-conferred{color:var(--tx-m);font-style:italic;margin-bottom:8px}
.cert-rank{font-family:var(--fH);font-size:22px;font-weight:700;margin-bottom:12px}
.cert-stats{color:var(--tx-m);font-size:14px}
.cert-footer{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;align-items:end;text-align:center}
.cert-seal-inner{font-size:40px;display:block;margin-bottom:4px;filter:drop-shadow(0 2px 8px rgba(176,128,16,.3))}
.cert-seal p{font-family:var(--fH);font-size:9px;letter-spacing:.2em;color:var(--tx-d)}
.cert-sig-line{font-family:var(--fD);font-size:26px;color:var(--b3)}
.cert-sig-title{font-family:var(--fH);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-d)}
.cert-issued{color:var(--tx-d);font-size:12px}
.cert-hieroglyphs{text-align:center;font-size:18px;color:var(--g2);margin-top:20px;letter-spacing:.22em;opacity:.25}
.cert-badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:10px}
.cert-badge-chip{padding:3px 10px;border:1px solid;border-radius:var(--rx);font-family:var(--fH);font-size:10px}
.cert-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.cert-payment-box{max-width:560px;margin:32px auto 0;background:var(--bg-card);border:2px solid var(--bd-lap);border-radius:var(--rx);padding:36px 24px;text-align:center;box-shadow:var(--sh-m),var(--sh-b);box-sizing:border-box;width:100%}
.cert-payment-icon{font-size:48px;display:block;margin-bottom:14px}
.cert-payment-title{font-family:var(--fH);font-size:20px;color:var(--b3);margin-bottom:10px;word-break:break-word}
.cert-payment-desc{color:var(--tx-m);font-size:clamp(13px,3vw,15px);line-height:1.7;margin-bottom:18px}
.cert-payment-price{font-family:var(--fH);font-size:clamp(20px,6vw,32px);color:var(--b3);margin-bottom:22px;font-weight:700}
.cert-payment-note{color:var(--tx-d);font-size:12px;margin-top:14px;font-style:italic}
.cert-payment-box .btn{width:100%;max-width:100%;white-space:normal;word-break:break-word;line-height:1.4;height:auto;padding:14px 16px}

/* ────────────────────────────────────────────
   MISC
──────────────────────────────────────────── */
.status-page{padding:100px 0}
.status-box{max-width:500px;margin:0 auto;text-align:center;padding:64px 40px;background:var(--bg-card);border-radius:var(--rx);border:1.5px solid var(--bd);box-shadow:var(--sh-l)}
.status-icon{font-size:64px;display:block;margin-bottom:24px}
.status-success .status-icon{color:var(--t2)}
.status-cancel  .status-icon{color:#DC2626}
.status-detail{color:var(--tx-m);margin:12px 0 24px}
.about-page{padding:60px 0 80px}
.about-content{max-width:700px;margin:0 auto}
.about-content p{margin-bottom:20px;color:var(--tx-w);font-size:18px;line-height:1.8}
.about-content h2{font-size:28px;margin:36px 0 14px;color:var(--b3)}
.about-content ul{list-style:none;padding:0;margin-bottom:24px}
.about-content ul li{padding:10px 0 10px 26px;border-bottom:1px solid var(--bd);color:var(--tx-m);position:relative}
.about-content ul li::before{content:'𓂀';position:absolute;left:0;color:var(--t2);font-size:13px}
.empty-state{text-align:center;padding:80px 20px;color:var(--tx-d)}
.empty-glyph{font-size:52px;display:block;margin-bottom:16px}
.pp-modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.65);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  z-index:2000;display:flex;align-items:center;justify-content:center;
  padding:16px;
}
.pp-modal{
  background:linear-gradient(160deg,var(--s0),var(--s1));
  border:3px solid var(--g2);border-radius:var(--rx);
  padding:40px 36px 32px;
  max-width:460px;width:100%;text-align:center;
  box-shadow:var(--sh-l),var(--sh-g),0 0 80px rgba(212,165,32,.1);
  position:relative;
  animation:ppModalPop .35s cubic-bezier(.34,1.56,.64,1);
  max-height:90vh;overflow-y:auto;
}
@keyframes ppModalPop{0%{transform:scale(.88);opacity:0}60%{transform:scale(1.03)}100%{transform:scale(1);opacity:1}}
.pp-modal-close{
  position:absolute;top:14px;right:16px;
  background:none;border:none;font-size:18px;cursor:pointer;
  color:var(--tx-d);padding:4px 8px;border-radius:var(--r);transition:all .2s;
}
.pp-modal-close:hover{color:var(--b3);background:var(--b0)}
.pp-modal-icon{font-size:56px;margin-bottom:12px;display:block;line-height:1;filter:drop-shadow(0 4px 12px rgba(176,128,16,.3))}
.pp-modal-title{font-family:var(--fD);font-size:clamp(18px,3vw,26px);color:var(--b3);margin-bottom:10px}
.pp-modal-desc{font-family:var(--fB);font-size:15px;color:var(--tx-m);margin-bottom:14px;line-height:1.65;font-style:italic}
.pp-modal-price{
  font-family:var(--fH);font-size:28px;font-weight:700;color:var(--lapis,var(--b3));
  margin-bottom:16px;
}
.pp-modal-divider{height:2px;background:linear-gradient(90deg,transparent,var(--g2),transparent);margin-bottom:20px}
#paypal-button-container{min-height:50px;margin-bottom:8px}
.pp-close{margin-top:8px;font-size:11px!important;color:var(--tx-d)!important;border-color:var(--bd)!important}
.pp-close:hover{color:var(--tx-m)!important;border-color:var(--tx-d)!important}

@media(max-width:480px){
  .pp-modal{padding:32px 20px 24px;border-radius:16px}
  .pp-modal-icon{font-size:44px}
  .pp-modal-title{font-size:18px}
  .pp-modal-price{font-size:22px}
}
.alert{padding:14px 20px;border-radius:var(--r);margin-bottom:24px;font-size:16px}
.alert-error{background:#FEF2F2;border:1.5px solid #FECACA;color:#DC2626}
.alert-success{background:var(--t1);border:1.5px solid rgba(0,153,136,.3);color:var(--t3)}
.free-badge{color:var(--t2)!important;font-weight:700;font-family:var(--fH)}

/* ────────────────────────────────────────────
   FOOTER — ETERNAL ARCHIVE
──────────────────────────────────────────── */
.footer{
  background:linear-gradient(135deg,var(--b4),var(--b3),var(--b4));
  padding:64px 0 44px;margin-top:80px;
  border-top:4px solid var(--g2);position:relative;
}
/* Gold shimmer top bar */
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,transparent,var(--g2),var(--g1),var(--t2),var(--g1),var(--g2),transparent);
  background-size:400%;animation:slideB 10s linear infinite;pointer-events:none;
}
/* Hieroglyph frieze */
.footer::after{
  content:'𓂀 𓃒 𓁀 𓃠 𓂸 𓁦 𓃒 𓂀 𓃠 𓁦 𓂸 𓃒 𓂀';
  position:absolute;bottom:0;left:0;right:0;
  text-align:center;font-size:15px;letter-spacing:.35em;
  color:rgba(255,255,255,.06);padding-bottom:8px;pointer-events:none;
}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 24px;text-align:center}
.footer-brand{margin-bottom:30px}
.footer-brand .logo-glyph{
  font-size:36px;display:block;margin-bottom:10px;
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 0 10px rgba(176,128,16,.3));animation:gFloat 4s ease-in-out infinite;
}
.footer-brand .logo-text{font-family:var(--fD);font-size:24px;color:var(--s0);display:block;margin-bottom:8px}
.footer-tagline{color:rgba(255,255,255,.35);font-size:14px;font-style:italic;letter-spacing:.06em}
.footer-nav{display:flex;justify-content:center;flex-wrap:wrap;gap:30px;margin-bottom:32px}
.footer-nav a{color:rgba(255,255,255,.5);font-family:var(--fH);font-size:11px;letter-spacing:.1em;text-transform:uppercase;transition:color .2s}
.footer-nav a:hover{color:var(--g1)}
.footer-copy{color:rgba(255,255,255,.2);font-size:13px}
.footer-copy a{color:rgba(255,255,255,.35)}.footer-copy a:hover{color:var(--g1)}

/* ────────────────────────────────────────────
   PRINT
──────────────────────────────────────────── */
@media print{
  .nav,.footer,.cert-actions,.music-nav-btn{display:none!important}
  body{background:#fff;color:#1A1206}
  .cert-frame{border:2px solid #B08010!important;box-shadow:none!important;background:#FFFDF5!important}
}

/* ────────────────────────────────────────────
   RESPONSIVE
──────────────────────────────────────────── */
@media (max-width:960px){
  .hero-content-wrap{grid-template-columns:1fr}
  .hero-statue{display:none}
  .yuki-throne-card{grid-template-columns:1fr}
  .yuki-img-frame{height:320px}
  .yuki-img-overlay{background:linear-gradient(to top,var(--bg-card) 0%,transparent 50%)}
  .cat-profile-grid{grid-template-columns:1fr}
  .cat-photo-frame{max-width:380px;margin:0 auto}
  .profile-stats-row{grid-template-columns:repeat(2,1fr)}
  .cert-footer{grid-template-columns:1fr;gap:24px}
  .cert-frame{padding:40px 32px}
  .cert-payment-box{padding:28px 16px;margin:20px auto 0}
}
@media (max-width:768px){
  /* ── STICKY HEADER ── */
  .nav{position:sticky;top:0;z-index:900;overflow:visible}
  .nav-inner{
    height:62px;padding:0 16px;
    flex-wrap:nowrap;justify-content:space-between;
    overflow:visible;
  }
  /* Logo compact */
  .nav-logo{gap:8px}
  .logo-text{font-size:16px}
  .logo-glyph{font-size:24px}
  /* Hide desktop links */
  .nav-links{
    display:none;
    flex-direction:column;
    position:absolute;top:62px;left:0;right:0;
    background:#FDFBF5;
    border-bottom:3px solid #D4A520;
    padding:8px 0 12px;gap:0;
    box-shadow:0 8px 30px rgba(60,44,16,.18);
    z-index:901;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{
    display:flex;align-items:center;gap:10px;
    padding:13px 20px;font-size:13px;font-weight:600;
    border-bottom:1px solid rgba(176,128,16,.12);
    color:#1C3D7A;border-radius:0;
  }
  .nav-links a:hover{background:#EBF0FA;color:#1C3D7A}
  .nav-links a .nav-icon{font-size:16px;opacity:1}
  .nav-links li:last-of-type a{border-bottom:none}
  .nav-cta{
    margin:8px 16px 4px !important;
    border-radius:8px !important;
    justify-content:center !important;
    padding:13px 20px !important;
    background:linear-gradient(135deg,#3A2C04,#B08010,#D4A520) !important;
    color:#FFFBEC !important;
    border:none !important;
    font-size:12px !important;
    font-weight:700 !important;
    box-shadow:0 4px 16px rgba(176,128,16,.25) !important;
    width:calc(100% - 32px) !important;
  }
  /* Hide music btn in mobile menu, show in topbar */
  /* Show hamburger */
  .nav-toggle{display:flex}
  /* Show mobile right (CTA pill + hamburger) */
  .nav-mobile-right{display:flex}
  .hero{padding:80px 0 120px;min-height:auto}
  .hero-title{font-size:clamp(34px,9vw,60px)}
  .hero-pyramids{height:200px}
  .pyramid.p-bg{border-left-width:150px;border-right-width:150px;border-bottom-width:260px}
  .pyramid.p-l,.pyramid.p-sm{display:none}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%;justify-content:center}
  .home-duel-arena{grid-template-columns:1fr}
  .home-duel-vs{order:-1;flex-direction:row;justify-content:center}
  .upgrade-cards{grid-template-columns:1fr}
  .cats-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
  .profile-actions{flex-direction:column}
  .profile-actions .btn{width:100%;justify-content:center}
  .duel-page .duel-arena,.duel-arena-wrap .duel-arena{grid-template-columns:1fr}
  .yuki-right{padding:30px 26px}
  .cta-section{padding:60px 0 90px}
  .cta-inner{padding:60px 24px}
  .cta-main-btn{display:flex!important;width:100%;max-width:100%;justify-content:center}
  .cta-btn-wrap{padding:0 16px}
  .home-duel-card{padding:44px 24px}
  .stats-band-inner{flex-wrap:wrap}
  .stat-pill{padding:20px 22px;flex:1;min-width:130px}
  .page-nav-inner{grid-template-columns:1fr 1fr}
  .page-nav-center{display:none}
  .profile-right-card{padding:24px 20px}
  .profile-stats-row{grid-template-columns:repeat(2,1fr)}
  .cat-photo-frame{max-width:320px;width:100%;margin:0 auto}
  .cat-profile-grid{gap:20px}
  .profile-right-card{padding:20px 16px}
  .upgrade-cards{grid-template-columns:1fr 1fr}
  .cat-nav-strip{flex-direction:column;gap:6px}
  /* Ranking search bar */
  .ranking-search-form{flex-direction:column;gap:8px}
  .ranking-search-form > div{min-width:0!important}
  .ranking-search-form .btn{width:100%;justify-content:center}
}
@media (max-width:480px){
  .container{padding-left:14px;padding-right:14px}
  .cats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  /* Cat profile mobile */
  .cat-profile-page{padding:20px 0 60px}
  .cat-profile-grid{grid-template-columns:1fr;gap:20px}
  .cat-photo-frame{max-width:280px;width:100%;margin:0 auto}
  .profile-stats-row{grid-template-columns:repeat(2,1fr);gap:8px}
  .stat-box{padding:14px 10px}
  .profile-name{font-size:clamp(22px,6vw,36px)}
  .profile-right-card{padding:18px 14px}
  .share-buttons{gap:6px}
  .share-btn{padding:10px 6px;font-size:12px}
  .upgrade-cards{grid-template-columns:1fr 1fr;gap:8px}
  .upgrade-card{padding:12px 10px}
  .upgrade-icon{font-size:22px}
  .upgrade-name{font-size:10px}
  .upgrade-price{font-size:11px}
  .rival-card{padding:14px 14px}
  .yuki-offering-wrap{padding:20px 14px}
  .yuki-amount-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .yuki-amount-btn{padding:9px 4px;font-size:10px}
  .yuki-offering-cta{padding:13px 16px;font-size:11px}
  .cat-nav-strip{gap:6px}
  .cat-nav-btn{padding:8px 10px}
  .profile-badges{padding:14px 12px}
  .rank-progress-section{padding:14px 12px}
  .profile-stats-row{grid-template-columns:repeat(2,1fr)}

  .profile-right-card{padding:20px 16px}
  .profile-name{font-size:clamp(24px,8vw,48px)}
  .upgrade-cards{grid-template-columns:1fr}
  .share-buttons{flex-wrap:wrap}
  .share-btn{flex:none;width:calc(50% - 4px);min-width:0}
  .profile-actions .btn{width:100%;justify-content:center;font-size:12px;padding:12px 16px}
  .badges-list{gap:6px}
  .badge-item{padding:6px 12px;font-size:10px}
  .stat-num{font-size:22px}
  .cta-title{font-size:18px}
  .cta-main-btn{font-size:12px;padding:14px 20px}
  .stat-pill-divider{display:none}
  .cert-frame{padding:28px 18px}
  .page-nav-link{padding:18px 16px;gap:10px}
  .page-nav-icon{width:40px;height:40px;font-size:22px}
  .page-nav-title{font-size:11px}
}

/* ── BACK TO TOP ── */
.back-to-top{
  position:fixed;bottom:28px;right:24px;z-index:9990;
  width:52px;height:52px;border-radius:50%;
  background:#1C3D7A !important;
  color:#FFFFFF !important;
  border:3px solid #D4A520;
  box-shadow:0 0 0 5px rgba(212,165,32,.2),0 6px 24px rgba(28,61,122,.35);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:900;cursor:pointer;
  transition:all .3s;
  opacity:0;transform:translateY(16px);
  pointer-events:none;
}
.back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.back-to-top:hover{
  background:#2A5098 !important;
  transform:translateY(-4px);
  box-shadow:0 0 0 6px rgba(212,165,32,.3),0 10px 32px rgba(28,61,122,.45);
}

/* ── FLOATING CTA (mobile only) ── */
.floating-cta{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(20px);
  z-index:799;
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 32px;
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1));
  color:var(--g5)!important;
  border-radius:var(--rx);
  font-family:var(--fH);font-size:12px;font-weight:700;letter-spacing:.08em;
  text-decoration:none;white-space:nowrap;
  box-shadow:0 8px 30px rgba(176,128,16,.35),0 0 0 3px rgba(212,165,32,.15);
  transition:opacity .3s,transform .3s;
  opacity:0;
  pointer-events:none;
}
.floating-cta.visible{
  opacity:1;
  transform:translateX(-50%) translateY(0);
  pointer-events:auto;
}
.floating-cta:hover{
  box-shadow:0 12px 40px rgba(176,128,16,.5);
  transform:translateX(-50%) translateY(-3px);
}

@media (max-width:768px){
  .back-to-top{bottom:84px}
}
@media (max-width:480px){
  .floating-cta{padding:12px 24px;font-size:11px;width:calc(100% - 48px)}
  .floating-cta{justify-content:center}
}

/* ════════════════════════════════════════════
   GAMIFICATION — Rank Progress · Rivals · Live
   ════════════════════════════════════════════ */

/* ── Rank Progress Bar ── */
.rank-progress-section{
  background:var(--bg-card);border:1.5px solid var(--bd);border-radius:var(--rl);
  padding:18px 20px;margin-bottom:20px;box-shadow:var(--sh);
}
.rank-progress-header{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;
}
.rank-progress-label{
  font-family:var(--fH);font-size:11px;font-weight:700;color:var(--b3);letter-spacing:.06em;
}
.rank-progress-pct{
  font-family:var(--fH);font-size:13px;font-weight:700;color:var(--g3);
}
.rank-progress-wrap{position:relative}
.rank-progress-track{
  height:10px;background:var(--bd);border-radius:6px;overflow:hidden;
  box-shadow:inset 0 1px 3px rgba(0,0,0,.08);
}
.rank-progress-fill{
  height:100%;width:0%;border-radius:6px;
  background:linear-gradient(90deg,var(--b3),var(--g2));
  transition:width .8s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
}
.rank-progress-fill::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  animation:progressShimmer 2s ease-in-out infinite;
}
@keyframes progressShimmer{to{left:200%}}
.rank-progress-tooltip{
  position:absolute;top:-38px;left:50%;transform:translateX(-50%) translateY(4px);
  background:var(--b3);color:#FFF;font-family:var(--fH);font-size:10px;
  padding:5px 12px;border-radius:6px;white-space:nowrap;opacity:0;
  transition:all .2s;pointer-events:none;box-shadow:var(--sh-b);
}
.rank-progress-tooltip::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--b3);
}
.rank-progress-tip{
  font-size:12px;color:var(--tx-d);margin-top:8px;font-style:italic;
}

/* ── Social Pressure Bar ── */
.social-pressure-bar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 14px;background:var(--bg-panel);border:1px solid var(--bd);
  border-radius:var(--r);margin-bottom:16px;flex-wrap:wrap;
}
.live-badge{
  display:flex;align-items:center;gap:7px;
  font-family:var(--fH);font-size:10px;font-weight:700;color:var(--red,#DC2626);
  letter-spacing:.06em;
}
.live-dot{
  width:8px;height:8px;border-radius:50%;background:#DC2626;
  box-shadow:0 0 0 3px rgba(220,38,38,.2);
  animation:livePulse 1.5s ease-in-out infinite;display:inline-block;flex-shrink:0;
}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 2px rgba(220,38,38,.3)}50%{box-shadow:0 0 0 6px rgba(220,38,38,.1)}}
.pressure-rank-pos{
  font-family:var(--fH);font-size:10px;color:var(--tx-m);letter-spacing:.04em;
}

/* ── Rival Card ── */
.rival-card{
  background:linear-gradient(135deg,var(--bg-card),color-mix(in srgb,#DC2626 4%,var(--bg-card)));
  border:1.5px solid rgba(220,38,38,.25);border-radius:var(--rl);
  padding:18px 20px;margin-bottom:20px;box-shadow:var(--sh);
  position:relative;overflow:hidden;
}
.rival-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#DC2626,#FF6B6B,#DC2626);
  background-size:200%;animation:slideB 3s linear infinite;pointer-events:none;
}
.rival-header{
  font-family:var(--fH);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:#DC2626;margin-bottom:12px;font-weight:700;
}
.rival-body{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.rival-thumb{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid rgba(220,38,38,.3);flex-shrink:0}
.rival-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.rival-name{font-family:var(--fH);font-size:13px;font-weight:700;color:var(--tx);text-decoration:none}
.rival-name:hover{color:var(--red,#DC2626)}
.rival-rank{font-size:11px;font-weight:600}
.rival-vens{font-size:11px;color:var(--tx-d)}
.rival-progress-track{height:6px;background:rgba(220,38,38,.1);border-radius:3px;overflow:hidden;margin-bottom:8px}
.rival-progress-fill{height:100%;width:0%;border-radius:3px;background:#DC2626;transition:width .8s ease}
.rival-msg{font-size:12px;color:var(--tx-m);font-style:italic;margin-bottom:10px}
.rival-challenge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--fH);font-size:10px;font-weight:700;letter-spacing:.08em;
  color:#DC2626;text-decoration:none;transition:all .2s;
}
.rival-challenge:hover{color:#B71C1C;letter-spacing:.12em}

/* ── Social Pulse Ticker ── */
.social-pulse-section{
  background:var(--b4);border-bottom:2px solid var(--g2);
  padding:10px 0;overflow:hidden;
}
.social-pulse-ticker{
  display:flex;align-items:center;gap:0;
  max-width:1200px;margin:0 auto;padding:0 24px;
  font-family:var(--fH);font-size:10px;letter-spacing:.04em;
  overflow:hidden;position:relative;height:28px;
}
.pulse-live-badge{
  display:flex;align-items:center;gap:6px;
  color:var(--g1);font-weight:700;font-size:10px;letter-spacing:.2em;
  flex-shrink:0;margin-right:20px;
}
.pulse-item{
  position:absolute;left:120px;
  white-space:nowrap;color:rgba(255,255,255,.6);
  opacity:0;transform:translateY(10px);
  transition:all .4s ease;pointer-events:none;
}
.pulse-item.pulse-active{opacity:1;transform:translateY(0)}
.pulse-cat{color:var(--g1);font-weight:700}
.pulse-action{color:rgba(255,255,255,.5)}
.pulse-rank{color:var(--t2)}

/* ── Daily Missions ── */
.daily-missions-wrap{
  background:var(--bg-card);border:1.5px solid var(--bd);border-radius:var(--rl);
  padding:18px 20px;margin-bottom:20px;box-shadow:var(--sh);
}
.missions-title{
  font-family:var(--fH);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--b3);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--bd);
  display:flex;align-items:center;gap:6px;
}
#daily-missions{display:flex;flex-direction:column;gap:10px}
.dm-item{background:var(--bg-panel);border-radius:var(--r);padding:10px 12px}
.dm-top{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.dm-icon{font-size:16px;flex-shrink:0}
.dm-label{font-family:var(--fH);font-size:11px;font-weight:600;color:var(--tx);flex:1}
.dm-prog{font-family:var(--fH);font-size:10px;color:var(--tx-d)}
.dm-bar{height:5px;background:var(--bd);border-radius:3px;overflow:hidden;margin-bottom:4px}
.dm-fill{height:100%;background:linear-gradient(90deg,var(--b3),var(--t2));border-radius:3px;width:0%;transition:width .7s ease}
.dm-reward{font-size:10px;color:var(--g3);font-style:italic}

@media(max-width:600px){
  .rival-body{gap:10px}
  .rival-thumb{width:40px;height:40px}
  .social-pressure-bar{flex-direction:column;gap:6px;text-align:center}
  .pulse-item{left:90px;font-size:9px}
}

/* ── FAVORITES BUTTON ── */
.btn-fav{
  background:var(--bg-card);color:var(--tx-m);
  border:1.5px solid var(--bd);
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .25s;
}
.btn-fav:hover{border-color:rgba(220,38,38,.4);color:#DC2626;background:rgba(220,38,38,.05)}
.btn-fav-active{
  background:rgba(220,38,38,.06)!important;
  color:#DC2626!important;border-color:rgba(220,38,38,.4)!important;
}

/* ── CAT NAV STRIP ── */
.cat-nav-strip{
  display:flex;flex-direction:column;gap:8px;margin-top:12px;
}
.cat-nav-btn{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;
  background:var(--bg-card);border:1.5px solid var(--bd);border-radius:var(--r);
  text-decoration:none;color:var(--tx);transition:all .22s;
}
.cat-nav-btn:hover{border-color:var(--b3);background:var(--b0);transform:translateX(3px)}
.cat-nav-thumb{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1.5px solid var(--bd)}
.cat-nav-info{display:flex;flex-direction:column;gap:1px;min-width:0}
.cat-nav-dir{font-family:var(--fH);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-d)}
.cat-nav-name{font-family:var(--fH);font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--b3)}

/* ════════════════════════════════════════════
   KINGDOM LIVE TICKER
   Sticky under header · Announcements + Events
   ════════════════════════════════════════════ */
.kingdom-ticker{
  position:relative;top:auto;z-index:auto;
  background:linear-gradient(135deg,var(--b4) 0%,var(--b3) 50%,var(--b4) 100%);
  border-bottom:2px solid var(--g2);
  overflow:hidden;
  transition:height .3s ease, opacity .3s ease;
  height:44px;
}
.kingdom-ticker.kt-hidden{
  height:0!important;min-height:0!important;opacity:0;pointer-events:none;
  border:none!important;overflow:hidden;padding:0!important;margin:0!important;
}
.kt-inner{
  max-width:1400px;margin:0 auto;padding:0 16px;
  display:flex;align-items:center;gap:14px;height:44px;
}

/* Badge */
.kt-badge{
  display:flex;align-items:center;gap:6px;flex-shrink:0;
  background:rgba(212,165,32,.15);border:1px solid rgba(212,165,32,.35);
  border-radius:20px;padding:4px 12px;
}
.kt-badge-text{
  font-family:var(--fH);font-size:9px;letter-spacing:.22em;
  font-weight:700;color:var(--g1);text-transform:uppercase;
}

/* Scrolling track */
.kt-track-wrap{
  flex:1;overflow:hidden;position:relative;
  mask-image:linear-gradient(90deg,transparent 0%,black 5%,black 95%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,black 5%,black 95%,transparent 100%);
}
@media(max-width:900px){
  .kt-track-wrap{
    mask-image:none;
    -webkit-mask-image:none;
  }
}
.kt-track{
  display:flex;align-items:center;gap:0;
  white-space:nowrap;
  animation:ktScroll 30s linear infinite;
}
.kt-track:hover{animation-play-state:paused}
@keyframes ktScroll{
  0%   {transform:translateX(0)}
  100% {transform:translateX(-50%)}
}
.kt-item{
  display:inline-flex;align-items:center;gap:8px;
  padding:0 28px;flex-shrink:0;
  font-family:var(--fH);font-size:11px;letter-spacing:.03em;
  color:rgba(255,255,255,.75);
  border-right:1px solid rgba(255,255,255,.08);
}
.kt-item.kt-announcement{color:var(--g1);font-weight:600}
.kt-item.kt-announcement.kt-royal{color:var(--g1)}
.kt-item.kt-announcement.kt-warning{color:#FCA5A5}
.kt-item.kt-announcement.kt-event{color:var(--t2)}
.kt-item a{color:inherit;text-decoration:none;transition:color .2s}
.kt-item a:hover{color:#FFF}
.kt-icon{font-size:14px;flex-shrink:0;filter:drop-shadow(0 0 4px rgba(255,255,255,.3))}
.kt-separator{color:rgba(255,255,255,.15);padding:0 12px;font-size:16px}
.kt-loading{color:rgba(255,255,255,.35);font-style:italic}

/* Yuki announcement special */
.kt-item.kt-royal{
  color:var(--g1)!important;
  text-shadow:0 0 12px rgba(212,165,32,.4);
}
.kt-item.kt-royal .kt-icon{
  filter:drop-shadow(0 0 8px rgba(212,165,32,.6));
  animation:crownGlow 2s ease-in-out infinite;
}

/* Close button */
.kt-close{
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.35);font-size:14px;padding:4px 8px;
  border-radius:4px;flex-shrink:0;transition:all .2s;
  line-height:1;
}
.kt-close:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.08)}

/* Mobile */
@media(max-width:768px){
  .kingdom-ticker{height:38px}
  .kt-inner{height:38px;padding:0 10px;gap:8px}
  .kt-badge{padding:3px 8px}
  .kt-badge-text{font-size:8px}
  .kt-item{font-size:10px;padding:0 18px}
  .kt-icon{font-size:12px}
}
@media(max-width:480px){
  .kt-badge-text{display:none}
  .kt-badge{padding:3px 6px}
  .kt-item{font-size:9px;padding:0 14px}
}

/* ════════════════════════════════════════════
   YUKI VENERATION POPUP
   Appears after 4s · Closed only by venerating
   ════════════════════════════════════════════ */

@keyframes yukiOverlayIn {
  from { opacity:0 }
  to   { opacity:1 }
}
@keyframes yukiBoxIn {
  0%   { opacity:0; transform:translateY(40px) scale(.92) }
  60%  { transform:translateY(-6px) scale(1.02) }
  100% { opacity:1; transform:translateY(0) scale(1) }
}
@keyframes yukiRaysRotate {
  to { transform:translate(-50%,-50%) rotate(360deg) }
}
@keyframes yukiGlyphFloat {
  0%,100% { transform:translateY(0) }
  50%     { transform:translateY(-10px) }
}
@keyframes yukiCrownPulse {
  0%,100% { filter:drop-shadow(0 0 12px rgba(212,165,32,.5)) }
  50%     { filter:drop-shadow(0 0 32px rgba(212,165,32,1)) }
}
@keyframes yukiCtaPulse {
  0%,100% { box-shadow:0 0 0 0 rgba(212,165,32,.5),0 8px 30px rgba(176,128,16,.4) }
  50%     { box-shadow:0 0 0 10px rgba(212,165,32,0),0 8px 30px rgba(176,128,16,.4) }
}
@keyframes yukiNumCount {
  from { opacity:0; transform:scale(.8) }
  to   { opacity:1; transform:scale(1) }
}

/* OVERLAY */
.yuki-popup-overlay {
  position:fixed;inset:0;z-index:9995;
  background:rgba(6,14,40,.82);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .4s ease;
}
.yuki-popup-overlay.yuki-visible {
  opacity:1;pointer-events:auto;
  animation:yukiOverlayIn .4s ease;
}

/* BOX */
.yuki-popup-box {
  position:relative;
  background:linear-gradient(160deg, #0A0B1A 0%, #0F1F3D 45%, #1A0F05 100%);
  border:2px solid var(--g2);
  border-radius:24px;
  padding:52px 40px 36px;
  max-width:440px;width:100%;
  text-align:center;
  overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(212,165,32,.12),
    0 0 80px rgba(212,165,32,.08),
    0 30px 100px rgba(0,0,0,.7);
  transform:translateY(40px) scale(.92);
  opacity:0;
  transition:all .5s cubic-bezier(.34,1.56,.64,1);
}
.yuki-popup-overlay.yuki-visible .yuki-popup-box {
  transform:translateY(0) scale(1);
  opacity:1;
}

/* Rotating rays behind everything */
.yuki-popup-rays {
  position:absolute;
  top:50%;left:50%;
  width:700px;height:700px;
  transform:translate(-50%,-50%);
  background:conic-gradient(
    from 0deg,
    rgba(212,165,32,.06) 0deg, transparent 18deg,
    rgba(28,61,122,.04) 36deg, transparent 54deg,
    rgba(212,165,32,.06) 72deg, transparent 90deg,
    rgba(28,61,122,.04) 108deg, transparent 126deg,
    rgba(212,165,32,.06) 144deg, transparent 162deg,
    rgba(28,61,122,.04) 180deg, transparent 198deg,
    rgba(212,165,32,.06) 216deg, transparent 234deg,
    rgba(28,61,122,.04) 252deg, transparent 270deg,
    rgba(212,165,32,.06) 288deg, transparent 306deg,
    rgba(28,61,122,.04) 324deg, transparent 342deg,
    rgba(212,165,32,.06) 360deg
  );
  animation:yukiRaysRotate 20s linear infinite;
  pointer-events:none;border-radius:50%;
}

/* Top glyph */
.yuki-popup-glyph {
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  font-size:22px;
  background:linear-gradient(135deg,#0A0B1A,#0F1F3D);
  border:2px solid var(--g2);
  border-radius:0 0 14px 14px;
  padding:6px 20px 10px;
  color:var(--g1);
  filter:drop-shadow(0 0 8px rgba(212,165,32,.5));
  z-index:2;letter-spacing:.3em;
}

/* Crown */
.yuki-popup-crown {
  font-size:52px;
  position:relative;z-index:1;
  margin-bottom:6px;
  display:inline-block;
  animation:yukiGlyphFloat 3s ease-in-out infinite, yukiCrownPulse 2.5s ease-in-out infinite;
}

/* Text */
.yuki-popup-eyebrow {
  font-family:var(--fH);font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(212,165,32,.55);
  margin-bottom:8px;
}
.yuki-popup-title {
  font-family:var(--fD);
  font-size:clamp(36px,8vw,58px);
  background:linear-gradient(180deg,#FFF8DC,#F0C848,#D4A520);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;margin-bottom:10px;
  filter:drop-shadow(0 2px 12px rgba(212,165,32,.3));
}
.yuki-popup-sub {
  font-family:var(--fB);font-size:15px;color:rgba(255,255,255,.5);
  line-height:1.7;margin-bottom:20px;font-style:italic;
}

/* Counter */
.yuki-popup-counter {
  display:inline-flex;align-items:baseline;gap:8px;
  background:rgba(212,165,32,.08);border:1px solid rgba(212,165,32,.2);
  border-radius:var(--rx);padding:10px 24px;margin-bottom:24px;
  animation:yukiNumCount .5s ease .6s both;
}
.yuki-popup-ven-num {
  font-family:var(--fH);font-size:28px;font-weight:700;
  color:var(--g1);line-height:1;
}
.yuki-popup-ven-lbl {
  font-family:var(--fH);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(212,165,32,.5);
}

/* CTA — THE main button */
.yuki-popup-cta {
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:16px 24px;
  background:linear-gradient(135deg,#3A2C04,#B08010,#D4A520,#F0C848,#D4A520);
  background-size:200%;
  color:#1A0C00 !important;
  font-family:var(--fH);font-size:13px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;text-decoration:none;
  border:none;border-radius:12px;cursor:pointer;
  margin-bottom:12px;
  animation:yukiCtaPulse 2s ease-in-out infinite;
  transition:transform .2s, background-position .3s;
  position:relative;z-index:2;
}
.yuki-popup-cta:hover {
  transform:translateY(-3px);
  background-position:right;
  color:#1A0C00 !important;
  animation:none;
  box-shadow:0 12px 40px rgba(212,165,32,.45);
}
.yuki-popup-cta-icon {
  font-size:20px;
  filter:drop-shadow(0 0 6px rgba(212,165,32,.5));
}

/* Later link */
.yuki-popup-later {
  background:none;border:none;cursor:pointer;
  font-family:var(--fH);font-size:10px;letter-spacing:.08em;
  color:rgba(255,255,255,.25);transition:color .2s;
  padding:6px;display:block;width:100%;margin-bottom:10px;
}
.yuki-popup-later:hover { color:rgba(255,255,255,.5); }

/* Law text */
.yuki-popup-law {
  font-family:var(--fH);font-size:9px;letter-spacing:.12em;
  color:rgba(212,165,32,.25);text-transform:uppercase;
}

/* RESPONSIVE */
@media(max-width:480px) {
  .yuki-popup-box{padding:44px 24px 28px;border-radius:18px}
  .yuki-popup-title{font-size:44px}
  .yuki-popup-crown{font-size:44px}
  .yuki-popup-sub{font-size:14px}
  .yuki-popup-cta{padding:14px 20px;font-size:12px}
}

/* ════════════════════════════════════════════
   PWA ADD TO HOME SCREEN BANNER
   ════════════════════════════════════════════ */
.pwa-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:8990;
  background:#1C3D7A;
  border-top:3px solid #D4A520;
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.34,1.1,.64,1);
  box-shadow:0 -6px 30px rgba(0,0,0,.3);
}
.pwa-banner.pwa-visible{
  transform:translateY(0);
}
.pwa-banner-inner{
  max-width:960px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:12px 20px;
}
.pwa-banner-left{
  display:flex;align-items:center;gap:12px;flex:1;min-width:0;
}
.pwa-banner-icon{
  width:42px;height:42px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,#B08010,#D4A520);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;box-shadow:0 3px 10px rgba(0,0,0,.25);
  line-height:1;
}
.pwa-banner-text{
  display:flex;flex-direction:column;gap:2px;min-width:0;
}
.pwa-banner-title{
  font-family:'Cinzel',serif;font-size:13px;font-weight:700;
  color:#FFFFFF;letter-spacing:.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pwa-banner-sub{
  font-family:'Cinzel',serif;font-size:10px;
  color:rgba(255,255,255,.5);letter-spacing:.03em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pwa-banner-actions{
  display:flex;align-items:center;gap:8px;flex-shrink:0;
}
.pwa-btn-install{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 18px;
  background:linear-gradient(135deg,#B08010,#D4A520,#F0C848);
  color:#1A0C00 !important;
  font-family:'Cinzel',serif;font-size:11px;font-weight:700;letter-spacing:.06em;
  border:none;border-radius:8px;cursor:pointer;
  box-shadow:0 3px 14px rgba(176,128,16,.4);
  transition:all .2s;white-space:nowrap;
}
.pwa-btn-install:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(176,128,16,.55);
}
.pwa-btn-dismiss{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.55);
  font-size:15px;width:32px;height:32px;
  border-radius:6px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;flex-shrink:0;line-height:1;
}
.pwa-btn-dismiss:hover{
  background:rgba(255,255,255,.2);color:#FFF;
}
.pwa-ios-hint{
  display:none;align-items:center;justify-content:center;gap:8px;
  padding:6px 20px 10px;
  font-family:'Cinzel',serif;font-size:10px;
  color:rgba(255,255,255,.6);letter-spacing:.04em;
  border-top:1px solid rgba(255,255,255,.1);
}
.pwa-ios-hint strong{color:#D4A520}
.pwa-ios-hint svg{flex-shrink:0;opacity:.5}

@media(max-width:640px){
  .pwa-banner-inner{padding:10px 14px;gap:10px}
  .pwa-banner-title{font-size:12px}
  .pwa-banner-sub{display:none}
  .pwa-banner-icon{width:36px;height:36px;font-size:18px}
  .pwa-btn-install{padding:8px 14px;font-size:10px}
}
@media(max-width:400px){
  .pwa-btn-install .pwa-btn-text{display:none}
  .pwa-btn-install{padding:9px 12px}
}

/* ════════════════════════════════════════════
   YUKI OFFERING SECTION — Divine Royal Light
   Papyrus ivory · Lapis · Gold
   ════════════════════════════════════════════ */
.yuki-offering-wrap{
  background:linear-gradient(160deg,var(--g0),#FFFBF0,var(--s2));
  border:2px solid var(--g2);
  border-radius:20px;
  padding:32px 28px;
  margin-top:20px;
  position:relative;
  overflow:hidden;
  box-shadow:var(--sh-l),var(--sh-g),0 0 0 4px rgba(212,165,32,.06);
}
/* Hieroglyph watermark */
.yuki-offering-wrap::before{
  content:'𓂀 𓃒 𓁦 𓃠 𓂸';
  position:absolute;bottom:-8px;right:12px;
  font-size:90px;line-height:1;letter-spacing:.2em;
  color:var(--b3);opacity:.04;
  pointer-events:none;
}
/* Animated gold top border */
.yuki-offering-wrap::after{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--b3),var(--g2),var(--t2),var(--g1),var(--b3));
  background-size:400%;animation:slideB 8s linear infinite;
  pointer-events:none;border-radius:20px 20px 0 0;
}

/* Header */
.yuki-offering-header{
  text-align:center;margin-bottom:24px;
  padding-bottom:18px;
  border-bottom:1px solid var(--bd-gold);
}
.yuki-offering-glyph{
  font-size:40px;display:block;margin-bottom:10px;
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 3px 10px rgba(176,128,16,.25));
  animation:crownGlow 2.5s ease-in-out infinite;
}
.yuki-offering-title{
  font-family:var(--fD);font-size:clamp(17px,2.5vw,22px);
  color:var(--b3);margin-bottom:8px;
  text-shadow:0 1px 8px rgba(28,61,122,.1);
}
.yuki-offering-sub{
  font-family:var(--fB);font-size:14px;color:var(--tx-m);
  line-height:1.7;font-style:italic;
}

/* Amount grid */
.yuki-amount-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  margin-bottom:10px;
}
.yuki-amount-btn{
  padding:12px 8px;border-radius:10px;
  background:var(--bg-card);
  border:1.5px solid var(--bd);
  color:var(--tx-m);
  font-family:var(--fH);font-size:12px;font-weight:700;letter-spacing:.04em;
  cursor:pointer;transition:all .22s;box-shadow:var(--sh);
}
.yuki-amount-btn:hover{
  border-color:var(--g2);color:var(--g3);
  background:var(--gold-bg,#FFFBEC);
  transform:translateY(-2px);box-shadow:var(--sh-m),var(--sh-g);
}
.yuki-amount-btn.selected{
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g2));
  border-color:var(--g2);color:#FFF !important;
  box-shadow:var(--sh-m),var(--sh-g);
  transform:translateY(-2px);
}
.yuki-amount-custom{margin-bottom:14px}
.yuki-amount-input{
  width:100%;padding:10px 14px;
  background:var(--bg-card);
  border:1.5px solid var(--bd);
  border-radius:10px;color:var(--tx);
  font-family:var(--fH);font-size:13px;
  transition:border-color .2s,box-shadow .2s;
}
.yuki-amount-input:focus{
  outline:none;border-color:var(--g2);
  box-shadow:0 0 0 3px rgba(212,165,32,.12);
}

/* From selector */
.yuki-from-section{margin-bottom:12px}
.yuki-from-label{
  display:block;font-family:var(--fH);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--tx-m);margin-bottom:6px;font-weight:600;
}
.yuki-from-select{
  width:100%;padding:10px 14px;
  background:var(--bg-card);
  border:1.5px solid var(--bd);
  border-radius:10px;color:var(--tx);
  font-family:var(--fB);font-size:14px;
  cursor:pointer;transition:border-color .2s;
}
.yuki-from-select:focus{outline:none;border-color:var(--g2)}

/* Message textarea */
.yuki-msg-input{
  width:100%;padding:10px 40px 10px 14px;
  background:var(--bg-card);
  border:1.5px solid var(--bd);
  border-radius:10px;color:var(--tx);
  font-family:var(--fB);font-size:14px;
  resize:vertical;min-height:72px;
  transition:border-color .2s,box-shadow .2s;
  margin-bottom:14px;
}
.yuki-msg-input:focus{
  outline:none;border-color:var(--g2);
  box-shadow:0 0 0 3px rgba(212,165,32,.1);
}

/* CTA button */
.yuki-offering-cta{
  width:100%;padding:15px 20px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g2),var(--g1));
  background-size:200%;
  color:#1A0C00 !important;
  font-family:var(--fH);font-size:13px;font-weight:700;letter-spacing:.1em;
  border:none;border-radius:12px;cursor:pointer;
  transition:all .25s;margin-bottom:10px;
  box-shadow:var(--sh-m),var(--sh-g);
}
.yuki-offering-cta:not(:disabled):hover{
  background-position:right;
  transform:translateY(-3px);
  box-shadow:var(--sh-l),0 0 40px rgba(212,165,32,.25);
}
.yuki-offering-cta:disabled{
  opacity:.5;cursor:not-allowed;
  background:var(--bd);color:var(--tx-d) !important;
  box-shadow:none;
}
.yuki-offering-cta-icon{font-size:18px}
.yuki-offering-secure{
  font-family:var(--fH);font-size:10px;letter-spacing:.06em;
  color:var(--tx-d);text-align:center;
}

@media(max-width:480px){
  .yuki-offering-wrap{padding:22px 16px;border-radius:14px}
  .yuki-amount-grid{gap:6px}
  .yuki-amount-btn{padding:10px 6px;font-size:11px}
  .yuki-offering-title{font-size:17px}
}

/* ── Cat Offering History ── */
.cat-offerings-history{
  background:var(--g0);border:1.5px solid var(--bd-gold);
  border-radius:var(--rl);padding:18px 20px;margin-bottom:20px;
  box-shadow:var(--sh),var(--sh-g);
}
.offerings-history-title{
  font-family:var(--fH);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--g3);margin-bottom:4px;
}
.offerings-total{font-size:13px;color:var(--tx-m);margin-bottom:12px}
.offerings-total strong{color:var(--b3);font-family:var(--fH);font-size:15px}
.offerings-list{display:flex;flex-direction:column;gap:8px}
.offering-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;background:var(--bg-card);
  border:1px solid var(--bd);border-radius:var(--r);
  font-size:13px;
}
.offering-item-icon{font-size:16px;flex-shrink:0;filter:drop-shadow(0 1px 4px rgba(176,128,16,.3))}
.offering-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.offering-item-amount{font-family:var(--fH);font-size:12px;font-weight:700;color:var(--g3)}
.offering-item-msg{font-size:12px;color:var(--tx-d);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.offering-item-date{font-size:11px;color:var(--tx-d);white-space:nowrap;flex-shrink:0}

/* ── Yuki Offering Stats (on Yuki profile) ── */
.yuki-offering-stats{
  display:flex;gap:12px;flex-wrap:wrap;
  background:var(--g0);border:1.5px solid var(--bd-gold);
  border-radius:var(--rl);padding:16px 18px;
  margin-bottom:16px;box-shadow:var(--sh),var(--sh-g);
}
.yuki-offering-stat-item{
  display:flex;align-items:center;gap:10px;flex:1;min-width:120px;
}
.yuki-offering-stat-icon{font-size:24px;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(176,128,16,.3))}
.yuki-offering-stat-num{
  display:block;font-family:var(--fH);font-size:18px;font-weight:700;
  color:var(--g3);line-height:1;
}
.yuki-offering-stat-lbl{
  display:block;font-family:var(--fH);font-size:9px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--tx-d);margin-top:2px;
}
@media(max-width:480px){
  .yuki-offering-stats{flex-direction:column;gap:8px}
}

/* ════════════════════════════════════════════
   YUKI THRONE CTA SECTION
   ════════════════════════════════════════════ */
.yuki-throne-cta{
  padding:80px 0;
  background:linear-gradient(160deg,var(--s2),var(--s1),var(--s2));
  border-top:3px solid var(--g2);
  border-bottom:3px solid var(--g2);
  position:relative;overflow:hidden;
}
.yuki-throne-cta-inner{
  display:grid;grid-template-columns:200px 1fr;
  gap:48px;align-items:center;
  position:relative;z-index:1;
  background:var(--bg-card);
  border:2px solid var(--bd-gold);
  border-radius:var(--rx);
  padding:40px 44px;
  box-shadow:var(--sh-l),var(--sh-g);
  overflow:hidden;
}
.yuki-throne-cta-rays{
  position:absolute;inset:-50%;
  background:radial-gradient(ellipse at 50% 50%,rgba(176,128,16,.06) 0%,transparent 60%);
  pointer-events:none;animation:sunPulse 5s ease-in-out infinite;
}
/* Gold top bar */
.yuki-throne-cta-inner::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--b3),var(--g2),var(--t2),var(--g1),var(--b3));
  background-size:400%;animation:slideB 8s linear infinite;pointer-events:none;
}
.yuki-throne-cta-left{position:relative;flex-shrink:0}
.yuki-throne-cta-img-link{display:block;position:relative;text-decoration:none}
.yuki-throne-cta-photo{
  width:160px;height:160px;border-radius:50%;object-fit:cover;
  border:3px solid var(--g2);
  box-shadow:var(--sh-l),var(--sh-g),0 0 0 6px rgba(212,165,32,.1);
  display:block;margin:0 auto;
  transition:transform .3s;
}
.yuki-throne-cta-img-link:hover .yuki-throne-cta-photo{transform:scale(1.04)}
.yuki-throne-cta-glyph{
  width:160px;height:160px;border-radius:50%;
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g2));
  display:flex;align-items:center;justify-content:center;
  font-size:64px;margin:0 auto;
  box-shadow:var(--sh-l),var(--sh-g);
}
.yuki-throne-cta-crown{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  font-size:26px;z-index:2;
  filter:drop-shadow(0 2px 8px rgba(176,128,16,.5));
  animation:crownGlow 2.5s ease-in-out infinite;
}
.yuki-throne-cta-body{min-width:0}
.yuki-throne-cta-eyebrow{
  font-family:var(--fH);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--g3);display:block;margin-bottom:8px;
}
.yuki-throne-cta-name{
  font-family:var(--fD);font-size:clamp(32px,5vw,56px);
  background:linear-gradient(135deg,var(--g4),var(--g2),var(--g1));
  background-size:200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:shimmer 5s linear infinite;
  line-height:1;margin-bottom:10px;
}
.yuki-throne-cta-desc{
  font-family:var(--fB);font-size:16px;color:var(--tx-m);
  line-height:1.7;font-style:italic;margin-bottom:20px;
}
.yuki-throne-cta-stats{
  display:flex;gap:20px;flex-wrap:wrap;margin-bottom:24px;
}
.yuki-throne-cta-stat{display:flex;flex-direction:column;gap:2px}
.ytcs-num{font-family:var(--fH);font-size:22px;font-weight:700;color:var(--b3)}
.ytcs-lbl{font-family:var(--fH);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx-d)}
.yuki-throne-cta-actions{display:flex;gap:12px;flex-wrap:wrap}

/* Offering card special styling in journal */
.event-card-offering{
  background:linear-gradient(135deg,var(--g0),#FFFBF5) !important;
  border-color:var(--bd-gold) !important;
  box-shadow:var(--sh-m),var(--sh-g) !important;
}
.event-card-offering::before{
  background:linear-gradient(90deg,var(--g2),var(--g1),var(--g2)) !important;
}

@media(max-width:768px){
  .yuki-throne-cta-inner{
    grid-template-columns:1fr;
    text-align:center;padding:28px 20px;gap:20px;
  }
  .yuki-throne-cta-stats{justify-content:center}
  .yuki-throne-cta-actions{justify-content:center}
  .yuki-throne-cta-photo,.yuki-throne-cta-glyph{width:120px;height:120px}
}
@media(max-width:480px){
  .yuki-throne-cta{padding:48px 0}
  .yuki-throne-cta-actions{flex-direction:column}
  .yuki-throne-cta-actions .btn{width:100%;justify-content:center}
}

/* ════════════════════════════════════════════
   YUKI THRONE STRIP — Compact across pages
   ════════════════════════════════════════════ */
.yuki-strip{
  background:linear-gradient(135deg,var(--b4) 0%,var(--b3) 40%,#1A0F05 100%);
  border-bottom:2px solid var(--g2);
  padding:10px 0;
  width:100%;
}
.yuki-strip-inner{
  max-width:1200px;margin:0 auto;padding:0 16px;
  display:flex;align-items:center;gap:10px;
  flex-wrap:nowrap;overflow:hidden;
}
.yuki-strip-glyph{
  font-size:20px;flex-shrink:0;
  color:#FFD700;
  -webkit-text-fill-color:#FFD700;
  filter:drop-shadow(0 0 6px rgba(212,165,32,.7));
  animation:crownGlow 2.5s ease-in-out infinite;
}
.yuki-strip-text{
  font-family:var(--fH);font-size:11px;font-weight:600;
  color:rgba(255,255,255,.8);letter-spacing:.03em;
  flex:1;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.yuki-strip-btn{
  padding:7px 14px;border-radius:7px;
  background:linear-gradient(135deg,#B08010,#D4A520,#F0C848);
  color:#1A0C00 !important;
  font-family:var(--fH);font-size:10px;font-weight:700;letter-spacing:.06em;
  text-decoration:none;white-space:nowrap;flex-shrink:0;
  transition:all .2s;box-shadow:0 2px 8px rgba(176,128,16,.3);
}
.yuki-strip-btn:hover{transform:translateY(-2px);box-shadow:0 5px 16px rgba(176,128,16,.4)}
.yuki-strip-btn-offer{
  background:transparent !important;
  border:1.5px solid rgba(212,165,32,.5);
  color:rgba(255,215,0,.9) !important;
  box-shadow:none;
}
.yuki-strip-btn-offer:hover{background:rgba(212,165,32,.12)!important}

@media(max-width:768px){
  .yuki-strip-inner{gap:8px;padding:0 12px}
  .yuki-strip-text{font-size:10px}
  .yuki-strip-btn{padding:6px 12px;font-size:9px}
}
@media(max-width:480px){
  .yuki-strip-glyph{font-size:16px}
  .yuki-strip-text{font-size:9px}
  .yuki-strip-btn{padding:6px 10px;font-size:8px;letter-spacing:.02em}
  .yuki-strip-btn-offer{display:none}
}
@media(max-width:340px){
  .yuki-strip-text{display:none}
  .yuki-strip-btn-offer{display:none}
}


.btn-venerate{
  background:linear-gradient(135deg,#C41E3A,#E84393,#FF6B35,#FFD700,#E84393,#C41E3A);
  background-size:400% 400%;
  color:#FFF !important;
  border:2px solid transparent;
  font-size:clamp(12px,2.5vw,16px) !important;
  letter-spacing:.06em !important;
  animation:veneratePulse 2s ease-in-out infinite, venShift 4s linear infinite;
  box-shadow:0 0 0 0 rgba(228,67,147,.5),0 4px 16px rgba(196,30,58,.35);
  position:relative;overflow:hidden;
  width:100%;box-sizing:border-box;
  white-space:normal;word-break:break-word;
  text-align:center;
}
.btn-venerate::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.18) 50%,transparent 100%);
  transform:translateX(-100%);
  animation:venShimmer 2.5s ease-in-out infinite;
}
.btn-venerate:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 0 0 4px rgba(228,67,147,.15),0 8px 24px rgba(196,30,58,.45) !important;
  animation:venShift 2s linear infinite !important;
}
.btn-venerate.venerated{
  background:var(--bg-panel) !important;color:var(--tx-m) !important;
  border-color:var(--bd) !important;animation:none !important;
  cursor:default;font-size:13px !important;box-shadow:none !important;
}
.btn-venerate.venerated::before{display:none}
@keyframes venShift{
  0%  {background-position:0% 50%}
  50% {background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes venShimmer{
  0%  {transform:translateX(-100%)}
  60%,100%{transform:translateX(200%)}
}
@keyframes veneratePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(228,67,147,.5),0 6px 24px rgba(196,30,58,.3)}
  50%    {box-shadow:0 0 0 10px rgba(228,67,147,.0),0 8px 32px rgba(196,30,58,.5)}
}

/* ════════════════════════════════════════════
   YUKI BOTTOM CTA — Appears on every page
   ════════════════════════════════════════════ */
.yuki-bottom-cta{
  position:relative;
  background:linear-gradient(160deg,#070D20 0%,#0F1A3A 40%,#1A0C04 100%);
  border-top:3px solid var(--g2);
  padding:56px 0;
  overflow:hidden;
}
.yuki-bottom-cta-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 60% at 20% 50%, rgba(28,61,122,.35) 0%, transparent 70%),
    radial-gradient(ellipse 40% 80% at 80% 50%, rgba(176,128,16,.12) 0%, transparent 70%);
  pointer-events:none;
}
.yuki-bottom-cta::before{
  content:'𓂀 𓃒 𓁦 𓃠 𓂸 𓁦 𓃒 𓂀';
  position:absolute;bottom:-10px;right:0;left:0;
  font-size:100px;line-height:1;letter-spacing:.4em;
  color:#FFF;opacity:.025;pointer-events:none;
  white-space:nowrap;overflow:hidden;
}

.yuki-bottom-cta-inner{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:120px 1fr auto;
  gap:36px;align-items:center;
}

/* Photo */
.yuki-bottom-cta-photo-wrap{
  position:relative;display:block;flex-shrink:0;
  width:100px;height:100px;text-decoration:none;margin:0 auto;
}
.yuki-bottom-cta-photo{
  width:100px;height:100px;border-radius:50%;object-fit:cover;
  border:3px solid var(--g2);
  box-shadow:0 0 0 6px rgba(212,165,32,.1),0 8px 30px rgba(0,0,0,.4);
  transition:transform .3s;display:block;
}
.yuki-bottom-cta-photo-wrap:hover .yuki-bottom-cta-photo{transform:scale(1.06)}
.yuki-bottom-cta-glyph-wrap{
  position:relative;width:100px;height:100px;
  background:linear-gradient(135deg,var(--g5),var(--g3));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 6px rgba(212,165,32,.1),0 8px 30px rgba(0,0,0,.4);
  margin:0 auto;
}
.yuki-bottom-cta-glyph{font-size:48px;line-height:1}
.yuki-bottom-cta-crown{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  font-size:20px;filter:drop-shadow(0 0 8px rgba(212,165,32,.7));
  animation:crownGlow 2.5s ease-in-out infinite;
}

/* Body */
.yuki-bottom-cta-eyebrow{
  font-family:var(--fH);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(212,165,32,.6);display:block;margin-bottom:6px;
}
.yuki-bottom-cta-name{
  font-family:var(--fD);
  font-size:clamp(28px,4vw,48px);
  background:linear-gradient(135deg,#FFF8DC,#F0C848,#D4A520);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.1;margin-bottom:8px;
}
.yuki-bottom-cta-desc{
  font-family:var(--fB);font-size:15px;color:rgba(255,255,255,.45);
  line-height:1.65;font-style:italic;margin-bottom:8px;
}
.yuki-bottom-cta-vens{
  font-family:var(--fH);font-size:11px;color:rgba(255,255,255,.35);
  letter-spacing:.08em;
}
.yuki-bottom-cta-vens span{color:var(--g1);font-size:14px;font-weight:700}

/* Buttons */
.yuki-bottom-cta-actions{
  display:flex;flex-direction:column;gap:10px;flex-shrink:0;min-width:180px;
}
.yuki-bottom-cta-btn-primary{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 24px;
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g1));
  background-size:200%;
  color:#1A0C00 !important;
  font-family:var(--fH);font-size:11px;font-weight:700;letter-spacing:.1em;
  text-decoration:none;border-radius:10px;
  box-shadow:0 4px 20px rgba(176,128,16,.35);
  transition:all .25s;
  animation:shimmer 4s linear infinite;
}
.yuki-bottom-cta-btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 32px rgba(176,128,16,.5);
  color:#1A0C00 !important;
}
.yuki-bottom-cta-btn-icon{font-size:16px}
.yuki-bottom-cta-btn-ghost{
  display:flex;align-items:center;justify-content:center;
  padding:12px 24px;
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(212,165,32,.35);
  color:rgba(212,165,32,.8) !important;
  font-family:var(--fH);font-size:11px;font-weight:700;letter-spacing:.1em;
  text-decoration:none;border-radius:10px;
  transition:all .25s;
}
.yuki-bottom-cta-btn-ghost:hover{
  background:rgba(212,165,32,.1);
  border-color:var(--g2);color:var(--g1) !important;
  transform:translateY(-2px);
}

/* RESPONSIVE */
@media(max-width:860px){
  .yuki-bottom-cta-inner{
    grid-template-columns:90px 1fr;
    grid-template-rows:auto auto;
  }
  .yuki-bottom-cta-actions{
    grid-column:1/-1;
    flex-direction:row;flex-wrap:wrap;
  }
  .yuki-bottom-cta-btn-primary,
  .yuki-bottom-cta-btn-ghost{flex:1;min-width:140px;}
}
@media(max-width:560px){
  .yuki-bottom-cta{padding:36px 0}
  .yuki-bottom-cta-inner{
    grid-template-columns:1fr;text-align:center;gap:18px;
  }
  .yuki-bottom-cta-photo-wrap,
  .yuki-bottom-cta-glyph-wrap{margin:0 auto}
  .yuki-bottom-cta-actions{
    flex-direction:column;
  }
  .yuki-bottom-cta-btn-primary,
  .yuki-bottom-cta-btn-ghost{width:100%;justify-content:center}
  .yuki-bottom-cta-name{font-size:28px}
  .yuki-bottom-cta-desc br{display:none}
}

/* ── Offering Event Card ── */
.event-card-offering{
  background:linear-gradient(135deg,var(--g0),#FFFBF0) !important;
  border-color:var(--bd-gold) !important;
  box-shadow:var(--sh-m),var(--sh-g),0 0 0 1px rgba(212,165,32,.1) !important;
  padding:0 !important;
}
.event-card-offering::before{
  background:linear-gradient(90deg,var(--g5),var(--g2),var(--g1),var(--g2),var(--g5)) !important;
  background-size:200%;animation:slideB 4s linear infinite !important;
}
.offering-card-inner{
  display:flex;gap:16px;padding:18px 20px;align-items:flex-start;
}
.offering-from-avatar{
  display:flex;align-items:center;gap:8px;flex-shrink:0;
}
.offering-from-img{
  width:44px;height:44px;border-radius:50%;object-fit:cover;
  border:2px solid var(--g2);box-shadow:0 2px 8px rgba(176,128,16,.2);
}
.offering-from-placeholder{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--b3),var(--b4));
  color:#FFF;font-family:var(--fH);font-size:18px;font-weight:700;
  display:flex;align-items:center;justify-content:center;text-decoration:none;
}
.offering-anon-avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--bg-panel);border:1.5px solid var(--bd);
  font-size:22px;display:flex;align-items:center;justify-content:center;
}
.offering-arrow{
  font-size:14px;color:var(--g3);font-weight:700;flex-shrink:0;
}
.offering-yuki-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g2));
  font-size:22px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(176,128,16,.3);flex-shrink:0;
  animation:crownGlow 2.5s ease-in-out infinite;
}
.offering-card-body{flex:1;min-width:0}
.offering-card-title{
  font-family:var(--fH);font-size:15px;font-weight:700;
  margin-bottom:8px;line-height:1.4;
  display:flex;flex-wrap:wrap;align-items:baseline;gap:4px;
}
.offering-from-name{
  color:var(--b3);text-decoration:none;font-weight:700;
}
.offering-from-name:hover{color:var(--t2)}
.offering-from-name.anon{color:var(--tx-m);font-style:italic;font-weight:400}
.offering-verb{font-size:13px;color:var(--tx-m);font-weight:400}
.offering-yuki-name{
  color:var(--g3) !important;font-family:var(--fD);font-size:16px;
  text-decoration:none;font-weight:700;
}
.offering-yuki-name:hover{color:var(--g2) !important}
.offering-amount-badge{
  display:inline-flex;align-items:center;
  background:linear-gradient(135deg,var(--g5),var(--g3),var(--g2));
  color:#FFF;
  font-family:var(--fH);font-size:18px;font-weight:700;letter-spacing:.04em;
  padding:6px 18px;border-radius:var(--rx);
  box-shadow:var(--sh-g),0 3px 12px rgba(176,128,16,.2);
  margin-bottom:10px;
}
.offering-message{
  font-family:var(--fB);font-size:14px;font-style:italic;
  color:var(--tx-m);line-height:1.6;
  margin:0 0 10px;padding:10px 16px;
  background:var(--bg-panel);border-left:3px solid var(--g2);
  border-radius:0 var(--r) var(--r) 0;
}
.offering-msg-quote{font-size:18px;color:var(--g3);font-family:Georgia,serif;line-height:1}

@media(max-width:640px){
  .offering-card-inner{flex-direction:column;gap:12px;padding:14px 14px}
  .offering-from-avatar{justify-content:center;flex-wrap:wrap}
  .offering-card-title{justify-content:center;text-align:center;font-size:14px}
  .offering-amount-badge{font-size:15px;padding:5px 14px;margin:0 auto 8px}
  .offering-message{font-size:13px}
}

/* ── Yuki Strip STICKY ── */
.yuki-strip-sticky{
  position:relative;top:auto;z-index:auto;
  box-shadow:0 3px 16px rgba(0,0,0,.2);
}



/* ── Kingdom Ticker Footer ── */
.kingdom-ticker-footer{
  position:relative;
  border-top:2px solid var(--g2);
  border-bottom:2px solid var(--g2);
}

/* ════════════════════════════════════
   VIRAL FEATURES — Score Bars · Boost · Pressure
   ════════════════════════════════════ */

/* Social Pressure Hero */
.social-pressure-hero{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;
}
.sph-item{
  font-family:var(--fH);font-size:11px;letter-spacing:.04em;
  padding:7px 12px;border-radius:var(--rx);
  display:inline-flex;align-items:center;gap:6px;
}
.sph-fire{background:rgba(255,107,53,.1);color:#FF6B35;border:1px solid rgba(255,107,53,.25)}
.sph-sword{background:rgba(28,61,122,.08);color:var(--b3);border:1px solid var(--bd-lap)}
.sph-live{background:rgba(220,38,38,.08);color:#DC2626;border:1px solid rgba(220,38,38,.2)}

/* Global Score */
.global-score-wrap{
  background:var(--bg-card);border:1.5px solid var(--bd);border-radius:var(--rl);
  padding:16px 18px;margin-bottom:16px;box-shadow:var(--sh);
}
.global-score-header{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;
}
.global-score-label{
  font-family:var(--fH);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--b3);
}
.global-score-num{
  font-family:var(--fH);font-size:28px;font-weight:700;color:var(--g3);line-height:1;
}
.gscore-row{
  display:flex;align-items:center;gap:10px;margin-bottom:8px;
}
.gscore-label{
  font-family:var(--fH);font-size:10px;letter-spacing:.06em;color:var(--tx-d);
  width:80px;flex-shrink:0;
}
.gscore-track{
  flex:1;height:7px;background:var(--bd);border-radius:4px;overflow:hidden;
}
.gscore-fill{
  height:100%;width:0%;border-radius:4px;
}
.gscore-val{
  font-family:var(--fH);font-size:11px;font-weight:700;color:var(--tx-m);
  width:28px;text-align:right;flex-shrink:0;
}

/* Boost + Legendary buttons */
.profile-actions-viral{display:flex;flex-direction:column;gap:10px}
.profile-actions-row2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.btn-boost{
  padding:12px 16px;border-radius:10px;border:none;cursor:pointer;
  background:linear-gradient(135deg,#FF4500,#FF6B35,#FFD700);
  color:#1A0C00;font-family:var(--fH);font-size:11px;font-weight:700;letter-spacing:.06em;
  transition:all .2s;box-shadow:0 4px 16px rgba(255,107,53,.35);
}
.btn-boost:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(255,107,53,.5)}
.btn-legendary{
  padding:12px 16px;border-radius:10px;border:none;cursor:pointer;
  background:linear-gradient(135deg,#B08010,#D4A520,#F0C848);
  color:#1A0C00;font-family:var(--fH);font-size:11px;font-weight:700;letter-spacing:.06em;
  transition:all .2s;box-shadow:0 4px 16px rgba(176,128,16,.35);
}
.btn-legendary:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(176,128,16,.5)}

/* Period tabs — ranking */
.period-tabs{
  display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;
}
.period-tab{
  padding:8px 16px;border-radius:var(--rx);border:1.5px solid var(--bd);
  background:var(--bg-card);color:var(--tx-m);font-family:var(--fH);
  font-size:10px;font-weight:700;letter-spacing:.08em;text-decoration:none;
  transition:all .2s;
}
.period-tab:hover{border-color:var(--b3);color:var(--b3)}
.period-tab.active{background:var(--b3);color:#FFF;border-color:var(--b3)}

@media(max-width:480px){
  .social-pressure-hero{flex-direction:column;gap:6px}
  .sph-item{font-size:10px;padding:6px 10px}
  .profile-actions-row2{grid-template-columns:1fr}
  .gscore-label{width:68px;font-size:9px}
  .global-score-num{font-size:22px}
  .period-tabs{gap:4px}
  .period-tab{padding:7px 12px;font-size:9px}
}

/* ════════════════════════════════════
   COMMUNITY SCORE VOTING
   ════════════════════════════════════ */
.score-vote-count{
  font-family:var(--fH);font-size:9px;letter-spacing:.1em;
  color:var(--tx-d);background:var(--bg-panel);
  padding:2px 8px;border-radius:var(--rx);margin-left:6px;
  border:1px solid var(--bd);
}
.score-vote-panel{
  margin-top:16px;padding-top:16px;
  border-top:1px solid var(--bd);
}
.score-vote-title{
  font-family:var(--fH);font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--b3);margin-bottom:12px;
}
.score-vote-row{
  display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap;
}
.score-vote-lbl{
  font-family:var(--fH);font-size:10px;color:var(--tx-d);
  width:90px;flex-shrink:0;letter-spacing:.04em;
}
.score-stars{
  display:flex;gap:2px;flex:1;
}
.star-btn{
  background:none;border:none;cursor:pointer;
  font-size:16px;color:rgba(0,0,0,.15);padding:2px;
  transition:transform .1s,color .15s;line-height:1;
}
.star-btn:hover{transform:scale(1.3)}
.score-vote-pick{
  font-family:var(--fH);font-size:11px;font-weight:700;
  color:var(--tx-m);width:32px;text-align:right;flex-shrink:0;
}
.score-vote-submit{
  width:100%;margin-top:12px;
  transition:all .2s;
}
.score-vote-submit:disabled{opacity:.45;cursor:not-allowed}
.score-voted-badge{
  margin-top:14px;padding:10px 16px;
  background:rgba(0,122,114,.08);border:1px solid rgba(0,122,114,.2);
  border-radius:var(--r);
  font-family:var(--fH);font-size:11px;font-weight:700;color:var(--t2);
  text-align:center;
}
@keyframes scaleIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}

@media(max-width:480px){
  .score-vote-lbl{width:70px;font-size:9px}
  .star-btn{font-size:14px;padding:1px}
  .score-vote-row{gap:5px}
  .score-vote-pick{width:26px;font-size:10px}
}

