:root {
  --bg: #08090d;
  --surface: #111318;
  --surface2: #191c24;
  --border: #252830;
  --text: #e4e4ec;
  --muted: #6c6f7e;
  --accent: #646cff;
  --accent-dim: rgba(100,108,255,0.15);
  --pink: #ec4899;
  --green: #10b981;
  --yellow: #eab308;
  --red: #ef4444;
  --blue: #3b82f6;
  --purple: #a78bfa;
}
/* Light theme overrides */
[data-theme="light"] {
  --bg: #f5f5f7;
  --surface: #ffffff;
  --surface2: #eeeef0;
  --border: #d4d4d8;
  --text: #18181b;
  --muted: #71717a;
  --accent: #4f46e5;
  --accent-dim: rgba(79,70,229,0.1);
}
[data-theme="light"] .gate-box{box-shadow:0 20px 60px rgba(0,0,0,0.08);}
[data-theme="light"] #gate{background:radial-gradient(ellipse at 50% 40%,rgba(79,70,229,0.04),transparent 60%);}

*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-text-size-adjust:100%;}
::selection{background:var(--accent);color:#fff;}
input,select,button{font-family:inherit;}

/* ===== GATE ===== */
#gate{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:radial-gradient(ellipse at 50% 40%,rgba(100,108,255,0.06),transparent 60%);}
.gate-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 40px;max-width:380px;width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,0.4);}
.gate-box .logo{font-size:3rem;margin-bottom:4px;}
.gate-box h1{font-size:1.2rem;font-weight:600;margin-bottom:4px;letter-spacing:-0.3px;}
.gate-box .subtitle{color:var(--muted);margin-bottom:28px;font-size:0.82rem;}
.gate-box input{width:100%;padding:11px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.92rem;margin-bottom:10px;outline:none;transition:border-color 0.2s;}
.gate-box input:focus{border-color:var(--accent);}
.gate-box .btn-primary{width:100%;padding:11px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:0.92rem;font-weight:600;cursor:pointer;transition:opacity 0.2s;margin-top:4px;margin-bottom:6px;}
.gate-box .btn-primary:hover{opacity:0.85;}
.gate-box .error{color:var(--red);font-size:0.82rem;margin-top:6px;min-height:18px;}
.gate-box .hint{font-size:0.8rem;color:var(--muted);margin-bottom:16px;line-height:1.4;}

/* Stay Connected Checkbox */
.stay-connected-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:0.82rem;color:var(--muted);margin:10px 0 4px;justify-content:center;user-select:none;}
.stay-connected-label input[type="checkbox"]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;margin:0;}
.stay-connected-label span{transition:color 0.2s;}
.stay-connected-label:hover span{color:var(--text);}

/* ===== APP LAYOUT ===== */
#app{display:none;min-height:100vh;}
#app.active{display:flex;flex-direction:column;}
.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 8px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
.app-header h1{font-size:1.15rem;font-weight:600;display:flex;align-items:center;gap:8px;letter-spacing:-0.3px;}
.header-actions{display:flex;gap:6px;align-items:center;}
.btn{padding:7px 14px;border-radius:7px;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;font-size:0.82rem;font-weight:500;transition:all 0.2s;}
.btn:hover{border-color:var(--accent);color:var(--accent);}
.btn-disconnect{opacity:0.5;transition:opacity 0.2s,border-color 0.2s,color 0.2s;}
.btn-disconnect:hover{opacity:1;border-color:var(--red);color:var(--red);}
.btn-active{border-color:var(--accent);background:var(--accent);color:#fff;}
.btn-active:hover{opacity:0.85;background:var(--accent);color:#fff;}

/* ===== STATS ===== */
.stats-bar{display:flex;gap:32px;padding:16px 8px;background:var(--surface);border-bottom:1px solid var(--border);}
.stat{display:flex;flex-direction:column;}
.stat-value{font-size:1.6rem;font-weight:700;letter-spacing:-0.5px;}
.stat-value.blue{color:var(--blue);}
.stat-value.yellow{color:var(--yellow);}
.stat-value.purple{color:var(--purple);}
.stat-label{font-size:0.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.6px;margin-top:2px;}

/* ===== LEGEND ===== */
.legend{display:flex;gap:18px;padding:10px 8px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.legend-item{display:flex;align-items:center;gap:5px;font-size:0.72rem;color:var(--muted);}

/* ===== MAIN CONTENT ===== */
.main-content{padding:1rem;margin:0 auto;flex:1;}
.project-title-copy{cursor:pointer;position:relative;display:inline-block;}
.project-title-copy:hover{color:var(--accent);}
.copy-tooltip{position:absolute;top:-26px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:0.68rem;padding:3px 8px;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity 0.3s;font-weight:500;}
.copy-tooltip.show{opacity:1;}

/* ===== STATUS DOT ===== */
.status-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;display:inline-block;}
.status-dot.todo{background:var(--muted);}
.status-dot.in-progress{background:var(--blue);box-shadow:0 0 8px rgba(59,130,246,0.5);}
.status-dot.review{background:var(--yellow);box-shadow:0 0 8px rgba(234,179,8,0.4);}
.status-dot.approved{background:var(--green);}
.status-dot.revision{background:var(--red);box-shadow:0 0 6px rgba(239,68,68,0.4);}

/* ===== IDEAS SECTION ===== */
.ideas-section{margin-bottom:28px;}
.section-title{font-size:1rem;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px;letter-spacing:-0.2px;}
.idea-form{display:flex;gap:8px;margin-bottom:14px;}
.idea-form input{flex:1;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.88rem;outline:none;transition:border-color 0.2s;}
.idea-form input:focus{border-color:var(--accent);}
.idea-form select{padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-size:0.82rem;outline:none;min-width:130px;}
.idea-form select:focus{border-color:var(--accent);}
.idea-form button{padding:10px 18px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;white-space:nowrap;font-size:0.88rem;transition:opacity 0.2s;}
.idea-form button:hover{opacity:0.85;}
.idea-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;transition:border-color 0.2s;}
.idea-item:hover{border-color:var(--accent-dim);}
.idea-text{flex:1;font-size:0.88rem;}
.idea-project{font-size:0.72rem;padding:3px 8px;border-radius:5px;background:var(--surface2);white-space:nowrap;}
.idea-actions{display:flex;gap:3px;}
.idea-actions button{padding:5px 9px;border-radius:5px;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;font-size:0.78rem;transition:all 0.2s;white-space:nowrap;}
.idea-actions .ship-btn:hover{border-color:var(--accent);color:var(--accent);}
.idea-actions .plan-btn:hover{border-color:var(--yellow);color:var(--yellow);}
.idea-actions .del-btn:hover{border-color:var(--red);color:var(--red);}
.empty-msg{color:var(--muted);font-size:0.82rem;font-style:italic;padding:8px 0;}

/* ===== PROJECT GRID ===== */
.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:14px;}
.project-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow 0.2s;}
.project-card[draggable="true"]{cursor:default;}
.project-card.dragging{opacity:0.4;border:2px dashed var(--accent);}
.project-card.drag-over{box-shadow:0 0 0 2px var(--accent);border-color:var(--accent);}
.project-drag-handle{cursor:grab;color:var(--muted);font-size:0.82rem;user-select:none;padding:2px 4px;border-radius:4px;transition:color 0.2s, opacity 0.2s;opacity:0;}
.project-drag-handle:active{cursor:grabbing;}
.project-drag-handle:hover{color:var(--text);}
.project-card-header:hover .project-drag-handle{opacity:1;}
.project-accent{height:3px;width:100%;}
.project-card-header{padding:14px 16px 10px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.project-info h3{font-size:0.95rem;font-weight:600;margin-bottom:2px;letter-spacing:-0.2px;}
.project-info .tech{font-size:0.72rem;color:var(--muted);}
.project-link{color:var(--muted);text-decoration:none;font-size:0.78rem;white-space:nowrap;flex-shrink:0;}
.project-link:hover{color:var(--accent);}

/* ===== TASK LIST ===== */
.task-list{padding:4px 16px;flex:1;min-height:50px;max-height:var(--task-list-max-height, 400px);overflow-y:auto;transition:max-height 0.3s ease;}
.task-item{padding:9px 0;border-bottom:1px solid var(--border);}
.task-item:last-child{border-bottom:none;}
.task-row{display:flex;align-items:center;gap:9px;}
.task-text{flex:1;font-size:0.88rem;line-height:1.35;}
.task-actions{display:none;gap:2px;}
.task-item:hover .task-actions{display:inline-flex;}
.task-actions button{background:none;border:none;cursor:pointer;font-size:0.82rem;padding:3px 5px;border-radius:4px;transition:background 0.15s;}
.task-actions button:hover{background:var(--surface2);}
.task-meta{margin-top:5px;padding-left:18px;display:flex;flex-direction:column;gap:3px;}
.task-meta-item{font-size:0.78rem;color:var(--muted);padding:5px 9px;background:var(--bg);border-radius:5px;border-left:2px solid var(--accent);line-height:1.4;}
.task-meta-item.response{border-left-color:var(--yellow);}
.task-meta-item a{color:var(--accent);text-decoration:underline;word-break:break-all;}
.task-meta-label{font-weight:600;margin-right:5px;}
.task-meta-label.plan{color:var(--accent);}
.task-meta-label.claw{color:var(--yellow);}

/* ===== ADD TASK ===== */
.add-task{display:flex;gap:6px;padding:8px 16px 14px;align-items:flex-end;}
.add-task textarea{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:0.84rem;outline:none;transition:border-color 0.2s;font-family:inherit;line-height:1.4;}
.add-task textarea:focus{border-color:var(--accent);}
.add-task button{padding:8px 14px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:0.84rem;transition:opacity 0.2s;}
.add-task button:hover{opacity:0.85;}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:20px;right:20px;padding:11px 20px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:0.84rem;z-index:999;opacity:0;transform:translateY(8px);transition:all 0.3s;pointer-events:none;}
.toast.show{opacity:1;transform:translateY(0);}
.toast.success{border-color:var(--green);color:var(--green);}
.toast.error{border-color:var(--red);color:var(--red);}
.toast.info{border-color:var(--blue);color:var(--blue);}

/* ===== SHOW MORE ===== */
.show-more-btn{background:none;border:none;color:var(--accent);font-size:0.72rem;cursor:pointer;padding:2px 0;font-weight:500;}
.show-more-btn:hover{text-decoration:underline;}

/* ===== CHAR COUNTER ===== */
.char-counter{font-size:0.68rem;color:var(--muted);text-align:right;margin-top:-6px;margin-bottom:4px;padding-right:4px;}
.char-counter.warn{color:var(--yellow);}
.char-counter.danger{color:var(--red);}

/* ===== DRAG & DROP ===== */
.task-item.dragging{opacity:0.4;border:1px dashed var(--accent);}
.task-item.drag-over{border-top:2px solid var(--accent);padding-top:7px;}
.drag-handle{cursor:grab;color:var(--muted);font-size:0.72rem;margin-right:2px;user-select:none;}
.drag-handle:active{cursor:grabbing;}

/* ===== ARCHIVE ===== */
.archive-toggle{display:flex;align-items:center;gap:6px;padding:6px 16px;cursor:pointer;font-size:0.78rem;color:var(--muted);user-select:none;border-top:1px solid var(--border);transition:color 0.2s;}
.archive-toggle:hover{color:var(--text);}
.archive-toggle .arrow{transition:transform 0.2s;display:inline-block;}
.archive-toggle .arrow.open{transform:rotate(90deg);}
.archived-tasks{display:none;padding:0 16px 8px;}
.archived-tasks.visible{display:block;}
.archived-tasks .task-item{opacity:0.6;}
.project-card-header .project-header-actions{display:flex;align-items:center;gap:6px;opacity:0;transition:opacity 0.2s;}
.project-card-header:hover .project-header-actions{opacity:1;}
.project-card.expanded .project-header-actions{opacity:1;}
.project-card-header .archive-project-btn{background:none;border:none;cursor:pointer;font-size:0.72rem;color:var(--muted);padding:2px 6px;border-radius:4px;transition:all 0.2s;}
.project-card-header .archive-project-btn:hover{color:var(--red);background:var(--surface2);}
.project-card-header .prompt-project-btn{background:none;border:none;cursor:pointer;font-size:0.72rem;color:var(--muted);padding:2px 6px;border-radius:4px;transition:all 0.2s;}
.project-card-header .prompt-project-btn:hover{color:var(--accent);background:var(--surface2);}
.archived-projects-section{margin-top:20px;}
.archived-project-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;opacity:0.6;}
.archived-project-item span{flex:1;font-size:0.88rem;}
.archived-project-item button{padding:4px 10px;border-radius:5px;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;font-size:0.78rem;}
.archived-project-item button:hover{border-color:var(--accent);color:var(--accent);}
.archived-project-item button[style*="color:var(--red)"]:hover{border-color:var(--red);}

/* ===== FOOTER STATS ===== */
.footer-stats{padding:12px;border-top:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:0.72rem;color:var(--muted);margin-top:auto;}
.footer-stats a{color:var(--accent);text-decoration:none;}
.footer-stats a:hover{text-decoration:underline;}
.footer-stats .db-stats{display:flex;gap:16px;}
.footer-stats .db-stat{display:flex;align-items:center;gap:4px;}

/* ===== REVISION FEEDBACK MODAL ===== */
.revision-modal{max-width:480px;}
.revision-modal h2{font-size:1rem;margin-bottom:12px;}
.revision-modal textarea{width:100%;min-height:100px;padding:10px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.88rem;font-family:inherit;resize:vertical;outline:none;margin-bottom:12px;}
.revision-modal textarea:focus{border-color:var(--accent);}

/* ===== PROMPT EDITOR MODAL ===== */
.prompt-modal{max-width:560px;}
.prompt-modal h2{font-size:1rem;margin-bottom:8px;}
.prompt-modal .prompt-hint{font-size:0.78rem;color:var(--muted);margin-bottom:12px;line-height:1.4;}
.prompt-modal textarea{width:100%;min-height:180px;padding:10px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.85rem;font-family:'Inter',system-ui,monospace;resize:vertical;outline:none;margin-bottom:12px;line-height:1.5;}
.prompt-modal textarea:focus{border-color:var(--accent);}

/* ===== ADD PROJECT MODAL ===== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;align-items:center;justify-content:center;}
.modal-overlay.visible{display:flex;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px;max-width:440px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,0.4);max-height:85vh;overflow-y:auto;}

/* ===== EXPANDED TASK MODAL (kept for backward compat) ===== */
.task-modal{max-width:640px;}
.task-modal h2{font-size:1.1rem;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.task-modal .task-full-text{font-size:0.95rem;line-height:1.5;padding:12px;background:var(--bg);border-radius:8px;border:1px solid var(--border);margin-bottom:12px;}
.task-modal .task-full-meta{margin-bottom:12px;}
.task-modal .task-full-meta-item{font-size:0.88rem;color:var(--muted);padding:10px 12px;background:var(--bg);border-radius:8px;border-left:3px solid var(--accent);line-height:1.5;margin-bottom:8px;word-break:break-word;}
.task-modal .task-full-meta-item a{color:var(--accent);text-decoration:underline;}
.task-modal .task-full-meta-item.response{border-left-color:var(--yellow);}

/* ===== PROJECT EXPAND (inline) ===== */
.project-card{transition:all 0.35s cubic-bezier(0.4,0,0.2,1);}
.project-card.expanded{grid-column:1/-1;box-shadow:0 0 0 2px var(--accent), 0 8px 32px rgba(100,108,255,0.12);z-index:10;transition:all 0.3s ease;}
.project-card.expanded .task-list{max-height:none;overflow-y:visible;}
.project-card.expanded .task-meta-item{white-space:pre-wrap;}
.expand-project-btn{background:none;border:none;cursor:pointer;font-size:0.78rem;color:var(--muted);padding:2px 6px;border-radius:4px;transition:all 0.2s;display:inline-flex;align-items:center;justify-content:center;}
.expand-project-btn:hover{color:var(--accent);background:var(--surface2);}
.modal h2{font-size:1rem;font-weight:600;margin-bottom:16px;}
.modal label{display:block;font-size:0.78rem;color:var(--muted);margin-bottom:4px;margin-top:10px;}
.modal input{width:100%;padding:9px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:0.86rem;outline:none;}
.modal input:focus{border-color:var(--accent);}
.modal-actions{display:flex;gap:8px;margin-top:18px;justify-content:flex-end;}
.modal-actions button{padding:8px 18px;border-radius:7px;font-size:0.86rem;font-weight:600;cursor:pointer;border:none;}
.modal-actions .modal-cancel{background:var(--surface2);color:var(--text);border:1px solid var(--border);}
.modal-actions .modal-save{background:var(--accent);color:#fff;}
.delete-confirm-modal{max-width:380px;text-align:center;border-top:3px solid var(--red);animation:modalSlideIn 0.2s ease-out;}
.delete-confirm-icon{font-size:2.4rem;margin-bottom:8px;display:block;animation:warningPulse 1.5s ease-in-out infinite;}
.delete-confirm-modal h2{color:var(--red);font-size:1rem;margin-bottom:6px;}
.delete-confirm-msg{font-size:0.88rem;color:var(--muted);margin:8px 0 4px;line-height:1.5;}
.delete-confirm-detail{font-size:0.78rem;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px 12px;margin:10px 0 4px;line-height:1.4;word-break:break-word;}
.delete-confirm-modal .modal-actions{justify-content:center;gap:12px;}
.delete-confirm-btn{background:var(--red) !important;color:#fff !important;transition:all 0.2s;}
.delete-confirm-btn:hover{opacity:0.85;transform:scale(1.02);}
.delete-confirm-modal .modal-cancel{transition:all 0.2s;}
.delete-confirm-modal .modal-cancel:hover{border-color:var(--text);color:var(--text);}
@keyframes modalSlideIn{from{opacity:0;transform:translateY(-8px) scale(0.97);}to{opacity:1;transform:translateY(0) scale(1);}}
@keyframes warningPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.1);}}

/* ===== INLINE EDIT ===== */
.task-edit-input{flex:1;padding:4px 8px;background:var(--bg);border:1px solid var(--accent);border-radius:4px;color:var(--text);font-size:0.88rem;font-family:inherit;outline:none;}

/* ===== RESPONSIVE ===== */

/* Tablet / small desktop */
@media(max-width:860px){
  .project-grid{grid-template-columns:1fr;}
  .stats-bar{gap:20px;flex-wrap:wrap;}
  .idea-form{flex-direction:column;}
  .idea-form select{min-width:auto;}
  .app-header{padding:12px 8px;}
  .main-content{padding:6px;}
  .stats-bar{padding:14px 8px;}
  .legend{padding:8px 8px;}
  .view-switcher{padding:8px 8px;}
  .todo-add-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:stretch;}
  .todo-add-row input[type="text"]{grid-column:1/-1;}
  .todo-add-row input[type="datetime-local"]{min-width:auto;width:100%;}
  .todo-add-row select{width:100%;}
  .todo-add-row #todoBucket{grid-column:1/-1;}
  .todo-add-row button{grid-column:1/-1;}
  .todos-toolbar{flex-direction:column;gap:8px;}
}

/* Phone */
@media(max-width:480px){
  /* Gate */
  .gate-box{padding:32px 20px;border-radius:14px;}
  .gate-box .logo{font-size:2.4rem;}
  .gate-box h1{font-size:1.05rem;}

  /* Header — wrap buttons */
  .app-header{padding:10px 8px;flex-wrap:wrap;gap:8px;}
  .app-header h1{font-size:1rem;gap:5px;}
  .header-actions{gap:4px;flex-wrap:wrap;justify-content:flex-end;}
  .header-actions .btn{padding:6px 10px;font-size:0.78rem;min-height:36px;min-width:36px;display:inline-flex;align-items:center;justify-content:center;}

  /* View switcher — fill width */
  .view-switcher{gap:4px;padding:6px 8px;}
  .view-tab{flex:1;text-align:center;padding:8px 8px;font-size:0.82rem;}

  /* Stats bar — compact grid */
  .stats-bar{gap:6px;padding:10px 8px;justify-content:space-between;}
  .stat-value{font-size:1.3rem;}
  .stat-label{font-size:0.62rem;}

  /* Legend — smaller */
  .legend{gap:10px;padding:6px 8px;}
  .legend-item{font-size:0.68rem;}

  /* Main content */
  .main-content{padding:6px 4px;}

  /* Ideas section */
  .idea-form{gap:6px;}
  .idea-item{padding:8px 10px;gap:8px;flex-wrap:wrap;}
  .idea-text{font-size:0.82rem;min-width:0;}
  .idea-actions{flex-wrap:nowrap;gap:2px;}
  .idea-actions button{padding:4px 7px;font-size:0.72rem;}

  /* Project cards */
  .project-grid{gap:10px;}
  .project-card-header{padding:10px 12px 8px;}
  .project-info h3{font-size:0.88rem;}
  .project-link{font-size:0.72rem;}

  /* Always show project header actions on touch (no hover) */
  .project-card-header .project-header-actions{opacity:1;}

  /* Task list */
  .task-list{padding:4px 12px;}
  .task-row{gap:6px;}
  .task-text{font-size:0.82rem;}
  .task-meta{padding-left:14px;}
  .task-meta-item{font-size:0.72rem;padding:4px 8px;}

  /* Always show task actions on touch */
  .task-actions{display:inline-flex !important;}
  .task-actions button{font-size:0.78rem;padding:4px 6px;}

  /* Always show drag handles on touch */
  .drag-handle{opacity:1 !important;}
  .project-drag-handle{opacity:1 !important;}
  .todo-drag-handle{opacity:1 !important;}

  /* Add task area */
  .add-task{padding:6px 12px 10px;gap:4px;}
  .add-task textarea{font-size:0.82rem;padding:7px 10px;}
  .add-task button{padding:7px 12px;font-size:0.82rem;}

  /* ===== TODOS VIEW — FULL MOBILE OVERHAUL ===== */

  /* Todos toolbar: stack filters + sort vertically, full width */
  .todos-toolbar{padding:8px 8px;gap:6px;flex-direction:column;align-items:stretch;}
  .todo-filters{gap:3px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;}
  .filter-btn{flex:1;text-align:center;padding:8px 8px;font-size:0.82rem;white-space:nowrap;min-height:36px;}
  .todo-sort{width:100%;}
  .todo-sort select{width:100%;padding:8px 10px;font-size:0.82rem;}

  /* Todos main content */
  .todos-main-content{padding:8px 6px;}

  /* Todo add form: use CSS grid for clean stacked layout */
  .todo-add-form{margin-bottom:14px;}
  .todo-add-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:stretch;}
  .todo-add-row input[type="text"]{grid-column:1/-1;font-size:0.88rem;padding:12px 12px;border-radius:10px;}
  .todo-add-row select{font-size:0.84rem;padding:10px 10px;width:100%;border-radius:8px;}
  .todo-add-row input[type="datetime-local"]{font-size:0.84rem;padding:10px 10px;width:100%;min-width:auto;border-radius:8px;}
  .todo-add-row #todoBucket{grid-column:1/-1;}
  .todo-add-row button{grid-column:1/-1;padding:12px 18px;font-size:0.88rem;border-radius:10px;width:100%;}

  /* Bucket bar */
  .bucket-bar{padding:6px 8px;gap:4px;}
  .bucket-tab{font-size:0.72rem;padding:4px 10px;}
  .bucket-manage-btn{font-size:0.78rem;padding:3px 6px;}

  /* Todo list: tighter spacing */
  .todo-list{gap:6px;}

  /* Todo items: bigger tap targets, better spacing */
  .todo-item{padding:10px 10px;border-radius:10px;}
  .todo-item.todo-overdue{border-left-width:3px;}
  .todo-row{gap:8px;flex-wrap:wrap;}
  .todo-text{font-size:0.86rem;min-width:0;word-break:break-word;flex:1 1 0;}

  /* Checkbox: bigger for touch */
  .todo-checkmark{width:22px;height:22px;border-radius:6px;}
  .todo-checkbox-label input:checked + .todo-checkmark::after{font-size:0.78rem;}

  /* Priority badge: slightly larger for readability */
  .todo-priority-badge{font-size:0.7rem;padding:3px 8px;}

  /* Always show todo actions on touch */
  .todo-actions{display:inline-flex !important;gap:2px;}
  .todo-actions button{font-size:0.82rem;padding:6px 8px;min-height:32px;min-width:32px;display:inline-flex;align-items:center;justify-content:center;}

  /* Always show drag handles on touch */
  .todo-drag-handle{opacity:1 !important;font-size:0.9rem;padding:4px;}

  /* Todo meta: reduce left padding, make it fit phone width */
  .todo-meta{padding-left:38px;gap:6px;margin-top:6px;}
  .todo-due{font-size:0.78rem;}
  .todo-snoozed{font-size:0.78rem;}

  /* Todo stats bar (at top of todos view) */
  #todosStatsBar{gap:6px;padding:10px 8px;justify-content:space-between;}
  #todosStatsBar .stat-value{font-size:1.3rem;}
  #todosStatsBar .stat-label{font-size:0.62rem;}

  /* Todo inline edit input */
  .todo-item .task-edit-input{font-size:0.86rem;padding:8px 10px;border-radius:8px;width:100%;}

  /* Empty message */
  .todo-list .empty-msg{padding:20px 8px;text-align:center;font-size:0.88rem;}

  /* Modals — near full-width on phones */
  .modal{width:95%;padding:20px 16px;border-radius:12px;max-height:90vh;}
  .modal h2{font-size:0.95rem;}
  .modal input{font-size:0.84rem;padding:8px 10px;}
  .modal label{font-size:0.74rem;}
  .modal-actions button{padding:8px 14px;font-size:0.84rem;}
  .task-modal{max-width:95%;}
  .prompt-modal{max-width:95%;}
  .revision-modal{max-width:95%;}
  .snooze-modal{max-width:95%;}
  .snooze-options{gap:4px;}
  .snooze-options button{padding:6px 10px;font-size:0.78rem;}

  /* Footer */
  .footer-stats{flex-direction:column;align-items:flex-start;gap:6px;padding:10px 8px;font-size:0.68rem;}
  .footer-stats .db-stats{gap:10px;flex-wrap:wrap;}

  /* Toast */
  .toast{left:12px;right:12px;bottom:12px;text-align:center;font-size:0.82rem;}

  /* Expanded project - don't force full grid width on phones (it's already 1fr) */
  .project-card.expanded{grid-column:auto;box-shadow:0 0 0 2px var(--accent);}
}

/* ===== VIEW SWITCHER ===== */
.view-switcher{display:flex;gap:4px;padding:10px 8px;background:var(--surface);border-bottom:1px solid var(--border);}
.view-tab{padding:8px 20px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);cursor:pointer;font-size:0.88rem;font-weight:500;transition:all 0.2s;font-family:inherit;}
.view-tab:hover{border-color:var(--accent);color:var(--text);}
.view-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;}

/* ===== TODOS VIEW ===== */
.todos-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 8px;border-bottom:1px solid var(--border);gap:12px;}
.todo-filters{display:flex;gap:4px;}
.filter-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);cursor:pointer;font-size:0.82rem;font-weight:500;transition:all 0.2s;font-family:inherit;}
.filter-btn:hover{border-color:var(--accent);color:var(--text);}
.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.todo-sort select{padding:6px 10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:0.82rem;outline:none;font-family:inherit;}
.todo-sort select:focus{border-color:var(--accent);}

.todos-main-content{padding:1rem;margin:0 auto;flex:1;max-width:720px;width:100%;}

/* ===== BUCKET BAR ===== */
.bucket-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;}
.bucket-tabs{display:flex;gap:4px;flex:1;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;}
.bucket-tab{padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);cursor:pointer;font-size:0.78rem;font-weight:500;transition:all 0.2s;white-space:nowrap;font-family:inherit;}
.bucket-tab:hover{border-color:var(--accent);color:var(--text);}
.bucket-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;}
.bucket-tab .bucket-count{font-size:0.68rem;opacity:0.7;margin-left:4px;}
.bucket-manage-btn{background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:0.82rem;padding:4px 8px;color:var(--muted);transition:all 0.2s;}
.bucket-manage-btn:hover{border-color:var(--accent);color:var(--text);}

/* Bucket badge on todo items */
.todo-bucket-badge{font-size:0.68rem;padding:2px 8px;border-radius:10px;background:var(--surface2);color:var(--muted);border:1px solid var(--border);white-space:nowrap;}

/* Bucket Manager Modal */
.bucket-manager-modal{max-width:420px;}
.bucket-add-row{display:flex;gap:8px;margin-bottom:12px;}
.bucket-add-row input{flex:1;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.86rem;outline:none;font-family:inherit;}
.bucket-add-row input:focus{border-color:var(--accent);}
.bucket-add-row button{padding:8px 14px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:0.84rem;white-space:nowrap;font-family:inherit;}
.bucket-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto;}
.bucket-list-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface2);border-radius:8px;border:1px solid var(--border);}
.bucket-list-item .bucket-name{font-size:0.86rem;color:var(--text);}
.bucket-list-item .bucket-name.default{color:var(--muted);font-style:italic;}
.bucket-list-item button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:0.82rem;padding:4px 6px;border-radius:4px;transition:color 0.2s;}
.bucket-list-item button:hover{color:var(--red);}

/* Bucket select in add form */
#todoBucket{padding:10px 10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-size:0.82rem;outline:none;font-family:inherit;}
#todoBucket:focus{border-color:var(--accent);}

/* Todo Add Form */
.todo-add-form{margin-bottom:20px;}
.todo-add-row{display:flex;gap:8px;align-items:center;}
.todo-add-row input[type="text"]{flex:1;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.88rem;outline:none;transition:border-color 0.2s;font-family:inherit;}
.todo-add-row input[type="text"]:focus{border-color:var(--accent);}
.todo-add-row select{padding:10px 10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-size:0.82rem;outline:none;font-family:inherit;}
.todo-add-row input[type="datetime-local"]{padding:9px 10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-size:0.82rem;outline:none;min-width:170px;font-family:inherit;}
.todo-add-row input[type="datetime-local"]:focus{border-color:var(--accent);}
.todo-add-row button{padding:10px 18px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;white-space:nowrap;font-size:0.88rem;transition:opacity 0.2s;font-family:inherit;}
.todo-add-row button:hover{opacity:0.85;}

/* Todo List */
.todo-list{display:flex;flex-direction:column;gap:4px;}
.todo-item{padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:all 0.2s;}
.todo-item:hover{border-color:var(--accent-dim);}
.todo-item.todo-done{opacity:0.5;}
.todo-item.todo-done .todo-text{text-decoration:line-through;color:var(--muted);}
.todo-item.todo-overdue{border-left:3px solid var(--red);}
.todo-item.dragging{opacity:0.4;border:1px dashed var(--accent);}
.todo-item.drag-over{border-top:2px solid var(--accent);}

.todo-row{display:flex;align-items:center;gap:10px;}
.todo-drag-handle{cursor:grab;color:var(--muted);font-size:0.82rem;user-select:none;padding:2px 4px;border-radius:4px;transition:opacity 0.2s;opacity:0;}
.todo-drag-handle:active{cursor:grabbing;}
.todo-item:hover .todo-drag-handle{opacity:1;}

/* Custom Checkbox */
.todo-checkbox-label{position:relative;display:flex;align-items:center;cursor:pointer;flex-shrink:0;}
.todo-checkbox-label input{position:absolute;opacity:0;width:0;height:0;}
.todo-checkmark{width:18px;height:18px;border:2px solid var(--border);border-radius:5px;transition:all 0.2s;display:flex;align-items:center;justify-content:center;}
.todo-checkbox-label input:checked + .todo-checkmark{background:var(--green);border-color:var(--green);}
.todo-checkbox-label input:checked + .todo-checkmark::after{content:'✓';color:#fff;font-size:0.7rem;font-weight:700;}
.todo-checkbox-label:hover .todo-checkmark{border-color:var(--accent);}

.todo-text{flex:1;font-size:0.88rem;line-height:1.35;cursor:default;}
.todo-actions{display:none;gap:2px;}
.todo-item:hover .todo-actions{display:inline-flex;}
.todo-actions button{background:none;border:none;cursor:pointer;font-size:0.82rem;padding:3px 5px;border-radius:4px;transition:background 0.15s;}
.todo-actions button:hover{background:var(--surface2);}

/* Priority Badge */
.todo-priority-badge{font-size:0.68rem;padding:2px 7px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px;flex-shrink:0;}
.priority-low{background:rgba(107,114,128,0.15);color:#9ca3af;}
.priority-high{background:rgba(234,179,8,0.15);color:var(--yellow);}
.priority-urgent{background:rgba(239,68,68,0.15);color:var(--red);}

/* Due Date & Snooze Meta */
.todo-meta{display:flex;gap:12px;padding-left:56px;margin-top:4px;flex-wrap:wrap;}
.todo-due{font-size:0.75rem;color:var(--muted);}
.todo-due.overdue{color:var(--red);font-weight:500;}
.todo-due.due-soon{color:var(--yellow);}
.todo-snoozed{font-size:0.75rem;color:var(--purple);font-style:italic;}

/* Green stat color */
.stat-value.green{color:var(--green);}
.stat-value.red{color:var(--red);}

/* ===== SNOOZE MODAL ===== */
.snooze-modal{max-width:400px;}
.snooze-modal h2{font-size:1rem;margin-bottom:8px;}
.snooze-options{display:flex;flex-wrap:wrap;gap:6px;}
.snooze-options button{padding:7px 14px;border-radius:7px;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;font-size:0.82rem;font-weight:500;transition:all 0.2s;font-family:inherit;}
.snooze-options button:hover{border-color:var(--accent);color:var(--accent);}
.snooze-modal input[type="datetime-local"]{padding:9px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:0.86rem;outline:none;font-family:inherit;}
.snooze-modal input:focus{border-color:var(--accent);}
