:root {
  --primary: #17476f;
  --primary-strong: #103754;
  --primary-soft: #eaf3f9;
  --accent: #2f89a8;
  --sidebar-bg: #17476f;
  --bg: #f3f6f9;
  --surface: #ffffff;
  --text: #203040;
  --muted: #6a7b8b;
  --line: #dde5eb;
  --success: #247551;
  --warning: #a66c12;
  --danger: #a83c47;
  --shadow: 0 12px 34px rgba(24, 56, 84, 0.08);
  --radius: 16px;
}
* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--text); background: var(--bg); }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
.hidden { display: none !important; }

/* Login */
.login-shell { min-height: 100vh; display: grid; grid-template-columns: minmax(0, 1fr) minmax(420px, 540px); background: linear-gradient(135deg, #103754 0%, #17476f 48%, #2f89a8 100%); }
.login-hero { color: white; padding: 72px clamp(32px, 6vw, 96px); display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; }
.login-hero::after { content: ""; position: absolute; width: 520px; height: 520px; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; right: -160px; bottom: -210px; box-shadow: 0 0 0 60px rgba(255,255,255,.04), 0 0 0 120px rgba(255,255,255,.03); }
.brand { display: flex; align-items: center; gap: 12px; font-weight: 800; font-size: 23px; letter-spacing: -.4px; }
.brand-mark { width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center; background: rgba(255,255,255,.17); border: 1px solid rgba(255,255,255,.25); font-size: 22px; }
.hero-copy { max-width: 700px; position: relative; z-index: 1; }
.hero-copy h1 { margin: 0 0 18px; font-size: clamp(42px, 5vw, 68px); line-height: 1.02; letter-spacing: -2px; }
.hero-copy p { margin: 0; font-size: 18px; line-height: 1.65; color: rgba(255,255,255,.84); max-width: 640px; }
.hero-pills { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 28px; }
.hero-pill { padding: 9px 13px; border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.10); border-radius: 999px; font-size: 13px; }
.login-panel { background: #f8fafc; padding: 36px; display: grid; place-items: center; }
.login-card { background: white; width: 100%; max-width: 430px; padding: 34px; border-radius: 22px; box-shadow: 0 20px 58px rgba(10, 38, 58, .20); }
.login-card h2 { margin: 0 0 6px; font-size: 28px; letter-spacing: -.8px; }
.login-card p { color: var(--muted); margin: 0 0 24px; line-height: 1.55; }
.demo-note { background: var(--primary-soft); color: var(--primary); border-radius: 12px; padding: 12px 14px; font-size: 13px; margin: 14px 0; line-height: 1.45; }

/* Form */
.field { display: grid; gap: 7px; margin-bottom: 14px; }
.field label { font-size: 13px; color: #526474; font-weight: 700; }
.input, .select, .textarea { width: 100%; border: 1px solid var(--line); background: #fff; color: var(--text); border-radius: 11px; padding: 11px 12px; outline: none; transition: .2s border, .2s box-shadow; }
.input:focus, .select:focus, .textarea:focus { border-color: #7bb4ca; box-shadow: 0 0 0 4px rgba(47,137,168,.12); }
.textarea { min-height: 96px; resize: vertical; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.form-grid .field { margin: 0; }
.form-grid .wide { grid-column: 1 / -1; }
.btn { border: 0; border-radius: 11px; padding: 10px 14px; font-weight: 700; background: #edf2f6; color: #304454; display: inline-flex; align-items: center; justify-content: center; gap: 8px; transition: .16s ease; }
.btn:hover { transform: translateY(-1px); filter: brightness(.98); }
.btn-primary { background: var(--primary); color: white; }
.btn-accent { background: var(--accent); color: white; }
.btn-danger { background: #fae9eb; color: var(--danger); }
.btn-success { background: #e4f4ec; color: var(--success); }
.btn-block { width: 100%; }
.btn-ghost { background: transparent; }

/* Layout */
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 276px 1fr; }
.sidebar { background: var(--sidebar-bg); color: #e7f1f7; padding: 18px 14px; position: sticky; top: 0; height: 100vh; overflow-y: auto; }
.sidebar .brand { padding: 6px 8px 18px; border-bottom: 1px solid rgba(255,255,255,.12); margin-bottom: 14px; }

.sidebar-brand-wrap { background: #ffffff; border-radius: 14px; padding: 9px 10px; margin: 0 0 14px; min-height: 72px; display: flex; align-items: center; justify-content: center; overflow: hidden; box-shadow: 0 8px 20px rgba(7, 36, 62, .16); }
.sidebar-logo { width: 100%; max-width: 226px; height: 54px; display: block; object-fit: contain; }
.sidebar .brand-mark { width: 38px; height: 38px; border-radius: 12px; }
.nav-section { color: rgba(230,241,248,.55); font-size: 10px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; padding: 16px 10px 7px; }
.nav-link { display: flex; align-items: center; gap: 11px; width: 100%; color: rgba(236,246,251,.80); background: transparent; border: 0; border-radius: 10px; padding: 10px; text-align: left; font-size: 14px; margin: 2px 0; }
.nav-link:hover { background: rgba(255,255,255,.07); color: white; }
.nav-link.active { background: rgba(91,173,201,.24); color: white; box-shadow: inset 3px 0 0 #70c0d6; }
.nav-icon { width: 20px; display: grid; place-items: center; font-size: 16px; }
.sidebar-footer { margin-top: 18px; padding: 14px 10px; border-top: 1px solid rgba(255,255,255,.12); color: rgba(236,246,251,.7); font-size: 12px; line-height: 1.6; }
.main { min-width: 0; }
.topbar { height: 70px; background: white; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 0 26px; position: sticky; top: 0; z-index: 5; }
.topbar-left { display: flex; align-items: center; gap: 14px; }
.mobile-menu { display: none; }
.breadcrumb { color: var(--muted); font-size: 13px; }
.workspace-badge { padding: 7px 10px; border-radius: 999px; background: var(--primary-soft); color: var(--primary); font-size: 12px; font-weight: 800; }
.user-chip { display: flex; align-items: center; gap: 10px; }
.avatar { width: 38px; height: 38px; background: #d8ebf2; color: var(--primary); display: grid; place-items: center; border-radius: 50%; font-weight: 800; }
.content { padding: 26px; }
.page-header { display: flex; justify-content: space-between; gap: 14px; align-items: flex-start; margin-bottom: 20px; }
.page-title h1 { margin: 0; font-size: 29px; letter-spacing: -.8px; }
.page-title p { margin: 6px 0 0; color: var(--muted); line-height: 1.5; font-size: 14px; }
.header-actions { display: flex; gap: 9px; flex-wrap: wrap; justify-content: flex-end; }

/* Cards */
.grid { display: grid; gap: 16px; }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card { background: var(--surface); border: 1px solid #e4eaef; border-radius: var(--radius); box-shadow: var(--shadow); }
.card-pad { padding: 18px; }
.stat { padding: 17px; }
.stat-label { color: var(--muted); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .7px; }
.stat-value { font-size: 30px; font-weight: 850; letter-spacing: -1.2px; margin-top: 6px; }
.stat-sub { color: var(--muted); font-size: 12px; margin-top: 5px; }
.card-title { padding: 17px 18px 12px; font-weight: 850; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.card-body { padding: 16px 18px 18px; }

/* Tables */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; min-width: 720px; }
th { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .7px; font-weight: 850; padding: 11px 12px; border-bottom: 1px solid var(--line); text-align: left; }
td { padding: 12px; border-bottom: 1px solid #edf1f4; font-size: 13px; vertical-align: middle; }
tr:last-child td { border-bottom: 0; }
.actions { display: flex; gap: 5px; flex-wrap: wrap; }
.icon-btn { border: 0; border-radius: 8px; padding: 7px 9px; background: #edf3f6; color: #496170; }
.icon-btn:hover { background: #e2ebf0; }
.badge { display: inline-flex; align-items: center; gap: 5px; padding: 5px 8px; border-radius: 999px; font-size: 11px; font-weight: 800; background: #edf3f6; color: #4a6171; white-space: nowrap; }
.badge.success { background: #e4f4ec; color: var(--success); }
.badge.warning { background: #fff3dc; color: var(--warning); }
.badge.danger { background: #fae9eb; color: var(--danger); }
.badge.info { background: #e5f3fa; color: #276980; }

/* Dashboard visuals */
.bar-chart { display: flex; gap: 12px; align-items: flex-end; height: 170px; padding: 18px 6px 2px; }
.bar { flex: 1; min-width: 20px; border-radius: 8px 8px 3px 3px; background: linear-gradient(180deg, #5cadc6, #1f6687); position: relative; }
.bar span { position: absolute; bottom: -22px; left: 50%; transform: translateX(-50%); color: var(--muted); font-size: 11px; }
.list { display: grid; gap: 10px; }
.list-item { display: flex; justify-content: space-between; gap: 12px; align-items: center; border-bottom: 1px solid #edf1f4; padding: 0 0 10px; }
.list-item:last-child { border-bottom: 0; padding-bottom: 0; }
.list-main strong { font-size: 13px; display: block; }
.list-main span { font-size: 12px; color: var(--muted); display: block; margin-top: 3px; }

/* Agenda */
.agenda-grid { display: grid; grid-template-columns: 90px repeat(5, minmax(150px, 1fr)); min-width: 920px; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.agenda-cell { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); min-height: 63px; padding: 6px; font-size: 12px; }
.agenda-head { min-height: auto; padding: 10px 7px; font-weight: 800; color: #4f6474; background: #f7fafb; }
.agenda-time { color: var(--muted); background: #fbfcfd; font-weight: 700; }
.appointment { border-left: 4px solid var(--accent); background: #eaf6fa; color: #28586a; border-radius: 7px; padding: 6px; font-size: 11px; line-height: 1.35; }
.appointment.confirmed { border-color: var(--success); background: #e6f4ec; color: #265e47; }
.appointment.pending { border-color: var(--warning); background: #fff5df; color: #77551a; }

/* Config */
.tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.tab { border: 1px solid var(--line); background: white; color: #506676; padding: 9px 12px; border-radius: 999px; font-weight: 750; font-size: 13px; }
.tab.active { background: var(--primary); color: white; border-color: var(--primary); }
.switch-row { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 12px 0; border-bottom: 1px solid #edf1f4; }
.switch-row:last-child { border-bottom: 0; }
.switch-copy strong { display: block; font-size: 13px; }
.switch-copy span { display: block; margin-top: 3px; color: var(--muted); font-size: 12px; }
.switch { width: 46px; height: 26px; border: 0; border-radius: 999px; background: #c7d2d9; padding: 3px; transition: .2s; }
.switch::after { content: ""; display: block; width: 20px; height: 20px; border-radius: 50%; background: white; transition: .2s; box-shadow: 0 1px 5px rgba(0,0,0,.18); }
.switch.on { background: var(--success); }
.switch.on::after { transform: translateX(20px); }
.notice { border-radius: 12px; padding: 13px 14px; font-size: 13px; line-height: 1.55; background: #eaf3f9; color: #315f77; border: 1px solid #d5e8f2; }
.notice.warning { background: #fff7e8; color: #75551c; border-color: #f2dfb7; }

/* Modal */
.modal-backdrop { position: fixed; inset: 0; background: rgba(18, 37, 54, .54); display: grid; place-items: center; padding: 20px; z-index: 30; }
.modal { width: min(760px, 100%); max-height: min(90vh, 900px); overflow-y: auto; background: white; border-radius: 18px; box-shadow: 0 22px 80px rgba(0,0,0,.22); }
.modal-header { display: flex; justify-content: space-between; gap: 12px; align-items: center; padding: 17px 19px; border-bottom: 1px solid var(--line); }
.modal-header h3 { margin: 0; font-size: 18px; }
.modal-body { padding: 18px 19px; }
.modal-footer { display: flex; justify-content: flex-end; gap: 9px; padding: 14px 19px 19px; }
.close { border: 0; background: transparent; font-size: 20px; color: var(--muted); }
.toast-wrap { position: fixed; right: 18px; bottom: 18px; display: grid; gap: 8px; z-index: 60; }
.toast { background: #153e5d; color: white; padding: 12px 14px; border-radius: 10px; box-shadow: var(--shadow); min-width: 250px; font-size: 13px; animation: toast-in .18s ease; }
@keyframes toast-in { from { transform: translateY(8px); opacity: 0; } }
.empty { padding: 25px; text-align: center; color: var(--muted); font-size: 13px; }

/* responsive */
@media (max-width: 1120px) { .grid-4 { grid-template-columns: repeat(2, minmax(0,1fr)); } .grid-3 { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 880px) {
  .login-shell { display: block; background: #f8fafc; }
  .login-hero { min-height: 300px; padding: 32px 24px; }
  .hero-copy h1 { font-size: 42px; margin-top: 38px; }
  .hero-copy p { font-size: 15px; }
  .login-panel { padding: 22px; margin-top: -28px; position: relative; z-index: 2; }
  .app-shell { display: block; }
  .sidebar { position: fixed; z-index: 20; left: -290px; width: 276px; transition: .22s ease; box-shadow: 10px 0 32px rgba(0,0,0,.22); }
  .sidebar.open { left: 0; }
  .mobile-menu { display: inline-flex; }
  .topbar { padding: 0 15px; }
  .content { padding: 17px; }
  .page-header { display: block; }
  .header-actions { justify-content: flex-start; margin-top: 13px; }
  .user-chip .user-name { display: none; }
}
@media (max-width: 620px) {
  .grid-4, .grid-3, .grid-2, .form-grid { grid-template-columns: 1fr; }
  .login-card { padding: 25px; }
  .hero-pills { display: none; }
  .content { padding: 14px; }
  .page-title h1 { font-size: 25px; }
  .stat-value { font-size: 25px; }
}

/* Phase 4.1 */
.phone-grid { display: grid; grid-template-columns: minmax(210px, 1.2fr) minmax(160px, 1fr); gap: 10px; }
.schedule-editor { display: grid; gap: 8px; }
.schedule-row { border: 1px solid var(--line); border-radius: 12px; padding: 11px; display: grid; gap: 9px; background: var(--surface); }
.day-toggle { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--text); }
.day-toggle input { width: 17px; height: 17px; accent-color: var(--primary); }
.schedule-times { display: grid; grid-template-columns: minmax(110px, 1fr) 18px minmax(110px, 1fr) auto minmax(110px, 1fr) 18px minmax(110px, 1fr); gap: 8px; align-items: center; }
.schedule-times.disabled { opacity: .48; }
.schedule-times .input { padding: 9px; }
.meal-label { font-size: 11px; color: var(--muted); font-weight: 800; text-transform: uppercase; letter-spacing: .3px; white-space: nowrap; }
.color-input { width: 100%; min-height: 46px; padding: 4px; border-radius: 11px; border: 1px solid var(--line); background: var(--surface); }
.theme-preview { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; margin-top: 10px; padding: 14px; border-radius: 12px; border: 1px dashed var(--line); background: var(--bg); }
.pdf-preview { margin-top: 16px; min-height: 235px; border: 1px solid var(--line); border-radius: 13px; overflow: hidden; background: #fff; color: #263746; box-shadow: 0 8px 24px rgba(25,55,75,.07); }
.pdf-head { background: var(--pdf-primary); color: #fff; padding: 16px; display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.pdf-head span { font-size: 12px; opacity: .9; }
.pdf-line { height: 6px; background: var(--pdf-secondary); }
.pdf-body { padding: 16px; }
.pdf-body h4 { margin: 0 0 12px; color: var(--pdf-primary); }
.pdf-body p { margin: 5px 0; font-size: 12px; }
.pdf-footer { border-top: 1px solid #e4ebef; padding: 10px 16px; color: #6d7d88; font-size: 11px; }
.sticky-save { position: sticky; bottom: 16px; display: flex; justify-content: flex-end; margin-top: 16px; padding: 12px; border-radius: 14px; background: rgba(255,255,255,.88); border: 1px solid var(--line); box-shadow: var(--shadow); backdrop-filter: blur(8px); z-index: 4; }
.section-box { border: 1px solid var(--line); border-radius: 13px; padding: 13px; background: #fbfcfd; }
.section-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 10px; }
.section-head strong, .section-head span { display: block; }
.section-head span { color: var(--muted); font-size: 12px; margin-top: 3px; }
.specialty-row { display: grid; grid-template-columns: 1fr 1fr 1.2fr auto; gap: 10px; align-items: end; border-top: 1px solid var(--line); padding-top: 12px; margin-top: 12px; }
.specialty-row .field { margin: 0; }
.specialty-remove { margin-bottom: 1px; }
.detail-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; margin-top: 14px; }
.detail-grid > div { padding: 12px; border: 1px solid var(--line); border-radius: 10px; }
.detail-grid strong, .detail-grid span { display: block; }
.detail-grid span { margin-top: 5px; color: var(--muted); font-size: 13px; }
.detail-grid .wide { grid-column: 1 / -1; }
.export-grid { display: grid; gap: 10px; margin-top: 14px; }
.export-card { display: block; border: 1px solid var(--line); border-radius: 12px; padding: 14px; background: #fbfcfd; transition: .16s ease; }
.export-card:hover { transform: translateY(-1px); border-color: var(--accent); }
.export-card strong, .export-card span { display: block; }
.export-card span { margin-top: 5px; color: var(--muted); font-size: 12px; line-height: 1.5; }
.modal-wide { width: min(980px,100%); }


.asset-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
.asset-card { display: grid; grid-template-columns: 88px 1fr; gap: 12px; align-items: start; border: 1px solid var(--line); border-radius: 14px; padding: 13px; background: #fbfcfd; }
.asset-thumb { width: 88px; height: 88px; border: 1px dashed var(--line); border-radius: 12px; display: grid; place-items: center; overflow: hidden; background: #fff; color: var(--muted); font-size: 11px; text-align: center; padding: 6px; }
.asset-thumb img { width: 100%; height: 100%; object-fit: contain; }
.asset-copy strong, .asset-copy span, .asset-copy small { display: block; }
.asset-copy span { color: var(--muted); font-size: 12px; line-height: 1.45; margin-top: 4px; }
.asset-copy small { color: var(--muted); margin-top: 8px; }
.asset-input { margin-top: 10px; font-size: 12px; }
.asset-actions { grid-column: 1 / -1; display: flex; gap: 8px; flex-wrap: wrap; }
.pdf-brand { display: flex; align-items: center; gap: 10px; }
.pdf-brand img { width: 54px; height: 54px; object-fit: contain; background: rgba(255,255,255,.92); border-radius: 8px; padding: 4px; }
.pdf-brand span { display: block; margin-top: 4px; }
.pdf-crest img { width: 54px; height: 54px; object-fit: contain; background: rgba(255,255,255,.92); border-radius: 8px; padding: 4px; }
.storage-head { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; }
.storage-head span { display: block; color: var(--muted); font-size: 12px; margin-top: 4px; }
.storage-bar { height: 12px; border-radius: 999px; overflow: hidden; background: #e7eef3; margin-top: 16px; }
.storage-bar span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg,var(--primary),var(--accent)); }
.storage-meta { display: flex; justify-content: space-between; gap: 10px; color: var(--muted); font-size: 12px; margin-top: 8px; }
:root[data-theme="dark"] .asset-card { background:#1b2934; }

:root[data-theme="dark"] { --bg:#17232d; --surface:#22313d; --text:#edf5f8; --muted:#adc0ca; --line:#3a4b57; --primary-soft:#243f50; --shadow:0 12px 34px rgba(0,0,0,.18); }
:root[data-theme="dark"] .main, :root[data-theme="dark"] .content { background:var(--bg); }
:root[data-theme="dark"] .topbar, :root[data-theme="dark"] .card, :root[data-theme="dark"] .modal, :root[data-theme="dark"] .input, :root[data-theme="dark"] .select, :root[data-theme="dark"] .textarea, :root[data-theme="dark"] .sticky-save { background:var(--surface); color:var(--text); }
:root[data-theme="dark"] .section-box, :root[data-theme="dark"] .theme-preview, :root[data-theme="dark"] .export-card { background:#1b2934; }

@media (max-width: 900px) { .asset-grid { grid-template-columns: 1fr; } .schedule-times { grid-template-columns: 1fr 18px 1fr; } .meal-label { grid-column: 1 / -1; margin-top: 3px; } .specialty-row { grid-template-columns: 1fr; } .phone-grid { grid-template-columns: 1fr; } }

/* Phase 5A: Catálogo maestro de pacientes */
.patient-toolbar { display:grid; grid-template-columns:minmax(260px,1.6fr) minmax(170px,.7fr) minmax(190px,.8fr); gap:12px; align-items:end; margin-bottom:14px; }
.patient-toolbar .field { margin:0; }
.patient-name strong, .patient-name span { display:block; }
.patient-name span { color:var(--muted); font-size:12px; margin-top:4px; }
.pagination { display:flex; justify-content:space-between; align-items:center; gap:12px; padding-top:14px; color:var(--muted); font-size:12px; }
.pagination .actions { display:flex; align-items:center; gap:10px; }
.patient-detail-head { display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.patient-detail-head h3 { margin:0; font-size:20px; }
.patient-detail-head p { margin:6px 0 0; color:var(--muted); font-size:13px; }
.patient-avatar { width:74px; height:74px; flex:0 0 74px; display:grid; place-items:center; overflow:hidden; border-radius:16px; border:1px solid var(--line); background:var(--primary-soft); color:var(--primary); font-size:30px; }
.patient-avatar img { width:100%; height:100%; object-fit:cover; }
.btn:disabled { opacity:.48; cursor:not-allowed; }
@media (max-width: 820px) { .patient-toolbar { grid-template-columns:1fr; } .pagination { align-items:flex-start; flex-direction:column; } }


/* Phase 5A.1: avisos internos del sistema */
.system-dialog-backdrop { position:fixed; inset:0; z-index:120; display:grid; place-items:center; padding:20px; background:rgba(17,34,48,.58); backdrop-filter:blur(3px); }
.system-dialog { width:min(520px,100%); display:grid; grid-template-columns:44px minmax(0,1fr); gap:14px; padding:20px; border-radius:18px; background:var(--surface); border:1px solid var(--line); box-shadow:0 24px 90px rgba(0,0,0,.28); animation:dialog-in .16s ease; }
.system-dialog-icon { width:44px; height:44px; display:grid; place-items:center; border-radius:50%; font-size:20px; font-weight:900; background:#e5f3fa; color:#276980; }
.system-dialog.warning .system-dialog-icon { background:#fff3dc; color:var(--warning); }
.system-dialog.danger .system-dialog-icon { background:#fae9eb; color:var(--danger); }
.system-dialog.success .system-dialog-icon { background:#e4f4ec; color:var(--success); }
.system-dialog-copy h3 { margin:0; font-size:18px; }
.system-dialog-copy p { margin:8px 0 0; color:var(--muted); font-size:13px; line-height:1.6; }
.system-dialog-actions { grid-column:1 / -1; display:flex; justify-content:flex-end; gap:9px; margin-top:4px; }
@keyframes dialog-in { from { opacity:0; transform:translateY(8px) scale(.985); } }


/* Phase 5A.2: PWA instalable y experiencia responsive */
.sidebar-overlay { display:none; }
.install-app-btn { background:var(--primary-soft); color:var(--primary); white-space:nowrap; }
@media (display-mode: standalone) {
  .install-app-btn { display:none !important; }
  body { overscroll-behavior-y:none; }
}
@media (max-width: 880px) {
  .sidebar-overlay { display:block; position:fixed; inset:0; z-index:18; border:0; padding:0; background:rgba(8,26,40,.48); opacity:0; visibility:hidden; pointer-events:none; transition:.2s ease; }
  .sidebar-overlay.open { opacity:1; visibility:visible; pointer-events:auto; }
  .sidebar { z-index:20; }
  .topbar { min-height:64px; height:auto; padding:8px 12px; }
  .topbar-left { min-width:0; }
  .breadcrumb { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:40vw; }
  .workspace-badge { display:none; }
  .install-app-btn { padding:9px 10px; font-size:12px; }
  .user-chip { gap:6px; }
  .avatar { width:34px; height:34px; font-size:12px; }
  .content { padding:16px; }
  .modal-backdrop { padding:10px; align-items:end; }
  .modal { width:100%; max-height:92vh; border-radius:18px 18px 0 0; }
  .modal-header, .modal-body, .modal-footer { padding-left:15px; padding-right:15px; }
  .system-dialog-backdrop { padding:12px; }
}
@media (max-width: 620px) {
  .topbar { gap:6px; }
  .mobile-menu { padding:9px 11px; }
  .breadcrumb { max-width:32vw; font-size:12px; }
  .install-app-btn { font-size:0; width:38px; min-width:38px; height:38px; padding:0; }
  .install-app-btn::before { content:'⇩'; font-size:18px; line-height:1; }
  .btn-ghost#logout { padding:8px 7px; font-size:12px; }
  .content { padding:12px; }
  .card-pad, .card-body, .stat { padding:14px; }
  .page-header { margin-bottom:14px; }
  .page-title h1 { font-size:23px; }
  .page-title p { font-size:13px; }
  .header-actions .btn { width:100%; }
  .tabs { gap:6px; overflow-x:auto; flex-wrap:nowrap; padding-bottom:3px; scrollbar-width:thin; }
  .tab { flex:0 0 auto; }
  .modal-footer { flex-direction:column-reverse; }
  .modal-footer .btn { width:100%; }
  .system-dialog { grid-template-columns:38px minmax(0,1fr); gap:11px; padding:16px; }
  .system-dialog-icon { width:38px; height:38px; }
  .system-dialog-actions { flex-direction:column-reverse; }
  .system-dialog-actions .btn { width:100%; }
  .detail-grid { grid-template-columns:1fr; }
  .detail-grid .wide { grid-column:auto; }
  .patient-detail-head { align-items:flex-start; }
  .toast-wrap { left:12px; right:12px; bottom:12px; }
  .toast { min-width:0; width:100%; }
  .storage-meta { display:grid; gap:4px; }
}

/* Fase 5B: expediente clínico e historia clínica */
.patient-link{border:0;background:transparent;padding:0;color:var(--primary);font:inherit;text-align:left;cursor:pointer}.patient-link:hover{text-decoration:underline}
.back-row{display:flex;margin-bottom:14px}.patient-record-header{display:flex;gap:18px;align-items:center;padding:18px;margin-bottom:12px}.record-photo{width:94px;height:94px;border-radius:18px;background:#edf3f8;display:flex;align-items:center;justify-content:center;font-size:38px;overflow:hidden;flex:0 0 auto}.record-photo img{width:100%;height:100%;object-fit:cover}.record-identity{min-width:0}.record-folio{font-size:12px;color:var(--primary);font-weight:800;letter-spacing:.08em}.record-identity h1{margin:4px 0 8px;font-size:24px}.record-meta{display:flex;gap:8px 18px;flex-wrap:wrap;color:var(--muted);font-size:13px}.clinical-alert-banner{padding:12px 14px;background:#fff3cd;border:1px solid #f2d47e;color:#6b5200;border-radius:12px;margin:0 0 14px}.record-tabs{display:flex;gap:8px;overflow:auto;padding:2px 0 10px;margin-bottom:6px}.record-tab{white-space:nowrap;border:1px solid var(--border);background:var(--card);padding:10px 13px;border-radius:10px;cursor:pointer;color:var(--text)}.record-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.record-content{min-height:220px}.clinical-form{display:grid;gap:12px}.clinical-section{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.clinical-section summary{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 17px;cursor:pointer;background:color-mix(in srgb,var(--primary) 6%,var(--card));list-style:none}.clinical-section summary::-webkit-details-marker{display:none}.clinical-section summary span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.clinical-section-body{padding:16px}.urgency-tag{display:inline-block;padding:2px 6px;border-radius:999px;background:#ffe2e2;color:#a12626;font-size:10px;font-weight:700;margin-left:5px}.check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:8px}.check-item{display:flex;gap:8px;align-items:center;padding:9px 10px;border:1px solid var(--border);border-radius:9px;background:var(--card)}.matrix-table th,.matrix-table td{text-align:center}.matrix-table td:first-child,.matrix-table th:first-child{text-align:left;min-width:190px}.treatment-row{display:grid;grid-template-columns:1.2fr 1.2fr .55fr .7fr auto;gap:10px;align-items:end;padding:12px;border:1px solid var(--border);border-radius:12px;margin-bottom:10px}.odonto-toolbar{display:flex;gap:12px;flex-wrap:wrap}.odonto-toolbar .field{min-width:230px}.odonto-legend-wrap{display:flex;flex-wrap:wrap;gap:7px 11px;margin:10px 0}.odonto-legend{display:inline-flex;align-items:center;gap:5px;font-size:11px}.odonto-legend i{width:11px;height:11px;border-radius:50%;display:inline-block}.odontogram-grid{display:grid;grid-template-columns:repeat(8,minmax(92px,1fr));gap:9px}.tooth-card{border:1px solid var(--border);border-radius:11px;padding:7px;text-align:center;background:var(--card)}.tooth-surfaces{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;margin-top:6px}.tooth-face{border:1px solid #d1d9e0;border-radius:4px;padding:5px 0;font-size:10px;cursor:pointer;background:var(--face-color)}.tooth-face.missing{color:#fff;font-weight:900;background:var(--face-color)}.signature-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}.signature-grid label{display:block;font-weight:700;margin-bottom:7px}.signature-pad{width:100%;height:140px;background:#fff;border:1px dashed #9eafbd;border-radius:10px;touch-action:none}.sticky-save{position:sticky;bottom:12px;z-index:4;display:flex;justify-content:flex-end;padding:11px;background:color-mix(in srgb,var(--card) 92%,transparent);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 22px rgba(0,0,0,.08);margin-top:14px}.history-file-list{display:flex;flex-direction:column;gap:6px;margin:10px 0}.upload-line{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;word-break:break-all}
@media(max-width:1100px){.odontogram-grid{grid-template-columns:repeat(4,minmax(88px,1fr))}.treatment-row{grid-template-columns:1fr 1fr}.treatment-row .btn{grid-column:1/-1}}
@media(max-width:700px){.patient-record-header{align-items:flex-start;padding:14px}.record-photo{width:72px;height:72px;border-radius:14px}.record-identity h1{font-size:19px}.record-meta{font-size:12px;display:grid;gap:5px}.record-tabs{margin-left:-2px;margin-right:-2px}.clinical-section summary{padding:13px}.clinical-section-body{padding:12px}.odontogram-grid{grid-template-columns:repeat(2,minmax(90px,1fr));gap:7px}.signature-grid{grid-template-columns:1fr}.signature-pad{height:125px}.sticky-save .btn{width:100%}.treatment-row{grid-template-columns:1fr}.stack-mobile{display:grid}.stack-mobile .btn{width:100%}}
.input-suffix-wrap{display:flex;align-items:center;border:1px solid var(--border);border-radius:9px;background:var(--card);overflow:hidden}.input-suffix-wrap .input{border:0;border-radius:0;min-width:0}.input-suffix-wrap span{padding:0 10px;color:var(--muted);font-size:12px;white-space:nowrap;border-left:1px solid var(--border)}
.conditional-grid{display:none;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:12px;border:1px dashed var(--border);border-radius:10px;background:color-mix(in srgb,var(--primary) 3%,var(--card))}.conditional-grid.visible{display:grid}.conditional-field{display:none}.conditional-field.visible{display:block}@media(max-width:700px){.conditional-grid{grid-template-columns:1fr}}

/* Fase 5B.1 — rediseño visual profesional */
:root{
  --bg:#f5f7fb;--surface:#fff;--text:#163047;--muted:#728293;--line:#e4eaf0;
  --shadow:0 8px 22px rgba(29,62,93,.06);--radius:12px;
}
body{font-size:14px;letter-spacing:-.01em}.content{padding:24px 28px 36px;max-width:1720px;width:100%;margin:0 auto}.main{min-width:0;background:var(--bg)}
.sidebar{padding:0 12px 16px;width:auto}.sidebar-brand-wrap{margin:0 -12px 10px;border-radius:0;min-height:78px;box-shadow:none;border-bottom:1px solid rgba(20,50,73,.12)}.sidebar-logo{max-width:205px;height:54px}.sidebar-clinic{margin:10px 2px 4px;padding:10px;border-radius:9px;background:rgba(255,255,255,.08)}.sidebar-clinic span,.sidebar-clinic strong{display:block}.sidebar-clinic span{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.6)}.sidebar-clinic strong{font-size:12px;margin-top:3px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer{display:grid;gap:3px}.sidebar-footer span{font-size:11px;color:rgba(255,255,255,.62)}
.topbar{min-height:68px;height:auto;border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(20,53,77,.02);padding:9px 24px;background:#fff}.topbar-context{display:grid;gap:2px}.topbar-context strong{font-size:14px;color:var(--text)}.breadcrumb{font-size:11px;color:var(--muted)}
.card{border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow)}.card-title{font-size:15px;padding:15px 18px}.card-body{padding:18px}.page-title h1{font-size:27px;letter-spacing:-.04em}.page-title p{line-height:1.5}.btn{border-radius:8px;padding:9px 13px;font-size:13px;box-shadow:none}.btn:hover{transform:none;filter:brightness(.98)}.input,.select,.textarea{border-radius:8px;background:#fff}.stat{border-radius:11px;box-shadow:var(--shadow)}
.patient-hero{overflow:hidden;margin-bottom:14px;background:linear-gradient(105deg,var(--primary-strong),var(--primary));color:#fff;border-radius:14px;box-shadow:0 14px 28px rgba(16,55,84,.16)}.patient-hero-main{display:flex;align-items:center;gap:18px;padding:22px 24px 17px}.patient-hero .record-photo{width:94px;height:94px;border:4px solid rgba(255,255,255,.76);background:#fff;color:var(--primary);border-radius:50%;font-size:25px;font-weight:900;box-shadow:0 8px 18px rgba(0,0,0,.16)}.patient-hero .record-identity h1{font-size:25px;letter-spacing:-.04em;color:#fff}.patient-hero .record-folio{color:#bde9ff}.patient-hero .record-meta{color:rgba(255,255,255,.88);gap:7px 20px}.patient-hero .record-meta span{display:grid;gap:2px}.patient-hero .record-meta b{color:#fff;font-size:10px;text-transform:uppercase;letter-spacing:.06em}.patient-hero-insights{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:rgba(255,255,255,.17)}.patient-insight{display:flex;gap:10px;min-width:0;padding:14px 18px;background:rgba(6,37,63,.2)}.patient-insight-icon{display:grid;place-items:center;width:29px;height:29px;border-radius:50%;background:rgba(255,255,255,.14);font-size:13px;flex:0 0 auto}.patient-insight strong,.patient-insight small{display:block}.patient-insight strong{font-size:12px}.patient-insight small{margin-top:4px;font-size:11px;line-height:1.35;color:rgba(255,255,255,.78);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patient-insight.alert .patient-insight-icon{background:#ffe777;color:#5b4b00}.patient-insight.ok .patient-insight-icon{background:#b9edcc;color:#175b37}
.record-tabs{background:#fff;border:1px solid var(--line);border-radius:11px;padding:4px;gap:2px;box-shadow:var(--shadow);margin-bottom:14px}.record-tab{border:0;background:transparent;border-radius:7px;padding:10px 12px;color:#607284;font-size:13px}.record-tab:hover{background:#f1f6f9;color:var(--primary)}.record-tab.active{background:var(--primary-soft);color:var(--primary);font-weight:800}
.clinical-section{border-radius:10px;background:#fff;border-color:var(--line)}.clinical-section summary{background:#f9fbfd;padding:14px 16px}.clinical-section summary strong{font-size:14px}.clinical-section-body{padding:17px}.check-item{border-radius:7px;background:#fff}.sticky-save{border-radius:10px}
/* odontograma profesional */
.odontogram-pro{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}.odonto-commandbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 17px;background:#f7fafc;border-bottom:1px solid var(--line)}.odonto-commandbar h4{margin:0;font-size:16px;color:var(--text)}.odonto-commandbar p{margin:4px 0 0;font-size:12px;color:var(--muted)}.odonto-command-actions{display:flex;gap:9px;align-items:end;flex-wrap:wrap}.odonto-command-actions label{display:grid;gap:5px;color:var(--muted);font-size:11px;font-weight:800}.odonto-command-actions .select{min-width:118px;padding:8px 9px}.odonto-layout{display:grid;grid-template-columns:210px minmax(0,1fr);min-height:470px}.odonto-palette{padding:14px;border-right:1px solid var(--line);background:#fbfdfe}.odonto-palette>strong{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#52687b}.odonto-legend-wrap{display:grid;gap:5px;margin:11px 0}.odonto-legend{display:flex;align-items:center;gap:7px;width:100%;border:1px solid transparent;background:transparent;border-radius:7px;padding:6px 7px;color:#607284;text-align:left;font-size:11px}.odonto-legend:hover{background:#f0f5f8}.odonto-legend.active{border-color:color-mix(in srgb,var(--legend-color) 55%,#fff);background:color-mix(in srgb,var(--legend-color) 12%,#fff);color:#234050;font-weight:800}.odonto-legend i{width:12px;height:12px;flex:0 0 auto;border-radius:3px;background:var(--legend-color);border:1px solid rgba(0,0,0,.08)}.odonto-palette-help{display:grid;gap:4px;border-top:1px solid var(--line);padding-top:10px;color:var(--muted);font-size:10px}.odonto-palette-help b{color:var(--text);margin-bottom:2px}.odontogram-canvas{overflow-x:auto;padding:16px 13px 12px;background:#fff}.dental-arch{min-width:920px;padding:10px 0}.dental-arch+.dental-arch{border-top:1px dashed #d6e0e8;margin-top:10px;padding-top:18px}.dental-arch-label{margin-bottom:8px;color:#7a8b99;font-size:10px;text-transform:uppercase;letter-spacing:.1em;text-align:center}.dental-row{display:grid;grid-template-columns:repeat(16,minmax(51px,1fr));gap:5px}.dental-unit{position:relative;display:grid;gap:5px;justify-items:center;min-width:51px}.dental-silhouette{position:relative;width:42px;height:69px;padding:0;border:0;background:transparent}.tooth-svg{width:100%;height:100%;filter:drop-shadow(0 1px 1px rgba(40,69,92,.12))}.tooth-svg path{fill:#fff;stroke:#9aaab6;stroke-width:1.15;transition:.15s}.dental-silhouette:hover .tooth-svg path{fill:#f2f8fb;stroke:var(--primary)}.dental-unit .dental-silhouette::after{content:"";position:absolute;left:11px;right:11px;top:7px;height:17px;border-radius:50%;background:color-mix(in srgb,var(--tooth-accent) 22%,transparent);pointer-events:none}.missing-cross{position:absolute;inset:-3px 0 auto;color:#d64545;font-size:66px;font-style:normal;line-height:66px;font-weight:500;pointer-events:none}.surface-map{position:relative;width:38px;height:38px}.surface-piece{position:absolute;border:1px solid #8395a3;background:var(--surface-fill,#fff);padding:0;font-size:0;transition:.12s}.surface-piece:hover{z-index:3;filter:brightness(.93);border-color:var(--primary)}.surface-v{left:7px;top:0;width:24px;height:10px;border-radius:8px 8px 3px 3px}.surface-l{left:7px;bottom:0;width:24px;height:10px;border-radius:3px 3px 8px 8px}.surface-m{left:0;top:7px;width:10px;height:24px;border-radius:8px 3px 3px 8px}.surface-d{right:0;top:7px;width:10px;height:24px;border-radius:3px 8px 8px 3px}.surface-o{left:10px;top:10px;width:18px;height:18px;border-radius:50%}.tooth-number{font-size:10px;color:#455b6d}.tooth-note{width:49px;border:0;border-bottom:1px solid #d9e3ea;background:transparent;padding:2px 1px;color:#6e7e8b;font-size:9px;text-align:center;outline:none}.tooth-note:focus{border-color:var(--primary);color:var(--text)}.odonto-footnote{padding:11px 14px;border-top:1px solid var(--line);background:#f8fbfd;color:var(--muted);font-size:11px;line-height:1.5}
:root[data-theme="dark"] .topbar,:root[data-theme="dark"] .record-tabs,:root[data-theme="dark"] .odontogram-pro,:root[data-theme="dark"] .odontogram-canvas,:root[data-theme="dark"] .dental-unit,:root[data-theme="dark"] .clinical-section{background:var(--surface)}:root[data-theme="dark"] .odonto-commandbar,:root[data-theme="dark"] .odonto-palette,:root[data-theme="dark"] .clinical-section summary{background:#1b2934}:root[data-theme="dark"] .tooth-svg path{fill:#eef5f7;stroke:#8fa4af}:root[data-theme="dark"] .odonto-legend.active{color:#eef5f7}
@media(max-width:980px){.content{padding:18px}.patient-hero-insights{grid-template-columns:1fr}.odonto-layout{grid-template-columns:1fr}.odonto-palette{border-right:0;border-bottom:1px solid var(--line)}.odonto-legend-wrap{display:flex;flex-wrap:wrap}.odonto-legend{width:auto}.odonto-palette-help{display:none}}
@media(max-width:700px){.content{padding:12px}.topbar{padding:7px 10px}.patient-hero-main{align-items:flex-start;padding:16px;gap:12px}.patient-hero .record-photo{width:68px;height:68px;font-size:18px}.patient-hero .record-identity h1{font-size:19px;margin-top:3px}.patient-hero .record-meta{display:grid;gap:5px}.patient-hero .record-meta span{display:block}.patient-hero .record-meta b{display:block;margin-bottom:1px}.patient-insight{padding:11px 14px}.record-tabs{border-radius:9px}.record-tab{padding:9px 10px}.odonto-commandbar{display:grid;padding:13px}.odonto-command-actions{display:grid;grid-template-columns:1fr}.odonto-command-actions .btn{width:100%}.odonto-palette{padding:11px}.dental-arch{min-width:850px}}

/* Phase 5B.2 - Clinical UI polish */
.sidebar-toggle { width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 9px; background: #fff; color: #526a79; display: inline-grid; place-items: center; font-size: 18px; transition: .18s ease; }
.sidebar-toggle:hover { color: var(--primary); border-color: color-mix(in srgb,var(--primary) 30%,#fff); background: var(--primary-soft); }
.app-shell { transition: grid-template-columns .22s ease; }
.app-shell.sidebar-collapsed { grid-template-columns: 0 minmax(0,1fr); }
.app-shell.sidebar-collapsed .sidebar { width: 0; min-width: 0; padding-left: 0; padding-right: 0; overflow: hidden; transform: translateX(-100%); }
.sidebar { transition: width .22s ease, transform .22s ease, padding .22s ease; }

/* Professional patient directory */
.patients-overview { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 12px; margin-bottom: 15px; }
.patients-overview > div { padding: 15px 16px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface); box-shadow: 0 6px 18px rgba(24,56,84,.045); }
.patients-overview span,.patients-overview small { display:block; }
.patients-overview span { color: var(--muted); font-size: 11px; font-weight: 850; text-transform: uppercase; letter-spacing: .65px; }
.patients-overview strong { display:block; margin-top: 7px; color: var(--primary); font-size: 24px; letter-spacing: -.7px; }
.patients-overview small { margin-top: 4px; color: var(--muted); font-size: 11px; line-height: 1.4; }
.patient-directory { overflow: visible; }
.patient-directory-head { display:flex; justify-content:space-between; gap:14px; padding: 17px 18px 0; }
.patient-directory-head h3 { margin:0; font-size:17px; }
.patient-directory-head p { margin:5px 0 0; color:var(--muted); font-size:12px; line-height:1.45; }
.patient-toolbar { display:grid; grid-template-columns:minmax(260px,1fr) minmax(150px,210px) minmax(170px,230px); gap:11px; align-items:end; padding:14px; margin-bottom:12px; border:1px solid var(--line); border-radius:11px; background:#f8fbfc; }
.patient-toolbar .field { margin:0; }
.patient-cell { display:flex; align-items:center; gap:10px; min-width:205px; }
.patient-list-avatar { width:38px; height:38px; flex:0 0 auto; display:grid; place-items:center; border-radius:50%; background:#e5f2f7; color:var(--primary); font-size:11px; font-weight:900; }
.patient-folio { color:var(--primary); font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12px; }
.contact-cell strong,.contact-cell span { display:block; }
.contact-cell strong { font-size:12px; }
.contact-cell span { margin-top:4px; color:var(--muted); font-size:11px; }
.patient-actions { display:flex; align-items:center; justify-content:flex-end; gap:7px; min-width:165px; }
.btn-sm { padding:8px 10px; border-radius:8px; font-size:12px; white-space:nowrap; }
.row-action-menu { position:relative; }
.row-action-menu summary { list-style:none; width:34px; height:34px; display:grid; place-items:center; border:1px solid var(--line); border-radius:8px; background:#fff; color:#607586; cursor:pointer; font-weight:900; letter-spacing:1px; }
.row-action-menu summary::-webkit-details-marker { display:none; }
.row-action-menu[open] summary { border-color:var(--primary); color:var(--primary); background:var(--primary-soft); }
.row-action-popover { position:absolute; z-index:12; right:0; top:40px; width:205px; padding:6px; border:1px solid var(--line); border-radius:10px; background:#fff; box-shadow:0 14px 34px rgba(22,53,74,.16); }
.row-action-popover button { display:block; width:100%; padding:9px 10px; border:0; border-radius:7px; background:transparent; color:#425a69; text-align:left; font-size:12px; }
.row-action-popover button:hover { background:#eef5f8; color:var(--primary); }

/* Configuration workspace, desktop inspired by modern medical SaaS */
.settings-layout { display:grid; grid-template-columns:248px minmax(0,1fr); gap:16px; align-items:start; }
.settings-nav { position:sticky; top:86px; overflow:hidden; padding:8px; border:1px solid var(--line); border-radius:12px; background:var(--surface); box-shadow:0 8px 22px rgba(24,56,84,.05); }
.settings-nav-title { padding:10px 10px 12px; color:var(--muted); font-size:10px; font-weight:900; text-transform:uppercase; letter-spacing:.8px; }
.settings-nav-item { display:flex; width:100%; gap:10px; align-items:flex-start; padding:11px 10px; border:0; border-radius:9px; background:transparent; color:#536a79; text-align:left; }
.settings-nav-item:hover { background:#f1f6f8; }
.settings-nav-item.active { background:var(--primary-soft); color:var(--primary); box-shadow:inset 3px 0 0 var(--primary); }
.settings-nav-item strong,.settings-nav-item small { display:block; }
.settings-nav-item strong { font-size:13px; }
.settings-nav-item small { margin-top:3px; color:var(--muted); font-size:10px; line-height:1.35; }
.settings-nav-icon { width:20px; flex:0 0 auto; text-align:center; font-size:15px; }
.settings-content { min-width:0; }
.settings-content > .grid:first-child,.settings-content > form > .grid:first-child { align-items:start; }

/* Odontogram aligned by opposing arches */
.dental-arch { min-width:920px; padding:8px 0; }
.dental-arch+.dental-arch { border-top:0; margin-top:0; padding-top:8px; }
.dental-arch-label { margin:0 0 6px; }
.dental-arch-lower .dental-arch-label { order:2; margin:6px 0 0; }
.dental-arch-lower { display:flex; flex-direction:column; }
.dental-arch-lower .dental-row { order:1; }
.dental-unit { align-content:center; gap:3px; }
.dental-unit-upper .dental-silhouette { transform:rotate(180deg); }
.dental-unit-upper .missing-cross { transform:rotate(180deg); }
.dental-unit-lower .dental-silhouette { transform:none; }
.dental-unit-upper .tooth-note { order:0; margin-bottom:3px; }
.dental-unit-upper .dental-silhouette { order:1; }
.dental-unit-upper .tooth-number { order:2; }
.dental-unit-upper .surface-map { order:3; margin-top:1px; }
.dental-unit-lower .surface-map { order:0; margin-bottom:1px; }
.dental-unit-lower .tooth-number { order:1; }
.dental-unit-lower .dental-silhouette { order:2; }
.dental-unit-lower .tooth-note { order:3; margin-top:3px; }
.dental-occlusion-line { position:relative; min-width:920px; height:22px; margin:1px 0; display:flex; align-items:center; justify-content:center; }
.dental-occlusion-line::before { content:""; position:absolute; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,#bfcdd6 8%,#bfcdd6 92%,transparent); }
.dental-occlusion-line span { position:relative; padding:2px 9px; border-radius:999px; background:#fff; color:#8a9ba7; font-size:9px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; }

:root[data-theme="dark"] .patient-toolbar,:root[data-theme="dark"] .row-action-menu summary,:root[data-theme="dark"] .row-action-popover,:root[data-theme="dark"] .dental-occlusion-line span { background:var(--surface); }
:root[data-theme="dark"] .row-action-popover button { color:#d9e7ed; }

@media(max-width:980px){.settings-layout{grid-template-columns:1fr}.settings-nav{position:static;display:flex;overflow-x:auto;gap:5px}.settings-nav-title{display:none}.settings-nav-item{min-width:185px}.patient-toolbar{grid-template-columns:1fr 1fr}.patient-search{grid-column:1/-1}}
@media(max-width:880px){.app-shell.sidebar-collapsed{grid-template-columns:1fr}.app-shell.sidebar-collapsed .sidebar{width:276px;padding:0 12px 16px;transform:none}.sidebar-toggle{display:inline-grid}.sidebar:not(.open){left:-290px}.sidebar.open{left:0}.patients-overview{grid-template-columns:1fr}.patient-toolbar{grid-template-columns:1fr}.patient-search{grid-column:auto}}
@media(max-width:620px){.settings-nav-item{min-width:160px}.settings-nav-item small{display:none}.patient-directory-head{padding:14px 14px 0}.patient-actions{justify-content:flex-start}.row-action-popover{left:0;right:auto}.patients-overview{gap:8px}.patients-overview>div{padding:12px 13px}}

/* Phase 5B image storage verification */
.history-file-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;margin:12px 0}.history-file-card{display:flex;gap:10px;align-items:center;padding:8px;border:1px solid var(--line,#d6dee6);border-radius:8px;text-decoration:none;background:#fff;color:inherit}.history-file-card img{width:58px;height:58px;object-fit:cover;border-radius:6px;background:#f4f7f9}.history-file-card span{display:flex;flex-direction:column;gap:4px;min-width:0;font-weight:600}.history-file-card small{font-size:11px;color:#5d6b79;font-weight:400}.asset-thumb img{object-fit:contain}

/* Phase 5C medical notes */
.file-type-badge{display:grid;place-items:center;width:58px;height:58px;border-radius:6px;background:#fee2e2;color:#991b1b;font-size:14px;font-weight:900;letter-spacing:.08em}.section-box p{white-space:pre-wrap;line-height:1.55;margin:8px 0 0}.clinical-section-body .detail-grid{margin-top:0}

/* Fase 5D: filtros clínicos y recetas médicas odontológicas */
.record-filter-bar{display:grid;grid-template-columns:minmax(170px,1.2fr) minmax(180px,1fr) minmax(135px,.7fr) minmax(135px,.7fr) auto;gap:10px;align-items:end;padding:14px;margin:0 0 14px;border:1px solid var(--border);border-radius:12px;background:var(--card);box-shadow:var(--shadow)}
.record-filter-bar .field{margin:0}.record-filter-bar label{font-size:11px;text-transform:uppercase;letter-spacing:.055em;color:var(--muted);font-weight:800}.filter-actions{display:flex;align-items:end}.filter-actions .btn{white-space:nowrap}.rx-folio{color:#bf1e2e}.prescription-medication-row{padding:14px;border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--primary) 2%,var(--card));margin-bottom:12px}.prescription-row-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:11px}.prescription-row-head strong{color:var(--primary)}.btn-small{padding:7px 10px;font-size:12px}.signature-grid.one-column{grid-template-columns:1fr;max-width:760px}.record-content .table-actions{gap:6px;flex-wrap:wrap}
@media(max-width:1100px){.record-filter-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-actions{grid-column:1/-1}.filter-actions .btn{width:100%}}
@media(max-width:620px){.record-filter-bar{grid-template-columns:1fr;padding:12px}.filter-actions{grid-column:auto}.prescription-medication-row{padding:11px}}

/* Phase 5D.1: clinical accordions follow workspace primary color */
.clinical-section summary {
  background: var(--primary);
  color: #ffffff;
  border-bottom: 1px solid color-mix(in srgb, var(--primary) 78%, #000000 22%);
  transition: background-color .18s ease, filter .18s ease;
}
.clinical-section summary:hover {
  filter: brightness(.96);
}
.clinical-section[open] summary {
  background: color-mix(in srgb, var(--primary) 88%, #000000 12%);
}
.clinical-section summary strong {
  color: #ffffff;
}
.clinical-section summary div span {
  color: rgba(255,255,255,.82);
}
.clinical-section summary > span {
  color: #ffffff;
  font-size: 18px;
  line-height: 1;
  margin-top: 0;
  opacity: .95;
}
:root[data-theme="dark"] .clinical-section summary,
:root[data-theme="dark"] .clinical-section[open] summary {
  background: var(--primary);
  color: #ffffff;
}

/* Phase 5E: reusable templates and informed consent documents */
.rich-editor-shell{overflow:hidden;border:1px solid var(--line);border-radius:12px;background:var(--surface)}
.rich-toolbar{display:flex;flex-wrap:wrap;gap:7px;align-items:center;padding:9px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--primary) 5%,var(--surface))}
.rich-tool{min-width:34px;height:32px;padding:0 9px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--primary);cursor:pointer;font-size:13px}
.rich-tool:hover,.rich-variable:hover{border-color:var(--primary);background:var(--primary-soft)}
.rich-size{width:92px;min-width:92px;height:32px;padding:4px 7px;font-size:12px}
.rich-variable-wrap{display:flex;flex-wrap:wrap;gap:5px;align-items:center;flex:1 1 100%}
.rich-variable-wrap>span{margin-right:3px;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.rich-variable{padding:5px 8px;border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--primary);cursor:pointer;font-size:11px;font-weight:700}
.rich-editor{min-height:230px;padding:15px;background:var(--surface);color:var(--text);font-size:15px;line-height:1.62;outline:none}
.rich-editor:focus{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--primary) 20%,transparent)}
.rich-editor p{margin:.4em 0}.rich-editor ul,.rich-editor ol{padding-left:24px}.rich-editor li{margin:.22em 0}
.rich-preview{line-height:1.65}.rich-preview>div{margin-top:10px}.rich-preview p{margin:.55em 0}.rich-preview ul,.rich-preview ol{padding-left:24px}
@media(max-width:620px){.rich-editor{min-height:190px;padding:12px}.rich-toolbar{gap:6px;padding:7px}.rich-variable-wrap>span{width:100%}}


/* Performance state feedback */
.patient-sync-state{display:flex;align-items:center;justify-content:flex-end;min-width:190px;font-size:12px;color:#607386;text-align:right}.patient-loading,.patient-loaded,.patient-load-error{display:inline-flex;align-items:center;gap:7px}.patient-loading i{width:12px;height:12px;border:2px solid rgba(23,71,111,.22);border-top-color:var(--primary);border-radius:50%;animation:odontosuite-spin .72s linear infinite}.patient-loaded{color:#267346}.patient-load-error{color:#a23b48;max-width:280px}.patient-directory .table-wrap{content-visibility:auto;contain-intrinsic-size:520px}.content{transition:opacity .16s ease}.btn{transition:transform .12s ease,box-shadow .12s ease,background-color .16s ease,border-color .16s ease}.btn:not(:disabled):active{transform:translateY(1px)}@keyframes odontosuite-spin{to{transform:rotate(360deg)}}
@media(max-width:760px){.patient-sync-state{justify-content:flex-start;text-align:left;min-width:0;margin-top:8px}.patient-directory-head{align-items:flex-start;flex-direction:column}}

/* Phase 5H: treatment catalog and permanent treatment plans */
.plan-item-row{padding:14px;margin:0 0 12px;border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--primary) 3%,var(--card));box-shadow:0 3px 12px rgba(16,43,66,.04)}
.plan-row-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:11px}.plan-row-heading strong{color:var(--primary)}
.plan-total-box{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:14px;padding:14px 16px;border:1px solid color-mix(in srgb,var(--primary) 32%,var(--border));border-radius:12px;background:color-mix(in srgb,var(--primary) 7%,var(--card))}.plan-total-box span{font-weight:700;color:var(--muted)}.plan-total-box strong{font-size:18px;color:var(--primary)}
.tooth-multi{min-height:100px}.local-image-preview{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}.local-image-preview span{padding:6px 9px;border:1px solid var(--border);border-radius:999px;background:var(--card);color:var(--muted);font-size:12px}
.treatment-catalog-note{line-height:1.5}
@media(max-width:620px){.plan-item-row{padding:11px}.plan-total-box{align-items:flex-start;flex-direction:column}.plan-total-box strong{font-size:16px}}


/* Phase 5H.2: spacious professional forms and treatment plan editor */
.form-grid{gap:18px 20px}
.field{gap:8px}
.field label{font-size:12px;letter-spacing:.025em;color:color-mix(in srgb,var(--text) 82%,var(--muted));line-height:1.35}
.field small{display:block;color:var(--muted);font-size:11px;line-height:1.5;margin-top:1px}
.input,.select,.textarea{min-height:44px;padding:12px 13px;border-radius:10px;background:var(--surface);line-height:1.45}
.textarea{min-height:118px;line-height:1.58}
.clinical-form{gap:18px}
.clinical-section{border-radius:16px;box-shadow:0 5px 18px rgba(16,43,66,.045)}
.clinical-section summary{padding:17px 20px}
.clinical-section-body{padding:22px}
.clinical-section-body>.field,.clinical-section-body>.form-grid,.clinical-section-body>.detail-grid{max-width:1500px}
.clinical-section-body .form-grid{gap:18px 20px}
.clinical-section-body .field{padding:13px 14px;border:1px solid color-mix(in srgb,var(--border) 86%,var(--primary) 14%);border-radius:12px;background:color-mix(in srgb,var(--primary) 2%,var(--surface));align-content:start}
.clinical-section-body .field .input,.clinical-section-body .field .select,.clinical-section-body .field .textarea{background:var(--surface)}
.clinical-section-body .conditional-grid{gap:14px;padding:14px}
.clinical-section-body .conditional-grid .field{padding:12px}
.plan-item-row{padding:18px;margin-bottom:16px;border-radius:15px;background:color-mix(in srgb,var(--primary) 2%,var(--surface));box-shadow:0 6px 18px rgba(16,43,66,.055)}
.plan-row-heading{align-items:flex-start;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid color-mix(in srgb,var(--border) 82%,var(--primary) 18%)}
.plan-row-heading strong,.plan-row-heading span{display:block}
.plan-row-heading strong{font-size:15px}
.plan-row-heading span{max-width:780px;margin-top:4px;color:var(--muted);font-size:12px;line-height:1.5}
.plan-item-stack{display:grid;gap:13px}
.plan-item-group{padding:14px;border:1px solid color-mix(in srgb,var(--border) 88%,var(--primary) 12%);border-radius:12px;background:var(--surface)}
.plan-item-group-title{margin-bottom:11px;color:var(--primary);font-size:11px;font-weight:850;letter-spacing:.07em;text-transform:uppercase}
.plan-item-main-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px}
.plan-item-editor-grid{display:grid;grid-template-columns:minmax(260px,1fr) minmax(130px,.28fr) minmax(150px,.3fr);gap:14px 16px}
.plan-item-clinical-grid{display:grid;grid-template-columns:minmax(230px,.65fr) minmax(300px,1.35fr);gap:14px 16px}
.plan-item-group .field{padding:0;border:0;background:transparent;margin:0}
.plan-item-group .textarea{min-height:126px}
.plan-item-group .tooth-multi{min-height:126px}
.plan-total-box{margin-top:18px;padding:16px 18px;border-radius:13px}
.settings-content .form-grid,.modal-body .form-grid{gap:18px 20px}
.settings-content .section-box{padding:16px}
.signature-grid{gap:20px}
@media(max-width:980px){.plan-item-editor-grid,.plan-item-clinical-grid{grid-template-columns:1fr}.plan-item-main-grid{grid-template-columns:1fr}}
@media(max-width:700px){.clinical-section summary{padding:15px 16px}.clinical-section-body{padding:15px}.clinical-section-body .field{padding:11px 12px}.form-grid{gap:13px}.plan-item-row{padding:13px}.plan-item-group{padding:12px}.plan-row-heading{gap:8px}.textarea{min-height:104px}}
:root[data-theme="dark"] .clinical-section-body .field,:root[data-theme="dark"] .plan-item-row,:root[data-theme="dark"] .plan-item-group{background:color-mix(in srgb,var(--surface) 94%,var(--primary) 6%)}


/* Phase 5H.3: treatment plan cost per odontological organ and optional signature */
.plan-line-total{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:13px;padding:11px 13px;border:1px solid color-mix(in srgb,var(--primary) 22%,var(--border));border-radius:10px;background:color-mix(in srgb,var(--primary) 5%,var(--surface))}
.plan-line-total span{color:var(--muted);font-size:12px;font-weight:700;line-height:1.45}.plan-line-total strong{color:var(--primary);font-size:15px;text-align:right}.optional-label{color:var(--muted);font-size:11px;font-weight:600}
@media(max-width:620px){.plan-line-total{align-items:flex-start;flex-direction:column}.plan-line-total strong{text-align:left}}

/* Phase 5I: payments and patient statement */
.financial-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}.financial-summary article{padding:16px 17px;border:1px solid color-mix(in srgb,var(--border) 82%,var(--primary) 18%);border-radius:14px;background:linear-gradient(145deg,color-mix(in srgb,var(--primary) 4%,var(--surface)),var(--surface));box-shadow:0 5px 16px rgba(16,43,66,.045)}.financial-summary span{display:block;color:var(--muted);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.financial-summary strong{display:block;margin-top:8px;color:var(--primary);font-size:18px;line-height:1.25}.payment-method-row{display:grid;grid-template-columns:minmax(180px,.8fr) minmax(130px,.35fr) minmax(220px,1fr) auto;gap:12px;align-items:end;margin-bottom:12px;padding:13px;border:1px solid color-mix(in srgb,var(--border) 84%,var(--primary) 16%);border-radius:12px;background:color-mix(in srgb,var(--primary) 3%,var(--surface))}.payment-method-row .field{padding:0!important;border:0!important;background:transparent!important}.check-row{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;background:color-mix(in srgb,var(--primary) 5%,var(--surface));font-size:13px;font-weight:700}.attachment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.attachment-card{display:grid;gap:4px;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:inherit;text-decoration:none}.attachment-card:hover{border-color:var(--primary)}.attachment-card span,.attachment-card small{color:var(--muted);font-size:11px}.break-all{overflow-wrap:anywhere;word-break:break-all}.icon-btn.danger{color:#b91c1c}
@media(max-width:980px){.financial-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.payment-method-row{grid-template-columns:1fr 1fr}.payment-method-row .btn{justify-self:start}}
@media(max-width:620px){.financial-summary{grid-template-columns:1fr}.payment-method-row{grid-template-columns:1fr}}
.attachment-card[type="button"]{width:100%;cursor:pointer;text-align:left;font:inherit}

/* Phase 5J: integral patient summary, timeline and general files */
.record-summary-grid{display:grid;gap:14px;margin-bottom:16px}.summary-alert{display:flex;gap:8px;flex-direction:column;padding:15px 17px;border-radius:14px;border:1px solid var(--border);background:var(--surface)}.summary-alert strong{font-size:14px}.summary-alert span{font-size:13px;line-height:1.5}.summary-alert.warning{border-color:#f2b8b8;background:#fff3f3;color:#9f1d1d}.summary-alert.ok{border-color:#bce0c7;background:#f2fbf5;color:#17663a}.summary-actions{display:flex;flex-wrap:wrap;gap:9px}.summary-card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.summary-card-grid article{min-height:92px;padding:14px 15px;border:1px solid color-mix(in srgb,var(--border) 82%,var(--primary) 18%);border-radius:13px;background:linear-gradient(145deg,color-mix(in srgb,var(--primary) 4%,var(--surface)),var(--surface));box-shadow:0 5px 14px rgba(16,43,66,.04)}.summary-card-grid span{display:block;color:var(--muted);font-size:10px;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.summary-card-grid strong{display:block;margin-top:9px;color:var(--primary);font-size:15px;line-height:1.38}.vitals-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.vitals-summary div{padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.vitals-summary span,.vitals-summary strong{display:block}.vitals-summary span{color:var(--muted);font-size:10px;font-weight:800;text-transform:uppercase}.vitals-summary strong{margin-top:5px;color:var(--primary);font-size:13px}.muted-line{display:block;margin-top:11px;color:var(--muted)}.timeline-filter{display:grid;grid-template-columns:minmax(180px,.8fr) minmax(190px,1fr) minmax(145px,.5fr) minmax(145px,.5fr) auto;gap:10px;margin-bottom:14px}.record-timeline{display:grid;gap:0}.timeline-item{position:relative;display:grid;grid-template-columns:18px minmax(0,1fr) auto;gap:11px;padding:11px 0;border-bottom:1px solid var(--border)}.timeline-item:last-child{border-bottom:0}.timeline-dot{width:11px;height:11px;margin-top:4px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 13%,transparent)}.timeline-item strong,.timeline-item small,.timeline-item p{display:block}.timeline-item small{margin-top:4px;color:var(--muted);font-size:11px}.timeline-item p{margin:5px 0 0;color:var(--text);font-size:12px}.general-file-grid{display:grid;gap:11px}.general-file-card{display:grid;grid-template-columns:84px minmax(0,1fr) auto;gap:13px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:13px;background:var(--surface)}.general-file-card.voided{opacity:.68;background:color-mix(in srgb,#b91c1c 4%,var(--surface))}.general-file-card img,.general-file-icon{width:84px;height:68px;border-radius:9px;object-fit:cover;border:1px solid var(--border);background:color-mix(in srgb,var(--primary) 7%,var(--surface))}.general-file-icon{display:grid;place-items:center;color:var(--primary);font-size:16px;font-weight:900}.general-file-main strong,.general-file-main span,.general-file-main small,.general-file-main em{display:block}.general-file-main strong{color:var(--primary);font-size:14px}.general-file-main span{margin-top:4px;font-size:12px}.general-file-main small{margin-top:4px;color:var(--muted);font-size:11px}.general-file-main p{margin:7px 0 0;color:var(--text);font-size:12px}.general-file-main em{margin-top:6px;color:#9f1d1d;font-size:11px}.general-file-actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:1120px){.summary-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.timeline-filter{grid-template-columns:repeat(2,minmax(0,1fr))}.timeline-filter .btn{justify-self:start}.record-overview-grid{grid-template-columns:1fr!important}}
@media(max-width:700px){.summary-card-grid{grid-template-columns:1fr}.summary-actions .btn{flex:1 1 calc(50% - 9px)}.vitals-summary{grid-template-columns:1fr}.timeline-filter{grid-template-columns:1fr}.timeline-item{grid-template-columns:14px minmax(0,1fr)}.timeline-item .btn{grid-column:2;justify-self:start}.general-file-card{grid-template-columns:64px minmax(0,1fr)}.general-file-card img,.general-file-icon{width:64px;height:58px}.general-file-actions{grid-column:2;justify-content:flex-start}}

/* Sincronización multidispositivo en tiempo real */
.realtime-chip{display:inline-flex;align-items:center;gap:7px;min-height:30px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap;border:1px solid rgba(23,71,111,.14);background:#eef6fb;color:#17476f;transition:background .2s ease,color .2s ease,border-color .2s ease}
.realtime-chip i{display:block;width:8px;height:8px;border-radius:50%;background:#2f89a8;box-shadow:0 0 0 3px rgba(47,137,168,.14)}
.realtime-chip.connected{background:#edf9f2;color:#17613a;border-color:#ccebd8}
.realtime-chip.connected i{background:#23a55a;box-shadow:0 0 0 3px rgba(35,165,90,.15)}
.realtime-chip.connecting{background:#f1f6fb;color:#315b7d;border-color:#d6e3ed}
.realtime-chip.connecting i{background:#4e8db7;animation:syncPulse 1.25s ease-in-out infinite}
.realtime-chip.pending{background:#fff8e8;color:#916015;border-color:#f3dfaa}
.realtime-chip.pending i{background:#e6a525;animation:syncPulse 1s ease-in-out infinite}
.realtime-chip.offline{background:#fff0f0;color:#a22b31;border-color:#f1d0d2}
.realtime-chip.offline i{background:#cf4e55;box-shadow:0 0 0 3px rgba(207,78,85,.14)}
@keyframes syncPulse{0%,100%{opacity:.45;transform:scale(.85)}50%{opacity:1;transform:scale(1.12)}}
@media(max-width:980px){.realtime-chip{padding:0 8px}.realtime-chip span{display:none}}

/* Phase 5L: premium orthodontics module */
.ortho-module-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:0 0 14px;padding:18px 20px;border:1px solid color-mix(in srgb,var(--primary) 20%,var(--border));border-radius:16px;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 8%,var(--surface)),var(--surface));box-shadow:0 6px 18px rgba(16,43,66,.045)}
.ortho-module-head h2{margin:8px 0 4px;color:var(--primary);font-size:23px;line-height:1.2}.ortho-module-head p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}
.premium-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;background:color-mix(in srgb,var(--primary) 12%,var(--surface));color:var(--primary);font-size:10px;font-weight:850;letter-spacing:.065em;text-transform:uppercase}
.ortho-subnav{display:flex;gap:8px;overflow-x:auto;margin:0 0 16px;padding:8px;border:1px solid var(--border);border-radius:13px;background:var(--surface);scrollbar-width:thin}
.ortho-subtab{min-height:38px;padding:0 13px;border:1px solid transparent;border-radius:9px;background:transparent;color:var(--muted);cursor:pointer;font-size:12px;font-weight:800;white-space:nowrap;transition:background-color .16s ease,color .16s ease,border-color .16s ease}
.ortho-subtab:hover{border-color:color-mix(in srgb,var(--primary) 25%,var(--border));background:color-mix(in srgb,var(--primary) 5%,var(--surface));color:var(--primary)}
.ortho-subtab.active{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 18%,transparent)}
.prefilled-grid{margin-bottom:16px}
@media(max-width:700px){.ortho-module-head{padding:15px 16px}.ortho-module-head h2{font-size:20px}.ortho-subnav{margin-inline:-2px;padding:6px}.ortho-subtab{min-height:36px;padding:0 11px}}
.ortho-gallery-filter-bar{margin-bottom:12px}.ortho-gallery-stats{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 14px}.ortho-gallery-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);font-size:12px;font-weight:800;cursor:pointer}.ortho-gallery-pill strong{color:var(--primary)}.ortho-gallery-pill.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,var(--surface));color:var(--primary)}.ortho-gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.ortho-gallery-card{display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:0 5px 16px rgba(16,43,66,.045)}.ortho-gallery-preview{display:block;padding:0;border:0;background:color-mix(in srgb,var(--primary) 5%,var(--surface));cursor:pointer}.ortho-gallery-preview img{display:block;width:100%;height:240px;object-fit:cover}.ortho-gallery-preview.pdf{display:grid;place-items:center;height:240px}.ortho-gallery-icon{display:grid;place-items:center;width:110px;height:110px;border-radius:24px;border:1px solid color-mix(in srgb,var(--primary) 24%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 12%,var(--surface)),var(--surface));color:var(--primary);font-size:30px;font-weight:900;letter-spacing:.06em}.ortho-gallery-body{display:grid;gap:8px;padding:15px 15px 8px}.ortho-gallery-body strong{font-size:15px;line-height:1.35;color:var(--primary)}.ortho-gallery-body span,.ortho-gallery-body small,.ortho-gallery-body p{margin:0;color:var(--muted);overflow-wrap:anywhere}.ortho-gallery-body span{font-size:12px}.ortho-gallery-body p{font-size:12px;line-height:1.55;color:var(--text)}.ortho-gallery-body small{font-size:11px}.ortho-gallery-meta{display:flex;flex-wrap:wrap;gap:7px}.badge.subtle{background:color-mix(in srgb,var(--primary) 5%,var(--surface));color:var(--primary)}.ortho-gallery-actions{display:flex;gap:8px;padding:0 15px 15px}.ortho-gallery-actions .btn{flex:1}.ortho-viewer{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(260px,.9fr);gap:18px;align-items:start}.ortho-viewer-stage{display:grid;place-items:center;min-height:360px;padding:12px;border:1px solid var(--border);border-radius:16px;background:#f8fafc}.ortho-viewer-stage img{max-width:100%;max-height:68vh;border-radius:12px;box-shadow:0 8px 24px rgba(16,43,66,.12)}.ortho-viewer-pdf{display:grid;place-items:center;gap:10px;text-align:center;color:var(--muted)}.ortho-viewer-sidebar{padding:14px;border:1px solid var(--border);border-radius:16px;background:var(--surface)}.detail-list{display:grid;gap:12px}.detail-list div{display:grid;gap:4px}.detail-list strong{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--primary)}.detail-list span{font-size:13px;color:var(--text);overflow-wrap:anywhere}.detail-list .mono{font-size:11px;color:var(--muted)}@media(max-width:920px){.ortho-viewer{grid-template-columns:1fr}.ortho-viewer-stage{min-height:260px}}@media(max-width:620px){.ortho-gallery-grid{grid-template-columns:1fr}.ortho-gallery-preview img,.ortho-gallery-preview.pdf{height:220px}.ortho-gallery-actions{flex-direction:column}}

/* Phase 5L: premium periodontics module */
.perio-module-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:0 0 14px;padding:18px 20px;border:1px solid color-mix(in srgb,var(--primary) 20%,var(--border));border-radius:16px;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 8%,var(--surface)),var(--surface));box-shadow:0 6px 18px rgba(16,43,66,.045)}
.perio-module-head h2{margin:8px 0 4px;color:var(--primary);font-size:23px;line-height:1.2}.perio-module-head p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}
.premium-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;background:color-mix(in srgb,var(--primary) 12%,var(--surface));color:var(--primary);font-size:10px;font-weight:850;letter-spacing:.065em;text-transform:uppercase}
.perio-subnav{display:flex;gap:8px;overflow-x:auto;margin:0 0 16px;padding:8px;border:1px solid var(--border);border-radius:13px;background:var(--surface);scrollbar-width:thin}
.perio-subtab{min-height:38px;padding:0 13px;border:1px solid transparent;border-radius:9px;background:transparent;color:var(--muted);cursor:pointer;font-size:12px;font-weight:800;white-space:nowrap;transition:background-color .16s ease,color .16s ease,border-color .16s ease}
.perio-subtab:hover{border-color:color-mix(in srgb,var(--primary) 25%,var(--border));background:color-mix(in srgb,var(--primary) 5%,var(--surface));color:var(--primary)}
.perio-subtab.active{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 18%,transparent)}
.prefilled-grid{margin-bottom:16px}
@media(max-width:700px){.perio-module-head{padding:15px 16px}.perio-module-head h2{font-size:20px}.perio-subnav{margin-inline:-2px;padding:6px}.perio-subtab{min-height:36px;padding:0 11px}}
.perio-gallery-filter-bar{margin-bottom:12px}.perio-gallery-stats{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 14px}.perio-gallery-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);font-size:12px;font-weight:800;cursor:pointer}.perio-gallery-pill strong{color:var(--primary)}.perio-gallery-pill.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,var(--surface));color:var(--primary)}.perio-gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.perio-gallery-card{display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:0 5px 16px rgba(16,43,66,.045)}.perio-gallery-preview{display:block;padding:0;border:0;background:color-mix(in srgb,var(--primary) 5%,var(--surface));cursor:pointer}.perio-gallery-preview img{display:block;width:100%;height:240px;object-fit:cover}.perio-gallery-preview.pdf{display:grid;place-items:center;height:240px}.perio-gallery-icon{display:grid;place-items:center;width:110px;height:110px;border-radius:24px;border:1px solid color-mix(in srgb,var(--primary) 24%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 12%,var(--surface)),var(--surface));color:var(--primary);font-size:30px;font-weight:900;letter-spacing:.06em}.perio-gallery-body{display:grid;gap:8px;padding:15px 15px 8px}.perio-gallery-body strong{font-size:15px;line-height:1.35;color:var(--primary)}.perio-gallery-body span,.perio-gallery-body small,.perio-gallery-body p{margin:0;color:var(--muted);overflow-wrap:anywhere}.perio-gallery-body span{font-size:12px}.perio-gallery-body p{font-size:12px;line-height:1.55;color:var(--text)}.perio-gallery-body small{font-size:11px}.perio-gallery-meta{display:flex;flex-wrap:wrap;gap:7px}.badge.subtle{background:color-mix(in srgb,var(--primary) 5%,var(--surface));color:var(--primary)}.perio-gallery-actions{display:flex;gap:8px;padding:0 15px 15px}.perio-gallery-actions .btn{flex:1}.perio-viewer{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(260px,.9fr);gap:18px;align-items:start}.perio-viewer-stage{display:grid;place-items:center;min-height:360px;padding:12px;border:1px solid var(--border);border-radius:16px;background:#f8fafc}.perio-viewer-stage img{max-width:100%;max-height:68vh;border-radius:12px;box-shadow:0 8px 24px rgba(16,43,66,.12)}.perio-viewer-pdf{display:grid;place-items:center;gap:10px;text-align:center;color:var(--muted)}.perio-viewer-sidebar{padding:14px;border:1px solid var(--border);border-radius:16px;background:var(--surface)}.detail-list{display:grid;gap:12px}.detail-list div{display:grid;gap:4px}.detail-list strong{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--primary)}.detail-list span{font-size:13px;color:var(--text);overflow-wrap:anywhere}.detail-list .mono{font-size:11px;color:var(--muted)}@media(max-width:920px){.perio-viewer{grid-template-columns:1fr}.perio-viewer-stage{min-height:260px}}@media(max-width:620px){.perio-gallery-grid{grid-template-columns:1fr}.perio-gallery-preview img,.perio-gallery-preview.pdf{height:220px}.perio-gallery-actions{flex-direction:column}}


/* Phase 5M: premium periodontics module */
.perio-chart-grid{display:grid;grid-template-columns:1fr;gap:14px}
.perio-tooth-card{border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:13px;box-shadow:0 4px 14px rgba(16,43,66,.035)}
.perio-tooth-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:10px}
.perio-tooth-head strong{margin-right:auto;color:var(--primary);font-size:15px}
.perio-tooth-head label{font-size:12px;color:var(--muted);font-weight:750}
.perio-site-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-bottom:10px}
.perio-site{display:grid;gap:5px;padding:8px;border:1px solid color-mix(in srgb,var(--border) 85%,var(--primary) 15%);border-radius:10px;background:color-mix(in srgb,var(--primary) 3%,var(--surface))}
.perio-site strong{font-size:11px;color:var(--primary);text-align:center}.perio-site .input{min-height:34px;padding:6px;font-size:12px}.perio-site label{font-size:10px;color:var(--muted);font-weight:700}
.form-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.form-grid.compact .field{padding:0!important;border:0!important;background:transparent!important}
@media(max-width:1100px){.perio-site-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.form-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:620px){.perio-site-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid.compact{grid-template-columns:1fr}}

/* Phase 5M2: PerioChart-style professional periodontal chart form */
.periochart-form .section-body{overflow:visible}.perio-chart-panel{margin:16px 0;border:1px solid color-mix(in srgb,var(--primary) 20%,var(--border));border-radius:16px;background:var(--surface);box-shadow:0 6px 18px rgba(16,43,66,.05);overflow:hidden}.perio-chart-panel-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:14px 16px;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 10%,var(--surface)),var(--surface));border-bottom:1px solid var(--border)}.perio-chart-panel-head strong{display:block;color:var(--primary);font-size:15px}.perio-chart-panel-head span{display:block;margin-top:3px;color:var(--muted);font-size:12px;line-height:1.45}.perio-site-legend{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}.perio-site-legend span{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:24px;padding:0 7px;border:1px solid color-mix(in srgb,var(--primary) 20%,var(--border));border-radius:999px;background:var(--surface);color:var(--primary);font-size:10px;font-weight:900}.perio-chart-scroll{overflow:auto;max-width:100%;padding-bottom:6px}.periochart-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.periochart-table th,.periochart-table td{border-right:1px solid var(--border);border-bottom:1px solid var(--border);vertical-align:middle}.periochart-table thead th{position:sticky;top:0;z-index:3;background:var(--primary);color:#fff;font-size:10px;font-weight:900;text-align:center;padding:9px 6px;white-space:nowrap}.periochart-table thead th:first-child{left:0;z-index:4}.periochart-table tbody th{position:sticky;left:0;z-index:2;width:118px;min-width:118px;padding:7px 8px;background:color-mix(in srgb,var(--primary) 8%,var(--surface));color:var(--primary);font-size:10px;font-weight:900;text-align:left;letter-spacing:.03em;text-transform:uppercase}.periochart-table td{width:116px;min-width:116px;padding:6px;background:#fff}.perio-surface-separator th{position:static!important;background:color-mix(in srgb,var(--primary) 14%,var(--surface))!important;color:var(--primary)!important;padding:9px 12px!important;font-size:11px!important;text-transform:uppercase!important;letter-spacing:.06em!important}.perio-micro-sites{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.perio-micro-input{width:100%;min-height:32px;border:1px solid var(--border);border-radius:8px;background:#f8fafc;color:var(--text);font-size:12px;font-weight:800;text-align:center}.perio-micro-input:focus{outline:2px solid color-mix(in srgb,var(--primary) 18%,transparent);border-color:var(--primary);background:#fff}.perio-micro-checks{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.perio-micro-checks label{display:grid;place-items:center;gap:2px;min-height:33px;border:1px solid var(--border);border-radius:8px;background:#f8fafc;color:var(--muted);font-size:8px;font-weight:850;cursor:pointer}.perio-micro-checks label:has(input:checked){border-color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,#fff);color:var(--primary)}.perio-status-cell{display:grid;grid-template-columns:1fr 1fr;gap:5px}.perio-status-cell label{display:flex;align-items:center;justify-content:center;gap:4px;min-height:32px;border:1px solid var(--border);border-radius:8px;background:#f8fafc;color:var(--muted);font-size:9px;font-weight:850}.perio-status-cell label:has(input:checked){border-color:#dc2626;background:#fef2f2;color:#b91c1c}.perio-mini-select,.perio-note-input{width:100%;min-height:32px;border:1px solid var(--border);border-radius:8px;background:#f8fafc;color:var(--text);font-size:11px;font-weight:750;padding:0 6px}.perio-note-input{font-size:10px}.perio-mini-select:focus,.perio-note-input:focus{outline:2px solid color-mix(in srgb,var(--primary) 18%,transparent);border-color:var(--primary);background:#fff}@media(max-width:760px){.perio-chart-panel-head{display:grid}.periochart-table tbody th{width:96px;min-width:96px}.periochart-table td{width:104px;min-width:104px}.perio-micro-input{min-height:30px;font-size:11px}.perio-micro-checks label{min-height:30px}}

/* Phase 5N: premium dental aesthetics module */
.esthetic-module-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:0 0 14px;padding:18px 20px;border:1px solid color-mix(in srgb,var(--primary) 20%,var(--border));border-radius:16px;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 8%,var(--surface)),var(--surface));box-shadow:0 6px 18px rgba(16,43,66,.045)}
.esthetic-module-head h2{margin:8px 0 4px;color:var(--primary);font-size:23px;line-height:1.2}.esthetic-module-head p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}
.esthetic-subnav{display:flex;gap:8px;overflow-x:auto;margin:0 0 16px;padding:8px;border:1px solid var(--border);border-radius:13px;background:var(--surface);scrollbar-width:thin}.esthetic-subtab{min-height:38px;padding:0 13px;border:1px solid transparent;border-radius:9px;background:transparent;color:var(--muted);cursor:pointer;font-size:12px;font-weight:800;white-space:nowrap}.esthetic-subtab:hover{border-color:color-mix(in srgb,var(--primary) 25%,var(--border));background:color-mix(in srgb,var(--primary) 5%,var(--surface));color:var(--primary)}.esthetic-subtab.active{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 18%,transparent)}
.esthetic-gallery-filter-bar{margin-bottom:12px}.esthetic-gallery-stats{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 14px}.esthetic-gallery-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);font-size:12px;font-weight:800;cursor:pointer}.esthetic-gallery-pill strong{color:var(--primary)}.esthetic-gallery-pill.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,var(--surface));color:var(--primary)}.esthetic-gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.esthetic-gallery-card{display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:0 5px 16px rgba(16,43,66,.045)}.esthetic-gallery-preview{display:block;padding:0;border:0;background:color-mix(in srgb,var(--primary) 5%,var(--surface));cursor:pointer}.esthetic-gallery-preview img{display:block;width:100%;height:240px;object-fit:cover}.esthetic-gallery-preview.pdf{display:grid;place-items:center;height:240px}.esthetic-gallery-icon{display:grid;place-items:center;width:110px;height:110px;border-radius:24px;border:1px solid color-mix(in srgb,var(--primary) 24%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 12%,var(--surface)),var(--surface));color:var(--primary);font-size:30px;font-weight:900;letter-spacing:.06em}.esthetic-gallery-body{display:grid;gap:8px;padding:15px 15px 8px}.esthetic-gallery-body strong{font-size:15px;line-height:1.35;color:var(--primary)}.esthetic-gallery-body span,.esthetic-gallery-body small,.esthetic-gallery-body p{margin:0;color:var(--muted);overflow-wrap:anywhere}.esthetic-gallery-actions{display:flex;gap:8px;padding:0 15px 15px}.esthetic-gallery-actions .btn{flex:1}.esthetic-viewer{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(260px,.9fr);gap:18px;align-items:start}.esthetic-viewer-stage{display:grid;place-items:center;min-height:360px;padding:12px;border:1px solid var(--border);border-radius:16px;background:#f8fafc}.esthetic-viewer-stage img{max-width:100%;max-height:68vh;border-radius:12px;box-shadow:0 8px 24px rgba(16,43,66,.12)}.esthetic-viewer-pdf{display:grid;place-items:center;gap:10px;text-align:center;color:var(--muted)}.esthetic-viewer-sidebar{padding:14px;border:1px solid var(--border);border-radius:16px;background:var(--surface)}
.esthetic-procedure-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.esthetic-procedure-card{display:flex;align-items:center;gap:9px;padding:11px 12px;border:1px solid var(--border);border-radius:12px;background:var(--surface);font-size:12px;font-weight:800;color:var(--text);cursor:pointer}.esthetic-procedure-card:has(input:checked){border-color:var(--primary);background:color-mix(in srgb,var(--primary) 9%,var(--surface));color:var(--primary)}
.esthetic-analysis-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.esthetic-analysis-canvas-wrap{overflow:auto;border:1px solid var(--border);border-radius:16px;background:#f8fafc;padding:12px}.esthetic-analysis-canvas-wrap canvas{display:block;width:100%;max-width:900px;height:auto;margin:auto;border-radius:12px;background:#fff;box-shadow:0 8px 20px rgba(16,43,66,.08);touch-action:none}.esthetic-analysis-preview{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(260px,.8fr);gap:18px}.esthetic-analysis-preview img{width:100%;border-radius:14px;border:1px solid var(--border);background:#f8fafc}.perio-instructions{margin-bottom:14px;padding:15px;border:1px solid color-mix(in srgb,var(--primary) 22%,var(--border));border-radius:16px;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 8%,var(--surface)),var(--surface));box-shadow:0 6px 18px rgba(16,43,66,.04)}.perio-instructions-title{font-size:13px;font-weight:900;color:var(--primary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px}.perio-instructions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.perio-chip{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:999px;font-size:11px;font-weight:800;border:1px solid var(--border)}.perio-chip b{font-size:11px}.perio-chip.pd,.perio-row-pd th{background:#ecfdf5;color:#047857}.perio-chip.rec,.perio-row-rec th{background:#eff6ff;color:#1d4ed8}.perio-chip.bop,.perio-row-bop th{background:#fff1f2;color:#be123c}.perio-chip.sup,.perio-row-sup th{background:#fffbeb;color:#b45309}.perio-chip.plaque,.perio-row-plaque th{background:#f5f3ff;color:#6d28d9}.perio-chip.status,.perio-row-status th,.perio-row-mobility th,.perio-row-furcation th,.perio-row-prognosis th{background:#f8fafc;color:#334155}.perio-instructions p{margin:10px 0 0;color:var(--muted);font-size:12px;line-height:1.55}.perio-row-pd td{background:#f0fdf4}.perio-row-rec td{background:#eff6ff}.perio-row-bop td{background:#fff1f2}.perio-row-sup td{background:#fffbeb}.perio-row-plaque td{background:#f5f3ff}
@media(max-width:920px){.esthetic-viewer,.esthetic-analysis-preview{grid-template-columns:1fr}.esthetic-viewer-stage{min-height:260px}}@media(max-width:620px){.esthetic-gallery-grid{grid-template-columns:1fr}.esthetic-gallery-preview img,.esthetic-gallery-preview.pdf{height:220px}.esthetic-gallery-actions{flex-direction:column}.esthetic-module-head{padding:15px 16px}.esthetic-subnav{padding:6px}.esthetic-subtab{min-height:36px;padding:0 11px}}
