/* =====================================================================
   AfyaMate — custom styles (mobile-first)
   Palette: Afya Blue #0E6EB8 • Deep Navy #0B2942 • Teal #18A999
   Fonts:   Sora (display) + Inter (body) — see README for self-hosting
   ===================================================================== */
:root{
  --am-primary:#0E6EB8;
  --am-primary-600:#0C5E9E;
  --am-primary-100:#E9F4FC;
  --am-navy:#0B2942;
  --am-navy-700:#10334F;
  --am-accent:#18A999;
  --am-amber:#D97706;
  --am-red:#DC2626;
  --am-ink:#13202E;
  --am-muted:#5B6B7B;
  --am-line:#E4E9EF;
  --am-radius:14px;
  --am-font-display:'Sora',system-ui,sans-serif;
  --am-font-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--am-font-body);color:var(--am-ink);background:#fff;margin:0;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,.display-font{font-family:var(--am-font-display);letter-spacing:-.01em}
a{color:var(--am-primary)}
.text-muted{color:var(--am-muted)!important}

/* Buttons */
.btn{border-radius:10px;font-weight:600;padding:.55rem 1.1rem}
.btn-primary{background:var(--am-primary);border-color:var(--am-primary)}
.btn-primary:hover,.btn-primary:focus{background:var(--am-primary-600);border-color:var(--am-primary-600)}
.btn-outline-primary{color:var(--am-primary);border-color:var(--am-primary)}
.btn-outline-primary:hover{background:var(--am-primary);border-color:var(--am-primary)}
.btn-accent{background:var(--am-accent);border:none;color:#fff}
.btn-accent:hover{background:#128f81;color:#fff}

/* Cards */
.card{border:1px solid var(--am-line);border-radius:var(--am-radius);box-shadow:0 1px 2px rgba(11,41,66,.05)}
.card-header{background:#fff;border-bottom:1px solid var(--am-line);font-family:var(--am-font-display);font-weight:600}
.stat-card{position:relative;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}
.stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(11,41,66,.10)}
.stat-card .stat-icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:1.15rem;color:#fff}
.stat-card .stat-num{font-family:var(--am-font-display);font-size:1.65rem;font-weight:700}
.stat-card::after{content:"";position:absolute;right:-28px;top:-28px;width:96px;height:96px;border-radius:50%;background:var(--am-primary-100);opacity:.6;z-index:0}
.stat-card>*{position:relative;z-index:1}

/* ---------------- App shell ---------------- */
.app-shell{min-height:100vh;display:flex}
.sidebar{
  position:fixed;inset:0 auto 0 0;width:262px;z-index:1045;
  background:
    radial-gradient(circle at 88% 8%, rgba(24,169,153,.14), transparent 38%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.022) 0 2px, transparent 2px 26px),
    var(--am-navy);
  color:#CBD5E1;display:flex;flex-direction:column;
  transform:translateX(-100%);transition:transform .25s ease;
}
.sidebar.open{transform:translateX(0)}
.sidebar .brand{display:flex;align-items:center;gap:.65rem;padding:1.05rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar .brand img{height:74px}
.sidebar .brand .name{font-family:var(--am-font-display);font-weight:700;color:#fff;font-size:1.1rem}
.sidebar .hospital-tag{font-size:.72rem;color:#7FB3D8;display:block}
.sidebar nav{flex:1;overflow-y:auto;padding:.8rem .7rem}
.side-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:#5E7A93;padding:.85rem .6rem .3rem}
.side-link{display:flex;align-items:center;gap:.75rem;color:#C7D6E2;text-decoration:none;
  padding:.6rem .75rem;border-radius:10px;font-size:.92rem;margin-bottom:2px;transition:background .15s,color .15s}
.side-link i{width:20px;text-align:center;font-size:.95rem;color:#7FB3D8}
.side-link:hover{background:rgba(255,255,255,.07);color:#fff}
.side-link.active{background:var(--am-primary);color:#fff}
.side-link.active i{color:#fff}
.sidebar .side-foot{padding:.9rem 1.2rem;border-top:1px solid rgba(255,255,255,.08);font-size:.75rem;color:#5E7A93}
.sidebar-backdrop{position:fixed;inset:0;background:rgba(11,41,66,.5);z-index:1040;opacity:0;pointer-events:none;transition:opacity .2s}
.sidebar-backdrop.show{opacity:1;pointer-events:auto}

.main-area{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}
.topbar{position:sticky;top:0;z-index:1030;background:#fff;border-bottom:1px solid var(--am-line);
  display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem}
.topbar .page-title{font-family:var(--am-font-display);font-weight:700;font-size:1.05rem;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.burger{border:1px solid var(--am-line);background:#fff;border-radius:10px;width:40px;height:40px;display:grid;place-items:center;color:var(--am-navy)}
.user-chip{display:flex;align-items:center;gap:.55rem;margin-left:auto;text-decoration:none;color:var(--am-ink)}
.user-chip .avatar{width:36px;height:36px;border-radius:50%;background:var(--am-primary);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--am-font-display)}
.content{padding:1rem;flex:1}
.app-footer{background:var(--am-navy);color:#9FB4C6;font-size:.8rem;padding:.85rem 1rem;text-align:center}

/* Global fuzzy search box */
.global-search{position:relative;flex:1;max-width:520px}
.global-search input{border-radius:12px;border:1px solid var(--am-line);background:#F7FAFC;padding-left:2.4rem}
.global-search .fa-magnifying-glass{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--am-muted)}
.search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--am-line);
  border-radius:12px;box-shadow:0 16px 38px rgba(11,41,66,.14);max-height:340px;overflow:auto;display:none;z-index:1050}
.search-results.show{display:block}
.search-results a{display:flex;justify-content:space-between;gap:.6rem;padding:.65rem .9rem;color:var(--am-ink);text-decoration:none;border-bottom:1px solid var(--am-line);font-size:.9rem}
.search-results a:last-child{border-bottom:0}
.search-results a:hover{background:var(--am-primary-100)}
.search-results .sub{color:var(--am-muted);font-size:.78rem}

/* ---------------- Tables: cards on mobile ---------------- */
.table-wrap{overflow-x:auto;border:1px solid var(--am-line);border-radius:var(--am-radius);background:#fff}
.table{margin:0}
.table thead th{background:var(--am-primary-100);color:var(--am-navy);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.06em;border-bottom:0;white-space:nowrap;font-family:var(--am-font-display)}
.table td{vertical-align:middle;font-size:.9rem}
.table tbody tr{transition:background .12s}
.table tbody tr:hover{background:#F7FBFE}
@media (max-width:767.98px){
  .table-cards thead{display:none}
  .table-cards tbody tr{display:block;border-bottom:8px solid #F1F5F9;padding:.4rem .2rem}
  .table-cards tbody td{display:flex;justify-content:space-between;gap:1rem;border:0;padding:.35rem .75rem}
  .table-cards tbody td::before{content:attr(data-label);font-weight:600;color:var(--am-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
  .table-cards tbody td.actions-cell{justify-content:flex-end}
}

/* Badges for statuses */
.badge{font-weight:600;border-radius:999px;padding:.38em .8em}
.bg-stage{background:var(--am-primary-100);color:var(--am-primary-600)}
.bg-ok{background:#E7F6F0;color:#0F7B5F}
.bg-warn{background:#FEF3E2;color:#B45309}
.bg-bad{background:#FDECEC;color:#B91C1C}

/* Forms */
.form-label{font-weight:600;font-size:.85rem;color:var(--am-navy)}
.form-control,.form-select{border-radius:10px;border-color:var(--am-line);padding:.55rem .8rem}
.form-control:focus,.form-select:focus{border-color:var(--am-primary);box-shadow:0 0 0 .2rem rgba(14,110,184,.12)}
.input-group-text{border-radius:10px;border-color:var(--am-line);background:#F7FAFC}

/* Section heading with rule */
.section-head{display:flex;align-items:center;gap:.7rem;margin:1.4rem 0 .8rem}
.section-head h2,.section-head h5{margin:0}
.section-head::after{content:"";flex:1;height:1px;background:var(--am-line)}

/* Subtle animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.fade-up{animation:fadeUp .35s ease both}
.fade-up-1{animation-delay:.05s}.fade-up-2{animation-delay:.12s}.fade-up-3{animation-delay:.19s}.fade-up-4{animation-delay:.26s}
@media (prefers-reduced-motion:reduce){.fade-up,.stat-card{animation:none;transition:none}}

/* ---------------- Auth pages ---------------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:1.25rem;background:
  radial-gradient(640px 320px at 12% -8%, var(--am-primary-100), transparent),
  radial-gradient(540px 300px at 105% 108%, #E5F6F3, transparent), #fff}
.auth-card{width:100%;max-width:430px;border:1px solid var(--am-line);border-radius:18px;background:#fff;
  box-shadow:0 22px 60px rgba(11,41,66,.10);padding:1.8rem;animation:fadeUp .4s ease both}
.auth-card .logo{height:74px;margin-bottom:.9rem}

/* ---------------- Landing page ---------------- */
.land-nav{background:#fff;border-bottom:1px solid var(--am-line)}
.hero{position:relative;overflow:hidden;background:
  radial-gradient(circle at 86% 18%, rgba(14,110,184,.10), transparent 42%),
  radial-gradient(circle at 6% 90%, rgba(24,169,153,.10), transparent 40%), #fff;
  padding:4rem 0 4.5rem}
.hero .ring{position:absolute;border:2px dashed rgba(14,110,184,.18);border-radius:50%;pointer-events:none}
.hero .ring.r1{width:340px;height:340px;right:-90px;top:-90px}
.hero .ring.r2{width:200px;height:200px;left:-60px;bottom:-60px;border-color:rgba(24,169,153,.22)}
.hero h1{font-size:clamp(1.9rem,4.6vw,3.1rem);font-weight:800;line-height:1.12}
.hero .lead{color:var(--am-muted);max-width:34rem}
.hero .word-accent{color:var(--am-primary);position:relative}
.feature-tile{border:1px solid var(--am-line);border-radius:var(--am-radius);padding:1.3rem;height:100%;transition:transform .18s,box-shadow .18s;background:#fff}
.feature-tile:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(11,41,66,.09)}
.feature-tile .ic{width:46px;height:46px;border-radius:12px;background:var(--am-primary-100);color:var(--am-primary);display:grid;place-items:center;font-size:1.15rem;margin-bottom:.85rem}
.land-footer{background:var(--am-navy);color:#9FB4C6;padding:2.4rem 0 1.4rem}
.land-footer a{color:#CBD5E1;text-decoration:none}
.land-footer a:hover{color:#fff}

/* Queue / patient journey timeline */
.journey{display:flex;gap:.45rem;flex-wrap:wrap}
.journey .step{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--am-muted);
  background:#F4F8FB;border:1px solid var(--am-line);border-radius:999px;padding:.3rem .75rem}
.journey .step.done{background:#E7F6F0;color:#0F7B5F;border-color:#BEE7D8}
.journey .step.now{background:var(--am-primary);color:#fff;border-color:var(--am-primary)}

/* Bed grid (ward view) */
.bed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(106px,1fr));gap:.7rem}
.bed{border:1px solid var(--am-line);border-radius:12px;padding:.8rem .5rem;text-align:center;font-size:.85rem;background:#fff;transition:transform .15s}
.bed:hover{transform:translateY(-2px)}
.bed i{font-size:1.3rem;display:block;margin-bottom:.35rem}
.bed.available i{color:var(--am-accent)} .bed.occupied i{color:var(--am-red)} .bed.maintenance i{color:var(--am-amber)}

/* Print */
@media print{.sidebar,.topbar,.app-footer,.no-print{display:none!important}.content{padding:0}}

/* ---------------- Desktop ---------------- */
@media (min-width: 992px){
  .sidebar{transform:none;position:sticky;top:0;height:100vh}
  .sidebar-backdrop{display:none}
  .burger{display:none}
  .content{padding:1.6rem 2rem}
  .topbar{padding:.7rem 2rem}
}

/* ---- Additions for app module pages ---- */
/* Standalone stat cards (icon + number + label) used across module dashboards */
.stat-card:not(.card){background:#fff;border:1px solid var(--am-line);border-radius:16px;padding:1rem 1.1rem;
  display:flex;align-items:center;gap:.85rem;color:inherit;text-decoration:none;width:100%}
.stat-card:not(.card)>i.fa-solid{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  font-size:1.15rem;color:#fff;background:var(--am-primary);flex:none}
.stat-card .num{font-family:var(--am-font-display);font-size:1.5rem;font-weight:700;display:block;line-height:1.12}
.stat-card .lbl{font-size:.8rem;color:var(--am-muted)}
a.stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(11,41,66,.10)}

/* Extra badge tones */
.bg-info{background:#E6F1FB;color:var(--am-primary-600)}
.bg-primary{background:var(--am-primary)!important;color:#fff}
.bg-purple{background:#EFE9FB;color:#6D28D9}
.bg-teal{background:#E1F6F2;color:#0E8C7E}

/* Generic avatar (patient files, visit strip) */
.avatar{width:42px;height:42px;border-radius:50%;background:var(--am-primary);color:#fff;display:inline-grid;
  place-items:center;font-weight:700;font-family:var(--am-font-display);flex:none}
.avatar-lg{width:74px;height:74px;font-size:1.7rem}

/* Teal button */
.btn-teal{background:var(--am-accent);border-color:var(--am-accent);color:#fff}
.btn-teal:hover,.btn-teal:focus{filter:brightness(.94);color:#fff}

/* Journey step numbered dots (visit page reuses .journey .step) */
.journey .step .dot{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:.72rem;
  font-weight:700;background:#fff;border:1px solid currentColor}
.journey .step.now .dot{background:#fff;color:var(--am-primary)}
.journey .step.done .dot{background:#0F7B5F;color:#fff;border-color:#0F7B5F}

/* Search-select (single + multi, with optional "add new") */
.ss{position:relative}
.ss .ss-toggle{display:flex;align-items:center;width:100%;min-height:38px;background:#fff;background-image:none}
.ss .ss-toggle.form-select{padding-right:.85rem}
.ss .ss-toggle::after{content:"";margin-left:.5rem;border:.3em solid transparent;border-top-color:currentColor;opacity:.55;transition:transform .15s}
.ss.ss-open .ss-toggle::after{transform:rotate(180deg)}
.ss .ss-label{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--am-ink)}
.ss .ss-label.placeholder{color:#7a8896}
.ss .ss-pop{
  display:none;position:absolute;left:0;top:calc(100% + 4px);z-index:1100;
  background:#fff;border:1px solid var(--am-line);border-radius:10px;
  box-shadow:0 10px 28px rgba(11,41,66,.16);padding:.45rem;
  min-width:100%;                       /* never narrower than the trigger */
  width:max(100%, 340px);               /* expand past the trigger on desktop */
  max-width:min(480px, 92vw);           /* but stay within the viewport on mobile */
}
.ss.ss-open .ss-pop{display:block}
.ss .ss-q{margin-bottom:.4rem}
.ss .ss-opts{max-height:240px;overflow:auto}
.ss .ss-opt{
  display:flex;align-items:center;gap:.5rem;width:100%;
  padding:.4rem .55rem;border:0;background:transparent;
  border-radius:8px;text-align:left;font-size:.88rem;cursor:pointer;color:var(--am-ink);line-height:1.3;
}
.ss .ss-opt:hover{background:var(--am-primary-100)}
.ss .ss-opt.on{background:var(--am-primary-100);font-weight:600}
.ss .ss-opt input[type=checkbox]{flex-shrink:0;accent-color:var(--am-primary)}
.ss .ss-opt.ss-new{color:var(--am-primary);font-weight:600}
.ss .ss-opt .ss-hint{margin-left:auto;padding-left:.75rem;font-weight:400;font-size:.74rem;color:var(--am-muted);white-space:nowrap}
.ss .ss-newgroup{margin-top:.35rem;border-top:1px dashed var(--am-line);padding-top:.35rem;display:grid;gap:.15rem}
.ss .ss-empty{padding:.6rem .5rem;font-size:.85rem;text-align:center;color:var(--am-muted)}
.ss .ss-done{display:flex;width:100%;justify-content:center;margin-top:.35rem;padding:.45rem;
  border:0;border-top:1px solid var(--am-line);background:transparent;color:var(--am-primary);
  font-weight:600;cursor:pointer;font-size:.82rem;border-radius:0 0 9px 9px}
.ss .ss-done:hover{background:var(--am-primary-100)}

/* Button "is loading" state — animated typing dots appended after the label.
   The button stays clickable on the keyboard but pointer-events are blocked so
   accidental double-submits don't happen. Width is animated in steps so the
   dots appear one at a time, classic IM typing-dots look. */
.btn.is-loading{pointer-events:none;opacity:.9}
.btn.is-loading::after{
  content:'...';
  display:inline-block;
  margin-left:.4rem;
  width:1.4em;
  text-align:left;
  overflow:hidden;
  vertical-align:bottom;
  animation:btn-typing 1.2s steps(4) infinite;
}
@keyframes btn-typing{from{width:0}to{width:1.4em}}
