@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=DM+Sans:wght@300;400;500;600&display=swap');
:root{
  --bg:#fdf6f8;--surface:#fff;--surface2:#fdf0f3;--border:#f0d9e0;--border2:#ddb8c4;
  --text:#2d1f25;--text2:#8a6672;--text3:#c4a0aa;
  --accent:#c8456c;--accent-light:#fce8ee;
  --lavender:#e8e0f5;--lavender-text:#9b7ec8;
  --tsumitate:#e85a8a;--growth:#5a8fc8;
  --c-work:#c8456c;--c-life:#5a8fc8;--c-learn:#c87a3a;--c-travel:#4a8a5a;
  --good:#2d5a3d;--good-soft:#e6f0ea;--bad:#8b2c2c;--bad-soft:#f6e3e3;
  --c-income:#2d5a3d;--c-fixed:#86AFC5;--c-food:#C79A9A;--c-transport:#B8C89A;--c-necessities:#D1B36A;--c-optional:#B7A6B5;
  --radius:8px;--radius-lg:14px;
  --mono:'DM Mono',monospace;--sans:'DM Sans',sans-serif;
  --fs-base:15px;--fs-sm:13px;--fs-xs:11px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:var(--fs-base);height:100vh;display:flex;flex-direction:column;overflow:hidden}

/* TOPBAR */
.topbar{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}
.logo{font-family:var(--mono);font-size:14px;font-weight:500;letter-spacing:-.02em;margin-right:12px}.logo span{color:var(--accent)}
.vbtns{display:flex;border:1px solid var(--border);border-radius:20px;overflow:hidden}
.vbtn{padding:4px 14px;background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:var(--fs-sm);color:var(--text2);border-right:1px solid var(--border);transition:.15s}.vbtn:last-child{border-right:none}.vbtn.active{background:var(--accent);color:#fff}
.spacer{flex:1}
.nav-wrap{display:flex;align-items:center;gap:8px}
.nav-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:3px 10px;cursor:pointer;font-size:14px;color:var(--text2)}
.period{font-family:var(--mono);font-size:var(--fs-sm);min-width:160px;text-align:center}
.save-btn{padding:5px 16px;background:var(--accent);color:#fff;border:none;border-radius:20px;font-family:var(--sans);font-size:var(--fs-sm);font-weight:500;cursor:pointer}
.load-lbl{padding:5px 14px;background:none;border:1px solid var(--border);border-radius:20px;font-family:var(--sans);font-size:var(--fs-sm);color:var(--text2);cursor:pointer}

/* LAYOUT */
.app-shell{display:flex;flex:1;overflow:hidden}
.panel{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;min-height:0}
.sidebar{width:250px;border-left:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;overflow:hidden;transition:width .2s ease}
.sidebar.collapsed{width:28px}
.sidebar.collapsed .sidebar-body{display:none}
.sidebar.collapsed .stab{display:none}
.stabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}
.stab{flex:1;padding:8px 4px;background:none;border:none;font-family:var(--sans);font-size:var(--fs-sm);color:var(--text2);cursor:pointer;border-bottom:2px solid transparent}.stab.active{color:var(--text);border-bottom-color:var(--text)}
.sidebar-toggle{background:none;border:none;color:var(--text3);cursor:pointer;padding:8px 12px;font-size:var(--fs-base);flex-shrink:0;line-height:1}.sidebar-toggle:hover{color:var(--text)}
.sidebar-body{flex:1;overflow-y:auto;padding:10px}

/* NOTES */
.note-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px;margin-bottom:6px}
.note-toolbar{display:flex;gap:4px;margin-bottom:4px}
.note-fmt-btn{background:none;border:1px solid var(--border);border-radius:3px;padding:1px 6px;font-size:var(--fs-xs);cursor:pointer;color:var(--text2);font-family:var(--sans);line-height:1.4}
.note-fmt-btn:hover{background:var(--surface);border-color:var(--accent)}
.note-content{outline:none;font-family:var(--sans);font-size:var(--fs-base);color:var(--text);min-height:48px;line-height:1.5;word-break:break-word}
.note-content:empty:before{content:attr(data-placeholder);color:var(--text3);pointer-events:none}
.note-meta{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono);margin-top:4px;display:flex;justify-content:space-between}
.icon-btn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:var(--fs-xs);padding:0 2px}
.add-btn{width:100%;padding:7px;background:none;border:1px dashed var(--border2);border-radius:var(--radius);color:var(--text2);cursor:pointer;font-family:var(--sans);font-size:var(--fs-sm);margin-top:6px}

/* EVENT PILL */
.evt-pill{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-sm);border-radius:3px;padding:2px 8px;margin:2px 0}
.evt-pill button{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:var(--fs-sm);padding:0;line-height:1}


/* SPEND */
.spend-day-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:10px 14px}
.spend-cat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:6px 8px}
.spend-cat-label{font-size:var(--fs-xs);color:var(--text2);margin-bottom:2px;display:flex;align-items:center;gap:4px}
.spend-cat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.spend-expr-input{width:100%;background:none;border:none;outline:none;font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;color:var(--text)}.spend-expr-input::placeholder{color:var(--text3);font-weight:300;font-size:var(--fs-xs)}
.spend-breakdown{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono);margin-top:1px}
.spend-total-row{padding:8px 14px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}

/* WEEK */
.week-shell{display:grid;grid-template-columns:90px repeat(7,1fr);column-gap:5px;overflow-x:auto;flex-shrink:0;min-width:500px}

.week-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:8px;display:flex;flex-direction:column;gap:4px;overflow-y:auto;height:200px;margin-bottom:10px}
.week-col.today-col{border-color:var(--accent);border-width:1.5px}
.week-col.focus-col{background:#fce8ee;border-color:#c2607a;border-width:1.5px}
.wc-head{text-align:center;padding-bottom:6px;border-bottom:1px solid var(--border);margin-bottom:2px;flex-shrink:0;cursor:pointer}
.wc-dow{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text2)}
.wc-num{font-family:var(--mono);font-size:20px;font-weight:300}
.wc-task{font-size:var(--fs-sm);background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:4px 7px;cursor:pointer;line-height:1.4;word-break:break-word;display:flex;align-items:flex-start;gap:4px}
.wc-task.done{text-decoration:line-through;opacity:.4}
.wc-task-text{flex:1}
.wc-task-del{opacity:0;transition:.1s;flex-shrink:0;font-size:var(--fs-xs)}.wc-task:hover .wc-task-del{opacity:.5}
.wc-task-input{width:100%;background:none;border:none;border-bottom:1px dashed var(--border);outline:none;font-family:var(--sans);font-size:var(--fs-sm);color:var(--text2);padding:3px 2px;flex-shrink:0}
.wc-spend{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text3);padding-top:4px;border-top:1px solid var(--border);margin-top:auto;flex-shrink:0}
.wk-spend-toggle{display:flex;align-items:center;justify-content:space-between;padding:4px 2px;flex-shrink:0}
.wk-sp-corner{font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);padding:5px 8px;border-right:1px solid var(--border);border-bottom:1px solid var(--border2);border-top:2px solid var(--border2);background:var(--surface2);display:flex;align-items:center}
.wk-sp-hdr{font-family:var(--mono);font-size:var(--fs-xs);text-align:center;padding:4px 2px;border-right:1px solid var(--border);border-bottom:1px solid var(--border2);border-top:2px solid var(--border2);background:var(--surface2);color:var(--text2);display:flex;flex-direction:column;align-items:center;gap:1px}
.wk-sp-hdr-n{font-size:var(--fs-sm);color:var(--text);font-weight:500}
.wk-sp-lab{font-size:var(--fs-xs);padding:3px 8px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface2);display:flex;flex-direction:column;gap:1px;justify-content:center}
.wk-sp-jp{color:var(--text);font-weight:500;font-size:var(--fs-xs)}
.wk-sp-en{color:var(--text3);font-size:var(--fs-xs)}
.wk-sp-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.wk-sp-inp{width:100%;border:none;outline:none;background:none;font-family:var(--mono);font-size:var(--fs-xs);text-align:right;padding:4px 5px;color:var(--text)}.wk-sp-inp:focus{background:var(--accent-light)}.wk-sp-inp::-webkit-inner-spin-button,.wk-sp-inp::-webkit-outer-spin-button{-webkit-appearance:none}
.wk-sp-log{width:100%;font-family:var(--mono);font-size:var(--fs-xs);text-align:right;padding:4px 5px;color:var(--text);cursor:pointer;min-height:22px;box-sizing:border-box}.wk-sp-log:hover{background:var(--accent-light)}
.sl-list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px;max-height:200px;overflow-y:auto}
.sl-item{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);padding:4px 0;border-bottom:1px solid var(--border)}
.sl-item-label{flex:1;color:var(--text2)}
.sl-item-amount{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text)}
.sl-del{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:0 2px;line-height:1}.sl-del:hover{color:var(--bad)}
.sl-total{font-family:var(--mono);font-size:var(--fs-sm);text-align:right;color:var(--text2);margin-bottom:10px;padding-top:4px;border-top:1px solid var(--border2)}
.sl-add-row{display:flex;gap:6px;align-items:center;margin-bottom:8px}
.sl-inp{border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:var(--fs-sm);font-family:var(--sans);background:var(--bg);color:var(--text);outline:none}.sl-inp:focus{border-color:var(--accent)}
.search-result{display:flex;align-items:center;gap:8px;padding:7px 6px;border-radius:6px;cursor:pointer}.search-result:hover{background:var(--surface2)}
.wk-sp-tot-lab{font-weight:600;border-top:1px solid var(--border2)}
.wk-sp-tot{font-family:var(--mono);font-size:var(--fs-xs);text-align:right;padding:4px 5px;color:var(--text2);background:var(--surface2);border-right:1px solid var(--border);border-top:1px solid var(--border2)}
.wc-evt{font-size:var(--fs-xs);border-radius:3px;padding:2px 6px;flex-shrink:0;display:flex;align-items:center;gap:3px}
.wc-slot{font-size:var(--fs-xs);color:var(--text2);line-height:1.4;padding:1px 0}

/* MONTH */
.month-wrap{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}
.month-cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:1fr;gap:2px;flex:1;min-height:0}
.mh-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text2);text-align:center;padding:4px 0;font-weight:500}
.mc{background:var(--surface);border:1px solid var(--border);border-radius:4px;min-height:80px;padding:5px;cursor:pointer;transition:border-color .1s;overflow:hidden}.mc:hover{border-color:var(--border2)}.mc.today-mc{border-color:var(--accent);border-width:1.5px}.mc.other{opacity:.3}
.mc-num{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;margin-bottom:2px}
.mc-item{font-size:var(--fs-xs);border-radius:2px;padding:1px 4px;margin-bottom:1px;word-break:break-word;line-height:1.3}
.mc-spend{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text3);margin-top:2px}
.mc-more{font-size:var(--fs-xs);color:var(--text3);margin-top:1px}


/* YEAR */
.year-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ymb{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.ymb-head{padding:8px 10px;border-bottom:1px solid var(--border);font-weight:500;font-size:var(--fs-sm);display:flex;align-items:center;justify-content:space-between}
.ymb-month-name{font-family:var(--mono)}
.ymb-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;padding:6px 8px}
.ymb-mini-dow{font-size:var(--fs-xs);text-align:center;color:var(--text3);text-transform:uppercase}
.ymb-mini-day{font-size:var(--fs-xs);text-align:center;padding:2px;border-radius:3px;color:var(--text2);cursor:pointer}
.ymb-mini-day.has-ev{background:var(--accent-light);color:var(--accent)}
.ymb-mini-day.has-task{background:var(--lavender);color:var(--lavender-text)}
.ymb-mini-day.has-slot{background:#e8eef5;color:#2c4a6e}
.ymb-mini-day.is-today{background:var(--accent);color:#fff;border-radius:4px}
.ymb-mini-day.other{opacity:.2}
.ymb-goals{border-top:1px solid var(--border);padding:6px 8px}
.ymb-goal-row{display:flex;align-items:center;gap:5px;border-bottom:1px solid var(--border);padding:3px 0}.ymb-goal-row:last-child{border-bottom:none}
.ymb-goal-icon{font-size:var(--fs-xs);width:14px;flex-shrink:0;color:var(--text3)}
.ymb-goal-input{flex:1;background:none;border:none;outline:none;font-family:var(--sans);font-size:var(--fs-xs);color:var(--text)}.ymb-goal-input::placeholder{color:var(--text3)}
.ymb-summary{border-top:1px solid var(--border);padding:4px 8px;font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono)}

/* MULTIYEAR */
.my-year-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px}
.my-year-focused{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.my-year-hdr{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface2)}
.my-year-num{font-family:var(--mono);font-size:18px;font-weight:500}
.my-year-age{font-size:var(--fs-xs);color:var(--text2)}

/* YEAR REDESIGN */
.year-strip{display:flex;gap:6px;padding:2px 0 10px;overflow-x:auto;scrollbar-width:none;flex-shrink:0}
.year-strip::-webkit-scrollbar{display:none}
.year-strip-card{flex:0 0 auto;width:62px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:6px 4px;cursor:pointer;text-align:center;transition:.1s}.year-strip-card:hover{border-color:var(--border2);background:var(--surface2)}.year-strip-card.year-strip-cur{border-color:var(--accent);background:var(--accent-light)}
.year-strip-year{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;color:var(--text)}
.year-strip-age{font-size:var(--fs-xs);color:var(--text3);margin-bottom:4px}
.year-strip-dots{display:flex;flex-wrap:wrap;justify-content:center;min-height:12px;gap:2px}
.year-card-hdr{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface2)}
.year-card-left{display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.year-cat-badges{display:flex;flex-wrap:wrap;gap:4px}
.year-cat-badge{font-size:var(--fs-xs);font-family:var(--mono);padding:1px 6px;border-radius:10px;font-weight:500}
.year-cat-work{background:#f8e0e5;color:var(--c-work)}.year-cat-life{background:#deeaf8;color:var(--c-life)}.year-cat-learn{background:#f8ece0;color:var(--c-learn)}.year-cat-travel{background:#ddf0e5;color:var(--c-travel)}
.year-card-center{min-width:0}
.year-summary-inp{width:100%;background:none;border:1px solid transparent;outline:none;font-family:var(--sans);font-size:var(--fs-sm);color:var(--text);padding:3px 6px;border-radius:4px}.year-summary-inp:hover{border-color:var(--border)}.year-summary-inp:focus{background:var(--surface);border-color:var(--border2)}.year-summary-inp::placeholder{color:var(--text3)}
.year-card-right{min-width:130px}
.year-hdr-nisa{display:flex;flex-direction:column;gap:4px}
.year-hdr-nisa-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.year-hdr-nisa-fill{height:100%;background:linear-gradient(90deg,var(--tsumitate),var(--growth));border-radius:2px}
.year-hdr-nisa-vals{display:flex;gap:6px;align-items:center;font-family:var(--mono);font-size:var(--fs-xs)}
.year-hdr-nisa-v{color:var(--text);font-weight:500}.year-hdr-nisa-p{color:var(--text3)}.year-hdr-nisa-d{color:var(--c-travel);font-weight:500}
.year-timeline{padding:8px 14px 10px;border-top:1px solid var(--border)}
.year-tl-header{display:grid;grid-template-columns:repeat(12,1fr);margin-bottom:4px}
.year-tl-mlabel{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text3);font-family:var(--mono);padding:0 2px;border-right:1px solid var(--border);padding-bottom:3px}.year-tl-mlabel:last-child{border-right:none}
.year-tl-track{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;margin-bottom:2px;min-height:18px}
.year-tl-chip{display:flex;align-items:center;gap:3px;padding:2px 5px;border-radius:4px;overflow:hidden;min-width:0}
.year-tl-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.year-tl-txt{font-size:var(--fs-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;font-family:var(--sans)}
.year-tl-work{background:#f8e0e5}.year-tl-work .year-tl-dot{background:var(--c-work)}.year-tl-work .year-tl-txt{color:var(--c-work)}
.year-tl-life{background:#deeaf8}.year-tl-life .year-tl-dot{background:var(--c-life)}.year-tl-life .year-tl-txt{color:var(--c-life)}
.year-tl-learn{background:#f8ece0}.year-tl-learn .year-tl-dot{background:var(--c-learn)}.year-tl-learn .year-tl-txt{color:var(--c-learn)}
.year-tl-travel{background:#ddf0e5}.year-tl-travel .year-tl-dot{background:var(--c-travel)}.year-tl-travel .year-tl-txt{color:var(--c-travel)}
.year-tl-other{background:var(--surface2)}.year-tl-other .year-tl-dot{background:var(--text3)}.year-tl-other .year-tl-txt{color:var(--text2)}
.year-footer{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px dashed var(--border2);padding:8px 14px;gap:12px}
.year-footer-col{display:flex;align-items:center;gap:6px;min-width:0}
.year-footer-icon{font-size:var(--fs-xs);color:var(--text3);flex-shrink:0;width:12px}
.year-footer-inp{flex:1;background:none;border:1px solid transparent;outline:none;font-family:var(--sans);font-size:var(--fs-xs);color:var(--text);padding:2px 4px;border-radius:4px;min-width:0}.year-footer-inp:hover{border-color:var(--border)}.year-footer-inp:focus{background:var(--surface);border-color:var(--border2)}.year-footer-inp::placeholder{color:var(--text3)}
.year-collapsed{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;transition:.1s}.year-collapsed:hover{background:var(--surface2)}
.year-collapsed-meta{flex:1;font-size:var(--fs-xs);color:var(--text2);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.year-collapsed-expand{font-size:var(--fs-xs);color:var(--text3);flex-shrink:0}

/* SAVINGS */
.savings-wrap{display:flex;flex-direction:column;gap:12px}
.savings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px}
.savings-title{font-size:var(--fs-xs);font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--text2);margin-bottom:10px}
.nisa-projections{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}
.nisa-proj-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px}
.nisa-proj-year{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text2)}
.nisa-proj-age{font-size:var(--fs-xs);color:var(--text3);margin-bottom:4px}
.nisa-proj-val{font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;color:var(--accent)}
.nisa-proj-contrib{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono)}
.nisa-hero{display:flex;gap:12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px}
.nisa-hero-stat{flex:1;min-width:0}
.nisa-hero-lab{font-size:var(--fs-xs);color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.nisa-hero-big{font-family:var(--mono);font-size:16px;font-weight:600;color:var(--text)}
.nisa-hero-sub{font-size:var(--fs-xs);color:var(--text3);margin-top:2px}
.nisa-prog{display:flex;height:5px;border-radius:3px;overflow:hidden;background:var(--border);margin-top:5px}
.nisa-prog-t{background:var(--accent);height:100%}
.nisa-prog-g{background:#2c4a6e;height:100%}
.nisa-leg{display:flex;gap:8px;margin-top:4px}
.nisa-2col{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.nisa-panel{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px}
.nisa-phdr{font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.nisa-panel.ts .nisa-phdr{color:var(--accent)}
.nisa-panel.gr .nisa-phdr{color:#2c4a6e}
.nisa-tl-row{display:flex;align-items:center;gap:5px;margin-bottom:5px}
.nisa-tl-year{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text2);width:36px;flex-shrink:0}
.nisa-tl-inp{flex:1;min-width:0;border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-family:var(--mono);font-size:var(--fs-xs);background:var(--surface);color:var(--text);outline:none}
.nisa-tl-annot{font-size:var(--fs-xs);color:var(--text3);white-space:nowrap}
.nisa-tl-x{background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;line-height:1;padding:0 2px;flex-shrink:0}
.nisa-tl-skip{font-size:var(--fs-xs);color:var(--text3);padding:3px 0;cursor:pointer;user-select:none}
.nisa-tl-add{width:100%;padding:4px;background:none;border:1px dashed var(--border2);border-radius:4px;font-family:var(--sans);font-size:var(--fs-xs);color:var(--text2);cursor:pointer;margin-top:2px}
.nisa-config-row{display:flex;gap:16px;align-items:flex-start;margin-top:12px}
.nisa-config-left{flex:0 0 180px}
.nisa-config-right{flex:1;min-width:0}
.nisa-snaps-scroll{max-height:180px;overflow-y:auto}
.nisa-meta{display:grid;grid-template-columns:1fr;gap:6px;margin-bottom:0}
.nisa-meta-cell{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px}
.nisa-meta-lab{font-size:var(--fs-xs);color:var(--text3);margin-bottom:3px}
.nisa-snaps{width:100%;border-collapse:collapse;font-size:var(--fs-xs)}
.nisa-snaps th{font-size:var(--fs-xs);color:var(--text3);font-weight:500;text-align:left;padding:3px 5px;border-bottom:1px solid var(--border)}
.nisa-snap-row td{padding:4px 5px;border-bottom:1px solid var(--border);vertical-align:middle}
.nisa-snap-year{font-family:var(--mono);font-weight:500;color:var(--text)}
.nisa-snap-bar{display:inline-flex;height:4px;border-radius:2px;overflow:hidden;background:var(--border);width:56px;vertical-align:middle}
.nisa-settings{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.nisa-setting{display:flex;flex-direction:column;gap:3px}
.nisa-setting label{font-size:var(--fs-xs);color:var(--text2)}
.nisa-setting input{border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-family:var(--mono);font-size:var(--fs-sm);background:var(--surface2);color:var(--text);outline:none}
.curr-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.curr-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px}
.curr-code{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;color:var(--text2);margin-bottom:2px}
.curr-input{width:100%;background:none;border:none;outline:none;font-family:var(--mono);font-size:14px;font-weight:500;color:var(--text)}
.curr-jpy{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono);margin-top:2px}
.savings-collapse{overflow:hidden}
.savings-collapse-head{display:flex;align-items:center;gap:12px;cursor:pointer;user-select:none}
.savings-collapse-head:hover .savings-collapse-chevron{color:var(--text)}
.savings-collapse-names{flex:1;min-width:0}
.savings-collapse-sub{font-size:var(--fs-xs);color:var(--text3);margin-top:2px}
.savings-collapse-total{font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;color:var(--text);white-space:nowrap}
.savings-collapse-chevron{font-size:var(--fs-xs);color:var(--text3);transition:transform .2s;flex-shrink:0}
.savings-collapse.open .savings-collapse-chevron{transform:rotate(180deg)}
.savings-collapse-body{display:none;border-top:1px solid var(--border);margin-top:10px;padding-top:10px}
.savings-collapse.open .savings-collapse-body{display:block}
.savings-total-row{border-top:1px solid var(--border);padding-top:8px;margin-top:8px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.savings-total-row span:first-child{font-size:var(--fs-xs);color:var(--text2)}
.savings-total-row span:last-child{font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;color:var(--text)}
.bond-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.bond-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px;min-width:0}
.bond-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}

/* FINANCE */
.fin-wrap{display:flex;flex-direction:column;gap:10px}
.fin-hero{display:grid;grid-template-columns:1.1fr 1fr 1.4fr;gap:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 22px;align-items:start}
.fin-hero-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text2);margin-bottom:5px;font-weight:500}
.fin-hero-balance{font-size:24px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.fin-hero-delta{font-size:var(--fs-xs);margin-top:3px;color:var(--text2)}.fin-hero-delta.up{color:var(--c-income)}.fin-hero-delta.down{color:var(--bad)}
.fin-spark{width:100%}
.fin-prop{height:12px;border-radius:99px;overflow:hidden;display:flex;background:var(--border);margin-top:7px}
.fin-prop-leg{display:flex;flex-wrap:wrap;gap:3px 10px;margin-top:6px;font-size:var(--fs-xs);color:var(--text2)}
.fin-prop-leg span{display:inline-flex;align-items:center;gap:4px}.fin-prop-leg i{width:7px;height:7px;border-radius:2px;display:inline-block;flex-shrink:0}.fin-prop-leg b{font-variant-numeric:tabular-nums}
.fin-2col{display:grid;grid-template-columns:1.4fr 1fr;gap:12px;align-items:start}
.fin-left{display:flex;flex-direction:column;gap:8px}
.fin-compare{position:sticky;top:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}
.fin-compare-h{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text2);font-weight:600;margin-bottom:10px}
.fin-cg{display:grid;grid-template-columns:1fr 52px 52px 56px;gap:2px 4px;font-size:var(--fs-xs);align-items:center}
.fin-cg-hdr{font-size:var(--fs-xs);color:var(--text2);text-align:right;padding-bottom:3px;border-bottom:1px solid var(--border)}.fin-cg-hdr.l{text-align:left}
.fin-cg-lab{font-size:var(--fs-xs);color:var(--text);padding:3px 0}
.fin-cg-v{text-align:right;font-variant-numeric:tabular-nums;color:var(--text3);font-size:var(--fs-xs)}.fin-cg-v.cur{color:var(--text);font-weight:600}
.fin-cg-total{border-top:1px solid var(--border);padding-top:5px;font-weight:600}
.fin-ytd{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}
.fin-ytd-lab{font-size:var(--fs-xs);color:var(--text2);margin-bottom:2px}
.fin-ytd-val{font-size:var(--fs-sm);font-weight:600;font-variant-numeric:tabular-nums;color:var(--c-income)}
.fin-cumnet{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}
.fin-cum-row{display:flex;justify-content:space-between;font-size:var(--fs-xs);padding:2px 0;font-variant-numeric:tabular-nums;color:var(--text2)}
.fin-cum-total{border-top:1px solid var(--border);margin-top:4px;padding-top:4px;font-weight:700;color:var(--text)!important;font-size:var(--fs-sm)}
.fin-acc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.fin-acc-head{display:grid;grid-template-columns:12px 1fr auto auto;gap:8px;align-items:center;padding:10px 14px;cursor:pointer;user-select:none;background:var(--surface2)}.fin-acc-head:hover{background:var(--border)}
.fin-acc-chev{color:var(--text3);font-size:var(--fs-xs);transition:transform .15s}.fin-acc.open .fin-acc-chev{transform:rotate(90deg)}
.fin-acc-title{font-size:var(--fs-sm);font-weight:600}.fin-acc-title .jp{color:var(--text3);font-weight:400;margin-left:5px;font-size:var(--fs-xs)}
.fin-acc-meta{font-size:var(--fs-xs);color:var(--text2)}.fin-acc-meta.auto-pill{background:var(--accent-light);color:var(--accent);padding:2px 8px;border-radius:99px;font-size:var(--fs-xs)}
.fin-acc-total{font-size:var(--fs-sm);font-weight:600;font-variant-numeric:tabular-nums}.fin-acc-total.income{color:var(--c-income)}
.fin-acc-body{display:none;border-top:1px solid var(--border);padding:2px 0}.fin-acc.open .fin-acc-body{display:block}
.fin-row{display:grid;grid-template-columns:1fr 130px;gap:10px;align-items:center;padding:6px 14px;border-bottom:1px solid var(--surface2)}.fin-row:last-child{border-bottom:none}.fin-row:hover{background:var(--surface2)}
.fin-row-label{font-size:var(--fs-sm);color:var(--text)}.fin-row-label .en{color:var(--text3);font-size:var(--fs-xs);margin-left:4px}
.fin-inp-wrap{display:flex;align-items:center;gap:4px;background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:4px 7px;transition:border-color .1s}.fin-inp-wrap:focus-within,.fin-inp-wrap.filled{border-color:var(--accent);background:var(--accent-light)}
.fin-inp-wrap .yen{font-size:var(--fs-xs);color:var(--text3)}
.fin-inp-wrap input{flex:1;border:none;background:transparent;outline:none;font-family:var(--mono);font-size:var(--fs-sm);text-align:right;font-variant-numeric:tabular-nums;color:var(--text);min-width:0}.fin-inp-wrap input::placeholder{color:var(--text3)}
.fin-inp-wrap.negative input{color:#8b2c2c}
.fin-chip-auto{display:flex;align-items:center;justify-content:space-between;border:1px dashed var(--border2);border-radius:5px;padding:4px 7px;background:var(--surface2)}
.fin-chip-auto-badge{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text3)}
.fin-chip-auto-val{font-size:var(--fs-sm);font-variant-numeric:tabular-nums;color:var(--text);font-family:var(--mono)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:500}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;min-width:300px;max-width:420px;width:90%}
.modal-title{font-size:var(--fs-sm);font-weight:500;margin-bottom:14px}
.modal input,.modal textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px;font-family:var(--sans);font-size:var(--fs-sm);background:var(--surface2);color:var(--text);outline:none;margin-bottom:8px}
.modal-row{display:flex;gap:8px;margin-top:4px}
.modal-btn{flex:1;padding:8px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--sans);font-size:var(--fs-sm)}
.modal-btn.primary{background:var(--text);color:#fff}
.modal-btn.ghost{background:none;border:1px solid var(--border);color:var(--text2)}

/* SPLASH */
#splash{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:999}
.splash-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px 48px;max-width:380px;width:90%;text-align:center}
.splash-logo{font-family:var(--mono);font-size:32px;font-weight:500;margin-bottom:4px;background:linear-gradient(90deg,var(--accent),var(--lavender-text));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.splash-sub{font-size:var(--fs-sm);color:var(--text2);margin-bottom:28px}
.splash-btn{display:block;width:100%;padding:12px;border-radius:10px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer;margin-bottom:8px;border:none}
.splash-btn.primary{background:var(--accent);color:#fff}
.splash-btn.ghost{background:none;border:1px solid var(--border);color:var(--text2)}
.splash-version{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text3);margin-bottom:24px;letter-spacing:.04em}
.splash-hint{margin-top:18px;font-size:var(--fs-xs);color:var(--text3);line-height:1.7}

::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* ── PERIOD TRACKER ─────────────────────────────────────────────────── */
.pd-stats-row{display:flex;gap:12px;margin-bottom:12px;align-items:stretch;width:100%}
.pd-hero{flex:1;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.pd-today-section{margin-bottom:12px}
.cycle-stat-list{display:flex;flex-direction:column;gap:6px;flex:1;padding:10px 12px 6px}
.cycle-stat-row{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;align-items:start;padding:9px 12px;background:rgba(255,240,246,0.7);border:1px solid rgba(220,95,135,0.15);border-radius:14px}
.cycle-stat-big{font-size:16px;font-weight:700;color:var(--text);font-family:var(--mono);line-height:1.3;white-space:nowrap}
.cycle-stat-meta{font-size:var(--fs-xs);color:var(--text2);line-height:1.4}
.cycle-stat-note{font-size:var(--fs-xs);color:var(--text3);margin-top:2px}
.cycle-stat-footer{font-size:var(--fs-xs);color:var(--text3);padding:8px 12px 10px;line-height:1.4}
.pd-year-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:10px}
.pd-year-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:12px}
.pd-month-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:8px}
.pd-mc-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:6px}
.pd-mc-month{font-size:var(--fs-sm);font-weight:600;color:var(--text)}
.pd-mc-cycle{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono)}
.pd-mc-cycle-pred{color:var(--accent)}
.pd-mc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.pd-mc-dh{font-size:var(--fs-xs);color:var(--text3);text-align:center;padding:2px 0;font-family:var(--mono)}
.pd-mc-blank{aspect-ratio:1}
.pd-mc-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:10px;cursor:pointer;border-radius:4px;position:relative;font-family:var(--mono)}
.pd-mc-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text2)}
.pd-mc-day:hover .pd-mc-inner{background:var(--surface2)}
.pd-mc-period{background:var(--accent-light)!important;color:var(--accent)!important;font-weight:600}
.pd-mc-flow-spotting{background:#fde8ee!important;color:var(--accent)!important;font-weight:600}
.pd-mc-flow-light{background:#f9c0cb!important;color:#8a2040!important;font-weight:600}
.pd-mc-flow-medium{background:#f49aab!important;color:#fff!important;font-weight:600}
.pd-mc-flow-heavy{background:#e86585!important;color:#fff!important;font-weight:700}
.pd-mc-start{background:var(--accent)!important;color:#fff!important;font-weight:700}
.pd-mc-pred{border:1.5px solid var(--accent)!important;color:var(--accent)!important;background:none!important;font-weight:600}
.pd-mc-pred-travel{color:#8a6820!important;background:none!important;font-weight:600}
.pd-mc-pred-far{border:1px solid rgba(220,95,135,0.35)!important;color:rgba(220,95,135,0.55)!important;background:none!important}
.pd-mc-travel-day{border:1px solid #D1B36A!important;border-radius:4px!important}
.pd-travel-callout{background:#fdf5e0;border:1px solid #D1B36A;border-radius:var(--radius);padding:8px 12px;margin-bottom:10px;font-size:var(--fs-xs);color:var(--text)}
.pd-mc-fertile{background:#e8e0f5!important;color:#7a5cb8!important;font-weight:600}
.pd-mc-ovulation{background:#7a5cb8!important;color:#fff!important;font-weight:700}
.pd-mc-today{font-weight:700;color:var(--text)!important}
.pd-mc-disabled{cursor:default;pointer-events:none}
.pd-mc-disabled .pd-mc-inner{color:var(--border)!important}
.pd-mc-sym-dot{position:absolute;bottom:1px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.8}
.pd-mc-travel-dot{position:absolute;bottom:1px;left:calc(50% + 4px);width:3px;height:3px;border-radius:50%;background:#6ba3a8;opacity:.85}
.pd-legend{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.pd-leg{display:flex;align-items:center;gap:5px;font-size:var(--fs-xs);color:var(--text2)}
.pd-leg-sw{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.pd-leg-period{background:var(--accent)}
.pd-leg-pred{background:none;border:1.5px solid var(--accent)}
.pd-leg-pred-far{background:none;border:1px solid rgba(220,95,135,0.35)}
.pd-leg-travel-sq{width:12px;height:12px;border:1px solid #D1B36A;border-radius:3px;flex-shrink:0}
.pd-leg-sym-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.7;flex-shrink:0}
.pd-leg-travel-dot{width:6px;height:6px;border-radius:50%;background:#6ba3a8;flex-shrink:0}
.pd-leg-fertile{background:#e8e0f5;border:1px solid #b59ee0}
.pd-leg-ovulation{background:#7a5cb8}
.pd-fertile-badge{display:inline-block;background:#e8e0f5;color:#7a5cb8;border:1px solid #b59ee0;border-radius:10px;padding:0 7px;font-size:var(--fs-xs);font-weight:600;margin-left:6px;vertical-align:middle}
.pd-fertile-badge-ov{background:#7a5cb8;color:#fff;border-color:#7a5cb8}
.pd-ch-travel-icon{color:#6ba3a8;font-size:var(--fs-xs)}
.pd-section-title{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text2);font-weight:600;padding:10px 14px 6px;border-bottom:1px solid var(--border)}
.pd-bottom{display:grid;grid-template-columns:1fr 260px;gap:12px}
.pd-today-card{background:var(--accent-light);border:1px solid var(--accent);border-radius:20px;padding:14px;margin-bottom:16px}
.pd-today-header{font-size:var(--fs-xs);color:var(--text3);margin-bottom:2px}
.pd-today-cycleday{font-size:var(--fs-sm);font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pd-sym-cat-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin:8px 0 5px;font-family:var(--mono)}
.pd-chip-row{display:flex;flex-wrap:wrap;gap:4px}
.pd-chip{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:3px 10px;font-size:var(--fs-xs);color:var(--text2);cursor:pointer;white-space:nowrap;transition:.1s}
.pd-chip:hover{border-color:var(--accent)}
.pd-chip-active{background:var(--accent)!important;border-color:var(--accent)!important;color:#fff!important;font-weight:700!important}
.pd-today-sym-summary{display:flex;flex-wrap:wrap;gap:4px;margin:6px 0 8px}
.pd-more-sym-link{background:none;border:none;color:var(--text3);font-size:var(--fs-xs);cursor:pointer;padding:0;font-family:var(--sans);text-decoration:underline;text-underline-offset:2px}.pd-more-sym-link:hover{color:var(--text2)}
.pd-log-sym-btn{background:none;border:1px solid var(--accent);color:var(--accent);border-radius:var(--radius);padding:5px 14px;font-size:var(--fs-xs);font-weight:600;font-family:var(--sans);cursor:pointer}.pd-log-sym-btn:hover{background:var(--accent-light)}
.pd-today-cols{display:grid;grid-template-columns:1fr 1fr;gap:0 20px;margin-top:8px}
.pd-today-col{min-width:0}
.pd-today-sym-chip{background:var(--accent-light);border:1px solid var(--accent);color:var(--accent);border-radius:12px;padding:2px 8px;font-size:var(--fs-xs)}
.pd-ch{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.pd-bbt-chart{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;padding-bottom:8px}
.pd-ch-empty{padding:14px;font-size:var(--fs-xs);color:var(--text3)}
.pd-ch-row{display:grid;grid-template-columns:64px 1fr 60px;gap:10px;align-items:center;padding:6px 12px;border-bottom:none}
.pd-ch-row-est{background:rgba(220,95,135,0.06);border-radius:10px}
.pd-ch-label{font-size:var(--fs-xs);color:var(--text2);font-family:var(--mono)}
.pd-ch-pred-label{color:var(--accent)}
.pd-ch-bar-wrap{position:relative;height:12px;display:flex;align-items:center;width:100%}
.pd-ch-bar{height:10px;background:var(--accent-light);border-radius:999px;position:relative;overflow:hidden;flex-shrink:0}
.pd-ch-bar-period{height:100%;background:var(--accent);border-radius:999px}
.pd-ch-bar-pred{position:absolute;top:1px;left:0;height:10px;border:1.5px dashed var(--accent);background:transparent;border-radius:999px;pointer-events:none}
.pd-ch-len{font-size:var(--fs-xs);color:var(--text2);font-family:var(--mono);text-align:right}
.pd-insight{font-size:var(--fs-xs);color:var(--text)}
.pd-insight-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.pd-insight-chip{background:var(--accent);color:#fff;border-radius:12px;padding:2px 8px;font-size:var(--fs-xs);font-weight:500}
/* period today card — dashboard layout */
.period-dashboard-grid{display:flex;flex-direction:column;gap:10px}
.period-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:14px 16px}
.period-header-card{display:flex;justify-content:space-between;align-items:center;gap:10px}
.pd-tc-header-left{flex:1;min-width:0}
.log-period-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-family:var(--sans);font-size:var(--fs-xs);font-weight:600;padding:6px 14px;min-width:110px;max-width:150px;flex-shrink:0;white-space:nowrap}
.log-period-btn:hover{opacity:.85}
.pd-tc-title{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text3);font-weight:600;font-family:var(--mono);margin-bottom:8px}
.symptom-group{margin-top:8px}
.symptom-group-title{font-size:var(--fs-xs);color:var(--text3);margin-bottom:4px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em}
.cycle-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.pd-row-2{display:grid;grid-template-columns:2fr 3fr;gap:10px}
.pd-row-3{display:grid;grid-template-columns:2fr 1fr;gap:10px;align-items:start}
.pd-pattern-card .pd-insight{font-size:var(--fs-xs);color:var(--text)}
@media(max-width:700px){
  .period-header-card{flex-direction:column;align-items:flex-start}
  .log-period-btn{width:100%!important;min-width:0;max-width:none}
  .cycle-details-grid,.pd-row-2,.pd-row-3{grid-template-columns:1fr}
}
