/* Basic UI improvements */
:root{
  --bg:#f4f6f8;
  --input-bg:#ffffff;
  --text:#0f1724;
  --muted:#94a3b8;
  --primary:#163fbe;
  --primary-600: #0f36c1;
  --card-shadow: 0 14px 44px rgba(15,23,36,0.08);
  --card-radius: 20px;
  --input-radius: 12px;
  --btn-radius: 12px;
  --base-font: 15px;
}
body{font-family:Inter,Segoe UI,Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);font-size:var(--base-font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.form-label{display:block;margin-bottom:8px;color:var(--text);font-weight:600;font-size:13px}
.form-field{background:var(--input-bg);border:1px solid #eef2f7;padding:12px 14px;border-radius:var(--input-radius);color:var(--text);font-size:15px;box-sizing:border-box;height:48px}
.form-field:focus{outline:none;box-shadow:0 10px 30px rgba(15,54,193,0.10);border-color:rgba(15,54,193,0.14)}
.form-field::placeholder{color:#9aa6b6}
.checkbox{display:inline-flex;align-items:center}
.button{background:linear-gradient(180deg,var(--primary),var(--primary-600));color:#fff;border:none;padding:10px 14px;border-radius:8px;cursor:pointer;transition:all 160ms ease}

/* Login card */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:72px}
.login-card{width:520px;max-width:94vw;background:#fff;border-radius:var(--card-radius);box-shadow:var(--card-shadow);padding:48px 40px 40px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}
.logo-circle{width:96px;height:96px;border-radius:50%;background:linear-gradient(180deg,rgba(22,63,190,0.14),rgba(22,63,190,0.06));display:inline-flex;align-items:center;justify-content:center;margin:0 0 6px}
.logo-circle svg{width:44px;height:44px;fill:var(--primary)}
.login-title{font-size:26px;font-weight:800;margin:0;letter-spacing:-0.02em}
.login-sub{font-size:14px;color:var(--muted);margin:0}
.form-row{margin-bottom:14px;text-align:left}
.button-large{width:100%;height:52px;padding:0;border-radius:var(--btn-radius);font-size:16px;font-weight:700;box-shadow:0 12px 30px rgba(15,54,193,0.10);transition:transform .12s ease,box-shadow .12s ease}
.button-large:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(15,54,193,0.12)}
.login-help{margin-top:12px;font-size:13px;color:var(--muted)}

.hero-art{display:block;margin:0 auto;max-width:180px;opacity:0.98}

.login-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}

.login-card .form-row{width:100%;max-width:420px}

.brand-sub{font-size:12px;color:var(--muted);margin-top:6px;letter-spacing:0.02em}

/* compact form tweaks */
.form-row .form-field + .form-field{margin-top:8px}

/* Modal dialog */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(2,6,23,0.45);z-index:1000}
.modal.open{display:flex}
.modal-content{background:var(--input-bg);padding:20px;border-radius:10px;max-width:520px;width:100%;box-shadow:0 10px 30px rgba(2,6,23,0.2)}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.modal-title{font-size:18px;font-weight:700}
.modal-close{background:transparent;border:none;font-size:20px;cursor:pointer;color:var(--muted)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.full-width{grid-column:1/-1}

/* Site card */
.site-cards{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}
.site-card{background:#fff;border:1px solid #e6eef8;padding:14px;border-radius:8px;min-width:220px;flex:1 1 240px;box-shadow:0 4px 12px rgba(10,18,45,0.04)}
.site-card h3{margin:0 0 6px 0;font-size:18px}
.site-card p{margin:0;color:var(--muted);font-size:14px}

/* Login / hero */
.hero{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:40px 20px;background:linear-gradient(180deg,rgba(0,94,165,0.08),rgba(0,94,165,0.03));border-radius:12px}
.hero-left{max-width:560px}
.hero-title{font-size:28px;margin:0 0 8px}
.hero-sub{color:var(--muted);margin:0 0 16px}
.login-panel{background:#fff;padding:20px;border-radius:10px;box-shadow:0 10px 30px rgba(2,6,23,0.06);min-width:320px}
.login-panel h2{margin:0 0 12px}
.nav{display:flex;gap:12px;align-items:center;margin-bottom:18px}
.nav a{color:var(--primary);text-decoration:none;font-weight:600}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.app-shell{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{width:200px;background:#fff;border-right:1px solid #e8ecf0;display:flex;flex-direction:column;padding:0}
.sidebar-header{padding:20px 16px 12px;border-bottom:1px solid #e8ecf0}
.sidebar-brand{font-size:16px;font-weight:700;color:var(--primary)}
.sidebar-version{font-size:11px;color:var(--muted);margin-top:2px}
.sidebar-nav{flex:1;padding:12px 8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--text);text-decoration:none;font-size:14px;font-weight:500;margin-bottom:4px;transition:background .15s}
.nav-item:hover{background:#f0f4ff}
.nav-item.active{background:var(--primary);color:#fff}
.nav-item .nav-icon{width:18px;height:18px;opacity:0.7}
.nav-item.active .nav-icon{opacity:1}
.sidebar-footer{padding:16px;border-top:1px solid #e8ecf0}
.sidebar-footer .nav-item{margin-bottom:6px}
.user-info{display:flex;align-items:center;gap:10px;padding:10px 12px}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.user-details{font-size:13px}
.user-name{font-weight:600;color:var(--text)}
.user-role{color:var(--muted);font-size:11px}
.nav-item.logout{color:#dc2626}
.nav-item.logout:hover{background:#fef2f2}

/* Main content */
.main-content{flex:1;background:var(--bg);padding:32px 40px}
.page-title{font-size:24px;font-weight:700;margin:0 0 24px}

/* Stat cards */
.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}
.stat-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;border:1px solid #e8ecf0}
.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.stat-icon.blue{background:#e8f0fe}
.stat-icon.green{background:#e6f7ed}
.stat-icon.purple{background:#f3e8ff}
.stat-icon svg{width:24px;height:24px}
.stat-icon.blue svg{fill:#3b82f6}
.stat-icon.green svg{fill:#22c55e}
.stat-icon.purple svg{fill:#a855f7}
.stat-label{font-size:13px;color:var(--muted);margin-bottom:2px}
.stat-value{font-size:28px;font-weight:700;color:var(--text)}

/* Workflow status */
.workflow-card{background:#f0f4ff;border-radius:12px;padding:20px 24px}
.workflow-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px}
.workflow-text{font-size:13px;color:#475569;line-height:1.5;margin-bottom:16px}
.button-primary{background:var(--primary);color:#fff;border:none;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}

/* Page header */
.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.page-header-left h1{font-size:24px;font-weight:700;margin:0 0 4px}
.page-header-left p{font-size:13px;color:var(--muted);margin:0}
.page-actions{display:flex;gap:10px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid #e0e6ed;background:#fff;color:var(--text);transition:all .15s}
.btn:hover{background:#f8fafc;border-color:#d0d7de}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-600)}
.btn svg{width:16px;height:16px;fill:currentColor}

/* Search */
.search-box{position:relative;margin-bottom:20px}
.search-box input{width:100%;max-width:340px;padding:10px 14px 10px 40px;border:1px solid #e0e6ed;border-radius:8px;font-size:14px}
.search-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(22,63,190,0.08)}
.search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;fill:#9ca3af}

/* Data table */
.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;border:1px solid #e8ecf0}
.data-table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;border-bottom:1px solid #e8ecf0;background:#fafbfc}
.data-table td{padding:14px 16px;font-size:14px;border-bottom:1px solid #f0f3f6;vertical-align:top}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover{background:#f8fafc}
.cell-main{font-weight:600;color:var(--text)}
.cell-sub{font-size:12px;color:var(--muted);margin-top:2px}
.cell-link{color:var(--primary);text-decoration:none}
.cell-link:hover{text-decoration:underline}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600}
.badge-success{background:#dcfce7;color:#16a34a}
.badge-warning{background:#fef3c7;color:#d97706}
.badge-info{background:#e0e7ff;color:#4f46e5}
.badge-muted{background:#f1f5f9;color:#64748b}
.badge svg{width:14px;height:14px;fill:currentColor}

/* Dyslexia indicator */
.dyslexia-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;background:#fef3c7;color:#d97706;font-size:12px;font-weight:600}
.dyslexia-badge svg{width:14px;height:14px;fill:currentColor}

/* Action link */
.action-link{display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-size:13px;text-decoration:none;cursor:pointer}
.action-link:hover{color:var(--primary)}
.action-link svg{width:14px;height:14px;fill:currentColor}

/* Spin animation */
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.spin{animation:spin 1s linear infinite}

/* (Removed old overridden centered-card styles to avoid conflicts) */

/* Icons */
.icon{width:20px;height:20px;vertical-align:middle;fill:currentColor;margin-right:8px}

/* Animations */
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes slideUp { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }
@keyframes cardPop { from{opacity:0;transform:translateY(8px) scale(.99)} to{opacity:1;transform:translateY(0) scale(1)} }

.fade-in{animation:fadeIn 300ms ease both}
.slide-up{animation:slideUp 260ms ease both}
.card-animate{animation:cardPop 360ms cubic-bezier(.2,.9,.3,1) both}

.modal.open .modal-content{animation:slideUp 220ms ease both}
.site-card.card-animate{opacity:1}
