*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f0e8;
  --ink:#2d2640;
  --muted:#8a8295;
  --soft:#b5aec3;
  --card:#ffffff;
  --line:rgba(107,92,165,.14);
  --accent:#6b5ca5;
  --accent-2:#8b7fc7;
  --green:#5dae8b;
  --blue:#4a90b8;
  --amber:#d4a843;
  --danger:#e85d5d;
  --shadow:0 8px 28px rgba(45,38,64,.08);
}
body{
  height:100dvh;
  font-family:"DM Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--bg);
  color:var(--ink);
  overflow:hidden;
}
button,input,textarea{font:inherit}
button{-webkit-tap-highlight-color:transparent}
.app-shell{height:100dvh;display:flex;flex-direction:column;width:100%;background:var(--bg)}
.topbar{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.brand h1{font-family:Georgia,"Times New Roman",serif;font-size:22px;font-weight:400;line-height:1;color:#3d3552}
.brand span{display:block;margin-top:-2px;font-size:11px;color:var(--muted);font-style:italic;letter-spacing:.5px}
.top-actions{display:flex;align-items:center;gap:8px}
.icon-btn{width:36px;height:36px;border:0;border-radius:11px;background:var(--card);color:var(--muted);display:grid;place-items:center;box-shadow:0 1px 3px rgba(0,0,0,.04);cursor:pointer}
.icon-btn:active{transform:scale(.96)}
.library-only{display:none}
.main{position:relative;flex:1;overflow:hidden}
.panel{position:absolute;inset:0;display:none;overflow:auto;padding:0 0 98px;-webkit-overflow-scrolling:touch}
.panel.active{display:block}
.screen{min-height:100%;display:none;flex-direction:column;align-items:center;justify-content:center;max-width:430px;margin:0 auto}
.screen.active{display:flex}
.screen h2,.library-head h2,.drawer-head h2{font-family:Georgia,"Times New Roman",serif;font-size:30px;font-weight:400;line-height:1.16;text-align:center;color:#3d3552}
.screen p{margin:10px 0 32px;color:var(--muted);font-size:15px;text-align:center;line-height:1.45}
.trial-banner{width:100%;margin:0 0 18px;padding:12px 14px;border:1px solid rgba(232,93,93,.18);border-radius:12px;background:rgba(232,93,93,.08);color:var(--danger);font-size:13px;line-height:1.45;text-align:left}
.mode-list{width:100%;display:flex;flex-direction:column;gap:12px}
.choice{width:100%;border:0;border-radius:14px;background:var(--card);padding:18px;display:flex;gap:15px;align-items:center;text-align:left;box-shadow:0 1px 4px rgba(0,0,0,.04);cursor:pointer}
.choice:active{transform:scale(.985)}
.choice-icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.purple{background:linear-gradient(135deg,var(--accent),var(--accent-2))}
.green{background:linear-gradient(135deg,var(--green),#7dc2a0)}
.blue{background:linear-gradient(135deg,var(--blue),#76aeca)}
.amber{background:linear-gradient(135deg,var(--amber),#dbbb63)}
.choice strong{display:block;font-size:15px;margin-bottom:3px}
.choice small{display:block;color:var(--muted);font-size:13px;line-height:1.35}
.back{margin-top:24px;border:0;background:transparent;color:var(--muted);display:inline-flex;gap:7px;align-items:center;cursor:pointer}
.session-screen{justify-content:flex-start;padding-top:16px}
.prompt{width:100%;background:var(--card);border-radius:18px;padding:22px 24px;text-align:center;font-size:17px;line-height:1.55;box-shadow:var(--shadow);margin:8px 0 26px;position:relative}
.prompt:after{content:"";position:absolute;left:50%;bottom:-10px;width:18px;height:10px;transform:translateX(-50%);background:var(--card);clip-path:polygon(0 0,100% 0,50% 100%)}
.wave{height:24px;display:flex;align-items:center;justify-content:center;gap:3px;margin-bottom:10px}
.bar{width:3px;height:5px;border-radius:2px;background:var(--danger);opacity:.28;transition:height .08s}
.status{font-size:13px;color:var(--muted);min-height:18px;margin-bottom:10px}
.status.rec{color:var(--danger);font-weight:600}
.meter{width:min(260px,80vw);height:8px;border-radius:999px;background:rgba(107,92,165,.12);overflow:hidden;margin-bottom:18px}
.meter span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--green),var(--amber),var(--danger));transition:width .08s}
.mic{width:86px;height:86px;border:0;border-radius:50%;background:linear-gradient(145deg,var(--accent),var(--accent-2));color:#fff;font-size:30px;display:grid;place-items:center;box-shadow:0 8px 30px rgba(107,92,165,.25);cursor:pointer;margin-bottom:22px}
.mic.recording{background:linear-gradient(145deg,var(--danger),#ef7777);animation:pulse 1.4s infinite}
@keyframes pulse{50%{transform:scale(1.05)}}
textarea{width:100%;resize:vertical;min-height:132px;border:1.5px solid var(--line);border-radius:14px;background:var(--card);padding:14px 15px;color:var(--ink);outline:none;line-height:1.5}
textarea:focus,input:focus{border-color:var(--accent-2)}
.session-buttons{width:100%;display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.pill,.small-btn,.full-btn{border:1px solid var(--line);border-radius:999px;background:var(--card);color:var(--muted);padding:10px 14px;display:inline-flex;gap:7px;align-items:center;justify-content:center;cursor:pointer}
.pill.primary,.full-btn{background:var(--accent);border-color:var(--accent);color:#fff}
.pill.danger{border-color:rgba(196,77,77,.35);color:var(--danger)}
.library-head{padding:0 20px;margin-bottom:16px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.library-head>div{display:flex;align-items:baseline;gap:16px;min-width:0}
.library-head h2{text-align:left;font-size:22px;font-family:Georgia,"Times New Roman",serif;font-weight:400;color:#3d3552;white-space:nowrap}
.library-head p{font-size:12px;color:var(--soft);margin:0}
.storage-card{background:rgba(255,255,255,.72);border:1px solid rgba(139,127,199,.08);border-radius:12px;padding:10px 12px;margin:0 16px 14px;box-shadow:0 1px 2px rgba(0,0,0,.02)}
.storage-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;color:var(--muted);margin-bottom:7px}
.storage-row.sync-row{margin-top:8px}
.storage-row.plan-row{margin-top:8px}
.storage-row.sync-status-row{margin:7px 0 0}
.storage-row span{display:inline-flex;align-items:center;gap:7px}.storage-row strong{color:var(--ink);font-size:12px;white-space:nowrap}
.info-dot{width:18px;height:18px;border-radius:50%;border:1px solid rgba(107,92,165,.2);background:#fff;color:var(--accent);display:inline-grid;place-items:center;font-size:10px;cursor:pointer;padding:0}
.info-dot:active{transform:scale(.94)}
.storage-track{height:7px;border-radius:999px;background:rgba(107,92,165,.12);overflow:hidden}.storage-track span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--green),var(--amber),var(--danger));transition:width .2s}
.storage-card p{font-size:11px;line-height:1.45;color:var(--muted);margin-top:8px}
.segment{padding:0 20px;display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:14px}
.segment button{border:0;background:transparent;color:var(--soft);padding:9px 3px;margin-right:16px;border-bottom:2px solid transparent;cursor:pointer}
.segment button.active{color:var(--accent);border-bottom-color:var(--accent)}
.lib-tabs{padding:0 20px;display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:14px}
.lib-tabs button{border:0;background:transparent;color:var(--soft);padding:10px 3px;margin-right:20px;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;font-size:14px}
.lib-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}
.lib-view{display:none}
.lib-view.active{display:block}
.organize-hint{margin:0 16px 12px;padding:8px 12px;border-radius:10px;background:rgba(107,92,165,.06);color:var(--accent);font-size:12px;display:flex;align-items:center;gap:8px}
.breadcrumb{padding:0 20px;margin-bottom:6px;font-size:13px;color:var(--soft)}
.breadcrumb a{color:var(--accent);text-decoration:none;cursor:pointer}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .sep{margin:0 6px;color:var(--soft)}
.folder-title{padding:0 20px;margin:4px 0 16px;font-family:Georgia,"Times New Roman",serif;font-size:24px;font-weight:400;color:#3d3552}
.folder-list{padding:0 16px;display:flex;flex-direction:column;gap:8px}
.folder-item{border:0;border-radius:12px;background:var(--card);padding:14px 18px;text-align:left;box-shadow:0 1px 2px rgba(0,0,0,.03);cursor:pointer;display:flex;align-items:center;gap:14px;width:100%;transition:transform .15s,box-shadow .15s}
.folder-item:hover{transform:translateX(4px);box-shadow:0 3px 10px rgba(0,0,0,.05)}
.folder-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:15px;flex:0 0 auto}
.folder-icon.purple{background:rgba(107,92,165,.1);color:var(--accent)}
.folder-icon.amber{background:rgba(212,168,67,.12);color:var(--amber)}
.folder-icon.green{background:rgba(93,174,139,.1);color:var(--green)}
.folder-icon.blue{background:rgba(74,144,184,.1);color:var(--blue)}
.folder-icon.rose{background:rgba(199,91,142,.1);color:#c75b8e}
.folder-icon.gold{background:rgba(212,168,67,.12);color:#b88a2a}
.folder-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.folder-name{font-weight:600;font-size:15px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.folder-meta{font-size:12px;color:var(--soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.folder-count{font-size:12px;color:var(--soft);flex-shrink:0;white-space:nowrap}
.folder-arrow{color:var(--soft);font-size:12px;flex-shrink:0}
.doc-list{padding:0 16px;display:flex;flex-direction:column;gap:8px}
.doc-item{border:0;border-radius:10px;background:var(--card);padding:14px 18px;text-align:left;box-shadow:0 1px 2px rgba(0,0,0,.02);cursor:pointer;display:flex;flex-direction:column;gap:4px;width:100%;transition:transform .15s,box-shadow .15s}
.doc-item:hover{transform:translateX(4px);box-shadow:0 3px 10px rgba(0,0,0,.05)}
.doc-head{display:flex;align-items:center;gap:10px;min-width:0}
.doc-icon{font-size:14px;color:var(--soft);flex-shrink:0}
.doc-title{flex:1;min-width:0;font-weight:600;font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.doc-updated{font-size:11px;color:var(--soft);white-space:nowrap;margin-left:auto}
.doc-preview{font-size:13px;line-height:1.5;color:var(--muted);padding-left:24px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.empty-inline{padding:24px 18px}
.empty{text-align:center;color:var(--muted);padding:46px 18px;display:none}
.empty h3{font-family:Georgia,"Times New Roman",serif;color:#3d3552;font-weight:400;font-size:22px;margin-bottom:8px}
.empty p{max-width:340px;margin:0 auto;font-size:14px;line-height:1.55}
.capture-list{padding:0 16px;display:flex;flex-direction:column;gap:8px}
.capture-item{border:0;border-radius:12px;background:var(--card);padding:14px 18px;text-align:left;box-shadow:0 1px 2px rgba(0,0,0,.03);cursor:pointer;display:flex;flex-direction:column;gap:4px;width:100%;transition:transform .15s,box-shadow .15s}
.capture-item:hover{transform:translateX(4px);box-shadow:0 3px 10px rgba(0,0,0,.05)}
.capture-head{display:flex;align-items:center;gap:10px;min-width:0}
.capture-type{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:15px;flex:0 0 auto}
.capture-type.purple{background:rgba(107,92,165,.1);color:var(--accent)}
.capture-type.green{background:rgba(93,174,139,.1);color:var(--green)}
.capture-type.blue{background:rgba(74,144,184,.1);color:var(--blue)}
.capture-type.amber{background:rgba(212,168,67,.12);color:var(--amber)}
.capture-title{flex:1;min-width:0;font-weight:600;font-size:15px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink)}
.capture-date{font-size:11px;color:var(--soft);white-space:nowrap;margin-left:auto}
.capture-preview{font-size:13px;line-height:1.5;color:var(--muted);padding-left:46px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sync-chip{border:1px solid rgba(93,174,139,.28);border-radius:999px;color:var(--green);padding:3px 8px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;font-size:11px;opacity:.72;transition:opacity .15s}
.capture-item:hover .sync-chip{opacity:1}
.sync-chip.active{background:rgba(93,174,139,.13);font-weight:600;opacity:1}
.tabs{height:68px;padding:6px 0 max(6px,env(safe-area-inset-bottom));background:var(--card);border-top:1px solid var(--line);display:flex;flex-shrink:0}
.tabs button{flex:1;border:0;background:transparent;color:var(--soft);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer}
.tabs i{font-size:20px}.tabs span{font-size:10px;font-weight:600}.tabs button.active{color:var(--accent)}
.drawer,.search{position:fixed;inset:0;background:rgba(45,38,64,.48);backdrop-filter:blur(8px);z-index:20;display:none;padding:18px;align-items:flex-end;justify-content:center}
.drawer.open,.search.open{display:flex}
.drawer-card,.search-card{width:100%;max-width:460px;background:var(--card);border-radius:18px;padding:18px;box-shadow:0 18px 60px rgba(0,0,0,.2)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.drawer-head h2{text-align:left;font-size:26px}
.field{display:block;margin-bottom:13px}.field span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:700}
.field input,.search input{width:100%;border:1.5px solid var(--line);border-radius:12px;background:#fff;padding:12px 13px;color:var(--ink);outline:none}
.toggle{display:flex;gap:10px;align-items:flex-start;margin:12px 0 18px;color:var(--muted);font-size:13px;line-height:1.4}.toggle input{margin-top:2px;accent-color:var(--accent)}
.cloud-note{border:1px solid var(--line);border-radius:12px;background:rgba(107,92,165,.06);padding:11px 12px;margin:4px 0 13px;font-size:12px;line-height:1.45;color:var(--muted)}.cloud-note strong{display:block;color:var(--ink);margin-bottom:2px}
.full-btn{width:100%;border-radius:14px;padding:13px}
.search{align-items:flex-start;padding-top:58px}.search-card{padding:7px}.search input{border:0;background:transparent;font-size:16px}
#searchResults{border-top:1px solid var(--line);margin-top:4px;max-height:55dvh;overflow:auto}.result{padding:12px;border-radius:10px;cursor:pointer}.result:hover{background:rgba(107,92,165,.07)}
.detail-title{padding:0 20px;margin:4px 0 8px;font-family:Georgia,"Times New Roman",serif;font-size:28px;font-weight:400;line-height:1.15;color:#3d3552}
.detail-meta{padding:0 20px;font-size:12px;color:var(--soft);margin-bottom:16px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.detail-body{padding:0 20px}
.detail-body .detail-text{white-space:pre-wrap;font-size:15px;line-height:1.7;color:var(--ink)}
.audio-block{background:rgba(245,240,232,.6);border-radius:12px;padding:12px 14px;margin:18px 0;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.audio-block audio{width:100%;display:block}
.detail-actions{padding:18px 20px 8px;display:flex;gap:8px;margin-top:18px;border-top:1px solid rgba(139,127,199,.1);flex-wrap:wrap}
.toast{position:fixed;left:50%;bottom:86px;transform:translateX(-50%) translateY(8px);background:#3d3552;color:#fff;border-radius:999px;padding:10px 16px;font-size:13px;opacity:0;pointer-events:none;transition:.2s;z-index:40}.toast.show{opacity:1;transform:translateX(-50%)}
@media(min-width:760px){
  .session-screen{padding-top:34px}
}
@media(max-width:640px){
  .library-head{align-items:flex-start;padding:0 16px}
  .library-head>div{display:block}
  .library-head p{margin-top:3px}
  .segment{padding:0 16px}
  .capture-list{padding:0 12px}
  .storage-card{padding:12px}
  .storage-row{align-items:flex-start}
  .capture-item{padding:13px 14px}
  .capture-preview{padding-left:0}
}
@media(max-width:420px){
  .capture-head .sync-chip{display:none}
}
@media(max-width:390px){
  .topbar{padding-left:14px;padding-right:14px}.brand h1{font-size:20px}.icon-btn{width:35px;height:35px}
  .screen h2{font-size:26px}.choice{padding:15px}.choice-icon{width:42px;height:42px}.mic{width:78px;height:78px}
  .session-buttons{justify-content:stretch}.pill{flex:1;padding-left:10px;padding-right:10px}
}

/* Sign-in prompt banner (Option B soft gate) */
.signin-prompt{display:flex;align-items:center;gap:14px;margin:0 16px 14px;padding:14px 16px;border-radius:14px;background:linear-gradient(135deg,rgba(107,92,165,.10),rgba(139,127,199,.06));border:1px solid rgba(107,92,165,.22);box-shadow:0 4px 14px rgba(107,92,165,.06)}
.signin-prompt-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;font-size:13px;line-height:1.4;color:var(--ink)}
.signin-prompt-text strong{color:var(--accent);font-size:14px}
.signin-prompt-text span{color:var(--muted)}
.signin-prompt-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.signin-prompt-dismiss{width:30px;height:30px;border-radius:50%;border:0;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;font-size:13px}
.signin-prompt-dismiss:hover{background:rgba(107,92,165,.08);color:var(--accent)}
.empty.signed-out{padding:32px 24px;border:1px dashed rgba(107,92,165,.30);background:rgba(107,92,165,.04);border-radius:14px;margin:8px 16px}
.empty.signed-out h3{color:var(--accent);margin-bottom:6px}
.empty.signed-out p{color:var(--muted);margin-bottom:14px;font-size:14px;line-height:1.5}
.empty.signed-out .pill{display:inline-flex;align-items:center;gap:8px}
@media(max-width:480px){
  .signin-prompt{flex-direction:column;align-items:stretch;text-align:center;gap:10px}
  .signin-prompt-actions{justify-content:center}
}

/* Signed-in user avatar in topbar */
.auth-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:13px;font-weight:600;display:grid;place-items:center;letter-spacing:.5px}
.icon-btn.auth-signed-in{padding:0;border-color:transparent;background:transparent;box-shadow:none}
.icon-btn.auth-signed-in:hover{background:rgba(107,92,165,.08)}
