:root{
  --pai:#6c5ce7; --pai-2:#8a7bf0; --pai-soft:#efeaff;
  --mae:#ff5b9e; --mae-2:#ff86b9; --mae-soft:#ffe9f2;
  --child:#ffb02e;
  --ink:#2c2a4a; --muted:#6b6b80; --line:#e7e6f2;
  --bg1:#f3f1ff; --bg2:#fff0f6; --card:#ffffff;
  --radius:22px; --shadow:0 12px 30px rgba(60,40,120,.14);
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:linear-gradient(160deg,var(--bg1),var(--bg2));
  min-height:100vh;-webkit-text-size-adjust:100%;
}
.wrap{max-width:600px;margin:0 auto;padding:12px 14px 36px}

/* APP BAR */
.appbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.lock{font-size:1.2rem;text-decoration:none;opacity:.55;padding:6px}

/* AVATAR (foto ou emoji em círculo colorido) */
.ava{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;background:#fff;overflow:hidden;flex:none;
  box-shadow:0 4px 12px rgba(0,0,0,.12);line-height:1;
}
.ava img{width:100%;height:100%;object-fit:cover;display:block}
.ava.pai{border:4px solid var(--pai);background:var(--pai-soft)}
.ava.mae{border:4px solid var(--mae);background:var(--mae-soft)}
.ava.child{border:4px solid var(--child);background:#fff6e6}
.ava.tiny{width:40px;height:40px;font-size:22px;border-width:3px}
.ava.mini{width:58px;height:58px;font-size:30px}
.ava.sm{width:52px;height:52px;font-size:28px;border-width:3px}
.ava.xl{width:168px;height:168px;font-size:96px;border-width:7px;box-shadow:0 14px 34px rgba(0,0,0,.22)}

/* VIEWING OTHER DAY */
.viewing{display:block;text-align:center;background:#fff;border:1px dashed var(--line);
  border-radius:14px;padding:10px 14px;margin-bottom:12px;text-decoration:none;color:var(--ink);font-size:.95rem}

/* TODAYBAR (faixa compacta de hoje) */
.todaybar{
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
  border-radius:18px;padding:10px 14px;color:#fff;margin-bottom:12px;box-shadow:var(--shadow);
}
.todaybar.pai{background:linear-gradient(150deg,var(--pai),var(--pai-2))}
.todaybar.mae{background:linear-gradient(150deg,var(--mae),var(--mae-2))}
.todaybar .ava{background:#fff}
.tb-name{font-size:1.5rem;font-weight:800}
.tb-dn{font-size:1.5rem}
.tb-side{display:flex;align-items:center;gap:6px;font-size:1.2rem}
.tb-side .ava{background:#fff}
.tb-cap{font-size:.72rem;letter-spacing:.05em;font-weight:800;text-transform:uppercase;background:rgba(255,255,255,.22);padding:4px 10px;border-radius:999px}
.tb-star{font-size:1.1rem}
.t-arrow{font-size:1.6rem}

/* SLEEPS (quantas noites) */
.sleeps{
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
  background:var(--card);border-radius:18px;padding:12px;margin-bottom:14px;
  box-shadow:0 4px 14px rgba(60,40,120,.08);
}
.sleeps .moons{font-size:1.5rem;letter-spacing:2px}
.sleeps .t-arrow{font-size:1.5rem}

/* BOTÃO HOJE */
.hoje-btn{
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 16px;
  font-weight:800;font-size:.95rem;color:var(--ink);text-decoration:none;
  box-shadow:0 3px 10px rgba(60,40,120,.10);
}
.hoje-btn.on{background:var(--child);color:#5a4500;border-color:transparent}
.hoje-btn:active{transform:scale(.96)}

/* DIVISOR VERTICAL DE SEMANA */
.wdiv{flex:0 0 auto;width:34px;align-self:stretch;display:flex;flex-direction:column;align-items:center;gap:5px;padding-top:18px}
.wdiv-badge{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.6rem;font-weight:800;color:var(--muted);white-space:nowrap}
.wdiv-dot{width:12px;height:12px;border-radius:50%}
.wdiv-dot.pai{background:var(--pai)} .wdiv-dot.mae{background:var(--mae)}
.wdiv-line{flex:1;border-left:2px dashed #cfcce6;min-height:64px}

/* TROCA PARENTAL (senha) */
.swapbar{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.swap-target{font-weight:700;color:var(--muted);font-size:.95rem}
.swap-target strong{color:var(--ink)}
.swap-btn{background:var(--child);color:#5a4500;font-weight:800}
.swap-erro{background:#ffe1e7;color:#b00030;border-radius:12px;padding:8px 12px;margin-bottom:10px;text-align:center;font-weight:700}

/* BARRA DO MÊS + IR PARA UM DIA */
.monthbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px;flex-wrap:wrap}
.month-label{font-size:1.2rem;font-weight:800;color:var(--ink)}
.gotoform{display:flex;gap:6px;align-items:center}
.gotoform input[type=date]{padding:7px 9px;font-size:.95rem}
.gotoform button{padding:8px 14px}

/* HORIZONTAL CALENDAR STRIP */
.strip{
  display:flex;gap:8px;overflow-x:auto;overflow-y:visible;padding:24px 4px 12px;margin-bottom:12px;
  scroll-behavior:auto;scroll-snap-type:none;overscroll-behavior-x:contain;cursor:grab;
  -webkit-overflow-scrolling:touch;scrollbar-width:thin;
  user-select:none;-webkit-user-select:none;
}
.strip.dragging{cursor:grabbing}
.strip.dragging .day{pointer-events:none}
.strip img{-webkit-user-drag:none;user-drag:none}
.strip::-webkit-scrollbar{height:6px}
.strip::-webkit-scrollbar-thumb{background:#d9d6ee;border-radius:3px}
.strip::-webkit-scrollbar-track{background:transparent}
.day{
  flex:0 0 auto;width:80px;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  text-decoration:none;color:var(--ink);border-radius:18px;padding:10px 6px;
  background:#fff;border:3px solid transparent;position:relative;transition:transform .15s;
}
.day.pai{background:var(--pai-soft)}
.day.mae{background:var(--mae-soft)}
.day.swap{background:#fff}
.day.weekend{box-shadow:inset 0 0 0 2px rgba(255,176,46,.5)}
.day .dow{font-size:.8rem;font-weight:800;text-transform:uppercase}
.day .dnum{font-size:.72rem;color:var(--muted);margin-top:-3px}
.day.pai .dow{color:var(--pai)} .day.mae .dow{color:var(--mae)}
.day .dn{font-size:1rem;opacity:.5}
.day .badges{display:flex;gap:2px;min-height:16px;font-size:.8rem;line-height:1}
.day.focus{
  width:100px;transform:scale(1.04);border-color:var(--ink);
  box-shadow:0 10px 24px rgba(44,42,74,.22);animation:pop .4s ease;
}
.day.focus.pai{background:var(--pai-soft)} .day.focus.mae{background:var(--mae-soft)}
.day.focus.swap{background:#fff}
.day.focus .ava.sm{width:64px;height:64px;font-size:36px}
.day.is-today:not(.focus){border-color:var(--child)}
.todaytag{position:absolute;top:-11px;background:var(--child);color:#5a4500;font-size:.6rem;font-weight:800;
  padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}
.day .here{position:absolute;top:-20px;font-size:1.4rem;animation:bounce 1s infinite}

/* pilha de avatares nos dias de troca */
.stack{display:flex;flex-direction:column;align-items:center;gap:1px}
.lvl{position:relative;display:inline-flex}
.corner{position:absolute;bottom:-3px;right:-5px;font-size:.82rem;line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.35))}
.sep{font-size:.85rem;opacity:.55;line-height:.7;margin:-1px 0}
.ava.stk{width:44px;height:44px;font-size:25px;border-width:3px}
.day.focus .ava.stk{width:54px;height:54px;font-size:31px}

@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
@keyframes pop{from{transform:scale(.9)}to{transform:scale(1.04)}}

/* ATIVIDADES no calendário */
.acts{display:flex;gap:2px;justify-content:center;font-size:.95rem;line-height:1;min-height:18px}
.day.focus .acts{font-size:1.2rem}

/* CARTÃO de atividades do dia em foco */
.dayacts{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.da-item{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:16px;padding:12px 16px;box-shadow:0 4px 14px rgba(60,40,120,.08)}
.da-emoji{font-size:2rem;line-height:1}
.da-name{font-weight:800;font-size:1.15rem}
.da-time{margin-left:auto;color:var(--muted);font-weight:700;white-space:nowrap}

/* TABELA DO COMBINADO (Semana 1 e 2) */
.pattern{background:var(--card);border-radius:16px;padding:4px 16px;margin-bottom:14px;box-shadow:0 4px 14px rgba(60,40,120,.07)}
.pattern summary{cursor:pointer;font-weight:800;padding:12px 0}
.ptable{width:100%;border-collapse:collapse;margin:4px 0 16px}
.ptable caption{text-align:left;font-weight:800;font-size:1.05rem;margin:8px 0;color:var(--ink)}
.ptable caption .cur{color:var(--child);font-size:.8rem;font-weight:800}
.ptable th,.ptable td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
.ptable th{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.ptable td.pai{color:var(--pai);font-weight:800}
.ptable td.mae{color:var(--mae);font-weight:800}

/* HELP */
.help{background:var(--card);border-radius:16px;padding:4px 16px;box-shadow:0 4px 14px rgba(60,40,120,.07)}
.help summary{cursor:pointer;font-weight:700;padding:12px 0}
.help ul{margin:.2rem 0 .9rem;padding-left:1.1rem;color:var(--muted)}
.help li{margin:.4rem 0}

/* ===== ÁREA DOS PAIS ===== */
.topbar h1{font-size:1.4rem;margin:.3rem 0}
.topbar .sub{color:var(--muted);margin:.2rem 0 1rem}
.topbar a{color:var(--pai);text-decoration:none;font-weight:600}
.flash{background:#e9fff0;border:1px solid #b7f0c8;color:#0b6b2e;padding:10px 14px;border-radius:12px;margin-bottom:14px;font-weight:600}
.panel{background:var(--card);border-radius:16px;padding:16px 18px;margin-bottom:14px;box-shadow:0 4px 14px rgba(60,40,120,.07)}
.panel h2{margin:.1rem 0 .6rem;font-size:1.15rem}
.panel .hint{color:var(--muted);font-size:.88rem;margin:.3rem 0 .6rem}
.big-week{color:var(--pai)}
.form{display:flex;flex-direction:column;gap:10px}
.form label{display:flex;flex-direction:column;gap:5px;font-size:.92rem;font-weight:600;color:var(--muted)}
.form input,.form select{font-weight:500;color:var(--ink)}
.form button{align-self:flex-start}
input[type=date],input[type=text],input[type=number],input[type=password],input[type=file],select{
  padding:9px 11px;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:#fff;color:var(--ink)}
button{background:var(--pai);color:#fff;border:0;border-radius:10px;padding:10px 16px;font-size:1rem;font-weight:700;cursor:pointer}
button:active{transform:translateY(1px)}
button.secondary{background:#efeefb;color:var(--ink)}
button.danger{background:#ff4d6d}
.btn-mini{background:#fff;border:1px solid var(--line);color:var(--ink);text-decoration:none;padding:7px 12px;border-radius:10px;font-weight:700;font-size:.9rem}
.danger-mini{background:#ffe1e7;color:#b00030;padding:7px 12px;font-size:.85rem}
code{background:#f0eefb;padding:2px 6px;border-radius:6px}
.ovr-list{list-style:none;margin:0 0 12px;padding:0}
.ovr-list li{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;margin:6px 0;flex-wrap:wrap}
.ovr-list li.pai{background:var(--pai-soft)} .ovr-list li.mae{background:var(--mae-soft)}
.ovr-who{font-weight:800;margin-left:6px}
.ovr-note{color:var(--muted)}
.tag{font-size:.68rem;font-weight:800;padding:3px 7px;border-radius:999px;margin-left:6px;background:#ffd23f;color:#5a4500}
.logout{margin-top:8px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.92rem;margin-top:8px}
.foot a{color:var(--muted);text-decoration:none;font-weight:700}

/* fotos no painel */
.photos{display:flex;gap:16px;flex-wrap:wrap}
.photo-slot{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}
.photo-slot .ava{width:84px;height:84px;font-size:46px}
.photo-slot label{font-size:.85rem;font-weight:700}
.photo-slot input[type=file]{font-size:.78rem;max-width:150px}

/* atividades (painel pais) */
.emoji-pick{display:flex;flex-wrap:wrap;gap:6px;margin:2px 0 4px}
.emoji-opt{background:#f3f1ff;border:1px solid var(--line);border-radius:10px;padding:6px 9px;font-size:1.2rem;line-height:1;cursor:pointer}
.dows{border:1px solid var(--line);border-radius:12px;padding:8px 12px;display:flex;flex-wrap:wrap;gap:12px}
.dows legend{font-size:.85rem;color:var(--muted);font-weight:700;padding:0 4px}
.dow-chk{display:flex;align-items:center;gap:5px;font-weight:600;color:var(--ink);font-size:.95rem}
.act-list{list-style:none;margin:12px 0 0;padding:0}
.act-list li{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;background:#faf9ff;margin:6px 0}
.act-emoji{font-size:1.7rem;line-height:1}
.act-info{flex:1;font-size:.95rem}

/* ===== RESPONSIVO ===== */
/* Desktop/tablet: carrossel bem mais amplo (mais dias visíveis) */
@media (min-width: 760px){
  .wrap{max-width:1080px}
  .appbar,.monthbar,.swapbar,.swap-erro,.dayacts,.pattern{max-width:660px;margin-left:auto;margin-right:auto}
  .day{width:94px}
  .day.focus{width:118px}
  .day .ava.sm{width:60px;height:60px;font-size:33px}
  .day.focus .ava.sm{width:78px;height:78px;font-size:44px}
  .day .ava.stk{width:50px;height:50px;font-size:28px}
  .day.focus .ava.stk{width:62px;height:62px;font-size:35px}
}
/* Celular: mais restrito, poucos dias e cards grandes */
@media (max-width: 480px){
  .day{width:84px}
  .day.focus{width:104px}
  .day .ava.sm{width:56px;height:56px;font-size:30px}
  .day.focus .ava.sm{width:68px;height:68px;font-size:38px}
}
