:root{--white:#fff;--off:#f8fafc;--sky-lt:#f0f9ff;--sky:#0ea5e9;--sky-dk:#0284c7;--ink:#111827;--ink-soft:#374151;--muted:#6b7280;--mid:#9ca3af;--border:#e5e7eb;--border-lt:#f3f4f6;--green:#22c55e;--green-dk:#16a34a;--red:#dc2626;--red-dk:#b91c1c;--shadow-sm:0 1px 4px #0000000f;--shadow-sky:0 4px 16px #0ea5e914}*,:before,:after{box-sizing:border-box}body{background:var(--white);color:var(--ink);-webkit-font-smoothing:antialiased;min-height:100vh;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}#dh-nav{z-index:100;position:sticky;top:0}.dh-header{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#ffffffeb;grid-template-columns:1fr auto 1fr;align-items:center;height:56px;padding:0 1.5rem;display:grid}.dh-header-title{color:var(--ink);letter-spacing:-.03em;-webkit-user-select:none;user-select:none;font-family:Funnel Display,sans-serif;font-size:1.1rem;font-weight:800;text-decoration:none}.dh-logo-accent{color:var(--sky);font-style:normal}.dh-header-center{align-items:center;gap:8px;display:flex}.dh-header-right{justify-content:flex-end;align-items:center;display:flex}.dh-btn{cursor:pointer;background:var(--white);color:var(--ink-soft);border:1px solid var(--border);white-space:nowrap;border-radius:6px;justify-content:center;align-items:center;padding:.5rem 1.1rem;font-family:Inter,sans-serif;font-size:.82rem;font-weight:500;line-height:1.4;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.dh-btn:hover:not(:disabled){background:var(--off);border-color:var(--sky)}.dh-btn:active:not(:disabled){background:var(--sky-lt)}.dh-btn:disabled{color:var(--mid);cursor:default;opacity:.6}.dh-btn-primary{background:var(--sky);color:var(--white);border-color:var(--sky);font-family:Funnel Display,sans-serif;font-weight:700}.dh-btn-primary:hover:not(:disabled){background:var(--sky-dk);border-color:var(--sky-dk)}.dh-btn-primary:disabled{background:var(--mid);border-color:var(--mid);color:var(--white);opacity:1}.dh-btn-success{background:var(--green);color:var(--white);border-color:var(--green);font-family:Funnel Display,sans-serif;font-weight:700}.dh-btn-success:hover:not(:disabled){background:var(--green-dk);border-color:var(--green-dk)}.dh-btn-success:disabled{opacity:.6;cursor:default}.dh-btn-danger{background:var(--red);color:var(--white);border-color:var(--red);font-family:Inter,sans-serif;font-weight:600}.dh-btn-danger:hover:not(:disabled){background:var(--red-dk);border-color:var(--red-dk)}.dh-btn-header{background:var(--sky-lt);color:var(--ink-soft);border:1px solid var(--border);white-space:nowrap;border-radius:6px;padding:.4rem .85rem;font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;transition:background .15s,border-color .15s}.dh-btn-header:hover:not(:disabled){background:var(--off);border-color:var(--sky)}.dh-input{background:var(--white);border:1px solid var(--border);width:100%;color:var(--ink);border-radius:6px;outline:none;margin-top:4px;padding:.6rem .85rem;font-family:Inter,sans-serif;font-size:.85rem;transition:border-color .15s,box-shadow .15s;display:block}.dh-input:focus{border-color:var(--sky);box-shadow:0 0 0 3px #0ea5e91f}.dh-input::placeholder{color:var(--mid)}.dh-panel{background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:8px}.dh-panel-sunken{background:var(--off);border:1px solid var(--border);border-radius:8px}.dh-dialog{background:var(--white);border:1px solid var(--border);border-radius:12px;max-width:380px;margin:4rem auto;overflow:hidden;box-shadow:0 4px 24px #0000000f}.dh-dialog-titlebar{background:var(--off);border-bottom:1px solid var(--border);color:var(--ink);letter-spacing:-.02em;padding:1.1rem 1.5rem;font-family:Funnel Display,sans-serif;font-size:1.1rem;font-weight:700}.dh-dialog-body{padding:1.5rem}.dh-form-label{color:var(--ink-soft);margin-bottom:1rem;font-family:Inter,sans-serif;font-size:.82rem;font-weight:500;display:block}.dh-table{border-collapse:collapse;background:var(--white);border:1px solid var(--border);border-radius:8px;width:100%;font-family:Inter,sans-serif;overflow:hidden}.dh-table thead tr{background:var(--off)}.dh-table th{text-align:left;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:.6rem 1rem;font-size:.7rem;font-weight:500}.dh-table td{border-bottom:1px solid var(--border-lt);color:var(--ink-soft);padding:.85rem 1rem;font-size:.82rem}.dh-table tbody tr:last-child td{border-bottom:none}.dh-table tbody tr:hover td{background:var(--sky-lt);cursor:pointer}.dh-table tbody tr.dh-row-playing td{background:#e0f2fe}.dh-table tbody tr.dh-row-playing:hover td{background:#bae6fd}.dh-table tbody tr.dh-row-playing td:first-child{box-shadow:inset 3px 0 0 var(--sky)}.dh-date-group-header td{background:var(--off);border-bottom:1px solid var(--border);padding:.6rem 1rem;font-family:Inter,sans-serif}.dh-table tbody tr.dh-date-group-today:hover td{background:var(--off);cursor:default}.dh-date-group-collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}.dh-date-group-expanded td,.dh-date-group-expanded:hover td{background:var(--sky-lt)}.dh-col-header-row th{background:var(--sky-lt);border-bottom:1px solid var(--border);padding:.5rem 1rem}.dh-col-header-today th{background:var(--off)}.dh-group-date{color:var(--ink);font-size:.85rem;font-weight:600}.dh-group-count{color:var(--muted);margin-left:.5rem;font-size:.78rem;font-weight:400}.dh-group-inner{justify-content:space-between;align-items:center;display:flex}.dh-group-toggle-btn{border:1px solid var(--border);color:var(--muted);pointer-events:none;white-space:nowrap;vertical-align:middle;background:0 0;border-radius:5px;padding:.18rem .5rem;font-family:Inter,sans-serif;font-size:.72rem;font-weight:500;transition:border-color .15s,color .15s}.dh-date-group-collapsible:hover .dh-group-toggle-btn{border-color:var(--mid);color:var(--ink-soft)}.dh-group-spacer td{border:none;padding:.9rem 0}.dh-table tbody tr.dh-group-spacer:hover td{cursor:default;background:0 0}.dh-badge{border-radius:999px;padding:.2rem .6rem;font-family:Inter,sans-serif;font-size:.7rem;font-weight:500;display:inline-block}.dh-badge-draft{color:#a16207;background:#fef9c3}.dh-badge-review{background:var(--sky-lt);color:var(--sky-dk)}.dh-badge-approved{color:var(--green-dk);background:#dcfce7}.dh-badge-none{background:var(--border-lt);color:var(--muted)}.dh-badge-transcript{color:#c2410c;background:#fff7ed}.dh-badge-failed{color:#92400e;background:#fef3c7}.dh-section{background:var(--white);border:1px solid var(--border);border-radius:8px;margin-bottom:.6rem;transition:border-color .15s;overflow:hidden}.dh-section:hover{border-color:#cbd5e1}.dh-section-head{background:var(--off);color:var(--sky);letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.6rem 1rem;font-family:Funnel Display,sans-serif;font-size:.7rem;font-weight:700;display:flex}.dh-section-edit-btn{cursor:pointer;background:var(--white);border:1px solid var(--border);color:var(--ink-soft);border-radius:4px;flex-shrink:0;padding:.2rem .65rem;font-family:Inter,sans-serif;font-size:.72rem;font-weight:500;transition:background .15s,border-color .15s}.dh-section-edit-btn:hover:not(:disabled){background:var(--sky-lt);border-color:var(--sky);color:var(--sky-dk)}.dh-section-edit-btn:disabled{color:var(--mid);cursor:default}.dh-section-body{white-space:pre-wrap;word-break:break-word;overflow-wrap:break-word;background:var(--white);min-height:40px;color:var(--ink-soft);max-width:100%;padding:.85rem 1rem;font-family:Inter,sans-serif;font-size:.82rem;font-weight:300;line-height:1.75}.dh-textarea{box-sizing:border-box;border:1px solid var(--border);resize:vertical;background:var(--white);width:100%;min-height:80px;color:var(--ink);border-radius:6px;outline:none;padding:.6rem .85rem;font-family:Inter,sans-serif;font-size:.82rem;font-weight:300;line-height:1.7;transition:border-color .15s,box-shadow .15s}.dh-textarea:focus{border-color:var(--sky);box-shadow:0 0 0 3px #0ea5e91f}.dh-save-row{background:var(--off);border-top:1px solid var(--border);align-items:center;gap:8px;padding:.6rem 1rem .75rem;display:flex}.dh-missing{color:var(--red);background:#fef2f2;border:1px solid #fecaca;border-radius:4px;align-items:center;gap:.3rem;padding:.1rem .4rem;font-family:Inter,sans-serif;font-size:.72rem;font-weight:500;display:inline-flex}.dh-toast{background:var(--ink);color:var(--white);z-index:9999;border-radius:8px;max-width:360px;padding:.85rem 1.25rem;font-family:Inter,sans-serif;font-size:.82rem;font-weight:400;animation:.15s dh-fadein;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 8px 24px #00000026}@keyframes dh-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dh-page{max-width:820px;margin:0 auto;padding:2rem 1.5rem 3rem}.dh-page-wide{max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem}.dh-page-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;display:flex}.dh-page-title{color:var(--ink);letter-spacing:-.02em;margin:0;font-family:Funnel Display,sans-serif;font-size:1.35rem;font-weight:700}.dh-meta-bar{color:var(--muted);word-break:break-word;overflow-wrap:break-word;margin-bottom:1rem;font-size:.78rem}.dh-attribution{color:var(--muted);border-top:1px solid var(--border);margin-top:1.25rem;padding-top:.85rem;font-family:Inter,sans-serif;font-size:.75rem;line-height:1.6}.dh-error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:1rem;padding:1rem 1.25rem}.dh-error-title{color:var(--red);margin:0 0 .25rem;font-family:Inter,sans-serif;font-size:.88rem;font-weight:600}.dh-error-detail{color:var(--ink-soft);margin:0 0 .5rem;font-size:.82rem}.dh-expired-banner{color:#92400e;background:#fffbe6;border:1px solid #fde68a;border-radius:6px;margin-bottom:1rem;padding:.65rem 1rem;font-size:.82rem}.dh-consent-panel{background:var(--off);border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;padding:1.25rem 1.5rem}.dh-consent-label{letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin:0 0 .6rem;font-size:.72rem;font-weight:700}.dh-consent-script{color:var(--ink-soft);margin:0;font-size:1rem;font-weight:600;line-height:1.65}.dh-consent-accordion{margin-bottom:1.25rem}.dh-consent-accordion>summary.dh-consent-accordion-trigger{color:var(--sky);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.35rem;padding:.25rem 0;font-size:.82rem;font-weight:500;list-style:none;display:inline-flex}.dh-consent-accordion>summary.dh-consent-accordion-trigger::-webkit-details-marker{display:none}.dh-consent-accordion>summary.dh-consent-accordion-trigger:before{content:"›";font-size:1rem;line-height:1;transition:transform .15s;display:inline-block}.dh-consent-accordion[open]>summary.dh-consent-accordion-trigger:before{transform:rotate(90deg)}.dh-consent-accordion-body{border:1px solid var(--border);border-radius:8px;margin-top:.75rem;overflow:hidden}.dh-consent-item{border-bottom:1px solid var(--border)}.dh-consent-item:last-child{border-bottom:none}.dh-consent-item>summary.dh-consent-item-q{color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--white);justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.82rem;font-weight:500;list-style:none;display:flex}.dh-consent-item>summary.dh-consent-item-q::-webkit-details-marker{display:none}.dh-consent-item>summary.dh-consent-item-q:after{content:"+";color:var(--muted);flex-shrink:0;font-size:1rem;transition:transform .15s}.dh-consent-item[open]>summary.dh-consent-item-q:after{transform:rotate(45deg)}.dh-consent-item-a{color:var(--muted);background:var(--off);margin:0;padding:0 1rem .85rem;font-size:.82rem;font-weight:300;line-height:1.75}.dh-form-dialog{background:var(--white);border:1px solid var(--border);border-radius:12px;max-width:480px;margin:2.5rem auto;overflow:hidden;box-shadow:0 4px 24px #0000000f}.dh-form-dialog-title{background:var(--off);border-bottom:1px solid var(--border);color:var(--ink);letter-spacing:-.01em;padding:1rem 1.5rem;font-family:Funnel Display,sans-serif;font-size:.95rem;font-weight:700}.dh-form-dialog-body{padding:1.5rem}.dh-form-group{margin-bottom:1rem}.dh-field-label{color:var(--ink-soft);margin-bottom:4px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;display:block}.dh-field-error{color:var(--red);margin:6px 0 0;font-family:Inter,sans-serif;font-size:.78rem;font-weight:500}.dh-form-footer{border-top:1px solid var(--border);background:var(--off);align-items:center;gap:8px;padding:.85rem 1.5rem 1.1rem;display:flex}.dh-rec-btn{aspect-ratio:1;background:var(--red);cursor:pointer;width:72px;height:72px;color:var(--white);letter-spacing:.1em;border:none;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:3px;padding:0;font-family:Inter,sans-serif;font-size:.65rem;font-weight:700;transition:background .15s,box-shadow .15s;display:flex}.dh-rec-btn:hover:not(:disabled){background:var(--red-dk);box-shadow:0 0 0 8px #dc26261a}.dh-rec-btn:active:not(:disabled){transform:scale(.96)}.dh-rec-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1.2s ease-in-out infinite dh-rec-pulse}@keyframes dh-warning-flash{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes dh-rec-pulse{0%{box-shadow:0 0 #dc262699}60%{box-shadow:0 0 0 6px #dc262600}to{box-shadow:0 0 #dc262600}}.dh-elapsed{font-variant-numeric:tabular-nums;min-width:90px;color:var(--ink);letter-spacing:.02em;font-family:Inter,sans-serif;font-size:1.75rem;font-weight:300}.dh-progress-bar-wrap{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.dh-progress-bar-fill{background:linear-gradient(90deg, var(--sky-lt) 0%, var(--sky) 40%, var(--sky-dk) 60%, var(--sky-lt) 100%);background-size:200% 100%;width:100%;height:100%;animation:1.4s infinite dh-shimmer}@keyframes dh-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.dh-stage-list{flex-direction:column;gap:16px;padding:4px 0;display:flex}.dh-stage{align-items:flex-start;gap:12px;display:flex}.dh-stage-dot{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;transition:background .2s,border-color .2s;display:flex}.dh-stage--pending .dh-stage-dot{background:var(--border);border:2px solid var(--border)}.dh-stage--active .dh-stage-dot{background:var(--sky);border:2px solid var(--sky);animation:1.2s ease-in-out infinite dh-stage-pulse}.dh-stage--done .dh-stage-dot{background:var(--sky);border:2px solid var(--sky)}.dh-stage--done .dh-stage-dot:after{content:"✓";color:#fff;font-size:11px;font-weight:700;line-height:1}@keyframes dh-stage-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.65;transform:scale(.88)}}.dh-stage-text{flex-direction:column;gap:2px;display:flex}.dh-stage-name{font-size:.875rem;line-height:1.3;transition:color .2s,font-weight .2s}.dh-stage--pending .dh-stage-name{color:var(--muted);font-weight:400}.dh-stage--active .dh-stage-name,.dh-stage--done .dh-stage-name{color:var(--ink);font-weight:600}.dh-stage-sub{color:var(--muted);font-size:.75rem;line-height:1.4;transition:opacity .2s}.dh-stage--pending .dh-stage-sub{opacity:0}.dh-stage--active .dh-stage-sub,.dh-stage--done .dh-stage-sub{opacity:1}a.dh-back-link{color:var(--sky);font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;text-decoration:none}a.dh-back-link:hover{color:var(--sky-dk);text-decoration:underline}a.dh-back-cta{color:var(--muted);margin-bottom:.5rem;font-family:Inter,sans-serif;font-size:.82rem;text-decoration:none;display:inline-block}a.dh-back-cta:hover{text-decoration:underline}.dh-download-link{color:var(--sky);cursor:pointer;font-family:Inter,sans-serif;font-size:.78rem;text-decoration:underline}.dh-action-cell{text-align:center;white-space:nowrap;width:80px}.dh-lock-icon{opacity:.45;cursor:default;font-size:.9rem}.dh-btn-delete-session{color:var(--red);border:1px solid var(--red);cursor:pointer;background:0 0;border-radius:4px;padding:2px 10px;font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;transition:background .15s,color .15s}.dh-btn-delete-session:hover{background:var(--red);color:var(--white)}.dh-play-cell{white-space:nowrap;padding-left:.5rem;padding-right:.5rem}.dh-btn-row-play{border:1px solid var(--border);background:var(--white);width:26px;height:26px;color:var(--sky);cursor:pointer;vertical-align:middle;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.7rem;line-height:1;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.dh-btn-row-play:hover{background:var(--sky);border-color:var(--sky);color:var(--white)}.dh-row-duration{font-variant-numeric:tabular-nums;color:var(--muted);vertical-align:middle;margin-left:.5rem;font-size:.78rem;display:inline-block}.dh-audio-player{z-index:150;background:var(--white);border-top:1px solid var(--border);align-items:center;gap:.85rem;padding:.6rem 1rem;font-family:Inter,sans-serif;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0000000f}.dh-audio-play{background:var(--sky);width:36px;height:36px;color:var(--white);cursor:pointer;border:none;border-radius:50%;flex:none;justify-content:center;align-items:center;padding:0;font-size:.85rem;line-height:1;transition:background .15s;display:inline-flex}.dh-audio-play:hover{background:var(--sky-dk)}.dh-audio-meta{flex-direction:column;flex:0 220px;gap:2px;min-width:0;display:flex;overflow:hidden}.dh-audio-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.dh-audio-status{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.dh-audio-scrubber{min-width:80px;accent-color:var(--sky);cursor:pointer;flex:auto}.dh-audio-time{font-variant-numeric:tabular-nums;color:var(--muted);white-space:nowrap;flex:none;font-size:.78rem}.dh-audio-close{color:var(--muted);cursor:pointer;background:0 0;border:none;flex:none;padding:0 .25rem;font-size:1.3rem;line-height:1;transition:color .15s}.dh-audio-close:hover{color:var(--ink)}.dh-modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dh-modal{background:var(--white);border-radius:10px;width:100%;max-width:380px;padding:2rem;box-shadow:0 8px 32px #0000002e}.dh-modal-title{color:var(--ink);margin:0 0 .75rem;font-family:Funnel Display,sans-serif;font-size:1.15rem;font-weight:700}.dh-modal-body{color:var(--ink-soft);margin:0 0 1.5rem;font-size:.875rem;line-height:1.6}.dh-modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.dh-meta-header{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:.75rem 1.25rem;display:flex}.dh-meta-rows{flex-direction:column;gap:.15rem;display:flex}.dh-meta-row{color:#374151;font-size:.82rem;line-height:1.65}.dh-meta-label{margin-right:.4em;font-weight:500}.dh-meta-value{color:#6b7280}.dh-btn-play{white-space:nowrap;flex-shrink:0;padding:4px 12px;font-size:.78rem}.dh-note-area{margin-bottom:.25rem}.dh-note-textarea{color:#374151;resize:vertical;box-sizing:border-box;white-space:pre-wrap;background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:100%;min-height:560px;padding:1.25rem;font-family:Inter,sans-serif;font-size:.84rem;font-weight:300;line-height:1.85}.dh-note-textarea:focus{border-color:#87ceeb;outline:none;box-shadow:0 0 0 3px #87ceeb40}.dh-note-textarea[readonly]{cursor:default;color:#374151;background:#f9fafb}.dh-note-textarea[readonly]:focus{box-shadow:none;border-color:#e5e7eb}.dh-save-status{color:#9ca3af;white-space:nowrap;font-size:.72rem;font-style:italic}.dh-save-status.dh-save-error{color:#dc2626;font-style:normal}.dh-tab-bar{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;grid-template-columns:1fr 1fr;margin-bottom:.75rem;display:grid;overflow:hidden}.dh-tab{color:#6b7280;cursor:pointer;white-space:nowrap;background:#f9fafb;border:none;justify-content:center;align-items:center;gap:.35rem;padding:.6rem 1rem;font-family:Inter,sans-serif;font-size:.82rem;font-weight:500;transition:background .12s,color .12s;display:flex}.dh-tab+.dh-tab{border-left:1px solid #e5e7eb}.dh-tab:hover:not(.dh-tab-active){color:#374151;background:#f0f9ff}.dh-tab-active{color:#111827;background:#fff;font-weight:600}.dh-transcript-body{color:#374151;box-sizing:border-box;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word;-webkit-user-select:text;user-select:text;cursor:text;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;width:100%;min-height:560px;padding:1.25rem;font-family:Inter,sans-serif;font-size:.84rem;font-weight:300;line-height:1.85;display:block;overflow-y:auto}
