:root{--bg:#fff7f2;--panel:#fffdfa;--ink:#35241f;--muted:#7b6961;--line:#eadbd2;--brand:#f29f8f;--brand2:#8db7a8;--warn:#e8a23d;--danger:#d86b64;--ok:#4c9a6a;--shadow:0 14px 40px rgba(95,57,40,.11);--r:24px;font-size:16px}*{box-sizing:border-box}body{margin:0;background:linear-gradient(135deg,#fff7f2,#f8efe8);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--ink);overflow:hidden}.app-shell{height:100vh;display:grid;grid-template-columns:252px 1fr;gap:14px;padding:14px}.sidebar,.main,.card,.modal-card{background:rgba(255,253,250,.92);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}.sidebar{display:flex;flex-direction:column;padding:14px;min-height:0}.brand{display:flex;gap:12px;align-items:center;margin-bottom:12px}.brand-mark{width:48px;height:48px;border-radius:17px;background:var(--brand);display:grid;place-items:center;color:white;font-size:21px}.brand strong{font-size:24px}.brand span{font-size:13px;color:var(--muted);line-height:1.15}.nav{display:grid;gap:6px;overflow:hidden}.nav button{border:0;background:transparent;text-align:left;padding:11px 12px;border-radius:15px;color:var(--muted);font-size:15.5px;display:flex;gap:10px;align-items:center;cursor:pointer}.nav button.active,.nav button:hover{background:#fff0e9;color:var(--ink)}.nav i{width:20px;text-align:center}.profile-box{margin-top:auto;background:#fff6f1;border:1px solid var(--line);border-radius:18px;padding:12px}.profile-box label{display:block;font-weight:800;margin-bottom:8px}.profile-box select,.form-control{width:100%;border:1px solid var(--line);border-radius:14px;background:white;padding:11px 12px;font-size:16px;color:var(--ink)}.profile-box small{display:block;margin-top:8px;color:var(--muted);line-height:1.25}.main{min-width:0;display:flex;flex-direction:column;padding:14px;overflow:hidden}.topbar{height:72px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex:0 0 auto}.topbar h1{margin:0;font-size:27px}.topbar p{margin:4px 0 0;color:var(--muted);font-size:15px}.top-actions{display:flex;gap:10px;align-items:center}.search{height:43px;display:flex;align-items:center;gap:8px;background:white;border:1px solid var(--line);border-radius:15px;padding:0 12px;min-width:330px}.search input{border:0;outline:0;font-size:16px;width:100%;background:transparent}.btn{border:0;border-radius:15px;padding:11px 14px;background:var(--brand);color:white;font-weight:800;font-size:15px;cursor:pointer;display:inline-flex;gap:8px;align-items:center}.btn.ghost{background:#fff2eb;color:var(--ink);border:1px solid var(--line)}.btn.soft{background:#edf7f2;color:#275c47}.btn.danger{background:#fff0f0;color:#9e3933}.content{flex:1;min-height:0;overflow:hidden}.grid{display:grid;gap:12px;height:100%;min-height:0}.cols-3{grid-template-columns:1.1fr 1fr 1fr}.cols-2{grid-template-columns:1fr 1fr}.rows{display:grid;gap:12px;min-height:0}.card{padding:16px;overflow:hidden;min-height:0}.card h2{margin:0 0 12px;font-size:20px}.muted{color:var(--muted)}.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.kpi{background:#fff5ef;border:1px solid var(--line);border-radius:18px;padding:13px}.kpi b{font-size:25px}.kpi span{display:block;color:var(--muted);font-size:14px}.list{display:grid;gap:8px;overflow:auto;max-height:100%;padding-right:3px}.item{background:white;border:1px solid var(--line);border-radius:16px;padding:11px;display:flex;gap:10px;align-items:flex-start}.avatar{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;color:white;font-weight:900;background:var(--brand2);flex:none}.item h3{font-size:16px;margin:0 0 3px}.item p{margin:0;color:var(--muted);font-size:14px}.badge{border-radius:999px;padding:5px 9px;font-size:13px;font-weight:800;background:#fff0e9;color:#995244;display:inline-flex;gap:6px;align-items:center}.badge.ok{background:#edf7f2;color:#2e7a54}.badge.warn{background:#fff5df;color:#8c5d13}.badge.danger{background:#fff0f0;color:#99413c}.timeline{position:relative;display:grid;gap:8px;overflow:auto}.timeline .item{align-items:center}.timeline time{font-weight:900;color:#6b4a3f;min-width:54px}.calendar{height:100%;display:grid;grid-template-rows:auto 1fr;gap:10px}.cal-head{display:grid;grid-template-columns:repeat(5,1fr) .42fr .42fr;gap:7px}.cal-head div{text-align:center;font-weight:900;color:var(--muted);font-size:14px}.cal-grid{display:grid;grid-template-columns:repeat(5,1fr) .42fr .42fr;grid-auto-rows:1fr;gap:7px;min-height:0}.day{background:white;border:1px solid var(--line);border-radius:13px;padding:7px;overflow:hidden;min-height:0}.day.weekend{background:#f4eee9;color:#9c8b83}.day.holiday{background:#fff0f0;border-color:#f0b5b0}.day .num{font-weight:900;font-size:14px}.events{display:grid;gap:4px;margin-top:4px}.event{border-radius:9px;padding:4px 5px;font-size:12.5px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#edf7f2}.weekend .event{display:none}.table{width:100%;border-collapse:separate;border-spacing:0 8px;font-size:15px}.table td,.table th{text-align:left;padding:9px 10px;background:white;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.table td:first-child,.table th:first-child{border-left:1px solid var(--line);border-radius:12px 0 0 12px}.table td:last-child,.table th:last-child{border-right:1px solid var(--line);border-radius:0 12px 12px 0}.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;overflow:auto}.photo{min-height:145px;border-radius:18px;background:linear-gradient(135deg,#f6b7a8,#9bc4b6);padding:12px;color:white;display:flex;flex-direction:column;justify-content:space-between}.photo:nth-child(even){background:linear-gradient(135deg,#9bc4b6,#d8bf93)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-row{display:grid;gap:6px}.form-row label{font-weight:900;font-size:14px}.form-row.full{grid-column:1/-1}textarea.form-control{min-height:92px;resize:none}.modal{position:fixed;inset:0;background:rgba(54,37,31,.32);display:grid;place-items:center;z-index:20;padding:20px}.modal-card{width:min(820px,96vw);max-height:92vh;padding:18px;display:grid;gap:12px}.modal-head{display:flex;justify-content:space-between;align-items:center}.modal-head h2{margin:0}.modal-body{overflow:auto}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.fab{position:fixed;right:24px;bottom:24px;z-index:10;border:0;border-radius:999px;background:var(--brand);color:white;box-shadow:var(--shadow);padding:16px 19px;font-size:17px;font-weight:900;display:flex;gap:10px;align-items:center;cursor:pointer}.toast-root{position:fixed;right:22px;top:88px;display:grid;gap:8px;z-index:30}.toast{background:#35241f;color:white;border-radius:16px;padding:12px 14px;box-shadow:var(--shadow)}.empty{height:100%;display:grid;place-items:center;text-align:center;color:var(--muted)}.tabs{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.tabs button{border:1px solid var(--line);background:white;border-radius:999px;padding:8px 11px;font-weight:800}.tabs button.active{background:#fff0e9}.compact-stack{display:grid;gap:8px;overflow:auto}.pill-row{display:flex;gap:6px;flex-wrap:wrap}.split{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;height:100%;min-height:0}@media(max-width:980px){.app-shell{grid-template-columns:76px 1fr}.brand span,.brand strong,.nav span,.profile-box label,.profile-box small{display:none}.brand{justify-content:center}.nav button{justify-content:center}.profile-box{padding:8px}.search{min-width:200px}.gallery{grid-template-columns:repeat(2,1fr)}}
/* V4.1 ciblée : pas de refonte visuelle, uniquement ergonomie drawers + calendrier. */
.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.calendar-toolbar h2{margin:0;text-transform:capitalize}.empty-day{background:transparent;border:0;box-shadow:none}.day{cursor:pointer}.day:hover{outline:2px solid rgba(242,159,143,.35)}.day.vacation{box-shadow:inset 0 0 0 2px rgba(141,183,168,.20)}.event.absence,.event.absent,.event.maladie{background:#fff0f0;color:#99413c}.event.cp{background:#fff5df;color:#8c5d13}.event.extra,.event.adaptation{background:#fff0e9;color:#995244}.event.more{background:#f4eee9;color:#7b6961}.drawer-overlay{position:fixed;inset:0;background:rgba(54,37,31,.24);z-index:24;display:flex;justify-content:flex-end}.drawer{width:min(560px,94vw);height:100vh;background:rgba(255,253,250,.98);border-left:1px solid var(--line);box-shadow:-18px 0 50px rgba(95,57,40,.16);display:grid;grid-template-rows:auto 1fr auto;padding:18px;gap:12px}.drawer-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.drawer-head h2,.drawer-body h2{margin:0;font-size:24px}.drawer-body{overflow:auto;display:grid;align-content:start;gap:12px;padding-right:2px}.drawer-footer{display:flex;justify-content:space-between;gap:10px;border-top:1px solid var(--line);padding-top:12px}.drawer-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.drawer-actions .item{width:100%;text-align:left;cursor:pointer}.section-title{font-weight:900;color:var(--muted);margin-top:6px}.empty-line{background:white;border:1px solid var(--line);border-radius:16px;padding:12px;color:var(--muted)}@media(max-width:760px){.drawer-actions{grid-template-columns:1fr}.calendar-toolbar{align-items:stretch;flex-direction:column}.month-btn{justify-content:center}}
/* V4.2 correctifs ciblés : permissions de saisie + calendrier plein écran. */
.calendar{grid-template-rows:auto auto minmax(0,1fr);padding:12px;gap:7px;min-height:0;height:100%}
.calendar-toolbar{margin-bottom:0;min-height:42px;flex:0 0 auto}
.cal-grid{grid-template-rows:repeat(var(--weeks,6),minmax(0,1fr));height:100%;overflow:hidden;align-self:stretch}
.cal-head{flex:0 0 auto}
.day{display:grid;grid-template-rows:auto minmax(0,1fr);padding:6px}
.day .events{min-height:0;overflow:hidden}
.content .calendar.card{height:100%}
/* V5 : améliorations métier sans changement de thème. */
.v5-calendar{grid-template-rows:auto auto minmax(0,1fr)}
.v5-cal-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.v5-cal-actions .active{background:#fff0e9;color:var(--ink);border:1px solid var(--line)}
.v5-week{height:100%;display:grid;grid-template-columns:repeat(5,1fr) .45fr .45fr;gap:8px;min-height:0;overflow:hidden}
.v5-week-day{background:white;border:1px solid var(--line);border-radius:16px;padding:10px;overflow:auto;display:grid;align-content:start;gap:8px;cursor:pointer}
.v5-week-day.weekend{background:#f4eee9;color:#9c8b83}
.v5-week-day.weekend .item{display:none}
.v5-day{height:100%;display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;min-height:0;overflow:hidden}
.inner-card{box-shadow:none;background:white;overflow:auto}
@media(max-width:980px){.v5-day{grid-template-columns:1fr}.v5-week{grid-template-columns:1fr}.v5-week-day.weekend{display:none}}

/* V5.1 : correctifs ciblés calendrier, sans changement de thème. */
.calendar.card.v5-calendar{
  grid-template-rows:auto auto 26px minmax(0,1fr);
  gap:6px;
  padding:10px;
}
.calendar.card.v5-calendar .calendar-toolbar{
  min-height:38px;
}
.calendar.card.v5-calendar .calendar-toolbar h2{
  font-size:20px;
  margin:0;
  line-height:1.1;
}
.calendar.card.v5-calendar .btn{
  padding:8px 11px;
  font-size:14px;
  border-radius:13px;
}
.calendar.card.v5-calendar .v5-cal-actions{
  min-height:36px;
  flex-wrap:nowrap;
  overflow:hidden;
}
.calendar.card.v5-calendar .cal-head{
  min-height:24px;
  align-self:stretch;
  display:grid;
  align-items:center;
}
.calendar.card.v5-calendar .cal-head div{
  display:grid;
  place-items:center;
  min-height:24px;
  font-size:13px;
}
.calendar.card.v5-calendar .cal-grid{
  height:100%;
  min-height:0;
}
.calendar.card.v5-calendar .day{
  border-radius:12px;
  padding:5px;
}
.calendar.card.v5-calendar .day .num{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:4px;
  min-width:0;
}
.calendar.card.v5-calendar .day .num em{
  font-style:normal;
  font-size:10px;
  font-weight:900;
  color:#995244;
  background:#fff0e9;
  border:1px solid rgba(242,159,143,.45);
  border-radius:999px;
  padding:2px 5px;
  white-space:nowrap;
}
.calendar.card.v5-calendar .day.today{
  border:2px solid var(--brand);
  box-shadow:inset 0 0 0 2px rgba(242,159,143,.18), 0 0 0 3px rgba(242,159,143,.14);
  background:#fffdfa;
}
.calendar.card.v5-calendar .day.today .num span{
  width:24px;
  height:24px;
  border-radius:999px;
  background:var(--brand);
  color:white;
  display:inline-grid;
  place-items:center;
}
@media(max-height:760px){
  .calendar.card.v5-calendar{gap:5px;padding:8px;grid-template-rows:auto auto 22px minmax(0,1fr)}
  .calendar.card.v5-calendar .calendar-toolbar h2{font-size:18px}
  .calendar.card.v5-calendar .btn{padding:7px 9px;font-size:13px}
  .calendar.card.v5-calendar .v5-cal-actions{min-height:32px}
  .calendar.card.v5-calendar .cal-head,.calendar.card.v5-calendar .cal-head div{min-height:21px}
  .calendar.card.v5-calendar .event{font-size:11.5px;padding:3px 4px}
  .calendar.card.v5-calendar .day .num em{display:none}
}

/* V5.2 : correction ciblée vues semaine/jour.
   La grille calendrier V5.1 réserve une ligne d'entête pour la vue mois.
   En semaine/jour, il n'y a pas d'entête de jours : on fait donc occuper
   aux vues toute la hauteur restante, sans changement de thème. */
.calendar.card.v5-calendar > .v5-week,
.calendar.card.v5-calendar > .v5-day{
  grid-row:3 / 5;
  height:100%;
  min-height:0;
  align-self:stretch;
}
.calendar.card.v5-calendar > .v5-week{
  grid-template-rows:minmax(0,1fr);
}
.calendar.card.v5-calendar > .v5-day{
  grid-template-rows:minmax(0,1fr);
}
.calendar.card.v5-calendar .v5-week-day,
.calendar.card.v5-calendar .inner-card{
  min-height:0;
  height:100%;
}
.calendar.card.v5-calendar .v5-week-day{
  align-content:start;
}

/* V5.4 : timeline nounou compacte, sans changement de thème. */
.today-grid{grid-template-columns:1fr 1.15fr 1fr}
.today-compact{display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;gap:10px}
.next-event{background:#fff5ef;border:1px solid var(--line);border-radius:18px;padding:12px;display:flex;gap:10px;align-items:flex-start}
.next-event span{width:38px;height:38px;border-radius:14px;background:var(--brand);color:white;display:grid;place-items:center;flex:none}
.next-event b{display:block;font-size:16px;margin-bottom:3px}.next-event p{margin:0;color:var(--muted);font-size:14px;line-height:1.25}
.today-child-list{display:grid;gap:8px;overflow:hidden;min-height:0}
.today-child-row{border:1px solid var(--line);background:white;border-radius:17px;padding:10px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;text-align:left;cursor:pointer;color:var(--ink)}
.today-child-row:hover{outline:2px solid rgba(242,159,143,.28)}
.today-child-main{display:grid;gap:2px;min-width:0}.today-child-main strong{font-size:16px}.today-child-main em{font-style:normal;color:var(--muted);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.today-child-main small{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.full-btn{justify-content:center}.compact-timeline{max-height:none;overflow:auto}
@media(max-height:760px){.next-event{padding:9px}.today-child-row{padding:8px}.today-child-main small{display:none}}

/* Versioning V5.5 */
.title-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.version-badge{font-size:13px;font-weight:800;border:1px solid rgba(99,70,54,.18);background:rgba(255,255,255,.72);color:#7a5545;border-radius:999px;padding:5px 10px;line-height:1}
.version-footer{position:fixed;right:18px;bottom:12px;z-index:30;pointer-events:auto}
.version-footer button{border:1px solid rgba(99,70,54,.16);background:rgba(255,255,255,.78);backdrop-filter:blur(8px);border-radius:999px;padding:7px 11px;font-size:12px;font-weight:800;color:#7a5545;box-shadow:0 10px 30px rgba(98,67,46,.08);cursor:pointer}
.version-panel{padding:16px;border:1px solid rgba(99,70,54,.12);border-radius:18px;background:rgba(255,255,255,.58);margin-bottom:14px}
.version-big{font-size:28px;font-weight:900;color:#6f4b3d;margin-bottom:6px}
.changelog-list{display:grid;gap:10px;max-height:calc(100vh - 240px);overflow:auto;padding-right:4px}
.change-row{border:1px solid rgba(99,70,54,.12);background:rgba(255,255,255,.58);border-radius:16px;padding:12px 14px}
.change-row strong{display:block;font-size:17px;color:#6f4b3d;margin-bottom:4px}
.change-row p{margin:0;color:#7d6a60}

/* V5.7 : onboarding corrigé, sans changement de thème. */
.app-hidden{display:none!important}
.sidebar{overflow:hidden}.brand,.profile-box{flex:0 0 auto}.nav{min-height:0;overflow:auto;padding-right:3px;scrollbar-width:thin}.nav::-webkit-scrollbar,.drawer-body::-webkit-scrollbar,.drawer-actions::-webkit-scrollbar{width:8px}.nav::-webkit-scrollbar-thumb,.drawer-body::-webkit-scrollbar-thumb,.drawer-actions::-webkit-scrollbar-thumb{background:#eadbd2;border-radius:999px}
.version-footer{left:24px;right:auto;bottom:16px;z-index:8}.fab{z-index:12}.toast-root{z-index:50}
.drawer{max-height:100vh;display:grid;grid-template-rows:auto minmax(0,1fr) auto}.drawer-body{min-height:0;overflow:auto}.drawer-actions{min-height:0;max-height:calc(100vh - 210px);overflow:auto;padding-right:4px}
.auth-gate{height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#fff7f2,#f8efe8);color:var(--ink);overflow:auto}.auth-shell{width:min(1060px,96vw);display:grid;grid-template-columns:.95fr 1.05fr;gap:16px}.auth-card{background:rgba(255,253,250,.94);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:22px;min-height:0}.auth-hero{display:grid;align-content:space-between;gap:18px}.auth-hero .brand-mark{width:64px;height:64px;border-radius:22px;font-size:28px}.auth-hero h1{font-size:36px;line-height:1.02;margin:10px 0}.auth-hero p{color:var(--muted);font-size:17px;line-height:1.45}.auth-tabs{display:flex;gap:8px;margin-bottom:14px}.auth-tabs button{border:1px solid var(--line);background:white;border-radius:999px;padding:10px 14px;font-weight:900;color:var(--ink);cursor:pointer}.auth-tabs button.active{background:#fff0e9}.auth-form{display:grid;gap:12px}.auth-form h2{margin:0 0 2px;font-size:24px}.auth-form p{margin:0 0 8px;color:var(--muted)}.auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.auth-code-list{display:grid;gap:8px;margin-top:14px}.auth-code{border:1px solid var(--line);background:white;border-radius:16px;padding:10px 12px;display:flex;justify-content:space-between;gap:12px;align-items:center}.auth-code code{font-weight:900;color:#6f4b3d}.auth-actions{display:flex;gap:8px;flex-wrap:wrap}.session-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff5ef;border-radius:999px;padding:8px 11px;color:var(--muted);font-weight:800}.top-actions .session-chip{max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-error{background:#fff0f0;color:#99413c;border:1px solid #f0b5b0;border-radius:14px;padding:10px 12px;font-weight:800;display:none}.auth-error.show{display:block}.auth-success{background:#edf7f2;color:#2e7a54;border:1px solid #cfe7db;border-radius:14px;padding:10px 12px;font-weight:800}.logout-btn{padding:9px 11px}
@media(max-width:860px){.auth-shell{grid-template-columns:1fr}.auth-hero h1{font-size:30px}.auth-grid{grid-template-columns:1fr}.version-footer{display:none}.top-actions .session-chip{display:none}}
@media(max-height:720px){.auth-gate{place-items:start center}.auth-card{padding:16px}.auth-hero p{font-size:15px}.auth-code-list{max-height:160px;overflow:auto}.profile-box{padding:9px}.nav button{padding:9px 10px;font-size:14.5px}.brand{margin-bottom:8px}.brand-mark{width:42px;height:42px}.brand strong{font-size:21px}.brand span{font-size:12px}}

/* V5.7 : PIN et onglets auth plus robustes */
.pin-input{letter-spacing:.35em;text-align:center;font-weight:900}
.auth-tabs{flex-wrap:wrap}.auth-tabs button{white-space:nowrap}
@media(max-width:620px){.auth-tabs{overflow:auto;flex-wrap:nowrap;padding-bottom:4px}.auth-tabs button{flex:0 0 auto}}

/* V5.9 : onboarding simplifié, sans changement du thème principal */
.auth-shell-simple{grid-template-columns:.82fr 1.18fr;align-items:stretch}
.auth-hero-simple{gap:16px}
.auth-hero-simple h1{margin-bottom:6px}
.auth-choice-stack{display:grid;gap:10px}
.auth-choice{width:100%;border:1px solid var(--line);background:white;border-radius:18px;padding:12px;text-align:left;display:flex;gap:12px;align-items:center;color:var(--ink);cursor:pointer}
.auth-choice i{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:#fff0e9;color:#995244;font-size:18px;flex:none}
.auth-choice strong{display:block;font-size:16px}
.auth-choice small{display:block;color:var(--muted);font-weight:700;margin-top:2px}
.auth-choice.active{outline:2px solid rgba(242,159,143,.45);background:#fff8f4}
@media(max-width:860px){.auth-shell-simple{grid-template-columns:1fr}}

/* V5.10 onboarding */
.compact-choices{gap:10px;margin:14px 0 18px;}
.compact-choices .auth-choice{padding:12px 14px;}
.compact-choices .auth-choice i{font-size:18px;}

/* V5.10.2 — onboarding compact */
.auth-form-centered{align-content:center;min-height:100%;}
.role-card-grid{display:grid;grid-template-columns:1fr;gap:12px;margin:14px 0 6px;}
.role-card{width:100%;border:1px solid var(--line);background:white;border-radius:22px;padding:15px 16px;text-align:left;display:grid;grid-template-columns:52px 1fr;gap:14px;align-items:center;color:var(--ink);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease;}
.role-card:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(75,52,42,.08);background:#fff8f4;}
.role-card i{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:#fff0e9;color:#995244;font-size:21px;}
.role-card strong{display:block;font-size:18px;margin-bottom:2px;}
.role-card small{display:block;color:var(--muted);font-weight:750;line-height:1.35;}
.auth-form-compact{max-width:620px;margin:0 auto;align-content:center;min-height:100%;}
.back-link{border:0;background:transparent;color:var(--muted);font-weight:900;display:inline-flex;gap:8px;align-items:center;padding:0 0 4px;cursor:pointer;width:max-content;}
.back-link:hover{color:var(--ink);}
.signup-heading{display:flex;gap:14px;align-items:center;border:1px solid var(--line);background:#fff8f4;border-radius:22px;padding:14px;margin-bottom:2px;}
.signup-heading>i{width:48px;height:48px;border-radius:17px;display:grid;place-items:center;background:#fff0e9;color:#995244;font-size:20px;flex:none;}
.signup-heading h2{margin:0;font-size:23px;}
.signup-heading p{margin:3px 0 0;font-size:15.5px;}
.signup-fields{display:grid;gap:10px;}
@media(min-width:900px){.role-card-grid{grid-template-columns:1fr;}.auth-form-centered{padding:8px 6px;}}
@media(max-height:720px){.role-card{padding:11px 13px;grid-template-columns:44px 1fr}.role-card i{width:44px;height:44px;border-radius:15px}.role-card strong{font-size:16px}.role-card small{font-size:13px}.signup-heading{padding:11px}.signup-heading>i{width:42px;height:42px}.signup-fields{gap:8px}.auth-form-compact .form-row{gap:5px}}
