:root{color-scheme:light;--bg: #f4f8f7;--surface: #ffffff;--text: #0f172a;--muted: #64748b;--border: #dbe7e4;--brand: #0f766e;--brand-dark: #115e59;--brand-soft: #ccfbf1;--danger: #b91c1c;--radius: 16px;--shadow: 0 12px 40px rgba(15, 23, 42, .08);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;overflow-x:hidden;-webkit-text-size-adjust:100%}button,input,select,textarea{font:inherit;font-size:16px}a{color:var(--brand)}.muted{color:var(--muted);line-height:1.6}.full-center{min-height:60vh;display:grid;place-items:center}.auth-page{min-height:100dvh;display:grid;place-items:center;padding:calc(1rem + var(--safe-top)) 1rem calc(1rem + var(--safe-bottom));background:radial-gradient(circle at top left,var(--brand-soft),transparent 40%),var(--bg)}.auth-card{width:min(420px,100%);background:#fffffff2;border:1px solid var(--border);border-radius:24px;padding:2rem;box-shadow:var(--shadow);display:grid;gap:1rem}.auth-card h1{margin:0;font-size:1.5rem;letter-spacing:-.03em}.auth-form{display:grid;gap:.85rem}.field{display:grid;gap:.35rem}.field span{font-size:.85rem;font-weight:700;color:#334155}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:.7rem .85rem;background:#fff;outline:none;min-height:44px}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0f766e26}.btn{border:0;border-radius:12px;padding:.75rem 1rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:44px;touch-action:manipulation}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark)}.btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border)}.btn-danger{background:#fee2e2;color:var(--danger)}.shell{min-height:100dvh;display:grid;grid-template-columns:280px 1fr}.shell-sidebar{position:sticky;top:0;height:100dvh;display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#ffffffeb;border-inline-end:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.shell-brand{display:flex;align-items:center;gap:.75rem;padding:.5rem}.shell-brand strong{display:block;font-size:.95rem;color:#166534}.shell-brand-sub{display:block;font-size:.75rem;color:var(--muted);margin-top:.15rem}.shell-nav{display:flex;flex-direction:column;gap:.25rem;flex:1;overflow:auto}.shell-nav-link{display:flex;align-items:center;gap:.5rem;padding:.65rem .75rem;border-radius:12px;text-decoration:none;color:#334155;font-weight:600;font-size:.9rem}.shell-nav-link:hover,.shell-nav-link.active{background:var(--brand);color:#fff}.shell-footer{display:grid;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border)}.shell-signout{width:100%}.shell-main{display:flex;flex-direction:column;min-width:0}.shell-topbar{padding:calc(.85rem + var(--safe-top)) 1.25rem .75rem;border-bottom:1px solid var(--border);background:#f4f8f7d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.shell-greeting{margin:0;font-weight:800;font-size:1.1rem}.shell-role{margin:.2rem 0 0;font-size:.85rem;color:var(--muted)}.shell-content{flex:1;padding:1rem 1.25rem calc(5.5rem + var(--safe-bottom));min-width:0}.shell-mobile-nav{display:none}.page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.page-header h1{margin:0;font-size:clamp(1.35rem,4vw,1.85rem);letter-spacing:-.03em}.page-header-actions{display:flex;gap:.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem;margin-bottom:1rem}.card-title{margin:0 0 .75rem;font-size:1rem}.card-body{min-width:0}.grid-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.stat-value{margin:0;font-size:2rem;font-weight:800;letter-spacing:-.04em}.form-row{display:grid;gap:.75rem}@media(min-width:640px){.form-row{grid-template-columns:1fr 1fr auto;align-items:end}}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px;border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;min-width:480px;font-size:.9rem}.data-table th,.data-table td{padding:.65rem .75rem;text-align:start;border-bottom:1px solid #edf2f7}.data-table th{background:#f1f5f9;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:#475569}.dl-grid{display:grid;grid-template-columns:140px 1fr;gap:.5rem 1rem;margin:0}.dl-grid dt{font-weight:700;color:var(--muted);font-size:.85rem}.more-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem}.more-tile{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem .5rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);text-decoration:none;color:var(--text);font-weight:700;font-size:.8rem;text-align:center}.more-tile:hover,.more-tile.active{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-dark)}@media(max-width:900px){.shell{grid-template-columns:1fr}.shell-sidebar{display:none}.shell-mobile-nav{display:flex;position:fixed;inset-inline:0;bottom:0;z-index:40;padding:.35rem calc(.5rem + var(--safe-right)) calc(.45rem + var(--safe-bottom)) calc(.5rem + var(--safe-left));background:#fffffff7;border-top:1px solid var(--border);box-shadow:0 -8px 30px #0f172a14;justify-content:space-around;gap:.25rem}.shell-mobile-link{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.35rem;font-size:.62rem;font-weight:700;color:#475569;text-decoration:none;border-radius:10px}.shell-mobile-link.active{background:var(--brand-soft);color:var(--brand-dark)}.shell-content{padding-bottom:calc(5rem + var(--safe-bottom))}}@media print{.shell-sidebar,.shell-mobile-nav,.shell-topbar,.page-header-actions{display:none!important}.shell{grid-template-columns:1fr}.shell-content{padding:0}}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{overflow-x:hidden}button,input,select,textarea{font-size:16px}button{min-height:44px;touch-action:manipulation}.brand-mark{background:#fff url(/icon.svg) center/cover no-repeat;color:transparent;border:1px solid rgba(15,118,110,.2);box-shadow:0 14px 35px #0f766e29;overflow:hidden}.brand-mark.small{width:48px;height:48px;border-radius:16px}.auth-card .brand-mark{width:150px;height:150px;border-radius:28px;justify-self:center}.auth-card h1,.sidebar-brand strong{color:#166534}.patient-file-hint{margin:.6rem 0 .85rem;padding:.75rem .9rem;border-radius:14px;background:#ecfeff;color:#0f766e;border:1px solid rgba(15,118,110,.18);font-weight:750}.patient-file-modal{position:fixed;inset:0;z-index:9999;display:grid;place-items:end center;padding:1rem;background:#0f172a6b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.patient-file-sheet{width:min(720px,100%);max-height:min(88dvh,760px);overflow:auto;background:#fff;color:#0f172a;border-radius:28px;padding:1rem;box-shadow:0 30px 80px #0f172a47}.patient-file-header{display:flex;align-items:center;gap:.9rem;padding:.75rem;background:linear-gradient(135deg,#ecfeff,#f0fdf4);border-radius:22px;margin-bottom:.9rem}.patient-file-avatar{width:64px;height:64px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(135deg,#0f766e,#0ea5b7);color:#fff;font-size:1.9rem;font-weight:900;flex:0 0 auto}.patient-file-header h2{margin:.1rem 0;font-size:1.55rem}.patient-file-header p,.patient-file-header small{color:#64748b;margin:0}.patient-file-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}.patient-file-grid>div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:.85rem;display:grid;gap:.25rem}.patient-file-grid span{color:#64748b;font-size:.82rem;font-weight:700}.patient-file-grid strong{color:#0f172a;line-height:1.45;word-break:break-word}.patient-file-actions{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin-top:.9rem}@media(max-width:820px){body{background:#f6faf9;overscroll-behavior-y:none}.app{display:block;min-height:100dvh;padding-bottom:calc(76px + var(--safe-bottom))}.sidebar{position:fixed;inset:auto 0 0;z-index:50;height:auto;width:100%;padding:.38rem calc(.45rem + var(--safe-right)) calc(.38rem + var(--safe-bottom)) calc(.45rem + var(--safe-left));border:1px solid rgba(219,231,228,.95);border-bottom:0;border-radius:22px 22px 0 0;box-shadow:0 -14px 44px #0f172a1f;background:#fffffff7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);overflow:hidden}[dir=rtl] .sidebar{border-left:1px solid rgba(219,231,228,.95)}.sidebar-brand,.sidebar-footer{display:none!important}.sidebar nav,nav{display:flex!important;flex-wrap:nowrap;gap:.36rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0 .05rem}.sidebar nav::-webkit-scrollbar,nav::-webkit-scrollbar{display:none}nav button{flex:0 0 74px;min-width:74px;max-width:74px;min-height:56px;padding:.38rem .18rem;border-radius:16px;flex-direction:column;justify-content:center;gap:.16rem;font-size:.66rem;line-height:1.05;text-align:center}nav .nav-active,nav button:hover{transform:none}nav button svg{width:18px;height:18px}.content{padding:calc(.85rem + var(--safe-top)) calc(.75rem + var(--safe-right)) calc(1rem + 76px + var(--safe-bottom)) calc(.75rem + var(--safe-left));min-width:0;width:100%}.topbar{position:sticky;top:0;z-index:20;margin:calc(-.85rem - var(--safe-top)) calc(-.75rem - var(--safe-right)) .85rem calc(-.75rem - var(--safe-left));padding:calc(.8rem + var(--safe-top)) calc(.75rem + var(--safe-right)) .75rem calc(.75rem + var(--safe-left));background:#f6faf9f0;border-bottom:1px solid rgba(219,231,228,.9);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);flex-direction:row;align-items:center}.topbar h1{font-size:1.45rem}.topbar p{font-size:.86rem}.topbar .ghost{min-height:40px;padding:.55rem .75rem}.panel,.metric,.signature-card{border-radius:20px;padding:.9rem;box-shadow:0 12px 34px #0f172a12}.cards.four,.cards,.two-col,.two-layout,.form-grid,.form-grid.wide{grid-template-columns:1fr!important}.metric{min-height:94px}.metric strong{font-size:1.75rem}.toolbar{display:grid;grid-template-columns:1fr;align-items:stretch}.toolbar input,.toolbar select,.toolbar button{width:100%}.field{gap:.3rem}input,select,textarea{min-height:44px;padding:.72rem .78rem;border-radius:13px}textarea{min-height:96px}.table-wrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:14px}table{min-width:560px;font-size:.86rem}th,td{padding:.65rem .55rem}tbody tr{cursor:pointer}.checklist{grid-template-columns:1fr}.signature-canvas{height:170px}.auth-shell{min-height:100dvh;padding:calc(1rem + var(--safe-top)) calc(.9rem + var(--safe-right)) calc(1rem + var(--safe-bottom)) calc(.9rem + var(--safe-left))}.auth-card{padding:1.15rem;border-radius:24px}.auth-card .brand-mark{width:126px;height:126px;border-radius:24px;margin:0 auto}.auth-card h1{font-size:1.55rem}.patient-file-modal{padding:.75rem calc(.75rem + var(--safe-right)) calc(.75rem + var(--safe-bottom)) calc(.75rem + var(--safe-left))}.patient-file-sheet{border-radius:26px 26px 18px 18px;max-height:86dvh}.patient-file-grid{grid-template-columns:1fr}}@media(max-width:430px){nav button{flex-basis:68px;min-width:68px;max-width:68px;font-size:.61rem}.topbar{gap:.5rem}.topbar h1{font-size:1.32rem}.content{padding-inline:.6rem}table{min-width:520px;font-size:.8rem}.patient-file-header h2{font-size:1.32rem}}@media print{.patient-file-modal{position:static;inset:auto;background:#fff;padding:0}.patient-file-sheet{box-shadow:none;max-height:none}.patient-file-actions,.sidebar,.topbar{display:none!important}}
