/* ===== Great Journey, общие стили ===== */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Spectral:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&display=swap');

:root{
  --bg:#0c1410;
  --bg-2:#111d16;
  --panel:#16241b;
  --panel-2:#1b2c21;
  --border:#27402f;
  --green:#4ade80;
  --green-soft:#6ee7a0;
  --green-dim:#2f9e5a;
  --text:#e6f2ea;
  --text-dim:#9fbcab;
  --text-faint:#6f8a7b;
  --radius:14px;
  --shadow:0 8px 30px rgba(0,0,0,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(74,222,128,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(74,222,128,.06), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:'Spectral', Georgia, serif;
  font-weight:600;
  line-height:1.7;
  min-height:100vh;
}

a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* ===== Header / nav ===== */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(12,20,16,.82);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;gap:18px;height:72px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Cinzel',serif;font-weight:600}
.brand img{height:40px;width:40px}
.brand span{font-size:1.05rem;letter-spacing:.04em;color:var(--text)}
.nav-links{display:flex;gap:15px;margin-left:auto;align-items:center}
.nav-links a{
  font-family:'Cinzel',serif;font-size:.76rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--text-dim);white-space:nowrap;
  padding:6px 0;border-bottom:2px solid transparent;transition:.2s;
}
.nav-links a:hover{color:var(--green);border-color:var(--green-dim)}
.nav-links a.active{color:var(--green);border-color:var(--green)}
.nav-links a.nav-login{border:1px solid var(--border);border-radius:7px;padding:6px 14px;color:var(--text-soft)}
.nav-links a.nav-gate{display:inline-flex;align-items:center;justify-content:center;padding:6px;border:none;color:var(--text-soft);transition:color .15s,transform .15s}
.nav-links a.nav-gate:hover{color:var(--green,#4ade80);transform:translateY(-1px)}
.nav-links a.nav-gate-up{color:#d9b95c}
.nav-links a.nav-gate-up:hover{color:#e8c96a}
.nav-links a.nav-login:hover{border-color:var(--green);color:var(--green);background:rgba(74,222,128,.08)}
html{scroll-behavior:smooth}

/* logo in header */
.brand-logo{padding:4px 0}
.brand-logo svg{filter:drop-shadow(0 0 14px rgba(74,222,128,.25))}

/* ===== Hero ===== */
.hero{text-align:center;padding:90px 0 60px;position:relative}
.hero img.logo{width:min(560px,92%);height:auto;filter:drop-shadow(0 0 40px rgba(74,222,128,.25))}
.hero .tagline{
  margin-top:18px;color:var(--text-dim);font-style:italic;font-size:1.1rem;
}

/* text hero (no big logo) */
.hero-text{padding:96px 0 64px;max-width:860px;margin:0 auto}
.hero-title{
  font-family:'Cinzel',serif;font-weight:600;
  font-size:clamp(1.7rem,4vw,2.7rem);line-height:1.25;color:var(--text);
  letter-spacing:.01em;text-shadow:0 0 40px rgba(74,222,128,.18);
}
.hero-sub{
  margin-top:24px;color:var(--green-soft);font-size:clamp(1rem,2vw,1.25rem);
  line-height:1.6;max-width:680px;margin-left:auto;margin-right:auto;
}
.hero .cta{margin-top:34px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn{
  font-family:'Cinzel',serif;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  padding:13px 26px;border-radius:10px;border:1px solid var(--green-dim);
  color:var(--green);background:rgba(74,222,128,.06);transition:.2s;cursor:pointer;
}
.btn:hover{background:rgba(74,222,128,.16);border-color:var(--green)}
.btn.solid{background:var(--green);color:#06231a;border-color:var(--green);font-weight:600}
.btn.solid:hover{background:var(--green-soft)}

/* ===== Section titles ===== */
.section-head{text-align:center;margin:70px 0 36px}
.section-head h2{
  font-family:'Cinzel',serif;font-weight:700;font-size:1.9rem;color:var(--text);
  letter-spacing:.03em;
}
.section-head .sub{color:var(--text-faint);margin-top:8px;font-size:.98rem}
.divider{width:70px;height:2px;background:var(--green-dim);margin:14px auto 0;position:relative}
.divider::before,.divider::after{content:"";position:absolute;top:50%;width:5px;height:5px;border-radius:50%;background:var(--green);transform:translateY(-50%)}
.divider::before{left:-9px}.divider::after{right:-9px}

/* ===== Grid of section tiles (home) ===== */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;padding-bottom:40px}
.tile{
  display:block;background:linear-gradient(160deg,var(--panel),var(--bg-2));
  border:1px solid var(--border);border-radius:var(--radius);padding:26px 24px;
  transition:.25s;position:relative;overflow:hidden;
}
.tile::after{content:"";position:absolute;inset:0;background:radial-gradient(400px 200px at 100% 0,rgba(74,222,128,.10),transparent 60%);opacity:0;transition:.25s}
.tile:hover{transform:translateY(-4px);border-color:var(--green-dim);box-shadow:var(--shadow)}
.tile:hover::after{opacity:1}
.tile .ic{font-size:1.7rem;margin-bottom:14px;display:block}
.tile h3{font-family:'Cinzel',serif;font-weight:700;font-size:1.15rem;color:var(--text);margin-bottom:8px}
.tile p{color:var(--text-dim);font-size:.95rem}

/* ===== Tabs (обычное / эпическое) ===== */
.tabs{display:flex;gap:10px;justify-content:center;margin-bottom:34px;flex-wrap:wrap}
.tab{
  font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;
  padding:11px 24px;border-radius:999px;border:1px solid var(--border);
  color:var(--text-dim);background:transparent;cursor:pointer;transition:.2s;
}
.tab:hover{color:var(--green-soft);border-color:var(--green-dim)}
.tab.active{background:var(--green);color:#06231a;border-color:var(--green);font-weight:600}
.tab.epic.active{background:#c084fc;border-color:#c084fc;color:#1a0a2e}
.tab.epic:hover{color:#d8b4fe;border-color:#9333ea}

.panel-note{
  text-align:center;color:var(--text-faint);font-style:italic;
  font-size:.92rem;margin:-18px auto 30px;max-width:600px;
}

/* ===== Material cards ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:22px}
.card{
  background:linear-gradient(160deg,var(--panel),var(--bg-2));
  border:1px solid var(--border);border-radius:var(--radius);
  padding:26px;display:flex;flex-direction:column;transition:.25s;
}
.card:hover{border-color:var(--green-dim);box-shadow:var(--shadow)}
.card.epic{border-color:#3b2a52}
.card.epic:hover{border-color:#7e3ff2;box-shadow:0 8px 30px rgba(120,60,242,.25)}
.card .badge{
  align-self:flex-start;font-family:'Cinzel',serif;font-size:.66rem;letter-spacing:.1em;
  text-transform:uppercase;padding:4px 11px;border-radius:999px;margin-bottom:14px;
  background:rgba(74,222,128,.12);color:var(--green-soft);border:1px solid var(--green-dim);
}
.card.epic .badge{background:rgba(168,85,247,.14);color:#d8b4fe;border-color:#7e3ff2}
.card h3{font-family:'Cinzel',serif;font-weight:700;font-size:1.3rem;color:var(--text);margin-bottom:6px}
.card .lvl{color:var(--text-faint);font-size:.85rem;margin-bottom:14px;font-style:italic}
.card p{color:var(--text-dim);font-size:.97rem;flex-grow:1;margin-bottom:20px}
.card .dl{
  align-self:flex-start;display:inline-flex;align-items:center;gap:9px;
  font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  padding:11px 20px;border-radius:9px;border:1px solid var(--green-dim);
  color:var(--green);background:rgba(74,222,128,.06);transition:.2s;
}
.card .dl:hover{background:var(--green);color:#06231a}
.card.epic .dl{border-color:#7e3ff2;color:#d8b4fe;background:rgba(168,85,247,.06)}
.card.epic .dl:hover{background:#a855f7;color:#1a0a2e}

/* ===== Footer ===== */
.site-footer{
  border-top:1px solid var(--border);margin-top:90px;padding:44px 0;
  text-align:center;color:var(--text-faint);font-size:.9rem;
}
.site-footer a{color:var(--green-soft)}
.site-footer .links{display:flex;gap:24px;justify-content:center;margin-bottom:16px;flex-wrap:wrap}
.site-footer .links a{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim)}
.site-footer .links a:hover{color:var(--green)}

/* hidden panel for tab switching */
.tab-panel{display:none}
.tab-panel.show{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

@media(max-width:640px){
  .nav{height:auto;padding:14px 0;flex-wrap:wrap;gap:14px}
  .nav-links{margin-left:0;width:100%;justify-content:center;flex-wrap:wrap}
  .hero{padding:54px 0 40px}
}

/* ===== Классы: группы и карточки ===== */
.intro-block{max-width:760px;margin:0 auto 10px;color:var(--text-dim);text-align:center;font-size:1.05rem}
.src-legend{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin:24px 0 8px;font-size:.82rem}
.src-legend span{display:inline-flex;align-items:center;gap:7px;color:var(--text-faint)}
.src-tag{font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:.06em;padding:2px 6px;border-radius:5px;font-weight:600;font-style:normal}
.src-PHB{background:rgba(96,165,250,.14);color:#93c5fd;border:1px solid #3b82f6}
.src-GJ{background:rgba(74,222,128,.14);color:#6ee7a0;border:1px solid #2f9e5a}
.src-HB{background:rgba(168,85,247,.14);color:#d8b4fe;border:1px solid #7e3ff2}
.groups-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px}
@media(max-width:900px){.groups-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.groups-grid{grid-template-columns:1fr}}
.group-card{display:block;background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:.25s}
.group-card:hover{transform:translateY(-3px);border-color:var(--green-dim);box-shadow:var(--shadow)}
.group-card .gtop{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.group-card h3{font-family:'Cinzel',serif;font-weight:700;font-size:1.15rem;color:var(--green);margin:0}
.group-card .arr{color:var(--green-dim);font-size:1.3rem;line-height:1;transition:.2s}
.group-card:hover .arr{color:var(--green)}
.group-card .mech{color:var(--text-dim);font-size:.86rem;font-style:italic;margin-bottom:12px;line-height:1.5}
.group-card .members{display:flex;flex-wrap:wrap;gap:6px}
.group-card .chip{font-size:.8rem;color:var(--text);background:rgba(74,222,128,.05);border:1px solid var(--border);border-radius:999px;padding:3px 9px}

/* group / class detail */
.crumbs{font-size:.82rem;color:var(--text-faint);margin:30px 0 0}
.crumbs a{color:var(--green-soft)}
.class-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:13px;margin-top:20px}
@media(max-width:600px){.class-grid{grid-template-columns:1fr}}
.class-card{display:block;background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:.2s}
.class-card:hover{border-color:var(--green-dim);transform:translateY(-2px)}
.class-card .ctop{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.class-card .cname{font-family:'Cinzel',serif;font-weight:700;font-size:1.05rem;color:var(--text)}
.class-card .cdesc{color:var(--text-dim);font-size:.9rem;line-height:1.5}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:20px 0}
.stat-box{background:var(--bg-2);border-radius:9px;padding:12px;text-align:center}
.stat-box .l{color:var(--text-faint);font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.stat-box .v{color:var(--green-soft);font-size:.95rem;font-weight:500}
.dl-big{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#06231a;font-family:'Cinzel',serif;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;padding:13px 28px;border-radius:9px;font-weight:600}
.dl-big:hover{background:var(--green-soft)}

/* admin */
.admin-bar{background:rgba(168,85,247,.10);border:1px solid #7e3ff2;border-radius:10px;padding:12px 18px;margin:20px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.admin-bar .who{color:#d8b4fe;font-size:.85rem}
.admin-bar a{color:#d8b4fe;font-size:.82rem;border:1px solid #7e3ff2;padding:6px 14px;border-radius:7px}
.adm-btn{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;padding:7px 14px;border-radius:7px;border:1px solid;cursor:pointer;background:transparent;text-decoration:none;display:inline-block}
.adm-add{border-color:#2f9e5a;color:#4ade80}
.adm-add:hover{background:var(--green);color:#06231a}
.adm-del{border-color:#a32d2d;color:#f09595}
.adm-del:hover{background:#e24b4a;color:#fff}
.adm-form{max-width:560px;margin:30px auto;background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:var(--radius);padding:28px}
.adm-form label{display:block;color:var(--text-dim);font-size:.85rem;margin:14px 0 5px}
.adm-form input,.adm-form select,.adm-form textarea{width:100%;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:10px 12px;font-family:'Spectral',serif;font-size:.95rem}
.adm-form textarea{min-height:70px;resize:vertical}
.adm-form button{margin-top:20px;width:100%;background:var(--green);color:#06231a;border:none;border-radius:9px;padding:13px;font-family:'Cinzel',serif;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer}

/* ===== Footer social ===== */
.site-footer .social{display:flex;gap:18px;justify-content:center;margin:18px 0 14px;flex-wrap:wrap}
.soc-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-dim);border:1px solid var(--border);border-radius:9px;padding:9px 18px;font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;transition:.2s}
.soc-link:hover{color:var(--green);border-color:var(--green-dim);background:rgba(74,222,128,.05)}
.soc-link svg{flex-shrink:0}

.tile .ic{color:var(--green);display:block;margin-bottom:14px}
.tile .ic svg{width:30px;height:30px}

.site-footer .attribution{max-width:680px;margin:14px auto 0;font-size:.72rem;line-height:1.55;color:#5a6b62}
.site-footer .attribution a{color:#6f8a7b;text-decoration:underline}
.site-footer .attribution a:hover{color:var(--green-soft)}


/* вкладки на странице класса */
.tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;border-bottom:1px solid var(--border);padding-bottom:12px}
.tab{background:none;border:1px solid var(--border);color:var(--text-soft);font-family:inherit;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;padding:7px 14px;border-radius:99px;cursor:pointer;transition:.15s}
.tab:hover{border-color:var(--green-soft)}
.tab.active{background:var(--green);color:#06231a;border-color:var(--green);font-weight:600}
/* карточки систем магии */
.magic-card{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:10px}
.magic-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.magic-name{font-weight:600;color:var(--green-soft);font-size:1.02rem;text-decoration:none}
.magic-name:hover{text-decoration:underline}
.res-pill{background:rgba(74,222,128,.12);color:var(--green-soft);border:1px solid var(--green-line);border-radius:99px;padding:3px 11px;font-size:.72rem;text-decoration:none;white-space:nowrap}
.res-pill:hover{background:rgba(74,222,128,.2)}
.magic-desc{color:var(--text-soft);font-size:.9rem;line-height:1.55;margin-top:6px}
.magic-prog{color:var(--text-faint);font-size:.8rem;margin-top:5px}
/* список заклинаний */
.spell-cols{columns:2;column-gap:24px}
@media(max-width:520px){.spell-cols{columns:1}}
.spell-lvl{color:var(--green-soft);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;margin:10px 0 4px;break-after:avoid}
.spell-link{display:block;color:var(--text-soft);text-decoration:none;font-size:.9rem;padding:2px 0;break-inside:avoid}
.spell-link:hover{color:var(--green-soft);text-decoration:underline}

/* страница заклинания */
.spell-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0 0 16px}
.spell-meta>div{background:var(--bg-2);border-radius:8px;padding:9px 12px;font-size:.85rem;color:var(--text)}
.spell-meta>div span{display:block;color:var(--text-faint);font-size:.72rem;margin-bottom:2px}
.upcast{background:rgba(74,222,128,.08);border-left:3px solid var(--green-line);border-radius:6px;padding:11px 14px;margin:12px 0;color:var(--text);font-size:.9rem;line-height:1.55}
.upcast-h{color:var(--green-soft);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}

/* панель фильтров заклинаний */
.filter-panel{max-width:760px;margin:0 auto;background:#0a1009;border:1px solid var(--border);border-radius:12px;padding:13px}
.src-toggle{display:flex;gap:7px;margin-bottom:9px}
.src-btn{flex:1;background:#1a2620;color:var(--text-soft);border:1px solid var(--border);border-radius:7px;padding:8px;font-family:inherit;font-size:.78rem;cursor:pointer}
.src-btn.active{background:#d9b95c;color:#2a2110;font-weight:600;border-color:#d9b95c}
.filter-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:8px}
.f-input,.f-sel{background:var(--bg-2);border:1px solid var(--border);border-radius:7px;padding:8px 11px;color:var(--text);font-family:inherit;font-size:.82rem}
.f-input{flex:2;min-width:150px}
.f-sel{flex:1;min-width:100px;cursor:pointer}
.f-sel.sm{flex:0 1 auto}
.f-reset{background:none;border:1px solid var(--border);color:var(--text-faint);border-radius:7px;padding:8px 14px;font-family:inherit;font-size:.8rem;cursor:pointer}
.f-reset:hover{border-color:var(--green-soft);color:var(--green-soft)}
.f-count{color:var(--text-faint);font-size:.78rem;margin-top:2px}
/* строки заклинаний */
.spell-row{display:flex;justify-content:space-between;align-items:center;background:var(--bg-2);border-radius:7px;padding:9px 13px;margin-bottom:4px;text-decoration:none;color:var(--green-soft);font-size:.92rem}
.spell-row:hover{background:#16241b}
.sp-school{color:var(--text-faint);font-size:.78rem}
.tag-r{color:#d8b4fe;font-style:normal;font-size:.7rem;border:1px solid #7e3ff2;border-radius:4px;padding:1px 5px;margin-left:5px}

/* ====== панель фильтров в стиле dnd.su ====== */
.dnd-filter{max-width:980px;margin:10px auto 0;background:#0e1712;border:1px solid var(--border);border-radius:10px;padding:10px}
.dnd-srctabs{display:flex;gap:8px;margin-bottom:9px}
.dnd-src{flex:1;background:#e8e0cf;color:#3a3a32;border:none;border-radius:7px;padding:11px;font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:.15s}
.dnd-src:hover{background:#efe9da}
.dnd-src.active{background:#d9b95c;color:#2a2110}
.cl-src,.cl-view{flex:1;background:#e8e0cf;color:#3a3a32;border:none;border-radius:8px;padding:9px;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:.15s}
.cl-src:hover,.cl-view:hover{background:#efe9da}
.cl-src.active,.cl-view.active{background:#d9b95c;color:#2a2110}
.dnd-row{display:flex;gap:7px;margin-bottom:7px;align-items:flex-start;flex-wrap:wrap}
.dnd-sel,.dnd-search input{background:#e8e0cf;border:none;border-radius:8px;height:44px;padding:0 14px;box-sizing:border-box;color:#3a3a32;font-family:inherit;font-size:.88rem;cursor:pointer}
.dnd-sel{flex:1 1 90px;min-width:88px;max-width:230px;box-sizing:border-box;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;appearance:none;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='%237a7363'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:28px}
.dnd-sel option{background:#e8e0cf;color:#3a3a32}
.dnd-search{flex:1.3 1 130px;min-width:120px;max-width:240px;height:44px;position:relative;display:flex}
.dnd-search input{flex:1;width:100%;box-sizing:border-box}
.dnd-search input::placeholder{color:#8a8270}
.dnd-search span{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#8a8270}
.dnd-exclude{background:#e8e0cf;border:none;border-radius:8px;height:44px;padding:0 16px;box-sizing:border-box;color:#3a3a32;font-family:inherit;font-size:.88rem;cursor:pointer;display:flex;align-items:center;gap:7px}
.dnd-exclude .x{color:#c98a6a;font-weight:bold}
.dnd-exclude.on{background:#c98a6a;color:#fff}
.dnd-actions{display:flex;gap:0;border-radius:8px;overflow:hidden;margin-left:auto}
.dnd-act-btn{background:#5a5a52;color:#e8e0cf;border:none;padding:11px 15px;font-family:inherit;font-size:1rem;cursor:pointer}
.dnd-act-btn.dnd-x{background:#c98a6a}
.dnd-go{flex:0 0 auto;background:var(--green);color:#1a3326;border:none;border-radius:8px;padding:11px 26px;font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer}
.dnd-sortrow{display:flex;gap:7px;align-items:center;padding-top:4px}
.dnd-sort{background:#e8e0cf;border:none;border-radius:7px;padding:8px 16px;color:#3a3a32;font-family:inherit;font-size:.88rem;cursor:pointer}
.dnd-sort.active{background:#d9b95c;color:#2a2110;font-weight:600}
.dnd-gear{background:#5a5a52;color:#e8e0cf;border:none;border-radius:7px;padding:8px 12px;cursor:pointer;font-size:1rem}
@media(max-width:640px){.dnd-row{flex-wrap:wrap}.dnd-sel,.dnd-search{min-width:44%}}

/* сетка мини-карточек (характеристики, навыки) */
.grid-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(max-width:520px){.grid-cards{grid-template-columns:1fr}}
.mini-card{display:block;background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:9px;padding:11px 13px;text-decoration:none;color:var(--text)}
.mini-card:hover{border-color:var(--green-line)}
.mini-card b{color:var(--green-soft)}
.mini-card div{color:var(--text-soft);font-size:.82rem;line-height:1.45;margin-top:4px}

/* кнопка Поиск отдельной строкой внизу */
.dnd-go-full{width:100%;background:var(--green);color:#1a3326;border:none;border-radius:8px;padding:12px;font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;margin-top:4px}
.dnd-go-full:hover{filter:brightness(1.08)}

/* ====== список заклинаний в стиле dnd.su ====== */
.spell-legend{max-width:980px;margin:8px auto 0;background:#0e1712;border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:.72rem;color:var(--text-soft)}
.legend-top{text-align:right;margin-bottom:6px}
.legend-top b{color:var(--text)}
.lg-conc{background:#5e9cd6;color:#0c1410;border-radius:4px;padding:0 5px;font-weight:bold}
.lg-rit{background:#a78bfa;color:#0c1410;border-radius:4px;padding:0 5px;font-weight:bold}
.legend-schools{display:flex;flex-wrap:wrap;gap:4px 14px;justify-content:center;border-top:1px solid var(--border);padding-top:6px}
.legend-schools span{color:var(--text-soft)}
.grp-head{color:var(--green);font-weight:bold;font-size:1rem;font-family:'Cinzel',serif;margin:10px 0 4px}
.spell-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px 18px}
@media(max-width:760px){.spell-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.spell-grid{grid-template-columns:1fr}}
.sp-item{display:grid;grid-template-columns:22px 15px minmax(0,1fr) 64px;align-items:center;gap:5px;padding:4px 4px;border-bottom:1px solid #1a2b20;text-decoration:none;font-size:.85rem;color:var(--text)}
.sp-item:hover{background:#142318}
.sp-lvl{color:var(--text-faint);font-size:.78rem;text-align:center}
.sp-ic{color:var(--green-soft);text-align:center;font-size:.95rem}
.sp-nm{color:var(--text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-item:hover .sp-nm{color:var(--green-soft)}
/* правый блок: концентрация + компоненты, фиксированная ширина для ровного выравнивания */
.sp-right{display:flex;align-items:center;justify-content:flex-end;gap:4px}
.conc-bar{width:4px;height:14px;background:#5e9cd6;border-radius:2px;flex:none}
.rit-mark{color:#a78bfa;font-size:.72rem;font-weight:bold;flex:none}
.sp-comp{display:flex;gap:2px;flex:none}
.sp-comp .c{color:#3a4a40;font-size:.74rem;font-weight:bold;width:11px;text-align:center}
.sp-comp .c.on{color:#8fb8d8}

/* метка плетения в списке магии */
.kind-tag{font-size:.62rem;color:#a78bfa;background:rgba(167,139,250,.12);border-radius:4px;padding:0 4px;margin-left:5px;vertical-align:middle}

/* табы типа на вкладке Homebrew */
.kind-tabs{display:flex;gap:5px;flex-wrap:wrap;margin:8px 0 4px}
.kind-btn{background:#e8e0cf;color:#3a3a32;border:none;border-radius:6px;padding:6px 13px;font-family:inherit;font-size:.82rem;cursor:pointer}
.kind-btn.active{background:#d9b95c;color:#2a2110;font-weight:600}

/* мультиселект класса */
.dnd-multi{position:relative;flex:1 1 90px;min-width:88px;max-width:230px;height:44px}
.dnd-multi-btn{display:flex;width:100%;height:44px;align-items:center;justify-content:space-between;gap:6px;box-sizing:border-box;background:#e8e0cf;color:#3a3a32;border:none;border-radius:8px;padding:0 13px;font-family:inherit;font-size:.88rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dnd-multi-btn.has{background:#d9b95c;color:#2a2110;font-weight:600}
.dnd-multi-btn:after{content:'▾';color:#8a8270;flex:0 0 auto}
.dnd-reset{flex:0 0 auto;width:auto;background:rgba(224,168,74,.15);border:1px solid rgba(224,168,74,.4);border-radius:6px;padding:9px 18px;font-family:inherit;font-size:.88rem;color:#e0a84a;cursor:pointer;white-space:nowrap}
.dnd-named{flex:0 0 auto;display:flex;align-items:center;gap:7px;background:#e8e0cf;color:#3a3a32;border-radius:8px;padding:11px 14px;font-family:inherit;font-size:.88rem;cursor:pointer;white-space:nowrap}
.dnd-named input{accent-color:#4ade80;cursor:pointer}
.dnd-reset:hover{background:rgba(224,168,74,.25)}
.dnd-multi-pop{display:none;position:absolute;top:calc(100% + 4px);left:0;z-index:30;background:#1a2620;border:1px solid var(--border);border-radius:8px;padding:8px;max-height:240px;overflow-y:auto;min-width:200px;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.dnd-multi-pop.open{display:block}
.dnd-multi-pop label{display:flex;align-items:center;gap:7px;padding:4px 6px;font-size:.85rem;color:var(--text-soft);cursor:pointer;border-radius:5px;white-space:nowrap}
.dnd-multi-pop label:hover{background:#223027}
.dnd-multi-pop input{width:auto;accent-color:#4ade80}
