:root{
  --bg:#0c0f16;
  --bg2:#121620;
  --panel:#161b27;
  --panel2:#1c2230;
  --line:#2a3242;
  --ink:#e8e2d4;
  --ink-soft:#9aa3b2;
  --gold:#caa24a;
  --gold-bright:#e8c878;
  --jade:#5fae86;
  --qi:#6cc4d6;
  --danger:#c0584b;
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Noto Serif SC',Georgia,serif;
  background:
    radial-gradient(900px 500px at 80% -5%, #1a2235 0%, transparent 55%),
    radial-gradient(700px 500px at 0% 110%, #15281f 0%, transparent 50%),
    linear-gradient(160deg,#0c0f16,#0a0d13 70%);
  color:var(--ink);
  min-height:100vh;
  overflow-x:hidden;
}

/* плывущий туман на фоне */
.mist{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background:
    radial-gradient(500px 200px at 20% 30%, rgba(180,200,220,.06), transparent 70%),
    radial-gradient(600px 240px at 75% 60%, rgba(160,190,210,.05), transparent 70%);
  animation:drift 24s ease-in-out infinite alternate;
}
@keyframes drift{from{transform:translateX(-3%)}to{transform:translateX(3%)}}

/* силуэты гор внизу */
.mountains{
  position:fixed;left:0;right:0;bottom:0;height:240px;z-index:0;pointer-events:none;opacity:.5;
  background:
    radial-gradient(420px 220px at 12% 100%, #1b2a3a 0%, transparent 70%),
    radial-gradient(520px 260px at 42% 100%, #16202e 0%, transparent 72%),
    radial-gradient(480px 240px at 72% 100%, #1a2636 0%, transparent 72%),
    radial-gradient(380px 200px at 95% 100%, #141d2a 0%, transparent 70%);
}

/* парящие журавли */
.cranes{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.crane{
  position:absolute;left:-6%;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.5)) hue-rotate(-15deg);
  animation:flyAcross linear infinite;
}
@keyframes flyAcross{
  0%{transform:translateX(0) translateY(0)}
  50%{transform:translateX(55vw) translateY(-18px)}
  100%{transform:translateX(112vw) translateY(6px)}
}

.topbar,.realm,.layout{position:relative;z-index:1}

/* ---------- Topbar ---------- */
.topbar{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:14px 20px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(20,25,36,.9),rgba(12,15,22,.7));
  backdrop-filter:blur(6px);
}
.brand{display:flex;align-items:center;gap:12px}
.seal{
  font-family:'Ma Shan Zheng',cursive;font-size:34px;color:#fff;
  width:52px;height:52px;display:grid;place-items:center;border-radius:12px;
  background:linear-gradient(135deg,var(--danger),#8c3a30);
  box-shadow:0 6px 18px rgba(192,88,75,.4), inset 0 0 0 2px rgba(255,255,255,.1);
}
.brand h1{margin:0;font-size:21px;font-weight:700;letter-spacing:.5px}
.brand small{color:var(--gold);font-size:12px;letter-spacing:2px;text-transform:uppercase}
.top-actions{margin-left:auto;display:flex;gap:8px}

/* ресурсы */
.resources{display:flex;gap:8px;flex-wrap:wrap;flex:1;justify-content:center}
.res{
  display:flex;align-items:center;gap:6px;
  background:var(--panel);border:1px solid var(--line);
  padding:6px 11px;border-radius:10px;font-size:14px;min-width:74px;
}
.res-ico{font-size:16px}
.res-val{font-weight:700}
.res-rate{color:var(--jade);font-size:11.5px;margin-left:auto}

/* ---------- Realm bar ---------- */
.realm{
  margin:14px 20px 0;padding:12px 18px;border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(108,196,214,.08),rgba(202,162,74,.06));
  border:1px solid var(--line);
}
.realm-name{font-size:16px;font-weight:700;color:var(--gold-bright)}
.realm-bonus{color:var(--ink-soft);font-size:13px;margin:3px 0 8px}
.realm-bar{height:9px;border-radius:6px;background:#0c1018;overflow:hidden;border:1px solid var(--line)}
.realm-fill{height:100%;background:linear-gradient(90deg,var(--qi),var(--gold));transition:width .4s}
.realm-next{font-size:12px;color:var(--ink-soft);margin-top:6px}

/* ---------- Layout ---------- */
.layout{
  display:grid;grid-template-columns:1fr 380px;gap:18px;
  padding:18px 20px 40px;max-width:1200px;margin:0 auto;
}
.col-title{font-size:15px;margin:6px 0 10px;color:var(--gold);font-weight:600;letter-spacing:.5px}

/* ---------- Map ---------- */
.map-wrap{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px;display:flex;justify-content:center;
}
#map{border-radius:10px;cursor:pointer;display:block;max-width:100%}
.hint{color:var(--ink-soft);font-size:12.5px;margin:10px 2px 0;line-height:1.5}

.trade{margin-top:14px}
.trade-row{font-size:14px;margin-bottom:8px}

/* ---------- Log ---------- */
.log{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;max-height:200px;overflow:auto;font-size:13px;line-height:1.7;
}
.log-line{padding:3px 0;border-bottom:1px dashed rgba(255,255,255,.05)}
.log-line:last-child{border-bottom:none}
.muted{color:var(--ink-soft)}

/* ---------- Tabs (правая колонка) ---------- */
.tabs{display:flex;gap:8px;margin-bottom:14px}
.tab{
  flex:1;padding:11px;border:1px solid var(--line);background:var(--panel);
  color:var(--ink-soft);border-radius:11px;cursor:pointer;font-family:inherit;
  font-size:14px;font-weight:600;transition:.15s;
}
.tab.active{background:linear-gradient(135deg,var(--gold),#9a7a2e);color:#1a1206;border-color:transparent}
.panel{display:none}
.panel.active{display:block}

.cap-info{color:var(--ink-soft);font-size:13px;margin-bottom:10px;text-align:center}

/* теги таланта/ранга у ученика */
.d-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:9px}
.tag{font-size:11px;padding:2px 8px;border-radius:6px;border:1px solid var(--line)}
.tag-rank{color:var(--ink-soft)}
.disciple.is-hurt{border-color:#4a2a26;background:linear-gradient(180deg,rgba(192,88,75,.06),var(--panel))}
.d-hurt{color:#e88;font-size:12.5px}
.d-busy{color:var(--gold);font-size:12.5px}
.d-row select:disabled{opacity:.5}

/* активные варки / экспедиции */
.brew-active{display:flex;flex-direction:column;gap:7px;margin-bottom:12px}
.brew-row{
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(202,162,74,.08);border:1px solid rgba(202,162,74,.25);
  border-radius:10px;padding:9px 12px;font-size:13px;
}
.brew-timer{font-variant-numeric:tabular-nums;color:var(--gold-bright);font-weight:700}

/* выбор учеников для охоты */
.hunt-pick{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;margin-bottom:12px}
.hunt-pick-title{font-size:12.5px;color:var(--ink-soft);margin-bottom:8px}
.hunt-list{display:flex;flex-direction:column;gap:6px}
.hp{display:flex;align-items:center;gap:8px;font-size:13.5px;cursor:pointer}
.hp small{color:var(--ink-soft)}
.hp input{accent-color:var(--gold)}

.alchemy,.hunt{display:flex;flex-direction:column;gap:10px}

/* ---------- Cards (buildings) ---------- */
.buildings{display:flex;flex-direction:column;gap:10px}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:13px 15px;transition:.15s;
}
.card:hover{border-color:#3a4458}
.card-head{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.b-ico{font-size:24px}
.b-name{font-weight:700;font-size:14.5px}
.b-lvl{color:var(--ink-soft);font-size:12px}
.b-desc{color:var(--ink-soft);font-size:12.5px;line-height:1.5;margin-bottom:10px}

/* ---------- Disciples ---------- */
.disciples{display:flex;flex-direction:column;gap:10px}
.disciple{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;
}
.d-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.d-name{font-weight:700;font-size:14.5px}
.d-lvl{font-size:11.5px;color:var(--gold);background:rgba(202,162,74,.12);padding:2px 8px;border-radius:6px}
.d-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.d-row select{
  flex:1;padding:8px 10px;background:var(--panel2);color:var(--ink);
  border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:13px;
}
.d-prod{font-size:12.5px;color:var(--jade);white-space:nowrap}
.empty{color:var(--ink-soft);font-size:13px;text-align:center;padding:20px 0;line-height:1.6}

/* ---------- Buttons ---------- */
.btn{
  border:1px solid var(--line);background:var(--panel2);color:var(--ink);
  padding:9px 14px;border-radius:10px;cursor:pointer;font-family:inherit;
  font-size:13.5px;font-weight:600;transition:.14s;width:100%;
}
.btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold-bright)}
.btn:active:not(:disabled){transform:translateY(1px)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-dim{opacity:.5}
.btn-accent{background:linear-gradient(135deg,var(--jade),#3d8862);color:#06140d;border-color:transparent;margin-bottom:12px}
.btn-accent:hover:not(:disabled){color:#fff}
.btn-sm{width:auto;padding:7px 11px;font-size:12.5px}
.btn-danger{border-color:#4a2a26}
.btn-danger:hover{border-color:var(--danger);color:#e88}

/* ---------- Toasts ---------- */
.toasts{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:50;
  display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{
  background:rgba(28,34,48,.97);border:1px solid var(--gold);color:var(--ink);
  padding:11px 18px;border-radius:11px;font-size:13.5px;box-shadow:0 10px 30px rgba(0,0,0,.5);
  opacity:0;transform:translateY(12px);transition:.3s;max-width:90vw;text-align:center;
}
.toast.show{opacity:1;transform:translateY(0)}

/* ---------- Mobile ---------- */
@media(max-width:880px){
  .layout{grid-template-columns:1fr}
  .resources{order:3;width:100%;justify-content:flex-start}
  .top-actions{order:2}
}
