:root{--bg:#F5F7FA;--card:#fff;--navy:#1B2A4A;--navy-light:#2D4470;--navy-muted:#8494B2;--accent:#2563EB;--accent-light:#EFF6FF;--green:#2D8B55;--green-light:#E8F5EE;--red:#C0392B;--red-light:#FDEDEB;--border:#E2E8F0;--shadow:0 1px 3px rgba(27,42,74,.06),0 4px 12px rgba(27,42,74,.04);--amber:#D4801F;--amber-bg:#FDF6EC}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:'DM Sans',sans-serif;font-size:14px;background:var(--bg);color:var(--navy);-webkit-font-smoothing:antialiased}

/* App shell */
.app{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--bg);position:relative}
.app-header{padding:14px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);background:var(--card);position:sticky;top:0;z-index:10}
.app-header h1{font-size:20px;font-weight:700}
.app-header h1 span{color:var(--accent)}
.app-body{flex:1;display:flex;flex-direction:column}

/* Views */
.view{display:none;flex:1;flex-direction:column}
.view.on{display:flex}

/* Common */
.card{background:var(--card);border-radius:12px;box-shadow:var(--shadow);padding:20px;margin:0 20px 16px}
.pill{font-size:12px;padding:5px 14px;border-radius:20px;cursor:pointer;display:inline-block;font-weight:500;font-family:'DM Sans',sans-serif;border:none;transition:all .15s;user-select:none}
.pill:hover{opacity:.85}
.pill-on{background:var(--navy);color:#fff}
.pill-off{background:transparent;border:1px solid var(--border);color:var(--navy-muted)}
.pill-off:hover{border-color:var(--navy-muted);color:var(--navy)}
.pill-hc{background:var(--green-light);color:var(--green);font-size:11px;padding:3px 10px}
.btn{border:none;padding:14px 24px;border-radius:10px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;width:100%;text-align:center;transition:all .15s}
.btn:active{opacity:.85}
.btn:hover{opacity:.9}
.btn-primary{background:var(--navy);color:#fff}
.btn-accent{background:var(--accent);color:#fff}
.btn-green{background:var(--green);color:#fff}
.btn-outline{background:var(--card);color:var(--navy);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--navy-muted);background:var(--bg)}
.btn-sm{padding:8px 16px;font-size:12px;width:auto;border-radius:8px}
.btn-copy{background:#E6F1FB;color:#0C447C}
.btn-copy:hover{background:#d4e6f7}
.input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--navy);background:var(--card);outline:none}
.input:focus{border-color:var(--accent)}
.label{font-size:12px;font-weight:500;color:var(--navy-muted);margin-bottom:4px;display:block}
.section-title{font-size:11px;font-weight:600;color:var(--navy-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px}
.toggle{width:40px;height:24px;border-radius:12px;position:relative;cursor:pointer;flex-shrink:0;transition:background .15s}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.15s;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.toggle.on{background:var(--green)}.toggle.on::after{left:18px}
.toggle.off{background:var(--border)}
.badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:10px}
.badge-green{background:var(--green-light);color:var(--green)}
.badge-amber{background:var(--amber-bg);color:var(--amber)}
.divider{height:1px;background:var(--border);margin:16px 0}
.sec-h{font-size:16px;font-weight:600;color:var(--accent);margin:0 0 8px;padding-left:12px;border-left:3px solid var(--accent)}
.note-text{font-size:15px;color:#555;line-height:1.9}
.back-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;min-width:32px;min-height:32px;justify-content:center;color:var(--navy-muted);transition:background .15s}
.back-btn:hover{background:var(--bg)}
.back-btn svg{flex-shrink:0}
.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s}
.avatar:hover{opacity:.8}
.pref-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}
.pref-row:last-child{border:none}
.pref-info p{font-size:14px;font-weight:500;margin:0}
.pref-info small{font-size:12px;color:var(--navy-muted)}
.note-row{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .15s}
.note-row:hover{background:var(--bg)}
.note-row:active{background:var(--bg)}
.len-example{font-size:12px;color:var(--navy-muted);font-style:italic;line-height:1.5;padding:8px 12px;background:var(--bg);border-radius:8px;margin:6px 0 0}
.app-footer{padding:12px 20px;border-top:1px solid var(--border);background:var(--card)}

/* Record button */
.rec-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 20px}
.rec-btn{width:88px;height:88px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:.15s}
.rec-btn:active{transform:scale(.95)}
.rec-btn:hover{opacity:.9}
.rec-btn-hc{background:var(--red);box-shadow:0 0 0 6px rgba(192,57,43,.12)}
.rec-btn-gen{background:#185FA5;box-shadow:0 0 0 6px rgba(24,95,165,.12)}
.rec-inner{width:24px;height:24px;border-radius:50%;background:#fff}
.stop-inner{width:20px;height:20px;border-radius:3px;background:#fff}

/* Waveform */
.wave{display:flex;align-items:center;justify-content:center;gap:3px;height:56px}
.wave-bar{width:3px;border-radius:2px;background:var(--red);transition:height .1s}

/* Progress steps */
.prog-step{display:flex;align-items:center;gap:10px;padding:8px 0}
.prog-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.prog-done{background:var(--green)}
.prog-active{border:2px solid var(--accent)}
.prog-pending{border:2px solid var(--border)}

/* Transcript lines */
.tx-line{padding:8px 0;font-size:14px;line-height:1.6;color:#555;border-bottom:1px dashed var(--border);cursor:pointer;transition:background .15s}
.tx-line:last-child{border:none}
.tx-line:hover{background:var(--accent-light)}
.tx-line:active{background:var(--accent-light)}
.tx-line[contenteditable="true"]{background:var(--amber-bg);outline:2px solid var(--accent);outline-offset:-2px;border-radius:4px;padding:6px 8px}
.tx-highlight{background:#FFE082;border-radius:2px;padding:0 1px}
.tx-edit{background:var(--amber-bg);color:#633806;padding:0 3px;border-radius:3px}

/* Bottom nav */
.bottom-nav{display:flex;justify-content:space-around;padding:8px 0;border-top:1px solid var(--border);background:var(--card);position:sticky;bottom:0;z-index:10}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;padding:4px 12px;color:var(--navy-muted);font-size:10px;font-weight:500;transition:color .15s}
.nav-item:hover{color:var(--navy)}
.nav-item.on{color:var(--accent)}
.nav-item svg{width:20px;height:20px}

/* Toast */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:10px 20px;border-radius:10px;font-size:13px;font-weight:500;z-index:100;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap;max-width:90vw;text-align:center}
.toast.show{opacity:1}

/* Onboard checkbox */
.ob-check{width:22px;height:22px;border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s}
.ob-check.checked{background:var(--green)}
.ob-check.unchecked{border:1.5px solid var(--border);background:transparent}

/* Note content editable */
[contenteditable="true"]{outline:2px solid var(--accent);border-radius:6px;padding:4px}

/* Radio dot */
.radio-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.radio-dot.sel{background:var(--green)}
.radio-dot.unsel{border:1.5px solid var(--border)}

/* File input hidden */
#audioFileInput{display:none}

/* Regenerate drawer */
.regen-drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3);z-index:20;opacity:0;transition:opacity .25s;pointer-events:none}
.regen-drawer-overlay.open{opacity:1;pointer-events:auto}
.regen-drawer{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:var(--card);border-radius:16px 16px 0 0;z-index:21;transform:translate(-50%,100%);transition:transform .3s ease;max-height:70vh;display:flex;flex-direction:column}
.regen-drawer.open{transform:translate(-50%,0)}
.regen-drawer-handle{width:36px;height:4px;border-radius:2px;background:var(--border);margin:10px auto}
.regen-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px 12px}
.regen-drawer-body{flex:1;overflow-y:auto;padding:0 20px 20px}
.regen-drawer-close{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;color:var(--navy-muted);transition:background .15s}
.regen-drawer-close:hover{background:var(--bg)}
.regen-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;margin-left:6px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

/* Section picker inline */
.section-picker-inline{background:var(--bg);border-radius:10px;padding:12px;margin:8px 0;display:none}
.section-picker-inline.open{display:block}
.section-picker-inline label{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px;cursor:pointer}
.section-picker-inline input[type="checkbox"]{accent-color:var(--green);width:16px;height:16px}

.badge-soon{background:var(--bg);color:var(--navy-muted);font-size:9px;font-weight:600;padding:2px 7px;border-radius:8px;margin-left:6px;text-transform:uppercase;letter-spacing:.3px}
.pref-row.disabled{opacity:.5;pointer-events:none}
.pref-soap-toggles{display:flex;gap:8px;align-items:center;margin:8px 0}
.pref-soap-toggle{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;user-select:none;border:2px solid transparent}
.pref-soap-toggle.active{background:var(--green-light);color:var(--green);border-color:var(--green)}
.pref-soap-toggle.inactive{background:var(--bg);color:var(--navy-muted);border-color:var(--border)}
.pref-soap-toggle:hover{opacity:.8}
.pref-format-result{font-size:13px;color:var(--navy);font-weight:500;margin:6px 0 0;padding:6px 12px;background:var(--bg);border-radius:8px;display:inline-block}
.pref-presets{display:flex;gap:6px;align-items:center;margin:10px 0 0;flex-wrap:wrap}
.pref-preset-pill{font-size:11px;padding:4px 10px;border-radius:12px;cursor:pointer;font-weight:500;background:var(--bg);color:var(--navy-muted);border:1px solid var(--border);transition:all .15s;user-select:none}
.pref-preset-pill:hover{border-color:var(--navy-muted);color:var(--navy)}
.pref-hp-btn{margin-top:10px;font-size:12px;padding:6px 14px;border-radius:8px;cursor:pointer;font-weight:600;border:1px solid var(--border);background:var(--card);color:var(--navy);transition:all .15s;display:inline-block}
.pref-hp-btn:hover{border-color:var(--navy-muted);background:var(--bg)}
.pref-hp-btn.active{background:var(--green-light);color:var(--green);border-color:var(--green)}
.review-card-header{background:var(--card);padding:18px 20px;border-bottom:1px solid var(--border)}
.review-patient{font-size:17px;font-weight:600;margin:0 0 4px;cursor:text;border-bottom:1px dashed var(--border);display:inline-block;min-width:60px;outline:none;transition:border-color .15s}
.review-patient:empty::before{content:'Tap to name this note';color:var(--navy-muted);font-weight:400;font-style:italic}
.review-patient:focus{border-bottom-color:var(--accent);background:var(--accent-light);border-radius:4px;padding:0 4px}
.review-meta{font-size:12px;color:var(--navy-muted);margin:4px 0 0;line-height:1.4}
.review-date{font-size:13px;color:var(--navy-muted);margin:0}
.review-format-badge{display:inline-block;font-size:11px;padding:3px 10px;border-radius:20px;background:var(--navy);color:#fff;font-weight:500;margin-top:8px}
.section-toggles{display:flex;gap:4px;flex-wrap:wrap;align-items:center;margin-top:8px}
.section-toggles .sec-toggle{font-size:11px;padding:3px 8px;border-radius:12px;cursor:pointer;font-weight:500;transition:all .15s;user-select:none;border:1px solid transparent}
.section-toggles .sec-toggle.active{background:var(--green-light);color:var(--green);border-color:var(--green)}
.section-toggles .sec-toggle.inactive{background:var(--bg);color:var(--navy-muted);border-color:var(--border)}
.section-toggles .sec-toggle:hover{opacity:.8}
.sec-copy-btn:hover{opacity:.8!important;background:var(--bg)!important}
.badge-sent{background:var(--green-light);color:var(--green);font-size:10px;font-weight:600;padding:3px 8px;border-radius:10px}
.badge-pending{background:var(--amber-bg);color:var(--amber);font-size:10px;font-weight:600;padding:3px 8px;border-radius:10px}
.regen-warning{padding:12px;background:var(--amber-bg);border-radius:8px;margin-top:12px;font-size:13px;color:#7A5A1F}
.regen-warning-btns{display:flex;gap:8px;margin-top:8px}

/* Delete button in history rows */
.note-delete-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;color:var(--navy-muted);opacity:.4;transition:all .15s;display:flex;align-items:center;justify-content:center}
.note-delete-btn:hover{color:var(--red);background:var(--red-light);opacity:1}

/* Swipe to delete (mobile) */
.note-row-swipe{position:relative;overflow:hidden}
.note-row-delete-action{position:absolute;top:0;right:0;bottom:0;width:80px;background:var(--red);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:11px;font-weight:600;cursor:pointer}
.note-row-delete-action svg{stroke:#fff}
.note-row-content{position:relative;z-index:1;background:var(--card);transition:transform .25s ease}

@media(min-width:481px) and (max-width:767px){
.app{border-left:1px solid var(--border);border-right:1px solid var(--border)}
}
