@import "./auth-theme.css";
@import "./header.css";

/* =====================================================
   openHealth — Styles  (openFashion architecture)
   Mobile-first · data-module CSS backgrounds · bottom nav
   ===================================================== */
:root {
    --primary:#0284c7; --primary-dark:#0369a1; --primary-light:#e0f2fe;
    --accent:#0d9488; --accent-dark:#0f766e;
    --success:#10b981; --warning:#f59e0b; --danger:#ef4444;
    --slate-50:#f5f5f7; --slate-100:#e8e8ed; --slate-200:#d2d2d7;
    --slate-300:#aeaeb2; --slate-400:#8e8e93; --slate-500:#636366;
    --slate-600:#48484a; --slate-700:#3a3a3c; --slate-800:#2c2c2e; --slate-900:#1d1d1f;
    --bg:#ffffff; --bg-secondary:var(--slate-50);
    --text:var(--slate-800); --text-muted:var(--slate-500); --border:var(--slate-200);
    --radius:16px; --radius-sm:8px; --radius-lg:24px;
    --shadow-sm:0 1px 2px rgba(0,0,0,.05);
    --shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
    --shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
    --header-height:56px; --nav-height:64px;
    --safe-top:env(safe-area-inset-top,0px); --safe-bottom:env(safe-area-inset-bottom,0px);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;overflow-x:hidden;min-height:100dvh}
.hidden{display:none!important}

/* Auth */
.auth-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:linear-gradient(135deg,#0c4a6e 0%,#0369a1 30%,#0284c7 60%,#0891b2 80%,#0d9488 100%);position:relative;overflow:hidden}
.auth-screen::before{content:'';position:absolute;inset:0;background-image:url("https://images.unsplash.com/photo-1519494026892-80bbd2d6fd0d?auto=format&fit=crop&w=1600&q=80");background-size:cover;background-position:center;opacity:.12;z-index:0}
.auth-card{width:100%;max-width:400px;background:rgba(255,255,255,.13);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.22);border-radius:var(--radius-lg);padding:2rem 1.5rem;position:relative;z-index:1;box-shadow:0 24px 64px rgba(0,0,0,.3)}
.auth-logo{width:72px;height:72px;background:white;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;box-shadow:0 8px 32px rgba(0,0,0,.25)}
.auth-logo img{width:54px;height:54px;border-radius:10px;object-fit:cover}
.auth-title{text-align:center;color:white;font-size:1.75rem;font-weight:900;letter-spacing:-.02em;margin-bottom:.25rem}
.auth-subtitle{text-align:center;color:rgba(255,255,255,.7);font-size:.875rem;margin-bottom:1.5rem}
.auth-facility-badge{text-align:center;color:rgba(255,255,255,.92);font-size:.9375rem;font-weight:700;margin-bottom:1.5rem;background:rgba(255,255,255,.12);padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.18)}
.auth-label{display:block;color:rgba(255,255,255,.8);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.4rem}
.auth-input{width:100%;padding:.875rem 1rem;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-sm);color:white;font-size:1rem;font-family:inherit;outline:none;transition:border-color .2s,background .2s;margin-bottom:1rem}
.auth-input::placeholder{color:rgba(255,255,255,.38)}
.auth-input:focus{border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.22)}
.auth-btn{width:100%;padding:1rem;background:white;color:var(--primary);border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:800;cursor:pointer;margin-top:.25rem;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:transform .15s,box-shadow .15s}
.auth-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.auth-btn:active{transform:scale(.98)}
.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.auth-error{color:#fca5a5;font-size:.8125rem;text-align:center;margin:.5rem 0 .75rem}
.auth-switch{text-align:center;margin-top:1rem}
.auth-switch button{background:none;border:none;color:rgba(255,255,255,.65);font-size:.8125rem;cursor:pointer;font-family:inherit;text-decoration:underline;transition:color .15s}
.auth-switch button:hover{color:white}

/* Main app */
.main-app{height:100dvh;display:flex;flex-direction:column;overflow:hidden;position:relative;isolation:isolate}
.main-app::before{content:'';position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:scale(1.04);filter:saturate(1.1) contrast(1.02);z-index:-2}
.main-app::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,105,161,.48) 0%,rgba(3,105,161,.18) 20%,rgba(248,250,252,.90) 48%,rgba(248,250,252,.97) 100%),radial-gradient(circle at top right,rgba(13,148,136,.14),transparent 30%);z-index:-1}

/* Home: beautiful medical image background */
.main-app[data-module="home"]::before{background-image:url("https://images.unsplash.com/photo-1530497610245-94d3c16cda28?auto=format&fit=crop&w=1600&q=80")}
/* Modules: clean solid accent colour — no distracting image */
.main-app:not([data-module="home"])::before{background-image:none!important;filter:none;transform:none}
.main-app[data-module="mpi"]::before{background-color:#eff6ff}
.main-app[data-module="opd"]::before{background-color:#f0fdf4}
.main-app[data-module="appointments"]::before{background-color:#ecfeff}
.main-app[data-module="referrals"]::before{background-color:#eef2ff}
.main-app[data-module="lab"]::before{background-color:#faf5ff}
.main-app[data-module="bloodbank"]::before{background-color:#fff1f2}
.main-app[data-module="pharmacy"]::before{background-color:#fdf4ff}
.main-app[data-module="stores"]::before{background-color:#fff7ed}
.main-app[data-module="reports"]::before{background-color:#f0f9ff}
.main-app[data-module="hiv"]::before{background-color:#fef2f2}
.main-app[data-module="mch"]::before{background-color:#fdf4ff}
/* Modules: overlay is solid light — forms/text fully readable */
.main-app:not([data-module="home"])::after{background:#f8fafc}

/* Header */
.mobile-header{position:sticky;top:0;min-height:calc(var(--header-height) + var(--safe-top));background:rgba(255,255,255,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.07);display:flex;align-items:center;padding:calc(var(--safe-top) + 6px) .75rem 8px;gap:.5rem;z-index:100}
.mobile-header__back{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--primary);font-size:1.25rem;border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}
.mobile-header__back:hover{background:var(--bg-secondary)}
.mobile-header__brand{flex:1;display:flex;align-items:center;gap:.625rem;cursor:pointer;min-width:0;-webkit-tap-highlight-color:transparent}
.mobile-header__logo{width:34px;height:34px;flex-shrink:0;border-radius:8px;overflow:hidden}
.mobile-header__logo img{width:100%;height:100%;object-fit:cover}
.mobile-header__info{min-width:0}
#header-title{font-size:.9375rem;font-weight:800;color:var(--text);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#header-subtitle{font-size:.6875rem;color:var(--text-muted);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-header__actions{display:flex;gap:.25rem;flex-shrink:0}
.mobile-header__btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text);font-size:1.25rem;border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}
.mobile-header__btn:hover{background:var(--bg-secondary)}

/* Content */
.content{flex:1;min-height:0;overflow-y:auto;padding-bottom:calc(var(--nav-height) + max(var(--safe-bottom),8px) + 16px);position:relative;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}
.content.module-active{padding-bottom:0;overflow:hidden}

/* Hub */
.hub-header{padding:1.5rem 1rem .75rem;max-width:640px;margin:0 auto;width:100%}
.hub-greeting{font-size:.6875rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.08em}
.hub-title{font-size:1.625rem;font-weight:900;color:var(--slate-900);line-height:1.2;margin-top:.125rem}
.hub-facility{font-size:.8125rem;color:var(--text-muted);margin-top:.25rem}
.hub-section{padding:0 1rem;margin-bottom:1.25rem;max-width:640px;margin-left:auto;margin-right:auto;width:100%}
.hub-section-label{font-size:.6rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-400);display:flex;align-items:center;gap:.5rem;margin-bottom:.625rem}
.hub-section-label::after{content:'';flex:1;height:1px;background:var(--border)}
.hub-section-note{font-size:.6875rem;color:#94a3b8;margin-bottom:.625rem;line-height:1.5}
.hub-cards{display:flex;flex-direction:column;gap:.5rem}
@media(min-width:600px){.hub-cards{display:grid;grid-template-columns:1fr 1fr;gap:.625rem}}
.hub-card{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:rgba(255,255,255,.78);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(0,0,0,.055);border-radius:var(--radius);cursor:pointer;text-decoration:none;color:inherit;text-align:left;width:100%;font-family:inherit;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s,background .15s;-webkit-tap-highlight-color:transparent}
.hub-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);background:rgba(255,255,255,.94)}
.hub-card:active{transform:scale(.97);box-shadow:none}
.hub-card-icon{width:2.5rem;height:2.5rem;flex-shrink:0;border-radius:.75rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem}
.hub-card-body{flex:1;min-width:0}
.hub-card-name{font-size:.875rem;font-weight:700;color:var(--slate-900);line-height:1.2;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.hub-card-desc{font-size:.6875rem;color:var(--text-muted);margin-top:.1rem;line-height:1.4}
.hub-card-chevron{color:var(--slate-300);font-size:.875rem;flex-shrink:0}
.hub-card-badge{font-size:.5rem;font-weight:800;padding:.15rem .45rem;border-radius:.25rem;line-height:1.5}

/* Bottom nav */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + max(var(--safe-bottom),8px));padding-bottom:max(var(--safe-bottom),8px);background:rgba(255,255,255,.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;z-index:100;transition:transform .25s ease,opacity .25s ease}
.bottom-nav.is-hidden{transform:translateY(100%);opacity:0;pointer-events:none}
.nav-item{flex:1;border:none;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;color:var(--text-muted);font-size:.6rem;font-weight:700;cursor:pointer;font-family:inherit;text-transform:uppercase;letter-spacing:.05em;-webkit-tap-highlight-color:transparent;transition:color .15s}
.nav-item i{font-size:1.375rem}
.nav-item.active{color:var(--primary)}
@media(min-width:768px){
    .bottom-nav{top:var(--header-height);bottom:0;left:0;width:72px;height:auto;flex-direction:column;padding-bottom:0;padding-top:.75rem;border-top:none;border-right:1px solid var(--border);transform:none!important;opacity:1!important}
    .content{margin-left:72px;padding-bottom:2rem}
    .content.module-active{margin-left:72px}
    .nav-item span{display:none}
    .nav-item{font-size:0;padding:.875rem 0}
    .nav-item i{font-size:1.5rem}
}

/* Side menu */
.side-menu{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.48);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.side-menu-content{position:absolute;top:0;right:0;bottom:0;width:300px;max-width:85vw;background:var(--bg);animation:slideInRight .22s ease;display:flex;flex-direction:column;overflow:hidden}
@keyframes slideInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
.side-menu-header{padding:calc(var(--safe-top) + 1.75rem) 1.25rem 1.375rem;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 50%,var(--accent) 100%);flex-shrink:0}
.menu-user{display:flex;align-items:center;gap:.875rem;color:white}
.menu-avatar{width:48px;height:48px;background:rgba(255,255,255,.22);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800;flex-shrink:0}
.menu-user-details h3{font-weight:700;font-size:.9375rem}
.menu-user-details p{opacity:.72;font-size:.75rem;margin-top:.1rem}
.side-menu-nav{flex:1;overflow-y:auto;padding:.5rem 0}
.menu-section-label{font-size:.6rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-400);padding:.75rem 1.25rem .25rem}
.side-menu-nav button,.side-menu-nav a{display:flex;align-items:center;gap:.875rem;width:100%;padding:.75rem 1.25rem;border:none;background:transparent;color:var(--text);font-size:.875rem;font-weight:500;text-align:left;cursor:pointer;text-decoration:none;transition:background .15s;font-family:inherit;-webkit-tap-highlight-color:transparent}
.side-menu-nav button:hover,.side-menu-nav a:hover{background:var(--bg-secondary)}
.side-menu-nav button i,.side-menu-nav a i{font-size:1.125rem;color:var(--text-muted);flex-shrink:0}
.menu-divider{height:1px;background:var(--border);margin:.375rem 1.25rem}
.side-menu-footer{padding:.875rem 1.25rem calc(.875rem + var(--safe-bottom));border-top:1px solid var(--border);flex-shrink:0}
.side-menu-footer button{display:flex;align-items:center;gap:.75rem;color:var(--danger);font-size:.875rem;font-weight:600;background:none;border:none;cursor:pointer;font-family:inherit;padding:.5rem 0;-webkit-tap-highlight-color:transparent}
.side-menu-footer button i{font-size:1.125rem}

/* Toast */
#toast-container{position:fixed;top:1rem;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:.5rem;align-items:center;pointer-events:none}
.oh-toast{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:var(--slate-900);color:white;border-radius:9999px;box-shadow:0 8px 32px rgba(0,0,0,.3);font-size:.875rem;font-weight:500;white-space:nowrap;pointer-events:auto;animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;pointer-events:none}}

/* Offline */
.offline-badge{position:fixed;bottom:calc(var(--nav-height) + 12px);left:50%;transform:translateX(-50%);padding:.5rem 1rem;border-radius:9999px;font-size:.6875rem;font-weight:700;z-index:150;transition:opacity .3s;white-space:nowrap}
.offline-badge.badge--offline{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}
.offline-badge.badge--hidden{opacity:0;pointer-events:none}

/* ── Module scaffold ───────────────────────────────────── */
.module-mobile-nav{display:none!important}
.module-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1rem;text-align:center}
.module-search-input{width:100%;padding:.625rem .875rem .625rem 2.5rem;border:1.5px solid #e2e8f0;border-radius:.75rem;font-size:.9375rem;font-family:inherit;outline:none;background:#fff;color:#1e293b}
.module-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(2,132,199,.12)}
.module-mobile-button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent;border:none;color:#64748b;cursor:pointer;font-family:inherit;font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.5rem;-webkit-tap-highlight-color:transparent;transition:color .15s}
.module-mobile-button.is-active,.module-mobile-button:has(i.active){color:var(--primary)}
.module-status-pill{background:var(--primary-light);color:var(--primary);font-weight:600}
.module-heading-icon{color:var(--primary);flex-shrink:0}
.native-scroll{-webkit-overflow-scrolling:touch}
/* ── KPI Cards ──────────────────────────────────────────── */
.kpi-card{background:white;border:1px solid var(--kpi-accent-border,#e2e8f0);border-radius:.875rem;padding:.875rem 1rem;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.kpi-card__meta{display:flex;align-items:center;gap:.625rem;margin-bottom:.375rem}
.kpi-icon{width:2.25rem;height:2.25rem;border-radius:.625rem;display:flex;align-items:center;justify-content:center;background:var(--kpi-accent-soft,#e0f2fe);color:var(--kpi-accent,var(--primary));font-size:1.125rem;flex-shrink:0}
.kpi-label{font-size:.625rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;line-height:1.3}
.kpi-value{font-size:1.5rem;font-weight:900;color:#1e293b;letter-spacing:-.02em;line-height:1}
/* ── Form Components ────────────────────────────────────── */
.form-label{display:block;font-size:.75rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.375rem}
.form-input{width:100%;padding:.75rem 1rem;border:1.5px solid #e2e8f0;border-radius:.75rem;font-size:1rem;font-family:inherit;color:#1e293b;background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}
.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(2,132,199,.12)}
.form-input::placeholder{color:#94a3b8}
select.form-input{cursor:pointer}
textarea.form-input{resize:vertical;min-height:80px}
/* ── Radio Chips ────────────────────────────────────────── */
.radio-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.25rem}
.radio-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .875rem;border:1.5px solid #e2e8f0;border-radius:9999px;font-size:.8125rem;font-weight:600;color:#475569;background:#f8fafc;cursor:pointer;transition:all .15s;font-family:inherit;-webkit-tap-highlight-color:transparent;line-height:1.4}
.radio-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.radio-chip.selected{border-color:var(--primary);color:white;background:var(--primary)}

/* Utility */
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.spin{animation:spin 1s linear infinite}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius-sm);border:none;font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s,transform .1s}
.btn-primary{background:var(--primary);color:white}
.btn-primary:hover{background:var(--primary-dark)}
.btn-secondary{background:var(--bg-secondary);color:var(--text)}
.btn-sm{padding:.4rem .75rem;font-size:.8125rem}
