 :root {
  --green-50:#f2f7f7;--green-100:#e5f0f0;--green-200:#cfe6e6;--green-300:#a6e1fa;
  --green-400:#6fcfdd;--green-500:#00a6a6;--green-600:#0b7f7f;--green-700:#0d1b1e;
  --brown-50:#f5f1ee;--brown-100:#e9e1db;--brown-200:#d8cbc2;--brown-300:#c0b0a4;
  --brown-400:#a59184;--brown-500:#837569;--brown-600:#6f6258;
  --amber-50:#f7f8ef;--amber-100:#eff1d9;--amber-200:#e0e3bf;--amber-300:#d1d6a3;
  --amber-400:#c7cb85;--amber-500:#b2b66f;--amber-600:#9aa05f;
  --slate-50:#f6f7f8;--slate-100:#e9ecef;--slate-200:#d7dde2;--slate-300:#b6c0c8;
  --slate-400:#8fa0ab;--slate-500:#6d7c87;--slate-600:#4f5c65;--slate-700:#354047;
  --slate-800:#232b31;--slate-900:#0d1b1e;
  --red-100:#fee2e2;--red-500:#dc4343;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 10px 25px rgba(13,27,30,.12),0 2px 8px rgba(13,27,30,.06);
  --shadow-md:0 22px 40px rgba(13,27,30,.22),0 8px 20px rgba(13,27,30,.12);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Space Grotesk',sans-serif;color:var(--slate-800);min-height:100vh;position:relative;z-index:0;line-height:1.35}
body::before{content:"";position:fixed;inset:0;background:
  radial-gradient(circle at 12% 18%,rgba(131,117,105,.22),transparent 45%),
  radial-gradient(circle at 88% 82%,rgba(166,225,250,.22),transparent 40%),
  linear-gradient(rgba(246,245,241,.94),rgba(241,240,236,.9)),
  url('/background.jpg') center center / cover no-repeat;z-index:-1}
.hidden{display:none!important}
button{cursor:pointer;font-family:inherit;touch-action:manipulation}
input,textarea,select{font-family:inherit;font-size:inherit}

/* Auth */
#auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;
  background:transparent}
.auth-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);padding:40px;max-width:400px;width:100%;text-align:center}
.auth-card{border:1px solid rgba(255,255,255,.75);backdrop-filter:blur(12px);background:linear-gradient(165deg,rgba(255,255,255,.95),rgba(255,255,255,.83))}
.auth-card h1{font-family:'Fraunces',serif;font-size:30px;color:var(--green-700);margin-bottom:6px;letter-spacing:.2px}
.auth-card p{color:var(--slate-500);margin-bottom:24px;font-size:14px}
.auth-card input{width:100%;padding:12px 14px;border:1px solid var(--slate-200);border-radius:12px;margin-bottom:12px;outline:none;transition:border .2s,box-shadow .2s}
.auth-card input:focus{border-color:var(--green-400)}
.auth-card input:focus{box-shadow:0 0 0 3px rgba(88,173,110,.2)}
.auth-card .btn{width:100%;padding:12px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--green-500),var(--green-600));color:#fff;font-weight:700;font-size:15px;transition:transform .2s,filter .2s}
.auth-card .btn:hover{transform:translateY(-1px);filter:brightness(1.02)}
.auth-card .toggle{margin-top:16px;font-size:13px;color:var(--slate-500)}
.auth-card .toggle a{color:var(--green-500);cursor:pointer;text-decoration:underline}
.auth-error{color:var(--red-500);font-size:13px;margin-bottom:10px}

/* App Layout */
#app-screen{display:none;flex-direction:column;min-height:100vh}
header{background:linear-gradient(135deg,var(--green-700),var(--green-600));padding:12px 18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:120;border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(6px)}
header h1{font-family:'Fraunces',serif;font-size:22px;color:var(--amber-100);white-space:nowrap;letter-spacing:.2px}
.header-right{display:flex;align-items:center;gap:10px}
.header-right .user-info{font-size:12px;color:#ddf0df;padding:6px 10px;background:rgba(255,255,255,.1);border-radius:999px}
.header-right button{padding:7px 14px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(255,255,255,.06);font-size:12px;color:#eff8f0;transition:all .2s}
.header-right button:hover{background:rgba(255,255,255,.14)}

/* Tabs */
.tabs{display:flex;gap:8px;background:linear-gradient(135deg,var(--green-700),#215f3a);padding:10px 10px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:sticky;top:58px;z-index:110;box-shadow:0 8px 18px rgba(0,0,0,.12)}
.tabs::-webkit-scrollbar{display:none}
.tab-btn{padding:10px 14px;border:none;background:rgba(255,255,255,.06);color:rgba(226,243,230,.9);font-size:12px;font-weight:700;white-space:nowrap;border:1px solid rgba(255,255,255,.08);border-radius:999px;transition:all .2s;position:relative;letter-spacing:.2px}
.tab-btn.active{color:var(--green-700);background:linear-gradient(135deg,var(--amber-100),var(--amber-300));border-color:transparent;box-shadow:0 6px 14px rgba(0,0,0,.15)}
.tab-btn:hover{background:rgba(255,255,255,.13)}
.tab-badge{position:absolute;top:4px;right:2px;min-width:18px;height:18px;border-radius:50%;background:var(--amber-400);color:var(--green-700);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}

/* Mobile Navigation */
.mobile-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:260;background:linear-gradient(135deg,rgba(23,79,43,.96),rgba(31,110,59,.96));backdrop-filter:blur(10px);border-top:1px solid rgba(201,233,209,.25);padding:8px 10px calc(8px + env(safe-area-inset-bottom));gap:8px;box-shadow:0 -10px 24px rgba(0,0,0,.2);pointer-events:auto}
.mobile-nav-btn{flex:1;min-height:52px;border:none;border-radius:14px;background:rgba(255,255,255,.08);color:#eef8f0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:11px;font-weight:700;letter-spacing:.2px;transition:all .2s}
.mobile-nav-btn .mn-ico{font-size:16px;line-height:1}
.mobile-nav-btn.active{background:linear-gradient(135deg,var(--green-100),var(--amber-100));color:var(--green-700);box-shadow:0 6px 14px rgba(0,0,0,.2)}
.mobile-nav-btn.tap{transform:scale(.94);filter:brightness(1.08)}

.mobile-sheet{position:fixed;inset:0;z-index:300;display:flex;align-items:flex-end;pointer-events:none}
.mobile-sheet.hidden{display:none}
.mobile-sheet:not(.hidden){pointer-events:auto}
.mobile-sheet-backdrop{position:absolute;inset:0;background:rgba(8,20,12,.45)}
.mobile-sheet-panel{position:relative;width:100%;background:linear-gradient(160deg,#f7fcf8,#eff8f2);border-radius:22px 22px 0 0;padding:14px 14px calc(22px + env(safe-area-inset-bottom));box-shadow:0 -12px 30px rgba(0,0,0,.25);animation:sheetUp .22s ease;border-top:1px solid rgba(47,141,79,.2)}
.mobile-sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.mobile-sheet-head h4{font-size:14px;color:var(--green-700)}
.mobile-sheet-close{border:none;background:var(--green-100);width:32px;height:32px;border-radius:10px;color:var(--green-700);font-size:16px}
.mobile-sheet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.mobile-sheet-btn{border:1px solid var(--green-200);background:linear-gradient(145deg,#ffffff,#f3faf4);border-radius:14px;aspect-ratio:1/1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;padding:8px 6px;font-size:12px;color:var(--green-700);font-weight:700;box-shadow:0 4px 10px rgba(47,141,79,.08);transition:all .2s}
.mobile-sheet-btn .ms-ico{font-size:19px;line-height:1}
.mobile-sheet-btn.active{border-color:var(--green-400);background:linear-gradient(145deg,var(--green-50),var(--amber-50));box-shadow:0 6px 12px rgba(47,141,79,.14)}
.mobile-sheet-btn:active{transform:scale(.97)}

/* Main */
main{flex:1;padding:20px;max-width:1180px;margin:0 auto;width:100%}
.tab-content{display:none}
.tab-content.active{display:block}
.tab-content.active{animation:tabFade .28s ease}
.section-title{font-family:'Fraunces',serif;font-size:26px;color:var(--green-700);margin-bottom:16px}
.card{background:linear-gradient(170deg,rgba(255,255,255,.97),rgba(255,255,255,.88));border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:16px;border:1px solid rgba(255,255,255,.85)}
.tab-content.active .card{animation:cardIn .4s ease both}
.card h3{font-size:15px;font-weight:600;margin-bottom:12px;color:var(--green-600)}
.card-muted{color:var(--slate-400);font-size:13px}
.btn-sm{padding:9px 14px;border:none;border-radius:12px;font-size:13px;font-weight:700;transition:all .2s;min-height:38px}
.btn-primary{background:linear-gradient(135deg,var(--green-500),var(--green-600));color:#fff}.btn-primary:hover{filter:brightness(1.03);transform:translateY(-1px)}
.btn-outline{background:#fff;border:1px solid var(--slate-200);color:var(--slate-600)}.btn-outline:hover{background:var(--slate-100)}
.btn-amber{background:linear-gradient(135deg,var(--amber-400),var(--amber-500));color:#fff}.btn-amber:hover{filter:brightness(1.03)}
.btn-brown{background:linear-gradient(135deg,var(--brown-400),var(--brown-500));color:#fff}.btn-brown:hover{filter:brightness(1.03)}
.input{padding:10px 12px;border:1px solid var(--slate-200);border-radius:12px;outline:none;width:100%;transition:border .2s,box-shadow .2s;background:#fff;min-height:40px}
.input:focus{border-color:var(--green-400);box-shadow:0 0 0 3px rgba(88,173,110,.2)}
textarea.input{resize:vertical;min-height:60px}
.flex{display:flex}.flex-wrap{flex-wrap:wrap}.gap-2{gap:8px}.gap-3{gap:12px}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:700px){.grid-2{grid-template-columns:1fr}}

/* Today Tasks */
.today-tasks{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.task-chip{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;display:flex;align-items:center;gap:4px}
.task-chip.done{background:var(--green-100);color:var(--green-600)}
.task-chip.pending{background:var(--amber-100);color:var(--amber-600)}

/* Partner message notification */
.partner-msg-card{background:linear-gradient(135deg,var(--green-100),var(--amber-50));border:1px solid var(--green-200);border-radius:var(--radius);padding:16px;margin-bottom:16px;position:relative}
.partner-msg-card .pmsg-label{font-size:11px;font-weight:600;color:var(--green-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.partner-msg-card .pmsg-text{font-size:15px;color:var(--slate-700);line-height:1.5}
.partner-msg-card .pmsg-from{font-size:12px;color:var(--slate-500);margin-top:6px}

/* Daily Ritual */
.ritual-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.ritual-field label{font-size:12px;color:var(--slate-500);display:block;margin-bottom:6px}
.ritual-field textarea{min-height:80px}
.ritual-partner{margin-top:10px;padding:10px;border-radius:12px;background:var(--green-50);border:1px solid var(--green-200);font-size:13px;color:var(--green-700)}
@media(max-width:800px){.ritual-grid{grid-template-columns:1fr}}

/* Messages */
.msg-history{max-height:300px;overflow-y:auto;margin-top:8px}
.msg-bubble{padding:8px 12px;border-radius:12px;margin-bottom:6px;font-size:13px;max-width:85%}
.msg-bubble.mine{background:var(--green-100);margin-left:auto;border-bottom-right-radius:4px}
.msg-bubble.theirs{background:var(--brown-100);border-bottom-left-radius:4px}
.msg-bubble .msg-meta{font-size:10px;color:var(--slate-400);margin-top:2px}
.msg-date-sep{text-align:center;font-size:11px;color:var(--slate-400);margin:8px 0}

/* Week Nav */
.week-nav{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.week-nav button{width:32px;height:32px;border-radius:8px;border:1px solid var(--slate-200);background:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--slate-500)}
.week-nav button:hover{background:var(--green-50)}
.week-nav span{font-size:13px;color:var(--slate-500);min-width:200px;text-align:center}

/* Mood */
.mood-row{display:flex;gap:6px;flex-wrap:wrap}
.mood-btn{width:44px;height:44px;border-radius:12px;border:2px solid var(--slate-200);background:#fff;font-size:22px;transition:all .2s;display:flex;align-items:center;justify-content:center}
.mood-btn.selected{border-color:var(--green-500);background:var(--green-50);transform:scale(1.15)}
.mood-btn:hover{border-color:var(--green-300)}
.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:8px}
.week-cell{text-align:center;padding:6px 2px;border-radius:8px;background:var(--slate-50);min-height:48px}
.week-cell .day-label{font-size:10px;color:var(--slate-400);text-transform:uppercase;margin-bottom:2px}
.week-cell .day-val{font-size:18px}
.week-cell.today{background:var(--green-100);border:1px solid var(--green-300)}

/* Boards */
.boards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.board{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;min-height:150px;border:1px solid var(--slate-200)}
.board-header{padding:12px 16px;font-weight:600;font-size:14px;display:flex;justify-content:space-between;align-items:center;background:var(--green-50);border-bottom:1px solid var(--slate-200)}
.board-cards{padding:8px 12px;min-height:60px}
.board-card{padding:10px 12px;background:var(--slate-50);border-radius:12px;margin-bottom:8px;font-size:13px;cursor:grab;display:flex;justify-content:space-between;align-items:start;border:1px solid transparent;transition:all .15s;gap:8px}
.board-card:hover{border-color:var(--green-200);background:var(--green-50)}
.board-card .author{font-size:10px;color:var(--slate-400);margin-top:2px}
.board-card .del-btn{opacity:0;font-size:11px;color:var(--slate-400);cursor:pointer;padding:2px 4px}
.board-card:hover .del-btn{opacity:1}
.board-card.dragging{opacity:.4}
.board-card .card-tools{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.board-card .move-select{border:1px solid var(--slate-200);border-radius:8px;font-size:11px;padding:2px 4px;background:#fff;color:var(--slate-600)}
.board-add{padding:8px 12px}
.board-add input{width:100%;padding:6px 10px;border:1px solid var(--slate-200);border-radius:6px;font-size:13px;outline:none}
.board-add input:focus{border-color:var(--green-300)}

/* Kanban Bucket List */
.kanban{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.kanban-col{background:var(--slate-50);border-radius:var(--radius);min-height:200px;display:flex;flex-direction:column;border:1px solid var(--slate-200)}
.kanban-col-header{padding:12px 16px;font-weight:600;font-size:14px;border-bottom:1px solid var(--slate-200);display:flex;align-items:center;gap:8px}
.kanban-col-header .kh-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.kanban-col-header .kh-count{margin-left:auto;font-size:12px;font-weight:400;color:var(--slate-400)}
.kanban-cards{padding:8px;flex:1;min-height:80px}
.kanban-card{padding:10px 12px;background:#fff;border-radius:12px;margin-bottom:8px;font-size:13px;cursor:grab;display:flex;justify-content:space-between;align-items:start;border:1px solid var(--slate-200);transition:all .15s;box-shadow:0 1px 2px rgba(0,0,0,.04);gap:8px}
.kanban-card:hover{border-color:var(--green-300);box-shadow:var(--shadow)}
.kanban-card .kc-author{font-size:10px;color:var(--slate-400);margin-top:3px}
.kanban-card .kc-del{opacity:0;color:var(--slate-400);cursor:pointer;font-size:11px;padding:2px 4px;flex-shrink:0}
.kanban-card:hover .kc-del{opacity:1}
.kanban-card.dragging{opacity:.3;transform:rotate(2deg)}
.kanban-card .card-tools{display:flex;flex-direction:column;gap:4px;align-items:flex-end}
.kanban-card .move-select{border:1px solid var(--slate-200);border-radius:8px;font-size:11px;padding:2px 4px;background:#fff;color:var(--slate-600)}
@media(max-width:700px){.kanban{grid-template-columns:1fr}}

/* Check-in */
.checkin-slider{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.checkin-slider label{width:110px;font-size:13px;color:var(--slate-600);flex-shrink:0}
.checkin-slider input[type=range]{flex:1;accent-color:var(--green-500)}
.checkin-slider span{width:20px;text-align:center;font-weight:600;color:var(--green-600)}
.sunday-badge{display:inline-block;background:var(--amber-400);color:#fff;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;margin-left:6px}
.past-checkin-card{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:12px;background:var(--slate-50);border-radius:8px;margin-bottom:8px;border:1px solid var(--slate-200)}
.past-checkin-card .ci-label{font-size:11px;color:var(--slate-400)}
.past-checkin-card .ci-val{font-size:18px;font-weight:600;color:var(--green-600)}

/* Journal */
.journal-entry{padding:14px;background:var(--slate-50);border-radius:8px;margin-bottom:10px;border:1px solid var(--slate-200)}
.journal-entry h4{font-size:14px;margin-bottom:4px;color:var(--green-600)}
.journal-entry p{font-size:13px;color:var(--slate-600);white-space:pre-wrap}
.journal-entry .meta{font-size:11px;color:var(--slate-400);margin-top:6px;display:flex;justify-content:space-between}

/* Movie & Activity */
.list-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--slate-200)}
.list-item:last-child{border:none}
.list-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.list-title{font-size:14px;font-weight:500;flex:1}
.list-sub{font-size:12px;color:var(--slate-400)}
.list-actions{display:flex;gap:4px;align-items:center}
.list-actions select{padding:3px 6px;border:1px solid var(--slate-200);border-radius:6px;font-size:11px;background:#fff}
.list-del{opacity:0;color:var(--slate-400);cursor:pointer;font-size:12px;padding:4px}
.list-item:hover .list-del{opacity:1}
.filter-pills{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.filter-pill{padding:5px 14px;border-radius:20px;border:1px solid var(--slate-200);background:#fff;font-size:12px;color:var(--slate-500);transition:all .2s}
.filter-pill.active{background:var(--green-500);color:#fff;border-color:var(--green-500)}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.gallery-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:1;background:var(--slate-100);border:1px solid var(--slate-200)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item .gi-overlay{position:absolute;bottom:0;left:0;right:0;padding:8px;background:linear-gradient(transparent,rgba(0,0,0,.6));color:#fff;font-size:11px;opacity:0;transition:opacity .3s}
.gallery-item:hover .gi-overlay{opacity:1}
.gallery-item .gi-del{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;border:none;font-size:12px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.gallery-item:hover .gi-del{opacity:1}
.upload-area{border:2px dashed var(--slate-300);border-radius:var(--radius);padding:24px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:16px}
.upload-area:hover{border-color:var(--green-400);background:var(--green-50)}
.upload-area.dragover{border-color:var(--green-500);background:var(--green-100)}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:8px;object-fit:contain}
.lightbox .lb-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;border:none;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.lightbox .lb-caption{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#fff;font-size:14px;text-align:center;max-width:80vw}

/* Countdown */
.countdown-item{display:flex;align-items:center;gap:10px;padding:8px 0}
.countdown-emoji{font-size:24px}
.countdown-info{flex:1}
.countdown-info .cd-title{font-size:14px;font-weight:500}
.countdown-info .cd-days{font-size:12px;color:var(--green-500);font-weight:600}

/* Calendar */
.cal-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.cal-header button{padding:6px 12px;border-radius:8px;border:1px solid var(--slate-200);background:#fff;font-size:13px;color:var(--slate-600)}
.cal-header button:hover{background:var(--green-50)}
.cal-header h3{flex:1;text-align:center;font-size:15px;font-weight:500}
.cal-day-card{border:1px solid var(--slate-200);border-radius:var(--radius);overflow:hidden;margin-bottom:8px}
.cal-day-header{padding:8px 12px;background:var(--green-50);font-size:13px;font-weight:600;display:flex;justify-content:space-between;color:var(--green-600)}
.cal-day-body{padding:10px 12px;font-size:13px;color:var(--slate-600)}
.cal-day-body .cal-row{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px solid var(--slate-100)}
.cal-day-body .cal-row:last-child{border:none}

/* Planner */
.planner-list .list-item{align-items:flex-start}
.plan-meta{font-size:11px;color:var(--slate-400)}
.status-chip{padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700}
.status-planned{background:var(--amber-100);color:var(--amber-600)}
.status-done{background:var(--green-100);color:var(--green-600)}
.status-canceled{background:var(--slate-100);color:var(--slate-500)}

/* Appreciation */
.jar-box{display:flex;align-items:center;justify-content:space-between;padding:12px;border:1px dashed var(--green-300);border-radius:14px;background:var(--green-50);margin-bottom:12px}
.jar-note{padding:10px 12px;background:#fff;border:1px solid var(--slate-200);border-radius:12px;margin-bottom:8px}

/* Goals */
.goal-card{border:1px solid var(--slate-200);border-radius:14px;padding:12px;margin-bottom:10px;background:#fff}
.goal-title{font-weight:600;color:var(--green-700)}
.goal-progress{height:8px;border-radius:999px;background:var(--slate-100);overflow:hidden;margin:6px 0}
.goal-progress span{display:block;height:100%;background:linear-gradient(135deg,var(--green-400),var(--amber-400))}
.goal-meta{font-size:11px;color:var(--slate-400);display:flex;justify-content:space-between}

/* Repair */
.repair-card{border:1px solid var(--slate-200);border-radius:14px;padding:12px;margin-bottom:10px;background:#fff}
.repair-card .repair-prompt{font-weight:600;color:var(--green-700);margin-bottom:6px}
.repair-card .repair-answer{font-size:13px;color:var(--slate-600)}

/* Toast */
.toast-container{position:fixed;top:20px;right:20px;z-index:2000}
.toast{padding:10px 16px;border-radius:8px;background:var(--green-600);color:#fff;font-size:13px;margin-bottom:6px;animation:slideIn .3s ease;box-shadow:var(--shadow-md)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes tabFade{from{opacity:.35;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@keyframes cardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes sheetUp{from{transform:translateY(20px);opacity:.7}to{transform:translateY(0);opacity:1}}

/* Responsive */
@media(max-width:600px){
  main{padding:12px 12px 18px}
  header{padding:10px 12px;top:0}
  header h1{font-size:18px}
  .header-right .user-info{display:none}
  .tabs{top:54px;padding:8px 8px;gap:6px}
  .tab-btn{font-size:11px;padding:9px 11px;min-height:36px}
  .boards-container{grid-template-columns:1fr}
  .past-checkin-card{grid-template-columns:repeat(3,1fr)}
  .week-grid{gap:3px}
  .week-cell .day-val{font-size:14px}
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}
  .section-title{font-size:22px}
  .card{padding:14px;border-radius:14px}
  .grid-2{gap:12px}
  .btn-sm{min-height:40px}
  .task-assign-form{flex-direction:column}
  .task-assign-form input{min-width:100%}
  .checkin-slider{gap:8px}
  .checkin-slider label{width:92px;font-size:12px}
}

@media(max-width:420px){
  .tabs{padding:7px 6px}
  .tab-btn{padding:8px 10px;font-size:10px}
  .card h3{font-size:14px}
}

@media(max-width:900px){
  .tabs{display:none}
  .mobile-nav{display:flex}
  main{padding-bottom:110px}
}

/* Weekly Tasks */
.task-card{padding:14px;background:var(--slate-50);border-radius:8px;margin-bottom:8px;border:1px solid var(--slate-200);display:flex;align-items:flex-start;gap:10px}
.task-card.task-done{opacity:.7;background:var(--green-50);border-color:var(--green-200)}
.task-checkbox{width:22px;height:22px;border-radius:50%;border:2px solid var(--slate-300);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:all .2s}
.task-checkbox:hover{border-color:var(--green-400)}
.task-card.task-done .task-checkbox{background:var(--green-500);border-color:var(--green-500);color:#fff}
.task-card .task-body{flex:1}
.task-card .task-text{font-size:14px;font-weight:500;color:var(--slate-700)}
.task-card.task-done .task-text{text-decoration:line-through;color:var(--slate-400)}
.task-card .task-meta{font-size:11px;color:var(--slate-400);margin-top:3px}
.task-card .task-note{font-size:12px;color:var(--slate-500);margin-top:4px;font-style:italic}
.task-card .task-del{opacity:0;color:var(--slate-400);cursor:pointer;font-size:12px;padding:4px;flex-shrink:0}
.task-card:hover .task-del{opacity:1}
.task-section-header{font-size:14px;font-weight:600;color:var(--green-600);margin:16px 0 8px;display:flex;align-items:center;gap:6px}
.task-assign-form{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.task-assign-form input{flex:1;min-width:150px}

/* Edit mode for previous day */
.edit-day-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--amber-50);border:1px solid var(--amber-200);border-radius:8px;margin-bottom:12px;font-size:13px}
.edit-day-bar select{padding:4px 8px;border:1px solid var(--amber-200);border-radius:6px;font-size:13px;background:#fff}
.edit-day-bar .edit-label{color:var(--amber-600);font-weight:500}

/* Calendar question row */
.cal-question-row{padding:6px 0;border-bottom:1px solid var(--slate-100)}
.cal-question-row:last-child{border:none}
.cal-q-text{font-size:12px;color:var(--green-600);font-weight:500;margin-bottom:3px}
.cal-q-answer{font-size:12px;color:var(--slate-600);padding-left:8px}

/* Notification prompt */
.notif-bar{background:var(--amber-50);border:1px solid var(--amber-200);border-radius:8px;padding:10px 14px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--amber-600)}
.notif-bar button{padding:5px 12px;border-radius:6px;border:none;background:var(--green-500);color:#fff;font-size:12px;font-weight:500;cursor:pointer}
.notif-bar button:hover{background:var(--green-600)}
.notif-bar .notif-dismiss{background:transparent;color:var(--slate-400);border:none;font-size:16px;cursor:pointer;padding:2px 6px}

/* Habits / Streaks (row-style) */
.habit-card{border:1px solid var(--slate-200);background:#fff;border-radius:var(--radius);padding:10px;margin-bottom:8px;display:flex;align-items:center;gap:12px}
.habit-header{display:flex;align-items:center;gap:8px}
.habit-title{min-width:180px;font-weight:600;color:var(--green-600);display:flex;align-items:center;gap:8px}
.habit-days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;flex:1}
.habit-day{text-align:center}
.habit-day-lbl{font-size:10px;color:var(--slate-400);text-transform:uppercase}
.habit-circle{width:28px;height:28px;border-radius:50%;border:2px solid var(--slate-300);display:flex;align-items:center;justify-content:center;background:#fff;color:var(--slate-500);cursor:pointer;user-select:none;margin:2px auto 0}
.habit-circle:hover{border-color:var(--green-400)}
.habit-circle.done{background:var(--green-500);border-color:var(--green-500);color:#fff}
.habit-circle.disabled{opacity:.4;pointer-events:none}
.habit-val{font-size:10px;color:var(--slate-400);height:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
