/* ISL School Portal — auth.isllaos.com */
:root{
  --c-bg:#f8fafc; --c-surface:#fff; --c-border:#e5e7eb;
  --c-text:#0f172a; --c-muted:#64748b; --c-link:#2563eb;
  --c-primary:#2563eb; --c-primary-hover:#1d4ed8;
  --c-danger:#dc2626; --c-success:#16a34a; --c-warn:#d97706;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-lg:0 10px 25px -5px rgba(0,0,0,.10),0 8px 10px -6px rgba(0,0,0,.08);
  --radius:12px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--c-bg); color:var(--c-text); line-height:1.5;
}
a{color:var(--c-link);text-decoration:none} a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .75rem;color:var(--c-text)}
h1{font-size:1.5rem} h2{font-size:1.25rem} h3{font-size:1.05rem}

/* ---- Topbar ---- */
.topbar{
  background:#fff;border-bottom:1px solid var(--c-border);
  padding:.75rem 1.25rem;display:flex;align-items:center;gap:1rem;
}
.topbar .brand{font-weight:700;color:var(--c-text);display:flex;align-items:center;gap:.5rem}
.topbar .brand .logo{
  width:32px;height:32px;border-radius:8px;background:var(--c-primary);
  color:#fff;display:grid;place-items:center;font-weight:700
}
.topbar nav{margin-left:auto;display:flex;gap:1rem;align-items:center}
.topbar nav a{color:var(--c-text);font-size:.9rem}
.topbar .user-chip{
  display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;
  border:1px solid var(--c-border);border-radius:999px;font-size:.85rem
}

/* ---- Layout ---- */
.container{max-width:1100px;margin:0 auto;padding:1.5rem}
.container-sm{max-width:480px;margin:0 auto;padding:1.5rem}
.card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;
}
.card + .card{margin-top:1rem}
.card h1,.card h2{margin-top:0}

/* ---- Auth (login/forgot/reset) ---- */
.auth-wrap{
  min-height:100vh;display:grid;place-items:center;padding:2rem 1rem;
  background:linear-gradient(135deg,#eff6ff 0%,#f8fafc 100%);
}
.auth-card{
  background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);
  padding:2rem;width:100%;max-width:400px;
}
.auth-card .brand{text-align:center;margin-bottom:1.5rem}
.auth-card .brand .logo{
  width:56px;height:56px;border-radius:14px;background:var(--c-primary);
  color:#fff;display:inline-grid;place-items:center;font-size:1.5rem;font-weight:700;margin-bottom:.5rem
}
.auth-card .brand h1{font-size:1.25rem;margin:.25rem 0}
.auth-card .brand p{margin:0;color:var(--c-muted);font-size:.9rem}
.auth-card .links{display:flex;justify-content:space-between;font-size:.85rem;margin-top:1rem}
.divider{display:flex;align-items:center;margin:1.25rem 0;color:var(--c-muted);font-size:.8rem}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--c-border)}
.divider span{padding:0 .75rem}

/* ---- Forms ---- */
.field{margin-bottom:1rem}
.field label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.35rem;color:#374151}
.field input,.field select,.field textarea{
  width:100%;padding:.6rem .75rem;border:1px solid var(--c-border);
  border-radius:8px;font-size:.95rem;background:#fff;color:var(--c-text);
  transition:border .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,.15)
}
.field .hint{font-size:.75rem;color:var(--c-muted);margin-top:.25rem}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.6rem 1rem;border:1px solid transparent;border-radius:8px;
  font-size:.9rem;font-weight:500;cursor:pointer;text-decoration:none;
  transition:all .15s;
}
.btn-primary{background:var(--c-primary);color:#fff}
.btn-primary:hover{background:var(--c-primary-hover);text-decoration:none;color:#fff}
.btn-block{width:100%}
.btn-google{background:#fff;color:#374151;border-color:var(--c-border)}
.btn-google:hover{background:#f9fafb;text-decoration:none;color:#374151}
.btn-google img{width:18px;height:18px}
.btn-secondary{background:#fff;color:var(--c-text);border-color:var(--c-border)}
.btn-secondary:hover{background:#f9fafb;text-decoration:none;color:var(--c-text)}
.btn-danger{background:var(--c-danger);color:#fff}
.btn-danger:hover{background:#b91c1c;text-decoration:none;color:#fff}
.btn-sm{padding:.35rem .65rem;font-size:.8rem}

/* ---- Alerts ---- */
.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;border:1px solid}
.alert-error  {background:#fef2f2;color:#991b1b;border-color:#fecaca}
.alert-success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}
.alert-info   {background:#eff6ff;color:#1e40af;border-color:#bfdbfe}
.alert-warn   {background:#fffbeb;color:#92400e;border-color:#fde68a}

/* ---- App launcher tiles ---- */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1rem}
.tile{
  display:block;background:#fff;border:1px solid var(--c-border);
  border-radius:var(--radius);padding:1.25rem;text-decoration:none;color:var(--c-text);
  transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden;
}
.tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);text-decoration:none;color:var(--c-text)}
.tile .icon{
  width:48px;height:48px;border-radius:10px;display:grid;place-items:center;
  color:#fff;font-weight:700;font-size:1.25rem;margin-bottom:.75rem;
}
.tile h3{margin:0 0 .25rem;font-size:1rem}
.tile p{margin:0;color:var(--c-muted);font-size:.85rem}
.tile .badges{margin-top:.5rem}
.tile .badge{
  display:inline-block;background:#f1f5f9;color:#475569;font-size:.7rem;
  padding:.15rem .5rem;border-radius:999px;margin-right:.25rem
}

/* ---- Tables ---- */
.table-wrap{overflow-x:auto;border:1px solid var(--c-border);border-radius:var(--radius);background:#fff}
table.data{width:100%;border-collapse:collapse;font-size:.9rem}
table.data th,table.data td{padding:.6rem .85rem;text-align:left;border-bottom:1px solid var(--c-border)}
table.data th{background:#f8fafc;font-weight:600;color:#374151;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}
table.data tr:last-child td{border-bottom:none}
table.data tr:hover td{background:#fafafa}

.badge-role{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.72rem;background:#eef2ff;color:#3730a3;margin:.1rem .15rem .1rem 0}
.badge-status{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.72rem}
.badge-status.active   {background:#dcfce7;color:#166534}
.badge-status.disabled {background:#fee2e2;color:#991b1b}
.badge-status.locked   {background:#fef3c7;color:#92400e}
.badge-status.pending  {background:#e0e7ff;color:#3730a3}

/* ---- Page header ---- */
.page-head{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.page-head h1{margin:0}
.page-head .actions{margin-left:auto;display:flex;gap:.5rem}

/* ---- Toolbar (search/filters) ---- */
.toolbar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.toolbar input,.toolbar select{padding:.5rem .75rem;border:1px solid var(--c-border);border-radius:8px;font-size:.9rem}

/* ---- Role grid (user-edit page) ---- */
.role-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem}
.role-card{border:1px solid var(--c-border);border-radius:var(--radius);padding:1rem;background:#fff}
.role-card h4{margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}
.role-card .swatch{width:14px;height:14px;border-radius:4px}
.role-card .check-list label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;padding:.2rem 0}
.role-card .no-access{color:var(--c-muted);font-size:.85rem;font-style:italic}

/* ---- Footer ---- */
.footer{text-align:center;color:var(--c-muted);font-size:.8rem;padding:2rem 1rem}
