/* ═══════════════════════════════════════════════
   Eternity LastChaos — Main Stylesheet
   ═══════════════════════════════════════════════ */
:root {
  --gold:       #c9a84c;
  --gold-light: #e8ca7a;
  --gold-dim:   #7a6128;
  --blood:      #8b1a1a;
  --blood-l:    #c13030;
  --deep:       #060610;
  --dark1:      #0d0d1a;
  --dark2:      #111122;
  --dark3:      #16162e;
  --dark4:      #1c1c38;
  --panel:      rgba(14,12,28,0.94);
  --text:       #d4c9a8;
  --text-dim:   #7a7060;
  --border:     rgba(201,168,76,0.18);
  --border-h:   rgba(201,168,76,0.45);
}

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

/* Stars */
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 10% 15%,rgba(255,255,255,.5),transparent),
    radial-gradient(1px 1px at 35% 7%, rgba(255,255,255,.35),transparent),
    radial-gradient(1.5px 1.5px at 65% 12%,rgba(255,255,255,.4),transparent),
    radial-gradient(1px 1px at 85% 25%,rgba(255,255,255,.3),transparent),
    radial-gradient(1px 1px at 5% 45%, rgba(255,255,255,.35),transparent),
    radial-gradient(1.5px 1.5px at 28% 60%,rgba(255,255,255,.25),transparent),
    radial-gradient(1px 1px at 55% 75%,rgba(255,255,255,.4),transparent),
    radial-gradient(1px 1px at 88% 70%,rgba(255,255,255,.3),transparent),
    radial-gradient(1px 1px at 20% 88%,rgba(255,255,255,.25),transparent),
    radial-gradient(2px 2px at 50% 50%,rgba(201,168,76,.1),transparent);
}

/* ── NAV ── */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:64px;padding:0 2rem;
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(180deg,rgba(6,6,16,.97) 0%,rgba(6,6,16,.88) 100%);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(14px);
}
.nav-logo{text-decoration:none;display:flex;align-items:center}
.nav-logo-inner{display:flex;align-items:center;gap:.6rem}
.nav-logo-img{height:42px;width:auto;filter:drop-shadow(0 0 8px rgba(100,150,255,.4))}
.nav-eternity{
  font-family:'Cinzel',serif;font-size:.95rem;font-weight:900;
  letter-spacing:.18em;color:var(--gold);
  text-shadow:0 0 20px rgba(201,168,76,.4);
}
.nav-links{display:flex;gap:.15rem;align-items:center}
.nav-links a{
  font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.08em;
  color:var(--text-dim);text-decoration:none;
  padding:.4rem .85rem;border-radius:3px;transition:color .2s,background .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--gold);background:rgba(201,168,76,.07)}
.admin-link{color:#9999ff!important}
.nav-right{display:flex;align-items:center;gap:.6rem}
.nav-user{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.08em;color:var(--gold-dim)}
.nav-cta{
  font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.12em;
  background:linear-gradient(135deg,var(--blood) 0%,#5a0f0f 100%);
  border:1px solid var(--blood-l);color:#f5c5c5;
  padding:.42rem 1.1rem;border-radius:3px;cursor:pointer;
  text-decoration:none;transition:all .2s;white-space:nowrap;
}
.nav-cta:hover{background:linear-gradient(135deg,var(--blood-l) 0%,var(--blood) 100%)}
.nav-cta--outline{background:transparent;border-color:var(--border-h);color:var(--gold)}
.nav-cta--outline:hover{background:rgba(201,168,76,.08)}

/* ── HERO ── */
#hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:80px 2rem 4rem;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-image:url('../img/hero-bg.jpg');
  background-size:cover;background-position:center top;
  filter:brightness(.45) saturate(.7);
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(6,6,16,.3) 0%,rgba(6,6,16,.65) 60%,var(--deep) 100%),
    radial-gradient(ellipse 70% 50% at 50% 40%,rgba(139,26,26,.15),transparent);
}
.hero-content{position:relative;z-index:2;max-width:820px}
.hero-logo{
  margin-bottom:1.2rem;
  animation:fadeUp .8s ease both;
}
.hero-logo img{
  height:clamp(100px,20vw,200px);width:auto;
  filter:drop-shadow(0 0 24px rgba(100,150,255,.55)) drop-shadow(0 0 48px rgba(201,168,76,.2));
  animation:logoGlow 3s ease-in-out infinite alternate;
}
@keyframes logoGlow{
  from{filter:drop-shadow(0 0 16px rgba(100,150,255,.4)) brightness(1.0)}
  to  {filter:drop-shadow(0 0 32px rgba(120,180,255,.7)) drop-shadow(0 0 64px rgba(201,168,76,.25)) brightness(1.1)}
}
.hero-eternity-title{
  font-family:'Cinzel',serif;font-size:clamp(1.1rem,3vw,1.8rem);
  font-weight:400;letter-spacing:.5em;color:var(--gold-dim);
  margin-bottom:.4rem;animation:fadeUp .8s .1s ease both;
}
.hero-sub{
  font-size:1.1rem;font-style:italic;color:var(--text-dim);
  margin:0 0 2rem;animation:fadeUp .8s .25s ease both;
}
.hero-stats{
  display:flex;gap:3rem;justify-content:center;
  margin-bottom:2rem;animation:fadeUp .8s .35s ease both;
}
.hero-stat-num{font-family:'Cinzel',serif;font-size:2rem;font-weight:600;color:var(--gold);display:block}
.hero-stat-lbl{font-size:.72rem;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase}
.hero-actions{display:flex;gap:1rem;justify-content:center;animation:fadeUp .8s .45s ease both}
.btn-primary{
  font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.12em;
  background:linear-gradient(135deg,var(--blood) 0%,#5a0f0f 100%);
  border:1px solid var(--blood-l);color:#f5c5c5;
  padding:.85rem 2rem;border-radius:3px;text-decoration:none;
  transition:all .25s;display:inline-block;
}
.btn-primary:hover{background:linear-gradient(135deg,var(--blood-l) 0%,var(--blood) 100%);transform:translateY(-1px)}
.btn-secondary{
  font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.12em;
  background:transparent;border:1px solid var(--border-h);color:var(--gold);
  padding:.85rem 2rem;border-radius:3px;text-decoration:none;
  transition:all .25s;display:inline-block;
}
.btn-secondary:hover{background:rgba(201,168,76,.08);transform:translateY(-1px)}
.hero-divider{
  width:160px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);
  margin:2rem auto 0;animation:fadeUp .8s .55s ease both;
}

/* ── PAGE ── */
.page-wrap{position:relative;z-index:1;padding-top:80px;min-height:100vh}
.section-head{text-align:center;padding:3rem 2rem 2rem}
.section-title{
  font-family:'Cinzel',serif;font-size:clamp(1.5rem,3vw,2.2rem);
  font-weight:600;color:var(--gold-light);letter-spacing:.08em;
}
.section-title span{color:var(--blood-l)}
.section-sub{font-size:.95rem;color:var(--text-dim);font-style:italic;margin-top:.5rem}
.gold-line{width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);margin:1rem auto 0}
.container{max-width:1100px;margin:0 auto;padding:0 1.5rem 5rem}

/* ── ALERT ── */
.alert{padding:.8rem 1.2rem;border-radius:3px;margin-bottom:1.2rem;font-size:.95rem}
.alert-error{background:rgba(139,26,26,.3);border:1px solid rgba(193,48,48,.4);color:#f5aaaa}
.alert-success{background:rgba(60,180,100,.15);border:1px solid rgba(60,180,100,.35);color:#aaf5c0}

/* ── NEWS ── */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.news-card{
  background:var(--dark3);border:1px solid var(--border);border-radius:4px;
  overflow:hidden;transition:border-color .3s,transform .2s;cursor:pointer;
  text-decoration:none;display:block;color:inherit;
}
.news-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.news-img{
  width:100%;height:130px;
  background:linear-gradient(135deg,var(--dark4) 0%,var(--dark2) 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:2.8rem;border-bottom:1px solid var(--border);
}
.news-body{padding:1.1rem 1.3rem 1.4rem}
.news-date{font-size:.73rem;color:var(--text-dim);margin-bottom:.35rem;letter-spacing:.04em}
.news-tag{
  display:inline-block;font-family:'Cinzel',serif;font-size:.58rem;
  letter-spacing:.18em;padding:.22rem .55rem;border-radius:2px;margin-bottom:.5rem;
}
.tag-update{background:rgba(139,26,26,.4);color:#f5c5c5;border:1px solid rgba(193,48,48,.4)}
.tag-event {background:rgba(201,168,76,.15);color:var(--gold);border:1px solid var(--border)}
.tag-patch {background:rgba(28,28,56,.8);color:#9999ff;border:1px solid rgba(100,100,200,.3)}
.news-card-title{font-family:'Cinzel',serif;font-size:.95rem;font-weight:600;color:var(--gold-light);line-height:1.4;margin-bottom:.55rem}
.news-excerpt{font-size:.88rem;color:var(--text-dim);line-height:1.6}

/* News detail */
.news-detail{max-width:760px;margin:0 auto;padding:0 1.5rem 5rem}
.news-detail-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.news-detail-title{font-family:'Cinzel',serif;font-size:clamp(1.4rem,3vw,2rem);font-weight:600;color:var(--gold-light);margin:.6rem 0}
.news-detail-body{font-size:1.05rem;line-height:1.9;color:var(--text)}
.news-detail-body p{margin-bottom:1rem}
.news-detail-body strong{color:var(--gold-light)}
.news-detail-body em{color:var(--text-dim)}
.back-link{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.1em;color:var(--gold-dim);text-decoration:none}
.back-link:hover{color:var(--gold)}

/* ── RANKING TABS ── */
.rank-tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.rank-tab{
  font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.1em;
  padding:.48rem 1.2rem;border:1px solid var(--border);background:transparent;
  color:var(--text-dim);border-radius:2px;cursor:pointer;text-decoration:none;
  transition:all .2s;display:inline-block;
}
.rank-tab:hover,.rank-tab.active{color:var(--gold);border-color:var(--border-h);background:rgba(201,168,76,.07)}

/* ── TABLE ── */
.rank-table{width:100%;border-collapse:collapse;font-size:.93rem}
.rank-table thead tr{border-bottom:1px solid var(--border)}
.rank-table th{
  font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.14em;
  color:var(--gold-dim);padding:.65rem 1rem;text-align:left;font-weight:400;
}
.rank-table tbody tr{border-bottom:1px solid rgba(201,168,76,.06);transition:background .15s}
.rank-table tbody tr:hover{background:rgba(201,168,76,.04)}
.rank-table td{padding:.72rem 1rem;color:var(--text)}
.rn{font-family:'Cinzel',serif;font-weight:600;color:var(--text-dim);width:40px}
.rn.g{color:#ffd700}.rn.s{color:#c0c0c0}.rn.b{color:#cd7f32}
.rname{font-weight:600;color:var(--gold-light)}
.rscore{font-family:'Cinzel',serif;font-size:.88rem;color:var(--gold);text-align:right}
.rlvl{color:var(--text-dim);font-size:.88rem;text-align:center}
.rcls{font-size:.78rem;padding:.18rem .48rem;border-radius:2px;letter-spacing:.04em}
.cls-titan   {background:rgba(180,60,60,.2);color:#f5aaaa;border:1px solid rgba(180,60,60,.3)}
.cls-knight  {background:rgba(60,100,200,.2);color:#aabcf5;border:1px solid rgba(60,100,200,.3)}
.cls-healer  {background:rgba(60,180,100,.2);color:#aaf5c0;border:1px solid rgba(60,180,100,.3)}
.cls-mage    {background:rgba(160,60,200,.2);color:#d8aaf5;border:1px solid rgba(160,60,200,.3)}
.cls-rogue   {background:rgba(200,160,60,.2);color:#f5e0aa;border:1px solid rgba(200,160,60,.3)}
.cls-ranger  {background:rgba(60,180,180,.2);color:#aaf5f5;border:1px solid rgba(60,180,180,.3)}
.cls-sorcerer{background:rgba(120,60,200,.2);color:#c5aaf5;border:1px solid rgba(120,60,200,.3)}
.guild-name{font-family:'Cinzel',serif;font-size:.93rem;font-weight:600;color:var(--gold-light)}
.guild-tag{font-size:.78rem;color:var(--text-dim)}

/* ── FORMS / AUTH ── */
.form-page{max-width:460px;margin:0 auto;padding:0 1.5rem 5rem}
.form-panel{
  background:var(--panel);border:1px solid var(--border);border-radius:6px;
  padding:2rem 2.5rem 2.5rem;position:relative;
}
.form-panel::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);
  border-radius:6px 6px 0 0;
}
.form-title{font-family:'Cinzel',serif;font-size:1.2rem;font-weight:600;color:var(--gold-light);text-align:center;margin-bottom:.3rem;letter-spacing:.08em}
.form-subtitle{text-align:center;font-size:.9rem;color:var(--text-dim);font-style:italic;margin-bottom:1.8rem}
.form-group{margin-bottom:1.2rem}
.form-label{display:block;font-family:'Cinzel',serif;font-size:.63rem;letter-spacing:.15em;color:var(--gold-dim);margin-bottom:.45rem}
.form-input,.form-select{
  width:100%;background:rgba(6,6,20,.85);border:1px solid var(--border);border-radius:3px;
  color:var(--text);font-family:'Crimson Pro',serif;font-size:1rem;
  padding:.62rem .9rem;outline:none;transition:border-color .2s;
}
.form-input:focus,.form-select:focus{border-color:var(--gold-dim)}
.form-input::placeholder{color:var(--text-dim);font-style:italic}
.form-select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%237a6128'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9rem center;
}
.form-select option{background:#111122}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{
  width:100%;font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.15em;
  padding:.88rem;
  background:linear-gradient(135deg,var(--blood) 0%,#5a0f0f 100%);
  border:1px solid var(--blood-l);color:#f5c5c5;
  border-radius:3px;cursor:pointer;transition:all .25s;margin-top:.6rem;
}
.form-submit:hover{background:linear-gradient(135deg,var(--blood-l) 0%,var(--blood) 100%)}
.form-hint{text-align:center;font-size:.82rem;color:var(--text-dim);margin-top:1rem}
.form-hint a{color:var(--gold-dim);text-decoration:none}
.form-hint a:hover{color:var(--gold)}

/* ── ADMIN ── */
.admin-wrap{max-width:1000px;margin:0 auto;padding:0 1.5rem 5rem}
.admin-title{font-family:'Cinzel',serif;font-size:1.5rem;color:var(--gold-light);margin-bottom:1.5rem;letter-spacing:.1em}
.admin-nav{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}
.admin-nav a{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.1em;color:var(--text-dim);text-decoration:none;padding:.42rem 1rem;border:1px solid var(--border);border-radius:2px;transition:all .2s}
.admin-nav a:hover,.admin-nav a.active{color:var(--gold);border-color:var(--border-h);background:rgba(201,168,76,.07)}
.admin-card{background:var(--dark3);border:1px solid var(--border);border-radius:4px;padding:1.5rem;margin-bottom:1.5rem}
.admin-card h3{font-family:'Cinzel',serif;font-size:1rem;color:var(--gold);margin-bottom:1rem;letter-spacing:.08em}
.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}
.admin-stat{background:var(--dark4);border:1px solid var(--border);border-radius:3px;padding:1rem;text-align:center}
.admin-stat-val{font-family:'Cinzel',serif;font-size:1.6rem;color:var(--gold);display:block}
.admin-stat-lbl{font-size:.72rem;letter-spacing:.1em;color:var(--text-dim)}
.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}
.admin-table th{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.12em;color:var(--gold-dim);padding:.5rem .8rem;text-align:left;border-bottom:1px solid var(--border)}
.admin-table td{padding:.55rem .8rem;border-bottom:1px solid rgba(201,168,76,.06);color:var(--text)}
.admin-table tr:hover td{background:rgba(201,168,76,.03)}
.badge{display:inline-block;font-size:.65rem;letter-spacing:.08em;padding:.18rem .45rem;border-radius:2px}
.badge-admin{background:rgba(201,168,76,.2);color:var(--gold);border:1px solid var(--border)}
.badge-user{background:rgba(28,28,56,.8);color:#9999ff;border:1px solid rgba(100,100,200,.3)}
.action-link{font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.08em;color:var(--blood-l);text-decoration:none;cursor:pointer}
.action-link:hover{color:#f5aaaa}
.action-link-safe{color:var(--gold-dim)}
.action-link-safe:hover{color:var(--gold)}

/* ── FOOTER ── */
footer{
  position:relative;z-index:1;border-top:1px solid var(--border);
  padding:2rem;text-align:center;
}
.footer-inner{max-width:600px;margin:0 auto}
.footer-logo{font-family:'Cinzel',serif;font-size:1rem;color:var(--gold-dim);margin-bottom:.5rem;letter-spacing:.1em}
.footer-logo span{color:var(--blood-l)}
.footer-text{font-size:.8rem;color:var(--text-dim);margin-bottom:.4rem}
.footer-links a{font-size:.78rem;color:var(--text-dim);text-decoration:none;margin:0 .3rem}
.footer-links a:hover{color:var(--gold)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to  {opacity:1;transform:translateY(0)}
}
.fade-in{animation:fadeUp .55s ease both}

/* ── RESPONSIVE ── */
@media(max-width:640px){
  #navbar{padding:0 1rem}
  .nav-eternity{display:none}
  .nav-links a{font-size:.6rem;padding:.35rem .5rem}
  .hero-stats{gap:1.5rem}
  .form-row{grid-template-columns:1fr}
  .admin-stat-grid{grid-template-columns:1fr 1fr}
}

/* ── NAV USER BUTTON ──────────────────────────────────────────────────────*/
.nav-user-btn {
  font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.08em;
  color:var(--gold-dim);text-decoration:none;
  padding:.38rem .85rem;border:1px solid var(--border);border-radius:3px;
  transition:all .2s;
}
.nav-user-btn:hover,.nav-user-btn.active {
  color:var(--gold);border-color:var(--border-h);background:rgba(201,168,76,.07);
}

/* ── CASTLES STRIP ────────────────────────────────────────────────────────*/
.castles-strip {
  position:relative;z-index:1;
  background:linear-gradient(90deg, rgba(8,8,20,.98) 0%, rgba(16,14,32,.98) 50%, rgba(8,8,20,.98) 100%);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:1.2rem 2rem;
}
.castles-inner {
  max-width:900px;margin:0 auto;
  display:flex;align-items:center;gap:2rem;
  flex-wrap:wrap;
}
.castles-label {
  font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.18em;
  color:var(--gold-dim);white-space:nowrap;
}
.castles-list {
  display:flex;gap:1.5rem;flex-wrap:wrap;flex:1;
}
.castle-card {
  flex:1;min-width:200px;
  background:rgba(16,14,32,.8);border:1px solid var(--border);
  border-radius:4px;padding:.9rem 1.1rem;
  transition:border-color .3s;
}
.castle-card:hover { border-color:var(--border-h); }
.castle-card-top {
  display:flex;align-items:center;gap:.7rem;margin-bottom:.5rem;
}
.castle-icon-img { font-size:1.5rem; }
.castle-card-name {
  font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.1em;
  color:var(--gold-light);font-weight:600;
}
.castle-war { font-size:.72rem;color:var(--blood-l);letter-spacing:.04em;margin-top:.1rem; }
.castle-card-guild {
  font-family:'Cinzel',serif;font-size:1rem;font-weight:600;
  color:var(--gold);margin-bottom:.2rem;
}
.castle-card-char { font-size:.82rem;color:var(--text-dim);font-style:italic; }

/* ── CABINET ──────────────────────────────────────────────────────────────*/
.cabinet-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(440px,1fr));
  gap:1.5rem;
}
.cab-card {
  background:var(--dark3);border:1px solid var(--border);border-radius:4px;
  padding:1.5rem 1.8rem;position:relative;
}
.cab-card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);
  border-radius:4px 4px 0 0;
}
.cab-card-title {
  font-family:'Cinzel',serif;font-size:.9rem;letter-spacing:.12em;
  color:var(--gold);margin-bottom:1.2rem;font-weight:600;
}
.cab-profile { display:flex;gap:1.2rem;align-items:flex-start; }
.cab-avatar {
  width:70px;height:70px;border-radius:4px;
  background:linear-gradient(135deg,var(--dark4),var(--dark2));
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;flex-shrink:0;
}
.cab-info-list { flex:1; }
.cab-info-row {
  display:flex;justify-content:space-between;align-items:center;
  padding:.4rem 0;border-bottom:1px solid rgba(201,168,76,.06);
  font-size:.9rem;
}
.cab-info-row:last-child { border-bottom:none; }
.cab-info-lbl { color:var(--text-dim);font-size:.82rem;letter-spacing:.04em; }
.cab-info-val { color:var(--text);font-weight:600; }

/* ── STATIC PAGES ─────────────────────────────────────────────────────────*/
.static-content { max-width:800px;margin:0 auto; }
.rule-block {
  background:var(--dark3);border:1px solid var(--border);border-radius:4px;
  padding:1.4rem 1.8rem;margin-bottom:1.2rem;
}
.rule-block h3 {
  font-family:'Cinzel',serif;font-size:.95rem;letter-spacing:.1em;
  color:var(--gold);margin-bottom:.9rem;
}
.rule-block ul { padding-left:1.2rem; }
.rule-block li {
  color:var(--text);font-size:.95rem;line-height:1.7;margin-bottom:.35rem;
}
.rule-block p { color:var(--text);font-size:.95rem;line-height:1.7; }
.support-grid {
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:1.2rem;margin-bottom:1.5rem;
}
.support-card {
  background:var(--dark3);border:1px solid var(--border);border-radius:4px;
  padding:1.4rem 1.5rem;text-align:center;
}
.support-icon { font-size:2.2rem;margin-bottom:.7rem; }
.support-card h3 {
  font-family:'Cinzel',serif;font-size:.9rem;letter-spacing:.1em;
  color:var(--gold-light);margin-bottom:.6rem;
}
.support-card p { font-size:.88rem;color:var(--text-dim);line-height:1.6; }
.support-card a:not(.btn-primary):not(.btn-secondary) { color:var(--gold-dim);font-size:.88rem; }
.support-card ul { list-style:none;padding:0;text-align:left; }
.support-card ul li { padding:.3rem 0;border-bottom:1px solid rgba(201,168,76,.06); }

@media(max-width:640px){
  .cabinet-grid { grid-template-columns:1fr; }
  .castles-list { flex-direction:column; }
  .castle-card { min-width:auto; }
  .cab-profile { flex-direction:column; }
}

/* ── HOME PANELS (rates + status) ────────────────────────────────────*/
.home-panels {
  position:relative;z-index:1;
  max-width:1100px;margin:0 auto;padding:2rem 1.5rem 0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
  gap:1.5rem;
}
.home-panel {
  background:var(--dark3);border:1px solid var(--border);border-radius:4px;
  padding:1.4rem 1.8rem;
}
.home-panel-title {
  font-family:'Cinzel',serif;font-size:.82rem;letter-spacing:.14em;
  color:var(--gold);margin-bottom:1.1rem;font-weight:600;
}
/* Rates */
.rates-grid {
  display:grid;grid-template-columns:1fr 1fr;gap:.5rem .8rem;
}
.rate-item {
  display:flex;justify-content:space-between;align-items:center;
  padding:.35rem .6rem;background:rgba(0,0,0,.25);border-radius:3px;
  border:1px solid rgba(201,168,76,.08);
}
.rate-item.rate-full { grid-column:1/-1; }
.rate-lbl { font-size:.78rem;color:var(--text-dim);letter-spacing:.03em; }
.rate-val { font-family:'Cinzel',serif;font-size:.78rem;color:var(--gold);font-weight:600; }
/* Status */
.status-list { display:flex;flex-direction:column;gap:.35rem; }
.status-row {
  display:flex;justify-content:space-between;align-items:center;
  padding:.38rem .6rem;background:rgba(0,0,0,.25);border-radius:3px;
  border:1px solid rgba(201,168,76,.08);font-size:.83rem;
}
.status-row.status-info { border-color:rgba(201,168,76,.04); }
.status-count { font-family:'Cinzel',serif;font-size:.78rem;color:var(--text-dim); }
.srv-online { color:#4caf50;font-size:.78rem;letter-spacing:.04em;display:flex;align-items:center;gap:.3rem; }
.srv-offline { color:var(--blood-l);font-size:.78rem;letter-spacing:.04em; }

/* ── TOPBAR ────────────────────────────────────────────────────────── */
.topbar {
  position:fixed;top:0;left:0;right:0;z-index:300;
  background:linear-gradient(90deg, #0a0208 0%, #12041a 50%, #0a0208 100%);
  border-bottom:1px solid rgba(139,26,26,.5);
  height:38px;
}
.topbar-inner {
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:flex-end;
  height:100%;padding:0 1.5rem;gap:1rem;
}
.topbar-text {
  font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.15em;
  color:var(--text-dim);margin-right:auto;
}
.topbar-btn {
  font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.12em;
  background:linear-gradient(135deg, #5a0f0f 0%, var(--blood-l) 100%);
  border:1px solid var(--blood-l);color:#fff5f5;
  padding:.3rem 1.1rem;border-radius:2px;text-decoration:none;
  transition:all .2s;white-space:nowrap;
  box-shadow:0 0 10px rgba(193,48,48,.3);
}
.topbar-btn:hover {
  background:linear-gradient(135deg, var(--blood-l) 0%, #c13030 100%);
  box-shadow:0 0 18px rgba(193,48,48,.5);
}
.topbar-news {
  font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.1em;
  color:var(--gold-dim);text-decoration:none;transition:color .2s;
}
.topbar-news:hover { color:var(--gold); }

/* Сдвигаем navbar вниз на высоту topbar */
#navbar { top:38px; }
.page-wrap { padding-top:118px; }
#hero { padding-top:118px; }

/* ── GUILD LEGEND ────────────────────────────────────────────────── */
.guild-legend {
  display:flex;gap:1.5rem;margin-bottom:1.2rem;
  font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.08em;
}
.guild-legend-item { display:flex;align-items:center;gap:.4rem; }

/* ── OLT SHOP ────────────────────────────────────────────────────────*/
.olt-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
  gap:1.2rem;
}
.olt-card {
  background:var(--dark3);border:1px solid var(--border);border-radius:6px;
  padding:1.4rem 1.2rem;display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:.5rem;transition:border-color .3s, transform .2s;
}
.olt-card:hover:not(.olt-card--poor) { border-color:var(--border-h); transform:translateY(-2px); }
.olt-card--poor { opacity:.55; filter:grayscale(.4); }
.olt-card-icon  { font-size:2.2rem; }
.olt-card-name  { font-family:'Cinzel',serif;font-size:.88rem;font-weight:600;color:var(--gold-light);line-height:1.3; }
.olt-card-desc  { font-size:.78rem;color:var(--text-dim);font-style:italic; }
.olt-card-count { font-size:.8rem;color:var(--text-dim);background:rgba(0,0,0,.3);padding:.15rem .5rem;border-radius:2px; }
.olt-card-price {
  display:flex;align-items:baseline;gap:.3rem;
  margin-top:.3rem;
}
.olt-price-num {
  font-family:'Cinzel',serif;font-size:1.3rem;font-weight:600;color:silver;
}
.olt-price-lbl { font-size:.72rem;letter-spacing:.1em;color:var(--text-dim); }
.olt-buy-btn {
  width:100%;margin-top:.4rem;
  font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.12em;
  background:linear-gradient(135deg,rgba(100,120,180,.3) 0%,rgba(60,80,140,.3) 100%);
  border:1px solid rgba(100,140,220,.4);color:#aabcf5;
  padding:.55rem .8rem;border-radius:3px;cursor:pointer;transition:all .2s;
}
.olt-buy-btn:hover {
  background:linear-gradient(135deg,rgba(100,120,180,.55) 0%,rgba(60,80,140,.55) 100%);
  border-color:rgba(100,140,220,.7);
}
.olt-buy-btn--disabled {
  width:100%;margin-top:.4rem;
  font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.08em;
  background:transparent;border:1px solid rgba(100,100,100,.3);
  color:var(--text-dim);padding:.55rem .8rem;border-radius:3px;
}

/* ── CHARACTER PROFILE ───────────────────────────────────────────────*/
.char-profile-header {
  display:flex;align-items:flex-start;gap:1.5rem;
  background:var(--dark3);border:1px solid var(--border);border-radius:6px;
  padding:1.5rem 1.8rem;margin-bottom:1.5rem;
}
.char-profile-avatar {
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  width:90px;height:90px;
  background:linear-gradient(135deg,var(--dark4),var(--dark2));
  border:1px solid var(--border);border-radius:6px;
}
.char-profile-name {
  font-family:'Cinzel',serif;font-size:1.6rem;font-weight:600;
  color:var(--gold-light);margin-bottom:.4rem;
}
.char-profile-guild {
  font-size:.88rem;color:var(--text-dim);margin-bottom:.5rem;
}
.char-profile-level { font-size:.95rem;color:var(--text); }

.char-stats-grid {
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.2rem;
}
.char-stat-card {
  background:var(--dark3);border:1px solid var(--border);border-radius:4px;
  padding:1.2rem 1.4rem;position:relative;
}
.char-stat-card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);
  border-radius:4px 4px 0 0;
}
.char-stat-card-title {
  font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.12em;
  color:var(--gold);margin-bottom:1rem;font-weight:600;
}
.char-stat-row {
  display:flex;justify-content:space-between;align-items:center;
  padding:.35rem 0;border-bottom:1px solid rgba(201,168,76,.06);
  font-size:.9rem;
}
.char-stat-row:last-child { border-bottom:none; }
.char-stat-lbl { color:var(--text-dim);font-size:.82rem; }
.char-stat-val { font-family:'Cinzel',serif;font-size:.88rem;color:var(--text);font-weight:600; }

.char-bar-wrap {
  width:100%;height:8px;background:rgba(0,0,0,.4);border-radius:4px;
  overflow:hidden;margin-bottom:.3rem;
}
.char-bar-fill { height:100%;border-radius:4px;transition:width .3s; }
