:root{
  --bg:#0b1220;
  --panel:#111a2e;
  --text:#e6eefc;
  --muted:#a7b5d7;
  --accent:#4f8cff;
  --danger:#ff5c7a;
  --ok:#38d39f;
  --border:rgba(255,255,255,.10);
  --dev-banner-height:28px;
}
*[hidden]{display:none !important}

*{box-sizing:border-box}
html,body{height:100%}
html{
  background:linear-gradient(180deg, var(--bg), #060a13 55%);
  background-repeat:no-repeat;
  background-color:#060a13;
}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  font-size:14px;
  background:transparent;
  color:var(--text);
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
.dev-banner{
  height:var(--dev-banner-height);
  display:flex;
  align-items:center;
  justify-content:center;
  background:#ff8a00;
  color:#1c1000;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:11px;
  position:sticky;
  top:0;
  z-index:20;
}
.has-dev-banner .topbar{
  top:var(--dev-banner-height);
}

a{color:inherit}
.container{max-width:1650px;margin:0 auto;padding:16px}

.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;border-bottom:1px solid var(--border);
  background:rgba(0,0,0,.15);backdrop-filter: blur(10px);
  position:sticky;top:0;z-index:10;
}
.page-content{
  flex:1;
  overflow:auto;
  min-height:0;
}
.topbar-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.fy-form{margin:0}
.fy-label{font-size:14px;font-weight:400}
.fy-btn{
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:4px 8px;
  border-radius:999px;
  cursor:pointer;
  font-size:13px;
  line-height:1;
}
.fy-btn:disabled{opacity:.4;cursor:default}
.brand{display:flex;gap:10px;align-items:center;font-weight:700;text-decoration:none}
.brand .dot{width:10px;height:10px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 6px rgba(79,140,255,.12)}
.nav{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.nav a{opacity:.9;text-decoration:none;padding:6px 10px;border-radius:12px;font-size:13px;transition:background .15s ease, color .15s ease, opacity .15s ease;outline:0;border:1px solid transparent;box-shadow:0 0 0 2px transparent;box-sizing:border-box;display:flex;align-items:center;min-height:38px}
.nav a:hover{background:rgba(255,255,255,.06)}
.nav a.active{
  opacity:1;
  background:rgba(255,255,255,.12);
  border-color:rgba(79,140,255,.45);
  box-shadow:0 0 0 2px rgba(79,140,255,.18);
}
.networth-range-selector{
  display:flex;
  gap:6px;
  align-items:center;
  padding:4px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.18);
  position:relative;
  --networth-indicator-left:3px;
  --networth-indicator-width:0px;
}
.networth-range-selector::before{
  display:none;
}
.networth-range-link{
  border:1px solid transparent;
  background:transparent;
  border-radius:999px;
  padding:6px 12px;
  font-size:12px;
  color:var(--muted);
  cursor:pointer;
  transition:color .15s ease, background .15s ease, border-color .15s ease;
  position:relative;
  z-index:1;
  --indicator-offset-left:0px;
  --indicator-offset-right:0px;
}
.networth-range-link.active{
  background:rgba(79,140,255,.25);
  border-color:rgba(79,140,255,.45);
  color:var(--text);
}
.networth-range-link:focus-visible{
  outline:2px solid rgba(79,140,255,.5);
  outline-offset:2px;
}
.pill-selector{
  display:flex;
  gap:6px;
  align-items:center;
  padding:4px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.18);
}
.pill-option{
  border:1px solid transparent;
  background:transparent;
  border-radius:999px;
  padding:6px 12px;
  font-size:12px;
  color:var(--muted);
  cursor:pointer;
  transition:color .15s ease, background .15s ease, border-color .15s ease;
}
.pill-option.active{
  background:rgba(79,140,255,.25);
  border-color:rgba(79,140,255,.45);
  color:var(--text);
}
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:4px;
  width:40px;
  height:38px;
  padding:6px;
  border-radius:12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
}
.nav-toggle-bar{
  width:18px;
  height:2px;
  background:var(--text);
  border-radius:999px;
  display:block;
}
.profile-menu{position:relative}
.profile-button{
  display:flex;align-items:center;gap:8px;
  background:transparent;
  border:1px solid transparent;
  color:var(--text);
  padding:6px 10px;border-radius:12px;cursor:pointer;
  font-size:13px;
}
.profile-avatar{
  width:26px;height:26px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(79,140,255,.25);
  border:1px solid rgba(79,140,255,.45);
  font-weight:700;font-size:11px;
}
.profile-label{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-caret{opacity:.7}
.profile-dropdown{
  position:absolute;right:0;top:calc(100% + 8px);
  min-width:0;width:100%;padding:6px;border-radius:12px;
  background:linear-gradient(180deg, rgba(18,24,36,.96), rgba(12,16,26,.94));
  border:1px solid var(--border);backdrop-filter:blur(10px);
  box-shadow:0 12px 24px rgba(0,0,0,.35);
  z-index:20;
  box-sizing:border-box;
}
.profile-item{
  width:100%;display:flex;align-items:center;
  padding:8px 10px;border-radius:10px;border:0;
  background:transparent;color:var(--text);cursor:pointer;
  text-align:left;font-size:13px;
}
.profile-item:hover{background:rgba(255,255,255,.06)}
.profile-item.danger{color:rgba(255,92,122,.95)}
.toggle-group{
  display:inline-flex;
  gap:6px;
  padding:4px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.18);
}
.toggle-btn{
  border:1px solid transparent;
  background:transparent;
  color:var(--muted);
  padding:6px 12px;
  border-radius:999px;
  cursor:pointer;
  font-size:12px;
}
.toggle-btn.active{
  background:rgba(79,140,255,.25);
  border-color:rgba(79,140,255,.45);
  color:var(--text);
}
.toggle-btn.active[data-toggle-value="1"]{
  background:rgba(56,211,159,.20);
  border-color:rgba(56,211,159,.45);
  color:rgba(56,211,159,.95);
}
.toggle-btn.active[data-toggle-value="0"]{
  background:rgba(255,92,122,.18);
  border-color:rgba(255,92,122,.45);
  color:rgba(255,92,122,.95);
}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border:1px solid var(--border);
  border-radius:12px;background:rgba(255,255,255,.06);
  color:var(--text);cursor:pointer;text-decoration:none;
  font-size:13px;
  white-space:nowrap;
}
.btn.primary{background:rgba(79,140,255,.18);border-color:rgba(79,140,255,.35)}
.btn.danger{background:rgba(255,92,122,.12);border-color:rgba(255,92,122,.35)}
.btn.disabled{opacity:.55;pointer-events:none}
.btn-disabled-wrap{
  display:inline-flex;
  cursor:not-allowed;
}
.btn-disabled-wrap .btn{
  pointer-events:none;
  cursor:not-allowed;
}

@supports (-webkit-touch-callout: none) {
  form[action^="/login"] input,
  form[action^="/login"] select,
  form[action^="/login"] textarea {
    font-size:16px;
  }
}
.btn:disabled{
  opacity:.55;
  pointer-events:none;
  cursor:default;
}
.btn:active{transform:translateY(1px)}
.btn.pulse{animation:pulseBadge 1s ease-in-out infinite}

.grid{display:grid;gap:14px;align-items:start;grid-template-columns:minmax(0,1fr)}
.grid > *{min-width:0}
@media (min-width: 900px){.grid.cols-4{grid-template-columns:repeat(4,1fr)}}
@media (min-width: 900px){.grid.cols-3{grid-template-columns:repeat(3,1fr)}}
@media (min-width: 900px){.grid.cols-2{grid-template-columns:repeat(2,1fr)}}
.scroll-row{
  display:flex;
  gap:14px;
  align-items:flex-start;
  overflow-x:auto;
  padding-bottom:4px;
  -webkit-overflow-scrolling:touch;
}
.scroll-row > *{
  flex:1 0 240px;
  min-width:240px;
}
@media (max-width: 900px){
  .scroll-row{
    flex-direction:column;
    overflow-x:visible;
  }
  .scroll-row > *{
    flex:1 1 auto;
    min-width:0;
  }
}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border:1px solid var(--border);
  border-radius:18px;
  padding:12px;
}
.chart-tooltip{
  position:fixed;
  z-index:50;
  max-width:none;
  width:max-content;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(79,140,255,.35);
  background:rgba(15,22,34,.95);
  color:rgba(230,238,252,.95);
  font-size:12px;
  line-height:1.35;
  pointer-events:none;
  white-space:pre;
  box-shadow:0 10px 24px rgba(0,0,0,.35);
}
body[data-page="dashboard" i] .chart-tooltip,
body[data-page="dashboard" i] .custom-tooltip{
  max-width:none;
  width:max-content;
  white-space:pre;
}
.card h3{margin:0 0 10px 0;font-size:14px;color:var(--muted);font-weight:650}
.kpi{display:flex;flex-direction:column;gap:6px;min-height:130px}
.kpi .value{font-size:22px;font-weight:800;letter-spacing:-.02em}
.kpi .sub{font-size:13px;color:var(--muted)}

.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.row-nowrap{flex-wrap:nowrap}
.row.actions-right{
  justify-content:flex-end;
  width:100%;
}
.spacer{flex:1}
.muted{color:var(--muted);font-size:13px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:rgba(0,0,0,.20);font-size:12px;color:var(--muted)}
.pill.ok{border-color:rgba(56,211,159,.35);color:rgba(56,211,159,.95);background:rgba(56,211,159,.10)}
.pill.bad{border-color:rgba(255,92,122,.35);color:rgba(255,92,122,.95);background:rgba(255,92,122,.10)}
.pill.info{border-color:rgba(72,167,255,.35);color:rgba(126,191,255,.95);background:rgba(72,167,255,.12)}
.pill.warn{border-color:rgba(255,179,71,.35);color:rgba(255,179,71,.95);background:rgba(255,179,71,.12)}
.pill.pulse{animation:pulseBadge 1s ease-in-out infinite}
.ai-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid rgba(99,201,255,.35);
  background:rgba(99,201,255,.12);
  color:rgba(189,229,255,.95);
  font-size:11px;
  letter-spacing:.02em;
  text-transform:uppercase;
  white-space:nowrap;
}
.ai-tag-rule{
  border-color:rgba(255,179,71,.35);
  background:rgba(255,179,71,.12);
  color:rgba(255,206,141,.95);
}
@keyframes pulseBadge{
  0%{box-shadow:0 0 0 0 rgba(72,167,255,.55)}
  60%{box-shadow:0 0 0 14px rgba(72,167,255,0)}
  100%{box-shadow:0 0 0 0 rgba(72,167,255,0)}
}
.pm-saved{margin-left:8px}
.pm-actions{width:200px;min-width:200px}
.pm-divider{border-top:2px solid rgba(255,255,255,.2);margin:12px 0}
.pm-add-row{width:50%;max-width:50%;justify-content:flex-start}
.pm-add-row .pm-add-date{width:135px;min-width:135px}
.pm-add-row .pm-add-property{width:240px;min-width:240px}
.text-ok{color:var(--ok)}
.text-danger{color:var(--danger)}
.settings-saved{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-width:60px;
  padding:3px 10px;
  border-radius:999px;
  border:1px solid rgba(56,211,159,.35);
  background:rgba(56,211,159,.15);
  font-size:12px;
  color:rgba(56,211,159,.95);
  opacity:0;
  transform:translateY(2px);
  transition:opacity .2s ease, transform .2s ease;
}
.settings-saved.active{
  opacity:1;
  transform:translateY(0);
}
.settings-saved.error{
  border-color:rgba(255,92,122,.35);
  background:rgba(255,92,122,.12);
  color:rgba(255,92,122,.95);
}

.form{max-width:460px;margin:40px auto}
.form label{display:block;margin:10px 0 6px;color:var(--muted);font-size:13px}
.login-logo{
  display:flex;
  justify-content:center;
  margin:32px auto 14px;
}
.login-logo img{
  max-width:180px;
  height:auto;
}
.login-logo + .form{
  margin-top:16px;
}
.login-logo + .card + .form{
  margin-top:16px;
}
.input{
  width:100%;padding:10px 10px;border-radius:12px;border:1px solid var(--border);
  background:rgba(0,0,0,.18);color:var(--text);
  font-size:13px;
  font-family:inherit;
  line-height:1.4;
  color-scheme:dark;
}
.input option,
.input optgroup{
  background:#0f1622;
  color:var(--text);
}
.input.error{
  border-color:rgba(255,92,122,.6);
  box-shadow:0 0 0 2px rgba(255,92,122,.15);
}
.input.compact{padding:6px 8px;border-radius:10px;font-size:12px}
.input.auto-width{width:auto;min-width:0;max-width:100%}
.btn.compact{padding:6px 8px;border-radius:10px;font-size:12px}
.alert{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,92,122,.35);background:rgba(255,92,122,.10);color:rgba(255,92,122,.95)}

canvas{width:100%;height:260px}
.chart-compact{height:130px}

table{font-size:13px}
table th, table td{padding:6px !important}
table thead th{font-weight:650}
.cell-missing{background:rgba(255,140,0,.32) !important;color:#ffe6c7}
.cell-missing .muted{color:#ffd19a !important}
.table-fit{
  width:max-content;
  min-width:100%;
}
.table-fit th,
.table-fit td{
  white-space:nowrap;
}
.table-scroll{
  overflow-x:auto;
  display:block;
  width:100%;
  max-width:100%;
  -webkit-overflow-scrolling:touch;
  touch-action:pan-x;
}
.table-link{color:inherit;text-decoration:none}
.table-link:hover{text-decoration:underline}

.spinner{
  width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(255,255,255,.2);
  border-top-color:var(--accent);
  animation:spin 0.9s linear infinite;
}
.spinner-lg{
  width:32px;height:32px;border-width:4px;
}
@keyframes spin{to{transform:rotate(360deg)}}

.tax-loading{
  display:flex;
  margin:0;
  padding:0;
  font-size:16px;
  text-align:center;
  align-items:center;
  justify-content:center;
}
.rec-headline{font-size:14px;font-weight:700;margin-bottom:8px}
.rec-section{margin-top:10px}
.rec-section h4{margin:0 0 6px 0;font-size:13px;color:var(--muted)}
.rec-section ul{margin:0;padding-left:18px}
.rec-persona{margin-bottom:6px}
.rec-disclaimer{margin-top:10px;font-size:12px;color:var(--muted)}
.rec-table{width:100%;border-collapse:collapse;font-size:12px}
.rec-table th,.rec-table td{padding:6px 8px;border-top:1px solid var(--border);vertical-align:top}
.rec-table th{color:var(--muted);font-weight:600}
.rec-details{margin-top:8px}
.rec-details summary{cursor:pointer;color:var(--muted);font-size:12px}
.rec-history-btn{align-items:flex-start}
.rec-history-text{
  min-width:0;
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
}
.kpi-runrate{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.pm-drop-target.is-drop{
  background:rgba(255,255,255,.06);
  outline:2px dashed var(--border);
  outline-offset:-2px;
}
.kpi-runrate-item{
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  padding:4px 8px;
  border-radius:10px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.14);
  font-size:12px;
}
.tax-explain{
  margin-top:10px;
}
.tax-explain summary{
  cursor:pointer;
  color:var(--text);
  font-size:12px;
}
.tax-explain-body{
  margin-top:6px;
}
.tax-explain-table{
  width:100%;
  border-collapse:collapse;
  font-size:12px;
}
.tax-explain-table th,
.tax-explain-table td{
  padding:6px 4px !important;
  border-bottom:1px solid var(--border);
}
.tax-explain-table th{
  text-align:left;
  color:var(--muted);
  font-weight:600;
}
.tax-explain .muted{
  display:block;
  margin-top:6px;
  white-space:pre-line;
  font-size:12px;
}
#property-cashflow table th:first-child,
#property-cashflow table td:first-child{
  white-space:nowrap;
  width:1%;
}
.sample-placeholder{
  position:absolute;
  left:10px;
  top:10px;
  right:10px;
  color:var(--muted);
  pointer-events:none;
  opacity:1;
  transition:opacity 1s ease;
  font-family:inherit;
  font-size:13px;
  line-height:1.4;
  font-weight:400;
}
.has-tooltip{
  cursor:help;
}
.btn-disabled-wrap.has-tooltip{
  cursor:not-allowed;
}
.custom-tooltip{
  position:fixed;
  max-width:none;
  width:max-content;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(79,140,255,.35);
  background:rgba(15,22,34,.95);
  color:rgba(230,238,252,.95);
  font-size:12px;
  line-height:1.35;
  z-index:50;
  pointer-events:none;
  white-space:pre;
  opacity:0;
  transform:translateY(4px);
  transition:opacity .08s ease, transform .08s ease;
  box-shadow:0 10px 24px rgba(0,0,0,.35);
}
.custom-tooltip.visible{
  opacity:1;
  transform:translateY(0);
}
.custom-tooltip.validation-tooltip::after{
  content:'';
  position:absolute;
  left:50%;
  bottom:-6px;
  width:10px;
  height:10px;
  background:rgba(15,22,34,.95);
  border-right:1px solid rgba(79,140,255,.35);
  border-bottom:1px solid rgba(79,140,255,.35);
  transform:translateX(-50%) rotate(45deg);
}

.blur-personal{
  position:relative;
  transition:filter .2s ease, opacity .2s ease;
}
body[data-blur-personal-info="1"] .blur-personal{
  filter:blur(5px);
  opacity:.75;
}
body[data-blur-personal-info="1"] .blur-personal::after{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:6px;
  background:linear-gradient(130deg, rgba(255,255,255,.08), rgba(0,0,0,.35));
  mix-blend-mode:screen;
}

body[data-blur-personal-info="1"] #networth-more-table td:nth-child(2),
body[data-blur-personal-info="1"] #cash-more-table td:nth-child(2),
body[data-blur-personal-info="1"] #profit-more-table td:nth-child(2),
body[data-blur-personal-info="1"] #tax-ai-explain-table td:nth-child(2){
  filter:blur(6px);
  opacity:.8;
}

#property-cashflow .has-tooltip{
  cursor:auto;
}

.modal{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  z-index:1000;
}
.modal[hidden]{display:none !important}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.modal-dialog{
  position:relative;
  width:min(740px, calc(100vw - 24px));
  max-height:calc(100vh - 24px);
  overflow:auto;
  border-radius:18px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(17,26,46,.98), rgba(12,18,32,.98));
  box-shadow:0 20px 70px rgba(0,0,0,.55);
}
.modal-dialog.pm-debug-dialog{
  width:min(1200px, calc(100vw - 24px));
}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 12px;border-bottom:1px solid var(--border);
}
.modal-body{padding:12px}

@media (max-width: 900px){
  .topbar{
    flex-wrap:wrap;
    align-items:flex-start;
    gap:8px;
  }
  .nav-toggle{
    display:inline-flex;
    margin-left:auto;
  }
  .nav{
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    padding:4px 0 6px;
    display:none;
  }
  body.nav-open .nav{display:flex}
  .nav a{width:100%;justify-content:flex-start}
  .profile-menu{width:100%}
  .profile-button{width:100%;justify-content:space-between}
  .profile-dropdown{
    left:0;
    right:auto;
    width:100%;
  }
  .table-nowrap{
    width:max-content;
    min-width:100%;
  }
  .table-nowrap th,
  .table-nowrap td{
    white-space:nowrap;
  }
}

.scrap-loader{
  width:14px;
  height:14px;
  display:inline-block;
  border:2px solid rgba(255,255,255,.4);
  border-top-color:var(--accent);
  border-radius:999px;
  animation:spin 0.9s linear infinite;
}

@keyframes spin{
  0%{transform:rotate(0deg);}
  100%{transform:rotate(360deg);}
}
