@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&display=swap');
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;width:100%;overflow:hidden;font-family:'Lato',sans-serif;background:#0a0e1a;}

.db{
  position:fixed;top:0;left:0;right:0;bottom:0;
  display:flex;flex-direction:column;
  overflow:hidden;
}

/* ── Background slideshow ───────────────────────────────────────────────────── */
.bg-slideshow{
  position:absolute;top:0;left:0;right:0;bottom:0;
  overflow:hidden;
  background:#0a0e1a;
}
.bg-slideshow img{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  transition:opacity 1.5s ease;
  opacity:0;
}
.bg-slideshow img.active{opacity:0.6;}

.overlay-top{
  position:absolute;top:0;left:0;right:0;
  height:200px;
  background:linear-gradient(to bottom,rgba(0,0,0,0.8) 0%,rgba(0,0,0,0) 100%);
  z-index:2;pointer-events:none;
}
.overlay-bot{
  position:absolute;bottom:0;left:0;right:0;
  height:320px;
  background:linear-gradient(to top,rgba(0,0,0,0.95) 0%,rgba(0,0,0,0.6) 50%,rgba(0,0,0,0) 100%);
  z-index:2;pointer-events:none;
}

/* ── Top bar ────────────────────────────────────────────────────────────────── */
.topbar{
  position:relative;z-index:10;
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:16px 20px 12px;
  flex-shrink:0;
}
.tb-time{font-size:56px;font-weight:300;color:#fff;line-height:1;letter-spacing:-1px;text-shadow:0 2px 16px rgba(0,0,0,0.6);}
.tb-date{font-size:14px;font-weight:300;color:rgba(255,255,255,0.7);margin-top:4px;letter-spacing:0.02em;}
.tb-right{display:flex;gap:20px;align-items:flex-start;}
.tb-wx{text-align:right;}
.tb-wx-main{display:flex;align-items:center;gap:6px;justify-content:flex-end;}
.tb-wx-icon{font-size:28px;}
.tb-wx-temp{font-size:38px;font-weight:300;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,0.5);}
.tb-wx-detail{font-size:11px;color:rgba(255,255,255,0.5);margin-top:3px;text-align:right;line-height:1.6;}
.tb-moon{text-align:center;}
.tb-moon-icon{font-size:32px;display:block;line-height:1;}
.tb-moon-label{font-size:9px;color:rgba(255,255,255,0.4);margin-top:3px;white-space:nowrap;letter-spacing:0.04em;text-transform:uppercase;}
.tb-actions{display:flex;flex-direction:column;gap:5px;align-items:flex-end;}
.top-btn{background:rgba(255,255,255,0.08);border:0.5px solid rgba(255,255,255,0.15);border-radius:20px;padding:5px 12px;font-size:10px;color:rgba(255,255,255,0.55);cursor:pointer;font-family:'Lato',sans-serif;white-space:nowrap;transition:background 0.15s;}
.top-btn:hover{background:rgba(255,255,255,0.16);color:#fff;}
.logout-btn{border-color:rgba(255,100,100,0.2);color:rgba(255,150,150,0.6);}
.logout-btn:hover{background:rgba(200,50,50,0.2);color:rgba(255,150,150,0.9);}

/* ── Photo area (middle flex space) ────────────────────────────────────────── */
.photo-area{flex:1;position:relative;z-index:3;}

/* ── Week strip ─────────────────────────────────────────────────────────────── */
.week-strip{
  position:relative;z-index:10;
  display:grid;grid-template-columns:repeat(7,1fr);
  gap:5px;padding:8px 12px 12px;
  flex-shrink:0;
}
.day{
  background:rgba(0,0,0,0.45);
  backdrop-filter:blur(12px);
  border:0.5px solid rgba(255,255,255,0.1);
  border-radius:8px;overflow:hidden;
  display:flex;flex-direction:column;
  min-height:160px;
}
.day.today{border-color:rgba(120,180,255,0.5);background:rgba(15,50,120,0.5);}
.day-hdr{
  padding:5px 7px;
  background:rgba(0,0,0,0.3);
  border-bottom:0.5px solid rgba(255,255,255,0.06);
  text-align:center;flex-shrink:0;
}
.day-name{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.4);}
.today .day-name{color:rgba(150,210,255,0.9);}
.day-num{font-size:18px;font-weight:300;color:rgba(255,255,255,0.9);line-height:1.2;}
.today .day-num{color:#fff;}
.day-wx{
  padding:5px 7px;
  border-bottom:0.5px solid rgba(255,255,255,0.05);
  text-align:center;flex-shrink:0;
}
.day-wx-row{display:flex;align-items:center;justify-content:center;gap:4px;}
.day-wx-icon{font-size:14px;}
.day-wx-hi{font-size:12px;font-weight:700;color:#fff;}
.day-wx-lo{font-size:10px;color:rgba(255,255,255,0.4);}
.day-wx-precip{font-size:9px;color:#7ec8f0;margin-top:2px;}
.day-cal{
  padding:4px 6px;
  border-bottom:0.5px solid rgba(255,255,255,0.05);
  min-height:26px;flex-shrink:0;
}
.cal-pill{font-size:8px;padding:2px 4px;border-radius:3px;margin-bottom:2px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cal-pill.you{background:rgba(55,138,221,0.3);color:rgba(150,210,255,0.95);}
.cal-pill.spouse{background:rgba(212,83,126,0.3);color:rgba(255,170,200,0.95);}
.cal-free{font-size:8px;color:rgba(255,255,255,0.15);}
.day-menu{padding:4px 6px;flex:1;overflow:hidden;}
.menu-meal{margin-bottom:4px;}
.meal-type{font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:rgba(255,255,255,0.25);}
.meal-name{font-size:9px;color:rgba(255,255,255,0.85);line-height:1.3;}
.meal-link{font-size:8px;color:#7ec8f0;text-decoration:none;display:inline-block;margin-top:1px;}
.meal-link:hover{text-decoration:underline;}
.meal-add{font-size:8px;color:rgba(255,255,255,0.2);background:none;border:none;cursor:pointer;padding:2px 0;font-family:'Lato',sans-serif;display:block;}
.meal-add:hover{color:rgba(255,255,255,0.65);}
.meal-del{font-size:9px;color:rgba(255,100,100,0.3);background:none;border:none;cursor:pointer;padding:0;margin-left:4px;font-family:'Lato',sans-serif;}
.meal-del:hover{color:rgba(255,100,100,0.8);}

/* ── Meal form ───────────────────────────────────────────────────────────────── */
.meal-form{
  position:absolute;bottom:220px;left:50%;transform:translateX(-50%);
  width:340px;z-index:40;
  background:rgba(6,10,22,0.97);
  border:0.5px solid rgba(255,255,255,0.12);
  border-radius:12px;padding:16px;
  display:none;
  backdrop-filter:blur(20px);
}
.meal-form.open{display:block;}
.mf-title{font-size:12px;font-weight:700;color:#fff;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:12px;}
.mf-row{margin-bottom:8px;}
.mf-label{font-size:11px;color:rgba(255,255,255,0.4);display:block;margin-bottom:3px;}
.mf-input,.mf-select{width:100%;background:rgba(255,255,255,0.07);border:0.5px solid rgba(255,255,255,0.12);border-radius:6px;padding:7px 10px;font-size:13px;color:#fff;font-family:'Lato',sans-serif;}
.mf-input::placeholder{color:rgba(255,255,255,0.2);}
.mf-actions{display:flex;gap:8px;margin-top:12px;}
.mf-btn{font-size:12px;padding:7px 18px;border-radius:6px;border:0.5px solid rgba(255,255,255,0.15);background:rgba(255,255,255,0.08);color:#fff;cursor:pointer;font-family:'Lato',sans-serif;transition:background 0.15s;}
.mf-btn:hover{background:rgba(255,255,255,0.18);}
.mf-btn.primary{background:#185FA5;border-color:#185FA5;}
.mf-btn.primary:hover{background:#0C447C;}

/* ── Side tabs ───────────────────────────────────────────────────────────────── */
.side-btns{position:absolute;right:0;top:50%;transform:translateY(-50%);z-index:20;display:flex;flex-direction:column;gap:5px;}
.side-btn{writing-mode:vertical-rl;background:rgba(0,0,0,0.5);backdrop-filter:blur(8px);border:0.5px solid rgba(255,255,255,0.12);border-radius:8px 0 0 8px;padding:12px 7px;font-size:9px;font-weight:700;color:rgba(255,255,255,0.6);letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;transition:background 0.15s;user-select:none;}
.side-btn:hover,.side-btn.active{background:rgba(255,255,255,0.12);color:#fff;}

/* ── Side panels ─────────────────────────────────────────────────────────────── */
.side-panel{position:absolute;right:-310px;top:0;bottom:0;width:290px;background:rgba(5,8,18,0.97);backdrop-filter:blur(20px);border-left:0.5px solid rgba(255,255,255,0.08);z-index:30;transition:right 0.25s ease;display:flex;flex-direction:column;padding:16px 14px;overflow-y:auto;}
.side-panel.open{right:0;}
.sp-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;flex-shrink:0;}
.sp-title{font-size:11px;font-weight:700;color:#fff;letter-spacing:0.08em;text-transform:uppercase;}
.sp-close{font-size:16px;color:rgba(255,255,255,0.3);cursor:pointer;line-height:1;}
.sp-close:hover{color:#fff;}

/* ── Grocery ─────────────────────────────────────────────────────────────────── */
.store-section{margin-bottom:16px;border-bottom:0.5px solid rgba(255,255,255,0.06);padding-bottom:12px;}
.store-section:last-of-type{border-bottom:none;}
.store-name{font-size:10px;font-weight:700;color:rgba(255,255,255,0.55);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px;display:flex;justify-content:space-between;}
.store-count{font-size:9px;color:rgba(255,255,255,0.2);font-weight:400;text-transform:none;letter-spacing:0;}
.loc-group{margin-bottom:6px;}
.loc-label{font-size:8px;font-weight:700;color:rgba(255,255,255,0.22);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:3px;margin-top:6px;}
.g-item{display:flex;align-items:center;gap:6px;padding:3px 0;border-bottom:0.5px solid rgba(255,255,255,0.04);}
.g-item:last-child{border-bottom:none;}
.g-check{width:11px;height:11px;border-radius:50%;border:1.5px solid rgba(255,255,255,0.2);cursor:pointer;flex-shrink:0;transition:background 0.12s;}
.g-check.done{background:#1D9E75;border-color:#1D9E75;}
.g-txt{font-size:11px;color:rgba(255,255,255,0.75);flex:1;}
.g-txt.done{opacity:0.3;text-decoration:line-through;}
.g-del{font-size:12px;color:rgba(255,255,255,0.15);background:none;border:none;cursor:pointer;padding:0;font-family:'Lato',sans-serif;}
.g-del:hover{color:rgba(255,80,80,0.7);}
.add-row{display:flex;gap:5px;margin-top:10px;flex-wrap:wrap;flex-shrink:0;}
.add-input{flex:1;min-width:80px;background:rgba(255,255,255,0.06);border:0.5px solid rgba(255,255,255,0.1);border-radius:5px;padding:6px 8px;font-size:11px;color:#fff;font-family:'Lato',sans-serif;}
.add-input::placeholder{color:rgba(255,255,255,0.2);}
.add-sel{background:rgba(255,255,255,0.06);border:0.5px solid rgba(255,255,255,0.1);border-radius:5px;padding:6px 4px;font-size:10px;color:rgba(255,255,255,0.5);font-family:'Lato',sans-serif;}
.add-btn{background:rgba(255,255,255,0.1);border:0.5px solid rgba(255,255,255,0.15);border-radius:5px;padding:6px 12px;font-size:14px;color:#fff;cursor:pointer;transition:background 0.15s;}
.add-btn:hover{background:rgba(255,255,255,0.2);}
.export-btn{margin-top:12px;width:100%;background:#185FA5;border:none;border-radius:6px;padding:9px;font-size:12px;color:#fff;cursor:pointer;font-family:'Lato',sans-serif;flex-shrink:0;transition:background 0.15s;}
.export-btn:hover{background:#0C447C;}

/* ── Todo ────────────────────────────────────────────────────────────────────── */
.todo-item{display:flex;align-items:flex-start;gap:7px;padding:6px 0;border-bottom:0.5px solid rgba(255,255,255,0.05);}
.todo-item:last-child{border-bottom:none;}
.todo-check{width:12px;height:12px;border-radius:3px;border:1.5px solid rgba(255,255,255,0.2);cursor:pointer;flex-shrink:0;margin-top:2px;transition:background 0.12s;}
.todo-check.done{background:#378ADD;border-color:#378ADD;}
.todo-txt{font-size:11px;color:rgba(255,255,255,0.8);line-height:1.4;flex:1;}
.todo-txt.done{opacity:0.3;text-decoration:line-through;}
.todo-del{font-size:12px;color:rgba(255,255,255,0.15);background:none;border:none;cursor:pointer;padding:0;font-family:'Lato',sans-serif;}
.todo-del:hover{color:rgba(255,80,80,0.7);}

/* ── Photo modal ─────────────────────────────────────────────────────────────── */
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.75);z-index:50;display:none;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:#0b1120;border:0.5px solid rgba(255,255,255,0.1);border-radius:16px;width:480px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:0.5px solid rgba(255,255,255,0.07);flex-shrink:0;}
.modal-title{font-size:12px;font-weight:700;color:#fff;letter-spacing:0.08em;text-transform:uppercase;}
.modal-close{font-size:18px;color:rgba(255,255,255,0.35);cursor:pointer;}
.modal-close:hover{color:#fff;}
.modal-body{padding:18px;overflow-y:auto;flex:1;}
.upload-zone{border:1px dashed rgba(255,255,255,0.15);border-radius:10px;padding:20px;text-align:center;cursor:pointer;margin-bottom:14px;transition:border-color 0.15s;}
.upload-zone:hover{border-color:rgba(255,255,255,0.35);}
.upload-hint{font-size:13px;color:rgba(255,255,255,0.4);}
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;}
.photo-thumb{position:relative;aspect-ratio:4/3;border-radius:8px;overflow:hidden;}
.photo-thumb img{width:100%;height:100%;object-fit:cover;}
.photo-thumb .del-btn{position:absolute;top:4px;right:4px;background:rgba(0,0,0,0.65);border:none;border-radius:50%;width:20px;height:20px;color:#fff;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.photo-thumb .del-btn:hover{background:rgba(200,40,40,0.8);}
.modal-footer{border-top:0.5px solid rgba(255,255,255,0.07);padding-top:12px;}
.footer-row{display:flex;align-items:center;gap:12px;}
.footer-row .mf-label{margin:0;min-width:110px;}

/* ── Responsive ──────────────────────────────────────────────────────────────── */
@media (max-width:768px) {
  .tb-time{font-size:36px;}
  .tb-date{font-size:11px;}
  .tb-wx-temp{font-size:26px;}
  .tb-moon-icon{font-size:22px;}
  .week-strip{gap:3px;padding:6px 6px 8px;}
  .day{min-height:130px;}
  .side-panel{width:260px;}
}
