
    :root{
      color-scheme:dark;
      --bg:#070b14;--bg2:#0d1322;--panel:#11192c;--panel2:#151f36;
      --text:#f6f8ff;--muted:#95a0b8;--line:rgba(255,255,255,.09);
      --accent:#6c7cff;--accent2:#8b5cf6;--green:#3ddc97;--yellow:#f4c95d;--red:#ff6b7a;
      --shadow:0 24px 70px rgba(0,0,0,.35);--r:20px
    }
    *{box-sizing:border-box}
    html{background:var(--bg)}
    body{margin:0;min-height:100vh;background:
      radial-gradient(circle at 82% -10%,rgba(108,124,255,.17),transparent 35%),
      radial-gradient(circle at 10% 110%,rgba(139,92,246,.11),transparent 32%),
      var(--bg);color:var(--text);font:15px/1.5 Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif}
    button,input,select,textarea{font:inherit}
    button{cursor:pointer}
    h1,h2,h3,p{margin-top:0}
    h1{font-size:clamp(26px,4vw,38px);margin-bottom:4px}
    h2{font-size:19px}
    .hidden{display:none!important}.muted{color:var(--muted)}
    .glass{background:linear-gradient(180deg,rgba(21,31,54,.94),rgba(14,21,38,.94));border:1px solid var(--line);box-shadow:var(--shadow)}
    .btn{border:0;border-radius:12px;padding:11px 15px;color:white}
    .btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));font-weight:800}
    .btn.secondary{background:rgba(255,255,255,.06);border:1px solid var(--line)}
    .btn.ghost{background:transparent;color:#c4cbff}
    .btn.danger{background:rgba(255,107,122,.12);border:1px solid rgba(255,107,122,.3);color:#ffd4da}
    .btn.full{width:100%}
    .iconbtn{width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:white;position:relative}
    input,select,textarea{width:100%;border:1px solid var(--line);background:#0a1120;color:white;border-radius:12px;padding:12px;outline:none}
    input:focus,select:focus,textarea:focus{border-color:rgba(108,124,255,.7);box-shadow:0 0 0 3px rgba(108,124,255,.12)}
    label{display:grid;gap:7px;color:#dce1ef;margin:14px 0;font-size:13px}
    .auth{min-height:100vh;display:grid;place-items:center;padding:20px}
    .auth-card{width:min(430px,100%);padding:28px;border-radius:28px}
    .brand{display:flex;gap:12px;align-items:center}.brand-mark{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent2));font-weight:900;font-size:20px;box-shadow:0 12px 30px rgba(108,124,255,.35)}
    .brand strong{display:block}.brand small{display:block;color:var(--muted)}
    .auth .brand{margin-bottom:30px}
    .demo-code{padding:12px;border-radius:12px;background:rgba(108,124,255,.12);border:1px solid rgba(108,124,255,.3);margin:14px 0}
    .app{min-height:100vh}
    .sidebar{position:fixed;inset:0 auto 0 0;width:248px;padding:20px 15px;background:rgba(7,11,20,.94);border-right:1px solid var(--line);backdrop-filter:blur(18px);display:flex;flex-direction:column;z-index:20}
    .sidebar .brand{padding:4px 8px 24px}
    .nav{display:grid;gap:6px}.nav button{border:0;background:transparent;color:var(--muted);padding:11px 12px;border-radius:12px;text-align:left;display:flex;gap:12px;align-items:center}
    .nav button.active,.nav button:hover{color:white;background:linear-gradient(90deg,rgba(108,124,255,.2),rgba(139,92,246,.06))}
    .side-foot{margin-top:auto;padding:8px;color:var(--muted);font-size:12px}
    .sync{margin-bottom:8px}.sync i{display:inline-block;width:8px;height:8px;background:var(--green);border-radius:50%;margin-right:7px}
    .main{margin-left:248px;padding:24px clamp(16px,3vw,40px) 90px}
    .topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px}
    .top-actions{display:flex;gap:10px}
    .badge{position:absolute;right:-5px;top:-5px;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;background:var(--red);font-size:11px;font-weight:900}
    .view{display:none}.view.active{display:block;animation:fade .2s ease}@keyframes fade{from{opacity:.45;transform:translateY(4px)}to{opacity:1;transform:none}}
    .alert{display:none;padding:12px 14px;border-radius:14px;margin-bottom:16px}.alert.show{display:block}.alert.red{background:rgba(255,107,122,.1);border:1px solid rgba(255,107,122,.35)}.alert.yellow{background:rgba(244,201,93,.1);border:1px solid rgba(244,201,93,.3)}
    .grid4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
    .grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
    .grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:18px}
    .card{padding:18px;border-radius:var(--r)}
    .metric{min-height:130px}.label{color:var(--muted);font-size:13px}.value{font-size:28px;font-weight:900;letter-spacing:-.03em;margin:8px 0}.value.small{font-size:20px}.danger-text{color:#ff9da8}.foot{font-size:12px;color:var(--muted)}
    .progress{height:7px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden;margin:10px 0}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px}
    .head{display:flex;justify-content:space-between;align-items:center;gap:10px}
    .chip{padding:5px 8px;border-radius:999px;background:rgba(108,124,255,.13);border:1px solid rgba(108,124,255,.25);color:#ccd1ff;font-size:11px}
    .stack{display:grid;gap:10px}.status-card{display:flex;gap:10px;padding:12px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035)}.dot{width:10px;height:10px;border-radius:50%;margin-top:6px;flex:0 0 auto}.dot.red{background:var(--red)}.dot.yellow{background:var(--yellow)}.dot.green{background:var(--green)}.status-card strong{display:block}.status-card span{display:block;color:var(--muted);font-size:12px}
    .row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid var(--line)}.row:last-child{border-bottom:0}.row small{display:block;color:var(--muted)}
    .money{font-weight:800;font-variant-numeric:tabular-nums}.money.neg{color:#ff9da8}.money.pos{color:#7ae7b6}
    .toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px}.toolbar-actions{display:flex;gap:8px;flex-wrap:wrap}
    .table .row{padding:13px 0}.tx-actions{display:flex;gap:6px}.mini{border:0;border-radius:8px;padding:6px 8px;background:rgba(255,255,255,.06);color:var(--muted)}
    .debt-card,.payment-card{padding:20px;border-radius:var(--r);background:linear-gradient(180deg,rgba(21,31,54,.94),rgba(14,21,38,.94));border:1px solid var(--line);box-shadow:var(--shadow)}
    .status{padding:5px 8px;border-radius:999px;font-size:11px;white-space:nowrap}.status.ok{background:rgba(61,220,151,.12);color:#91efc9}.status.warn{background:rgba(244,201,93,.12);color:#ffe18e}
    .meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.meta div{padding:10px;border-radius:12px;background:rgba(255,255,255,.035)}.meta small{display:block;color:var(--muted)}
    .bar-list{display:grid;gap:12px}.bar-top{display:flex;justify-content:space-between;gap:10px}.bar{height:8px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden}.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px}
    .setting{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line)}.setting:last-child{border-bottom:0}.setting span{display:block;color:var(--muted);font-size:12px}
    dialog{width:min(640px,calc(100% - 24px));padding:20px;border-radius:24px;border:1px solid var(--line);background:#10182b;color:white;box-shadow:0 30px 100px rgba(0,0,0,.55)}dialog::backdrop{background:rgba(0,0,0,.66);backdrop-filter:blur(6px)}
    .modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.segments{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;background:#0a1120;padding:4px;border-radius:13px;margin:15px 0}.segments button{border:0;background:transparent;color:var(--muted);padding:9px;border-radius:10px}.segments button.active{background:rgba(108,124,255,.2);color:white}.two-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}
    .toast{position:fixed;right:18px;bottom:18px;z-index:1000;padding:12px 15px;border-radius:13px;background:#18223b;border:1px solid var(--line);box-shadow:var(--shadow);opacity:0;transform:translateY(8px);transition:.2s;pointer-events:none}.toast.show{opacity:1;transform:none}
    .bottom{display:none}
    @media(max-width:1050px){.grid4{grid-template-columns:repeat(2,1fr)}}
    @media(max-width:760px){
      .sidebar{display:none}.main{margin-left:0;padding:18px 14px 100px}.topbar{align-items:flex-start}.top-actions .primary{display:none}.grid4,.grid3,.grid2{grid-template-columns:1fr}.metric{min-height:auto}.two-fields{grid-template-columns:1fr;gap:0}.toolbar{align-items:flex-start}
      .bottom{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:10px;right:10px;bottom:10px;z-index:30;padding:8px;border-radius:20px;background:rgba(10,15,28,.95);border:1px solid var(--line);backdrop-filter:blur(18px)}
      .bottom button{border:0;background:transparent;color:var(--muted);display:grid;place-items:center;gap:1px}.bottom button.active{color:#d4d8ff}.bottom span{font-size:10px}.bottom .add{width:48px;height:48px;border-radius:16px;margin:-18px auto 0;background:linear-gradient(135deg,var(--accent),var(--accent2));color:white;font-size:26px}
    }
  

.auth-switch{display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:5px;background:#0a1120;border-radius:14px;margin:18px 0}
.auth-switch button{border:0;border-radius:10px;padding:10px;background:transparent;color:var(--muted)}
.auth-switch button.active{background:rgba(108,124,255,.2);color:#fff}
.auth-message{display:none;margin:14px 0;padding:12px 14px;border-radius:13px;border:1px solid var(--line)}
.auth-message.show{display:block}
.auth-message.ok{background:rgba(61,220,151,.10);border-color:rgba(61,220,151,.3);color:#baf5da}
.auth-message.error{background:rgba(255,107,122,.10);border-color:rgba(255,107,122,.3);color:#ffd2d8}
.auth-message.info{background:rgba(108,124,255,.10);border-color:rgba(108,124,255,.3);color:#d8dcff}
.loading{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;background:rgba(4,7,13,.72);backdrop-filter:blur(10px)}
.loading-card{padding:22px 26px;border-radius:20px;text-align:center}
.spinner{width:34px;height:34px;margin:0 auto 13px;border:3px solid rgba(255,255,255,.12);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.sync.online i{background:var(--green)}
.sync.offline i{background:var(--red)}
.sync.syncing i{background:var(--yellow)}
.error-panel{padding:16px;border-radius:16px;background:rgba(255,107,122,.1);border:1px solid rgba(255,107,122,.35);margin-bottom:16px}
.auth-links{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:12px}
.small-note{font-size:12px;color:var(--muted)}
.cloud-pill{display:inline-flex;align-items:center;gap:7px;padding:6px 9px;border-radius:999px;background:rgba(61,220,151,.1);border:1px solid rgba(61,220,151,.25);color:#aef1d3;font-size:11px}
.empty{padding:20px;text-align:center;color:var(--muted)}


/* Life OS v2.4 — управление счетами */
.account-card-editable{
  cursor:pointer;
  position:relative;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
}
.account-card-editable:hover{
  transform:translateY(-2px);
  border-color:rgba(108,124,255,.42);
  box-shadow:0 22px 70px rgba(0,0,0,.38),0 0 0 1px rgba(108,124,255,.12);
}
.account-card-editable::after{
  content:"Изменить";
  position:absolute;
  right:14px;
  top:13px;
  color:#c9ceff;
  font-size:11px;
  opacity:.7;
}
.account-options{
  display:grid;
  gap:10px;
  margin:16px 0;
}
.check-row{
  display:flex;
  grid-template-columns:none;
  align-items:flex-start;
  gap:11px;
  margin:0;
  padding:12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(255,255,255,.03);
  cursor:pointer;
}
.check-row input{
  width:18px;
  height:18px;
  margin:2px 0 0;
  accent-color:var(--accent);
  flex:0 0 auto;
}
.check-row span{display:block}
.check-row strong{display:block;color:var(--text)}
.check-row small{display:block;color:var(--muted);margin-top:2px}
.account-modal-actions{align-items:center}
.modal-spacer{flex:1}
.account-archive-panel{margin:0 0 18px}
.archived-account-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid var(--line);
}
.archived-account-row:last-child{border-bottom:0}
.archived-account-row small{display:block;color:var(--muted)}
@media(max-width:760px){
  .main{padding-bottom:145px}
  .view{padding-bottom:26px}
  .account-card-editable::after{right:12px;top:11px}
  .account-modal-actions{flex-wrap:wrap}
  .account-modal-actions .modal-spacer{display:none}
  .account-modal-actions .btn{flex:1}
  .account-modal-actions .danger{flex-basis:100%}
}


/* Life OS v2.5 — управление долгами */
.three-fields{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.debt-summary{margin-bottom:18px}
.debt-card{
  position:relative;
  overflow:hidden;
}
.debt-card.closed{opacity:.74}
.debt-direction{
  display:inline-flex;
  align-items:center;
  padding:5px 8px;
  border-radius:999px;
  font-size:11px;
  color:#cfd4ff;
  background:rgba(108,124,255,.11);
  border:1px solid rgba(108,124,255,.24);
}
.debt-direction.incoming{
  color:#aef1d3;
  background:rgba(61,220,151,.10);
  border-color:rgba(61,220,151,.24);
}
.debt-card-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:16px;
}
.debt-card-actions .btn{flex:1}
.debt-detail-line{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:9px 0;
  border-bottom:1px solid var(--line);
}
.debt-detail-line:last-child{border-bottom:0}
.debt-detail-line span{color:var(--muted)}
.debt-payment-total{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:14px 0;
  padding:14px;
  border-radius:14px;
  background:rgba(108,124,255,.10);
  border:1px solid rgba(108,124,255,.24);
}
.debt-payment-total strong{font-size:20px}
.debt-history-item{
  padding:13px 0;
  border-bottom:1px solid var(--line);
}
.debt-history-item:last-child{border-bottom:0}
.debt-history-main{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.debt-history-item small{display:block;color:var(--muted)}
.debt-history-breakdown{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:12px;
  margin-top:6px;
}
.debt-history-item.deleted{opacity:.55}
textarea{resize:vertical}
@media(max-width:760px){
  .three-fields{grid-template-columns:1fr;gap:0}
  .debt-card-actions .btn{flex-basis:100%}
}


/* Life OS v2.5.1 — исправленная мобильная навигация */
.mobile-menu-dialog{
  width:min(520px,calc(100vw - 24px));
}
.mobile-menu-grid{
  display:grid;
  gap:10px;
}
.mobile-menu-item{
  width:100%;
  border:1px solid var(--line);
  border-radius:16px;
  padding:15px;
  background:rgba(255,255,255,.035);
  color:var(--text);
  text-align:left;
  cursor:pointer;
}
.mobile-menu-item:active{
  transform:scale(.985);
}
.mobile-menu-item strong{
  display:block;
  font-size:16px;
}
.mobile-menu-item span{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
}
@media(max-width:760px){
  .bottom button[data-view="debts"].active,
  .bottom #mobileMore.active{
    color:#d4d8ff;
  }
}


/* Life OS v2.6 — обязательные платежи */
.payment-card{
  position:relative;
}
.payment-card .value{
  margin-top:14px;
}
.payment-date-line{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:13px 0;
  padding:10px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.payment-date-line span{color:var(--muted)}
.payment-card-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.payment-card-actions .btn{flex:1}
.payment-archive-panel{margin-top:18px}
.inactive-payment-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:13px 0;
  border-bottom:1px solid var(--line);
}
.inactive-payment-row:last-child{border-bottom:0}
.inactive-payment-row small{
  display:block;
  color:var(--muted);
  margin-top:3px;
}
.inactive-payment-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.recurring-payment-actions{align-items:center}
@media(max-width:760px){
  .payment-card-actions .btn{flex-basis:100%}
  .inactive-payment-row{
    align-items:flex-start;
    flex-direction:column;
  }
  .inactive-payment-actions{width:100%}
  .inactive-payment-actions .btn{flex:1}
  .recurring-payment-actions{flex-wrap:wrap}
  .recurring-payment-actions .modal-spacer{display:none}
  .recurring-payment-actions .btn{flex:1}
  .recurring-payment-actions .danger{flex-basis:100%}
}


/* Life OS v2.7 — центр уведомлений */
.notification-settings-card{
  align-self:start;
}
.notification-device-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:14px 0 8px;
}
.notification-settings-form{
  margin-top:14px;
}
.notification-switches{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:12px 0;
}
.notification-settings-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:14px;
}
.notification-center-list{
  display:grid;
  gap:10px;
}
.notification-center-item{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:13px;
  border:1px solid var(--line);
  border-radius:15px;
  background:rgba(255,255,255,.03);
}
.notification-center-item-main{
  display:flex;
  align-items:flex-start;
  gap:10px;
}
.notification-center-item .dot{
  flex:0 0 auto;
  margin-top:5px;
}
.notification-center-item strong{
  display:block;
}
.notification-center-item span{
  display:block;
  color:var(--muted);
  margin-top:3px;
  font-size:12px;
}
.notification-center-critical{
  border-color:rgba(255,92,115,.28);
}
@media(max-width:760px){
  .notification-switches{
    grid-template-columns:1fr;
  }
  .notification-device-actions .btn{
    flex:1;
  }
  .notification-settings-footer{
    align-items:stretch;
    flex-direction:column;
  }
  .notification-center-item{
    flex-direction:column;
  }
  .notification-center-item .btn{
    width:100%;
  }
}


/* Life OS v2.8 — регистрация фонового push */
.background-push-box{
  margin-top:14px;
  padding:14px;
  border:1px solid rgba(108,124,255,.28);
  border-radius:16px;
  background:rgba(108,124,255,.07);
}
.background-push-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
}
.background-push-head strong{
  display:block;
}
.background-push-head span:not(.status){
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
}
.background-push-box .btn{
  width:100%;
}
@media(max-width:760px){
  .background-push-head{
    flex-direction:column;
  }
}


/* Life OS v3.0 — бюджет и прогноз до зарплаты */
.budget-preview-card{
  margin-bottom:18px;
}
.budget-preview-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:14px;
}
.budget-preview-grid div{
  padding:12px;
  border-radius:14px;
  background:rgba(255,255,255,.035);
  border:1px solid var(--line);
}
.budget-preview-grid span{
  display:block;
  color:var(--muted);
  font-size:12px;
}
.budget-preview-grid strong{
  display:block;
  margin-top:4px;
  font-size:17px;
}
.budget-advice,
.budget-recommendation{
  margin-top:14px;
  padding:13px;
  border-radius:14px;
  background:rgba(108,124,255,.09);
  border:1px solid rgba(108,124,255,.24);
}
.budget-advice.warn,
.budget-recommendation.warn{
  background:rgba(244,201,93,.09);
  border-color:rgba(244,201,93,.28);
}
.budget-advice.danger,
.budget-recommendation.danger{
  background:rgba(255,107,122,.09);
  border-color:rgba(255,107,122,.3);
}
.forecast-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding:11px 0;
  border-bottom:1px solid var(--line);
}
.forecast-row:last-child{border-bottom:0}
.forecast-row span{color:var(--muted)}
.forecast-row strong{text-align:right}
.income-expectation-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.income-expectation-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
  padding:14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(255,255,255,.03);
}
.income-expectation-card.cancelled{
  opacity:.58;
}
.income-expectation-main h3{
  margin:0;
  font-size:16px;
}
.income-expectation-main p{
  margin:4px 0 0;
  color:var(--muted);
  font-size:12px;
}
.income-expectation-amount{
  margin-top:7px;
  font-size:18px;
  font-weight:900;
}
.income-expectation-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.income-expectation-actions .btn{
  padding:9px 11px;
}
@media(max-width:900px){
  .budget-preview-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .budget-preview-grid{grid-template-columns:1fr 1fr}
  .income-expectation-card{
    grid-template-columns:1fr;
  }
  .income-expectation-actions{
    justify-content:stretch;
  }
  .income-expectation-actions .btn{
    flex:1;
  }
}


/* Life OS v3.1 — предварительное распределение дохода */
.salary-distribution-card{
  margin-top:18px;
}
.distribution-controls{
  display:grid;
  grid-template-columns:1.25fr .8fr .8fr;
  gap:12px;
  margin-top:14px;
}
.distribution-summary{
  display:grid;
  gap:0;
  margin-top:16px;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
}
.distribution-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
  padding:13px 14px;
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.025);
}
.distribution-row:last-child{
  border-bottom:0;
}
.distribution-row span{
  color:var(--muted);
}
.distribution-row strong{
  text-align:right;
}
.distribution-row.required strong{
  color:var(--warn);
}
.distribution-row.positive strong{
  color:var(--ok);
}
.distribution-row.danger strong{
  color:var(--danger);
}
.distribution-detail{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
}
.distribution-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:14px;
}
.distribution-plan-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.distribution-plan-card{
  padding:14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(255,255,255,.03);
}
.distribution-plan-card.archived{
  opacity:.58;
}
.distribution-plan-card .plan-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  margin-top:12px;
}
.distribution-plan-card .plan-grid div{
  padding:10px;
  border-radius:12px;
  background:rgba(255,255,255,.03);
}
.distribution-plan-card .plan-grid span{
  display:block;
  color:var(--muted);
  font-size:11px;
}
.distribution-plan-card .plan-grid strong{
  display:block;
  margin-top:3px;
}
.distribution-plan-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:12px;
}
@media(max-width:900px){
  .distribution-controls{
    grid-template-columns:1fr;
  }
  .distribution-plan-card .plan-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}


/* Life OS v3.1.1 — пояснение покрытия платежей резервами */
.forecast-detail{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:11px;
  line-height:1.35;
}


/* Ось v3.2 — фирменный знак и ребрендинг */
.brand-mark{
  overflow:hidden;
  padding:0;
  background:#111B3A;
  border:1px solid rgba(139,108,255,.18);
  box-shadow:0 12px 30px rgba(93,168,255,.18);
}
.brand-mark img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}
.brand-version{
  display:inline-flex;
  vertical-align:middle;
  margin-left:6px;
  padding:3px 7px;
  border:1px solid rgba(139,108,255,.28);
  border-radius:999px;
  color:#B9C4FF;
  background:rgba(139,108,255,.10);
  font-size:.62em;
  font-weight:700;
  letter-spacing:.04em;
}
.auth-card .brand strong{font-size:1.08rem}
.auth-card .brand small{margin-top:4px}


/* Ось v3.2.3 — логотип без внешней рамки */
.brand-mark{
  width:46px;
  height:46px;
  flex:0 0 46px;
  overflow:visible;
  padding:0;
  background:transparent;
  border:0;
  box-shadow:none;
  border-radius:14px;
}
.brand-mark img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:14px;
  box-shadow:0 8px 22px rgba(93,168,255,.14);
}
.sidebar .brand-mark{
  width:42px;
  height:42px;
  flex-basis:42px;
  border-radius:13px;
}
.sidebar .brand-mark img{
  border-radius:13px;
  box-shadow:0 7px 18px rgba(93,168,255,.12);
}


/* Ось v3.2.4 — одна цельная иконка без эффекта «рамка в рамке» */
.brand-mark,
.sidebar .brand-mark{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}
.brand-mark img,
.sidebar .brand-mark img{
  box-shadow:none !important;
  object-fit:cover !important;
}


/* Ось v3.3.0 — новая главная страница */
.topbar-copy{min-width:0}
.page-subtitle{
  margin:2px 0 2px;
  color:#cbd4ea;
  font-size:15px;
  font-weight:550;
}
.page-date{
  margin:0;
  font-size:13px;
  text-transform:none;
}
.section-kicker{
  display:block;
  margin-bottom:4px;
  color:#8fa2d4;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.dashboard-view{
  --dashboard-gap:16px;
}
.focus-card{
  position:relative;
  overflow:hidden;
  margin-bottom:var(--dashboard-gap);
  padding:22px;
  border:1px solid rgba(108,124,255,.52);
  background:
    radial-gradient(circle at 100% 0,rgba(110,231,255,.10),transparent 34%),
    radial-gradient(circle at 0 100%,rgba(139,108,255,.15),transparent 40%),
    linear-gradient(145deg,rgba(20,31,57,.98),rgba(10,17,32,.98));
  box-shadow:0 22px 65px rgba(0,0,0,.32),0 0 0 1px rgba(93,168,255,.08);
}
.focus-card::after{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  right:-90px;
  top:-100px;
  border-radius:50%;
  background:rgba(108,124,255,.13);
  filter:blur(8px);
  pointer-events:none;
}
.focus-head{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:16px;
}
.focus-head h2{
  margin:0 0 3px;
  font-size:24px;
}
.focus-head p{margin:0}
.focus-badge{
  padding:7px 11px;
  border-radius:999px;
  background:rgba(108,124,255,.14);
  border:1px solid rgba(108,124,255,.34);
  color:#dce2ff;
  font-size:11px;
  font-weight:750;
}
.focus-actions{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.focus-action{
  display:flex;
  align-items:flex-start;
  gap:11px;
  min-height:96px;
  padding:14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
}
.focus-action-icon{
  display:grid;
  place-items:center;
  flex:0 0 34px;
  width:34px;
  height:34px;
  border-radius:11px;
  font-size:17px;
  font-weight:900;
}
.focus-action strong{
  display:block;
  margin-bottom:4px;
  font-size:14px;
}
.focus-action span:not(.focus-action-icon){
  display:block;
  color:var(--muted);
  font-size:12px;
  line-height:1.4;
}
.focus-action.primary .focus-action-icon{background:rgba(93,168,255,.15);color:#8dc5ff}
.focus-action.positive .focus-action-icon,
.focus-action.protected .focus-action-icon{background:rgba(61,220,151,.14);color:#7ae7b6}
.focus-action.warning .focus-action-icon{background:rgba(244,201,93,.14);color:#ffe18e}
.focus-action.danger .focus-action-icon{background:rgba(255,107,122,.14);color:#ff9da8}
.focus-day{
  position:relative;
  z-index:1;
  margin-top:14px;
  padding-top:13px;
  border-top:1px solid rgba(255,255,255,.08);
  color:#cbd4ea;
  font-size:13px;
}

.dashboard-metrics{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-bottom:var(--dashboard-gap);
}
.dashboard-metrics .metric{
  min-height:148px;
  padding:16px;
  overflow:hidden;
}
.metric-top{
  display:flex;
  align-items:center;
  gap:8px;
}
.metric-icon{
  display:grid;
  place-items:center;
  width:28px;
  height:28px;
  border-radius:9px;
  background:rgba(108,124,255,.12);
  color:#cdd4ff;
  font-size:13px;
  font-weight:900;
}
.metric-available{border-color:rgba(61,220,151,.18)}
.metric-available .metric-icon{background:rgba(61,220,151,.12);color:#80e9ba}
.metric-capital{border-color:rgba(93,168,255,.20)}
.metric-capital .metric-icon{background:rgba(93,168,255,.12);color:#8dc5ff}
.metric-debt{border-color:rgba(255,107,122,.18)}
.metric-debt .metric-icon{background:rgba(255,107,122,.12);color:#ff9da8}
.metric-payment{border-color:rgba(244,201,93,.18)}
.metric-payment .metric-icon{background:rgba(244,201,93,.12);color:#ffe18e}
.dashboard-metrics .value{
  margin:12px 0 7px;
  font-size:clamp(22px,2.3vw,31px);
}
.dashboard-metrics .value.small{
  font-size:clamp(17px,1.7vw,22px);
  line-height:1.25;
}

.dashboard-main-grid{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(300px,.75fr);
  gap:var(--dashboard-gap);
  margin-bottom:var(--dashboard-gap);
}
.dashboard-main-grid > .card{margin:0}
.commander-card .stack{margin-top:12px}
.dot.blue{background:#5da8ff}

.quick-actions-card{
  margin-bottom:var(--dashboard-gap);
}
.quick-action-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:14px;
}
.quick-action{
  display:flex;
  align-items:center;
  gap:11px;
  min-width:0;
  padding:13px;
  border-radius:15px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.035);
  color:var(--text);
  text-align:left;
  transition:transform .18s ease,border-color .18s ease,background .18s ease;
}
.quick-action:hover{
  transform:translateY(-2px);
  border-color:rgba(108,124,255,.38);
  background:rgba(108,124,255,.07);
}
.quick-action-icon{
  display:grid;
  place-items:center;
  flex:0 0 36px;
  width:36px;
  height:36px;
  border-radius:11px;
  font-size:19px;
  font-weight:900;
}
.quick-action strong{display:block;font-size:13px}
.quick-action small{display:block;margin-top:2px;color:var(--muted);font-size:11px}
.quick-action.expense .quick-action-icon{background:rgba(255,107,122,.13);color:#ff9da8}
.quick-action.income .quick-action-icon{background:rgba(61,220,151,.13);color:#7ae7b6}
.quick-action.budget .quick-action-icon{background:rgba(93,168,255,.13);color:#8dc5ff}
.quick-action.debts .quick-action-icon{background:rgba(139,108,255,.14);color:#b8a5ff}

.secondary-dashboard-grid{margin-bottom:0}

@media(max-width:1100px){
  .focus-actions{grid-template-columns:1fr}
  .focus-action{min-height:auto}
  .dashboard-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-main-grid{grid-template-columns:1fr}
  .quick-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .topbar{
    display:grid;
    grid-template-columns:minmax(0,1fr);
    align-items:start;
    gap:12px;
    margin-bottom:17px;
  }
  .topbar-copy{width:100%;min-width:0}
  .topbar-copy h1{
    max-width:100%;
    font-size:31px;
    line-height:1.12;
    overflow-wrap:break-word;
  }
  .page-subtitle{max-width:100%;font-size:14px}
  .page-date{font-size:12px}
  .top-actions{
    width:100%;
    justify-content:flex-end;
    gap:7px;
    flex-wrap:nowrap;
  }
  .cloud-pill{padding:6px 8px}
  .focus-card{padding:17px}
  .focus-head h2{font-size:22px}
  .dashboard-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .dashboard-metrics .metric{min-height:138px;padding:14px}
  .dashboard-metrics .value{font-size:23px}
  .dashboard-metrics .value.small{font-size:17px}
  .quick-action-grid{grid-template-columns:1fr 1fr}
  .quick-action{padding:11px}
}
@media(max-width:390px){
  .dashboard-metrics{grid-template-columns:1fr}
  .quick-action-grid{grid-template-columns:1fr}
}

/* Ось v3.3.2 — единая мобильная адаптация */
:root{
  --visual-viewport-height:100dvh;
  --mobile-nav-height:78px;
}

.details-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  list-style:none;
  cursor:pointer;
  user-select:none;
}
.details-summary::-webkit-details-marker{display:none}
.details-summary strong{display:block;font-size:19px;color:var(--text)}
.details-summary small{display:block;margin-top:3px;color:var(--muted);font-size:12px;font-weight:400}
.details-summary-side{display:flex;align-items:center;gap:9px}
.details-chevron{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:10px;background:rgba(255,255,255,.05);color:var(--muted);transition:transform .18s ease}
details[open] .details-chevron{transform:rotate(180deg)}
.details-content{margin-top:16px}
.budget-settings-card{align-self:start}
.payment-archive-panel{margin-top:18px}

.iconbtn:focus{outline:none}
.iconbtn:focus-visible{outline:3px solid rgba(93,168,255,.72);outline-offset:2px}
.report-row strong.negative{color:#ff9da8}
.report-row strong.positive{color:#7ae7b6}
.bar-top span{min-width:0;overflow-wrap:anywhere}
.bar-top strong{flex:0 0 auto;white-space:nowrap}

@media(max-width:760px){
  html{
    scroll-padding-top:calc(env(safe-area-inset-top,0px) + 10px);
  }
  body{
    min-height:100dvh;
    overflow-x:hidden;
  }
  .app::before{
    content:"";
    position:fixed;
    z-index:45;
    top:0;
    left:0;
    right:0;
    height:env(safe-area-inset-top,0px);
    background:#070b14;
    pointer-events:none;
  }
  .main{
    margin-left:0;
    padding:
      calc(14px + env(safe-area-inset-top,0px))
      14px
      calc(var(--mobile-nav-height) + 68px + env(safe-area-inset-bottom,0px));
  }
  .view{
    padding-bottom:40px;
  }
  .topbar{
    display:grid;
    grid-template-columns:minmax(0,1fr);
    gap:10px;
    align-items:start;
    margin-bottom:16px;
  }
  .topbar-copy{min-width:0;width:100%}
  .topbar-copy h1{
    margin:0 0 5px;
    max-width:100%;
    font-size:clamp(29px,8.2vw,34px);
    line-height:1.08;
    letter-spacing:-.035em;
    overflow-wrap:anywhere;
  }
  .page-subtitle{
    max-width:34ch;
    margin:0;
    font-size:14px;
    line-height:1.45;
  }
  .page-date{margin-top:4px;font-size:12px}
  .top-actions{
    width:100%;
    display:flex;
    justify-content:flex-end;
    align-items:center;
    gap:7px;
  }
  .top-actions .iconbtn{
    width:43px;
    height:43px;
    flex:0 0 43px;
    border-radius:14px;
  }
  .cloud-pill{
    min-height:43px;
    padding:7px 11px;
    font-size:12px;
  }

  /* Внутренние заголовки не дублируют название страницы из верхней панели. */
  .view > .toolbar{
    justify-content:flex-end;
    align-items:stretch;
    margin:0 0 16px;
  }
  .view > .toolbar > div:first-child{display:none}
  #settingsView > .toolbar{display:none}
  .view > .toolbar > .btn{
    width:100%;
    min-height:48px;
    white-space:nowrap;
  }
  .toolbar-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:9px;
    width:100%;
  }
  .toolbar-actions .btn{
    min-width:0;
    min-height:48px;
    padding:10px 12px;
    white-space:nowrap;
  }
  #budgetView > .toolbar .btn,
  #debtsView > .toolbar .btn,
  #paymentsView > .toolbar .btn{
    width:100%;
    min-height:48px;
    padding:10px 14px;
    white-space:nowrap;
  }

  .card,
  .debt-card,
  .payment-card{
    padding:15px;
    border-radius:18px;
  }
  .card h2,.debt-card h2,.payment-card h2{margin-bottom:8px}
  .grid4,.grid3,.grid2{gap:12px;margin-bottom:12px}

  /* Финансы */
  #financeAccounts{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  #financeAccounts .account-card-editable{
    min-height:132px;
    padding:14px;
  }
  #financeAccounts .value.small{
    margin-top:24px;
    font-size:18px;
    line-height:1.2;
    overflow-wrap:anywhere;
  }
  #financeAccounts .foot{font-size:11px}
  .account-card-editable::after{font-size:10px}

  /* Долги */
  #debtSummary{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  #debtSummary > :last-child{grid-column:1/-1}
  #debtSummary .metric{
    min-height:0;
    padding:14px;
  }
  #debtSummary .value{font-size:22px;margin:7px 0}
  #debtCards{gap:12px}
  .debt-card .value{font-size:27px}
  .debt-card .meta{gap:8px}
  .debt-card-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    margin-top:13px;
  }
  .debt-card-actions .btn{
    min-width:0;
    min-height:45px;
    padding:9px 10px;
    flex-basis:auto;
  }
  .debt-card-actions .btn:last-child:nth-child(3){grid-column:1/-1}

  /* Платежи */
  #paymentCards{gap:12px}
  .payment-card .value{
    margin:10px 0;
    font-size:28px;
  }
  .payment-date-line{
    margin:10px 0;
    padding:9px 0;
  }
  .payment-card > p{margin:0 0 12px;font-size:13px}
  .payment-card-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }
  .payment-card-actions .btn{
    min-width:0;
    min-height:45px;
    padding:9px 8px;
    flex-basis:auto;
    font-size:13px;
  }
  .payment-archive-panel{padding:14px}
  .inactive-payment-row{gap:10px;padding:11px 0}

  /* Бюджет */
  #budgetView > .grid4{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  #budgetView > .grid4 .metric{
    min-height:0;
    padding:14px;
  }
  #budgetView > .grid4 .value.small{font-size:18px}
  #budgetView > .grid2{display:block}
  #budgetView > .grid2 > .card,
  #budgetView > .grid2 > details{margin-bottom:12px}
  .budget-settings-card{padding:14px}
  .budget-settings-card .details-content{margin-top:10px}
  .budget-settings-card label{margin:10px 0}
  .budget-settings-card .two-fields,
  .budget-settings-card .three-fields{gap:0}
  .salary-distribution-card .head,
  #budgetView article > .head{
    align-items:flex-start;
  }
  .salary-distribution-card .head h2{font-size:21px}
  .distribution-controls{gap:0}
  .distribution-summary{margin-top:12px}
  .distribution-row{padding:10px 0;gap:10px}
  .distribution-row span{font-size:13px}
  .distribution-row strong{font-size:14px}
  .distribution-actions .btn{width:100%}
  .distribution-plan-card .plan-grid{gap:7px}
  .distribution-plan-card .plan-grid div{padding:9px}
  .income-expectation-card{padding:14px}
  .income-expectation-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }
  .income-expectation-actions .btn{
    min-width:0;
    width:100%;
    padding:9px 7px;
    font-size:13px;
  }
  .income-expectation-actions .btn:last-child:nth-child(3){grid-column:1/-1}
  .budget-recommendation,.budget-advice{padding:13px;font-size:13px;line-height:1.45}
  .forecast-row{padding:10px 0;gap:12px}
  .forecast-row span{font-size:13px}
  .forecast-row strong{font-size:14px;white-space:nowrap}

  /* Отчёты */
  #reportsView .grid2{display:block}
  #reportsView .grid2 > .card{margin-bottom:12px}
  #categoryReport{gap:10px}
  #categoryReport .bar-top{align-items:flex-end;font-size:14px}
  #monthReport .row{padding:10px 0}
  #monthReport .row span{font-size:14px}
  #monthReport .row strong{white-space:nowrap}

  /* Настройки */
  #settingsView .grid2{display:block}
  #settingsView .grid2 > .card{margin-bottom:12px}
  .notification-settings-card .head{align-items:flex-start}
  .notification-settings-card .head p{font-size:12px;margin-bottom:0}
  .notification-device-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0 7px}
  .notification-device-actions .btn{min-width:0;padding:9px 7px;font-size:13px}
  .background-push-box{padding:12px;margin-top:12px}
  .background-push-head{gap:8px;margin-bottom:9px}
  .background-push-box .btn{min-height:44px;padding:9px 10px}
  .notification-settings-form label{margin:10px 0}
  .notification-switches{gap:8px}
  .check-row{padding:10px;gap:10px}
  .check-row strong{font-size:14px}
  .check-row small{font-size:11px;line-height:1.35}
  .notification-settings-footer{gap:9px}
  .notification-settings-footer .btn{width:100%}
  .setting{padding:11px 0}
  .setting .btn{min-width:96px;padding:9px 11px}
  #resetPasswordBtn{width:100%;margin-top:8px}

  /* Мобильное меню */
  .mobile-menu-dialog{
    width:min(520px,calc(100vw - 28px));
    max-height:calc(var(--visual-viewport-height) - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 28px);
    overflow-y:auto;
    padding:18px;
  }
  .mobile-menu-dialog .modal-head{position:static;margin:0 0 12px;padding:0;background:none}
  .mobile-menu-grid{gap:9px}
  .mobile-menu-item{padding:13px}
  .mobile-menu-item strong{font-size:15px}
  .mobile-menu-item span{font-size:11px}

  /* Модальные окна и клавиатура iPhone */
  #txModal,#accountModal,#recurringPaymentModal,#debtModal,#debtPaymentModal,#incomeExpectationModal,#incomeReceivedModal{
    position:fixed;
    inset:max(8px,env(safe-area-inset-top,0px)) 0 auto 0;
    width:min(640px,calc(100vw - 24px));
    max-height:calc(var(--visual-viewport-height) - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 16px);
    margin:0 auto;
    padding:0;
    overflow:hidden;
    border-radius:22px;
  }
  #txModal > form,#accountModal > form,#recurringPaymentModal > form,#debtModal > form,#debtPaymentModal > form,#incomeExpectationModal > form,#incomeReceivedModal > form{
    display:flex;
    flex-direction:column;
    max-height:inherit;
    overflow-y:auto;
    overscroll-behavior:contain;
    padding:18px;
    scrollbar-gutter:stable;
  }
  #txModal .modal-head,#accountModal .modal-head,#recurringPaymentModal .modal-head,#debtModal .modal-head,#debtPaymentModal .modal-head,#incomeExpectationModal .modal-head,#incomeReceivedModal .modal-head{
    position:sticky;
    z-index:4;
    top:-18px;
    margin:-18px -18px 12px;
    padding:18px;
    background:linear-gradient(180deg,#111a2f 76%,rgba(17,26,47,.96));
    border-bottom:1px solid rgba(255,255,255,.05);
  }
  .modal-head h2{font-size:23px;line-height:1.16;margin-bottom:6px}
  .modal-head p{font-size:12px;line-height:1.4;margin-bottom:0}
  .modal-head .iconbtn{flex:0 0 44px;width:44px;height:44px}
  .modal-actions{
    position:sticky;
    z-index:5;
    bottom:-18px;
    display:grid;
    grid-template-columns:1fr 1.25fr;
    gap:8px;
    margin:16px -18px -18px;
    padding:12px 18px calc(12px + env(safe-area-inset-bottom,0px));
    background:linear-gradient(0deg,#111a2f 78%,rgba(17,26,47,.96));
    border-top:1px solid rgba(255,255,255,.06);
  }
  .modal-actions .modal-spacer{display:none}
  .modal-actions .btn{
    min-width:0;
    min-height:48px;
    padding:10px 8px;
  }
  .modal-actions .danger{grid-column:1/-1;grid-row:1}
  .segments{position:relative;margin:8px 0 12px}
  .segments button{min-height:44px;font-size:14px}
  .segments button.active{
    color:#fff;
    background:linear-gradient(135deg,rgba(108,124,255,.48),rgba(139,92,246,.38));
    box-shadow:inset 0 0 0 1px rgba(166,175,255,.32);
    font-weight:800;
  }
  input,select,textarea{font-size:16px}
  input[type="date"],input[type="time"]{
    min-height:48px;
    height:48px;
    padding-block:8px;
  }
  label{margin:11px 0}
  .two-fields,.three-fields{grid-template-columns:1fr;gap:0}

  /* Нижняя навигация всегда стоит выше home indicator. */
  .bottom{
    left:10px;
    right:10px;
    bottom:calc(10px + env(safe-area-inset-bottom,0px));
    min-height:70px;
    padding:8px 7px;
    border-radius:22px;
    z-index:50;
  }
  .bottom button{min-width:0;min-height:50px}
  .bottom span{font-size:10px}
  .bottom .add{
    width:52px;
    height:52px;
    margin:-20px auto 0;
  }
}

@media(max-width:390px){
  #financeAccounts{grid-template-columns:1fr}
  #budgetView > .grid4{grid-template-columns:1fr}
  #debtSummary{grid-template-columns:1fr}
  #debtSummary > :last-child{grid-column:auto}
  .toolbar-actions{grid-template-columns:1fr}
  .notification-device-actions{grid-template-columns:1fr}
}

@media(max-width:760px){
  #genericModal{
    position:fixed;
    inset:max(8px,env(safe-area-inset-top,0px)) 0 auto 0;
    width:min(640px,calc(100vw - 24px));
    max-height:calc(var(--visual-viewport-height) - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 16px);
    margin:0 auto;
    overflow-y:auto;
    overscroll-behavior:contain;
    padding:18px;
  }
  #genericModal > .modal-head{
    position:sticky;
    z-index:4;
    top:-18px;
    margin:-18px -18px 12px;
    padding:18px;
    background:linear-gradient(180deg,#111a2f 76%,rgba(17,26,47,.96));
    border-bottom:1px solid rgba(255,255,255,.05);
  }
}

@media(max-width:760px){
  body:has(dialog[open]){overflow:hidden}
  #txModal,#accountModal,#recurringPaymentModal,#debtModal,#debtPaymentModal,#incomeExpectationModal,#incomeReceivedModal,#genericModal{
    top:calc(var(--visual-viewport-offset-top,0px) + max(8px,env(safe-area-inset-top,0px)));
  }
}
