/* FamilyPlanner UI
   Mobile-first. Top bar only. Family-configurable colours via
   --color-primary / --color-accent (injected per request in <head>). */

:root{
  --color-primary:#4f46e5;
  --color-accent:#06b6d4;

  --bg:#f5f6f9;
  --surface:#ffffff;
  --surface-2:#fbfbfd;
  --text:#171a21;
  --muted:#6b7280;
  --border:#e6e8ee;
  --ring:color-mix(in srgb, var(--color-primary) 35%, transparent);
  --shadow:0 1px 2px rgba(16,20,30,.06), 0 8px 24px -16px rgba(16,20,30,.28);

  --radius:16px;
  --radius-sm:10px;
  --space:16px;
  --maxw:960px;

  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,
    "Apple Color Emoji","Segoe UI Emoji",sans-serif;
}

html[data-theme="dark"]{
  --bg:#0f1115; --surface:#171a21; --surface-2:#1c2029;
  --text:#e8eaf0; --muted:#9aa2af; --border:#262b36;
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 10px 30px -18px rgba(0,0,0,.7);
}
@media (prefers-color-scheme:dark){
  html[data-theme="auto"]{
    --bg:#0f1115; --surface:#171a21; --surface-2:#1c2029;
    --text:#e8eaf0; --muted:#9aa2af; --border:#262b36;
    --shadow:0 1px 2px rgba(0,0,0,.4), 0 10px 30px -18px rgba(0,0,0,.7);
  }
}

*{box-sizing:border-box}
/* The hidden attribute must always win, also over display:flex/grid classes. */
[hidden]{display:none !important}
html,body{margin:0}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-bottom:env(safe-area-inset-bottom);
}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--space)}

/* ---- Top bar ---- */
.topbar{
  position:sticky;top:0;z-index:30;
  background:color-mix(in srgb, var(--surface) 86%, transparent);
  backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar__inner{display:flex;align-items:center;gap:12px;height:60px}
.brand{display:flex;align-items:center;gap:10px;font-weight:680;letter-spacing:-.01em}
.brand__name{font-size:1.02rem}
@media (max-width:430px){.brand__name{display:none}}
.brand__mark{
  width:28px;height:28px;
  background:url("/assets/img/favicon.svg") center/contain no-repeat;
}
.brand__mark--lg{width:46px;height:46px}
.brandlk{display:inline-flex;align-items:center;gap:10px;text-decoration:none;line-height:1}
.brandlk__text{display:flex;flex-direction:column;gap:3px}
.brandlk__word{font-weight:800;font-size:1.16rem;letter-spacing:-.02em}
.brandlk__a{color:#4f46e5}
.brandlk__b{color:#0891b2}
.brandlk__sub{font-size:.6rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.brandlk--lg{gap:14px}
.brandlk--lg .brandlk__word{font-size:1.95rem}
.brandlk--lg .brandlk__sub{font-size:.74rem;letter-spacing:.18em}
@media (prefers-color-scheme:dark){.brandlk__a{color:#818cf8}.brandlk__b{color:#22d3ee}}

/* To-do module */
.todo-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:14px 0 16px}
.todo-filters__status{display:inline-flex;gap:6px}
.chip{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:999px;padding:6px 14px;font:inherit;font-size:.86rem;font-weight:600;cursor:pointer}
.chip.is-on{background:var(--color-primary);border-color:transparent;color:#fff}
.todo-filters__sel{max-width:200px}
.todo-list{display:flex;flex-direction:column;gap:10px}
.todo-card{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px}
.todo-card__check{margin-top:3px;width:20px;height:20px;flex:none;cursor:pointer}
.todo-card__body{flex:1;min-width:0;cursor:pointer}
.todo-card__top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.todo-card__title{margin:0;font-size:1rem;font-weight:640}
.todo-card.is-done .todo-card__title{text-decoration:line-through;color:var(--muted)}
.todo-chip{font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:999px;background:var(--surface-2);color:var(--muted)}
.todo-card__meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:7px}
.todo-meta{font-size:.8rem;color:var(--muted);display:inline-flex;align-items:center;gap:4px}
.todo-meta--who{background:var(--surface-2);border-radius:999px;padding:2px 9px;font-weight:600}
.todo-due{font-size:.8rem;font-weight:600;color:var(--muted);white-space:nowrap}
.todo-due.is-overdue{color:#dc2626;font-weight:700}
.todo-due.is-today{color:#d97706;font-weight:700}
.todo-dialog{width:min(520px,94vw)}
.todo-extra{margin-top:8px;border-top:1px solid var(--border);padding-top:12px}
.todo-extra__h{font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:12px 0 6px}
.todo-checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.todo-checkitem{display:flex;align-items:center;gap:9px;padding:4px 0}
.todo-checkitem input{width:18px;height:18px;flex:none;cursor:pointer}
.todo-checkitem span{flex:1;min-width:0}
.todo-checkitem.is-done span{text-decoration:line-through;color:var(--muted)}
.todo-x{border:0;background:transparent;color:var(--muted);font-size:1.15rem;line-height:1;cursor:pointer;padding:0 4px}
.todo-x:hover{color:#dc2626}
.todo-additem{display:flex;gap:8px;margin-top:8px}
.todo-additem .input{flex:1}
.todo-atts{list-style:none;margin:0 0 8px;padding:0;display:flex;flex-direction:column;gap:4px}
.todo-att{display:flex;align-items:center;gap:8px}
.todo-att a{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.todo-upload{cursor:pointer}
.todo-catlist{margin-bottom:14px}
.todo-dot{width:14px;height:14px;border-radius:50%;background:var(--border);flex:none}

.nav{display:flex;gap:4px;margin-left:auto}
.nav__link{
  padding:8px 12px;border-radius:999px;color:var(--muted);
  font-size:.94rem;font-weight:560;white-space:nowrap;transition:color .15s,background .15s;
}
.nav__link:hover{color:var(--text)}
.nav__link.is-active{background:var(--color-primary);color:#fff}

/* Settings dropdown in the top bar */
.navdd{position:relative}
.navdd__toggle{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.navdd__toggle::-webkit-details-marker{display:none}
.navdd__menu{
  position:absolute;top:calc(100% + 8px);right:0;z-index:60;
  display:flex;flex-direction:column;min-width:170px;padding:6px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);box-shadow:var(--shadow);
}
.navdd__item{padding:9px 12px;border-radius:8px;color:var(--muted);font-size:.93rem;font-weight:560}
.navdd__item:hover{color:var(--text);background:var(--surface-2)}
.navdd__item.is-active{background:var(--color-primary);color:#fff}

.account{display:flex;align-items:center;gap:10px;margin-left:8px}
.account__me{display:inline-flex;text-decoration:none;border-radius:50%}
.account__logout{display:flex}
.profile__head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.profile__name{font-weight:700;font-size:1.1rem}
.ha-map{padding:12px 0;border-top:1px solid var(--border)}
.ha-map:first-child{border-top:0}
.ha-map__head{margin-bottom:8px}
.ha-map__chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.ha-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 6px 4px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);font-size:.85rem}
.ha-chip__x{border:0;background:transparent;color:var(--muted);font-size:1.1rem;line-height:1;cursor:pointer;padding:0 2px}
.ha-chip__x:hover{color:#dc2626}
.ha-map__add{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.ha-map__add .input{flex:1;min-width:160px}
.notif-log{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.notif-log__row{display:flex;align-items:center;gap:12px;padding:10px 0;border-top:1px solid var(--border)}
.notif-log__row:first-child{border-top:0}
.notif-log__time{flex:none;font-variant-numeric:tabular-nums;color:var(--muted);font-size:.85rem;width:42px}
.notif-log__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.notif-log__title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-log__text{font-size:.85rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-log__badge{flex:none;font-size:.72rem;font-weight:700;padding:3px 8px;border-radius:999px}
.notif-log__badge.is-ok{background:color-mix(in srgb,#16a34a 18%,var(--surface));color:#15803d}
.notif-log__badge.is-fail{background:color-mix(in srgb,#dc2626 18%,var(--surface));color:#b91c1c}
.notif-log__badge.is-none{background:var(--surface-2);color:var(--muted)}

/* Public landing page */
.landing{max-width:none;padding:0}
.btn--lg{padding:14px 24px;font-size:1.04rem}
.lp__bar{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:1120px;margin:0 auto;padding:18px 20px}
.lp__brand{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:1.1rem}
.lp__nav{display:flex;gap:8px}

/* Hero */
.lp__hero{
  display:grid;grid-template-columns:1fr;gap:32px;align-items:center;
  max-width:1120px;margin:0 auto;padding:32px 20px 28px;
}
@media (min-width:880px){.lp__hero{grid-template-columns:1.05fr .95fr;padding:56px 20px 40px}}
.lp__eyebrow{display:inline-block;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 12%,var(--surface));
  padding:6px 12px;border-radius:999px;margin-bottom:16px}
.lp__title{font-size:clamp(2.1rem,5.2vw,3.3rem);line-height:1.08;letter-spacing:-.02em;margin:0 0 16px}
.lp__lead{font-size:1.15rem;color:var(--muted);margin:0 0 26px;max-width:540px}
.lp__cta{display:flex;gap:12px;flex-wrap:wrap}
.lp__note{margin:16px 0 0;font-size:.85rem;color:var(--muted)}
.lp__hero-art{max-width:520px;margin:0 auto;width:100%}
.lp__hero-art svg{width:100%;height:auto;display:block;filter:drop-shadow(0 18px 40px rgba(10,12,18,.12))}

/* Feature cards with icons */
.lp__features{display:grid;gap:16px;grid-template-columns:1fr;max-width:1120px;margin:0 auto;padding:28px 20px}
@media (min-width:640px){.lp__features{grid-template-columns:1fr 1fr}}
@media (min-width:980px){.lp__features{grid-template-columns:1fr 1fr 1fr}}
.lp__feature{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:transform .12s ease, box-shadow .12s ease}
.lp__feature:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(10,12,18,.12)}
.lp__ico{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:13px;margin-bottom:12px;
  color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 14%,var(--surface))}
.lp__ico svg{width:24px;height:24px}
.lp__ico--shopping{color:#16a34a;background:color-mix(in srgb,#16a34a 14%,var(--surface))}
.lp__ico--tasks{color:#d97706;background:color-mix(in srgb,#f59e0b 16%,var(--surface))}
.lp__ico--home{color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 16%,var(--surface))}
.lp__feature-name{margin:0 0 6px;font-size:1.08rem}
.lp__feature-desc{margin:0;color:var(--muted);font-size:.92rem;line-height:1.5}

/* Phone-mockup showcase */
.lp__showcase{max-width:1080px;margin:0 auto;padding:20px 20px 8px;display:flex;flex-direction:column;gap:36px}
.lp__show-row{display:grid;grid-template-columns:1fr;gap:24px;align-items:center}
@media (min-width:820px){
  .lp__show-row{grid-template-columns:0.9fr 1.1fr;gap:40px}
  .lp__show-row--rev .lp__show-art{order:2}
}
.lp__show-art{display:flex;justify-content:center}
.lp-phone{width:100%;max-width:240px;height:auto;filter:drop-shadow(0 22px 44px rgba(10,12,18,.18))}
.lp__show-text h2{font-size:1.5rem;margin:0 0 10px;letter-spacing:-.01em}
.lp__show-text p{color:var(--muted);margin:0 0 16px;font-size:1.02rem;line-height:1.55}
.lp__checks{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.lp__checks li{position:relative;padding-left:30px;font-weight:560}
.lp__checks li::before{content:"";position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:50%;
  background:color-mix(in srgb,#16a34a 18%,var(--surface))}
.lp__checks li::after{content:"";position:absolute;left:6px;top:7px;width:8px;height:5px;
  border-left:2px solid #16a34a;border-bottom:2px solid #16a34a;transform:rotate(-45deg)}

/* Scrolling reviews */
.reviews{padding:36px 0 8px;overflow:hidden}
.reviews__head{text-align:center;max-width:680px;margin:0 auto 22px;padding:0 20px}
.reviews__head h2{font-size:1.6rem;margin:0 0 6px}
.reviews__viewport{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.reviews__track{display:flex;gap:16px;width:max-content;padding:8px 8px;animation:lp-marquee 48s linear infinite}
.reviews:hover .reviews__track{animation-play-state:paused}
@keyframes lp-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.review{flex:0 0 320px;max-width:320px;margin:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;display:flex;flex-direction:column;gap:10px}
.lp-stars{color:#f59e0b;letter-spacing:2px;font-size:.95rem}
.review__text{margin:0;font-size:.95rem;line-height:1.55}
.review__who{display:flex;align-items:center;gap:10px;font-size:.9rem}
.review__avatar{flex:none;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem}
.review__avatar--a{background:var(--color-primary)}
.review__avatar--b{background:#16a34a}
.review__avatar--c{background:#f59e0b}
.review__avatar--d{background:var(--color-accent)}
.review__avatar--e{background:#db2777}
@media (prefers-reduced-motion:reduce){.reviews__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}

.lp__closing{text-align:center;padding:40px 20px 60px}
.lp__closing h2{font-size:1.6rem;margin:0 0 8px}
.lp__closing .muted{margin:0 0 20px}

/* Site footer */
.sitefooter{border-top:1px solid var(--border);margin-top:32px;padding:18px 0;color:var(--muted)}
.sitefooter__inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:.85rem}
.sitefooter__links{display:flex;align-items:center;gap:8px}
.sitefooter__links a{color:var(--muted)}
.sitefooter__links a:hover{color:var(--text)}
.avatar{
  width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;font-weight:680;color:#fff;font-size:.9rem;
  background:linear-gradient(135deg,var(--color-primary),var(--color-accent));
}
.avatar--lg{width:52px;height:52px;font-size:1.2rem}
.avatar--photo{overflow:hidden;background:var(--surface-2)}
.avatar--photo img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.input--file{padding:8px;font-size:.85rem}

/* ---- Buttons ---- */
.btn{
  --bg-btn:var(--surface);
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font:inherit;font-weight:600;font-size:.95rem;cursor:pointer;
  padding:11px 16px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg-btn);color:var(--text);
  transition:transform .04s ease, background .15s, border-color .15s, opacity .15s;
}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.6}
.btn.is-busy{opacity:.6;cursor:progress;pointer-events:none}
.btn:focus-visible{outline:none;box-shadow:0 0 0 4px var(--ring)}
.btn--primary{background:var(--color-primary);border-color:transparent;color:#fff}
.btn--primary:hover{background:color-mix(in srgb,var(--color-primary) 90%, #000)}
.btn--outline{background:transparent;border-color:color-mix(in srgb,var(--color-primary) 45%, var(--border))}
.btn--ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn--ghost:hover{color:var(--text);background:var(--surface-2)}
.btn--sm{padding:7px 11px;font-size:.85rem}
.btn--block{width:100%}

/* ---- Cards & layout ---- */
.page{padding:24px 0 64px}
.page--center{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px}
.page__head{margin-bottom:20px}
.eyebrow{margin:0 0 6px;font-size:.78rem;font-weight:680;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary)}
.page__title{margin:0;font-size:clamp(1.5rem,5vw,2rem);font-weight:720;letter-spacing:-.02em}
.page__lead{margin:8px 0 0;color:var(--muted)}

.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,var(--color-primary),var(--color-accent));opacity:.9}
.card__title{margin:0 0 6px;font-size:1.05rem;font-weight:680;letter-spacing:-.01em}
.card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.card__head .card__title{margin:0}
.card__hint{margin:0 0 14px;color:var(--muted);font-size:.9rem}
.card--highlight{border-color:color-mix(in srgb,var(--color-accent) 50%,var(--border))}

.grid{display:grid;gap:14px;grid-template-columns:1fr}
@media (min-width:560px){.grid{grid-template-columns:1fr 1fr}}
@media (min-width:860px){.grid{grid-template-columns:1fr 1fr 1fr}}

.settings-grid{display:grid;gap:16px;grid-template-columns:1fr}
@media (min-width:720px){.settings-grid{grid-template-columns:1fr 1fr}}

/* ---- Modules ---- */
.module__top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.module__name{margin:0;font-size:1.05rem;font-weight:680}
.module__desc{margin:8px 0 0;color:var(--muted);font-size:.92rem}
.module--soon{opacity:.78}

/* Shopping summary on the dashboard card */
.shopsum{margin:12px 0 0;font-weight:680;font-size:.95rem}
.shopsum__cats{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.shopsum__chip{
  font-size:.74rem;font-weight:700;border:1.5px solid var(--border);
  border-radius:999px;padding:3px 9px;white-space:nowrap;
}

/* Upcoming events on the dashboard agenda card */
.upcoming{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column}
.upcoming__item{display:flex;align-items:center;gap:10px;padding:8px 0;border-top:1px solid var(--border)}
.upcoming__text{display:flex;flex-direction:column;min-width:0}
.upcoming__title{font-weight:620;font-size:.93rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.upcoming__meta{color:var(--muted);font-size:.8rem}
.upcoming__who{flex:none}
.tag{font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--color-accent);border:1px solid color-mix(in srgb,var(--color-accent) 40%,var(--border));
  padding:3px 8px;border-radius:999px}

/* ---- Forms ---- */
.form{display:flex;flex-direction:column;gap:14px}
.form--inline{margin-top:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field__label{font-size:.82rem;font-weight:600;color:var(--muted)}
.input{
  font:inherit;color:var(--text);background:var(--surface-2);
  border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;width:100%;
  transition:border-color .15s, box-shadow .15s;
}
.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px var(--ring)}
.input--code{letter-spacing:.3em;font-size:1.1rem;text-align:center}
.row{display:flex;gap:14px;flex-wrap:wrap}
.field--color{flex:1}
.swatch{width:100%;height:46px;padding:4px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);cursor:pointer}

/* ---- Auth ---- */
.auth{min-height:calc(100vh - 0px);display:grid;place-items:center;padding:32px 16px}
.auth__card{width:100%;max-width:400px;padding:28px}
.auth__head{text-align:center;margin-bottom:18px;display:flex;flex-direction:column;align-items:center;gap:8px}
.auth__title{margin:0;font-size:1.4rem;font-weight:720;letter-spacing:-.02em}
.auth__sub{margin:0;color:var(--muted);font-size:.92rem}
.auth__divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.8rem;margin:18px 0}
.auth__divider::before,.auth__divider::after{content:"";height:1px;flex:1;background:var(--border)}
.auth__hint{margin:10px 0 0;color:var(--muted);font-size:.85rem;min-height:1em;text-align:center}

.people{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.person{display:flex;align-items:center;gap:14px;width:100%;text-align:left;cursor:pointer;
  background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;font:inherit;color:var(--text)}
.person:hover{border-color:var(--color-primary)}
.person__name{font-weight:620}
.person__hint{margin-left:auto;font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

/* ---- Lists, notices, misc ---- */
.list{list-style:none;margin:0 0 4px;padding:0;display:flex;flex-direction:column}
.list__row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.list__row:last-child{border-bottom:0}
.muted{color:var(--muted);font-size:.86rem}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.status{font-weight:700;margin:0 0 8px}
.status--on{color:#16a34a}.status--off{color:var(--muted)}
.notice{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:16px;font-size:.9rem}
.notice--accent{border-color:color-mix(in srgb,var(--color-accent) 50%,var(--border))}
.elevate{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.link{color:var(--color-primary);font-weight:600}
.reveal{margin:6px 0 14px}
.reveal summary{cursor:pointer;color:var(--muted);font-size:.86rem}
.key{display:block;margin-top:8px;word-break:break-all;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px;font-size:.78rem}
.codes{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.codes li{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px;text-align:center;letter-spacing:.05em}

/* ---- Flash ---- */
.flash-stack{display:flex;flex-direction:column;gap:8px;margin:16px 0 0}
.flash{padding:11px 14px;border-radius:var(--radius-sm);font-size:.9rem;border:1px solid var(--border);background:var(--surface)}
.flash--success{border-color:#16a34a55;background:color-mix(in srgb,#16a34a 12%,var(--surface))}
.flash--error{border-color:#dc262655;background:color-mix(in srgb,#dc2626 12%,var(--surface))}
.flash--info{border-color:var(--border)}

/* ---- Shopping list ---- */
.shop__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.shop__headbtns{display:flex;align-items:center;gap:10px}
.shop__status{font-size:.8rem;font-weight:640;color:#b45309;background:color-mix(in srgb,#f59e0b 16%,var(--surface));
  border:1px solid #f59e0b66;border-radius:999px;padding:4px 10px}
.shop__add{margin-bottom:14px;padding:14px}
.shop__barcode{
  display:flex;align-items:center;gap:10px;
  font-size:.85rem;font-weight:620;
  background:color-mix(in srgb,var(--color-accent) 12%,var(--surface));
  border:1px solid color-mix(in srgb,var(--color-accent) 45%,var(--border));
  border-radius:var(--radius-sm);padding:8px 12px;
}
.shop__barcode-clear{margin-left:auto;border:0;background:transparent;color:var(--muted);font-size:1.1rem;cursor:pointer;line-height:1}
.shop__barcode-clear:hover{color:var(--text)}
.shop__cats,.shop__filters{display:flex;flex-wrap:wrap;gap:8px}
.shop__filters{margin:0 0 12px}
.shopchip{
  font:inherit;font-size:.85rem;font-weight:620;cursor:pointer;
  padding:6px 12px;border-radius:999px;border:1.5px solid var(--border);
  background:var(--surface);transition:transform .05s ease;
}
.shopchip:active{transform:scale(.96)}
.shop__list{list-style:none;margin:0;padding:0;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden}
.shop__list:empty{display:none}
.shopitem{display:flex;align-items:center;border-bottom:1px solid var(--border)}
.shopitem:last-child{border-bottom:0}
.shopitem__main{
  flex:1;display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:13px 14px;cursor:pointer;min-width:0;
  user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;
}
.shopitem__main.is-holding{background:color-mix(in srgb,var(--color-primary) 10%,var(--surface));transition:background .45s ease .15s}
.shopitem__name{font-weight:600}
.shopitem__tag{font-size:.68rem;font-weight:700;color:#fff;border-radius:999px;padding:2px 8px;letter-spacing:.02em}
@media (max-width:760px){
  /* Phones: shrink category badges to colour-only dots to save row space. */
  .shopitem__tag{width:11px;height:11px;padding:0;font-size:0;border-radius:50%;flex:none;overflow:hidden}
}
.shopitem__qtywrap{margin-left:auto;display:flex;align-items:center;gap:6px;flex:none}
.shopitem__qty{
  background:var(--surface-2);border:1px solid var(--border);border-radius:8px;
  padding:3px 10px;font-size:.9rem;font-weight:700;white-space:nowrap;min-width:34px;text-align:center;
}
.shopitem__step{
  width:32px;height:32px;border-radius:50%;border:1px solid var(--border);
  background:var(--surface-2);font:inherit;font-size:1.1rem;font-weight:700;line-height:1;
  color:var(--color-primary);cursor:pointer;flex:none;
}
.shopitem__step:disabled{opacity:.35;cursor:default}
.shopitem__step:active:not(:disabled){background:color-mix(in srgb,var(--color-primary) 15%,var(--surface-2))}
.shopitem--done .shopitem__qty{font-weight:500;color:var(--muted);text-decoration:line-through}
/* !important: the tag colour is set inline from the category, grey must win here */
.shopitem--done .shopitem__tag{background:var(--border) !important;color:var(--muted);text-decoration:line-through}
.shopitem__edit{border:0;background:transparent;color:var(--muted);font-size:1rem;cursor:pointer;padding:13px 14px}
.shopitem--striking .shopitem__name{text-decoration:line-through;opacity:.45}
.shopitem--striking{background:color-mix(in srgb,var(--color-primary) 5%,var(--surface))}
.shopitem--done .shopitem__name{text-decoration:line-through;color:var(--muted);font-weight:500}
.shopitem--empty{padding:16px;color:var(--muted);cursor:default}
.shop__done-title{font-size:.95rem;font-weight:680;color:var(--muted);margin:20px 0 8px}
.shop__list--done .shopitem__main{padding:10px 14px}

/* ---- Chores game ---- */
.chores__members{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;margin-bottom:14px}
.chores__member{
  display:flex;flex-direction:column;align-items:center;gap:4px;flex:none;
  padding:10px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);
  background:var(--surface);min-width:86px;
}
.chores__member.is-active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 7%,var(--surface))}
.chores__membername{font-size:.82rem;font-weight:640}
.chores__memberpts{font-size:.78rem;color:var(--muted);font-weight:700}
.chores__balance{display:flex;align-items:baseline;gap:10px;margin:4px 0 14px}
.chores__balance-num{font-size:1.6rem;font-weight:780;letter-spacing:-.02em}
.chores__approvals{margin-bottom:14px;border-color:color-mix(in srgb,var(--color-accent) 50%,var(--border))}
.chores__tasks{display:grid;gap:12px;grid-template-columns:1fr}
@media (min-width:720px){.chores__tasks{grid-template-columns:1fr 1fr}}
.choretask--paused{opacity:.65}
.choretask__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.choretask__name{margin:0;font-size:1.02rem;font-weight:680}
.choretask__meta{display:flex;align-items:center;gap:10px;margin-top:6px;font-size:.9rem;flex-wrap:wrap}
.choretask__pts{font-weight:700;color:var(--color-primary)}
.choretask__streak,.choretask__freeze{font-weight:640}
.choretask__hint{margin:6px 0 0;font-size:.8rem;color:var(--muted)}
.choretask__action{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex:none}
.chores__donebtn{min-width:110px}
.chores__checked{font-size:1.5rem}
.chores__rejected{color:#dc2626;border-color:#dc262666}
.choretask__pause{margin-top:10px;padding-top:8px;border-top:1px solid var(--border);font-size:.82rem}
.chores__shoptitle{font-size:1.05rem;font-weight:700;margin:22px 0 10px}
.chores__shop{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.chorereward{padding:14px;text-align:center;position:relative;overflow:hidden}
.chorereward--locked{opacity:.55}
.chorereward__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.16;pointer-events:none}
.chorereward__body{position:relative}
.chorereward__name{margin:0;font-size:.95rem;font-weight:660}
.chorereward__pts{margin:8px 0;font-size:1.1rem;font-weight:760}
.chorereward__date{margin:0;font-size:.78rem}
.chorereward--done{opacity:.82}

/* Redeem confirmation modal */
.redeem-dialog{width:min(380px,94vw);text-align:center;position:relative;padding:0;overflow:hidden}
.redeem-dialog__close{position:absolute;top:8px;right:8px;z-index:2}
.redeem-dialog__art{
  display:flex;align-items:center;justify-content:center;
  height:180px;background:var(--surface-2);font-size:4rem;overflow:hidden;
}
.redeem-dialog__img{width:100%;height:100%;object-fit:cover;display:block}
.redeem-dialog__name{margin:16px 18px 4px;font-size:1.25rem;font-weight:740;letter-spacing:-.01em}
.redeem-dialog__pts{margin:0;font-size:1.4rem;font-weight:800}
.redeem-dialog__balance{margin:6px 18px 0;font-size:.85rem}
.redeem-dialog form{margin:16px 18px 8px}
.redeem-dialog > [data-modal-close]{margin:0 18px 18px;width:calc(100% - 36px)}
.chores__shopnote{margin-top:10px;font-size:.82rem}
.chores__count{display:inline-grid;place-items:center;min-width:20px;height:20px;border-radius:999px;
  background:#fff;color:var(--color-primary);font-size:.74rem;font-weight:800;padding:0 5px;margin-left:4px}
.choretask__icon{font-size:1.15rem;margin-right:2px}
.chores__approveall{margin-top:12px}
.choremanage__pts{width:80px;flex:none;text-align:center}
.choremanage__icon .input{width:64px;text-align:center}
.choremanage__list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.choremanage__item{border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;background:var(--surface-2)}
.choremanage__item summary{font-weight:620;font-size:.92rem}
.choremanage__form{margin-top:10px;gap:10px}
.choremanage__remove{margin-top:8px;display:flex;justify-content:flex-end}
.choremanage__addtitle{font-size:.92rem;font-weight:680;margin:14px 0 8px;color:var(--muted)}

/* Game v3: streak row, compact task cards, subtabs, manage rows */
.gstreaks{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin-bottom:12px}
.gstreaks__chip{
  display:inline-flex;align-items:center;gap:5px;flex:none;
  background:color-mix(in srgb,#f59e0b 14%,var(--surface));
  border:1.5px solid #f59e0b88;border-radius:999px;padding:6px 12px;
  font-size:.86rem;font-weight:700;
}
.gstreaks__icon{font-size:1rem}
.gstreaks__freeze{font-weight:640;font-size:.78rem}
.gtask-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(155px,1fr))}
.gtask{position:relative;overflow:hidden;padding:12px;display:flex;flex-direction:column;gap:6px}
.gtask--paused{opacity:.6}
.gtask__bg{position:absolute;right:-8px;bottom:-16px;font-size:4.6rem;opacity:.10;pointer-events:none;line-height:1}
.gtask__name{margin:0;font-size:.92rem;font-weight:680;position:relative}
.gtask__meta{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:640;position:relative;flex-wrap:wrap}
.gtask__action{margin-top:auto;position:relative;display:flex;flex-direction:column;gap:6px;align-items:stretch}
.gtask__action .tag{align-self:flex-start}
.gtask__pauselink{position:absolute;right:0;bottom:0}
.gtask__pausebtn{border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:.95rem;padding:4px;opacity:.55}
.gtask__pausebtn:hover{opacity:1}
.gtask__pausenote{margin:4px 0 0;font-size:.76rem;position:relative}
.chores__showall{margin-top:10px}
.agenda-dialog--wide{width:min(640px,96vw)}
.agenda-dialog--wide [data-search]{margin-bottom:12px}
.gtask-grid--modal{max-height:60vh;overflow-y:auto;padding:2px}
.subtabs{display:flex;gap:6px;margin-bottom:16px}
.subtabs__tab{padding:8px 16px;border-radius:999px;font-size:.92rem;font-weight:620;color:var(--muted);border:1px solid var(--border);background:var(--surface)}
.subtabs__tab.is-active{background:var(--color-primary);border-color:transparent;color:#fff}
.manage-row__label{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}
.manage-row--off{opacity:.55}
.manage-row__icon{font-size:1.2rem}
.manage-row__thumb{width:34px;height:34px;border-radius:8px;object-fit:cover;flex:none}
.gamekid__pts{margin-left:auto;font-weight:760;font-size:.95rem}

/* Device (trusted network) avatar */
.avatar--device{background:linear-gradient(135deg,#64748b,#94a3b8);font-size:1rem}
.devicephoto{margin-top:14px;padding-top:12px;border-top:1px solid var(--border);align-items:center}

/* Home Assistant: uniform tiles (fixed height, clamped names) + modals */
.ha-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.ha-tile{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  height:128px;padding:10px;cursor:pointer;font:inherit;color:var(--text);
  border-radius:var(--radius);border:1.5px solid var(--border);
  background:var(--surface);box-shadow:var(--shadow);overflow:hidden;
  transition:transform .05s ease, border-color .15s;
}
.ha-tile:active{transform:scale(.97)}
.ha-tile--on{background:color-mix(in srgb,#f59e0b 14%,var(--surface));border-color:#f59e0b}
.ha-tile--clim.ha-tile--active{background:color-mix(in srgb,#ef4444 8%,var(--surface));border-color:#ef444488}
.ha-tile__icon{font-size:1.6rem;line-height:1}
.ha-tile__name{
  font-weight:660;font-size:.88rem;text-align:center;line-height:1.25;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  max-height:2.5em;
}
.ha-tile__big{font-size:1.35rem;font-weight:780;letter-spacing:-.02em;line-height:1.1}
.ha-tile__sub{font-size:.74rem;font-weight:700;color:var(--muted);white-space:nowrap}
.ha-tile--on .ha-tile__sub{color:#b45309}
.ha-thermo__target{display:flex;align-items:center;gap:14px;justify-content:center}
.ha-thermo__set{font-size:1.6rem;font-weight:760;min-width:84px;text-align:center}
.ha-clim__current{margin:0 0 14px;font-size:1.1rem;font-weight:680}
.ha-clim__picker{margin:6px 0}
.ha-clim__label{text-align:center;margin:4px 0 14px;font-size:.8rem}
.ha-bigtoggle{margin-bottom:14px}
.ha-dim__row{display:flex;align-items:center;gap:12px;margin-top:8px}
.ha-dim__icon{font-size:1.1rem;flex:none}
.ha-dim__range{flex:1;accent-color:#f59e0b;height:32px}
.ha-dim__hint{margin:8px 0 0;font-size:.78rem}

/* Mobile: collapse the top navigation into a burger menu */
.burger{display:none}
.navdd__sep{height:1px;background:var(--border);margin:6px 4px}
@media (max-width:760px){
  .nav__link--top{display:none}
  .navdd--gear{display:none}
  .burger{display:block}
  .burger .navdd__menu{min-width:200px}
}

/* ---- Password vault ---- */
.pwvault__err{color:#dc2626;font-size:.86rem;margin:0 0 10px;font-weight:600}
.pwvault__search{margin-bottom:16px}

/* The safe (locked state) */
.pwsafe{max-width:360px;margin:24px auto;text-align:center}
.pwsafe__door{
  width:160px;height:160px;margin:0 auto 18px;border-radius:22px;position:relative;
  background:
    radial-gradient(circle at 50% 42%, #6b7280 0 38%, #4b5563 39% 100%);
  box-shadow:inset 0 0 0 6px #374151, inset 0 0 0 10px #9ca3af, 0 12px 30px -12px rgba(0,0,0,.5);
}
.pwsafe__dial{
  position:absolute;top:50%;left:50%;width:74px;height:74px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:conic-gradient(from 0deg,#cbd5e1,#94a3b8,#e2e8f0,#94a3b8,#cbd5e1);
  box-shadow:inset 0 0 0 6px #64748b, 0 2px 6px rgba(0,0,0,.4);
  display:grid;place-items:center;
}
.pwsafe__dial-knob{width:22px;height:22px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#f1f5f9,#64748b)}
.pwsafe__bolts{position:absolute;inset:0}
.pwsafe__bolts span{position:absolute;width:10px;height:10px;border-radius:50%;background:#1f2937;box-shadow:inset 0 1px 1px rgba(255,255,255,.25)}
.pwsafe__bolts span:nth-child(1){top:14px;left:14px}
.pwsafe__bolts span:nth-child(2){top:14px;right:14px}
.pwsafe__bolts span:nth-child(3){bottom:14px;left:14px}
.pwsafe__bolts span:nth-child(4){bottom:14px;right:14px}
.pwsafe__title{margin:0 0 14px;font-size:1.5rem;font-weight:760;letter-spacing:-.02em}
.pwsafe__form{display:flex;flex-direction:column;gap:10px}
.pwsafe__pin{text-align:center}
.pwsafe__hint{margin:14px 0 0;color:var(--muted);font-size:.84rem}
.pwsafe__setup{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.pwsafe__setup .link{background:none;border:0;cursor:pointer;font:inherit}

/* Entry cards, recognisable private vs shared */
.pwvault__cards{display:grid;gap:12px;grid-template-columns:1fr}
@media (min-width:560px){.pwvault__cards{grid-template-columns:1fr 1fr}}
@media (min-width:900px){.pwvault__cards{grid-template-columns:1fr 1fr 1fr}}
.pwcard{
  position:relative;overflow:hidden;display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px 16px;box-shadow:var(--shadow);border-left:4px solid var(--border);
}
.pwcard--personal{border-left-color:var(--color-accent)}
.pwcard--parents{border-left-color:#f59e0b}
.pwcard--shared{border-left-color:var(--color-primary)}
.pwcard__bg{position:absolute;right:-10px;bottom:-10px;max-width:48%;max-height:78%;opacity:.12;pointer-events:none;object-fit:contain}
.pwcard > *:not(.pwcard__bg){position:relative}
.pwcard__top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.pwcard__name{margin:0;min-width:0;font-size:1.02rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pwcard__badge{
  flex:none;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  padding:3px 8px;border-radius:999px;
}
.pwcard--personal .pwcard__badge{background:color-mix(in srgb,var(--color-accent) 18%,var(--surface));color:var(--color-accent)}
.pwcard--parents .pwcard__badge{background:color-mix(in srgb,#f59e0b 20%,var(--surface));color:#b45309}
.pwcard--shared .pwcard__badge{background:color-mix(in srgb,var(--color-primary) 16%,var(--surface));color:var(--color-primary)}
.pwlink{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.pwcard__field{display:flex;align-items:center;gap:8px;margin-top:8px}
.pwcard__flab{flex:none;width:38px;font-size:.66rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.pwcard__fwrap{position:relative;flex:1;min-width:0;display:flex}
.pwcard__fval{
  flex:1;min-width:0;height:32px;line-height:22px;box-sizing:border-box;
  font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:copy;
  padding:4px 8px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);
  user-select:none;-webkit-user-select:none;
}
.pwcard__fval--mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.04em;padding-right:34px}
.pwcard__fval.is-copied{background:color-mix(in srgb,#16a34a 20%,var(--surface));border-color:#16a34a}
.pwcard__eye{
  position:absolute;right:3px;top:50%;transform:translateY(-50%);
  display:flex;align-items:center;justify-content:center;width:28px;height:28px;
  border:0;background:transparent;color:var(--muted);cursor:pointer;padding:0;
}
.pwcard__eye svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pwcard__eye:hover{color:var(--color-primary)}
.pwcard__eye.is-on{color:var(--color-primary)}
.pwcard__eyeslash{display:none}
.pwcard__eye.is-on .pwcard__eyeslash{display:block}
.pwcard__notes{margin:8px 0 0;font-size:.84rem;color:var(--muted);white-space:pre-wrap;word-break:break-word}
.pwcard__foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto;padding-top:12px}
.pwcard__url{color:var(--color-primary);font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:62%}
.pwcard__edit{flex:none;margin:0}
.pwvault__gear summary{list-style:none}
.pwvault__gear summary::-webkit-details-marker{display:none}
.pwvault__gear .navdd__menu button.navdd__item{width:100%;text-align:left;background:transparent;border:0;cursor:pointer;font:inherit;font-size:.93rem;font-weight:560}
.pwkeys__list{margin-bottom:14px}

/* Copy toast */
.pwtoast{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:120;
  background:#16a34a;color:#fff;font-weight:680;font-size:.88rem;
  padding:10px 16px;border-radius:999px;box-shadow:var(--shadow);
}
.pwtoast[hidden]{display:none}

/* Barcode scan overlay */
.scan{position:fixed;inset:0;z-index:100;background:rgba(8,10,16,.92);display:flex;align-items:center;justify-content:center;padding:18px}
.scan[hidden]{display:none}
.scan__inner{width:min(440px,100%);display:flex;flex-direction:column;gap:12px}
.scan__video{width:100%;border-radius:var(--radius);background:#000;aspect-ratio:3/4;object-fit:cover}
.scan__hint{color:#fff;text-align:center;margin:0;font-size:.9rem}

/* Category management */
.shopcat-edit{display:flex;align-items:center;gap:8px;flex:1;flex-wrap:wrap}
.shopcat-edit .input{flex:1;min-width:110px}
.swatch--sm{width:38px;height:38px;flex:none}
.shopcat-chipview{display:flex;align-items:center;gap:8px;font-weight:600}
.shopcat-dot{width:14px;height:14px;border-radius:50%;display:inline-block}

@media (prefers-reduced-motion:reduce){*{transition:none !important}}

/* ---- Family members ---- */
.card--full{grid-column:1 / -1}
.field--grow2{flex:2}
.field--grow1{flex:1}
.member-list{display:flex;flex-direction:column;gap:14px}
.member{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;background:var(--surface-2)}
.member--off{opacity:.6}
.member__id{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.member__name{font-weight:680;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.member__edit{margin-top:6px}
.member__more{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.check{display:flex;align-items:center;gap:8px;font-size:.92rem;color:var(--text);cursor:pointer}
.check input{width:18px;height:18px;accent-color:var(--color-primary)}

/* ---- Dashboard module links ---- */
.module--link{display:block;color:inherit;transition:transform .08s ease, border-color .15s}
.module--link:hover{border-color:var(--color-primary);transform:translateY(-1px)}

/* ---- Agenda: full-bleed week grid ---- */
.avatar--sm{width:26px;height:26px;font-size:.72rem;flex:none}

.agenda-shell{
  width:100%;
  height:calc(100dvh - 60px);   /* exact viewport height minus the top bar */
  display:flex;flex-direction:column;overflow:hidden;
}
.agenda-shell .flash-stack{margin:8px 12px 0}

.agenda-bar{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface);
}
.agenda-bar__week{display:flex;align-items:center;gap:12px;margin:0 auto}
.wknav{
  width:36px;height:36px;border-radius:50%;flex:none;
  display:grid;place-items:center;
  background:var(--surface-2);border:1px solid var(--border);
  font-size:1.45rem;line-height:1;color:var(--text);padding-bottom:3px;
  transition:background .15s, border-color .15s;
}
.wknav:hover{background:color-mix(in srgb, var(--color-primary) 12%, var(--surface-2));border-color:var(--color-primary)}
.agenda-bar__title{margin:0;font-size:1rem;font-weight:700;letter-spacing:-.01em;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.agenda-bar__range{color:var(--muted);font-weight:520;font-size:.86rem}
.agenda-bar__actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.agenda-warn{
  width:24px;height:24px;border-radius:50%;display:grid;place-items:center;
  background:#dc2626;color:#fff;font-weight:800;font-size:.8rem;
}
.agenda-srcerr{color:#dc2626}

.agenda-scroll{flex:1 1 auto;overflow:auto;overscroll-behavior:contain}
.agenda-grid{
  display:grid;
  grid-template-columns:130px repeat(7, minmax(120px,1fr));
  /* grid-template-rows is set per request (nonce style block): all members
     always fit the viewport, rows weighted by their busiest day */
  grid-template-rows:44px;
  grid-auto-rows:minmax(44px,1fr);
  height:100%;
  min-width:100%;
  background:var(--bg);
}
.agenda-corner{
  position:sticky;top:0;left:0;z-index:6;
  background:var(--surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border);
}
.agenda-dayhead{
  position:sticky;top:0;z-index:5;
  display:flex;align-items:center;justify-content:center;gap:6px;
  background:var(--surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border);
  font-size:.8rem;font-weight:640;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;
}
.agenda-dayhead__num{
  display:grid;place-items:center;width:24px;height:24px;border-radius:50%;
  color:var(--text);font-weight:700;
}
.agenda-dayhead.is-today .agenda-dayhead__num{background:var(--color-primary);color:#fff}
.agenda-dayhead.is-today{color:var(--color-primary)}

.agenda-member{
  position:sticky;left:0;z-index:4;
  display:flex;align-items:center;gap:8px;padding:8px;
  background:var(--surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border);
  overflow:hidden;
}
.agenda-member__name{font-size:.86rem;font-weight:640;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.agenda-cell{
  position:relative;display:flex;flex-direction:column;gap:3px;padding:3px;
  border-bottom:1px solid var(--border);border-right:1px solid var(--border);
  min-width:0;min-height:0;overflow-y:auto;scrollbar-width:thin;
}
.agenda-cell.is-today{background:color-mix(in srgb, var(--color-primary) 5%, var(--bg))}

.evt{
  --evt-color:var(--color-primary);
  display:flex;align-items:baseline;gap:5px;width:100%;min-width:0;
  font:inherit;font-size:.76rem;text-align:left;cursor:pointer;
  background:color-mix(in srgb, var(--evt-color) 14%, var(--surface));
  border:1px solid color-mix(in srgb, var(--evt-color) 30%, var(--border));
  border-left:3px solid var(--evt-color);
  border-radius:7px;padding:3px 7px;color:var(--text);
}
.evt:hover{background:color-mix(in srgb, var(--evt-color) 24%, var(--surface))}
.evt__time{font-weight:700;color:var(--evt-color);flex:none}
.evt__title{font-weight:560;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.evt--allday{background:var(--evt-color);border-color:var(--evt-color);color:#fff}
.evt--allday .evt__title{font-weight:640}

.agenda-cell__add{
  margin-top:auto;min-height:20px;border:0;background:transparent;color:var(--muted);
  font-size:.95rem;font-weight:700;cursor:pointer;border-radius:6px;opacity:0;
  transition:opacity .12s, background .12s;
}
.agenda-cell:hover .agenda-cell__add,
.agenda-cell__add:focus-visible{opacity:.75;background:var(--surface-2)}
@media (hover:none){.agenda-cell__add{opacity:.3}}

/* Display filter dropdown (hide finished events) */
.agenda-filter{position:relative}
.agenda-filter summary{list-style:none;cursor:pointer}
.agenda-filter summary::-webkit-details-marker{display:none}
.agenda-filter[open] summary{background:var(--surface-2);border-radius:var(--radius-sm)}
.agenda-filter__panel{
  position:absolute;right:0;top:calc(100% + 6px);z-index:40;
  width:240px;padding:14px;gap:10px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);box-shadow:var(--shadow);
}
.agenda-filter__hours{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--text)}
.agenda-filter__num{width:64px;text-align:center}

/* Event dialog */
.agenda-dialog{
  border:0;border-radius:var(--radius);padding:20px;
  width:min(440px, 94vw);background:var(--surface);color:var(--text);
  box-shadow:var(--shadow);
}
.agenda-dialog::backdrop{background:rgba(10,12,18,.45);backdrop-filter:blur(2px)}
.confirm-modal{
  border:0;border-radius:var(--radius);padding:22px;
  width:min(380px,92vw);background:var(--surface);color:var(--text);box-shadow:var(--shadow);
}
.confirm-modal::backdrop{background:rgba(10,12,18,.45);backdrop-filter:blur(2px)}
.confirm-modal__msg{margin:0 0 18px;font-size:1rem;line-height:1.5}
.confirm-modal__actions{display:flex;justify-content:flex-end;gap:10px}
.btn--danger{background:#dc2626;border-color:transparent;color:#fff}
.btn--danger:hover{background:color-mix(in srgb,#dc2626 88%,#000)}
.agenda-dialog__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.agenda-dialog__title{margin:0;font-size:1.1rem;font-weight:700;letter-spacing:-.01em}
.agenda-dialog__delete{margin-top:10px;display:flex;justify-content:flex-end}

/* Calendar sources: stacked rows + split rules */
.list__row--stack{display:block}
.srcrow__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.rules{margin-top:10px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}
.rules__title{margin:0 0 2px;font-size:.85rem;font-weight:680}
.rules__list{list-style:none;margin:8px 0;padding:0;display:flex;flex-direction:column;gap:6px}
.rules__item{display:flex;align-items:center;gap:8px;font-size:.9rem;flex-wrap:wrap}
.rules__match{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--surface);
  border:1px solid var(--border);border-radius:6px;padding:1px 7px;font-size:.82rem}
.rules__item form{margin-left:auto}
.rules__add{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.rules__add .input{flex:1;min-width:120px}
.rules__fallback{margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}
.rules__fallback-label{margin:0 0 6px;font-size:.85rem;font-weight:640}
.rules__fallback-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.check--inline{font-size:.88rem}
.member-checks{display:flex;flex-wrap:wrap;gap:6px 14px;padding:4px 0}
.editform{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.input--sm{padding:8px 10px;font-size:.9rem}

/* Phones: show two days at a time (today + tomorrow) and swipe through the
   rest of the week; the member column stays pinned. */
@media (max-width:760px){
  .agenda-grid{grid-template-columns:76px repeat(7, calc((100vw - 76px) / 2))}
  .agenda-scroll{scroll-snap-type:x mandatory;scroll-padding-left:76px}
  .agenda-dayhead{scroll-snap-align:start}
  .agenda-member__name{font-size:.78rem}
  .agenda-bar__range{display:none}
}
