:root{
  --ink:#2A2A2A;
  --line:#E8E8E8;
  --line-soft:#F1F1F1;
  --muted:#9A9A9A;
  --red:#E05C5C;
  --orange:#F5A623;
  --blue:#4A90D9;
  --green:#5CB85C;
  --purple:#9B59B6;
  --tabbar-h:62px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  background:#FFFFFF;
  color:var(--ink);
  font-family:'DM Sans',sans-serif;
  overflow:hidden;
}
.hand{font-family:'Caveat',cursive}

/* ---------- layout shell ---------- */
main{height:100dvh;display:flex;flex-direction:column}
.page{flex:1;display:none;flex-direction:column;min-height:0;padding-bottom:var(--tabbar-h)}
.page.active{display:flex;animation:pageIn .28s ease both}
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- calendar selector (workspace switcher) ---------- */
.sel-row{display:flex;justify-content:center;padding:10px 56px 0;min-height:30px}
.cal-select{
  background:none;border:none;cursor:pointer;
  font-family:'Caveat',cursive;font-weight:600;font-size:20px;color:var(--muted);
  display:inline-flex;align-items:center;gap:7px;padding:1px 10px 3px;
  border-radius:10px 13px 9px 12px/12px 9px 13px 10px;
  transition:color .15s;
}
.cal-select:hover{color:var(--ink);background:#FAFAFA}
.cal-select .cdot{width:9px;height:9px}
.cal-select .extra{font-size:15px;color:var(--muted)}
.cdot{
  display:inline-block;width:10px;height:10px;flex:none;
  border-radius:46% 54% 50% 50%/52% 48% 54% 46%;transform:rotate(15deg);
}

/* ---------- calendar manager panel ---------- */
.panel-backdrop{
  position:fixed;inset:0;z-index:58;display:none;
  justify-content:center;align-items:flex-start;padding:48px 12px 12px;
}
.panel-backdrop.open{display:flex}
.panel{
  transform:rotate(-.3deg);z-index:60;
  background:#fff;width:min(380px,94vw);max-height:min(74dvh,560px);overflow-y:auto;
  border:2.5px solid var(--ink);
  border-radius:14px 18px 12px 16px/16px 12px 18px 14px;
  box-shadow:4px 5px 0 rgba(42,42,42,.14);
  padding:12px 14px 14px;
  animation:popIn .2s cubic-bezier(.34,1.4,.64,1) both;
}
.panel h4{
  font-family:'Caveat',cursive;font-weight:700;font-size:22px;
  margin:2px 2px 6px;transform:rotate(-.6deg);
}
.panel-row{
  display:flex;align-items:center;gap:9px;padding:7px 4px;
  border-bottom:1.5px solid var(--line-soft);cursor:pointer;
}
.panel-row:hover{background:#FAFAFA}
.panel-row .vis{
  width:21px;height:21px;flex:none;cursor:pointer;background:#fff;
  border:2px solid var(--muted);
  border-radius:8px 10px 7px 9px/9px 7px 10px 8px;
  font-family:'Caveat',cursive;font-weight:700;font-size:16px;line-height:1;color:var(--ink);
  display:flex;align-items:center;justify-content:center;padding:0;
}
.panel-row .vis.on{border-color:var(--ink)}
.panel-row .nm{
  flex:1;min-width:0;font-family:'Caveat',cursive;font-weight:600;font-size:21px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.panel-row.is-active .nm{text-decoration:underline 2px}
.panel-row .tag{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.panel-row .tag.shared{color:var(--blue)}
.panel-row .mini{
  background:none;border:none;cursor:pointer;color:var(--muted);
  font-family:'Caveat',cursive;font-size:17px;padding:2px 4px;
}
.panel-row .mini:hover{color:var(--ink)}
.panel-acts{display:flex;flex-direction:column;gap:2px;padding-top:8px}
.panel-act{
  background:none;border:none;cursor:pointer;text-align:left;
  font-family:'Caveat',cursive;font-weight:600;font-size:19px;color:var(--ink);
  padding:4px 4px 5px;border-radius:8px;
}
.panel-act:hover{background:#FAFAFA}
.panel-act.subtle{color:var(--muted);font-size:17px}
.panel-act.danger{color:var(--red)}
.panel-foot{
  border-top:1.5px solid var(--line);margin-top:8px;padding-top:9px;
  font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.panel-foot .who{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.g-btn{
  display:inline-flex;align-items:center;gap:8px;background:#fff;cursor:pointer;
  border:2px solid var(--ink);color:var(--ink);
  border-radius:11px 14px 10px 13px/13px 10px 14px 11px;
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:13px;
  padding:7px 14px 8px;
}
.g-btn:hover{transform:rotate(-1deg)}
.g-btn svg{width:16px;height:16px}
.setup-hint{font-size:12px;color:var(--muted);line-height:1.45;padding:2px 4px}
.setup-hint code{background:#F5F5F5;padding:1px 4px;border-radius:4px;font-size:11px}
.panel-foot{flex-wrap:wrap}
.auth-or{
  width:100%;text-align:center;color:var(--muted);
  font-family:'Caveat',cursive;font-size:17px;margin:6px 0 2px;
}
.auth-form{display:flex;flex-direction:column;gap:9px;width:100%}
.auth-form input{
  width:100%;border:none;border-bottom:2px solid var(--line);
  background:transparent;outline:none;color:var(--ink);
  padding:5px 2px 6px;font-family:'DM Sans',sans-serif;font-size:13.5px;border-radius:0;
}
.auth-form input:focus{border-bottom-color:var(--ink)}
.auth-row{display:flex;gap:8px;justify-content:flex-end;margin-top:2px}
.marker-btn.sm{font-size:17px;padding:5px 14px 7px;border-width:2px}

/* ---------- generic small dialog ---------- */
.dlg-backdrop{
  position:fixed;inset:0;background:rgba(42,42,42,.28);z-index:70;
  display:none;align-items:center;justify-content:center;padding:18px;
}
.dlg-backdrop.open{display:flex;animation:fadeIn .18s ease}
.dlg{
  background:#fff;width:min(360px,100%);
  border:2.5px solid var(--ink);
  border-radius:14px 18px 12px 16px/16px 12px 18px 14px;
  box-shadow:4px 5px 0 rgba(42,42,42,.14);
  transform:rotate(-.4deg);padding:16px 18px;
  animation:popIn .22s cubic-bezier(.34,1.4,.64,1) both;
}
.dlg h3{font-family:'Caveat',cursive;font-weight:700;font-size:27px;margin-bottom:8px;transform:rotate(-.8deg)}
.dlg p{font-size:13.5px;color:#5a5a5a;line-height:1.5;margin-bottom:10px}
.dlg .big-code{
  font-family:'Caveat',cursive;font-weight:700;font-size:42px;letter-spacing:.14em;
  text-align:center;padding:6px 0 10px;user-select:all;
}
.dlg input[type=text]{
  width:100%;border:none;border-bottom:2px solid var(--line);
  background:transparent;outline:none;color:var(--ink);
  padding:4px 2px 6px;font-family:'Caveat',cursive;font-size:24px;font-weight:600;
  border-radius:0;margin-bottom:14px;
}
.dlg input[type=text]:focus{border-bottom-color:var(--ink)}
.dlg-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}
.dlg .err{color:var(--red);font-size:12.5px;min-height:16px;margin-bottom:4px}

/* color picker dialog */
.cdot-btn{
  background:none;border:none;cursor:pointer;padding:4px;margin:-4px;
  display:flex;align-items:center;border-radius:50%;
}
.cdot-btn:hover .cdot{transform:rotate(15deg) scale(1.35)}
.cdot-btn .cdot{transition:transform .12s}
.color-grid{display:flex;flex-wrap:wrap;gap:11px;padding:8px 2px 4px}
.color-swatch{
  width:36px;height:36px;cursor:pointer;border:2.5px solid transparent;
  border-radius:46% 54% 50% 50%/52% 48% 54% 46%;
  transform:rotate(8deg);transition:transform .12s;
}
.color-swatch:hover{transform:rotate(8deg) scale(1.12)}
.color-swatch.sel{border-color:var(--ink);transform:scale(1.15)}
.custom-color-row{display:flex;align-items:center;gap:10px;margin-top:12px}
.custom-color-row input[type=color]{
  width:44px;height:34px;border:2px solid var(--line);border-radius:9px 12px 8px 11px/11px 8px 12px 9px;
  background:#fff;cursor:pointer;padding:2px;
}
.custom-color-row .tag{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}

/* members dialog */
.mem-row{
  display:flex;align-items:center;gap:9px;padding:8px 2px;
  border-bottom:1.5px solid var(--line-soft);
}
.mem-row:last-child{border-bottom:none}
.mem-name{
  flex:1;min-width:0;font-family:'Caveat',cursive;font-weight:600;font-size:20px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.mem-name small{font-size:14px;color:var(--muted);font-weight:500}
.mem-row .tag{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.mem-row .tag.shared{color:var(--blue)}
.mem-btns{display:flex;gap:4px}
.mem-btns .mini{
  background:none;border:none;cursor:pointer;color:var(--muted);
  font-family:'Caveat',cursive;font-size:17px;padding:2px 5px;white-space:nowrap;
}
.mem-btns .mini:hover{color:var(--ink)}
.mem-btns .mini.ok{color:var(--green);font-weight:700}
.mem-btns .mini.danger:hover{color:var(--red)}
.mem-btns .mini.confirming{color:var(--red);font-weight:700}

/* ---------- calendar page ---------- */
.cal-head{position:relative;text-align:center;padding:0 56px 6px}
.month-label{
  font-family:'Caveat',cursive;font-style:italic;font-weight:600;
  font-size:clamp(34px,5vw,46px);line-height:1;
  display:inline-block;transform:rotate(-1.2deg);
}
.month-underline{display:block;margin:2px auto 0;width:min(240px,60%);height:8px;overflow:visible}
.month-underline path{
  stroke:var(--ink);stroke-width:2.5;fill:none;stroke-linecap:round;opacity:.85;
  stroke-dasharray:300;stroke-dashoffset:300;animation:drawIn .7s .15s ease forwards;
}
@keyframes drawIn{to{stroke-dashoffset:0}}
.nav-arrow{
  position:absolute;top:4px;background:none;border:none;cursor:pointer;
  font-family:'Caveat',cursive;font-size:36px;line-height:1;color:var(--muted);
  padding:4px 14px;transition:color .15s, transform .15s;z-index:2;
}
.nav-arrow:hover{color:var(--ink);transform:scale(1.15)}
.nav-arrow.prev{left:8px}
.nav-arrow.next{right:8px}
.today-jump{
  position:absolute;right:16px;top:52px;background:none;border:none;cursor:pointer;
  font-family:'Caveat',cursive;font-size:19px;color:var(--muted);
}
.today-jump:hover{color:var(--ink)}

.cal-wrap{flex:1;min-height:0;overflow-y:auto;padding:4px 14px 18px}
.weekday-row{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:2px}
.weekday-row span{
  font-family:'Caveat',cursive;font-weight:600;font-size:17px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  text-align:center;padding:4px 0;
}
.cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(96px,auto);
  border-right:1.5px solid var(--line-soft);border-bottom:1.5px solid var(--line-soft);
}
.cell{
  position:relative;padding:7px 8px 8px;cursor:pointer;min-width:0;
  animation:cellIn .35s ease both;
}
@keyframes cellIn{from{opacity:0}to{opacity:1}}
.cell.blank{cursor:default;animation:none}
.cell-line{position:absolute;inset:-1px 0 0 -1px;border-top:1.5px solid var(--line);border-left:1.5px solid var(--line);pointer-events:none}
.cell:hover:not(.blank){background:#FAFAFA}
.date-num{
  font-family:'Caveat',cursive;font-weight:600;font-size:21px;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  min-width:30px;height:30px;color:var(--ink);
}
.date-num.today{
  border:2.5px solid rgba(224,92,92,.75);
  border-radius:52% 46% 55% 44% / 46% 56% 43% 54%;
  transform:rotate(-7deg);
}
.cell-events{margin-top:3px;display:flex;flex-direction:column;gap:1px}
.cell-ev{
  font-family:'Caveat',cursive;font-weight:500;font-size:16.5px;line-height:1.25;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cell-ev .cdot{width:7px;height:7px;margin-right:4px;vertical-align:1px}
.more-link{
  font-family:'Caveat',cursive;font-size:15px;color:var(--muted);margin-top:1px;
}

/* mobile agenda */
.agenda{display:none;flex:1;overflow-y:auto;padding:6px 20px 24px}
.agenda-day{padding:10px 2px 12px;border-bottom:1.5px solid var(--line)}
.agenda-date{font-family:'Caveat',cursive;font-weight:700;font-size:23px;display:flex;align-items:baseline;gap:10px}
.agenda-date small{font-size:16px;font-weight:500;color:var(--muted)}
.agenda-date .today-ring{
  display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;
  border:2.5px solid rgba(224,92,92,.75);border-radius:52% 46% 55% 44% / 46% 56% 43% 54%;
  transform:rotate(-6deg);
}
.agenda-ev{font-family:'Caveat',cursive;font-size:19px;padding:2px 0 0 6px}
.agenda-ev small{color:var(--muted);font-size:15px;margin-left:6px}
.agenda-ev .cdot{width:8px;height:8px;margin-right:5px}
.agenda-empty{font-family:'Caveat',cursive;font-size:24px;color:var(--muted);text-align:center;margin-top:60px;transform:rotate(-1.5deg)}

.fab{
  display:none;position:fixed;right:18px;bottom:calc(var(--tabbar-h) + 16px);z-index:30;
  width:54px;height:54px;background:#fff;border:2.5px solid var(--ink);
  border-radius:48% 52% 46% 54% / 54% 46% 56% 44%;
  font-family:'Caveat',cursive;font-size:34px;line-height:1;color:var(--ink);
  cursor:pointer;box-shadow:2px 3px 0 rgba(42,42,42,.12);
}
.fab:active{transform:scale(.94)}

/* ---------- day/event modal ---------- */
.backdrop{
  position:fixed;inset:0;background:rgba(42,42,42,.28);z-index:50;
  display:none;align-items:center;justify-content:center;padding:18px;
}
.backdrop.open{display:flex;animation:fadeIn .18s ease}
@keyframes fadeIn{from{opacity:0}}
.modal{
  background:#fff;width:min(440px,100%);max-height:min(82dvh,640px);
  display:flex;flex-direction:column;
  border:2.5px solid var(--ink);
  border-radius:14px 18px 12px 16px / 16px 12px 18px 14px;
  box-shadow:4px 5px 0 rgba(42,42,42,.14);
  transform:rotate(-.4deg);
  animation:popIn .22s cubic-bezier(.34,1.4,.64,1) both;
}
@keyframes popIn{from{opacity:0;transform:scale(.93) rotate(-.4deg)}to{opacity:1;transform:scale(1) rotate(-.4deg)}}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 18px 4px}
.modal-title{font-family:'Caveat',cursive;font-weight:700;font-size:30px;line-height:1.05;transform:rotate(-.8deg)}
.modal-close{
  background:none;border:none;cursor:pointer;font-family:'Caveat',cursive;
  font-size:30px;line-height:1;color:var(--muted);padding:0 4px;
}
.modal-close:hover{color:var(--ink)}
.modal-body{flex:1;overflow-y:auto;padding:8px 18px 16px}

.ev-row{display:flex;gap:10px;align-items:flex-start;padding:9px 2px;border-bottom:1.5px solid var(--line-soft)}
.ev-row:last-of-type{border-bottom:none}
.ev-dot{width:11px;height:11px;border-radius:46% 54% 50% 50%/52% 48% 54% 46%;margin-top:8px;flex:none;transform:rotate(20deg)}
.ev-main{flex:1;min-width:0}
.ev-title{font-family:'Caveat',cursive;font-weight:600;font-size:23px;line-height:1.1}
.ev-meta{font-size:12.5px;color:var(--muted);margin-top:1px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.ev-notes{font-family:'Caveat',cursive;font-size:17px;color:#5a5a5a;margin-top:2px;line-height:1.2}
.ev-amount{font-size:14px;font-weight:700;white-space:nowrap;margin-top:6px}
.ev-actions{display:flex;flex-direction:column;gap:6px;margin-top:3px}
.icon-btn{
  background:none;border:none;cursor:pointer;color:var(--muted);
  line-height:1;padding:3px;font-family:'Caveat',cursive;font-size:18px;
}
.icon-btn:hover{color:var(--ink)}
.icon-btn.danger:hover{color:var(--red)}
.icon-btn.confirming{color:var(--red);font-weight:700}
.no-events{font-family:'Caveat',cursive;font-size:22px;color:var(--muted);text-align:center;padding:26px 0;transform:rotate(-1deg)}

.marker-btn{
  display:inline-block;background:#fff;cursor:pointer;
  border:2.5px solid var(--ink);color:var(--ink);
  border-radius:12px 16px 10px 14px / 14px 10px 16px 12px;
  font-family:'Caveat',cursive;font-weight:700;font-size:22px;line-height:1;
  padding:8px 22px 10px;
  transition:transform .12s, box-shadow .12s;
}
.marker-btn:hover{transform:rotate(-1deg) scale(1.03);box-shadow:2px 3px 0 rgba(42,42,42,.15)}
.marker-btn:active{transform:scale(.97)}
.marker-btn.primary{background:var(--ink);color:#fff}
.marker-btn.ghost{border-color:var(--muted);color:var(--muted)}
.modal-foot{padding:0 18px 16px;display:flex;gap:10px;justify-content:flex-end}

/* ---------- event form ---------- */
.fld{margin-bottom:13px}
.fld label{display:block;font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.fld input[type=text],.fld input[type=date],.fld input[type=time],.fld input[type=number],.fld textarea{
  width:100%;border:none;border-bottom:2px solid var(--line);
  background:transparent;outline:none;color:var(--ink);
  padding:4px 2px 6px;font-family:'DM Sans',sans-serif;font-size:15px;
  border-radius:0;
}
.fld input:focus,.fld textarea:focus{border-bottom-color:var(--ink)}
#f-title{font-family:'Caveat',cursive !important;font-size:26px !important;font-weight:600}
.fld textarea{font-family:'Caveat',cursive !important;font-size:19px !important;resize:vertical;min-height:44px;line-height:1.25}
.chip-row{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  border:2px solid;background:#fff;cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:700;
  padding:5px 13px 6px;
  border-radius:11px 14px 10px 13px / 13px 10px 14px 11px;
  transition:all .12s;
}
.chip.sel{color:#fff !important;transform:rotate(-1.5deg)}
.cal-chip{
  border:2px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;
  font-family:'Caveat',cursive;font-size:17px;font-weight:600;
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 12px 5px;border-radius:11px 14px 10px 13px/13px 10px 14px 11px;
}
.cal-chip.sel{border-color:var(--ink);transform:rotate(-1deg)}
.cal-chip .cdot{width:8px;height:8px}
.seg-row{display:flex;gap:7px;flex-wrap:wrap}
.seg{
  border:2px solid var(--line);background:#fff;color:var(--muted);cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;
  padding:5px 12px 6px;border-radius:10px 13px 9px 12px/12px 9px 13px 10px;
}
.seg.sel{border-color:var(--ink);color:var(--ink);font-weight:700;transform:rotate(-1deg)}
.two-col{display:flex;gap:16px}
.two-col .fld{flex:1}

/* ---------- whiteboard ---------- */
.board-top{display:flex;align-items:center;gap:4px;padding:8px 14px 0;flex-wrap:wrap}
.board-top .cal-select{font-size:18px;padding-left:0}
.board-tabs{display:flex;gap:2px;align-items:center;flex-wrap:wrap;flex:1;min-width:0}
.board-tab{
  background:none;border:none;cursor:pointer;
  font-family:'Caveat',cursive;font-weight:600;font-size:21px;color:var(--muted);
  padding:2px 12px 4px;position:relative;white-space:nowrap;
}
.board-tab.active{color:var(--ink)}
.board-tab.active::after{
  content:"";position:absolute;left:10px;right:10px;bottom:0;height:3px;
  background:var(--ink);border-radius:40% 60% 50% 50%/60% 40% 60% 40%;opacity:.85;
}
.board-tab input{
  font-family:'Caveat',cursive;font-weight:600;font-size:21px;color:var(--ink);
  border:none;border-bottom:2px solid var(--ink);outline:none;background:#fff;width:110px;
}
.board-add{
  background:none;border:none;cursor:pointer;color:var(--muted);
  font-family:'Caveat',cursive;font-size:25px;line-height:1;padding:0 10px 4px;
}
.board-add:hover{color:var(--ink)}
.live-dot{
  display:inline-block;width:8px;height:8px;background:var(--green);
  border-radius:50%;margin-left:6px;vertical-align:2px;
  animation:pulse 1.6s ease infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.toolbar{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:8px 14px 10px;border-bottom:1.5px solid var(--line);
}
.swatches{display:flex;gap:7px}
.swatch{
  width:26px;height:26px;cursor:pointer;border:2px solid transparent;
  border-radius:46% 54% 50% 50%/52% 48% 54% 46%;
  transition:transform .12s;
}
.swatch.sel{border-color:var(--ink);transform:scale(1.18) rotate(8deg)}
.sizes{display:flex;gap:6px;align-items:center}
.size-btn{
  width:30px;height:30px;background:#fff;border:2px solid var(--line);cursor:pointer;
  border-radius:48% 52% 46% 54%/54% 46% 56% 44%;
  display:flex;align-items:center;justify-content:center;
}
.size-btn.sel{border-color:var(--ink)}
.size-btn i{background:var(--ink);border-radius:50%;display:block}
.tool-btn{
  background:#fff;border:2px solid var(--line);cursor:pointer;color:var(--ink);
  font-family:'Caveat',cursive;font-weight:600;font-size:18px;line-height:1;
  padding:5px 13px 7px;border-radius:10px 13px 9px 12px/12px 9px 13px 10px;
}
.tool-btn.sel{border-color:var(--ink);transform:rotate(-1.5deg)}
.tool-btn.danger{color:var(--red)}
.tool-spacer{flex:1}
.canvas-wrap{flex:1;min-height:0;position:relative}
#board-canvas{position:absolute;inset:0;width:100%;height:100%;touch-action:none;cursor:crosshair}

/* ---------- budget ---------- */
.budget-wrap{flex:1;overflow-y:auto;padding:0 20px 28px;max-width:640px;width:100%;margin:0 auto}
.budget-head{position:relative;text-align:center;padding:0 56px 10px}
.totals{display:flex;justify-content:center;gap:clamp(18px,6vw,48px);padding:8px 0 18px}
.total-box{text-align:center}
.total-box .lbl{font-family:'Caveat',cursive;font-weight:600;font-size:20px;color:var(--muted)}
.total-box .val{font-size:clamp(20px,4.5vw,28px);font-weight:700;letter-spacing:-.02em}
.bgt-group{margin-bottom:20px}
.bgt-group h3{
  font-family:'Caveat',cursive;font-weight:700;font-size:26px;
  display:flex;align-items:center;gap:9px;margin-bottom:2px;transform:rotate(-.6deg);
}
.bgt-group h3 .ev-dot{margin-top:2px}
.bgt-row{display:flex;align-items:baseline;gap:10px;padding:6px 2px 7px;border-bottom:1.5px solid var(--line-soft)}
.bgt-row .t{font-family:'Caveat',cursive;font-weight:500;font-size:21px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bgt-row .t .cdot{width:8px;height:8px;margin-right:5px}
.bgt-row .d{font-size:12px;color:var(--muted);white-space:nowrap}
.bgt-row .a{font-size:14.5px;font-weight:700;white-space:nowrap}
.bgt-sub{display:flex;justify-content:flex-end;gap:10px;padding:6px 2px 0;font-size:13px;font-weight:700}
.bgt-sub .lbl{font-family:'Caveat',cursive;font-weight:600;font-size:18px;color:var(--muted)}
.bgt-empty{font-family:'Caveat',cursive;font-size:23px;color:var(--muted);text-align:center;padding:34px 0;transform:rotate(-1deg)}
.chart-box{margin-top:8px;padding-top:6px}
.chart-box h3{font-family:'Caveat',cursive;font-weight:700;font-size:25px;margin-bottom:12px;transform:rotate(-.6deg)}
.chart{display:flex;align-items:flex-end;gap:4%;height:130px;border-bottom:2px solid var(--ink);padding:0 4px}
.chart-col{flex:1;display:flex;align-items:flex-end;justify-content:center;gap:4px;height:100%;position:relative}
.bar{width:min(22px,38%);border-radius:6px 8px 2px 3px/8px 6px 3px 2px;min-height:2px;transition:height .4s ease;transform-origin:bottom}
.bar.in{background:rgba(92,184,92,.8)}
.bar.out{background:rgba(224,92,92,.8)}
.chart-labels{display:flex;gap:4%;padding:5px 4px 0}
.chart-labels span{flex:1;text-align:center;font-family:'Caveat',cursive;font-size:16px;color:var(--muted)}
.chart-legend{display:flex;gap:16px;justify-content:center;margin-top:10px;font-size:12px;color:var(--muted)}
.chart-legend i{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:-1px}

/* ---------- tab bar ---------- */
nav.tabbar{
  position:fixed;left:0;right:0;bottom:0;height:var(--tabbar-h);z-index:40;
  background:#fff;border-top:1.5px solid var(--line);
  display:flex;justify-content:space-around;align-items:stretch;
  padding-bottom:env(safe-area-inset-bottom);
}
.tab{
  flex:1;max-width:160px;background:none;border:none;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:#ABABAB;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:.05em;position:relative;transition:color .15s;
}
.tab svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tab.active{color:var(--ink)}
.tab.active::after{
  content:"";position:absolute;bottom:7px;width:5px;height:5px;background:var(--ink);
  border-radius:60% 40% 55% 45%/45% 55% 40% 60%;
}

/* ---------- toast ---------- */
.toast{
  position:fixed;left:50%;bottom:calc(var(--tabbar-h) + 18px);transform:translateX(-50%) rotate(-.5deg);
  background:var(--ink);color:#fff;z-index:80;
  font-family:'Caveat',cursive;font-weight:600;font-size:19px;
  padding:8px 20px 10px;border-radius:12px 16px 10px 14px/14px 10px 16px 12px;
  opacity:0;pointer-events:none;transition:opacity .25s;
  max-width:90vw;text-align:center;
}
.toast.show{opacity:1}

/* ---------- responsive ---------- */
@media (max-width:640px){
  .cal-grid{grid-auto-rows:minmax(72px,auto)}
  .cell{padding:4px 4px 5px}
  .cell-ev{font-size:14px}
  .date-num{font-size:18px;min-width:26px;height:26px}
}
@media (max-width:500px){
  .cal-wrap .weekday-row,.cal-wrap .cal-grid{display:none}
  .agenda{display:block}
  .fab{display:block}
  .backdrop{align-items:flex-end;padding:0}
  .modal{
    width:100%;max-height:88dvh;transform:none;
    border-radius:18px 22px 0 0/22px 18px 0 0;border-bottom:none;
    animation:slideUp .26s cubic-bezier(.32,1.2,.62,1) both;
  }
  @keyframes slideUp{from{transform:translateY(60%);opacity:.4}to{transform:none;opacity:1}}
}
