/* ═══════════════════════════════════════════
   HABITS  —  Clean flat layout
   ═══════════════════════════════════════════ */

/* ── Page wrapper ── */
.habits-container { padding-bottom: 2rem; animation: fadeIn .4s ease-out; }

.habits-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2.5rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--border-subtle);
}
.habits-header h2 { font-size: 1.75rem; font-weight: 700; color: var(--text-primary); }

/* ── Add button ── */
.add-btn {
    background: var(--accent-primary);
    border: none; color: #fff;
    padding: .55rem 1.25rem;
    border-radius: 100px;
    font-size: .85rem; font-weight: 600;
    cursor: pointer; font-family: var(--font-main);
    box-shadow: 0 4px 15px rgba(129,140,248,.3);
    transition: all .2s ease; white-space: nowrap;
}
.add-btn:hover { transform: translateY(-2px); filter: brightness(1.1); box-shadow: 0 6px 20px rgba(129,140,248,.45); }

/* ── Groups ── */
.habits-list { display: flex; flex-direction: column; gap: 2rem; }

.habit-group {
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid var(--border-subtle);
    background: rgba(255,255,255,.025);
}

/* ── Category headers ── */
.habit-category-header {
    padding: .65rem 1.25rem;
    font-size: .68rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: .14em;
}
.habit-category-header.urgent  { background: linear-gradient(90deg,rgba(239,68,68,.14),transparent);  color:#fca5a5; border-bottom:1px solid rgba(239,68,68,.12); }
.habit-category-header.medium  { background: linear-gradient(90deg,rgba(129,140,248,.14),transparent); color:#a5b4fc; border-bottom:1px solid rgba(129,140,248,.1); }
.habit-category-header.low     { background: linear-gradient(90deg,rgba(100,116,139,.14),transparent); color:#94a3b8; border-bottom:1px solid rgba(100,116,139,.1); }

/* ── Single habit row ── */
.habit-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: .875rem;
    padding: .9rem 1.25rem;
    border-bottom: 1px solid rgba(255,255,255,.04);
    transition: background .15s;
    width: 100%; box-sizing: border-box;
}
.habit-item:last-child { border-bottom: none; }
.habit-item:hover { background: rgba(255,255,255,.03); }

/* ── Checkbox ── */
.habit-checkbox {
    width: 22px; height: 22px; min-width: 22px;
    border: 2px solid rgba(255,255,255,.22);
    border-radius: 6px; background: transparent;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; color: #fff;
    font-size: .78rem; font-weight: 700;
    padding: 0; flex-shrink: 0;
    transition: all .2s cubic-bezier(.4,0,.2,1);
}
.habit-checkbox:hover { border-color: var(--accent-primary); background: rgba(129,140,248,.12); transform: scale(1.08); }
.habit-checkbox.checked { background: var(--accent-primary); border-color: var(--accent-primary); box-shadow: 0 0 10px rgba(129,140,248,.4); }

/* ── Name — fills all available space ── */
.habit-label {
    flex: 1;                /* take remaining width */
    min-width: 0;           /* allow shrinking */
    font-size: .95rem;
    font-weight: 500;
    color: var(--text-primary);
    line-height: 1.4;
    word-break: break-word;
    transition: all .2s;
    text-align: left;
}

/* ── Done state ── */
.habit-item.done .habit-label { color: var(--text-muted); opacity: .55; }
.habit-item.done .habit-checkbox { background: rgba(129,140,248,.45); border-color: rgba(129,140,248,.45); }

/* ── Streak badge ── */
.streak-badge {
    font-size: .68rem; font-weight: 700; color: #fb923c;
    background: rgba(251,146,60,.1); padding: 2px 8px;
    border-radius: 20px; border: 1px solid rgba(251,146,60,.2);
    white-space: nowrap; flex-shrink: 0;
}

/* ── Delete — right side, show on hover ── */
.habit-delete {
    background: transparent; border: none;
    color: var(--text-muted); font-size: 1.15rem;
    cursor: pointer; opacity: 0;
    padding: 2px 5px; border-radius: 5px;
    transition: all .15s; line-height: 1; flex-shrink: 0;
}
.habit-item:hover .habit-delete { opacity: .45; }
.habit-delete:hover { opacity: 1 !important; color: var(--danger); background: rgba(239,68,68,.1); }

/* ── Modal ── */
.modal-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.72);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    display: flex; justify-content: center; align-items: center;
    z-index: 1000; opacity: 0; visibility: hidden;
    transition: opacity .25s, visibility .25s;
}
.modal-overlay.open { opacity: 1; visibility: visible; }

.modal {
    background: #1a2035; padding: 2rem;
    border-radius: 20px; width: 90%; max-width: 420px;
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 30px 70px rgba(0,0,0,.55);
    transform: scale(.96) translateY(14px);
    transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.modal-overlay.open .modal { transform: scale(1) translateY(0); }
.modal h2 { font-size: 1.2rem; font-weight: 700; color: var(--text-primary); margin-bottom: 1.5rem; }

.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-size: .73rem; font-weight: 600; color: var(--text-muted); margin-bottom: .45rem; text-transform: uppercase; letter-spacing: .08em; }

.form-input {
    width: 100%; padding: .7rem 1rem;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 10px; color: var(--text-primary);
    font-size: .9rem; font-family: var(--font-main);
    outline: none; transition: all .2s; box-sizing: border-box;
}
.form-input:focus { border-color: var(--accent-primary); background: rgba(129,140,248,.07); box-shadow: 0 0 0 3px rgba(129,140,248,.12); }
.form-input option { background: #1a2035; }

.modal-actions { display: flex; justify-content: flex-end; gap: .75rem; margin-top: 1.75rem; }

.cancel-btn {
    background: transparent; border: 1px solid rgba(255,255,255,.12);
    color: var(--text-secondary); padding: .6rem 1.25rem;
    border-radius: 100px; font-size: .85rem; cursor: pointer;
    transition: all .2s; font-family: var(--font-main);
}
.cancel-btn:hover { background: rgba(255,255,255,.06); color: var(--text-primary); }

.save-btn {
    background: var(--accent-primary); border: none;
    padding: .6rem 1.5rem; color: white; border-radius: 100px;
    font-size: .85rem; font-weight: 600; cursor: pointer;
    transition: all .2s; font-family: var(--font-main);
    box-shadow: 0 4px 15px rgba(129,140,248,.3);
}
.save-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }

/* ── Light mode ── */
[data-mode="light"] .habit-group      { background: #fff; border-color: rgba(0,0,0,.07); }
[data-mode="light"] .habit-item       { border-bottom-color: rgba(0,0,0,.05); }
[data-mode="light"] .habit-item:hover { background: rgba(0,0,0,.02); }
[data-mode="light"] .habit-checkbox   { border-color: rgba(0,0,0,.2); }
[data-mode="light"] .habit-label      { color: #1e293b; }
[data-mode="light"] .form-input       { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: #0f172a; }
[data-mode="light"] .modal            { background: #fff; border-color: rgba(0,0,0,.08); }

/* ── Responsive ── */
@media (max-width: 768px) {
    .habits-header   { margin-bottom: 1.5rem; }
    .habits-header h2{ font-size: 1.4rem; }
    .habit-item      { padding: .8rem 1rem; gap: .7rem; }
    .habit-label     { font-size: .875rem; }
}

/* ══════════════════════════════════════════
   🌱 HABIT GARDEN
══════════════════════════════════════════ */
.garden-section {
    margin-bottom: 2rem;
}

.garden-label {
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--text-muted);
    margin-bottom: 1rem;
}

.garden-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 1.5rem;
    background: rgba(255,255,255,.02);
    border: 1px solid rgba(255,255,255,.05);
    border-radius: 20px;
    min-height: 140px;
    align-items: flex-end;
    position: relative;
    overflow: hidden;
}

/* Soil / ground line */
.garden-grid::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 28px;
    background: linear-gradient(180deg, transparent, rgba(101,163,13,.07));
    border-top: 1px solid rgba(101,163,13,.1);
    pointer-events: none;
}

/* Individual plant pot */
.plant-pot {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .3rem;
    width: 80px;
    cursor: pointer;
    transition: transform .25s cubic-bezier(.34,1.56,.64,1);
    position: relative;
    z-index: 1;
    padding-bottom: .5rem;
}

.plant-pot:hover {
    transform: translateY(-6px) scale(1.05);
}

.plant-pot:active {
    transform: scale(.94);
}

.plant-svg-wrap {
    width: 60px;
    height: 70px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.plant-name {
    font-size: .65rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-align: center;
    max-width: 80px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

.plant-stage {
    font-size: .58rem;
    color: var(--text-muted);
    text-align: center;
}

/* Done today — subtle glow pulse */
.plant-pot.plant-done .plant-svg-wrap {
    animation: plantGlow 2.5s ease-in-out infinite;
}

@keyframes plantGlow {
    0%, 100% { filter: brightness(1); }
    50%       { filter: brightness(1.15) drop-shadow(0 0 8px rgba(129,140,248,.35)); }
}

/* Wilted — greyscale, slight droop */
.plant-pot.plant-wilted {
    opacity: .55;
    filter: grayscale(.4);
}
.plant-pot.plant-wilted .plant-svg-wrap {
    transform: rotate(-4deg);
    transform-origin: bottom center;
}

/* Bloom celebration pop on first done */
@keyframes bloomPop {
    0%   { transform: scale(0) rotate(-20deg); opacity: 0; }
    60%  { transform: scale(1.2) rotate(5deg); }
    100% { transform: scale(1) rotate(0); opacity: 1; }
}
.plant-pot.plant-done .plant-svg-wrap svg {
    animation: bloomPop .5s cubic-bezier(.34,1.56,.64,1) both;
}

/* Light mode */
[data-mode="light"] .garden-grid {
    background: rgba(0,0,0,.02);
    border-color: rgba(0,0,0,.07);
}

/* Mobile */
@media (max-width: 600px) {
    .garden-grid {
        gap: .75rem;
        padding: 1rem;
    }
    .plant-pot {
        width: 68px;
    }
}
