:root {
      --color-bg-dark: #0B1020;
      --color-primary: #4C6FFF;
      --color-secondary: #12C6A7;
      --color-accent: #FF5C5C;
      --color-card: #F5F7FB;
      --color-text-main: #141824;
      --color-text-soft: #A1AEC6;
      --color-border: #d7dff3;
      --radius-lg: 16px;
      --radius-sm: 9px;
      --shadow-card: 0 10px 22px rgba(5,10,30,0.32);
      --shadow-soft: 0 6px 14px rgba(32,87,255,0.18);
    }

    * {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
      font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    }

    html, body {
      min-height: 100%;
    }

    body {
      display: flex;
      min-height: 100vh;
      background: radial-gradient(circle at top left, #243B8C, #0B1020 55%);
      color: #fff;
    }

    .sidebar {
      width: 250px;
      padding: 18px 16px;
      background: rgba(5, 7, 15, 0.95);
      border-right: 1px solid rgba(255,255,255,0.05);
      display: flex;
      flex-direction: column;
      gap: 20px;
      position: sticky;
      top: 0;
      min-height: 100vh;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .brand-mark {
      width: 42px;
      height: 42px;
      border-radius: 14px;
      background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
      display: grid;
      place-items: center;
      font-weight: 800;
      box-shadow: 0 10px 24px rgba(76,111,255,0.35);
    }

    .brand-name {
      font-size: 1.08rem;
      font-weight: 800;
      line-height: 1.05;
      letter-spacing: -0.03em;
      white-space: nowrap;
    }

    .brand-tagline {
      font-size: 0.72rem;
      color: #A1AEC6;
    }

    .nav {
      display: flex;
      flex-direction: column;
      gap: 6px;
      font-size: 0.85rem;
    }

    .nav-section-title {
      font-size: 0.7rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--color-text-soft);
      margin-bottom: 2px;
    }

    .nav-link {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 9px 10px;
      border-radius: 10px;
      color: #d9e1ff;
      cursor: pointer;
      transition: background 0.18s ease, transform 0.08s ease;
      user-select: none;
    }

    .nav-link:hover {
      background: rgba(255,255,255,0.04);
      transform: translateY(-1px);
    }

    .nav-link.active {
      background: linear-gradient(135deg, var(--color-primary), #6C8CFF);
      color: #fff;
      box-shadow: 0 6px 14px rgba(24,67,255,0.45);
    }

    .nav-dot {
      width: 7px;
      height: 7px;
      border-radius: 999px;
      background: rgba(255,255,255,0.4);
      flex: 0 0 auto;
    }

    .nav-link.active .nav-dot {
      background: #fff;
    }

    .sidebar-footer {
      margin-top: auto;
      font-size: 0.75rem;
      color: var(--color-text-soft);
      line-height: 1.4;
    }

    .main {
      flex: 1;
      padding: 16px 18px 20px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      overflow-x: hidden;
    }

    header.main-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      flex-wrap: wrap;
    }

    .title-block h1 {
      font-size: 1.25rem;
      margin-bottom: 2px;
    }

    .title-block p {
      font-size: 0.78rem;
      color: var(--color-text-soft);
      max-width: 760px;
      line-height: 1.45;
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
    }

    .pill {
      padding: 6px 10px;
      border-radius: 999px;
      font-size: 0.72rem;
      background: rgba(76,111,255,0.09);
      color: #dfe6ff;
      border: 1px solid rgba(255,255,255,0.12);
      white-space: nowrap;
    }

    .btn-primary,
    .btn-ghost,
    .btn-danger,
    .btn-inline {
      border: none;
      cursor: pointer;
      transition: transform 0.1s ease, box-shadow 0.1s ease, opacity 0.15s ease;
    }

    .btn-primary,
    .btn-danger,
    .btn-ghost {
      padding: 8px 14px;
      border-radius: 999px;
      font-size: 0.78rem;
      font-weight: 700;
      white-space: nowrap;
    }

    .btn-primary {
      background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
      color: #fff;
      box-shadow: 0 6px 14px rgba(32,87,255,0.35);
    }

    .btn-primary:hover,
    .btn-danger:hover,
    .btn-ghost:hover,
    .btn-inline:hover {
      transform: translateY(-1px);
    }

    .btn-save-main {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 18px;
      background: linear-gradient(135deg, #00C6FF, #0072FF);
      font-size: 0.8rem;
      text-transform: uppercase;
      letter-spacing: 0.09em;
    }

    .btn-save-main-icon {
      font-size: 1rem;
      line-height: 1;
    }

    .btn-save-main-label {
      position: relative;
      top: 0.5px;
    }

    .btn-save-main:hover {
      transform: translateY(-2px);
    }

    .btn-delete-main {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 18px;
      background: linear-gradient(135deg, #FF5C5C, #FF2D55);
      font-size: 0.8rem;
      text-transform: uppercase;
      letter-spacing: 0.09em;
    }

    .btn-delete-main-icon {
      font-size: 1rem;
      line-height: 1;
    }

    .btn-delete-main-label {
      position: relative;
      top: 0.5px;
    }

    .btn-delete-main:hover {
      transform: translateY(-2px);
    }

    .btn-ghost {
      background: transparent;
      color: #fff;
      border: 1px solid rgba(255,255,255,0.16);
    }

    .btn-danger {
      background: linear-gradient(135deg, #FF5C5C, #FF2D55);
      color: #fff;
      box-shadow: 0 6px 14px rgba(255,45,85,0.28);
    }

    .page {
      display: none;
      gap: 12px;
    }

    .page.active {
      display: flex;
      flex-direction: column;
    }

    .card {
      background: #ffffff;
      border-radius: var(--radius-lg);
      padding: 12px 12px 10px;
      color: var(--color-text-main);
      box-shadow: var(--shadow-card);
    }

    .card-title-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 8px;
      gap: 8px;
      flex-wrap: wrap;
    }

    .card-title-row h2 {
      font-size: 0.92rem;
    }

    .card-lead {
      font-size: 0.8rem;
      line-height: 1.45;
      color: var(--color-text-soft);
      margin-bottom: 10px;
    }

    .dashboard-grid-top,
    .content-grid,
    .category-top-grid,
    .planning-grid {
      display: grid;
      gap: 12px;
    }

    .dashboard-grid-top {
      grid-template-columns: 1.1fr 0.9fr;
      align-items: stretch;
    }

    .planning-grid,
    .category-top-grid,
    .content-grid {
      grid-template-columns: 1.15fr 0.85fr;
      align-items: start;
    }

    .planning-grid {
      align-items: stretch;
    }

    #page-necessities .category-top-grid,
    #page-leisure .category-top-grid,
    #page-savings .category-top-grid {
      align-items: stretch;
    }

    #page-necessities .category-top-grid > .card,
    #page-leisure .category-top-grid > .card,
    #page-savings .category-top-grid > .card {
      height: 100%;
    }

    .quick-main {
      background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
      border-radius: var(--radius-lg);
      padding: 12px;
      color: #fff;
      box-shadow: 0 10px 20px rgba(12,28,90,0.55);
      margin-bottom: 10px;
    }

    .quick-main-label {
      font-size: 0.72rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      opacity: 0.92;
    }

    .quick-main-value {
      font-size: 1.45rem;
      font-weight: 700;
      margin: 4px 0;
    }

    .quick-main-sub {
      font-size: 0.75rem;
      opacity: 0.95;
      line-height: 1.45;
    }

    .mini-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 8px;
    }

    .quick-secondary,
    .summary-item,
    .kpi {
      background: #F5F7FB;
      border-radius: var(--radius-lg);
      padding: 10px 11px;
      border: 1px solid rgba(76,111,255,0.12);
    }

    .quick-secondary {
      display: flex;
      flex-direction: column;
      gap: 3px;
      min-height: 110px;
    }

    .quick-secondary-label,
    .summary-label,
    .kpi-label,
    .metric-label {
      font-size: 0.72rem;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: var(--color-text-soft);
    }

    .quick-secondary-value,
    .summary-total,
    .kpi-value,
    .metric-value {
      font-size: 1.1rem;
      font-weight: 700;
      color: var(--color-text-main);
    }

    .quick-secondary-sub,
    .summary-sub,
    .metric-sub {
      font-size: 0.75rem;
      color: var(--color-text-soft);
      line-height: 1.4;
    }

    .delta-positive { color: #0B9E84; }
    .delta-negative { color: #D83B5B; }
    .delta-neutral { color: var(--color-text-soft); }

    .allocation-layout {
      display: flex;
      justify-content: center;
      align-items: center;
      min-height: 560px;
      width: 100%;
    }

    .pie-chart-wrap {
      width: 100%;
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 10px 0 4px;
    }

    .pie-chart-shell {
      width: min(100%, 1040px);
      display: flex;
      justify-content: center;
      align-items: center;
    }

    .allocation-svg {
      width: 100%;
      height: auto;
      overflow: visible;
    }

    .allocation-slice {
      stroke: #ffffff;
      stroke-width: 2;
    }

    .allocation-label-line {
      stroke: rgba(20, 24, 36, 0.28);
      stroke-width: 1.5;
      fill: none;
    }

    .allocation-label {
      font-size: 15px;
      font-weight: 700;
      fill: #141824;
    }

    .allocation-label.small {
      font-size: 13px;
      font-weight: 600;
      fill: #5b6a86;
    }

    .allocation-label.detail {
      font-size: 13px;
      font-weight: 600;
      fill: #5b6a86;
    }

    .allocation-label.inside {
      fill: #ffffff;
      stroke: rgba(20,24,36,0.34);
      stroke-width: 4px;
      paint-order: stroke;
      font-size: 18px;
      font-weight: 800;
    }

    .allocation-carousel {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr) auto;
      align-items: center;
      gap: 10px;
      width: 100%;
    }

    .allocation-nav-btn {
      width: 38px;
      height: 38px;
      border-radius: 999px;
      border: 1px solid rgba(76,111,255,0.18);
      background: rgba(76,111,255,0.10);
      color: #3554d8;
      cursor: pointer;
      font-size: 1rem;
      font-weight: 900;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      box-shadow: var(--shadow-soft);
      transition: transform 0.1s ease, background 0.15s ease, opacity 0.15s ease;
      user-select: none;
    }

    .allocation-nav-btn:hover {
      background: rgba(76,111,255,0.16);
      transform: translateY(-1px);
    }

    .allocation-page-indicator {
      margin-top: 4px;
      text-align: center;
      font-size: 0.74rem;
      font-weight: 700;
      color: var(--color-text-soft);
      letter-spacing: 0.06em;
    }

    .empty-state {

      border: 1px dashed rgba(76,111,255,0.25);
      background: #F8FAFF;
      color: var(--color-text-soft);
      border-radius: 14px;
      padding: 18px 14px;
      text-align: center;
      font-size: 0.82rem;
      line-height: 1.45;
    }

    .metric-grid,
    .summary-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 8px;
    }

    .summary-grid {
      margin-top: 8px;
    }

    .metric,
    .summary-item {
      display: flex;
      flex-direction: column;
      gap: 4px;
      min-height: 92px;
      justify-content: center;
    }

    .metric.delta-positive .metric-value,
    .metric.delta-positive .metric-sub { color: #0B9E84; }

    .metric.delta-negative .metric-value,
    .metric.delta-negative .metric-sub { color: #D83B5B; }

    .metric.delta-neutral .metric-value,
    .metric.delta-neutral .metric-sub { color: var(--color-text-soft); }

    #page-necessities #necessitiesMetrics,
    #page-leisure #leisureMetrics,
    #page-savings #savingsMetrics {
      align-items: stretch;
      justify-items: center;
      grid-auto-rows: 1fr;
      grid-template-columns: repeat(3, 1fr);
    }

    #page-necessities #necessitiesMetrics .metric,
    #page-leisure #leisureMetrics .metric,
    #page-savings #savingsMetrics .metric {
      width: 100%;
      height: 100%;
      align-items: center;
      justify-content: center;
      text-align: center;
    }

    #page-necessities #necessitiesMetrics .metric-label,
    #page-necessities #necessitiesMetrics .metric-value,
    #page-necessities #necessitiesMetrics .metric-sub,
    #page-leisure #leisureMetrics .metric-label,
    #page-leisure #leisureMetrics .metric-value,
    #page-leisure #leisureMetrics .metric-sub,
    #page-savings #savingsMetrics .metric-label,
    #page-savings #savingsMetrics .metric-value,
    #page-savings #savingsMetrics .metric-sub {
      width: 100%;
      text-align: center;
    }

    #page-necessities #necessitiesMetrics .metric-sub,
    #page-leisure #leisureMetrics .metric-sub,
    #page-savings #savingsMetrics .metric-sub {
      min-height: 1.4em;
    }

    .input-grid {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 8px;
      align-items: end;
    }

    .planning-income-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
      align-items: end;
    }

    .field {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .field label {
      font-size: 0.74rem;
      color: var(--color-text-soft);
      font-weight: 600;
    }

    .field input,
    .field select {
      width: 100%;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid var(--color-border);
      background: #fff;
      color: var(--color-text-main);
      font-size: 0.86rem;
      outline: none;
      transition: border-color 0.12s ease, box-shadow 0.12s ease;
    }

    .field input:focus,
    .field select:focus {
      border-color: rgba(76,111,255,0.55);
      box-shadow: 0 0 0 4px rgba(76,111,255,0.10);
    }

    .table-wrap {
      overflow-x: auto;
    }

    table {
      width: 100%;
      border-collapse: collapse;
      font-size: 0.82rem;
      margin-top: 4px;
    }

    th, td {
      padding: 10px 8px;
      text-align: right;
      border-bottom: 1px solid #edf1fb;
      white-space: nowrap;
    }

    th:first-child, td:first-child,
    th:nth-child(2), td:nth-child(2) {
      text-align: left;
    }

    th {
      background: #E2E7F5;
      color: var(--color-text-main);
      font-size: 0.74rem;
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }

    tr:nth-child(even) td {
      background: #F8F9FC;
    }



    #planningComparisonDataTable th,
    #planningComparisonDataTable td {
      text-align: center !important;
    }

    .tag {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 4px 9px;
      border-radius: 999px;
      font-size: 0.7rem;
      font-weight: 700;
      white-space: nowrap;
    }

    .tag-necessities {
      background: rgba(76,111,255,0.10);
      color: #3554d8;
    }

    .tag-leisure {
      background: rgba(76,111,255,0.10);
      color: #3554d8;
    }

    .tag-savings {
      background: rgba(76,111,255,0.10);
      color: #3554d8;
    }

    .btn-inline {
      padding: 6px 10px;
      border-radius: 999px;
      background: rgba(255,92,92,0.12);
      color: #d53d53;
      font-size: 0.74rem;
      font-weight: 700;
    }

    .helper-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
      margin-top: 8px;
      font-size: 0.75rem;
      color: var(--color-text-soft);
    }

    .progress-card {
      display: flex;
      flex-direction: column;
      gap: 10px;
      height: 100%;
    }

    .progress-row {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .progress-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      font-size: 0.8rem;
      font-weight: 700;
      color: var(--color-text-main);
    }

    .progress-meta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      font-size: 0.75rem;
      color: var(--color-text-soft);
    }

    .progress-track {
      width: 100%;
      height: 10px;
      border-radius: 999px;
      background: #E8ECF8;
      overflow: hidden;
    }

    .progress-fill {
      height: 100%;
      border-radius: inherit;
      width: 0%;
      transition: width 0.2s ease;
      background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    }

    .info-box {
      padding: 10px 12px;
      border-radius: 12px;
      background: #F8FAFF;
      border: 1px solid rgba(76,111,255,0.12);
      color: var(--color-text-main);
      font-size: 0.8rem;
      line-height: 1.45;
    }

    .info-box strong {
      color: var(--color-primary);
    }

    .mono {
      font-variant-numeric: tabular-nums;
    }


    /* === Import/Export (menu) === */
    .hf-io-row {
      display: flex;
      gap: 8px;
      margin-top: 10px;
      margin-bottom: 6px;
    }

    .hf-io-btn {
      flex: 1 1 0;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      padding: 6px 8px;
      border-radius: 10px;
      border: 1px solid rgba(255,255,255,0.16);
      background: rgba(255,255,255,0.04);
      color: #d9e1ff;
      cursor: pointer;
      font-size: 0.72rem;
      font-weight: 600;
      transition: background 0.18s ease, transform 0.08s ease;
      user-select: none;
    }

    .hf-io-btn svg {
      width: 14px;
      height: 14px;
      display: block;
      fill: currentColor;
      opacity: 0.95;
    }

    .hf-io-btn:hover {
      background: rgba(255,255,255,0.08);
      transform: translateY(-1px);
    }

    .hf-io-btn:active {
      transform: translateY(0);
    }


    /* === Sottovoci voci budget === */
    .entry-actions {
      display: inline-flex;
      align-items: center;
      justify-content: flex-end;
      gap: 6px;
      flex-wrap: wrap;
    }

    .btn-folder {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      padding: 6px 10px;
      border-radius: 999px;
      border: 1px solid rgba(76,111,255,0.18);
      background: rgba(76,111,255,0.10);
      color: #3554d8;
      cursor: pointer;
      font-size: 0.74rem;
      font-weight: 700;
      transition: transform 0.1s ease, background 0.15s ease;
      white-space: nowrap;
    }

    .btn-folder:hover {
      background: rgba(76,111,255,0.16);
      transform: translateY(-1px);
    }

    .entry-note {
      margin-top: 3px;
      font-size: 0.72rem;
      color: var(--color-text-soft);
      line-height: 1.35;
    }

    .subentry-modal-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.62);
      z-index: 12000;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 18px;
    }

    .subentry-modal-card {
      width: min(760px, 96vw);
      max-height: 88vh;
      overflow: auto;
      background: #fff;
      color: var(--color-text-main);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-card);
      padding: 14px;
    }

    .subentry-modal-header {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 10px;
      margin-bottom: 10px;
    }

    .subentry-modal-header h2 {
      font-size: 1rem;
      margin-bottom: 3px;
    }

    .subentry-modal-subtitle {
      font-size: 0.78rem;
      color: var(--color-text-soft);
      line-height: 1.45;
    }

    .subentry-form-grid {
      display: grid;
      grid-template-columns: 1.25fr 0.75fr auto;
      gap: 8px;
      align-items: end;
      margin: 10px 0 12px;
    }

    .subentry-summary-box {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 8px;
      margin: 8px 0 10px;
    }

    .subentry-summary-item {
      background: #F5F7FB;
      border: 1px solid rgba(76,111,255,0.12);
      border-radius: 14px;
      padding: 10px;
    }

    .subentry-summary-label {
      font-size: 0.7rem;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: var(--color-text-soft);
      margin-bottom: 3px;
    }

    .subentry-summary-value {
      font-size: 1rem;
      font-weight: 800;
      color: var(--color-text-main);
    }

    .btn-modal-close {
      border: 1px solid rgba(20,24,36,0.12);
      background: #F5F7FB;
      color: var(--color-text-main);
      border-radius: 999px;
      width: 32px;
      height: 32px;
      cursor: pointer;
      font-weight: 800;
      line-height: 1;
    }

    .app-dialog-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.62);
      z-index: 13000;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 18px;
    }

    .app-dialog-card {
      width: min(420px, 92vw);
      max-height: 85vh;
      overflow: auto;
      background: #fff;
      color: var(--color-text-main);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-card);
      padding: 14px;
    }

    .app-dialog-header {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 10px;
      margin-bottom: 10px;
    }

    .app-dialog-header h2 {
      font-size: 1rem;
      margin: 0;
    }

    .app-dialog-message {
      font-size: 0.82rem;
      color: var(--color-text-main);
      line-height: 1.45;
      margin: 0;
      white-space: pre-wrap;
    }

    .app-dialog-actions {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 8px;
      margin-top: 14px;
    }

    .btn-dialog-cancel {
      border: 1px solid rgba(20,24,36,0.12);
      background: #F5F7FB;
      color: var(--color-text-main);
      cursor: pointer;
      padding: 8px 14px;
      border-radius: 999px;
      font-size: 0.78rem;
      font-weight: 700;
      white-space: nowrap;
      transition: transform 0.1s ease, box-shadow 0.1s ease, opacity 0.15s ease;
    }

    .btn-dialog-cancel:hover {
      transform: translateY(-1px);
    }

    @media (max-width: 900px) {
      .subentry-form-grid,
      .subentry-summary-box {
        grid-template-columns: 1fr;
      }

      .entry-actions {
        justify-content: flex-start;
      }

      .allocation-carousel {
        grid-template-columns: 1fr;
      }

      .allocation-nav-btn {
        width: 100%;
        height: 34px;
      }
    }

    @media (max-width: 1180px) {
      .dashboard-grid-top,
      .planning-grid,
      .category-top-grid,
      .content-grid,
      .allocation-layout {
        grid-template-columns: 1fr;
      }

    }

    @media (max-width: 900px) {
      body {
        flex-direction: column;
      }

      .sidebar {
        width: 100%;
        min-height: auto;
        position: static;
      }

      .nav {
        flex-direction: row;
        overflow-x: auto;
        padding-bottom: 2px;
      }

      .nav-link {
        flex: 0 0 auto;
      }

      .main {
        padding: 12px;
      }

      .mini-grid,
      .metric-grid,
      .summary-grid {
        grid-template-columns: 1fr;
      }

      .input-grid,
      .planning-income-grid {
        grid-template-columns: 1fr;
      }

    }

    /* === Cross-platform responsive layer: PC/Desktop/Tablet + Android/iOS/macOS hardening === */
    :root {
      --sidebar-width-fluid: clamp(15.5rem, 18vw, 18rem);
      --page-gutter-fluid: clamp(0.875rem, 1.45vw, 1.375rem);
      --card-padding-fluid: clamp(0.875rem, 1.2vw, 1.125rem);
      --control-height-touch: 2.75rem;
      --header-gap-fluid: clamp(0.75rem, 1.2vw, 1rem);
    }

    html {
      min-width: 320px;
      background: var(--color-bg-dark);
      -webkit-text-size-adjust: 100%;
      text-size-adjust: 100%;
      scroll-behavior: smooth;
    }

    body {
      width: 100%;
      min-width: 320px;
      min-height: 100vh;
      min-height: 100svh;
      min-height: 100dvh;
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
      padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
    }

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

    button,
    .nav-link,
    .hf-io-btn,
    .btn-folder,
    .btn-inline {
      touch-action: manipulation;
      -webkit-tap-highlight-color: rgba(76,111,255,0.18);
    }

    button:focus-visible,
    .nav-link:focus-visible,
    input:focus-visible,
    select:focus-visible {
      outline: 3px solid rgba(76,111,255,0.34);
      outline-offset: 2px;
    }

    .sidebar {
      flex: 0 0 var(--sidebar-width-fluid);
      width: var(--sidebar-width-fluid);
      min-width: 0;
      min-height: 100vh;
      min-height: 100dvh;
      max-height: 100dvh;
      overflow-y: auto;
      overflow-x: hidden;
      -webkit-overflow-scrolling: touch;
      padding: clamp(1rem, 1.35vw, 1.25rem);
    }

    .brand,
    .brand-name,
    .nav,
    .nav > div,
    .main,
    .page,
    .card,
    .title-block,
    .header-actions,
    .allocation-carousel,
    .allocation-layout,
    .pie-chart-wrap,
    .pie-chart-shell {
      min-width: 0;
    }

    .brand-name {
      font-size: clamp(0.88rem, 0.72vw + 0.62rem, 1.02rem);
      line-height: 1.05;
      letter-spacing: -0.035em;
      white-space: nowrap;
      overflow-wrap: normal;
      word-break: keep-all;
    }

    .nav > div {
      display: flex;
      flex-direction: column;
      gap: 0.375rem;
      min-width: 0;
    }

    .nav-link {
      min-height: 2.5rem;
      line-height: 1.2;
    }

    .main {
      flex: 1 1 auto;
      min-width: 0;
      width: 100%;
      padding: var(--page-gutter-fluid);
      gap: clamp(0.75rem, 1vw, 1rem);
    }

    header.main-header {
      gap: var(--header-gap-fluid);
      align-items: flex-start;
    }

    .title-block {
      flex: 1 1 30rem;
    }

    .title-block h1 {
      font-size: clamp(1.15rem, 1.05vw + 0.9rem, 1.75rem);
      line-height: 1.2;
      overflow-wrap: anywhere;
    }

    .title-block p,
    .card-lead,
    .info-box,
    .empty-state {
      font-size: clamp(0.82rem, 0.24vw + 0.76rem, 0.95rem);
      line-height: 1.55;
    }

    .header-actions {
      justify-content: flex-end;
    }

    .btn-primary,
    .btn-danger,
    .btn-ghost,
    .btn-inline,
    .btn-folder,
    .hf-io-btn,
    .allocation-nav-btn,
    .btn-modal-close {
      -webkit-user-select: none;
      user-select: none;
    }

    .btn-primary,
    .btn-danger,
    .btn-ghost,
    .btn-save-main,
    .btn-delete-main {
      min-height: 2.5rem;
      padding-inline: clamp(0.85rem, 1vw, 1.15rem);
    }

    .card {
      padding: var(--card-padding-fluid);
      overflow: hidden;
    }

    .card-title-row h2 {
      font-size: clamp(0.95rem, 0.45vw + 0.8rem, 1.15rem);
      line-height: 1.25;
    }

    .dashboard-grid-top,
    .planning-grid,
    .category-top-grid,
    .content-grid {
      grid-template-columns: minmax(0, 1.15fr) minmax(18rem, 0.85fr);
      gap: clamp(0.75rem, 1vw, 1rem);
    }

    .mini-grid,
    .metric-grid,
    .summary-grid {
      grid-template-columns: repeat(auto-fit, minmax(min(100%, 10.5rem), 1fr));
    }

    #page-necessities #necessitiesMetrics,
    #page-leisure #leisureMetrics,
    #page-savings #savingsMetrics {
      grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr));
    }

    .quick-secondary,
    .summary-item,
    .kpi,
    .metric {
      min-width: 0;
    }

    .metric-value,
    .quick-secondary-value,
    .summary-total,
    .kpi-value {
      font-size: clamp(1rem, 0.35vw + 0.95rem, 1.25rem);
      overflow-wrap: anywhere;
    }

    .input-grid,
    .planning-income-grid,
    .subentry-form-grid {
      grid-template-columns: repeat(auto-fit, minmax(min(100%, 13rem), 1fr));
    }

    .field input,
    .field select,
    #selectLanguage,
    #selectCurrency {
      min-height: 2.75rem;
      font-size: clamp(0.92rem, 0.22vw + 0.84rem, 1rem);
      line-height: 1.25;
    }

    .field input[readonly] {
      cursor: default;
    }

    .table-wrap {
      width: 100%;
      max-width: 100%;
      overflow-x: auto;
      overflow-y: hidden;
      -webkit-overflow-scrolling: touch;
      overscroll-behavior-x: contain;
      scrollbar-width: thin;
    }

    .table-wrap table {
      min-width: 44rem;
    }

    #planningComparisonDataTable {
      min-width: 62rem;
    }

    th,
    td {
      padding: clamp(0.55rem, 0.7vw, 0.75rem) clamp(0.5rem, 0.6vw, 0.7rem);
      vertical-align: middle;
    }

    td:first-child,
    th:first-child {
      white-space: normal;
      min-width: 10rem;
      max-width: 26rem;
      overflow-wrap: anywhere;
    }

    .entry-actions {
      min-width: max-content;
    }

    .allocation-layout {
      min-height: clamp(24rem, 50vw, 35rem);
      overflow: hidden;
    }

    .pie-chart-shell {
      width: 100%;
      max-width: 65rem;
      margin-inline: auto;
    }

    .allocation-svg {
      display: block;
      width: 100%;
      max-width: 100%;
      max-height: min(72vh, 46rem);
    }

    .allocation-label {
      font-size: clamp(0.82rem, 1.25vw, 0.98rem);
    }

    .allocation-label.small,
    .allocation-label.detail {
      font-size: clamp(0.72rem, 1.05vw, 0.86rem);
    }

    .allocation-label.inside {
      font-size: clamp(0.9rem, 1.4vw, 1.12rem);
    }

    .subentry-modal-overlay,
    #overlayLangCurrency {
      padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left)) !important;
      overscroll-behavior: contain;
    }

    .subentry-modal-card,
    #overlayLangCurrency > .card {
      width: min(47.5rem, 100%);
      max-height: calc(100vh - 2rem);
      max-height: calc(100dvh - max(1rem, env(safe-area-inset-top)) - max(1rem, env(safe-area-inset-bottom)));
      overflow: auto;
      -webkit-overflow-scrolling: touch;
    }

    .subentry-modal-header {
      position: sticky;
      top: 0;
      z-index: 1;
      background: #fff;
      padding-bottom: 0.5rem;
    }

    @media (hover: none) and (pointer: coarse) {
      .field input,
      .field select,
      #selectLanguage,
      #selectCurrency {
        font-size: 16px;
      }

      .btn-primary,
      .btn-danger,
      .btn-ghost,
      .btn-inline,
      .btn-folder,
      .hf-io-btn,
      .allocation-nav-btn,
      .btn-modal-close {
        min-height: var(--control-height-touch);
      }

      .nav-link {
        min-height: var(--control-height-touch);
      }
    }

    @media (max-width: 1180px) {
      .dashboard-grid-top,
      .planning-grid,
      .category-top-grid,
      .content-grid {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 1024px) {
      body {
        flex-direction: column;
      }

      .sidebar {
        position: sticky;
        top: env(safe-area-inset-top);
        z-index: 1000;
        flex: 0 0 auto;
        width: 100%;
        max-height: none;
        min-height: auto;
        border-right: 0;
        border-bottom: 1px solid rgba(255,255,255,0.08);
        gap: 0.75rem;
        padding: 0.875rem max(0.875rem, env(safe-area-inset-right)) 0.75rem max(0.875rem, env(safe-area-inset-left));
      }

      .brand {
        justify-content: space-between;
      }

      .brand-name {
        font-size: clamp(1rem, 2.4vw, 1.16rem);
        letter-spacing: -0.028em;
      }

      .nav {
        flex-direction: row;
        overflow: hidden;
        width: 100%;
      }

      .nav > div {
        flex-direction: row;
        align-items: center;
        gap: 0.5rem;
        width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        padding-bottom: 0.25rem;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
      }

      .nav-section-title {
        flex: 0 0 auto;
        margin: 0 0.125rem 0 0;
        padding: 0.55rem 0.15rem;
      }

      .nav-link {
        flex: 0 0 auto;
        white-space: nowrap;
      }

      .hf-io-row {
        margin: 0;
        max-width: min(100%, 26rem);
      }

      .sidebar-footer {
        margin-top: 0;
        font-size: 0.7rem;
      }

      .main {
        padding: max(0.875rem, env(safe-area-inset-top)) max(0.875rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(0.875rem, env(safe-area-inset-left));
      }

      .header-actions {
        width: 100%;
        justify-content: flex-start;
      }

      .allocation-carousel {
        grid-template-columns: 1fr;
      }

      .allocation-nav-btn {
        width: 100%;
      }
    }

    @media (max-width: 820px) {
      .main-header,
      .card-title-row,
      .helper-row,
      .progress-head,
      .progress-meta {
        align-items: flex-start;
      }

      .header-actions,
      .hf-io-row {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .btn-save-main,
      .btn-delete-main,
      .hf-io-btn {
        width: 100%;
      }

      .planning-income-grid,
      .input-grid,
      .subentry-form-grid,
      .subentry-summary-box {
        grid-template-columns: 1fr;
      }

      .allocation-layout {
        min-height: 24rem;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
      }

      .pie-chart-wrap {
        justify-content: flex-start;
      }

      .pie-chart-shell {
        min-width: 42rem;
      }

      .subentry-modal-card {
        padding: 0.875rem;
      }
    }

    @media (max-width: 640px) {
      .header-actions,
      .hf-io-row {
        grid-template-columns: 1fr;
      }

      .pill,
      .tag {
        white-space: normal;
      }

      .table-wrap table {
        min-width: 38rem;
      }

      #planningComparisonDataTable {
        min-width: 56rem;
      }

      .pie-chart-shell {
        min-width: 38rem;
      }
    }



    /* === Premium sidebar hamburger toggle === */
    :root {
      --sidebar-collapsed-width: clamp(4.75rem, 5.6vw, 5.35rem);
      --hamburger-size: clamp(2.55rem, 2.4vw, 2.85rem);
    }

    .sidebar {
      transition:
        width 0.24s ease,
        flex-basis 0.24s ease,
        padding 0.24s ease,
        box-shadow 0.24s ease,
        border-color 0.24s ease;
      will-change: width, flex-basis;
    }

    .brand {
      width: 100%;
      justify-content: space-between;
      gap: 0.75rem;
    }

    .brand-copy {
      flex: 1 1 auto;
      min-width: 0;
    }

    .sidebar-toggle-btn {
      flex: 0 0 auto;
      width: var(--hamburger-size);
      height: var(--hamburger-size);
      margin-left: auto;
      border: 1px solid rgba(255,255,255,0.22);
      border-radius: 16px;
      background:
        radial-gradient(circle at 28% 18%, rgba(255,255,255,0.36), rgba(255,255,255,0) 34%),
        linear-gradient(135deg, #00C6FF 0%, #0072FF 48%, #4C6FFF 100%);
      color: #ffffff;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;
      isolation: isolate;
      overflow: hidden;
      box-shadow:
        0 14px 28px rgba(0,114,255,0.34),
        inset 0 1px 0 rgba(255,255,255,0.34),
        inset 0 -10px 22px rgba(6,20,66,0.18);
      -webkit-tap-highlight-color: rgba(76,111,255,0.18);
      transition:
        transform 0.16s ease,
        box-shadow 0.16s ease,
        filter 0.16s ease,
        border-color 0.16s ease;
    }

    .sidebar-toggle-btn::before {
      content: "";
      position: absolute;
      inset: -38% -88%;
      background: linear-gradient(115deg, transparent 34%, rgba(255,255,255,0.42) 48%, transparent 62%);
      transform: translateX(-44%) rotate(8deg);
      opacity: 0.72;
      transition: transform 0.42s ease;
      z-index: -1;
    }

    .sidebar-toggle-btn::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      border: 1px solid rgba(255,255,255,0.18);
      pointer-events: none;
    }

    .sidebar-toggle-btn:hover {
      transform: translateY(-2px);
      border-color: rgba(255,255,255,0.34);
      filter: saturate(1.08) brightness(1.05);
      box-shadow:
        0 18px 34px rgba(0,114,255,0.42),
        0 0 0 5px rgba(76,111,255,0.10),
        inset 0 1px 0 rgba(255,255,255,0.38),
        inset 0 -10px 22px rgba(6,20,66,0.18);
    }

    .sidebar-toggle-btn:hover::before {
      transform: translateX(52%) rotate(8deg);
    }

    .sidebar-toggle-btn:active {
      transform: translateY(0) scale(0.98);
    }

    .sidebar-toggle-btn:focus-visible {
      outline: 3px solid rgba(0,198,255,0.36);
      outline-offset: 3px;
    }

    .sidebar-toggle-lines {
      width: 1.08rem;
      height: 0.86rem;
      display: inline-flex;
      flex-direction: column;
      justify-content: space-between;
      align-items: stretch;
      pointer-events: none;
    }

    .sidebar-toggle-lines span {
      display: block;
      height: 2px;
      border-radius: 999px;
      background: currentColor;
      box-shadow: 0 0 10px rgba(255,255,255,0.52);
      transform-origin: center;
      transition: transform 0.22s ease, opacity 0.18s ease, width 0.18s ease;
    }

    .sidebar-toggle-lines span:nth-child(2) {
      width: 82%;
      align-self: flex-end;
    }

    body.sidebar-collapsed .sidebar-toggle-lines span:nth-child(2) {
      width: 100%;
      align-self: stretch;
    }

    @media (min-width: 1025px) {
      body.sidebar-collapsed .sidebar {
        flex-basis: var(--sidebar-collapsed-width);
        width: var(--sidebar-collapsed-width);
        padding-inline: clamp(0.68rem, 0.85vw, 0.82rem);
        align-items: center;
        box-shadow: 12px 0 28px rgba(3,7,24,0.22);
      }

      body.sidebar-collapsed .brand {
        justify-content: center;
        gap: 0;
      }

      body.sidebar-collapsed .brand-copy,
      body.sidebar-collapsed .nav-section-title,
      body.sidebar-collapsed .nav-link span:not(.nav-dot),
      body.sidebar-collapsed .hf-io-btn span,
      body.sidebar-collapsed .sidebar-footer {
        width: 0;
        max-width: 0;
        opacity: 0;
        overflow: hidden;
        pointer-events: none;
        white-space: nowrap;
      }

      body.sidebar-collapsed .sidebar-toggle-btn {
        margin-inline: auto;
      }

      body.sidebar-collapsed .nav,
      body.sidebar-collapsed .nav > div,
      body.sidebar-collapsed .hf-io-row {
        width: 100%;
      }

      body.sidebar-collapsed .nav > div {
        align-items: center;
      }

      body.sidebar-collapsed .nav-link {
        width: 2.75rem;
        height: 2.75rem;
        padding: 0;
        justify-content: center;
        border-radius: 16px;
      }

      body.sidebar-collapsed .nav-dot {
        width: 0.58rem;
        height: 0.58rem;
      }

      body.sidebar-collapsed .hf-io-row {
        flex-direction: column;
        gap: 0.55rem;
        margin-top: 0;
      }

      body.sidebar-collapsed .hf-io-btn {
        width: 100%;
        min-width: 0;
        padding-inline: 0;
        border-radius: 16px;
      }

      body.sidebar-collapsed .hf-io-btn svg {
        width: 1.05rem;
        height: 1.05rem;
      }
    }

    @media (max-width: 1024px) {
      .sidebar-toggle-btn {
        border-radius: 15px;
      }

      body.sidebar-collapsed .sidebar {
        gap: 0;
        padding-bottom: 0.875rem;
      }

      body.sidebar-collapsed .nav,
      body.sidebar-collapsed .hf-io-row,
      body.sidebar-collapsed .sidebar-footer {
        display: none;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      *,
      *::before,
      *::after {
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
      }
    }

/* === PWA shell, iOS/macOS/Android/Windows hardening === */
:root {
  color-scheme: light;
  --pwa-bg: #05152f;
  --pwa-glow-a: rgba(0, 198, 255, 0.42);
  --pwa-glow-b: rgba(76, 111, 255, 0.30);
}

html,
body {
  overscroll-behavior: none;
  overscroll-behavior-y: none;
  -webkit-overflow-scrolling: touch;
  background-color: var(--pwa-bg);
}

html {
  min-height: 100%;
}

body {
  min-height: 100vh;
  min-height: 100svh;
  min-height: 100dvh;
  padding-top: env(safe-area-inset-top);
  padding-right: env(safe-area-inset-right);
  padding-bottom: env(safe-area-inset-bottom);
  padding-left: env(safe-area-inset-left);
}

img,
svg,
canvas,
video {
  max-width: 100%;
  height: auto;
}

.app-loader {
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  min-height: 100dvh;
  padding:
    max(24px, env(safe-area-inset-top))
    max(24px, env(safe-area-inset-right))
    max(24px, env(safe-area-inset-bottom))
    max(24px, env(safe-area-inset-left));
  background: #05152f;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 620ms ease, visibility 620ms ease;
}

.app-loader__logo {
  width: min(48vw, 230px);
  aspect-ratio: 1 / 1;
  object-fit: contain;
  display: block;
  transform: translateZ(0) scale(1);
  transform-origin: center center;
  animation: helpcoreLogoHeartbeat 3s ease-in-out infinite;
  will-change: transform, opacity;
  box-shadow: none;
  filter: none;
  border: 0;
  background: transparent;
}

body.app-ready .app-loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.noscript-warning {
  position: fixed;
  inset: auto 16px 16px 16px;
  z-index: 2147483001;
  padding: 14px 16px;
  border-radius: 16px;
  background: #ffffff;
  color: #141824;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.32);
  font: 700 14px/1.4 -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-align: center;
}

@keyframes helpcoreLogoHeartbeat {
  0% { transform: translateZ(0) scale(1); opacity: 0.94; }
  18% { transform: translateZ(0) scale(1.055); opacity: 1; }
  32% { transform: translateZ(0) scale(1); opacity: 0.96; }
  46% { transform: translateZ(0) scale(1.035); opacity: 1; }
  64%, 100% { transform: translateZ(0) scale(1); opacity: 0.94; }
}



@media (prefers-reduced-motion: reduce) {
  .app-loader__logo {
    animation: none !important;
  }
}

/* === Dashboard Asset Allocation: force light card in dark mode for readable pie-chart labels === */


/* Smartphone-only readability boost for both Asset Allocation pie charts. */
@media (max-width: 640px) {
  #page-dashboard > .card .allocation-label {
    font-size: 0.98rem;
    font-weight: 800;
  }

  #page-dashboard > .card .allocation-label.small,
  #page-dashboard > .card .allocation-label.detail {
    font-size: 0.86rem;
    font-weight: 700;
  }

  #page-dashboard > .card .allocation-label.inside {
    font-size: 1.12rem;
    font-weight: 900;
  }
}

/* Smartphone-only: place Save/Delete controls above the page title and keep them side by side. */
@media (max-width: 640px) {
  header.main-header {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  header.main-header .header-actions {
    order: 1;
    flex: none;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
    justify-content: stretch;
  }

  header.main-header .title-block {
    order: 2;
    flex: 0 1 auto;
    width: 100%;
  }

  header.main-header .btn-save-main,
  header.main-header .btn-delete-main {
    width: 100%;
    min-width: 0;
    justify-content: center;
    gap: 0.25rem;
    padding-inline: 0.45rem;
    font-size: clamp(0.64rem, 2.35vw, 0.72rem);
    letter-spacing: 0.045em;
  }

  header.main-header .btn-save-main-icon,
  header.main-header .btn-delete-main-icon {
    font-size: 0.9rem;
  }
}

/* === HelpBudgetAllocation - smartphone Android/iOS sidebar, menu, hamburger and scroll parity with HelpRate AI === */
:root {
  color-scheme: light;
}

.sidebar .sidebar-toggle-btn,
.sidebar .sidebar-toggle-btn:hover,
.sidebar .sidebar-toggle-btn:active {
  border: none !important;
}

.sidebar .sidebar-toggle-btn::after {
  border: none !important;
}

.sidebar .sidebar-toggle-btn:focus,
.sidebar .sidebar-toggle-btn:focus-visible {
  outline: none !important;
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    overscroll-behavior: none !important;
    -webkit-text-size-adjust: 100% !important;
    -webkit-tap-highlight-color: transparent !important;
  }

  body {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100svh !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
    touch-action: manipulation !important;
  }

  .sidebar {
    position: relative !important;
    top: auto !important;
    z-index: 1000 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: min(76svh, 640px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
    padding: max(12px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 14px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22) !important;
    display: flex !important;
    flex: 0 0 auto !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    transform: none !important;
  }

  .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    min-width: 0 !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
  }

  .sidebar .brand-name {
    font-size: clamp(1rem, 4.2vw, 1.16rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.028em !important;
    margin: 0 !important;
    text-align: left !important;
  }

  .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    border: none !important;
    border-radius: 15px !important;
    pointer-events: auto !important;
    -webkit-tap-highlight-color: rgba(76,111,255,0.18) !important;
  }

  .nav {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin-top: 8px !important;
    padding-top: 0 !important;
    border-top: 0 !important;
    overflow: visible !important;
  }

  .nav > div {
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .nav-section-title,
  .nav-dot {
    display: none !important;
  }

  .nav-link {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
    font-size: 0.94rem !important;
    font-weight: 600 !important;
    line-height: 1.22 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    text-align: left !important;
    -webkit-user-select: none !important;
    user-select: none !important;
  }

  .nav-link span,
  .hf-io-btn span {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    opacity: 1 !important;
    overflow: visible !important;
  }

  .hf-io-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 2px 0 0 0 !important;
    max-width: 100% !important;
  }

  .hf-io-btn {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
    font-size: 0.86rem !important;
    font-weight: 600 !important;
  }

  .hf-io-btn svg {
    width: 14px !important;
    height: 14px !important;
    flex: 0 0 auto !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: auto !important;
    bottom: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) 0 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    pointer-events: none !important;
  }

  body.sidebar-collapsed .sidebar .brand {
    width: auto !important;
    min-height: 0 !important;
    justify-content: flex-end !important;
    pointer-events: none !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    pointer-events: auto !important;
    margin: 0 !important;
    box-shadow: 0 10px 24px rgba(0, 114, 255, 0.38), inset 0 1px 0 rgba(255,255,255,0.34) !important;
  }

  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  .main {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 14px max(14px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left)) !important;
  }

  body.sidebar-collapsed .main {
    height: 100svh !important;
    padding-top: max(70px, calc(env(safe-area-inset-top) + 62px)) !important;
  }

  .main-header,
  header.main-header {
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    margin-bottom: 18px !important;
  }

  .main-header .title-block,
  header.main-header .title-block,
  .title-block {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    flex: 0 1 auto !important;
  }

  .title-block h1 {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 0 7px 0 !important;
    font-size: clamp(1.12rem, 5.2vw, 1.42rem) !important;
    line-height: 1.18 !important;
    letter-spacing: -0.025em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: auto !important;
    text-wrap: pretty;
  }

  .title-block p {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    font-size: clamp(0.88rem, 3.8vw, 1rem) !important;
    line-height: 1.42 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
  }

  .header-actions {
    width: 100% !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    align-items: stretch !important;
    justify-content: stretch !important;
  }

  .header-actions .btn-primary,
  .btn-save-main,
  .btn-delete-main {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 42px !important;
    padding: 10px 8px !important;
    font-size: 0.72rem !important;
    line-height: 1.15 !important;
    white-space: normal !important;
  }

  .planning-grid,
  .category-top-grid,
  .content-grid,
  .dashboard-grid-top,
  .input-grid,
  .planning-income-grid,
  .subentry-form-grid,
  .subentry-summary-box {
    width: 100% !important;
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .card,
  .page,
  .allocation-carousel,
  .allocation-layout,
  table {
    max-width: 100% !important;
  }

  .table-wrap,
  .allocation-layout {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-x: contain !important;
  }

  input,
  textarea,
  select,
  button {
    font-size: max(1rem, 16px) !important;
  }
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body {
    min-height: 100vh !important;
    min-height: 100svh !important;
    min-height: -webkit-fill-available !important;
  }

  body {
    min-height: 100svh !important;
  }

  .sidebar,
  .main {
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
  }
}

/* Smartphone Android/iOS landscape: keep the same visible collapsed top bar behavior as HelpRate AI. */
@media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    -webkit-text-size-adjust: 100% !important;
  }

  body {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100svh !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    touch-action: manipulation !important;
  }

  .sidebar {
    position: relative !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    flex: 0 0 auto !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: min(76svh, 640px) !important;
    margin: 0 !important;
    padding: max(12px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 14px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    pointer-events: auto !important;
  }

  .nav,
  .nav > div {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin-top: 8px !important;
    padding-top: 0 !important;
    border-top: 0 !important;
  }

  .hf-io-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 2px 0 0 0 !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: none !important;
    overflow: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  .main,
  body.sidebar-collapsed .main {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 100svh !important;
    height: 100svh !important;
    max-height: none !important;
    margin: 0 !important;
    margin-left: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .main {
    padding-top: max(14px, env(safe-area-inset-top)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
  }

  body.sidebar-collapsed .main {
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
  }
}

@media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  body.sidebar-collapsed .main {
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
  }
}

/* === HelpBudgetAllocation - requested universal Android/iOS header/title parity patch v2 === */
@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  /* Portrait + generic smartphone Android/iOS: keep the same always-visible sidebar title row as HelpRate AI. */
  .sidebar .brand,
  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name,
  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-name,
  body.sidebar-collapsed .brand-name {
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    color: #ffffff !important;
    margin: 0 !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: none !important;
    overflow: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  body.sidebar-collapsed .main {
    height: 100svh !important;
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
  }

  /* Smartphone Android/iOS page header order: title + description first, Save/Delete row directly underneath on every page. */
  header.main-header,
  .main-header {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 12px !important;
  }

  header.main-header .title-block,
  .main-header .title-block,
  .title-block {
    order: 1 !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    flex: 0 1 auto !important;
  }

  header.main-header .header-actions,
  .main-header .header-actions,
  .header-actions {
    order: 2 !important;
    width: 100% !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    margin: 0 !important;
  }

  .title-block h1 {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 0 7px 0 !important;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: clamp(1.12rem, 5.2vw, 1.42rem) !important;
    font-weight: 700 !important;
    line-height: 1.18 !important;
    letter-spacing: -0.025em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: auto !important;
    text-wrap: pretty;
  }

  .title-block p {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: clamp(0.88rem, 3.8vw, 1rem) !important;
    font-weight: 400 !important;
    line-height: 1.42 !important;
    color: var(--color-text-soft) !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
  }
}

@media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  .sidebar .brand,
  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name,
  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }
}


/* === HelpBudgetAllocation 1 - final requested title/font parity patch v1.0.2 === */
/* Desktop/Tablet/Smartphone Android/iOS page header typography aligned to HelpRate AI. */
.main-header .title-block,
header.main-header .title-block,
.title-block {
  flex: 1 1 auto;
  min-width: 0;
}

.title-block h1 {
  font-family: system-ui, -apple-system, sans-serif !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  line-height: normal !important;
  letter-spacing: normal !important;
  margin: 0 0 4px 0 !important;
}

.title-block h1.dashboard-hero-title {
  font-size: 1.38rem !important;
  font-weight: 800 !important;
}

.title-block p {
  font-family: system-ui, -apple-system, sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 400 !important;
  line-height: normal !important;
  letter-spacing: normal !important;
  color: var(--color-text-soft) !important;
  margin: 0 !important;
}

.mobile-sidebar-title {
  display: none;
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  /* Independent mobile title: remains visible even when older collapsed-sidebar rules hide .brand-copy. */
  .sidebar .brand,
  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-copy,
  body.sidebar-collapsed .brand-copy {
    display: none !important;
    visibility: hidden !important;
  }

  .sidebar .mobile-sidebar-title,
  body.sidebar-collapsed .sidebar .mobile-sidebar-title {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex: 1 1 auto !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    font-family: system-ui, -apple-system, sans-serif !important;
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    color: #ffffff !important;
    text-align: left !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: none !important;
    overflow: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  body.sidebar-collapsed .main {
    height: 100svh !important;
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
  }

  .title-block h1,
  .title-block h1.dashboard-hero-title {
    font-family: system-ui, -apple-system, sans-serif !important;
    font-size: clamp(1.12rem, 5.2vw, 1.42rem) !important;
    font-weight: 700 !important;
    line-height: 1.18 !important;
    letter-spacing: -0.025em !important;
    margin: 0 0 7px 0 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: auto !important;
    text-wrap: pretty;
  }

  .title-block p {
    font-family: system-ui, -apple-system, sans-serif !important;
    font-size: clamp(0.88rem, 3.8vw, 1rem) !important;
    font-weight: 400 !important;
    line-height: 1.42 !important;
    letter-spacing: normal !important;
    margin: 0 !important;
    color: var(--color-text-soft) !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
  }
}

/* Requested update: keep the Dashboard page title explicitly bold on PC/Desktop, Tablet, Smartphone, Android and iOS. */
#pageTitle.dashboard-hero-title {
  font-weight: 800 !important;
}


/* === HelpBudgetAllocation - Tablet Android/iOS sidebar menu visual parity with smartphone Android/iOS === */
@media (min-width: 769px) and (max-width: 1366px) and (hover: none) and (pointer: coarse) {
  .sidebar .brand,
  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    min-width: 0 !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-name {
    font-size: clamp(1rem, 2.2vw, 1.16rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.028em !important;
    margin: 0 !important;
    text-align: left !important;
  }

  .sidebar .brand-copy,
  body.sidebar-collapsed .brand-copy {
    display: none !important;
    visibility: hidden !important;
  }

  .sidebar .mobile-sidebar-title,
  body.sidebar-collapsed .sidebar .mobile-sidebar-title {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex: 1 1 auto !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    font-family: system-ui, -apple-system, sans-serif !important;
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    color: #ffffff !important;
    text-align: left !important;
    pointer-events: auto !important;
  }

  .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    border: none !important;
    border-radius: 15px !important;
    pointer-events: auto !important;
    -webkit-tap-highlight-color: rgba(76,111,255,0.18) !important;
  }

  .nav {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin-top: 8px !important;
    padding-top: 0 !important;
    border-top: 0 !important;
    overflow: visible !important;
  }

  .nav > div {
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .nav-section-title,
  .nav-dot {
    display: none !important;
  }

  .nav-link {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
    font-size: 0.94rem !important;
    font-weight: 600 !important;
    line-height: 1.22 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    text-align: left !important;
    -webkit-user-select: none !important;
    user-select: none !important;
  }

  .nav-link span,
  .hf-io-btn span {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    opacity: 1 !important;
    overflow: visible !important;
  }

  .hf-io-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 2px 0 0 0 !important;
    max-width: 100% !important;
  }

  .hf-io-btn {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
    font-size: 0.86rem !important;
    font-weight: 600 !important;
  }

  .hf-io-btn svg {
    width: 14px !important;
    height: 14px !important;
    flex: 0 0 auto !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: none !important;
    overflow: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  body.sidebar-collapsed .main {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    height: 100svh !important;
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
  }
}


/* === Universal Android/iOS parity patch - 20260609-universal-android-ios-v3 ===
   Unifica sidebar, menu hamburger, header, pagine, contenitori e controlli touch
   su Android, iOS, tablet touch e desktop responsive senza rami per sistema operativo. */
:root {
  --pwa-universal-version: "20260609-universal-android-ios-v3";
}

html,
body {
  width: 100%;
  min-height: 100vh;
  min-height: 100svh;
  overscroll-behavior: none;
}

/* === Universal double-tap lock guard - 20260609-universal-android-ios-v3 ===
   Same touch behavior on Android, iOS and desktop responsive: no double-tap zoom,
   no synthetic double-click layout lock, no OS-specific branches. */
html,
body,
.hba-doubletap-guard,
.hba-doubletap-guard body,
.sidebar,
.main,
.main-header,
.page,
.card,
.nav,
.nav-link,
.hf-io-row,
.hf-io-btn,
.sidebar-toggle-btn,
.btn-primary,
.btn-inline,
.btn-folder,
.allocation-nav-btn,
button,
a,
[role="button"] {
  touch-action: manipulation !important;
  -ms-touch-action: manipulation !important;
  -webkit-tap-highlight-color: transparent !important;
}

.nav-link,
.hf-io-btn,
.sidebar-toggle-btn,
.btn-primary,
.btn-inline,
.btn-folder,
.allocation-nav-btn,
button,
a,
[role="button"] {
  -webkit-user-select: none;
  user-select: none;
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body,
  .sidebar,
  .main,
  .main-header,
  .page,
  .card,
  .nav,
  .nav-link,
  .hf-io-row,
  .hf-io-btn,
  .sidebar-toggle-btn,
  .btn-primary,
  .btn-inline,
  .btn-folder,
  .allocation-nav-btn,
  button,
  a,
  [role="button"] {
    touch-action: manipulation !important;
    -ms-touch-action: manipulation !important;
    -webkit-tap-highlight-color: transparent !important;
  }
}

button,
.nav-link,
.hf-io-btn,
input,
select,
textarea {
  touch-action: manipulation;
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  body {
    width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
  }

  .sidebar,
  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    z-index: 1000 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,0.10) !important;
    background: rgba(5,7,15,0.98) !important;
    box-shadow: none !important;
    transform: none !important;
  }

  .sidebar .brand,
  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    border: 0 !important;
    outline: 0 !important;
    box-shadow: none !important;
  }

  .sidebar .brand-copy,
  body.sidebar-collapsed .brand-copy {
    display: none !important;
    visibility: hidden !important;
  }

  .sidebar .mobile-sidebar-title,
  body.sidebar-collapsed .sidebar .mobile-sidebar-title {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex: 1 1 auto !important;
    max-width: calc(100vw - 92px) !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    line-height: 1.05 !important;
    color: #ffffff !important;
    text-align: left !important;
  }

  .sidebar-toggle-btn,
  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    min-height: 46px !important;
    flex: 0 0 46px !important;
    margin-left: auto !important;
    border: 0 !important;
    border-radius: 15px !important;
    pointer-events: auto !important;
  }

  .main,
  body.sidebar-collapsed .main {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  .nav,
  .nav > div {
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
  }

  .nav-section-title,
  .nav-dot {
    display: none !important;
  }

  .nav-link {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
    font-size: 0.94rem !important;
    font-weight: 600 !important;
    line-height: 1.22 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    text-align: left !important;
    user-select: none !important;
    -webkit-user-select: none !important;
  }

  .hf-io-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 2px 0 0 0 !important;
    max-width: 100% !important;
  }

  .hf-io-btn {
    width: 100% !important;
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
    font-size: 0.86rem !important;
    font-weight: 600 !important;
  }

  .main-header {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
  }

  .title-block {
    order: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .header-actions {
    order: 2 !important;
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }

  .title-block h1,
  .title-block h1.dashboard-hero-title {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: clamp(1.12rem, 5.2vw, 1.42rem) !important;
    font-weight: 800 !important;
    line-height: 1.18 !important;
    letter-spacing: -0.025em !important;
    margin: 0 0 7px 0 !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    hyphens: auto !important;
    text-wrap: pretty;
  }

  .title-block p {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: clamp(0.88rem, 3.8vw, 1rem) !important;
    font-weight: 400 !important;
    line-height: 1.42 !important;
    margin: 0 !important;
    color: var(--color-text-soft) !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
  }

  .page,
  .card,
  .planning-grid,
  .category-grid,
  .allocation-carousel,
  .allocation-layout,
  .table-wrap,
  table {
    max-width: 100% !important;
    min-width: 0 !important;
  }
}

@media (min-width: 769px) and (max-width: 1366px) and (hover: none) and (pointer: coarse) {
  .sidebar .mobile-sidebar-title,
  body.sidebar-collapsed .sidebar .mobile-sidebar-title {
    display: block !important;
    visibility: visible !important;
  }

  .sidebar .brand-copy,
  body.sidebar-collapsed .brand-copy {
    display: none !important;
    visibility: hidden !important;
  }
}

/* Final universal touch override: Android and iOS use the same tap model. */
html,
body,
.sidebar,
.main,
.main-header,
.page,
.card,
.nav,
.nav-link,
.hf-io-row,
.hf-io-btn,
.sidebar-toggle-btn,
.btn-primary,
.btn-inline,
.btn-folder,
.allocation-nav-btn,
button,
a,
[role="button"] {
  touch-action: manipulation !important;
  -ms-touch-action: manipulation !important;
  -webkit-tap-highlight-color: transparent !important;
}
