/**
 * IIFIN — Дашборд /personal-finance/
 * Мигрировано из Elementor inline-стилей.
 */

.dashboard-page{ font-family:"Roboto",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; color:var(--foreground); }
.dashboard-page *{ box-sizing:border-box }

.dashboard-page .pf-wrap{
  max-width:1200px; margin:0 auto; padding:20px 15px 100px; overflow-x:hidden;
  background: transparent;
  border-radius:var(--radius-xl);
}
body.page-slug-personal-finance .dashboard-page .pf-wrap{
  padding-bottom: calc(20px + env(safe-area-inset-bottom,0px));
}
.dashboard-page .muted{color:var(--muted-foreground);font-size:13px}

/* Заголовок страницы */
.dashboard-page .pf-header{
  display:flex; flex-wrap:wrap; align-items:flex-start; justify-content:space-between; gap:12px 20px;
  margin-bottom:var(--spacing-5);
}
.dashboard-page .pf-title{font-size:clamp(22px,4vw,28px); font-weight:700; margin:0 0 4px; color:var(--foreground)}
.dashboard-page .pf-subtitle{font-size:14px; color:var(--muted-foreground); margin:0}
.dashboard-page .pf-ai-btn{
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 18px; border-radius:var(--radius-full);
  background:rgba(124,58,237,.12);
  color:#7c3aed;
  border:1.5px solid #7c3aed;
  font-size:14px; font-weight:600; text-decoration:none;
  cursor:pointer; font-family:inherit;
  transition:background .15s ease, border-color .15s ease;
}
.dashboard-page .pf-ai-btn:hover{
  background:rgba(124,58,237,.22);
  border-color:#6d28d9;
  color:#6d28d9;
}
.dashboard-page .pf-ai-btn .material-symbols-outlined{font-size:18px}

/* Панель онбординга как карточка/виджет (промо-карточка с градиентом — исключена, в iifin-onboarding.css) */
.dashboard-page #iifin-onboarding-root .iifin-ob:not(.iifin-ob--wizard-card){
  background:var(--surface-card);
  border:1px solid var(--stroke-card);
  border-radius:var(--radius-xl);
  padding:var(--spacing-5);
  box-shadow:var(--shadow-sm);
}
.dashboard-page #iifin-onboarding-root .iifin-ob__card:not(.iifin-ob__card--promo){
  background:var(--surface-raised);
  border:1px solid var(--stroke-field);
}

/* KPI — плитка 2×2 как в референсе */
.dashboard-page .kpi-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:var(--spacing-4);
  margin-bottom:var(--spacing-5);
}
@media (min-width:640px){
  .dashboard-page .kpi-grid{ grid-template-columns:repeat(4,1fr); }
}
.dashboard-page .kpi-card{
  background:var(--surface-card);
  border:1px solid var(--stroke-card);
  border-radius:var(--radius-lg);
  padding:var(--spacing-4);
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:88px;
  position:relative;
}
.dashboard-page .kpi-card--clickable{
  cursor:pointer;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.dashboard-page .kpi-card--clickable:hover{
  border-color:var(--stroke-field);
  box-shadow:var(--shadow-md);
}
.dashboard-page .kpi-card--clickable:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
.dashboard-page .kpi-card--clickable{
  cursor:pointer;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.dashboard-page .kpi-card--clickable:hover{
  border-color:var(--stroke-field);
  box-shadow:var(--shadow-md);
}
.dashboard-page .kpi-card--clickable:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
.dashboard-page .kpi-trend-corner{
  position:absolute; top:10px; right:10px;
  font-size:12px; font-weight:500; padding:2px 8px; border-radius:var(--radius-full);
}
.dashboard-page .kpi-value-wrap{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px}
.dashboard-page .kpi-value{font-size:20px;font-weight:600;color:var(--foreground)}
.dashboard-page .kpi-icon{
  font-size:32px; color:var(--primary); margin-bottom:4px;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 28;
}
.dashboard-page .kpi-label{font-size:12px;color:var(--muted-foreground);margin-bottom:6px}
.dashboard-page .kpi-trend-badge{font-size:12px;font-weight:500;padding:2px 8px;border-radius:var(--radius-full)}
.dashboard-page .kpi-trend-badge.trend-up{background:var(--success-light);color:var(--success-dark)}
.dashboard-page .kpi-trend-badge.trend-down{background:var(--danger-light);color:var(--danger-dark)}
.dashboard-page .kpi-trend-badge.trend-new{background:var(--primary-light, rgba(36,168,166,.15));color:var(--primary)}
.dashboard-page .kpi-badge{display:inline-block;padding:4px 8px;border-radius:var(--radius-full);font-size:12px;border:1px solid var(--stroke-field)}
/* KPI карточки — кликабельные */
.dashboard-page .kpi-card--clickable{cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}
.dashboard-page .kpi-card--clickable:hover{border-color:var(--stroke-field);box-shadow:var(--shadow-md)}
.dashboard-page .kpi-card--clickable:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
.dashboard-page .kpi-card--clickable{cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}
.dashboard-page .kpi-card--clickable:hover{border-color:var(--stroke-field);box-shadow:var(--shadow-md)}
.dashboard-page .kpi-card--clickable:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
.dashboard-page .badge{display:inline-block;padding:4px 8px;border-radius:var(--radius-full);font-size:12px;border:1px solid var(--stroke-field)}
.dashboard-page .badge.green{background:var(--success-light);color:var(--success-dark);border-color:var(--success)}
.dashboard-page .badge.yellow{background:var(--warning-light);color:var(--warning-dark);border-color:var(--warning)}
.dashboard-page .badge.red{background:var(--danger-light);color:var(--danger-dark);border-color:var(--danger)}

/* Прогресс */
.dashboard-page .progress{height:8px;background:var(--muted);border-radius:var(--radius-full);margin-top:6px;overflow:hidden}
.dashboard-page .progress-bar{
  height:100%;
  background:var(--primary);
  width:0%;
  transition: width .5s cubic-bezier(.2,.6,.2,1);
}
@media (prefers-reduced-motion:no-preference){
  .dashboard-page .progress-bar{
    background-image:linear-gradient(90deg,rgba(255,255,255,.4),rgba(255,255,255,0));
    background-size:200% 100%; animation:pb-move 2.2s linear infinite;
  }
  @keyframes pb-move{to{background-position:-200% 0}}
}

/* Быстрые действия — 4 карточки по референсу */
.dashboard-page .qa-section-title{
  font-size:16px; font-weight:600; margin:0 0 var(--spacing-3); color:var(--foreground)
}
.dashboard-page .quick-actions{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:var(--spacing-3);
  margin:0 0 var(--spacing-5);
}
.dashboard-page .qa{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  min-height:88px;
  text-align:left;
  text-decoration:none;
  background:var(--surface-card);
  border:1px solid var(--stroke-card);
  border-radius:var(--radius-lg);
  padding:var(--spacing-4);
  color:var(--foreground);
  box-shadow:var(--shadow-sm);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.dashboard-page .qa:hover{
  border-color:var(--stroke-field);
  box-shadow:var(--shadow-md);
}
.dashboard-page .qa .material-symbols-outlined{
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;
  font-size:28px; line-height:1; color:var(--primary); margin-bottom:8px;
}
.dashboard-page .qa-title{font-weight:600; font-size:14px; margin-bottom:2px}
.dashboard-page .qa-desc{font-size:12px; color:var(--muted-foreground); line-height:1.3}
@media (max-width:420px){
  .dashboard-page .quick-actions{grid-template-columns:repeat(2,1fr)}
}

/* Карточка целей + приоритет */
.dashboard-page .goals-priority-card{
  background:var(--surface-card);
  border:1px solid var(--stroke-card);
  border-radius:var(--radius-xl);
  padding:var(--spacing-5);
  margin:var(--spacing-5) 0;
  box-shadow:var(--shadow-sm);
}
.dashboard-page .goals-priority-header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-bottom:var(--spacing-4);
}
.dashboard-page .goals-priority-title{font-size:1.1rem; font-weight:600; margin:0; color:var(--foreground)}
.dashboard-page .goals-priority-all{
  font-size:14px; font-weight:500; color:var(--primary); text-decoration:none;
}
.dashboard-page .goals-priority-all:hover{text-decoration:underline}
.dashboard-page .goals-list{display:grid; gap:12px; margin-bottom:var(--spacing-4)}
.dashboard-page .goal-item{
  background:var(--surface-raised);
  border:1px solid var(--stroke-field);
  border-radius:var(--radius-md);
  padding:14px 16px;
}
.dashboard-page .goal-title{font-weight:600; margin:0 0 6px; color:var(--foreground); font-size:15px}
.dashboard-page .goal-meta{font-size:13px; color:var(--muted-foreground); margin-bottom:8px; line-height:1.4}
.dashboard-page .goal-bar{position:relative; height:14px; background:var(--muted); border-radius:999px; overflow:hidden}
.dashboard-page .goal-bar-fill{height:100%; width:0%; background:var(--primary); transition:width .5s cubic-bezier(.2,.6,.2,1)}
.dashboard-page .goal-bar-label{position:absolute; top:50%; left:10px; transform:translateY(-50%); font-size:11px; font-weight:600; color:#fff; text-shadow:0 1px 1px rgba(0,0,0,.25)}
.dashboard-page .goals-priority-footer{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:12px;
  padding-top:var(--spacing-4);
  border-top:1px solid var(--stroke-field);
}
.dashboard-page .priority-inline{
  display:flex; flex-wrap:wrap; align-items:center; gap:10px;
}
.dashboard-page .priority-inline .pi-label{font-size:13px; font-weight:500; color:var(--muted-foreground)}
.dashboard-page .priority-chips{display:flex; flex-wrap:wrap; gap:6px}
.dashboard-page .priority-chip{
  display:inline-flex; align-items:center;
  border:1px solid var(--stroke-field);
  border-radius:var(--radius-full);
  padding:5px 12px;
  cursor:pointer;
  user-select:none;
  background:var(--surface-raised);
  color:var(--foreground);
  font-size:13px;
  transition:border-color .15s, background .15s;
}
.dashboard-page .priority-chip input{position:absolute; opacity:0; pointer-events:none}
.dashboard-page .priority-chip:hover{border-color:var(--stroke-focus)}
.dashboard-page .priority-chip input:checked+span{color:var(--primary); font-weight:600}
.dashboard-page .priority-status{font-size:12px}
.dashboard-page .chips{display:flex;flex-wrap:wrap;gap:8px}
.dashboard-page .chip{
  display:inline-flex;align-items:center;
  border:1px solid var(--stroke-field);
  border-radius:var(--radius-full);
  padding:6px 12px;
  cursor:pointer;
  user-select:none;
  background:var(--surface-raised);
  color:var(--foreground);
  font-size:14px;
}
.dashboard-page .chip input{position:absolute;opacity:0;pointer-events:none}
.dashboard-page .chip:hover{border-color:var(--stroke-focus)}
.dashboard-page .chip input:checked+span{color:var(--primary);font-weight:600}
.dashboard-page .chip input:checked~span::after{content:"";display:inline-block;width:6px;height:6px;margin-left:8px;border-radius:50%;background:var(--primary)}

/* Карточки сводок */
.dashboard-page .grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-5)}
.dashboard-page .grid--dashboard{grid-template-columns:1fr 1fr}
.dashboard-page .goals-full{grid-column:1 / -1}
.dashboard-page .iifin-block{
  background:var(--surface-card);
  padding:var(--spacing-5);
  border-radius:var(--radius-xl);
  border:1px solid var(--stroke-card);
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  gap:var(--spacing-3);
}
.dashboard-page .iifin-block h2{font-size:1.1rem;margin:0 0 8px;padding-bottom:0;border:none;font-weight:600;color:var(--foreground)}

/* Скелетоны */
.dashboard-page .skeleton{
  position:relative;background:linear-gradient(90deg,#f3f4f6 25%,#eef2f7 37%,#f3f4f6 63%);
  background-size:400% 100%;animation:shimmer 1.2s infinite;border-radius:12px;
}
.dashboard-page .skeleton-lines{min-height:48px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* Стрелки-ссылки */
.dashboard-page .arrow-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-weight:500;
  text-decoration:none;
  color:var(--primary);
  padding:6px 12px;
  border:1px solid var(--stroke-field);
  border-radius:var(--radius-full);
  background:var(--surface-raised);
  box-shadow:var(--shadow-sm);
  align-self:flex-start;
  margin-top:6px;
  transition:border-color .2s ease, background .2s ease;
}
.dashboard-page .arrow-link .material-symbols-outlined{font-size:18px}
.dashboard-page .arrow-link:hover{border-color:var(--stroke-focus);background:var(--muted)}

/* Капитал, Активы, Обязательства — 3 карточки сразу после KPI */
.dashboard-page .capital-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--spacing-4);
  margin:0 0 var(--spacing-5);
}
.dashboard-page .capital-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  padding:var(--spacing-4);
  border-radius:var(--radius-xl);
  text-decoration:none;
  color:#fff;
  min-height:100px;
  transition:transform .15s ease, box-shadow .15s ease;
  text-align:center;
}
.dashboard-page .capital-card:hover{transform:translateY(-2px); box-shadow:var(--shadow-lg)}
.dashboard-page .capital-card--static{cursor:default; pointer-events:none}
.dashboard-page .capital-card--static:hover{transform:none; box-shadow:var(--shadow-md)}
.dashboard-page .capital-card--static .capital-card-arrow{display:none}
.dashboard-page .capital-card--capital{
  background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
  box-shadow:var(--shadow-md);
}
.dashboard-page .capital-card--assets{
  background:linear-gradient(135deg, #0B7E95 0%, #24a8a6 100%);
  box-shadow:var(--shadow-md);
}
.dashboard-page .capital-card--obligations{
  background:linear-gradient(135deg, #1e3a5f 0%, #2d5a87 100%);
  box-shadow:var(--shadow-md);
}
.dashboard-page .capital-card-label{font-size:13px; opacity:.9; margin-bottom:4px}
.dashboard-page .capital-card-value{font-size:36px; font-weight:700; line-height:1.2}
.dashboard-page .capital-card-meta{
  font-size:11px; opacity:.85; margin-top:6px; line-height:1.4;
  display:flex; flex-direction:column; gap:2px; align-items:center; text-align:center;
}
.dashboard-page .capital-card-meta--spacer{
  min-height:32px;
  margin-top:auto;
}
.dashboard-page .capital-card-meta strong{font-weight:600}
.dashboard-page .capital-card-dti{font-size:10px; opacity:.8}
.dashboard-page .capital-card-arrow{
  align-self:flex-end; margin-top:8px;
  font-size:20px; opacity:.9;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;
}
@media (max-width:640px){
  .dashboard-page .capital-cards{grid-template-columns:1fr}
}

/* Цели — заголовок с ссылкой «Все» */
.dashboard-page .goals-header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-bottom:8px;
}
.dashboard-page .goals-header h2{margin:0}
.dashboard-page .goals-header .arrow-link{margin-top:0}
/* Цели список */
.dashboard-page .goals-list{display:grid;gap:10px}
.dashboard-page .goal-item{background:var(--surface-raised);border:1px solid var(--stroke-field);border-radius:var(--radius-md);padding:10px 12px}
.dashboard-page .goal-title{font-weight:600;margin:0 0 6px;color:var(--foreground)}
.dashboard-page .goal-meta{font-size:13px;color:#374151;margin-bottom:6px;line-height:1.4}
.dashboard-page .goal-bar{position:relative;height:12px;background:#e8eef2;border-radius:999px;overflow:hidden}
.dashboard-page .goal-bar-fill{height:100%;width:0%;background:#ff8c42;transition:width .5s cubic-bezier(.2,.6,.2,1)}
.dashboard-page .goal-bar-label{position:absolute;top:50%;left:8px;transform:translateY(-50%);font-size:11px;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.25)}

/* A11y */
.dashboard-page a:focus-visible,
.dashboard-page button:focus-visible,
.dashboard-page .chip:focus-within{
  outline:2px solid #94d2e5; outline-offset:2px; border-radius:10px;
}

@media (max-width:960px){
  .dashboard-page .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .dashboard-page .grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .dashboard-page *{animation:none !important;transition:none !important}
}

/* ИИ-отчёт */
.dashboard-page #finance-report-output.report-box{
  border: 1px solid #0B7E95 !important;
  background: #f9fdff !important;
  border-radius: 12px !important;
  box-shadow: 0 2px 10px rgba(0,119,182,.08) !important;
  padding: 12px !important;
  min-height: 56px;
}
@media (prefers-color-scheme: dark){
  .dashboard-page #finance-report-output.report-box{
    border-color: rgba(148, 210, 229, .9) !important;
    background: rgba(10, 26, 36, .35) !important;
  }
}

/* KPI Overlay — bottom sheet (mobile) / centered modal (desktop) */
.iifin-kpi-overlay{
  position:fixed; inset:0; z-index:10001;
  display:none; align-items:flex-end; justify-content:center;
  background:transparent;
  transition:background .25s ease;
}
.iifin-kpi-overlay.is-open{
  display:flex;
  background:rgba(15,23,42,.45);
}
.iifin-kpi-overlay__backdrop{
  position:absolute; inset:0; cursor:pointer;
}
.iifin-kpi-overlay__sheet{
  position:relative; z-index:1;
  width:100%; max-width:480px;
  display:flex; flex-direction:column;
  background:var(--surface-card,#fff);
  box-shadow:0 24px 48px rgba(0,0,0,.2);
  overflow:hidden;
  max-height:85vh;
}
/* Mobile: bottom sheet */
.iifin-kpi-overlay--mobile .iifin-kpi-overlay__sheet{
  border-radius:20px 20px 0 0;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(0.32,0.72,0,1);
  padding-bottom:env(safe-area-inset-bottom);
}
.iifin-kpi-overlay--mobile.is-open .iifin-kpi-overlay__sheet{
  transform:translateY(0);
}
.iifin-kpi-overlay__gripper{
  width:36px; height:4px;
  background:var(--neutral-300,#d1d5db);
  border-radius:2px;
  margin:10px auto 4px;
  flex-shrink:0;
}
/* Desktop: centered modal */
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__sheet{
  border-radius:20px;
  margin:4vh 16px;
  max-height:80vh;
}
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__gripper{ display:none; }
.iifin-kpi-overlay__header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 20px;
  background:linear-gradient(135deg, var(--primary,#24a8a6) 0%, #0b7e95 100%);
  color:#fff;
  flex-shrink:0;
}
.iifin-kpi-overlay__title{
  margin:0; font-size:18px; font-weight:700;
}
.iifin-kpi-overlay__close{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; padding:0;
  border:none; border-radius:12px;
  background:rgba(255,255,255,.2);
  color:#fff; cursor:pointer;
  transition:background .15s;
}
.iifin-kpi-overlay__close:hover{
  background:rgba(255,255,255,.3);
}
.iifin-kpi-overlay__close .material-symbols-outlined{ font-size:24px; }
.iifin-kpi-overlay__body{
  flex:1; overflow-y:auto; padding:20px;
  -webkit-overflow-scrolling:touch;
  display:flex; flex-direction:column; gap:16px;
}
.iifin-kpi-overlay__value--main{
  font-size:28px; font-weight:700; color:var(--foreground);
}
.iifin-kpi-overlay__value--positive{ color:var(--success-dark,#059669); }
.iifin-kpi-overlay__value--negative{ color:var(--danger-dark,#dc2626); }
.iifin-kpi-overlay__trend{
  font-size:14px; color:var(--muted-foreground);
}
.iifin-kpi-overlay__section{
  background:var(--surface-raised,rgba(0,0,0,.03));
  border:1px solid var(--stroke-field,rgba(0,0,0,.08));
  border-radius:12px;
  padding:12px 16px;
}
.iifin-kpi-overlay__label{
  font-size:12px; font-weight:600; color:var(--muted-foreground);
  margin-bottom:8px;
}
.iifin-kpi-overlay__row{
  display:flex; justify-content:space-between; align-items:center;
  font-size:14px; margin-bottom:4px;
}
.iifin-kpi-overlay__row:last-child{ margin-bottom:0; }
.iifin-kpi-overlay__meta{
  font-size:13px; color:var(--muted-foreground);
}
.iifin-kpi-overlay__rec{
  font-size:14px; line-height:1.45; color:var(--foreground);
}
.iifin-kpi-overlay__rec--positive{ color:var(--success-dark); }
.iifin-kpi-overlay__rec--negative{ color:var(--danger-dark); }
.iifin-kpi-overlay__status{
  font-size:14px; font-weight:600;
}
.iifin-kpi-overlay__status--comfortable{ color:var(--success-dark); }
.iifin-kpi-overlay__status--sufficient{ color:var(--primary); }
.iifin-kpi-overlay__status--basic{ color:var(--warning-dark); }
.iifin-kpi-overlay__status--critical{ color:var(--danger-dark); }
.iifin-kpi-overlay__cta{
  display:inline-flex; align-items:center; justify-content:center;
  padding:14px 24px;
  background:var(--primary,#24a8a6);
  color:#fff; font-weight:600; font-size:15px;
  border-radius:12px; text-decoration:none;
  transition:background .15s, transform .1s;
  margin-top:8px;
}
.iifin-kpi-overlay__cta:hover{
  background:#0b7e95; color:#fff;
}

/* Reports Viewer Overlay (COMP · Reports · Viewer) */
.iifin-reports-viewer-overlay{
  position:fixed; inset:0; z-index:10000;
  display:none; align-items:stretch; justify-content:center;
  background:transparent;
  transition:background .25s ease;
}
.iifin-reports-viewer-overlay.is-open{
  display:flex;
  background:rgba(15,23,42,.45);
}
.iifin-reports-viewer-backdrop{
  position:absolute; inset:0; cursor:pointer;
}
.iifin-reports-viewer-sheet{
  position:relative; z-index:1;
  width:100%; max-width:720px; max-height:92vh;
  margin:4vh 16px 4vh;
  display:flex; flex-direction:column;
  background:#fff;
  border-radius:20px;
  box-shadow:0 24px 48px rgba(0,0,0,.2);
  overflow:hidden;
}
.iifin-reports-viewer-header{
  flex:0 0 auto;
  background:linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);
  color:#fff;
  padding:16px 20px;
  display:flex; flex-direction:column; gap:12px;
}
.iifin-reports-viewer-header__row{
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.iifin-reports-viewer-back{
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.2) !important; border:none !important;
  border-radius:12px; padding:10px 14px !important;
  color:#fff !important; font-size:14px; font-weight:600; cursor:pointer;
}
.iifin-reports-viewer-back:hover{ background:rgba(255,255,255,.3) !important; }
.iifin-reports-viewer-title-wrap{ width:100%; min-width:0; }
.iifin-reports-viewer-title{ margin:0; font-size:18px; font-weight:700; }
.iifin-reports-viewer-date{ font-size:13px; opacity:.9; display:block; margin-top:2px; }
.iifin-reports-viewer-actions{ display:flex; gap:10px; flex-wrap:wrap; }
/* Кнопки в оверлее отчётов — фиолетовый хедер (finance) */
.iifin-reports-viewer-btn{
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.25) !important; border:none !important;
  border-radius:12px; padding:10px 14px !important;
  color:#fff !important; font-size:13px; font-weight:600; cursor:pointer;
}
.iifin-reports-viewer-btn:hover{ background:rgba(255,255,255,.35) !important; }
.iifin-reports-viewer-btn--link{ text-decoration:none; color:inherit; }
.iifin-reports-viewer-btn--link:hover{ text-decoration:underline; }
.iifin-reports-viewer-body{
  flex:1; overflow-y:auto; padding:20px;
  -webkit-overflow-scrolling:touch;
}

/* ===== KPI Overlay (bottom sheet mobile / centered modal desktop) ===== */
.iifin-kpi-overlay{
  position:fixed; inset:0; z-index:10001;
  display:none; align-items:stretch; justify-content:center;
  background:transparent;
  transition:background .25s ease;
}
.iifin-kpi-overlay.is-open{
  display:flex;
  background:rgba(15,23,42,.45);
}
.iifin-kpi-overlay__backdrop{
  position:absolute; inset:0; cursor:pointer;
}
.iifin-kpi-overlay__sheet{
  position:relative; z-index:1;
  width:100%; max-width:480px; max-height:85vh;
  display:flex; flex-direction:column;
  background:var(--surface-card);
  border-radius:20px;
  box-shadow:0 24px 48px rgba(0,0,0,.2);
  overflow:hidden;
}
/* Desktop: centered modal */
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__sheet{
  margin:4vh 16px;
}
/* Mobile: bottom sheet */
.iifin-kpi-overlay--mobile .iifin-kpi-overlay__sheet{
  position:fixed; left:0; right:0; bottom:0;
  max-height:75dvh;
  margin:0;
  border-radius:20px 20px 0 0;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(0.32,0.72,0,1);
  padding-bottom:env(safe-area-inset-bottom);
}
.iifin-kpi-overlay--mobile.is-open .iifin-kpi-overlay__sheet{
  transform:translateY(0);
}
.iifin-kpi-overlay__gripper{
  width:36px; height:4px;
  background:var(--neutral-300,#d1d5db);
  border-radius:2px;
  margin:10px auto 4px;
  flex-shrink:0;
}
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__gripper{ display:none; }
.iifin-kpi-overlay__header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:12px 16px 16px;
  border-bottom:1px solid var(--stroke-field);
}
.iifin-kpi-overlay__title{
  margin:0; font-size:18px; font-weight:700; color:var(--foreground);
}
.iifin-kpi-overlay__close{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px;
  padding:0; border:none; border-radius:12px;
  background:transparent; color:var(--muted-foreground);
  cursor:pointer;
  transition:background .15s, color .15s;
}
.iifin-kpi-overlay__close:hover{
  background:var(--muted); color:var(--foreground);
}
.iifin-kpi-overlay__close .material-symbols-outlined{ font-size:24px; }
.iifin-kpi-overlay__body{
  flex:1; overflow-y:auto; padding:20px;
  -webkit-overflow-scrolling:touch;
  display:flex; flex-direction:column; gap:16px;
}
.iifin-kpi-overlay__value--main{
  font-size:28px; font-weight:700; color:var(--foreground);
}
.iifin-kpi-overlay__value--positive{ color:var(--success-dark,#059669); }
.iifin-kpi-overlay__value--negative{ color:var(--danger-dark,#dc2626); }
.iifin-kpi-overlay__trend{
  font-size:14px; color:var(--muted-foreground);
}
.iifin-kpi-overlay__section{
  background:var(--surface-raised);
  border:1px solid var(--stroke-field);
  border-radius:12px;
  padding:12px 16px;
}
.iifin-kpi-overlay__label{
  font-size:12px; font-weight:600; color:var(--muted-foreground);
  margin-bottom:8px;
}
.iifin-kpi-overlay__row{
  display:flex; justify-content:space-between; align-items:center;
  font-size:14px; margin-bottom:4px;
}
.iifin-kpi-overlay__row:last-child{ margin-bottom:0; }
.iifin-kpi-overlay__meta{
  font-size:13px; color:var(--muted-foreground);
}
.iifin-kpi-overlay__rec{
  font-size:14px; line-height:1.45; color:var(--foreground);
}
.iifin-kpi-overlay__rec--positive{ color:var(--success-dark); }
.iifin-kpi-overlay__rec--negative{ color:var(--danger-dark); }
.iifin-kpi-overlay__status{
  font-size:14px; font-weight:600;
}
.iifin-kpi-overlay__status--comfortable{ color:var(--success-dark); }
.iifin-kpi-overlay__status--sufficient{ color:var(--primary); }
.iifin-kpi-overlay__status--basic{ color:var(--warning-dark); }
.iifin-kpi-overlay__status--critical{ color:var(--danger-dark); }
.iifin-kpi-overlay__cta{
  display:inline-flex; align-items:center; justify-content:center;
  padding:14px 24px;
  background:var(--primary);
  color:#fff;
  font-weight:600; font-size:15px;
  border-radius:12px;
  text-decoration:none;
  transition:background .2s, color .2s;
  margin-top:8px;
}
.iifin-kpi-overlay__cta:hover{
  background:var(--primary-600,#0b7e95);
  color:#fff;
}

/* Архив отчётов /reports/ — без доп. заливки, стили как на странице «Ещё» */
.page-slug-reports .e-con-boxed.e-con:has(> .iifin-reports-page){
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.iifin-reports-page{
  background: transparent !important;
  padding: var(--spacing-4, 16px) 12px !important;
  padding-bottom: 20px !important;
  max-width: 560px;
  margin: 0 auto;
}
.iifin-reports-archive{ margin: 16px 0 24px; }
.iifin-reports-archive__toolbar{ margin-bottom: 12px; }
.iifin-reports-archive__filter{ display: inline-flex; align-items: center; gap: 8px; font-size: 14px; }
.iifin-reports-archive__filter select{ padding: 8px 12px; border-radius: 10px; border: 1px solid #e5e7eb; }
.iifin-reports-archive__list{ display: flex; flex-direction: column; gap: 20px; }
.iifin-reports-archive__section-title{ margin: 0 0 4px 0; font-size: 17px; font-weight: 700; color: #111827; }
.iifin-reports-archive__section-hint{ margin: 0 0 10px 0; font-size: 13px; color: #6b7280; }
.iifin-reports-archive__section{ display: flex; flex-direction: column; gap: 12px; }
.iifin-reports-archive__card{
  display: flex; align-items: flex-start; gap: 14px;
  background: #faf8f5; border: 1px solid #e5e7eb; border-radius: 20px;
  padding: 16px 20px; box-shadow: 0 1px 3px rgba(0,0,0,.04);
  border-left: 4px solid #e5e7eb;
}
.iifin-reports-archive__card--finance{ border-left-color: #7c3aed; background: linear-gradient(135deg, #faf5ff 0%, #faf8f5 100%); }
.iifin-reports-archive__card--investment{ border-left-color: #0d9488; background: linear-gradient(135deg, #ccfbf1 0%, #faf8f5 100%); }
.iifin-reports-archive__card--detailed_ai,
.iifin-reports-archive__card--transactions_ai{ border-left-color: #41a3c8; background: linear-gradient(135deg, #e8f6fa 0%, #faf8f5 100%); }
.iifin-reports-archive__icon{ font-size: 28px; color: #24a8a6; flex-shrink: 0; margin-top: 2px; }
.iifin-reports-archive__card--finance .iifin-reports-archive__icon{ color: #7c3aed; }
.iifin-reports-archive__card--investment .iifin-reports-archive__icon{ color: #0d9488; }
.iifin-reports-archive__card--detailed_ai .iifin-reports-archive__icon,
.iifin-reports-archive__card--transactions_ai .iifin-reports-archive__icon{ color: #41a3c8; }
.iifin-reports-archive__body{ flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.iifin-reports-archive__head{
  display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
}
.iifin-reports-archive__title{
  margin: 0; font-size: 16px; font-weight: 600; line-height: 1.3; flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.iifin-reports-archive__actions{ display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.iifin-reports-archive__meta{
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px 12px;
  font-size: 13px; color: #6b7280;
}
.iifin-reports-archive__type{ color: #6b7280; }
.iifin-reports-archive__date{ color: #9ca3af; }
.iifin-reports-archive__meta .iifin-reports-archive__btn-delete{ margin-left: auto; }
.iifin-reports-archive__btn{
  padding: 4px 10px; border-radius: 8px;
  border: 1.5px solid #24a8a6 !important;
  background: transparent !important; color: #24a8a6 !important; font-weight: 600; cursor: pointer; font-size: 12px;
}
.iifin-reports-archive__btn:hover{ background: rgba(36, 168, 166, .1) !important; }
.iifin-reports-archive__btn-delete{
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; padding: 0 !important; border: none !important; border-radius: 0;
  background: none !important; color: #64748b !important; cursor: pointer;
  box-shadow: none !important;
}
.iifin-reports-archive__btn-delete:hover{ color: #dc2626 !important; background: none !important; }
.iifin-reports-archive__btn-delete .material-symbols-outlined{ font-size: 18px; color: inherit !important; }
@media (max-width: 480px){
  .iifin-reports-archive__card{ padding: 12px 14px; gap: 10px; }
  .iifin-reports-archive__icon{ font-size: 22px; }
  .iifin-reports-archive__title{
    font-size: 14px; white-space: normal;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .iifin-reports-archive__btn{ padding: 3px 8px !important; font-size: 11px !important; }
  .iifin-reports-archive__btn-delete{ width: 20px !important; height: 20px !important; }
  .iifin-reports-archive__btn-delete .material-symbols-outlined{ font-size: 16px !important; }
}
.iifin-reports-archive__empty{ text-align: center; padding: 32px 16px; color: #6b7280; }
.iifin-reports-archive__empty a{ color: #24a8a6; }
.iifin-reports-archive__links{ display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; margin-top: 24px; }
.iifin-reports-archive__links .iifin-reports__card{
  display: flex; flex-direction: column; gap: 8px;
  background: #faf8f5; border-radius: 20px; border: 1px solid #e5e7eb;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
}

.report-box section{ background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px; padding:12px 14px; margin:10px 0; }
.report-box h2{ margin:0 0 8px; font-size:18px; }
.report-box h3{ margin:0 0 8px; font-size:15px; color:#0B7E95; }
.report-box p{ margin:8px 0; line-height:1.45; }
.report-box ul,.report-box ol{ margin:8px 0 8px 18px; }
.report-box li{ margin:6px 0; }
.report-box p.risk-low{ border-left:4px solid #10b981; background:#ecfdf5; padding:8px 10px; border-radius:10px; }
.report-box p.risk-medium{ border-left:4px solid #f59e0b; background:#fffbeb; padding:8px 10px; border-radius:10px; }
.report-box p.risk-high{ border-left:4px solid #ef4444; background:#fef2f2; padding:8px 10px; border-radius:10px; }

/* KPI + charts надстройка (source_meta) в viewer */
#iifin-fr-summary-wrap .iifin-fr-hint{ margin:0 0 8px; font-size:12px; color:#6b7280; }
#iifin-fr-summary-wrap .iifin-fr-chips{ display:block; margin:0 0 10px; }
#iifin-fr-summary-wrap .iifin-fr-chip{
  display:inline-block; margin:0 6px 6px 0; padding:6px 10px;
  border-radius:999px; background:#e5f3f3; border:1px solid rgba(0,0,0,.06);
  font-size:12px; white-space:normal;
}
#iifin-fr-summary-wrap .iifin-fr-chip b{ font-weight:700; }
#iifin-fr-summary-wrap .iifin-fr-chip .muted{ opacity:.7; margin-left:6px; }
#iifin-fr-summary-wrap .iifin-fr-charts{ display:block; margin-top:6px; }
#iifin-fr-summary-wrap .iifin-fr-chart-card{
  display:inline-block; width:100%; max-width:340px; vertical-align:top;
  margin:0 10px 10px 0; padding:10px; border-radius:12px;
  background:#fff; border:1px solid rgba(0,0,0,.06); box-sizing:border-box;
}
#iifin-fr-summary-wrap .iifin-fr-chart-card--wide{ max-width:100%; }
#iifin-fr-summary-wrap .iifin-fr-chart-title{ font-size:13px; font-weight:700; margin:0 0 6px; color:#111827; }
#iifin-fr-summary-wrap .iifin-fr-chart-area{
  position:relative; width:100%; max-width:300px; margin:0 auto;
  aspect-ratio:1/1; min-height:240px;
}
#iifin-fr-summary-wrap .iifin-fr-chart-area canvas{ display:block; width:100%!important; height:100%!important; }
#iifin-fr-summary-wrap .iifin-fr-chart-area--line{
  max-width:100%; aspect-ratio:auto; height:280px; min-height:280px;
}
#iifin-fr-summary-wrap .iifin-fr-chart-area--line canvas{ display:block; width:100%!important; height:100%!important; }

.dashboard-page #finance-ai-wrapper {
  position: relative;
  margin-top: 0;
  min-height: 220px;
}
.dashboard-page #finance-ai-content { position: relative; z-index: 1; transition: filter 0.25s ease, opacity 0.25s ease; }

.dashboard-page #finance-ai-locked-overlay{
  position:absolute; inset:0;
  display:none !important;
  align-items:center; justify-content:center;
  padding:20px; z-index:2;
  border-radius:16px;
  background: #fafbfc;
}
.dashboard-page .iifin-ai-lock-inner{
  max-width:720px; width:100%;
  margin:0 auto;
  padding:16px 22px 14px;
  border-radius:18px;
  background: radial-gradient(circle at top left, rgba(241, 237, 231, 0.98), rgba(230, 244, 246, 0.96));
  box-shadow:0 10px 24px rgba(15, 23, 42, 0.16);
  text-align:center;
  color:#111827;
}
.dashboard-page .iifin-ai-lock-title{ font-size:16px; font-weight:600; margin-bottom:6px; }
.dashboard-page .iifin-ai-lock-text{ font-size:13px; color:#4b5563; margin-bottom:12px; line-height:1.45; }
.dashboard-page .iifin-ai-lock-note{
  font-size:12px; color:#6b7280; line-height:1.45;
  margin:0 0 20px;
}
.dashboard-page .iifin-ai-lock-actions{
  display:flex; justify-content:center; margin:0;
}
.dashboard-page .iifin-ai-lock-btn{
  flex-shrink:0;
  padding:12px 24px;
  border-radius:12px;
  font-weight:600;
}

@media (max-width: 600px) {
  .dashboard-page .iifin-ai-lock-inner { padding:18px 16px; border-radius:16px; }
}
@media (max-width: 768px) {
  .dashboard-page #finance-ai-wrapper { min-height: 260px; }
  .dashboard-page #finance-ai-locked-overlay {
    align-items: center;
    padding: 16px;
  }
  .dashboard-page .iifin-ai-lock-inner {
    margin: 0;
    padding: 20px 18px;
  }
}

.dashboard-page .iifin-ai-locked #finance-ai-content,
#finance-ai-wrapper.iifin-ai-locked #finance-ai-content{
  display: none !important;
}
.dashboard-page .iifin-ai-locked #finance-ai-locked-overlay,
#finance-ai-wrapper.iifin-ai-locked #finance-ai-locked-overlay{
  display:flex !important;
}

/* Стили для overlay — #finance-ai-wrapper вне .dashboard-page (в iifin-reports-viewer-overlay) */
#iifin-reports-viewer-overlay #finance-ai-wrapper,
#finance-ai-wrapper {
  position: relative;
  margin-top: 0;
  min-height: 220px;
}
#iifin-reports-viewer-overlay #finance-ai-locked-overlay,
#finance-ai-locked-overlay {
  position: absolute;
  inset: 0;
  display: none !important;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 2;
  border-radius: 16px;
  background: #fafbfc !important;
}
#iifin-reports-viewer-overlay .iifin-ai-lock-inner,
#finance-ai-wrapper .iifin-ai-lock-inner {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  padding: 16px 22px 14px;
  border-radius: 18px;
  background: radial-gradient(circle at top left, rgba(241, 237, 231, 0.98), rgba(230, 244, 246, 0.96));
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.16);
  text-align: center;
  color: #111827;
}
#iifin-reports-viewer-overlay .iifin-ai-lock-title { font-size: 16px; font-weight: 600; margin-bottom: 6px; }
#iifin-reports-viewer-overlay .iifin-ai-lock-text { font-size: 13px; color: #4b5563; margin-bottom: 12px; line-height: 1.45; }
#iifin-reports-viewer-overlay .iifin-ai-lock-note {
  font-size: 12px; color: #6b7280; line-height: 1.45;
  margin: 0 0 20px;
}
#iifin-reports-viewer-overlay .iifin-ai-lock-actions {
  display: flex; justify-content: center; margin: 0;
}
#iifin-reports-viewer-overlay .iifin-ai-lock-btn {
  flex-shrink: 0; padding: 12px 24px; border-radius: 12px; font-weight: 600;
}
#iifin-reports-viewer-overlay #finance-ai-wrapper.iifin-ai-locked #finance-ai-content { display: none !important; }
#iifin-reports-viewer-overlay #finance-ai-wrapper.iifin-ai-locked #finance-ai-locked-overlay { display: flex !important; }
@media (max-width: 768px) {
  #iifin-reports-viewer-overlay #finance-ai-wrapper { min-height: 260px; }
  #iifin-reports-viewer-overlay #finance-ai-locked-overlay { padding: 16px; }
  #iifin-reports-viewer-overlay .iifin-ai-lock-inner { padding: 20px 18px; }
}

.dashboard-page #finance-report-output.report-box section{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:14px;
  padding:12px 14px;
  margin:10px 0;
}
.dashboard-page #finance-report-output.report-box h2{ margin:0 0 8px; font-size:18px; }
.dashboard-page #finance-report-output.report-box h3{ margin:0 0 8px; font-size:15px; color:#0B7E95; }
.dashboard-page #finance-report-output.report-box p{ margin:8px 0; line-height:1.45; }
.dashboard-page #finance-report-output.report-box ul,
.dashboard-page #finance-report-output.report-box ol{ margin:8px 0 8px 18px; }
.dashboard-page #finance-report-output.report-box li{ margin:6px 0; }

.dashboard-page #finance-report-output.report-box p.risk-low{
  border-left:4px solid #10b981;background:#ecfdf5;padding:8px 10px;border-radius:10px;
}
.dashboard-page #finance-report-output.report-box p.risk-medium{
  border-left:4px solid #f59e0b;background:#fffbeb;padding:8px 10px;border-radius:10px;
}
.dashboard-page #finance-report-output.report-box p.risk-high{
  border-left:4px solid #ef4444;background:#fef2f2;padding:8px 10px;border-radius:10px;
}

.dashboard-page .iifin-gen-card{
  display:flex; align-items:flex-start; gap:12px;
  border:1px solid rgba(11,126,149,.35);
  background:#f8fdff;
  border-radius:14px;
  padding:12px 14px;
}
.dashboard-page .iifin-spinner{
  width:20px;height:20px;border-radius:999px;
  border:3px solid rgba(11,126,149,.18);
  border-top-color: var(--primary-600);
  animation:iifin-spin 1s linear infinite;
  flex:0 0 auto;margin-top:2px;
}
@keyframes iifin-spin{ to{ transform:rotate(360deg);} }
.dashboard-page .iifin-gen-title{ font-weight:600; margin:0 0 2px; }
.dashboard-page .iifin-gen-sub{ font-size:13px; color:var(--muted); margin:0; }

.dashboard-page .iifin-button--primary{ position:relative; overflow:hidden; }
.dashboard-page .iifin-button--primary .ripple{
  position:absolute;
  border-radius:999px;
  transform:scale(0);
  opacity:.25;
  background: currentColor;
  animation: iifin-ripple .55s ease-out;
  pointer-events:none;
}
@keyframes iifin-ripple{
  to{ transform:scale(3.2); opacity:0; }
}

@media (max-width: 768px){
  .dashboard-page .pf-wrap{
    max-width: 100%;
    width: 100%;
    padding-left: 12px;
    padding-right: 12px;
    border-radius: 0;
  }
}
@media (max-width: 768px){
  .dashboard-page{
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
  .dashboard-page .pf-wrap{
    max-width: 100%;
    width: 100%;
  }
}

/* Настройки суммари — карточка выбора источника (над KPI) */
.dashboard-page .iifin-summary-settings{
  background: var(--surface-card);
  border: 1px solid var(--stroke-card);
  border-radius: var(--radius-lg);
  padding: var(--spacing-4);
  margin-bottom: var(--spacing-5);
  box-shadow: var(--shadow-sm);
}
/* Десктоп: одна строка; мобильный: две строки */
.dashboard-page .iifin-summary-settings__bar{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px 24px;
}
@media (max-width: 640px){
  .dashboard-page .iifin-summary-settings__bar{
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
}
.dashboard-page .iifin-summary-source-row,
.dashboard-page .iifin-summary-period-row{
  display: flex;
  align-items: center;
  gap: 10px 12px;
}
@media (min-width: 641px){
  .dashboard-page .iifin-summary-period-row{
    margin-left: auto;
  }
}
.dashboard-page .iifin-summary-settings__label{
  font-size: 13px;
  font-weight: 500;
  color: var(--muted-foreground);
  flex-shrink: 0;
}
/* Сегментированный переключатель */
.dashboard-page .iifin-summary-segment{
  display: inline-flex;
  border-radius: var(--radius-md);
  border: 1px solid var(--stroke-field);
  background: var(--surface-raised);
  overflow: hidden;
}
.dashboard-page .iifin-summary-segment__option{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted-foreground);
  cursor: pointer;
  transition: background .15s, color .15s;
}
.dashboard-page .iifin-summary-segment__option:not(:last-child){
  border-right: 1px solid var(--stroke-field);
}
.dashboard-page .iifin-summary-segment__option:hover{
  color: var(--foreground);
}
.dashboard-page .iifin-summary-segment__option input{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.dashboard-page .iifin-summary-segment__option:has(input:checked){
  background: #24A8A6;
  color: #fff;
}
.dashboard-page .iifin-summary-segment__option:has(input:checked):not(:last-child){
  border-right-color: rgba(255,255,255,.3);
}
/* Кнопка инфо + тултип */
.dashboard-page .iifin-summary-info{
  position: relative;
}
.dashboard-page .iifin-summary-info__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: transparent;
  color: var(--muted-foreground);
  cursor: pointer;
  transition: color .15s;
}
.dashboard-page .iifin-summary-info__btn:hover{
  color: var(--foreground);
}
.dashboard-page .iifin-summary-info__btn .material-symbols-outlined{
  font-size: 16px;
}
.dashboard-page .iifin-summary-tooltip{
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(6px);
  max-width: 360px;
  min-width: 280px;
  padding: 14px 16px;
  background: var(--foreground);
  color: var(--surface-card);
  font-size: 13px;
  line-height: 1.5;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .15s, visibility .15s;
  z-index: 10010;
  white-space: pre-line;
}
.dashboard-page .iifin-summary-info:hover .iifin-summary-tooltip,
.dashboard-page .iifin-summary-info__btn:focus + .iifin-summary-tooltip,
.dashboard-page .iifin-summary-tooltip.is-visible{
  opacity: 1;
  visibility: visible;
}
@media (max-width: 640px){
  .dashboard-page .iifin-summary-tooltip{
    left: 50%;
    transform: translateX(calc(-50% - 60px)) translateY(6px);
  }
}
/* Период */
.dashboard-page .iifin-summary-period{
  display: flex;
  align-items: center;
}
.dashboard-page .iifin-summary-months-select{
  height: 36px;
  padding: 0 32px 0 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--stroke-field);
  background: var(--surface-raised);
  font-size: 14px;
  min-width: 72px;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b7280' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
}
/* Кнопка базы данных (ссылка на доходы/расходы) */
.dashboard-page .iifin-summary-db-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 36px;
  border-radius: var(--radius-md);
  border: 1px solid #24A8A6;
  background: transparent;
  color: #24A8A6;
  text-decoration: none;
  transition: background .15s, color .15s;
}
.dashboard-page .iifin-summary-db-btn:hover{
  background: rgba(36,168,166,.12);
  color: #1a8a88;
}
.dashboard-page .iifin-summary-db-btn .material-symbols-outlined{
  font-size: 20px;
}
.dashboard-page .iifin-summary-capped-msg{
  margin-top: 8px;
  padding: 8px 12px;
  background: rgba(245,158,11,.12);
  border-radius: var(--radius-md);
  font-size: 12px;
  color: #92400e;
}

/* KPI карточки — кликабельные для overlay */
.dashboard-page .kpi-card--clickable{
  cursor: pointer;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.dashboard-page .kpi-card--clickable:hover{
  border-color: var(--stroke-focus, rgba(36,168,166,.4));
  box-shadow: var(--shadow-md);
}
.dashboard-page .kpi-card--clickable:focus-visible{
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* KPI Overlay — bottom sheet (mobile) / centered modal (desktop) */
.iifin-kpi-overlay{
  position: fixed; inset: 0; z-index: 10010;
  display: none; align-items: stretch; justify-content: center;
  background: transparent;
  transition: background .25s ease;
}
.iifin-kpi-overlay.is-open{
  display: flex;
  background: rgba(15,23,42,.45);
  cursor: pointer;
}
.iifin-kpi-overlay__backdrop{
  position: absolute; inset: 0; cursor: pointer;
}
.iifin-kpi-overlay__sheet{
  position: relative; z-index: 1;
  width: 100%; max-width: 480px;
  display: flex; flex-direction: column;
  background: var(--surface-card, #fff);
  box-shadow: 0 24px 48px rgba(0,0,0,.2);
  overflow: hidden;
}
/* Desktop: centered modal, высота по содержимому */
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__sheet{
  height: fit-content;
  max-height: 85vh;
  margin: 4vh 16px;
  border-radius: 20px;
}
/* Mobile: bottom sheet */
.iifin-kpi-overlay--mobile .iifin-kpi-overlay__sheet{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  max-height: 85dvh;
  margin: 0;
  border-radius: 20px 20px 0 0;
  transform: translateY(100%);
  transition: transform .3s cubic-bezier(0.32, 0.72, 0, 1);
  padding-bottom: env(safe-area-inset-bottom);
}
.iifin-kpi-overlay--mobile.is-open .iifin-kpi-overlay__sheet{
  transform: translateY(0);
}
.iifin-kpi-overlay__gripper{
  width: 36px; height: 4px;
  background: var(--neutral-300, #d1d5db);
  border-radius: 2px;
  margin: 10px auto 4px;
  flex-shrink: 0;
}
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__gripper{ display: none; }
.iifin-kpi-overlay__header{
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 20px 16px;
  flex-shrink: 0;
}
.iifin-kpi-overlay__title{
  margin: 0; font-size: 18px; font-weight: 700; color: var(--foreground, #111827);
}
.iifin-kpi-overlay__close{
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; padding: 0;
  border: none; border-radius: 12px;
  background: rgba(0,0,0,.06); color: var(--foreground);
  cursor: pointer;
}
.iifin-kpi-overlay__close:hover{ background: rgba(0,0,0,.1); }
.iifin-kpi-overlay__close .material-symbols-outlined{ font-size: 24px; }
/* Mobile: крестик не показывать (ТЗ v2) */
.iifin-kpi-overlay--mobile .iifin-kpi-overlay__close{ display: none !important; }
.iifin-kpi-overlay__body{
  flex: 1; overflow-y: auto; padding: 0 20px 24px;
  -webkit-overflow-scrolling: touch;
  display: flex; flex-direction: column; gap: 16px;
}
.iifin-kpi-overlay__value--main{
  font-size: 28px; font-weight: 700; color: var(--foreground);
  line-height: 1.2;
}
.iifin-kpi-overlay__value--positive{ color: var(--success-dark, #059669); }
.iifin-kpi-overlay__value--negative{ color: var(--danger-dark, #dc2626); }
.iifin-kpi-overlay__trend{
  font-size: 14px; color: var(--muted-foreground);
}
.iifin-kpi-overlay__section{
  background: rgba(0,0,0,.04); border-radius: 12px; padding: 12px 16px;
}
.iifin-kpi-overlay__label{
  font-size: 12px; font-weight: 600; color: var(--muted-foreground);
  margin-bottom: 8px;
}
.iifin-kpi-overlay__row{
  display: flex; justify-content: space-between; align-items: center;
  font-size: 14px; margin-bottom: 4px;
}
.iifin-kpi-overlay__row:last-child{ margin-bottom: 0; }
.iifin-kpi-overlay__meta{
  font-size: 13px; color: var(--muted-foreground);
}
.iifin-kpi-overlay__rec{
  font-size: 14px; line-height: 1.45; color: var(--foreground);
}
.iifin-kpi-overlay__rec--positive{ color: var(--success-dark); }
.iifin-kpi-overlay__rec--negative{ color: var(--danger-dark); }
.iifin-kpi-overlay__status{
  font-size: 14px; font-weight: 600;
}
.iifin-kpi-overlay__status--comfortable{ color: var(--success-dark); }
.iifin-kpi-overlay__status--sufficient{ color: var(--primary); }
.iifin-kpi-overlay__status--basic{ color: var(--warning-dark); }
.iifin-kpi-overlay__status--critical{ color: var(--danger-dark); }
/* CTA — изолирован от глобальных .button и т.п. (ТЗ v2) */
#iifin-kpi-overlay .iifin-kpi-overlay__cta{
  display: inline-flex; align-items: center; justify-content: center;
  padding: 14px 24px; border-radius: 12px;
  background: var(--primary, #24a8a6) !important; color: #fff !important;
  font-family: inherit; font-weight: 600; font-size: 15px; text-decoration: none;
  margin-top: 8px; border: none; box-shadow: none; appearance: none;
  transition: background .2s ease; cursor: pointer;
}
#iifin-kpi-overlay .iifin-kpi-overlay__cta:hover{ background: var(--primary-600, #0b7e95) !important; color: #fff !important; }
/* Mobile: анимация закрытия свайпом вниз */
.iifin-kpi-overlay--mobile.is-closing .iifin-kpi-overlay__sheet{ transform: translateY(100%); }
/* Desktop: высота по контенту, центрирование */
.iifin-kpi-overlay--desktop{ align-items: center; }
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__sheet{ height: fit-content; max-height: 85vh; }

/* KPI карточки — кликабельные */
.dashboard-page .kpi-card--clickable{
  cursor: pointer;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.dashboard-page .kpi-card--clickable:hover{
  border-color: var(--stroke-focus);
  box-shadow: var(--shadow-md);
}
.dashboard-page .kpi-card--clickable:focus-visible{
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* KPI Overlay — bottom sheet (mobile) / centered modal (desktop) */
.iifin-kpi-overlay{
  position: fixed; inset: 0; z-index: 10010;
  display: none; align-items: stretch; justify-content: center;
  background: transparent;
  transition: background .25s ease;
}
.iifin-kpi-overlay.is-open{
  display: flex;
  background: rgba(15, 23, 42, .45);
}
.iifin-kpi-overlay__backdrop{
  position: absolute; inset: 0; cursor: pointer;
}
.iifin-kpi-overlay__sheet{
  position: relative; z-index: 1;
  width: 100%; max-width: 480px; max-height: 85vh;
  display: flex; flex-direction: column;
  background: var(--surface-card);
  box-shadow: 0 24px 48px rgba(0, 0, 0, .2);
  overflow: hidden;
}
/* Desktop: centered modal */
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__sheet{
  margin: 4vh 16px;
  border-radius: 20px;
}
/* Mobile: bottom sheet */
.iifin-kpi-overlay--mobile .iifin-kpi-overlay__sheet{
  position: fixed; left: 0; right: 0; bottom: 0;
  max-height: 80dvh;
  margin: 0;
  border-radius: 20px 20px 0 0;
  transform: translateY(100%);
  transition: transform .3s cubic-bezier(0.32, 0.72, 0, 1);
  padding-bottom: env(safe-area-inset-bottom);
}
.iifin-kpi-overlay--mobile.is-open .iifin-kpi-overlay__sheet{
  transform: translateY(0);
}
.iifin-kpi-overlay__gripper{
  width: 36px; height: 4px;
  background: var(--stroke-field);
  border-radius: 2px;
  margin: 10px auto 4px;
  flex-shrink: 0;
}
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__gripper{ display: none; }
.iifin-kpi-overlay__header{
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 16px 16px;
  border-bottom: 1px solid var(--stroke-field);
  flex-shrink: 0;
}
.iifin-kpi-overlay__title{
  margin: 0; font-size: 18px; font-weight: 700; color: var(--foreground);
}
.iifin-kpi-overlay__close{
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; padding: 0;
  border: none; border-radius: 12px;
  background: transparent;
  color: var(--muted-foreground);
  cursor: pointer;
  transition: background .15s, color .15s;
}
.iifin-kpi-overlay__close:hover{
  background: var(--muted);
  color: var(--foreground);
}
.iifin-kpi-overlay__close .material-symbols-outlined{ font-size: 24px; }
.iifin-kpi-overlay__body{
  flex: 1; overflow-y: auto; padding: 20px;
  -webkit-overflow-scrolling: touch;
  display: flex; flex-direction: column; gap: 16px;
}
.iifin-kpi-overlay__value--main{
  font-size: 28px; font-weight: 700; color: var(--foreground);
  line-height: 1.2;
}
.iifin-kpi-overlay__value--positive{ color: var(--success-dark); }
.iifin-kpi-overlay__value--negative{ color: var(--danger-dark); }
.iifin-kpi-overlay__trend{
  font-size: 14px; color: var(--muted-foreground);
}
.iifin-kpi-overlay__section{
  background: var(--surface-raised);
  border: 1px solid var(--stroke-field);
  border-radius: var(--radius-md);
  padding: 12px 16px;
}
.iifin-kpi-overlay__label{
  font-size: 12px; font-weight: 600; color: var(--muted-foreground);
  margin-bottom: 8px;
}
.iifin-kpi-overlay__row{
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 14px; margin-bottom: 4px;
}
.iifin-kpi-overlay__row:last-child{ margin-bottom: 0; }
.iifin-kpi-overlay__meta{
  font-size: 13px; color: var(--muted-foreground);
}
.iifin-kpi-overlay__rec{
  font-size: 14px; line-height: 1.45; color: var(--foreground);
}
.iifin-kpi-overlay__rec--positive{ color: var(--success-dark); }
.iifin-kpi-overlay__rec--negative{ color: var(--danger-dark); }
.iifin-kpi-overlay__status{
  font-size: 14px; font-weight: 600;
}
.iifin-kpi-overlay__status--comfortable{ color: var(--success-dark); }
.iifin-kpi-overlay__status--sufficient{ color: var(--primary); }
.iifin-kpi-overlay__status--basic{ color: var(--warning-dark); }
.iifin-kpi-overlay__status--critical{ color: var(--danger-dark); }
.iifin-kpi-overlay__cta{
  display: inline-flex; align-items: center; justify-content: center;
  padding: 12px 20px;
  background: var(--primary);
  color: #fff;
  font-weight: 600; font-size: 15px;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background .2s, transform .15s;
  margin-top: 8px;
}
.iifin-kpi-overlay__cta:hover{
  background: var(--primary-600, #0b7e95);
  color: #fff;
}

/* KPI карточки — кликабельные */
.dashboard-page .kpi-card--clickable{
  cursor: pointer;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.dashboard-page .kpi-card--clickable:hover{
  border-color: var(--stroke-focus);
  box-shadow: var(--shadow-md);
}

/* KPI Overlay — bottom sheet (mobile) / centered modal (desktop) */
.iifin-kpi-overlay{
  position: fixed; inset: 0; z-index: 10001;
  display: none; align-items: stretch; justify-content: center;
  background: transparent;
  transition: background .25s ease;
}
.iifin-kpi-overlay.is-open{
  display: flex;
  background: rgba(15, 23, 42, .45);
}
.iifin-kpi-overlay__backdrop{
  position: absolute; inset: 0; cursor: pointer;
}
.iifin-kpi-overlay__sheet{
  position: relative; z-index: 1;
  width: 100%; max-width: 480px; max-height: 85vh;
  display: flex; flex-direction: column;
  background: var(--surface-card);
  box-shadow: 0 24px 48px rgba(0,0,0,.2);
  overflow: hidden;
}
/* Desktop: centered modal */
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__sheet{
  margin: 4vh 16px;
  border-radius: 20px;
}
/* Mobile: bottom sheet */
.iifin-kpi-overlay--mobile .iifin-kpi-overlay__sheet{
  position: fixed; left: 0; right: 0; bottom: 0;
  max-height: 85dvh;
  margin: 0;
  border-radius: 20px 20px 0 0;
  transform: translateY(100%);
  transition: transform .3s cubic-bezier(0.32, 0.72, 0, 1);
  padding-bottom: env(safe-area-inset-bottom);
}
.iifin-kpi-overlay--mobile.is-open .iifin-kpi-overlay__sheet{
  transform: translateY(0);
}
.iifin-kpi-overlay__gripper{
  width: 36px; height: 4px;
  background: var(--neutral-300, #d1d5db);
  border-radius: 2px;
  margin: 10px auto 4px;
  flex-shrink: 0;
}
.iifin-kpi-overlay--desktop .iifin-kpi-overlay__gripper{ display: none; }
.iifin-kpi-overlay__header{
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 16px 16px;
  flex-shrink: 0;
}
.iifin-kpi-overlay__title{
  margin: 0; font-size: 18px; font-weight: 700; color: var(--foreground);
}
.iifin-kpi-overlay__close{
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; padding: 0;
  border: none; border-radius: 12px;
  background: rgba(0,0,0,.06);
  color: var(--foreground);
  cursor: pointer;
}
.iifin-kpi-overlay__close:hover{ background: rgba(0,0,0,.1); }
.iifin-kpi-overlay__close .material-symbols-outlined{ font-size: 22px; }
.iifin-kpi-overlay__body{
  flex: 1; overflow-y: auto; padding: 0 16px 24px;
  -webkit-overflow-scrolling: touch;
}
.iifin-kpi-overlay__value--main{
  font-size: 28px; font-weight: 700; color: var(--foreground);
  margin-bottom: 8px;
}
.iifin-kpi-overlay__value--positive{ color: var(--success-dark, #059669); }
.iifin-kpi-overlay__value--negative{ color: var(--danger-dark, #dc2626); }
.iifin-kpi-overlay__trend{
  font-size: 14px; color: var(--muted-foreground);
  margin-bottom: 16px;
}
.iifin-kpi-overlay__section{
  background: var(--surface-raised);
  border: 1px solid var(--stroke-field);
  border-radius: 12px;
  padding: 12px 14px;
  margin-bottom: 12px;
}
.iifin-kpi-overlay__label{
  font-size: 12px; font-weight: 600; color: var(--muted-foreground);
  margin-bottom: 8px;
}
.iifin-kpi-overlay__row{
  display: flex; justify-content: space-between; align-items: center;
  font-size: 14px; margin-bottom: 4px;
}
.iifin-kpi-overlay__row:last-child{ margin-bottom: 0; }
.iifin-kpi-overlay__meta{
  font-size: 13px; color: var(--muted-foreground);
  margin-bottom: 12px;
}
.iifin-kpi-overlay__rec{
  font-size: 14px; line-height: 1.45; color: var(--foreground);
  margin-bottom: 20px;
  padding: 10px 12px;
  background: rgba(36,168,166,.08);
  border-radius: 10px;
  border-left: 4px solid var(--primary);
}
.iifin-kpi-overlay__rec--positive{ border-left-color: var(--success); background: var(--success-light, rgba(16,185,129,.1)); }
.iifin-kpi-overlay__rec--negative{ border-left-color: var(--danger); background: var(--danger-light, rgba(239,68,68,.1)); }
.iifin-kpi-overlay__rec--neutral{ border-left-color: var(--muted-foreground); background: rgba(0,0,0,.04); }
.iifin-kpi-overlay__status{
  font-size: 14px; font-weight: 600;
  margin-bottom: 12px;
  padding: 6px 10px;
  border-radius: 8px;
  display: inline-block;
}
.iifin-kpi-overlay__status--comfortable{ background: var(--success-light); color: var(--success-dark); }
.iifin-kpi-overlay__status--sufficient{ background: var(--warning-light); color: var(--warning-dark); }
.iifin-kpi-overlay__status--basic{ background: rgba(245,158,11,.2); color: #92400e; }
.iifin-kpi-overlay__status--critical{ background: var(--danger-light); color: var(--danger-dark); }
.iifin-kpi-overlay__cta{
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%; padding: 14px 20px;
  background: var(--primary);
  color: #fff;
  font-weight: 600; font-size: 15px;
  border-radius: 12px;
  text-decoration: none;
  transition: background .2s ease;
}
.iifin-kpi-overlay__cta:hover{ background: var(--primary-600, #0b7e95); color: #fff; }

/* =====================================================================
 * Demo mode styles
 * ===================================================================== */

/* Banner */
.iifin-demo-banner {
  background: linear-gradient(135deg, #0f2b35 0%, #0d5a6a 100%);
  color: #fff;
  position: sticky;
  top: 0;
  z-index: 200;
}
.iifin-demo-banner__inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px 16px;
  max-width: 1220px;
  margin: 0 auto;
  padding: 10px 20px;
}
.iifin-demo-banner__label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.15);
  border-radius: 20px;
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .05em;
  flex-shrink: 0;
}
.iifin-demo-banner__label .material-symbols-outlined { font-size: 14px; }
.iifin-demo-banner__text {
  flex: 1;
  font-size: 13px;
  color: rgba(255,255,255,.82);
  min-width: 160px;
}
.iifin-demo-banner__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.iifin-demo-banner__cta {
  display: inline-flex;
  align-items: center;
  padding: 7px 16px;
  border-radius: 10px;
  background: #24A8A6;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: background .15s ease;
}
.iifin-demo-banner__cta:hover { background: #1a9090; color: #fff; }
.iifin-demo-banner__login {
  font-size: 13px;
  color: rgba(255,255,255,.72);
  text-decoration: none;
}
.iifin-demo-banner__login:hover { color: #fff; }

/* Locked elements */
.iifin-demo-mode .iifin-demo-locked {
  opacity: .72;
  cursor: pointer;
}
.iifin-demo-lock-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 8px;
  background: rgba(36,168,166,.18);
  color: var(--primary, #24A8A6);
  font-size: 11px;
  font-weight: 700;
  margin-left: 4px;
}

/* KPI trend badges */
.dashboard-page .kpi-badge--up  { background: rgba(16,185,129,.14); color: #047857; }
.dashboard-page .kpi-badge--down { background: rgba(239,68,68,.12); color: #b91c1c; }
.dashboard-page .kpi-value--positive { color: var(--success, #059669); }

/* Goal items (demo layout) */
.dashboard-page .goal-item__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.dashboard-page .goal-item__name {
  font-size: 14px;
  font-weight: 600;
  color: var(--foreground);
  display: flex;
  align-items: center;
  gap: 5px;
}
.dashboard-page .goal-item__pct {
  font-size: 13px;
  font-weight: 600;
  color: var(--muted-foreground);
}
.dashboard-page .goal-item__progress { margin-bottom: 6px; }
.dashboard-page .goal-item__bar-track {
  height: 7px;
  background: var(--muted, #f0f0f0);
  border-radius: 999px;
  overflow: hidden;
}
.dashboard-page .goal-item__bar-fill {
  height: 100%;
  background: var(--primary, #24A8A6);
  border-radius: 999px;
  transition: width .5s ease;
}
.dashboard-page .goal-item__bar-fill--done { background: var(--success, #059669); }
.dashboard-page .goal-item__meta {
  font-size: 12px;
  color: var(--muted-foreground);
}
.dashboard-page .goal-item--done .goal-item__name { color: var(--muted-foreground); }
.dashboard-page .goal-item__done-icon {
  font-size: 16px;
  color: var(--success, #059669);
  vertical-align: middle;
}

/* Priority chip active state (demo) */
.dashboard-page .priority-chip--active {
  border-color: var(--primary, #24A8A6);
  background: rgba(36,168,166,.08);
  color: var(--primary, #24A8A6);
  font-weight: 600;
}

/* Muted text in demo */
.iifin-demo-muted { color: var(--muted-foreground); cursor: default; pointer-events: none; }

/* Footer CTA */
.iifin-demo-footer-cta {
  background: linear-gradient(135deg, #0d5a6a 0%, #1399ac 100%);
  padding: 20px;
}
.iifin-demo-footer-cta__inner {
  max-width: 1220px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 14px;
  color: rgba(255,255,255,.88);
}
.iifin-demo-footer-cta__btn {
  display: inline-flex;
  align-items: center;
  padding: 10px 20px;
  border-radius: 12px;
  background: #fff;
  color: #0d5a6a;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  flex-shrink: 0;
  transition: opacity .15s ease;
}
.iifin-demo-footer-cta__btn:hover { opacity: .9; }

/* Demo bottom nav — показываем на мобильном (реальный скрыт т.к. нет авторизации) */
@media (max-width: 1023px) {
  .iifin-demo-bottom-nav {
    display: flex !important;
  }
  /* Отступ снизу, чтобы контент не прятался под панелью */
  .iifin-demo-mode .pf-wrap {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  }
  .iifin-demo-mode .iifin-demo-footer-cta {
    display: none;
  }
}
/* На десктопе скрываем демо-панель (там footer CTA) */
@media (min-width: 1024px) {
  .iifin-demo-bottom-nav {
    display: none !important;
  }
}
