@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@800;900&family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  color-scheme: dark;
  --bg: #070a12;
  --bg-soft: #0b1020;
  --panel: rgba(15, 23, 42, 0.72);
  --panel-solid: #101828;
  --panel-2: rgba(30, 41, 59, 0.62);
  --panel-3: rgba(51, 65, 85, 0.46);
  --line: rgba(148, 163, 184, 0.16);
  --line-strong: rgba(148, 163, 184, 0.26);
  --text: #f8fafc;
  --muted: rgba(226, 232, 240, 0.72);
  --subtle: rgba(226, 232, 240, 0.48);
  --blue: #60a5fa;
  --cyan: #22d3ee;
  --violet: #a78bfa;
  --indigo: #818cf8;
  --green: #34d399;
  --amber: #f59e0b;
  --red: #fb7185;
  --radius-2xl: 32px;
  --radius-xl: 24px;
  --radius-lg: 18px;
  --radius-md: 13px;
  --sidebar: 320px;
  --shadow: 0 30px 120px rgba(0, 0, 0, 0.44);
  --shadow-soft: 0 16px 48px rgba(0, 0, 0, 0.24);
  --ease: 160ms ease;
  --brand: "Montserrat", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { min-height: 100%; background: var(--bg); }
body {
  min-height: 100vh;
  margin: 0;
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 12% -14%, rgba(34, 211, 238, 0.18), transparent 30rem),
    radial-gradient(circle at 88% 0%, rgba(129, 140, 248, 0.18), transparent 32rem),
    radial-gradient(circle at 50% 110%, rgba(96, 165, 250, 0.08), transparent 32rem),
    linear-gradient(180deg, #080b14 0%, #05070d 100%);
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .26;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(circle at top, black 0%, transparent 74%);
}
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
[hidden] { display: none !important; }

input, textarea, select {
  width: 100%;
  color: var(--text);
  background: rgba(15, 23, 42, 0.72);
  border: 1px solid var(--line-strong);
  border-radius: 14px;
  padding: 13px 14px;
  outline: none;
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}
textarea { min-height: 132px; resize: vertical; line-height: 1.55; }
input:focus, textarea:focus, select:focus {
  border-color: rgba(96, 165, 250, 0.72);
  box-shadow: 0 0 0 4px rgba(96, 165, 250, 0.14);
  background: rgba(15, 23, 42, 0.9);
}
input::placeholder, textarea::placeholder { color: rgba(226, 232, 240, 0.36); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0 17px;
  color: var(--text);
  font-weight: 800;
  letter-spacing: -0.015em;
  background: rgba(255,255,255,.06);
  transition: transform var(--ease), border-color var(--ease), background var(--ease), box-shadow var(--ease);
}
.btn:hover { transform: translateY(-1px); border-color: rgba(96,165,250,.42); background: rgba(255,255,255,.095); }
.btn:active { transform: translateY(0); }
.btn-primary { border-color: rgba(96,165,250,.42); background: linear-gradient(135deg, #38bdf8, #6366f1 54%, #8b5cf6); color: white; box-shadow: 0 16px 42px rgba(99,102,241,.24); }
.btn-secondary { border-color: rgba(96,165,250,.28); background: rgba(96,165,250,.12); color: #dbeafe; }
.btn-muted { background: rgba(15,23,42,.78); color: var(--muted); }
.btn-danger { background: rgba(251,113,133,.12); border-color: rgba(251,113,133,.26); color: #fecdd3; }
.icon-btn {
  width: 40px; height: 40px; display: inline-grid; place-items: center;
  border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.06); color: var(--muted); font-size: 1.15rem; font-weight: 900;
}
.icon-btn:hover { color: var(--text); background: rgba(255,255,255,.1); border-color: rgba(96,165,250,.4); }
.eyebrow { margin: 0 0 8px; color: var(--cyan); text-transform: uppercase; letter-spacing: .18em; font-size: .72rem; font-weight: 900; }
.muted { color: var(--muted); }
.notice { margin: 18px 0; padding: 14px 16px; border: 1px solid rgba(96,165,250,.26); border-radius: 18px; background: rgba(96,165,250,.1); color: #dbeafe; }
.notice.error { border-color: rgba(251,113,133,.34); background: rgba(251,113,133,.12); color: #fecdd3; }
.notice.success { border-color: rgba(52,211,153,.34); background: rgba(52,211,153,.1); color: #bbf7d0; }

/* Auth */
.auth-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
  overflow: hidden;
}
.auth-shell {
  width: min(1180px, 100%);
  min-height: min(720px, calc(100vh - 56px));
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  position: relative;
  z-index: 1;
  border: 1px solid var(--line);
  border-radius: 36px;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(15,23,42,.72), rgba(6,8,14,.9));
  box-shadow: var(--shadow);
  backdrop-filter: blur(28px);
}
.auth-story {
  position: relative;
  overflow: hidden;
  padding: 34px;
  background:
    radial-gradient(circle at 20% 15%, rgba(34,211,238,.22), transparent 22rem),
    radial-gradient(circle at 84% 82%, rgba(167,139,250,.2), transparent 26rem),
    rgba(15,23,42,.28);
}
.auth-story::after {
  content: ""; position: absolute; inset: auto -18% -18% auto; width: 440px; height: 440px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12); background: radial-gradient(circle, rgba(96,165,250,.14), transparent 64%);
}
.auth-logo-lockup { display: inline-flex; align-items: center; gap: 12px; position: relative; z-index: 1; }
.auth-logo-mark, .brand-emblem {
  width: 46px; height: 46px; border-radius: 16px; display: grid; place-items: center; font-weight: 950; color: #06101f;
  background: linear-gradient(135deg, var(--cyan), var(--blue) 55%, var(--violet));
  box-shadow: 0 14px 40px rgba(34,211,238,.18);
}
.auth-logo-lockup strong { display: block; font-family: var(--brand); font-weight: 800; letter-spacing: .055em; }
.auth-logo-lockup span { display: block; color: var(--subtle); text-transform: uppercase; letter-spacing: .105em; font-size: .72rem; margin-top: 2px; }
.auth-copy { position: relative; z-index: 1; max-width: 620px; margin-top: clamp(86px, 13vh, 138px); padding-bottom: 118px; }
.auth-copy h1 { margin: 0; font-size: clamp(3rem, 5.2vw, 5.65rem); line-height: .9; letter-spacing: -.072em; text-wrap: balance; }
.auth-copy p:not(.eyebrow) { max-width: 560px; color: var(--muted); font-size: 1.02rem; line-height: 1.6; text-wrap: pretty; }
.auth-orbit { position: absolute; inset: 80px 50px auto auto; width: 240px; height: 240px; border: 1px solid rgba(255,255,255,.1); border-radius: 999px; opacity: .8; }
.auth-orbit span { position: absolute; width: 12px; height: 12px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 30px var(--cyan); }
.auth-orbit span:nth-child(1) { top: 20px; left: 60px; }
.auth-orbit span:nth-child(2) { right: 20px; top: 120px; background: var(--violet); box-shadow: 0 0 30px var(--violet); }
.auth-orbit span:nth-child(3) { left: 92px; bottom: 18px; background: var(--blue); box-shadow: 0 0 30px var(--blue); }
.auth-metrics { position: absolute; left: 34px; right: 34px; bottom: 34px; display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; z-index: 2; }
.auth-metrics article { min-height: 86px; border: 1px solid var(--line); border-radius: 20px; padding: 15px 16px; background: rgba(255,255,255,.055); backdrop-filter: blur(18px); }
.auth-metrics strong { display: block; font-size: 1.05rem; letter-spacing: -.02em; }
.auth-metrics span { display: block; margin-top: 4px; color: var(--subtle); font-size: .82rem; line-height: 1.35; }
.auth-panel { display: flex; flex-direction: column; justify-content: center; padding: clamp(28px, 5vw, 58px); background: rgba(6,8,14,.52); border-left: 1px solid var(--line); }
.auth-panel-head h2 { margin: 0; font-size: clamp(2.1rem, 4vw, 4rem); line-height: .94; letter-spacing: -.06em; }
.auth-panel-head p:not(.eyebrow) { margin: 12px 0 0; color: var(--muted); line-height: 1.6; }
.auth-form { display: grid; gap: 16px; margin-top: 30px; }
.auth-form label span { display: block; margin-bottom: 7px; color: var(--subtle); font-weight: 750; font-size: .88rem; }
.auth-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; color: var(--subtle); }
.checkline { display: inline-flex; align-items: center; gap: 8px; }
.checkline input { width: auto; }
.auth-submit { min-height: 52px; font-size: 1rem; }

@media (max-height: 760px) and (min-width: 981px) {
  .auth-shell { min-height: calc(100vh - 40px); }
  .auth-copy { margin-top: 70px; padding-bottom: 104px; }
  .auth-copy h1 { font-size: clamp(2.8rem, 4.7vw, 4.9rem); }
  .auth-copy p:not(.eyebrow) { font-size: .96rem; line-height: 1.5; }
  .auth-metrics article { min-height: 76px; padding: 13px 14px; }
}

@media (max-width: 980px) {
  .auth-shell { grid-template-columns: 1fr; min-height: auto; }
  .auth-story { min-height: 560px; }
  .auth-copy { margin-top: 88px; padding-bottom: 124px; }
  .auth-copy h1 { font-size: clamp(3.1rem, 12vw, 5.4rem); }
  .auth-panel { border-left: 0; border-top: 1px solid var(--line); }
}

@media (max-width: 640px) {
  .auth-screen { padding: 14px; overflow: auto; }
  .auth-story { padding: 24px; min-height: 590px; }
  .auth-orbit { opacity: .35; transform: scale(.78); transform-origin: top right; }
  .auth-copy { margin-top: 76px; padding-bottom: 0; }
  .auth-copy h1 { font-size: clamp(2.75rem, 15vw, 4.4rem); }
  .auth-metrics { position: relative; left: auto; right: auto; bottom: auto; margin-top: 24px; grid-template-columns: 1fr; }
  .auth-panel { padding: 28px 22px 30px; }
}

/* Layout */
.admin-grid-shell { min-height: 100vh; position: relative; z-index: 1; display: grid; grid-template-columns: var(--sidebar) minmax(0, 1fr); }
.sidebar { position: sticky; top: 0; height: 100vh; overflow-y: auto; padding: 18px; border-right: 1px solid var(--line); background: rgba(6, 8, 14, 0.68); backdrop-filter: blur(26px); }
.sidebar-inner { min-height: 100%; display: flex; flex-direction: column; }
.sidebar::-webkit-scrollbar, .modal-panel::-webkit-scrollbar { width: 8px; }
.sidebar::-webkit-scrollbar-thumb, .modal-panel::-webkit-scrollbar-thumb { background: rgba(148,163,184,.18); border-radius: 999px; }
.brand-block { display: flex; align-items: center; gap: 12px; min-height: 76px; padding: 14px; margin-bottom: 14px; border: 1px solid var(--line); border-radius: 24px; background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.025)); box-shadow: var(--shadow-soft); }
.brand-copy strong { display: block; font-family: var(--brand); font-weight: 800; letter-spacing: .055em; font-size: 1.02rem; }
.brand-copy span { display: block; margin-top: 3px; color: var(--subtle); font-size: .72rem; letter-spacing: .095em; text-transform: uppercase; }
.overview-nav, .nav-group-title, .nav-item, .module-strip button, .control-card { appearance: none; font: inherit; }
.overview-nav, .nav-group-title, .nav-item { width: 100%; border: 0; text-align: left; background: transparent; color: var(--muted); }
.overview-nav { display: grid; grid-template-columns: 38px minmax(0,1fr); align-items: center; gap: 11px; padding: 12px; margin-bottom: 14px; border: 1px solid var(--line); border-radius: 20px; background: rgba(255,255,255,.045); transition: var(--ease); }
.overview-nav:hover, .overview-nav.active { border-color: rgba(34,211,238,.34); background: linear-gradient(135deg, rgba(34,211,238,.12), rgba(99,102,241,.08)); color: var(--text); }
.overview-nav strong { display: block; }
.overview-nav small { display: block; margin-top: 2px; color: var(--subtle); }
.nav-icon { width: 38px; height: 38px; border-radius: 14px; display: grid; place-items: center; background: rgba(34,211,238,.12); color: var(--cyan); border: 1px solid rgba(34,211,238,.18); }
.nav-group { margin: 12px 0; }
.nav-group-title { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; color: var(--subtle); text-transform: uppercase; letter-spacing: .14em; font-size: .67rem; font-weight: 900; }
.nav-group-title em { font-style: normal; padding: 2px 8px; border-radius: 999px; border: 1px solid var(--line); color: var(--subtle); }
.nav-group-items { display: grid; gap: 4px; }
.nav-item { display: grid; grid-template-columns: 10px minmax(0,1fr) auto; align-items: center; gap: 10px; min-height: 39px; padding: 9px 10px; border: 1px solid transparent; border-radius: 14px; transition: var(--ease); font-size: .875rem; }
.nav-dot { width: 7px; height: 7px; border-radius: 999px; background: rgba(148,163,184,.34); }
.nav-label { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.nav-count { min-width: 24px; height: 22px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 999px; color: var(--subtle); font-size: .72rem; }
.nav-item:hover, .nav-item.active { color: var(--text); border-color: rgba(96,165,250,.22); background: rgba(96,165,250,.09); }
.nav-item.active .nav-dot { background: var(--cyan); box-shadow: 0 0 18px rgba(34,211,238,.7); }
.nav-item.active .nav-count { color: #dbeafe; border-color: rgba(96,165,250,.28); background: rgba(96,165,250,.12); }
.main-panel { min-width: 0; padding: 26px; }
.topbar { display: flex; justify-content: space-between; align-items: flex-start; gap: 22px; margin-bottom: 22px; }
.topbar-title h1 { margin: 0; max-width: 940px; font-size: clamp(2.8rem, 6vw, 6.6rem); line-height: .88; letter-spacing: -.08em; }
.topbar-title p:not(.eyebrow) { margin: 14px 0 0; max-width: 840px; color: var(--muted); line-height: 1.6; font-size: 1.02rem; }
.top-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.metric-strip { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; margin-bottom: 16px; }
.metric-strip article { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: 24px; padding: 18px; background: linear-gradient(145deg, rgba(15,23,42,.78), rgba(15,23,42,.46)); box-shadow: var(--shadow-soft); }
.metric-strip article::after { content: ""; position: absolute; inset: auto -20% -50% 35%; height: 110px; border-radius: 999px; background: rgba(96,165,250,.12); filter: blur(22px); }
.metric-strip span { display: block; color: var(--subtle); font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 900; }
.metric-strip strong { display: block; margin-top: 8px; font-size: 2.4rem; line-height: 1; letter-spacing: -.06em; }
.metric-strip small { display: block; margin-top: 8px; color: var(--muted); }
.module-strip { display: flex; gap: 10px; overflow-x: auto; padding: 4px 2px 18px; margin-bottom: 8px; }
.module-strip button { flex: 0 0 auto; min-width: 138px; border: 1px solid var(--line); border-radius: 18px; padding: 12px 15px; text-align: left; color: var(--text); background: rgba(255,255,255,.052); transition: var(--ease); }
.module-strip button:hover, .module-strip button.active { border-color: rgba(34,211,238,.34); background: linear-gradient(135deg, rgba(34,211,238,.12), rgba(129,140,248,.1)); transform: translateY(-1px); }
.module-strip span { display: block; font-weight: 900; }
.module-strip small { display: block; margin-top: 3px; color: var(--subtle); }
.workspace { border: 1px solid var(--line); border-radius: 30px; overflow: hidden; background: rgba(9, 13, 24, 0.66); box-shadow: var(--shadow); backdrop-filter: blur(24px); }
.workspace-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; padding: 22px; border-bottom: 1px solid var(--line); }
.workspace-head h2 { margin: 0; font-size: clamp(1.8rem, 3vw, 3rem); letter-spacing: -.055em; }
.workspace-head p:not(.eyebrow) { margin: 8px 0 0; color: var(--muted); }
.workspace-tools { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.search-box { display: grid; gap: 6px; min-width: min(360px, 100%); }
.search-box span { color: var(--subtle); font-size: .75rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 900; }
.content-stage { padding: 22px; }
.upload-station { margin: 22px; padding: 18px; border: 1px solid rgba(34,211,238,.2); border-radius: 24px; display: grid; grid-template-columns: 0.9fr 1.5fr; gap: 16px; align-items: center; background: linear-gradient(135deg, rgba(34,211,238,.09), rgba(129,140,248,.07)); }
.upload-station p { margin: 6px 0 0; color: var(--muted); line-height: 1.55; }
.upload-form { display: grid; grid-template-columns: 1.2fr 0.8fr 1fr auto; gap: 10px; align-items: center; }
.file-drop { min-height: 48px; display: grid; place-items: center; border: 1px dashed rgba(148,163,184,.32); border-radius: 16px; padding: 11px; background: rgba(15,23,42,.64); color: var(--muted); text-align: center; cursor: pointer; }
.file-drop input { display: none; }

/* Cards and workspaces */
.overview-layout { display: grid; grid-template-columns: minmax(0, .95fr) minmax(0, 1.45fr); gap: 18px; align-items: start; }
.overview-side { display: grid; gap: 14px; min-width: 0; }
.hero-console { min-height: 420px; display: flex; flex-direction: column; justify-content: flex-end; position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: 28px; padding: 26px; background:
  radial-gradient(circle at 30% 10%, rgba(34,211,238,.18), transparent 16rem),
  radial-gradient(circle at 80% 80%, rgba(167,139,250,.17), transparent 18rem), rgba(15,23,42,.66); }
.hero-console h3 { margin: 0; font-size: clamp(2.2rem, 4vw, 4.7rem); line-height: .9; letter-spacing: -.07em; }
.hero-console p:not(.eyebrow) { max-width: 580px; color: var(--muted); line-height: 1.65; }
.card-actions { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; margin-top: 16px; }
.card-actions .btn {
  flex: 0 1 auto;
  max-width: 100%;
  min-width: 0;
  height: auto;
  min-height: 42px;
  line-height: 1.2;
  text-align: center;
}
.card-actions .icon-btn {
  flex: 0 0 auto;
}
.command-grid, .record-grid, .page-grid, .product-grid, .film-grid, .tool-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.media-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px,1fr)); gap: 14px; }
.control-card, .record-card, .page-card, .product-card, .film-card, .tool-card, .section-card, .media-card { border: 1px solid var(--line); border-radius: 24px; background: rgba(15,23,42,.62); box-shadow: var(--shadow-soft); }
.control-card { min-height: 194px; padding: 20px; color: var(--text); text-align: left; transition: var(--ease); }
.control-card:hover { border-color: rgba(96,165,250,.35); background: rgba(20,31,52,.78); transform: translateY(-2px); }
.control-card b { display: block; color: var(--cyan); font-size: .78rem; letter-spacing: .16em; }
.control-card strong { display: block; margin-top: 20px; font-size: 1.35rem; letter-spacing: -.035em; }
.control-card p { color: var(--muted); line-height: 1.5; min-height: 64px; }
.site-health-card {
  border: 1px solid rgba(96,165,250,.22);
  border-radius: 24px;
  padding: 18px;
  background: linear-gradient(145deg, rgba(15,23,42,.78), rgba(15,23,42,.52));
  box-shadow: var(--shadow-soft);
}
.site-health-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}
.site-health-head h3 {
  margin: 0;
  color: var(--text);
  font-size: 1.3rem;
  letter-spacing: -.035em;
}
.site-health-head p {
  margin: 7px 0 0;
  color: var(--muted);
  line-height: 1.5;
}
.site-health-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}
.site-health-summary span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 4px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-weight: 800;
  font-size: .78rem;
}
.site-health-summary .bad { color: #fecdd3; border-color: rgba(251,113,133,.32); background: rgba(251,113,133,.09); }
.site-health-summary .warn { color: #fde68a; border-color: rgba(245,158,11,.32); background: rgba(245,158,11,.09); }
.site-health-list { display: grid; gap: 9px; }
.site-health-loading,
.site-health-empty {
  margin-top: 14px;
  color: var(--muted);
  border: 1px dashed rgba(148,163,184,.22);
  border-radius: 16px;
  padding: 14px;
}
.site-health-issue {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.035);
}
.site-health-issue > span {
  display: inline-flex;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--subtle);
  font-size: .68rem;
  font-weight: 900;
  text-transform: uppercase;
}
.site-health-issue.critical > span { color: #fecdd3; border-color: rgba(251,113,133,.34); background: rgba(251,113,133,.1); }
.site-health-issue.warning > span { color: #fde68a; border-color: rgba(245,158,11,.34); background: rgba(245,158,11,.1); }
.site-health-issue strong { display: block; color: var(--text); }
.site-health-issue p { margin: 4px 0 0; color: var(--muted); line-height: 1.45; }
.record-card, .page-card, .product-card, .film-card, .tool-card, .media-card { padding: 18px; }
.card-top { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: flex-start; gap: 12px; }
.card-top > div { min-width: 0; }
.card-top h3 { margin: 0; font-size: 1.15rem; letter-spacing: -.025em; }
.card-top p, .record-card p, .page-card p, .product-card p, .film-card p, .tool-card p { color: var(--muted); line-height: 1.55; }
.file-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.file-meta span, .badge { display: inline-flex; align-items: center; min-height: 24px; border: 1px solid var(--line); border-radius: 999px; padding: 3px 9px; color: var(--subtle); font-size: .74rem; font-weight: 800; overflow-wrap: normal; word-break: keep-all; hyphens: none; }
.badge { justify-self: end; white-space: nowrap; flex: 0 0 auto; }
.badge.published, .badge.active, .badge.public, .badge.paid, .badge.visible { color: #bbf7d0; border-color: rgba(52,211,153,.3); background: rgba(52,211,153,.08); }
.badge.draft, .badge.pending { color: #fde68a; border-color: rgba(245,158,11,.3); background: rgba(245,158,11,.09); }
.badge.hidden, .badge.archived, .badge.private, .badge.cancelled { color: #fecdd3; border-color: rgba(251,113,133,.28); background: rgba(251,113,133,.08); }
.card-image { width: 100%; height: 170px; object-fit: cover; border-radius: 18px; border: 1px solid var(--line); margin-bottom: 14px; background: rgba(255,255,255,.04); }
.media-thumb { width: 100%; height: 160px; object-fit: cover; border-radius: 18px; display: grid; place-items: center; color: var(--subtle); background: rgba(255,255,255,.05); border: 1px solid var(--line); margin-bottom: 14px; }
.empty-state { padding: 60px 22px; text-align: center; color: var(--muted); border: 1px dashed rgba(148,163,184,.24); border-radius: 24px; background: rgba(255,255,255,.025); }

/* Settings */
.settings-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.section-card { overflow: hidden; }
.section-head { padding: 20px; border-bottom: 1px solid var(--line); background: linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.018)); }
.section-head h3 { margin: 0; font-size: 1.3rem; letter-spacing: -.035em; }
.section-head p { margin: 7px 0 0; color: var(--muted); line-height: 1.55; }
.setting-row { display: grid; grid-template-columns: minmax(190px, .42fr) minmax(0, 1fr); gap: 18px; align-items: start; padding: 18px 20px; border-top: 1px solid rgba(148,163,184,.09); }
.setting-row:first-of-type { border-top: 0; }
.setting-label strong { display: block; font-size: .98rem; letter-spacing: -.01em; }
.setting-label small { display: block; margin-top: 4px; color: var(--subtle); font-size: .78rem; word-break: break-word; }
.setting-body { min-width: 0; display: grid; gap: 12px; }
.setting-control { min-width: 0; width: 100%; display: flex; align-items: center; gap: 10px; }
.setting-control > input:not([type="checkbox"]), .setting-control > textarea, .setting-control > select { flex: 1 1 auto; min-width: 0; }
.setting-control > .btn {
  flex: 0 0 auto;
  min-width: 92px;
  white-space: nowrap;
}
.setting-actions { display: flex; justify-content: flex-end; align-items: center; gap: 10px; }
.setting-save { min-width: 92px; height: 38px; padding: 0 16px; font-size: .84rem; }
.setting-save[disabled] { opacity: .62; cursor: wait; transform: none; }
.color-preview, .preview-chip { width: 46px; height: 46px; flex: 0 0 auto; border-radius: 14px; border: 1px solid var(--line); background: rgba(255,255,255,.06); object-fit: cover; }
.structured-control { width: 100%; min-width: 0; display: grid; gap: 12px; }
.structured-control > .btn { justify-self: stretch; height: 44px; border-style: dashed; color: var(--muted); }
.structured-rows { display: grid; gap: 10px; }
.structured-row { min-width: 0; display: grid; grid-template-columns: minmax(150px,.85fr) minmax(88px,.38fr) minmax(180px,1.1fr) minmax(112px,auto) 42px; gap: 10px; align-items: center; padding: 10px; border: 1px solid rgba(148,163,184,.14); border-radius: 20px; background: rgba(15,23,42,.38); }
.structured-row input { min-width: 0; }
.structured-row.simple { grid-template-columns: minmax(0,1fr) 42px; }
.structured-row .icon-btn { width: 42px; height: 42px; padding: 0; border-radius: 999px; font-size: 1.45rem; line-height: 1; color: var(--muted); }
.structured-row .icon-btn:hover { color: var(--text); border-color: rgba(96,165,250,.4); background: rgba(96,165,250,.12); }
.mini-check { display: inline-flex; align-items: center; justify-content: center; gap: 8px; color: var(--muted); white-space: nowrap; padding: 0 10px; min-height: 42px; border: 1px solid rgba(148,163,184,.12); border-radius: 999px; background: rgba(255,255,255,.025); }
.mini-check input { width: 16px; height: 16px; accent-color: var(--cyan); }

/* Editor modal */
.modal { position: fixed; inset: 0; z-index: 80; display: grid; place-items: center; padding: 22px; background: rgba(2,6,23,.74); backdrop-filter: blur(18px); }
.modal-panel { width: min(1040px, 100%); max-height: 92vh; overflow-y: auto; border: 1px solid var(--line-strong); border-radius: 30px; background: #0d1220; box-shadow: var(--shadow); }
.modal-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; padding: 22px; border-bottom: 1px solid var(--line); background: linear-gradient(135deg, rgba(96,165,250,.09), rgba(167,139,250,.07)); }
.modal-header h2 { margin: 0; font-size: 2rem; letter-spacing: -.05em; }
.modal-header p:not(.eyebrow) { margin: 6px 0 0; color: var(--muted); }
.editor-form { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; padding: 22px; }
.field { display: grid; gap: 7px; }
.field.full, .advanced-fields, .form-actions { grid-column: 1 / -1; }
.field label { color: var(--muted); font-weight: 800; }
.field small { color: var(--subtle); line-height: 1.45; }
.field.checkbox { display: flex; align-items: center; gap: 9px; min-height: 48px; padding: 12px; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,.035); }
.field.checkbox input { width: auto; }
.advanced-fields { border: 1px solid var(--line); border-radius: 22px; padding: 0; overflow: hidden; background: rgba(255,255,255,.03); }
.advanced-fields summary { cursor: pointer; padding: 16px 18px; color: var(--muted); font-weight: 900; }
.advanced-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; padding: 0 18px 18px; }
.form-actions { display: flex; justify-content: flex-end; gap: 10px; padding-top: 8px; }
.media-picker-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); gap: 14px; padding: 22px; }
.media-picker-grid button { text-align: left; color: var(--text); border: 1px solid var(--line); border-radius: 20px; background: rgba(255,255,255,.04); padding: 12px; overflow: hidden; }
.media-picker-grid strong, .media-picker-grid small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.media-picker-grid small { color: var(--subtle); margin-top: 4px; }

@media (max-width: 1180px) {
  .admin-grid-shell { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; border-right: 0; border-bottom: 1px solid var(--line); }
  .nav-groups { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
  .overview-layout, .settings-grid { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .auth-shell { grid-template-columns: 1fr; }
  .auth-story { min-height: 520px; }
  .auth-copy { margin-top: 120px; }
  .auth-panel { border-left: 0; border-top: 1px solid var(--line); }
  .topbar, .workspace-head { flex-direction: column; }
  .metric-strip { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .command-grid, .record-grid, .page-grid, .product-grid, .film-grid, .tool-grid { grid-template-columns: 1fr; }
  .settings-grid { grid-template-columns: 1fr; }
  .setting-row { grid-template-columns: 1fr; }
  .setting-actions { justify-content: stretch; }
  .setting-save { width: 100%; }
  .upload-station, .upload-form, .editor-form, .advanced-grid { grid-template-columns: 1fr; }
  .structured-row { grid-template-columns: 1fr; }
  .structured-row .icon-btn { width: 100%; }
}
@media (max-width: 580px) {
  .main-panel, .sidebar, .auth-screen { padding: 14px; }
  .topbar-title h1 { font-size: 3rem; }
  .metric-strip { grid-template-columns: 1fr; }
  .auth-metrics { grid-template-columns: 1fr; position: relative; left: auto; right: auto; bottom: auto; margin-top: 30px; }
}

/* Locked admin design refinements: keep the approved visual direction, fix control overflow. */
.section-card,
.setting-row,
.setting-body,
.setting-control,
.structured-control,
.structured-rows,
.structured-row {
  max-width: 100%;
}

.setting-row-structured {
  grid-template-columns: 1fr;
  gap: 14px;
}

.setting-row-media {
  grid-template-columns: 1fr;
  gap: 14px;
}

.setting-row-structured .setting-label {
  max-width: 680px;
}

.setting-row-media .setting-label {
  max-width: 680px;
}

.setting-row-structured .setting-body,
.setting-row-structured .setting-control,
.setting-row-structured .structured-control,
.setting-row-media .setting-body,
.setting-row-media .setting-control {
  width: 100%;
}

.setting-row-structured .setting-control {
  display: block;
}

.setting-row-structured .setting-actions {
  justify-content: flex-end;
  padding-top: 2px;
}

.structured-control {
  overflow: visible;
}

.structured-rows {
  width: 100%;
}

.structured-row {
  width: 100%;
  grid-template-columns: minmax(128px, 1fr) minmax(76px, .52fr) minmax(160px, 1.22fr) minmax(110px, auto) 38px;
  gap: 10px;
  align-items: center;
}

.structured-row input {
  height: 44px;
  padding: 0 14px;
  font-size: .95rem;
}

.structured-row .mini-check {
  height: 44px;
  min-height: 44px;
  padding: 0 13px;
  font-size: .9rem;
}

.structured-row .icon-btn {
  width: 38px;
  height: 38px;
  min-width: 38px;
  font-size: 1.12rem;
}

.structured-control > .btn {
  width: 100%;
}

.setting-row-structured .structured-row:not(.simple) {
  grid-template-columns: minmax(0, 1fr) minmax(0, .82fr) 42px;
}

.setting-row-structured .structured-row:not(.simple) input:nth-of-type(3) {
  grid-column: 1 / -1;
}

.setting-row-structured .structured-row:not(.simple) .mini-check {
  grid-column: 1 / 3;
  justify-content: flex-start;
}

.setting-row-structured .structured-row:not(.simple) .icon-btn {
  grid-column: 3;
  width: 42px;
  height: 42px;
}

@media (max-width: 1220px) {
  .structured-row {
    grid-template-columns: minmax(130px, 1fr) minmax(72px, .5fr) minmax(150px, 1.1fr) 38px;
  }

  .structured-row .mini-check {
    grid-column: 1 / -2;
    justify-content: flex-start;
  }
}

@media (max-width: 860px) {
  .setting-row-structured .setting-actions {
    justify-content: stretch;
  }

  .structured-row,
  .structured-row.simple {
    grid-template-columns: 1fr 42px;
  }

  .structured-row input:nth-of-type(1),
  .structured-row input:nth-of-type(3),
  .structured-row .mini-check {
    grid-column: 1 / -1;
  }

  .structured-row .icon-btn {
    width: 42px;
    height: 42px;
  }
}

/* Admin overflow hardening: keep long labels, URLs, filenames, and button text inside their windows. */
.artlas-admin,
.artlas-admin * {
  min-width: 0;
}

.artlas-admin h1,
.artlas-admin h2,
.artlas-admin h3,
.artlas-admin p,
.artlas-admin small,
.artlas-admin strong,
.artlas-admin span,
.artlas-admin label,
.artlas-admin button,
.artlas-admin a,
.artlas-admin .btn,
.artlas-admin .badge,
.artlas-admin .notice,
.artlas-admin .field,
.artlas-admin .field label,
.artlas-admin .setting-label,
.artlas-admin .setting-label strong,
.artlas-admin .setting-label small,
.artlas-admin .card-top,
.artlas-admin .card-top h3,
.artlas-admin .record-card,
.artlas-admin .page-card,
.artlas-admin .product-card,
.artlas-admin .film-card,
.artlas-admin .tool-card,
.artlas-admin .media-card,
.artlas-admin .media-picker-grid button {
  overflow-wrap: anywhere;
  word-break: normal;
}

.artlas-admin .btn,
.artlas-admin button,
.artlas-admin .badge,
.artlas-admin .file-meta span,
.artlas-admin .nav-group-title,
.artlas-admin .module-strip button,
.artlas-admin .top-actions a,
.artlas-admin .top-actions button {
  white-space: normal;
}

.artlas-admin .setting-control > .btn {
  white-space: nowrap;
}

.artlas-admin .btn,
.artlas-admin button,
.artlas-admin .badge,
.artlas-admin .file-meta span,
.artlas-admin .nav-count,
.artlas-admin .mini-check,
.artlas-admin .icon-btn {
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
}

.artlas-admin .badge,
.artlas-admin .nav-count,
.artlas-admin .icon-btn {
  white-space: nowrap;
}

.artlas-admin .btn,
.artlas-admin button {
  line-height: 1.2;
  text-align: center;
}

.artlas-admin .nav-item {
  min-height: 39px;
  height: auto;
  text-align: left;
  justify-content: flex-start;
  justify-items: start;
}

.artlas-admin .nav-label {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  line-height: 1.25;
  text-align: left;
}

.artlas-admin .nav-count {
  align-self: center;
}

.artlas-admin .sidebar,
.artlas-admin .sidebar-inner,
.artlas-admin .brand-block,
.artlas-admin .brand-copy,
.artlas-admin .overview-nav,
.artlas-admin .nav-groups,
.artlas-admin .nav-group,
.artlas-admin .nav-group-title,
.artlas-admin .nav-group-items {
  text-align: left;
}

.artlas-admin .overview-nav,
.artlas-admin .nav-group-title {
  justify-content: flex-start;
}

.artlas-admin .nav-group-title {
  gap: 10px;
}

.artlas-admin .nav-group-title span {
  flex: 1 1 auto;
  text-align: left;
}

.artlas-admin .modal-panel {
  max-width: calc(100vw - 28px);
}

.artlas-admin .modal-header,
.artlas-admin .workspace-head,
.artlas-admin .topbar,
.artlas-admin .card-top,
.artlas-admin .form-actions,
.artlas-admin .top-actions {
  min-width: 0;
}

.artlas-admin .editor-form,
.artlas-admin .advanced-grid,
.artlas-admin .upload-form,
.artlas-admin .settings-grid,
.artlas-admin .command-grid,
.artlas-admin .record-grid,
.artlas-admin .page-grid,
.artlas-admin .product-grid,
.artlas-admin .film-grid,
.artlas-admin .tool-grid,
.artlas-admin .media-grid {
  min-width: 0;
}

.artlas-admin input,
.artlas-admin textarea,
.artlas-admin select {
  max-width: 100%;
}

.artlas-admin textarea,
.artlas-admin input[type="text"],
.artlas-admin input[type="url"],
.artlas-admin input[type="email"],
.artlas-admin input[type="search"] {
  overflow-wrap: anywhere;
}

.media-picker-grid strong,
.media-picker-grid small {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  line-height: 1.35;
}

@media (max-width: 680px) {
  .artlas-admin .modal {
    padding: 10px;
  }

  .artlas-admin .modal-header,
  .artlas-admin .workspace-head,
  .artlas-admin .topbar {
    gap: 12px;
  }

  .artlas-admin .form-actions,
  .artlas-admin .top-actions,
  .artlas-admin .workspace-tools {
    width: 100%;
  }

  .artlas-admin .setting-control {
    flex-wrap: wrap;
  }

  .artlas-admin .setting-control > .btn {
    width: 100%;
  }

  .artlas-admin .form-actions .btn,
  .artlas-admin .top-actions .btn,
  .artlas-admin .workspace-tools .btn {
    width: 100%;
  }
}
