/* ════════════════════════════════════════════════════════════════
   MYTHRAEL — PAGES CSS v3.4 (FLUID + DOCUMENTED)
   Стили внутренних страниц: /server /clan /castles /bosses /wiki /legal
   ────────────────────────────────────────────────────────────────

   ⚠ ОБЯЗАТЕЛЬНОЕ ПРАВИЛО ОБНОВЛЕНИЯ ⚠
   ────────────────────────────────────────────────────────────
   ПЕРЕД любой правкой/добавлением/удалением в этом файле:
     1. Прочитать актуальную документацию (MDN, web.dev, CSS-Tricks)
        по затрагиваемым CSS-свойствам и паттернам.
     2. Проверить нововведения (container queries, :has, cqi/cqw,
        color-mix, oklch, anchor positioning, view-transitions).
     3. Использовать fluid-переменные из style.css (:root):
          --fs-xs..--fs-4xl  (типографика)
          --sp-1..--sp-8     (отступы)
          --r-sm..--r-pill   (скругления)
        НЕ хардкодить px без необходимости.
     4. После правки — проверить на 6 брейкпоинтах:
        360 / 480 / 768 / 1024 / 1280 / 1440.
     5. Bump VERSION в sw.js и ?v= в HTML.
   ────────────────────────────────────────────────────────────

   СТРУКТУРА:
     1. Hero страниц (page-hero)
     2. Page-content (контейнер тела страницы)
     3. Секции (cfg-section h2/h3)
     4. Карточки рейтов (cfg-grid / cfg-card)
     5. Виталити-блок (vit-row)
     6. Row-list (двухколоночные списки key/value)
     7. Заточка (ench-blocks / ench-table)
     8. Фильтры (filter-bar / flt-btn)
     9. Карточки классов (classes-grid)
    10. Боссы (boss-list)
    11. Инстансы (inst-list)
    12. PvP (olympiad/castles/matrix)
    13. Wiki (wiki-nav)
    14. Download-карточка
    15. Правила (rules-list)
    16. Брейкпоинты страниц (5 диапазонов)
═══════════════════════════════════════════════════════════════ */


/* ── 1. HERO СТРАНИЦ ───────────────────────────────────────── */
.page-hero{
  text-align:center;
  padding:clamp(80px,12vw,140px) var(--cpad) clamp(40px,6vw,64px);
  background:var(--bg-2);
  border-bottom:1px solid var(--brd);
  position:relative;overflow:hidden;
}
/* фоновый радиальный glow (clipped by overflow:hidden) */
.page-hero::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:700px;height:300px;
  background:radial-gradient(ellipse,rgba(200,150,42,0.04) 0%,transparent 70%);
  pointer-events:none;
}
.page-hero h1{
  font-family:var(--ff-h);font-weight:var(--fw-bk);
  font-size:clamp(28px,5vw,56px);
  letter-spacing:0.1em;color:var(--t1);
  margin-bottom:var(--s3);position:relative;
}
.page-hero-sub{font-size:clamp(12px,1.4vw,14px);color:var(--t3);letter-spacing:0.08em;position:relative;}


/* ── 2. PAGE-CONTENT ──────────────────────────────────────── */
.page-content{max-width:960px;margin:0 auto;padding:clamp(32px,5vw,56px) var(--cpad) clamp(60px,8vw,100px);}


/* ── 3. СЕКЦИИ СТРАНИЦ ────────────────────────────────────── */
.cfg-section{margin-bottom:clamp(32px,5vw,52px);}
.cfg-section h2{
  font-family:var(--ff-h);font-weight:var(--fw-b);
  font-size:clamp(14px,1.8vw,18px);
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--gold);margin-bottom:clamp(16px,2vw,24px);
  padding-bottom:10px;
  border-bottom:1px solid var(--brd);
  position:relative;
}
.cfg-section h2::after{
  content:'';position:absolute;bottom:-1px;left:0;width:40px;height:1px;
  background:var(--gold-l);
}
.cfg-section h3{
  font-size:clamp(13px,1.5vw,15px);font-weight:var(--fw-sb);
  color:var(--t2);margin:var(--s5) 0 var(--s3);letter-spacing:0.04em;
}


/* ── 4. КАРТОЧКИ РЕЙТОВ (cfg-grid) ────────────────────────── */
.cfg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1px;background:var(--brd);border:1px solid var(--brd);}
.cfg-card{background:var(--bg-2);padding:clamp(16px,2.5vw,24px) var(--s3);text-align:center;transition:background var(--tr);}
.cfg-card:hover{background:var(--bg-3);}
.cfg-label{font-size:clamp(10px,1vw,11px);color:var(--t4);margin-bottom:8px;letter-spacing:0.1em;text-transform:uppercase;}
.cfg-value{font-family:var(--ff-h);font-weight:var(--fw-bk);font-size:clamp(22px,3vw,32px);color:var(--t2);}
.cfg-value.hi{background:var(--gold-grd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.cfg-note{font-size:clamp(11px,1.2vw,12px);color:var(--t4);margin-top:var(--s3);}


/* ── 5. ВИТАЛИТИ ──────────────────────────────────────────── */
.vit-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--brd);border:1px solid var(--brd);}
.vit-cell{background:var(--bg-2);padding:clamp(16px,2.5vw,24px) var(--s3);text-align:center;transition:background var(--tr);}
.vit-cell:hover{background:var(--bg-3);}
.vit-tier{font-size:clamp(10px,1vw,11px);color:var(--t4);margin-bottom:8px;letter-spacing:0.1em;text-transform:uppercase;}
.vit-mult{font-family:var(--ff-h);font-weight:var(--fw-bk);font-size:clamp(22px,3vw,32px);color:var(--t2);}
.vit-mult.hi{background:var(--gold-grd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}


/* ── 6. ROW-LIST (key/value список) ───────────────────────── */
.row-list{display:flex;flex-direction:column;gap:0;}
.row-item{display:flex;justify-content:space-between;align-items:center;padding:clamp(10px,1.5vw,14px) 0;border-bottom:1px solid var(--brd);gap:var(--s4);}
.row-item:last-child{border-bottom:none;}
.row-item span{color:var(--t3);font-size:clamp(12px,1.4vw,14px);}
.row-item b{color:var(--t1);font-size:clamp(12px,1.4vw,14px);font-weight:var(--fw-sb);text-align:right;}
.row-item b.hi{color:var(--gold-l);}
.row-item b.warn{color:#f0a040;}
.row-item b.bad{color:var(--red);}
.row-list.sm .row-item{padding:7px 0;}


/* ── 7. ЗАТОЧКА (ench-blocks + table) ─────────────────────── */
.ench-blocks{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);margin-bottom:var(--s6);}
.ench-blocks-main{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);margin-bottom:var(--s6);}
.ench-block{background:var(--surf);border:1px solid var(--brd);padding:clamp(16px,2.5vw,24px);}
.ench-table-wrap{overflow-x:auto;}
.ench-table{width:100%;border-collapse:collapse;font-size:clamp(12px,1.3vw,13px);}
.ench-table th{text-align:left;padding:10px 14px;color:var(--t4);border-bottom:1px solid var(--brd);font-size:clamp(10px,1.1vw,11px);font-weight:var(--fw-sb);letter-spacing:0.1em;text-transform:uppercase;}
.ench-table td{padding:9px 14px;border-bottom:1px solid var(--brd);color:var(--t2);}
.ench-table tr:last-child td{border-bottom:none;}
.ench-table tr:hover td{background:var(--surf-2);}


/* ── 8. ФИЛЬТРЫ (filter-bar) ──────────────────────────────── */
.filter-bar{display:flex;flex-wrap:wrap;gap:var(--s2);margin-bottom:var(--s3);}
.flt-btn{
  background:var(--surf);border:1px solid var(--brd);color:var(--t3);
  padding:7px 14px;font-size:clamp(10px,1.1vw,11px);font-weight:var(--fw-m);
  letter-spacing:0.08em;text-transform:uppercase;
  transition:all var(--tr);cursor:pointer;
}
.flt-btn:hover{border-color:var(--brd-2);color:var(--t1);}
.flt-btn.active{background:rgba(200,150,42,0.1);border-color:var(--brd-3);color:var(--gold-l);}


/* ── 9. КАРТОЧКИ КЛАССОВ ──────────────────────────────────── */
.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--s3);margin:var(--s5) 0 var(--s3);}
.class-card{
  background:var(--surf);border:1px solid var(--brd);
  border-left:3px solid;          /* цвет приходит из inline-style по race */
  padding:var(--s4);
  transition:all var(--tr);
}
.class-card:hover{background:var(--surf-2);transform:translateY(-2px);}
.class-name{font-family:var(--ff-h);font-weight:var(--fw-b);font-size:clamp(13px,1.5vw,14px);color:var(--t1);margin-bottom:4px;}
.class-prev{font-size:clamp(11px,1.2vw,12px);margin-bottom:var(--s3);}
.class-tags{display:flex;gap:4px;flex-wrap:wrap;}
.tag-race,.tag-role{font-size:clamp(10px,1vw,11px);padding:2px 7px;background:rgba(200,150,42,0.06);border:1px solid var(--brd);color:var(--t3);}
.classes-count{font-size:clamp(11px,1.2vw,12px);color:var(--t4);margin-top:var(--s2);}


/* ── 10. БОССЫ ────────────────────────────────────────────── */
.boss-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--s4);}
.boss-card.legendary{border-top:2px solid var(--gold);}
.boss-card.epic{border-top:2px solid #8040e0;}
.boss-card.instance{border-top:2px solid #4080ff;}
.boss-tier-label{font-size:clamp(10px,1vw,11px);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:var(--s2);}
.boss-card.legendary .boss-tier-label{color:var(--gold);}
.boss-card.epic .boss-tier-label{color:#a070e8;}
.boss-card.instance .boss-tier-label{color:#6090e8;}
.boss-loc{font-size:clamp(11px,1.2vw,12px);color:var(--t4);margin-bottom:var(--s3);}
.boss-note{font-size:clamp(11px,1.2vw,12px);color:var(--t4);margin-top:var(--s3);font-style:italic;}


/* ── 11. ИНСТАНСЫ ─────────────────────────────────────────── */
.inst-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--s3);}
.inst-card{background:var(--surf);border:1px solid var(--brd);padding:clamp(14px,2vw,18px);transition:background var(--tr);}
.inst-card:hover{background:var(--surf-2);}
.inst-name{font-family:var(--ff-h);font-weight:var(--fw-b);font-size:clamp(13px,1.5vw,15px);color:var(--gold-l);margin-bottom:var(--s3);}


/* ── 12. PVP / ОЛИМП / ЗАМКИ / МАТРИЦА ────────────────────── */
.oly-rewards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3);margin-top:var(--s5);}
.oly-rew-card{background:var(--surf);border:1px solid var(--brd);padding:clamp(14px,2vw,20px);text-align:center;transition:background var(--tr);}
.oly-rew-card:hover{background:var(--surf-2);}
.oly-rew-label{font-size:clamp(10px,1.1vw,11px);color:var(--t3);margin-bottom:var(--s2);letter-spacing:0.08em;text-transform:uppercase;}
.oly-rew-pts{font-family:var(--ff-h);font-weight:var(--fw-bk);font-size:clamp(18px,2.5vw,24px);color:var(--t1);}
.oly-rew-pts.hi{color:var(--gold-l);}
.castle-grid{display:flex;flex-wrap:wrap;gap:var(--s2);margin-top:var(--s3);}
.castle-chip{background:var(--surf);border:1px solid var(--brd);color:var(--t3);padding:5px 12px;font-size:clamp(11px,1.2vw,12px);transition:all var(--tr);}
.castle-chip:hover{border-color:var(--brd-2);color:var(--t1);}
.pvp-matrix{display:flex;flex-direction:column;gap:var(--s2);}
.pvp-row{background:var(--surf);border:1px solid var(--brd);padding:clamp(12px,2vw,16px);display:flex;gap:var(--s4);align-items:flex-start;flex-wrap:wrap;transition:background var(--tr);}
.pvp-row:hover{background:var(--surf-2);}
.pvp-cls{min-width:100px;font-weight:var(--fw-sb);color:var(--gold-l);font-size:clamp(12px,1.4vw,14px);flex-shrink:0;}
.pvp-detail{display:flex;flex-direction:column;gap:4px;flex:1;}
.pvp-beats{font-size:clamp(11px,1.2vw,12px);color:#60c080;}
.pvp-loses{font-size:clamp(11px,1.2vw,12px);color:#e07060;}


/* ── 13. ВИКИ ─────────────────────────────────────────────── */
.wiki-nav{display:flex;flex-wrap:wrap;gap:var(--s2);margin-bottom:var(--s6);}


/* ── 14. СКАЧАТЬ — КАРТОЧКА ───────────────────────────────── */
.dl-card{
  background:var(--surf);border:1px solid var(--brd);
  border-top:2px solid var(--gold);
  padding:clamp(24px,4vw,40px);margin-bottom:var(--s7);text-align:center;
  position:relative;overflow:hidden;
}
.dl-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-l),transparent);
}
.dl-card-title{font-family:var(--ff-h);font-weight:var(--fw-bk);font-size:clamp(18px,2.5vw,26px);letter-spacing:0.08em;color:var(--t1);margin-bottom:var(--s5);}
.dl-info{text-align:left;max-width:420px;margin:0 auto var(--s6);}
.btn-dl{
  background:var(--gold-grd);color:#07060e;
  border:none;padding:clamp(8px,1vw,11px) clamp(20px,3vw,32px);
  font-size:clamp(11px,1.2vw,13px);font-weight:var(--fw-b);
  letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;
  transition:all var(--tr);
}
.btn-dl:hover{box-shadow:0 6px 28px rgba(200,150,42,0.36);transform:translateY(-1px);}
.dl-steps{color:var(--t2);font-size:clamp(13px,1.5vw,14px);line-height:2.2;padding-left:var(--s5);}
.dl-steps b{color:var(--t1);}


/* ── 15. ПРАВИЛА ──────────────────────────────────────────── */
.rules-list{display:flex;flex-direction:column;gap:var(--s3);margin-bottom:var(--s6);}
.rule-block{
  background:var(--surf);border:1px solid var(--brd);
  padding:clamp(14px,2.5vw,20px) clamp(16px,3vw,24px);
  display:flex;gap:var(--s4);align-items:flex-start;
  transition:all var(--tr);
}
.rule-block:hover{background:var(--surf-2);border-color:var(--brd-2);}
.rule-num{
  min-width:clamp(28px,4vw,36px);height:clamp(28px,4vw,36px);
  border:1px solid var(--brd-2);display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-h);font-weight:var(--fw-bk);color:var(--gold);
  font-size:clamp(12px,1.4vw,14px);flex-shrink:0;
}
.rule-title{font-size:clamp(13px,1.5vw,15px);font-weight:var(--fw-sb);color:var(--t1);margin-bottom:4px;}
.rule-text{font-size:clamp(12px,1.3vw,13px);color:var(--t3);line-height:1.6;}
.rules-footer{text-align:center;color:var(--t4);font-size:clamp(12px,1.3vw,13px);padding-top:var(--s6);border-top:1px solid var(--brd);}
.rules-footer a{color:var(--gold);transition:color var(--tr);}
.rules-footer a:hover{color:var(--gold-l);}


/* ════════════════════════════════════════════════════════════════
   16. БРЕЙКПОИНТЫ СТРАНИЦ (5 диапазонов раскладки сеток)
═══════════════════════════════════════════════════════════════ */

/* ── 16.1. ОЧЕНЬ УЗКИЕ <375px ─────────────────────────────── */
@media (max-width:374px){
  .page-hero h1{font-size:24px;letter-spacing:0.06em;}
  .ench-blocks,.ench-blocks-main{grid-template-columns:1fr;}
  .oly-rewards{grid-template-columns:1fr;}
  .vit-row{grid-template-columns:repeat(2,1fr);}
  .cfg-grid{grid-template-columns:repeat(2,1fr);}
  .classes-grid{grid-template-columns:1fr;}
  .boss-list{grid-template-columns:1fr;}
  .inst-list{grid-template-columns:1fr;}
  .dl-info{max-width:100%;}
  .pvp-row{flex-direction:column;gap:var(--s2);}
  .pvp-cls{min-width:unset;}
}

/* ── 16.2. МОБИЛКИ 375-599px ──────────────────────────────── */
@media (min-width:375px) and (max-width:599px){
  .ench-blocks,.ench-blocks-main{grid-template-columns:1fr;}
  .oly-rewards{grid-template-columns:repeat(3,1fr);}
  .vit-row{grid-template-columns:repeat(2,1fr);}
  .cfg-grid{grid-template-columns:repeat(2,1fr);}
  .classes-grid{grid-template-columns:repeat(2,1fr);}
  .boss-list{grid-template-columns:1fr;}
  .inst-list{grid-template-columns:repeat(2,1fr);}
  .pvp-row{flex-direction:column;gap:var(--s2);}
}

/* ── 16.3. ПЛАНШЕТЫ 600-767px ─────────────────────────────── */
@media (min-width:600px) and (max-width:767px){
  .ench-blocks,.ench-blocks-main{grid-template-columns:1fr 1fr;}
  .oly-rewards{grid-template-columns:repeat(3,1fr);}
  .vit-row{grid-template-columns:repeat(4,1fr);}
  .cfg-grid{grid-template-columns:repeat(3,1fr);}
  .classes-grid{grid-template-columns:repeat(3,1fr);}
  .boss-list{grid-template-columns:repeat(2,1fr);}
  .inst-list{grid-template-columns:repeat(2,1fr);}
}

/* ── 16.4. ШИРОКИЕ ПЛАНШЕТЫ 768-1023px ────────────────────── */
@media (min-width:768px) and (max-width:1023px){
  .classes-grid{grid-template-columns:repeat(3,1fr);}
  .boss-list{grid-template-columns:repeat(2,1fr);}
  .inst-list{grid-template-columns:repeat(3,1fr);}
  .oly-rewards{grid-template-columns:repeat(3,1fr);}
}

/* ── 16.5. ДЕСКТОП 1024px+ ────────────────────────────────── */
@media (min-width:1024px){
  .classes-grid{grid-template-columns:repeat(4,1fr);}
  .boss-list{grid-template-columns:repeat(3,1fr);}
  .inst-list{grid-template-columns:repeat(4,1fr);}
}

/* ── 16.6. РАСШИРЕНИЕ КОНТЕЙНЕРА НА БОЛЬШИХ ───────────────── */
@media (min-width:1440px){
  .page-content{max-width:1100px;}
}
@media (min-width:1920px){
  .page-content{max-width:1280px;}
}

/* ── 17. УПЛОТНЕНИЕ <600px ──────────────────────────────── */
@media (max-width:599px){
  .page-hero{padding:80px 14px 28px}
  .page-hero h1{font-size:24px;letter-spacing:0.06em}
  .page-hero-sub{font-size:11px}
  .page-content{padding:24px 14px 48px}
  .cfg-section h2{font-size:14px}
  .cfg-section h3{font-size:12px}
  .cfg-value,.vit-mult{font-size:20px}
  .row-item span,.row-item b{font-size:12px}
  .btn-dl{padding:10px 22px;font-size:11px}
  .dl-card{padding:18px}
  .dl-card-title{font-size:16px}
  .rule-block{padding:12px}
  .rule-title{font-size:13px}
  .rule-text{font-size:12px}
}

/* ───────────── 18. SOON-CARD (заглушки страниц) ───────────── */
.soon-card{
  max-width:760px;margin:48px auto;padding:clamp(24px,4vw,48px);
  background:linear-gradient(180deg,rgba(28,22,12,0.78),rgba(14,11,8,0.92));
  border:1px solid var(--brd);border-radius:12px;
  box-shadow:0 14px 40px rgba(0,0,0,0.4);text-align:center;
}
.soon-icon{font-size:clamp(40px,6vw,64px);line-height:1;margin-bottom:12px;color:var(--gold)}
.soon-title{font-family:var(--ff-h);font-size:clamp(22px,3vw,34px);letter-spacing:.02em;color:var(--ink);margin:0 0 14px}
.soon-sub{font-size:clamp(13px,1.4vw,16px);line-height:1.65;color:var(--mut);margin:0 0 14px}
.soon-list{list-style:none;padding:0;margin:14px 0 22px;display:grid;gap:8px;text-align:left}
.soon-list li{padding:10px 14px;background:rgba(0,0,0,0.28);border-left:2px solid var(--gold);border-radius:0 6px 6px 0;font-size:clamp(12px,1.2vw,14px);color:var(--ink-d)}
.soon-card .btn{margin-top:8px}

/* ───────────── 19. LEGAL ─────────────────────────────────── */
.legal-wrap{max-width:920px;padding-top:32px;padding-bottom:48px}
.legal-h1{font-family:var(--ff-h);font-size:clamp(22px,3vw,32px);margin:0 0 18px;color:var(--ink);letter-spacing:.02em}
.legal-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px;border-bottom:1px solid var(--brd);padding-bottom:8px}
.legal-tab{
  padding:8px 14px;font-size:clamp(11px,1.2vw,13px);font-family:var(--ff-b);
  background:rgba(0,0,0,0.32);color:var(--mut);
  border:1px solid var(--brd);border-radius:6px;cursor:pointer;
  transition:background .2s,color .2s,border-color .2s;
}
.legal-tab:hover{color:var(--ink);border-color:var(--gold-d)}
.legal-tab.active{background:linear-gradient(180deg,var(--gold),var(--gold-d));color:#1a1408;border-color:var(--gold);font-weight:600}
.legal-content{
  padding:clamp(16px,2vw,24px);
  background:linear-gradient(180deg,rgba(20,16,10,0.75),rgba(10,8,6,0.9));
  border:1px solid var(--brd);border-radius:8px;
  font-size:clamp(13px,1.3vw,15px);line-height:1.7;color:var(--ink-d);
}
.legal-content h2{font-family:var(--ff-h);font-size:clamp(18px,2.2vw,22px);color:var(--gold);margin:18px 0 10px;letter-spacing:.02em}
.legal-content h3{font-size:clamp(14px,1.6vw,17px);color:var(--ink);margin:14px 0 8px}
.legal-content p{margin:0 0 10px}
.legal-content ul,.legal-content ol{margin:0 0 12px;padding-left:22px}
.legal-content li{margin:4px 0}
.legal-content strong{color:var(--gold)}
.legal-date{font-size:11px;color:var(--mut);margin-bottom:14px;font-style:italic}
.legal-doc hr{display:none}
@media(max-width:600px){
  .legal-tabs{gap:4px}
  .legal-tab{padding:7px 10px;font-size:11px}
}

/* ════════════════════════════════════════════════════════════════
   ── 20. АДАПТИВ v2 — 10 БРЕЙКПОИНТОВ (2026-06-15) ─────────────
   360 · 414 · 480 · 768 · 1024 · 1280 · 1366 · 1440 · 1920 · 2560
═══════════════════════════════════════════════════════════════ */

/* ── 20.1. ULTRA-NARROW ≤360 ───────────────────────────────── */
@media (max-width:360px){
  .page-hero{padding:72px 12px 22px}
  .page-hero h1{font-size:22px;letter-spacing:0.05em}
  .page-hero-sub{font-size:10px}
  .page-content{padding:20px 12px 40px}
  .cfg-section h2{font-size:13px;letter-spacing:0.06em}
  .cfg-section h3{font-size:11px}
  .cfg-grid{grid-template-columns:1fr}
  .vit-row{grid-template-columns:1fr 1fr}
  .vit-mult,.cfg-value{font-size:18px}
  .ench-blocks,.ench-blocks-main{grid-template-columns:1fr}
  .classes-grid{grid-template-columns:1fr}
  .boss-list{grid-template-columns:1fr}
  .inst-list{grid-template-columns:1fr}
  .oly-rewards{grid-template-columns:1fr}
  .pvp-row{flex-direction:column;gap:6px}
  .pvp-cls{min-width:unset}
  .dl-card{padding:14px}
  .dl-card-title{font-size:14px}
  .btn-dl{padding:9px 18px;font-size:10px}
  .rule-block{padding:10px;gap:10px}
  .rule-num{min-width:26px;height:26px;font-size:11px}
  .legal-tabs{gap:3px}
  .legal-tab{padding:6px 8px;font-size:10px}
  .soon-card{margin:24px 8px;padding:18px}
}

/* ── 20.2. PHONE-S 361-414 ─────────────────────────────────── */
@media (min-width:361px) and (max-width:414px){
  .page-hero{padding:80px 14px 26px}
  .page-hero h1{font-size:24px}
  .page-content{padding:24px 14px 44px}
  .cfg-grid{grid-template-columns:1fr 1fr}
  .vit-row{grid-template-columns:1fr 1fr}
  .classes-grid{grid-template-columns:1fr}
  .boss-list{grid-template-columns:1fr}
  .inst-list{grid-template-columns:1fr 1fr}
  .oly-rewards{grid-template-columns:repeat(3,1fr);gap:6px}
}

/* ── 20.3. PHONE-XL 415-479 ────────────────────────────────── */
@media (min-width:415px) and (max-width:479px){
  .page-hero{padding:82px 16px 28px}
  .page-hero h1{font-size:26px}
  .cfg-grid{grid-template-columns:1fr 1fr}
  .vit-row{grid-template-columns:repeat(4,1fr)}
  .classes-grid{grid-template-columns:1fr 1fr}
  .inst-list{grid-template-columns:1fr 1fr}
  .boss-list{grid-template-columns:1fr}
}

/* ── 20.4. ДЕСКТОП XL 1280-1365 ────────────────────────────── */
@media (min-width:1280px) and (max-width:1365px){
  .page-content{max-width:1040px;padding:48px var(--cpad) 80px}
  .classes-grid{grid-template-columns:repeat(4,1fr)}
  .boss-list{grid-template-columns:repeat(3,1fr)}
}

/* ── 20.5. LAPTOP-HD 1366-1439 ─────────────────────────────── */
@media (min-width:1366px) and (max-width:1439px){
  .page-content{max-width:1080px;padding:52px var(--cpad) 88px}
  .classes-grid{grid-template-columns:repeat(4,1fr)}
  .boss-list{grid-template-columns:repeat(3,1fr)}
  .inst-list{grid-template-columns:repeat(4,1fr)}
  .oly-rewards{grid-template-columns:repeat(3,1fr);gap:18px}
}

/* ── 20.6. WIDE 1440-1919 ──────────────────────────────────── */
@media (min-width:1440px) and (max-width:1919px){
  .page-content{max-width:1140px}
  .boss-list{grid-template-columns:repeat(4,1fr)}
  .inst-list{grid-template-columns:repeat(4,1fr)}
}

/* ── 20.7. FULL-HD 1920-2559 (умеренные пропорции) ──────────── */
@media (min-width:1920px) and (max-width:2559px){
  .page-content{max-width:1240px;padding:52px var(--cpad) 84px}
  .page-hero{padding:96px var(--cpad) 64px}
  .page-hero h1{font-size:clamp(40px,2.5vw,50px)}
  .page-hero-sub{font-size:13px}
  .cfg-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
  .cfg-value,.vit-mult{font-size:24px}
  .classes-grid{grid-template-columns:repeat(5,1fr);gap:14px}
  .boss-list{grid-template-columns:repeat(4,1fr);gap:18px}
  .inst-list{grid-template-columns:repeat(4,1fr)}
  .oly-rewards{gap:18px}
  .ench-table{font-size:13px}
  .row-item span,.row-item b{font-size:14px}
}

/* ── 20.8. QHD 2560+ (умеренное масштабирование) ────────────── */
@media (min-width:2560px){
  .page-content{max-width:1480px;padding:64px var(--cpad) 96px}
  .page-hero{padding:120px var(--cpad) 72px}
  .page-hero h1{font-size:clamp(52px,2.8vw,62px);letter-spacing:0.1em}
  .page-hero-sub{font-size:14px;letter-spacing:0.1em}
  .cfg-section h2{font-size:17px;letter-spacing:0.08em}
  .cfg-section h3{font-size:15px}
  .cfg-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .cfg-card{padding:22px var(--s3)}
  .cfg-value,.vit-mult{font-size:28px}
  .classes-grid{grid-template-columns:repeat(5,1fr);gap:18px}
  .boss-list{grid-template-columns:repeat(4,1fr);gap:22px}
  .inst-list{grid-template-columns:repeat(5,1fr)}
  .row-item span,.row-item b{font-size:15px}
  .ench-table{font-size:14px}
  .ench-table th{font-size:12px}
  .legal-content{font-size:15px;line-height:1.7}
  .soon-card{max-width:860px;padding:48px}
}
/* ── 20.9. LANDSCAPE phone ─────────────────────────────────── */
@media (max-height:480px) and (orientation:landscape){
  .page-hero{padding:70px var(--cpad) 24px}
  .page-hero h1{font-size:22px}
  .page-content{padding:20px var(--cpad) 40px}
}

/* ════════════════════════════════════════════════════════════════
   ── 21. UNIFIED ADAPTIVE PAGES (10 BP) ─────────────────────────
═══════════════════════════════════════════════════════════════ */

/* 360+ */
@media (min-width:360px){
  .page-hero{padding:80px 14px 24px}
  .page-hero h1{font-size:22px;letter-spacing:0.05em}
  .page-hero-sub{font-size:10px}
  .page-content{padding:24px 14px 40px}
  .cfg-section h2{font-size:13px;letter-spacing:0.06em}
  .cfg-section h3{font-size:11px}
  .cfg-grid{grid-template-columns:1fr;gap:1px}
  .vit-row{grid-template-columns:1fr 1fr}
  .cfg-value,.vit-mult{font-size:18px}
  .classes-grid{grid-template-columns:1fr;gap:8px}
  .boss-list{grid-template-columns:1fr;gap:10px}
  .inst-list{grid-template-columns:1fr;gap:8px}
  .oly-rewards{grid-template-columns:1fr;gap:8px}
  .pvp-row{flex-direction:column;gap:6px}
  .pvp-cls{min-width:unset}
  .ench-blocks,.ench-blocks-main{grid-template-columns:1fr}
}

/* 414+ */
@media (min-width:414px){
  .page-hero{padding:84px 16px 28px}
  .page-hero h1{font-size:24px}
  .page-content{padding:28px 16px 44px}
  .cfg-grid{grid-template-columns:1fr 1fr}
  .cfg-value,.vit-mult{font-size:20px}
  .inst-list{grid-template-columns:1fr 1fr;gap:10px}
  .oly-rewards{grid-template-columns:repeat(3,1fr);gap:8px}
}

/* 480+ */
@media (min-width:480px){
  .page-hero{padding:90px 18px 32px}
  .page-hero h1{font-size:28px}
  .page-hero-sub{font-size:11px}
  .page-content{padding:32px 18px 52px}
  .cfg-section h2{font-size:14px}
  .vit-row{grid-template-columns:repeat(4,1fr)}
  .cfg-grid{grid-template-columns:repeat(3,1fr)}
  .classes-grid{grid-template-columns:1fr 1fr;gap:10px}
  .boss-list{grid-template-columns:1fr;gap:12px}
  .inst-list{grid-template-columns:repeat(3,1fr)}
}

/* 768+ */
@media (min-width:768px){
  .page-hero{padding:96px var(--cpad) 40px}
  .page-hero h1{font-size:34px}
  .page-content{padding:40px var(--cpad) 64px}
  .cfg-section h2{font-size:15px}
  .cfg-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .classes-grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .boss-list{grid-template-columns:1fr 1fr;gap:14px}
  .inst-list{grid-template-columns:repeat(3,1fr)}
  .ench-blocks,.ench-blocks-main{grid-template-columns:1fr 1fr;gap:14px}
  .pvp-row{flex-direction:row;flex-wrap:wrap;gap:12px}
  .pvp-cls{min-width:100px}
}

/* 1024+ */
@media (min-width:1024px){
  .page-hero{padding:108px var(--cpad) 48px}
  .page-hero h1{font-size:40px}
  .page-content{padding:48px var(--cpad) 72px;max-width:1000px}
  .cfg-section h2{font-size:16px}
  .classes-grid{grid-template-columns:repeat(4,1fr);gap:14px}
  .boss-list{grid-template-columns:repeat(3,1fr);gap:16px}
  .inst-list{grid-template-columns:repeat(4,1fr)}
}

/* 1280+ */
@media (min-width:1280px){
  .page-hero{padding:116px var(--cpad) 52px}
  .page-hero h1{font-size:44px}
  .page-content{max-width:1060px;padding:52px var(--cpad) 76px}
  .classes-grid{gap:16px}
}

/* 1366+ */
@media (min-width:1366px){
  .page-content{max-width:1100px}
  .page-hero h1{font-size:46px}
}

/* 1440+ */
@media (min-width:1440px){
  .page-hero{padding:124px var(--cpad) 56px}
  .page-hero h1{font-size:48px}
  .page-content{max-width:1140px;padding:56px var(--cpad) 80px}
  .boss-list{grid-template-columns:repeat(3,1fr);gap:18px}
}

/* 1920+ */
@media (min-width:1920px){
  .page-hero{padding:140px var(--cpad) 64px}
  .page-hero h1{font-size:52px;letter-spacing:0.06em}
  .page-hero-sub{font-size:13px}
  .page-content{max-width:1240px;padding:60px var(--cpad) 88px}
  .cfg-section h2{font-size:17px}
  .cfg-value,.vit-mult{font-size:26px}
  .classes-grid{grid-template-columns:repeat(5,1fr);gap:16px}
  .boss-list{grid-template-columns:repeat(4,1fr);gap:20px}
  .inst-list{grid-template-columns:repeat(4,1fr)}
  .ench-table{font-size:13px}
  .row-item span,.row-item b{font-size:14px}
}

/* 2560+ */
@media (min-width:2560px){
  .page-hero{padding:160px var(--cpad) 72px}
  .page-hero h1{font-size:58px;letter-spacing:0.08em}
  .page-hero-sub{font-size:14px;letter-spacing:0.1em}
  .page-content{max-width:1480px;padding:72px var(--cpad) 100px}
  .cfg-section h2{font-size:18px}
  .cfg-section h3{font-size:15px}
  .cfg-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .cfg-card{padding:24px var(--s3)}
  .cfg-value,.vit-mult{font-size:30px}
  .classes-grid{grid-template-columns:repeat(5,1fr);gap:20px}
  .boss-list{grid-template-columns:repeat(4,1fr);gap:24px}
  .inst-list{grid-template-columns:repeat(5,1fr)}
  .row-item span,.row-item b{font-size:15px}
  .ench-table{font-size:14px}
  .ench-table th{font-size:12px}
  .legal-content{font-size:15px;line-height:1.7}
}

/* landscape phone */
@media (max-height:480px) and (orientation:landscape){
  .page-hero{padding:64px var(--cpad) 20px}
  .page-hero h1{font-size:22px}
  .page-content{padding:20px var(--cpad) 36px}
}


/* ════════════════════════════════════════════════════════════════
   17. LANDING (lp-) — главная страница, контент между hero и footer
   ────────────────────────────────────────────────────────────────
   Все размеры/цвета — через переменные :root (style.css).
   Брейкпоинты: 360 / 480 / 768 / 1024 / 1280 / 1440.
═══════════════════════════════════════════════════════════════ */


/* ========================================================
   LANDING PAGE SECTIONS (lp-*) — Mythrael L2HF
   Adaptive grid · mask-icon system · 6 breakpoints
   ======================================================== */

.lp-section{
  padding: clamp(2rem, 5vw, 4.5rem) clamp(1rem, 4vw, 2.5rem);
  max-width: 1280px;
  margin: 0 auto;
}
.lp-section + .lp-section{ border-top: 1px solid var(--brd); }

.lp-eyebrow{
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: var(--fs-xs);
  color: var(--gold-l);
  margin: 0 0 var(--sp-2);
  font-weight: var(--fw-sb);
}
.lp-h2{
  font-family: var(--ff-display);
  font-size: clamp(1.6rem, 4.2vw, 2.6rem);
  margin: 0 0 var(--sp-3);
  background: var(--gold-grd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1.15;
}
.lp-divider{
  width: clamp(60px, 12vw, 96px);
  height: 2px;
  background: var(--gold-grd);
  margin: 0 0 var(--sp-5);
  opacity: 0.7;
}
.lp-sub{
  color: var(--t2);
  max-width: 64ch;
  margin: 0 0 var(--sp-6);
  font-size: var(--fs-md);
  line-height: 1.65;
}

/* §1 About */
.lp-about-text{
  max-width: 72ch;
  color: var(--t1);
  font-size: var(--fs-md);
  line-height: 1.75;
}
.lp-about-text p + p{ margin-top: var(--sp-4); }
.lp-about-text strong{ color: var(--t1); font-weight: var(--fw-sb); }
.lp-about-text em{ color: var(--gold-l); font-style: normal; font-weight: var(--fw-sb); }

/* §2 Features grid — adaptive auto-fit */
.lp-features-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: clamp(0.75rem, 2vw, 1.25rem);
}
.lp-feat{
  position: relative;
  padding: clamp(1rem, 2.5vw, 1.5rem) clamp(0.85rem, 2vw, 1.25rem);
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--brd);
  border-radius: 4px;
  transition: border-color 0.2s, transform 0.2s;
  text-align: left;
}
.lp-feat::before{
  content: '';
  position: absolute; inset: 0;
  border: 1px solid var(--gold-l);
  border-radius: 4px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}
.lp-feat:hover{ transform: translateY(-2px); border-color: transparent; }
.lp-feat:hover::before{ opacity: 0.6; }
.lp-feat:focus-within{ box-shadow: var(--focus-ring); }

/* Mask-icon system: --icon CSS-var holds url(...) */
.lp-feat-icon, .lp-race-glyph{
  display: inline-block;
  width: clamp(32px, 6vw, 44px);
  height: clamp(32px, 6vw, 44px);
  background: var(--gold-grd);
  -webkit-mask: var(--icon) center / contain no-repeat;
          mask: var(--icon) center / contain no-repeat;
  margin-bottom: var(--sp-2);
  flex-shrink: 0;
}
.lp-feat-name{
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  margin: 0 0 var(--sp-2);
  color: var(--t1);
  font-weight: var(--fw-sb);
}
.lp-feat-sub{
  color: var(--t2);
  font-size: var(--fs-md);
  line-height: 1.55;
  margin: 0;
}

/* §3 Races / classes — adaptive */
.lp-races-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
  gap: clamp(0.75rem, 2vw, 1.5rem);
}
.lp-race{
  padding: clamp(1rem, 2.5vw, 1.5rem);
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--brd);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.lp-race-head{
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.lp-race-title{
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.lp-race-glyph{
  width: clamp(40px, 7vw, 52px);
  height: clamp(40px, 7vw, 52px);
  margin: 0;
}
.lp-race-name{
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  color: var(--t1);
  margin: 0;
  font-weight: var(--fw-sb);
  line-height: 1.1;
}
.lp-race-count{
  font-size: var(--fs-xs);
  color: var(--gold-l);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-top: 2px;
}
.lp-race-lore{
  color: var(--t2);
  font-size: var(--fs-md);
  line-height: 1.6;
  margin: 0;
}
.lp-race-lore em{
  color: var(--gold-l);
  font-style: normal;
  font-weight: var(--fw-sb);
}
.lp-race-classes{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.lp-race-classes span{
  display: inline-block;
  padding: 4px 10px;
  background: rgba(245,210,123,0.06);
  border: 1px solid var(--brd);
  border-radius: 2px;
  color: var(--t1);
  font-size: var(--fs-xs);
  line-height: 1.4;
  letter-spacing: 0.02em;
}

/* §4 Mechanics — adaptive grid */
.lp-mech-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: clamp(0.75rem, 2vw, 1.25rem);
}
.lp-mech{
  padding: clamp(1rem, 2.5vw, 1.5rem);
  background: rgba(255,255,255,0.02);
  border-left: 2px solid var(--gold-l);
  border-radius: 0 4px 4px 0;
}
.lp-mech-name{
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  color: var(--t1);
  margin: 0 0 var(--sp-2);
  font-weight: var(--fw-sb);
}
.lp-mech-desc{
  color: var(--t2);
  font-size: var(--fs-md);
  line-height: 1.65;
  margin: 0;
}
.lp-mech-desc em{
  color: var(--gold-l);
  font-style: normal;
  font-weight: var(--fw-sb);
}

/* §5 Locations grid */
.lp-loc-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr));
  gap: clamp(0.5rem, 1.5vw, 1rem);
}
.lp-loc{
  padding: var(--sp-3) var(--sp-4);
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--brd);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: border-color 0.2s;
}
.lp-loc:hover{ border-color: var(--gold-l); }
.lp-loc-lv{
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  background: var(--gold-grd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: var(--fw-sb);
}
.lp-loc-name{
  color: var(--t1);
  font-size: var(--fs-sm);
  font-weight: var(--fw-sb);
  line-height: 1.3;
}
.lp-loc-tag{
  color: var(--t2);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* §6 Rates */
.lp-rates-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr));
  gap: clamp(0.5rem, 1.5vw, 1rem);
}
.lp-rate{
  padding: clamp(1rem, 2.5vw, 1.5rem) var(--sp-3);
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--brd);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-2);
}
.lp-rate-value{
  font-family: var(--ff-display);
  font-size: clamp(1.5rem, 4vw, 2.2rem);
  background: var(--gold-grd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: var(--fw-sb);
  line-height: 1;
}
.lp-rate-label{
  color: var(--t2);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  line-height: 1.3;
}

/* §7 Vitality */
.lp-vit-table{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 140px), 1fr));
  gap: clamp(0.5rem, 1.5vw, 1rem);
}
.lp-vit-cell{
  padding: var(--sp-4) var(--sp-3);
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--brd);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-2);
}
.lp-vit-step{
  color: var(--t2);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin: 0;
}
.lp-vit-mult{
  font-family: var(--ff-display);
  font-size: clamp(1.4rem, 3.6vw, 2rem);
  background: var(--gold-grd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: var(--fw-sb);
  line-height: 1;
}

/* §8 Final CTA */
.lp-cta{
  text-align: center;
  padding-top: clamp(2.5rem, 6vw, 5rem);
  padding-bottom: clamp(2.5rem, 6vw, 5rem);
}
.lp-cta-title{
  font-family: var(--ff-display);
  font-size: clamp(1.6rem, 4.2vw, 2.4rem);
  margin: 0 0 var(--sp-3);
  background: var(--gold-grd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.lp-cta-sub{
  color: var(--t2);
  font-size: var(--fs-md);
  margin: 0 0 var(--sp-5);
}
.lp-cta-btns{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-3);
}

/* §9 Server section */
.lp-server code{
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 0.9em;
  background: rgba(245,210,123,0.08);
  border: 1px solid var(--brd);
  border-radius: 3px;
  padding: 1px 6px;
  color: var(--gold-l);
}

/* ========================================================
   LANDING v3 — Saga / Pantheon / Battles
   ======================================================== */

/* §10 Saga timeline — vertical rail with gold line */
.lp-saga-list{
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}
.lp-saga-list::before{
  content: '';
  position: absolute;
  left: clamp(56px, 12vw, 100px);
  top: 8px;
  bottom: 8px;
  width: 1px;
  background: linear-gradient(to bottom, transparent, var(--gold-l) 8%, var(--gold-l) 92%, transparent);
  opacity: 0.45;
}
.lp-saga-item{
  display: grid;
  grid-template-columns: clamp(56px, 12vw, 100px) 1fr;
  gap: clamp(1rem, 3vw, 2rem);
  padding: var(--sp-3) 0;
  position: relative;
  align-items: start;
}
.lp-saga-item::after{
  content: '';
  position: absolute;
  left: clamp(56px, 12vw, 100px);
  top: calc(var(--sp-3) + 8px);
  width: 11px; height: 11px;
  border-radius: 50%;
  background: var(--bg);
  border: 2px solid var(--gold-l);
  transform: translateX(-50%);
}
.lp-saga-year{
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  color: var(--gold-l);
  font-weight: var(--fw-sb);
  text-align: right;
  padding-right: var(--sp-3);
  letter-spacing: 0.04em;
  padding-top: 4px;
}
.lp-saga-body{
  padding-left: clamp(0.75rem, 2vw, 1.5rem);
  border-left: 1px solid var(--brd);
}
.lp-saga-name{
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  color: var(--t1);
  margin: 0 0 var(--sp-2);
  font-weight: var(--fw-sb);
  line-height: 1.25;
}
.lp-saga-body p{
  color: var(--t2);
  font-size: var(--fs-md);
  line-height: 1.65;
  margin: 0;
}
.lp-saga-current::after{
  width: 15px; height: 15px;
  background: var(--gold-grd);
  box-shadow: 0 0 0 4px rgba(245,210,123,0.18);
  top: calc(var(--sp-3) + 6px);
}
.lp-saga-current .lp-saga-name{
  background: var(--gold-grd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.lp-saga-current .lp-saga-body{
  border-left-color: var(--gold-l);
}

/* §11 Pantheon — god cards */
.lp-god-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: clamp(0.75rem, 2vw, 1.5rem);
}
.lp-god{
  padding: clamp(1.25rem, 3vw, 1.75rem) clamp(1rem, 2.5vw, 1.5rem);
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--brd);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-2);
  position: relative;
  transition: border-color 0.2s, transform 0.2s;
}
.lp-god::before{
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 2px;
  background: var(--gold-grd);
  opacity: 0.55;
}
.lp-god:hover{ transform: translateY(-2px); border-color: var(--gold-l); }
.lp-god-icon{
  display: inline-block;
  width: clamp(48px, 9vw, 64px);
  height: clamp(48px, 9vw, 64px);
  background: var(--gold-grd);
  -webkit-mask: var(--icon) center / contain no-repeat;
          mask: var(--icon) center / contain no-repeat;
  margin-bottom: var(--sp-2);
}
.lp-god-name{
  font-family: var(--ff-display);
  font-size: var(--fs-xl);
  margin: 0;
  background: var(--gold-grd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: var(--fw-sb);
  line-height: 1.1;
}
.lp-god-meta{
  font-size: var(--fs-xs);
  color: var(--t2);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin: 0;
}
.lp-god-meta em{
  font-style: normal;
  color: var(--gold-l);
  font-weight: var(--fw-sb);
}
.lp-god-lore{
  color: var(--t2);
  font-size: var(--fs-md);
  line-height: 1.65;
  margin: var(--sp-2) 0 0;
}

/* §12 Battles — vertical lore-timeline */
.lp-bat-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2.5vw, 1.5rem);
}
.lp-bat-item{
  padding: clamp(1.25rem, 3vw, 1.75rem) clamp(1rem, 2.5vw, 1.5rem);
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--brd);
  border-left: 3px solid var(--gold-l);
  border-radius: 0 4px 4px 0;
  position: relative;
}
.lp-bat-era{
  display: inline-block;
  font-size: var(--fs-xs);
  color: var(--gold-l);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-bottom: var(--sp-2);
  font-weight: var(--fw-sb);
}
.lp-bat-name{
  font-family: var(--ff-display);
  font-size: var(--fs-xl);
  color: var(--t1);
  margin: 0 0 var(--sp-3);
  font-weight: var(--fw-sb);
  line-height: 1.2;
}
.lp-bat-desc{
  color: var(--t2);
  font-size: var(--fs-md);
  line-height: 1.7;
  margin: 0 0 var(--sp-3);
}
.lp-bat-outcome{
  color: var(--t1);
  font-size: var(--fs-sm);
  line-height: 1.55;
  margin: 0;
  padding-top: var(--sp-2);
  border-top: 1px solid var(--brd);
}
.lp-bat-outcome strong{
  color: var(--gold-l);
  font-weight: var(--fw-sb);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: var(--fs-xs);
  margin-right: var(--sp-1);
}

/* Mobile fine-tune: tighter saga on narrow screens */
@media (max-width: 480px){
  .lp-saga-list::before{ left: clamp(40px, 16vw, 60px); }
  .lp-saga-item{ grid-template-columns: clamp(40px, 16vw, 60px) 1fr; gap: 0.75rem; }
  .lp-saga-item::after{ left: clamp(40px, 16vw, 60px); }
  .lp-saga-year{ padding-right: 0.5rem; font-size: var(--fs-sm); }
}
