/* ── Reset ── */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;touch-action:manipulation}
html,body{height:100%;-webkit-user-select:none;user-select:none}
/* 텍스트 입력/복사가 필요한 영역만 선택·스크롤 허용 */
input,textarea{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default;touch-action:auto}
.summary-card,.transcript-box,.tab-content{-webkit-user-select:text;user-select:text;touch-action:pan-y}
:root{
  --sat: env(safe-area-inset-top, 0px);
  --sab: env(safe-area-inset-bottom, 0px);
}

/* ── Design Tokens ── */
:root{
  --bg:#fafafa;
  --surface:#fff;
  --surface2:#f5f5f5;
  --border:#ebebeb;
  --border2:#e0e0e0;
  --text:#111;
  --text2:#444;
  --text3:#aaa;
  --text4:#ccc;
  --accent:#111;
  --success:#34c759;
  --danger:#ff3b30;
  --warn:#ff9500;
  --info:#007aff;
  --r-sm:8px;--r-md:11px;--r-lg:14px;--r-xl:20px;
  --font:'Inter',sans-serif;
}
body.dark{
  --bg:#0f0f0f;
  --surface:#1a1a1a;
  --surface2:#222;
  --border:#2a2a2a;
  --border2:#333;
  --text:#f0f0f0;
  --text2:#bbb;
  --text3:#666;
  --text4:#444;
}

body{font-family:var(--font);background:var(--bg);color:var(--text);max-width:430px;margin:0 auto;min-height:100vh;overflow-x:hidden}

/* ── Screens ── */
.screen{display:none;flex-direction:column;min-height:100vh}
.screen.active{display:flex}

/* ── Topbar ── */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:calc(44px + var(--sat)) 20px 12px;border-bottom:0.5px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10}
.topbar-title{font-size:17px;font-weight:600;color:var(--text);letter-spacing:-0.3px}
.topbar-left{display:flex;align-items:center;gap:8px}
.ic-btn{width:32px;height:32px;background:var(--surface2);border:0.5px solid var(--border);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text3);font-size:15px;transition:background .15s}
.ic-btn:active{background:var(--border)}

/* ── Bottom Nav ── */
.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;background:var(--bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:0.5px solid var(--border);display:flex;padding:10px 0 calc(14px + var(--sab));z-index:20}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:6px 0;min-height:44px;font-size:9px;font-weight:500;color:var(--text4);text-transform:uppercase;letter-spacing:.5px;transition:color .2s}
.nav-item.active{color:var(--text)}
.nav-badge-wrap{position:relative;display:inline-block}
.nav-badge{position:absolute;top:-2px;right:-4px;background:var(--danger);color:#fff;font-size:9px;font-weight:600;min-width:15px;height:15px;border-radius:8px;display:none;align-items:center;justify-content:center;padding:0 3px}

/* ── Spinner ── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.spinner{width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--text);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
.spinner.sm{width:13px;height:13px;border-width:1.5px}

/* ════════════════════════════════
   SETUP SCREEN (최초 설정)
════════════════════════════════ */
#setup-screen{padding:calc(44px + var(--sat)) 24px calc(40px + var(--sab));overflow-y:auto;justify-content:center}
.setup-header{margin-bottom:28px}
.setup-header h2{font-size:22px;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}
.setup-header p{font-size:13px;color:var(--text3);line-height:1.6}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:11px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:7px}
.form-input{width:100%;background:var(--surface);border:0.5px solid var(--border2);border-radius:var(--r-md);padding:13px 14px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color .2s}
.form-input:focus{border-color:var(--text)}
.form-input::placeholder{color:var(--text4)}
.form-input.error{border-color:var(--danger)}
.form-hint{font-size:11px;color:var(--text4);margin-top:5px;line-height:1.5}
.form-hint a{color:var(--text3);text-decoration:underline}
.form-error{font-size:11px;color:var(--danger);margin-top:4px;display:none}
.form-error.show{display:block}
.btn-primary{width:100%;background:var(--text);color:#fff;border:none;border-radius:var(--r-md);padding:14px;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;letter-spacing:-0.2px;transition:opacity .15s;margin-top:6px;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-primary:active{opacity:.85}
.btn-primary:disabled{opacity:.35;cursor:not-allowed}

/* ════════════════════════════════
   LOGIN SCREEN
════════════════════════════════ */
#login-screen{justify-content:space-between;padding:0;background:var(--bg)}
.login-top{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 32px 40px;gap:24px}
.login-logo-wrap{width:72px;height:72px;border-radius:20px;background:var(--surface2);border:0.5px solid var(--border);display:flex;align-items:center;justify-content:center}
.login-logo-inner{width:36px;height:36px;border-radius:9px;background:var(--text);display:flex;align-items:center;justify-content:center}
.login-mic{width:12px;height:17px;background:#fff;border-radius:6px;position:relative}
.login-mic::after{content:'';position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);width:8px;height:5px;border-bottom:1.5px solid #fff;border-left:1.5px solid #fff;border-right:1.5px solid #fff;border-radius:0 0 4px 4px}
.login-brand{text-align:center}
.login-brand-main{font-size:23px;font-weight:700;color:var(--text);letter-spacing:-0.8px;line-height:1.1}
.login-brand-sub{font-size:23px;font-weight:300;color:var(--text);letter-spacing:-0.8px;line-height:1.15}
.login-brand-line{width:22px;height:1px;background:var(--border2);margin:10px auto}
.login-brand-powered{font-size:10px;font-weight:400;color:var(--text4);letter-spacing:1.5px;text-transform:uppercase}
.login-tagline{font-size:13px;color:var(--text3);text-align:center;line-height:1.7;max-width:220px}
.login-bottom{padding:0 24px 48px;display:flex;flex-direction:column;gap:10px}
.login-divider{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.login-divider-line{flex:1;height:0.5px;background:var(--border)}
.login-divider-text{font-size:11px;color:var(--text4)}
.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--surface);border:0.5px solid var(--border2);border-radius:var(--r-md);padding:14px 18px;cursor:pointer;transition:background .15s}
.google-btn:active{background:var(--surface2)}
.google-btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}
.google-icon{width:20px;height:20px;border-radius:50%;background:var(--surface2);border:0.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#4285f4;font-family:sans-serif;flex-shrink:0}
.google-btn-text{font-size:14px;font-weight:500;color:var(--text2)}
.login-notice{font-size:11px;color:var(--text4);text-align:center;line-height:1.7}
.login-notice span{color:var(--text3)}
.login-setup-link{font-size:12px;color:var(--text3);text-align:center;cursor:pointer;text-decoration:underline;padding:4px}

/* ════════════════════════════════
   HOME / RECORD SCREEN
════════════════════════════════ */
#home-screen{padding-bottom:calc(80px + var(--sab))}
.home-topbar{display:flex;align-items:center;justify-content:space-between;padding:calc(44px + var(--sat)) 20px 12px;border-bottom:0.5px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10}
.home-brand{display:flex;align-items:center;gap:8px}
.home-avatar{width:28px;height:28px;border-radius:50%;background:var(--surface2);border:0.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text2)}
.home-brand-text{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-0.2px}
.home-brand-text span{font-weight:300}
.home-content{padding:16px 18px;display:flex;flex-direction:column;gap:12px}

/* Status bar */
.status-bar{display:flex;align-items:center;gap:6px;padding:7px 11px;background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-sm)}
.status-dot{width:6px;height:6px;border-radius:50%;background:var(--text4);flex-shrink:0;transition:background .3s}
.status-dot.online{background:var(--success)}
.status-dot.offline{background:var(--danger)}
.status-text{font-size:11px;color:var(--text2);flex:1}
.battery-text{font-size:11px;color:var(--text3)}
.battery-text.low{color:var(--warn)}

/* Record card */
.rec-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-xl);padding:28px 24px;text-align:center}
.rec-timer{font-size:48px;font-weight:200;color:var(--text);letter-spacing:3px;font-variant-numeric:tabular-nums;line-height:1;margin-bottom:4px}
#rec-waveform{display:block;margin:8px auto}
.rec-btn-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;margin:16px 0 12px}
.rec-btn{width:78px;height:78px;border-radius:50%;background:var(--text);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,opacity .15s}
.rec-btn:active{transform:scale(.94);opacity:.85}
.rec-btn:disabled{opacity:.4;cursor:not-allowed}
.rec-btn-inner{width:26px;height:26px;background:#fff;border-radius:50%;transition:border-radius .2s,width .2s,height .2s}
.rec-btn.recording .rec-btn-inner{border-radius:5px;width:22px;height:22px}
.rec-btn-label{font-size:12px;color:var(--text3);font-weight:400}
.rec-btn-hint{font-size:10px;color:var(--text4);margin-top:2px}

/* Chunk progress */
.chunk-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:14px}
.chunk-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.chunk-label{font-size:11px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.chunk-count{font-size:11px;color:var(--text4)}
.chunk-pbar-wrap{height:2px;background:var(--surface2);border-radius:1px;margin-bottom:9px;overflow:hidden}
.chunk-pbar-fill{height:100%;width:0%;background:var(--text);border-radius:1px;transition:width .4s ease}
.chunk-dots{display:grid;grid-template-columns:repeat(9,1fr);gap:3px}
.chunk-dot{height:22px;border-radius:5px;background:var(--surface2);border:0.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:8px;color:var(--text4);font-weight:500;transition:all .25s}
.chunk-dot.done{background:var(--text);border-color:var(--text);color:#fff}
.chunk-dot.doing{background:var(--surface2);border-color:var(--text2);color:var(--text2);animation:cdpulse 1s infinite}
.chunk-dot.retry{background:#fff8f0;border-color:var(--warn);color:var(--warn)}
.chunk-dot.fail{background:#fff5f5;border-color:var(--danger);color:var(--danger)}
@keyframes cdpulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes fadeout{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(.97)}}
.history-item.deleting{animation:fadeout .25s ease forwards;pointer-events:none}

/* Processing card */
.processing-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:14px;display:none}
.proc-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--border);font-size:13px;color:var(--text3)}
.proc-row:last-child{border-bottom:none}
.proc-row i,.proc-row .spinner{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.proc-row.done{color:var(--success)}
.proc-row.doing{color:var(--text2)}
.proc-row.error{color:var(--danger)}

/* ════════════════════════════════
   OVERLAY SCREEN (recording active)
════════════════════════════════ */
#overlay-screen{position:fixed;inset:0;background:#000;z-index:50;display:none;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:100%;left:0;transform:none;cursor:pointer}
#overlay-screen.active{display:flex}
/* REC 배지 - 항상 표시 */
.ov-rec-badge{position:absolute;top:calc(24px + var(--sat));left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.07);border:0.5px solid rgba(255,255,255,.12);border-radius:20px;padding:6px 14px}
.ov-rec-dot{width:6px;height:6px;border-radius:50%;background:#ff3b30;animation:recpulse 1.2s infinite;flex-shrink:0}
@keyframes recpulse{0%,100%{opacity:1}50%{opacity:.3}}
.ov-rec-label{font-size:11px;color:#ccc;font-weight:600;letter-spacing:.8px}
/* 타이머 - 항상 극도로 희미하게, 탭하면 밝게 */
.ov-timer-always{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:64px;font-weight:100;color:rgba(255,255,255,.03);letter-spacing:4px;font-variant-numeric:tabular-nums;pointer-events:none;transition:color .3s}
#overlay-screen.ui-visible .ov-timer-always{color:rgba(255,255,255,.7)}
/* 버튼 영역 - 탭하면 표시 */
.ov-ui{position:absolute;bottom:calc(50px + var(--sab));left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:20px;opacity:0;pointer-events:none;transition:opacity .25s}
#overlay-screen.ui-visible .ov-ui{opacity:1;pointer-events:auto}
/* 탭 힌트 */
.ov-tap-hint-center{position:absolute;bottom:calc(20px + var(--sab));font-size:11px;color:rgba(255,255,255,.06);letter-spacing:.3px;transition:opacity .3s;pointer-events:none}
#overlay-screen.ui-visible .ov-tap-hint-center{opacity:0}
.ov-transcript-preview{max-width:280px;font-size:12px;color:rgba(255,255,255,.5);line-height:1.6;text-align:center;margin-bottom:8px;opacity:0;transition:opacity .3s}
/* 버튼 */
.ov-btn-row{display:flex;gap:24px;align-items:center}
.ov-btn{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.ov-btn-circle{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:opacity .15s}
.ov-btn-circle:active{opacity:.7}
.ov-btn-menu .ov-btn-circle{background:rgba(255,255,255,.1);border:0.5px solid rgba(255,255,255,.2)}
.ov-btn-stop .ov-btn-circle{background:#ff3b30;border:none}
.ov-btn-label{font-size:11px;color:#666;letter-spacing:.3px}
.ov-stop-inner-sq{width:20px;height:20px;background:#fff;border-radius:4px}
.ov-btn-pause .ov-btn-circle{background:rgba(255,255,255,.15);border:0.5px solid rgba(255,255,255,.3)}
.ov-btn-bookmark .ov-btn-circle{background:rgba(0,122,255,.2);border:0.5px solid rgba(0,122,255,.4)}
.ov-transcript-preview{font-size:11px;color:rgba(255,255,255,.45);line-height:1.6;text-align:center;max-height:72px;overflow:hidden;padding:0 24px;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}

/* Post-record manual flow card */
.post-rec-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:16px;display:none;flex-direction:column;gap:10px}
.post-rec-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:2px}
.post-rec-info{font-size:11px;color:var(--text4);margin-bottom:4px}
.post-rec-step{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--surface2);border:0.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:background .15s}
.post-rec-step:active{background:var(--border)}
.post-rec-step.done{border-color:var(--success);background:rgba(52,199,89,.06)}
.post-rec-step.doing{border-color:var(--info);background:rgba(0,122,255,.06)}
.post-rec-step.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.post-step-icon{width:30px;height:30px;border-radius:8px;background:var(--surface);border:0.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px}
.post-rec-step.done .post-step-icon{background:rgba(52,199,89,.1);border-color:rgba(52,199,89,.3);color:var(--success)}
.post-rec-step.doing .post-step-icon{background:rgba(0,122,255,.1);border-color:rgba(0,122,255,.3)}
.post-step-info{flex:1}
.post-step-label{font-size:13px;font-weight:500;color:var(--text)}
.post-step-sub{font-size:11px;color:var(--text4);margin-top:1px}
.post-step-arrow{font-size:14px;color:var(--text4)}
.chunk-sel-btn{padding:5px 10px;border-radius:6px;border:0.5px solid var(--border);background:var(--surface2);font-size:12px;font-weight:500;color:var(--text3);cursor:pointer;transition:all .15s}
.chunk-sel-btn.active{background:var(--text);color:#fff;border-color:var(--text)}
#history-screen{padding-bottom:calc(80px + var(--sab))}
.search-wrap{padding:10px 18px}
.search-box{display:flex;align-items:center;gap:8px;background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:9px 13px}
.search-box i{font-size:14px;color:var(--text4)}
.search-input{flex:1;background:none;border:none;outline:none;font-family:var(--font);font-size:13px;color:var(--text)}
.search-input::placeholder{color:var(--text4)}
.history-list{padding:0 18px;display:flex;flex-direction:column;gap:8px}
.history-item-wrap{position:relative;overflow:hidden;border-radius:var(--r-lg)}
.history-item{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:13px;cursor:pointer;transition:border-color .15s,transform .2s;position:relative;z-index:1;touch-action:pan-y}
.history-item:active{border-color:var(--text2)}
.swipe-delete-bg{position:absolute;right:0;top:0;bottom:0;width:80px;background:var(--danger);display:flex;align-items:center;justify-content:center;border-radius:0 var(--r-lg) var(--r-lg) 0;z-index:0}
.swipe-delete-bg svg{color:#fff}
.history-item-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.history-item-title{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-0.2px}
.history-item-date{font-size:10px;color:var(--text4)}
.history-badges{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:7px}
.hbadge{font-size:10px;padding:2px 7px;border-radius:20px;font-weight:500}
.hb-dur{color:var(--text2);background:var(--surface2)}
.hb-chunk{color:var(--text4);background:var(--surface2)}
.hb-sent{color:var(--success);background:rgba(52,199,89,.08)}
.hb-fail{color:var(--danger);background:rgba(255,59,48,.07)}
.history-preview{font-size:12px;color:var(--text3);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.history-actions{display:flex;gap:5px;margin-top:10px;padding-top:10px;border-top:0.5px solid var(--border)}
.h-act{flex:1;background:var(--surface2);border:0.5px solid var(--border);border-radius:7px;padding:8px 4px;display:flex;align-items:center;justify-content:center;gap:3px;font-size:10px;color:var(--text3);font-weight:500;cursor:pointer;transition:background .15s;min-height:36px}
.h-act:active{background:var(--border)}
.h-act i{font-size:12px}
.history-empty{text-align:center;padding:60px 20px;color:var(--text4)}
.rec-live-badge{display:none;align-items:center;gap:6px;background:rgba(255,59,48,.08);border:0.5px solid rgba(255,59,48,.2);border-radius:20px;padding:5px 12px;margin:8px 18px 0;font-size:11px;color:var(--danger);font-weight:500}
.rec-live-badge.show{display:flex}
.rec-live-dot{width:6px;height:6px;border-radius:50%;background:var(--danger);animation:recpulse 1.2s infinite;flex-shrink:0}
.history-empty p{font-size:13px;line-height:1.6}

/* ════════════════════════════════
   DETAIL SCREEN
════════════════════════════════ */
#detail-screen{padding-bottom:calc(60px + var(--sab));overflow-y:auto}
.detail-content{padding:14px 18px;display:flex;flex-direction:column;gap:11px}
.detail-meta{display:flex;justify-content:space-between;align-items:flex-start}
.detail-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.4px;cursor:pointer;border-bottom:1px dashed transparent;transition:border-color .2s}
.detail-title:hover{border-bottom-color:var(--border2)}
.detail-title-input{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.4px;background:none;border:none;border-bottom:1px solid var(--text3);outline:none;width:100%;font-family:var(--font);padding:0}
.detail-badges{display:flex;flex-direction:column;align-items:flex-end;gap:4px}

/* Audio player */
.player-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:14px}
.player-waveform{height:32px;display:flex;align-items:center;gap:2px;margin-bottom:8px;cursor:pointer}
.player-wave-bar{border-radius:1px;background:var(--surface2);flex-shrink:0;transition:background .1s}
.player-wave-bar.played{background:var(--text)}
.player-times{display:flex;justify-content:space-between;font-size:10px;color:var(--text4);margin-bottom:10px;font-variant-numeric:tabular-nums}
.player-controls{display:flex;align-items:center;justify-content:center;gap:18px}
.player-ctrl{width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text3);font-size:18px}
.player-ctrl:active{color:var(--text)}
.player-play-btn{width:44px;height:44px;background:var(--text);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:17px;transition:opacity .15s}
.player-play-btn:active{opacity:.8}
.player-speed{font-size:10px;color:var(--text3);background:var(--surface2);border:0.5px solid var(--border);border-radius:6px;padding:3px 8px;cursor:pointer;font-weight:500}

/* Tabs */
.detail-tabs{display:flex;gap:5px}
.detail-tab{flex:1;padding:8px;background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-sm);font-size:12px;font-weight:500;color:var(--text4);text-align:center;cursor:pointer;transition:all .15s}
.detail-tab.active{border-color:var(--text);color:var(--text);background:var(--surface2)}
.tab-content{display:none}
.tab-content.active{display:block}
.summary-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:14px;display:flex;flex-direction:column;gap:8px}
.sum-section-label{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-top:10px;margin-bottom:4px}
.keyword-wrap{display:flex;flex-wrap:wrap;gap:5px;margin:4px 0 8px}
.keyword-tag{font-size:11px;font-weight:500;color:var(--text2);background:var(--surface2);border:0.5px solid var(--border);border-radius:20px;padding:3px 10px;cursor:pointer;transition:background .15s}
.keyword-tag:active{background:var(--border)}
.sum-item{display:flex;gap:8px;align-items:flex-start}
.sum-dot{width:4px;height:4px;border-radius:50%;background:var(--text);margin-top:8px;flex-shrink:0}
.sum-txt{font-size:13px;color:var(--text2);line-height:1.6}

/* 인라인 편집 가능 용어 정리 / STT 의심 단어 */
.term-item{display:flex;align-items:center;gap:6px;padding:6px 0;font-size:13px;color:var(--text2);line-height:1.6;border-bottom:0.5px solid var(--border2)}
.term-item:last-child{border-bottom:0}
.term-original{color:var(--text2);font-weight:500;white-space:nowrap}
.term-arrow{color:var(--text4);margin:0 2px}
.term-meaning{flex:1;color:var(--text2);cursor:pointer;padding:2px 6px;border-radius:4px;transition:background 0.15s;min-width:0;word-break:break-word}
.term-meaning:hover{background:var(--surface2)}
.term-meaning.editing{background:var(--surface);border:0.5px solid var(--border);padding:1px 5px}
.term-input{flex:1;background:transparent;border:0;font-family:var(--font);font-size:13px;color:var(--text1);outline:none;padding:0;min-width:0}
.term-btn{flex-shrink:0;background:transparent;border:0.5px solid var(--border2);border-radius:4px;padding:3px 8px;font-size:11px;cursor:pointer;color:var(--text3);transition:all 0.15s;font-family:var(--font)}
.term-btn:hover{background:var(--surface2);color:var(--text1)}
.term-btn.apply{color:var(--success);border-color:var(--success)}
.term-btn.apply:hover{background:var(--success);color:#fff}
.term-btn.dismiss{color:var(--text4)}
.term-btn.delete{color:var(--danger);padding:3px 6px}
.term-btn.delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}

.transcript-box{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:14px;font-size:13px;color:var(--text2);line-height:1.7;white-space:pre-wrap;word-break:break-word;max-height:50vh;overflow-y:auto}
.action-items-box{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:14px;display:flex;flex-direction:column;gap:8px}
.action-progress{font-size:11px;color:var(--text3);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.action-progress-bar{flex:1;height:2px;background:var(--border2);border-radius:1px;overflow:hidden}
.action-progress-fill{height:100%;background:var(--success);border-radius:1px;transition:width .3s}
.action-item{display:flex;align-items:flex-start;gap:10px;padding:10px;background:var(--surface2);border-radius:var(--r-sm);cursor:pointer}
.action-check{width:16px;height:16px;border-radius:4px;background:var(--surface);border:0.5px solid var(--border2);flex-shrink:0;margin-top:1px;transition:background .15s,border-color .15s;display:flex;align-items:center;justify-content:center}
.action-item{transition:background .2s}
.action-item.checked{background:rgba(52,199,89,.06)}
.action-item.checked .action-check{background:var(--success);border-color:var(--success);transform:scale(1.1);transition:all .25s}
.action-item.checked .action-check::after{content:'✓';font-size:9px;color:#fff;font-weight:700}
.action-item.checked .action-txt{text-decoration:line-through;color:var(--text4);transition:color .2s}
.action-txt{font-size:12px;color:var(--text2);line-height:1.5}
.drive-link-btn{display:flex;align-items:center;gap:6px;background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:10px 13px;font-size:12px;color:var(--info);text-decoration:none;cursor:pointer;transition:background .15s}
.drive-link-btn:active{background:var(--surface2)}
.drive-link-btn i{font-size:15px}

/* ════════════════════════════════
   SETTINGS SCREEN
════════════════════════════════ */
#settings-screen{padding-bottom:calc(80px + var(--sab));overflow-y:auto}
.settings-content{padding:14px 18px;display:flex;flex-direction:column;gap:5px}
.settings-section{font-size:10px;font-weight:500;color:var(--text4);text-transform:uppercase;letter-spacing:.8px;margin:14px 0 5px;padding-left:2px}
.settings-section:first-child{margin-top:0}
.profile-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:14px;display:flex;align-items:center;gap:11px}
.profile-avatar{width:42px;height:42px;border-radius:50%;background:var(--surface2);border:0.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;color:var(--text2);flex-shrink:0}
.profile-name{font-size:14px;font-weight:600;color:var(--text);letter-spacing:-0.2px}
.profile-email{font-size:11px;color:var(--text4);margin-top:1px}
.profile-badge{font-size:10px;font-weight:500;color:var(--success);background:rgba(52,199,89,.08);border:0.5px solid rgba(52,199,89,.15);border-radius:20px;padding:2px 8px;display:inline-block;margin-top:4px}
.settings-row{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:11px 13px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background .15s}
.settings-row:active{background:var(--surface2)}
.settings-row-left{display:flex;align-items:center;gap:9px}
.settings-row-icon{width:28px;height:28px;border-radius:7px;background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;color:var(--text3)}
.settings-row-label{font-size:13px;color:var(--text2)}
.settings-row-value{font-size:11px;color:var(--text4)}
.toggle{width:36px;height:20px;border-radius:10px;background:var(--border2);position:relative;cursor:pointer;transition:background .25s;flex-shrink:0}
.toggle-dot{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left .25s;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.toggle.on{background:var(--text)}
.toggle.on .toggle-dot{left:18px}
.settings-input-row{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:11px 13px}
.settings-input-label{font-size:11px;color:var(--text4);margin-bottom:6px;font-weight:500}
.settings-input{width:100%;background:var(--surface2);border:0.5px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s}
.settings-input:focus{border-color:var(--text2)}
.settings-save-btn{background:var(--text);color:#fff;border:none;border-radius:var(--r-sm);padding:8px 16px;font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;margin-top:8px;transition:opacity .15s}
.settings-save-btn:active{opacity:.8}

/* API Key 카드: 마스킹된 값 + 복사·편집 버튼 */
.apikey-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:11px 13px}
.apikey-card + .apikey-card{margin-top:6px}
.apikey-card-label{font-size:11px;color:var(--text4);margin-bottom:6px;font-weight:500;display:flex;justify-content:space-between;align-items:center}
.apikey-card-extra{font-size:10px;color:var(--text4);font-weight:400}
.apikey-display{display:flex;align-items:center;gap:6px}
.apikey-masked{flex:1;font-family:'SF Mono', Menlo, Monaco, monospace;font-size:12px;color:var(--text2);background:var(--surface2);border:0.5px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;letter-spacing:0.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.apikey-masked.empty{color:var(--text4);font-style:italic;letter-spacing:0;font-family:var(--font)}
.apikey-btn{flex-shrink:0;background:var(--surface2);border:0.5px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;cursor:pointer;color:var(--text2);transition:background .15s;display:flex;align-items:center;justify-content:center}
.apikey-btn:hover{background:var(--surface)}
.apikey-btn:active{background:var(--border2)}
.apikey-editor{margin-top:8px;display:none}
.apikey-editor.open{display:block}

/* 진입 메뉴(>) 행 */
.settings-nav-row{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:13px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background .15s}
.settings-nav-row:active{background:var(--surface2)}
.settings-nav-left{display:flex;align-items:center;gap:11px;flex:1;min-width:0}
.settings-nav-icon{width:30px;height:30px;border-radius:7px;background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text2)}
.settings-nav-text{flex:1;min-width:0}
.settings-nav-title{font-size:13px;color:var(--text);font-weight:500;letter-spacing:-0.1px}
.settings-nav-desc{font-size:11px;color:var(--text4);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.settings-nav-arrow{color:var(--text4);flex-shrink:0;margin-left:8px}

/* 풀스크린 서브 화면 (용어 사전, 에러 로그) */
.sub-screen{position:fixed;inset:0;background:var(--bg);z-index:150;display:none;flex-direction:column}
.sub-screen.open{display:flex}
.sub-screen-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:0.5px solid var(--border);background:var(--bg)}
.sub-screen-back{background:transparent;border:0;padding:4px;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center}
.sub-screen-title{font-size:16px;font-weight:600;color:var(--text);letter-spacing:-0.2px;flex:1}
.sub-screen-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}
.sub-screen-actions{padding:12px 16px;border-top:0.5px solid var(--border);display:flex;gap:8px;background:var(--bg)}
.sub-screen-action-btn{flex:1;padding:11px;border-radius:var(--r-md);border:0.5px solid var(--border2);background:var(--surface);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;color:var(--text2)}
.sub-screen-action-btn.danger{color:var(--danger);border-color:var(--danger)}

/* 에러 로그 항목 */
.error-log-item{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:11px 13px;font-size:12px}
.error-log-meta{display:flex;justify-content:space-between;color:var(--text4);font-size:10px;margin-bottom:4px}
.error-log-message{color:var(--text2);font-weight:500;margin-bottom:6px;line-height:1.4}
.error-log-details{color:var(--text4);font-family:'SF Mono', Menlo, monospace;font-size:11px;background:var(--surface2);border-radius:4px;padding:6px 8px;max-height:120px;overflow-y:auto;white-space:pre-wrap;word-break:break-all;line-height:1.5;display:none}
.error-log-details.open{display:block}
.error-log-expand{color:var(--text3);font-size:11px;cursor:pointer;text-decoration:underline;text-decoration-style:dotted}
.danger-row{background:var(--surface);border:0.5px solid rgba(255,59,48,.15);border-radius:var(--r-md);padding:11px 13px;display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.danger-row:active{background:rgba(255,59,48,.04)}
.danger-label{font-size:13px;color:var(--danger);font-weight:500}
.settings-version{font-size:10px;color:var(--text4);text-align:center;margin-top:16px}
.admin-email-row{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:0.5px solid var(--border2);font-size:12px}
.admin-email-row:last-child{border-bottom:0}
.admin-email-addr{flex:1;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-badge{font-size:10px;padding:2px 6px;border-radius:10px;font-weight:500;flex-shrink:0}
.admin-badge.disabled{background:rgba(255,59,48,.08);color:var(--danger);border:0.5px solid rgba(255,59,48,.2)}
.admin-badge.admin{background:rgba(52,199,89,.08);color:var(--success);border:0.5px solid rgba(52,199,89,.2)}
.admin-btn{flex-shrink:0;background:transparent;border:0.5px solid var(--border2);border-radius:4px;padding:3px 8px;font-size:11px;cursor:pointer;color:var(--text3);font-family:var(--font)}
.admin-btn:hover{background:var(--surface2)}
.admin-btn.danger{color:var(--danger);border-color:rgba(255,59,48,.3)}
.admin-btn.danger:hover{background:rgba(255,59,48,.06)}
.admin-error-row{padding:8px 10px;border-bottom:0.5px solid var(--border2);font-size:11px}
.admin-error-row:last-child{border-bottom:0}
.admin-error-meta{display:flex;justify-content:space-between;color:var(--text4);margin-bottom:3px}
.admin-error-msg{color:var(--text2);line-height:1.4}

/* ════════════════════════════════
   SHARED COMPONENTS
════════════════════════════════ */
/* Toast */
.toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%);background:var(--text);color:#fff;border-radius:20px;padding:9px 16px;font-size:12px;font-weight:500;z-index:200;pointer-events:none;opacity:0;transition:opacity .25s;white-space:nowrap;max-width:90vw;text-align:center;overflow:hidden;text-overflow:ellipsis}
.toast.success{background:var(--success)}
.toast.error{background:var(--danger)}
.toast.warn{background:var(--warn)}
.toast.info{background:var(--info)}
.toast.show{opacity:1}

/* Confirm dialog */
.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:none;align-items:center;justify-content:center;padding:20px}
.confirm-overlay.open{display:flex}
.confirm-box{background:var(--surface);border-radius:18px;padding:22px 20px;width:100%;max-width:320px;border:0.5px solid var(--border)}
.confirm-title{font-size:16px;font-weight:700;margin-bottom:8px;letter-spacing:-0.3px}
.confirm-msg{font-size:13px;color:var(--text3);line-height:1.6;margin-bottom:22px}
.confirm-actions{display:flex;gap:8px}
.confirm-btn{flex:1;padding:13px;border-radius:var(--r-md);border:none;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}
.confirm-btn:active{opacity:.75}
.confirm-cancel{background:var(--surface2);color:var(--text2)}
.confirm-ok{background:var(--danger);color:#fff}

/* Title input modal */
.title-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none;align-items:flex-end;justify-content:center}
.title-overlay.open{display:flex}

/* 녹음 중 플로팅 복귀 버튼 (모든 화면 공통) */
.floating-overlay-btn{
  position:fixed; bottom:90px; right:16px; z-index:60;
  width:56px; height:56px; border-radius:50%;
  background:#000; color:#fff;
  display:none; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,0.3);
  cursor:pointer; border:0;
  font-family:var(--font);
}
.floating-overlay-btn.show{display:flex}
.floating-overlay-btn .floating-dot{
  position:absolute; top:8px; right:8px;
  width:10px; height:10px; border-radius:50%;
  background:#ff3b30; animation:pulse 1.5s infinite;
}
.floating-overlay-btn .floating-label{
  position:absolute; bottom:-22px; left:50%; transform:translateX(-50%);
  font-size:10px; color:var(--text2); white-space:nowrap;
}
@keyframes pulse{
  0%,100%{opacity:1; transform:scale(1)}
  50%{opacity:0.5; transform:scale(1.2)}
}
.title-box{background:var(--surface);border-radius:22px 22px 0 0;padding:20px 20px 24px;width:100%;max-width:430px;transition:transform .2s}
.title-handle{width:36px;height:4px;background:var(--border2);border-radius:2px;margin:0 auto 16px}
.title-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px}
.title-input{width:100%;background:var(--surface2);border:0.5px solid var(--border2);border-radius:var(--r-md);padding:12px 14px;color:var(--text);font-family:var(--font);font-size:14px;outline:none}
.title-input:focus{border-color:var(--text2)}
.title-actions{display:flex;gap:7px;margin-top:12px}
.title-cancel{flex:1;padding:12px;border-radius:var(--r-md);border:0.5px solid var(--border2);background:var(--surface2);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;color:var(--text2)}
.mode-btn{padding:8px 12px;border-radius:var(--r-sm);border:0.5px solid var(--border2);background:var(--surface2);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;color:var(--text2);transition:all 0.15s}
.mode-btn.active{background:var(--text1);color:var(--surface1);border-color:var(--text1)}
.title-confirm{flex:1;padding:12px;border-radius:var(--r-md);border:none;background:var(--text);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;color:#fff}
