:root{--bg:#080A1B;--panel:#10152B;--panel2:#151B38;--line:#2D3566;--text:#F7F7FF;--muted:#AAB3D5;--cyan:#24D8FF;--pink:#F767D5;--violet:#7C4DFF;--green:#4ADE80;--red:#FB7185;--gold:#FBBF24}*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at 15% 10%,#31489D55,transparent 28%),radial-gradient(circle at 85% 30%,#9C2D8E55,transparent 26%),linear-gradient(120deg,#080A1B,#120B28 55%,#071C2A);color:var(--text)}button,input,select{font:inherit}.hidden{display:none!important}.login-wrap{min-height:100vh;padding:36px;display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch}.hero-card,.login-card{border:1px solid #ffffff18;box-shadow:0 30px 100px #0008}.hero-card{min-height:560px;border-radius:34px 0 0 34px;padding:72px;background:radial-gradient(circle at 20% 15%,#2EEBFF99,transparent 18%),radial-gradient(circle at 82% 70%,#FF3CC766,transparent 28%),linear-gradient(135deg,#4356C2aa,#261B61)}.login-card{border-radius:0 34px 34px 0;padding:72px;background:#0B1027cc;backdrop-filter:blur(18px)}.logo{width:72px;height:72px;border-radius:24px;background:linear-gradient(135deg,var(--cyan),var(--violet),var(--pink));display:grid;place-items:center;font-weight:900;box-shadow:0 0 40px #24D8FF77}.logo.small{width:42px;height:42px;border-radius:14px}.hero-card h1{font-size:56px;line-height:.98;letter-spacing:-4px;max-width:760px}.hero-card p,.login-card p{color:#D3D7F4;font-size:20px;line-height:1.7}.pills{display:flex;gap:14px;flex-wrap:wrap;margin-top:52px}.pills span{background:#0A102Caa;border:1px solid #ffffff16;border-radius:999px;padding:12px 18px;color:#DDE2FF}label{display:block;color:#B8C2E8;font-weight:800;margin:24px 0 8px}input,select{width:100%;padding:17px 18px;border-radius:18px;border:1px solid #33406F;background:#080C20;color:white;outline:none}button{border:0;border-radius:18px;padding:15px 20px;color:white;font-weight:850;background:linear-gradient(90deg,var(--cyan),#2478FF,var(--violet));cursor:pointer;box-shadow:0 8px 28px #1d4ed855;margin-top:18px}button.ghost{background:#111832;border:1px solid #34406E;box-shadow:none}.app{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.sidebar{padding:24px;background:#080C21cc;border-right:1px solid #ffffff12;position:sticky;top:0;height:100vh}.brand{display:flex;gap:14px;align-items:center;margin-bottom:30px}.brand span{display:block;color:var(--muted);font-size:12px}.nav{display:block;width:100%;text-align:left;background:transparent;border:1px solid transparent;box-shadow:none;margin:8px 0;color:#C8D1F3}.nav.active,.nav:hover{background:linear-gradient(90deg,#24306B,#151B38);border-color:#39447D}.nav.danger{color:#FDA4AF}main{padding:34px;overflow:auto}header{display:flex;justify-content:space-between;gap:24px;align-items:center;margin-bottom:28px}.eyebrow{letter-spacing:8px;color:#2DE2FF;font-weight:900;font-size:12px}header h1{font-size:48px;margin:0;letter-spacing:-2px}.grid{display:grid;gap:18px}.kpi{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:linear-gradient(180deg,#10162Fdd,#0B1026dd);border:1px solid #2C3567;border-radius:28px;padding:24px;box-shadow:0 20px 70px #0004}.card h3{margin:0 0 16px;font-size:24px}.metric .label{text-transform:uppercase;letter-spacing:6px;color:#9EA9D0;font-weight:900;font-size:12px}.metric .value{font-size:32px;font-weight:950;margin-top:18px}.green{color:var(--green)}.red{color:var(--red)}.cyan{color:var(--cyan)}.muted{color:var(--muted)}.two{grid-template-columns:1fr 1fr}.three{grid-template-columns:repeat(3,1fr)}table{width:100%;border-collapse:collapse}th,td{padding:13px 10px;border-bottom:1px solid #28315E;text-align:left}th{color:#9FAAD1;text-transform:uppercase;letter-spacing:3px;font-size:12px}td.num{text-align:right;font-variant-numeric:tabular-nums}.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.form-grid .wide{grid-column:span 2}.bar{height:10px;background:#1A2448;border-radius:999px;overflow:hidden}.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--cyan),var(--violet),var(--pink))}.badge{display:inline-flex;border:1px solid #3A457E;border-radius:999px;padding:6px 10px;color:#C8D1F3}.ok{border-color:#31d98b;color:#7BF2B4}.warn{border-color:#fbbf24;color:#FDE68A}@media(max-width:950px){.login-wrap,.app{display:block}.hero-card,.login-card{border-radius:28px;margin-bottom:18px;padding:34px}.hero-card h1{font-size:38px}.sidebar{height:auto;position:relative}.kpi,.two,.three,.form-grid{grid-template-columns:1fr}.form-grid .wide{grid-column:auto}}

/* RosetaFi Lite v1.2.2 - UI Restore + Opening Balance polish */
.mini{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.035);
  border-radius:22px;
  padding:16px 18px;
}

/* RosetaFi Lite v1.6.9 - Lokasi Saldo */
@media screen {
  .home-panels {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin-top: 0 !important;
  }

  .saldo-locations-card {
    border-color: rgba(34,211,238,.24) !important;
    background:
      radial-gradient(circle at 6% 0%, rgba(34,211,238,.10), transparent 30%),
      radial-gradient(circle at 95% 18%, rgba(74,222,128,.08), transparent 26%),
      rgba(15,23,42,.94) !important;
  }

  .saldo-total {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4px 12px;
    align-items: end;
    margin-bottom: 12px;
    padding: 12px 14px;
    border: 1px solid rgba(34,211,238,.16);
    border-radius: 16px;
    background: rgba(5,11,24,.34);
  }

  .saldo-total span,
  .saldo-total small {
    color: var(--muted);
  }

  .saldo-total span {
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .12em;
    text-transform: uppercase;
  }

  .saldo-total b {
    font-size: clamp(19px, 4vw, 25px);
    line-height: 1;
    color: var(--green);
    white-space: nowrap;
  }

  .saldo-total small {
    grid-column: 1 / -1;
    font-size: 12px;
  }

  .saldo-location-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .saldo-location-item {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    padding: 12px;
    border: 1px solid rgba(148,163,184,.14);
    border-radius: 17px;
    background: rgba(5,11,24,.32);
  }

  .saldo-location-item strong {
    grid-column: 2;
    color: #F8FAFC;
    font-size: 15px;
    line-height: 1;
    white-space: nowrap;
  }

  .saldo-location-item b,
  .saldo-location-item small {
    display: block;
    min-width: 0;
  }

  .saldo-location-item b {
    overflow: hidden;
    color: #F8FAFC;
    font-size: 14px;
    line-height: 1.15;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .saldo-location-item small {
    margin-top: 3px;
    color: var(--muted);
    font-size: 10.5px;
  }

  .saldo-logo {
    width: 44px;
    height: 44px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 15px;
    display: grid;
    place-items: center;
    color: white;
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .02em;
    box-shadow: 0 10px 26px rgba(0,0,0,.22);
  }

  .saldo-logo-cash {
    color: #34D399;
    border-color: rgba(52,211,153,.28);
    background: rgba(6,78,59,.34);
  }

  .saldo-logo-bca {
    color: #DBEAFE;
    background: linear-gradient(135deg, #075EAE, #1D4ED8);
  }

  .saldo-logo-bsi {
    color: #ECFDF5;
    background: linear-gradient(135deg, #059669, #FBBF24);
  }

  .saldo-logo-bri {
    color: #EFF6FF;
    background: linear-gradient(135deg, #1D4ED8, #60A5FA);
  }

  .saldo-logo-mandiri {
    color: #1E3A8A;
    background: linear-gradient(135deg, #FFFFFF, #FACC15);
  }

  .saldo-logo-hand {
    color: #F0FDFA;
    border-color: rgba(45,212,191,.24);
    background: rgba(15,118,110,.32);
  }

  .saldo-logo-bank,
  .saldo-logo-wallet {
    color: #E0F2FE;
    background: linear-gradient(135deg, rgba(14,165,233,.36), rgba(124,77,255,.32));
  }

  .saldo-location-sheet {
    max-width: 920px;
  }

  .saldo-editor-list {
    display: grid;
    gap: 10px;
    margin-top: 14px;
  }

  .saldo-editor-row {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr) minmax(140px, .55fr) auto;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border: 1px solid rgba(148,163,184,.16);
    border-radius: 17px;
    background: rgba(5,11,24,.34);
  }

  .saldo-editor-row input {
    margin: 0;
    min-height: 44px;
    padding: 11px 12px !important;
    font-size: 14px !important;
  }

  .saldo-editor-row .tiny-btn {
    margin: 0;
  }
}

@media screen and (max-width: 560px) {
  .saldo-location-list {
    grid-template-columns: 1fr;
  }

  .saldo-editor-row {
    grid-template-columns: 46px 1fr auto;
  }

  .saldo-editor-row .saldo-amount {
    grid-column: 2 / -1;
  }
}

/* RosetaFi Lite v1.6.8 - floating center action */
@media screen {
  .bottom-nav {
    overflow: visible !important;
    padding-top: 12px !important;
  }

  .fab-wrapper {
    position: relative !important;
    z-index: 3;
    top: -34px !important;
    color: var(--cyan) !important;
    font-size: 10px !important;
    letter-spacing: .08em;
  }

  .fab {
    width: 66px !important;
    height: 66px !important;
    border: 7px solid rgba(8,10,27,.98) !important;
    border-radius: 22px !important;
    background: linear-gradient(135deg, var(--cyan), #54A9FF 48%, var(--violet)) !important;
    box-shadow:
      0 18px 44px rgba(36,216,255,.24),
      0 0 0 1px rgba(255,255,255,.10) inset !important;
    font-size: 34px !important;
    font-weight: 850 !important;
  }

  .fab-wrapper > span:last-child {
    margin-top: 0;
    color: var(--cyan);
    font-weight: 950;
  }
}

/* RosetaFi Lite v1.6.7 - CSV import export tools */
@media screen {
  .journal-tools {
    border-color: rgba(36,216,255,.22) !important;
    background:
      radial-gradient(circle at 10% 8%, rgba(36,216,255,.13), transparent 28%),
      radial-gradient(circle at 92% 22%, rgba(124,77,255,.12), transparent 30%),
      rgba(15,23,42,.92) !important;
  }

  .journal-tools .panel-title {
    align-items: flex-start;
  }

  .journal-tools h3 {
    margin-bottom: 4px !important;
  }

  .journal-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
  }

  .journal-actions button,
  .csv-file-btn {
    display: grid;
    place-items: center;
    min-height: 48px;
    margin: 0;
    padding: 12px 14px;
    border: 1px solid rgba(255,255,255,.13);
    border-radius: 16px;
    background: rgba(5,11,24,.46);
    box-shadow: none;
    color: #fff;
    font-weight: 900;
    text-align: center;
  }

  .journal-actions button:first-child {
    background: linear-gradient(90deg, var(--cyan), #2478FF, var(--violet));
    box-shadow: 0 14px 32px rgba(36,120,255,.20);
  }

  .csv-file-btn {
    cursor: pointer;
  }

  .csv-file-btn input {
    display: none;
  }

  .journal-note,
  #importMsg {
    margin: 12px 0 0;
    font-size: 12px;
    line-height: 1.45;
  }

  .csv-import-sheet {
    width: min(920px, calc(100vw - 28px));
    max-height: calc(100vh - 28px);
    overflow: auto;
    margin: 14px auto;
    padding: 18px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 24px;
    background:
      radial-gradient(circle at 10% 0%, rgba(36,216,255,.14), transparent 30%),
      radial-gradient(circle at 96% 20%, rgba(124,77,255,.16), transparent 32%),
      #0B1026;
  }

  .csv-flow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin: 14px 0;
  }

  .csv-flow div {
    display: grid;
    gap: 5px;
    min-height: 78px;
    padding: 12px;
    border: 1px solid rgba(255,255,255,.11);
    border-radius: 16px;
    background: rgba(5,11,24,.44);
  }

  .csv-flow b {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    border-radius: 10px;
    background: rgba(36,216,255,.18);
    color: var(--cyan);
    font-size: 13px;
  }

  .csv-flow span {
    color: #DDE6FF;
    font-size: 12px;
    font-weight: 850;
    line-height: 1.25;
  }

  .csv-upload-box {
    display: grid;
    place-items: center;
    min-height: 76px;
    margin: 12px 0;
    border: 1px dashed rgba(36,216,255,.45);
    border-radius: 18px;
    background: rgba(36,216,255,.08);
    color: #fff;
    font-size: 17px;
    font-weight: 950;
    cursor: pointer;
  }

  .csv-upload-box input {
    display: none;
  }

  .csv-mode {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 12px 0;
  }

  .csv-mode label {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 6px 10px;
    align-items: start;
    margin: 0;
    padding: 12px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    background: rgba(5,11,24,.38);
    color: #fff;
  }

  .csv-mode input {
    width: auto;
    margin-top: 2px;
  }

  .csv-mode span {
    grid-column: 2;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.35;
    font-weight: 600;
  }

  .csv-preview {
    min-height: 90px;
    margin-top: 12px;
    padding: 12px;
    border: 1px solid rgba(255,255,255,.11);
    border-radius: 18px;
    background: rgba(5,11,24,.48);
  }

  .csv-preview-head {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: flex-start;
    margin-bottom: 10px;
  }

  .csv-preview-head b,
  .csv-preview-head span {
    display: block;
    min-width: 0;
    font-size: 12px;
    line-height: 1.35;
  }

  .csv-preview-head span {
    color: var(--muted);
    text-align: right;
  }

  .csv-preview .table-scroll {
    max-height: 280px;
  }

  .csv-footer-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
  }

  .csv-footer-actions button {
    margin-top: 0;
  }

  .csv-footer-actions button:disabled {
    cursor: not-allowed;
    opacity: .45;
  }

  @media (max-width: 760px) {
    .journal-actions {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .csv-flow,
    .csv-mode {
      grid-template-columns: 1fr;
    }

    .csv-preview-head {
      display: block;
    }

    .csv-preview-head span {
      margin-top: 4px;
      text-align: left;
    }
  }
}
.mini span{display:block;color:var(--muted);font-weight:800;font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.mini b{font-size:22px;color:#fff;letter-spacing:-.03em}

/* Dashboard number responsive fix */
.metric{min-width:0;overflow:hidden}.metric .value{font-size:clamp(24px,2.15vw,36px);line-height:1.05;letter-spacing:-.055em;white-space:nowrap}.metric .label{line-height:1.25}.card{overflow:hidden}.two{align-items:start}.app main{min-width:0}header{min-width:0}.login-card button{margin-right:8px}.brand b{display:block}
@media(max-width:1250px){.kpi{grid-template-columns:repeat(2,minmax(0,1fr))}.metric .value{font-size:clamp(28px,4vw,44px)}}
@media(max-width:760px){main{padding:22px}.kpi{grid-template-columns:1fr}header{display:block}header h1{font-size:38px}.metric .value{font-size:32px}.login-wrap{padding:16px}}

/* RosetaFi Lite v1.4.2 - Ekuitas detail mini rows */
.mini-box {
  margin: 10px 0 18px;
  padding: 12px 14px;
  border: 1px solid rgba(148, 163, 255, .16);
  border-radius: 18px;
  background: rgba(255, 255, 255, .035);
}

.mini-row {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 6px 0;
  color: var(--muted);
  font-size: 14px;
}

.mini-row b {
  color: var(--text);
  white-space: nowrap;
}

details {
  margin-top: 8px;
  color: var(--muted);
}

summary {
  cursor: pointer;
  font-weight: 800;
  color: var(--cyan);
  margin: 8px 0;
}

.red {
  color: var(--red) !important;
}

.green {
  color: var(--green) !important;
}

/* RosetaFi Lite v1.4.2b - Fix Neraca Detail Responsive Width */
.grid.three,
.grid.two {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  align-items: stretch !important;
}

.card {
  min-width: 0 !important;
  overflow: hidden !important;
}

.card h2 {
  font-size: clamp(26px, 2.4vw, 38px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.04em !important;
  word-break: normal !important;
  overflow-wrap: anywhere !important;
}

.mini-box {
  overflow: hidden !important;
}

.mini-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

.mini-row span {
  min-width: 0 !important;
  flex: 1 1 140px !important;
}

.mini-row b {
  flex: 0 0 auto !important;
  white-space: nowrap !important;
}

details {
  max-height: 220px;
  overflow: auto;
}

@media (max-width: 1300px) {
  .grid.three,
  .grid.two {
    grid-template-columns: 1fr !important;
  }
}

/* RosetaFi Lite v1.4.2c - Neraca panels without nested cards */
.neraca-head {
  margin-bottom: 18px;
}

.neraca-grid {
  margin-top: 18px;
}

.neraca-panel {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  gap: 6px;
}

.neraca-panel > b {
  margin-top: 8px;
}

.card .neraca-panel {
  border-radius: 18px;
  box-shadow: none;
}

/* RosetaFi Lite v1.5 - App-like home experience */
.home {
  display: grid;
  gap: 18px;
}

.home-hero {
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 28px;
  padding: 28px;
  background:
    radial-gradient(circle at 18% 20%, rgba(36,216,255,.26), transparent 34%),
    radial-gradient(circle at 85% 15%, rgba(247,103,213,.22), transparent 32%),
    linear-gradient(135deg, rgba(24,38,90,.95), rgba(8,15,38,.94));
  box-shadow: 0 24px 80px rgba(0,0,0,.32);
}

.soft-label {
  display: inline-flex;
  width: fit-content;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  padding: 7px 11px;
  color: #C8F7FF;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.home-hero h2 {
  margin: 22px 0 10px;
  font-size: clamp(38px, 6vw, 72px);
  line-height: .95;
  letter-spacing: 0;
}

.home-hero p {
  max-width: 680px;
  margin: 0;
  color: #DDE6FF;
  font-size: 17px;
  line-height: 1.6;
}

.status-pill {
  display: inline-flex;
  flex: 0 0 auto;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  padding: 10px 13px;
  color: #DDE6FF;
  font-size: 13px;
  font-weight: 900;
}

.quick-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 12px;
}

.quick {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 58px;
  margin: 0;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 20px;
  background: rgba(255,255,255,.055);
  box-shadow: none;
}

.quick.primary {
  background: linear-gradient(90deg, var(--cyan), #2478FF, var(--violet));
  box-shadow: 0 16px 38px rgba(36,120,255,.24);
}

.quick.report-quick {
  border-color: rgba(36,216,255,.28);
  background: rgba(36,216,255,.09);
}

.quick span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 12px;
  background: rgba(255,255,255,.14);
  font-size: 13px;
  font-weight: 950;
  line-height: 1;
}

.report-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  margin: 0;
  padding: 18px;
  text-align: left;
  border: 1px solid rgba(36,216,255,.28);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(36,216,255,.11), rgba(247,103,213,.10));
  box-shadow: none;
}

.report-banner span {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--cyan), var(--violet));
  font-weight: 950;
}

.report-banner b,
.report-banner small {
  display: block;
}

.report-banner small {
  margin-top: 4px;
  color: var(--muted);
}

.table-scroll {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.table-scroll table {
  min-width: 760px;
}

.table-scroll::-webkit-scrollbar {
  height: 8px;
}

.table-scroll::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(170,179,213,.35);
}

.tax-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.tax-head p {
  margin: 0;
}

.tax-period {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr .7fr auto;
  gap: 10px;
  align-items: center;
}

.tax-period input {
  min-width: 0;
}

.tax-period button {
  margin: 0;
  white-space: nowrap;
}

.tax-content {
  display: grid;
  gap: 18px;
  margin-top: 18px;
}

.tax-grid {
  display: grid;
  gap: 18px;
  margin-top: 18px;
}

.tax-report table {
  min-width: 980px;
}

.table-scroll tfoot td {
  border-top: 1px solid rgba(255,255,255,.22);
  background: rgba(36,216,255,.08);
  color: #F8FAFF;
  font-weight: 900;
}

.period-trigger {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 58px;
  margin: 0;
  padding: 10px 14px;
  border: 1px solid rgba(36,216,255,.28);
  background: rgba(36,216,255,.08);
  box-shadow: none;
}

.period-trigger span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.period-trigger b {
  margin-top: 5px;
  font-size: 14px;
}

.period-modal {
  position: fixed;
  z-index: 80;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(3,6,18,.72);
  backdrop-filter: blur(14px);
}

.period-sheet {
  width: min(720px, 100%);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  padding: 18px;
  background: #0B1026;
  box-shadow: 0 30px 120px rgba(0,0,0,.55);
}

.period-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.period-head b,
.period-head span {
  display: block;
}

.period-head b {
  font-size: 22px;
}

.period-head span {
  margin-top: 4px;
  color: var(--muted);
}

.period-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.period-options button {
  min-height: 76px;
  margin: 0;
  padding: 14px;
  text-align: left;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.055);
  box-shadow: none;
}

.period-options b,
.period-options span {
  display: block;
}

.period-options span {
  margin-top: 6px;
  color: var(--muted);
  font-size: 12px;
}

.period-custom {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 10px;
  align-items: end;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.1);
}

.period-custom label {
  margin: 0 0 6px;
}

.period-custom button {
  margin: 0;
}

.mood-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.mood-card {
  min-width: 0;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 20px;
  padding: 18px;
  background: rgba(255,255,255,.04);
}

.mood-card span,
.mood-card small {
  display: block;
  color: var(--muted);
}

.mood-card span {
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.mood-card b {
  display: block;
  overflow-wrap: anywhere;
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1;
}

.mood-card small {
  margin-top: 8px;
}

.home-panels {
  margin-top: 0;
}

.soft-card {
  border-radius: 24px;
}

.panel-title {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 16px;
}

.panel-title h3 {
  margin: 0;
}

.tiny-btn {
  flex: 0 0 auto;
  margin: 0;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: none;
  font-size: 13px;
}

.cash-row,
.category-chip {
  display: grid;
  grid-template-columns: 92px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid rgba(255,255,255,.07);
}

.cash-row span,
.category-chip span {
  min-width: 0;
  color: var(--muted);
  font-size: 13px;
}

.cash-row div,
.category-chip div {
  display: grid;
  gap: 4px;
}

.cash-row i,
.category-chip i {
  display: block;
  height: 7px;
  border-radius: 999px;
}

.cash-row .in {
  background: linear-gradient(90deg, var(--green), var(--cyan));
}

.cash-row .out,
.category-chip i {
  background: linear-gradient(90deg, var(--pink), var(--violet));
}

.cash-row b,
.category-chip b {
  white-space: nowrap;
  font-size: 13px;
}

.unit-strip {
  border-radius: 24px;
}

.unit-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.unit-pill {
  display: grid;
  gap: 6px;
  min-height: 94px;
  margin: 0;
  padding: 16px;
  text-align: left;
  border-radius: 18px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: none;
}

.unit-pill b {
  font-size: 22px;
}

.unit-pill span,
.unit-pill small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--muted);
}

@media(max-width:760px) {
  body {
    padding-bottom: 142px;
  }

  .app {
    display: block;
  }

  main {
    padding: 18px;
  }

  header {
    margin-bottom: 18px;
  }

  header .eyebrow,
  header #subtitle {
    display: none;
  }

  header h1 {
    font-size: 30px;
  }

  header button {
    width: auto;
    margin-top: 12px;
    padding: 11px 14px;
    border-radius: 14px;
  }

  .sidebar {
    position: fixed;
    z-index: 20;
    left: 12px;
    right: 12px;
    bottom: 12px;
    top: auto;
    display: flex;
    gap: 6px;
    height: auto;
    padding: 8px;
    border: 1px solid rgba(255,255,255,.13);
    border-radius: 22px;
    background: rgba(8,12,33,.92);
    backdrop-filter: blur(18px);
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .brand,
  .nav.danger {
    display: none;
  }

  .nav {
    flex: 0 0 132px;
    min-height: 48px;
    margin: 0;
    padding: 8px 6px;
    text-align: center;
    border-radius: 16px;
    font-size: 11px;
    line-height: 1.1;
  }

  .home-hero {
    display: block;
    padding: 22px;
    border-radius: 24px;
  }

  .home-hero h2 {
    font-size: 42px;
  }

  .status-pill {
    margin-top: 16px;
  }

  .quick-actions,
  .mood-grid,
  .unit-list {
    grid-template-columns: 1fr 1fr;
  }

  .report-banner {
    align-items: flex-start;
    padding: 16px;
  }

  .report-banner span {
    width: 42px;
    height: 42px;
  }

  .tax-period {
    grid-template-columns: 1fr 1fr;
  }

  .tax-period button:last-child {
    grid-column: 1 / -1;
  }

  .period-trigger {
    grid-column: 1 / -1;
  }

  .period-modal {
    align-items: end;
    padding: 10px;
  }

  .period-sheet {
    border-radius: 22px;
  }

  .period-options,
  .period-custom {
    grid-template-columns: 1fr;
  }

  .mood-grid {
    gap: 10px;
  }

  .mood-card {
    padding: 15px;
  }

  .mood-card:first-child {
    grid-column: 1 / -1;
  }

  .cash-row,
  .category-chip {
    grid-template-columns: 78px 1fr;
  }

  .cash-row b,
  .category-chip b {
    grid-column: 2;
    white-space: normal;
  }
}

/* RosetaFi Lite v1.5.1 - Professional report preview and PDF print */
.report-modal {
  position: fixed;
  z-index: 60;
  inset: 0;
  padding: 24px;
  background: rgba(3,6,18,.78);
  backdrop-filter: blur(14px);
}

.report-shell {
  display: grid;
  grid-template-rows: auto auto 1fr;
  max-width: 1120px;
  height: calc(100vh - 48px);
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  overflow: hidden;
  background: #0B1026;
  box-shadow: 0 30px 120px rgba(0,0,0,.55);
}

.report-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.report-toolbar b,
.report-toolbar span {
  display: block;
}

.report-toolbar span {
  color: var(--muted);
  font-size: 13px;
}

.report-toolbar > div:last-child {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.report-scroll {
  overflow: auto;
  padding: 24px;
  background: #E8ECF5;
}

.report-picker {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.report-type {
  display: block;
  min-height: 74px;
  margin: 0;
  padding: 13px;
  text-align: left;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: rgba(255,255,255,.045);
  box-shadow: none;
}

.report-type.active {
  border-color: rgba(36,216,255,.52);
  background: linear-gradient(135deg, rgba(36,216,255,.16), rgba(124,77,255,.16));
}

.report-type b,
.report-type span {
  display: block;
}

.report-type b {
  margin-bottom: 6px;
}

.report-type span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.3;
}

.report-paper {
  max-width: 860px;
  min-height: 1120px;
  margin: 0 auto;
  padding: 44px;
  background: #fff;
  color: #111827;
  box-shadow: 0 18px 70px rgba(15,23,42,.22);
  font-family: Inter, Arial, sans-serif;
}

.report-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  padding-bottom: 18px;
  border-bottom: 3px solid #111827;
}

.report-head b {
  display: block;
  font-size: 24px;
  letter-spacing: 0;
}

.report-head span,
.report-head small {
  color: #4B5563;
}

.report-section {
  margin-top: 26px;
}

.report-section h1 {
  margin: 0 0 10px;
  color: #111827;
  font-size: 28px;
  line-height: 1.14;
  letter-spacing: 0;
}

.report-section h2 {
  margin: 0 0 12px;
  color: #111827;
  font-size: 17px !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
}

.report-section p {
  margin: 0;
  color: #4B5563;
  line-height: 1.55;
}

.report-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}

.report-kpis div {
  border: 1px solid #D1D5DB;
  border-radius: 10px;
  padding: 12px;
  background: #F9FAFB;
}

.report-kpis span {
  display: block;
  color: #6B7280;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.report-kpis b {
  display: block;
  margin-top: 7px;
  color: #111827;
  font-size: 18px;
  line-height: 1.15;
  overflow-wrap: anywhere;
}

.report-paper table {
  width: 100%;
  border-collapse: collapse;
  color: #111827;
  font-size: 12px;
}

.report-paper th,
.report-paper td {
  padding: 9px 8px;
  border-bottom: 1px solid #E5E7EB;
  text-align: left;
}

.report-paper th {
  color: #374151;
  background: #F3F4F6;
  font-size: 11px;
  letter-spacing: .04em;
}

.report-paper .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.report-paper tfoot td {
  border-top: 2px solid #111827;
  background: #F9FAFB;
  font-weight: 800;
}

.report-section.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

@media(max-width:760px) {
  .report-modal {
    padding: 10px;
  }

  .report-shell {
    height: calc(100vh - 20px);
    border-radius: 18px;
  }

  .report-toolbar {
    display: block;
  }

  .report-toolbar > div:last-child {
    justify-content: flex-start;
    margin-top: 12px;
  }

  .report-picker {
    grid-template-columns: 1fr 1fr;
    padding: 12px;
  }

  .report-type {
    min-height: 68px;
    padding: 11px;
  }

  .report-scroll {
    padding: 12px;
  }

  .report-paper {
    min-height: auto;
    padding: 22px;
  }

  .report-kpis,
  .report-section.two-col {
    grid-template-columns: 1fr;
  }
}

@media print {
  body * {
    visibility: hidden !important;
  }

  #reportModal,
  #reportModal * {
    visibility: visible !important;
  }

  #reportModal {
    position: static !important;
    padding: 0 !important;
    background: #fff !important;
    backdrop-filter: none !important;
  }

  .report-shell {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: none !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #fff !important;
  }

  .report-toolbar {
    display: none !important;
  }

  .report-picker {
    display: none !important;
  }

  .report-scroll {
    overflow: visible !important;
    padding: 0 !important;
    background: #fff !important;
  }

  .report-paper {
    max-width: none !important;
    min-height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
  }

  @page {
    size: A4;
    margin: 14mm;
  }
}

.scan-modal {
  position: fixed;
  z-index: 90;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(3,6,18,.72);
  backdrop-filter: blur(14px);
}

.scan-sheet {
  width: min(780px, 100%);
  max-height: 92vh;
  overflow: auto;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  padding: 20px;
  background: #0B1026;
  box-shadow: 0 30px 120px rgba(0,0,0,.55);
}

.camera-btn {
  display: grid;
  place-items: center;
  min-height: 92px;
  margin: 14px 0;
  border: 1px dashed rgba(36,216,255,.45);
  border-radius: 20px;
  background: rgba(36,216,255,.08);
  color: #F8FAFF;
  cursor: pointer;
}

.camera-btn input {
  display: none;
}

.scan-preview {
  width: 100%;
  max-height: 280px;
  object-fit: contain;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: #050816;
}

.scan-enhanced {
  margin-top: 10px;
  background: #fff;
}

.scan-grid {
  margin-top: 14px;
}

.scan-caption {
  width: 100%;
  min-height: 170px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid #33406F;
  border-radius: 18px;
  background: #080C20;
  color: white;
}

.scan-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.upload-nota-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 15px 22px;
  border-radius: 18px;
  color: white;
  font-weight: 850;
  text-decoration: none;
  background: linear-gradient(90deg,var(--cyan),#2478FF,var(--violet));
  box-shadow: 0 8px 28px #1d4ed855;
}

.danger-btn {
  min-height: 58px;
  padding: 15px 22px;
  border: 1px solid rgba(255,99,132,.45);
  border-radius: 18px;
  color: #fff;
  font-weight: 850;
  background: rgba(255,99,132,.16);
}

.nota-preview-img {
  display: block;
  width: min(520px, 100%);
  max-height: 68vh;
  object-fit: contain;
  margin: 18px auto;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  background: #fff;
}

.correction-btn {
  opacity: .86;
  white-space: nowrap;
}

.correction-sheet {
  width: min(760px, calc(100vw - 28px));
  max-height: 88vh;
  overflow: auto;
  margin: 6vh auto;
  border: 1px solid rgba(108,124,255,.38);
  border-radius: 26px;
  padding: 22px;
  background: #0B1026;
  box-shadow: 0 30px 120px rgba(0,0,0,.55);
}

/* RosetaFi Lite v1.6 - mobile real estate app shell */
:root {
  --bg: #0B1121;
  --panel: #131C2F;
  --panel2: #16223A;
  --line: #1E293B;
  --text: #F8FAFC;
  --muted: #94A3B8;
  --cyan: #22D3EE;
  --pink: #F472B6;
  --violet: #818CF8;
  --green: #34D399;
  --red: #FB7185;
  --gold: #FBBF24;
  --safe-bottom: env(safe-area-inset-bottom, 20px);
}

html {
  background: #050816;
}

body {
  width: 100%;
  max-width: 480px;
  min-height: 100vh;
  margin: 0 auto;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 88% 6%, rgba(129,140,248,.16), transparent 28%),
    radial-gradient(circle at 8% 18%, rgba(34,211,238,.12), transparent 24%),
    var(--bg);
  box-shadow: 0 0 52px rgba(0,0,0,.48);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
}

.login-wrap {
  display: flex !important;
  min-height: 100vh;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  padding: 24px;
  background:
    radial-gradient(circle at top right, rgba(30,41,59,.8), transparent 38%),
    var(--bg);
}

.hero-card,
.login-card {
  min-height: auto !important;
  border: 1px solid var(--line) !important;
  border-radius: 22px !important;
  padding: 24px !important;
  background: var(--panel) !important;
  box-shadow: none !important;
}

.hero-card {
  text-align: center;
}

.logo {
  width: 64px;
  height: 64px;
  margin: 0 auto 18px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--cyan), var(--violet));
  box-shadow: 0 0 28px rgba(129,140,248,.38);
}

.logo.small {
  width: 36px;
  height: 36px;
  margin: 0;
  border-radius: 10px;
  font-size: 14px;
}

.hero-card h1 {
  max-width: none;
  margin: 0 0 10px;
  font-size: 26px;
  line-height: 1.1;
  letter-spacing: 0;
}

.hero-card p,
.login-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
}

.pills {
  margin-top: 20px;
  justify-content: center;
}

.pills span {
  border-color: var(--line);
  background: var(--bg);
  color: var(--muted);
  font-size: 12px;
}

button,
input,
select,
textarea {
  font: inherit;
}

input,
select,
textarea,
.search-input {
  border: 1px solid #26385f !important;
  border-radius: 14px !important;
  background: #0A1020 !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

input:focus,
select:focus,
textarea:focus,
.search-input:focus {
  border-color: var(--violet) !important;
  box-shadow: 0 0 0 1px rgba(129,140,248,.68) !important;
}

button {
  border-radius: 14px;
}

.app {
  display: flex !important;
  min-height: 100vh;
  flex-direction: column;
  padding-bottom: calc(88px + var(--safe-bottom));
}

.sidebar {
  display: none !important;
}

.app main {
  flex: 1;
  min-width: 0;
  overflow: visible;
  padding: 0 20px 22px !important;
}

.app-header {
  position: sticky;
  z-index: 40;
  top: 0;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  min-width: 0;
  margin: 0 -20px 14px !important;
  padding: 18px 20px 12px !important;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(11,17,33,.92);
  backdrop-filter: blur(14px);
}

.header-logo-group {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.header-title h1 {
  margin: 0;
  font-size: 18px;
  line-height: 1.05;
  letter-spacing: .02em;
}

.header-title p {
  margin: 2px 0 0;
  color: var(--cyan);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
}

.btn-icon {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel);
  color: var(--muted);
  box-shadow: none;
}

.bottom-nav {
  position: fixed;
  z-index: 60;
  bottom: 0;
  left: 50%;
  display: grid;
  width: min(100vw, 480px);
  max-width: 480px;
  height: calc(76px + var(--safe-bottom));
  transform: translateX(-50%);
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: start;
  padding: 10px 8px var(--safe-bottom);
  border-top: 1px solid rgba(255,255,255,.06);
  background: rgba(11,17,33,.96);
  backdrop-filter: blur(16px);
  overflow: hidden;
}

.bottom-nav .nav,
.bottom-nav .nav-item {
  display: flex !important;
  width: auto;
  min-width: 0;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin: 0 !important;
  padding: 6px 2px !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--muted);
  box-shadow: none !important;
  font-size: 10.5px;
  font-weight: 850;
  line-height: 1.1;
  text-align: center;
}

.bottom-nav .nav.active {
  color: var(--cyan);
}

.nav-icon {
  display: grid;
  width: 26px;
  height: 26px;
  place-items: center;
  border-radius: 10px;
  background: var(--panel);
  color: inherit;
  font-size: 10px;
  font-weight: 950;
}

.bottom-nav .nav.active .nav-icon {
  background: rgba(34,211,238,.12);
  box-shadow: 0 0 16px rgba(34,211,238,.22);
}

.fab-wrapper {
  position: relative;
  top: -26px;
  color: var(--cyan) !important;
}

.fab {
  display: grid;
  width: 54px;
  height: 54px;
  place-items: center;
  border: 4px solid var(--bg);
  border-radius: 18px;
  background: linear-gradient(135deg, var(--cyan), var(--violet));
  box-shadow: 0 10px 26px rgba(129,140,248,.34);
  color: white;
  font-size: 30px;
  line-height: 1;
}

.view {
  animation: rosetaFade .2s ease-out;
}

@keyframes rosetaFade {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

.card,
.soft-card,
.mood-card,
.mini,
.mini-box,
.scan-sheet,
.correction-sheet {
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  background: var(--panel) !important;
  box-shadow: none !important;
}

.card {
  padding: 18px !important;
}

.home {
  gap: 16px;
}

.home-hero {
  display: block;
  min-height: auto;
  padding: 22px !important;
  border-color: rgba(129,140,248,.28) !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at 90% -20%, rgba(129,140,248,.25), transparent 42%),
    linear-gradient(145deg, var(--panel2), var(--panel)) !important;
  box-shadow: none !important;
}

.home-hero h2 {
  margin: 16px 0 8px;
  font-size: clamp(36px, 12vw, 48px) !important;
  line-height: 1;
  letter-spacing: 0 !important;
}

.home-hero p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.soft-label {
  border-color: rgba(34,211,238,.32);
  background: rgba(34,211,238,.08);
  color: var(--cyan);
}

.status-pill {
  margin-top: 16px;
  border-radius: 8px;
  background: rgba(52,211,153,.08);
  color: var(--green);
}

.quick-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px;
}

.quick {
  justify-content: flex-start;
  min-height: 66px;
  padding: 12px !important;
  border-color: var(--line) !important;
  border-radius: 16px !important;
  background: var(--panel) !important;
  color: var(--text);
}

.quick b {
  min-width: 0;
  font-size: clamp(15px, 4.3vw, 18px);
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.quick.primary,
.upload-nota-btn {
  background: linear-gradient(135deg, var(--cyan), var(--violet)) !important;
}

.quick span,
.report-banner span {
  border-radius: 12px;
  background: rgba(255,255,255,.10);
}

.report-banner {
  border-color: rgba(34,211,238,.28);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(34,211,238,.08), rgba(244,114,182,.08));
}

.mood-grid,
.home-panels,
.grid.two,
.grid.three,
.kpi {
  grid-template-columns: 1fr !important;
}

.mood-card {
  min-height: auto;
  padding: 18px;
}

.mood-card b {
  font-size: clamp(28px, 9vw, 38px);
  line-height: 1.05;
}

.panel-title {
  align-items: center;
  gap: 12px;
}

.panel-title h3,
.card h3 {
  font-size: 18px !important;
  line-height: 1.15;
}

.tiny-btn {
  min-height: 38px;
  margin: 0;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  color: var(--text);
  box-shadow: none;
}

.cash-row,
.category-chip,
.unit-pill {
  border-color: var(--line);
  background: #0A1020;
}

.form-grid {
  grid-template-columns: 1fr !important;
}

.form-grid .wide {
  grid-column: auto !important;
}

table {
  min-width: 640px;
}

.table-wrap,
.table-scroll,
#trxTable,
#dashTrxTable,
#notaList {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.scan-modal {
  align-items: stretch;
  padding: 10px;
}

.scan-sheet {
  width: 100%;
  max-height: calc(100vh - 20px);
  padding: 18px;
}

.scan-preview {
  max-height: 330px;
  border-radius: 16px;
}

.scan-caption {
  min-height: 150px;
  border-color: #26385f;
  border-radius: 16px;
  background: #0A1020;
  font-size: 14px;
}

.scan-actions {
  display: grid;
  grid-template-columns: 1fr;
}

.scan-actions .ghost,
.upload-nota-btn {
  width: 100%;
  min-height: 56px;
}

.report-modal {
  padding: 8px;
}

.report-shell {
  max-width: 464px;
  border-radius: 18px;
}

@media (min-width: 760px) {
  body {
    max-width: 480px;
  }

  .login-wrap,
  .app {
    display: flex !important;
  }

  .hero-card,
  .login-card {
    margin-bottom: 0;
  }

  header.app-header {
    display: flex !important;
  }
}

.hidden {
  display: none !important;
}

/* RosetaFi Lite v1.6.1 - PDF paper sizing and smart orientation */
.report-modal {
  padding: 8px;
}

.report-shell {
  width: min(1180px, calc(100vw - 16px));
  max-width: 1180px;
}

.report-scroll {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.report-paper {
  flex: 0 0 auto;
  max-width: none !important;
  margin: 0 auto;
  box-sizing: border-box;
}

.report-paper.report-portrait {
  width: 794px;
  min-height: 1123px;
  padding: 44px;
}

.report-paper.report-landscape {
  width: 1123px;
  min-height: 794px;
  padding: 36px;
}

.report-paper.report-landscape .report-section {
  margin-top: 20px;
}

.report-paper.report-landscape .report-head {
  padding-bottom: 14px;
}

.report-paper.report-landscape h1 {
  font-size: 24px;
}

.report-paper.report-landscape table {
  font-size: 10.5px;
}

.report-paper.report-landscape th,
.report-paper.report-landscape td {
  padding: 7px 6px;
  vertical-align: top;
}

.report-paper.report-wide table {
  font-size: 9.4px;
}

.report-paper.report-wide th,
.report-paper.report-wide td {
  padding: 6px 5px;
}

.report-paper .num {
  white-space: nowrap;
}

.report-paper th {
  white-space: normal;
}

.report-paper td {
  overflow-wrap: anywhere;
}

.report-paper.report-wide td {
  overflow-wrap: normal;
}

.report-kpis {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.report-section.two-col {
  grid-template-columns: 1fr 1fr !important;
}

@media(max-width:760px) {
  .report-toolbar {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .report-toolbar > div:last-child {
    margin-top: 0;
  }

  .report-picker {
    grid-template-columns: repeat(4, 150px);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .report-type {
    min-width: 150px;
  }

  .report-paper.report-portrait {
    width: 794px;
    padding: 38px;
  }

  .report-paper.report-landscape {
    width: 1123px;
    padding: 32px;
  }
}

@media print {
  .report-paper.report-portrait {
    page: rosetafiPortrait;
  }

  .report-paper.report-landscape {
    page: rosetafiLandscape;
  }

  @page rosetafiPortrait {
    size: A4 portrait;
    margin: 13mm;
  }

  @page rosetafiLandscape {
    size: A4 landscape;
    margin: 10mm;
  }

  .report-paper.report-portrait,
  .report-paper.report-landscape {
    width: auto !important;
    min-height: auto !important;
    padding: 0 !important;
  }

  .report-paper.report-landscape table {
    font-size: 9.6px !important;
  }

  .report-paper.report-wide table {
    font-size: 8.6px !important;
  }

  .report-head,
  .report-kpis,
  .report-section h1,
  .report-section h2 {
    break-after: avoid;
  }

  .report-kpis,
  .report-section.two-col {
    break-inside: avoid;
  }

  .report-paper tr {
    break-inside: avoid;
  }
}

/* RosetaFi Lite v1.6.2 - modern real estate UI refresh */
@media screen {
  :root {
    --bg: #0B1121;
    --panel: #131C2F;
    --panel2: #16223A;
    --line: #1E293B;
    --text: #F8FAFC;
    --muted: #94A3B8;
    --cyan: #22D3EE;
    --cyan-glow: rgba(34, 211, 238, .28);
    --pink: #F472B6;
    --violet: #818CF8;
    --violet-glow: rgba(129, 140, 248, .28);
    --green: #34D399;
    --red: #FB7185;
    --gold: #FBBF24;
  }

  html {
    background: #050816;
  }

  body {
    max-width: 480px;
    background: linear-gradient(180deg, #0B1121 0%, #101A2F 46%, #0B1121 100%);
    box-shadow: 0 0 50px rgba(0,0,0,.50);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  }

  .login-wrap {
    gap: 18px;
    background: linear-gradient(145deg, #0B1121, #101A2F);
  }

  .hero-card,
  .login-card {
    border-color: rgba(148,163,184,.18) !important;
    border-radius: 20px !important;
    background: rgba(19,28,47,.92) !important;
  }

  .hero-card {
    padding-top: 34px !important;
    padding-bottom: 34px !important;
  }

  .hero-card h1 {
    font-size: 30px;
    font-weight: 900;
  }

  .login-card h2 {
    margin-top: 0;
    font-size: 20px;
  }

  .logo {
    border-radius: 18px;
    background: linear-gradient(135deg, var(--cyan), var(--violet));
    box-shadow: 0 0 26px var(--violet-glow);
  }

  .pills span,
  .badge,
  .soft-label {
    border-color: rgba(34,211,238,.32);
    background: rgba(34,211,238,.08);
    color: var(--cyan);
    font-weight: 850;
  }

  .app {
    padding-bottom: calc(82px + var(--safe-bottom));
  }

  .app main {
    padding: 15px 20px 18px !important;
  }

  .app-header {
    margin: 0 -20px 16px !important;
    padding: 20px 20px 12px !important;
    border-bottom-color: rgba(255,255,255,.05);
    background: rgba(11,17,33,.94);
    box-shadow: 0 10px 28px rgba(3,7,18,.22);
  }

  .header-title h1 {
    font-size: 20px;
    font-weight: 900;
    letter-spacing: .03em;
  }

  .header-title p {
    color: var(--cyan);
    font-size: 11px;
    letter-spacing: .18em;
  }

  .btn-icon {
    width: 50px;
    height: 50px;
    padding: 0 !important;
    border-color: rgba(148,163,184,.18);
    border-radius: 18px;
    background: rgba(19,28,47,.82);
  }

  .btn-icon svg,
  .nav-icon svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .home {
    gap: 14px;
  }

  .home-hero {
    position: relative;
    padding: 24px !important;
    border-color: rgba(129,140,248,.28) !important;
    border-radius: 20px !important;
    background: linear-gradient(145deg, #16223A, #131C2F) !important;
  }

  .home-hero h2 {
    margin: 18px 0 10px;
    font-size: clamp(40px, 11.5vw, 56px) !important;
    font-weight: 900;
    letter-spacing: -.02em !important;
  }

  .home-hero p {
    max-width: 360px;
    font-size: 15px;
  }

  .status-pill {
    display: inline-flex;
    width: fit-content;
    padding: 8px 11px;
    border-radius: 9px;
    font-size: 12px;
  }

  .quick-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px;
  }

  .quick {
    min-height: 72px;
    justify-content: flex-start;
    gap: 12px;
    padding: 14px !important;
    border-color: rgba(148,163,184,.16) !important;
    border-radius: 16px !important;
    background: rgba(19,28,47,.94) !important;
  }

  .quick.primary {
    border-color: transparent !important;
    background: linear-gradient(135deg, var(--cyan), var(--violet)) !important;
  }

  .quick span {
    display: grid;
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    place-items: center;
    border-radius: 14px;
    background: rgba(255,255,255,.09);
    color: #F8FAFC;
    font-size: 13px;
    font-weight: 950;
  }

  .quick .quick-icon svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .quick:not(.primary) .quick-icon {
    color: var(--text);
    background: rgba(148,163,184,.12);
  }

  .quick.report-quick .quick-icon {
    color: var(--cyan);
    background: rgba(34,211,238,.10);
  }

  .quick b {
    font-size: 17px;
    font-weight: 900;
  }

  .card,
  .soft-card,
  .mood-card,
  .mini,
  .mini-box,
  .scan-sheet,
  .correction-sheet {
    border-color: rgba(148,163,184,.16) !important;
    border-radius: 16px !important;
    background: rgba(19,28,47,.94) !important;
  }

  .soft-card,
  .unit-strip {
    padding: 18px !important;
  }

  .panel-title h3,
  .card h3 {
    font-size: 17px !important;
    font-weight: 900;
  }

  .mood-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px;
  }

  .mood-card:first-child {
    grid-column: 1 / -1;
  }

  .mood-card {
    padding: 16px !important;
  }

  .mood-card span,
  .mood-card small,
  .muted {
    color: var(--muted);
  }

  .mood-card b {
    font-size: clamp(24px, 7.6vw, 34px);
  }

  .cash-row,
  .category-chip,
  .unit-pill,
  .table-scroll {
    border-color: rgba(148,163,184,.14);
    background: #0B1121;
  }

  .unit-list {
    gap: 10px;
  }

  input,
  select,
  textarea,
  .search-input {
    border-radius: 12px !important;
    border-color: rgba(148,163,184,.20) !important;
    background: #0B1121 !important;
  }

  button,
  .upload-nota-btn {
    border-radius: 12px;
  }

  .tiny-btn {
    min-height: 36px;
    border-color: rgba(148,163,184,.18);
    background: rgba(255,255,255,.06);
  }

  .bottom-nav {
    height: calc(76px + var(--safe-bottom));
    padding: 11px 8px var(--safe-bottom);
    border-top-color: rgba(255,255,255,.06);
    background: rgba(11,17,33,.96);
  }

  .bottom-nav .nav,
  .bottom-nav .nav-item {
    gap: 5px;
    font-size: 10.5px;
  }

  .nav-icon {
    width: 28px;
    height: 28px;
    border-radius: 10px;
    background: transparent;
  }

  .bottom-nav .nav.active {
    color: var(--cyan);
  }

  .bottom-nav .nav.active .nav-icon {
    background: rgba(34,211,238,.10);
    filter: drop-shadow(0 0 8px var(--cyan-glow));
  }

  .fab {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    border-color: #0B1121;
    background: linear-gradient(135deg, var(--cyan), var(--violet));
    box-shadow: 0 10px 26px var(--violet-glow);
    font-size: 34px;
    font-weight: 700;
  }

  .scan-sheet {
    border-radius: 20px !important;
  }

  .camera-btn {
    border-radius: 16px;
    background: rgba(34,211,238,.06);
  }
}

/* RosetaFi Lite v1.6.3 - compact tax page and clean tax report paper */
@media screen {
  .tax-head {
    gap: 14px;
    padding: 18px !important;
    overflow: hidden;
  }

  .tax-head h3 {
    margin-bottom: 8px;
  }

  .tax-head p {
    max-width: 100%;
    font-size: 14px;
    line-height: 1.45;
    overflow-wrap: anywhere;
  }

  .tax-period {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 92px;
    gap: 10px;
    align-items: stretch;
  }

  .tax-period input[type="hidden"] {
    display: none !important;
  }

  .period-trigger {
    min-height: 62px;
    padding: 10px 14px !important;
    overflow: hidden;
  }

  .period-trigger b {
    font-size: 13px;
    line-height: 1.25;
    white-space: normal;
  }

  .tax-tariff-field {
    display: grid;
    gap: 5px;
    width: 92px;
    min-width: 0;
    margin: 0;
    color: var(--muted);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
  }

  .tax-tariff-field input {
    width: 100%;
    min-height: 38px;
    height: 38px;
    padding: 8px 10px !important;
    text-align: center;
  }

  .tax-load-btn {
    grid-column: 1 / -1;
    min-height: 46px;
    margin: 0 !important;
    padding: 10px 14px !important;
  }

  .tax-kpi-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
  }

  .tax-kpi-grid .metric {
    min-height: 104px;
    padding: 15px !important;
  }

  .tax-kpi-grid .metric .label {
    font-size: 10px;
    line-height: 1.35;
    letter-spacing: .17em;
  }

  .tax-kpi-grid .metric .value {
    margin-top: 12px;
    font-size: clamp(20px, 5.6vw, 28px);
    line-height: 1.05;
    letter-spacing: 0;
    white-space: nowrap;
    overflow-wrap: normal;
  }

  .tax-grid {
    gap: 14px;
    margin-top: 14px;
  }

  .tax-report {
    padding: 16px !important;
  }

  .tax-report .panel-title {
    align-items: flex-start;
    gap: 10px;
  }

  .tax-report .panel-title h3 {
    font-size: 15px !important;
    line-height: 1.25;
  }

  .tax-report .tiny-btn {
    flex: 0 0 auto;
    min-height: 34px;
    padding: 7px 10px;
    font-size: 12px;
  }

  .report-paper.report-kind-neraca-ringkas table {
    width: 100%;
    table-layout: fixed;
  }

  .report-paper.report-kind-neraca-ringkas th,
  .report-paper.report-kind-neraca-ringkas td,
  .report-paper.report-kind-neraca-ringkas .num {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .report-paper.report-kind-neraca-ringkas th:first-child,
  .report-paper.report-kind-neraca-ringkas td:first-child {
    width: 24%;
  }
}

@media print {
  .report-paper.report-kind-neraca-ringkas table {
    width: 100%;
    table-layout: fixed;
    font-size: 8.2px !important;
  }

  .report-paper.report-kind-neraca-ringkas th,
  .report-paper.report-kind-neraca-ringkas td,
  .report-paper.report-kind-neraca-ringkas .num {
    white-space: normal !important;
    overflow-wrap: anywhere;
  }
}

/* RosetaFi Lite v1.6.4 - compact readable data tables */
@media screen {
  .table-scroll table {
    min-width: 720px;
    font-size: 12px;
    table-layout: auto;
  }

  .tax-report .table-scroll table {
    min-width: 920px;
  }

  .table-scroll th {
    padding: 9px 8px;
    font-size: 10px;
    line-height: 1.15;
    letter-spacing: .16em;
    white-space: nowrap;
    vertical-align: middle;
  }

  .table-scroll td {
    padding: 9px 8px;
    color: rgba(248,250,252,.92);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
    white-space: nowrap;
    vertical-align: middle;
  }

  .table-scroll tbody td:first-child,
  .table-scroll thead th:first-child,
  .table-scroll td.num,
  .table-scroll th.num {
    text-align: center !important;
  }

  .table-scroll tbody td:nth-child(7) {
    min-width: 240px;
  }

  .tax-report .table-scroll td {
    font-size: 12px;
  }

  .tax-report .table-scroll td:first-child,
  .tax-report .table-scroll td:nth-child(2),
  .tax-report .table-scroll td.num {
    text-align: center !important;
  }

  .table-scroll tfoot td {
    padding: 10px 8px;
    font-size: 12px;
    font-weight: 900;
  }

  #dashTrxTable .table-scroll table,
  #trxTable .table-scroll table {
    min-width: 1040px;
  }

  #dashTrxTable .table-scroll td,
  #trxTable .table-scroll td {
    font-size: 11.5px;
  }

  #dashTrxTable .table-scroll tbody td:nth-child(7),
  #trxTable .table-scroll tbody td:nth-child(7) {
    min-width: 280px;
  }
}

/* RosetaFi Lite v1.6.5 - compact three-column dashboard totals */
@media screen {
  .mood-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .mood-card:first-child {
    grid-column: auto !important;
  }

  .mood-card {
    min-height: 124px;
    padding: 14px 12px !important;
  }

  .mood-card span {
    font-size: 10px;
    line-height: 1.2;
    letter-spacing: .16em;
    white-space: nowrap;
  }

  .mood-card b {
    margin-top: 13px;
    font-size: clamp(13px, 2.8vw, 18px) !important;
    line-height: 1.05;
    letter-spacing: 0;
    white-space: nowrap;
    overflow-wrap: normal;
  }

  .mood-card small {
    margin-top: 8px;
    font-size: 11px;
    line-height: 1.25;
  }
}

/* RosetaFi Lite v1.6.6 - compact balance sheet view */
@media screen {
  .neraca-page {
    display: grid;
    gap: 12px;
  }

  .balance-card {
    padding: 16px !important;
    border-color: rgba(52,211,153,.24) !important;
    background:
      radial-gradient(circle at 10% 0%, rgba(52,211,153,.16), transparent 30%),
      radial-gradient(circle at 92% 18%, rgba(251,191,36,.12), transparent 28%),
      linear-gradient(145deg, rgba(13,35,34,.94), rgba(19,28,47,.94)) !important;
  }

  .balance-headline {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
  }

  .balance-headline h3 {
    margin: 10px 0 6px !important;
    font-size: 20px !important;
  }

  .balance-headline p {
    max-width: 410px;
    font-size: 13px;
    line-height: 1.4;
  }

  .balance-headline .status-pill {
    margin-top: 0;
    white-space: nowrap;
  }

  .neraca-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 14px;
  }

  .balance-mini {
    min-width: 0;
    min-height: 86px;
    padding: 12px 10px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 14px;
    background: rgba(5,11,24,.52);
  }

  .balance-mini span {
    display: block;
    color: var(--muted);
    font-size: 9.5px;
    font-weight: 900;
    letter-spacing: .13em;
    line-height: 1.2;
    text-transform: uppercase;
  }

  .balance-mini b {
    display: block;
    margin-top: 12px;
    font-size: clamp(12px, 2.8vw, 16px);
    line-height: 1.05;
    white-space: nowrap;
  }

  .tone-asset b {
    color: #6EE7B7;
  }

  .tone-passive b {
    color: #FDE68A;
  }

  .tone-diff b {
    color: #93C5FD;
  }

  .neraca-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    margin-top: 0 !important;
  }

  .neraca-panel {
    gap: 4px;
    padding: 16px !important;
    border-radius: 18px !important;
    box-shadow: none !important;
  }

  .neraca-grid > .neraca-panel:nth-child(1) {
    border-color: rgba(52,211,153,.22) !important;
    background:
      radial-gradient(circle at 8% 5%, rgba(52,211,153,.12), transparent 28%),
      rgba(15,31,42,.94) !important;
  }

  .neraca-grid > .neraca-panel:nth-child(2) {
    border-color: rgba(251,191,36,.22) !important;
    background:
      radial-gradient(circle at 92% 8%, rgba(251,191,36,.12), transparent 28%),
      rgba(28,29,40,.94) !important;
  }

  .neraca-grid > .neraca-panel:nth-child(3) {
    border-color: rgba(244,114,182,.20) !important;
    background:
      radial-gradient(circle at 10% 8%, rgba(244,114,182,.11), transparent 28%),
      rgba(28,26,43,.94) !important;
  }

  .neraca-panel h3 {
    margin-bottom: 8px !important;
    font-size: 17px !important;
  }

  .neraca-panel p {
    margin: 10px 0 4px;
  }

  .neraca-panel p.muted {
    font-size: 12px;
    line-height: 1.25;
  }

  .neraca-panel h2 {
    margin: 0 0 4px;
    font-size: clamp(20px, 5.2vw, 28px) !important;
    line-height: 1.06 !important;
    letter-spacing: 0 !important;
    white-space: nowrap;
  }

  .neraca-panel small {
    font-size: 11px;
    line-height: 1.3;
  }

  .neraca-panel > b {
    display: block;
    width: fit-content;
    max-width: 100%;
    margin-top: 10px;
    padding: 8px 10px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 12px;
    background: rgba(5,11,24,.42);
    font-size: 12px;
    line-height: 1.25;
  }

  .neraca-panel .mini-box {
    margin: 8px 0;
    padding: 10px;
    border-radius: 13px;
    background: rgba(5,11,24,.36) !important;
  }

  .neraca-panel .mini-row {
    gap: 8px !important;
    padding: 4px 0;
    flex-wrap: nowrap !important;
    font-size: 11.5px;
    line-height: 1.25;
  }

  .neraca-panel .mini-row span {
    flex: 1 1 auto !important;
  }

  .neraca-panel .mini-row b {
    flex: 0 0 auto !important;
    font-size: 11.5px;
  }

  .neraca-panel details {
    max-height: 150px;
    margin-top: 6px;
  }

  .kategori-detail {
    padding: 18px !important;
  }

  .kategori-detail .panel-title {
    align-items: flex-start;
  }

  .kategori-detail h3 {
    margin-bottom: 4px !important;
  }

  .detail-actions {
    display: flex;
    gap: 8px;
    flex: 0 0 auto;
  }
}
