/* ===== Deck Family — warm design language ===== */
:root{
  --cream:#f7efe1;
  --cream-2:#fdf9f1;
  --plum:#5a2660;
  --plum-soft:#7a4a82;
  --clay:#b9603c;
  --gold:#d99a3a;
  --sage:#8a9b78;
  --ink:#322a31;
  --muted:#9c9087;
  --line:#ece2d2;
  --card:#fffdf8;
  --shadow:0 10px 30px rgba(90,38,96,0.07);
  --radius:22px;
  --serif:"Fraunces", Georgia, serif;
  --sans:"Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --tabbar-h:64px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:-0.01em;margin:0;}
a{color:inherit;text-decoration:none;}
.muted{color:var(--muted);}

.app{max-width:520px;margin:0 auto;min-height:100vh;position:relative;}

/* Views */
.view{display:block;padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 18px);}
.view[hidden]{display:none;}

.page{padding:0 18px;}

/* ===== Hero (Home) ===== */
.hero{
  background:linear-gradient(160deg,#5a2660 0%,#6e3370 55%,#864a76 100%);
  color:var(--cream-2);
  padding:calc(env(safe-area-inset-top) + 26px) 22px 30px;
  border-radius:0 0 30px 30px;
  box-shadow:0 14px 34px rgba(90,38,96,0.20);
}
.hero-top{display:flex;justify-content:space-between;align-items:center;}
.hero-date{
  font-size:13px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  opacity:0.85;
}
.skippy-greeting{display:flex;gap:14px;align-items:flex-start;margin-top:18px;}
.skippy-avatar{
  flex:0 0 auto;width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,0.16);display:grid;place-items:center;font-size:26px;
  border:1px solid rgba(255,255,255,0.25);
}
.skippy-bubble{padding-top:2px;}
.skippy-name{margin:0;font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;opacity:0.8;}
.skippy-text{margin:3px 0 0;font-family:var(--serif);font-size:21px;line-height:1.25;font-weight:500;}

/* ===== Topbar (other views) ===== */
.topbar{
  padding:calc(env(safe-area-inset-top) + 22px) 22px 14px;
}
.topbar h1{font-size:30px;color:var(--plum);}

/* ===== Cards ===== */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
  margin-top:16px;
  box-shadow:var(--shadow);
}
.page > .card:first-child{margin-top:20px;}
.card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;}
.card-head h2{font-size:19px;color:var(--plum);}
.card-link{font-size:13px;font-weight:600;color:var(--clay);}
.section-title{font-size:18px;color:var(--plum);margin:26px 4px 4px;}

/* Glance list */
.glance-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px;}
.glance-item{display:flex;align-items:center;gap:12px;font-size:15px;}
.dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;}
.dot-plum{background:var(--plum);}
.dot-clay{background:var(--clay);}
.dot-gold{background:var(--gold);}
.dot-sage{background:var(--sage);}
.g-time{font-weight:700;font-size:13px;color:var(--clay);min-width:42px;}
.g-label{color:var(--ink);}

/* Todo peek + lists */
.todo-peek,.todo-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px;}
.todo-peek li,.todo-list li{display:flex;align-items:center;gap:12px;font-size:15px;}
.chk{
  width:20px;height:20px;border-radius:7px;border:2px solid var(--sage);
  flex:0 0 auto;background:rgba(143,157,111,0.10);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:13px;line-height:1;color:transparent;transition:background .15s,border-color .15s,color .15s;
}
.chk:hover{border-color:var(--plum-soft);}
.chk[aria-busy="true"]{opacity:.5;cursor:wait;}

/* ===== To-Do — same priority-card treatment as the Health tracker (Jul 1 2026) ===== */
.td-card{padding:6px 19px;}
.td-list{display:flex;flex-direction:column;}
.td-prio{border-left-color:var(--line);}
.td-prio .pt{font-size:13.5px;}
.td-prio .pw{font-size:11.5px;color:var(--muted);margin-top:2px;font-weight:600;}
.td-prio .chk{margin-top:1px;}
.td-lv{background:rgba(90,38,96,0.09);color:var(--plum);}
.td-prio.td-overdue{border-left-color:#c04040;}
.td-prio.td-overdue .td-lv{background:rgba(251,113,133,.16);color:#c04040;}
.td-prio.td-today{border-left-color:var(--gold);}
.td-prio.td-today .td-lv{background:rgba(217,154,58,.18);color:#95651c;}
.td-prio.td-week{border-left-color:var(--sage);}
.td-prio.td-week .td-lv{background:rgba(138,155,120,.16);color:#5a7a52;}
.td-prio.chk-pending{opacity:.6;}
.td-prio.chk-done{opacity:.45;}
.td-prio.chk-done .pt{text-decoration:line-through;}
.td-prio.chk-done .chk{background:var(--sage);border-color:var(--sage);color:#fff;}
.td-prio.chk-done .chk::after{content:"✓";}

/* ===== Tiles ===== */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;}
.tiles-kids{margin-top:10px;}
.tile{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 16px;display:flex;flex-direction:column;gap:4px;min-height:118px;
  box-shadow:var(--shadow);transition:transform .12s ease, box-shadow .12s ease;
  position:relative;overflow:hidden;
}
.tile:active{transform:scale(0.975);}
.tile-icon{
  width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  background:rgba(90,38,96,0.08);color:var(--plum);margin-bottom:6px;
}
.tile-icon svg{width:20px;height:20px;}
.tile-name{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--plum);margin-top:auto;}
.tile-sub{font-size:12px;color:var(--muted);}
.tile-wide{grid-column:1 / -1;min-height:96px;flex-direction:row;align-items:center;gap:14px;}
.tile-wide .tile-icon{margin-bottom:0;flex:0 0 auto;}
.tile-wide .tile-name{margin-top:0;}
.tile-wide .tile-sub{display:block;}
.tile-skippy{background:linear-gradient(135deg,#fff5e2 0%,#ffe9c7 100%);border-color:rgba(217,154,58,0.35);}
.tile-skippy .tile-name{color:var(--clay);}
.tile-skippy .tile-icon{background:rgba(217,154,58,0.16);color:var(--clay);}
.tile-health .tile-icon{background:rgba(196,90,64,0.10);color:var(--clay);}
.tile-business .tile-icon{background:rgba(90,38,96,0.09);color:var(--plum);}
.tile-calendar .tile-icon{background:rgba(217,154,58,0.14);color:#a5750f;}
.tile-todo .tile-icon{background:rgba(107,143,113,0.14);color:var(--sage);}
.tile-health::after,.tile-business::after,.tile-calendar::after,.tile-todo::after{content:"";position:absolute;right:-20px;top:-20px;width:70px;height:70px;border-radius:50%;opacity:0.10;}
.tile-health::after{background:var(--clay);}
.tile-business::after{background:var(--plum);}
.tile-calendar::after{background:var(--gold);}
.tile-todo::after{background:var(--sage);}
.tile-shop .tile-icon{background:rgba(196,90,64,0.10);color:var(--clay);}
.tile-shop::after{content:"";position:absolute;right:-20px;top:-20px;width:70px;height:70px;border-radius:50%;opacity:0.10;background:var(--clay);}

/* ===== Embed cards ===== */
.embed-card{display:flex;flex-direction:column;gap:10px;}
.embed-kicker{font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold);margin:0;}
.embed-card h2{font-size:24px;color:var(--plum);}
.btn{
  display:inline-block;text-align:center;padding:13px 20px;border-radius:16px;
  font-weight:600;font-size:15px;margin-top:6px;align-self:flex-start;
}
.btn-primary{background:var(--plum);color:var(--cream-2);}
.btn-skippy{background:var(--clay);color:#fff;}
.placeholder-note{font-size:12px;color:var(--muted);font-style:italic;margin:4px 0 0;}

/* ===== Segmented (To-Do tabs) ===== */
.segmented{
  display:flex;gap:6px;margin:8px 18px 0;background:rgba(90,38,96,0.07);
  padding:5px;border-radius:16px;
}
.seg-btn{
  flex:1;border:none;background:transparent;font-family:var(--sans);font-weight:600;
  font-size:14px;color:var(--plum-soft);padding:9px;border-radius:12px;cursor:pointer;
}
.seg-btn.is-active{background:var(--card);color:var(--plum);box-shadow:0 2px 8px rgba(90,38,96,0.10);}
.todo-panel[hidden]{display:none;}

/* ===== Calendar week strip ===== */
.week-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.day-cell{position:relative;text-align:center;padding:10px 0 13px;border-radius:14px;border:1px solid var(--line);background:var(--cream-2);}
.day-cell.has-ev::after{content:"";position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--gold);}
.day-cell.today.has-ev::after{background:var(--cream-2);}
.day-cell .dow{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;}
.day-cell .dnum{font-family:var(--serif);font-size:17px;color:var(--ink);margin-top:2px;}
.day-cell.today{background:var(--plum);border-color:var(--plum);}
.day-cell.today .dow,.day-cell.today .dnum{color:var(--cream-2);}

/* ===== Calendar — today timeline (Jul 1 2026: flows through the day, past events drop off) ===== */
.cal-allday{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
.cal-allday-chip{background:rgba(217,154,58,0.14);color:var(--clay);font-weight:600;font-size:12.5px;padding:6px 12px;border-radius:30px;}
.cal-timeline{position:relative;height:1200px;overflow-y:auto;border-radius:16px;background:var(--cream-2);border:1px solid var(--line);}
.cal-hour{position:absolute;left:0;right:0;border-top:1px solid var(--line);}
.cal-hour-label{position:absolute;left:8px;top:-9px;font-size:11px;font-weight:600;color:var(--muted);background:var(--cream-2);padding:0 4px;}
.cal-now-line{position:absolute;left:54px;right:8px;height:2px;background:var(--clay);z-index:3;}
.cal-now-line::before{content:"";position:absolute;left:-5px;top:-4px;width:9px;height:9px;border-radius:50%;background:var(--clay);}
.cal-block{
  position:absolute;left:56px;right:8px;min-height:16px;box-sizing:border-box;
  border-radius:8px;padding:5px 10px 5px 12px;overflow:hidden;
  background:var(--card);box-shadow:0 2px 6px rgba(90,38,96,0.10),inset 3px 0 0 0 var(--plum);
  font-size:12.5px;line-height:1.3;z-index:2;
}
.cal-block{cursor:pointer;} /* tap any block to see its full, untruncated title + time */
.cal-block .cal-block-title{
  font-weight:600;color:var(--ink);overflow-wrap:anywhere;
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden;
}
.cal-block .cal-block-time{color:var(--muted);font-size:11px;}
/* Short back-to-back events (House Help, Evening Routine, etc.) don't have room for three
   stacked lines — collapse to a max-2-line compact row so they never spill into the next block. */
.cal-block.cal-compact{padding:2px 10px 2px 12px;}
.cal-block.cal-compact .cal-block-time{font-size:9.5px;}
.cal-block.cal-compact .cal-block-title{font-size:11px;-webkit-line-clamp:2;overflow-wrap:anywhere;}
.cal-block.cal-c1{box-shadow:0 2px 6px rgba(90,38,96,0.10),inset 3px 0 0 0 var(--plum);}
.cal-block.cal-c2{box-shadow:0 2px 6px rgba(90,38,96,0.10),inset 3px 0 0 0 var(--clay);}
.cal-block.cal-c3{box-shadow:0 2px 6px rgba(90,38,96,0.10),inset 3px 0 0 0 var(--gold);}
.cal-block.cal-c4{box-shadow:0 2px 6px rgba(90,38,96,0.10),inset 3px 0 0 0 var(--sage);}
.cal-block-past{opacity:.42;background:var(--cream-2);box-shadow:inset 3px 0 0 0 var(--line);}
.cal-block-past .cal-block-title,.cal-block-past .cal-block-time{color:var(--muted);}
.cal-empty-today{padding:20px;text-align:center;color:var(--muted);font-size:13.5px;}
.cal-upcoming-day{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin:16px 0 6px;}
.cal-upcoming-day:first-child{margin-top:4px;}

/* ===== Skippy view ===== */
.skippy-view{background:linear-gradient(180deg,#fff6e6 0%,var(--cream) 60%);}
.skippy-topbar h1{color:var(--clay);}
.skippy-card{
  background:#fff;border:2px solid rgba(217,154,58,0.30);border-radius:26px;
  padding:30px 22px;text-align:center;margin-top:20px;box-shadow:0 12px 30px rgba(217,154,58,0.15);
}
.skippy-hero-emoji{font-size:54px;}
.skippy-card h2{font-size:26px;color:var(--clay);margin-top:8px;}
.skippy-card p{color:var(--muted);margin:8px 0 0;}
.skippy-card .btn{align-self:center;margin-top:18px;}

/* ===== Health / Business command-center cards ===== */
.hc-hero{
  background:var(--clay);color:var(--cream-2);border-radius:26px;padding:22px;margin-top:20px;
}
.hc-hero-label{font-size:12px;color:#f1cdbb;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;}
.hc-hero-rows{margin-top:15px;display:flex;flex-direction:column;gap:14px;}
.hc-hero-rows .k{font-size:11px;color:#f0cbb9;font-weight:700;text-transform:uppercase;letter-spacing:.6px;}
.hc-hero-rows .v{font-size:15px;font-weight:600;margin-top:2px;}

.hc-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f4ecdf;gap:12px;}
.hc-row:last-child{border-bottom:none;}
.hc-pill{font-size:11px;font-weight:700;padding:5px 11px;border-radius:20px;white-space:nowrap;background:rgba(90,38,96,0.09);color:var(--plum);}
.hc-pill.amber{background:rgba(217,154,58,0.14);color:#95651c;}
.hc-pill.watch{background:rgba(184,96,60,0.12);color:var(--clay);}
.hc-lbl{font-size:11px;color:var(--muted);font-weight:600;}
.hc-mini-grid{display:flex;gap:9px;margin-top:4px;flex-wrap:wrap;}
.hc-mini{flex:1;min-width:100px;background:var(--cream-2);border-radius:14px;padding:11px 13px;}
.hc-mini .v{font-size:13px;font-weight:700;margin-top:2px;}
.hc-empty{font-size:13px;color:var(--muted);font-style:italic;}
.hc-hyp{font-size:11.5px;color:var(--muted);font-style:italic;margin-left:6px;}
.hc-checklist li{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid #f4ecdf;font-size:14px;font-weight:600;}
.hc-checklist li:last-child{border-bottom:none;}
.hc-source-note{font-size:11px;color:var(--muted);margin-top:10px;}

/* Person switcher (Health tab) */
.hp-switcher{display:flex;gap:7px;margin:14px 18px 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.hp-switcher::-webkit-scrollbar{display:none;}
.hp-btn{flex:0 0 auto;border:1px solid var(--line);background:var(--card);font-family:var(--sans);font-weight:700;font-size:13px;color:var(--plum-soft);padding:9px 16px;border-radius:14px;cursor:pointer;white-space:nowrap;}
.hp-btn.is-active{background:var(--plum);color:var(--cream-2);border-color:var(--plum);}
.hp-panel[hidden]{display:none;}

/* Intimacy tracker dots */
.hc-dots-row{display:flex;gap:9px;justify-content:space-between;}
.hc-dots-row .d{text-align:center;}
.hc-dots-row .dcircle{width:26px;height:26px;border-radius:50%;background:var(--line);margin:0 auto;}
.hc-dots-row .dcircle.on{background:var(--plum);}
.hc-dots-row .dcircle.today{border:2px dashed #d8c9b6;background:transparent;}

/* EQ score big number */
.hc-score-row{display:flex;align-items:flex-end;justify-content:space-between;}
.hc-score-big{display:flex;align-items:flex-end;gap:10px;}
.hc-score-big .num{font-family:var(--serif);font-size:40px;font-weight:500;color:var(--plum);line-height:.9;}
.hc-score-big .unit{font-size:13px;color:var(--muted);font-weight:600;padding-bottom:6px;}

/* Food bar */
.hc-food-top{display:flex;justify-content:space-between;}
.hc-food-top .v2{font-family:var(--serif);font-size:22px;font-weight:500;}
.hc-food-bar{height:9px;border-radius:6px;background:#f0e7d8;margin-top:13px;overflow:hidden;display:flex;}

/* Correlation matrix */
.hc-corr-row{display:flex;gap:7px;}
.hc-corr-box{flex:1;text-align:center;border-radius:12px;padding:11px 4px;}
.hc-corr-box .v{font-size:15px;font-weight:700;margin-top:3px;}

/* Cycle bar */
.hc-cycle-bar{display:flex;height:8px;border-radius:6px;overflow:hidden;margin-top:14px;background:#f0e7d8;}
.hc-cycle-labels{display:flex;justify-content:space-between;font-size:10px;color:#b9ada0;font-weight:600;margin-top:5px;}

/* Gracie feedback card */
.hc-feedback{background:#f3ecf3;border-color:#e6d6e7;}
.hc-feedback .quote{font-family:var(--serif);font-size:15px;font-weight:400;font-style:italic;color:var(--plum);line-height:1.5;}

/* ===== Dashboard-classic (dc-) — ported 1:1 from artifacts-src/nick-health-command-center.html
   so the Health tab's card structure matches the live Command Center, not an approximation.
   Reuses the app's existing color tokens (identical hex to the dashboard's --pur/--mag/--grn/etc). ===== */
.dc-bento2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:4px;}
.dc-bento2>div{min-width:0;}
.dc-bento2 .section-title{margin:0 0 8px;font-size:15px;}
.dc-sgrp{grid-column:1/-1;font-size:10.5px;letter-spacing:.1em;color:var(--clay);font-weight:700;margin:14px 2px 6px;text-transform:uppercase;}
.dc-grid3{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.dc-m{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 15px;box-shadow:var(--shadow);position:relative;overflow:hidden;}
.dc-m.oor{border-color:rgba(192,64,64,.4);box-shadow:inset 0 0 0 1px rgba(192,64,64,.2);}
.dc-m.watchb{border-color:rgba(217,154,58,.45);}
.dc-m .top{display:flex;justify-content:space-between;align-items:center;gap:6px;}
.dc-m .nm{font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dc-m .dot{width:8px;height:8px;border-radius:50%;flex:none;}
.dc-m .val{font-family:var(--serif);font-size:19px;font-weight:600;letter-spacing:-.02em;margin-top:3px;color:var(--ink);}
.dc-m .val .u{font-size:11px;color:var(--muted);font-weight:500;margin-left:2px;font-family:var(--sans);}
.dc-m .trend{font-size:11px;color:#b0a89a;font-weight:500;margin-top:7px;display:flex;align-items:flex-start;gap:5px;flex-wrap:wrap;line-height:1.3;}
.dc-m .trend b{color:var(--ink);font-weight:700;}
.dc-m .tp{display:inline-flex;flex-direction:column;align-items:center;line-height:1.15;}
.dc-m .tp .tv{color:#b0a89a;}
.dc-m .tp em{font-style:normal;font-size:8px;color:#c8bfb5;margin-top:1px;font-weight:600;letter-spacing:.02em;white-space:nowrap;}
.dc-m .ar{font-weight:700;margin:0 1px;color:#c8bfb5;}
.dc-m .ar.up{color:var(--sage);}
.dc-m .ar.dn{color:#c04040;}
.dc-m .foot{font-size:9px;color:var(--muted);font-weight:500;margin-top:8px;letter-spacing:.01em;}
.dc-m .spark{margin-top:7px;height:26px;display:block;}
.dc-m.oor .val{color:#c04040;}
.dc-gauges{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px;}
.dc-gz{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:14px 8px;text-align:center;box-shadow:var(--shadow);}
.dc-gz .ring{width:56px;height:56px;border-radius:50%;margin:0 auto;position:relative;}
.dc-gz .ring::after{content:"";position:absolute;inset:7px;border-radius:50%;background:var(--card);}
.dc-gz .gznum{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);margin-top:9px;}
.dc-gz .lbl{font-size:10.5px;color:var(--muted);font-weight:600;margin-top:4px;}
.dc-gz .dl{font-size:10px;font-weight:700;margin-top:3px;}
.dc-gz .dl.up{color:var(--sage);}
.dc-gz .dl.dn{color:#c04040;}
.dc-gz .dl.fl{color:var(--muted);}

/* Reps as link cards */
.hc-hero-rows a.rep-link{display:block;color:inherit;text-decoration:none;-webkit-tap-highlight-color:rgba(255,255,255,.15);}
.hc-hero-rows a.rep-link:active{opacity:.82;}
.hc-hero-rows .openarr{font-size:10px;font-weight:700;opacity:.85;margin-left:5px;}

/* Protocol — highlighted summary + ordered daily list */
.dc-protocol-summary{background:rgba(90,38,96,.07);border-radius:14px;margin:8px;padding:14px 15px !important;color:var(--plum) !important;font-weight:700 !important;}
.dc-protocol-summary .chev{color:var(--gold);font-weight:800;margin-left:4px;}
.dc-protocol-details[open] .dc-protocol-summary{background:var(--plum);color:var(--cream-2) !important;}
.dc-protocol-details[open] .dc-protocol-summary .chev{color:var(--gold);}
.dc-protocol-list{margin:0;padding:4px 19px 6px;list-style:none;counter-reset:proto;}
.dc-protocol-list li{counter-increment:proto;display:flex;gap:12px;padding:11px 0;border-top:1px solid var(--line);align-items:flex-start;}
.dc-protocol-list li:first-child{border-top:0;}
.dc-protocol-list li::before{content:counter(proto);flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--plum);color:var(--cream-2);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--sans);}
.dc-protocol-list .time{flex:0 0 84px;font-size:10.5px;font-weight:700;color:var(--clay);text-transform:uppercase;letter-spacing:.03em;padding-top:2px;}
.dc-protocol-list .item{flex:1;font-size:13px;color:var(--ink);line-height:1.5;}
.dc-protocol-next{padding:2px 19px 16px;}
.dc-protocol-next ul{margin:0;padding:0;list-style:none;}
.dc-protocol-next li{font-size:12.5px;color:#5a4553;padding:5px 0;border-top:1px solid var(--line);}
.dc-protocol-next li:first-child{border-top:0;}

/* Out-of-range toggle */
.oor-toggle{font-size:11px;font-weight:600;color:var(--clay);background:rgba(185,96,60,.08);border:1px solid rgba(185,96,60,.32);border-radius:20px;padding:5px 12px;cursor:pointer;}
.oor-toggle.on{background:var(--clay);color:var(--cream-2);}
.hp-panel.oor-only .dc-m:not(.oor){display:none;}
.hp-panel.oor-only .dc-sgrp{display:none;}

/* Marker cards tappable */
.dc-m{cursor:pointer;transition:transform .1s ease;}
.dc-m:active{transform:scale(0.97);}

/* Trends — range chips + inline line charts */
.dc-rangebar{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap;}
.dc-rangebar button{font-size:12px;font-weight:700;color:var(--plum-soft);background:var(--cream-2);border:1px solid var(--line);border-radius:14px;padding:6px 13px;cursor:pointer;font-family:var(--sans);}
.dc-rangebar button.on{background:var(--plum);color:var(--cream-2);border-color:var(--plum);}
.dc-rangebar button.dc-range-limited{opacity:.45;}
.dc-rangebar button.dc-range-limited.on{opacity:1;}
.dc-trends .dc-trend-note{margin:0 0 14px;}
.dc-trend-group{margin-bottom:18px;}
.dc-trend-group:last-of-type{margin-bottom:0;}
.dc-trend-h{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;}
.dc-linechart{width:100%;height:70px;display:block;}
.dc-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px;}
.dc-legend span{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);font-weight:600;}
.dc-legend i{width:12px;height:3px;border-radius:2px;display:inline-block;}

/* Marker detail modal */
.mk-overlay{position:fixed;inset:0;background:rgba(50,42,49,.55);z-index:900;display:none;align-items:flex-end;justify-content:center;}
.mk-overlay.on{display:flex;}
.mk-sheet{background:var(--cream);width:100%;max-width:520px;height:92vh;border-radius:26px 26px 0 0;overflow-y:auto;padding:16px 20px calc(24px + env(safe-area-inset-bottom));box-shadow:0 -10px 40px rgba(50,42,49,.3);}
.mk-sheet-head{display:flex;justify-content:space-between;align-items:flex-start;}
.mk-close{background:var(--card);border:1px solid var(--line);border-radius:12px;width:34px;height:34px;font-size:16px;color:var(--ink);flex:none;}
.mk-grp{font-size:11px;font-weight:700;color:var(--clay);text-transform:uppercase;letter-spacing:.08em;}
.mk-name{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);margin-top:4px;}
.mk-val{font-family:var(--serif);font-size:42px;font-weight:600;color:var(--plum);margin-top:18px;}
.mk-val .u{font-size:15px;color:var(--muted);font-weight:500;font-family:var(--sans);margin-left:4px;}
.mk-opt{font-size:13px;color:var(--muted);margin-top:4px;}
.mk-chart{width:100%;height:130px;margin-top:22px;}
.mk-hist-h{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:22px 0 6px;}
.mk-hist-row{display:flex;justify-content:space-between;padding:11px 0;border-top:1px solid var(--line);font-size:13.5px;}
.mk-hist-row:first-child{border-top:0;}
.mk-hist-row b{font-weight:700;color:var(--ink);}
.dc-gz .up{color:var(--sage);} .dc-gz .dn{color:#c04040;} .dc-gz .fl{color:var(--muted);}
.dc-prio{background:var(--card);border:1px solid var(--line);border-left:4px solid #c04040;border-radius:13px;padding:12px 15px;margin-bottom:8px;display:flex;gap:11px;align-items:flex-start;}
.dc-prio .rk{font-family:var(--serif);font-weight:500;font-size:15px;color:#c8bfb5;min-width:16px;}
.dc-prio .pt{font-size:13.5px;font-weight:700;color:var(--ink);}
.dc-prio .pw{font-size:12px;color:var(--muted);margin-top:2px;}
.dc-prio .lv{font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:6px;margin-left:auto;white-space:nowrap;}
.dc-exgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.dc-exp{background:rgba(217,154,58,.07);border:1px solid rgba(217,154,58,.25);border-radius:14px;padding:12px 14px;}
.dc-exp .ex-nm{font-size:13px;font-weight:700;color:var(--ink);}
.dc-exp .ex-since{font-size:10.5px;color:#a08e68;white-space:nowrap;}
.dc-exp .ex-w{font-size:12px;color:#8a7c6a;margin:4px 0 0;line-height:1.4;}
.dc-dgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.dc-dcard{background:rgba(90,38,96,.05);border:1px solid rgba(90,38,96,.2);border-radius:14px;padding:12px 13px;}
.dc-dcard .dtop{display:flex;justify-content:space-between;align-items:center;gap:6px;}
.dc-dcard .dnm{font-size:11.5px;font-weight:600;color:#5a3862;line-height:1.2;}
.dc-dcard .ddot{width:8px;height:8px;border-radius:50%;flex:none;}
.dc-dcard .dval{font-family:var(--serif);font-size:22px;font-weight:500;margin-top:6px;color:var(--ink);}
.dc-dcard .dtt{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-top:1px;}
.dc-dcard .dnote{font-size:10.5px;color:var(--muted);line-height:1.45;margin-top:7px;}
.dc-rx{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.dc-rxh{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--clay);margin-bottom:7px;}
.dc-rxcol.next .dc-rxh{color:var(--gold);}
.dc-rx ul{margin:0;padding:0;list-style:none;}
.dc-rx li{font-size:12.5px;color:#5a4553;padding:6px 0 6px 18px;position:relative;border-top:1px solid var(--line);line-height:1.45;}
.dc-rx li:first-child{border-top:0;}
.dc-rx li:before{content:'';position:absolute;left:1px;top:12px;width:6px;height:6px;border-radius:50%;background:var(--plum);}
.dc-rxcol.next li:before{background:var(--gold);}
.dc-rx li b{color:var(--ink);font-weight:700;}
.dc-chathead{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.dc-chathead .av{width:36px;height:36px;border-radius:12px;background:var(--plum);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--cream-2);font-family:var(--serif);}
.dc-chip2{font-size:11.5px;padding:7px 12px;border-radius:20px;background:#f5ede1;border:1px solid var(--line);color:var(--ink);white-space:nowrap;}
.dc-chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px;}
.dc-inbar{display:flex;gap:8px;align-items:center;margin-top:10px;}
.dc-inbar input{flex:1;background:#f5ede1;border:1px solid var(--line);border-radius:22px;padding:11px 16px;color:var(--ink);font-family:var(--sans);font-size:13px;}
.dc-inbar .send{width:40px;height:40px;border-radius:50%;border:none;background:var(--plum);color:var(--cream-2);font-size:18px;flex:none;display:flex;align-items:center;justify-content:center;font-weight:700;}

/* ===== Bottom tab bar ===== */
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  max-width:520px;margin:0 auto;
  height:calc(var(--tabbar-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  display:flex;background:rgba(253,249,241,0.94);
  backdrop-filter:saturate(1.4) blur(12px);
  border-top:1px solid var(--line);
}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);}
.tab-ic{font-size:21px;filter:grayscale(0.4);opacity:0.7;transition:all .15s;}
.tab-lbl{font-size:10.5px;font-weight:600;}
.tab.is-active{color:var(--plum);}
.tab.is-active .tab-ic{filter:none;opacity:1;transform:translateY(-1px);}

@media (min-width:520px){
  .app,.tabbar{border-radius:0;}
}

/* ===== Desktop / large-screen layout ===== */
@media (min-width:640px) and (max-width:899px){
  .app{max-width:640px;}
  .tabbar{max-width:640px;}
  .tiles-parents{grid-template-columns:1fr 1fr 1fr;}
  .dc-grid3{grid-template-columns:repeat(3,1fr);}
  .biz-kpis{grid-template-columns:repeat(3,1fr);}
}
@media (min-width:900px){
  body{background:var(--cream-2);}
  .app{
    max-width:1180px;margin:0 auto;padding-left:104px;
    background:var(--cream);min-height:100vh;
  }
  .view{padding-bottom:32px;}
  .page{padding:0 36px 40px;max-width:920px;}
  .hero,.topbar{padding-left:36px;padding-right:36px;}
  .card,.embed-card{padding:24px 26px;}

  /* Bottom tab bar → left sidebar */
  .tabbar{
    position:fixed;left:0;top:0;bottom:0;right:auto;max-width:104px;width:104px;
    height:100vh;flex-direction:column;justify-content:flex-start;gap:6px;
    padding:calc(env(safe-area-inset-top) + 28px) 10px 20px;
    border-top:none;border-right:1px solid var(--line);
    background:var(--card);backdrop-filter:none;
  }
  .tab{flex:0 0 auto;width:100%;padding:12px 4px;border-radius:16px;gap:5px;}
  .tab.is-active{background:rgba(90,38,96,0.08);}
  .tab-ic{font-size:23px;}
  .tab-lbl{font-size:10px;}

  /* Wider multi-column grids so content doesn't look stretched-mobile */
  .tiles-parents{grid-template-columns:repeat(4,1fr);}
  .dc-grid3{grid-template-columns:repeat(4,1fr);}
  .biz-kpis{grid-template-columns:repeat(4,1fr);}
  .dc-exgrid{grid-template-columns:repeat(3,1fr)!important;}
  .week-strip{max-width:520px;}
  .hp-btns{flex-wrap:wrap;}

  /* Health/Business two-column reading layout on very wide screens */
  .view[data-view="health"] .page,
  .view[data-view="business"] .page{
    max-width:1040px;
  }
}
@media (min-width:1200px){
  .app{padding-left:104px;}
  .page{max-width:1000px;}
  .dc-grid3{grid-template-columns:repeat(5,1fr);}
}

/* ===== Skippy School — avatar pick + hub (Phase 1 merge, Jul 1 2026) ===== */
.sk-kidpick{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:8px;}
.sk-kidcard{
  width:145px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 12px;box-shadow:var(--shadow);transition:transform .12s ease;
}
.sk-kidcard:active{transform:scale(.97);}
.sk-face{font-size:44px;}
.sk-who{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--plum);margin-top:8px;}
.sk-age{font-size:12px;font-weight:600;color:var(--muted);margin-top:2px;}

.sk-hub-hero{
  background:linear-gradient(160deg,#5a2660 0%,#6e3370 55%,#864a76 100%);
  color:var(--cream-2);padding:calc(env(safe-area-inset-top) + 24px) 22px 34px;
  border-radius:0 0 30px 30px;box-shadow:0 14px 34px rgba(90,38,96,0.20);
}
.sk-hub-back{
  background:rgba(255,255,255,0.16);border:1px solid rgba(255,255,255,0.25);
  color:var(--cream-2);font-weight:600;font-size:13px;padding:7px 14px;border-radius:30px;
}
.sk-hub-avatar{
  width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,0.16);
  border:1px solid rgba(255,255,255,0.25);display:flex;align-items:center;justify-content:center;
  font-size:26px;margin-top:16px;
}
.sk-hub-greet{font-family:var(--serif);font-size:23px;font-weight:500;margin-top:12px;}
.sk-hub-cards{display:flex;flex-direction:column;gap:14px;padding:20px 18px 40px;max-width:480px;margin:0 auto;}
.sk-hub-card{
  display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;cursor:pointer;width:100%;
  text-align:left;transition:transform .12s;
}
.sk-hub-card:active{transform:scale(.98);}
.sk-hub-icon{width:52px;height:52px;border-radius:16px;flex:none;display:flex;align-items:center;justify-content:center;font-size:24px;}
.sk-hub-card.day .sk-hub-icon{background:rgba(90,38,96,0.10);}
.sk-hub-card.les .sk-hub-icon{background:rgba(185,96,60,0.12);}
.sk-hub-card.meet .sk-hub-icon{background:rgba(217,154,58,0.16);}
.sk-hub-tt{font-family:var(--serif);font-weight:600;font-size:17px;color:var(--plum);}
.sk-hub-sub{font-size:12.5px;font-weight:600;color:var(--muted);margin-top:2px;}
.sk-hub-arr{margin-left:auto;color:var(--muted);font-size:20px;}

/* ===== Business view ===== */
.biz-kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px;}
.biz-kpi{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:14px 14px 12px;box-shadow:var(--shadow);position:relative;overflow:hidden;}
.biz-kpi::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--gold);opacity:.9;}
.biz-kpi.warn::before{background:#c04040;} .biz-kpi.good::before{background:var(--sage);} .biz-kpi.amb::before{background:var(--gold);}
.biz-kpi .lab{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700;}
.biz-kpi .val{font-family:var(--serif);font-size:21px;font-weight:600;margin-top:6px;color:var(--ink);}
.biz-kpi.warn .val{color:#c04040;} .biz-kpi.good .val{color:var(--sage);} .biz-kpi.amb .val{color:var(--gold);}
.biz-kpi .note{font-size:10.5px;color:var(--muted);margin-top:3px;line-height:1.35;}

.biz-flags{display:flex;flex-direction:column;gap:10px;}
.biz-flag{padding:11px 13px;border-radius:14px;border-left:3px solid var(--line);background:var(--cream-2);}
.biz-flag.urgent{border-left-color:#c04040;background:rgba(192,64,64,.06);}
.biz-flag.warn{border-left-color:var(--gold);background:rgba(217,154,58,.08);}
.biz-flag.watch{border-left-color:var(--sage);background:rgba(138,155,120,.07);}
.biz-flag .ttl{font-size:13.5px;font-weight:700;color:var(--ink);}
.biz-flag .meta{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.45;}

.biz-team{display:flex;flex-direction:column;gap:12px;}
.biz-person{padding-bottom:12px;border-bottom:1px solid var(--line);}
.biz-person:last-child{border-bottom:none;padding-bottom:0;}
.biz-person .who{display:flex;flex-direction:column;font-size:13.5px;}
.biz-person .who .role{font-size:11.5px;color:var(--clay);font-weight:600;margin-top:1px;}
.biz-person .what{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.4;}

.biz-watch-item{padding:10px 0;border-top:1px solid var(--line);font-size:13px;}
.biz-watch-item:first-child{border-top:none;}
.biz-watch-item .nm{font-weight:700;color:var(--ink);}
.biz-watch-item .st{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;margin-left:8px;padding:2px 8px;border-radius:8px;}
.biz-watch-item .st.risk{background:rgba(192,64,64,.14);color:#c04040;}
.biz-watch-item .st.mon{background:rgba(217,154,58,.16);color:#95651c;}
