:root{--bg: #f3f8f6;--bg-overlay: radial-gradient(circle at 100% 0%, #d7ebdf 0%, rgba(215, 235, 223, 0) 55%), radial-gradient(circle at 0% 100%, #dce8f5 0%, rgba(220, 232, 245, 0) 50%);--surface: #ffffff;--surface-2: #f8fbf8;--text-main: #15201b;--text-muted: #57685f;--line: #d6e3db;--brand: #1f8f65;--brand-deep: #176c4c;--font-body: "Outfit", sans-serif;--font-heading: "Space Grotesk", sans-serif;--font-scale: 17px;--font-scale-factor: 1.08;--danger: #b03a2f;--warning: #f8f5df;--shadow: 0 10px 36px rgba(37, 80, 62, .12);--dur-fast: .14s;--dur-med: .22s;--ease-out: cubic-bezier(.22, 1, .36, 1)}*{box-sizing:border-box}body{margin:0;color:var(--text-main);font-family:var(--font-body);font-size:var(--font-scale);line-height:1.45;background:var(--bg);background-image:var(--bg-overlay);min-height:100vh}button,input,select,textarea{font:inherit}.app-shell{max-width:760px;margin:0 auto;min-height:100vh;padding:1rem 1rem 6.5rem;background:var(--bg);background-image:var(--bg-overlay)}.admin-shell{max-width:1240px;margin:0 auto;min-height:100vh;padding:1rem 1rem 3rem;background:var(--bg);background-image:var(--bg-overlay)}.system-admin-banner{margin-bottom:.8rem;display:inline-flex;align-items:center;border:1px solid #cdbd77;background:#fff7d9;color:#6d5612;border-radius:999px;padding:.24rem .62rem;font-size:.8rem;font-weight:600;letter-spacing:.02em}.inactivity-logout-banner{margin:0 0 .8rem;border:1px solid #d3bf69;background:#fff7d8;color:#6d5612;border-radius:.75rem;padding:.55rem .7rem;font-size:.9rem;font-weight:600}.top-bar{display:flex;align-items:start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.top-bar-brand{display:flex;align-items:flex-start;gap:.9rem;min-width:0}.top-bar-brand-text{min-width:0}.top-bar-actions{display:flex;align-items:center;gap:.45rem}.top-bar-action-stack{display:flex;flex-direction:column;align-items:flex-end;gap:.32rem}.top-bar-user-email{margin:0;color:var(--text-muted);font-size:.82rem;line-height:1.2}.portal-title-row{display:flex;align-items:center;gap:.75rem;min-width:0}.portal-title-text{min-width:0}.practice-logo{width:3rem;height:3rem;object-fit:cover;background:#fff}.system-admin-shell .top-bar{position:relative;align-items:flex-start}.system-admin-shell .portal-title-row{align-items:flex-start;gap:.9rem}.system-admin-shell .practice-logo{width:auto;height:4.5rem;max-width:none;flex:0 0 auto;object-fit:contain;object-position:left center;background:transparent}.system-admin-shell .portal-title-text{position:absolute;left:50%;top:0;transform:translate(-50%);display:flex;flex-direction:column;justify-content:flex-start;align-items:center;text-align:center;width:max-content;max-width:calc(100% - 24rem);pointer-events:none}.patient-practice-logo{width:3rem;height:3rem;flex:0 0 auto;background:transparent}.top-bar h1{margin:0;font-family:var(--font-heading);font-size:clamp(calc(1.45rem * var(--font-scale-factor)),calc(3.5vw * var(--font-scale-factor)),calc(2.15rem * var(--font-scale-factor)));line-height:1.05}.top-bar-subtitle{margin:.35rem 0 0;color:var(--text-muted);font-size:calc(.98rem * var(--font-scale-factor))}.card{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:1rem;padding:.95rem;box-shadow:var(--shadow);transition:transform var(--dur-med) var(--ease-out),box-shadow var(--dur-med) var(--ease-out),border-color var(--dur-fast) ease}.day-controls{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem}.day-controls h2{margin:0;font-size:calc(1.08rem * var(--font-scale-factor))}.link-button{border:0;padding:0;margin-top:.25rem;color:var(--brand-deep);background:transparent;font-size:.9rem;cursor:pointer;transition:color var(--dur-fast) ease}.link-button:hover{color:var(--brand)}.warning-card{margin-top:.95rem;background:var(--warning);display:flex;align-items:center;justify-content:space-between;gap:.8rem}.events-list{display:grid;gap:.75rem;margin-top:.95rem}.events-list.is-animated .event-card{opacity:0;animation:event-card-enter .3s var(--ease-out) forwards}.events-list.is-animated .event-card:nth-child(1){animation-delay:0ms}.events-list.is-animated .event-card:nth-child(2){animation-delay:30ms}.events-list.is-animated .event-card:nth-child(3){animation-delay:60ms}.events-list.is-animated .event-card:nth-child(4){animation-delay:90ms}.events-list.is-animated .event-card:nth-child(5){animation-delay:.12s}.events-list.is-animated .event-card:nth-child(6){animation-delay:.15s}.events-list.is-animated .event-card:nth-child(7){animation-delay:.18s}.events-list.is-animated .event-card:nth-child(8){animation-delay:.21s}.events-list.is-animated .event-card:nth-child(9){animation-delay:.24s}.events-list.is-animated .event-card:nth-child(10){animation-delay:.27s}.event-card{text-align:left;border:1px solid var(--line);cursor:pointer;transform:translateY(0)}.event-card:hover{transform:translateY(-1px);border-color:#c7d9cf;box-shadow:0 14px 30px #18403221}.event-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.event-type-chip{font-size:1.08rem;font-weight:700;line-height:1.2}.event-type-inline{display:inline-flex;align-items:center;gap:.55rem}.event-card-header time{font-size:1rem;font-weight:600}.event-summary{margin:.35rem 0 0;color:var(--text-muted);font-size:.86rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state{text-align:center;background:var(--surface-2)}.empty-state h3{margin:0;font-size:calc(1.08rem * var(--font-scale-factor));font-family:var(--font-heading)}.empty-state p{margin:.5rem 0 0;color:var(--text-muted)}.export-actions{margin-top:.7rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.export-modal-card{width:min(500px,100%)}.header-export-button{min-height:2.15rem;padding:.45rem .75rem;font-weight:500;white-space:nowrap}.gear-button{border:0;background:transparent;color:var(--brand-deep);padding:.12rem;min-width:2.2rem;min-height:2.2rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),color var(--dur-fast) ease}.gear-button:hover{color:var(--brand);transform:rotate(14deg) scale(1.03)}.gear-button:focus-visible{outline:2px solid var(--brand-deep);outline-offset:3px;border-radius:.45rem}.support-text{margin:.65rem 0 0;color:var(--text-muted);font-size:calc(.92rem * var(--font-scale-factor))}.support-list{margin:.75rem 0 0;padding-left:1.2rem;color:var(--text-main);font-size:calc(.96rem * var(--font-scale-factor));line-height:1.45}.field-error-inline{color:var(--danger);font-size:.84rem;white-space:nowrap}.dialog-body-text{margin:.75rem 0 0;color:var(--text-main);font-size:calc(1.18rem * var(--font-scale-factor));line-height:1.4}.dialog-actions{justify-content:flex-end}.toast-stack{position:fixed;right:1rem;bottom:1rem;z-index:30;display:grid;gap:.55rem;width:min(360px,calc(100vw - 2rem))}.toast-item{border:1px solid #b9e2cf;background:#e9f8f0;color:#0f6d4a;border-radius:.75rem;padding:.68rem .8rem;font-size:.94rem;font-weight:600;box-shadow:0 8px 20px #0c483029}.email-compose-row{margin-top:.6rem;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.45rem}.email-send-button{color:var(--brand-deep)}.primary-button,.secondary-button,.icon-button,.danger-text-button{border:0;border-radius:.7rem;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),filter var(--dur-fast) ease,background-color var(--dur-fast) ease,border-color var(--dur-fast) ease,color var(--dur-fast) ease}.primary-button{background:var(--brand);color:#fff;padding:.62rem .9rem;font-weight:600}.primary-button:disabled{background:#88b7a4;cursor:not-allowed}.secondary-button{border:1px solid var(--line);background:var(--surface-2);color:var(--text-main);padding:.62rem .9rem}.secondary-button:disabled{background:#e6ece9;color:#7a8881;border-color:#c8d5ce;cursor:not-allowed}.primary-button:hover:not(:disabled){background:#24a374;box-shadow:0 8px 16px #1f8f653d;transform:scale(1.02)}.secondary-button:hover:not(:disabled){background:#ecf6f0;border-color:#b7cbc0;transform:scale(1.015)}.icon-button:hover{background:#eff7f2;border-color:#b7cbc0;transform:scale(1.04)}.danger-text-button:hover{color:#982e24;background:#fff1ef;transform:scale(1.015)}.primary-button:active:not(:disabled),.secondary-button:active:not(:disabled),.icon-button:active,.danger-text-button:active{transform:scale(.99)}.icon-button{width:2.15rem;height:2.15rem;background:var(--surface);border:1px solid var(--line);color:var(--text-main)}.danger-text-button{background:transparent;color:var(--danger);padding:.45rem 0}.fab{position:fixed;right:1.2rem;bottom:1.2rem;width:3.5rem;height:3.5rem;border-radius:999px;border:0;background:var(--brand);color:#fff;font-size:1.8rem;line-height:1;box-shadow:0 12px 26px #1e503e52;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-med) var(--ease-out),background-color var(--dur-fast) ease}.fab:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 16px 30px #1e503e57}.modal-overlay,.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#111d188c;z-index:12;padding:.8rem;display:flex;justify-content:center;align-items:center;animation:overlay-fade-in var(--dur-med) ease}.modal-card{width:min(560px,100%);max-height:92vh;overflow-y:auto;border-radius:1rem;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);padding:1rem;animation:modal-pop-in var(--dur-med) var(--ease-out)}.email-preview-modal-card{width:min(760px,100%)}.email-preview-body{min-height:220px;white-space:pre-wrap}.email-preview-html{width:100%;min-height:220px;border:1px solid var(--line);border-radius:.6rem;padding:.75rem;background:#fff;line-height:1.45}.email-preview-html p{margin:0 0 .72rem}.email-preview-html p:last-child{margin-bottom:0}.modal-header,.settings-header{display:flex;align-items:center;justify-content:space-between;gap:.7rem}.modal-header h2,.settings-header h2{margin:0;font-size:calc(1.14rem * var(--font-scale-factor));font-family:var(--font-heading)}.modal-title-row{display:flex;align-items:center;gap:.55rem}.modal-title-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--brand-deep)}.modal-header-actions{display:inline-flex;align-items:center;gap:.45rem}.event-type-choice-grid{margin-top:.8rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.event-type-choice{border:1px solid var(--line);background:var(--surface-2);border-radius:.8rem;min-height:3.15rem;padding:.55rem .65rem;text-align:left;color:var(--text-main);display:flex;align-items:center;gap:.55rem;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) ease,background-color var(--dur-fast) ease}.event-type-choice:hover{transform:scale(1.015);border-color:#c5d7cd;background:#f0f8f3}.event-type-choice-icon{color:var(--brand-deep)}.event-type-choice.is-daily-checkin{border-color:#bfd7cc;background:#f3faf6}.selected-event-type-card{min-height:2.35rem;border:1px solid var(--line);border-radius:.6rem;background:var(--surface-2);padding:.4rem .65rem;display:inline-flex;align-items:center;gap:.5rem}.warning-banner{margin-top:.75rem;background:var(--warning);border:1px solid #f2e9b2;border-radius:.7rem;padding:.65rem;font-size:.92rem}.field-row{margin-top:.75rem;display:grid;grid-template-columns:minmax(110px,140px) minmax(0,1fr);align-items:start;column-gap:.65rem;row-gap:.35rem}.field-row label,.field-row>span{font-weight:500;margin:0;grid-column:1}.field-row>input,.field-row>select,.field-row>textarea,.field-row>.secondary-button,.field-row>.selected-event-type-card,.field-row>.star-rating,.field-row>.phase-label{grid-column:2}.field-row>.phase-label{margin-top:-.1rem}.field-row-full{grid-template-columns:minmax(0,1fr)}.field-row-full>*{grid-column:1 / -1}.type-input-inline{display:grid;grid-template-columns:minmax(90px,120px) minmax(0,1fr);align-items:center;gap:.55rem}.type-input-inline>label{font-weight:500}.preset-picker{display:grid;gap:.5rem}.preset-grid{display:flex;flex-wrap:wrap;gap:.4rem}.preset-category-grid{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:.35rem}.preset-category-link{border:0;background:transparent;color:var(--text-muted);padding:.1rem .08rem .2rem;border-bottom:2px solid transparent;font-size:.86rem;line-height:1.1;transition:color var(--dur-fast) ease,border-color var(--dur-fast) ease}.preset-category-link:hover{color:var(--brand-deep)}.preset-category-link.is-selected{color:var(--brand-deep);border-bottom-color:var(--brand)}.preset-option-button{flex:0 0 auto;border:1px solid var(--line);border-radius:.65rem;background:#fff;color:var(--text-main);min-width:96px;min-height:2.35rem;padding:.35rem .45rem;display:inline-flex;align-items:center;justify-content:center;gap:.28rem;font-size:.85rem;white-space:nowrap;transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) ease,background-color var(--dur-fast) ease}.preset-option-button:hover{transform:scale(1.015);border-color:#c1d4ca;background:#f2faf5}.preset-option-button.is-selected{border-color:var(--brand);background:#dbf4e8;color:var(--brand-deep)}.preset-option-icon{font-size:1rem;line-height:1}.toggle-row{margin-top:.75rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.toggle-row-compact{margin-top:0;border:1px solid var(--line);border-radius:.7rem;background:#fff;padding:.45rem .55rem}.toggle-label{font-weight:500}.toggle-control{position:relative;width:2.8rem;height:1.6rem;flex-shrink:0}.toggle-input{position:absolute;top:0;right:0;bottom:0;left:0;margin:0;opacity:0;cursor:pointer;z-index:2}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#d7e1dc;border:1px solid #c5d2cb;border-radius:999px;transition:background-color .2s ease,border-color .2s ease}.toggle-slider:after{content:"";position:absolute;top:.11rem;left:.11rem;width:1.15rem;height:1.15rem;border-radius:50%;background:#fff;box-shadow:0 1px 4px #00000038;transition:transform .2s ease}.toggle-input:checked+.toggle-slider{background:#1f8f65;border-color:#1f8f65}.toggle-input:checked+.toggle-slider:after{transform:translate(1.2rem)}.toggle-input:focus-visible+.toggle-slider{outline:2px solid #176c4c;outline-offset:2px}.toggle-input:disabled{cursor:not-allowed}.toggle-input:disabled+.toggle-slider{opacity:.6}input,select,textarea{width:100%;border-radius:.6rem;border:1px solid var(--line);background:#fff;color:var(--text-main);min-height:2.35rem;padding:.5rem .65rem;transition:border-color var(--dur-fast) ease,box-shadow var(--dur-fast) ease,background-color var(--dur-fast) ease}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;border-color:#9dc7b3;box-shadow:0 0 0 3px #1f8f6524;background:#fff}.star-rating{display:flex;align-items:center;gap:.08rem}.star-button{border:0;background:transparent;padding:.06rem;margin:0;line-height:0;display:inline-flex;align-items:center;justify-content:center}.star-icon{width:1.85rem;height:1.85rem;fill:transparent;stroke:#df7c1d;stroke-width:1.8;transition:transform .14s ease}.star-icon.is-filled{fill:#f5a623}.star-button:hover .star-icon,.star-button:focus-visible .star-icon{transform:scale(1.08)}.star-button:focus-visible{outline:2px solid #176c4c;outline-offset:1px;border-radius:.3rem}.bowel-type-picker{display:grid;gap:.45rem}.bowel-type-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.42rem}.bowel-type-option{border:1px solid var(--line);border-radius:.62rem;background:#fff;color:var(--text-main);min-height:3.1rem;padding:.35rem .3rem .25rem;display:grid;justify-items:center;align-content:center;gap:.12rem;transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) ease,background-color var(--dur-fast) ease}.bowel-type-option:hover{transform:translateY(-1px)}.bowel-type-option.is-selected{border-color:var(--brand);background:#dbf4e8}.bowel-type-icon{width:100%;max-width:2.5rem;height:1.6rem;fill:#a06b4c;stroke:#7f5438;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.bowel-type-number{font-size:.76rem;font-weight:600}.phase-label{color:var(--text-muted);font-size:.88rem}.urination-flow-panel,.exercise-timer-panel{display:grid;gap:.4rem}.exercise-timer-actions,.urination-steps{display:flex;flex-wrap:wrap;gap:.4rem}.urination-step-button{min-height:2.1rem;padding:.45rem .65rem;display:inline-flex;align-items:center;gap:.35rem}.urination-step-button.is-active{border-color:var(--brand);background:#dbf4e8;color:var(--brand-deep)}.urination-record-button{width:100%;justify-content:center;text-align:center}.urination-record-button.is-recording{border-width:3px;border-color:var(--brand-deep);background:#e9f7f1;color:var(--brand-deep);font-weight:600}.urination-metrics{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;color:var(--text-muted);font-size:.86rem}.urination-times-inline{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem .85rem;font-size:.9rem}.urination-time-item{display:inline-flex;align-items:center;gap:.35rem;color:var(--text-muted)}.urination-time-item input{width:4.6rem;min-width:4.6rem;min-height:2rem;padding:.35rem .5rem;text-align:right}.urination-time-item input.is-running{color:var(--brand-deep);background:#e6f8ee;animation:timer-running-pulse 1.7s ease-in-out infinite}.urination-quality-row{display:grid;gap:.28rem}.timer-value{display:inline-flex;align-items:center;padding:.04rem .32rem;border-radius:.45rem;font-variant-numeric:tabular-nums}.timer-value.is-running{color:var(--brand-deep);background:#e6f8ee;animation:timer-running-pulse 1.7s ease-in-out infinite}@keyframes timer-running-pulse{0%,to{background:#e6f8ee}50%{background:#d3f1e2}}.modal-footer{margin-top:1rem;display:flex;align-items:center;justify-content:flex-end;gap:.55rem;flex-wrap:wrap}.modal-footer .danger-text-button{margin-right:auto}.settings-panel{width:min(760px,100%);height:min(95vh,980px);overflow-y:auto;border-radius:1rem;background:var(--surface);border:1px solid var(--line);padding:.95rem;animation:modal-pop-in var(--dur-med) var(--ease-out)}.settings-section{margin-top:1rem;border-top:1px solid var(--line);padding-top:.9rem}.settings-section h3,.settings-subsection-title-row h4{margin:0;font-family:var(--font-heading);font-size:calc(1.02rem * var(--font-scale-factor))}.settings-section-title-row,.settings-subsection-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.settings-card,.settings-subcard{margin-top:.75rem;border:1px solid var(--line);border-radius:.85rem;background:var(--surface-2);padding:.75rem}.type-card-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:.55rem}.settings-row{margin-top:.5rem;display:grid;grid-template-columns:minmax(110px,140px) minmax(0,1fr);align-items:start;column-gap:.65rem;row-gap:.3rem}.settings-row-tight{margin-top:0}.settings-row label{font-weight:500;margin:0;grid-column:1;margin-top:.5rem}.settings-row>input,.settings-row>select,.settings-row>textarea{grid-column:2}.settings-row>a,.settings-row>button{grid-column:2;justify-self:start}.settings-row>.settings-row-with-action{grid-column:2;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.5rem}.settings-row>.settings-row-stack{grid-column:2;min-width:0;width:100%}.settings-row-stack>input[type=file]{width:100%;min-width:0}.settings-row-with-action>select{width:100%;min-width:0}.settings-row-with-action>button{white-space:nowrap}.settings-row-with-inline-select{display:inline-flex;align-items:center;gap:.5rem}.settings-row-with-inline-select>select{width:auto;min-width:max-content}.settings-row-with-inline-select>button{margin-left:0}.settings-row-with-badge{grid-column:2;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.settings-inline-support{margin-top:.35rem}.settings-inline-actions{margin-top:.65rem}.settings-theme-editor{margin-top:.85rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;align-items:start}.settings-theme-preview-pane{min-width:0}.settings-theme-preview{width:100%;min-height:100%;border-radius:1rem;border:1px solid var(--line);background:var(--bg);background-image:var(--bg-overlay);padding:.85rem;box-shadow:inset 0 1px #ffffff73}.settings-theme-preview-app{max-width:none;min-height:720px;padding:1rem 1rem 5.75rem;border-radius:.8rem;overflow:hidden}.settings-theme-preview-app .top-bar{margin-bottom:.9rem}.settings-theme-preview-app .settings-section{margin-top:0}.settings-theme-preview-app .day-controls,.settings-theme-preview-app .warning-card,.settings-theme-preview-app .events-list{margin-top:.85rem}.settings-theme-preview-app .fab{pointer-events:none}.settings-theme-controls{margin-top:0;min-width:0}.settings-theme-control-list{margin-top:.85rem;display:grid;gap:.75rem}.settings-theme-field{display:grid;gap:.35rem;font-weight:500}.settings-theme-field>span{font-size:.9rem}.settings-theme-input-row{display:grid;grid-template-columns:2.65rem minmax(0,1fr);gap:.45rem;align-items:center}.settings-theme-color{width:2.5rem;min-width:2.5rem;height:2.8rem;padding:.16rem;border-radius:.65rem}.settings-edit-lock{border:0;margin:0;padding:0;min-width:0}.icon-button-danger{color:var(--danger);border-color:#e6c3be;background:#fff6f4}.field-list-header{margin-top:.65rem}.field-list{margin-top:.55rem;display:grid;gap:.45rem}.field-list-item{width:100%;text-align:left;border:1px solid var(--line);border-radius:.75rem;background:#fff;color:var(--text-main);padding:.55rem .65rem;display:flex;align-items:center;justify-content:space-between;gap:.7rem;transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) ease,box-shadow var(--dur-fast) ease}.admin-inline-row{margin-top:.55rem;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:.45rem;align-items:center}.admin-field-row{margin-top:.5rem;display:grid;grid-template-columns:minmax(160px,1fr) minmax(120px,150px) auto auto;align-items:center;gap:.45rem}.admin-options-input{grid-column:1 / -1}.admin-footer{margin-top:.9rem;display:grid;gap:.4rem}.admin-footer-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem 1rem}.admin-actions-row{margin-top:.6rem;display:flex;flex-wrap:wrap;gap:.5rem}.admin-tab-row{display:inline-flex;flex-wrap:wrap;gap:.45rem}.admin-tab{border:1px solid var(--line);border-radius:.7rem;background:#fff;color:var(--text-main);padding:.45rem .75rem;display:inline-flex;align-items:center;cursor:pointer;text-decoration:none;transition:border-color var(--dur-fast) ease,background-color var(--dur-fast) ease,color var(--dur-fast) ease}.admin-tab:hover{border-color:#b7cbc0;background:#eff7f2}.admin-tab.is-active{border-color:var(--brand);background:#dbf4e8;color:var(--brand-deep)}.clinic-table-wrap{margin-top:.65rem;overflow-x:auto}.clinic-admin-table{width:100%;border-collapse:collapse;min-width:900px}.clinic-admin-table th,.clinic-admin-table td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--line);vertical-align:top}.clinic-admin-table th{font-weight:700;color:var(--text-muted);font-size:.84rem;text-transform:uppercase;letter-spacing:.02em}.clinic-admin-table tr.is-selected td{background:#ecf7f1}.table-sort-button{border:0;padding:0;background:transparent;color:inherit;font:inherit;text-transform:inherit;letter-spacing:inherit;cursor:pointer}.table-sort-button:hover{color:var(--text-main)}.clinic-admin-table td .support-text{margin-top:.22rem}.clinic-admin-table td .admin-actions-row{margin-top:0;flex-wrap:nowrap;gap:0}.clinic-admin-table td .admin-actions-row>*+*{position:relative;padding-left:.8rem}.clinic-admin-table td .admin-actions-row>*+*:before{content:"|";position:absolute;left:.3rem;color:var(--text-muted)}.logging-request-workbench{margin-top:.85rem;display:grid;grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:.75rem;align-items:start}.logging-request-sidebar,.logging-request-preview{margin-top:0}.logging-preview-frame{width:100%;min-height:620px;border:1px solid var(--line);border-radius:.75rem;background:#fff}.clinic-table-link{color:var(--brand-deep);text-decoration:none;font-weight:600}button.clinic-table-link{border:0;background:transparent;padding:0;cursor:pointer;font:inherit}.clinic-table-link:hover{color:var(--brand);text-decoration:underline}.clinic-table-link.is-disabled{color:#9aa9a1;pointer-events:none;cursor:default;text-decoration:none}.clinic-admin-modal-card{width:min(680px,100%);max-height:94vh}.program-builder-modal-card{width:min(1240px,100%);max-height:94vh}.role-option-list{margin-top:.75rem;display:grid;gap:.75rem}.user-picture-field{display:grid;gap:.65rem;justify-items:start}.user-picture-input{display:none}.user-picture-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.65rem}.user-picture-preview{width:4.5rem;height:4.5rem;border-radius:999px;border:1px solid var(--line);background:#fff;object-fit:cover}.user-picture-placeholder{display:grid;place-items:center;color:var(--text-muted);font-size:.85rem;background:var(--surface)}.role-option-card{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:.8rem;border:1px solid var(--line);border-radius:.85rem;background:var(--surface);padding:.85rem .95rem;cursor:pointer;transition:border-color var(--dur-fast) ease,background-color var(--dur-fast) ease,box-shadow var(--dur-fast) ease}.role-option-card:hover{border-color:#b7cbc0;background:#fbfdfc}.role-option-card.is-selected{border-color:var(--brand);background:#eef8f2;box-shadow:0 8px 18px #1f8f6514}.role-option-card input[type=checkbox]{width:1.1rem;height:1.1rem;margin:.1rem 0 0;accent-color:var(--brand)}.role-option-copy{min-width:0}.role-option-copy strong{display:block;font-size:1rem}.role-option-copy .support-text{margin:.2rem 0 0}.clinic-admin-embedded{padding:.35rem 0 0}.clinic-table-logo{width:2.4rem;height:2.4rem;border-radius:.45rem;border:1px solid var(--line);object-fit:cover;background:#fff}.clinic-status-badge{display:inline-flex;margin-left:.5rem;font-size:.74rem;padding:.12rem .4rem;border-radius:999px}.clinic-status-badge.is-waiting,.clinic-status-badge.is-pending{background:#fff2d6;color:#7f5a11;border:1px solid #f1db9f}.clinic-status-badge.is-authenticated{background:#def5e9;color:#0f6d4a;border:1px solid #bde6d2}.clinic-status-badge.is-deactivated{background:#fde8e6;color:#94372d;border:1px solid #f4c9c2}.admin-user-row{margin-top:.55rem;display:grid;grid-template-columns:minmax(130px,1fr) minmax(180px,1.2fr) minmax(130px,1fr) minmax(120px,.9fr) auto auto auto;gap:.45rem;align-items:center}.admin-role-row{margin-top:.55rem;display:grid;grid-template-columns:minmax(170px,1fr) minmax(220px,1.3fr) auto;gap:.45rem;align-items:center}.clinic-list{margin-top:.6rem;display:grid;gap:.55rem}.clinic-list-row{border:1px solid var(--line);border-radius:.8rem;background:#fff;padding:.7rem;display:flex;align-items:center;justify-content:space-between;gap:.7rem}.clinic-dashboard-grid{margin-top:.7rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.portal-metric{margin:.35rem 0 0;font-family:var(--font-heading);font-size:calc(1.8rem * var(--font-scale-factor));font-weight:700}.is-disabled{pointer-events:none;opacity:.55}.field-list-item:hover{transform:translateY(-1px);border-color:#c7d9cf;box-shadow:0 8px 16px #18403212}.field-list-meta{color:var(--text-muted);font-size:.84rem}.icon-picker{margin-top:.55rem;display:flex;flex-wrap:wrap;gap:.4rem}.icon-choice{width:2.15rem;height:2.15rem;border-radius:.6rem;border:1px solid var(--line);background:#fff;color:var(--text-main);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) ease,background-color var(--dur-fast) ease}.icon-choice:hover:not(:disabled){transform:scale(1.045);border-color:#b7cbc0;background:#eff7f2}.icon-choice.is-active{border-color:var(--brand);background:#dbf4e8;color:var(--brand-deep)}.icon-choice:disabled{opacity:.45;cursor:not-allowed}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-pop-in{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes event-card-enter{0%{opacity:0;transform:translateY(8px) scale(.995)}to{opacity:1;transform:translateY(0) scale(1)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}@media (max-width: 680px){.top-bar{flex-direction:column;align-items:stretch}.top-bar-brand{align-items:center}.system-admin-shell .top-bar{position:static}.system-admin-shell .portal-title-text{position:static;transform:none;width:auto;max-width:none;pointer-events:auto}.warning-card{flex-direction:column;align-items:start}.export-actions{grid-template-columns:minmax(0,1fr)}.settings-panel{border-radius:.8rem;height:96vh}.field-row:not(.field-row-full),.settings-row{grid-template-columns:minmax(88px,110px) minmax(0,1fr);column-gap:.55rem}.event-type-choice-grid{grid-template-columns:minmax(0,1fr)}.admin-inline-row,.admin-field-row,.admin-user-row,.admin-role-row{grid-template-columns:minmax(0,1fr);align-items:stretch}.admin-footer-row{flex-direction:column;align-items:stretch}.settings-theme-editor{grid-template-columns:minmax(0,1fr)}.settings-theme-preview-app{min-height:0;padding-bottom:5rem}.settings-theme-control-list,.clinic-dashboard-grid,.logging-request-workbench{grid-template-columns:minmax(0,1fr)}.logging-preview-frame{min-height:440px}.bowel-type-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.preset-category-grid{display:flex;grid-template-columns:none;gap:.2rem}.preset-category-link{font-size:.78rem;padding:.05rem .02rem .16rem}.urination-times-inline{gap:.45rem .65rem}}
