:root {
  --font-brand: 'Recoleta', 'Georgia', serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --color-sand-10: #FCF7F3; --color-sand-20: #F3E8DA; --color-sand-30: #D5BBA4; --color-sand-40: #A38B74;
  --color-mauve-10: #F9F6F9; --color-mauve-20: #E8D9E1; --color-mauve-30: #A28C9F; --color-mauve-40: #85516B;
  --color-green-10: #E9FAF1; --color-green-30: #4DAE84; --color-green-40: #2F7A5A;
  --color-red-10: #FFF2F2; --color-red-30: #D86060; --color-red-40: #B10000;
  --color-yellow-40: #FFD252;
  --color-grey-10: #F9F9F9; --color-grey-20: #EAEAEA; --color-grey-30: #D1D1D1; --color-grey-40: #B6B6B6; --color-grey-50: #7C7C7C;
  --color-dark-10: #4F4F4F; --color-dark-20: #2A2A2A; --color-dark-30: #1A1A1A; --color-dark-40: #121212;
  --color-white: #ffffff; --color-charcoal: #121212; --color-off-white: #FDFCFB;
  --text-primary: var(--color-dark-40); --text-secondary: var(--color-dark-30); --text-muted: var(--color-grey-50);
  --surface-page: var(--color-white); --surface-subtle: var(--color-grey-10); --surface-card: var(--color-sand-10);
  --border-light: var(--color-grey-20); --border-base: var(--color-grey-30);
  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px; --space-5: 20px; --space-6: 24px; --space-8: 32px;
  --radius-sm: 4px; --radius-md: 10px; --radius-full: 1000px;
  --text-display: 28px; --text-h1: 22px; --text-h2: 18px; --text-h3: 15px; --text-h4: 13px; --text-small: 12px; --text-xs: 10px;
  --header-height: 52px;
  --panel-width: 380px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { background: var(--surface-subtle); color: var(--text-primary); font-family: var(--font-body); font-size: var(--text-h4); line-height: 1.55; min-height: 100vh; -webkit-font-smoothing: antialiased; }
h1, h2, h3 { font-family: var(--font-brand); }
.symbol { font-family: var(--font-body); }

.header { background: var(--color-charcoal); padding: var(--space-3) var(--space-6); display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; position: sticky; top: 0; z-index: 100; min-height: var(--header-height); }
.header-left { display: flex; align-items: center; gap: var(--space-4); }
.header-logo { height: 20px; }
.header-title { font-family: var(--font-brand); font-size: var(--text-h3); color: var(--color-off-white); }
.header-actions { display: flex; align-items: center; gap: var(--space-2); }
.btn-header { background: var(--color-dark-20); color: var(--color-off-white); border: 1px solid var(--color-dark-10); border-radius: var(--radius-full); padding: 6px var(--space-3); font-family: var(--font-body); font-size: var(--text-small); font-weight: 500; cursor: pointer; transition: all 0.1s ease; }
.btn-header:hover { background: var(--color-dark-30); }
.btn-header.danger { color: var(--color-red-30); }
.btn-header.toggle.active { background: var(--color-mauve-40); border-color: var(--color-mauve-40); color: var(--color-white); }

.app { display: grid; grid-template-columns: 1fr var(--panel-width); gap: var(--space-5); padding: var(--space-5); max-width: 1600px; margin: 0 auto; align-items: start; }
.app.panel-closed { grid-template-columns: 1fr 0; gap: 0; }
.app.panel-closed .side-panel { display: none; }
.main { display: flex; flex-direction: column; gap: var(--space-4); min-width: 0; }
.side-panel { position: sticky; top: calc(var(--header-height) + var(--space-3)); display: flex; flex-direction: column; gap: var(--space-4); align-self: start; max-height: calc(100vh - var(--header-height) - var(--space-5) * 2); overflow-y: auto; padding-right: var(--space-1); }
.side-panel::-webkit-scrollbar { width: 6px; }
.side-panel::-webkit-scrollbar-track { background: transparent; }
.side-panel::-webkit-scrollbar-thumb { background: var(--color-grey-30); border-radius: var(--radius-full); }

.section { background: var(--color-white); border-radius: var(--radius-md); border: 1px solid var(--border-light); overflow: hidden; }
.section-header { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border-light); display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.section-title { font-family: var(--font-body); font-size: var(--text-h4); font-weight: 600; }
.section-subtitle { font-size: var(--text-xs); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.section-body { padding: var(--space-4); }
.section-body.compact { padding: var(--space-3) var(--space-4); }
.section.collapsible .section-header { cursor: pointer; user-select: none; }
.section.collapsed .section-body { display: none; }
.section-chevron { font-size: var(--text-h4); color: var(--text-muted); transition: transform 0.15s ease; }
.section.collapsed .section-chevron { transform: rotate(-90deg); }

.summary { background: var(--color-charcoal); border-radius: var(--radius-md); padding: var(--space-5); color: var(--color-off-white); }
.summary-tier-label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-grey-40); margin-bottom: 2px; font-weight: 600; }
.summary-tier-name { font-family: var(--font-brand); font-size: var(--text-display); line-height: 1.15; color: var(--color-off-white); margin-bottom: var(--space-3); }
.summary-points-row { display: flex; align-items: baseline; gap: var(--space-2); margin-bottom: var(--space-4); }
.summary-points-value { font-family: var(--font-brand); font-size: var(--text-h1); font-weight: 700; color: var(--color-sand-30); }
.summary-points-label { font-size: var(--text-small); color: var(--color-grey-40); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.progress-track { height: 5px; background: var(--color-dark-20); border-radius: var(--radius-full); overflow: hidden; margin-bottom: var(--space-2); }
.progress-fill { height: 100%; background: var(--color-sand-30); transition: width 0.3s ease; }
.progress-meta { display: flex; justify-content: space-between; font-size: var(--text-xs); color: var(--color-grey-40); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); margin-top: var(--space-4); }
.stat { background: var(--color-dark-20); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); }
.stat-label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-grey-40); font-weight: 600; margin-bottom: 2px; }
.stat-value { font-family: var(--font-brand); font-size: var(--text-h2); font-weight: 500; color: var(--color-off-white); }
.stat-value.pos { color: var(--color-green-30); }
.stat-value.neg { color: var(--color-red-30); }
.stat-value.warn { color: var(--color-yellow-40); }
.stat-sub { font-size: var(--text-xs); color: var(--color-grey-50); margin-top: 2px; }

.timeline-wrap { background: var(--color-white); border-radius: var(--radius-md); border: 1px solid var(--border-light); }
.timeline { display: flex; flex-direction: row; gap: 0; overflow-x: auto; overflow-y: visible; padding: var(--space-4) var(--space-3); scroll-snap-type: x proximity; }
.timeline::-webkit-scrollbar { height: 10px; }
.timeline::-webkit-scrollbar-track { background: var(--color-grey-10); border-radius: var(--radius-full); }
.timeline::-webkit-scrollbar-thumb { background: var(--color-grey-30); border-radius: var(--radius-full); }

.month { flex: 0 0 240px; width: 240px; display: flex; flex-direction: column; scroll-snap-align: start; padding: 0 var(--space-2); border-right: 1px dashed var(--color-grey-20); position: relative; }
.month:last-child { border-right: none; }
.month-header { padding: 0 0 var(--space-2) 0; }
.month-title { font-family: var(--font-brand); font-size: var(--text-h3); display: flex; align-items: baseline; gap: var(--space-2); }
.month-title-num { color: var(--text-primary); }
.month-title-tag { font-size: var(--text-xs); color: var(--text-muted); font-family: var(--font-body); font-weight: 400; }
.month-status { font-size: var(--text-xs); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; margin-top: 2px; }

.month-rail { position: relative; padding-left: var(--space-5); padding-top: var(--space-2); min-height: 60px; flex: 1; }
.month-rail::before { content: ''; position: absolute; left: 8px; top: 4px; bottom: 0; width: 2px; background: var(--color-grey-20); border-radius: 1px; }

.event-node { position: relative; margin-bottom: var(--space-2); }
.event-node::before { content: ''; position: absolute; left: -19px; top: 8px; width: 10px; height: 10px; border-radius: 50%; background: var(--color-white); border: 2px solid var(--color-grey-30); z-index: 1; }
.event-node.user::before { border-color: var(--color-sand-40); background: var(--color-sand-30); }
.event-node.system::before { border-color: var(--color-mauve-30); background: var(--color-mauve-20); }
.event-node.unlock::before { border-color: var(--color-green-30); background: var(--color-green-30); }
.event-node.perk::before { border-color: var(--color-yellow-40); background: var(--color-yellow-40); }
.event-node.derived::before { width: 6px; height: 6px; left: -17px; top: 10px; border-color: var(--color-mauve-30); background: var(--color-mauve-30); }
.event-node.invalid::before { border-color: var(--color-red-30); background: var(--color-white); }

.event-card { border-radius: var(--radius-sm); padding: var(--space-1) var(--space-2); font-size: var(--text-small); cursor: pointer; border: 1px solid transparent; line-height: 1.35; transition: background 0.1s; user-select: none; }
.event-card:hover { background: var(--surface-subtle); }
.event-node.user .event-card { background: var(--color-sand-10); border-color: var(--color-sand-20); }
.event-node.system .event-card { background: var(--color-mauve-10); border-color: var(--color-mauve-20); color: var(--color-mauve-40); }
.event-node.unlock .event-card { background: var(--color-green-10); border-color: var(--color-green-30); color: var(--color-green-40); font-weight: 500; }
.event-node.perk .event-card { background: #FFF8E1; border-color: var(--color-yellow-40); }
.event-node.derived .event-card { background: transparent; border-color: transparent; color: var(--text-muted); font-size: var(--text-xs); padding: 1px var(--space-2); }
.event-node.invalid .event-card { opacity: 0.55; }

.event-summary { display: flex; justify-content: space-between; align-items: center; gap: var(--space-2); }
.event-summary-text { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.event-summary-meta { white-space: nowrap; font-weight: 600; font-family: var(--font-brand); font-size: var(--text-small); }
.event-summary-meta.pts { color: var(--color-mauve-40); }
.event-summary-meta.cost { color: var(--color-red-40); }
.event-summary-meta.cost.take { color: var(--color-sand-40); }
.event-summary-meta.warn { color: var(--text-muted); font-size: var(--text-xs); font-weight: 400; font-family: var(--font-body); }
.event-detail { display: none; padding-top: var(--space-2); margin-top: var(--space-2); border-top: 1px dashed var(--border-light); font-size: var(--text-xs); color: var(--text-secondary); }
.event-node.expanded .event-detail { display: block; }
.event-detail-row { display: flex; justify-content: space-between; gap: var(--space-2); padding: 2px 0; }
.event-detail-row .label { color: var(--text-muted); }
.event-detail-row .value { font-weight: 500; color: var(--text-primary); }
.event-detail-actions { display: flex; gap: var(--space-2); margin-top: var(--space-2); }
.btn-mini { background: var(--color-white); border: 1px solid var(--border-light); border-radius: var(--radius-sm); padding: 3px var(--space-2); font-family: var(--font-body); font-size: var(--text-xs); cursor: pointer; color: var(--text-secondary); }
.btn-mini:hover { background: var(--surface-subtle); }
.btn-mini.danger:hover { background: var(--color-red-10); border-color: var(--color-red-30); color: var(--color-red-40); }

.add-event-row { display: flex; gap: var(--space-1); flex-wrap: wrap; margin-top: var(--space-3); padding-left: 0; }
.btn-add { background: var(--color-white); border: 1px dashed var(--border-base); border-radius: var(--radius-sm); padding: 4px var(--space-2); font-family: var(--font-body); font-size: var(--text-xs); cursor: pointer; transition: all 0.1s ease; color: var(--text-secondary); }
.btn-add:hover { background: var(--surface-subtle); border-color: var(--color-mauve-30); color: var(--text-primary); }

.picker { margin-top: var(--space-2); padding: var(--space-3); background: var(--surface-subtle); border-radius: var(--radius-sm); display: flex; flex-direction: column; gap: var(--space-3); max-height: 460px; overflow-y: auto; }
.picker-section { display: flex; flex-direction: column; gap: var(--space-1); }
.picker-section-label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); font-weight: 600; margin-bottom: 2px; }
.picker-btn { background: var(--color-white); border: 1px solid var(--border-light); border-radius: var(--radius-sm); padding: 6px var(--space-3); font-family: var(--font-body); font-size: var(--text-small); cursor: pointer; transition: all 0.1s ease; text-align: left; color: var(--text-primary); display: flex; justify-content: space-between; align-items: center; gap: var(--space-2); }
.picker-btn:hover { background: var(--surface-subtle); border-color: var(--color-mauve-30); }
.picker-btn-pts { color: var(--color-mauve-40); font-weight: 600; font-size: var(--text-xs); white-space: nowrap; }
.picker-btn.disabled { opacity: 0.4; cursor: not-allowed; pointer-events: none; }
.picker-close { display: flex; justify-content: flex-end; }
.picker-inline { display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; padding: var(--space-2); background: var(--color-white); border: 1px solid var(--border-light); border-radius: var(--radius-sm); }
.picker-input { padding: 4px var(--space-2); border: 1px solid var(--border-light); border-radius: var(--radius-sm); font-family: var(--font-body); font-size: var(--text-small); }
.picker-input.amount { width: 64px; }
.picker-input.biz { flex: 1; min-width: 100px; }
.picker-btn-primary { background: var(--color-charcoal); color: var(--color-white); border-color: var(--color-charcoal); padding: 6px var(--space-3); border-radius: var(--radius-sm); font-family: var(--font-body); font-size: var(--text-small); cursor: pointer; border-style: solid; border-width: 1px; }

.perk-row { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2); border: 1px solid var(--border-light); border-radius: var(--radius-sm); flex-wrap: wrap; }
.perk-row + .perk-row { margin-top: var(--space-2); }
.perk-tier { font-family: var(--font-brand); font-size: var(--text-small); font-weight: 600; color: var(--color-mauve-40); white-space: nowrap; }
.perk-input { flex: 1; min-width: 80px; padding: 4px var(--space-2); border: 1px solid var(--border-light); border-radius: var(--radius-sm); font-family: var(--font-body); font-size: var(--text-small); }
.perk-input.small { width: 60px; flex: 0 0 60px; }
.perk-type-toggle { display: flex; gap: 0; }
.perk-type-btn { padding: 4px 8px; border: 1px solid var(--border-light); background: var(--color-white); font-size: var(--text-xs); cursor: pointer; }
.perk-type-btn.active { background: var(--color-charcoal); color: var(--color-white); border-color: var(--color-charcoal); }
.perk-type-btn:first-child { border-radius: var(--radius-sm) 0 0 var(--radius-sm); }
.perk-type-btn:last-child { border-radius: 0 var(--radius-sm) var(--radius-sm) 0; border-left: 0; }
.perk-btn-del { background: none; border: none; cursor: pointer; color: var(--text-muted); padding: 0 var(--space-1); font-size: var(--text-h3); line-height: 1; }
.perk-btn-del:hover { color: var(--color-red-40); }
.manual-perk-row { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2); background: var(--surface-subtle); border-radius: var(--radius-sm); flex-wrap: wrap; }
.manual-perk-row + .manual-perk-row { margin-top: var(--space-1); }
.manual-perk-row .perk-input { background: var(--color-white); }

.tier-list { display: flex; flex-direction: column; gap: var(--space-1); }
.tier-item { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); border: 1px solid var(--border-light); font-size: var(--text-small); }
.tier-item.active { background: var(--color-mauve-10); border-color: var(--color-mauve-30); }
.tier-item-info { display: flex; flex-direction: column; gap: 0; flex: 1; min-width: 0; }
.tier-item-name { font-weight: 500; }
.tier-item-desc { font-size: var(--text-xs); color: var(--text-muted); }
.tier-item-pts { font-family: var(--font-brand); font-size: var(--text-small); color: var(--color-mauve-40); font-weight: 600; }

.profile-list { display: flex; flex-direction: column; gap: var(--space-1); }
.profile-row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); font-size: var(--text-small); }
.profile-row.indent { padding-left: var(--space-5); color: var(--text-muted); font-size: var(--text-xs); }
.profile-row.section-divider { border-top: 1px solid var(--border-light); margin-top: var(--space-1); padding-top: var(--space-3); }
.profile-row-label { color: var(--text-secondary); }
.profile-row-value { font-family: var(--font-brand); font-weight: 600; color: var(--text-primary); }
.profile-row.indent .profile-row-value { color: var(--text-muted); font-weight: 500; }
.profile-empty { color: var(--text-muted); font-size: var(--text-small); padding: var(--space-2) var(--space-3); font-style: italic; }

.biz-row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); border: 1px solid var(--border-light); font-size: var(--text-small); }
.biz-row + .biz-row { margin-top: var(--space-1); }
.biz-row.has-buyin { background: var(--color-sand-10); border-color: var(--color-sand-20); }
.biz-row-name { font-weight: 500; flex: 1; min-width: 0; }
.biz-row-stats { font-size: var(--text-xs); color: var(--text-muted); white-space: nowrap; }

.toast { position: fixed; bottom: var(--space-5); left: 50%; transform: translateX(-50%); background: var(--color-charcoal); color: var(--color-off-white); padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); font-size: var(--text-small); z-index: 1000; opacity: 0; transition: opacity 0.2s ease; pointer-events: none; }
.toast.show { opacity: 1; }
.help-text { background: var(--color-sand-10); border: 1px solid var(--color-sand-20); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); font-size: var(--text-small); color: var(--text-secondary); line-height: 1.45; }

@media (max-width: 1024px) {
  .app { grid-template-columns: 1fr; }
  .app.panel-closed { grid-template-columns: 1fr; }
  .side-panel { position: static; max-height: none; }
}
@media (max-width: 768px) {
  .header { padding: var(--space-2) var(--space-3); }
  .app { padding: var(--space-3); }
  .summary-tier-name { font-size: var(--text-h1); }
}
