/* ACTION BAR */
.action-bar{display:flex;gap:8px;margin-bottom:12px;}
.btn-quick{flex:1;background:var(--card);border:1.5px solid var(--bd2);border-radius:var(--r);color:var(--or2);font-family:'Inter',sans-serif;font-size:.88rem;font-weight:700;padding:13px;cursor:pointer;transition:var(--tr);}
.btn-quick:hover{background:var(--orxl);}
.btn-custom{flex:1;background:var(--card);border:1.5px solid var(--bd2);border-radius:var(--r);color:var(--or2);font-family:'Inter',sans-serif;font-size:.88rem;font-weight:700;padding:13px;cursor:pointer;transition:var(--tr);}
.btn-custom:hover{background:var(--orxl);}

.filter-row{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;padding-bottom:3px;scrollbar-width:none;}
.filter-row::-webkit-scrollbar{display:none;}
.filter-pill{flex-shrink:0;border:1.5px solid var(--bd);background:var(--card);color:var(--t3);font-family:'Inter',sans-serif;font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:999px;cursor:pointer;transition:var(--tr);}
.filter-pill.active{background:var(--or);border-color:var(--or);color:#fff;}

.task-list{display:flex;flex-direction:column;gap:8px;}
.task-item{background:var(--card);border:1.5px solid var(--bd);border-radius:var(--r);padding:12px 13px;display:flex;align-items:flex-start;gap:10px;transition:var(--tr);box-shadow:var(--sh);}
.task-item:hover{border-color:var(--bd2);}
.task-item.done{opacity:.5;}
.task-item.done .task-title{text-decoration:line-through;color:var(--t3);}
.task-item.done .task-goal-inline{opacity:.6;}
.task-check{width:22px;height:22px;border-radius:6px;border:2px solid var(--bd2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--tr);flex-shrink:0;margin-top:1px;}
.task-check:hover{border-color:var(--end);}
.task-check.checked{background:var(--end);border-color:var(--end);box-shadow:0 0 8px rgba(16,185,129,.3);cursor:default;}
.task-check.checked::after{content:'✓';color:#fff;font-size:12px;font-weight:700;}
.task-body{flex:1;min-width:0;align-self:center;}
.task-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.task-title{font-size:.88rem;font-weight:600;color:var(--t1);word-break:break-word;line-height:1.4;}
.task-goal-inline{font-size:.88rem;font-weight:700;color:var(--or2);white-space:nowrap;flex-shrink:0;}
.diff-badge{font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:999px;background:rgba(249,115,22,.1);color:var(--or2);}
.goal-badge{font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:999px;background:rgba(16,185,129,.1);color:#059669;}
.one-time-badge{font-size:.55rem;font-weight:700;padding:2px 6px;border-radius:999px;background:rgba(99,102,241,.12);color:#6366f1;flex-shrink:0;align-self:center;}
.count-progress-wrap{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;margin-left:auto;}
.count-inc-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--or);background:transparent;color:var(--or);font-size:1.1rem;font-weight:700;cursor:pointer;line-height:1;padding:0;transition:background .15s,color .15s;}
.count-inc-btn:active{background:var(--or);color:#fff;}
.count-progress-display{font-size:.82rem;font-weight:700;color:var(--or2);white-space:nowrap;}
.one-time-label{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--t2);margin-bottom:12px;cursor:pointer;}
.one-time-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--or);cursor:pointer;flex-shrink:0;}
.one-time-hint{font-size:.75rem;font-weight:400;color:var(--t3);}
.task-stats{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px;}
.sc-chip{font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:999px;}
.sc-chip.str{background:rgba(239,68,68,.1);color:var(--str);}
.sc-chip.per{background:rgba(139,92,246,.1);color:var(--per);}
.sc-chip.cha{background:rgba(236,72,153,.1);color:var(--cha);}
.sc-chip.end{background:rgba(16,185,129,.1);color:var(--end);}
.sc-chip.int{background:rgba(59,130,246,.1);color:var(--int);}
.sc-chip.agi{background:rgba(245,158,11,.1);color:var(--agi);}
.task-actions{display:flex;flex-direction:column;gap:2px;flex-shrink:0;align-self:stretch;justify-content:space-between;padding:1px 0;}
.btn-edit,.btn-del{width:26px;height:26px;background:none;border:none;cursor:pointer;border-radius:6px;transition:var(--tr);display:flex;align-items:center;justify-content:center;color:var(--t3);}
.btn-edit:hover{color:var(--or);background:var(--orxl);}
.btn-del:hover{color:#ef4444;background:rgba(239,68,68,.08);}
.task-check-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;align-self:center;}
.task-boost-icon{width:22px;height:22px;object-fit:contain;margin-top:2px;transition:var(--tr);flex-shrink:0;}
.task-boost-icon-pending{opacity:.4;filter:grayscale(85%);}
.task-item-icon{align-self:center;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:3.5rem;}
.task-item-icon .qtask-icon-img{width:35px;height:35px;object-fit:contain;}
.task-coin-preview{font-size:.72rem;font-weight:700;color:#d97706;background:rgba(245,158,11,.1);border-radius:20px;padding:2px 7px;white-space:nowrap;}
.task-coin-preview.earned{opacity:.7;}
.modal-coin-preview{font-size:.8rem;font-weight:600;color:#d97706;background:rgba(245,158,11,.1);border-radius:8px;padding:7px 12px;margin-top:4px;text-align:center;}
.btn-unfreeze{width:22px;height:22px;background:none;border:none;cursor:pointer;border-radius:6px;transition:var(--tr);display:flex;align-items:center;justify-content:center;padding:0;}
.btn-unfreeze:hover{background:rgba(249,115,22,.12);}
.task-item.frozen{border-color:rgba(96,165,250,.45);background:rgba(219,234,254,.15);}
.task-check.frozen-check{border-color:#93c5fd;cursor:default;background:rgba(219,234,254,.4);display:flex;align-items:center;justify-content:center;}
.task-check.frozen-check:hover{border-color:#93c5fd;}
.task-item.frozen .task-title{color:var(--t2);}
.freeze-task-list{display:flex;flex-direction:column;gap:8px;max-height:60vh;overflow-y:auto;margin-top:4px;}
.freeze-task-item{background:var(--bg1);border:1.5px solid var(--bd);border-radius:var(--r);padding:12px 14px;cursor:pointer;transition:var(--tr);}
.freeze-task-item:hover{border-color:rgba(96,165,250,.6);background:rgba(219,234,254,.25);}
.freeze-task-name{font-size:.9rem;font-weight:600;color:var(--t1);}
.freeze-task-goal{font-size:.78rem;color:var(--t2);margin-top:3px;}
.empty-state{text-align:center;padding:40px 24px;color:var(--t3);}
.empty-state .emoji{font-size:2.8rem;margin-bottom:10px;display:flex;align-items:center;justify-content:center;}
.empty-state p{font-size:.88rem;line-height:1.6;}

/* MODALS */
.modal-overlay{position:fixed;inset:0;z-index:8000;background:rgba(28,25,23,.5);backdrop-filter:blur(5px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal-box{background:var(--card);border-radius:var(--r2) var(--r2) 0 0;width:100%;max-width:480px;padding:20px 18px 36px;transform:translateY(40px);transition:transform .3s cubic-bezier(.4,0,.2,1);border-top:3px solid var(--or);max-height:90dvh;overflow-y:auto;}
.modal-overlay.open .modal-box{transform:translateY(0);}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.modal-title{font-size:1rem;font-weight:800;color:var(--t1);}
.modal-x{background:var(--orxl);border:none;color:var(--or2);width:28px;height:28px;border-radius:50%;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--tr);}
.modal-x:hover{background:var(--or);color:#fff;}
.modal-input{width:100%;background:var(--orxl);border:1.5px solid var(--bd);border-radius:var(--r);padding:11px 13px;color:var(--t1);font-family:'Inter',sans-serif;font-size:.9rem;outline:none;transition:var(--tr);margin-bottom:10px;}
.modal-input:focus{border-color:var(--or);box-shadow:0 0 0 3px var(--glow);}
.modal-row{display:flex;gap:8px;margin-top:4px;}
.btn-modal-save{flex:1;background:linear-gradient(135deg,var(--or),var(--or2));border:none;border-radius:var(--r);color:#fff;font-family:'Inter',sans-serif;font-size:.9rem;font-weight:700;padding:12px;cursor:pointer;width:100%;transition:var(--tr);}
.btn-modal-save:hover{transform:translateY(-1px);}
.btn-modal-cancel{flex:1;background:var(--orxl);border:1px solid var(--bd);border-radius:var(--r);color:var(--t2);font-family:'Inter',sans-serif;font-size:.9rem;font-weight:700;padding:12px;cursor:pointer;}

/* QUICK ADD */
.qlabel{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--t3);margin-bottom:10px;}
#qTaskName{display:flex;align-items:center;gap:8px;font-size:.85rem;}
#qTaskName .qtask-icon-img{width:28px;height:28px;object-fit:contain;flex-shrink:0;}
.qtask-grid{margin-bottom:4px;}
.qgroup{margin-bottom:10px;}
.qgroup:last-child{margin-bottom:0;}
.qgroup-hdr{font-size:.63rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;border-bottom:1px solid var(--bd);padding-bottom:3px;}
.qgroup-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;}
.modal-overlay.modal-center{align-items:center;padding:0 20px;}
.modal-overlay.modal-center .modal-box{border-radius:var(--r2);}
.qtask-btn{background:var(--orxl);border:1.5px solid var(--bd);border-radius:var(--r);padding:11px 6px;cursor:pointer;transition:var(--tr);display:flex;flex-direction:column;align-items:center;gap:5px;font-family:'Inter',sans-serif;}
.qtask-btn:hover{border-color:var(--or);background:var(--orl);}
.qtask-btn.qtask-done{opacity:.4;cursor:not-allowed;}
.qtask-btn.qtask-done:hover{border-color:var(--bd);background:var(--orxl);}
.qtask-btn span{font-size:.7rem;font-weight:700;color:var(--t1);}
.qtask-btn .emoji{font-size:1.5rem;}
.qtask-btn .qtask-icon-img{width:28px;height:28px;object-fit:contain;display:block;}
.qgoal-list{margin-bottom:12px;}
.qgoal-grid{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px;}
.qgoal-btn{padding:7px 14px;border:1.5px solid var(--bd);border-radius:20px;background:var(--orxl);color:var(--t2);font-family:'Inter',sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--tr);}
.qgoal-btn.active{background:var(--or);color:#fff;border-color:var(--or);}
.mode-tabs{display:flex;gap:6px;margin-bottom:10px;}
.mode-tab{flex:1;padding:9px;border:1.5px solid var(--bd);border-radius:var(--r);background:var(--orxl);color:var(--t2);font-family:'Inter',sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;transition:var(--tr);}
.mode-tab.active{background:var(--or);color:#fff;border-color:var(--or);}
.goal-select{width:100%;padding:10px 12px;background:var(--card);border:1.5px solid var(--bd);border-radius:var(--r);color:var(--t1);font-size:.95rem;font-family:'Inter',sans-serif;margin-bottom:8px;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;box-sizing:border-box;}
.goal-select:focus{outline:none;border-color:var(--or);}
.goal-select option{background:var(--bg);}
.custom-goal-input{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.custom-goal-input .modal-input{flex:1;margin-bottom:0;}
.custom-unit{color:var(--t2);font-size:.9rem;font-weight:600;white-space:nowrap;}
.qstats-preview{min-height:32px;margin-bottom:14px;}
.preview-label{font-size:.72rem;font-weight:700;color:var(--t3);margin-bottom:6px;}
.preview-chips{display:flex;flex-wrap:wrap;gap:5px;}
.qactions{display:flex;gap:8px;}
.btn-qback{flex:1;background:var(--orxl);border:1px solid var(--bd);border-radius:var(--r);color:var(--t2);font-family:'Inter',sans-serif;font-size:.88rem;font-weight:700;padding:12px;cursor:pointer;transition:var(--tr);}
.btn-qadd{flex:1;background:linear-gradient(135deg,var(--or),var(--or2));border:none;border-radius:var(--r);color:#fff;font-family:'Inter',sans-serif;font-size:.88rem;font-weight:700;padding:12px;cursor:pointer;transition:var(--tr);}
.btn-qadd:disabled{opacity:.4;cursor:not-allowed;}
.btn-qadd:not(:disabled):hover{transform:translateY(-1px);}
