:root{
  color-scheme:light;
  --bg:#edf4ff;
  --bg2:#fff7ed;
  --panel:#ffffffeb;
  --panel-solid:#fff;
  --ink:#0f172a;
  --muted:#64748b;
  --brand:#2563eb;
  --brand-strong:#1d4ed8;
  --brand2:#06b6d4;
  --accent:#f97316;
  --accent2:#8b5cf6;
  --danger:#dc2626;
  --ok:#16a34a;
  --line:#dbe4f0;
  --sidebar:#07111f;
  --sidebar2:#172554;
  --sideText:#eaf2ff;
  --shadow:0 24px 70px #0f172a18;
  --soft-shadow:0 12px 34px #1d4ed81f;
  --radius:26px;
}
html[data-theme="dark"]{
  color-scheme:dark;
  --bg:#06101f;
  --bg2:#111827;
  --panel:#0f1d31e8;
  --panel-solid:#111c2e;
  --ink:#e5eefc;
  --muted:#9aa9bd;
  --brand:#60a5fa;
  --brand-strong:#93c5fd;
  --brand2:#22d3ee;
  --accent:#fb923c;
  --accent2:#a78bfa;
  --danger:#fb7185;
  --ok:#4ade80;
  --line:#26364d;
  --sidebar:#020617;
  --sidebar2:#0b1630;
  --sideText:#e5eefc;
  --shadow:0 24px 70px #0009;
  --soft-shadow:0 14px 36px #0006;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 8% 8%,#60a5fa52 0 18rem,transparent 35rem),
    radial-gradient(circle at 95% 2%,#f9731652 0 14rem,transparent 30rem),
    radial-gradient(circle at 72% 92%,#8b5cf640 0 16rem,transparent 30rem),
    linear-gradient(135deg,var(--bg),var(--bg2));
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:none;color:var(--brand-strong)}
button,input,select,textarea{font:inherit}
.sidebar{
  position:fixed;
  inset:0 auto 0 0;
  width:292px;
  z-index:30;
  padding:22px;
  color:var(--sideText);
  background:
    radial-gradient(circle at 20% 10%,#38bdf84a,transparent 34%),
    radial-gradient(circle at 95% 55%,#f9731640,transparent 33%),
    linear-gradient(180deg,var(--sidebar),var(--sidebar2));
  box-shadow:16px 0 42px #0f172a35;
  transition:width .22s ease,transform .22s ease;
}
.brand{display:flex;gap:10px;align-items:center;margin-bottom:24px}
.brand-link{display:flex;align-items:center;gap:12px;min-width:0;color:inherit;border-radius:20px;padding:6px 8px 6px 2px;transition:background .18s ease,transform .18s ease}
.brand-link:hover{color:#fff;background:#ffffff14;transform:translateY(-1px)}
.logo{flex:0 0 auto;width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#06b6d4 52%,#f97316);display:inline-grid;place-items:center;color:#fff;font-weight:950;box-shadow:0 14px 34px #38bdf855;letter-spacing:-.04em}
.logo.big{width:76px;height:76px;font-size:36px;margin:auto;border-radius:26px}
.brand small{display:block;color:#b8c7dd;margin-top:2px;font-size:.78rem}.brand strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-text{min-width:0}.sidebar nav{display:grid;gap:8px}.sidebar nav a{display:flex;align-items:center;gap:12px;color:#dbeafe;padding:12px 13px;border-radius:16px;font-weight:780;transition:background .15s ease,transform .15s ease,color .15s ease}.sidebar nav a:hover{background:#ffffff1a;transform:translateX(3px);color:#fff}.sidebar nav svg{width:21px;height:21px;fill:currentColor;opacity:.95;flex:0 0 auto}.sidebar-close{display:none;margin-left:auto}.main{margin-left:292px;min-height:100vh;padding:30px;transition:margin-left .22s ease}.main.public{margin-left:0;padding:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px;padding:18px 20px;background:linear-gradient(135deg,#ffffffd9,#eff6ffd9);border:1px solid #ffffffa8;border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(18px)}html[data-theme="dark"] .topbar{background:linear-gradient(135deg,#0f1d31de,#111827de);border-color:#ffffff12}.topbar h1{margin:0;font-size:clamp(1.45rem,3vw,2.15rem);letter-spacing:-.04em}.topbar p{margin:4px 0 0;color:var(--muted)}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.icon-button,.theme-toggle,.ghost,button,.primary,.danger{border:0;border-radius:999px;padding:10px 15px;font-weight:800;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.icon-button{width:42px;height:42px;padding:0;background:var(--panel-solid);color:var(--ink);box-shadow:0 10px 24px #0f172a12}.theme-toggle,.ghost{background:color-mix(in srgb,var(--brand) 10%,var(--panel-solid));color:var(--brand);border:1px solid color-mix(in srgb,var(--brand) 18%,var(--line))}.primary,button[type="submit"]{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;box-shadow:0 12px 28px #2563eb38}.danger{background:linear-gradient(135deg,#ef4444,#f97316);color:#fff}.small{padding:8px 12px;font-size:.86rem}.full{width:100%;justify-content:center}.icon-button:hover,.theme-toggle:hover,.ghost:hover,button:hover,.primary:hover,.danger:hover{transform:translateY(-1px);box-shadow:var(--soft-shadow)}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:24px;align-items:center;margin-bottom:24px;padding:28px;background:linear-gradient(135deg,#2563eb,#06b6d4 48%,#f97316);border-radius:32px;color:#fff;box-shadow:0 30px 80px #2563eb35;position:relative;overflow:hidden}.dashboard-hero:after{content:"";position:absolute;right:-75px;top:-75px;width:220px;height:220px;border-radius:999px;background:#ffffff24}.dashboard-hero>*{position:relative;z-index:1}.dashboard-hero h2{font-size:clamp(1.8rem,4vw,3.25rem);line-height:.98;margin:8px 0 12px;letter-spacing:-.06em}.dashboard-hero p{max-width:760px;color:#eef6ff;margin:0;font-size:1.04rem}.eyebrow{display:inline-flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.14em;font-weight:900;font-size:.72rem;color:#fff;background:#ffffff24;border:1px solid #ffffff30;padding:8px 11px;border-radius:999px}.dashboard-search{background:#fffffff2;color:#0f172a;border-radius:24px;padding:18px;box-shadow:0 18px 45px #0f172a22}.dashboard-search label{font-weight:900;display:block;margin-bottom:9px}.search-shell{display:flex;gap:10px}.search-shell input{min-width:0;flex:1}.clear-search{display:inline-block;margin-top:10px;font-weight:800;color:#1d4ed8}.stats{display:grid;grid-template-columns:repeat(6,minmax(130px,1fr));gap:16px;margin-bottom:24px}.stats div{position:relative;overflow:hidden;background:var(--panel);border:1px solid #ffffff9e;border-radius:24px;padding:20px;box-shadow:var(--shadow);backdrop-filter:blur(14px)}html[data-theme="dark"] .stats div{border-color:#ffffff10}.stats div:before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--brand),var(--brand2),var(--accent))}.stats strong{display:block;font-size:2rem;letter-spacing:-.05em}.stats span{color:var(--muted);font-weight:800}.panel{background:var(--panel);border:1px solid #ffffffa8;border-radius:var(--radius);padding:24px;margin-bottom:24px;box-shadow:var(--shadow);backdrop-filter:blur(18px)}html[data-theme="dark"] .panel{border-color:#ffffff10}.panel h2{margin:0 0 14px;font-size:1.28rem;letter-spacing:-.03em}.panel p{color:var(--muted)}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.panel-head h2,.panel-head p{margin:0}.panel-head p{margin-top:4px;color:var(--muted)}.search-results-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.search-results-card{margin-bottom:0}.result-list{display:grid;gap:10px}.result-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:18px;background:color-mix(in srgb,var(--panel-solid) 78%,transparent);color:var(--ink)}.result-item:hover{border-color:color-mix(in srgb,var(--brand) 42%,var(--line));box-shadow:0 12px 28px #2563eb16}.result-item small{display:block;color:var(--muted);margin-top:2px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.mini-card{display:block;padding:18px;border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,color-mix(in srgb,var(--panel-solid) 94%,transparent),color-mix(in srgb,var(--brand) 5%,var(--panel-solid)));color:var(--ink);box-shadow:0 12px 28px #0f172a0d}.mini-card:hover{transform:translateY(-2px);box-shadow:var(--soft-shadow)}.mini-card h3{margin:0 0 6px}.pill-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.pill-row span{background:color-mix(in srgb,var(--brand) 11%,var(--panel-solid));color:var(--brand);padding:7px 10px;border-radius:999px;font-weight:850;font-size:.82rem}.table-wrap,.table{width:100%;overflow:auto}table{width:100%;border-collapse:separate;border-spacing:0 8px}th{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;text-align:left;padding:0 12px}td{background:color-mix(in srgb,var(--panel-solid) 88%,transparent);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:13px 12px;vertical-align:middle}td:first-child{border-left:1px solid var(--line);border-radius:16px 0 0 16px}td:last-child{border-right:1px solid var(--line);border-radius:0 16px 16px 0}.person-cell,.media-hero{display:flex;align-items:center;gap:12px}.avatar,.school-logo-placeholder{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--brand),var(--accent2));color:#fff;display:inline-grid;place-items:center;font-weight:950;object-fit:cover;box-shadow:0 10px 24px #2563eb24}.avatar.small{width:34px;height:34px;border-radius:12px;font-size:.78rem}.school-logo-img{width:72px;height:72px;border-radius:22px;object-fit:cover;box-shadow:var(--soft-shadow)}form.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}label{font-weight:800;color:var(--ink)}input,select,textarea{width:100%;margin-top:7px;border:1px solid var(--line);border-radius:16px;padding:12px 13px;background:color-mix(in srgb,var(--panel-solid) 88%,transparent);color:var(--ink);outline:none;transition:border .15s ease,box-shadow .15s ease}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px color-mix(in srgb,var(--brand) 16%,transparent)}textarea{min-height:105px;resize:vertical}.actions{display:flex;align-items:end;gap:10px}.search{display:flex;gap:10px;align-items:center;margin:10px 0 18px}.search input{margin-top:0}.inline-form,.upload-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.upload-row input{max-width:240px}.err{display:block;color:var(--danger);margin-top:6px}.empty{color:var(--muted);font-weight:750}.flash-wrap{display:grid;gap:10px;margin-bottom:18px}.flash{padding:13px 16px;border-radius:18px;font-weight:850;border:1px solid var(--line);background:var(--panel-solid)}.flash.success{border-color:color-mix(in srgb,var(--ok) 40%,var(--line));color:var(--ok)}.flash.error{border-color:color-mix(in srgb,var(--danger) 40%,var(--line));color:var(--danger)}.danger-zone{border-color:color-mix(in srgb,var(--danger) 36%,var(--line));background:linear-gradient(135deg,color-mix(in srgb,var(--danger) 7%,var(--panel)),var(--panel))}.site-footer{padding:12px 4px 24px;text-align:center;color:var(--muted);font-weight:750}.site-footer a{font-weight:900}.login-page{min-height:100vh;display:grid;place-items:center;padding:28px;background:radial-gradient(circle at top left,#60a5fa55,transparent 34%),radial-gradient(circle at bottom right,#f9731650,transparent 34%)}.login-card{width:min(440px,100%);padding:34px;border:1px solid #ffffff9e;border-radius:34px;background:var(--panel);box-shadow:var(--shadow);text-align:center;backdrop-filter:blur(18px)}.login-card h1{margin:16px 0 8px;font-size:2rem;letter-spacing:-.05em}.login-card p{color:var(--muted)}.login-card form{display:grid;gap:16px;text-align:left;margin-top:22px}.report{max-width:980px;margin-inline:auto}.sidebar-backdrop{display:none}.sidebar-collapsed .sidebar{width:90px}.sidebar-collapsed .brand-text,.sidebar-collapsed .sidebar nav span{display:none}.sidebar-collapsed .brand-link{padding-right:2px}.sidebar-collapsed .main{margin-left:90px}.sidebar-collapsed .sidebar nav a{justify-content:center}.sidebar-collapsed .sidebar nav svg{width:23px;height:23px}
@media (max-width:1180px){.stats{grid-template-columns:repeat(3,1fr)}.dashboard-hero{grid-template-columns:1fr}.search-results-grid{grid-template-columns:1fr}}
@media (max-width:780px){.sidebar{transform:translateX(-105%);width:min(310px,88vw)}body.sidebar-open .sidebar{transform:translateX(0)}.sidebar-close{display:inline-grid}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#02061780;z-index:20}body.sidebar-open .sidebar-backdrop{display:block}.main,.sidebar-collapsed .main{margin-left:0;padding:18px}.topbar{align-items:flex-start;flex-direction:column}.top-actions{width:100%;justify-content:space-between}.stats{grid-template-columns:repeat(2,1fr)}.dashboard-hero{padding:22px;border-radius:26px}.search-shell,.search{flex-direction:column}.panel-head{align-items:flex-start;flex-direction:column}.sidebar-collapsed .brand-text,.sidebar-collapsed .sidebar nav span{display:inline}.sidebar-collapsed .sidebar nav a{justify-content:flex-start}}
@media (max-width:520px){.stats{grid-template-columns:1fr}.main{padding:14px}.panel,.dashboard-search{padding:18px}.login-card{padding:24px}.inline-form,.upload-row{align-items:stretch}.upload-row input{max-width:none}}
@media print{.sidebar,.topbar,.site-footer,.sidebar-backdrop,.theme-toggle,.menu-button,.ghost,.primary,.danger,form{display:none!important}.main{margin:0;padding:0}.panel{box-shadow:none;border:0}.report{max-width:none}}

.avatar.xl{width:92px;height:92px;border-radius:28px;font-size:2rem}.big-metric{display:block;font-size:2.1rem;letter-spacing:-.05em;margin-top:8px}.attendance-card{padding:16px;border:1px solid var(--line);border-radius:22px;margin:14px 0;background:color-mix(in srgb,var(--panel-solid) 78%,transparent)}.stacked-form{display:grid;gap:8px;margin-top:12px}.stacked-form input,.stacked-form select,.stacked-form textarea{margin-top:0}.stacked-form textarea{min-height:84px}.mini-card form{margin-top:10px}.panel h3{letter-spacing:-.02em}.avatar[src$='.svg']{background:none}

/* Lekòl360 brand refresh */
:root{--brand:#0f766e;--brand-strong:#115e59;--brand2:#2563eb;--accent:#f59e0b;--accent2:#7c3aed;--bg:#eefdf8;--bg2:#eff6ff;--sidebar:#063b3a;--sidebar2:#0f172a;--shadow:0 24px 70px #0f766e18;--soft-shadow:0 12px 34px #0f766e24}html[data-theme="dark"]{--brand:#2dd4bf;--brand-strong:#5eead4;--brand2:#60a5fa;--accent:#fbbf24;--accent2:#a78bfa;--bg:#061716;--bg2:#0f172a;--sidebar:#021413;--sidebar2:#0b1630}.sidebar{background:radial-gradient(circle at 20% 10%,#2dd4bf40,transparent 34%),radial-gradient(circle at 100% 66%,#60a5fa33,transparent 35%),linear-gradient(180deg,var(--sidebar),var(--sidebar2))}.logo.wordmark{width:auto;min-width:92px;height:44px;padding:0 12px;border-radius:16px;font-size:.94rem;letter-spacing:-.04em;background:linear-gradient(135deg,#0f766e,#2563eb 62%,#f59e0b)}.logo.big.wordmark{width:auto;min-width:172px;height:76px;padding:0 22px;font-size:1.45rem;border-radius:26px}.login-brand{display:inline-block;color:#fff}.lekol360-hero,.entity-hero{background:linear-gradient(135deg,#0f766e,#2563eb 54%,#7c3aed)}.students-hero{background:linear-gradient(135deg,#0f766e,#14b8a6 45%,#2563eb)}.teachers-hero{background:linear-gradient(135deg,#2563eb,#7c3aed 55%,#f59e0b)}.filters-panel{border-color:color-mix(in srgb,var(--brand) 18%,var(--line))}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;align-items:end}.entity-table .chip,.chip{display:inline-flex;margin:3px 4px 3px 0;padding:6px 9px;border-radius:999px;background:color-mix(in srgb,var(--brand) 12%,var(--panel-solid));color:var(--brand);font-weight:850;font-size:.8rem}.action-card{border-color:color-mix(in srgb,var(--brand) 22%,var(--line));position:relative;overflow:hidden}.action-card:after{content:"";position:absolute;right:-32px;bottom:-36px;width:96px;height:96px;border-radius:999px;background:linear-gradient(135deg,color-mix(in srgb,var(--brand) 22%,transparent),color-mix(in srgb,var(--brand2) 18%,transparent))}.sidebar-collapsed .logo.wordmark{min-width:46px;width:46px;font-size:0;color:transparent}.sidebar-collapsed .logo.wordmark:before{content:"360";font-size:.78rem;color:#fff}.topbar h1:before{content:"";display:inline-block;width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--brand2));margin-right:10px;vertical-align:middle;box-shadow:0 0 0 5px color-mix(in srgb,var(--brand) 12%,transparent)}


/* Lekòl360 premium logo integration */
.brand-link{
  width:100%;
  padding:8px 10px;
  background:linear-gradient(135deg,#ffffff14,#ffffff08);
  border:1px solid #ffffff16;
}
.brand-logo-img{
  width:62px;
  height:62px;
  border-radius:20px;
  object-fit:cover;
  object-position:center;
  background:#fff;
  box-shadow:0 16px 34px #00000030,0 0 0 4px #ffffff12;
}
.brand-text strong{font-size:1.06rem;letter-spacing:-.035em}.brand small{font-size:.72rem;letter-spacing:.01em}.sidebar-collapsed .brand-link{justify-content:center;padding:8px}.sidebar-collapsed .brand-logo-img{width:54px;height:54px;border-radius:18px}.sidebar-collapsed .brand-text{display:none!important}
.topbar{
  display:grid;
  grid-template-columns:auto auto 1fr auto;
  background:linear-gradient(135deg,#ffffffee,#eff6ffee 54%,#ecfeffee);
  border:1px solid #ffffffd6;
}
html[data-theme="dark"] .topbar{background:linear-gradient(135deg,#0f1d31f2,#0b1630ef 58%,#042f2eef)}
.topbar-brand{
  display:flex;
  align-items:center;
  gap:11px;
  padding:6px 13px 6px 7px;
  border-radius:22px;
  color:var(--ink);
  background:color-mix(in srgb,var(--brand) 7%,#fff 82%);
  border:1px solid color-mix(in srgb,var(--brand) 16%,#fff);
  box-shadow:0 12px 28px #0f766e12;
}
.topbar-brand:hover{color:var(--brand-strong);transform:translateY(-1px)}
.topbar-brand img{width:50px;height:50px;border-radius:17px;object-fit:cover;background:#fff;box-shadow:0 10px 24px #0f172a16}.topbar-brand span{display:block;font-weight:950;letter-spacing:-.04em}.topbar-brand small{display:block;color:var(--muted);font-weight:800;font-size:.72rem;margin-top:1px}.topbar-title{min-width:0}.topbar-title h1{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.splash-screen{
  position:relative;
  isolation:isolate;
  min-height:100vh;
  display:grid;
  grid-template-columns:minmax(320px,1.05fr) minmax(320px,460px);
  align-items:center;
  gap:34px;
  padding:clamp(24px,5vw,72px);
  overflow:hidden;
  background:
    linear-gradient(135deg,#f8fbff 0%,#eefdf8 42%,#eff6ff 100%);
}
.splash-screen:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(circle at 12% 16%,#2563eb2b,transparent 28rem),
    radial-gradient(circle at 82% 18%,#22c55e24,transparent 24rem),
    radial-gradient(circle at 76% 86%,#f59e0b30,transparent 26rem),
    linear-gradient(115deg,#ffffffc7,#e0f2fe8c);
}
.splash-orb{position:absolute;z-index:-1;border-radius:999px;filter:blur(4px);opacity:.72}.splash-orb-blue{width:280px;height:280px;left:-80px;bottom:9%;background:linear-gradient(135deg,#2563eb55,#06b6d433)}.splash-orb-gold{width:210px;height:210px;right:12%;top:9%;background:linear-gradient(135deg,#f59e0b55,#22c55e33)}
.login-splash-panel{
  padding:clamp(28px,5vw,54px);
  border-radius:38px;
  background:linear-gradient(135deg,#ffffffcf,#ffffff8f);
  border:1px solid #ffffffd4;
  box-shadow:0 34px 90px #0f172a18;
  backdrop-filter:blur(22px);
}
.premium-logo img{
  display:block;
  width:min(430px,86vw);
  max-width:100%;
  border-radius:34px;
  background:#fff;
  box-shadow:0 28px 70px #0f766e22,0 0 0 1px #ffffff;
}
.login-splash-panel h1{margin:20px 0 8px;font-size:clamp(3rem,8vw,6.4rem);line-height:.9;letter-spacing:-.075em;background:linear-gradient(135deg,#0b2a5b,#2563eb 45%,#22c55e 70%,#f59e0b);-webkit-background-clip:text;background-clip:text;color:transparent}.login-splash-panel p{max-width:720px;font-size:clamp(1.05rem,2vw,1.35rem);color:#334155}.splash-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.splash-badges span{padding:9px 12px;border-radius:999px;background:#fff;border:1px solid #dbeafe;color:#0f172a;font-weight:850;box-shadow:0 10px 24px #0f172a0d}
.premium-auth-card{
  width:100%;
  max-width:460px;
  margin:0;
  padding:32px;
  border-radius:34px;
  background:#ffffffeb;
  border:1px solid #fff;
  box-shadow:0 34px 90px #0f172a24;
  backdrop-filter:blur(20px);
}
.auth-card-head{display:flex;align-items:center;gap:15px;margin-bottom:12px}.auth-card-head img{width:82px;height:82px;border-radius:25px;object-fit:cover;background:#fff;box-shadow:0 14px 30px #2563eb20}.auth-card-head h2{margin:2px 0 0;font-size:2rem;letter-spacing:-.05em}.premium-auth-card form{margin-top:18px}.premium-auth-card input{background:#f8fafc;border-color:#dbeafe}.premium-auth-card .primary.full{margin-top:8px;padding:14px 18px;background:linear-gradient(135deg,#0f766e,#2563eb 56%,#7c3aed)}
.hero-logo{
  display:block;
  width:clamp(142px,19vw,236px);
  border-radius:28px;
  margin:0 0 18px;
  background:#fff;
  box-shadow:0 24px 54px #0206172b,0 0 0 1px #ffffff85;
}
.lekol360-hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 88% 16%,#f59e0b73,transparent 16rem),
    radial-gradient(circle at 78% 84%,#22c55e59,transparent 18rem),
    linear-gradient(135deg,#083344,#0f766e 36%,#2563eb 72%,#7c3aed);
  box-shadow:0 30px 80px #0f766e2f;
}
.lekol360-hero:after{content:"";position:absolute;right:-70px;top:-70px;width:260px;height:260px;border-radius:999px;border:34px solid #ffffff1c}.lekol360-hero>*{position:relative;z-index:1}.stats>div,.mini-card,.panel{box-shadow:0 18px 54px #0f172a12}.stats>div{border:1px solid #ffffffb8;background:linear-gradient(135deg,#ffffffef,#f8fafcee)}.mini-card{background:linear-gradient(145deg,#ffffff,#f8fbff);border:1px solid #e2e8f0}.site-footer a{font-weight:950}
@media (max-width:1060px){.splash-screen{grid-template-columns:1fr}.premium-auth-card{max-width:none}.topbar{grid-template-columns:auto 1fr auto}.topbar-title{grid-column:1 / -1;order:3}.topbar-title h1{white-space:normal}.topbar-brand{margin-right:auto}}
@media (max-width:780px){.topbar{display:flex}.topbar-brand img{width:44px;height:44px}.topbar-brand small{display:none}.splash-screen{padding:22px}.login-splash-panel{padding:24px;border-radius:28px}.premium-logo img{border-radius:24px}.auth-card-head img{width:68px;height:68px}.hero-logo{width:142px}.brand-logo-img{width:56px;height:56px}}
@media (max-width:520px){.topbar-brand{width:100%;justify-content:flex-start}.splash-badges span{width:100%;text-align:center}.login-splash-panel h1{font-size:3.2rem}.premium-auth-card{padding:24px;border-radius:28px}}


/* Lekòl360 uniform navigation, typography, color, and dark-mode refinements */
:root{
  --brand:#0b7f72;
  --brand-strong:#075f57;
  --brand2:#1976d2;
  --brand3:#22c55e;
  --accent:#f5b027;
  --accent2:#6544d9;
  --bg:#f3fbf8;
  --bg2:#eef6ff;
  --panel:#fffffff0;
  --panel-solid:#ffffff;
  --ink:#102033;
  --muted:#64748b;
  --line:#d7e3ee;
  --sidebar:#042f2e;
  --sidebar2:#091b34;
  --sideText:#edfdfb;
  --shadow:0 24px 70px rgba(11,127,114,.16);
  --soft-shadow:0 14px 38px rgba(25,118,210,.18);
}
html[data-theme="dark"]{
  --bg:#041312;
  --bg2:#08152a;
  --panel:#0c1b29ee;
  --panel-solid:#0e2031;
  --ink:#ecfdf8;
  --muted:#a6b6c8;
  --line:#223a4f;
  --brand:#32d5c6;
  --brand-strong:#7ce9de;
  --brand2:#76b7ff;
  --brand3:#5ee285;
  --accent:#ffd166;
  --accent2:#b4a3ff;
  --sidebar:#021413;
  --sidebar2:#06162b;
  --sideText:#f1fffb;
  --shadow:0 24px 70px rgba(0,0,0,.55);
  --soft-shadow:0 14px 38px rgba(0,0,0,.42);
}
body{font-family:ui-rounded,"Aptos","Nunito Sans","Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;letter-spacing:-.01em;background:radial-gradient(circle at 9% 6%,color-mix(in srgb,var(--brand2) 22%,transparent),transparent 30rem),radial-gradient(circle at 92% 10%,color-mix(in srgb,var(--accent) 24%,transparent),transparent 24rem),radial-gradient(circle at 76% 92%,color-mix(in srgb,var(--brand3) 20%,transparent),transparent 28rem),linear-gradient(135deg,var(--bg),var(--bg2))}
.sidebar{width:304px;background:radial-gradient(circle at 12% 7%,color-mix(in srgb,var(--brand) 44%,transparent),transparent 34%),radial-gradient(circle at 105% 48%,color-mix(in srgb,var(--brand2) 35%,transparent),transparent 34%),linear-gradient(180deg,var(--sidebar),var(--sidebar2));overflow:visible}.main{margin-left:304px}.brand{position:relative}.sidebar-toggle-button{display:inline-grid!important;margin-left:auto;place-items:center;background:#ffffff18;color:#fff;border:1px solid #ffffff24;box-shadow:0 16px 34px #0004}.sidebar-toggle-button:hover{background:#ffffff26;transform:translateY(-1px)}.toggle-collapsed{display:none}.sidebar-collapsed .toggle-expanded{display:none}.sidebar-collapsed .toggle-collapsed{display:inline}.sidebar-collapsed .sidebar{width:92px}.sidebar-collapsed .main{margin-left:92px}.sidebar-collapsed .brand{justify-content:center}.sidebar-collapsed .sidebar-toggle-button{position:absolute;right:-18px;top:20px;width:38px;height:38px;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 14px 30px #0005}.sidebar nav a{position:relative;border:1px solid transparent;background:linear-gradient(135deg,#ffffff08,#ffffff03);font-size:.95rem}.sidebar nav a:hover{border-color:#ffffff25;background:linear-gradient(135deg,#ffffff1f,#ffffff10)}.sidebar nav a:before{content:"";width:6px;height:6px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--brand3));opacity:.72;box-shadow:0 0 18px color-mix(in srgb,var(--accent) 50%,transparent)}.sidebar-collapsed .sidebar nav a{justify-content:center;padding:13px}.sidebar-collapsed .sidebar nav a:before,.sidebar-collapsed .sidebar nav span{display:none}.brand-logo-img{box-shadow:0 16px 34px #0004,0 0 0 4px color-mix(in srgb,var(--accent) 20%,#fff 8%)}
.topbar{grid-template-columns:auto 1fr auto;background:linear-gradient(135deg,color-mix(in srgb,var(--panel-solid) 88%,transparent),color-mix(in srgb,var(--brand2) 8%,var(--panel-solid)));border-color:color-mix(in srgb,var(--brand) 15%,#fff)}.topbar h1,.dashboard-hero h2,.panel h2{font-weight:900;letter-spacing:-.055em}.topbar-brand{background:color-mix(in srgb,var(--brand) 8%,var(--panel-solid));border-color:color-mix(in srgb,var(--brand) 18%,var(--line));color:var(--ink)}html[data-theme="dark"] .topbar-brand{background:color-mix(in srgb,var(--brand) 13%,var(--panel-solid));border-color:color-mix(in srgb,var(--brand) 24%,var(--line))}
.module-hero{position:relative;overflow:hidden;box-shadow:0 28px 78px color-mix(in srgb,var(--brand) 24%,transparent);background:radial-gradient(circle at 88% 12%,color-mix(in srgb,var(--accent) 55%,transparent),transparent 15rem),radial-gradient(circle at 80% 86%,color-mix(in srgb,var(--brand3) 35%,transparent),transparent 16rem),linear-gradient(135deg,#063b3a,#0b7f72 38%,#1976d2 74%,#6544d9)}.module-hero:after{content:"";position:absolute;right:-54px;top:-54px;width:210px;height:210px;border-radius:999px;border:30px solid #ffffff1a}.module-hero>*{position:relative;z-index:1}.years-hero{background:linear-gradient(135deg,#075f57,#0b7f72 42%,#1976d2)}.classes-hero{background:linear-gradient(135deg,#0b7f72,#1976d2 55%,#22c55e)}.grades-hero{background:linear-gradient(135deg,#1976d2,#6544d9 56%,#f5b027)}.attendance-hero{background:linear-gradient(135deg,#0b7f72,#22c55e 48%,#1976d2)}.reports-hero{background:linear-gradient(135deg,#091b34,#1976d2 55%,#6544d9)}.import-hero{background:linear-gradient(135deg,#063b3a,#0b7f72 55%,#f5b027)}.schools-hero{background:linear-gradient(135deg,#042f2e,#0b7f72 46%,#1976d2)}.users-hero{background:linear-gradient(135deg,#091b34,#6544d9 55%,#1976d2)}.module-stats{margin-bottom:20px}.module-table-panel{overflow:hidden}.entity-table tr:hover td{background:color-mix(in srgb,var(--brand) 6%,transparent)}table{border-collapse:separate;border-spacing:0}thead th{background:color-mix(in srgb,var(--brand) 9%,var(--panel-solid));color:var(--ink);font-weight:900}td,th{border-bottom:1px solid var(--line)}input,select,textarea{background:color-mix(in srgb,var(--panel-solid) 90%,transparent);color:var(--ink);border-color:var(--line)}html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#091827;color:var(--ink);border-color:#284158}.panel,.mini-card,.stats>div,.dashboard-search{background:linear-gradient(145deg,color-mix(in srgb,var(--panel-solid) 94%,transparent),color-mix(in srgb,var(--brand2) 4%,var(--panel-solid)));border-color:color-mix(in srgb,var(--brand) 12%,var(--line))}html[data-theme="dark"] .panel,html[data-theme="dark"] .mini-card,html[data-theme="dark"] .stats>div,html[data-theme="dark"] .dashboard-search{background:linear-gradient(145deg,color-mix(in srgb,var(--panel-solid) 92%,transparent),color-mix(in srgb,var(--brand2) 9%,var(--panel-solid)));border-color:color-mix(in srgb,var(--brand) 20%,var(--line))}.chip{border:1px solid color-mix(in srgb,var(--brand) 18%,transparent)}.ghost{background:color-mix(in srgb,var(--brand) 9%,var(--panel-solid));color:var(--brand-strong)}.primary,button[type="submit"]{background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 14px 34px color-mix(in srgb,var(--brand2) 28%,transparent)}.danger{background:linear-gradient(135deg,#e11d48,#f97316)}.login-splash-panel,.premium-auth-card{background:linear-gradient(145deg,color-mix(in srgb,var(--panel-solid) 90%,transparent),color-mix(in srgb,var(--brand2) 6%,var(--panel-solid)));color:var(--ink)}html[data-theme="dark"] .splash-screen{background:linear-gradient(135deg,var(--bg),var(--bg2))}html[data-theme="dark"] .login-splash-panel p,html[data-theme="dark"] .premium-auth-card p{color:var(--muted)}html[data-theme="dark"] .splash-badges span{background:var(--panel-solid);border-color:var(--line);color:var(--ink)}html[data-theme="dark"] .premium-auth-card input{background:#091827;color:var(--ink)}
@media (max-width:780px){.sidebar{width:min(310px,88vw);transform:translateX(calc(-100% + 62px));padding-right:28px}body.sidebar-open .sidebar{transform:translateX(0)}body:not(.sidebar-open) .sidebar .brand-link,body:not(.sidebar-open) .sidebar nav{opacity:0;pointer-events:none}.sidebar-toggle-button{position:absolute;right:-18px;top:24px;width:42px;height:42px;background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 16px 34px #0006}.main,.sidebar-collapsed .main{margin-left:62px;padding:18px}.topbar{display:flex}.topbar-brand{width:100%}.sidebar-collapsed .sidebar{width:min(310px,88vw)}.sidebar-collapsed .brand-logo-img{width:56px;height:56px}.sidebar-collapsed .brand-text,.sidebar-collapsed .sidebar nav span{display:inline!important}.sidebar-collapsed .sidebar nav a{justify-content:flex-start}.sidebar-collapsed .sidebar nav a:before{display:block}}
@media print{.sidebar-toggle-button{display:none!important}}


/* Dark-mode review refinements */
.topbar-title h1{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.1}
.topbar{grid-template-columns:auto minmax(240px,1fr) auto}
.dashboard-search{min-width:min(100%,430px)}
.dashboard-search input{min-width:260px}
html[data-theme="dark"] .muted,html[data-theme="dark"] small,html[data-theme="dark"] .stats span,html[data-theme="dark"] .site-footer{color:#c4d2e3}
html[data-theme="dark"] input::placeholder,html[data-theme="dark"] textarea::placeholder{color:#b7c7d8;opacity:1}
.action-card{cursor:pointer}
.action-card h3:after{content:" →";color:var(--brand);font-weight:950}
@media (max-width:1180px){.dashboard-search{min-width:100%}.dashboard-search input{min-width:0}}


/* Profile pages, bottom sidebar hamburger toggle, and dashboard table pagination */
.sidebar{
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.sidebar nav{
  flex:1 1 auto;
  overflow:auto;
  padding-bottom:16px;
}
.sidebar-footer-actions{
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid #ffffff1a;
}
.sidebar-footer-actions .sidebar-toggle-button{
  position:static!important;
  width:100%;
  height:auto;
  min-height:48px;
  display:flex!important;
  justify-content:center;
  align-items:center;
  gap:10px;
  border-radius:18px;
  background:linear-gradient(135deg,#ffffff18,#ffffff0b);
  color:#fff;
  border:1px solid #ffffff24;
  box-shadow:0 14px 30px #0004;
}
.sidebar-footer-actions .sidebar-toggle-button:hover{background:#ffffff26;transform:translateY(-1px)}
.hamburger-icon{display:inline-grid;gap:4px;width:22px;flex:0 0 auto}
.hamburger-icon span{display:block;height:2.5px;border-radius:99px;background:currentColor;box-shadow:0 0 10px #ffffff4d}
.sidebar-toggle-label{font-weight:900;letter-spacing:.01em}
.sidebar-collapsed .sidebar-footer-actions .sidebar-toggle-button{width:48px;height:48px;margin-inline:auto;border-radius:16px;padding:0}
.sidebar-collapsed .sidebar-toggle-label{display:none}
.sidebar-collapsed .hamburger-icon{width:21px}
.person-name{font-weight:950;color:var(--ink);letter-spacing:-.02em}
.person-name:hover{color:var(--brand);text-decoration:none}
.profile-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.profile-heading{align-items:center}.profile-heading h2{margin:.15rem 0;font-size:clamp(2rem,5vw,4rem)}.profile-actions{display:flex;gap:10px;flex-wrap:wrap}
.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:20px}.profile-card{margin:0}.detail-list{display:grid;grid-template-columns:minmax(110px,auto) 1fr;gap:10px 16px;margin:0}.detail-list dt{color:var(--muted);font-weight:900}.detail-list dd{margin:0;font-weight:800}.chip-list{display:flex;gap:8px;flex-wrap:wrap}.avatar.xl{display:inline-grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand2));font-weight:950}
.table-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:12px 0 14px;padding:12px 14px;border:1px solid var(--line);border-radius:18px;background:color-mix(in srgb,var(--brand) 5%,var(--panel-solid));box-shadow:0 10px 26px #0f172a0c}.page-size-control,.pagination-buttons{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.page-size-control label,.page-size-control span,.pagination-status{color:var(--muted);font-weight:850}.page-size-control select{width:auto;min-width:86px;padding:8px 12px;border-radius:999px}.pagination-buttons button:disabled{opacity:.48;cursor:not-allowed;transform:none;box-shadow:none}
html[data-theme="dark"] .table-pagination{background:color-mix(in srgb,var(--brand) 8%,var(--panel-solid));box-shadow:0 10px 26px #0004}
@media (max-width:780px){.sidebar{overflow:visible}.sidebar nav{overflow:visible}.sidebar-footer-actions{position:relative}.sidebar-footer-actions .sidebar-toggle-button{position:absolute!important;right:-18px;bottom:12px;width:46px;height:46px;min-height:46px;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 16px 34px #0006}.sidebar-footer-actions .sidebar-toggle-label{display:none}.main,.sidebar-collapsed .main{margin-left:62px}.profile-hero{align-items:flex-start}.table-pagination{align-items:flex-start;flex-direction:column}.pagination-buttons{width:100%;justify-content:space-between}}
@media print{.table-pagination,.sidebar-footer-actions{display:none!important}}


/* Lekòl360 polished sidebar navigation refresh */
.sidebar{
  width:316px;
  padding:18px 16px;
  gap:14px;
  background:
    linear-gradient(180deg,#ffffff12,#ffffff05 42%,transparent 72%),
    radial-gradient(circle at 18% 8%,color-mix(in srgb,var(--brand) 58%,transparent),transparent 18rem),
    radial-gradient(circle at 112% 24%,color-mix(in srgb,var(--brand2) 44%,transparent),transparent 18rem),
    radial-gradient(circle at 48% 96%,color-mix(in srgb,var(--accent) 20%,transparent),transparent 16rem),
    linear-gradient(180deg,color-mix(in srgb,var(--sidebar) 92%,#0f766e),var(--sidebar2));
  border-right:1px solid #ffffff16;
  box-shadow:18px 0 54px rgba(2,6,23,.32);
  backdrop-filter:blur(18px);
}
.main{margin-left:316px}
.sidebar:before{
  content:"";
  position:absolute;
  inset:12px;
  z-index:-1;
  border-radius:30px;
  border:1px solid #ffffff10;
  background:linear-gradient(180deg,#ffffff08,transparent 36%,#00000010);
  pointer-events:none;
}
.brand{margin-bottom:4px;padding:2px}.brand-link{
  gap:13px;
  border-radius:24px;
  padding:10px;
  min-height:82px;
  background:linear-gradient(135deg,#ffffff1d,#ffffff0b 58%,#ffffff05);
  border:1px solid #ffffff20;
  box-shadow:0 18px 44px #00000020,inset 0 1px 0 #ffffff20;
}
.brand-link:hover{background:linear-gradient(135deg,#ffffff28,#ffffff10);transform:translateY(-2px) scale(1.01);box-shadow:0 22px 52px #0000002b,inset 0 1px 0 #ffffff2e}.brand-logo-img{width:58px;height:58px;border-radius:19px;transition:transform .22s ease,box-shadow .22s ease}.brand-link:hover .brand-logo-img{transform:rotate(-2deg) scale(1.04);box-shadow:0 18px 42px #0006,0 0 0 4px color-mix(in srgb,var(--accent) 26%,#fff 8%)}.brand-text strong{font-size:1.14rem;line-height:1;font-weight:950}.brand-text small{margin-top:5px;color:#cde9eb;font-size:.72rem;line-height:1.25;font-weight:780;max-width:172px}.sidebar nav{gap:6px;padding:6px 2px 16px;scrollbar-width:thin;scrollbar-color:#ffffff2c transparent}.sidebar nav::-webkit-scrollbar{width:6px}.sidebar nav::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:999px}.sidebar nav a{
  isolation:isolate;
  min-height:48px;
  padding:11px 12px;
  border-radius:18px;
  gap:12px;
  color:#e8fbfb;
  font-size:.94rem;
  font-weight:860;
  letter-spacing:-.015em;
  background:transparent;
  border:1px solid transparent;
  transform:translateX(0);
  transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease,color .18s ease,padding-left .18s ease;
}
.sidebar nav a:before{
  width:4px;
  height:22px;
  margin-left:-3px;
  border-radius:999px;
  opacity:0;
  background:linear-gradient(180deg,var(--accent),var(--brand3));
  box-shadow:0 0 20px color-mix(in srgb,var(--accent) 70%,transparent);
  transform:scaleY(.4);
  transition:opacity .18s ease,transform .18s ease;
}
.sidebar nav a:after{
  content:"";
  position:absolute;
  inset:4px;
  z-index:-1;
  border-radius:15px;
  background:linear-gradient(135deg,#ffffff1f,#ffffff09);
  opacity:0;
  transform:scale(.98);
  transition:opacity .18s ease,transform .18s ease;
}
.sidebar nav svg{
  width:22px;
  height:22px;
  padding:2px;
  opacity:.92;
  filter:drop-shadow(0 5px 10px rgba(0,0,0,.18));
  transition:transform .18s ease,opacity .18s ease,color .18s ease;
}
.sidebar nav a:hover,
.sidebar nav a:focus-visible{
  color:#fff;
  transform:translateX(5px);
  padding-left:14px;
  border-color:#ffffff24;
  background:linear-gradient(135deg,#ffffff18,#ffffff08);
  box-shadow:0 14px 30px rgba(0,0,0,.18),inset 0 1px 0 #ffffff18;
  outline:none;
}
.sidebar nav a:hover:before,.sidebar nav a:focus-visible:before,.sidebar nav a.is-active:before{opacity:1;transform:scaleY(1)}.sidebar nav a:hover:after,.sidebar nav a:focus-visible:after,.sidebar nav a.is-active:after{opacity:1;transform:scale(1)}.sidebar nav a:hover svg,.sidebar nav a:focus-visible svg{transform:translateX(1px) scale(1.08);opacity:1}.sidebar nav a.is-active{color:#fff;background:linear-gradient(135deg,color-mix(in srgb,var(--brand) 34%,transparent),color-mix(in srgb,var(--brand2) 22%,transparent));border-color:#ffffff2e;box-shadow:0 16px 34px rgba(0,0,0,.2),inset 0 1px 0 #ffffff24}.sidebar nav a.is-active svg{color:var(--accent);opacity:1}.sidebar-footer-actions{padding:14px 2px 2px;border-top:1px solid #ffffff16;background:linear-gradient(180deg,transparent,#00000012);border-radius:0 0 24px 24px}.sidebar-footer-actions .sidebar-toggle-button{
  position:relative!important;
  overflow:hidden;
  justify-content:space-between;
  min-height:54px;
  padding:10px 12px 10px 16px;
  border-radius:20px;
  background:
    radial-gradient(circle at 18% 10%,#ffffff36,transparent 42%),
    linear-gradient(135deg,color-mix(in srgb,var(--brand) 86%,#ffffff),color-mix(in srgb,var(--brand2) 84%,#0f172a) 68%,color-mix(in srgb,var(--accent2) 64%,#0f172a));
  border:1px solid #ffffff34;
  box-shadow:0 18px 42px rgba(0,0,0,.32),inset 0 1px 0 #ffffff40;
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.sidebar-footer-actions .sidebar-toggle-button:before{content:"";position:absolute;inset:-60% auto auto -20%;width:75%;height:180%;background:linear-gradient(90deg,transparent,#ffffff30,transparent);transform:rotate(18deg) translateX(-130%);transition:transform .5s ease}.sidebar-footer-actions .sidebar-toggle-button:hover{filter:saturate(1.08);transform:translateY(-2px);box-shadow:0 24px 54px rgba(0,0,0,.38),0 0 0 4px #ffffff10,inset 0 1px 0 #ffffff4d}.sidebar-footer-actions .sidebar-toggle-button:hover:before{transform:rotate(18deg) translateX(210%)}.hamburger-icon{width:24px;height:20px;place-content:center;gap:4.5px}.hamburger-icon span{height:2.5px;background:#fff;transition:transform .2s ease,width .2s ease,opacity .2s ease}.hamburger-icon span:nth-child(2){width:17px}.hamburger-icon span:nth-child(3){width:11px}.sidebar-footer-actions .sidebar-toggle-button:hover .hamburger-icon span{width:24px}.sidebar-toggle-label{color:#fff;font-size:.92rem;text-transform:uppercase;letter-spacing:.08em}.sidebar-collapsed .sidebar{width:96px;padding-inline:14px}.sidebar-collapsed .main{margin-left:96px}.sidebar-collapsed .brand-link{min-height:72px;padding:8px;justify-content:center}.sidebar-collapsed .brand-logo-img{width:52px;height:52px}.sidebar-collapsed .sidebar nav{align-items:center;padding-inline:0}.sidebar-collapsed .sidebar nav a{width:58px;height:52px;justify-content:center;padding:0;border-radius:18px}.sidebar-collapsed .sidebar nav a:hover{transform:translateX(0) translateY(-2px);padding-left:0}.sidebar-collapsed .sidebar nav a:before{display:none}.sidebar-collapsed .sidebar nav a:after{inset:5px}.sidebar-collapsed .sidebar nav svg{width:24px;height:24px}.sidebar-collapsed .sidebar-footer-actions .sidebar-toggle-button{width:56px;height:56px;min-height:56px;border-radius:18px;justify-content:center;padding:0}.sidebar-collapsed .hamburger-icon span:nth-child(1){transform:translateY(7px) rotate(45deg);width:22px}.sidebar-collapsed .hamburger-icon span:nth-child(2){opacity:0;transform:scaleX(.35)}.sidebar-collapsed .hamburger-icon span:nth-child(3){transform:translateY(-7px) rotate(-45deg);width:22px}
@media (max-width:780px){.sidebar{width:min(318px,88vw);padding:18px 18px 18px 14px}.sidebar:before{inset:10px}.sidebar-footer-actions .sidebar-toggle-button{position:absolute!important;right:-21px;bottom:16px;width:50px;height:50px;min-height:50px;justify-content:center;padding:0;border-radius:18px}.sidebar-footer-actions .sidebar-toggle-button .hamburger-icon span:nth-child(1),.sidebar-footer-actions .sidebar-toggle-button .hamburger-icon span:nth-child(2),.sidebar-footer-actions .sidebar-toggle-button .hamburger-icon span:nth-child(3){width:22px;opacity:1;transform:none}.sidebar-toggle-label{display:none!important}body.sidebar-open .sidebar-footer-actions .sidebar-toggle-button .hamburger-icon span:nth-child(1){transform:translateY(7px) rotate(45deg)}body.sidebar-open .sidebar-footer-actions .sidebar-toggle-button .hamburger-icon span:nth-child(2){opacity:0;transform:scaleX(.35)}body.sidebar-open .sidebar-footer-actions .sidebar-toggle-button .hamburger-icon span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}body:not(.sidebar-open) .sidebar .brand-link,body:not(.sidebar-open) .sidebar nav{opacity:0;pointer-events:none}.main,.sidebar-collapsed .main{margin-left:62px}}


/* Colorful branded sidebar icon system */
.sidebar nav a{
  --icon-c1:var(--brand);
  --icon-c2:var(--brand2);
  --icon-glow:color-mix(in srgb,var(--brand) 36%,transparent);
}
.sidebar nav a:nth-child(1){--icon-c1:#22c55e;--icon-c2:#0ea5e9;--icon-glow:#22c55e44}
.sidebar nav a:nth-child(2){--icon-c1:#38bdf8;--icon-c2:#2563eb;--icon-glow:#38bdf844}
.sidebar nav a:nth-child(3){--icon-c1:#f59e0b;--icon-c2:#ef4444;--icon-glow:#f59e0b44}
.sidebar nav a:nth-child(4){--icon-c1:#14b8a6;--icon-c2:#22c55e;--icon-glow:#14b8a644}
.sidebar nav a:nth-child(5){--icon-c1:#8b5cf6;--icon-c2:#ec4899;--icon-glow:#8b5cf644}
.sidebar nav a:nth-child(6){--icon-c1:#06b6d4;--icon-c2:#3b82f6;--icon-glow:#06b6d444}
.sidebar nav a:nth-child(7){--icon-c1:#f97316;--icon-c2:#facc15;--icon-glow:#f9731644}
.sidebar nav a:nth-child(8){--icon-c1:#10b981;--icon-c2:#84cc16;--icon-glow:#10b98144}
.sidebar nav a:nth-child(9){--icon-c1:#6366f1;--icon-c2:#a855f7;--icon-glow:#6366f144}
.sidebar nav a:nth-child(10){--icon-c1:#0ea5e9;--icon-c2:#14b8a6;--icon-glow:#0ea5e944}
.sidebar nav a:nth-child(11){--icon-c1:#f43f5e;--icon-c2:#fb7185;--icon-glow:#f43f5e44}
.sidebar nav svg{
  flex:0 0 auto;
  width:34px;
  height:34px;
  padding:7px;
  border-radius:13px;
  color:#fff;
  fill:currentColor;
  background:
    radial-gradient(circle at 28% 22%,#ffffff66,transparent 34%),
    linear-gradient(135deg,var(--icon-c1),var(--icon-c2));
  box-shadow:0 10px 24px var(--icon-glow),inset 0 1px 0 #ffffff55,inset 0 -8px 16px #00000016;
  filter:none;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,opacity .2s ease;
}
.sidebar nav a:hover svg,
.sidebar nav a:focus-visible svg,
.sidebar nav a.is-active svg{
  color:#fff;
  transform:translateX(1px) scale(1.1) rotate(-3deg);
  box-shadow:0 15px 30px var(--icon-glow),0 0 0 4px #ffffff12,inset 0 1px 0 #ffffff66,inset 0 -8px 16px #00000018;
}
.sidebar nav a.is-active svg{background:radial-gradient(circle at 28% 22%,#ffffff78,transparent 34%),linear-gradient(135deg,var(--icon-c2),var(--icon-c1))}.sidebar nav a span{line-height:1.15}.sidebar-collapsed .sidebar nav svg{width:38px;height:38px;padding:8px;border-radius:14px}.sidebar-collapsed .sidebar nav a{width:62px;height:56px}.sidebar-collapsed .sidebar nav a:hover svg,.sidebar-collapsed .sidebar nav a.is-active svg{transform:scale(1.08) rotate(-3deg)}
@media (max-width:780px){.sidebar nav svg{width:34px;height:34px}.sidebar-collapsed .sidebar nav svg{width:34px;height:34px}.sidebar-collapsed .sidebar nav a{width:auto;height:auto}}

/* Login, logout, and responsive shell UX refresh */
.mobile-menu-button{display:none;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;border:1px solid color-mix(in srgb,var(--brand) 22%,#fff);box-shadow:0 14px 30px color-mix(in srgb,var(--brand) 24%,transparent)}
.logout-button{background:color-mix(in srgb,var(--danger) 10%,var(--panel-solid));color:var(--danger);border-color:color-mix(in srgb,var(--danger) 20%,var(--line))}
.logout-button:hover{background:color-mix(in srgb,var(--danger) 15%,var(--panel-solid));color:var(--danger);transform:translateY(-1px)}
.auth-refresh.splash-screen{grid-template-columns:minmax(320px,1fr) minmax(340px,480px);gap:clamp(22px,4vw,44px);background:radial-gradient(circle at 8% 12%,color-mix(in srgb,var(--brand2) 22%,transparent),transparent 24rem),radial-gradient(circle at 91% 10%,color-mix(in srgb,var(--accent) 25%,transparent),transparent 22rem),linear-gradient(135deg,#f8fbff,#ecfdf5 45%,#eff6ff)}
.auth-hero-panel{max-width:840px}.auth-hero-panel h1{max-width:820px;font-size:clamp(2.7rem,6.4vw,5.8rem);line-height:.92}.auth-hero-panel p{max-width:620px}
.modern-login-card{position:relative;overflow:hidden}.modern-login-card:before{content:"";position:absolute;inset:0 0 auto;height:7px;background:linear-gradient(90deg,var(--brand),var(--brand2),var(--accent2),var(--accent));}.no-logo-head{align-items:flex-start;margin-bottom:4px}.no-logo-head h2{font-size:clamp(2rem,4vw,2.65rem)}.login-intro{color:var(--muted);font-weight:750;margin-top:8px}
.portal-login-options{display:grid;grid-template-columns:1fr;gap:10px;margin:20px 0}.portal-option{display:flex;align-items:center;gap:13px;padding:14px;border-radius:22px;color:var(--ink);background:linear-gradient(135deg,color-mix(in srgb,var(--brand) 7%,var(--panel-solid)),color-mix(in srgb,var(--brand2) 5%,var(--panel-solid)));border:1px solid color-mix(in srgb,var(--brand) 14%,var(--line));box-shadow:0 12px 30px #0f172a0d;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,background .16s ease}.portal-option:hover,.portal-option:focus-visible,.portal-option.is-selected{color:var(--ink);transform:translateY(-2px);border-color:color-mix(in srgb,var(--brand2) 36%,var(--line));box-shadow:0 18px 38px color-mix(in srgb,var(--brand2) 18%,transparent);outline:none}.portal-option.is-selected{background:linear-gradient(135deg,color-mix(in srgb,var(--brand) 14%,var(--panel-solid)),color-mix(in srgb,var(--brand2) 12%,var(--panel-solid)))}.portal-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 12px 24px color-mix(in srgb,var(--brand) 24%,transparent);font-size:1.35rem}.portal-option strong{display:block;font-size:1rem;font-weight:950}.portal-option small{display:block;color:var(--muted);font-weight:780;margin-top:2px}.portal-note{margin:0 0 14px;padding:12px 14px;border-radius:17px;background:color-mix(in srgb,var(--brand) 9%,var(--panel-solid));border:1px solid color-mix(in srgb,var(--brand) 15%,var(--line));color:var(--brand-strong);font-weight:800;line-height:1.35}.login-form-card label{font-weight:900;color:var(--ink)}.login-form-card input{min-height:48px;border-radius:16px}.login-security-note{margin:14px 0 0;color:var(--muted);font-size:.88rem;font-weight:750;line-height:1.4}
html[data-theme="dark"] .auth-refresh.splash-screen{background:radial-gradient(circle at 8% 12%,color-mix(in srgb,var(--brand2) 18%,transparent),transparent 24rem),radial-gradient(circle at 91% 10%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 22rem),linear-gradient(135deg,#031716,#08152a)}html[data-theme="dark"] .login-splash-panel,html[data-theme="dark"] .premium-auth-card{background:color-mix(in srgb,var(--panel-solid) 88%,transparent);border-color:#ffffff18}html[data-theme="dark"] .auth-hero-panel p{color:#d0ddea}html[data-theme="dark"] .portal-option{background:linear-gradient(135deg,color-mix(in srgb,var(--brand) 12%,var(--panel-solid)),color-mix(in srgb,var(--brand2) 8%,var(--panel-solid)));color:var(--ink)}html[data-theme="dark"] .portal-note{color:var(--brand-strong)}
@media (max-width:1060px){.auth-refresh.splash-screen{grid-template-columns:1fr}.auth-hero-panel{padding-bottom:30px}.modern-login-card{max-width:none}.portal-login-options{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:780px){.mobile-menu-button{display:inline-grid;flex:0 0 auto}.topbar{gap:12px}.topbar-brand{flex:1 1 auto;min-width:0}.topbar-title{width:100%}.top-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.top-actions .theme-toggle,.top-actions form,.top-actions form button{width:100%}.sidebar{transform:translateX(-105%);width:min(326px,88vw);padding:18px;z-index:40}body.sidebar-open .sidebar{transform:translateX(0)}body:not(.sidebar-open) .sidebar .brand-link,body:not(.sidebar-open) .sidebar nav{opacity:1;pointer-events:auto}.sidebar-backdrop{z-index:35}.main,.sidebar-collapsed .main{margin-left:0;padding:16px}.sidebar-footer-actions .sidebar-toggle-button{position:relative!important;right:auto;bottom:auto;width:100%;height:52px;min-height:52px;border-radius:18px}.sidebar-footer-actions .sidebar-toggle-label{display:inline!important}.sidebar-collapsed .sidebar{width:min(326px,88vw)}.sidebar-collapsed .brand-text,.sidebar-collapsed .sidebar nav span{display:inline!important}.sidebar-collapsed .sidebar nav a{width:auto;height:auto;justify-content:flex-start;padding:11px 12px}.sidebar-collapsed .sidebar nav svg{width:34px;height:34px}.sidebar-collapsed .sidebar-footer-actions .sidebar-toggle-button{width:100%;height:52px;justify-content:space-between;padding:10px 12px 10px 16px}.sidebar-collapsed .sidebar-toggle-label{display:inline!important}}
@media (max-width:560px){.portal-login-options{grid-template-columns:1fr}.auth-refresh.splash-screen{padding:16px}.premium-logo img{width:min(310px,88vw)}.modern-login-card{padding:22px}.top-actions{grid-template-columns:1fr}.topbar-brand div small{display:none}}


/* Portal-first login, French shell, compact sidebar tools, lighter typography */
body{font-weight:400;letter-spacing:-.006em}
strong,b,.stats strong,.mini-card h3,.panel h2,.panel h3,.brand-text strong,.topbar h1,.dashboard-hero h2{font-weight:650}
.sidebar nav a,.portal-option strong,.portal-option small,.login-form-card label,.portal-note,.chip,.page-size-control label,.page-size-control span,.pagination-status{font-weight:600}
.primary,button[type="submit"],.ghost,.theme-toggle,.icon-button,.danger{font-weight:650}
.site-footer a{font-weight:650!important}

.focused-topbar{position:relative;display:flex!important;align-items:center;justify-content:center;min-height:76px;padding:18px 74px;text-align:center;background:linear-gradient(135deg,color-mix(in srgb,var(--panel-solid) 92%,transparent),color-mix(in srgb,var(--brand) 5%,var(--panel-solid)));}
.focused-topbar .topbar-title{width:100%;display:flex;justify-content:center;min-width:0}
.focused-topbar h1{margin:0 auto;text-align:center;font-size:clamp(1.55rem,3vw,2.35rem);font-weight:650;letter-spacing:-.035em;line-height:1.08}
.focused-topbar .mobile-menu-button{position:absolute;left:18px;top:50%;transform:translateY(-50%)}
.focused-topbar .mobile-menu-button:hover{transform:translateY(-50%) scale(1.03)}
.focused-topbar .mobile-menu-button svg{width:22px;height:22px;fill:currentColor}
.module-hero .eyebrow,.module-hero h2,.entity-hero .eyebrow,.entity-hero h2,.lekol360-hero h2{display:none}
.module-hero,.entity-hero,.lekol360-hero{align-items:center;padding-block:24px}
.module-hero p,.entity-hero p,.lekol360-hero p{margin:0;max-width:760px;font-weight:450;line-height:1.55}

.portal-first-login .three-portals{grid-template-columns:1fr;gap:12px}
.portal-first-login .portal-option{min-height:74px}
.portal-first-login .portal-placeholder{margin:0 0 4px;padding:16px;border:1px dashed color-mix(in srgb,var(--brand) 28%,var(--line));border-radius:18px;color:var(--muted);background:color-mix(in srgb,var(--brand) 5%,var(--panel-solid));text-align:center;font-weight:500}
.portal-auth-fields{animation:authFieldsIn .22s ease both}
@keyframes authFieldsIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.compact-sidebar-tools{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;align-items:center;padding:12px 2px 2px!important}
.sidebar-tool,.sidebar-tool-form{min-width:0}
.sidebar-tool-form{display:block;margin:0}
.sidebar-tool{position:relative;width:100%;height:50px;min-height:50px!important;display:grid!important;place-items:center!important;padding:0!important;border-radius:17px!important;color:#fff!important;background:linear-gradient(135deg,#ffffff18,#ffffff08)!important;border:1px solid #ffffff22!important;box-shadow:0 12px 28px rgba(0,0,0,.22)!important;overflow:visible!important;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}
.sidebar-tool:hover,.sidebar-tool:focus-visible{transform:translateY(-2px);background:linear-gradient(135deg,#ffffff27,#ffffff11)!important;border-color:#ffffff36!important;box-shadow:0 18px 36px rgba(0,0,0,.28)!important;outline:none}
.sidebar-tool svg{width:22px!important;height:22px!important;fill:currentColor!important;padding:0!important;border-radius:0!important;background:none!important;box-shadow:none!important;filter:none!important;color:currentColor!important}
.sidebar-tool span{position:absolute;left:50%;bottom:calc(100% + 10px);z-index:80;max-width:220px;width:max-content;padding:7px 10px;border-radius:999px;background:#0f172a;color:#fff;font-size:.78rem;font-weight:600;line-height:1;white-space:nowrap;box-shadow:0 12px 28px rgba(0,0,0,.25);opacity:0;pointer-events:none;transform:translateX(-50%) translateY(5px);transition:opacity .16s ease,transform .16s ease}
.sidebar-tool:hover span,.sidebar-tool:focus-visible span{opacity:1;transform:translateX(-50%) translateY(0)}
.sidebar-user-pill{cursor:default}.sidebar-user-pill svg{color:#99f6e4!important}.theme-toggle svg{color:#bfdbfe!important}.logout-button svg{color:#fecaca!important}.sidebar-toggle-button svg{color:#fef3c7!important}
.sidebar-collapsed .compact-sidebar-tools{grid-template-columns:1fr;gap:9px}.sidebar-collapsed .sidebar-tool{width:56px;height:52px;margin-inline:auto}
.sidebar-collapsed .sidebar-tool span{left:calc(100% + 12px);bottom:50%;transform:translateY(50%) translateX(-4px)}
.sidebar-collapsed .sidebar-tool:hover span,.sidebar-collapsed .sidebar-tool:focus-visible span{transform:translateY(50%) translateX(0)}
.sidebar-collapsed .brand-link:after,.sidebar-collapsed .sidebar nav a:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;z-index:90;padding:8px 10px;border-radius:999px;background:#0f172a;color:#fff;font-size:.78rem;font-weight:600;line-height:1;white-space:nowrap;opacity:0;pointer-events:none;transform:translateY(-50%) translateX(-4px);transition:opacity .16s ease,transform .16s ease;box-shadow:0 12px 28px rgba(0,0,0,.25)}
.sidebar-collapsed .brand-link:hover:after,.sidebar-collapsed .sidebar nav a:hover:after,.sidebar-collapsed .brand-link:focus-visible:after,.sidebar-collapsed .sidebar nav a:focus-visible:after{opacity:1;transform:translateY(-50%) translateX(0)}
.sidebar-footer-actions .sidebar-toggle-button:before,.hamburger-icon{display:none!important}
.mobile-menu-button{display:inline-grid;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;border:1px solid color-mix(in srgb,var(--brand) 22%,#fff);box-shadow:0 14px 30px color-mix(in srgb,var(--brand) 24%,transparent)}

@media (min-width:781px){.mobile-menu-button{display:none!important}}
@media (max-width:780px){
  .focused-topbar{padding:16px 18px 16px 64px;min-height:68px;text-align:left;justify-content:flex-start}.focused-topbar .topbar-title{justify-content:flex-start}.focused-topbar h1{text-align:left;margin:0;font-size:1.45rem}.compact-sidebar-tools{grid-template-columns:repeat(4,minmax(0,1fr))}.sidebar-collapsed .compact-sidebar-tools{grid-template-columns:repeat(4,minmax(0,1fr))}.sidebar-collapsed .sidebar-tool{width:100%;height:50px}.sidebar-tool span,.sidebar-collapsed .sidebar-tool span{left:50%;bottom:calc(100% + 10px);transform:translateX(-50%) translateY(5px)}.sidebar-tool:hover span,.sidebar-collapsed .sidebar-tool:hover span{transform:translateX(-50%) translateY(0)}
}
@media (max-width:560px){.compact-sidebar-tools{grid-template-columns:repeat(2,minmax(0,1fr))}.portal-first-login .portal-option{min-height:68px}.focused-topbar{padding-right:14px}}


/* Refined portal login cleanup */
.transparent-login-logo img{
  background:transparent!important;
  box-shadow:none!important;
  border-radius:0!important;
  filter:drop-shadow(0 24px 44px color-mix(in srgb,var(--brand) 18%,transparent));
}
.portal-first-login .login-splash-panel{
  background:linear-gradient(135deg,#ffffffb8,#ffffff72);
}
.refined-portal-card{
  padding-top:30px;
}
.refined-portal-card .portal-subtitle{
  margin:0 0 14px;
  max-width:100%;
  text-align:left;
}
.refined-portal-card .aligned-portal-options{
  margin:0 0 14px;
  align-items:stretch;
}
.refined-portal-card .portal-option{
  align-items:center;
  justify-content:flex-start;
  text-align:left;
}
.refined-portal-card .portal-option > span:not(.portal-icon){
  display:flex;
  flex:1 1 auto;
  min-width:0;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
}
.refined-portal-card .portal-option strong{
  display:block;
  width:100%;
  font-size:1.02rem;
  text-align:left;
}
.refined-portal-card .portal-option small{
  display:block;
  width:100%;
  line-height:1.25;
  text-align:left;
}
.refined-portal-card .portal-note{
  margin-top:2px;
}
.refined-portal-card .auth-card-head,
.refined-portal-card .eyebrow,
.refined-portal-card h2,
.refined-portal-card .portal-placeholder{
  display:none!important;
}
@media (max-width:560px){
  .transparent-login-logo img{width:min(300px,82vw)!important}
  .refined-portal-card{padding-top:24px}
}

/* Lekòl360 production polish: transparent logo, compact sidebar, clean nav, modern login */
.crisp-logo{object-fit:contain;image-rendering:auto;backface-visibility:hidden;transform:translateZ(0)}
.brand-logo-img,.topbar-logo-img,.hero-logo,.premium-logo img{background:transparent!important;object-fit:contain!important;box-shadow:none!important}
.brand-link{min-height:68px;padding:8px 9px;border-radius:20px}
.brand-logo-img{width:50px!important;height:50px!important;border-radius:0!important;filter:drop-shadow(0 12px 22px rgba(0,0,0,.24))}
.topbar-logo-link{position:absolute;left:18px;top:50%;transform:translateY(-50%);display:grid;place-items:center;width:54px;height:54px;border-radius:18px;background:color-mix(in srgb,var(--brand) 7%,var(--panel-solid));border:1px solid color-mix(in srgb,var(--brand) 16%,var(--line));box-shadow:0 12px 28px rgba(15,23,42,.10);transition:transform .16s ease,box-shadow .16s ease}
.topbar-logo-link:hover{transform:translateY(-50%) scale(1.03);box-shadow:0 16px 34px rgba(15,23,42,.16)}
.topbar-logo-img{width:46px;height:46px;filter:drop-shadow(0 8px 14px rgba(15,23,42,.14))}
.focused-topbar{padding-left:90px;padding-right:90px}
.focused-topbar .mobile-menu-button{left:14px}.focused-topbar .mobile-menu-button + .topbar-logo-link{left:70px}
.sidebar{width:268px!important;padding:14px 12px!important;gap:8px}.main{margin-left:268px!important}.sidebar-collapsed .sidebar{width:86px!important}.sidebar-collapsed .main{margin-left:86px!important}.brand{margin-bottom:2px!important}.brand-text strong{font-size:1rem!important}.brand-text small{font-size:.68rem!important}.sidebar nav{gap:4px!important;padding-top:2px!important}.sidebar nav a{min-height:42px!important;padding:8px 10px!important;border-radius:14px!important;font-size:.88rem!important;gap:9px!important}.sidebar nav a:before{display:none!important;content:none!important}.sidebar nav svg{width:30px!important;height:30px!important;padding:6px!important;border-radius:11px!important}.sidebar nav a:hover,.sidebar nav a:focus-visible{transform:translateX(2px)!important;padding-left:10px!important}.sidebar-collapsed .sidebar nav a{width:54px!important;height:48px!important;padding:0!important}.sidebar-collapsed .sidebar nav svg{width:34px!important;height:34px!important}.compact-sidebar-tools{gap:6px!important;padding-top:8px!important}.sidebar-tool{height:44px!important;min-height:44px!important;border-radius:14px!important}.sidebar-tool svg{width:20px!important;height:20px!important}.sidebar-collapsed .sidebar-tool{width:50px!important;height:46px!important}.sidebar-footer-actions{padding-top:8px!important}
.login-page.auth-refresh{background:radial-gradient(circle at 12% 10%,rgba(37,99,235,.20),transparent 24rem),radial-gradient(circle at 88% 18%,rgba(245,176,39,.22),transparent 22rem),radial-gradient(circle at 72% 86%,rgba(34,197,94,.18),transparent 26rem),linear-gradient(135deg,#f8fbff,#eefdf8 48%,#eff6ff)!important}.login-splash-panel{position:relative;overflow:hidden}.login-splash-panel:after{content:"";position:absolute;right:-70px;bottom:-80px;width:230px;height:230px;border-radius:999px;background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(34,197,94,.12));pointer-events:none}.login-kicker{display:inline-flex;margin-bottom:14px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.9);color:var(--brand-strong);font-weight:700;box-shadow:0 10px 24px rgba(15,23,42,.08)}.login-feature-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.login-feature-badges span{padding:10px 13px;border-radius:999px;background:#fff;border:1px solid color-mix(in srgb,var(--brand) 12%,#dbeafe);color:#102033;font-weight:650;box-shadow:0 12px 28px rgba(15,23,42,.08)}.transparent-login-logo img{width:min(360px,76vw)!important;filter:drop-shadow(0 22px 42px rgba(15,118,110,.20))!important}.login-splash-panel h1{font-size:clamp(2.55rem,5.7vw,5.2rem)!important;line-height:.95!important}.login-card-heading span{display:inline-flex;margin-bottom:8px;color:var(--brand);font-weight:750}.login-card-heading h2{display:block!important;margin:0 0 6px;font-size:clamp(1.7rem,3vw,2.25rem);line-height:1;letter-spacing:-.045em}.refined-portal-card .login-card-heading h2{display:block!important}.portal-option{border-radius:20px!important}.portal-option:nth-child(1) .portal-icon{background:linear-gradient(135deg,#2563eb,#06b6d4)}.portal-option:nth-child(2) .portal-icon{background:linear-gradient(135deg,#7c3aed,#ec4899)}.portal-option:nth-child(3) .portal-icon{background:linear-gradient(135deg,#0f766e,#f59e0b)}
.hero-logo-link{display:inline-grid;place-items:center;margin:0 0 18px}.hero-logo{width:clamp(132px,18vw,216px)!important;margin:0!important;filter:drop-shadow(0 24px 42px rgba(2,6,23,.22))}.teachers-dashboard-hero{background:radial-gradient(circle at 86% 16%,rgba(245,176,39,.55),transparent 15rem),radial-gradient(circle at 78% 82%,rgba(34,197,94,.35),transparent 16rem),linear-gradient(135deg,#1e3a8a,#2563eb 42%,#7c3aed 76%)!important}.teachers-dashboard-hero .eyebrow,.teachers-dashboard-hero h2{display:block!important}.teachers-dashboard-hero h2{margin:.25rem 0;font-size:clamp(2rem,4vw,3.3rem);color:#fff}.teachers-dashboard-hero .eyebrow{color:#dbeafe;font-weight:700}.teachers-dashboard-hero p{color:#eef2ff!important}.site-footer{padding:18px;text-align:center;color:var(--muted);font-weight:500}.site-footer a{font-weight:700!important}
@media (max-width:780px){.sidebar{width:min(300px,88vw)!important}.main,.sidebar-collapsed .main{margin-left:0!important}.focused-topbar{padding:14px 16px 14px 116px!important;justify-content:flex-start}.focused-topbar .mobile-menu-button{left:12px}.focused-topbar .mobile-menu-button + .topbar-logo-link{left:62px}.topbar-logo-link{width:46px;height:46px;border-radius:15px}.topbar-logo-img{width:40px;height:40px}.focused-topbar h1{text-align:left;font-size:1.38rem}.auth-refresh.splash-screen{padding:18px!important}.login-feature-badges span{flex:1 1 100%;text-align:center}.sidebar-collapsed .sidebar{width:min(300px,88vw)!important}.sidebar-collapsed .main{margin-left:0!important}}
@media (max-width:560px){.focused-topbar{padding-left:110px!important}.transparent-login-logo img{width:min(270px,78vw)!important}.login-splash-panel h1{font-size:2.65rem!important}.login-card-heading h2{font-size:1.7rem}}
@media (min-width:781px){.focused-topbar .mobile-menu-button + .topbar-logo-link{left:18px}}
@media (max-width:780px){.focused-topbar .mobile-menu-button + .topbar-logo-link{left:62px}}

/* Ultra-compact sidebar menu spacing */
.sidebar nav{
  gap:1px!important;
  padding-top:0!important;
  padding-bottom:8px!important;
}
.sidebar nav a{
  min-height:36px!important;
  padding:5px 8px!important;
  border-radius:12px!important;
  gap:8px!important;
  font-size:.86rem!important;
  line-height:1.05!important;
}
.sidebar nav svg{
  width:26px!important;
  height:26px!important;
  padding:5px!important;
  border-radius:10px!important;
}
.sidebar nav a:hover,
.sidebar nav a:focus-visible{
  padding-left:8px!important;
  transform:translateX(1px)!important;
}
.sidebar-collapsed .sidebar nav a{
  width:48px!important;
  height:42px!important;
}
.sidebar-collapsed .sidebar nav svg{
  width:30px!important;
  height:30px!important;
  padding:6px!important;
}
@media (max-width:780px){
  .sidebar nav{gap:2px!important}
  .sidebar nav a{min-height:40px!important;padding:7px 9px!important}
  .sidebar nav svg{width:28px!important;height:28px!important}
}

/* Official Lekòl360 logo rollout */
.app-loading-screen{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:radial-gradient(circle at 16% 12%,rgba(37,99,235,.16),transparent 26rem),radial-gradient(circle at 84% 16%,rgba(245,158,11,.18),transparent 24rem),linear-gradient(135deg,#f8fbff,#eefdf8 52%,#eff6ff);transition:opacity .22s ease,visibility .22s ease}.app-loading-screen.is-hidden{opacity:0;visibility:hidden}.loading-logo{width:min(440px,78vw);height:auto;filter:drop-shadow(0 26px 52px rgba(15,118,110,.18))}html[data-theme="dark"] .app-loading-screen{background:radial-gradient(circle at 16% 12%,rgba(96,165,250,.13),transparent 26rem),radial-gradient(circle at 84% 16%,rgba(251,191,36,.12),transparent 24rem),linear-gradient(135deg,#031716,#08152a)}
.brand-link{align-items:center!important;gap:10px!important;min-height:76px!important;padding:8px 8px!important}.brand-logo-img{width:142px!important;height:auto!important;max-height:64px!important;border-radius:0!important;object-fit:contain!important;filter:drop-shadow(0 12px 22px rgba(0,0,0,.20))!important;flex:0 0 auto}.brand-text{display:none!important}.sidebar-collapsed .brand-logo-img{width:58px!important;height:58px!important;object-fit:contain!important}.sidebar-collapsed .brand-link{min-height:66px!important;justify-content:center!important;padding:6px!important}.topbar-logo-link{width:154px!important;height:58px!important;border-radius:20px!important;background:color-mix(in srgb,var(--panel-solid) 70%,transparent)!important;backdrop-filter:blur(14px)}.topbar-logo-img{width:138px!important;height:52px!important;object-fit:contain!important}.focused-topbar{padding-left:184px!important}.hero-logo{width:clamp(260px,28vw,410px)!important;height:auto!important}.premium-logo img{width:min(560px,84vw)!important;height:auto!important}.report-official-logo{width:170px;height:auto;object-fit:contain;flex:0 0 auto}.report .media-hero{gap:14px;align-items:center}@media print{.app-loading-screen,.sidebar,.topbar,.site-footer{display:none!important}.main,.sidebar-collapsed .main{margin-left:0!important}.report-official-logo{width:150px!important}}
@media (max-width:780px){.brand-logo-img{width:134px!important}.topbar-logo-link{width:118px!important;height:48px!important;left:58px!important}.topbar-logo-img{width:108px!important;height:42px!important}.focused-topbar{padding-left:188px!important}.focused-topbar .mobile-menu-button + .topbar-logo-link{left:62px!important}.hero-logo{width:min(310px,84vw)!important}.premium-logo img{width:min(420px,88vw)!important}.report-official-logo{width:136px}.report .media-hero{flex-wrap:wrap}.loading-logo{width:min(330px,82vw)}}
@media (max-width:560px){.focused-topbar{padding-left:148px!important}.topbar-logo-link{width:92px!important}.topbar-logo-img{width:84px!important}.premium-logo img{width:min(340px,86vw)!important}.hero-logo{width:min(280px,86vw)!important}}
/* Keep the expanded sidebar usable after the larger official wordmark. */
.sidebar{display:flex!important;flex-direction:column!important;max-height:100vh!important}.brand{flex:0 0 auto!important}.sidebar nav{flex:1 1 auto!important;min-height:0!important;max-height:calc(100vh - 170px)!important;overflow-y:auto!important;overflow-x:hidden!important;scrollbar-width:thin;scrollbar-color:#ffffff55 transparent}.sidebar-footer-actions{flex:0 0 auto!important}.sidebar nav::-webkit-scrollbar{width:6px}.sidebar nav::-webkit-scrollbar-thumb{background:#ffffff55;border-radius:999px}
/* Elegant login introduction section */
.login-introduction{position:relative;z-index:1;margin-top:clamp(18px,3vw,30px);max-width:760px;padding:clamp(18px,2.4vw,28px);border:1px solid color-mix(in srgb,var(--brand) 16%,#ffffff 72%);border-radius:30px;background:linear-gradient(135deg,rgba(255,255,255,.78),rgba(255,255,255,.48));box-shadow:0 24px 70px rgba(15,23,42,.11),inset 0 1px 0 rgba(255,255,255,.76);backdrop-filter:blur(18px);color:#102033}.login-introduction:before{content:"";position:absolute;inset:0 auto auto 0;width:7px;height:100%;border-radius:30px 0 0 30px;background:linear-gradient(180deg,var(--brand),var(--brand2),var(--accent));opacity:.95}.intro-heading-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}.intro-icon{display:grid;place-items:center;flex:0 0 auto;width:46px;height:46px;border-radius:17px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;box-shadow:0 16px 34px color-mix(in srgb,var(--brand) 28%,transparent);font-size:1.25rem}.intro-eyebrow{display:block;margin-bottom:4px;color:var(--brand-strong);font-size:.78rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.login-introduction h2{margin:0;color:#0f172a;font-size:clamp(1.28rem,2.4vw,2rem);line-height:1.05;letter-spacing:-.045em}.login-introduction p{margin:10px 0 0;max-width:68ch;color:#334155;font-size:clamp(.94rem,1.2vw,1.03rem);line-height:1.58}.intro-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:16px 0 4px}.intro-feature-grid div{display:flex;align-items:center;gap:10px;min-height:48px;padding:10px 12px;border-radius:18px;background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(239,246,255,.72));border:1px solid rgba(226,232,240,.88);box-shadow:0 10px 24px rgba(15,23,42,.07)}.intro-feature-grid div:last-child{grid-column:1 / -1}.intro-feature-grid span{display:grid;place-items:center;flex:0 0 auto;width:30px;height:30px;border-radius:12px;background:color-mix(in srgb,var(--brand) 11%,#ffffff);font-size:1rem}.intro-feature-grid strong{font-size:.9rem;line-height:1.22;color:#172033}.intro-tagline{display:inline-flex;align-items:center;margin-top:16px!important;padding:10px 14px;border-radius:999px;background:linear-gradient(135deg,color-mix(in srgb,var(--brand) 14%,#ffffff),color-mix(in srgb,var(--accent) 12%,#ffffff));color:var(--brand-strong)!important;font-weight:950;letter-spacing:-.015em}html[data-theme="dark"] .login-introduction{background:linear-gradient(135deg,rgba(15,29,49,.82),rgba(17,28,46,.58));border-color:#ffffff1c;color:#e5eefc;box-shadow:0 24px 70px rgba(0,0,0,.38),inset 0 1px 0 rgba(255,255,255,.08)}html[data-theme="dark"] .login-introduction h2{color:#f8fafc}html[data-theme="dark"] .login-introduction p{color:#cbd5e1}html[data-theme="dark"] .intro-feature-grid div{background:linear-gradient(135deg,rgba(15,29,49,.92),rgba(30,41,59,.76));border-color:#ffffff14}html[data-theme="dark"] .intro-feature-grid strong{color:#e5eefc}html[data-theme="dark"] .intro-feature-grid span{background:rgba(45,212,191,.12)}html[data-theme="dark"] .intro-tagline{background:linear-gradient(135deg,rgba(45,212,191,.14),rgba(251,191,36,.12));color:#99f6e4!important}@media (min-width:1061px){.auth-refresh.splash-screen{align-items:start}.auth-hero-panel{align-self:stretch}.login-introduction{max-height:52vh;overflow:auto;scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--brand) 35%,transparent) transparent}.login-introduction::-webkit-scrollbar{width:6px}.login-introduction::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--brand) 35%,transparent);border-radius:999px}}@media (max-width:1060px){.login-introduction{max-width:none}.intro-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.login-introduction{padding:18px;border-radius:24px}.intro-heading-row{align-items:flex-start}.intro-icon{width:40px;height:40px;border-radius:15px}.intro-feature-grid{grid-template-columns:1fr}.intro-feature-grid div:last-child{grid-column:auto}.login-introduction p{font-size:.94rem;line-height:1.52}.intro-tagline{display:flex;border-radius:20px;line-height:1.25}}

/* Cleaner text-free login splash panel */
.clean-login-visual{
  display:flex;
  min-height:clamp(360px,62vh,620px);
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:clamp(18px,3vw,30px);
  text-align:center;
}
.clean-login-visual .login-brand{
  position:relative;
  z-index:2;
  display:inline-grid;
  place-items:center;
  margin:0;
  padding:clamp(12px,2vw,20px);
  border-radius:34px;
  background:linear-gradient(135deg,rgba(255,255,255,.68),rgba(255,255,255,.34));
  border:1px solid rgba(255,255,255,.76);
  box-shadow:0 26px 72px rgba(15,23,42,.12),inset 0 1px 0 rgba(255,255,255,.86);
  backdrop-filter:blur(18px);
}
.clean-login-visual .transparent-login-logo img{
  width:min(520px,70vw)!important;
}
.login-visual-stack{
  position:relative;
  z-index:1;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
  width:min(420px,72vw);
}
.visual-pill{
  display:block;
  height:10px;
  border-radius:999px;
  box-shadow:0 12px 28px rgba(15,23,42,.11);
}
.visual-pill-blue{width:42%;background:linear-gradient(90deg,#2563eb,#06b6d4)}
.visual-pill-gold{width:24%;background:linear-gradient(90deg,#f59e0b,#facc15)}
.visual-pill-green{width:34%;background:linear-gradient(90deg,#0f766e,#22c55e)}
html[data-theme="dark"] .clean-login-visual .login-brand{
  background:linear-gradient(135deg,rgba(15,23,42,.54),rgba(15,23,42,.30));
  border-color:rgba(255,255,255,.14);
}
@media (max-width:1060px){
  .clean-login-visual{min-height:auto;padding:clamp(26px,6vw,46px)!important}
}
@media (max-width:560px){
  .clean-login-visual .transparent-login-logo img{width:min(320px,82vw)!important}
  .login-visual-stack{width:min(300px,78vw)}
}

/* Responsive Lekòl360 login introduction card */
.clean-login-visual{
  align-items:stretch;
  justify-content:center;
  text-align:left;
  min-height:auto;
}
.clean-login-visual .login-brand,
.clean-login-visual .login-visual-stack{
  align-self:center;
}
.lekol-intro-card{
  align-self:center;
  width:min(760px,100%);
  margin-top:clamp(14px,2.5vw,24px)!important;
  padding:clamp(18px,2.2vw,26px)!important;
  border-radius:30px!important;
  background:
    linear-gradient(135deg,rgba(255,255,255,.86),rgba(255,255,255,.56)),
    radial-gradient(circle at 92% 8%,rgba(37,99,235,.14),transparent 14rem)!important;
  border:1px solid color-mix(in srgb,var(--brand) 18%,#ffffff 70%)!important;
  box-shadow:0 24px 70px rgba(15,23,42,.12),inset 0 1px 0 rgba(255,255,255,.82)!important;
  backdrop-filter:blur(18px);
}
.lekol-intro-card .intro-heading-row{
  align-items:center;
  margin-bottom:clamp(10px,1.6vw,14px);
}
.lekol-intro-card .intro-icon{
  background:linear-gradient(135deg,#2563eb,#0f766e 58%,#f59e0b)!important;
}
.lekol-intro-card .intro-eyebrow{
  color:var(--brand-strong);
}
.lekol-intro-card h2{
  font-size:clamp(1.32rem,2.2vw,1.95rem)!important;
}
.lekol-intro-card p{
  font-size:clamp(.92rem,1vw,1rem)!important;
  line-height:1.56!important;
}
.intro-list-block{
  margin:clamp(12px,1.8vw,18px) 0;
}
.lekol-intro-card .intro-list-title{
  margin:0 0 10px!important;
  color:#0f172a;
  font-weight:850;
}
.lekol-intro-card .intro-feature-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px;
  margin:0!important;
}
.lekol-intro-card .intro-feature-grid div{
  min-height:44px;
  padding:9px 11px;
  border-radius:17px;
  background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(239,246,255,.74));
}
.lekol-intro-card .intro-feature-grid div:last-child{
  grid-column:1 / -1;
}
.lekol-intro-card .intro-feature-grid strong{
  font-size:.9rem;
  line-height:1.22;
}
.lekol-intro-card .intro-tagline{
  display:inline-flex;
  margin-top:14px!important;
  padding:10px 13px;
  border-radius:999px;
  color:#fff!important;
  font-weight:900;
  letter-spacing:-.01em;
  background:linear-gradient(135deg,#0f766e,#2563eb 58%,#7c3aed);
  box-shadow:0 14px 32px color-mix(in srgb,var(--brand) 22%,transparent);
}
html[data-theme="dark"] .lekol-intro-card{
  background:linear-gradient(135deg,rgba(15,23,42,.76),rgba(15,23,42,.50))!important;
  border-color:rgba(255,255,255,.16)!important;
  color:#e5eefc!important;
}
html[data-theme="dark"] .lekol-intro-card h2,
html[data-theme="dark"] .lekol-intro-card .intro-list-title{color:#f8fafc!important}
html[data-theme="dark"] .lekol-intro-card p{color:#cbd5e1!important}
html[data-theme="dark"] .lekol-intro-card .intro-feature-grid div{
  background:linear-gradient(135deg,rgba(30,41,59,.86),rgba(15,23,42,.72));
  border-color:rgba(255,255,255,.12);
}
@media (max-width:1060px){
  .lekol-intro-card{width:min(820px,100%)}
}
@media (max-width:780px){
  .lekol-intro-card{border-radius:24px!important}
  .lekol-intro-card .intro-feature-grid{grid-template-columns:1fr}
  .lekol-intro-card .intro-feature-grid div:last-child{grid-column:auto}
}
@media (max-width:560px){
  .clean-login-visual{padding:18px!important;gap:14px}
  .lekol-intro-card{padding:16px!important;border-radius:22px!important}
  .lekol-intro-card .intro-heading-row{align-items:flex-start;gap:10px}
  .lekol-intro-card .intro-icon{width:40px;height:40px;border-radius:14px}
  .lekol-intro-card .intro-tagline{display:flex;border-radius:18px;text-align:center;justify-content:center}
}

/* Prevent the richer login introduction from being clipped on shorter screens */
.login-page.splash-screen,
.login-page.auth-refresh{
  overflow-x:hidden!important;
  overflow-y:auto!important;
  align-items:start!important;
}
.login-page .clean-login-visual{
  padding:clamp(20px,3vw,34px)!important;
}
.login-page .clean-login-visual .transparent-login-logo img{
  width:min(420px,62vw)!important;
}
.login-page .lekol-intro-card{
  padding:clamp(16px,1.8vw,22px)!important;
}
.login-page .lekol-intro-card p{
  margin-top:8px!important;
}
.login-page .lekol-intro-card .intro-feature-grid div{
  min-height:40px;
  padding:8px 10px;
}
.login-page .lekol-intro-card .intro-tagline{
  margin-top:10px!important;
}
@media (max-width:780px){
  .login-page.splash-screen,.login-page.auth-refresh{align-items:stretch!important}
}
@media (max-width:560px){
  .login-page .clean-login-visual .transparent-login-logo img{width:min(300px,80vw)!important}
}

/* Compact two-column intro layout for desktop login */
.lekol-intro-card .intro-content-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,.92fr);
  gap:clamp(12px,1.8vw,18px);
  align-items:start;
}
.lekol-intro-card .intro-copy p:first-child{margin-top:0!important}
.lekol-intro-card .intro-list-block{margin:0!important}
.lekol-intro-card .intro-feature-grid{
  grid-template-columns:1fr!important;
  gap:7px!important;
}
.lekol-intro-card .intro-feature-grid div,
.login-page .lekol-intro-card .intro-feature-grid div{
  min-height:34px!important;
  padding:7px 9px!important;
  border-radius:14px!important;
}
.lekol-intro-card .intro-feature-grid span{
  width:26px!important;
  height:26px!important;
  border-radius:10px!important;
}
.lekol-intro-card .intro-feature-grid strong{font-size:.82rem!important}
.login-page .clean-login-visual .transparent-login-logo img{width:min(340px,52vw)!important}
.login-page .login-visual-stack{width:min(330px,56vw)}
.login-page .visual-pill{height:8px}
@media (max-width:1240px){
  .lekol-intro-card .intro-content-grid{grid-template-columns:1fr}
  .lekol-intro-card .intro-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
}
@media (max-width:780px){
  .lekol-intro-card .intro-content-grid{grid-template-columns:1fr}
  .lekol-intro-card .intro-feature-grid{grid-template-columns:1fr!important}
}

/* Full-width login intro section below the portal choices to prevent overcrowding */
.login-page > .lekol-intro-card{
  grid-column:1 / -1;
  width:min(1120px,100%);
  max-width:1120px;
  justify-self:center;
  margin:clamp(6px,1vw,12px) auto 0!important;
}
.login-page > .lekol-intro-card .intro-content-grid{
  grid-template-columns:minmax(0,1fr) minmax(300px,.78fr);
}
.login-page > .lekol-intro-card .intro-feature-grid{
  grid-template-columns:1fr!important;
}
.login-page > .clean-login-visual{
  min-height:clamp(250px,38vh,360px)!important;
}
.login-page > .clean-login-visual .transparent-login-logo img{
  width:min(380px,52vw)!important;
}
@media (max-width:1060px){
  .login-page > .lekol-intro-card .intro-content-grid{grid-template-columns:1fr}
  .login-page > .lekol-intro-card .intro-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
}
@media (max-width:780px){
  .login-page > .lekol-intro-card .intro-feature-grid{grid-template-columns:1fr!important}
}

/* Let the full intro copy expand naturally instead of scrolling/clipping inside the card */
.login-page > .lekol-intro-card,
.login-page .lekol-intro-card{
  height:auto!important;
  max-height:none!important;
  overflow:visible!important;
}
.login-page > .lekol-intro-card{
  padding-bottom:clamp(22px,2.4vw,30px)!important;
}

/* Rearranged premium split login layout: intro integrated with brand panel */
.login-page.splash-screen,
.login-page.auth-refresh{
  grid-template-columns:minmax(0,1.32fr) minmax(360px,470px)!important;
  align-items:center!important;
  gap:clamp(22px,4vw,46px)!important;
  padding:clamp(20px,3.8vw,56px)!important;
  overflow-x:hidden!important;
  overflow-y:auto!important;
}
.login-page > .clean-login-visual{
  display:flex!important;
  flex-direction:column!important;
  align-items:stretch!important;
  justify-content:center!important;
  gap:clamp(12px,1.8vw,18px)!important;
  min-height:auto!important;
  padding:clamp(22px,3vw,34px)!important;
  text-align:left!important;
}
.login-page > .clean-login-visual:after{
  opacity:.72;
}
.login-page > .clean-login-visual .login-brand,
.login-page > .clean-login-visual .login-visual-stack{
  align-self:flex-start!important;
}
.login-page > .clean-login-visual .login-brand{
  padding:clamp(8px,1.2vw,13px)!important;
  border-radius:28px!important;
}
.login-page > .clean-login-visual .transparent-login-logo img{
  width:min(330px,44vw)!important;
}
.login-page > .clean-login-visual .login-visual-stack{
  width:min(310px,42vw)!important;
  margin-left:clamp(10px,1.5vw,18px);
}
.login-page > .clean-login-visual .visual-pill{
  height:8px!important;
}
.login-page > .clean-login-visual .lekol-intro-card{
  width:100%!important;
  max-width:none!important;
  height:auto!important;
  max-height:none!important;
  overflow:visible!important;
  margin:0!important;
  padding:clamp(17px,2vw,24px)!important;
  border-radius:28px!important;
}
.login-page > .clean-login-visual .lekol-intro-card .intro-content-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(260px,.78fr)!important;
  gap:clamp(12px,1.7vw,18px)!important;
  align-items:start!important;
}
.login-page > .clean-login-visual .lekol-intro-card .intro-heading-row{
  margin-bottom:12px!important;
}
.login-page > .clean-login-visual .lekol-intro-card p{
  margin-top:7px!important;
  font-size:clamp(.86rem,.95vw,.96rem)!important;
  line-height:1.48!important;
}
.login-page > .clean-login-visual .intro-list-title{
  margin:0 0 8px!important;
}
.login-page > .clean-login-visual .intro-feature-grid{
  grid-template-columns:1fr!important;
  gap:7px!important;
}
.login-page > .clean-login-visual .intro-feature-grid div{
  min-height:34px!important;
  padding:7px 9px!important;
  border-radius:14px!important;
}
.login-page > .clean-login-visual .intro-feature-grid span{
  width:25px!important;
  height:25px!important;
  border-radius:10px!important;
}
.login-page > .clean-login-visual .intro-feature-grid strong{
  font-size:.8rem!important;
  line-height:1.16!important;
}
.login-page > .clean-login-visual .intro-tagline{
  margin-top:12px!important;
  padding:9px 12px!important;
  font-size:.9rem!important;
}
.login-page > .refined-portal-card{
  justify-self:stretch!important;
  align-self:center!important;
  position:relative!important;
  z-index:2!important;
}
@media (max-width:1180px){
  .login-page > .clean-login-visual .lekol-intro-card .intro-content-grid{grid-template-columns:1fr!important}
  .login-page > .clean-login-visual .intro-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
}
@media (max-width:1060px){
  .login-page.splash-screen,
  .login-page.auth-refresh{
    grid-template-columns:1fr!important;
    align-items:stretch!important;
  }
  .login-page > .refined-portal-card{max-width:none!important;order:1!important}
  .login-page > .clean-login-visual{order:2!important}
  .login-page > .clean-login-visual .login-brand,
  .login-page > .clean-login-visual .login-visual-stack{align-self:center!important;margin-left:0!important}
  .login-page > .clean-login-visual .lekol-intro-card .intro-content-grid{grid-template-columns:minmax(0,1fr) minmax(260px,.82fr)!important}
}
@media (max-width:780px){
  .login-page.splash-screen,
  .login-page.auth-refresh{padding:16px!important;gap:16px!important}
  .login-page > .clean-login-visual{padding:18px!important;border-radius:28px!important}
  .login-page > .clean-login-visual .lekol-intro-card .intro-content-grid{grid-template-columns:1fr!important}
  .login-page > .clean-login-visual .intro-feature-grid{grid-template-columns:1fr!important}
}
@media (max-width:560px){
  .login-page > .clean-login-visual .transparent-login-logo img{width:min(300px,78vw)!important}
  .login-page > .clean-login-visual .login-visual-stack{width:min(280px,74vw)!important}
}

/* Final balanced split login arrangement */
.login-page.splash-screen,
.login-page.auth-refresh{
  width:100%!important;
  grid-template-columns:minmax(540px,1fr) minmax(330px,390px)!important;
  gap:clamp(18px,2.5vw,28px)!important;
  padding:clamp(18px,2.4vw,30px)!important;
  align-items:start!important;
}
.login-page > .clean-login-visual{
  min-width:0!important;
  max-width:none!important;
  padding:clamp(18px,2.2vw,28px)!important;
  gap:12px!important;
}
.login-page > .refined-portal-card{
  width:100%!important;
  max-width:390px!important;
  padding:clamp(24px,2.6vw,32px)!important;
  margin-top:clamp(72px,8vw,106px)!important;
  justify-self:stretch!important;
}
.login-page > .clean-login-visual .transparent-login-logo img{
  width:min(330px,38vw)!important;
}
.login-page > .clean-login-visual .login-visual-stack{
  width:min(300px,34vw)!important;
}
.login-page > .clean-login-visual .lekol-intro-card{
  width:100%!important;
  padding:clamp(16px,1.8vw,22px)!important;
}
.login-page > .clean-login-visual .lekol-intro-card .intro-content-grid{
  grid-template-columns:1fr!important;
  gap:10px!important;
}
.login-page > .clean-login-visual .intro-copy{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:10px!important;
}
.login-page > .clean-login-visual .intro-copy p{
  margin:0!important;
  padding:11px 12px;
  border-radius:16px;
  background:rgba(255,255,255,.56);
  border:1px solid rgba(226,232,240,.72);
  font-size:.82rem!important;
  line-height:1.42!important;
}
.login-page > .clean-login-visual .intro-list-title{
  font-size:.86rem!important;
  margin:2px 0 8px!important;
}
.login-page > .clean-login-visual .intro-feature-grid{
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  gap:7px!important;
}
.login-page > .clean-login-visual .intro-feature-grid div{
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  min-height:82px!important;
  gap:6px!important;
  padding:9px!important;
}
.login-page > .clean-login-visual .intro-feature-grid span{
  width:28px!important;
  height:28px!important;
}
.login-page > .clean-login-visual .intro-feature-grid strong{
  font-size:.76rem!important;
  line-height:1.12!important;
}
.login-page > .clean-login-visual .intro-tagline{
  font-size:.86rem!important;
  margin-top:10px!important;
}
html[data-theme="dark"] .login-page > .clean-login-visual .intro-copy p{
  background:rgba(30,41,59,.68);
  border-color:rgba(255,255,255,.12);
}
@media (max-width:1180px){
  .login-page.splash-screen,
  .login-page.auth-refresh{grid-template-columns:1fr!important;align-items:stretch!important}
  .login-page > .refined-portal-card{order:1!important;max-width:none!important;margin-top:0!important}
  .login-page > .clean-login-visual{order:2!important}
  .login-page > .clean-login-visual .intro-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .login-page > .clean-login-visual .intro-feature-grid div{min-height:54px!important;flex-direction:row!important;align-items:center!important}
}
@media (max-width:780px){
  .login-page > .clean-login-visual .intro-copy{grid-template-columns:1fr!important}
  .login-page > .clean-login-visual .intro-feature-grid{grid-template-columns:1fr!important}
}

/* Readability polish for the integrated login introduction */
.login-page > .clean-login-visual{
  overflow:visible!important;
}
.login-page > .clean-login-visual .intro-copy{
  display:block!important;
}
.login-page > .clean-login-visual .intro-copy p{
  margin:8px 0 0!important;
  padding:0!important;
  border:0!important;
  background:transparent!important;
  font-size:clamp(.9rem,1vw,.98rem)!important;
  line-height:1.52!important;
}
.login-page > .clean-login-visual .intro-feature-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:8px!important;
}
.login-page > .clean-login-visual .intro-feature-grid div{
  flex-direction:row!important;
  align-items:center!important;
  min-height:48px!important;
  padding:9px 10px!important;
}
.login-page > .clean-login-visual .intro-feature-grid div:last-child{
  grid-column:1 / -1!important;
}
.login-page > .clean-login-visual .intro-feature-grid strong{
  font-size:.83rem!important;
  line-height:1.18!important;
}

/* Authenticated shell: keep branding logo only in the sidebar */
.sidebar .logo-only-brand{
  justify-content:center!important;
  align-items:center!important;
  min-height:76px!important;
  padding:8px!important;
}
.sidebar .logo-only-brand .brand-logo-img{
  display:block!important;
  width:min(150px,100%)!important;
  max-height:64px!important;
  height:auto!important;
  object-fit:contain!important;
}
.sidebar-collapsed .sidebar .logo-only-brand .brand-logo-img{
  width:58px!important;
  height:58px!important;
}
.focused-topbar{
  padding-left:clamp(18px,3vw,34px)!important;
  padding-right:clamp(18px,3vw,34px)!important;
}
.focused-topbar .topbar-title{
  grid-column:auto!important;
  order:0!important;
}
@media (max-width:780px){
  .focused-topbar{
    padding:14px 16px 14px 72px!important;
  }
}
@media (max-width:560px){
  .focused-topbar{
    padding-left:72px!important;
  }
}


/* 2026 brand-aligned Lekòl360 palette, logo, footer, login, and sidebar final pass */
:root{
  --lekol-navy:#003b79;
  --lekol-blue:#0787d8;
  --lekol-sky:#04a6df;
  --lekol-green:#6cc42a;
  --lekol-lime:#9bd21b;
  --lekol-orange:#ff9f05;
  --lekol-gold:#ffc20a;
  --brand:var(--lekol-navy);
  --brand-strong:#002b5d;
  --brand2:var(--lekol-blue);
  --brand3:var(--lekol-green);
  --accent:var(--lekol-orange);
  --accent2:var(--lekol-gold);
  --bg:#f5fbff;
  --bg2:#f6fff0;
  --panel:#fffffff2;
  --panel-solid:#ffffff;
  --ink:#08223f;
  --muted:#5e7189;
  --line:#d9e8f5;
  --sidebar:#002b5d;
  --sidebar2:#03172f;
  --sideText:#f2fbff;
  --shadow:0 24px 70px rgba(0,59,121,.15);
  --soft-shadow:0 14px 38px rgba(7,135,216,.18);
}
html[data-theme="dark"]{
  --bg:#03101f;
  --bg2:#061a16;
  --panel:#0a1b2fee;
  --panel-solid:#0e2035;
  --ink:#f1f8ff;
  --muted:#b7c8dc;
  --line:#25435f;
  --brand:#67c7ff;
  --brand-strong:#a7e0ff;
  --brand2:#0787d8;
  --brand3:#8ee15a;
  --accent:#ffb43b;
  --accent2:#ffd76a;
  --sidebar:#021326;
  --sidebar2:#020a14;
  --sideText:#f5fbff;
}
body{
  background:
    radial-gradient(circle at 8% 8%,rgba(7,135,216,.20),transparent 28rem),
    radial-gradient(circle at 94% 12%,rgba(255,159,5,.18),transparent 24rem),
    radial-gradient(circle at 78% 90%,rgba(108,196,42,.16),transparent 26rem),
    linear-gradient(135deg,var(--bg),var(--bg2))!important;
}
.primary,button[type="submit"]{background:linear-gradient(135deg,var(--lekol-navy),var(--lekol-blue) 58%,var(--lekol-green))!important;box-shadow:0 14px 30px rgba(7,135,216,.26)!important}.primary:hover,button[type="submit"]:hover{filter:saturate(1.08) brightness(1.03);transform:translateY(-1px)}
.sidebar{
  width:260px!important;
  padding:14px 12px!important;
  gap:8px!important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.11),rgba(255,255,255,.04) 42%,transparent 72%),
    radial-gradient(circle at 16% 8%,rgba(7,135,216,.46),transparent 15rem),
    radial-gradient(circle at 108% 26%,rgba(108,196,42,.34),transparent 15rem),
    radial-gradient(circle at 50% 100%,rgba(255,159,5,.20),transparent 15rem),
    linear-gradient(180deg,var(--sidebar),var(--sidebar2))!important;
  border-right:1px solid rgba(255,255,255,.14)!important;
  box-shadow:18px 0 50px rgba(2,6,23,.32)!important;
}
.main{margin-left:260px!important}.sidebar-collapsed .sidebar{width:84px!important}.sidebar-collapsed .main{margin-left:84px!important}
.sidebar .logo-only-brand{
  min-height:74px!important;
  border-radius:22px!important;
  padding:8px!important;
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(242,249,255,.88))!important;
  border:1px solid rgba(255,255,255,.72)!important;
  box-shadow:0 18px 42px rgba(0,24,54,.28),inset 0 1px 0 rgba(255,255,255,.9)!important;
}
.sidebar .logo-only-brand:hover,.sidebar .logo-only-brand:focus-visible{transform:translateY(-2px)!important;box-shadow:0 22px 50px rgba(0,24,54,.34),0 0 0 4px rgba(255,194,10,.16)!important;outline:none}
.sidebar .logo-only-brand .brand-logo-img{width:164px!important;max-height:58px!important;filter:none!important}.sidebar-collapsed .sidebar .logo-only-brand{min-height:62px!important;padding:6px!important;border-radius:18px!important}.sidebar-collapsed .sidebar .logo-only-brand .brand-logo-img{width:54px!important;height:54px!important;object-fit:contain!important}
.sidebar nav{gap:4px!important;padding:4px 1px 10px!important}.sidebar nav a{min-height:39px!important;padding:6px 8px!important;border-radius:14px!important;gap:8px!important;font-size:.86rem!important;line-height:1.1!important;color:#eef8ff!important;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.025))!important;border:1px solid transparent!important}.sidebar nav a:hover,.sidebar nav a:focus-visible,.sidebar nav a.is-active{background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.08))!important;border-color:rgba(255,255,255,.22)!important;transform:translateX(2px)!important;box-shadow:0 12px 26px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.14)!important;outline:none}.sidebar nav svg{width:28px!important;height:28px!important;padding:6px!important;border-radius:11px!important}.sidebar nav a:nth-child(1){--icon-c1:#0787d8;--icon-c2:#003b79;--icon-glow:rgba(7,135,216,.30)}.sidebar nav a:nth-child(2){--icon-c1:#6cc42a;--icon-c2:#0787d8;--icon-glow:rgba(108,196,42,.30)}.sidebar nav a:nth-child(3){--icon-c1:#ff9f05;--icon-c2:#ffc20a;--icon-glow:rgba(255,159,5,.30)}.sidebar nav a:nth-child(4){--icon-c1:#003b79;--icon-c2:#0787d8;--icon-glow:rgba(0,59,121,.30)}.sidebar nav a:nth-child(5){--icon-c1:#0787d8;--icon-c2:#6cc42a;--icon-glow:rgba(7,135,216,.30)}.sidebar nav a:nth-child(6){--icon-c1:#ff9f05;--icon-c2:#003b79;--icon-glow:rgba(255,159,5,.30)}.sidebar nav a:nth-child(7){--icon-c1:#6cc42a;--icon-c2:#003b79;--icon-glow:rgba(108,196,42,.30)}.sidebar nav a:nth-child(8){--icon-c1:#003b79;--icon-c2:#ff9f05;--icon-glow:rgba(0,59,121,.30)}.sidebar nav a:nth-child(9){--icon-c1:#0787d8;--icon-c2:#ffc20a;--icon-glow:rgba(7,135,216,.30)}.sidebar nav a:nth-child(10){--icon-c1:#003b79;--icon-c2:#6cc42a;--icon-glow:rgba(0,59,121,.30)}
.compact-sidebar-tools{gap:6px!important;padding-top:8px!important}.sidebar-tool{height:44px!important;min-height:44px!important;border-radius:14px!important;background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.07))!important}.sidebar-tool:hover,.sidebar-tool:focus-visible{background:linear-gradient(135deg,rgba(255,255,255,.25),rgba(255,255,255,.11))!important}.sidebar-collapsed .sidebar-tool{width:48px!important;height:44px!important}.sidebar-collapsed .sidebar nav a{width:48px!important;height:42px!important}.sidebar-collapsed .sidebar nav svg{width:30px!important;height:30px!important}
.focused-topbar{background:linear-gradient(135deg,color-mix(in srgb,var(--panel-solid) 92%,transparent),color-mix(in srgb,var(--brand2) 8%,var(--panel-solid)) 56%,color-mix(in srgb,var(--brand3) 5%,var(--panel-solid)))!important;border-color:color-mix(in srgb,var(--brand2) 18%,var(--line))!important}.panel,.mini-card,.stats>div,.dashboard-search{border-color:color-mix(in srgb,var(--brand2) 14%,var(--line))!important}.module-hero,.entity-hero,.lekol360-hero{background:radial-gradient(circle at 88% 14%,rgba(255,194,10,.44),transparent 15rem),radial-gradient(circle at 78% 84%,rgba(108,196,42,.34),transparent 16rem),linear-gradient(135deg,var(--lekol-navy),var(--lekol-blue) 58%,#0b5fac)!important}
.site-footer{display:flex!important;align-items:center!important;justify-content:center!important;gap:12px!important;flex-wrap:wrap!important;padding:18px!important;margin-top:24px!important;border-top:1px solid color-mix(in srgb,var(--brand2) 14%,var(--line));color:var(--muted)!important}.footer-logo{width:112px;height:auto;padding:5px 8px;border-radius:14px;background:linear-gradient(135deg,#fff,#f3faff);border:1px solid color-mix(in srgb,var(--brand2) 12%,#fff);box-shadow:0 10px 24px rgba(0,59,121,.10)}html[data-theme="dark"] .footer-logo{background:linear-gradient(135deg,#f8fbff,#eaf5ff);box-shadow:0 10px 26px rgba(0,0,0,.36)}
.login-page.splash-screen,.login-page.auth-refresh{grid-template-columns:minmax(300px,.9fr) minmax(340px,430px)!important;align-items:start!important;gap:clamp(18px,3vw,34px)!important;background:radial-gradient(circle at 10% 12%,rgba(7,135,216,.18),transparent 24rem),radial-gradient(circle at 90% 12%,rgba(255,159,5,.20),transparent 22rem),radial-gradient(circle at 78% 86%,rgba(108,196,42,.16),transparent 24rem),linear-gradient(135deg,#f8fbff,#f6fff0 48%,#edf8ff)!important}.login-page > .clean-login-visual{min-height:0!important;align-self:start!important;justify-content:flex-start!important;text-align:center!important;padding:clamp(20px,3vw,32px)!important}.login-page > .clean-login-visual .login-brand{align-self:center!important;background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(242,249,255,.78))!important;border:1px solid rgba(255,255,255,.78)!important;box-shadow:0 24px 62px rgba(0,59,121,.16),inset 0 1px 0 #fff!important}.login-page > .clean-login-visual .transparent-login-logo img{width:min(380px,44vw)!important;filter:none!important}.login-page > .clean-login-visual .login-visual-stack{align-self:center!important;width:min(320px,42vw)!important;margin-left:0!important}.login-page > .refined-portal-card{margin-top:clamp(18px,3vw,34px)!important;max-width:430px!important}.login-page > .lekol-intro-card{grid-column:2!important;align-self:start!important;width:100%!important;max-width:430px!important;margin:0!important;justify-self:stretch!important;padding:clamp(18px,2vw,24px)!important;border-radius:28px!important}.login-page > .lekol-intro-card .intro-content-grid{grid-template-columns:1fr!important}.login-page > .lekol-intro-card .intro-feature-grid{grid-template-columns:1fr!important}.login-page > .lekol-intro-card .intro-feature-grid div:last-child{grid-column:auto!important}.login-page > .lekol-intro-card .intro-copy p{margin:8px 0 0!important;padding:0!important;background:transparent!important;border:0!important}.login-page > .lekol-intro-card .intro-tagline{border-radius:18px!important;white-space:normal!important}html[data-theme="dark"] .login-page.splash-screen,html[data-theme="dark"] .login-page.auth-refresh{background:radial-gradient(circle at 10% 12%,rgba(7,135,216,.14),transparent 24rem),radial-gradient(circle at 90% 12%,rgba(255,159,5,.12),transparent 22rem),radial-gradient(circle at 78% 86%,rgba(108,196,42,.10),transparent 24rem),linear-gradient(135deg,#03101f,#061a16)!important}html[data-theme="dark"] .login-page > .clean-login-visual .login-brand{background:linear-gradient(135deg,#f8fbff,#eaf5ff)!important;border-color:rgba(255,255,255,.24)!important;box-shadow:0 24px 64px rgba(0,0,0,.40)!important}
@media (max-width:1180px){.login-page.splash-screen,.login-page.auth-refresh{grid-template-columns:1fr!important}.login-page > .refined-portal-card{order:1!important;max-width:none!important;margin-top:0!important}.login-page > .clean-login-visual{order:2!important}.login-page > .lekol-intro-card{order:3!important;grid-column:1!important;max-width:none!important}.login-page > .clean-login-visual .transparent-login-logo img{width:min(360px,72vw)!important}.login-page > .clean-login-visual .login-visual-stack{width:min(320px,72vw)!important}}
@media (max-width:780px){.sidebar{transform:translateX(-105%)!important;width:min(302px,88vw)!important;z-index:40!important}.sidebar-collapsed .sidebar{width:min(302px,88vw)!important}body.sidebar-open .sidebar{transform:translateX(0)!important}.main,.sidebar-collapsed .main{margin-left:0!important;padding:16px!important}.focused-topbar{padding:14px 16px 14px 72px!important}.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(2,6,23,.62);z-index:35}body.sidebar-open .sidebar-backdrop{display:block}.sidebar .logo-only-brand .brand-logo-img{width:150px!important}.login-page.splash-screen,.login-page.auth-refresh{padding:16px!important}.site-footer{margin-top:18px!important}.footer-logo{width:96px}}
@media (max-width:560px){.login-page > .clean-login-visual .transparent-login-logo img{width:min(300px,82vw)!important}.login-page > .lekol-intro-card{padding:16px!important}.footer-logo{width:88px}.sidebar nav a{font-size:.84rem!important}}


/* Clean flat-color system refresh — flat, modern Lekòl360 UI */
:root{
  --lekol-blue-900:#123c69;
  --lekol-blue-700:#1f6fb2;
  --lekol-blue-600:#2d8bd3;
  --lekol-green-600:#74b843;
  --lekol-green-500:#8ac84b;
  --lekol-amber-500:#f4a62a;
  --lekol-surface:#ffffff;
  --lekol-surface-2:#f5f8fb;
  --lekol-surface-3:#edf4fa;
  --lekol-text:#17324d;
  --lekol-muted:#63778c;
  --lekol-border:#dce7f0;
  --brand:var(--lekol-blue-700);
  --brand-strong:var(--lekol-blue-900);
  --brand2:var(--lekol-blue-600);
  --brand3:var(--lekol-green-600);
  --accent:var(--lekol-amber-500);
  --accent2:var(--lekol-green-500);
  --bg:var(--lekol-surface-2);
  --bg2:var(--lekol-surface-2);
  --panel:#ffffff;
  --panel-solid:#ffffff;
  --ink:var(--lekol-text);
  --muted:var(--lekol-muted);
  --line:var(--lekol-border);
  --sidebar:var(--lekol-blue-900);
  --sidebar2:var(--lekol-blue-900);
  --sideText:#ffffff;
  --shadow:0 10px 24px rgba(18,60,105,.08);
  --soft-shadow:0 8px 18px rgba(31,111,178,.10);
}
html[data-theme="dark"]{
  --lekol-surface:#13263a;
  --lekol-surface-2:#0d1b2a;
  --lekol-surface-3:#182d42;
  --lekol-text:#eef6ff;
  --lekol-muted:#b7c6d6;
  --lekol-border:#29445e;
  --brand:#78b9e8;
  --brand-strong:#cbe8fb;
  --brand2:#2d8bd3;
  --brand3:#8ac84b;
  --accent:#f4a62a;
  --accent2:#74b843;
  --bg:#0d1b2a;
  --bg2:#0d1b2a;
  --panel:#13263a;
  --panel-solid:#13263a;
  --ink:#eef6ff;
  --muted:#b7c6d6;
  --line:#29445e;
  --sidebar:#0b1f33;
  --sidebar2:#0b1f33;
  --sideText:#ffffff;
  --shadow:0 10px 24px rgba(0,0,0,.24);
  --soft-shadow:0 8px 18px rgba(0,0,0,.18);
}
body,
.login-page.auth-refresh,
.login-page.splash-screen,
.app-loading-screen{
  background:var(--bg)!important;
}
.topbar,.focused-topbar,.panel,.mini-card,.stats>div,.dashboard-search,.login-card,.premium-auth-card,.login-splash-panel,.lekol-intro-card,.table-pagination{
  background:var(--panel)!important;
  border:1px solid var(--line)!important;
  box-shadow:var(--shadow)!important;
}
.sidebar{
  background:var(--sidebar)!important;
  border-right:1px solid rgba(255,255,255,.12)!important;
  box-shadow:none!important;
}
.sidebar:before,.module-hero:after,.lekol360-hero:after,.entity-hero:after,.login-splash-panel:after,.splash-orb{display:none!important}
.sidebar .logo-only-brand,
.login-page > .clean-login-visual .login-brand{
  background:#ffffff!important;
  border:1px solid #dce7f0!important;
  box-shadow:none!important;
}
.sidebar .logo-only-brand:hover,.sidebar .logo-only-brand:focus-visible{box-shadow:none!important;transform:translateY(-1px)!important}
.sidebar nav a{
  background:transparent!important;
  border:1px solid transparent!important;
  color:#eef6ff!important;
  box-shadow:none!important;
}
.sidebar nav a:hover,.sidebar nav a:focus-visible,.sidebar nav a.is-active{
  background:#1f6fb2!important;
  border-color:#2d8bd3!important;
  box-shadow:none!important;
  transform:none!important;
}
.sidebar nav svg{
  color:#ffffff!important;
  background:#2d8bd3!important;
  box-shadow:none!important;
}
.sidebar nav a:nth-child(3n+1) svg{background:#2d8bd3!important}
.sidebar nav a:nth-child(3n+2) svg{background:#74b843!important}
.sidebar nav a:nth-child(3n) svg{background:#f4a62a!important}
.sidebar-tool,
.sidebar-footer-actions .sidebar-toggle-button{
  background:#173f68!important;
  border:1px solid #2a5f91!important;
  box-shadow:none!important;
}
.sidebar-tool:hover,.sidebar-tool:focus-visible,.sidebar-footer-actions .sidebar-toggle-button:hover{
  background:#1f6fb2!important;
  box-shadow:none!important;
  transform:none!important;
}
.primary,button[type="submit"]{
  background:#1f6fb2!important;
  color:#ffffff!important;
  box-shadow:none!important;
}
.primary:hover,button[type="submit"]:hover{background:#123c69!important;filter:none!important;transform:none!important}.ghost,.theme-toggle{background:#edf4fa!important;color:#123c69!important;border:1px solid #dce7f0!important;box-shadow:none!important}html[data-theme="dark"] .ghost,html[data-theme="dark"] .theme-toggle{background:#182d42!important;color:#cbe8fb!important;border-color:#29445e!important}.danger,.logout-button{background:#fff1f1!important;color:#b4232a!important;border:1px solid #ffd4d4!important;box-shadow:none!important}html[data-theme="dark"] .danger,html[data-theme="dark"] .logout-button{background:#3b1720!important;color:#ffb4b9!important;border-color:#65303a!important}
.module-hero,.entity-hero,.lekol360-hero,.students-hero,.teachers-hero,.years-hero,.classes-hero,.grades-hero,.attendance-hero,.reports-hero,.import-hero,.schools-hero,.users-hero,.teachers-dashboard-hero{
  background:#1f6fb2!important;
  box-shadow:none!important;
}
.visual-pill-blue{background:#2d8bd3!important}.visual-pill-gold{background:#f4a62a!important}.visual-pill-green{background:#74b843!important}.intro-icon,.portal-icon{background:#1f6fb2!important;box-shadow:none!important}.portal-option:nth-child(2) .portal-icon{background:#74b843!important}.portal-option:nth-child(3) .portal-icon{background:#f4a62a!important}.portal-option,.portal-note,.intro-feature-grid div{background:var(--lekol-surface-2)!important;border:1px solid var(--line)!important;box-shadow:none!important}.portal-option:hover,.portal-option:focus-visible,.portal-option.is-selected{background:var(--lekol-surface-3)!important;border-color:var(--brand)!important;box-shadow:none!important;transform:none!important}
thead th{background:var(--lekol-surface-3)!important}.entity-table tr:hover td{background:var(--lekol-surface-2)!important}.chip{background:var(--lekol-surface-3)!important;color:var(--brand-strong)!important}.app-loading-screen .loading-logo,.brand-logo-img,.premium-logo img,.footer-logo{filter:none!important}
.site-footer{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:10px!important;
  padding:24px 18px!important;
  margin-top:28px!important;
  text-align:center!important;
  background:transparent!important;
  border-top:1px solid var(--line)!important;
  box-shadow:none!important;
  color:var(--muted)!important;
}
.footer-copyright{display:block!important;line-height:1.45!important}.site-footer a{color:var(--brand)!important;font-weight:700!important}.footer-logo{
  display:block!important;
  width:116px!important;
  height:auto!important;
  margin:0 auto!important;
  padding:6px 10px!important;
  border-radius:12px!important;
  background:#ffffff!important;
  border:1px solid var(--line)!important;
  box-shadow:none!important;
}
html[data-theme="dark"] .footer-logo{background:#ffffff!important;border-color:#dce7f0!important;box-shadow:none!important}
@media (max-width:780px){.site-footer{padding:22px 14px!important;gap:9px!important}.footer-logo{width:104px!important}}


/* Operator request: flat sky-blue color across the entire app */
:root{
  --sky-blue:#38bdf8;
  --sky-blue-dark:#0ea5e9;
  --sky-blue-soft:#e0f2fe;
  --sky-blue-border:#bae6fd;
  --sky-blue-ink:#075985;
  --brand:var(--sky-blue);
  --brand-strong:var(--sky-blue-ink);
  --brand2:var(--sky-blue);
  --brand3:var(--sky-blue);
  --accent:var(--sky-blue);
  --accent2:var(--sky-blue);
  --bg:#e0f2fe;
  --bg2:#e0f2fe;
  --panel:#ffffff;
  --panel-solid:#ffffff;
  --ink:#083344;
  --muted:#3f6575;
  --line:#bae6fd;
  --sidebar:#38bdf8;
  --sidebar2:#38bdf8;
  --sideText:#083344;
  --shadow:none;
  --soft-shadow:none;
}
html[data-theme="dark"]{
  --sky-blue:#38bdf8;
  --sky-blue-dark:#0ea5e9;
  --sky-blue-soft:#082f49;
  --sky-blue-border:#0ea5e9;
  --sky-blue-ink:#e0f2fe;
  --brand:var(--sky-blue);
  --brand-strong:#e0f2fe;
  --brand2:var(--sky-blue);
  --brand3:var(--sky-blue);
  --accent:var(--sky-blue);
  --accent2:var(--sky-blue);
  --bg:#082f49;
  --bg2:#082f49;
  --panel:#0b3b59;
  --panel-solid:#0b3b59;
  --ink:#f0f9ff;
  --muted:#c7e6f5;
  --line:#0ea5e9;
  --sidebar:#075985;
  --sidebar2:#075985;
  --sideText:#f0f9ff;
}
body,
.login-page.auth-refresh,
.login-page.splash-screen,
.app-loading-screen{
  background:#e0f2fe!important;
  background-image:none!important;
}
html[data-theme="dark"] body,
html[data-theme="dark"] .login-page.auth-refresh,
html[data-theme="dark"] .login-page.splash-screen,
html[data-theme="dark"] .app-loading-screen{
  background:#082f49!important;
  background-image:none!important;
}
.topbar,.focused-topbar,.panel,.mini-card,.stats>div,.dashboard-search,.login-card,.premium-auth-card,.login-splash-panel,.lekol-intro-card,.table-pagination,.portal-option,.portal-note,.intro-feature-grid div,input,select,textarea,thead th{
  background:#ffffff!important;
  background-image:none!important;
  border-color:#bae6fd!important;
  box-shadow:none!important;
}
html[data-theme="dark"] .topbar,html[data-theme="dark"] .focused-topbar,html[data-theme="dark"] .panel,html[data-theme="dark"] .mini-card,html[data-theme="dark"] .stats>div,html[data-theme="dark"] .dashboard-search,html[data-theme="dark"] .login-card,html[data-theme="dark"] .premium-auth-card,html[data-theme="dark"] .login-splash-panel,html[data-theme="dark"] .lekol-intro-card,html[data-theme="dark"] .table-pagination,html[data-theme="dark"] .portal-option,html[data-theme="dark"] .portal-note,html[data-theme="dark"] .intro-feature-grid div,html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea,html[data-theme="dark"] thead th{
  background:#0b3b59!important;
  background-image:none!important;
  border-color:#0ea5e9!important;
}
.sidebar,.module-hero,.entity-hero,.lekol360-hero,.students-hero,.teachers-hero,.years-hero,.classes-hero,.grades-hero,.attendance-hero,.reports-hero,.import-hero,.schools-hero,.users-hero,.teachers-dashboard-hero,
.primary,button[type="submit"],.intro-icon,.portal-icon,.visual-pill,.visual-pill-blue,.visual-pill-gold,.visual-pill-green{
  background:#38bdf8!important;
  background-image:none!important;
  color:#083344!important;
  box-shadow:none!important;
}
html[data-theme="dark"] .sidebar,html[data-theme="dark"] .module-hero,html[data-theme="dark"] .entity-hero,html[data-theme="dark"] .lekol360-hero,html[data-theme="dark"] .students-hero,html[data-theme="dark"] .teachers-hero,html[data-theme="dark"] .years-hero,html[data-theme="dark"] .classes-hero,html[data-theme="dark"] .grades-hero,html[data-theme="dark"] .attendance-hero,html[data-theme="dark"] .reports-hero,html[data-theme="dark"] .import-hero,html[data-theme="dark"] .schools-hero,html[data-theme="dark"] .users-hero,html[data-theme="dark"] .teachers-dashboard-hero,
html[data-theme="dark"] .primary,html[data-theme="dark"] button[type="submit"],html[data-theme="dark"] .intro-icon,html[data-theme="dark"] .portal-icon,html[data-theme="dark"] .visual-pill,html[data-theme="dark"] .visual-pill-blue,html[data-theme="dark"] .visual-pill-gold,html[data-theme="dark"] .visual-pill-green{
  background:#075985!important;
  background-image:none!important;
  color:#f0f9ff!important;
}
.sidebar nav a,.sidebar-tool,.sidebar-footer-actions .sidebar-toggle-button{
  background:#7dd3fc!important;
  background-image:none!important;
  border-color:#bae6fd!important;
  color:#083344!important;
  box-shadow:none!important;
}
.sidebar nav a:hover,.sidebar nav a:focus-visible,.sidebar nav a.is-active,.sidebar-tool:hover,.sidebar-tool:focus-visible,.sidebar-footer-actions .sidebar-toggle-button:hover{
  background:#0ea5e9!important;
  background-image:none!important;
  color:#ffffff!important;
  border-color:#0284c7!important;
  transform:none!important;
  box-shadow:none!important;
}
.sidebar nav svg,.sidebar nav a:nth-child(3n+1) svg,.sidebar nav a:nth-child(3n+2) svg,.sidebar nav a:nth-child(3n) svg{
  background:#0ea5e9!important;
  background-image:none!important;
  color:#ffffff!important;
  box-shadow:none!important;
}
.sidebar .logo-only-brand,.login-page > .clean-login-visual .login-brand,.footer-logo{
  background:#ffffff!important;
  background-image:none!important;
  border-color:#bae6fd!important;
  box-shadow:none!important;
}
.ghost,.theme-toggle,.chip,.table-pagination{background:#e0f2fe!important;color:#075985!important;border-color:#bae6fd!important;box-shadow:none!important}.site-footer{background:transparent!important;border-top-color:#bae6fd!important}.site-footer a{color:#075985!important}.module-hero p,.entity-hero p,.lekol360-hero p,.module-hero h2,.entity-hero h2,.lekol360-hero h2,.module-hero .eyebrow,.entity-hero .eyebrow{color:#083344!important}
html[data-theme="dark"] .module-hero p,html[data-theme="dark"] .entity-hero p,html[data-theme="dark"] .lekol360-hero p,html[data-theme="dark"] .module-hero h2,html[data-theme="dark"] .entity-hero h2,html[data-theme="dark"] .lekol360-hero h2,html[data-theme="dark"] .module-hero .eyebrow,html[data-theme="dark"] .entity-hero .eyebrow{color:#f0f9ff!important}
html[data-theme="dark"] .site-footer a{color:#93c5fd!important;text-decoration:underline;text-underline-offset:3px}
html[data-theme="dark"] .site-footer a:hover,html[data-theme="dark"] .site-footer a:focus-visible{color:#bfdbfe!important}


/* Sky-blue cleanup: remove remaining multicolor callouts */
.login-page .lekol-intro-card .intro-tagline,
.lekol-intro-card .intro-tagline,
.action-card:after,
.modern-login-card:before,
.login-introduction:before{
  background:#38bdf8!important;
  background-image:none!important;
  color:#083344!important;
  box-shadow:none!important;
}
html[data-theme="dark"] .login-page .lekol-intro-card .intro-tagline,
html[data-theme="dark"] .lekol-intro-card .intro-tagline,
html[data-theme="dark"] .modern-login-card:before,
html[data-theme="dark"] .login-introduction:before{
  background:#075985!important;
  background-image:none!important;
  color:#f0f9ff!important;
}

/* Operator request: make the menu sidebar a distinct color from the sky-blue app shell */
:root{
  --menu-sidebar:#14345f;
  --menu-sidebar-2:#0f2748;
  --menu-sidebar-card:#1f4f86;
  --menu-sidebar-card-hover:#2b6cb0;
  --menu-sidebar-text:#f8fbff;
}
html[data-theme="dark"]{
  --menu-sidebar:#071a33;
  --menu-sidebar-2:#051224;
  --menu-sidebar-card:#0f315c;
  --menu-sidebar-card-hover:#1d5c99;
  --menu-sidebar-text:#f8fbff;
}
.sidebar{
  background:linear-gradient(180deg,var(--menu-sidebar),var(--menu-sidebar-2))!important;
  color:var(--menu-sidebar-text)!important;
  border-right:1px solid rgba(255,255,255,.14)!important;
}
.sidebar nav a,
.sidebar-tool,
.sidebar-footer-actions .sidebar-toggle-button{
  background:rgba(255,255,255,.10)!important;
  border-color:rgba(255,255,255,.16)!important;
  color:var(--menu-sidebar-text)!important;
}
.sidebar nav a:hover,
.sidebar nav a:focus-visible,
.sidebar nav a.is-active,
.sidebar-tool:hover,
.sidebar-tool:focus-visible,
.sidebar-footer-actions .sidebar-toggle-button:hover{
  background:var(--menu-sidebar-card-hover)!important;
  border-color:rgba(255,255,255,.30)!important;
  color:#ffffff!important;
}
.sidebar nav svg,
.sidebar nav a:nth-child(3n+1) svg,
.sidebar nav a:nth-child(3n+2) svg,
.sidebar nav a:nth-child(3n) svg{
  background:var(--menu-sidebar-card)!important;
  color:#ffffff!important;
}
.sidebar .brand-link,
.sidebar .logo-only-brand{
  background:rgba(255,255,255,.96)!important;
  border-color:rgba(255,255,255,.80)!important;
}

/* Operator request: centered login flow with logo above form and introduction below */
.main.public{
  margin-left:0!important;
  padding:0!important;
}
.login-page.portal-first-login{
  min-height:100vh!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:clamp(18px,3vw,28px)!important;
  padding:clamp(24px,4vw,52px)!important;
  overflow:auto!important;
  text-align:center!important;
}
.login-centered-stack{
  width:min(520px,100%)!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:clamp(12px,2vw,18px)!important;
  margin-inline:auto!important;
}
.login-top-logo{
  display:inline-grid!important;
  place-items:center!important;
  margin:0 auto!important;
  padding:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.login-top-logo img{
  display:block!important;
  width:min(330px,74vw)!important;
  height:auto!important;
  margin:0 auto!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.login-centered-stack .premium-auth-card{
  width:100%!important;
  max-width:520px!important;
  margin:0 auto!important;
  text-align:left!important;
}
.login-centered-stack .login-card-heading,
.login-centered-stack .portal-subtitle{
  text-align:center!important;
}
.login-centered-stack .login-card-heading span{
  justify-content:center!important;
}
.login-page.portal-first-login .lekol-intro-card{
  width:min(880px,100%)!important;
  max-width:880px!important;
  margin:0 auto!important;
  grid-column:auto!important;
  text-align:left!important;
  height:auto!important;
  max-height:none!important;
  overflow:visible!important;
}
.login-page.portal-first-login .splash-orb{
  display:none!important;
}
@media (max-width:560px){
  .login-page.portal-first-login{justify-content:flex-start!important;padding:20px 14px!important;gap:18px!important}
  .login-top-logo img{width:min(260px,78vw)!important}
  .login-centered-stack .premium-auth-card{padding:22px!important;border-radius:26px!important}
  .login-page.portal-first-login .lekol-intro-card{padding:18px!important;border-radius:24px!important}
}


/* Operator request: elegant login intro, refined colors, minimal titles, and colorful icon system */
:root{
  --ui-cream:#f8fafc;
  --ui-mist:#eef6ff;
  --ui-ink:#102033;
  --ui-muted:#587084;
  --ui-border:#dce8f4;
  --ui-card:#ffffff;
  --ui-blue:#2563eb;
  --ui-cyan:#06b6d4;
  --ui-violet:#7c3aed;
  --ui-emerald:#10b981;
  --ui-amber:#f59e0b;
  --ui-rose:#f43f5e;
}
html[data-theme="dark"]{
  --ui-cream:#071524;
  --ui-mist:#0b1f33;
  --ui-ink:#f4f9ff;
  --ui-muted:#bfd0df;
  --ui-border:#244760;
  --ui-card:#0d263d;
}
body{
  color:var(--ui-ink)!important;
  background:
    radial-gradient(circle at 10% 8%,rgba(37,99,235,.13),transparent 28rem),
    radial-gradient(circle at 88% 12%,rgba(16,185,129,.11),transparent 24rem),
    linear-gradient(135deg,var(--ui-cream),var(--ui-mist))!important;
}
.login-page.portal-first-login{
  background:
    radial-gradient(circle at 16% 10%,rgba(37,99,235,.16),transparent 26rem),
    radial-gradient(circle at 84% 22%,rgba(124,58,237,.12),transparent 24rem),
    radial-gradient(circle at 48% 100%,rgba(6,182,212,.13),transparent 28rem),
    linear-gradient(135deg,#f8fbff,#eef6ff 55%,#f7fbff)!important;
}
html[data-theme="dark"] .login-page.portal-first-login{
  background:
    radial-gradient(circle at 16% 10%,rgba(37,99,235,.16),transparent 26rem),
    radial-gradient(circle at 84% 22%,rgba(124,58,237,.15),transparent 24rem),
    linear-gradient(135deg,#06111f,#0b2034 58%,#071a2a)!important;
}
.login-top-logo{
  width:min(420px,92vw)!important;
  padding-inline:clamp(18px,5vw,44px)!important;
}
.login-top-logo img{
  width:min(360px,78vw)!important;
  max-width:100%!important;
}
.login-centered-stack .premium-auth-card,
.login-page.portal-first-login .lekol-intro-card{
  background:rgba(255,255,255,.88)!important;
  border:1px solid rgba(220,232,244,.92)!important;
  box-shadow:0 24px 70px rgba(15,35,65,.12)!important;
  backdrop-filter:blur(20px)!important;
}
html[data-theme="dark"] .login-centered-stack .premium-auth-card,
html[data-theme="dark"] .login-page.portal-first-login .lekol-intro-card{
  background:rgba(13,38,61,.88)!important;
  border-color:rgba(93,132,165,.28)!important;
  box-shadow:0 24px 70px rgba(0,0,0,.28)!important;
}
.login-page.portal-first-login .lekol-intro-card{
  padding:clamp(22px,3vw,34px)!important;
  border-radius:32px!important;
}
.lekol-intro-card .intro-heading-row{
  display:block!important;
  margin-bottom:18px!important;
  text-align:center!important;
}
.lekol-intro-card .intro-icon{
  display:none!important;
}
.lekol-intro-card .intro-eyebrow{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  margin-bottom:10px!important;
  padding:8px 13px!important;
  border-radius:999px!important;
  color:#1d4ed8!important;
  background:rgba(37,99,235,.09)!important;
  border:1px solid rgba(37,99,235,.15)!important;
  letter-spacing:.10em!important;
}
html[data-theme="dark"] .lekol-intro-card .intro-eyebrow{
  color:#93c5fd!important;
  background:rgba(96,165,250,.13)!important;
  border-color:rgba(147,197,253,.22)!important;
}
.lekol-intro-card h2{
  margin:0 auto!important;
  max-width:760px!important;
  color:var(--ui-ink)!important;
  font-size:clamp(1.55rem,3vw,2.35rem)!important;
  line-height:1.05!important;
  text-align:center!important;
}
.lekol-intro-card .intro-content-grid{
  grid-template-columns:minmax(0,1fr)!important;
  gap:20px!important;
}
.lekol-intro-card .intro-copy{
  display:grid!important;
  gap:10px!important;
  max-width:780px!important;
  margin:0 auto!important;
  text-align:center!important;
}
.lekol-intro-card .intro-copy p{
  margin:0!important;
  color:var(--ui-muted)!important;
  font-size:1rem!important;
  line-height:1.65!important;
}
.lekol-intro-card .intro-list-block{
  width:100%!important;
  max-width:780px!important;
  margin:0 auto!important;
}
.lekol-intro-card .intro-list-title{
  margin:0 0 13px!important;
  color:var(--ui-ink)!important;
  text-align:center!important;
  font-size:1.02rem!important;
  font-weight:850!important;
}
.lekol-intro-card .intro-feature-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
}
.lekol-intro-card .intro-feature-grid .intro-feature-button,
.lekol-intro-card .intro-feature-grid button{
  position:relative!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:11px!important;
  min-height:58px!important;
  padding:12px 14px!important;
  border:1px solid rgba(37,99,235,.14)!important;
  border-radius:19px!important;
  overflow:hidden!important;
  cursor:pointer!important;
  color:var(--ui-ink)!important;
  background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(238,246,255,.86))!important;
  box-shadow:0 12px 28px rgba(15,35,65,.08)!important;
  transform:translateY(0)!important;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease!important;
}
.lekol-intro-card .intro-feature-grid .intro-feature-button:before,
.lekol-intro-card .intro-feature-grid button:before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  opacity:0!important;
  background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(6,182,212,.10))!important;
  transition:opacity .18s ease!important;
}
.lekol-intro-card .intro-feature-grid .intro-feature-button:hover,
.lekol-intro-card .intro-feature-grid .intro-feature-button:focus-visible,
.lekol-intro-card .intro-feature-grid button:hover,
.lekol-intro-card .intro-feature-grid button:focus-visible{
  transform:translateY(-3px)!important;
  border-color:rgba(37,99,235,.34)!important;
  box-shadow:0 18px 38px rgba(37,99,235,.16)!important;
  outline:none!important;
}
.lekol-intro-card .intro-feature-grid .intro-feature-button:hover:before,
.lekol-intro-card .intro-feature-grid .intro-feature-button:focus-visible:before,
.lekol-intro-card .intro-feature-grid button:hover:before,
.lekol-intro-card .intro-feature-grid button:focus-visible:before{opacity:1!important}
.lekol-intro-card .intro-feature-grid .intro-feature-button span,
.lekol-intro-card .intro-feature-grid button span{
  position:relative!important;
  z-index:1!important;
  display:grid!important;
  place-items:center!important;
  width:34px!important;
  height:34px!important;
  border-radius:13px!important;
  background:linear-gradient(135deg,var(--ui-blue),var(--ui-cyan))!important;
  box-shadow:0 10px 22px rgba(37,99,235,.20)!important;
}
.lekol-intro-card .intro-feature-grid .intro-feature-button:nth-child(2) span{background:linear-gradient(135deg,var(--ui-violet),#ec4899)!important}
.lekol-intro-card .intro-feature-grid .intro-feature-button:nth-child(3) span{background:linear-gradient(135deg,var(--ui-emerald),#22c55e)!important}
.lekol-intro-card .intro-feature-grid .intro-feature-button:nth-child(4) span{background:linear-gradient(135deg,var(--ui-amber),#f97316)!important}
.lekol-intro-card .intro-feature-grid .intro-feature-button:nth-child(5) span{background:linear-gradient(135deg,var(--ui-rose),var(--ui-violet))!important}
.lekol-intro-card .intro-feature-grid .intro-feature-button strong,
.lekol-intro-card .intro-feature-grid button strong{
  position:relative!important;
  z-index:1!important;
  font-size:.96rem!important;
  line-height:1.25!important;
  text-align:left!important;
}
.lekol-intro-card .intro-feature-grid .intro-feature-button:last-child,
.lekol-intro-card .intro-feature-grid button:last-child{grid-column:1 / -1!important}
html[data-theme="dark"] .lekol-intro-card .intro-feature-grid .intro-feature-button,
html[data-theme="dark"] .lekol-intro-card .intro-feature-grid button{
  color:#f4f9ff!important;
  background:linear-gradient(135deg,rgba(15,45,72,.96),rgba(10,31,52,.88))!important;
  border-color:rgba(147,197,253,.18)!important;
}
.lekol-intro-card .intro-tagline{
  display:flex!important;
  width:max-content!important;
  max-width:100%!important;
  margin:18px auto 0!important;
  justify-content:center!important;
  color:#ffffff!important;
  background:linear-gradient(135deg,var(--ui-blue),var(--ui-violet))!important;
}
/* Remove decorative bullets/icons beside title areas for a cleaner minimal dashboard */
.dashboard-hero h1:before,.dashboard-hero h2:before,
.module-hero h1:before,.module-hero h2:before,
.entity-hero h1:before,.entity-hero h2:before,
.panel h1:before,.panel h2:before,
.topbar-title h1:before,.eyebrow:before,
.action-card h3:before{
  content:none!important;
  display:none!important;
}
/* Avoid duplicate logos on public/login pages while keeping dashboard footer branding larger */
.main.public .footer-logo{display:none!important}
.footer-logo{
  width:168px!important;
  max-width:min(46vw,180px)!important;
  padding:8px 14px!important;
}
/* Colorful modern sidebar/navigation icon system */
.sidebar nav a{--icon-c1:#2563eb;--icon-c2:#06b6d4;--icon-glow:rgba(37,99,235,.30)}
.sidebar nav a:nth-child(2){--icon-c1:#0ea5e9;--icon-c2:#38bdf8;--icon-glow:rgba(14,165,233,.30)}
.sidebar nav a:nth-child(3){--icon-c1:#10b981;--icon-c2:#34d399;--icon-glow:rgba(16,185,129,.30)}
.sidebar nav a:nth-child(4){--icon-c1:#7c3aed;--icon-c2:#a78bfa;--icon-glow:rgba(124,58,237,.30)}
.sidebar nav a:nth-child(5){--icon-c1:#f59e0b;--icon-c2:#fbbf24;--icon-glow:rgba(245,158,11,.30)}
.sidebar nav a:nth-child(6){--icon-c1:#ef4444;--icon-c2:#fb7185;--icon-glow:rgba(239,68,68,.30)}
.sidebar nav a:nth-child(7){--icon-c1:#14b8a6;--icon-c2:#2dd4bf;--icon-glow:rgba(20,184,166,.30)}
.sidebar nav a:nth-child(8){--icon-c1:#6366f1;--icon-c2:#818cf8;--icon-glow:rgba(99,102,241,.30)}
.sidebar nav a:nth-child(9){--icon-c1:#8b5cf6;--icon-c2:#d946ef;--icon-glow:rgba(139,92,246,.30)}
.sidebar nav a:nth-child(10){--icon-c1:#0f766e;--icon-c2:#22c55e;--icon-glow:rgba(15,118,110,.30)}
.sidebar nav a:nth-child(11){--icon-c1:#f43f5e;--icon-c2:#fb7185;--icon-glow:rgba(244,63,94,.30)}
.sidebar nav svg,
.sidebar nav a:nth-child(3n+1) svg,
.sidebar nav a:nth-child(3n+2) svg,
.sidebar nav a:nth-child(3n) svg{
  width:32px!important;
  height:32px!important;
  padding:7px!important;
  border-radius:13px!important;
  color:#ffffff!important;
  fill:currentColor!important;
  background:radial-gradient(circle at 30% 22%,rgba(255,255,255,.48),transparent 34%),linear-gradient(135deg,var(--icon-c1),var(--icon-c2))!important;
  border:1px solid rgba(255,255,255,.28)!important;
  box-shadow:0 12px 26px var(--icon-glow)!important;
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease!important;
}
.sidebar nav a:hover svg,.sidebar nav a:focus-visible svg,.sidebar nav a.is-active svg{
  transform:translateY(-1px) scale(1.07)!important;
  filter:saturate(1.12) brightness(1.05)!important;
  box-shadow:0 16px 32px var(--icon-glow)!important;
}
.sidebar-tool{--tool-c1:#2563eb;--tool-c2:#06b6d4;--tool-glow:rgba(37,99,235,.28)}
.sidebar-tool.theme-toggle{--tool-c1:#7c3aed;--tool-c2:#a78bfa;--tool-glow:rgba(124,58,237,.28)}
.sidebar-tool.logout-button,.sidebar-tool-form .logout-button{--tool-c1:#ef4444;--tool-c2:#fb7185;--tool-glow:rgba(239,68,68,.28)}
.sidebar-footer-actions .sidebar-toggle-button{--tool-c1:#10b981;--tool-c2:#34d399;--tool-glow:rgba(16,185,129,.28)}
.sidebar-tool svg,
.sidebar-footer-actions .sidebar-toggle-button svg,
.mobile-menu-button svg,
.icon-button svg{
  width:24px!important;
  height:24px!important;
  padding:5px!important;
  border-radius:11px!important;
  color:#ffffff!important;
  fill:currentColor!important;
  background:linear-gradient(135deg,var(--tool-c1,var(--ui-blue)),var(--tool-c2,var(--ui-cyan)))!important;
  box-shadow:0 10px 22px var(--tool-glow,rgba(37,99,235,.25))!important;
}
.mobile-menu-button,.icon-button{--tool-c1:#2563eb;--tool-c2:#06b6d4;--tool-glow:rgba(37,99,235,.25)}
.sidebar-tool:hover svg,
.sidebar-tool:focus-visible svg,
.sidebar-footer-actions .sidebar-toggle-button:hover svg,
.mobile-menu-button:hover svg,
.icon-button:hover svg{
  transform:scale(1.06)!important;
}
@media (max-width:780px){
  .lekol-intro-card .intro-feature-grid{grid-template-columns:1fr!important}
  .lekol-intro-card .intro-feature-grid .intro-feature-button:last-child,
  .lekol-intro-card .intro-feature-grid button:last-child{grid-column:auto!important}
  .footer-logo{width:146px!important}
}
@media (max-width:560px){
  .login-top-logo{padding-inline:clamp(16px,6vw,28px)!important}
  .login-top-logo img{width:min(300px,82vw)!important}
  .lekol-intro-card .intro-feature-grid .intro-feature-button,
  .lekol-intro-card .intro-feature-grid button{min-height:54px!important}
}


/* Operator request: fully clickable dashboard widgets and lighter sidebar bottom actions */
.dashboard-click-grid .dashboard-stat-card,
.stats > a.dashboard-stat-card{
  position:relative!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  min-height:128px!important;
  padding:22px!important;
  border:1px solid var(--line)!important;
  border-radius:28px!important;
  color:var(--ink)!important;
  background:var(--panel)!important;
  box-shadow:0 14px 34px rgba(15,35,65,.08)!important;
  text-decoration:none!important;
  cursor:pointer!important;
  overflow:hidden!important;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease!important;
}
.dashboard-click-grid .dashboard-stat-card:before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  opacity:0!important;
  background:linear-gradient(135deg,rgba(37,99,235,.10),rgba(6,182,212,.08))!important;
  transition:opacity .18s ease!important;
}
.dashboard-click-grid .dashboard-stat-card:after{
  content:"Ouvrir →"!important;
  position:absolute!important;
  right:18px!important;
  bottom:16px!important;
  color:var(--brand-strong)!important;
  font-size:.78rem!important;
  font-weight:900!important;
  opacity:0!important;
  transform:translateX(-6px)!important;
  transition:opacity .18s ease,transform .18s ease!important;
}
.dashboard-click-grid .dashboard-stat-card:hover,
.dashboard-click-grid .dashboard-stat-card:focus-visible{
  transform:translateY(-4px)!important;
  border-color:color-mix(in srgb,var(--brand) 38%,var(--line))!important;
  box-shadow:0 20px 44px rgba(37,99,235,.14)!important;
  outline:none!important;
}
.dashboard-click-grid .dashboard-stat-card:hover:before,
.dashboard-click-grid .dashboard-stat-card:focus-visible:before,
.dashboard-click-grid .dashboard-stat-card:hover:after,
.dashboard-click-grid .dashboard-stat-card:focus-visible:after{
  opacity:1!important;
  transform:translateX(0)!important;
}
.dashboard-click-grid .dashboard-stat-card strong,
.dashboard-click-grid .dashboard-stat-card span{
  position:relative!important;
  z-index:1!important;
}
.dashboard-click-grid .dashboard-stat-card strong{
  font-size:clamp(2rem,4vw,3rem)!important;
  line-height:1!important;
}
.dashboard-click-grid .dashboard-stat-card span{
  margin-top:8px!important;
}
.quick-actions .action-card{
  min-height:154px!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease!important;
}
.quick-actions .action-card:hover,
.quick-actions .action-card:focus-visible{
  transform:translateY(-4px)!important;
  border-color:color-mix(in srgb,var(--brand) 36%,var(--line))!important;
  box-shadow:0 20px 44px rgba(37,99,235,.14)!important;
  outline:none!important;
}
.sidebar-footer-actions,
.compact-sidebar-tools{
  background:transparent!important;
  border-top:0!important;
  box-shadow:none!important;
}
.sidebar-footer-actions .sidebar-tool,
.sidebar-footer-actions .sidebar-tool-form,
.sidebar-footer-actions .sidebar-toggle-button,
.compact-sidebar-tools .sidebar-tool,
.compact-sidebar-tools .sidebar-toggle-button,
.sidebar-tool-form .logout-button{
  background:transparent!important;
  background-image:none!important;
  border-color:transparent!important;
  border-width:0!important;
  box-shadow:none!important;
}
.sidebar-footer-actions .sidebar-tool:hover,
.sidebar-footer-actions .sidebar-tool:focus-visible,
.sidebar-footer-actions .sidebar-toggle-button:hover,
.sidebar-footer-actions .sidebar-toggle-button:focus-visible,
.sidebar-tool-form .logout-button:hover,
.sidebar-tool-form .logout-button:focus-visible{
  background:rgba(255,255,255,.08)!important;
  border-color:transparent!important;
  box-shadow:none!important;
  transform:translateY(-2px)!important;
  outline:none!important;
}
.sidebar-footer-actions .sidebar-tool svg,
.sidebar-footer-actions .sidebar-toggle-button svg,
.sidebar-tool-form .logout-button svg{
  box-shadow:0 10px 24px var(--tool-glow,rgba(37,99,235,.24))!important;
}
html[data-theme="dark"] .dashboard-click-grid .dashboard-stat-card{
  background:var(--panel)!important;
  box-shadow:0 14px 34px rgba(0,0,0,.20)!important;
}
@media (max-width:780px){
  .dashboard-click-grid .dashboard-stat-card{min-height:112px!important;padding:18px!important}
}

/* Operator profile/settings + logo visibility fixes */
.brand-link.logo-only-brand{
  justify-content:center!important;
  overflow:visible!important;
  padding:10px 8px!important;
}
.brand-logo-img.crisp-logo,
.loading-logo.crisp-logo,
.hero-logo.crisp-logo,
.footer-logo.crisp-logo,
.report-official-logo.crisp-logo,
.login-top-logo img{
  object-fit:contain!important;
  object-position:center!important;
  height:auto!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  overflow:visible!important;
}
.brand-logo-img.crisp-logo{
  width:min(226px,100%)!important;
  max-width:100%!important;
  min-height:72px!important;
  padding:4px 8px!important;
}
.sidebar-collapsed .brand-logo-img.crisp-logo{
  width:62px!important;
  min-height:40px!important;
  padding:2px!important;
}
.hero-logo-link{display:inline-flex!important;max-width:100%!important;overflow:visible!important;padding:2px!important}
.hero-logo.crisp-logo{width:clamp(170px,24vw,310px)!important;max-width:100%!important}
.sidebar-user-pill{cursor:pointer!important;text-decoration:none!important}
.sidebar-user-avatar{width:28px!important;height:28px!important;border-radius:50%!important;object-fit:cover!important;box-shadow:0 8px 18px rgba(0,0,0,.22)!important;border:2px solid rgba(255,255,255,.55)!important}
.sidebar-user-pill span{
  min-width:180px!important;
  max-width:min(320px,72vw)!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  line-height:1.18!important;
  text-align:center!important;
  border-radius:16px!important;
}
.sidebar-collapsed .sidebar-user-pill span{min-width:180px!important;text-align:left!important}
.profile-settings-hero{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:18px!important;flex-wrap:wrap!important;background:linear-gradient(135deg,#063b3a,#2563eb 58%,#7c3aed)!important}
.profile-settings-heading{display:flex;align-items:center;gap:18px;min-width:0;flex-wrap:wrap}.profile-settings-heading h2{margin:0;font-size:clamp(2rem,5vw,4.2rem);line-height:.95}.profile-photo-wrap{flex:0 0 auto}.profile-photo{box-shadow:0 20px 48px rgba(0,0,0,.22);border:3px solid rgba(255,255,255,.72);object-fit:cover}.settings-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:20px}.settings-card{margin:0}.profile-form{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-form .full-span,.security-note.full-span{grid-column:1 / -1}.profile-form textarea{min-height:104px;resize:vertical}.checkbox-line{display:flex!important;align-items:center;gap:10px;align-self:end;min-height:54px}.checkbox-line input{width:auto!important;margin:0}.profile-upload{margin-top:8px}.security-note{padding:12px 14px;border-radius:16px;background:color-mix(in srgb,var(--brand) 8%,var(--panel-solid));color:var(--muted);font-weight:700}.managed-users-card .result-list{margin-top:8px}.ghost.small{padding:7px 11px;font-size:.86rem}
@media (max-width:980px){.settings-layout{grid-template-columns:1fr}.profile-form{grid-template-columns:1fr}.profile-form .full-span,.security-note.full-span{grid-column:auto}.profile-settings-hero{align-items:flex-start!important}}
@media (max-width:780px){.brand-logo-img.crisp-logo{width:210px!important;min-height:68px!important}.sidebar-collapsed .brand-logo-img.crisp-logo{width:210px!important;min-height:68px!important}.sidebar-user-pill span{min-width:160px!important}.profile-settings-heading{align-items:flex-start}.profile-actions{width:100%}}
@media (max-width:520px){.hero-logo.crisp-logo{width:min(260px,88vw)!important}.profile-settings-heading h2{font-size:2.05rem}.settings-card{padding:18px!important}}

/* SMTP email settings */
.email-hero{background:linear-gradient(135deg,#0f172a,#2563eb 56%,#06b6d4)!important}
.email-settings-layout{align-items:stretch}.smtp-detail-list{grid-template-columns:minmax(130px,auto) 1fr}.smtp-card code{padding:2px 7px;border-radius:8px;background:color-mix(in srgb,var(--brand) 8%,var(--panel-solid));color:var(--brand-strong)}.announcement-card{margin-bottom:20px}.email-queue-panel small{color:var(--muted);font-weight:700}.email-status-sent{background:color-mix(in srgb,var(--ok) 16%,var(--panel-solid))!important;color:var(--ok)!important}.email-status-failed{background:color-mix(in srgb,var(--danger) 14%,var(--panel-solid))!important;color:var(--danger)!important}.email-status-retry,.email-status-queued{background:color-mix(in srgb,var(--accent) 16%,var(--panel-solid))!important;color:color-mix(in srgb,var(--accent) 72%,#7c2d12)!important}
@media (max-width:780px){.smtp-detail-list{grid-template-columns:1fr}.email-hero .inline-form{width:100%}.email-hero .inline-form button{width:100%}}

/* Clean transparent footer logo + gender-aware profile avatars */
.site-footer .footer-logo,
.footer-logo.crisp-logo,
html[data-theme="dark"] .footer-logo{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  border-radius:0!important;
  filter:none!important;
  object-fit:contain!important;
}
.avatar,
.avatar.small,
.avatar.xl,
.profile-photo,
.sidebar-user-avatar{
  object-fit:cover!important;
  background:transparent;
}
.profile-photo-wrap{background:transparent!important;border:0!important;box-shadow:none!important}

/* Final 2026 professional color polish and cleaner dashboard search */
.lekol360-hero{
  background:
    radial-gradient(circle at 12% 14%,rgba(255,255,255,.26),transparent 26%),
    linear-gradient(135deg,#063b3a 0%,#0f766e 34%,#2563eb 68%,#7c3aed 100%)!important;
  box-shadow:0 28px 70px rgba(15,118,110,.24)!important;
}
.dashboard-search{
  background:rgba(255,255,255,.96)!important;
  border:1px solid rgba(255,255,255,.78)!important;
  box-shadow:0 20px 54px rgba(15,23,42,.16)!important;
}
html[data-theme="dark"] .dashboard-search{
  background:rgba(15,29,49,.94)!important;
  border-color:rgba(255,255,255,.12)!important;
}
.search-shell input,.filters-grid input,.filters-grid select,.grid-form input,.grid-form select,.grid-form textarea{
  border:1px solid color-mix(in srgb,var(--brand) 16%,var(--line))!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.36)!important;
}
.dashboard-stat-card,.mini-card,.panel{
  border-color:color-mix(in srgb,var(--brand) 14%,var(--line))!important;
}
.dashboard-stat-card:hover,.mini-card:hover{
  transform:translateY(-3px)!important;
  box-shadow:0 18px 44px rgba(15,118,110,.18)!important;
}
.dashboard-stat-card:nth-child(2n){--brand:#2563eb;--brand2:#06b6d4}
.dashboard-stat-card:nth-child(3n){--brand:#7c3aed;--brand2:#f97316}

/* Login recovery + concise intro polish */
.concise-intro-card{max-width:min(920px,92vw)!important;margin:22px auto 0!important;padding:24px!important;display:grid!important;gap:14px!important}
.concise-intro-copy{display:grid!important;gap:10px!important;max-width:760px!important}.concise-intro-copy p{margin:0!important;font-size:clamp(.98rem,2vw,1.08rem)!important;line-height:1.65!important;color:var(--ink)!important}.auth-help{margin:10px 0 0!important;text-align:center!important;font-weight:800!important}.auth-help a{color:var(--brand)!important}.recovery-page{min-height:100vh!important;display:grid!important;place-items:center!important;padding:28px!important}.recovery-card{width:min(620px,94vw)!important}.force-password-page .recovery-card{width:min(680px,94vw)!important}
html[data-theme="dark"] .concise-intro-copy p{color:var(--ink)!important}
@media (max-width:780px){.concise-intro-card{margin-top:16px!important;padding:20px!important}.intro-heading-row{align-items:flex-start!important}.recovery-page{padding:18px!important}.recovery-card .login-card-heading h2{font-size:clamp(1.45rem,7vw,2rem)!important;line-height:1.08!important}}
html[data-theme="dark"] input::placeholder,html[data-theme="dark"] textarea::placeholder{color:#d7e4f3!important;opacity:1!important}
html[data-theme="dark"] .login-card-heading p,html[data-theme="dark"] .portal-option small,html[data-theme="dark"] .intro-eyebrow{color:#cfe0f4!important}


/* Accessibility and profile-photo polish — Lekòl360 production pass */
:root{
  --focus-ring:#f59e0b;
  --success-bg:#ecfdf5;
  --success-text:#065f46;
  --error-bg:#fef2f2;
  --error-text:#991b1b;
  --warning-bg:#fffbeb;
  --warning-text:#92400e;
}
html[data-theme="dark"]{
  --success-bg:#052e26;
  --success-text:#a7f3d0;
  --error-bg:#3b0a0a;
  --error-text:#fecaca;
  --warning-bg:#3a2604;
  --warning-text:#fde68a;
}
.main{color:var(--ink)}
.panel,.mini-card,.stats>div,.table-pagination,.login-card,.premium-auth-card,.result-item{
  color:var(--ink);
  background:linear-gradient(145deg,color-mix(in srgb,var(--panel-solid) 96%,transparent),color-mix(in srgb,var(--brand2) 4%,var(--panel-solid)));
  border:1px solid color-mix(in srgb,var(--brand) 14%,var(--line));
}
html[data-theme="dark"] .panel,html[data-theme="dark"] .mini-card,html[data-theme="dark"] .stats>div,html[data-theme="dark"] .table-pagination,html[data-theme="dark"] .login-card,html[data-theme="dark"] .premium-auth-card,html[data-theme="dark"] .result-item{
  background:linear-gradient(145deg,color-mix(in srgb,var(--panel-solid) 94%,#000),color-mix(in srgb,var(--brand2) 8%,var(--panel-solid)));
  border-color:#31445f;
  box-shadow:0 18px 46px rgba(0,0,0,.32);
}
.panel p,.mini-card p,.result-item small,.detail-list dt,.stats span,.empty,small,.muted{color:var(--muted)}
html[data-theme="dark"] .panel p,html[data-theme="dark"] .mini-card p,html[data-theme="dark"] .result-item small,html[data-theme="dark"] .detail-list dt,html[data-theme="dark"] .stats span,html[data-theme="dark"] .empty,html[data-theme="dark"] small,html[data-theme="dark"] .muted{color:#cbd8e8}
input,select,textarea{
  color:var(--ink);
  background:color-mix(in srgb,var(--panel-solid) 94%,#fff);
  border:1px solid color-mix(in srgb,var(--brand) 18%,var(--line));
}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{
  color:#f8fbff;
  background:#0a1726;
  border-color:#37506e;
}
input:hover,select:hover,textarea:hover{border-color:color-mix(in srgb,var(--brand) 42%,var(--line));box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 10%,transparent)}
input:focus,select:focus,textarea:focus,button:focus-visible,a:focus-visible{outline:3px solid color-mix(in srgb,var(--focus-ring) 72%,transparent);outline-offset:3px}
.primary,button.primary,button[type="submit"].primary,a.primary{color:#fff!important;background:linear-gradient(135deg,#0f766e,#2563eb)!important;border-color:transparent!important;box-shadow:0 14px 30px color-mix(in srgb,var(--brand) 24%,transparent)}
.primary:hover,button[type="submit"].primary:hover,a.primary:hover{filter:saturate(1.06) brightness(1.04);transform:translateY(-1px);box-shadow:0 18px 42px color-mix(in srgb,var(--brand2) 28%,transparent)}
.ghost,a.ghost,button.ghost{color:var(--brand-strong)!important;background:color-mix(in srgb,var(--brand) 8%,var(--panel-solid))!important;border:1px solid color-mix(in srgb,var(--brand) 26%,var(--line))!important}
.ghost:hover,a.ghost:hover,button.ghost:hover{color:var(--ink)!important;background:color-mix(in srgb,var(--brand) 15%,var(--panel-solid))!important;transform:translateY(-1px)}
html[data-theme="dark"] .ghost,html[data-theme="dark"] a.ghost,html[data-theme="dark"] button.ghost{color:#99f6e4!important;background:#123042!important;border-color:#3c6470!important}
html[data-theme="dark"] .ghost:hover,html[data-theme="dark"] a.ghost:hover,html[data-theme="dark"] button.ghost:hover{color:#fff!important;background:#174255!important}
.table-wrap table{border-collapse:separate;border-spacing:0;width:100%}
th{color:var(--ink);background:color-mix(in srgb,var(--brand) 9%,var(--panel-solid));font-weight:750}
td{color:var(--ink);border-bottom:1px solid var(--line)}
tbody tr:hover{background:color-mix(in srgb,var(--brand2) 7%,var(--panel-solid))}
html[data-theme="dark"] th{color:#f8fbff;background:#132943}
html[data-theme="dark"] td{color:#eaf2ff;border-bottom-color:#2b3d55}
html[data-theme="dark"] tbody tr:hover{background:#142b45}
.sidebar nav a,.sidebar-tool{color:#f8fbff!important}.sidebar nav a:hover,.sidebar nav a:focus-visible{background:#ffffff24;color:#fff!important}
.flash{border:1px solid transparent;color:var(--ink)}
.flash.success{background:var(--success-bg);color:var(--success-text);border-color:color-mix(in srgb,var(--success-text) 24%,transparent)}
.flash.error{background:var(--error-bg);color:var(--error-text);border-color:color-mix(in srgb,var(--error-text) 24%,transparent)}
.flash.warning{background:var(--warning-bg);color:var(--warning-text);border-color:color-mix(in srgb,var(--warning-text) 24%,transparent)}
.avatar{object-fit:cover;background:color-mix(in srgb,var(--brand) 12%,var(--panel-solid));border:1px solid color-mix(in srgb,var(--brand) 18%,var(--line))}
.upload-row,.compact-upload{gap:8px;align-items:center;flex-wrap:wrap}.compact-upload input[type="file"]{max-width:220px;font-size:.86rem}.profile-photo-manager{margin-top:16px}
.site-footer{color:var(--muted);text-align:center}.site-footer a{color:var(--brand-strong)!important}.site-footer a:hover{color:var(--brand2)!important;text-decoration:underline}
html[data-theme="dark"] .site-footer a{color:#99f6e4!important}html[data-theme="dark"] .site-footer a:hover{color:#bfdbfe!important}
@media (max-width:780px){.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.entity-table{min-width:760px}.profile-heading{align-items:flex-start}.upload-row input[type="file"]{width:100%;max-width:none}.profile-actions .primary,.profile-actions .ghost{width:100%;text-align:center}.stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:520px){.stats{grid-template-columns:1fr}.panel-head{gap:12px}.primary,.ghost,button{min-height:44px}.avatar.xl{width:78px;height:78px;border-radius:24px}}
