/* ===== L&L LUZ — cute couple schedule ===== */
:root{
  --bg:#FCEFE7;
  --bg2:#F8E3D6;
  --card:#FFFFFF;
  --ink:#3B2B26;
  --ink2:#6E574E;
  --muted:#A89189;
  --line:#F0DDD2;
  --line2:#EAD3C6;

  --accent:#E8907E;       /* coral — app primary */
  --accent-deep:#D9705C;
  --accent-soft:#FBE3DC;

  --lior:#4F9BD0;         /* him — blue */
  --lior-soft:#E1F0F9;
  --lior-deep:#3A82B6;
  --liron:#E87BA2;        /* her — pink */
  --liron-soft:#FBE2EC;
  --liron-deep:#D45A86;
  --both:#B07BD6;         /* together — purple */
  --both-soft:#F0E4FA;
  --both-deep:#9457C4;

  --mint:#5FC2A0;
  --mint-soft:#DDF4EC;
  --butter:#F2B84B;
  --butter-soft:#FBEECF;
  --sky:#62B6E6;
  --lilac:#B49BE6;
  --blush:#F08FA0;

  --ok:#4FB783;
  --warn:#E8A33D;
  --danger:#E2685E;

  --r-lg:26px;
  --r-md:18px;
  --r-sm:12px;
  --sh-sm:0 2px 8px rgba(140,90,70,.08);
  --sh-md:0 8px 24px rgba(150,90,70,.12);
  --sh-lg:0 16px 44px rgba(150,90,70,.18);
  --maxw:468px;
  --nav-h:74px;
  --font:'Rubik',-apple-system,system-ui,sans-serif;
  --display:'Baloo 2','Rubik',sans-serif;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;height:100%;}
body{
  font-family:var(--font);
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 80% -10%, #FBDFE9 0%, transparent 55%),
    radial-gradient(1000px 600px at -10% 10%, #DCEEFB 0%, transparent 50%),
    var(--bg);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,textarea,select{font-family:inherit;}
img{display:block;}
::-webkit-scrollbar{width:0;height:0;}

/* ===== App frame ===== */
#root{height:100%;}
.app{
  position:relative;
  width:100%;max-width:var(--maxw);
  height:100dvh;
  margin:0 auto;
  background:var(--bg);
  background-image:
    radial-gradient(900px 400px at 90% -5%, #FBDFE9 0%, transparent 60%),
    radial-gradient(700px 380px at 0% 8%, #DEEEFA 0%, transparent 55%);
  box-shadow:var(--sh-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  isolation:isolate;
}
@media(min-width:520px){
  .app{height:min(940px,96dvh);margin-top:max(0px,calc((100dvh - 940px)/2));border-radius:38px;border:1px solid rgba(255,255,255,.6);}
}
.screen{
  flex:1;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding:0 16px calc(var(--nav-h) + 26px);
  scroll-behavior:smooth;
}
.screen.noscroll{overflow:hidden;}
.main{flex:1;min-height:0;display:flex;flex-direction:column;}

/* ===== Top bar ===== */
.topbar{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px 10px;
}
.brand{display:flex;align-items:center;gap:9px;}
.brand-mark{
  width:38px;height:38px;border-radius:13px;
  display:grid;place-items:center;color:#fff;font-weight:800;
  background:linear-gradient(135deg,var(--liron),var(--accent) 55%,var(--lior));
  box-shadow:var(--sh-sm);font-size:13px;letter-spacing:.5px;
  transform:rotate(-4deg);
}
.brand-name{font-family:var(--display);font-weight:800;font-size:19px;line-height:1;letter-spacing:.3px;}
.brand-name small{display:block;font-family:var(--font);font-weight:500;font-size:10.5px;color:var(--muted);letter-spacing:2px;margin-top:3px;}
.topbar-sp{flex:1;}
.icon-btn{
  width:40px;height:40px;border-radius:13px;display:grid;place-items:center;
  background:rgba(255,255,255,.7);box-shadow:var(--sh-sm);color:var(--ink2);
  transition:transform .15s, background .15s;
}
.icon-btn:active{transform:scale(.92);}
.icon-btn.dot{position:relative;}
.icon-btn.dot::after{content:'';position:absolute;top:8px;inset-inline-end:8px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid #fff;}

/* ===== Bottom nav ===== */
.nav{
  position:absolute;bottom:0;inset-inline:0;height:var(--nav-h);
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--line);
  display:flex;align-items:stretch;justify-content:space-around;
  padding:8px 8px calc(8px + env(safe-area-inset-bottom));
  z-index:40;
}
.nav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--muted);font-size:10.5px;font-weight:600;position:relative;transition:color .15s;
}
.nav-item .ni{width:25px;height:25px;display:grid;place-items:center;transition:transform .2s;}
.nav-item.active{color:var(--accent-deep);}
.nav-item.active .ni{transform:translateY(-2px);}
.nav-item.center{flex:1;}
.nav-item .nav-label{line-height:1;}
.nav-item.center .ni{
  width:58px;height:58px;margin-top:-22px;border-radius:20px;
  background:linear-gradient(140deg,var(--liron),var(--accent));
  color:#fff;box-shadow:0 10px 22px rgba(216,110,92,.42);transform:rotate(-4deg);transition:transform .18s,background .2s;
}
.nav-item.center:active .ni{transform:rotate(-4deg) scale(.9);}
.nav-item.center.active .ni{background:linear-gradient(140deg,var(--both),var(--liron));box-shadow:0 10px 24px rgba(176,123,214,.5);}
.nav-item.center .ni svg{width:26px;height:26px;}
.nav-item.center .nav-label{display:none;}
.nav-fab{
  width:58px;height:58px;margin-top:-22px;border-radius:20px;
  background:linear-gradient(140deg,var(--liron),var(--accent));
  display:grid;place-items:center;color:#fff;box-shadow:0 10px 22px rgba(216,110,92,.42);
  transition:transform .18s;transform:rotate(-4deg);
}
.nav-fab:active{transform:rotate(-4deg) scale(.9);}
.nav-item.active .nav-dot{position:absolute;top:-2px;width:5px;height:5px;border-radius:50%;background:var(--accent);}

/* ===== Generic ===== */
.card{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:16px;}
.sect-h{display:flex;align-items:center;gap:9px;margin:22px 2px 12px;}
.sect-h h2{font-family:var(--display);font-size:18px;font-weight:700;margin:0;}
.sect-h .emoji{font-size:18px;}
.sect-h .sp{flex:1;}
.sect-h .more{font-size:12.5px;font-weight:600;color:var(--accent-deep);background:var(--accent-soft);padding:5px 11px;border-radius:20px;}
.muted{color:var(--muted);}
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:20px;font-size:12px;font-weight:600;}
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:22px;font-size:13px;font-weight:600;background:#fff;box-shadow:var(--sh-sm);color:var(--ink2);transition:transform .12s;}
.chip:active{transform:scale(.95);}
.chip.on{background:var(--ink);color:#fff;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:16px;font-weight:700;font-size:14.5px;transition:transform .14s,box-shadow .14s;}
.btn:active{transform:scale(.97);}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#fff;box-shadow:0 8px 18px rgba(216,110,92,.34);}
.btn-ghost{background:#fff;color:var(--ink);box-shadow:var(--sh-sm);}
.btn-soft{background:var(--accent-soft);color:var(--accent-deep);}
.btn-block{width:100%;}

.avatar{border-radius:50%;object-fit:cover;background:var(--line);box-shadow:0 0 0 2.5px #fff,var(--sh-sm);}
.av-ring-lior{box-shadow:0 0 0 2.5px var(--lior),0 2px 8px rgba(0,0,0,.12);}
.av-ring-liron{box-shadow:0 0 0 2.5px var(--liron),0 2px 8px rgba(0,0,0,.12);}

/* ===== Segmented (who) ===== */
.seg{display:flex;background:rgba(255,255,255,.7);border-radius:16px;padding:4px;gap:4px;box-shadow:inset 0 0 0 1px var(--line);}
.seg button{flex:1;padding:9px 6px;border-radius:12px;font-weight:700;font-size:13px;color:var(--ink2);display:flex;align-items:center;justify-content:center;gap:6px;transition:.18s;}
.seg button .sav{width:20px;height:20px;border-radius:50%;object-fit:cover;}
.seg button.on{color:#fff;box-shadow:var(--sh-sm);}
.seg button.on.me{background:var(--lior);}
.seg button.on.her{background:var(--liron);}
.seg button.on.us{background:var(--both);}

/* ===== Today header ===== */
.hero{
  position:relative;border-radius:var(--r-lg);overflow:hidden;margin-top:2px;
  box-shadow:var(--sh-md);aspect-ratio:16/12;
}
.hero img{width:100%;height:100%;object-fit:cover;transition:opacity .9s ease;}
.hero .grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(40,18,12,.06) 40%,rgba(40,18,12,.62) 100%);}
.hero .hero-top{position:absolute;top:12px;inset-inline:14px;display:flex;align-items:center;justify-content:space-between;}
.hero .hb{background:rgba(255,255,255,.9);padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700;color:var(--ink);box-shadow:var(--sh-sm);}
.hero .hero-cap{position:absolute;bottom:14px;inset-inline:16px;color:#fff;}
.hero .hero-cap h1{font-family:var(--display);font-size:23px;margin:0 0 3px;font-weight:800;text-shadow:0 2px 12px rgba(0,0,0,.3);}
.hero .hero-cap p{margin:0;font-size:13px;font-weight:500;opacity:.95;text-shadow:0 1px 8px rgba(0,0,0,.4);}
.hero-dots{position:absolute;bottom:14px;inset-inline-end:16px;display:flex;gap:5px;}
.hero-dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);}
.hero-dots i.on{background:#fff;width:16px;border-radius:3px;}

.couple-strip{display:flex;align-items:center;gap:10px;margin:14px 2px 4px;}
.couple-strip .av{width:44px;height:44px;}
.couple-strip .heart{color:var(--accent);font-size:15px;}
.couple-strip .who{font-weight:700;font-size:14px;}
.couple-strip .who small{display:block;font-weight:500;color:var(--muted);font-size:11px;}

/* ===== Daily summary ===== */
.summary{
  background:linear-gradient(135deg,#fff 0%,var(--accent-soft) 130%);
  border-radius:var(--r-lg);padding:16px;box-shadow:var(--sh-sm);position:relative;overflow:hidden;
}
.summary .ai-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--both-deep);background:var(--both-soft);padding:5px 10px;border-radius:20px;}
.summary p{margin:11px 0 0;font-size:14px;line-height:1.6;color:var(--ink);}
.summary .hl{font-weight:700;color:var(--accent-deep);}
.summary .hl.b{color:var(--lior-deep);}
.summary .hl.p{color:var(--liron-deep);}

/* ===== Timeline ===== */
.timeline{margin-top:6px;}
.tl-row{display:flex;gap:12px;align-items:stretch;}
.tl-time{width:50px;flex:none;text-align:end;padding-top:2px;}
.tl-time b{font-size:13px;font-weight:700;}
.tl-time span{display:block;font-size:10.5px;color:var(--muted);}
.tl-track{width:14px;flex:none;display:flex;flex-direction:column;align-items:center;}
.tl-track .dot{width:13px;height:13px;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 1.5px var(--line2);margin-top:4px;}
.tl-track .line{flex:1;width:2px;background:var(--line2);margin:3px 0;border-radius:2px;}
.tl-card{flex:1;margin-bottom:14px;border-radius:var(--r-md);padding:12px 14px;position:relative;overflow:hidden;box-shadow:var(--sh-sm);}
.tl-card .ev-top{display:flex;align-items:center;gap:8px;}
.tl-card h3{margin:0;font-size:14.5px;font-weight:700;flex:1;}
.tl-card .ev-meta{font-size:12px;color:var(--ink2);margin-top:5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.tl-card .ev-img{width:42px;height:42px;border-radius:12px;object-fit:cover;flex:none;box-shadow:var(--sh-sm);}
.tl-card .who-tag{width:22px;height:22px;border-radius:50%;object-fit:cover;}
.ev-lior{background:var(--lior-soft);border-inline-start:4px solid var(--lior);}
.ev-liron{background:var(--liron-soft);border-inline-start:4px solid var(--liron);}
.ev-both{background:var(--both-soft);border-inline-start:4px solid var(--both);}
.ev-task{background:var(--butter-soft);border-inline-start:4px solid var(--butter);}

/* ===== Running late sheet / chips ===== */
.late-row{display:flex;gap:10px;margin-top:8px;}
.late-card{flex:1;background:#fff;border-radius:var(--r-md);padding:13px;box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:7px;align-items:flex-start;}
.late-card .lc-ic{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;}
.late-card b{font-size:13.5px;}
.late-card span{font-size:11.5px;color:var(--muted);line-height:1.4;}

/* ===== Week view ===== */
.week-head{display:flex;gap:6px;margin:8px 0 4px;}
.wd{flex:1;text-align:center;border-radius:14px;padding:8px 2px;background:#fff;box-shadow:var(--sh-sm);transition:.15s;}
.wd small{font-size:10px;color:var(--muted);font-weight:600;display:block;}
.wd b{font-size:15px;font-weight:700;display:block;margin-top:2px;}
.wd .wd-dots{display:flex;gap:2px;justify-content:center;margin-top:4px;height:5px;}
.wd .wd-dots i{width:5px;height:5px;border-radius:50%;}
.wd.on{background:var(--ink);}
.wd.on small,.wd.on b{color:#fff;}
.wd.today b{color:var(--accent-deep);}
.wd.on.today b{color:#fff;}

.grid-day{position:relative;margin-top:10px;}
.hourline{display:flex;gap:10px;align-items:flex-start;height:58px;}
.hourline .hl-t{width:42px;font-size:11px;color:var(--muted);flex:none;text-align:end;transform:translateY(-6px);}
.hourline .hl-l{flex:1;border-top:1px dashed var(--line2);}
.gd-events{position:absolute;inset-inline-start:52px;inset-inline-end:0;top:0;bottom:0;}
.gd-ev{position:absolute;border-radius:12px;padding:7px 9px;font-size:12px;overflow:hidden;box-shadow:var(--sh-sm);}
.gd-ev b{font-size:12.5px;font-weight:700;display:block;line-height:1.2;}
.gd-ev span{font-size:10.5px;opacity:.85;}

/* ===== Find time together ===== */
.ft-banner{background:linear-gradient(135deg,var(--both),var(--both-deep));color:#fff;border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-md);position:relative;overflow:hidden;}
.ft-banner h2{font-family:var(--display);margin:0 0 4px;font-size:20px;}
.ft-banner p{margin:0;font-size:13px;opacity:.92;}
.ft-banner .blob{position:absolute;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.13);top:-40px;inset-inline-end:-20px;}
.slot{display:flex;align-items:center;gap:12px;background:#fff;border-radius:var(--r-md);padding:13px 14px;box-shadow:var(--sh-sm);margin-bottom:10px;}
.slot .slot-day{width:48px;flex:none;text-align:center;}
.slot .slot-day b{display:block;font-size:17px;font-weight:800;color:var(--both-deep);}
.slot .slot-day small{font-size:10px;color:var(--muted);}
.slot .slot-mid{flex:1;}
.slot .slot-mid b{font-size:14px;}
.slot .slot-mid span{display:block;font-size:11.5px;color:var(--muted);margin-top:2px;}
.slot .slot-len{font-size:11px;font-weight:700;color:var(--both-deep);background:var(--both-soft);padding:5px 9px;border-radius:14px;white-space:nowrap;}

/* ===== Date suggestions ===== */
.sug-cats{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 8px;margin:0 -16px;padding-inline:16px;}
.sug-card{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);background:#fff;margin-bottom:14px;}
.sug-card .sc-img{height:140px;position:relative;}
.sug-card .sc-img img{width:100%;height:100%;object-fit:cover;}
.sug-card .sc-tag{position:absolute;top:10px;inset-inline-start:10px;background:rgba(255,255,255,.92);padding:5px 11px;border-radius:18px;font-size:11.5px;font-weight:700;color:var(--ink);box-shadow:var(--sh-sm);}
.sug-card .sc-fav{position:absolute;top:10px;inset-inline-end:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;box-shadow:var(--sh-sm);}
.sug-card .sc-body{padding:13px 15px 15px;}
.sug-card .sc-body h3{margin:0 0 5px;font-size:16px;font-weight:700;}
.sug-card .sc-body p{margin:0;font-size:13px;color:var(--ink2);line-height:1.5;}
.sug-card .sc-foot{display:flex;align-items:center;gap:8px;margin-top:12px;}
.sug-meta{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--muted);font-weight:600;}

/* ===== Gallery ===== */
.gallery{columns:2;column-gap:10px;}
.gallery img{width:100%;border-radius:16px;margin-bottom:10px;box-shadow:var(--sh-sm);break-inside:avoid;}

/* ===== Tasks ===== */
.task-tabs{display:flex;gap:8px;overflow-x:auto;margin:0 -16px;padding:4px 16px 10px;}
.ttab{flex:none;padding:9px 15px;border-radius:18px;font-weight:700;font-size:13px;background:#fff;box-shadow:var(--sh-sm);color:var(--ink2);display:flex;align-items:center;gap:7px;transition:.15s;}
.ttab .tt-c{width:9px;height:9px;border-radius:50%;}
.ttab .tt-n{font-size:11px;background:var(--line);color:var(--ink2);border-radius:10px;padding:1px 6px;font-weight:700;}
.ttab.on{color:#fff;}
.acc{background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);margin-bottom:10px;overflow:hidden;}
.acc-h{display:flex;align-items:center;gap:10px;padding:13px 15px;}
.acc-h .ah-ic{width:30px;height:30px;border-radius:10px;display:grid;place-items:center;flex:none;}
.acc-h b{flex:1;font-size:14px;font-weight:700;}
.acc-h .ah-n{font-size:11.5px;color:var(--muted);font-weight:700;}
.acc-h .chev{transition:transform .25s;color:var(--muted);}
.acc.open .chev{transform:rotate(180deg);}
.acc-body{display:none;padding:0 12px 8px;}
.acc.open .acc-body{display:block;}
.task{display:flex;align-items:flex-start;gap:11px;padding:11px 8px;border-top:1px solid var(--line);}
.task .tk-check{width:23px;height:23px;border-radius:8px;border:2px solid var(--line2);flex:none;margin-top:1px;display:grid;place-items:center;transition:.15s;}
.task.done .tk-check{background:var(--ok);border-color:var(--ok);color:#fff;}
.task .tk-main{flex:1;min-width:0;}
.task .tk-main b{font-size:14px;font-weight:600;display:block;}
.task.done .tk-main b{text-decoration:line-through;color:var(--muted);}
.task .tk-meta{display:flex;gap:7px;flex-wrap:wrap;margin-top:6px;}
.tk-meta .m{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--ink2);background:var(--bg2);padding:3px 8px;border-radius:11px;}
.tk-meta .m.due{background:var(--accent-soft);color:var(--accent-deep);}
.tk-grip{color:var(--line2);flex:none;padding-top:2px;}
.add-task-row{display:flex;align-items:center;gap:8px;padding:10px 8px 4px;color:var(--accent-deep);font-weight:700;font-size:13.5px;}

/* ===== Pomodoro ===== */
.pomo{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:8px;}
.pomo-ring{position:relative;width:248px;height:248px;margin:10px auto 6px;}
.pomo-ring svg{transform:rotate(-90deg);}
.pomo-ring .pt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.pomo-ring .pt .tt{font-family:var(--display);font-size:54px;font-weight:800;line-height:1;letter-spacing:1px;}
.pomo-ring .pt .ph{font-size:13px;font-weight:700;color:var(--muted);margin-top:6px;text-transform:uppercase;letter-spacing:1.5px;}
.pomo-task{background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:13px 15px;display:flex;align-items:center;gap:11px;width:100%;margin:6px 0 16px;}
.pomo-task .pti{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;flex:none;}
.pomo-ctrls{display:flex;gap:12px;align-items:center;justify-content:center;}
.pomo-big{width:72px;height:72px;border-radius:24px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-deep));box-shadow:0 10px 22px rgba(216,110,92,.4);transition:transform .15s;}
.pomo-big:active{transform:scale(.92);}
.pomo-sm{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:#fff;box-shadow:var(--sh-sm);color:var(--ink2);}
.pomo-modes{display:flex;gap:8px;justify-content:center;margin:18px 0 4px;}
.pomo-stat{display:flex;gap:10px;width:100%;margin-top:20px;}
.pomo-stat .ps{flex:1;background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:13px;text-align:center;}
.pomo-stat .ps b{font-family:var(--display);font-size:22px;display:block;}
.pomo-stat .ps span{font-size:11px;color:var(--muted);font-weight:600;}

/* ===== Modal / sheet ===== */
.sheet-wrap{position:absolute;inset:0;z-index:60;display:flex;align-items:flex-end;justify-content:center;}
.sheet-bg{position:absolute;inset:0;background:rgba(40,20,15,.42);backdrop-filter:blur(2px);animation:fade .2s;}
.sheet{position:relative;width:100%;max-width:var(--maxw);background:var(--bg);border-radius:30px 30px 0 0;max-height:92%;overflow-y:auto;box-shadow:0 -10px 40px rgba(0,0,0,.2);animation:slideup .28s cubic-bezier(.2,.8,.3,1);padding:8px 18px calc(24px + env(safe-area-inset-bottom));}
@media(min-width:520px){.sheet{border-radius:30px;margin-bottom:14px;max-height:86%;}.sheet-wrap{align-items:center;}}
.sheet .grab{width:42px;height:5px;border-radius:3px;background:var(--line2);margin:8px auto 12px;}
.sheet h2{font-family:var(--display);font-size:20px;margin:4px 2px 14px;}
.field{margin-bottom:14px;}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink2);margin:0 2px 7px;}
.field input,.field textarea,.field select{
  width:100%;border:1.5px solid var(--line2);background:#fff;border-radius:14px;padding:13px 14px;font-size:14.5px;color:var(--ink);transition:.15s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.field textarea{resize:none;min-height:74px;line-height:1.5;}
.opt-row{display:flex;gap:8px;flex-wrap:wrap;}
.opt{padding:9px 14px;border-radius:14px;background:#fff;box-shadow:var(--sh-sm);font-size:13px;font-weight:600;color:var(--ink2);transition:.15s;border:2px solid transparent;}
.opt.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-deep);}
.who-pick{display:flex;gap:8px;}
.who-pick .wp{flex:1;padding:11px;border-radius:14px;background:#fff;box-shadow:var(--sh-sm);display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--ink2);border:2px solid transparent;transition:.15s;}
.who-pick .wp img{width:30px;height:30px;border-radius:50%;object-fit:cover;}
.who-pick .wp.on.me{border-color:var(--lior);background:var(--lior-soft);color:var(--lior-deep);}
.who-pick .wp.on.her{border-color:var(--liron);background:var(--liron-soft);color:var(--liron-deep);}
.who-pick .wp.on.us{border-color:var(--both);background:var(--both-soft);color:var(--both-deep);}
.file-drop{border:2px dashed var(--line2);border-radius:14px;padding:16px;text-align:center;color:var(--muted);font-size:13px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:7px;}
.file-chip{display:inline-flex;align-items:center;gap:7px;background:#fff;box-shadow:var(--sh-sm);border-radius:12px;padding:8px 11px;font-size:12.5px;font-weight:600;margin:6px 6px 0 0;}
.file-chip .fx{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-deep);flex:none;}

/* ===== Connect (calendar) ===== */
.connect-card{display:flex;align-items:center;gap:13px;background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:14px;margin-bottom:11px;}
.connect-card .cc-logo{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;flex:none;}
.connect-card .cc-main{flex:1;}
.connect-card .cc-main b{font-size:14.5px;}
.connect-card .cc-main span{display:block;font-size:12px;color:var(--muted);margin-top:2px;}
.toggle{width:48px;height:28px;border-radius:16px;background:var(--line2);position:relative;transition:.2s;flex:none;}
.toggle.on{background:var(--ok);}
.toggle i{position:absolute;top:3px;inset-inline-start:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:var(--sh-sm);transition:.2s;}
.toggle.on i{inset-inline-start:23px;}

/* ===== AI assist sheet ===== */
.ai-msg{display:flex;gap:10px;margin-bottom:14px;}
.ai-msg .ai-av{width:34px;height:34px;border-radius:12px;flex:none;display:grid;place-items:center;background:linear-gradient(135deg,var(--both),var(--lior));color:#fff;}
.ai-bubble{background:#fff;border-radius:6px 16px 16px 16px;padding:13px 15px;box-shadow:var(--sh-sm);font-size:13.5px;line-height:1.6;}
.ai-plan{background:var(--both-soft);border-radius:14px;padding:11px 13px;margin-top:10px;}
.ai-plan .api{display:flex;align-items:center;gap:9px;padding:7px 0;font-size:13px;font-weight:600;}
.ai-plan .api .t{font-weight:700;color:var(--both-deep);width:84px;flex:none;}

/* ===== recurring board ===== */
.rec{display:flex;align-items:center;gap:12px;background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:13px 14px;margin-bottom:10px;}
.rec .rc-ic{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;flex:none;font-size:19px;}
.rec .rc-main{flex:1;}
.rec .rc-main b{font-size:14.5px;}
.rec .rc-main .rc-sub{font-size:12px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.freq{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:11px;background:var(--mint-soft);color:#2f8c6b;}

/* quick add fab */
.quick-fab{
  position:absolute;bottom:calc(var(--nav-h) + 14px);inset-inline-end:16px;z-index:45;
  width:54px;height:54px;border-radius:18px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(140deg,var(--accent),var(--accent-deep));
  box-shadow:0 10px 24px rgba(216,110,92,.45);transition:transform .16s;
}
.quick-fab:active{transform:scale(.9) rotate(90deg);}

/* utility */
.toast{position:absolute;bottom:calc(var(--nav-h) + 16px);inset-inline:0;margin:0 auto;width:max-content;max-width:88%;background:var(--ink);color:#fff;padding:12px 18px;border-radius:16px;font-size:13.5px;font-weight:600;box-shadow:var(--sh-lg);z-index:80;display:flex;align-items:center;gap:9px;animation:toastin .3s;}
.fade-in{animation:fade .35s ease;}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
@keyframes slideup{from{transform:translateY(40px);opacity:.6;}to{transform:translateY(0);opacity:1;}}
@keyframes toastin{from{transform:translateY(14px);opacity:0;}to{transform:translateY(0);opacity:1;}}
@keyframes pop{0%{transform:scale(.8);}60%{transform:scale(1.08);}100%{transform:scale(1);}}
.pop{animation:pop .3s;}
.spin{animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ===================== DESKTOP ===================== */
@media(min-width:1000px){
  body{overflow:hidden;}
  .app{
    flex-direction:row;
    width:100vw;max-width:none;
    height:100dvh;
    margin:0;border-radius:0;
    border:none;
    box-shadow:none;
  }
  /* nav becomes a side rail (start side) */
  .nav{
    position:static;order:-1;height:auto;width:240px;flex:0 0 240px;
    flex-direction:column;justify-content:flex-start;align-items:stretch;gap:5px;
    border-top:none;border-inline-end:1px solid var(--line);
    background:rgba(255,255,255,.62);backdrop-filter:blur(14px);
    padding:24px 16px;
  }
  .nav-item{flex:0 0 auto;width:100%;flex-direction:row;justify-content:flex-start;gap:14px;padding:13px 15px;border-radius:16px;font-size:14.5px;font-weight:600;color:var(--ink2);transition:.15s;}
  .nav-item:hover{background:rgba(255,255,255,.7);}
  .nav-item .ni{width:26px;height:26px;transform:none;}
  .nav-item .nav-label{display:block;}
  .nav-item.active{background:var(--accent-soft);color:var(--accent-deep);}
  .nav-item.active .ni{transform:none;}
  .nav-dot{display:none;}
  /* neutralise the elevated heart on desktop -> normal row item */
  .nav-item.center{flex:0 0 auto;}
  .nav-item.center .ni{width:26px;height:26px;margin-top:0;border-radius:9px;background:none;color:inherit;box-shadow:none;transform:none;}
  .nav-item.center:active .ni{transform:none;}
  .nav-item.center .ni svg{width:24px;height:24px;}
  .nav-item.center .nav-label{display:block;}
  .nav-item.center.active{background:var(--both-soft);color:var(--both-deep);}
  .nav-item.center.active .ni{background:none;color:var(--both-deep);box-shadow:none;}

  .main{flex:1;min-width:0;}
  .topbar{padding:20px 36px 14px;}
  .screen{padding:0 36px 44px;}
  .screen > div{max-width:760px;margin-inline:auto;}
  .hero{aspect-ratio:16/8.2;}
  .gallery{columns:3;}
  .quick-fab{bottom:28px;inset-inline-end:28px;width:58px;height:58px;}
  .toast{bottom:28px;}
  .sheet-wrap{position:absolute;align-items:center;}
  .sheet{max-width:520px;border-radius:28px;max-height:84%;}
  /* a touch more air on wide cards */
  .summary,.ft-banner{padding:20px;}
}
@media(min-width:1280px){
  .screen > div{max-width:820px;}
}

/* ===================== v2: lanes, week cols, clean tasks, roomy desktop ===================== */
/* day grid — two lanes (Lior | Liron) */
.gd-ev2{position:absolute;border-radius:12px;padding:8px 10px;overflow:hidden;box-shadow:var(--sh-sm);cursor:pointer;transition:transform .12s;z-index:2;}
.gd-ev2:active{transform:scale(.98);}
.gd-ev2 b{font-size:12.5px;font-weight:700;display:block;line-height:1.25;}
.gd-ev2 span{font-size:10.5px;color:var(--ink2);display:block;margin-top:1px;}
.gd-ev2 .us-flag{font-size:10px;font-weight:700;color:var(--both-deep);margin-top:3px;}
.lane-head{display:flex;gap:6px;margin:10px 0 6px;}
.lane-head .lh-gutter{width:52px;flex:none;}
.lane-head .lh-col{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:8px;background:#fff;border-radius:12px;box-shadow:var(--sh-sm);border-bottom:3px solid var(--line2);}
.lane-head .lh-col img{width:24px;height:24px;border-radius:50%;object-fit:cover;}
.lane-head .lh-col b{font-size:13px;}
.lane-divider{position:absolute;top:0;bottom:0;inset-inline-start:49.5%;width:0;border-inline-start:1px dashed var(--line2);z-index:1;}

/* week columns */
.week-cols{display:flex;flex-direction:column;gap:10px;}
.week-col{background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:11px 13px;}
.week-col.is-today{box-shadow:0 0 0 2px var(--accent-soft),var(--sh-sm);}
.wc-head{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.wc-date{width:30px;height:30px;border-radius:10px;display:grid;place-items:center;font-weight:700;font-size:13px;background:var(--bg2);flex:none;}
.wc-head b{font-size:13.5px;}
.wc-empty{font-size:12px;color:var(--muted);padding:2px 2px 4px;}
.wc-ev{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;margin-bottom:6px;cursor:pointer;}
.wc-ev:last-child{margin-bottom:0;}
.wc-ev-t{font-size:11px;font-weight:700;color:var(--ink2);width:34px;flex:none;}
.wc-ev b{font-size:13px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wc-dot{width:8px;height:8px;border-radius:50%;flex:none;}

/* recurring grid wrapper */
.rec-intro{background:linear-gradient(135deg,#fff,var(--mint-soft) 130%);margin-bottom:14px;display:flex;gap:11px;align-items:center;}

/* clean tasks */
.tcard{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:4px 15px 6px;}
.tsec{border-top:1px solid var(--line);}
.tsec:first-child{border-top:none;}
.tsec-h{display:flex;align-items:center;gap:9px;width:100%;padding:15px 2px 9px;}
.tsec-dot{width:9px;height:9px;border-radius:50%;flex:none;}
.tsec-h b{font-size:13px;font-weight:700;}
.tsec-n{font-size:11px;font-weight:700;color:var(--muted);background:var(--bg2);border-radius:10px;padding:1px 8px;}
.trow{display:flex;align-items:flex-start;gap:11px;padding:11px 2px;}
.trow + .trow{border-top:1px solid var(--line);}
.trow.done .tk-main b{text-decoration:line-through;color:var(--muted);}
.trow.done .tk-check{background:var(--ok);border-color:var(--ok);color:#fff;}
.tk-focus{flex:none;padding-top:1px;width:30px;height:30px;display:grid;place-items:center;border-radius:9px;}
.tk-focus:active{background:var(--accent-soft);}
.tadd{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:14px;color:var(--accent-deep);font-weight:700;font-size:13.5px;border-top:1px solid var(--line);margin-top:2px;}

/* roomy desktop */
@media(min-width:1000px){
  .screen > div{max-width:1060px;margin-inline:auto;}
  .today-wrap{display:grid;grid-template-columns:1.04fr 1fr;gap:26px;align-items:start;}
  .today-b .sect-h{margin-top:0;}
  .slot-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  .slot-list .slot{margin-bottom:0;}
  .sug-list{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
  .sug-list .sug-card{margin-bottom:0;}
  .gallery{columns:4;}
  .week-cols{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;align-items:start;}
  .week-col{min-height:180px;padding:12px 11px;}
  .wc-head{flex-wrap:wrap;}
  .wc-ev{flex-wrap:wrap;}
  .rec-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  .rec-grid .rec{margin-bottom:0;}
  .rec-intro{grid-column:1/-1;}
  .rec-add{grid-column:1/-1;}
}
@media(min-width:1280px){
  .screen > div{max-width:1180px;}
}

/* ===================== v3: glance, schedule views, editable cats/types, flexible time ===================== */
.glance{display:flex;align-items:center;gap:12px;margin:14px 2px 2px;background:#fff;border-radius:18px;padding:9px 14px;box-shadow:var(--sh-sm);}
.glance-avs{display:flex;flex:none;}
.glance-avs img{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2.5px solid #fff;}
.glance-avs img:last-child{margin-inline-start:-13px;}
.glance-txt{flex:1;min-width:0;}
.glance-txt b{font-size:14px;display:block;}
.glance-txt span{font-size:11.5px;color:var(--muted);}
.glance-count{text-align:center;background:var(--accent-soft);border-radius:14px;padding:6px 13px;flex:none;}
.glance-count b{font-family:var(--display);font-size:18px;color:var(--accent-deep);display:block;line-height:1;}
.glance-count span{font-size:9.5px;color:var(--accent-deep);font-weight:600;}

.view-tabs{display:flex;gap:7px;margin:0 -16px 12px;padding:2px 16px 6px;overflow-x:auto;}
.view-tabs .chip{flex:none;}

/* multi-day (3-day) */
.md-head{display:grid;gap:5px;margin-bottom:5px;}
.md-col-h{text-align:center;padding:7px 2px;background:#fff;border-radius:11px;box-shadow:var(--sh-sm);cursor:pointer;}
.md-col-h small{font-size:10px;color:var(--muted);font-weight:600;display:block;}
.md-col-h b{font-size:15px;}
.md-col-h.today{background:var(--ink);}
.md-col-h.today small,.md-col-h.today b{color:#fff;}
.md-grid{display:grid;gap:5px;}
.md-hours{position:relative;}
.md-h{font-size:9.5px;color:var(--muted);text-align:end;padding-inline-end:4px;transform:translateY(-5px);}
.md-col{position:relative;background:#fff;border-radius:11px;overflow:hidden;box-shadow:var(--sh-sm);}
.md-line{border-top:1px solid var(--line);}
.md-line:first-child{border-top:none;}
.md-evs{position:absolute;inset:0;}
.md-ev{position:absolute;inset-inline:2px;border-radius:8px;padding:3px 5px;overflow:hidden;cursor:pointer;box-shadow:var(--sh-sm);}
.md-ev b{font-size:10px;font-weight:700;display:block;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.md-ev span{font-size:8.5px;color:var(--ink2);}

/* month */
.mo-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:6px;}
.mo-dow span{text-align:center;font-size:11px;font-weight:700;color:var(--muted);}
.mo-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.mo-cell{aspect-ratio:1;background:#fff;border-radius:12px;box-shadow:var(--sh-sm);padding:5px 4px;display:flex;flex-direction:column;align-items:center;gap:3px;position:relative;cursor:pointer;transition:transform .12s;}
.mo-cell:active{transform:scale(.94);}
.mo-cell.empty{background:transparent;box-shadow:none;cursor:default;}
.mo-cell.today{box-shadow:0 0 0 2px var(--accent);}
.mo-d{font-size:13px;font-weight:700;}
.mo-cell.today .mo-d{color:var(--accent-deep);}
.mo-dots{display:flex;gap:2px;flex-wrap:wrap;justify-content:center;}
.mo-dots i{width:5px;height:5px;border-radius:50%;}
.mo-n{position:absolute;top:4px;inset-inline-end:6px;font-size:9px;color:var(--muted);font-weight:700;}
.mo-legend{display:flex;gap:16px;justify-content:center;margin-top:16px;flex-wrap:wrap;}
.mo-legend span{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--ink2);font-weight:600;}
.mo-legend i{width:8px;height:8px;border-radius:50%;}

/* inline add + manage for cats/types */
.opt.opt-add{border:2px dashed var(--line2);background:var(--bg2);color:var(--accent-deep);}
.opt.opt-edit{margin-inline-start:auto;border:none;background:none;box-shadow:none;color:var(--muted);padding:9px 6px;}
.inline-add{background:var(--bg2);border-radius:14px;padding:12px;margin-top:8px;}
.inline-add .ia-row{display:flex;gap:8px;align-items:center;}
.inline-add input{flex:1;}
.emoji-row,.color-row{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px;}
.emoji-pick{width:38px;height:38px;border-radius:11px;background:#fff;box-shadow:var(--sh-sm);font-size:19px;display:grid;place-items:center;border:2px solid transparent;}
.emoji-pick.on{border-color:var(--accent);}
.color-pick{width:30px;height:30px;border-radius:50%;box-shadow:var(--sh-sm);border:3px solid #fff;outline:2px solid transparent;}
.color-pick.on{outline-color:var(--ink);}

/* manage list */
.mng-tabs{display:flex;gap:8px;margin-bottom:14px;}
.mng-tabs .chip{flex:1;justify-content:center;}
.mng-item{display:flex;align-items:center;gap:11px;background:#fff;border-radius:14px;box-shadow:var(--sh-sm);padding:11px 13px;margin-bottom:9px;}
.mng-item .mi-ic{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;flex:none;font-size:18px;color:#fff;}
.mng-item b{flex:1;font-size:14px;}
.mng-item .mi-btn{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;color:var(--muted);}
.mng-item .mi-btn:active{background:var(--bg2);}

/* flexible time */
.est-stepper{display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--line2);border-radius:14px;padding:8px 12px;}
.est-stepper .est-btn{width:40px;height:40px;border-radius:12px;background:var(--accent-soft);color:var(--accent-deep);display:grid;place-items:center;font-size:22px;font-weight:700;flex:none;transition:transform .12s;}
.est-stepper .est-btn:active{transform:scale(.9);}
.est-stepper .est-mid{flex:1;text-align:center;}
.est-stepper .est-mid input{width:72px;text-align:center;border:none;font-family:var(--display);font-size:24px;font-weight:800;color:var(--ink);background:none;padding:0;}
.est-stepper .est-mid input:focus{outline:none;}
.est-stepper .est-mid small{display:block;font-size:11px;color:var(--muted);font-weight:600;margin-top:-2px;}

@media(min-width:1000px){
  .md-grid .md-ev b{font-size:11.5px;}
  .mo-cell .mo-d{font-size:15px;}
}

/* ===== auth gate: splash + login (added for full-stack build) ===== */
.splash{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg);}
.splash-mark{width:72px;height:72px;border-radius:20px;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:800;color:#fff;font-size:24px;transform:rotate(-6deg);
  background:linear-gradient(135deg,var(--accent),var(--liron));box-shadow:var(--sh-md);animation:pulse 1.3s ease-in-out infinite;}
@keyframes pulse{0%,100%{transform:rotate(-6deg) scale(1);opacity:.9;}50%{transform:rotate(-6deg) scale(1.08);opacity:1;}}

.login-wrap{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  padding:24px;background:
    radial-gradient(120% 80% at 80% 0%, var(--liron-soft), transparent 60%),
    radial-gradient(120% 80% at 0% 100%, var(--lior-soft), transparent 60%), var(--bg);}
.login-lang{position:fixed;top:16px;inset-inline-end:16px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:8px 12px;font-weight:700;color:var(--ink2);box-shadow:var(--sh-sm);}
.login-card{width:100%;max-width:380px;background:var(--card);border-radius:var(--r-lg);padding:28px 22px;
  box-shadow:var(--sh-lg);text-align:center;}
.login-mark{width:64px;height:64px;margin:0 auto 14px;border-radius:18px;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:800;color:#fff;font-size:22px;transform:rotate(-6deg);
  background:linear-gradient(135deg,var(--accent),var(--liron));box-shadow:var(--sh-md);}
.login-card h1{font-family:var(--display);font-size:24px;margin:0 0 4px;color:var(--ink);}
.login-card .muted{font-size:13.5px;line-height:1.5;}
.login-card .field{text-align:start;}
.login-sent{display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:10px;}
.login-foot{color:var(--muted);font-size:12px;}
.btn-ghost.btn-block{display:flex;align-items:center;}

/* ===== anniversary card ===== */
.anniv-card{display:flex;align-items:center;gap:12px;margin-top:12px;padding:13px 15px;border-radius:var(--r-md);
  background:linear-gradient(120deg,var(--accent-soft),var(--liron-soft));box-shadow:var(--sh-sm);}
.anniv-card .anniv-emoji{font-size:26px;}
.anniv-card b{display:block;font-size:14px;color:var(--ink);font-family:var(--display);}
.anniv-card span{display:block;font-size:11.5px;color:var(--ink2);margin-top:2px;}

/* ===== gallery upload tile + delete ===== */
.gallery .gphoto{position:relative;break-inside:avoid;margin-bottom:10px;}
.gallery .gphoto img{width:100%;border-radius:16px;box-shadow:var(--sh-sm);display:block;}
.gallery .gphoto .gdel{position:absolute;top:8px;inset-inline-end:8px;width:28px;height:28px;border-radius:50%;
  background:rgba(0,0,0,.45);color:#fff;display:grid;place-items:center;backdrop-filter:blur(4px);}
.gallery-add{width:100%;border:2px dashed var(--line2);background:var(--bg2);border-radius:16px;
  padding:22px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--accent-deep);
  font-weight:700;font-size:13px;margin-bottom:10px;break-inside:avoid;}
