:root { color-scheme: light; }
* { box-sizing: border-box; scrollbar-width: thin; scrollbar-color: rgba(22, 50, 74, 0.18) transparent; }
*::-webkit-scrollbar { width: 8px; height: 8px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb { background: rgba(22, 50, 74, 0.16); border-radius: 999px; border: 2px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-thumb:hover { background: rgba(22, 50, 74, 0.24); border: 2px solid transparent; background-clip: padding-box; }
html, body { height: 100%; }
html { scroll-behavior: smooth; }
body { margin: 0; min-height: 100vh; background: var(--color-page-bg); color: var(--color-text); font-family: var(--font-family-base); position: relative; overflow: hidden; }
button, input, select, textarea { font: inherit; }
a { color: inherit; text-decoration: none; }
.shell-bg { position: fixed; inset: auto auto 0 0; pointer-events: none; border-radius: 999px; filter: blur(12px); opacity: 0.85; }
.shell-bg-one { width: 420px; height: 420px; background: radial-gradient(circle, rgba(111, 174, 217, 0.3), rgba(111, 174, 217, 0)); top: -140px; right: -80px; left: auto; }
.shell-bg-two { width: 360px; height: 360px; background: radial-gradient(circle, rgba(143, 211, 193, 0.24), rgba(143, 211, 193, 0)); bottom: -90px; left: -90px; }
.app-shell { position: relative; z-index: 1; width: min(calc(100% - 32px), var(--shell-max-width)); height: 100vh; margin: 0 auto; padding: 20px 0; display: grid; grid-template-rows: auto auto minmax(0, 1fr); gap: 18px; overflow: hidden; }
.shell-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 20px 24px; border: 1px solid rgba(255, 255, 255, 0.72); background: rgba(255, 255, 255, 0.8); backdrop-filter: blur(18px); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); }
.brand-block, .toolbar-controls, .sim-caption, .side-brand, .section-heading, .inline-actions, .pharmacy-actions, .mobile-appbar, .mobile-nav { display: flex; align-items: center; }
.brand-block { gap: 16px; }
.brand-mark { width: 52px; height: 52px; border-radius: 18px; display: grid; place-items: center; background: linear-gradient(135deg, var(--color-primary), #8dc6ea); color: white; font-weight: 700; letter-spacing: 0.08em; box-shadow: var(--shadow-card); }
.brand-mark.small { width: 40px; height: 40px; border-radius: 14px; }
.eyebrow { margin: 0 0 6px; color: var(--color-muted); font-size: 0.74rem; letter-spacing: 0.12em; text-transform: uppercase; }
.shell-toolbar h1, .desktop-header-card h2, .section-heading h3, .mobile-appbar h2, .mobile-hero h3 { margin: 0; }
.toolbar-subtitle, .section-copy, .side-brand p, .patient-card p, .patient-card span, .stat-card small, .med-item p, .med-item span, .mini-metric small, .data-panel p, .mobile-hero p, .mobile-list-item p, .mobile-reading-item p, .mobile-reading-item span { margin: 0; color: var(--color-muted); }
.toolbar-controls { gap: 16px; flex-wrap: wrap; justify-content: flex-end; }
.segmented-control { display: inline-flex; padding: 6px; border-radius: 999px; background: rgba(111, 174, 217, 0.12); border: 1px solid rgba(111, 174, 217, 0.16); }
.mode-toggle { border: 0; background: transparent; color: var(--color-muted); padding: 10px 18px; border-radius: 999px; cursor: pointer; transition: background 180ms ease, color 180ms ease, transform 180ms ease; }
.mode-toggle.active { background: white; color: var(--color-text); box-shadow: 0 10px 20px rgba(15, 46, 72, 0.08); }
.flash { padding: 14px 18px; border-radius: var(--radius-md); border: 1px solid transparent; box-shadow: var(--shadow-card); }
.flash-success { background: rgba(59, 167, 118, 0.12); border-color: rgba(59, 167, 118, 0.18); }
.flash-warning { background: rgba(216, 166, 84, 0.12); border-color: rgba(216, 166, 84, 0.18); }
.showcase-stage { min-height: 0; overflow: hidden; }
.simulation-grid { position: relative; height: 100%; display: block; }
.simulation-panel { height: 100%; transition: opacity 220ms ease, transform 220ms ease; }
.desktop-panel, .mobile-panel { opacity: 0; transform: scale(0.98); pointer-events: none; position: absolute; inset: 0; visibility: hidden; }
body[data-view-mode="desktop"] .desktop-panel, body[data-view-mode="mobile"] .mobile-panel { opacity: 1; transform: scale(1); pointer-events: auto; visibility: visible; position: relative; }
.sim-caption { justify-content: space-between; margin-bottom: 12px; padding: 0 4px; color: var(--color-muted); font-size: 0.86rem; }
.desktop-panel .desktop-app { width: min(var(--desktop-sim-width), 100%); margin: 0 auto; }
.desktop-app { height: calc(100% - 34px); display: grid; grid-template-columns: 240px minmax(0, 1fr); background: rgba(255, 255, 255, 0.78); backdrop-filter: blur(18px); border-radius: 34px; padding: 18px; border: 1px solid rgba(255, 255, 255, 0.9); box-shadow: var(--shadow-soft); overflow: hidden; }
.desktop-sidebar { display: flex; flex-direction: column; justify-content: space-between; gap: 22px; padding: 16px; border-radius: 26px; background: linear-gradient(180deg, rgba(220, 236, 247, 0.72), rgba(255, 255, 255, 0.9)); border: 1px solid rgba(111, 174, 217, 0.14); min-height: 0; overflow: auto; }
.side-brand { gap: 12px; margin-bottom: 28px; }
.sidebar-nav { display: grid; gap: 10px; }
.sidebar-nav a { padding: 12px 14px; border-radius: 16px; color: var(--color-muted); transition: background 180ms ease, color 180ms ease; }
.sidebar-nav a.active, .sidebar-nav a:hover { background: rgba(255, 255, 255, 0.88); color: var(--color-text); }
.patient-card, .card, .card-soft, .phone-frame { background: var(--color-surface); border: 1px solid rgba(22, 50, 74, 0.06); box-shadow: var(--shadow-card); }
.patient-card { padding: 18px; border-radius: 22px; }
.desktop-content { padding-left: 18px; display: grid; gap: 18px; min-height: 0; overflow-y: auto; overflow-x: hidden; padding-right: 6px; }
.desktop-content[data-desktop-section="medications"] .desktop-block[data-block="overview"],
.desktop-content[data-desktop-section="medications"] .desktop-block[data-block="pharmacy"],
.desktop-content[data-desktop-section="readings"] .desktop-block[data-block="overview"],
.desktop-content[data-desktop-section="readings"] .desktop-block[data-block="pharmacy"],
.desktop-content[data-desktop-section="pharmacy"] .desktop-block[data-block="overview"],
.desktop-content[data-desktop-section="pharmacy"] .desktop-block[data-block="content-grid"],
.desktop-content[data-desktop-section="medications"] .desktop-subcolumn[data-subcolumn="readings"],
.desktop-content[data-desktop-section="readings"] .desktop-subcolumn[data-subcolumn="medications"] { display: none; }
.desktop-content[data-desktop-section="medications"] .content-grid,
.desktop-content[data-desktop-section="readings"] .content-grid { grid-template-columns: 1fr; }
.card { border-radius: 26px; padding: 22px; }
.desktop-header-card { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(240, 248, 252, 0.92)); }
.stats-grid, .content-grid, .reading-summary-grid, .data-panels, .mobile-metric-grid { display: grid; gap: 16px; }
.stats-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.stat-card { padding: 18px; border-radius: 24px; background: rgba(255, 255, 255, 0.92); border: 1px solid rgba(22, 50, 74, 0.06); box-shadow: var(--shadow-card); }
.stat-card.primary { background: linear-gradient(135deg, rgba(111, 174, 217, 0.18), rgba(143, 211, 193, 0.14)); }
.stat-card strong, .mobile-metric strong { display: block; margin: 8px 0 6px; font-size: 1.28rem; }
.stat-label, .mobile-metric span { color: var(--color-muted); font-size: 0.86rem; }
.content-grid { grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); align-items: start; }
.stack-column { display: grid; gap: 16px; min-width: 0; }
.section-heading { justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.section-heading.compact { margin-bottom: 14px; }
.text-link { color: var(--color-primary); font-weight: 600; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-grid label { display: grid; gap: 8px; color: var(--color-muted); font-size: 0.92rem; }
.full-span { grid-column: 1 / -1; }
input, select, textarea { width: 100%; border: 1px solid var(--color-border); border-radius: 16px; background: var(--color-surface-alt); padding: 13px 14px; color: var(--color-text); outline: none; transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease; }
input:focus, select:focus, textarea:focus { border-color: rgba(111, 174, 217, 0.75); box-shadow: 0 0 0 4px rgba(111, 174, 217, 0.14); background: white; }
.form-actions { display: flex; gap: 12px; justify-content: flex-start; }
.btn { border: 0; cursor: pointer; border-radius: 16px; padding: 12px 18px; transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease; }
.btn:hover, .mode-toggle:hover, .chip-action:hover { transform: translateY(-1px); }
.btn-primary { background: linear-gradient(135deg, var(--color-primary), #84bfdf); color: white; box-shadow: 0 12px 20px rgba(111, 174, 217, 0.24); }
.btn-secondary { background: rgba(111, 174, 217, 0.1); color: var(--color-text); border: 1px solid rgba(111, 174, 217, 0.15); }
.btn-ghost { background: transparent; color: var(--color-muted); border: 1px solid var(--color-border); }
.btn-small { padding: 10px 14px; font-size: 0.88rem; }
.btn-block { width: 100%; }
.danger { color: var(--color-danger); }
.medication-list, .mobile-list, .mobile-reading-list { display: grid; gap: 12px; }
.med-item, .mobile-list-item, .mobile-reading-item { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 16px; border-radius: 20px; background: var(--color-surface-alt); border: 1px solid rgba(22, 50, 74, 0.05); }
.inline-actions { gap: 10px; flex-wrap: wrap; }
.reading-summary-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 16px; }
.mini-metric { padding: 16px; border-radius: 20px; background: linear-gradient(180deg, rgba(220, 236, 247, 0.42), rgba(255, 255, 255, 0.8)); border: 1px solid rgba(111, 174, 217, 0.12); }
.mini-metric strong { display: block; margin: 8px 0 4px; }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 13px 10px; border-bottom: 1px solid rgba(22, 50, 74, 0.06); vertical-align: top; }
th { color: var(--color-muted); font-size: 0.84rem; font-weight: 600; }
.pharmacy-block { display: grid; gap: 18px; }
.data-panels { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.data-panel { padding: 18px; border-radius: 22px; background: var(--color-surface-alt); }
.data-panel h4 { margin: 0 0 10px; }
.pharmacy-actions { gap: 12px; flex-wrap: wrap; }
.mobile-panel .phone-frame { width: min(100%, var(--mobile-sim-width)); height: calc(100% - 34px); margin: 0 auto; }
.phone-frame { padding: 14px; border-radius: 36px; background: linear-gradient(180deg, #fefefe, #eef6fb); position: relative; overflow: hidden; }
.phone-notch { width: 140px; height: 28px; border-radius: 0 0 18px 18px; background: #102739; position: absolute; top: 0; left: 50%; transform: translateX(-50%); z-index: 2; }
.mobile-app { border-radius: 28px; background: linear-gradient(180deg, #f9fcfe, #ffffff); padding: 28px 16px 18px; height: 100%; overflow-y: auto; overflow-x: hidden; }
.mobile-appbar { justify-content: space-between; margin-bottom: 18px; }
.avatar-badge { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 14px; background: rgba(111, 174, 217, 0.14); color: var(--color-text); font-weight: 700; }
.card-soft { border-radius: 24px; padding: 16px; background: rgba(255, 255, 255, 0.94); }
.mobile-hero { background: linear-gradient(135deg, rgba(111, 174, 217, 0.18), rgba(143, 211, 193, 0.12)); }
.mobile-metric-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 16px; }
.mobile-metric { text-align: center; }
.mobile-actions { display: flex; gap: 10px; overflow-x: auto; padding: 16px 0 4px; }
.chip-action { border: 0; border-radius: 999px; padding: 10px 14px; white-space: nowrap; background: rgba(111, 174, 217, 0.1); color: var(--color-text); cursor: pointer; }
.mobile-section { margin-top: 18px; }
.mobile-list-item, .mobile-reading-item { flex-direction: column; align-items: flex-start; }
.mobile-form-actions { margin-top: 14px; }
.mobile-nav { justify-content: space-between; gap: 8px; margin-top: 24px; padding-top: 14px; border-top: 1px solid rgba(22, 50, 74, 0.08); color: var(--color-muted); font-size: 0.83rem; }
.mobile-nav .active { color: var(--color-text); font-weight: 700; }
@media (max-width: 1300px) { .stats-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .content-grid { grid-template-columns: 1fr; } }
@media (max-width: 1100px) { .shell-toolbar, .desktop-header-card { flex-direction: column; align-items: flex-start; } .desktop-app { grid-template-columns: 1fr; } .desktop-sidebar { display: none; } .desktop-content { padding-left: 0; } .desktop-panel .desktop-app { width: 100%; } }
@media (max-width: 760px) { .app-shell { width: min(calc(100% - 18px), var(--shell-max-width)); padding: 14px 0; } .shell-toolbar { padding: 18px; border-radius: 24px; } .brand-block, .toolbar-controls { width: 100%; } .form-grid, .stats-grid, .reading-summary-grid, .data-panels, .mobile-metric-grid { grid-template-columns: 1fr; } .pharmacy-actions, .form-actions, .inline-actions { flex-direction: column; align-items: stretch; } .btn, .btn-small { width: 100%; text-align: center; } .med-item { flex-direction: column; align-items: flex-start; } .desktop-app { padding: 12px; } .desktop-panel .desktop-app, .mobile-panel .phone-frame { height: calc(100% - 30px); } }
