/* ═══════════════════════════════════════
   АЛАТАУ АЛАУЫ — Design System
═══════════════════════════════════════ */
:root {
  --gold:        #c9920a;
  --gold-mid:    #d4980e;
  --gold-bright: #f0b429;
  --flame:       #e85d04;
  --navy:        #0d1526;
  --bg:          #f5f7fc;
  --bg2:         #edf0f8;
  --surface:     #ffffff;
  --surf2:       #f9fafb;
  --surf3:       #f1f3f9;
  --text1:       #0f172a;
  --text2:       #334155;
  --text3:       #64748b;
  --text4:       #94a3b8;
  --border:      rgba(0,0,0,0.07);
  --border2:     rgba(0,0,0,0.11);
  --gold-bg:     rgba(212,152,14,0.08);
  --gold-border: rgba(212,152,14,0.22);
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.06),0 4px 12px rgba(0,0,0,0.04);
  --shadow-md:   0 4px 16px rgba(0,0,0,0.07),0 1px 3px rgba(0,0,0,0.05);
  --shadow-lg:   0 8px 32px rgba(0,0,0,0.09),0 2px 8px rgba(0,0,0,0.05);
  --shadow-xl:   0 16px 48px rgba(0,0,0,0.11),0 4px 16px rgba(0,0,0,0.06);
  --shadow-gold: 0 4px 24px rgba(212,152,14,0.25);
  --nav-h:       64px;
  --radius:      16px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text1);
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
h1,h2,h3,h4,h5,h6 {
  font-family:'Space Grotesk',system-ui,sans-serif;
  line-height:1.2;
  color:var(--text1);
}
a { text-decoration:none; color:inherit; cursor:pointer; }
img { display:block; max-width:100%; }
button { cursor:pointer; font:inherit; border:none; background:none; }
textarea,input,select { font:inherit; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--gold-mid); border-radius:99px; }
::selection { background:rgba(212,152,14,0.2); }
*:focus-visible { outline:2.5px solid var(--gold-mid); outline-offset:2px; border-radius:4px; }

/* ── Loader ── */
.page-loader {
  display:flex; align-items:center; justify-content:center;
  min-height:100vh;
}
.spinner {
  width:40px; height:40px;
  border:3px solid var(--gold-border);
  border-top-color:var(--gold-mid);
  border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Navbar ── */
#navbar-root { position:fixed; top:0; inset-inline:0; z-index:100; }
.navbar {
  height:var(--nav-h);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:0 40px;
  max-width:1280px; margin:0 auto;
}
.navbar-wrap {
  position:fixed; top:0; inset-inline:0; z-index:100;
  background:rgba(245,247,252,0.85);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
  border-bottom:1px solid transparent;
  transition:background .3s, border-color .3s, box-shadow .3s;
}
.navbar-wrap.scrolled {
  background:rgba(245,247,252,0.96);
  border-bottom-color:rgba(0,0,0,0.07);
  box-shadow:0 1px 20px rgba(0,0,0,0.06);
}
.nav-logo { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.nav-logo-img {
  width:36px; height:36px; border-radius:10px;
  overflow:hidden; border:1.5px solid rgba(212,152,14,0.5);
  box-shadow:0 0 0 3px rgba(212,152,14,0.08);
  flex-shrink:0;
}
.nav-logo-img img { width:100%; height:100%; object-fit:cover; }
.nav-logo-text { display:none; }
@media(min-width:640px) {
  .nav-logo-text { display:block; }
  .nav-logo-text .t1 { font-size:.875rem; font-weight:700; color:var(--gold); }
  .nav-logo-text .t2 { font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(13,21,38,.3); margin-top:1px; }
}
.nav-links { display:none; align-items:center; gap:2px; }
@media(min-width:1024px) { .nav-links { display:flex; } }
.nav-link {
  padding:8px 14px; border-radius:10px;
  font-size:.8125rem; font-weight:500;
  color:rgba(13,21,38,.55);
  transition:color .2s, background .2s;
  position:relative;
}
.nav-link:hover { color:var(--gold); }
.nav-link.active {
  color:var(--gold);
  background:rgba(201,146,10,0.09);
  border:1px solid rgba(201,146,10,0.2);
}
.nav-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.nav-btn-dash {
  display:none; align-items:center; gap:6px;
  padding:8px 16px; border-radius:10px; font-size:.75rem; font-weight:600;
  background:rgba(201,146,10,0.1); border:1px solid rgba(201,146,10,0.22); color:var(--gold);
  transition:background .2s;
}
@media(min-width:640px) { .nav-btn-dash { display:flex; } }
.nav-btn-dash:hover { background:rgba(201,146,10,0.18); }
.nav-btn-logout {
  width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,0.04); border:1px solid rgba(0,0,0,0.07); color:rgba(13,21,38,.4);
  transition:all .2s;
}
.nav-btn-logout:hover { color:#ef4444; border-color:rgba(239,68,68,.3); background:rgba(239,68,68,.08); }
.nav-burger {
  width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,0.04); border:1px solid rgba(0,0,0,0.07); color:rgba(13,21,38,.55);
}
@media(min-width:1024px) { .nav-burger { display:none; } }
.mobile-menu {
  display:none; flex-direction:column; gap:4px;
  padding:12px 20px 16px;
  background:rgba(245,247,252,0.98); border-bottom:1px solid rgba(0,0,0,0.06);
  backdrop-filter:blur(28px);
}
.mobile-menu.open { display:flex; }
.mobile-link {
  padding:12px 16px; border-radius:10px; font-size:.875rem; font-weight:500;
  color:rgba(13,21,38,.6); border:1px solid transparent;
  transition:all .15s;
}
.mobile-link:hover, .mobile-link.active {
  background:rgba(201,146,10,0.08); color:var(--gold); border-color:rgba(201,146,10,0.18);
}

/* ── Page base ── */
.page { padding-top:calc(var(--nav-h) + 32px); min-height:100vh; }

/* ── Containers ── */
.container { max-width:1280px; margin:0 auto; padding:0 20px; }
@media(min-width:640px) { .container { padding:0 32px; } }

/* ── Grid ── */
.grid-3 { display:grid; grid-template-columns:1fr; gap:20px; }
@media(min-width:640px) { .grid-3 { grid-template-columns:1fr 1fr; } }
@media(min-width:1024px) { .grid-3 { grid-template-columns:1fr 1fr 1fr; } }
.grid-6 { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media(min-width:640px) { .grid-6 { grid-template-columns:repeat(3,1fr); } }
@media(min-width:1024px) { .grid-6 { grid-template-columns:repeat(6,1fr); } }
.grid-4 { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media(min-width:1024px) { .grid-4 { grid-template-columns:repeat(4,1fr); } }
.grid-2 { display:grid; grid-template-columns:1fr; gap:24px; }
@media(min-width:1024px) { .grid-2 { grid-template-columns:1fr 1fr; } }

/* ── Badge ── */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 12px; border-radius:999px;
  font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  background:var(--gold-bg); border:1px solid var(--gold-border); color:var(--gold);
}

/* ── Buttons ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 26px; border-radius:12px;
  font-weight:700; font-size:.875rem;
  background:linear-gradient(135deg,var(--gold-mid) 0%,var(--flame) 100%);
  color:#fff; border:none;
  box-shadow:var(--shadow-gold);
  transition:transform .15s, box-shadow .15s, filter .15s;
  user-select:none;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(212,152,14,.38); filter:brightness(1.05); }
.btn-primary:active { transform:translateY(0); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 24px; border-radius:12px;
  font-weight:600; font-size:.875rem;
  background:var(--surface); border:1px solid var(--border2); color:var(--text2);
  box-shadow:0 1px 2px rgba(0,0,0,.05);
  transition:transform .15s, box-shadow .15s, border-color .15s;
}
.btn-ghost:hover { background:var(--surf3); border-color:rgba(0,0,0,.16); transform:translateY(-1px); box-shadow:var(--shadow-sm); }
.btn-sm { padding:7px 16px; font-size:.8125rem; border-radius:10px; }
.btn-icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:9px;
  background:var(--surface); border:1px solid var(--border); color:var(--text3);
  transition:all .15s;
}
.btn-icon:hover { background:var(--surf3); color:var(--text1); }
.btn-danger {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:9px; font-size:.8125rem; font-weight:600;
  background:rgba(239,68,68,.07); border:1px solid rgba(239,68,68,.18); color:#dc2626;
  transition:all .15s;
}
.btn-danger:hover { background:rgba(239,68,68,.14); }
.btn-edit {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:9px; font-size:.8125rem; font-weight:600;
  background:rgba(212,152,14,.08); border:1px solid rgba(212,152,14,.2); color:var(--gold);
  transition:all .15s;
}
.btn-edit:hover { background:rgba(212,152,14,.16); }

/* ── Form inputs ── */
.input {
  width:100%; padding:11px 16px; border-radius:12px;
  font-size:.875rem; background:var(--surf3); border:1.5px solid var(--border2);
  color:var(--text1); outline:none;
  transition:border-color .18s, background .18s, box-shadow .18s;
}
.input:focus { border-color:var(--gold-mid); background:var(--surface); box-shadow:0 0 0 3px rgba(212,152,14,.1); }
.input::placeholder { color:var(--text4); }
textarea.input { resize:vertical; min-height:120px; line-height:1.6; }
select.input { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }
.label { display:block; font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text3); margin-bottom:6px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:600px) { .form-row { grid-template-columns:1fr; } }

/* ── Card ── */
.card {
  background:var(--surface); border:1px solid var(--border); border-radius:20px;
  box-shadow:var(--shadow-sm);
  transition:transform .22s cubic-bezier(.16,1,.3,1), box-shadow .22s, border-color .22s;
  overflow:hidden;
}
.card:hover { transform:translateY(-5px); box-shadow:var(--shadow-xl); border-color:var(--gold-border); }
.card-img { width:100%; height:200px; object-fit:cover; background:var(--surf3); display:block; }
.card-img-placeholder { width:100%; height:200px; background:linear-gradient(135deg,var(--surf3),var(--bg2)); display:flex; align-items:center; justify-content:center; color:var(--text4); font-size:2.5rem; }
.card-body { padding:20px; }
.card-cat {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:999px; font-size:.65rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  margin-bottom:10px;
}
.card-title { font-size:1.0625rem; font-weight:700; color:var(--text1); margin-bottom:8px; line-height:1.35; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.card-excerpt { font-size:.8125rem; color:var(--text3); line-height:1.6; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:16px; }
.card-meta { display:flex; align-items:center; gap:12px; font-size:.75rem; color:var(--text4); }
.card-meta i { font-size:.7rem; }

/* ── Hero ── */
.hero {
  min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:80px 20px 60px; text-align:center; position:relative;
}
.hero-inner { max-width:800px; margin:0 auto; }
.hero-emblem-wrap {
  position:relative; width:148px; height:148px; margin:0 auto 36px;
}
.hero-emblem {
  width:100%; height:100%; border-radius:50%; overflow:hidden;
  border:2.5px solid rgba(212,152,14,.55);
  box-shadow:0 0 36px rgba(212,152,14,.28), 0 0 0 6px rgba(212,152,14,.07);
  background:#fff; position:relative; z-index:1;
}
.hero-emblem img { width:100%; height:100%; object-fit:cover; }
.hero-ring {
  position:absolute; inset:0; border-radius:50%;
  border:1px solid rgba(212,152,14,.2);
  animation:pulse-ring 3.5s ease-in-out infinite;
}
.hero-ring:nth-child(2) { transform:scale(1.35); animation-delay:.8s; }
.hero-ring:nth-child(3) { transform:scale(1.7);  animation-delay:1.6s; }
.hero-title {
  font-size:clamp(3rem,9vw,6.5rem);
  font-weight:900; line-height:1; tracking-tight; margin-bottom:16px;
}
.shimmer-text {
  background:linear-gradient(90deg,var(--gold-mid) 0%,var(--gold-bright) 35%,#f97316 55%,var(--gold-mid) 100%);
  background-size:200% auto;
  animation:shimmer 4s linear infinite;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-sub {
  display:flex; align-items:center; justify-content:center; gap:12px;
  margin-bottom:16px;
}
.hero-sub-line { width:48px; height:1px; }
.hero-sub-text { font-size:.6875rem; letter-spacing:.35em; text-transform:uppercase; font-weight:600; color:var(--gold); }
.hero-desc { font-size:1.0625rem; color:rgba(13,21,38,.55); max-width:520px; margin:0 auto 40px; line-height:1.7; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-bottom:64px; }
.hero-stats { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
@media(min-width:640px) { .hero-stats { grid-template-columns:repeat(4,1fr); } }
.stat-card {
  padding:20px 16px; border-radius:18px;
  display:flex; flex-direction:column; align-items:center; gap:8px; text-align:center;
  transition:transform .2s, background .2s;
}
.stat-card:hover { transform:scale(1.03); }
.stat-icon { width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center; }
.stat-value { font-size:1.5rem; font-weight:900; }
.stat-label { font-size:.6875rem; color:rgba(13,21,38,.4); line-height:1.3; }
.scroll-cue {
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:6px;
  animation:float-up 2s ease-in-out infinite;
}
.scroll-line { width:1px; height:32px; background:linear-gradient(to bottom,rgba(201,146,10,.5),transparent); }
.scroll-dot { width:6px; height:6px; border-radius:50%; background:var(--gold); }

/* ── Section ── */
.section { padding:80px 0; }
.section-header { text-align:center; margin-bottom:56px; }
.section-header h2 { font-size:clamp(1.8rem,4vw,2.8rem); margin-bottom:12px; }
.section-header p { color:rgba(13,21,38,.45); font-size:.9375rem; }
.section-title-row { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:16px; margin-bottom:40px; }
.section-title-row h2 { font-size:clamp(1.6rem,3.5vw,2.4rem); }
.see-all { display:flex; align-items:center; gap:6px; font-size:.875rem; font-weight:600; color:var(--gold); transition:transform .2s; }
.see-all:hover { transform:translateX(3px); }

/* ── Divider ── */
.divider-gold { height:1px; border:none; background:linear-gradient(90deg,transparent 0%,var(--gold-border) 30%,var(--gold-border) 70%,transparent 100%); margin:60px 0; }

/* ── Section cards (categories) ── */
.section-card {
  padding:20px 16px; border-radius:18px; text-align:center;
  border:1px solid; cursor:pointer;
  transition:transform .22s cubic-bezier(.16,1,.3,1), background .2s, box-shadow .2s;
  position:relative; overflow:hidden;
  display:block;
}
.section-card:hover { transform:translateY(-6px); }
.section-card-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin:0 auto 12px; }
.section-card-label { font-size:.8125rem; font-weight:700; color:var(--text1); margin-bottom:2px; }
.section-card-sub { font-size:.625rem; color:rgba(13,21,38,.4); line-height:1.4; }
.section-card-arrow { position:absolute; top:12px; right:12px; font-size:.8125rem; opacity:0; transition:opacity .2s; }
.section-card:hover .section-card-arrow { opacity:1; }

/* ── Article detail ── */
.article { max-width:800px; margin:0 auto; padding:32px 0 80px; }
.article-img { width:100%; height:400px; object-fit:cover; border-radius:20px; margin-bottom:32px; }
@media(max-width:640px) { .article-img { height:220px; } }
.article-meta { display:flex; flex-wrap:wrap; align-items:center; gap:12px; margin-bottom:20px; font-size:.8125rem; color:var(--text3); }
.article-title { font-size:clamp(1.6rem,4vw,2.4rem); font-weight:800; margin-bottom:20px; line-height:1.25; }
.article-excerpt { font-size:1.0625rem; color:var(--text2); line-height:1.75; margin-bottom:32px; padding-bottom:32px; border-bottom:1px solid var(--border); }
.prose p { margin-bottom:1.25rem; color:var(--text2); line-height:1.8; }
.prose h2 { margin:2rem 0 1rem; font-size:1.4rem; }
.prose h3 { margin:1.5rem 0 .75rem; font-size:1.15rem; }
.prose ul, .prose ol { margin:1rem 0 1rem 1.5rem; color:var(--text2); }
.prose li { margin-bottom:.4rem; }
.prose strong { color:var(--text1); font-weight:700; }
.prose blockquote { border-left:3px solid var(--gold-mid); padding-left:1rem; color:var(--text3); font-style:italic; margin:1.25rem 0; }

/* ── Login ── */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:80px 20px; }
.login-box { background:var(--surface); border:1px solid var(--border); border-radius:24px; box-shadow:var(--shadow-xl); padding:40px; width:100%; max-width:420px; }
.login-logo { text-align:center; margin-bottom:32px; }
.login-logo img { width:64px; height:64px; border-radius:18px; border:2px solid rgba(212,152,14,.4); margin:0 auto 12px; object-fit:cover; }
.login-logo h2 { font-size:1.25rem; color:var(--text1); }
.login-logo p { font-size:.8125rem; color:var(--text3); margin-top:4px; }
.login-form { display:flex; flex-direction:column; gap:16px; }
.input-wrap { position:relative; }
.input-wrap .input { padding-left:42px; }
.input-icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--text4); font-size:.875rem; pointer-events:none; }
.input-eye { position:absolute; right:14px; top:50%; transform:translateY(-50%); color:var(--text4); font-size:.8125rem; background:none; border:none; cursor:pointer; padding:4px; }
.login-error { padding:12px 16px; border-radius:10px; font-size:.875rem; display:flex; align-items:center; gap:8px; background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.2); color:#dc2626; }

/* ── Dashboard ── */
.dash-page { min-height:100vh; padding:calc(var(--nav-h) + 32px) 0 80px; }
.dash-header { display:flex; align-items:center; gap:16px; margin-bottom:32px; }
.dash-avatar {
  width:56px; height:56px; border-radius:18px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; font-weight:900; color:#fff;
}
.dash-name { font-size:1.5rem; font-weight:900; }
.dash-role { display:inline-flex; align-items:center; padding:2px 10px; border-radius:999px; font-size:.7rem; font-weight:600; margin-top:4px; }
.dash-tabs { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:32px; }
.tab-btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 18px; border-radius:12px; font-size:.8125rem; font-weight:600;
  background:var(--surface); border:1.5px solid var(--border); color:var(--text3);
  cursor:pointer; transition:all .15s;
}
.tab-btn:hover { color:var(--text2); border-color:var(--border2); }
.tab-btn.active { background:var(--gold-bg); border-color:var(--gold-border); color:var(--gold); }
.dash-stats { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media(min-width:768px) { .dash-stats { grid-template-columns:repeat(4,1fr); } }
.dash-stat {
  background:var(--surface); border-radius:20px; padding:24px;
  border:1px solid var(--border); box-shadow:var(--shadow-sm);
  transition:transform .2s, box-shadow .2s;
}
.dash-stat:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.dash-stat-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.dash-stat-value { font-size:1.875rem; font-weight:900; margin-bottom:4px; }
.dash-stat-label { font-size:.75rem; color:var(--text4); }

/* ── News list (dashboard) ── */
.news-row {
  display:flex; align-items:center; gap:16px; padding:16px;
  background:var(--surface); border:1px solid var(--border); border-radius:14px;
  box-shadow:0 2px 8px rgba(0,0,0,.04); transition:box-shadow .2s;
  margin-bottom:10px;
}
.news-row:hover { box-shadow:var(--shadow-sm); }
.news-row-info { flex:1; min-width:0; }
.news-row-title { font-size:.875rem; font-weight:600; color:var(--text1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:4px; }
.news-row-meta { font-size:.6875rem; color:var(--text4); display:flex; align-items:center; gap:10px; }
.news-row-actions { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.status-pill {
  padding:2px 8px; border-radius:999px; font-size:.6875rem; font-weight:600; flex-shrink:0;
}
.status-pub { background:rgba(16,185,129,.1); border:1px solid rgba(16,185,129,.2); color:#059669; }
.status-hid { background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.15); color:#dc2626; }
.btn-toggle {
  width:32px; height:32px; border-radius:9px; border:1px solid; display:flex; align-items:center; justify-content:center; font-size:.8125rem; transition:all .15s;
}
.btn-toggle-pub { background:rgba(16,185,129,.1); border-color:rgba(16,185,129,.2); color:#059669; }
.btn-toggle-pub:hover { background:rgba(16,185,129,.2); }
.btn-toggle-hid { background:rgba(0,0,0,.04); border-color:rgba(0,0,0,.07); color:var(--text4); }
.btn-toggle-hid:hover { background:rgba(0,0,0,.08); }

/* ── Editor form ── */
.editor-form { background:var(--surface); border:1px solid var(--gold-border); border-radius:24px; padding:32px; box-shadow:0 4px 24px rgba(0,0,0,.06); }
.editor-form h3 { font-size:1.0625rem; font-weight:700; margin-bottom:24px; display:flex; align-items:center; gap:8px; }
.editor-section { padding:20px 0; border-top:1px solid var(--border); }
.editor-section:first-child { border-top:none; padding-top:0; }
.editor-section-title { font-size:.75rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text3); margin-bottom:16px; }
.checkbox-row { display:flex; align-items:center; gap:10px; }
.checkbox-row input[type="checkbox"] { width:18px; height:18px; accent-color:var(--gold-mid); cursor:pointer; }
.checkbox-row label { font-size:.875rem; font-weight:500; cursor:pointer; }
.editors-list { display:flex; flex-direction:column; gap:10px; }
.editor-row {
  display:flex; align-items:center; gap:12px; padding:14px 16px;
  background:var(--surface); border:1px solid var(--border); border-radius:12px;
  box-shadow:0 2px 8px rgba(0,0,0,.03);
}
.editor-row-avatar {
  width:40px; height:40px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:.875rem; color:#fff;
  background:linear-gradient(135deg,#3b82f6,#8b5cf6);
}
.editor-row-info { flex:1; min-width:0; }
.editor-row-name { font-size:.875rem; font-weight:600; }
.editor-row-login { font-size:.75rem; color:var(--text4); }
.msg-ok { padding:10px 14px; border-radius:10px; font-size:.875rem; display:flex; align-items:center; gap:8px; background:rgba(16,185,129,.08); border:1px solid rgba(16,185,129,.2); color:#059669; }
.msg-err { padding:10px 14px; border-radius:10px; font-size:.875rem; display:flex; align-items:center; gap:8px; background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.2); color:#dc2626; }

/* ── Category pills ── */
.cat-filters { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:32px; }
.cat-pill {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 16px; border-radius:999px; font-size:.8125rem; font-weight:500;
  background:var(--surface); border:1px solid var(--border); color:var(--text3);
  cursor:pointer; transition:all .15s;
}
.cat-pill:hover { border-color:var(--border2); color:var(--text1); }
.cat-pill.active { background:var(--gold-bg); border-color:var(--gold-border); color:var(--gold); font-weight:600; }

/* ── Footer ── */
.footer {
  background:var(--navy); color:rgba(255,255,255,.7);
  padding:48px 0 32px; margin-top:80px;
}
.footer-inner { max-width:1280px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:1fr; gap:40px; }
@media(min-width:768px) { .footer-inner { grid-template-columns:1.5fr 1fr 1fr; } }
.footer-brand-name { font-size:1.125rem; font-weight:800; color:#fff; margin-bottom:8px; }
.footer-brand-desc { font-size:.8125rem; line-height:1.6; margin-bottom:16px; }
.footer-copy { font-size:.75rem; color:rgba(255,255,255,.3); margin-top:8px; }
.footer-col h4 { font-size:.8125rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:rgba(255,255,255,.4); margin-bottom:16px; }
.footer-links { display:flex; flex-direction:column; gap:8px; }
.footer-links a { font-size:.875rem; color:rgba(255,255,255,.6); transition:color .2s; }
.footer-links a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); margin-top:40px; padding-top:24px; text-align:center; font-size:.75rem; color:rgba(255,255,255,.25); }

/* ── Empty state ── */
.empty { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:80px 20px; text-align:center; color:var(--text4); }
.empty i { font-size:3rem; color:rgba(0,0,0,.1); }
.empty h3 { font-size:1.0625rem; color:var(--text3); }
.empty p { font-size:.875rem; }

/* ── Toast ── */
.toast {
  position:fixed; bottom:24px; right:24px; z-index:9999;
  padding:14px 20px; border-radius:14px; font-size:.875rem; font-weight:500;
  display:flex; align-items:center; gap:10px;
  background:var(--text1); color:#fff; box-shadow:var(--shadow-xl);
  animation:toast-in .3s cubic-bezier(.16,1,.3,1);
}
.toast.success { background:#059669; }
.toast.error { background:#dc2626; }
@keyframes toast-in { from { transform:translateY(24px); opacity:0; } to { transform:none; opacity:1; } }

/* ── Animations ── */
@keyframes shimmer { 0%{ background-position:-200% center; } 100%{ background-position:200% center; } }
@keyframes pulse-ring { 0%{ opacity:.6; } 50%{ opacity:0; transform:scale(1.15); } 100%{ opacity:.6; } }
@keyframes float-up { 0%,100%{ transform:translateX(-50%) translateY(0); } 50%{ transform:translateX(-50%) translateY(-8px); } }
.fade-in { animation:fade-in .4s ease both; }
@keyframes fade-in { from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }
.fade-in-1 { animation-delay:.1s; }
.fade-in-2 { animation-delay:.2s; }
.fade-in-3 { animation-delay:.3s; }
.fade-in-4 { animation-delay:.4s; }

/* ── Lang switch ── */
.lang-switch { display:flex; gap:6px; margin-bottom:24px; }
.lang-btn {
  padding:5px 14px; border-radius:8px; font-size:.8125rem; font-weight:600;
  background:var(--surf3); border:1px solid var(--border2); color:var(--text3);
  cursor:pointer; transition:all .15s;
}
.lang-btn.active { background:var(--gold-bg); border-color:var(--gold-border); color:var(--gold); }

/* ── Page header ── */
.page-header { padding:48px 0 32px; }
.page-header .badge { margin-bottom:12px; }
.page-header h1 { font-size:clamp(1.8rem,4vw,2.6rem); margin-bottom:10px; }
.page-header p { font-size:.9375rem; color:var(--text3); }

/* ── Back link ── */
.back-link { display:inline-flex; align-items:center; gap:6px; font-size:.875rem; color:var(--text3); margin-bottom:24px; transition:color .2s; }
.back-link:hover { color:var(--gold); }

/* ── Loading inline ── */
.loading-dots { display:flex; gap:6px; align-items:center; justify-content:center; padding:60px; }
.loading-dots span { width:8px; height:8px; border-radius:50%; background:var(--gold-mid); animation:dot-pulse 1.4s ease-in-out infinite both; }
.loading-dots span:nth-child(2) { animation-delay:.16s; }
.loading-dots span:nth-child(3) { animation-delay:.32s; }
@keyframes dot-pulse { 0%,80%,100%{ transform:scale(0); opacity:.5; } 40%{ transform:scale(1); opacity:1; } }

/* ── Search ── */
.search-wrap { position:relative; margin-bottom:32px; }
.search-wrap i { position:absolute; left:16px; top:50%; transform:translateY(-50%); color:var(--text4); font-size:.875rem; pointer-events:none; }
.search-input { padding-left:44px; }

/* ── Privacy / Terms ── */
.static-page { max-width:800px; margin:0 auto; padding:40px 0 80px; }
.static-page h1 { font-size:2rem; margin-bottom:8px; }
.static-page .date { font-size:.875rem; color:var(--text4); margin-bottom:40px; }
.static-page h2 { font-size:1.2rem; margin:2rem 0 .75rem; color:var(--text1); }
.static-page p, .static-page li { font-size:.9375rem; color:var(--text2); line-height:1.75; margin-bottom:.75rem; }
.static-page ul { padding-left:1.5rem; }

/* ── 404 ── */
.not-found { display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:60vh; text-align:center; padding:40px 20px; }
.not-found .code { font-size:7rem; font-weight:900; color:var(--gold-border); line-height:1; margin-bottom:16px; }
.not-found h2 { font-size:1.5rem; margin-bottom:8px; }
.not-found p { color:var(--text3); margin-bottom:24px; }
