/* 26 Connect Admin — Option 4 design tokens (Manrope, paper, ink, brand red) */
:root{
  --paper:#f6f5f1;
  --paper-2:#efece5;
  --ink:#0b0f1e;
  --ink-2:#1a2237;
  --muted:#5e6473;
  --line:#e5e1d6;
  --line-2:#d8d3c6;
  --brand:#dc1f1f;
  --brand-2:#b81818;
  --ok:#1f8a3d;
  --warn:#d18c00;
  --bad:#c11b1b;
  --card:#ffffff;
  --shadow:0 1px 2px rgba(11,15,30,0.04), 0 8px 28px -12px rgba(11,15,30,0.10);
  --r:24px;
  --r-sm:14px;
  --r-xs:10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body.admin{
  font-family:'Manrope',-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:500;
  background:linear-gradient(to right, var(--ink) 264px, var(--paper) 264px);
  color:var(--ink);
  display:grid;
  grid-template-columns:264px 1fr;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  letter-spacing:-0.01em;
}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}

/* Sidebar */
.sidebar{
  background:var(--ink);
  color:#e8e9ee;
  padding:28px 18px 18px;
  display:flex;
  flex-direction:column;
  gap:18px;
  position:sticky;
  top:0;
  max-height:100vh;
  overflow-y:auto;
  border-right:1px solid var(--ink-2);
}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:3px}
.brand{
  display:flex;align-items:center;gap:12px;
  padding:6px 10px 14px;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.brand-mark{
  width:42px;height:42px;
  display:block;flex-shrink:0;object-fit:contain;
}
.brand-name{font-weight:700;font-size:15px;letter-spacing:-0.01em}
.brand-name .muted{color:#8d92a3;font-weight:500}
.sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1}
.sidebar nav a{
  padding:10px 12px;
  border-radius:var(--r-sm);
  font-weight:500;font-size:14px;
  color:#bcc0cf;
  display:flex;align-items:center;gap:10px;
  transition:background 0.15s,color 0.15s;
}
.sidebar nav a::before{
  content:"";width:6px;height:6px;border-radius:50%;background:#3a4156;flex-shrink:0;
  transition:background 0.15s;
}
.sidebar nav a:hover{background:rgba(255,255,255,0.04);color:#fff}
.sidebar nav a.active{background:rgba(220,31,31,0.12);color:#fff}
.sidebar nav a.active::before{background:var(--brand)}
.sidebar-foot{
  padding-top:14px;border-top:1px solid rgba(255,255,255,0.06);
  display:flex;flex-direction:column;gap:8px;
  font-size:12px;color:#8d92a3;
}
.lang-switch{display:flex;gap:4px;align-items:center}
.lang-switch a{padding:3px 8px;border-radius:6px;color:#8d92a3;text-decoration:none}
.lang-switch a.on{background:#fff;color:var(--ink)}
.lang-switch span{color:#5e6373}
.sidebar-foot .logout{
  display:block;padding:8px 10px;border-radius:8px;
  background:rgba(255,255,255,0.04);color:#cbd1de;
  text-decoration:none;font-size:13px;font-weight:500;
}
.sidebar-foot .logout:hover{background:rgba(220,31,31,0.18);color:#fff}

/* Main */
.main{display:flex;flex-direction:column;min-height:100vh}
.topbar{
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  padding:36px 40px 18px;
  border-bottom:1px solid var(--line);
}
.topbar h1{margin:0;font-size:28px;font-weight:700;letter-spacing:-0.02em}
.topbar .muted{margin:6px 0 0;font-size:14px}
.topbar-actions{display:flex;gap:10px;align-items:center}
.content{padding:28px 40px 40px;flex:1}
.bottom{padding:14px 40px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}

/* Cards / grid */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:22px}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:20px;
  box-shadow:var(--shadow);
}
.card .label{font-size:12px;text-transform:uppercase;letter-spacing:0.04em;color:var(--muted);font-weight:600;margin-bottom:8px}
.card .value{font-size:28px;font-weight:700;letter-spacing:-0.02em}
.card .value small{font-size:14px;color:var(--muted);font-weight:500;margin-left:4px}
.card .delta{margin-top:6px;font-size:12px;font-weight:600}
.card .delta.up{color:var(--ok)}
.card .delta.down{color:var(--bad)}

.row{display:grid;gap:14px;grid-template-columns:repeat(12,1fr);margin-bottom:22px}
.row > .col-6{grid-column:span 6}
.row > .col-4{grid-column:span 4}
.row > .col-8{grid-column:span 8}
.row > .col-12{grid-column:span 12}
@media(max-width:1100px){.row > [class*='col-']{grid-column:span 12}}

/* Section header inside content */
.section-h{display:flex;justify-content:space-between;align-items:flex-end;margin:22px 0 12px}
.section-h h2{margin:0;font-size:18px;font-weight:700}
.section-h p{margin:0;color:var(--muted);font-size:13px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:999px;
  background:var(--ink);color:#fff;
  font-family:inherit;font-weight:600;font-size:14px;
  border:1px solid var(--ink);cursor:pointer;
  transition:transform 0.1s,background 0.15s;
}
.btn:hover{background:var(--ink-2);transform:translateY(-1px)}
.btn.brand{background:var(--brand);border-color:var(--brand)}
.btn.brand:hover{background:var(--brand-2)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.btn.ghost:hover{background:var(--paper-2)}
.btn.sm{padding:6px 12px;font-size:12px}
.btn.danger{background:var(--bad);border-color:var(--bad)}

/* Tables */
.table-wrap{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow);
}
table.t{width:100%;border-collapse:collapse;font-size:14px}
table.t th, table.t td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
table.t th{font-size:12px;text-transform:uppercase;letter-spacing:0.04em;color:var(--muted);font-weight:600;background:var(--paper-2)}
table.t tbody tr:last-child td{border-bottom:none}
table.t tbody tr:hover{background:var(--paper-2)}
table.t td .pill{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:600;text-transform:uppercase;letter-spacing:0.03em}
.pill.green{background:#d6f0dd;color:#0e5524}
.pill.amber{background:#fde8c5;color:#7a4a00}
.pill.red{background:#fadcdc;color:#7a1414}
.pill.gray{background:var(--paper-2);color:var(--muted)}
.pill.blue{background:#dee5f4;color:#1a346f}

/* Forms */
.form-group{margin-bottom:14px;display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:12px;text-transform:uppercase;letter-spacing:0.04em;color:var(--muted);font-weight:600}
.form-group input, .form-group select, .form-group textarea{
  font-family:inherit;font-size:14px;font-weight:500;
  padding:11px 14px;border-radius:var(--r-sm);
  border:1px solid var(--line-2);background:#fff;
  transition:border-color 0.15s,box-shadow 0.15s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{
  outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(11,15,30,0.08);
}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}

/* Filters bar */
.filters{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:14px 16px;margin-bottom:14px;box-shadow:var(--shadow);
}
.filters input, .filters select{
  font-family:inherit;font-size:13px;font-weight:500;
  padding:8px 12px;border-radius:10px;border:1px solid var(--line-2);background:#fff;
}

/* Empty state */
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty svg{margin-bottom:12px}

/* Login (legacy single-card variant kept for back-compat) */
body.admin.login{display:grid;grid-template-columns:1fr;place-items:center;background:radial-gradient(1200px 800px at 80% -10%,rgba(220,31,31,0.06),transparent 60%),var(--paper)}
.login-card{
  background:var(--card);padding:40px;border-radius:var(--r);
  box-shadow:0 30px 60px -20px rgba(11,15,30,0.18);
  width:100%;max-width:420px;border:1px solid var(--line);
}
.login-card .brand{justify-content:center;border:none;padding:0 0 18px}
.login-card .brand .brand-name{color:var(--ink)}
.login-card h1{margin:6px 0 4px;font-size:22px;font-weight:700;text-align:center}
.login-card p.subtitle{margin:0 0 22px;text-align:center;color:var(--muted);font-size:14px}
.login-card .btn{width:100%;justify-content:center;padding:13px}
.login-card .err{background:#fadcdc;color:#7a1414;padding:10px 14px;border-radius:var(--r-xs);font-size:13px;margin-bottom:14px;font-weight:600}

/* Login (split — matches dashboard rhythm: dark sidebar-like panel + content area) */
body.admin.login-split{display:grid;grid-template-columns:minmax(380px, 0.55fr) 1fr;min-height:100vh;background:var(--paper)}
.login-panel{
  background:var(--ink);color:#e8e9ee;
  padding:56px 56px 40px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;gap:48px;
}
.login-panel::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(900px 700px at 110% -10%, rgba(220,31,31,0.22), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(220,31,31,0.10), transparent 60%);
}
.login-panel > *{position:relative;z-index:1}
.login-brand{display:flex;align-items:center;gap:14px}
.login-brand img{width:54px;height:54px;object-fit:contain;display:block;flex-shrink:0}
.login-brand .brand-name{font-size:18px;font-weight:800;letter-spacing:-0.02em}
.login-brand .brand-name span.muted{color:#9aa2b5;font-weight:500}
.login-tagline h2{
  font-family:'Instrument Serif','Manrope',Georgia,serif;
  font-size:54px;font-weight:400;line-height:1.04;letter-spacing:-0.025em;
  margin:0 0 18px;font-style:italic;
}
.login-tagline h2 em{font-style:italic;color:#ff6f6f;font-family:inherit}
.login-tagline p{font-size:16px;color:#cdd2dd;line-height:1.55;max-width:440px;margin:0}
.login-features{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.login-features li{font-size:14px;color:#cdd2dd;display:flex;align-items:center;gap:12px;font-weight:500}
.login-features li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0}
.login-main{display:flex;align-items:center;justify-content:center;padding:48px}
.login-form{width:100%;max-width:380px}
.login-form h1{font-size:34px;font-weight:800;letter-spacing:-0.025em;margin:0 0 6px;color:var(--ink)}
.login-form .subtitle{font-size:14px;color:var(--muted);margin:0 0 28px}
.login-form .form-group{margin-bottom:14px}
.login-form label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ink)}
.login-form input{
  width:100%;padding:13px 16px;border-radius:14px;border:1px solid var(--line-2);
  font-family:inherit;font-size:15px;font-weight:500;background:var(--card);color:var(--ink);
  transition:border-color .15s, box-shadow .15s;
}
.login-form input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(11,15,30,0.08)}
.login-form button{
  width:100%;padding:14px;border:none;background:var(--brand);color:#fff;
  border-radius:999px;font-family:inherit;font-weight:700;font-size:15px;letter-spacing:-0.005em;
  cursor:pointer;transition:background .15s,transform .1s;margin-top:10px;
}
.login-form button:hover{background:var(--brand-2);transform:translateY(-1px)}
.login-form .err{background:#fadcdc;color:#7a1414;padding:11px 14px;border-radius:12px;font-size:13px;margin-bottom:14px;font-weight:600}
.login-foot{margin-top:28px;font-size:12px;color:var(--muted);text-align:center}
.login-foot a{color:var(--ink-2);font-weight:600;margin:0 6px;text-decoration:none}
.login-foot a:hover{color:var(--brand)}
@media (max-width:880px){
  body.admin.login-split{grid-template-columns:1fr}
  .login-panel{padding:36px;min-height:auto;gap:32px}
  .login-tagline h2{font-size:38px}
  .login-main{padding:32px 24px}
}

/* Status dot */
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle}
.dot.green{background:var(--ok)}
.dot.amber{background:var(--warn)}
.dot.red{background:var(--bad)}
.dot.gray{background:var(--muted)}

/* Mini chart fallback */
.spark{height:60px;width:100%;display:block}

/* Responsive */
@media(max-width:900px){
  body.admin{grid-template-columns:1fr;background:var(--paper)}
  .sidebar{position:relative;max-height:none;flex-direction:row;flex-wrap:wrap;padding:14px;overflow:visible}
  .sidebar nav{flex-direction:row;flex-wrap:wrap;flex:0 0 100%}
  .sidebar nav a{padding:8px 12px}
  .topbar,.content,.bottom{padding-left:20px;padding-right:20px}
}
