
:root{--app-primary:#5b5ff8;--app-primary-dark:#3730a3;--app-secondary:#8b5cf6;--app-bg:#f4f7ff;--app-card:#ffffff;--app-border:#e8ecfb;--app-text:#1f2937;--app-muted:#6b7280;--app-shadow:0 14px 40px rgba(58,73,140,.10);--app-shadow-soft:0 10px 24px rgba(58,73,140,.08);--app-radius:24px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:"Segoe UI","Hiragino Sans GB","Microsoft YaHei",sans-serif;background:linear-gradient(180deg,#f8faff 0%,#f4f7ff 45%,#eef3ff 100%);color:var(--app-text);min-height:100vh}a{text-decoration:none}.app-shell{position:relative;padding-bottom:88px}.app-noise{position:fixed;inset:0;background:radial-gradient(circle at top left,rgba(91,95,248,.08),transparent 32%),radial-gradient(circle at 90% 10%,rgba(139,92,246,.10),transparent 25%),radial-gradient(circle at 50% 100%,rgba(16,185,129,.06),transparent 30%);pointer-events:none;z-index:0}.login-body{background:radial-gradient(circle at top,#eef2ff 0%,#f8fafc 45%,#f3f4f6 100%)}.app-content,.app-navbar{position:relative;z-index:1}.app-navbar{background:rgba(44,48,113,.82);backdrop-filter:blur(18px);box-shadow:0 16px 40px rgba(34,39,87,.22);border-bottom:1px solid rgba(255,255,255,.08)}.app-nav-inner{min-height:76px}.nav-version{display:inline-flex;align-items:center;justify-content:center;padding:.1rem .48rem;border:1px solid rgba(255,255,255,.22);border-radius:999px;font-size:.72rem;vertical-align:middle;background:rgba(255,255,255,.08)}.brand-mark{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,#a5b4fc,#eef2ff);color:#3730a3;display:inline-flex;align-items:center;justify-content:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}.app-nav-pills .nav-link{color:rgba(255,255,255,.82);padding:.55rem .9rem;border-radius:999px;transition:.18s ease}.app-nav-pills .nav-link:hover,.app-nav-pills .nav-link.active{background:rgba(255,255,255,.14);color:#fff}.app-user-pill{padding:.45rem .8rem;border-radius:999px;background:rgba(255,255,255,.12)}.container{max-width:1280px}.card{border:none;border-radius:var(--app-radius);box-shadow:var(--app-shadow-soft);background:rgba(255,255,255,.94)}.card:hover{box-shadow:var(--app-shadow)}.hero-card{background:linear-gradient(135deg,rgba(91,95,248,.96),rgba(139,92,246,.92));color:#fff}.hero-text{max-width:720px;color:rgba(255,255,255,.86)}.hero-side-card{border-radius:22px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.16);padding:1.1rem 1.2rem;backdrop-filter:blur(6px)}.hero-side-label{font-size:.88rem;color:rgba(255,255,255,.78);margin-bottom:.45rem}.hero-side-value{font-size:2rem;font-weight:800;line-height:1.05}.divider{height:1px;background:rgba(255,255,255,.18)}.metric-card{padding:1.2rem;border-radius:24px;background:rgba(255,255,255,.92);box-shadow:var(--app-shadow-soft);border:1px solid var(--app-border)}.metric-icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:1rem}.metric-card-indigo .metric-icon{background:#eef2ff;color:#4338ca}.metric-card-violet .metric-icon{background:#f5f3ff;color:#7c3aed}.metric-card-emerald .metric-icon{background:#ecfdf5;color:#059669}.metric-card-amber .metric-icon{background:#fff7ed;color:#d97706}.metric-label{color:var(--app-muted);font-size:.92rem;margin-bottom:.45rem}.metric-value{font-size:1.9rem;font-weight:800;line-height:1.1}.metric-note{color:var(--app-muted);font-size:.85rem;margin-top:.45rem}.glass-card{border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,255,255,.76));border:1px solid rgba(255,255,255,.66);box-shadow:var(--app-shadow-soft)}.feed-card,.task-card,.review-item,.habit-card,.compact-feed-item{border:1px solid var(--app-border);border-radius:20px;padding:1rem 1.05rem;background:#fff;box-shadow:0 8px 18px rgba(60,72,110,.05)}.feed-card + .feed-card,.compact-feed-item + .compact-feed-item,.task-card + .task-card,.review-item + .review-item{margin-top:.9rem}.habit-card-inactive{background:#f8fafc;opacity:.82}.mini-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.34rem .72rem;border-radius:999px;background:#eef2ff;color:#4338ca;font-weight:700;font-size:.78rem;letter-spacing:.02em}.quick-actions{display:flex;gap:.8rem;flex-wrap:wrap}.quick-actions .btn{min-height:44px;padding-inline:1rem}.page-head,.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.action-inline{display:flex;gap:.55rem;justify-content:flex-end;flex-wrap:wrap}.empty-state{padding:1rem 1.1rem;border-radius:18px;background:#f8faff;color:var(--app-muted);border:1px dashed #d8def7}.mini-stat{display:flex;justify-content:space-between;align-items:center;padding:.82rem 0;border-bottom:1px dashed #e7ebf8;gap:1rem}.mini-stat:last-child{border-bottom:none;padding-bottom:0}.mini-stat:first-child{padding-top:0}.subtle-card{border:1px solid var(--app-border);background:#fff}.subtle-label,.stat-label{color:var(--app-muted)}.stat-value,.subtle-value{font-weight:800}.table-responsive{border-radius:18px}.table{--bs-table-bg:transparent}.table thead th{font-size:.84rem;color:#64748b;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid #e9eefb}.table>:not(caption)>*>*{padding:.92rem .75rem;border-bottom-color:#eef2fb}.note-row{background:#f8fbff;color:var(--app-muted);font-size:.9rem}.form-label{font-size:.9rem;font-weight:600;color:#4b5563;margin-bottom:.45rem}.form-control,.form-select{border-radius:16px;border-color:#dfe6fb;background:#fbfcff;min-height:46px;padding:.75rem .95rem;box-shadow:none}textarea.form-control{min-height:auto}.form-control:focus,.form-select:focus{border-color:#9aa6ff;box-shadow:0 0 0 .24rem rgba(91,95,248,.12);background:#fff}.btn{border-radius:14px;font-weight:600;min-height:42px}.btn-primary{background:linear-gradient(135deg,#5b5ff8,#7c3aed);border:none;box-shadow:0 10px 20px rgba(91,95,248,.24)}.btn-primary:hover{background:linear-gradient(135deg,#4c52f2,#6d28d9)}.btn-outline-primary{color:#4f46e5;border-color:#cfd8ff;background:rgba(255,255,255,.85)}.btn-outline-primary:hover{background:#eef2ff;border-color:#b7c5ff;color:#4338ca}.btn-outline-secondary{border-color:#dbe2f4;color:#475569;background:#fff}.btn-outline-danger{border-color:#f5c2c7;color:#b42318}.badge{border-radius:999px;padding:.48rem .68rem;font-weight:700}.text-bg-secondary{background:#eef2ff!important;color:#4338ca!important}.text-bg-primary{background:#e0f2fe!important;color:#0c4a6e!important}.text-bg-success{background:#ecfdf5!important;color:#047857!important}.text-bg-warning{background:#fff7ed!important;color:#c2410c!important}.text-bg-danger{background:#fef2f2!important;color:#b91c1c!important}.text-bg-info{background:#eff6ff!important;color:#1d4ed8!important}.text-bg-light{background:#f8fafc!important;color:#64748b!important}code{background:#f4f6fd;padding:.16rem .42rem;border-radius:.45rem}.mobile-hero{background:linear-gradient(135deg,#ffffff,#f4f7ff)}.mobile-entry-card{overflow:hidden}.mobile-entry-tabs{gap:.6rem;overflow:auto;flex-wrap:nowrap}.mobile-entry-tabs .nav-link{white-space:nowrap;border-radius:999px;background:#f3f5ff;color:#475569;padding:.52rem .9rem}.mobile-entry-tabs .nav-link.active{background:linear-gradient(135deg,#5b5ff8,#7c3aed);color:#fff;box-shadow:0 10px 18px rgba(91,95,248,.22)}.mobile-save-btn{min-height:48px}.compact-feed-item{padding:.85rem .95rem;border-radius:18px}.mobile-bottom-nav{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);width:min(94vw,520px);display:grid;grid-template-columns:repeat(6,1fr);gap:.45rem;padding:.55rem;border-radius:24px;background:rgba(26,32,64,.82);backdrop-filter:blur(20px);box-shadow:0 18px 40px rgba(17,24,39,.28);z-index:1080}.mobile-bottom-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.22rem;padding:.55rem .2rem;border-radius:18px;color:rgba(255,255,255,.76);font-size:.76rem}.mobile-bottom-link i{font-size:1.12rem}.mobile-bottom-link.active{background:rgba(255,255,255,.14);color:#fff}.alert{border:none;border-radius:18px;box-shadow:var(--app-shadow-soft)}@media (min-width:992px){.mobile-bottom-nav{display:none}}@media (max-width:991.98px){.container{max-width:100%;padding-left:1rem;padding-right:1rem}.page-head,.section-head{flex-direction:column;align-items:stretch}.action-inline{justify-content:flex-start}.quick-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.quick-actions .btn{width:100%}.hero-card .display-6{font-size:2rem}.card{border-radius:22px}}@media (max-width:575.98px){.app-shell{padding-bottom:96px}.navbar-brand span:nth-child(2){max-width:145px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero-card .display-6,.mobile-hero .h3{font-size:1.65rem}.metric-value{font-size:1.45rem}.mobile-entry-tabs{padding:1rem 1rem 0}.mobile-entry-card .tab-content{padding:1rem!important}.table-responsive{font-size:.94rem}}

.hero-card-v3{background:linear-gradient(135deg,#111827 0%,#312e81 46%,#0f766e 100%)}
.hero-split-board{border-radius:24px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.16);padding:1.15rem 1.2rem;backdrop-filter:blur(10px)}
.hero-split-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.metric-card-teal .metric-icon{background:#ecfeff;color:#0f766e}.metric-card-teal{border-color:#ccfbf1}
.compact-metric{height:100%;padding:1rem 1.05rem;border-radius:22px;background:rgba(255,255,255,.9);border:1px solid var(--app-border);box-shadow:var(--app-shadow-soft);display:flex;flex-direction:column;gap:.35rem}.compact-metric span{font-size:.84rem;color:var(--app-muted)}.compact-metric strong{font-size:1.15rem;line-height:1.25}.compact-metric small{color:var(--app-muted)}
.mobile-summary-grid{align-items:stretch}.mobile-stack .card{overflow:hidden}
.chip-group{display:flex;gap:.55rem;flex-wrap:wrap}.chip-btn{border:none;border-radius:999px;padding:.52rem .86rem;background:#eef2ff;color:#4338ca;font-weight:700;font-size:.83rem;line-height:1;transition:.18s ease}.chip-btn:hover{background:#dfe7ff}.chip-btn.is-hidden{display:none}.small-chips .chip-btn{font-size:.78rem;padding:.45rem .72rem}
.currency-badge{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .6rem;border-radius:999px;font-size:.74rem;font-weight:800;letter-spacing:.04em}.currency-jpy{background:#eef2ff;color:#4338ca}.currency-cny{background:#ecfeff;color:#0f766e}
.summary-box{padding:1rem 1.05rem;border-radius:22px;border:1px solid var(--app-border)}.summary-jpy{background:linear-gradient(180deg,#f8faff,#eef2ff)}.summary-cny{background:linear-gradient(180deg,#f5fffd,#ecfeff)}.summary-box-title{font-size:.8rem;font-weight:800;letter-spacing:.08em;margin-bottom:.75rem;color:#334155}.summary-box-row{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-top:1px dashed #d8def7}.summary-box-row:first-of-type{border-top:none;padding-top:0}
.finance-form-card{overflow:visible}.finance-form-modern .form-control-lg{min-height:52px;font-size:1.15rem}.finance-table-wrap{border-radius:20px}.finance-table tbody tr:hover{background:rgba(91,95,248,.03)}
.mobile-fast-form .form-control,.mobile-fast-form .form-select{min-height:48px}.mobile-fast-form textarea.form-control{min-height:auto}.mobile-fast-form .btn-primary{min-height:50px}
@media (max-width:991.98px){.finance-form-card{position:static!important}.compact-metric strong{font-size:1rem}}
@media (max-width:575.98px){.compact-metric{padding:.9rem}.chip-group{gap:.45rem}.chip-btn{padding:.48rem .76rem;font-size:.78rem}.hero-split-board{padding:1rem}.currency-badge{font-size:.7rem}}


/* V4 */
.recurring-form .form-label, .goal-grid .form-label { font-size: .85rem; color: #667085; }
.recurring-list { display: grid; gap: 12px; }
.recurring-item, .goal-card { border: 1px solid rgba(15,23,42,.08); border-radius: 18px; padding: 14px 16px; background: rgba(255,255,255,.88); }
.habit-metric-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; }
.habit-metric { border-radius: 14px; padding: 10px 12px; background: rgba(79,70,229,.06); }
.habit-metric span { display:block; font-size:.75rem; color:#667085; }
.habit-metric strong { font-size:1rem; }
.goal-grid { display:grid; gap: 12px; }
.countdown-pill { min-width: 78px; text-align:center; border-radius: 999px; padding: 8px 12px; font-weight: 700; background: rgba(79,70,229,.12); color: #4338ca; }
.countdown-pill.countdown-soon { background: rgba(245,158,11,.16); color: #b45309; }
.countdown-pill.countdown-over { background: rgba(239,68,68,.14); color: #b91c1c; }
.auto-review-box { border-radius: 16px; padding: 14px 16px; background: rgba(79,70,229,.06); color: #475467; font-size: .92rem; }
.review-text-block { white-space: normal; line-height: 1.7; }
@media (max-width: 767px) {
  .habit-metric-grid { grid-template-columns: 1fr; }
}

/* V4.1 UI balance patch */
.module-layout-row{align-items:start}
.module-rail-card{overflow:visible}
.recurring-wide-card,.module-rail-card,.module-main .card{scroll-margin-top:96px}
.recurring-wide-grid{align-items:start}
.recurring-panel{padding:1rem 1.05rem;border-radius:20px;border:1px solid var(--app-border);background:linear-gradient(180deg,#fbfcff,#f7f9ff)}
.recurring-list-wide{gap:14px}
.recurring-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.recurring-item-main{flex:1;min-width:0}
.module-main .task-card,.module-main .review-item,.module-main .habit-card{padding:1rem 1.1rem}
.goal-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (min-width:1200px){
  .module-rail{position:sticky;top:96px;align-self:start}
}
@media (max-width:1199.98px){
  .module-rail{position:static}
}
@media (max-width:991.98px){
  .recurring-item{flex-direction:column}
  .module-layout-row{gap:1rem}
}
@media (max-width:767.98px){
  .goal-grid{grid-template-columns:1fr}
  .action-inline{width:100%}
  .action-inline form,.action-inline a,.action-inline button{max-width:100%}
  .table-responsive{overflow-x:auto}
}


/* V5 */
.tool-stack{display:grid;gap:14px}.tool-import-form,.tool-tip-card{border:1px solid var(--app-border);border-radius:20px;padding:1rem 1.05rem;background:linear-gradient(180deg,#fbfcff,#f7f9ff)}
.module-filter-bar,.module-filter-grid{display:grid;gap:12px}.module-filter-grid{grid-template-columns:2fr 1fr 1fr}.module-filter-bar{grid-template-columns:1fr}
.mobile-fab-wrap{position:fixed;right:18px;bottom:98px;z-index:1085;display:flex;flex-direction:column;align-items:flex-end;gap:.7rem}.mobile-fab-main{width:56px;height:56px;border:none;border-radius:50%;background:linear-gradient(135deg,#5b5ff8,#7c3aed);color:#fff;box-shadow:0 18px 34px rgba(91,95,248,.35);font-size:1.2rem}.mobile-fab-menu{display:none;flex-direction:column;gap:.65rem;align-items:flex-end}.mobile-fab-menu.is-open{display:flex}.mobile-fab-link{display:flex;align-items:center;gap:.55rem;padding:.75rem .9rem;border-radius:16px;background:rgba(26,32,64,.92);color:#fff;box-shadow:0 12px 24px rgba(17,24,39,.24)}
[data-search][style*="display: none"]{display:none!important}
@media (min-width:992px){.mobile-fab-wrap{display:none}}
@media (max-width:767.98px){.module-filter-grid{grid-template-columns:1fr}.tool-stack{gap:12px}}


/* V5.1 UI cleanup */
.mobile-hero .text-secondary,
.section-head .text-secondary.small,
.tab-pane > .text-secondary.small,
.tool-tip-card .small.text-secondary,
.auto-review-box { display:none !important; }
.compact-metric small { display:none; }
.card-body .section-head { margin-bottom: .9rem; }
.form-label { margin-bottom: .35rem; }
::placeholder { opacity: .45; }


/* V5.2 dashboard readability */
.hero-card-v3{background:linear-gradient(135deg,#18214b 0%,#2f328c 52%,#166d6a 100%)}
.hero-card-v3 .mini-badge{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.2)}
.hero-card-v3 .display-6{letter-spacing:-.02em}
.hero-card-v3 .hero-text{max-width:38rem;color:rgba(255,255,255,.88);font-size:1.02rem;line-height:1.65}
.hero-card-v3 .quick-actions{gap:.8rem}
.hero-card-v3 .btn-outline-primary{background:rgba(255,255,255,.92);border-color:rgba(255,255,255,.35);color:#24316f}
.hero-card-v3 .btn-outline-primary:hover{background:#fff;color:#1d2a62;border-color:#fff}
.hero-card-v3 .btn-primary{box-shadow:0 12px 24px rgba(91,95,248,.28)}
.hero-split-board{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.24);box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.hero-split-board .divider{border-color:rgba(255,255,255,.18)!important}
.hero-side-label{font-size:.82rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.8)}
.hero-side-value{font-size:2.2rem;line-height:1.1;font-weight:800;letter-spacing:-.02em;color:#fff}
.hero-side-meta{margin-top:.35rem;font-size:.92rem;color:rgba(255,255,255,.78)}
.hero-split-board .text-success{color:#e9ffd8!important}
.hero-split-board .text-danger{color:#ffe2e2!important}
.hero-split-board .fs-4{color:#fff}
@media (max-width:991.98px){.hero-card-v3 .hero-text{font-size:.98rem}.hero-card-v3 .quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:575.98px){.hero-card-v3 .display-6{font-size:1.85rem}.hero-side-value{font-size:1.8rem}.hero-side-meta{font-size:.84rem}}


/* V5.1 personal-use quick wins */
.metric-value-sm{font-size:1.45rem}.quick-inline-actions{display:flex;gap:.6rem;flex-wrap:wrap}.quick-inline-actions .btn{min-height:38px}.tool-stack form{margin:0}
@media (max-width:575.98px){.metric-value-sm{font-size:1.2rem}.quick-inline-actions{display:grid;grid-template-columns:1fr 1fr}}


/* V5.2 personal-use V2 */
.focus-card{background:linear-gradient(180deg,#ffffff,#f7f9ff)}
.focus-task-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}
.focus-task-item{border:1px solid var(--app-border);border-radius:18px;padding:1rem 1.05rem;background:#fff}
.bulk-action-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding:.9rem 1rem;border:1px solid var(--app-border);border-radius:18px;background:linear-gradient(180deg,#fbfcff,#f7f9ff)}
.bulk-action-controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.bulk-action-controls .form-select{min-width:220px}
.task-card-selectable{display:flex;gap:.95rem;align-items:flex-start}.task-card-select{padding-top:.25rem}.task-card-body{flex:1;min-width:0}.task-card-selectable.is-selected{border-color:#b9c6ff;box-shadow:0 12px 24px rgba(91,95,248,.12);background:#f8faff}
.compare-box,.payment-summary-box,.mini-summary-block{border:1px solid var(--app-border);border-radius:18px;padding:.95rem 1rem;background:linear-gradient(180deg,#fbfcff,#f7f9ff)}
.compare-box.cny{background:linear-gradient(180deg,#f5fffd,#ecfeff)}
.empty-inline{font-size:.88rem;color:var(--app-muted)}
.payment-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.quick-filter-links .btn{min-height:36px}
@media (max-width:991.98px){.focus-task-grid,.payment-summary-grid{grid-template-columns:1fr}}
@media (max-width:767.98px){.bulk-action-bar{align-items:stretch}.bulk-action-controls{width:100%}.bulk-action-controls .form-select,.bulk-action-controls .btn{width:100%}}


/* V6.0 stability refactor */
.template-panel{border:1px solid var(--app-border);border-radius:18px;padding:.95rem 1rem;background:linear-gradient(180deg,#fbfcff,#f7f9ff)}
.template-chip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.template-chip{border:1px solid #dbe4ff;border-radius:16px;padding:.78rem .85rem;background:#fff;text-align:left;display:flex;flex-direction:column;gap:.22rem;transition:.18s ease;color:var(--app-text)}
.template-chip:hover{border-color:#bcc9ff;background:#f8faff;box-shadow:0 10px 18px rgba(91,95,248,.08)}
.template-chip-top{font-size:.76rem;font-weight:800;color:#4f46e5;letter-spacing:.02em}
.template-chip strong{font-size:.98rem;line-height:1.2}
.template-chip small{color:var(--app-muted);font-size:.76rem}
.task-quick-filters{display:flex;gap:.55rem;flex-wrap:wrap}
.task-quick-filters .btn{min-height:36px}
.task-quick-filters .btn.is-active{background:linear-gradient(135deg,#5b5ff8,#7c3aed);border-color:transparent;color:#fff;box-shadow:0 10px 18px rgba(91,95,248,.18)}
@media (max-width:991.98px){.template-chip-grid{grid-template-columns:1fr}}


/* V3.1 navbar alignment hotfix */
.app-nav-tools,.app-nav-meta{display:flex;align-items:center}
.app-nav-meta{gap:.65rem}
.app-nav-btn,.app-user-pill{min-height:40px;display:inline-flex;align-items:center;justify-content:center}
.app-nav-btn{padding-inline:.92rem;line-height:1;white-space:nowrap}
.app-user-pill{padding:.45rem .82rem;line-height:1;gap:.35rem;margin-bottom:0}
.app-user-pill i,.app-nav-btn i{display:inline-flex;align-items:center;justify-content:center}
.app-navbar .navbar-collapse{align-items:center}
@media (min-width:992px){
  .app-nav-tools{margin-left:.8rem}
  .app-nav-meta{margin-right:.15rem}
}
@media (max-width:991.98px){
  .app-nav-tools{margin-left:auto}
  .app-nav-meta{margin-top:.4rem;justify-content:flex-start}
}

/* V6.1 filters, snapshots, dictionaries */
.server-filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:end}
.server-filter-actions{display:flex;gap:.65rem;align-items:end}
.server-filter-actions .btn{min-width:96px}
.quick-filter-pills{display:flex;gap:.55rem;flex-wrap:wrap}
.pagination-line{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.pagination-wrap .pagination{margin:0}
.finance-table td,.finance-table th{white-space:nowrap}
.finance-table td:nth-child(6),.finance-table th:nth-child(6){white-space:normal;min-width:180px}
.snapshot-panel{border:1px solid var(--app-border);border-radius:18px;padding:1rem;background:linear-gradient(180deg,#fbfcff,#f7f9ff)}
.snapshot-list{display:flex;flex-direction:column;gap:.7rem}
.snapshot-item{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;padding:.8rem .9rem;border:1px solid var(--app-border);border-radius:16px;background:#fff}
.preset-group + .preset-group{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--app-border)}
.preset-group-head{font-weight:700;font-size:.95rem}
.preset-add-form{display:flex;gap:.55rem;margin-top:.5rem}
.preset-add-form .form-control{min-width:0}
.preset-chip-list{display:flex;flex-wrap:wrap;gap:.5rem}
.preset-chip{display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .68rem;border-radius:999px;border:1px solid #d7dff8;background:#fff;font-size:.82rem;line-height:1.1}
.preset-chip-system{background:#f3f5fb;color:#5f6b88}
.preset-chip.is-disabled{opacity:.55;background:#fafafa}
.preset-chip-actions{display:inline-flex;align-items:center;gap:.35rem}
.preset-chip-actions form{margin:0}
.rule-stack{display:flex;flex-direction:column;gap:.65rem}
.rule-item{padding:.8rem .9rem;border:1px solid var(--app-border);border-radius:16px;background:linear-gradient(180deg,#fff,#fafcff)}
.task-card.is-archived,.task-card-selectable.is-archived{opacity:.88;background:linear-gradient(180deg,#fbfbfd,#f3f4f8);border-color:#d7d7e3}
@media (max-width:1199.98px){.server-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:767.98px){.server-filter-grid{grid-template-columns:1fr}.server-filter-actions{display:grid;grid-template-columns:1fr 1fr}.snapshot-item,.pagination-line{align-items:stretch}.snapshot-item{flex-direction:column}.preset-add-form{display:grid;grid-template-columns:1fr auto}}

/* V6.2 fitness module */
.fitness-exercise-stack,.fitness-mobile-grid,.fitness-exercise-list{display:flex;flex-direction:column;gap:.75rem}
.fitness-inline-card{border:1px solid var(--app-border);border-radius:16px;padding:.8rem .85rem;background:linear-gradient(180deg,#fff,#fafcff)}
.fitness-exercise-line{display:flex;justify-content:space-between;gap:1rem;align-items:center;flex-wrap:wrap;padding:.62rem .1rem;border-bottom:1px dashed #e3e8f6}
.fitness-exercise-line:last-child{border-bottom:none;padding-bottom:0}
.fitness-session-item .badge{font-weight:600}
@media (max-width:767.98px){.fitness-inline-card{padding:.72rem}.fitness-exercise-line{align-items:flex-start}}


/* V7 streamlined forms */
.app-advanced{margin:0;border:1px solid var(--app-border);border-radius:16px;background:linear-gradient(180deg,#fff,#fafcff);overflow:hidden}
.app-advanced summary{list-style:none;cursor:pointer;padding:.82rem .95rem;font-weight:600;color:#44506b}
.app-advanced summary::-webkit-details-marker{display:none}
.app-advanced summary::after{content:"＋";float:right;color:#6a748d}
.app-advanced[open] summary::after{content:"－"}
.app-advanced-body{padding:0 .95rem .95rem;border-top:1px dashed #e3e8f6}
.app-advanced-body .form-label{margin-top:.2rem}

/* V8 A+D mixed shell redesign */
:root{
  --app-primary:#4f6cf7;
  --app-primary-dark:#3755db;
  --app-secondary:#8c6cf8;
  --app-bg:#f5f7fb;
  --app-card:#ffffff;
  --app-border:#e5eaf5;
  --app-text:#182132;
  --app-muted:#6b7280;
  --app-radius:20px;
  --app-shadow:0 16px 36px rgba(31,41,55,.08);
  --app-shadow-soft:0 10px 24px rgba(31,41,55,.05);
}
body.app-shell-v8{background:#f5f7fb;color:var(--app-text)}
.app-noise{background:radial-gradient(circle at top left,rgba(79,108,247,.05),transparent 28%),radial-gradient(circle at 88% 8%,rgba(140,108,248,.06),transparent 20%),radial-gradient(circle at 50% 100%,rgba(16,185,129,.04),transparent 25%)}
.app-shell-container{max-width:1440px;margin:0 auto;padding-left:20px;padding-right:20px}
.app-topbar{background:rgba(255,255,255,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(229,234,245,.9);z-index:1030}
.app-topbar-inner{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.app-brand-wrap{display:flex;align-items:center;gap:12px;min-width:220px}
.app-brand{color:var(--app-text);font-size:1.35rem}
.app-brand:hover{color:var(--app-text)}
.brand-mark{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#4f6cf7,#7b83ff);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 20px rgba(79,108,247,.22)}
.nav-version{display:inline-flex;align-items:center;justify-content:center;padding:.18rem .55rem;border:1px solid var(--app-border);border-radius:999px;font-size:.72rem;background:#fff;color:#64748b}
.app-top-tabs{display:flex;align-items:center;gap:8px;flex:1;justify-content:center}
.app-top-tab{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 16px;border-radius:999px;color:#475569;font-weight:600;transition:.18s ease}
.app-top-tab:hover{background:#edf2ff;color:#2740bf}
.app-top-tab.active{background:#eef3ff;color:#3857df;box-shadow:inset 0 0 0 1px #d9e3ff}
.app-top-actions{display:flex;align-items:center;gap:10px;justify-content:flex-end;min-width:240px}
.app-user-chip{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;background:#fff;border:1px solid var(--app-border);color:var(--app-text);font-weight:600}
.app-user-chip i{font-size:1.05rem;color:#64748b}
.app-workspace{display:grid;grid-template-columns:240px minmax(0,1fr);gap:24px;align-items:start}
.app-sidebar{position:sticky;top:96px}
.app-sidebar-card{display:flex;flex-direction:column;gap:14px;width:100%;padding:18px;border-radius:22px;background:#fff;border:1px solid var(--app-border);box-shadow:var(--app-shadow-soft)}
.app-sidebar-title{font-size:.9rem;font-weight:700;color:#8b95a7;padding:4px 8px}
.app-sidebar-nav,.app-sidebar-footer{display:flex;flex-direction:column;gap:6px}
.app-sidebar-link{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:14px;color:#46546a;font-weight:600;transition:.16s ease}
.app-sidebar-link i{width:18px;text-align:center;color:#7b879b}
.app-sidebar-link:hover{background:#f3f6fd;color:#25324b}
.app-sidebar-link.active{background:#eef3ff;color:#3554df;box-shadow:inset 0 0 0 1px #dce5ff}
.app-sidebar-link.active i{color:#3554df}
.app-sidebar-footer{padding-top:10px;margin-top:6px;border-top:1px solid #eef2f8}
.app-main{min-width:0}
.card,.metric-card,.feed-card,.task-card,.review-item,.habit-card,.compact-feed-item{border:1px solid var(--app-border);border-radius:20px;background:#fff;box-shadow:var(--app-shadow-soft)}
.card:hover{box-shadow:var(--app-shadow-soft)}
.alert{border-radius:16px}
.hero-card,.hero-card-v3{background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);color:var(--app-text);border:1px solid var(--app-border)!important;box-shadow:var(--app-shadow-soft)}
.hero-card .mini-badge,.hero-card-v3 .mini-badge{background:#eef3ff;color:#3554df;border:none}
.hero-card .hero-text,.hero-card-v3 .hero-text{color:#5e6b80}
.hero-card .display-6,.hero-card-v3 .display-6{font-size:2.15rem;color:#111827}
.hero-card .btn-outline-primary,.hero-card-v3 .btn-outline-primary{background:#fff;border-color:#d7e0f5;color:#3554df}
.hero-card .btn-outline-primary:hover,.hero-card-v3 .btn-outline-primary:hover{background:#f3f7ff;color:#2441c6}
.hero-split-board{background:#fbfcff;border:1px solid var(--app-border);box-shadow:none}
.hero-split-board .divider{background:#eef2f8}
.hero-side-label{color:#7a8497}
.hero-side-value{color:#111827}
.hero-side-meta{color:#7a8497}
.hero-split-board .text-success{color:#15803d!important}.hero-split-board .text-danger{color:#dc2626!important}.hero-split-board .fs-4{color:#111827!important}
.metric-card{padding:1.15rem 1.2rem}
.metric-icon{width:44px;height:44px;border-radius:14px;margin-bottom:.9rem}
.metric-label{font-size:.86rem;letter-spacing:.01em;color:#738095;font-weight:600}
.metric-value{font-size:1.75rem;font-weight:800;letter-spacing:-.02em}
.metric-note{font-size:.82rem}
.section-head h1,.section-head h2,.page-head h1,.page-head h2{font-weight:700;color:#111827}
.section-head .text-secondary.small,.page-head .text-secondary.small{color:#7b879b!important}
.quick-filter-pills .btn,.task-quick-filters .btn{border-radius:999px;background:#fff;border-color:#dde5f3;color:#4b5a73}
.quick-filter-pills .btn:hover,.task-quick-filters .btn:hover{background:#f3f7ff;border-color:#cad8f6;color:#3554df}
.form-control,.form-select{border-radius:14px;min-height:44px;background:#fcfdff;border-color:#dbe3f1}
.form-control:focus,.form-select:focus{border-color:#9eb2ff;box-shadow:0 0 0 .24rem rgba(79,108,247,.12)}
textarea.form-control{min-height:88px}
.btn{border-radius:12px;font-weight:600;min-height:40px}
.btn-sm{min-height:34px;border-radius:10px}
.btn-primary{background:linear-gradient(135deg,#4f6cf7,#5f7cff);box-shadow:0 8px 18px rgba(79,108,247,.18)}
.btn-primary:hover{background:linear-gradient(135deg,#3e5dea,#4d6ef3)}
.btn-outline-secondary{background:#fff;border-color:#dbe3f1;color:#475569}
.btn-outline-secondary:hover{background:#f6f9ff;border-color:#cad8f6;color:#2740bf}
.btn-outline-primary{background:#fff;border-color:#d7e0f5;color:#3554df}
.btn-outline-danger{background:#fff}
.table-responsive{border:1px solid var(--app-border);background:#fff}
.table thead th{font-size:.8rem;text-transform:none;letter-spacing:0;color:#7b879b;background:#fbfcfe}
.table>:not(caption)>*>*{padding:.88rem .8rem}
.bulk-action-bar,.compare-box,.payment-summary-box,.mini-summary-block,.template-panel,.snapshot-panel,.rule-item{background:linear-gradient(180deg,#fff,#fafcff);border:1px solid var(--app-border)}
.task-card-selectable,.feed-card,.review-item,.habit-card,.compact-feed-item{border-radius:18px}
.task-card-selectable .btn-sm{padding-inline:.7rem}
.badge{padding:.42rem .62rem;font-weight:700}
.server-filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:14px;border:1px solid var(--app-border);border-radius:18px;background:#fbfcff}
.server-filter-actions{align-items:end}
.pagination-wrap .page-link{border:none;border-radius:10px;color:#48556b;background:#fff;margin:0 2px}
.pagination-wrap .active .page-link{background:#eef3ff;color:#3554df}
.module-layout-row>.module-rail .card,.module-layout-row>.module-main .card{overflow:hidden}
.finance-form-card .card-body,.module-rail-card .card-body{padding:1.25rem}
.summary-box,.summary-jpy,.summary-cny{border:1px solid var(--app-border);border-radius:18px;padding:1rem;background:linear-gradient(180deg,#fff,#f9fbff)}
.summary-box-title{font-weight:700;margin-bottom:.7rem}
.summary-box-row{display:flex;justify-content:space-between;gap:12px;padding:.48rem 0;border-bottom:1px dashed #e9edf5}
.summary-box-row:last-child{border-bottom:none;padding-bottom:0}
.summary-box-row:first-of-type{padding-top:0}
.chip-btn{background:#f5f7ff;color:#3554df;border:1px solid #d9e3ff;border-radius:999px;padding:.48rem .78rem;font-size:.8rem;font-weight:700}
.chip-btn:hover{background:#eef3ff}
.mobile-bottom-nav{background:rgba(255,255,255,.96);border:1px solid var(--app-border);box-shadow:0 14px 28px rgba(17,24,39,.12)}
.mobile-bottom-link{color:#64748b}.mobile-bottom-link.active{background:#eef3ff;color:#3554df}
.mobile-fab-main{background:linear-gradient(135deg,#4f6cf7,#5f7cff);box-shadow:0 14px 28px rgba(79,108,247,.28)}
.mobile-fab-link{background:rgba(17,24,39,.9)}
.text-secondary{color:#7b879b!important}
@media (max-width:1199.98px){
  .app-workspace{grid-template-columns:220px minmax(0,1fr);gap:18px}
}
@media (max-width:991.98px){
  .app-shell-container{padding-left:16px;padding-right:16px}
  .app-topbar-inner{min-height:68px}
  .app-workspace{display:block;padding-top:16px}
  .app-main{width:100%}
  .hero-card .display-6,.hero-card-v3 .display-6{font-size:1.8rem}
  .server-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:767.98px){
  .server-filter-grid{grid-template-columns:1fr;padding:12px}
  .app-top-actions{gap:8px}
  .app-user-chip{padding:8px 12px}
}
@media (max-width:575.98px){
  .app-shell{padding-bottom:96px}
  .hero-card .display-6,.hero-card-v3 .display-6{font-size:1.55rem}
  .metric-value{font-size:1.45rem}
}

/* V8 second-pass page refinement */
.page-section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.page-section-header .h3{font-weight:800;letter-spacing:-.02em;color:#111827}
.page-hero-dashboard .card-body{padding-block:2rem}
.dashboard-side-panel{padding:1rem 1.1rem}
.dashboard-side-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dashboard-side-grid.compact{grid-template-columns:1fr 1fr}
.dashboard-side-item,.dashboard-side-mini{border:1px solid var(--app-border);border-radius:16px;padding:.95rem 1rem;background:#fff}
.dashboard-side-mini span{display:block;font-size:.8rem;color:#7b879b;margin-bottom:.35rem}
.dashboard-side-mini strong{display:block;font-size:1rem;line-height:1.35}
.dashboard-side-mini small{display:block;margin-top:.3rem;color:#7b879b}
.metric-progress{margin-top:.85rem;height:6px;border-radius:999px;background:#edf1f7;overflow:hidden}.metric-progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#4f6cf7,#88a1ff)}
.metric-card-emerald .metric-progress span{background:linear-gradient(90deg,#10b981,#52d8a6)}
.metric-card-amber .metric-progress span{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.metric-card-violet .metric-progress span{background:linear-gradient(90deg,#8b5cf6,#b088ff)}
.dashboard-focus-list,.timeline-stack,.dashboard-next-stack{display:flex;flex-direction:column;gap:12px}
.dashboard-focus-item,.timeline-item,.dashboard-next-card{display:flex;align-items:flex-start;gap:12px;padding:14px 15px;border:1px solid var(--app-border);border-radius:16px;background:#fff}
.dashboard-next-card{flex-direction:column;gap:4px}.dashboard-next-card span{font-size:.8rem;color:#7b879b}.dashboard-next-card strong{font-size:1rem}.dashboard-next-card small{color:#7b879b}.dashboard-next-card.muted{background:#fafcff}
.dashboard-check{width:14px;height:14px;border-radius:50%;border:2px solid #c9d4ea;margin-top:4px;flex:0 0 14px}.dashboard-check.is-done{background:#22c55e;border-color:#22c55e}
.progress-panel-stack{display:flex;flex-direction:column;gap:16px}.progress-panel-item{border:1px solid var(--app-border);border-radius:16px;padding:14px 15px;background:#fff}.progress-panel-value{font-weight:800;font-size:1.2rem}.progress-track{height:10px;border-radius:999px;background:#edf1f7;overflow:hidden}.progress-track span{display:block;height:100%;background:linear-gradient(90deg,#4f6cf7,#88a1ff);border-radius:999px}.progress-track.is-emerald span{background:linear-gradient(90deg,#10b981,#52d8a6)}.progress-track.is-amber span{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.timeline-item{position:relative;padding-left:18px}.timeline-dot{position:absolute;left:0;top:18px;width:9px;height:9px;border-radius:50%;background:#4f6cf7}.timeline-dot.is-finance{background:#8b5cf6}.timeline-dot.is-review{background:#f59e0b}.timeline-dot.is-task{background:#10b981}
.dashboard-health-grid,.finance-insight-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.dashboard-health-card{border:1px solid var(--app-border);border-radius:16px;padding:14px 15px;background:#fff}.dashboard-health-card span{display:block;font-size:.8rem;color:#7b879b;margin-bottom:.35rem}.dashboard-health-card strong{display:block;font-size:1.15rem;line-height:1.35}.dashboard-health-card small{display:block;margin-top:.35rem;color:#7b879b}
@media (max-width:1199.98px){.dashboard-side-grid,.dashboard-side-grid.compact,.dashboard-health-grid,.finance-insight-grid{grid-template-columns:1fr 1fr}}
@media (max-width:767.98px){.dashboard-side-grid,.dashboard-side-grid.compact,.dashboard-health-grid,.finance-insight-grid{grid-template-columns:1fr}.page-section-header{display:block}.page-section-header .d-flex{width:100%}}

/* V9 full-site redesign refinements */
.page-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:1.25rem}
.page-stat-card{border:1px solid var(--app-border);border-radius:18px;padding:1rem 1.05rem;background:linear-gradient(180deg,#fff,#fafcff);box-shadow:var(--app-shadow-soft)}
.page-stat-card span{display:block;font-size:.82rem;color:#7b879b;margin-bottom:.45rem;font-weight:600}
.page-stat-card strong{display:block;font-size:1.45rem;line-height:1.15;letter-spacing:-.02em;color:#111827}
.page-stat-card small{display:block;margin-top:.4rem;color:#7b879b}
.page-stat-card.is-emerald strong{color:#0f9f6e}.page-stat-card.is-violet strong{color:#6d4df2}.page-stat-card.is-amber strong{color:#cf7b00}.page-stat-card.is-indigo strong{color:#3554df}
.workbench-note{padding:.95rem 1rem;border:1px dashed #d9e3f6;border-radius:16px;background:#fbfcff;color:#607086}
.simple-list-stack{display:flex;flex-direction:column;gap:12px}
.simple-list-card{border:1px solid var(--app-border);border-radius:18px;padding:1rem 1.05rem;background:#fff;box-shadow:var(--app-shadow-soft)}
.simple-list-card .meta{font-size:.84rem;color:#7b879b;margin-top:.35rem}
.simple-list-card .body{margin-top:.65rem;color:#334155;font-size:.92rem;line-height:1.65}
.info-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.38rem .62rem;border-radius:999px;background:#f4f7ff;border:1px solid #dbe5ff;color:#3554df;font-size:.78rem;font-weight:700}
.section-card-title{font-size:1.08rem;font-weight:700;color:#111827}
.stretch-card{height:100%}
.tool-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.soft-divider{height:1px;background:#eef2f8;margin:1rem 0}
.user-admin-stack{display:flex;flex-direction:column;gap:10px}
.user-admin-stack form{margin:0}
.migration-banner{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem 1.1rem;border-radius:18px;background:linear-gradient(180deg,#eef4ff,#f8fbff);border:1px solid #d9e3ff}
.migration-banner strong{display:block;font-size:1rem;color:#17306b;margin-bottom:.25rem}
.migration-banner p{margin:0;color:#607086;line-height:1.6}
.compact-table-card .table-responsive{border:none}
@media (max-width:1199.98px){.page-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:767.98px){.page-stat-grid,.tool-grid-2{grid-template-columns:1fr}}

/* V10 charted analytics redesign */
.page-hero-dashboard{overflow:hidden}
.dashboard-chart-grid .card,.analytics-grid .card{overflow:hidden}
.chart-card{height:100%}
.chart-card .card-body{padding:1.1rem 1.15rem 1.05rem}
.chart-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.chart-card-head h3,.chart-card-head h2{font-size:1rem;font-weight:700;margin:0;color:#111827}
.chart-card-head p{margin:4px 0 0;font-size:.82rem;color:#7b879b}
.chart-kpi{display:inline-flex;align-items:center;justify-content:center;padding:.28rem .55rem;border-radius:999px;background:#f3f6fd;color:#4b5a73;font-size:.76rem;font-weight:700;white-space:nowrap}
.chart-canvas{width:100%;height:280px}
.chart-canvas.is-sm{height:240px}
.chart-canvas.is-lg{height:320px}
.analytics-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px}
.analytics-span-4{grid-column:span 4}.analytics-span-5{grid-column:span 5}.analytics-span-6{grid-column:span 6}.analytics-span-7{grid-column:span 7}.analytics-span-8{grid-column:span 8}.analytics-span-12{grid-column:span 12}
.chart-info-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.chart-info-row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:.65rem .8rem;border-radius:14px;background:#fbfcff;border:1px solid var(--app-border)}
.chart-info-row strong{font-size:.95rem}
.chart-info-row small{color:#7b879b}
.ring-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.ring-stat{padding:.85rem .9rem;border-radius:16px;background:#fbfcff;border:1px solid var(--app-border)}
.ring-stat span{display:block;font-size:.78rem;color:#7b879b;margin-bottom:6px}.ring-stat strong{font-size:1.1rem}
.dashboard-health-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.dashboard-health-card,.dashboard-next-card{padding:1rem;border-radius:18px;background:#fbfcff;border:1px solid var(--app-border)}
.dashboard-health-card span,.dashboard-next-card span{display:block;font-size:.8rem;color:#7b879b;margin-bottom:8px}.dashboard-health-card strong,.dashboard-next-card strong{display:block;font-size:1.2rem;line-height:1.2}.dashboard-health-card small,.dashboard-next-card small{display:block;margin-top:6px;color:#7b879b}
.dashboard-next-stack{display:flex;flex-direction:column;gap:12px}.dashboard-next-card.muted{background:#f8fafc}
.progress-panel-stack{display:flex;flex-direction:column;gap:16px}.progress-panel-item{padding:1rem;border-radius:18px;background:#fbfcff;border:1px solid var(--app-border)}
.progress-track{height:10px;border-radius:999px;background:#eef2f8;overflow:hidden}.progress-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#4f6cf7,#7c8fff)}
.progress-track.is-emerald span{background:linear-gradient(90deg,#10b981,#34d399)}
.progress-track.is-amber span{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.progress-panel-value{font-size:1.05rem;font-weight:800}
.timeline-stack{display:flex;flex-direction:column;gap:12px}.timeline-item{display:flex;gap:12px;align-items:flex-start;padding:.9rem;border:1px solid var(--app-border);border-radius:16px;background:#fbfcff}.timeline-dot{width:10px;height:10px;border-radius:50%;margin-top:.4rem;flex:none}.timeline-dot.is-task{background:#4f6cf7}.timeline-dot.is-finance{background:#10b981}.timeline-dot.is-review{background:#8b5cf6}
.page-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:1.25rem}.page-stat-card{padding:1rem 1.05rem;border-radius:20px;border:1px solid var(--app-border);background:linear-gradient(180deg,#fff,#fafcff);box-shadow:var(--app-shadow-soft)}.page-stat-card span{display:block;font-size:.82rem;color:#7b879b;margin-bottom:.5rem}.page-stat-card strong{display:block;font-size:1.45rem;line-height:1.2;margin-bottom:.2rem}.page-stat-card small{color:#7b879b}.page-stat-card.is-indigo{background:linear-gradient(180deg,#ffffff,#f6f8ff)}.page-stat-card.is-violet{background:linear-gradient(180deg,#ffffff,#faf7ff)}.page-stat-card.is-emerald{background:linear-gradient(180deg,#ffffff,#f5fdf9)}.page-stat-card.is-amber{background:linear-gradient(180deg,#ffffff,#fffaf2)}
.simple-list-stack{display:flex;flex-direction:column;gap:12px}.simple-list-card{padding:1rem;border:1px solid var(--app-border);border-radius:18px;background:#fff}.simple-list-card .meta{font-size:.83rem;color:#7b879b;margin-top:.35rem}.simple-list-card .body{margin-top:.55rem;color:#4b5563}
.goal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.goal-card{padding:1rem;border-radius:18px;border:1px solid var(--app-border);background:#fbfcff}.countdown-pill{padding:.35rem .6rem;border-radius:999px;background:#eef3ff;color:#3554df;font-weight:700;font-size:.78rem}.countdown-pill.countdown-soon{background:#fff7ed;color:#c2410c}.countdown-pill.countdown-over{background:#fef2f2;color:#b91c1c}
.migration-banner{padding:1rem 1.1rem;border-radius:18px;border:1px solid #fde68a;background:linear-gradient(180deg,#fffef7,#fff9e8)}
.workbench-note{padding:1rem;border-radius:18px;border:1px dashed var(--app-border);color:#617085;background:#fbfcff}
.info-chip{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .58rem;border-radius:999px;background:#eef3ff;color:#3554df;font-size:.78rem;font-weight:700}
.dashboard-side-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.dashboard-side-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-side-item,.dashboard-side-mini{padding:.95rem;border-radius:16px;background:#fff;border:1px solid var(--app-border)}
.dashboard-side-mini span{display:block;font-size:.78rem;color:#7b879b;margin-bottom:6px}.dashboard-side-mini strong{display:block;font-size:.98rem;line-height:1.35}.dashboard-side-mini small{display:block;margin-top:5px;color:#7b879b}
.module-filter-bar,.module-filter-grid{display:grid;gap:12px}.module-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.compact-table-card{border:1px solid var(--app-border);border-radius:18px;overflow:hidden}
@media (max-width:1199.98px){.analytics-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.analytics-span-8,.analytics-span-7,.analytics-span-6,.analytics-span-5,.analytics-span-4{grid-column:span 6}.page-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-health-grid{grid-template-columns:1fr}.goal-grid{grid-template-columns:1fr}}
@media (max-width:767.98px){.analytics-grid{grid-template-columns:1fr}.analytics-span-12,.analytics-span-8,.analytics-span-7,.analytics-span-6,.analytics-span-5,.analytics-span-4{grid-column:span 1}.page-stat-grid{grid-template-columns:1fr}.dashboard-side-grid,.dashboard-side-grid.compact,.ring-stat-grid,.module-filter-grid{grid-template-columns:1fr}.chart-canvas,.chart-canvas.is-lg,.chart-canvas.is-sm{height:240px}}

.chart-empty-state{height:100%;min-height:220px;display:flex;align-items:center;justify-content:center;text-align:center;padding:1rem 1.25rem;color:#7b879b;font-size:.92rem;background:linear-gradient(180deg,#fbfcff,#f7f9fd);border:1px dashed #d8e0ef;border-radius:16px}

/* V10.2 chart performance tuning */
.chart-canvas{position:relative;contain:layout paint style;transform:translateZ(0)}
.chart-canvas::before{content:"";position:absolute;inset:0;border-radius:16px;background:linear-gradient(90deg,rgba(243,246,253,.85) 0%,rgba(255,255,255,.98) 50%,rgba(243,246,253,.85) 100%);background-size:220% 100%;animation:chartPulse 1.6s ease-in-out infinite;opacity:0;pointer-events:none}
.chart-canvas:not([data-chart-booted="1"]):empty::before{opacity:1}
@keyframes chartPulse{0%{background-position:200% 0}100%{background-position:-20% 0}}
@supports (content-visibility:auto){
  .analytics-grid > .card,
  .dashboard-side-grid > .card,
  .module-main > .card,
  .module-rail > .card{content-visibility:auto;contain-intrinsic-size:360px}
}

/* V10.3 UI polish */
body.app-shell-v8{background:linear-gradient(180deg,#f7f9fc 0%,#f3f6fb 100%)}
.app-topbar{background:rgba(255,255,255,.92);backdrop-filter:blur(18px);box-shadow:0 10px 28px rgba(15,23,42,.04)}
.app-topbar-inner{min-height:78px}
.app-brand{font-size:1.28rem;letter-spacing:-.02em}
.app-top-tab{padding:0 18px;min-height:42px}
.app-top-tab.active{background:linear-gradient(180deg,#eef3ff,#f7f9ff);box-shadow:inset 0 0 0 1px #d7e2ff,0 6px 12px rgba(79,108,247,.06)}
.app-user-chip{background:linear-gradient(180deg,#fff,#fbfcff);box-shadow:0 8px 18px rgba(15,23,42,.05)}
.app-sidebar-card{padding:20px;border-radius:24px;box-shadow:0 18px 40px rgba(15,23,42,.05)}
.app-sidebar-title{padding:2px 8px 10px;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}
.app-sidebar-link{padding:12px 14px;border-radius:16px}
.app-sidebar-link.active{background:linear-gradient(180deg,#edf2ff,#f7f9ff);box-shadow:inset 0 0 0 1px #dbe4ff,0 10px 20px rgba(79,108,247,.06)}
.app-main > .alert{margin-bottom:14px}
.card,.metric-card,.feed-card,.task-card,.review-item,.habit-card,.compact-feed-item,.page-stat-card,.module-rail-card{border-color:#e4eaf3;box-shadow:0 16px 34px rgba(15,23,42,.045)}
@media (hover:hover){
  .card:hover,.page-stat-card:hover,.metric-card:hover,.task-card:hover{transform:translateY(-1px);box-shadow:0 18px 36px rgba(15,23,42,.06)}
}
.page-section-header{padding:18px 20px;border:1px solid var(--app-border);border-radius:22px;background:linear-gradient(135deg,#ffffff 0%,#f8fbff 65%,#f3f7ff 100%);box-shadow:var(--app-shadow-soft)}
.page-section-header .mini-badge{box-shadow:inset 0 0 0 1px #dde7ff;background:#f3f6ff}
.page-section-header h1{font-size:1.95rem;letter-spacing:-.03em}
.page-section-header .text-secondary{max-width:640px;font-size:.96rem}
.page-stat-grid{gap:14px;margin-bottom:1.4rem}
.page-stat-card{position:relative;overflow:hidden;padding:1.05rem 1.1rem 1rem;border-radius:22px}
.page-stat-card::before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:linear-gradient(90deg,#4f6cf7,#8b5cf6)}
.page-stat-card.is-emerald::before{background:linear-gradient(90deg,#10b981,#34d399)}
.page-stat-card.is-amber::before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.page-stat-card.is-violet::before{background:linear-gradient(90deg,#8b5cf6,#b088ff)}
.page-stat-card span{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:#7d8797}
.page-stat-card strong{font-size:1.58rem;margin-bottom:.25rem}
.page-stat-card small{line-height:1.45}
.metric-card{border-radius:22px;padding:1.15rem 1.2rem;background:linear-gradient(180deg,#fff,#fafcff)}
.metric-value{font-size:1.82rem}
.metric-note{line-height:1.45}
.metric-progress{height:7px;background:#edf2fb}
.chart-card{position:relative;border-radius:24px;overflow:hidden;background:linear-gradient(180deg,#ffffff 0%,#fcfdff 100%)}
.chart-card::before{content:"";position:absolute;left:0;top:0;right:0;height:1px;background:linear-gradient(90deg,rgba(79,108,247,.10),rgba(139,92,246,.16),rgba(16,185,129,.10))}
.chart-card .card-body{padding:1.2rem 1.25rem 1.15rem}
.chart-card-head{margin-bottom:14px;gap:16px}
.chart-card-head h2,.chart-card-head h3{font-size:1.04rem;letter-spacing:-.01em}
.chart-card-head p{font-size:.83rem;line-height:1.55;max-width:32rem}
.chart-kpi{padding:.34rem .68rem;background:linear-gradient(180deg,#f3f6fd,#eef3ff);border:1px solid #dde6f7;color:#425168;min-height:30px}
.chart-canvas{height:300px;border-radius:18px}
.chart-canvas.is-sm{height:250px}
.chart-canvas.is-lg{height:340px}
.chart-info-list{gap:12px}
.chart-info-row{padding:.82rem .9rem;border-radius:16px;background:linear-gradient(180deg,#fbfcfe,#f8faff)}
.chart-info-row strong{font-size:1rem;letter-spacing:-.01em}
.chart-info-row small{line-height:1.45}
.dashboard-focus-item,.timeline-item,.dashboard-next-card,.progress-panel-item,.dashboard-health-card,.ring-stat,.simple-list-card,.rule-item,.snapshot-item,.template-chip,.focus-task-item{border-radius:18px}
.dashboard-focus-item,.timeline-item{background:linear-gradient(180deg,#fff,#fbfcff)}
.dashboard-next-card,.dashboard-health-card,.progress-panel-item{background:linear-gradient(180deg,#fff,#f9fbff)}
.timeline-item{padding:1rem 1rem 1rem 1.05rem}
.timeline-dot{box-shadow:0 0 0 4px rgba(79,108,247,.08)}
.empty-state{display:flex;align-items:center;justify-content:center;min-height:108px;padding:1.2rem;border-radius:18px;background:linear-gradient(180deg,#fbfcff,#f7f9fd);border:1px dashed #dbe4f4;color:#718198;text-align:center;line-height:1.6}
.chart-empty-state{min-height:250px;border-style:solid;background:linear-gradient(180deg,#fbfcff,#f7f9fd)}
.server-filter-grid{padding:16px;border-radius:20px;background:linear-gradient(180deg,#ffffff,#fbfcff);box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.server-filter-grid .form-label{font-size:.77rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#7c889b}
.server-filter-actions .btn{min-width:104px}
.bulk-action-bar{padding:1rem 1.05rem;border-radius:20px;background:linear-gradient(180deg,#ffffff,#f9fbff)}
.task-card{border-radius:20px;padding:1.05rem 1.1rem;background:linear-gradient(180deg,#ffffff,#fbfcff)}
.task-card-selectable{gap:1rem}
.task-card-selectable.is-selected{background:linear-gradient(180deg,#f8fbff,#f3f7ff)}
.task-card-body .fw-semibold{font-size:1rem;color:#152033}
.task-card-body .small{line-height:1.5}
.table-responsive{border-radius:20px;border:1px solid var(--app-border);overflow:auto;background:#fff}
.table{margin-bottom:0}
.table thead th{position:sticky;top:0;z-index:2;background:linear-gradient(180deg,#fbfcfe,#f6f9fd);font-size:.79rem;font-weight:700;color:#7b879b;letter-spacing:.04em}
.table tbody tr{transition:background .15s ease,transform .15s ease}
.table tbody tr:hover{background:#f8fbff}
.finance-table tbody td,.finance-table tbody th{vertical-align:middle}
.finance-table td:nth-child(5){font-variant-numeric:tabular-nums}
.pagination-line{padding-top:.2rem}
.pagination-wrap .page-link{background:linear-gradient(180deg,#fff,#fbfcff);border:1px solid #e3eaf4;box-shadow:none}
.pagination-wrap .active .page-link{border-color:#dbe4ff;box-shadow:0 6px 14px rgba(79,108,247,.08)}
.summary-box,.summary-jpy,.summary-cny,.template-panel,.snapshot-panel,.compare-box,.payment-summary-box,.mini-summary-block{border-radius:20px;background:linear-gradient(180deg,#ffffff,#fbfcff)}
.summary-box-title{font-size:.94rem;letter-spacing:-.01em}
.summary-box-row{padding:.58rem 0}
.chip-btn{background:linear-gradient(180deg,#f7f9ff,#eef3ff);border-color:#d9e3ff;box-shadow:0 4px 10px rgba(79,108,247,.04)}
.chip-btn:hover{background:linear-gradient(180deg,#eef3ff,#e8efff)}
.compact-table-card,.module-rail-card,.finance-form-card{border-radius:22px}
.form-control,.form-select{background:linear-gradient(180deg,#fdfefe,#f9fbff)}
.form-control.form-control-lg{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}
.workbench-note,.migration-banner{border-radius:20px}
.migration-banner{box-shadow:0 10px 22px rgba(245,158,11,.07)}
.chart-canvas::before{border-radius:18px}
@media (max-width:991.98px){
  .page-section-header{padding:16px 16px 15px}
  .page-section-header h1{font-size:1.6rem}
  .chart-card .card-body{padding:1rem}
  .chart-canvas.is-lg{height:300px}
}
@media (max-width:767.98px){
  .page-stat-card strong{font-size:1.42rem}
  .chart-canvas,.chart-canvas.is-lg,.chart-canvas.is-sm{height:230px}
  .chart-empty-state{min-height:220px}
  .server-filter-grid{padding:12px}
}

/* V10.4 real-only UI cleanup */
html{scroll-padding-top:96px}
#account-overview,#account-backup,#account-dictionary{scroll-margin-top:104px}
.real-actions-panel{background:linear-gradient(180deg,#ffffff 0%,#fbfcff 100%)}
.real-action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.real-action-card{display:flex;align-items:flex-start;gap:12px;padding:1rem 1.05rem;border:1px solid var(--app-border);border-radius:18px;background:#fff;color:var(--app-text);transition:.18s ease;min-height:100%}
.real-action-card:hover{transform:translateY(-1px);background:#f9fbff;border-color:#d7e2f6;box-shadow:0 10px 24px rgba(31,41,55,.06);color:var(--app-text)}
.real-action-card .icon{width:38px;height:38px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#f3f6ff,#eef3ff);color:#3554df;flex:0 0 38px}
.real-action-card strong{display:block;font-size:.95rem;line-height:1.35}
.real-action-card small{display:block;margin-top:4px;color:#7b879b;line-height:1.45}
.app-sidebar-link{position:relative}
.app-sidebar-link.active::after{content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:999px;background:#3554df;opacity:.8}
.table-responsive thead th{position:sticky;top:0;z-index:2}
.table tbody tr:hover{background:#fafcff}
.action-inline .btn-sm{padding-inline:.72rem}
.page-section-header .btn{min-height:38px}
.page-section-header .text-secondary{line-height:1.6}
.timeline-item{padding:.8rem .85rem;border-radius:16px;background:#fff;border:1px solid var(--app-border)}
.timeline-item + .timeline-item{margin-top:10px}
.snapshot-item,.preset-chip,.rule-item,.template-chip,.simple-list-card{box-shadow:none}
.snapshot-item:hover,.simple-list-card:hover,.real-action-card:hover{box-shadow:0 10px 24px rgba(31,41,55,.06)}
@media (max-width:1199.98px){
  .real-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:767.98px){
  html{scroll-padding-top:72px}
  .real-action-grid{grid-template-columns:1fr}
}


/* V8.0.2 schedule filter polish */
.schedule-filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:16px;border:1px solid var(--app-border);border-radius:20px;background:linear-gradient(180deg,#ffffff,#fbfcff);box-shadow:inset 0 1px 0 rgba(255,255,255,.72)}
.schedule-filter-item{min-width:0}
.schedule-filter-item.filter-span-2{grid-column:span 2}
.schedule-filter-item .form-control,.schedule-filter-item .form-select{min-height:46px;border-radius:16px}
.schedule-filter-actions-wrap{display:flex;flex-direction:column;justify-content:flex-end}
.server-filter-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:stretch}
.server-filter-actions .btn{min-height:46px;min-width:0;border-radius:16px}
.quick-filter-pills .btn{display:inline-flex;align-items:center;gap:8px;padding:.48rem .78rem;border-radius:999px}
.quick-filter-pills .btn.is-active{box-shadow:0 10px 20px rgba(79,108,247,.16)}
.quick-filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:26px;padding:0 8px;height:24px;border-radius:999px;background:rgba(79,108,247,.1);color:inherit;font-size:.78rem;font-weight:700}
.quick-filter-pills .btn-primary .quick-filter-count{background:rgba(255,255,255,.18);color:#fff}
.filter-chip-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 12px;border-radius:16px;background:#f8fbff;border:1px solid #e4ebf7}
.filter-chip-label{font-size:.82rem;font-weight:700;color:#66758a}
.filter-chip{display:inline-flex;align-items:center;padding:.34rem .66rem;border-radius:999px;background:#fff;border:1px solid #dde6f5;color:#49566c;font-size:.82rem;line-height:1.2}
@media (max-width:1199.98px){
  .schedule-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .schedule-filter-item.filter-span-2{grid-column:span 2}
}
@media (max-width:991.98px){
  .schedule-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .schedule-filter-item.filter-span-2,.schedule-filter-actions-wrap{grid-column:span 2}
}
@media (max-width:767.98px){
  .schedule-filter-grid{grid-template-columns:1fr;padding:12px}
  .schedule-filter-item.filter-span-2,.schedule-filter-actions-wrap{grid-column:span 1}
  .server-filter-actions{grid-template-columns:1fr}
  .quick-filter-pills .btn{padding:.48rem .7rem}
}

/* V8 finance account / credit card management */
.account-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
}
.finance-account-card {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 18px;
    padding: 16px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    box-shadow: 0 8px 24px rgba(15, 23, 42, .05);
}
.finance-account-card.is-muted {
    opacity: .55;
    filter: grayscale(.25);
}
.finance-account-progress {
    height: 9px;
    border-radius: 99px;
    background: #e9eef7;
    overflow: hidden;
}
.finance-account-progress > div {
    height: 100%;
    border-radius: 99px;
    background: linear-gradient(90deg, #4f6cf7, #f59e0b, #ef4444);
}
.account-kv {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 6px 0;
    border-bottom: 1px dashed rgba(100, 116, 139, .22);
    font-size: .9rem;
}
.account-kv span { color: #64748b; }
.account-kv strong { text-align: right; }
.account-create-form,
.account-edit-form {
    border-top: 1px solid rgba(15, 23, 42, .08);
    padding-top: 12px;
}

/* V9 LifeOps layout */
.app-shell-v9 .page-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.35rem;border-radius:24px;background:linear-gradient(135deg,rgba(79,108,247,.10),rgba(16,185,129,.08));border:1px solid rgba(148,163,184,.22)}
.app-shell-v9 .eyebrow{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:#64748b;font-weight:800;margin-bottom:.25rem}
.app-shell-v9 .page-hero h1{font-size:1.7rem;font-weight:800;margin:0;color:#172033}
.app-shell-v9 .metric-card{height:100%;padding:1rem;border-radius:20px;background:#fff;border:1px solid rgba(148,163,184,.22);box-shadow:0 10px 24px rgba(15,23,42,.06)}
.app-shell-v9 .metric-card span{display:block;color:#64748b;font-size:.82rem;margin-bottom:.35rem}.app-shell-v9 .metric-card strong{display:block;font-size:1.35rem;color:#172033}.app-shell-v9 .metric-card small{display:block;color:#94a3b8;margin-top:.25rem}
.app-shell-v9 .card-soft{padding:1.15rem;border-radius:24px;background:#fff;border:1px solid rgba(148,163,184,.22);box-shadow:0 12px 30px rgba(15,23,42,.06)}
.app-shell-v9 .card-soft h2{font-size:1.1rem;font-weight:800;color:#172033;margin-bottom:.8rem}.app-shell-v9 .card-soft h3{font-weight:800}.app-shell-v9 .section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.app-shell-v9 .section-head p{margin:0;color:#64748b;font-size:.9rem}
.app-shell-v9 .action-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 0;border-bottom:1px solid rgba(148,163,184,.18)}.app-shell-v9 .action-row:last-child{border-bottom:0}.app-shell-v9 .danger-soft{background:rgba(239,68,68,.035);margin:0 -.5rem;padding:.85rem .5rem;border-radius:16px}
.app-shell-v9 .notice{padding:.8rem .9rem;border-radius:16px;margin-bottom:.65rem;border:1px solid rgba(148,163,184,.18)}.app-shell-v9 .notice.success{background:rgba(16,185,129,.08);color:#047857}.app-shell-v9 .notice.warning{background:rgba(245,158,11,.10);color:#92400e}.app-shell-v9 .notice.danger{background:rgba(239,68,68,.08);color:#b91c1c}
.app-shell-v9 .empty-state{padding:1rem;border-radius:18px;background:#f8fafc;color:#64748b;text-align:center}.app-shell-v9 .small-empty{padding:.45rem;text-align:left}.app-shell-v9 .app-subnav .nav-link{border-radius:999px}.app-shell-v9 .display-mini{font-size:1.45rem;font-weight:850;color:#111827}.app-shell-v9 .mini-list-item{display:flex;justify-content:space-between;gap:.75rem;padding:.55rem 0;border-bottom:1px solid rgba(148,163,184,.16)}
@media(max-width:767px){.app-shell-v9 .page-hero{display:block}.app-shell-v9 .action-row{align-items:flex-start;flex-direction:column}.app-shell-v9 .action-row form{width:100%}.app-shell-v9 .action-row .form-control{width:100%!important}}

/* V9.5 UI analytics polish */
:root{--v95-ink:#0f172a;--v95-soft:#f8fbff;--v95-line:#e6edf7;--v95-primary:#4f6cf7;--v95-success:#10b981;--v95-warn:#f59e0b;--v95-danger:#ef4444}
.app-shell-v9{background:linear-gradient(180deg,#f7faff 0%,#f2f6ff 48%,#eef4ff 100%)}
.app-shell-v9 .app-workspace{display:grid;grid-template-columns:238px minmax(0,1fr);gap:22px;align-items:start}
.app-shell-v9 .app-main{min-width:0}
.app-shell-v9 .app-topbar{background:rgba(255,255,255,.78);border-bottom:1px solid rgba(222,230,242,.82);box-shadow:0 12px 34px rgba(15,23,42,.05)}
.app-shell-v9 .app-brand{color:var(--v95-ink)}
.app-shell-v9 .app-top-tab{display:inline-flex;align-items:center;min-height:38px;padding:.45rem .9rem;border-radius:999px;color:#526174;font-weight:700;transition:.18s ease}
.app-shell-v9 .app-top-tab:hover{background:#f2f6ff;color:#25324b}
.app-shell-v9 .app-top-tab.active{background:linear-gradient(135deg,#edf2ff,#f7f9ff);color:#3554df;box-shadow:inset 0 0 0 1px #dae4ff}
.app-shell-v9 .app-user-chip{display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .72rem;border-radius:999px;background:#f6f8ff;color:#354154;font-weight:700;border:1px solid #e5ebf7}
.app-shell-v9 .page-hero-v95{background:radial-gradient(circle at 8% 0%,rgba(79,108,247,.16),transparent 32%),radial-gradient(circle at 100% 0%,rgba(16,185,129,.14),transparent 26%),linear-gradient(135deg,#ffffff,#f6f9ff);box-shadow:0 18px 45px rgba(15,23,42,.055)}
.hero-action-panel{display:flex;flex-wrap:wrap;gap:.55rem;justify-content:flex-end;max-width:440px}
.app-shell-v9 .metric-card.metric-glow{position:relative;overflow:hidden;background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)}
.app-shell-v9 .metric-card.metric-glow::after{content:"";position:absolute;right:-24px;top:-28px;width:76px;height:76px;border-radius:50%;background:rgba(79,108,247,.08)}
.dashboard-kpi-row .metric-card strong{font-size:1.45rem;letter-spacing:-.02em}
.app-shell-v9 .notice.info{background:rgba(79,108,247,.08);color:#2741a7;border-color:rgba(79,108,247,.14)}
.chart-kpi{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;padding:.24rem .58rem;border-radius:999px;background:#f2f6ff;color:#3554df;font-size:.76rem;font-weight:800;border:1px solid #e0e8ff}
.app-shell-v9 .chart-card{border:1px solid rgba(148,163,184,.2)!important;box-shadow:0 16px 38px rgba(15,23,42,.055)!important}
.app-shell-v9 .chart-card:hover{transform:translateY(-1px);box-shadow:0 22px 48px rgba(15,23,42,.075)!important}
.app-shell-v9 .chart-card-head{align-items:flex-start}
.app-shell-v9 .chart-canvas{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)}
.app-shell-v9 .metric-card,.app-shell-v9 .card-soft,.app-shell-v9 .chart-card{transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}
.app-shell-v9 .card-soft:hover,.app-shell-v9 .metric-card:hover{border-color:#d7e1f2;box-shadow:0 18px 42px rgba(15,23,42,.065)}
.app-shell-v9 .app-subnav{gap:.45rem;overflow-x:auto;flex-wrap:nowrap;padding-bottom:.25rem}
.app-shell-v9 .app-subnav .nav-link{white-space:nowrap;background:#fff;color:#526174;border:1px solid #e4eaf5;font-weight:700}
.app-shell-v9 .app-subnav .nav-link.active{background:linear-gradient(135deg,#4f6cf7,#7c3aed);border-color:transparent;color:#fff;box-shadow:0 12px 24px rgba(79,108,247,.2)}
.app-shell-v9 .action-row{border-bottom-style:dashed}
.app-shell-v9 .table-responsive{border:1px solid #e7edf6;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,.035)}
.app-shell-v9 .table tbody tr{transition:background .12s ease}
.app-shell-v9 .table tbody tr:hover{background:#f8fbff}
@media(max-width:991.98px){.app-shell-v9 .app-workspace{display:block}.hero-action-panel{justify-content:flex-start}.app-shell-v9 .app-top-actions{gap:.4rem}.app-shell-v9 .app-user-chip span{max-width:96px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}
@media(max-width:767.98px){.app-shell-v9 .page-hero-v95{padding:1.1rem}.dashboard-kpi-row .metric-card strong{font-size:1.25rem}.app-shell-v9 .chart-card-head{flex-direction:column}.hero-action-panel .btn{width:100%}.app-shell-v9 .app-subnav{margin-left:-.1rem;margin-right:-.1rem}}
