﻿
* { font-family: 'DM Sans', sans-serif; box-sizing: border-box; }
:root {
  --mobile-ads-height: calc(env(safe-area-inset-bottom, 0px) + 204px);
}
.app-dark-theme {
  --app-bg-1: #0f172a;
  --app-bg-2: #111827;
  --app-surface: rgba(29, 36, 52, 0.72);
  --app-surface-2: rgba(38, 46, 66, 0.76);
  --app-panel: rgba(23, 30, 44, 0.76);
  --app-panel-soft: rgba(31, 39, 57, 0.62);
  --app-border: rgba(255,255,255,0.09);
  --app-border-soft: rgba(255,255,255,0.06);
  --app-text: #f8fafc;
  --app-text-soft: #cbd5e1;
  --app-text-muted: #94a3b8;
  --app-success: #22e3a2;
  --app-danger: #ff6b6b;
  --app-info: #30d5ff;
  --app-cta: #19c38c;
  --app-modal-btn: #19c38c;
  --app-modal-btn-hover: #22d39a;
  --app-modal-btn-text: #07140f;
  --app-modal-btn-soft: rgba(25, 195, 140, 0.16);
  --app-modal-btn-border: rgba(25, 195, 140, 0.42);
  background:
    radial-gradient(circle at 18% 22%, rgba(20, 184, 166, 0.18), transparent 26%),
    radial-gradient(circle at 82% 70%, rgba(34, 211, 238, 0.14), transparent 24%),
    radial-gradient(circle at 50% 100%, rgba(16, 185, 129, 0.08), transparent 30%),
    linear-gradient(135deg, var(--app-bg-1) 0%, #0b1220 52%, var(--app-bg-2) 100%);
  color: var(--app-text);
}
.app-dark-theme body {
  color: var(--app-text);
}
.fade-in { animation: fadeIn 0.3s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.tab-active { border-bottom: 2px solid #1a1a1a; color: #1a1a1a; }
.tab-inactive { border-bottom: 2px solid transparent; color: #9ca3af; }
.nav-active { border-bottom: 2px solid #1a1a1a; color: #1a1a1a; }
.nav-inactive { border-bottom: 2px solid transparent; color: #9ca3af; }
.card-gradient { background: linear-gradient(135deg, #1c1917 0%, #3c3735 100%); }
.progress-bar { background: linear-gradient(90deg, #10b981 0%, #059669 100%); }
#floating-settings-btn { position: fixed; right: 24px; bottom: 24px; z-index: 99999; width: 56px; height: 56px; border-radius: 9999px; background:#1c1917; color:#fff; border:0; box-shadow:0 18px 40px rgba(0,0,0,.28); display:flex; align-items:center; justify-content:center; cursor:pointer; }
.theme-toggle-btn {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 95;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 9999px;
  border: 1px solid rgba(28, 25, 23, 0.08);
  background: rgba(255,255,255,0.20);
  color: #1c1917;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.16);
  backdrop-filter: blur(16px);
  cursor: pointer;
  transition: background-color .2s ease, border-color .2s ease, box-shadow .2s ease, color .2s ease, opacity .2s ease;
}
.theme-toggle-btn:hover {
  background: rgba(255,255,255,1);
}
.theme-toggle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.theme-toggle-icon-dark {
  display: none;
}
.app-dark-theme .theme-toggle-btn {
  background: rgba(15, 23, 42, 0.20);
  color: #f8fafc;
  border-color: rgba(255,255,255,0.08);
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
}
.app-dark-theme .theme-toggle-btn:hover {
  background: rgba(15, 23, 42, 1);
}
.app-dark-theme .theme-toggle-icon-light {
  display: inline-flex;
}
.app-dark-theme .theme-toggle-icon-dark {
  display: none;
}
body:not(.app-dark-theme) .theme-toggle-icon-light {
  display: none;
}
body:not(.app-dark-theme) .theme-toggle-icon-dark {
  display: inline-flex;
}
.brand-lockup { display:inline-flex; align-items:center; justify-content:center; gap:0; line-height:1; }
.brand-plus { display:inline-block; margin-left:.06em; font-size:1.34em; line-height:1; transform:translateY(.04em); }
.app-dark-theme #loading-screen {
  background:
    radial-gradient(circle at 50% 30%, rgba(16, 185, 129, 0.16), transparent 26%),
    linear-gradient(135deg, #0f172a 0%, #111827 100%) !important;
}
.app-dark-theme #loading-screen .loading-screen-panel {
  padding: 22px 26px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(31, 39, 57, 0.74), rgba(24, 31, 46, 0.82)) !important;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 24px 54px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,0.05);
  backdrop-filter: blur(22px) saturate(130%);
}
.app-dark-theme #loading-screen h1 {
  color: var(--app-text) !important;
}
.app-dark-theme #app {
  color: var(--app-text);
}
.app-dark-theme #app-shell-header,
.app-dark-theme #app-shell-nav {
  background: rgba(15, 23, 42, 0.72) !important;
  backdrop-filter: blur(22px) saturate(135%);
  border-color: rgba(255,255,255,0.08) !important;
}
.app-dark-theme #app-title,
.app-dark-theme #app-shell-nav h1 {
  color: var(--app-text) !important;
}
.app-dark-theme #mobile-menu-toggle {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: var(--app-text) !important;
  box-shadow: 0 14px 32px rgba(0,0,0,.28) !important;
}
.app-dark-theme #mobile-nav-overlay {
  background: rgba(2, 6, 23, 0.58) !important;
}
.app-dark-theme #app-shell-nav-list .nav-tab,
.app-dark-theme #app-shell-nav-list a[href*="wa.me"] {
  color: var(--app-text-soft) !important;
}
.app-dark-theme #app-shell-nav-list .nav-inactive {
  color: var(--app-text-soft) !important;
}
.app-dark-theme #app-shell-nav-list .nav-active {
  background: rgba(255,255,255,0.06) !important;
  color: var(--app-text) !important;
  border-left-color: var(--app-success) !important;
  box-shadow: 0 10px 28px rgba(0,0,0,.24) !important;
}
.app-dark-theme #app-shell-nav-list a[href*="wa.me"] {
  background: rgba(25, 195, 140, 0.12) !important;
  color: #9ef4d2 !important;
}
.app-dark-theme #app-shell-nav-list #mobile-menu-logout,
.app-dark-theme #app-floating-logout {
  background: rgba(255, 107, 107, 0.12) !important;
  color: #ff8f8f !important;
  border: 1px solid rgba(255, 107, 107, 0.14) !important;
  box-shadow: none !important;
}
.app-dark-theme .view-content,
.app-dark-theme .view-content * {
  border-color: var(--app-border-soft);
}
.app-dark-theme .view-content > .max-w-\[980px\],
.app-dark-theme .view-content .max-w-\[980px\] {
  color: var(--app-text);
}
.app-dark-theme .view-content [class*="bg-white"],
.app-dark-theme .view-content [class*="bg-stone-50"],
.app-dark-theme .view-content [class*="bg-stone-100"] {
  background: linear-gradient(180deg, rgba(31, 39, 57, 0.72) 0%, rgba(24, 31, 46, 0.76) 100%) !important;
  backdrop-filter: blur(22px) saturate(125%);
}
.app-dark-theme .view-content [class*="border-stone-100"],
.app-dark-theme .view-content [class*="border-stone-200"],
.app-dark-theme .view-content [class*="border-stone-300"] {
  border-color: var(--app-border) !important;
}
.app-dark-theme .view-content [class*="shadow-sm"],
.app-dark-theme .view-content [class*="shadow-"] {
  box-shadow:
    0 22px 48px rgba(0,0,0,0.22),
    inset 0 1px 0 rgba(255,255,255,0.05) !important;
}
.app-dark-theme .view-content h1,
.app-dark-theme .view-content h2,
.app-dark-theme .view-content h3,
.app-dark-theme .view-content h4,
.app-dark-theme .view-content .font-semibold,
.app-dark-theme .view-content .font-bold {
  color: var(--app-text) !important;
}
.app-dark-theme .view-content p,
.app-dark-theme .view-content span,
.app-dark-theme .view-content div,
.app-dark-theme .view-content button {
  color: inherit;
}
.app-dark-theme .view-content [class*="text-stone-900"] { color: var(--app-text) !important; }
.app-dark-theme .view-content [class*="text-stone-500"],
.app-dark-theme .view-content [class*="text-stone-400"],
.app-dark-theme .view-content [class*="text-stone-300"] { color: var(--app-text-muted) !important; }
.app-dark-theme .view-content [class*="text-emerald-600"],
.app-dark-theme .view-content [class*="text-emerald-700"] { color: var(--app-success) !important; }
.app-dark-theme .view-content [class*="text-red-500"],
.app-dark-theme .view-content [class*="text-red-600"] { color: var(--app-danger) !important; }
.app-dark-theme .view-content [class*="text-blue-600"],
.app-dark-theme .view-content [class*="text-cyan-500"] { color: var(--app-info) !important; }
.app-dark-theme .view-content [class*="bg-emerald-50"] {
  background: rgba(34, 227, 162, 0.08) !important;
}
.app-dark-theme .view-content [class*="bg-red-50"] {
  background: rgba(255, 107, 107, 0.08) !important;
}
.app-dark-theme .view-content [class*="bg-blue-50"],
.app-dark-theme .view-content [class*="bg-cyan-50"] {
  background: rgba(48, 213, 255, 0.08) !important;
}
.app-dark-theme .view-content [class*="bg-amber-50"] {
  background: rgba(250, 204, 21, 0.08) !important;
}
.app-dark-theme .dashboard-hero-card {
  background:
    linear-gradient(180deg, rgba(31, 39, 57, 0.74) 0%, rgba(24, 31, 46, 0.82) 100%) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(24px) saturate(130%);
}
.dashboard-view .dashboard-shell {
  width: 100%;
}
.dashboard-view .dashboard-hero-section {
  margin-bottom: 0 !important;
}
.app-dark-theme .dashboard-hero-card p,
.app-dark-theme .dashboard-hero-card span {
  color: var(--app-text-soft) !important;
}
.app-dark-theme #balance {
  color: var(--app-text) !important;
}
.app-dark-theme .view-content button[class*="bg-stone-900"],
.app-dark-theme .view-content a[class*="bg-stone-900"] {
  background: var(--app-cta) !important;
  color: #07140f !important;
}
.app-dark-theme .view-content input,
.app-dark-theme .view-content select,
.app-dark-theme .view-content textarea {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: var(--app-text) !important;
}
.app-dark-theme .view-content input::placeholder,
.app-dark-theme .view-content textarea::placeholder {
  color: var(--app-text-muted) !important;
}
.app-dark-theme #app-shell-ads .ads-rail {
  background:
    radial-gradient(circle at 50% 0%, rgba(34, 227, 162, 0.10), transparent 38%),
    rgba(28, 36, 52, 0.78) !important;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 24px 54px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(24px) saturate(135%);
}
.app-dark-theme #app-shell-ads [data-desktop-banner-card] {
  background: rgba(255,255,255,0.04) !important;
}
.app-dark-theme #app-shell-ads [data-desktop-banner-slot] {
  background: linear-gradient(180deg, rgba(52, 65, 85, 0.56), rgba(47, 59, 78, 0.48)) !important;
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(18px) saturate(120%);
}
.app-dark-theme #app-shell-ads [data-desktop-banner-slot] p:first-child {
  color: #ff6b6b !important;
}
.app-dark-theme #app-shell-ads [data-desktop-banner-slot] p:last-child,
.app-dark-theme #app-shell-ads .pt-4 p {
  color: var(--app-text-muted) !important;
}
.app-dark-theme #app-shell-ads .pt-4 span {
  color: var(--app-text-soft) !important;
}
.app-dark-theme .mobile-banner-rotator {
  background: rgba(12, 18, 32, 0.90) !important;
  border-top-color: rgba(255,255,255,0.08) !important;
  box-shadow: 0 -16px 44px rgba(0,0,0,0.32) !important;
  backdrop-filter: blur(20px) saturate(135%) !important;
}
.app-dark-theme .mobile-banner-slide,
.app-dark-theme .mobile-banner-placeholder {
  background: linear-gradient(180deg, rgba(31, 39, 57, 0.76), rgba(24, 31, 46, 0.82)) !important;
  border-color: rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(18px) saturate(120%);
}
.app-dark-theme .mobile-banner-placeholder-label {
  color: #ff6b6b !important;
}
.app-dark-theme .mobile-banner-placeholder-copy,
.app-dark-theme .mobile-banner-note {
  color: var(--app-text-muted) !important;
}
.app-dark-theme .mobile-banner-note span {
  color: var(--app-text-soft) !important;
}
.app-dark-theme .mobile-banner-support {
  background: var(--app-cta) !important;
  color: #07140f !important;
  box-shadow: 0 14px 30px rgba(25,195,140,0.22) !important;
}
.app-dark-theme [id^="modal-"] .relative,
.app-dark-theme #delete-confirm .relative {
  background: linear-gradient(180deg, rgba(24, 29, 43, 0.98), rgba(20, 24, 36, 0.98)) !important;
  color: var(--app-text) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(22px) saturate(125%);
}
.app-dark-theme #modal-settings-auth #modal-backdrop-settings-auth {
  background: rgba(2, 6, 23, 0.64) !important;
  backdrop-filter: blur(8px) !important;
}
.app-dark-theme #modal-settings-auth .settings-auth-panel .w-12.h-12 {
  background: rgba(25, 195, 140, 0.14) !important;
  color: #9ef4d2 !important;
  border: 1px solid rgba(34, 227, 162, 0.18);
}
.app-dark-theme #modal-settings-auth .settings-auth-submit {
  background: var(--app-modal-btn) !important;
  color: var(--app-modal-btn-text) !important;
  border-color: transparent !important;
  box-shadow: 0 14px 30px rgba(25, 195, 140, 0.24) !important;
}
.app-dark-theme [id^="modal-"] input,
.app-dark-theme [id^="modal-"] select,
.app-dark-theme [id^="modal-"] textarea {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: var(--app-text) !important;
}
.app-dark-theme [id^="modal-"] p,
.app-dark-theme [id^="modal-"] label,
.app-dark-theme [id^="modal-"] h2,
.app-dark-theme [id^="modal-"] h3,
.app-dark-theme #delete-confirm p,
.app-dark-theme #delete-confirm h2 {
  color: var(--app-text) !important;
}
.app-dark-theme [id^="modal-"] button[type="submit"]:not(#delete-ok),
.app-dark-theme [id^="modal-"] .settings-auth-submit,
.app-dark-theme #type-income,
.app-dark-theme #type-expense,
.app-dark-theme #delete-cancel {
  background: var(--app-modal-btn) !important;
  color: var(--app-modal-btn-text) !important;
  border-color: transparent !important;
  box-shadow: 0 14px 30px rgba(25, 195, 140, 0.22) !important;
}
.app-dark-theme [id^="modal-"] button[type="submit"]:not(#delete-ok):hover,
.app-dark-theme [id^="modal-"] .settings-auth-submit:hover,
.app-dark-theme #type-income:hover,
.app-dark-theme #type-expense:hover,
.app-dark-theme #delete-cancel:hover {
  background: var(--app-modal-btn-hover) !important;
  color: var(--app-modal-btn-text) !important;
}
.app-dark-theme #type-income,
.app-dark-theme #type-expense {
  border-width: 1px !important;
}
.app-dark-theme #type-income:not(.active),
.app-dark-theme #type-expense:not(.active) {
  background: var(--app-modal-btn-soft) !important;
  color: #9ef4d2 !important;
  border-color: var(--app-modal-btn-border) !important;
  box-shadow: none !important;
}
.app-dark-theme #delete-cancel {
  background: rgba(25, 195, 140, 0.14) !important;
  color: #9ef4d2 !important;
  border: 1px solid var(--app-modal-btn-border) !important;
  box-shadow: none !important;
}
.app-dark-theme #delete-ok {
  box-shadow: 0 14px 30px rgba(255, 107, 107, 0.18) !important;
}
.mobile-banner-rotator {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--mobile-ads-height);
  z-index: 60;
  pointer-events: auto;
  background: rgba(250, 250, 249, 0.98);
  border-top: 1px solid rgba(231, 229, 228, 0.96);
  box-shadow: 0 -16px 40px rgba(28, 25, 23, 0.08);
  padding: 12px 12px calc(env(safe-area-inset-bottom, 0px) + 8px);
  backdrop-filter: blur(10px);
  overflow: hidden;
}
.mobile-banner-track {
  position: relative;
  height: 88px;
}
.mobile-banner-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(10px) scale(.985);
  transition: opacity .45s ease, transform .45s ease;
  border-radius: 22px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 18px 40px rgba(28, 25, 23, 0.12);
  border: 1px solid rgba(231, 229, 228, 0.9);
}
.mobile-banner-slide.is-active {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.mobile-banner-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.mobile-banner-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 10px 16px;
  background: #ffffff;
}
.mobile-banner-placeholder-label {
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #f87171;
}
.mobile-banner-placeholder-copy {
  margin: 8px 0 0;
  font-size: 13px;
  line-height: 1.35;
  color: #a8a29e;
}
.mobile-banner-note {
  margin: 8px 6px 0;
  text-align: center;
  font-size: 11px;
  line-height: 1.35;
  color: #a8a29e;
}
.mobile-banner-note span {
  color: #78716c;
  font-weight: 700;
}
.mobile-banner-support {
  margin: 8px auto 0;
  min-width: 118px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 9999px;
  background: #10b981;
  color: #0c0a09;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(16, 185, 129, 0.22);
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
#app {
  padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 236px);
}
#app-floating-logout {
  display: none;
}
#app-shell-nav-list .nav-tab {
  border-bottom: 0;
}
#app-shell-nav-list .nav-inactive {
  color: #78716c;
}


button, a, input, select, textarea { -webkit-tap-highlight-color: transparent; }
.touch-manipulation { touch-action: manipulation; }
@media (max-width: 480px) {
  body { min-height: 100dvh; }
  :root { --mobile-ads-height: calc(env(safe-area-inset-bottom, 0px) + 190px); }
  .mobile-banner-track { height: 86px; }
  .mobile-banner-note { font-size: 10px; margin-top: 8px; }
  .mobile-banner-support { margin-top: 8px; padding: 9px 14px; font-size: 12px; }
  .theme-toggle-btn { left: auto; right: 14px; transform: none; bottom: calc(env(safe-area-inset-bottom, 0px) + 10px); width: 42px; height: 42px; }
  #app { padding-bottom: 0; }
}
@media (max-width: 899px) {
  html, body {
    height: 100dvh;
    overflow: hidden;
  }
  .theme-toggle-btn {
    left: auto;
    right: 16px;
    transform: none;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 10px);
    z-index: 85;
  }
  .app-dark-theme #app-shell-header {
    background: rgba(12, 18, 32, 0.86) !important;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .app-dark-theme #app-shell-nav {
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(17, 24, 39, 0.98)) !important;
  }
  #app {
    height: calc(100dvh - var(--mobile-ads-height));
    overflow: auto;
    padding-bottom: 0;
  }
}
@media (min-width: 900px) {
  #app {
    padding-bottom: 0;
  }
  .theme-toggle-btn {
    right: 28px;
    bottom: 28px;
    z-index: 70;
  }
  #app-floating-logout {
    display: inline-flex;
  }
}
  @media (min-width: 900px) {
    :root {
      --desktop-side-width: clamp(296px, 24vw, 360px);
      --desktop-side-gap: 2px;
      --desktop-side-header-height: 108px;
      --desktop-card-gap: 14px;
      --desktop-hero-height: 232px;
      --desktop-mid-height: 194px;
      --desktop-bottom-height: 248px;
      --desktop-ads-footer-height: 44px;
      --desktop-ads-card-height: 1fr;
    }
  #app {
    padding-left: calc(var(--desktop-side-width) + 4px) !important;
    padding-right: calc(var(--desktop-side-width) + 4px) !important;
    padding-bottom: 0 !important;
    overflow-x: hidden !important;
  }
  #app-shell-header {
    position: fixed !important;
    top: var(--desktop-side-gap) !important;
    left: var(--desktop-side-gap) !important;
    width: var(--desktop-side-width) !important;
    height: var(--desktop-side-header-height) !important;
    padding: 26px 24px 14px !important;
    background:
      radial-gradient(circle at 50% 0%, rgba(34, 227, 162, 0.10), transparent 38%),
      rgba(28, 36, 52, 0.78) !important;
    backdrop-filter: blur(24px) saturate(135%) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-bottom: 0 !important;
    border-radius: 30px 30px 0 0 !important;
    box-shadow:
      0 24px 54px rgba(0,0,0,.24),
      inset 0 1px 0 rgba(255,255,255,0.05) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    z-index: 30 !important;
  }
  #app-shell-nav {
    position: fixed !important;
    top: calc(var(--desktop-side-gap) + var(--desktop-side-header-height)) !important;
    left: var(--desktop-side-gap) !important;
    width: var(--desktop-side-width) !important;
    height: calc(100vh - (var(--desktop-side-gap) * 2) - var(--desktop-side-header-height)) !important;
    max-width: none !important;
    padding: 10px 18px 18px !important;
    background:
      radial-gradient(circle at 50% 0%, rgba(34, 227, 162, 0.10), transparent 38%),
      rgba(28, 36, 52, 0.78) !important;
    backdrop-filter: blur(24px) saturate(135%) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-top: 0 !important;
    border-radius: 0 0 30px 30px !important;
    box-shadow:
      0 24px 54px rgba(0,0,0,.24),
      inset 0 1px 0 rgba(255,255,255,0.05) !important;
    z-index: 29 !important;
  }
  #app-title-desktop {
    display: inline-flex !important;
    align-items: center !important;
  }
  #app-shell-ads {
    position: fixed !important;
    top: var(--desktop-side-gap) !important;
    right: var(--desktop-side-gap) !important;
    bottom: var(--desktop-side-gap) !important;
    width: var(--desktop-side-width) !important;
    z-index: 25 !important;
    overflow: visible !important;
  }
  #app-shell-ads .ads-rail {
    height: 100% !important;
    overflow: hidden !important;
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) var(--desktop-ads-footer-height) !important;
    gap: var(--desktop-card-gap) !important;
  }
  #app-shell-ads .desktop-ads-stack {
    min-height: 0 !important;
    height: 100% !important;
    display: grid !important;
    grid-template-rows: repeat(3, minmax(0, 1fr)) !important;
    gap: var(--desktop-card-gap) !important;
  }
  #app-shell-ads .desktop-ads-stack > * {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  #app-shell-ads [data-desktop-banner-card] {
    min-height: 0 !important;
    height: 100% !important;
    display: flex !important;
  }
  #app-shell-ads [data-desktop-banner-slot] {
    height: 100% !important;
    min-height: 0 !important;
  }
  #app-shell-ads .desktop-ads-footer {
    padding-top: 0 !important;
    margin-top: 0 !important;
    min-height: var(--desktop-ads-footer-height) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: left !important;
    padding-right: 56px !important;
  }
  #app-shell-ads .desktop-ads-footer p {
    margin: 0 !important;
    line-height: 1.35 !important;
    max-width: 100% !important;
  }
  #app-shell-nav-list {
    max-width: none !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding-top: 10px !important;
  }
  #app-shell-nav-list .nav-tab,
  #app-shell-nav-list a[href*="wa.me"] {
    width: 100% !important;
    min-height: 54px !important;
    border-radius: 20px !important;
  }
  #app-shell-nav-list .nav-tab {
    padding: 14px 18px !important;
  }
  #app-shell-nav-list .nav-active {
    box-shadow: 0 12px 28px rgba(0,0,0,.18) !important;
  }
  #app-floating-logout {
    position: fixed !important;
    left: calc(var(--desktop-side-gap) + 18px) !important;
    bottom: calc(var(--desktop-side-gap) + 18px) !important;
    width: calc(var(--desktop-side-width) - 36px) !important;
    justify-content: flex-start !important;
    padding: 14px 18px !important;
    border-radius: 20px !important;
    margin-top: 0 !important;
    z-index: 31 !important;
  }
  body:not(.app-dark-theme) {
    background:
      radial-gradient(circle at 22% 16%, rgba(16, 185, 129, 0.08), transparent 22%),
      radial-gradient(circle at 84% 18%, rgba(59, 130, 246, 0.06), transparent 20%),
      linear-gradient(180deg, #f8fafc 0%, #f5f7fb 100%) !important;
  }
  body:not(.app-dark-theme) #app-shell-header {
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,248,252,0.98)) !important;
    backdrop-filter: blur(20px) saturate(120%) !important;
    border: 1px solid rgba(226,232,240,0.95) !important;
    border-bottom: 0 !important;
    box-shadow:
      0 22px 48px rgba(15, 23, 42, 0.08),
      inset 0 1px 0 rgba(255,255,255,0.72) !important;
  }
  body:not(.app-dark-theme) #app-shell-nav {
    background:
      linear-gradient(180deg, rgba(248,250,252,0.98), rgba(241,245,249,0.98)) !important;
    backdrop-filter: blur(20px) saturate(120%) !important;
    border: 1px solid rgba(226,232,240,0.95) !important;
    border-top: 0 !important;
    box-shadow:
      0 22px 48px rgba(15, 23, 42, 0.08),
      inset 0 1px 0 rgba(255,255,255,0.72) !important;
  }
  body:not(.app-dark-theme) #app-title-desktop {
    color: #111827 !important;
  }
  body:not(.app-dark-theme) #app-shell-nav-list .nav-tab,
  body:not(.app-dark-theme) #app-shell-nav-list a[href*="wa.me"] {
    box-shadow: none !important;
  }
  body:not(.app-dark-theme) #app-shell-nav-list .nav-inactive {
    color: #475569 !important;
  }
  body:not(.app-dark-theme) #app-shell-nav-list .nav-active {
    background: #ffffff !important;
    color: #0f172a !important;
    border-left-color: #19c38c !important;
    box-shadow:
      0 12px 28px rgba(15, 23, 42, 0.10),
      inset 0 1px 0 rgba(255,255,255,0.92) !important;
  }
  body:not(.app-dark-theme) #app-shell-nav-list a[href*="wa.me"] {
    background: linear-gradient(180deg, rgba(220, 252, 231, 0.92), rgba(209, 250, 229, 0.92)) !important;
    color: #047857 !important;
    box-shadow: 0 10px 24px rgba(16, 185, 129, 0.10) !important;
  }
  body:not(.app-dark-theme) #app-floating-logout {
    background: linear-gradient(180deg, rgba(254,242,242,0.98), rgba(255,255,255,0.98)) !important;
    color: #ef4444 !important;
    border: 1px solid rgba(252, 165, 165, 0.42) !important;
    box-shadow: 0 12px 28px rgba(248, 113, 113, 0.10) !important;
  }
  body:not(.app-dark-theme) #app-shell-ads .ads-rail {
    background: linear-gradient(180deg, rgba(248,250,252,0.98), rgba(241,245,249,0.98)) !important;
    border: 1px solid rgba(226,232,240,0.95) !important;
    box-shadow:
      0 22px 48px rgba(15, 23, 42, 0.08),
      inset 0 1px 0 rgba(255,255,255,0.72) !important;
  }
  body:not(.app-dark-theme) #app-shell-ads [data-desktop-banner-card] {
    background: rgba(255,255,255,0.72) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.88) !important;
  }
  body:not(.app-dark-theme) #app-shell-ads [data-desktop-banner-slot] {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
    border: 1px solid rgba(226,232,240,0.88) !important;
  }
  body:not(.app-dark-theme) #app-shell-ads .desktop-ads-footer p {
    color: #94a3b8 !important;
  }
  body:not(.app-dark-theme) #app-shell-ads .desktop-ads-footer span {
    color: #64748b !important;
  }
  body:not(.app-dark-theme) .theme-toggle-btn {
    background: rgba(255,255,255,0.20) !important;
    color: #0f172a !important;
    border-color: rgba(226,232,240,0.92) !important;
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.10) !important;
  }
  body:not(.app-dark-theme) .theme-toggle-btn:hover {
    background: rgba(255,255,255,1) !important;
  }
}
@media (min-width: 900px) and (max-height: 860px) {
  #app {
    padding-left: calc(var(--desktop-side-width) + 6px) !important;
    padding-right: calc(var(--desktop-side-width) + 6px) !important;
  }
  #app-shell-header {
    top: 8px !important;
    left: 8px !important;
    width: clamp(276px, 22vw, 332px) !important;
  }
  #app-shell-ads {
    width: clamp(276px, 22vw, 332px) !important;
    top: 8px !important;
    bottom: 8px !important;
    right: 8px !important;
  }
  #app-floating-logout {
    left: 26px !important;
    bottom: 26px !important;
    width: calc(clamp(276px, 22vw, 332px) - 36px) !important;
  }
  #app-shell-nav {
    top: calc(8px + var(--desktop-side-header-height)) !important;
    left: 8px !important;
    width: clamp(276px, 22vw, 332px) !important;
    height: calc(100vh - 16px - var(--desktop-side-header-height)) !important;
  }
  #app-shell-ads .ads-rail {
    gap: 12px !important;
    padding: 12px !important;
  }
  #app-shell-ads .desktop-ads-stack {
    gap: 12px !important;
  }
  #app-shell-ads [data-desktop-banner-slot] {
    min-height: 132px !important;
  }
  #app-shell-ads .desktop-ads-footer p {
    font-size: 10px !important;
    line-height: 1.45 !important;
  }
  #app-shell-nav-list {
    max-width: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    border-bottom: 0 !important;
    padding-top: 8px !important;
  }
  #app-shell-nav-list .nav-tab {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    padding: 12px 14px !important;
    border-bottom: 0 !important;
    border-left: 3px solid transparent !important;
    border-radius: 14px !important;
    background: transparent !important;
    text-align: left !important;
  }
  #app-shell-nav-list .nav-active {
    border-left-color: #1a1a1a !important;
    color: #1a1a1a !important;
    background: #ffffff !important;
    box-shadow: 0 10px 24px rgba(28, 25, 23, 0.06);
  }
  #app-shell-nav-list .nav-inactive {
    color: #78716c !important;
  }
  #app-shell-nav-list .nav-tab i {
    margin-right: 10px !important;
  }
  .view-content {
    padding: 12px 4px 20px !important;
  }
  .dashboard-view .dashboard-shell {
    max-width: 1240px !important;
    margin-left: 0 !important;
    margin-right: auto !important;
  }
  .dashboard-view .space-y-6 {
    gap: var(--desktop-card-gap) !important;
  }
  .dashboard-view .dashboard-hero-card {
    min-height: var(--desktop-hero-height);
  }
  .dashboard-view .dashboard-stats-grid > div {
    min-height: var(--desktop-mid-height);
  }
  .dashboard-view .dashboard-bottom-grid {
    grid-template-columns: minmax(0, 1.58fr) minmax(0, 1fr) !important;
    align-items: stretch !important;
  }
  .dashboard-view .dashboard-bottom-grid > div {
    min-height: var(--desktop-bottom-height);
  }
  .app-dark-theme #app-shell-header {
    background: rgba(15, 23, 42, 0.88) !important;
    border-right-color: rgba(255,255,255,0.08) !important;
  }
  .app-dark-theme #app-shell-nav {
    background: rgba(15, 23, 42, 0.88) !important;
    border-right-color: rgba(255,255,255,0.08) !important;
  }
  .app-dark-theme .view-content {
    background: transparent !important;
  }
}
@media (min-width: 1200px) {
  .dashboard-view .dashboard-shell {
    max-width: 1320px !important;
  }
  .dashboard-view .dashboard-bottom-grid {
    grid-template-columns: minmax(0, 1.64fr) minmax(0, 1fr) !important;
  }
}
  @media (min-width: 900px) and (max-height: 860px) {
    :root {
      --desktop-card-gap: 12px;
      --desktop-hero-height: 214px;
      --desktop-mid-height: 176px;
      --desktop-bottom-height: 224px;
      --desktop-ads-footer-height: 38px;
    }
  }

