:root{
  /* Theme map standard: docs/THEME_MAP_RO.md */
  --bg:#f6f7fb;
  --panel:#ffffff;
  --panel2:#f3f5fb;
  --text:#111827;
  --muted:#6b7280;
  --border:rgba(17,24,39,0.12);
  --shadow: 0 14px 40px rgba(17,24,39,0.10);
  --radius:18px;
  --radius2:14px;
  --gap:14px;
  --focus: rgba(59,130,246,0.45);
  --page-a: rgba(59,130,246,0.14);
  --page-b: rgba(16,185,129,0.10);
  --page-c: #f6f8ff;
  --page-d: #eef3fb;
  --glass-wash: rgba(255,255,255,0.44);
  --glass-wash-2: rgba(255,255,255,0.22);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background:
    radial-gradient(1200px 800px at 20% -10%, var(--page-a), transparent 55%),
    radial-gradient(900px 700px at 110% 10%, var(--page-b), transparent 55%),
    linear-gradient(180deg, var(--page-c) 0%, var(--page-d) 100%);
  background-attachment: fixed, fixed, fixed;
  background-repeat: no-repeat;
  color:var(--text);
}

.authGateRoot{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  z-index:1200;
  background:
    radial-gradient(1200px 780px at 15% -10%, rgba(59,130,246,0.16), transparent 55%),
    radial-gradient(1000px 760px at 110% 0%, rgba(16,185,129,0.12), transparent 56%),
    linear-gradient(180deg, #eef4ff 0%, #eaf2fb 100%);
}
.authGateRoot.isOpen{display:flex}

.app.isHidden{display:none !important}

.authGate{
  width:min(1040px, 100%);
  display:grid;
  grid-template-columns:minmax(320px, 0.9fr) minmax(360px, 1.1fr);
  border:1px solid rgba(148,163,184,0.22);
  border-radius:28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,247,252,0.92));
  box-shadow:
    0 30px 70px rgba(15,23,42,0.14),
    inset 0 1px 0 rgba(255,255,255,0.92);
  overflow:hidden;
}
.authGate__brand{
  padding:34px 30px;
  border-right:1px solid rgba(148,163,184,0.18);
  background:
    radial-gradient(420px 260px at 0% 0%, rgba(59,130,246,0.18), transparent 64%),
    radial-gradient(380px 220px at 100% 100%, rgba(16,185,129,0.10), transparent 62%),
    linear-gradient(180deg, rgba(246,250,255,0.92), rgba(255,255,255,0.78));
  display:flex;
  flex-direction:column;
  gap:16px;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.authGate__logo{
  width:122px;
  height:122px;
  border-radius:28px;
  object-fit:cover;
  box-shadow:0 18px 42px rgba(15,23,42,0.20);
}
.authGate__title{
  max-width:360px;
  font-size:44px;
  line-height:0.98;
  font-weight:900;
  letter-spacing:-0.03em;
  color:#111111;
}

.authGate__panel{
  padding:34px 30px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
}
.authGate__panelTitle{
  font-size:34px;
  line-height:1;
  font-weight:900;
  letter-spacing:-0.03em;
  color:#0f172a;
}

.authField{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.authField__label{
  font-size:11px;
  color:#64748b;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}
.authField__ctrl{
  position:relative;
  display:flex;
  align-items:center;
}
.authField__ctrl .input{
  min-height:52px;
  border-radius:16px;
  padding-right:46px;
  border-color:rgba(148,163,184,0.28);
  background:rgba(255,255,255,0.96);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.92);
}
.authToggle{
  position:absolute;
  right:10px;
  width:32px;
  height:32px;
  border-radius:11px;
  border:1px solid rgba(148,163,184,0.26);
  background:rgba(255,255,255,0.92);
  color:#475569;
  cursor:pointer;
  display:grid;
  place-items:center;
  font-size:13px;
}
.authGate__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.authGate__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.authGate__actions .primaryBtn,
.authGate__actions .ghostBtn{
  min-height:46px;
  border-radius:15px;
  padding:0 18px;
  font-weight:800;
}
.authGate__status{
  min-height:20px;
  font-size:12px;
  color:#64748b;
}
.authGate__status.isErr{color:#b91c1c}
.authGate__status.isOk{color:#065f46}

.authRecovery{
  border:1px solid rgba(148,163,184,0.26);
  border-radius:18px;
  background:rgba(248,250,252,0.82);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:9px;
}
.authRecovery.isHidden{display:none}
.authRecovery__title{
  font-size:13px;
  font-weight:800;
}

@media (max-width: 860px){
  .authGate{
    grid-template-columns:1fr;
    border-radius:24px;
  }
  .authGate__brand{
    border-right:0;
    border-bottom:1px solid rgba(148,163,184,0.18);
    padding:24px 20px 22px;
    align-items:center;
    text-align:center;
  }
  .authGate__logo{width:96px; height:96px; border-radius:22px}
  .authGate__title{
    max-width:none;
    font-size:34px;
  }
  .authGate__panel{padding:20px}
}

body.theme-dashboard{
  --page-a: rgba(59,130,246,0.16);
  --page-b: rgba(14,165,233,0.10);
  --page-c: #f4f8ff;
  --page-d: #ecf2fb;
}
body.theme-crypto{
  --page-a: rgba(16,185,129,0.15);
  --page-b: rgba(45,212,191,0.11);
  --page-c: #f1fbf8;
  --page-d: #e9f6f4;
}
body.theme-stocks{
  --page-a: rgba(37,99,235,0.14);
  --page-b: rgba(56,189,248,0.10);
  --page-c: #f3f7ff;
  --page-d: #eaf0fb;
}
body.theme-taxe{
  --page-a: rgba(245,158,11,0.14);
  --page-b: rgba(249,115,22,0.10);
  --page-c: #fff8ef;
  --page-d: #f9f1e7;
}
body.theme-abonamente{
  --page-a: rgba(59,130,246,0.12);
  --page-b: rgba(2,132,199,0.10);
  --page-c: #f2f8ff;
  --page-d: #eaf1fb;
}
body.theme-utile{
  --page-a: rgba(244,63,94,0.13);
  --page-b: rgba(251,146,60,0.09);
  --page-c: #fff5f6;
  --page-d: #f8eef0;
}
body.theme-admin{
  --page-a: rgba(59,130,246,0.14);
  --page-b: rgba(99,102,241,0.10);
  --page-c: #f4f7ff;
  --page-d: #edf2fb;
}
body.theme-credit{
  --page-a: rgba(100,116,139,0.15);
  --page-b: rgba(59,130,246,0.08);
  --page-c: #f5f7fb;
  --page-d: #edf1f7;
}
body.theme-hobby{
  --page-a: rgba(14,165,233,0.13);
  --page-b: rgba(6,182,212,0.10);
  --page-c: #f2fbff;
  --page-d: #eaf5f8;
}
body.theme-wishlist{
  --page-a: rgba(245,158,11,0.13);
  --page-b: rgba(34,197,94,0.10);
  --page-c: #fffaf1;
  --page-d: #f4f1e6;
}

a{color:inherit}
button{font:inherit}

.app{
  height:100vh;
  display:grid;
  grid-template-columns: 280px 1fr;
  transition: grid-template-columns .24s ease;
}

.sidebar{
  border-right:1px solid var(--border);
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:16px;
  overflow:visible;
  transition: padding .22s ease;
  position:relative;
  z-index:3;
  background: linear-gradient(180deg, var(--glass-wash) 0%, var(--glass-wash-2) 100%);
  backdrop-filter: blur(8px);
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 56px 10px 10px;
  min-height:96px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(243,245,251,0.95));
  box-shadow: var(--shadow);
  position:relative;
  cursor:pointer;
}
.brand__text{min-width:0; flex:1}
.brand__logoFull{
  display:block;
  width:78px;
  height:78px;
  object-fit:cover;
  border-radius:18px;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.18);
}
.brand__mark{
  width:44px;height:44px;
  border-radius:999px;
  display:grid;place-items:center;
  background: rgba(255,255,255,0.86);
  border:1px solid var(--border);
  font-weight:700;
  overflow:hidden;
}
.brand__logo{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:12px;
}
.brand__logo--mini{
  object-fit:cover;
  object-position:center center;
  padding:0;
  border-radius:12px;
  background:transparent;
}
.brand__logoFallback{
  display:none;
  width:100%;
  height:100%;
  border-radius:12px;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:19px;
  letter-spacing:0.02em;
  color:#f8fafc;
  background:#0f172a;
}
.brand__title{font-weight:700; letter-spacing:0.2px}
.brand__subtitle{font-size:12px; color:var(--muted); margin-top:2px}

.nav{
  padding:6px;
  flex:1;
  min-height:0;
  overflow-y:auto;
}
.nav__label{
  font-size:11px;
  letter-spacing:0.12em;
  color:var(--muted);
  margin:8px 8px 10px;
}
.nav__list{display:flex; flex-direction:column; gap:8px}

.tabBtn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  padding:12px 12px;
  border-radius:var(--radius2);
  border:1px solid transparent;
  background: transparent;
  color:var(--text);
  cursor:pointer;
}
.tabBtn:hover{background: rgba(17,24,39,0.03)}
.tabBtn:focus{outline:2px solid var(--focus); outline-offset:2px}
.tabBtn.isActive{
  background: rgba(17,24,39,0.06);
  border-color: var(--border);
}
.tabBtn__left{display:flex; align-items:center; gap:10px}
.tabBtn__icon{
  width:30px;height:30px;
  border-radius:12px;
  display:grid;place-items:center;
  background: rgba(17,24,39,0.06);
  border:1px solid var(--border);
  font-size:14px;
}
.tabBtn__name{font-weight:600}
.tabBtn__badge{font-size:12px; color:var(--muted)}
.tabIcon{
  width:32px;
  height:32px;
  border-radius:12px;
  display:grid;
  place-items:center;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.65);
  flex:0 0 auto;
  color:#334155;
}
.tabIcon svg{
  width:17px;
  height:17px;
  stroke:currentColor;
  fill:none;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.tabBtn.isActive .tabIcon{
  color:#1d4ed8;
  border-color: rgba(59,130,246,0.34);
  background: rgba(59,130,246,0.12);
}
.tabLabel{
  font-weight:600;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sidebar__collapseBtn{
  position:absolute;
  top:50%;
  right:10px;
  transform:translateY(-50%);
  width:36px;
  height:36px;
  border-radius:14px;
  font-size:15px;
  font-weight:700;
  z-index:4;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,0.88);
  border:1px solid rgba(17,24,39,0.14);
  box-shadow: 0 4px 12px rgba(15,23,42,0.10);
}
.sidebar__collapseBtn:focus{
  outline:none !important;
  box-shadow: 0 0 0 2px rgba(59,130,246,0.20), 0 4px 12px rgba(15,23,42,0.10) !important;
}
.sidebar__collapseBtn:focus:not(:focus-visible){
  box-shadow: 0 4px 12px rgba(15,23,42,0.10) !important;
}

.sidebar__footer{margin-top:auto}
.hint{
  display:flex; align-items:center; gap:10px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px;
  background: rgba(17,24,39,0.03);
}
.hint__dot{width:8px;height:8px;border-radius:99px;background: rgba(59,130,246,0.55)}
.hint__text{font-size:12px;color:var(--muted)}

.main{display:flex; flex-direction:column; min-width:0}

.topbar{
  position:sticky;
  top:0;
  z-index:10030;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 18px;
  border-bottom:none !important;
  backdrop-filter:none !important;
  background: transparent !important;
  box-shadow:none !important;
}

.pageTitle{font-size:18px;font-weight:700}

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

.topbar__nav{
  display:none;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(17,24,39,0.04);
  font-size:16px;
  font-weight:700;
}
.topbar__nav:hover{background: rgba(17,24,39,0.06)}

/* Desktop: header is intentionally minimal/hidden, account sits in sidebar */
@media (min-width: 901px){
  .topbar{display:none}
}

.chip{
  border:1px solid var(--border);
  background: rgba(17,24,39,0.04);
  color:var(--muted);
  padding:8px 10px;
  border-radius:999px;
  cursor:pointer;
  font-size:12px;
}
.chip:hover{background: rgba(17,24,39,0.06); color:var(--text)}
.chip:focus{outline:2px solid var(--focus); outline-offset:2px}

.account{position:relative}
.account__btn{
  display:flex; align-items:center; gap:10px;
  border:1px solid var(--border);
  background: rgba(17,24,39,0.04);
  border-radius:999px;
  padding:8px 10px;
  cursor:pointer;
}
.account__btn:hover{background: rgba(17,24,39,0.06)}
.account__btn:focus{outline:2px solid var(--focus); outline-offset:2px}
.account__avatar{
  width:28px;height:28px;border-radius:999px;
  display:grid;place-items:center;
  background: rgba(17,24,39,0.06);
  border:1px solid var(--border);
  font-weight:700;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  overflow:hidden;
}
.account__avatar.hasPhoto{
  color:transparent;
  font-size:0;
}
.account__name{font-size:13px;font-weight:600}
.account__chev{color:var(--muted)}

.account__menu{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  min-width:280px;
  z-index:10040;
  border:1px solid rgba(148,163,184,0.32);
  border-radius:18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,246,255,0.95));
  box-shadow: 0 16px 42px rgba(15,23,42,0.2);
  padding:10px;
  display:none;
  backdrop-filter: blur(8px);
}
.account__menu.isOpen{display:block}

.sidebar__account{
  margin-top:10px;
  margin-bottom:8px;
  position:relative;
  width:100%;
}
.sidebar__account .account__btn{
  width:100%;
  justify-content:space-between;
  border-radius:14px;
  padding:10px 12px;
}
.sidebar__account .account__menu{
  left:0;
  right:0;
  top:calc(100% + 8px);
  min-width:0;
}

.accountMenuHead{
  padding:4px 6px 6px;
}
.accountMenuHead__title{
  font-size:30px;
  font-weight:800;
  line-height:1.1;
  letter-spacing:-0.01em;
}
.accountMenuHead__email{
  margin-top:6px;
  color:#64748b;
  font-weight:700;
  font-size:13px;
  letter-spacing:0.01em;
  overflow-wrap:anywhere;
}
.accountMenuLang{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:2px 6px;
}
.accountMenuLang__label{
  font-weight:700;
  font-size:14px;
}
.langSwitch{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:3px;
  border:1px solid rgba(148,163,184,0.35);
  border-radius:999px;
  background: rgba(255,255,255,0.88);
}
.langSwitch__btn{
  border:none;
  background:transparent;
  color:#0f172a;
  font-weight:800;
  font-size:12px;
  letter-spacing:0.04em;
  padding:0;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:32px;
  height:32px;
  justify-content:center;
}
.langSwitch__btn:hover{
  background: rgba(15,23,42,0.06);
}
.langSwitch__btn.isActive{
  color:#0b1f44;
  background: linear-gradient(180deg, rgba(191,219,254,0.85), rgba(147,197,253,0.7));
  box-shadow: inset 0 0 0 1px rgba(59,130,246,0.28);
}
.langFlag{
  width:20px;
  height:20px;
  border-radius:999px;
  display:inline-block;
  position:relative;
  overflow:hidden;
  border:1px solid rgba(15,23,42,0.14);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.26);
}
.langFlag--ro{
  background: linear-gradient(90deg, #002b7f 0 33.33%, #fcd116 33.33% 66.66%, #ce1126 66.66% 100%);
}
.langFlag--us{
  background: repeating-linear-gradient(180deg, #b22234 0 2px, #ffffff 2px 4px);
}
.langFlag--us::after{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:44%;
  height:54%;
  background:#3c3b6e;
}
.profilePanel{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.profilePanel .card{
  padding:14px;
}
.profilePhotoRow{
  display:flex;
  align-items:center;
  gap:12px;
}
.profileAvatarPreview{
  width:56px;
  height:56px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.45);
  background:#eef2f8;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  display:grid;
  place-items:center;
  font-weight:800;
  color:#0f172a;
}
.profilePhotoBtns{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.menuItem{
  width:100%;
  text-align:left;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
  background: transparent;
  color:var(--text);
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:700;
}
.menuItem:hover{background: rgba(17,24,39,0.06)}
.menuItem:focus{outline:2px solid var(--focus); outline-offset:2px}
.menuItem--danger{color:#b42318}
.menuSep{height:1px;background: var(--border); margin:6px 0}
.menuItem__icon{
  width:20px;
  min-width:20px;
  height:20px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background: rgba(15,23,42,0.06);
  color:#0f172a;
  font-size:10px;
  font-weight:900;
}
.menuItem__icon::before{
  content:'';
  width:12px;
  height:12px;
  display:block;
  background: currentColor;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}
.menuItem--profile .menuItem__icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10Zm0 2c-4.97 0-9 2.24-9 5v3h18v-3c0-2.76-4.03-5-9-5Z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10Zm0 2c-4.97 0-9 2.24-9 5v3h18v-3c0-2.76-4.03-5-9-5Z'/%3E%3C/svg%3E");
}
.menuItem--admin .menuItem__icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m12 2 8 3v6c0 5.25-3.38 9.96-8 11-4.62-1.04-8-5.75-8-11V5l8-3Zm0 2.1L6 6.35v4.58c0 4.22 2.66 8.08 6 9.07 3.34-.99 6-4.85 6-9.07V6.35l-6-2.25Z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m12 2 8 3v6c0 5.25-3.38 9.96-8 11-4.62-1.04-8-5.75-8-11V5l8-3Zm0 2.1L6 6.35v4.58c0 4.22 2.66 8.08 6 9.07 3.34-.99 6-4.85 6-9.07V6.35l-6-2.25Z'/%3E%3C/svg%3E");
}
.menuItem--export .menuItem__icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M11 3h2v9.17l2.59-2.58L17 11l-5 5-5-5 1.41-1.41L11 12.17V3ZM5 19h14v2H5v-2Z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M11 3h2v9.17l2.59-2.58L17 11l-5 5-5-5 1.41-1.41L11 12.17V3ZM5 19h14v2H5v-2Z'/%3E%3C/svg%3E");
}
.menuItem--import .menuItem__icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M11 21h2v-9.17l2.59 2.58L17 13l-5-5-5 5 1.41 1.41L11 11.83V21ZM5 3h14v2H5V3Z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M11 21h2v-9.17l2.59 2.58L17 13l-5-5-5 5 1.41 1.41L11 11.83V21ZM5 3h14v2H5V3Z'/%3E%3C/svg%3E");
}
.menuItem--logout .menuItem__icon::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M10 3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h5v-2H5V5h5V3Zm3.59 4.59L12.17 9l2 2H8v2h6.17l-2 2 1.42 1.41L18 12l-4.41-4.41Z'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M10 3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h5v-2H5V5h5V3Zm3.59 4.59L12.17 9l2 2H8v2h6.17l-2 2 1.42 1.41L18 12l-4.41-4.41Z'/%3E%3C/svg%3E");
}
.menuItem--danger .menuItem__icon{
  color:#b42318;
  background: rgba(180,35,24,0.08);
}
.menuItem__label{
  font-size:14px;
}

.content{
  padding:18px;
  display:flex;
  flex:1;
  min-height:0;
}

.panel{
  width:100%;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background: rgba(255,255,255,0.78);
  box-shadow: var(--shadow);
  padding:18px;
  min-width:0;
}

.panel__title{font-size:16px; font-weight:700; margin:0 0 6px}
.panel__sub{color:var(--muted); margin:0 0 16px; font-size:13px}

.emptyState{
  border:1px dashed rgba(17,24,39,0.22);
  border-radius:var(--radius);
  padding:16px;
  color:var(--muted);
  background: rgba(17,24,39,0.02);
}

.kbd{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:12px;
  padding:2px 6px;
  border:1px solid var(--border);
  border-radius:8px;
  background: rgba(17,24,39,0.03);
}

.muted{color:var(--muted)}

/* Modal */
.modal{position:fixed; inset:0; display:none; z-index:9998}
.modal.isOpen{display:block}
.modal__backdrop{position:absolute; inset:0; background: rgba(0,0,0,0.55)}
.modal__panel{
  position:relative;
  width:min(720px, calc(100% - 28px));
  margin: 6vh auto;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background: rgba(255,255,255,0.98);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.modal__head{display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--border)}
.modal__title{font-weight:700}
.iconBtn{
  width:34px;height:34px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(17,24,39,0.04);
  color:var(--text);
  cursor:pointer;
}
.iconBtn:hover{background: rgba(17,24,39,0.06)}
.iconBtn:focus{outline:2px solid var(--focus); outline-offset:2px}
.modal__body{padding:16px; color:var(--text)}
.modal__foot{padding:14px 16px; border-top:1px solid var(--border); display:flex; justify-content:flex-end; gap:10px}

/* Modal Drawer (premium details) */
.modal.isDrawer .modal__panel{
  position:absolute;
  top:0; bottom:0; right:0;
  margin:0;
  width:min(520px, 92vw);
  max-height:100vh;
  border-radius: 18px 0 0 18px;
  box-shadow: 0 30px 90px rgba(0,0,0,0.35);
}
@media (max-width: 520px){
  .modal.isDrawer .modal__panel{width:100vw; border-radius: 0}
}
.modal.isDrawer .modal__head{padding:16px 16px}
.modal.isDrawer .modal__body{padding:16px}
.modal.isDrawer .modal__foot{justify-content:space-between; flex-wrap:wrap}

/* Admin panel modal */
.modal__panel.modal__panel--admin{
  width:min(1160px, calc(100% - 10px));
  max-height:min(94vh, 900px) !important;
  margin:1.2vh auto;
  border-radius:16px;
  border:1px solid rgba(148,163,184,0.30);
  background:
    radial-gradient(900px 300px at 8% -28%, rgba(59,130,246,0.15), transparent 60%),
    radial-gradient(900px 260px at 102% -20%, rgba(14,165,233,0.12), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,0.97), rgba(248,250,255,0.94));
  box-shadow:0 28px 80px rgba(15,23,42,0.18);
}
.modal__panel.modal__panel--admin .modal__head{
  padding:8px 10px;
  border-bottom:1px solid rgba(148,163,184,0.24);
  background:linear-gradient(180deg, rgba(255,255,255,0.97), rgba(255,255,255,0.86));
}
.modal__panel.modal__panel--admin .modal__title{
  font-size:16px;
  letter-spacing:-0.01em;
}
.modal__panel.modal__panel--admin .modal__body{
  padding:7px 8px 8px !important;
}
.adminPanel{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.adminPanelHero{
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:stretch;
  justify-content:space-between;
  gap:10px;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:12px;
  padding:8px 9px;
  background:linear-gradient(145deg, rgba(255,255,255,0.90), rgba(241,245,255,0.80));
  box-shadow:0 10px 26px rgba(15,23,42,0.07);
}
.adminPanelHero.adminPanelHero--compact{
  width:fit-content;
  max-width:100%;
  margin-left:auto;
  justify-content:flex-end;
  padding:4px;
  border-radius:10px;
  border-color:rgba(148,163,184,0.26);
  box-shadow:0 5px 14px rgba(15,23,42,0.05);
}
.adminPanelHero.adminPanelHero--compact .adminPanelHero__kpis{
  margin-left:0;
}
.adminPanelHero.adminPanelHero--compact::after{
  display:none;
}
.adminPanelHero::after{
  content:'';
  position:absolute;
  inset:auto -60px -60px auto;
  width:200px;
  height:200px;
  border-radius:50%;
  background:radial-gradient(circle at center, rgba(59,130,246,0.12), transparent 65%);
  pointer-events:none;
}
.adminPanelHero__title{
  margin:0;
  font-size:16px;
  font-weight:800;
  letter-spacing:-0.01em;
}
.adminPanelHero__sub{
  margin:3px 0 0;
  font-size:12px;
  max-width:64ch;
}
.adminPanelHero__kpis{
  display:grid;
  grid-template-columns:repeat(2, minmax(90px, 1fr));
  gap:5px;
  min-width:220px;
}
.adminPanelHero__kpi{
  border:1px solid rgba(148,163,184,0.24);
  border-radius:9px;
  padding:5px 7px;
  background:rgba(255,255,255,0.86);
}
.adminPanelHero__kpiLabel{
  font-size:9.5px;
  text-transform:uppercase;
  letter-spacing:0.09em;
}
.adminPanelHero__kpiValue{
  margin-top:1px;
  font-size:15px;
  font-weight:800;
  line-height:1.1;
}

.adminPanelGrid{
  display:grid;
  grid-template-columns:248px minmax(0, 1fr);
  gap:6px;
  align-items:start;
}
.adminPanelGrid__side,
.adminPanelGrid__main{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.adminPanelCard{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:10px;
  padding:7px 8px;
  background:rgba(255,255,255,0.90);
  box-shadow:0 8px 20px rgba(15,23,42,0.05);
}
.adminPanelCard::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:1px;
  background:linear-gradient(90deg, rgba(59,130,246,0.32), rgba(14,165,233,0.08));
  pointer-events:none;
}
.adminPanelCard--soft{
  background:linear-gradient(150deg, rgba(248,250,255,0.92), rgba(255,255,255,0.88));
}
.adminPanelCard__title{
  margin:0;
  font-size:14.5px;
  font-weight:800;
  letter-spacing:-0.01em;
}
.adminPanelCard__sub{
  margin:3px 0 0;
  font-size:11px;
  line-height:1.4;
}
.adminPanelCard__actions{
  margin-top:5px;
}
.adminPanel__status{
  margin-top:4px;
  min-height:14px;
  font-size:10px;
}
.adminPanelMeta{
  margin-top:4px;
  font-size:12px;
  line-height:1.3;
}
.adminPanel .btnRow{
  gap:5px;
}
.adminPanel .primaryBtn,
.adminPanel .ghostBtn{
  height:30px;
  padding:0 9px;
  border-radius:8px;
  font-size:12px;
  font-weight:700;
}
.adminPanel .input{
  height:30px;
  padding:4px 8px;
  border-radius:8px;
  font-size:12px;
  background:rgba(255,255,255,0.94);
}
.adminPanel .input.input--mini{
  padding:4px 7px;
}
.adminPanel textarea.input{
  height:auto;
  min-height:72px;
}

.adminPanelAudit__head{
  display:flex;
  justify-content:space-between;
  gap:8px;
  align-items:center;
}
.adminPanelAudit__toolbar{
  margin-top:5px;
  display:flex;
  gap:5px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.adminPanelAudit__toolbar--secondary{
  margin-top:4px;
  padding-top:4px;
  border-top:1px dashed rgba(148,163,184,0.28);
  flex-wrap:nowrap;
}
.adminPanelAudit__search{
  flex:1 1 250px;
  min-width:180px;
}
.adminPanelAudit__filters{
  display:flex;
  gap:6px;
  align-items:center;
  flex-wrap:wrap;
}
.adminPanelAudit__toolbar--secondary .adminPanelAudit__filters{
  flex-wrap:nowrap;
}
.adminPanelAudit__filters .input{
  width:auto;
}
.adminPanelAudit__pager{
  display:flex;
  gap:6px;
  align-items:center;
  margin-left:auto;
}
.adminPanelAudit__tableWrap{
  margin-top:5px;
  overflow:auto;
  max-height:330px;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:9px;
  background:rgba(255,255,255,0.94);
}
.adminPanelAudit__table{
  width:100%;
  min-width:980px;
  border-collapse:collapse;
  font-size:11.5px;
  line-height:1.35;
}
.adminPanelAudit__table th,
.adminPanelAudit__table td{
  padding:5px 6px;
  border-bottom:1px solid rgba(148,163,184,0.20);
  text-align:left;
  vertical-align:top;
}
.adminPanelAudit__table th{
  position:sticky;
  top:0;
  z-index:1;
  background:rgba(241,245,255,0.97);
  backdrop-filter:blur(5px);
  font-size:10px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.adminPanelAudit__table tbody tr:nth-child(even) td{
  background:rgba(241,245,255,0.30);
}
.adminPanelAudit__table tr:last-child td{
  border-bottom:none;
}
.adminPanelAudit__table td:nth-child(6){
  max-width:290px;
  overflow-wrap:anywhere;
}
.adminPanelAudit__empty{
  padding:8px !important;
}
.adminAuditDetails summary{
  cursor:pointer;
  font-size:11px;
  color:var(--muted);
}
.adminAuditDetails__pre{
  margin:5px 0 0;
  font-size:10px;
  white-space:pre-wrap;
}

@media (max-width: 1080px){
  .adminPanelGrid{grid-template-columns:1fr;}
  .adminPanelHero{
    flex-direction:column;
    align-items:flex-start;
  }
  .adminPanelHero__kpis{
    min-width:0;
    width:100%;
  }
  .adminPanelHero.adminPanelHero--compact{
    width:100%;
    margin-left:0;
  }
  .adminPanelGrid__side{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:6px;
  }
}
@media (max-width: 720px){
  .modal__panel.modal__panel--admin{
    width:calc(100% - 12px);
    margin:1.5vh auto;
    border-radius:16px;
  }
  .adminPanelAudit__toolbar--secondary{
    flex-wrap:wrap;
  }
  .adminPanelAudit__toolbar--secondary .adminPanelAudit__filters{
    flex-wrap:wrap;
  }
  .adminPanelAudit__pager{
    margin-left:0;
  }
  .adminPanelGrid__side{
    grid-template-columns:1fr;
  }
  .adminPanelHero__kpis{
    grid-template-columns:1fr;
  }
  .adminPanelCard__title{
    font-size:15px;
  }
}

.primaryBtn{
  border:1px solid var(--border);
  background: rgba(17,24,39,0.06);
  color:var(--text);
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
}
.primaryBtn:hover{background: rgba(17,24,39,0.08)}
.primaryBtn:focus{outline:2px solid var(--focus); outline-offset:2px}
.primaryBtn.isLoading{
  cursor:wait;
  opacity:0.92;
}
.primaryBtn.isLoading::after{
  content:'';
  display:inline-block;
  width:12px;
  height:12px;
  margin-left:8px;
  border-radius:999px;
  border:2px solid rgba(15,23,42,0.20);
  border-top-color:rgba(15,23,42,0.86);
  vertical-align:-2px;
  animation: btnSpin .7s linear infinite;
}
@keyframes btnSpin{
  to{transform:rotate(360deg)}
}

.ghostBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.70);
  color:var(--text);
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  text-decoration:none;
  user-select:none;
}
.ghostBtn:hover{background: rgba(17,24,39,0.04)}
.ghostBtn:focus{outline:2px solid var(--focus); outline-offset:2px}

.dangerBtn{
  border:1px solid rgba(239,68,68,0.35);
  background: rgba(239,68,68,0.10);
  color: rgba(185,28,28,1);
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
}
.dangerBtn:hover{background: rgba(239,68,68,0.14)}
.dangerBtn:focus{outline:2px solid var(--focus); outline-offset:2px}

/* Mobile drawer (sidebar) */
.drawerBackdrop{display:none}

/* Desktop sidebar collapse (icons-only) */
body.sidebarCollapsed .app{grid-template-columns:88px 1fr}
body.sidebarCollapsed .sidebar{
  padding:14px 12px;
  align-items:center;
}
body.sidebarCollapsed .brand{
  width:58px;
  min-width:58px;
  max-width:58px;
  min-height:58px;
  padding:0;
  justify-content:center;
  border-radius:16px;
  box-shadow:none;
  border:none;
  background:transparent;
}
body.sidebarCollapsed .brand__text{display:none}
body.sidebarCollapsed .brand__logoFull{display:none}
body.sidebarCollapsed .brand__mark{
  width:50px;
  height:50px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,0.14);
  background: rgba(255,255,255,0.98);
  box-shadow: 0 5px 14px rgba(15,23,42,0.14);
}
body.sidebarCollapsed .brand__logo--mini{
  border-radius:14px;
}
body.sidebarCollapsed .brand__logo,
body.sidebarCollapsed .brand__logoFallback{border-radius:14px}
body.sidebarCollapsed .nav{
  width:100%;
  padding:0;
}
body.sidebarCollapsed .nav__label{display:none}
body.sidebarCollapsed .nav__list{
  align-items:center;
  gap:10px;
}
body.sidebarCollapsed .tabBtn{
  width:52px;
  justify-content:center;
  padding:8px;
}
body.sidebarCollapsed .tabLabel{display:none}
body.sidebarCollapsed .sidebar__footer{display:none}
body.sidebarCollapsed .sidebar__account{
  margin-top:10px;
  margin-bottom:8px;
  display:flex;
  justify-content:center;
}
body.sidebarCollapsed .sidebar__account .account__btn{
  width:52px;
  height:52px;
  padding:0;
  border-radius:16px;
  justify-content:center;
  overflow:hidden;
  background: rgba(255,255,255,0.96);
  border:1px solid rgba(17,24,39,0.14);
  box-shadow: 0 5px 14px rgba(15,23,42,0.14);
}
body.sidebarCollapsed .sidebar__account .account__name,
body.sidebarCollapsed .sidebar__account .account__chev{display:none}
body.sidebarCollapsed .sidebar__account .account__avatar{
  width:100%;
  height:100%;
  border-radius:16px;
  border:none;
  background-color:transparent;
  margin:0;
}
body.sidebarCollapsed .sidebar__account .account__menu{
  left:calc(100% + 12px);
  right:auto;
  top:0;
  min-width:220px;
  max-width:min(320px, calc(100vw - 130px));
  z-index:10090;
  border-radius:16px;
  border:1px solid rgba(148,163,184,0.35);
  background: linear-gradient(180deg, rgba(255,255,255,0.97), rgba(244,247,255,0.94));
  box-shadow: 0 14px 40px rgba(15,23,42,0.22);
  backdrop-filter: blur(10px);
}
body.sidebarCollapsed .sidebar__account .account__menu::before{
  content:'';
  position:absolute;
  left:-7px;
  top:16px;
  width:12px;
  height:12px;
  transform:rotate(45deg);
  background: rgba(248,250,255,0.98);
  border-left:1px solid rgba(148,163,184,0.35);
  border-top:1px solid rgba(148,163,184,0.35);
}
body.sidebarCollapsed .sidebar__account .account__menu.isOpen{
  animation: accountMenuPop .14s ease-out;
}

@keyframes accountMenuPop{
  from{
    opacity:0;
    transform:translateX(-6px) scale(0.98);
  }
  to{
    opacity:1;
    transform:translateX(0) scale(1);
  }
}
body.sidebarCollapsed .sidebar__collapseBtn{
  right:-2px;
  top:-2px;
  transform:none;
  width:20px;
  height:20px;
  border-radius:10px;
  font-size:10px;
  padding:0;
  min-width:20px;
  line-height:1;
  background: rgba(241,245,249,0.96);
  border:1px solid rgba(17,24,39,0.14);
  box-shadow: 0 2px 6px rgba(15,23,42,0.12);
}
body:not(.sidebarCollapsed) .brand__mark{display:none}
body:not(.sidebarCollapsed) .brand__text{display:block}

@media (max-width: 900px){
  .app{grid-template-columns: 1fr}
  .topbar{display:flex}
  .topbar__nav{display:inline-flex; align-items:center; justify-content:center}
  .sidebar__collapseBtn{display:none}

  .sidebar{
    display:block;
    position:fixed;
    top:0;
    bottom:0;
    left:0;
    width:280px;
    max-width: calc(100vw - 56px);
    transform: translateX(-105%);
    transition: transform .22s ease;
    z-index:10020;
    overflow-y:auto;
  }
  .sidebar.isOpen{transform: translateX(0)}

  .drawerBackdrop{
    position:fixed;
    inset:0;
    background: rgba(0,0,0,0.25);
    z-index:10010;
  }
  .drawerBackdrop.isOpen{display:block}

  body.hasDrawerOpen{overflow:hidden}
  body.sidebarCollapsed .app{grid-template-columns:1fr}
  body.sidebarCollapsed .brand__text{display:block}
  body.sidebarCollapsed .nav{display:block}
  body.sidebarCollapsed .nav__label{display:block}
  body.sidebarCollapsed .tabLabel{display:inline}
  body.sidebarCollapsed .sidebar__footer{display:block}
  body.sidebarCollapsed .sidebar__account .account__name,
  body.sidebarCollapsed .sidebar__account .account__chev{display:inline}
  body.sidebarCollapsed .sidebar__account .account__btn{
    width:100%;
    height:auto;
    padding:10px 12px;
    border-radius:14px;
    justify-content:space-between;
  }
  body.sidebarCollapsed .sidebar__account .account__menu{
    left:0;
    right:0;
    min-width:0;
  }
}


/* === Hobby library (v1) === */
.hobbyWrap{display:flex; flex-direction:column; gap:12px}
.hobbyHeader{margin-top:12px; display:flex; flex-direction:column; gap:10px}
.hobbyHeader__top{display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap}
.hobbyHeader__bottom{display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap}
.hobbyHeader__search{flex:1; min-width:220px}
.hobbyHeader__actions2{display:flex; gap:10px; flex-wrap:wrap}

.subTabs{display:flex; gap:8px; flex-wrap:wrap}
.pillBtn{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.85);
  cursor:pointer;
}
.pillBtn:hover{background: rgba(17,24,39,0.03)}
.pillBtn.isActive{
  background: rgba(59,130,246,0.12);
  border-color: rgba(59,130,246,0.35);
}

.formGrid{display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:12px}
@media (max-width: 720px){ .formGrid{grid-template-columns:1fr} }
.label{font-size:12px; color: var(--muted); margin-bottom:6px}

.listWrap{display:flex; flex-direction:column; gap:10px; margin-top:12px}
.listCard{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.88);
  box-shadow: 0 8px 20px rgba(17,24,39,0.06);
  padding:12px;
}
.rowTitle{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.rowTitleText{font-weight:700}
.rowActions{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px}

.lookupBox{margin-top:12px}
.lookupResults{display:flex; flex-direction:column; gap:8px; margin-top:10px}
.lookupItem{
  width:100%;
  text-align:left;
  padding:10px;
  border-radius: 14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.78);
  cursor:pointer;
}
.lookupItem:hover{background: rgba(17,24,39,0.03)}
.lookupTitle{font-weight:700}


/* --- Hobby modal form usability fixes --- */
.modal__panel{max-height:88vh; display:flex; flex-direction:column}
.modal__body{overflow:auto}
.modal__foot{flex:0 0 auto}

.input{
  width:100%;
  box-sizing:border-box;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.92);
  color: var(--text);
}
.input:focus{
  outline: none;
  box-shadow: 0 0 0 3px var(--focus);
}
textarea.input{resize:vertical}

/* --- Generic small form helpers (used by Abonamente) --- */
.form{display:flex; flex-direction:column; gap:12px}
.formRow{display:grid; grid-template-columns: 140px 1fr; gap:12px; align-items:center}
@media (max-width: 720px){ .formRow{grid-template-columns:1fr} }
.formLabel{font-size:12px; color: var(--muted)}
.formCtrl{min-width:0}
.grid2{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:12px}
@media (max-width: 720px){ .grid2{grid-template-columns:1fr} }
.checkRow{display:flex; align-items:center; gap:10px; padding:8px 0}

/* === Abonamente === */
/* Clean + aligned: use full available content width (the .content container already adds gutters).
   This avoids the "column in the middle" effect caused by margin:auto inside a flex container. */
.subsWrap{display:flex; flex-direction:column; gap:14px; width:100%; max-width:none; margin:0}
.subsTop{display:grid; grid-template-columns: 1fr auto; gap:12px; align-items:stretch}
@media (max-width: 900px){
  .subsTop{grid-template-columns:1fr}
  .subsActions{justify-content:flex-start}
}
.subsVault{
  flex:1;
  min-width:260px;
  border:1px solid rgba(17,24,39,0.14);
  border-radius: var(--radius);
  background:
    radial-gradient(700px 220px at 10% 0%, rgba(59,130,246,0.18), transparent 60%),
    radial-gradient(500px 200px at 110% 20%, rgba(16,185,129,0.12), transparent 55%),
    rgba(255,255,255,0.88);
  box-shadow: 0 16px 40px rgba(17,24,39,0.08);
  padding:16px;
  position:relative;
  overflow:hidden;
}
.subsVault__head{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.subsVault__actions{display:flex; gap:10px; align-items:flex-start; justify-content:flex-end; flex-wrap:wrap}
.subsVault__actions .iconBtn{width:42px;height:42px;border-radius:14px}
.subsVault__actions .primaryBtn.iconBtn{border-color: rgba(59,130,246,0.35); background: rgba(59,130,246,0.10)}
.subsVault__actions .primaryBtn.iconBtn:hover{background: rgba(59,130,246,0.14)}
.subsVault__actions .ghostBtn.iconBtn{background: rgba(255,255,255,0.78)}
.subsVault__actions .ghostBtn.iconBtn:hover{background: rgba(17,24,39,0.04)}
.subsVault__title{font-weight:800; letter-spacing:0.2px; display:flex; align-items:center; gap:8px}
.subsVault__value{font-size:26px; font-weight:900; margin-top:6px}
.subsVault__meta{font-size:12px; margin-top:6px}

/* legacy (kept for compatibility in other patches, but not used by current Abonamente header) */
.subsActions{display:flex; gap:10px; flex-wrap:wrap; align-items:flex-start; justify-content:flex-end}
.subsActions .iconBtn{width:42px;height:42px;border-radius:14px}
.subsActions .primaryBtn.iconBtn{border-color: rgba(59,130,246,0.35); background: rgba(59,130,246,0.10)}
.subsActions .primaryBtn.iconBtn:hover{background: rgba(59,130,246,0.14)}
.subsActions .ghostBtn.iconBtn{background: rgba(255,255,255,0.78)}
.subsActions .ghostBtn.iconBtn:hover{background: rgba(17,24,39,0.04)}

/* KPI cards */
.subsKpis{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px}
@media (max-width: 900px){ .subsKpis{grid-template-columns:1fr} }
.subsKpi{
  border:1px solid rgba(17,24,39,0.10);
  border-radius: 16px;
  background: rgba(255,255,255,0.88);
  box-shadow: 0 12px 28px rgba(17,24,39,0.06);
  padding:12px 14px;
  display:flex;
  flex-direction:column;
  gap:6px;
  overflow:hidden;
  position:relative;
}
.subsKpi:before{
  content:'';
  position:absolute;
  inset:-120px -120px auto auto;
  width:260px;
  height:260px;
  background: radial-gradient(circle at 30% 30%, rgba(59,130,246,0.16), transparent 60%);
  transform: rotate(15deg);
}
.subsKpi__label{font-size:12px; color: var(--muted); position:relative}
.subsKpi__value{font-size:18px; font-weight:900; position:relative}
.subsKpi__sub{font-size:12px; color: var(--muted); position:relative}
.subsKpi.isGood:before{background: radial-gradient(circle at 30% 30%, rgba(34,197,94,0.14), transparent 60%)}
.subsKpi.isWarn:before{background: radial-gradient(circle at 30% 30%, rgba(245,158,11,0.16), transparent 60%)}
.subsKpi.isBad:before{background: radial-gradient(circle at 30% 30%, rgba(239,68,68,0.14), transparent 60%)}

.subsFocus{
  border:1px solid rgba(17,24,39,0.12);
  border-radius: var(--radius);
  background:
    radial-gradient(680px 200px at 0% 0%, rgba(148,163,184,0.18), transparent 60%),
    rgba(255,255,255,0.82);
  padding:14px 16px;
  box-shadow: 0 12px 28px rgba(17,24,39,0.06);
}
.subsFocus__head{display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:12px}
.subsFocus__title{font-weight:800; display:flex; align-items:center; gap:8px}
.subsFocus__rows{display:flex; flex-direction:column; gap:8px}
.subsFocus__row{display:flex; align-items:center; justify-content:space-between; gap:12px}

/* Toolbar (filters / search / sort / group) */
.subsToolbar{
  border:1px solid rgba(17,24,39,0.10);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.86);
  box-shadow: 0 10px 24px rgba(17,24,39,0.06);
  padding:12px;
}
.subsToolbar__main{
  display:grid;
  grid-template-columns: auto minmax(240px, 1fr) auto;
  gap:12px;
  align-items:center;
}
.subsSeg{display:flex; flex-wrap:wrap; gap:6px}
.subsToolbar__searchWrap{display:flex; align-items:center; gap:8px; min-width:0}
.subsSearch{width:100%; min-width:220px}
.subsToolbar__controls{display:flex; align-items:center; justify-content:flex-end; gap:10px; flex-wrap:wrap}
.subsSelect{width:auto; min-width:200px}

@media (max-width: 980px){
  .subsToolbar__main{grid-template-columns: 1fr;}
  .subsSelect{width:100%; min-width:0}
  .subsToolbar__controls{justify-content:flex-start}
  .subsSearch{min-width:0}
}

.subsList{display:flex; flex-direction:column; gap:12px}

/* Subscription Details Drawer */
.subDrawer{display:flex; flex-direction:column; gap:14px}
.subDrawer__head{padding:12px; border:1px solid var(--border); border-radius:18px; background: rgba(255,255,255,0.75)}
.subDrawer__titleRow{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.subDrawer__name{font-weight:900; font-size:18px; line-height:1.15}
.subDrawer__badges{display:flex; gap:8px; align-items:center; flex-wrap:wrap; justify-content:flex-end}
.subDrawer__meta{margin-top:8px; font-size:12px}
.subDrawer__progress{padding:12px; border:1px solid var(--border); border-radius:18px; background: rgba(255,255,255,0.75)}
.subDrawer__progressTop{display:flex; align-items:center; justify-content:space-between}
.subDrawer__pct{font-weight:900}
.subDrawer__kpis{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:10px; margin-top:12px}
@media (max-width: 520px){ .subDrawer__kpis{grid-template-columns:1fr} }
.subDrawer__kpi{border:1px solid var(--border); border-radius:16px; padding:10px; background: rgba(17,24,39,0.03)}
.subDrawer__kpiVal{font-weight:900; margin-top:4px}
.subDrawer__section{padding:12px; border:1px solid var(--border); border-radius:18px; background: rgba(255,255,255,0.75)}
.subDrawer__sectionTitle{font-weight:800; margin-bottom:10px}
.subDrawer__note{white-space:pre-wrap}
.subDrawer__rows{display:flex; flex-direction:column; gap:10px}
.subDrawer__row{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:10px; border:1px solid var(--border); border-radius:16px; background: rgba(255,255,255,0.70)}
.subDrawer__rowTitle{font-weight:800}
.subDrawer__rowSub{font-size:12px; margin-top:3px}
.subDrawer__rowAmt{font-weight:900; white-space:nowrap}

.subsCard{
  border:1px solid rgba(17,24,39,0.12);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.90);
  box-shadow: 0 12px 28px rgba(17,24,39,0.07);
  padding:14px;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.subsCard:hover{transform: translateY(-1px); box-shadow: 0 18px 42px rgba(17,24,39,0.10)}
.subsCard.isCovered{border-color: rgba(34,197,94,0.35); background: rgba(34,197,94,0.05)}
.subsCard.isOverdue{border-color: rgba(239,68,68,0.35); background: rgba(239,68,68,0.04)}

.subsCard__top{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.subsCard__title{min-width:0; flex:1; display:flex; gap:12px; align-items:flex-start}
.subsLogo{
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,0.10);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  letter-spacing:0.2px;
  flex:0 0 auto;
  background: rgba(59,130,246,0.10);
  color: rgba(30,64,175,1);
}
.subsLogo svg{width:22px;height:22px; fill: currentColor}

/* Logo picker (modal) */
.logoPicker{display:grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap:10px}
@media (max-width: 720px){ .logoPicker{grid-template-columns: repeat(2, minmax(0,1fr));} }
.logoPick{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.88);
  cursor:pointer;
  text-align:left;
  transition: background .12s ease, box-shadow .12s ease, transform .12s ease;
}
.logoPick:hover{background: rgba(17,24,39,0.03); transform: translateY(-1px)}
.logoPick.isActive{
  background: rgba(59,130,246,0.08);
  border-color: rgba(59,130,246,0.35);
  box-shadow: 0 0 0 3px var(--focus);
}
.logoPick__icon{
  width:28px;
  height:28px;
  border-radius:10px;
  border:1px solid rgba(17,24,39,0.10);
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(148,163,184,0.18);
  flex:0 0 auto;
}
.logoPick__icon svg{width:18px; height:18px; fill: currentColor; opacity:0.85}
.logoPick__label{font-size:12px; font-weight:900; line-height:1.1}
.subsTitleBlock{min-width:0; flex:1}
.subsCard__nameRow{display:flex; align-items:center; justify-content:space-between; gap:10px}
.subsCard__name{font-weight:900; letter-spacing:0.2px; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.subsCard__pct{font-weight:800; font-size:12px; color: var(--muted)}
.subsCard__chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:8px}
.subsCard__icons{display:flex; gap:8px; align-items:center; flex-wrap:wrap; justify-content:flex-end}

/* hover actions: icon buttons fade in on desktop, always visible on mobile */
.subsHoverActions{opacity:0; transform: translateY(-2px); transition: opacity .15s ease, transform .15s ease}
.subsCard:hover .subsHoverActions{opacity:1; transform: translateY(0)}
@media (hover: none), (max-width: 900px){
  .subsHoverActions{opacity:1; transform:none}
}

.subsCard__progress{height:9px; border-radius:999px; background: rgba(17,24,39,0.06); overflow:hidden; margin-top:12px}
.subsCard__progressBar{
  height:100%;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(59,130,246,0.80), rgba(59,130,246,0.25), rgba(59,130,246,0.65));
  background-size: 200% 100%;
  transition: width .55s ease;
}
.subsCard.isCovered .subsCard__progressBar{background: linear-gradient(90deg, rgba(34,197,94,0.78), rgba(34,197,94,0.28))}
.subsCard.isOverdue .subsCard__progressBar{background: linear-gradient(90deg, rgba(239,68,68,0.72), rgba(239,68,68,0.26))}

@media (prefers-reduced-motion: no-preference){
  .subsCard:not(.isCovered) .subsCard__progressBar{animation: subsBarShimmer 3.2s ease-in-out infinite}
}
@keyframes subsBarShimmer{
  0%{background-position: 0% 50%}
  50%{background-position: 100% 50%}
  100%{background-position: 0% 50%}
}

.subsCard__bottom{display:flex; justify-content:space-between; align-items:flex-end; gap:12px; margin-top:12px; flex-wrap:wrap}
.subsCard__targetVal{font-size:18px; font-weight:900}
.subsCard__rate{font-size:12px}
.subsWarn{color: rgba(185,28,28,1)}

/* Abonamente compact premium pass */
.panel.subsPage{
  border:1px solid rgba(59,130,246,0.16);
  background:
    radial-gradient(780px 220px at 8% -5%, rgba(59,130,246,0.11), transparent 62%),
    radial-gradient(780px 220px at 92% 0%, rgba(16,185,129,0.09), transparent 62%),
    rgba(255,255,255,0.86);
  box-shadow:0 20px 38px rgba(15,23,42,0.11);
}
.panel.subsPage .subsWrap{
  gap:10px;
}
.panel.subsPage .subsTop{
  gap:10px;
}
.panel.subsPage .subsVault{
  border-color:rgba(148,163,184,0.28);
  border-radius:16px;
  background:
    radial-gradient(700px 220px at 10% 0%, rgba(59,130,246,0.14), transparent 62%),
    radial-gradient(520px 200px at 105% 20%, rgba(16,185,129,0.10), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,245,249,0.90));
  box-shadow:
    0 12px 24px rgba(15,23,42,0.08),
    inset 0 1px 0 rgba(255,255,255,0.82);
  padding:12px;
}
.panel.subsPage .subsVault__actions{
  gap:8px;
}
.panel.subsPage .subsVault__actions .iconBtn{
  width:38px;
  height:38px;
  border-radius:12px;
}
.panel.subsPage .subsVault__title{
  font-size:15px;
}
.panel.subsPage .subsVault__value{
  font-size:clamp(29px, 2.2vw, 38px);
  line-height:1.02;
  margin-top:4px;
}
.panel.subsPage .subsVault__meta{
  margin-top:4px;
  font-size:11.5px;
}

.panel.subsPage .subsKpis{
  gap:9px;
}
.panel.subsPage .subsKpi{
  border-color:rgba(148,163,184,0.26);
  border-radius:15px;
  box-shadow:
    0 10px 20px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.82);
  min-height:90px;
  padding:9px 10px;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.panel.subsPage .subsKpi__label{
  font-size:10.5px;
  color:#60708a;
  letter-spacing:0.2px;
}
.panel.subsPage .subsKpi__value{
  font-size:clamp(22px, 1.9vw, 31px);
  line-height:1.03;
}
.panel.subsPage .subsKpi__sub{
  font-size:11px;
}

.panel.subsPage .subsFocus{
  border-color:rgba(148,163,184,0.25);
  border-radius:15px;
  background:
    radial-gradient(650px 190px at 0% 0%, rgba(148,163,184,0.12), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(241,245,249,0.88));
  box-shadow:
    0 10px 20px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.82);
  padding:11px;
}
.panel.subsPage .subsFocus__head{
  margin-bottom:9px;
}
.panel.subsPage .subsFocus__title{
  font-size:15px;
  letter-spacing:0.2px;
}
.panel.subsPage .subsFocus__rows{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:8px;
}
.panel.subsPage .subsFocus__row{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:10px;
  background:rgba(255,255,255,0.78);
  min-height:72px;
  padding:10px 11px;
  text-align:center;
}
.panel.subsPage .subsFocus__row .muted{
  font-size:11px;
  line-height:1.15;
  text-align:center;
}
.panel.subsPage .subsFocus__row > div:last-child{
  margin-top:6px;
  font-size:17px;
  line-height:1.2;
  font-weight:800;
  color:#0f172a;
  text-align:center;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.panel.subsPage .subsList{
  gap:9px;
}
.panel.subsPage .subsCard{
  border-color:rgba(148,163,184,0.26);
  border-radius:15px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,245,249,0.88));
  box-shadow:
    0 10px 20px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.82);
  padding:10px;
}
.panel.subsPage .subsCard__top{
  gap:10px;
}
.panel.subsPage .subsCard__title{
  gap:10px;
}
.panel.subsPage .subsLogo{
  width:38px;
  height:38px;
  border-radius:12px;
}
.panel.subsPage .subsLogo svg{
  width:20px;
  height:20px;
}
.panel.subsPage .subsCard__name{
  font-size:15px;
}
.panel.subsPage .subsCard__chips{
  gap:6px;
  margin-top:7px;
}
.panel.subsPage .subsCard__chips .chip{
  font-size:11px;
  padding:4px 8px;
}
.panel.subsPage .subsCard__icons{
  gap:7px;
}
.panel.subsPage .subsCard__icons .iconBtn{
  width:34px;
  height:34px;
  border-radius:11px;
}
.panel.subsPage .subsCard__progress{
  height:8px;
  margin-top:9px;
}
.panel.subsPage .subsCard__bottom{
  margin-top:9px;
  gap:10px;
}
.panel.subsPage .subsCard__targetVal{
  font-size:17px;
  line-height:1.05;
}
.panel.subsPage .subsCard__rate{
  font-size:11.5px;
}

@media (max-width: 900px){
  .panel.subsPage .subsVault{
    padding:11px;
  }
  .panel.subsPage .subsKpis{
    grid-template-columns:1fr;
  }
  .panel.subsPage .subsFocus__rows{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 620px){
  .panel.subsPage .subsFocus__rows{
    grid-template-columns:1fr;
  }
  .panel.subsPage .subsFocus__row{
    min-height:0;
  }
  .panel.subsPage .subsFocus__row > div:last-child{
    font-size:15px;
  }
  .panel.subsPage .subsCard__top{
    flex-direction:column;
    align-items:stretch;
  }
  .panel.subsPage .subsCard__icons{
    justify-content:flex-start;
  }
  .panel.subsPage .subsCard__bottom{
    align-items:flex-start;
  }
}
/* === Hobby library (v2 UI) === */
.hobbyToolbar{margin-top:12px; display:flex; flex-direction:column; gap:10px}
.hobbyToolbar__row{display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap}
.hobbyToolbar__row--controls{display:grid; grid-template-columns: 1fr minmax(260px, 560px) auto; gap:10px; align-items:center}
@media (max-width: 980px){.hobbyToolbar__row--controls{grid-template-columns: 1fr;}}
.hobbyToolbar__actions{display:flex; gap:10px; flex-wrap:wrap}
.hobbyToolbar__search{flex:1; min-width:240px}
.hobbyToolbar__controls{display:flex; gap:10px; flex-wrap:wrap}
.hobbyToolbar__controlsGrid{display:grid; grid-template-columns: repeat(3, minmax(160px, 1fr)); gap:10px; width:100%;}
@media (max-width: 860px){
  .hobbyToolbar__controlsGrid{grid-template-columns: 1fr;}
}
.hobbyToolbar__extras{display:flex; gap:10px; flex-wrap:nowrap; align-items:center; justify-content:flex-end}
@media (max-width: 980px){.hobbyToolbar__extras{flex-wrap:wrap; justify-content:flex-start}}
.hobbyStats{font-size:12px; line-height:1.2; white-space:nowrap}

.segGroup{display:inline-flex; gap:6px}
.segBtn{
  padding:8px 10px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.88);
  cursor:pointer;
  line-height:1;
  min-width:38px;
}
.segBtn:hover{background: rgba(17,24,39,0.03)}
.segBtn.isActive{
  background: rgba(59,130,246,0.10);
  box-shadow: 0 0 0 3px var(--focus);
}

.hobbyGrid{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap:12px;
}
@media (max-width: 520px){
  .hobbyGrid{grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));}
}

.hobbyList{
  margin-top:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.hobbyList .hobbyCard{flex-direction:row; align-items:stretch}
.hobbyList .hobbyCard__media{width:96px; aspect-ratio:auto}
.hobbyList .hobbyCard__media,.hobbyList .hobbyCard__img,.hobbyList .hobbyCard__ph{height:132px}
.hobbyList .hobbyCard__body{padding:12px; flex:1}
.hobbyList .hobbyCard__actions{
  border-top:none;
  border-left:1px solid rgba(17,24,39,0.06);
  justify-content:center;
  align-content:center;
  flex: 0 0 180px;
  background: rgba(255,255,255,0.55);
}
@media (max-width: 640px){
  .hobbyList .hobbyCard{flex-direction:column;}
  .hobbyList .hobbyCard__media{width:100%;}
  .hobbyList .hobbyCard__media,.hobbyList .hobbyCard__img,.hobbyList .hobbyCard__ph{height:auto; aspect-ratio: 2 / 3;}
  .hobbyList .hobbyCard__actions{flex: 0 0 auto; border-left:none; border-top:1px solid rgba(17,24,39,0.06); justify-content:flex-end; background: transparent;}
}

.hobbyCard{
  border:1px solid var(--border);
  border-radius: 18px;
  background: rgba(255,255,255,0.92);
  box-shadow: 0 10px 22px rgba(17,24,39,0.06);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  position:relative;
}

/* Cover blur background (uses inline CSS var --cover:url('...')) */
.hobbyCard.hasCover::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: var(--cover);
  background-size:cover;
  background-position:center;
  filter: blur(18px);
  opacity:0.20;
  transform: scale(1.08);
  pointer-events:none;
}
.hobbyCard > *{position:relative; z-index:1;}
.hobbyCard__media{
  position:relative;
  width:100%;
  aspect-ratio: 2 / 3;
  background: rgba(17,24,39,0.03);
  display:flex;
  align-items:center;
  justify-content:center;
}
.hobbyCard__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hobbyCard__ph{
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  color: var(--muted);
}
.hobbyCard__phIcon{font-size:26px}
.hobbyCard__phLetter{
  width:46px; height:46px;
  border-radius:16px;
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color: var(--text);
  background: rgba(255,255,255,0.75);
}

.hobbyCard__body{padding:12px; display:flex; flex-direction:column; gap:6px}
.hobbyCard__title{font-weight:800; line-height:1.15; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.hobbyCard__progress{
  height:6px;
  border-radius:999px;
  background: rgba(17,24,39,0.06);
  overflow:hidden;
}
.hobbyCard__progressBar{
  height:100%;
  border-radius:999px;
  background: rgba(59,130,246,0.55);
}
.hobbyCard__chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:6px}

/* Expandable details */
.hobbyCard__details{margin-top:8px; display:none; gap:8px; flex-direction:column}
.hobbyCard__notes{white-space:pre-wrap; font-size:13px; line-height:1.35}
.hobbyCard.isExpanded .hobbyCard__details{display:flex;}
.hobbyCard.isExpanded{box-shadow: 0 14px 28px rgba(17,24,39,0.10);}

.hobbyCard__actions{
  padding:10px 12px 12px;
  display:flex;
  gap:8px;
  justify-content:flex-end;
  flex-wrap:wrap;
  border-top:1px solid rgba(17,24,39,0.06);
}

/* Chips */
.chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.75);
  font-size:12px;
  line-height:1;
  color: var(--text);
}
.chip--status{cursor:pointer}
.chip--plan{background: rgba(148,163,184,0.16)}
.chip--doing{background: rgba(59,130,246,0.14)}
.chip--done{background: rgba(34,197,94,0.14)}
.chip--dbOn{background: rgba(34,197,94,0.12)}
.chip--dbOff{background: rgba(239,68,68,0.10)}
.chip--danger{background: rgba(239,68,68,0.12); border-color: rgba(239,68,68,0.22); color: rgba(185,28,28,1)}
.chip--subtle{background: rgba(17,24,39,0.04)}
.chip--mini{padding:5px 8px; font-size:11px;}

/* Toasts */
.toastHost{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:9999;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.toast{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.92);
  box-shadow: 0 10px 22px rgba(17,24,39,0.10);
  max-width:320px;
  font-size:13px;
}
.toast--ok{background: rgba(34,197,94,0.10)}
.toast--warn{background: rgba(245,158,11,0.10)}
.toast--err{background: rgba(239,68,68,0.10)}
.toast.isOut{opacity:0; transform: translateY(6px); transition: all .35s ease}

/* Stars input */
.starsInput{display:flex; gap:6px; align-items:center; flex-wrap:wrap}
.starBtn{
  width:34px; height:34px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.88);
  cursor:pointer;
  font-size:18px;
  line-height:1;
}
.starBtn:hover{background: rgba(17,24,39,0.03)}
.starBtn.isOn{background: rgba(245,158,11,0.12)}
.starClearBtn{
  width:34px; height:34px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(17,24,39,0.04);
  cursor:pointer;
  font-size:18px;
  line-height:1;
}
.starClearBtn:hover{background: rgba(17,24,39,0.06)}

/* Hobby modal layout + preview */
.hobbyModalLayout{
  display:grid;
  grid-template-columns: 1fr 300px;
  gap:14px;
  align-items:start;
}
@media (max-width: 900px){
  .hobbyModalLayout{grid-template-columns:1fr}
}

.hobbyPreview{position:sticky; top:0}
.hobbyPreview__media{
  position:relative;
  width:100%;
  aspect-ratio: 2 / 3;
  border-radius: 16px;
  overflow:hidden;
  border:1px solid rgba(17,24,39,0.06);
  background: rgba(17,24,39,0.03);
  display:flex;
  align-items:center;
  justify-content:center;
}
.hobbyPreview__img{width:100%; height:100%; object-fit:cover; display:none}
.hobbyPreview__placeholder{font-size:34px; color: var(--muted)}
.hobbyPreview__content{padding:12px}
.hobbyPreview__title{font-weight:900; line-height:1.15; margin-bottom:6px}
.hobbyPreview__badges{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}

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


/* ===== Hobby UI polish: icon buttons + sticky toolbar ===== */
.iconBtn{
  padding:0 !important;
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  line-height:1;
}
.iconBtn svg{width:20px; height:20px; display:block; fill:currentColor}

.hobbyToolbar{
  position:sticky;
  top:12px;
  z-index:8;
  padding:12px;
  border-radius:16px;
  background:rgba(248,250,252,.85);
  backdrop-filter:blur(10px);
  border:1px solid rgba(0,0,0,.06);
}

.hobbyCard__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  padding:10px;
}
.hobbyList .hobbyCard__actions{min-width:170px}
.hobbyWrap.isCompact .hobbyList .hobbyCard__actions{min-width:150px}

.hobbyCard__title{line-height:1.2}

/* ===== Hobby: compact density + hide covers toggle ===== */
.hobbyWrap.isCompact .hobbyList{gap:8px}
.hobbyWrap.isCompact .hobbyList .hobbyCard__media{width:72px}
.hobbyWrap.isCompact .hobbyList .hobbyCard__media,
.hobbyWrap.isCompact .hobbyList .hobbyCard__img,
.hobbyWrap.isCompact .hobbyList .hobbyCard__ph{height:96px}
.hobbyWrap.isCompact .hobbyList .hobbyCard__body{padding:10px; gap:4px}
.hobbyWrap.isCompact .hobbyList .hobbyCard__title{-webkit-line-clamp:1}
.hobbyWrap.isCompact .hobbyCard__progress{height:4px}
.hobbyWrap.isCompact .hobbyCard__actions{padding:8px; gap:6px}
.hobbyWrap.isCompact .iconBtn{width:34px; height:34px}
.hobbyWrap.isCompact .iconBtn svg{width:18px; height:18px}

.hobbyWrap.isNoCovers .hobbyList .hobbyCard__media{display:none}
.hobbyWrap.isNoCovers .hobbyCard.hasCover::before{opacity:0.08}
.hobbyWrap.isNoCovers .hobbyList .hobbyCard__actions{background:transparent}

.hobbyWrap.isCompact.isNoCovers .hobbyList .hobbyCard__body{padding:9px}
.hobbyWrap.isCompact .hobbyList .hobbyCard__actions{flex:0 0 150px}
.hobbyWrap.isNoCovers .hobbyList .hobbyCard__actions{flex:0 0 140px}


/* =========================
   Hobby: bulk select + pro pager
   ========================= */
.hobbySel{display:flex; align-items:center; padding: 0 10px;}
.hobbySel input{width:18px; height:18px; accent-color: var(--primary); cursor:pointer;}
.hobbyCard.isSelected{outline:2px solid rgba(0,0,0,0.12); outline-offset:2px;}

.hobbyBulkBar{margin-top:10px; padding:10px 12px; border:1px solid rgba(0,0,0,0.08); background: rgba(255,255,255,0.7); backdrop-filter: blur(8px); border-radius: 14px; display:flex; align-items:center; justify-content:space-between; gap:10px;}
.hobbyBulkBar.isHidden{display:none;}
.hobbyBulkBar__left{display:flex; align-items:center; gap:10px;}
.hobbyBulkBar__right{display:flex; align-items:center; gap:6px; flex-wrap:wrap; justify-content:flex-end;}

.hobbyPager__mid{display:flex; align-items:center; gap:8px;}
.pagerInput{width:72px; text-align:center;}

@media (max-width: 640px){
  .hobbyBulkBar{flex-direction:column; align-items:stretch;}
  .hobbyBulkBar__right{justify-content:flex-start;}
}



/* =========================
   Hobby: bulk select + pro pager
   ========================= */
.hobbySel{display:flex; align-items:center; padding: 0 10px;}
.hobbySel input{width:18px; height:18px; accent-color: var(--primary); cursor:pointer;}
.hobbyCard.isSelected{outline:2px solid rgba(0,0,0,0.12); outline-offset:2px;}

.hobbyBulkBar{
  margin-top:10px;
  padding:10px 12px;
  border:1px solid rgba(0,0,0,0.08);
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(8px);
  border-radius: 14px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 10px;
}
.hobbyBulkBar.isHidden{display:none;}
.hobbyBulkBar__left{display:flex; align-items:center; gap:10px;}
.hobbyBulkBar__right{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 6px;
  flex-wrap: wrap;
}

.hobbyPager__mid{display:flex; align-items:center; gap:8px;}
.pagerInput{width:72px; text-align:center;}


/* =========================
   Hobby: Details panel (Library)
   ========================= */
.hobbyLayout{display:flex; gap:12px; align-items:flex-start}
.hobbyMain{flex:1; min-width:0}
.hobbyDetail{width:340px; max-width:40vw; position:sticky; top:74px; align-self:flex-start; z-index:60; display:none}
.hobbyDetail.isOpen{display:block}
.hobbyDetailBackdrop{display:none}
.hobbyDetailBackdrop.isOpen{display:block; position:fixed; inset:0; background:rgba(0,0,0,.25); z-index:50}
.hobbyDetail__card{border:1px solid rgba(0,0,0,.08); border-radius:16px; background:#fff; padding:12px; box-shadow:0 10px 28px rgba(0,0,0,.08)}
.hobbyDetail__top{display:flex; gap:10px; align-items:flex-start}
.hobbyDetail__img{width:76px; height:110px; object-fit:cover; border-radius:10px; flex:0 0 auto; border:1px solid rgba(0,0,0,.08)}
.hobbyDetail__ph{width:76px; height:110px; border-radius:10px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; border:1px solid rgba(0,0,0,.08); background:rgba(0,0,0,.02); flex:0 0 auto}
.hobbyDetail__phIcon{font-size:18px}
.hobbyDetail__phLetter{font-weight:700; font-size:18px}
.hobbyDetail__head{flex:1; display:flex; align-items:flex-start; justify-content:space-between; gap:8px}
.hobbyDetail__headLeft{min-width:0}
.hobbyDetail__title{font-weight:700; line-height:1.15; margin-top:2px; font-size:15px; word-break:break-word}
.hobbyDetail__sub{margin-top:4px}
.hobbyDetail__actions{display:flex; gap:8px; margin:10px 0 6px}
.hobbyDetail__row{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:8px 0; border-top:1px solid rgba(0,0,0,.06)}
.hobbyDetail__rowActions{display:flex; gap:6px; flex-wrap:wrap; justify-content:flex-end}
.hobbyDetail__rating{font-weight:700}
.hobbyDetail__notes{padding:8px 0; border-top:1px solid rgba(0,0,0,.06)}
.hobbyDetail__notesBody{margin-top:6px; white-space:pre-wrap; word-break:break-word}
.chip--status.isOn{box-shadow:inset 0 0 0 2px rgba(0,0,0,.10)}
.hobbyCard.isActive{outline:2px solid rgba(0,0,0,.06); outline-offset:0}
@media (max-width: 900px){
  .hobbyLayout{display:block}
  .hobbyDetail{display:block; width:auto; max-width:none; left:10px; right:10px; bottom:10px; top:auto; position:fixed; transform:translateY(120%); transition:transform .18s ease}
  .hobbyDetail.isOpen{transform:translateY(0)}
  .hobbyDetail__card{max-height:75vh; overflow:auto}
}


/* Small info buttons */
.infoBtn{width:18px; height:18px; border-radius:999px; border:1px solid rgba(20,30,50,.15); background:rgba(255,255,255,.7); color:rgba(20,30,50,.65); display:inline-flex; align-items:center; justify-content:center; font-size:12px; line-height:1; padding:0; cursor:pointer; transition:transform .08s ease, background .12s ease, border-color .12s ease}
.infoBtn:hover{transform:translateY(-1px); background:rgba(255,255,255,.9); border-color:rgba(20,30,50,.22)}
.infoBtn:active{transform:translateY(0)}
.infoBtn:focus{outline:none; box-shadow:0 0 0 3px rgba(82,132,255,.22)}

/* =========================
   Crypto ATH
   ========================= */
.panel.cryptoAth{
  background:
    radial-gradient(110% 180% at 0% 0%, rgba(59,130,246,0.10) 0%, rgba(255,255,255,0.84) 38%),
    radial-gradient(100% 140% at 100% 0%, rgba(16,185,129,0.08) 0%, rgba(255,255,255,0.88) 44%),
    rgba(255,255,255,0.92);
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 20px 42px rgba(15,23,42,0.10);
}
.cryptoAth{display:flex; flex-direction:column; gap:12px}
.cryptoAth__head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  flex-wrap:wrap;
  padding-bottom:8px;
  border-bottom:1px solid rgba(15,23,42,0.08);
}
.cryptoAth__status{
  font-size:12px;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid rgba(15,23,42,0.08);
  background: rgba(255,255,255,0.7);
}
.cryptoAth .ghostBtn,
.cryptoAth .primaryBtn,
.cryptoAth .dangerBtn{
  border-radius:12px;
  padding:8px 12px;
  min-height:38px;
}
.cryptoAth__notice{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  font-size:13px;
}
.cryptoAth__notice.isWarn{background:rgba(239,68,68,0.10); border-color:rgba(239,68,68,0.25)}
.cryptoAth__notice.isOk{background:rgba(34,197,94,0.10); border-color:rgba(34,197,94,0.20)}
.cryptoAth__notice.isHidden{display:none}

.cryptoAthOwners{
  border:1px solid rgba(15,23,42,0.12);
  border-radius:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,250,252,0.88));
  padding:12px;
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  box-shadow: 0 8px 20px rgba(15,23,42,0.06);
}
.cryptoAthOwners__left{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.cryptoAthOwners__label{
  font-size:12px;
  color:var(--muted);
  font-weight:700;
}
.cryptoAthOwners__select{min-width:220px}
.cryptoAthOwners__actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.cryptoAthSummary{
  display:grid;
  grid-template-columns:repeat(5, minmax(160px, 1fr));
  gap:12px;
}
.cryptoAthSummary__card{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:16px;
  padding:10px 12px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.88));
  box-shadow: 0 8px 18px rgba(15,23,42,0.06);
  transition: transform .12s ease, box-shadow .12s ease;
}
.cryptoAthSummary__card:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(15,23,42,0.10);
}
.cryptoAthSummary__label{font-size:12px; color:var(--muted)}
.cryptoAthSummary__value{font-size:22px; font-weight:800; margin-top:2px; line-height:1.1}

.cryptoAth__section{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:16px;
  background:rgba(255,255,255,0.78);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.cryptoAth__sectionTitle{font-weight:800; letter-spacing:0.2px}

.cryptoAthAdd{
  display:grid;
  grid-template-columns:minmax(260px, 1fr) minmax(170px, 220px) auto;
  gap:8px;
  align-items:center;
}
.cryptoAthAdd__coinWrap{position:relative; min-width:220px}
.cryptoAth__picked{font-size:12px}

.cryptoAthSuggest{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 6px);
  z-index:120;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
  box-shadow:0 16px 32px rgba(17,24,39,0.12);
  max-height:300px;
  overflow:auto;
}
.cryptoAthSuggest.isHidden{display:none}
.cryptoAthSuggest__item{
  width:100%;
  text-align:left;
  display:grid;
  grid-template-columns:22px 1fr auto;
  gap:8px;
  align-items:center;
  border:0;
  border-bottom:1px solid rgba(17,24,39,0.06);
  background:#fff;
  padding:8px 10px;
  cursor:pointer;
}
.cryptoAthSuggest__item:last-child{border-bottom:0}
.cryptoAthSuggest__item:hover{background:rgba(59,130,246,0.08)}
.cryptoAthSuggest__img{width:20px; height:20px; border-radius:999px}
.cryptoAthSuggest__dot{display:inline-flex; align-items:center; justify-content:center; color:var(--muted)}
.cryptoAthSuggest__name{font-weight:600}

.cryptoAthTools{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(210px, 280px);
  gap:8px;
}

.cryptoAthTableWrap{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:16px;
  background:rgba(255,255,255,0.76);
  overflow:auto;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.75);
}
.cryptoAthTable{
  width:100%;
  border-collapse:collapse;
  min-width:1200px;
}
.cryptoAthTable th,
.cryptoAthTable td{
  border-bottom:1px solid rgba(17,24,39,0.08);
  padding:10px;
  text-align:left;
  vertical-align:middle;
}
.cryptoAthTable th{
  position:sticky;
  top:0;
  background:rgba(241,245,249,0.94);
  backdrop-filter: blur(6px);
  z-index:1;
  font-size:12px;
  color:var(--muted);
  font-weight:700;
}
.cryptoAthTable tr:last-child td{border-bottom:0}
.cryptoAthTable tbody tr:hover{background: rgba(59,130,246,0.05)}

.cryptoAth__coinCell{display:flex; align-items:center; gap:10px}
.cryptoAth__coinImg{
  width:28px;
  height:28px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,0.08);
}
.cryptoAth__coinPh{
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(17,24,39,0.12);
  color:var(--muted);
  font-size:11px;
  font-weight:700;
}
.cryptoAth__coinMeta{min-width:0}
.cryptoAth__coinName{font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:260px}

.cryptoAth__cellStack{display:flex; flex-direction:column; gap:4px}
.cryptoAth__amountInp{max-width:150px}
.cryptoAth__neg{color:#b45309; font-weight:700}
.cryptoAth__pos{color:#065f46; font-weight:700}
.cryptoActionRow{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
}
.cryptoActionIcon{
  width:36px !important;
  height:36px !important;
  min-height:36px !important;
  padding:0 !important;
  border-radius:10px !important;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.cryptoActionIcon svg{
  width:18px;
  height:18px;
  display:block;
  fill:currentColor;
}
.cryptoActionIcon--danger svg{
  width:17px;
  height:17px;
}

@media (max-width: 1200px){
  .cryptoAthSummary{grid-template-columns:repeat(3, minmax(160px, 1fr))}
}
@media (max-width: 860px){
  .cryptoAthSummary{grid-template-columns:repeat(2, minmax(140px, 1fr))}
  .cryptoAthOwners{display:grid; grid-template-columns:1fr}
  .cryptoAthOwners__left{display:grid; grid-template-columns:1fr}
  .cryptoAthOwners__select{min-width:0}
  .cryptoAthAdd{grid-template-columns:1fr}
  .cryptoAthTools{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .cryptoAthSummary{grid-template-columns:1fr}
  .cryptoActionIcon{
    width:34px !important;
    height:34px !important;
    min-height:34px !important;
  }
}

/* =========================
   Crypto Root + 10 STEPS
   ========================= */
.cryptoRoot{display:flex; flex-direction:column; gap:10px; width:100%}
.cryptoSwitch{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,250,252,0.88));
  box-shadow:
    0 10px 22px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.82);
}
.cryptoSwitch__tabs{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.cryptoSwitch__actions{
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:auto;
}
.cryptoSwitch__refresh{
  min-height:38px;
  padding:0 14px;
  border-radius:12px;
  font-weight:800;
  border-color:rgba(59,130,246,0.18);
  background:rgba(59,130,246,0.06);
  color:#163e8f;
}
.cryptoSwitch__refresh:hover{
  border-color:rgba(59,130,246,0.3);
  background:rgba(59,130,246,0.12);
}
.cryptoRoot__pane.isHidden{
  display:none;
}
@media (max-width: 860px){
  .cryptoSwitch{
    flex-direction:column;
    align-items:stretch;
  }
  .cryptoSwitch__actions{
    margin-left:0;
    justify-content:flex-end;
  }
}

.panel.cryptoSteps{
  background:
    radial-gradient(120% 170% at 0% 0%, rgba(59,130,246,0.09) 0%, rgba(255,255,255,0.9) 42%),
    radial-gradient(110% 145% at 100% 0%, rgba(16,185,129,0.08) 0%, rgba(255,255,255,0.94) 44%),
    rgba(255,255,255,0.95);
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 20px 42px rgba(15,23,42,0.09);
}
.cryptoSteps{display:flex; flex-direction:column; gap:12px}
.cryptoSteps__status{font-size:12px}
.cryptoStepsActions{display:flex; gap:8px; flex-wrap:wrap}
.cryptoStepsActions.isHidden{display:none}

.cryptoStepsProjects{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.cryptoStepsProjects.isHidden{display:none}
.cryptoStepsDetail{display:flex; flex-direction:column; gap:10px}
.cryptoStepsDetail.isHidden{display:none}
.cryptoStepsDetailTop{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  border:1px solid rgba(148,163,184,0.26);
  border-radius:13px;
  background:
    linear-gradient(140deg, rgba(255,255,255,0.96), rgba(239,246,255,0.88));
  padding:9px 11px;
  box-shadow:
    0 8px 16px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.85);
}
.cryptoStepsDetailTop__left{
  display:flex;
  flex-direction:column;
  gap:3px;
}
.cryptoStepsDetailTop__crumb{
  font-size:10px;
  color:var(--muted);
  font-weight:700;
  letter-spacing:0.2px;
  text-transform:uppercase;
}
.cryptoStepsDetailTop__title{
  font-weight:800;
  color:var(--text);
  font-size:15px;
}
.cryptoStepsDetailTop__actions{
  display:flex;
  align-items:center;
  gap:7px;
  flex-wrap:wrap;
}
.cryptoStepsDetailTop__actions .ghostBtn,
.cryptoStepsDetailTop__actions .dangerBtn{
  min-height:32px;
  padding:6px 9px;
  border-radius:10px;
}
.cryptoStepsProjectRow{
  display:grid;
  grid-template-columns:minmax(230px, 1.1fr) minmax(330px, 1.45fr) auto auto;
  align-items:center;
  gap:10px;
  border:1px solid rgba(15,23,42,0.10);
  border-radius:13px;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.95), rgba(241,245,249,0.9));
  padding:10px 12px;
  box-shadow:
    0 8px 16px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.84);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.cryptoStepsProjectRow:hover{
  transform:translateY(-1px);
  box-shadow:
    0 12px 22px rgba(15,23,42,0.08),
    inset 0 1px 0 rgba(255,255,255,0.9);
}
.cryptoStepsProjectRow.isActive{
  border-color:rgba(59,130,246,0.42);
  box-shadow:
    0 14px 26px rgba(59,130,246,0.16),
    inset 0 1px 0 rgba(255,255,255,0.9);
}
.cryptoStepsProjectRow__primary{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.cryptoStepsProjectRow__name{
  font-weight:800;
  font-size:22px;
  line-height:1.12;
  color:var(--text);
}
.cryptoStepsProjectRow__meta{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.cryptoStepsProjectRow__market{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:5px;
}
.cryptoStepsProjectRow__coin{
  font-weight:700;
  font-size:18px;
  line-height:1.15;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.cryptoStepsProjectRow__numbers{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.cryptoStepsMetric{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.35);
  background:rgba(255,255,255,0.9);
  font-size:16px;
  font-weight:700;
  line-height:1;
  color:#1f2937;
}
.cryptoStepsMetric.isPositive{
  color:#047857;
  border-color:rgba(16,185,129,0.42);
  background:rgba(236,253,245,0.92);
}
.cryptoStepsMetric.isNegative{
  color:#b91c1c;
  border-color:rgba(239,68,68,0.35);
  background:rgba(254,242,242,0.92);
}
.cryptoStepsProjectRow__status{
  font-size:12px;
  font-weight:800;
}
.cryptoStepsProjectRow__status--active{
  border-color:rgba(59,130,246,0.48);
  background:rgba(219,234,254,0.9);
  color:#1d4ed8;
}
.cryptoStepsProjectRow__status--completed,
.cryptoStepsProjectRow__status--closed{
  border-color:rgba(16,185,129,0.48);
  background:rgba(220,252,231,0.9);
  color:#047857;
}
.cryptoStepsProjectRow__status--draft,
.cryptoStepsProjectRow__status--archived{
  border-color:rgba(148,163,184,0.45);
  background:rgba(241,245,249,0.9);
  color:#475569;
}
.cryptoStepsProjectRow__actions{
  display:flex;
  justify-content:flex-end;
}
.cryptoStepsProjectRow__actions .ghostBtn{
  min-height:34px;
  padding:6px 12px;
  border-radius:10px;
}
.cryptoStepsInlinePlaceholder{
  margin-top:8px;
  padding:10px 12px;
  border:1px dashed rgba(15,23,42,0.18);
  border-radius:12px;
  background:rgba(248,250,252,0.8);
}

.cryptoStepsDetailCard{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(248,250,252,0.9));
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
  box-shadow:
    0 12px 24px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.82);
}
.cryptoStepsDetail__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}
.cryptoStepsDetail__head .panel__title{
  font-size:18px;
  line-height:1.2;
  margin:0;
}
.cryptoStepsDetail__meta{display:flex; align-items:center; gap:6px; flex-wrap:wrap}
.cryptoStepsSummary{
  display:grid;
  grid-template-columns:repeat(4, minmax(140px, 1fr));
  gap:10px;
}
.cryptoStepsSummary__card{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,245,249,0.86));
  padding:10px 12px;
  min-height:92px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  box-shadow:
    0 8px 18px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.78);
}
.cryptoStepsSummary__card .muted{
  text-align:center;
  font-size:11px;
  letter-spacing:.2px;
}
.cryptoStepsSummary__value{font-size:18px; font-weight:800; margin-top:4px}
.cryptoStepsSummary__value.isSmall{
  font-size:13px;
  font-weight:700;
  line-height:1.32;
  max-width:100%;
}

.cryptoStepsTimeline{display:flex; flex-direction:column; gap:10px}
.cryptoStepsStep{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.9));
  padding:10px;
  box-shadow:
    0 8px 16px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.82);
}
.cryptoStepsStep--active{border-color:rgba(59,130,246,0.45)}
.cryptoStepsStep--closed{border-color:rgba(16,185,129,0.40)}
.cryptoStepsStep__top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  padding-bottom:7px;
  border-bottom:1px solid rgba(148,163,184,0.22);
}
.cryptoStepsStep__title{font-weight:800}
.cryptoStepsStep__body{display:flex; flex-direction:column; gap:8px; margin-top:8px}
.cryptoStepsStep__helper{
  font-size:12px;
  color:var(--muted);
}

.cryptoStepsStart{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(160px, 220px) minmax(160px, 220px) auto;
  gap:8px;
  align-items:center;
}
.cryptoStepsStart--meta{grid-template-columns:minmax(220px, 1fr) minmax(280px, 1fr)}
.cryptoStepsLive{
  border:1px solid rgba(15,23,42,0.08);
  border-radius:12px;
  background:rgba(248,250,252,0.9);
  padding:8px 10px;
  display:flex;
  flex-direction:column;
  gap:5px;
}
.cryptoStepsLive__title{
  font-size:19px;
  font-weight:800;
  line-height:1.15;
}
.cryptoStepsLive__line{
  font-size:18px;
  line-height:1.24;
}
.cryptoStepsLive__line--pnl{
  font-weight:800;
}
.cryptoStepsLive__line--pnl.isPositive{color:#047857}
.cryptoStepsLive__line--pnl.isNegative{color:#b91c1c}

@media (max-width: 1160px){
  .cryptoStepsLive__title{
    font-size:17px;
  }
  .cryptoStepsLive__line{
    font-size:16px;
  }
}

@media (max-width: 980px){
  .cryptoStepsProjectRow{
    grid-template-columns:minmax(200px, 1fr) minmax(220px, 1fr);
    align-items:start;
  }
  .cryptoStepsProjectRow__status{
    justify-self:start;
  }
  .cryptoStepsProjectRow__actions{
    justify-self:end;
  }
  .cryptoStepsSummary{grid-template-columns:repeat(2, minmax(140px, 1fr))}
  .cryptoStepsStart{grid-template-columns:1fr}
  .cryptoStepsStart--meta{grid-template-columns:1fr}
  .cryptoStepsDetail__head{
    align-items:flex-start;
  }
}
@media (max-width: 560px){
  .cryptoStepsProjectRow{
    grid-template-columns:1fr;
    gap:8px;
    padding:9px 10px;
  }
  .cryptoStepsProjectRow__name{
    font-size:19px;
  }
  .cryptoStepsProjectRow__coin{
    font-size:15px;
  }
  .cryptoStepsMetric{
    font-size:13px;
  }
  .cryptoStepsProjectRow__actions{
    justify-content:flex-start;
  }
  .cryptoStepsDetailTop{
    padding:8px 9px;
  }
  .cryptoStepsLive__title{
    font-size:15px;
  }
  .cryptoStepsLive__line{
    font-size:14px;
  }
  .cryptoStepsSummary{grid-template-columns:1fr}
}

/* =========================
   Crypto PLAN
   ========================= */
.panel.cryptoPlan{
  background:
    radial-gradient(115% 170% at 0% 0%, rgba(16,185,129,0.09) 0%, rgba(255,255,255,0.86) 38%),
    radial-gradient(110% 140% at 100% 0%, rgba(59,130,246,0.08) 0%, rgba(255,255,255,0.90) 44%),
    rgba(255,255,255,0.94);
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 20px 42px rgba(15,23,42,0.10);
}
.cryptoPlan{display:flex; flex-direction:column; gap:12px}
.cryptoPlan__status{font-size:12px}
.cryptoPlan__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  border:1px solid rgba(148,163,184,0.24);
  border-radius:14px;
  padding:10px 12px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.95), rgba(240,253,250,0.88));
  box-shadow:
    0 10px 22px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.82);
}
.cryptoPlan__titleWrap .panel__title{
  margin:0;
  line-height:1.08;
}

.cryptoPlanStats{
  display:flex;
  flex-wrap:nowrap;
  align-items:stretch;
  gap:8px;
}
.cryptoPlanStats__card{
  flex:1 1 0;
  min-width:0;
  border:1px solid rgba(15,23,42,0.10);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,250,252,0.88));
  padding:9px 11px;
  box-shadow: 0 8px 16px rgba(15,23,42,0.06);
}
.cryptoPlanStats__label{
  font-size:11px;
  color:var(--muted);
  font-weight:700;
  letter-spacing:0.2px;
}
.cryptoPlanStats__value{
  font-size:17px;
  font-weight:800;
  line-height:1.15;
  margin-top:3px;
}

.cryptoPlanToolbar{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:16px;
  background:
    radial-gradient(130% 170% at 0% 0%, rgba(16,185,129,0.07) 0%, rgba(255,255,255,0.88) 46%),
    rgba(255,255,255,0.82);
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:10px;
  box-shadow: 0 10px 24px rgba(15,23,42,0.07);
}
.cryptoPlan .cryptoAth__picked{
  margin-top:2px;
  padding:6px 9px;
  border:1px dashed rgba(148,163,184,0.30);
  border-radius:10px;
  background:rgba(255,255,255,0.66);
  width:max-content;
}
.cryptoPlan .cryptoAth__picked.isHidden{display:none}
.cryptoPlanToolbar .cryptoAth__section{
  border:0;
  border-radius:12px;
  background:transparent;
  padding:0;
  box-shadow:none;
}

.cryptoPlanAdd{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(140px, 200px) minmax(140px, 200px) auto;
  gap:8px;
  align-items:center;
}
.cryptoPlanTools{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(180px, 240px) auto auto;
  gap:8px;
  align-items:center;
}
.cryptoPlan .ghostBtn,
.cryptoPlan .primaryBtn,
.cryptoPlan .dangerBtn{
  border-radius:11px;
  min-height:36px;
  padding:7px 11px;
}
.cryptoPlan__toggle{
  font-size:13px;
  white-space:nowrap;
}
.cryptoPlan__toggle.isActive{
  background: rgba(59,130,246,0.12);
  border-color: rgba(59,130,246,0.35);
}

.cryptoPlanTable{min-width:1420px}
.cryptoPlanTable th,
.cryptoPlanTable td{padding:8px 9px}
.cryptoPlan__qtyInp{max-width:138px; min-width:96px}
.cryptoPlan__toBuy{font-weight:700}
.cryptoPlan__drop{font-weight:700; color:#b45309}
.cryptoPlan__invest{font-weight:800; color:#065f46}
.cryptoPlan__athHold{font-weight:700; color:#1f3d8a}
.cryptoPlan__athTarget{font-weight:700; color:#0f766e}
.cryptoPlan__rowDone{
  background: rgba(16,185,129,0.08);
}
.cryptoPlan__rowDone:hover{
  background: rgba(16,185,129,0.14) !important;
}
.cryptoPlan__rowArchived{
  opacity:0.80;
}
.cryptoPlan .btnRow{
  gap:6px;
}
.cryptoPlan .chip{
  padding:4px 9px;
  font-size:11px;
}

.cryptoPlanTotal{
  border:1px solid rgba(15,23,42,0.12);
  border-radius:14px;
  background:rgba(255,255,255,0.90);
  padding:10px 12px;
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  justify-content:space-between;
  gap:8px;
  position:relative;
  box-shadow: 0 10px 24px rgba(15,23,42,0.10);
}
.cryptoPlanTotal__label{
  font-size:12px;
  color:var(--muted);
  font-weight:700;
}
.cryptoPlanTotal__value{
  font-size:20px;
  font-weight:800;
  line-height:1;
}
.cryptoPlanTotal__meta{font-size:12px}

@media (max-width: 980px){
  .cryptoPlanStats{flex-wrap:wrap}
  .cryptoPlanStats__card{flex-basis:calc(50% - 4px)}
  .cryptoPlanAdd{grid-template-columns:1fr}
  .cryptoPlanTools{grid-template-columns:1fr}
  .cryptoPlan__qtyInp{max-width:100%}
}
@media (max-width: 560px){
  .cryptoPlanStats__card{flex-basis:100%}
  .cryptoPlanTotal{
    position:static;
  }
}

/* =========================
   Crypto Compact Premium Pass
   ========================= */
.cryptoRoot{
  gap:8px;
}
.cryptoSwitch{
  gap:6px;
  padding:6px;
  border-radius:12px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.90), rgba(245,250,255,0.88));
  border-color:rgba(148,163,184,0.26);
  box-shadow:0 6px 14px rgba(15,23,42,0.06);
}
.cryptoSwitch .pillBtn{
  min-height:34px;
  padding:7px 12px;
  border-radius:11px;
  font-weight:700;
  border-color:rgba(148,163,184,0.3);
  background:rgba(255,255,255,0.72);
}
.cryptoSwitch .pillBtn.isActive{
  color:#0b2a67;
  border-color:rgba(59,130,246,0.5);
  background:
    linear-gradient(180deg, rgba(219,234,254,0.92), rgba(191,219,254,0.86));
  box-shadow:0 6px 14px rgba(59,130,246,0.18);
}

.cryptoRoot__body > .panel.cryptoAth,
.cryptoRoot__body > .panel.cryptoPlan,
.cryptoRoot__body > .panel.cryptoSteps{
  border-radius:16px;
  padding:12px;
}

.cryptoAth{gap:10px}
.cryptoAth__head{
  padding-bottom:7px;
  gap:8px;
}
.cryptoAth__status{
  padding:7px 10px;
  border-radius:9px;
}
.cryptoAth .ghostBtn,
.cryptoAth .primaryBtn,
.cryptoAth .dangerBtn{
  min-height:34px;
  padding:7px 10px;
  border-radius:10px;
}
.cryptoAthOwners{
  padding:10px;
  border-radius:14px;
  gap:8px;
}
.cryptoAthSummary{
  gap:9px;
}
.cryptoAthSummary__card{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  min-height:92px;
  border-radius:14px;
  padding:10px 12px;
  border-color:rgba(148,163,184,0.26);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(241,245,249,0.84));
  box-shadow:
    0 8px 18px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.76);
}
.cryptoAthSummary__label{
  text-align:center;
  font-size:11px;
  letter-spacing:0.2px;
}
.cryptoAthSummary__value{
  text-align:center;
  font-size:20px;
  line-height:1.05;
  margin-top:4px;
  font-weight:900;
}
.cryptoAth__section{
  border-radius:14px;
  padding:10px;
  gap:8px;
}
.cryptoAthAdd{
  grid-template-columns:minmax(240px, 1fr) minmax(150px, 200px) auto;
  gap:7px;
}
.cryptoAthTools{
  grid-template-columns:minmax(200px, 1fr) minmax(180px, 230px);
  gap:7px;
}
.cryptoAthTableWrap{
  border-radius:14px;
}
.cryptoAthTable{
  min-width:1080px;
}
.cryptoAthTable th,
.cryptoAthTable td{
  padding:8px;
}
.cryptoAth__coinCell{
  gap:8px;
}
.cryptoAth__coinImg,
.cryptoAth__coinPh{
  width:24px;
  height:24px;
}
.cryptoAth__amountInp{
  max-width:130px;
}

.cryptoSteps{gap:10px}
.cryptoStepsActions{
  gap:7px;
}
.cryptoStepsActions .ghostBtn,
.cryptoStepsActions .primaryBtn,
.cryptoStepsActions .dangerBtn{
  min-height:34px;
  padding:7px 10px;
  border-radius:10px;
}
.cryptoStepsProjects{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.cryptoStepsProjectRow{
  grid-template-columns:minmax(200px, 1fr) minmax(250px, 1.2fr) auto auto;
  border-radius:12px;
  padding:9px 10px;
  gap:8px;
}
.cryptoStepsProjectRow__name{
  font-size:17px;
}
.cryptoStepsProjectRow__coin{
  font-size:14px;
}
.cryptoStepsMetric{
  font-size:13px;
  min-height:22px;
  padding:2px 7px;
}
.cryptoStepsProjectRow__actions .ghostBtn{
  min-height:32px;
  padding:6px 10px;
}
.cryptoStepsDetail{
  gap:8px;
}
.cryptoStepsDetailTop{
  border-radius:11px;
  padding:7px 9px;
}
.cryptoStepsDetailTop__crumb{
  font-size:10px;
}
.cryptoStepsDetailTop__title{
  font-size:14px;
}
.cryptoStepsDetailCard{
  border-radius:14px;
  padding:10px;
  gap:8px;
}
.cryptoStepsDetail__meta{
  gap:5px;
}
.cryptoStepsSummary{
  gap:8px;
}
.cryptoStepsSummary__card{
  border-radius:12px;
  padding:8px;
}
.cryptoStepsSummary__value{
  font-size:16px;
}
.cryptoStepsSummary__value.isSmall{
  font-size:13px;
}
.cryptoStepsTimeline{
  gap:8px;
}
.cryptoStepsStep{
  border-radius:12px;
  padding:8px;
}
.cryptoStepsStep__body{
  gap:7px;
  margin-top:7px;
}
.cryptoStepsStep__helper{
  font-size:11px;
}
.cryptoStepsStart{
  grid-template-columns:minmax(200px, 1fr) minmax(140px, 190px) minmax(140px, 190px) auto;
  gap:7px;
}
.cryptoStepsStart--meta{
  grid-template-columns:minmax(200px, 1fr) minmax(220px, 1fr);
}
.cryptoStepsLive{
  border-radius:10px;
  padding:7px 9px;
}
.cryptoStepsLive__title{
  font-size:16px;
}
.cryptoStepsLive__line{
  font-size:14px;
}

.cryptoPlan{gap:10px}
.cryptoPlan__status{
  font-size:11px;
}
.cryptoPlan__head{
  border-radius:13px;
  padding:9px 11px;
}
.cryptoPlanStats{
  gap:6px;
}
.cryptoPlanStats__card{
  border-radius:13px;
  padding:7px 8px;
  min-height:64px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  border-color:rgba(148,163,184,0.28);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(241,245,249,0.84));
  box-shadow:
    0 8px 16px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.78);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.cryptoPlanStats__card:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.32);
  box-shadow:
    0 12px 24px rgba(15,23,42,0.09),
    inset 0 1px 0 rgba(255,255,255,0.82);
}
.cryptoPlanStats__label{
  text-align:center;
  font-size:9px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  line-height:1.15;
}
.cryptoPlanStats__value{
  text-align:center;
  width:100%;
  min-width:0;
  font-size:clamp(15px, 1.05vw, 19px);
  line-height:1.02;
  margin-top:2px;
  font-weight:800;
  font-variant-numeric:tabular-nums;
  letter-spacing:-0.02em;
  white-space:nowrap;
}
.cryptoPlanToolbar{
  border-radius:14px;
  padding:9px;
  gap:8px;
}
.cryptoPlanAdd{
  grid-template-columns:minmax(210px, 1fr) minmax(130px, 170px) minmax(130px, 170px) auto;
  gap:7px;
}
.cryptoPlanTools{
  grid-template-columns:minmax(210px, 1fr) minmax(160px, 210px) auto auto;
  gap:7px;
}
.cryptoPlanTable{
  min-width:1280px;
}
.cryptoPlanTable th,
.cryptoPlanTable td{
  padding:7px 8px;
}
.cryptoPlan__qtyInp{
  max-width:120px;
  min-width:88px;
}
.cryptoPlanTotal{
  border-radius:12px;
  padding:9px 10px;
}
.cryptoPlanTotal__value{
  font-size:18px;
}

/* PLAN compact premium pass */
.cryptoPlanToolbar{
  display:grid;
  grid-template-columns:minmax(0, 1.06fr) minmax(420px, 0.94fr);
  align-items:center;
  gap:9px;
  border:1px solid rgba(148,163,184,0.2);
  border-radius:14px;
  padding:9px;
  background:linear-gradient(180deg, rgba(255,255,255,0.9), rgba(248,250,252,0.84));
  box-shadow:0 8px 18px rgba(15,23,42,0.05);
}
.cryptoPlanToolbar__left{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.cryptoPlanToolbar__right{
  align-self:stretch;
}
.cryptoPlanAdd{
  grid-template-columns:minmax(220px, 1fr) minmax(120px, 158px) minmax(120px, 158px) auto;
  gap:6px;
}
.cryptoPlanTools{
  display:grid;
  grid-template-columns:minmax(180px, 1fr) minmax(150px, 200px) auto auto;
  gap:6px;
  align-items:center;
}
.cryptoPlan .cryptoAth__picked{
  margin-top:0;
  padding:5px 9px;
  border-radius:999px;
  background:rgba(255,255,255,0.78);
}
.cryptoPlan .input{
  min-height:36px;
  padding:7px 11px;
  border-radius:11px;
  font-size:13.5px;
}
.cryptoPlan .ghostBtn,
.cryptoPlan .primaryBtn,
.cryptoPlan .dangerBtn{
  min-height:36px;
  padding:0 11px;
  border-radius:11px;
  font-size:13px;
  font-weight:700;
}
.cryptoPlan .primaryBtn{
  box-shadow:0 8px 16px rgba(59,130,246,0.14);
}
.cryptoPlanTable{
  min-width:1210px;
}
.cryptoPlanTable th{
  font-size:11px;
  letter-spacing:0.2px;
  padding:6px 8px;
}
.cryptoPlanTable td{
  padding:5px 8px;
}
.cryptoPlanTable th:nth-child(n+3),
.cryptoPlanTable td:nth-child(n+3){
  text-align:center;
}
.cryptoPlan .cryptoAth__coinCell{
  gap:8px;
}
.cryptoPlan .cryptoAth__coinImg,
.cryptoPlan .cryptoAth__coinPh{
  width:24px;
  height:24px;
}
.cryptoPlan .cryptoAth__coinName{
  font-size:17px;
  line-height:1.1;
}
.cryptoPlan .cryptoAth__coinMeta .muted{
  font-size:12px;
  line-height:1.2;
}
.cryptoPlan__qtyInp{
  min-width:82px;
  max-width:112px;
  min-height:32px;
  margin-inline:auto;
  text-align:center;
}
.cryptoPlan__qtyWrap{
  display:flex;
  align-items:center;
  justify-content:center;
}
.cryptoPlan__qtyDisplay{
  min-width:0;
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  color:var(--text);
  font:inherit;
  font-size:16px;
  font-weight:600;
  letter-spacing:0;
  line-height:1.2;
  text-align:center;
  font-variant-numeric:tabular-nums;
}
.cryptoPlan__qtyWrap .cryptoPlan__qtyInp{
  display:none;
}
.cryptoPlan__qtyWrap.isEditing .cryptoPlan__qtyDisplay{
  display:none;
}
.cryptoPlan__qtyWrap.isEditing .cryptoPlan__qtyInp{
  display:block;
}
.cryptoPlan .cryptoActionRow{
  justify-content:center;
  gap:6px;
}
.cryptoPlan .cryptoActionIcon{
  width:34px !important;
  height:34px !important;
  min-height:34px !important;
  border-radius:10px !important;
}
.cryptoPlan .cryptoPlan__qtyAction{
  border-color:rgba(59,130,246,0.16) !important;
  background:rgba(59,130,246,0.06) !important;
  color:rgba(30,64,175,0.88) !important;
}
.cryptoPlan .cryptoPlan__qtyAction:hover{
  border-color:rgba(59,130,246,0.28) !important;
  background:rgba(59,130,246,0.12) !important;
  color:rgba(30,64,175,1) !important;
}
.cryptoPlan .cryptoPlan__qtyAction.isEditing{
  border-color:rgba(34,197,94,0.24) !important;
  background:rgba(34,197,94,0.12) !important;
  color:#166534 !important;
}
.cryptoPlan .cryptoPlan__archiveAction{
  border-color:rgba(148,163,184,0.2) !important;
  background:rgba(148,163,184,0.07) !important;
  color:rgba(71,85,105,0.88) !important;
}
.cryptoPlan .cryptoPlan__archiveAction:hover{
  border-color:rgba(148,163,184,0.3) !important;
  background:rgba(148,163,184,0.13) !important;
  color:rgba(51,65,85,1) !important;
}
.cryptoPlan .cryptoPlan__archiveAction.isArchived{
  border-color:rgba(245,158,11,0.22) !important;
  background:rgba(245,158,11,0.1) !important;
  color:rgba(146,64,14,0.92) !important;
}
.cryptoPlan .cryptoPlan__archiveAction.isArchived:hover{
  border-color:rgba(245,158,11,0.32) !important;
  background:rgba(245,158,11,0.16) !important;
  color:rgba(120,53,15,1) !important;
}
.cryptoPlan .cryptoActionIcon--danger{
  border-color:rgba(239,68,68,0.18) !important;
  background:rgba(239,68,68,0.05) !important;
  color:rgba(185,28,28,0.78) !important;
}
.cryptoPlan .cryptoActionIcon--danger:hover{
  border-color:rgba(239,68,68,0.28) !important;
  background:rgba(239,68,68,0.11) !important;
  color:rgba(185,28,28,1) !important;
}
.cryptoPlan .cryptoActionIcon svg{
  width:16px;
  height:16px;
}
.cryptoPlanTotal{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:10px;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:13px;
  padding:9px 12px;
  background:linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,250,252,0.86));
  box-shadow:
    0 8px 18px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.8);
}
.cryptoPlanTotal__label{
  font-size:10px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
  font-weight:800;
}
.cryptoPlanTotal__value{
  justify-self:center;
  font-size:clamp(18px, 1.35vw, 24px);
  line-height:1.05;
  font-weight:900;
  font-variant-numeric:tabular-nums;
}
.cryptoPlanTotal__meta{
  font-size:11px;
  justify-self:end;
  white-space:nowrap;
}
@media (max-width: 820px){
  .cryptoPlanTotal{
    grid-template-columns:1fr;
    text-align:center;
  }
  .cryptoPlanTotal__value,
  .cryptoPlanTotal__meta{
    justify-self:center;
  }
}
@media (max-width: 1120px){
  .cryptoPlanToolbar{
    grid-template-columns:1fr;
  }
}

/* ATH compact premium pass */
.panel.cryptoAth .cryptoAth__head{
  border:1px solid rgba(148,163,184,0.24);
  border-radius:14px;
  padding:10px 12px;
  margin-bottom:0;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.95), rgba(239,246,255,0.88));
  box-shadow:
    0 10px 22px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.82);
}
.panel.cryptoAth .cryptoAth__head .panel__title{
  margin:0;
  line-height:1.08;
}
.panel.cryptoAth .cryptoAth__status{
  display:none;
}
.panel.cryptoAth .cryptoAthOwners{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:end;
  gap:8px;
  border-radius:14px;
  padding:10px;
}
.panel.cryptoAth .cryptoAthOwners__left{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.panel.cryptoAth .cryptoAthOwners__label{
  margin:0;
  white-space:nowrap;
}
.panel.cryptoAth .cryptoAthOwners__actions{
  justify-content:flex-end;
  gap:6px;
}
.panel.cryptoAth .cryptoAthOwners__select{
  width:clamp(170px, 22vw, 300px);
  min-width:170px;
  max-width:300px;
  flex:0 0 auto;
}
.panel.cryptoAth .cryptoAthOwners__left .chip{
  width:auto;
  max-width:100%;
  white-space:nowrap;
  justify-self:start;
  margin-left:2px;
}
.panel.cryptoAth .cryptoAthSummary{
  gap:8px;
}
.panel.cryptoAth .cryptoAthSummary__card{
  min-height:92px;
  border-radius:14px;
  padding:10px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.panel.cryptoAth .cryptoAthSummary__label{
  font-size:11px;
  letter-spacing:0.2px;
}
.panel.cryptoAth .cryptoAthSummary__value{
  font-size:clamp(22px, 1.8vw, 30px);
  line-height:1.05;
  margin-top:3px;
  font-weight:900;
}
.panel.cryptoAth .cryptoAthInsights{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
  align-items:stretch;
}
.panel.cryptoAth .cryptoAthPerf{
  position:relative;
  border-radius:14px;
  padding:10px;
  gap:8px;
  border:1px solid rgba(148,163,184,0.22);
  background:linear-gradient(180deg, rgba(255,255,255,0.90), rgba(246,250,255,0.82));
  box-shadow:0 8px 22px rgba(15,23,42,0.06);
}
.panel.cryptoAth .cryptoAthPerf.isUp{
  border-color:rgba(59,130,246,0.30);
}
.panel.cryptoAth .cryptoAthPerf.isDown{
  border-color:rgba(239,68,68,0.26);
}
.panel.cryptoAth .cryptoAthPerf__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}
.panel.cryptoAth .cryptoAthPerf__ranges{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.panel.cryptoAth .cryptoAthPerf__ranges .pillBtn{
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.28);
  background:rgba(255,255,255,0.86);
  color:#334155;
  font-weight:800;
  letter-spacing:0.01em;
}
.panel.cryptoAth .cryptoAthPerf__ranges .pillBtn.isActive{
  border-color:rgba(59,130,246,0.42);
  color:#0b2a67;
  background:linear-gradient(180deg, rgba(219,234,254,0.92), rgba(191,219,254,0.84));
  box-shadow:0 8px 16px rgba(59,130,246,0.18);
}
.panel.cryptoAth .cryptoAthPerf__plot{
  position:relative;
  min-height:230px;
  border-radius:12px;
  border:1px solid rgba(148,163,184,0.22);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(241,245,249,0.82));
  overflow:hidden;
}
.panel.cryptoAth .cryptoAthPerf.isLoading .cryptoAthPerf__plot::after{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,0.55), rgba(255,255,255,0));
  transform:translateX(-100%);
  animation:cryptoAthPerfShimmer 1.35s ease-in-out infinite;
}
.panel.cryptoAth .cryptoAthPerf__plot iframe,
.panel.cryptoAth .cryptoAthPerf__plot canvas,
.panel.cryptoAth .cryptoAthPerf__plot svg{
  width:100%;
  height:100%;
  display:block;
}
.panel.cryptoAth .cryptoAthPerf__svg{
  width:100%;
  height:100%;
}
.panel.cryptoAth .cryptoAthPerf__grid{
  stroke:rgba(148,163,184,0.24);
  stroke-width:1;
}
.panel.cryptoAth .cryptoAthPerf__yLabel{
  fill:#64748b;
  font-size:11px;
  font-weight:700;
  font-variant-numeric:tabular-nums;
}
.panel.cryptoAth .cryptoAthPerf__axisX{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  min-height:18px;
  color:var(--muted);
  font-size:12px;
  font-variant-numeric:tabular-nums;
}
.panel.cryptoAth .cryptoAthPerf__axisTick{
  white-space:nowrap;
  color:#64748b;
}
.panel.cryptoAth .cryptoAthPerf__meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:#475569;
}
.panel.cryptoAth .cryptoAthPerf__metaNow{
  font-size:14px;
  font-weight:900;
  color:#0f172a;
}
.panel.cryptoAth .cryptoAthPerf__metaDelta{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 9px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.30);
  font-weight:800;
  font-variant-numeric:tabular-nums;
}
.panel.cryptoAth .cryptoAthPerf__metaDelta.isUp{
  color:#065f46;
  border-color:rgba(16,185,129,0.35);
  background:rgba(236,253,245,0.88);
}
.panel.cryptoAth .cryptoAthPerf__metaDelta.isDown{
  color:#b91c1c;
  border-color:rgba(239,68,68,0.34);
  background:rgba(254,242,242,0.90);
}
.panel.cryptoAth .cryptoAthPerf__metaAux{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.panel.cryptoAth .cryptoAthAlloc{
  border-radius:14px;
  padding:10px;
  gap:8px;
}

@keyframes cryptoAthPerfShimmer{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}
.panel.cryptoAth .cryptoAthAlloc__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}
.panel.cryptoAth .cryptoAthAlloc__sub{
  font-size:12px;
}
.panel.cryptoAth .cryptoAthAlloc__chart{
  display:grid;
  grid-template-columns:minmax(220px, 290px) minmax(0, 1fr);
  gap:12px;
  align-items:center;
}
.panel.cryptoAth .cryptoAthAlloc__ring{
  width:220px;
  height:220px;
  border-radius:999px;
  margin:0 auto;
  position:relative;
  box-shadow:
    0 14px 28px rgba(15,23,42,0.10),
    inset 0 0 0 1px rgba(255,255,255,0.55);
}
.panel.cryptoAth .cryptoAthAlloc__center{
  position:absolute;
  inset:22%;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(248,250,252,0.92));
  border:1px solid rgba(148,163,184,0.24);
  display:grid;
  place-items:center;
  text-align:center;
  padding:8px;
}
.panel.cryptoAth .cryptoAthAlloc__centerLabel{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.08em;
}
.panel.cryptoAth .cryptoAthAlloc__centerValue{
  margin-top:1px;
  font-size:14px;
  line-height:1.1;
  font-weight:900;
  color:#0f172a;
}
.panel.cryptoAth .cryptoAthAlloc__centerMeta{
  margin-top:1px;
  font-size:11px;
}
.panel.cryptoAth .cryptoAthAlloc__legend{
  display:flex;
  flex-direction:column;
  gap:7px;
}
.panel.cryptoAth .cryptoAthAlloc__row{
  appearance:none;
  width:100%;
  text-align:left;
  cursor:pointer;
  display:grid;
  grid-template-columns:auto minmax(0, 1fr) auto auto;
  gap:8px;
  align-items:center;
  border:1px solid rgba(148,163,184,0.20);
  border-radius:11px;
  background:rgba(255,255,255,0.78);
  padding:7px 9px;
  transition:border-color .14s ease, box-shadow .14s ease, transform .12s ease;
}
.panel.cryptoAth .cryptoAthAlloc__row:hover{
  border-color:rgba(59,130,246,0.34);
  box-shadow:0 8px 18px rgba(59,130,246,0.12);
}
.panel.cryptoAth .cryptoAthAlloc__row.isActive{
  border-color:rgba(59,130,246,0.52);
  background:linear-gradient(180deg, rgba(239,246,255,0.96), rgba(219,234,254,0.90));
  box-shadow:0 10px 20px rgba(59,130,246,0.18);
}
.panel.cryptoAth .cryptoAthAlloc__row.isStatic{
  cursor:default;
  opacity:0.94;
}
.panel.cryptoAth .cryptoAthAlloc__row:disabled{
  pointer-events:none;
}
.panel.cryptoAth .cryptoAthAlloc__dot{
  width:10px;
  height:10px;
  border-radius:99px;
  display:inline-block;
}
.panel.cryptoAth .cryptoAthAlloc__name{
  font-size:13px;
  font-weight:700;
  color:#0f172a;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.panel.cryptoAth .cryptoAthAlloc__pct{
  font-size:13px;
  font-variant-numeric:tabular-nums;
  color:#1e293b;
}
.panel.cryptoAth .cryptoAthAlloc__val{
  font-size:13px;
  font-weight:800;
  font-variant-numeric:tabular-nums;
  color:#0f172a;
}
.panel.cryptoAth .cryptoAth__section{
  border-radius:14px;
  padding:9px;
  gap:8px;
}
.panel.cryptoAth .cryptoAth__section--toolbar{
  display:grid;
  grid-template-columns:minmax(300px, 1fr) minmax(130px, 170px) auto minmax(250px, 1fr) minmax(170px, 230px);
  align-items:center;
  gap:7px;
}
.panel.cryptoAth .cryptoAth__section--toolbar .cryptoAth__sectionTitle{
  grid-column:1 / -1;
}
.panel.cryptoAth .cryptoAth__section--toolbar .cryptoAthAdd,
.panel.cryptoAth .cryptoAth__section--toolbar .cryptoAthTools{
  display:contents;
}
.panel.cryptoAth .cryptoAth__section--toolbar .cryptoAth__picked{
  grid-column:1 / -1;
}
.panel.cryptoAth .cryptoAth__sectionTitle{
  font-size:13px;
  margin:0;
}
.panel.cryptoAth .cryptoAthAdd{
  grid-template-columns:minmax(220px, 1fr) minmax(130px, 170px) auto;
  gap:7px;
}
.panel.cryptoAth .cryptoAthTools{
  grid-template-columns:minmax(220px, 1fr) minmax(170px, 230px);
  gap:7px;
}
.panel.cryptoAth .input{
  min-height:36px;
  padding:7px 11px;
  border-radius:11px;
  font-size:13.5px;
}
.panel.cryptoAth .ghostBtn,
.panel.cryptoAth .primaryBtn,
.panel.cryptoAth .dangerBtn{
  min-height:36px;
  padding:0 11px;
  border-radius:11px;
  font-size:13px;
  font-weight:700;
}
.panel.cryptoAth .cryptoAth__picked{
  margin-top:2px;
  padding:6px 9px;
  border:1px dashed rgba(148,163,184,0.30);
  border-radius:10px;
  background:rgba(255,255,255,0.66);
  width:max-content;
}
.panel.cryptoAth .cryptoAth__picked.isHidden{display:none}
.panel.cryptoAth .cryptoAthTable{
  min-width:1130px;
}
.panel.cryptoAth .cryptoAthTable th{
  font-size:11px;
  letter-spacing:0.2px;
  padding:6px 8px;
}
.panel.cryptoAth .cryptoAthTable td{
  padding:5px 8px;
}
.panel.cryptoAth .cryptoAthTable th:not(:first-child),
.panel.cryptoAth .cryptoAthTable td:not(:first-child){
  text-align:center;
}
.panel.cryptoAth .cryptoAthTable td:nth-child(2),
.panel.cryptoAth .cryptoAthTable td:nth-child(8),
.panel.cryptoAth .cryptoAthTable td:nth-child(9),
.panel.cryptoAth .cryptoAthTable td:nth-child(10){
  vertical-align:middle;
}
.panel.cryptoAth .cryptoAth__coinCell{
  gap:8px;
}
.panel.cryptoAth .cryptoAth__cellStack{
  gap:2px;
}
.panel.cryptoAth .cryptoAthTable td:nth-child(3) .cryptoAth__cellStack,
.panel.cryptoAth .cryptoAthTable td:nth-child(7) .cryptoAth__cellStack{
  align-items:center;
}
.panel.cryptoAth .cryptoAth__coinImg,
.panel.cryptoAth .cryptoAth__coinPh{
  width:24px;
  height:24px;
}
.panel.cryptoAth .cryptoAth__coinName{
  font-size:17px;
  line-height:1.1;
}
.panel.cryptoAth .cryptoAth__coinMeta .muted{
  font-size:12px;
  line-height:1.2;
}
.panel.cryptoAth .cryptoAth__amountInp{
  max-width:112px;
  min-width:82px;
  min-height:32px;
  margin-inline:auto;
  text-align:center;
}
.panel.cryptoAth .cryptoAthQty{
  display:flex;
  align-items:center;
  justify-content:center;
}
.panel.cryptoAth .cryptoAthQty__display{
  min-width:0;
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  color:var(--text);
  font:inherit;
  font-size:17px;
  font-weight:600;
  letter-spacing:0;
  line-height:1.2;
  text-align:center;
  font-variant-numeric:tabular-nums;
}
.panel.cryptoAth .cryptoAthQty .cryptoAth__amountInp{
  display:none;
}
.panel.cryptoAth .cryptoAthQty.isEditing .cryptoAthQty__display{
  display:none;
}
.panel.cryptoAth .cryptoAthQty.isEditing .cryptoAth__amountInp{
  display:block;
}
.panel.cryptoAth .cryptoAthTable td:nth-child(8) .chip{
  margin-inline:auto;
}
.panel.cryptoAth .cryptoActionRow{
  justify-content:center;
  gap:6px;
}
.panel.cryptoAth .cryptoActionIcon{
  width:34px !important;
  height:34px !important;
  min-height:34px !important;
}
.panel.cryptoAth .cryptoAthQtyAction{
  border-color:rgba(59,130,246,0.16) !important;
  background:rgba(59,130,246,0.06) !important;
  color:rgba(30,64,175,0.88) !important;
}
.panel.cryptoAth .cryptoAthQtyAction:hover{
  border-color:rgba(59,130,246,0.28) !important;
  background:rgba(59,130,246,0.12) !important;
  color:rgba(30,64,175,1) !important;
}
.panel.cryptoAth .cryptoActionIcon--danger{
  border-color:rgba(239,68,68,0.18) !important;
  background:rgba(239,68,68,0.05) !important;
  color:rgba(185,28,28,0.78) !important;
}
.panel.cryptoAth .cryptoActionIcon--danger:hover{
  border-color:rgba(239,68,68,0.28) !important;
  background:rgba(239,68,68,0.11) !important;
  color:rgba(185,28,28,1) !important;
}
.panel.cryptoAth .cryptoAthQtyAction.isEditing{
  border-color:rgba(34,197,94,0.24);
  background:rgba(34,197,94,0.12);
  color:#166534;
}

@media (max-width: 1280px){
  .panel.cryptoAth .cryptoAthOwners{
    grid-template-columns:1fr;
  }
  .panel.cryptoAth .cryptoAthOwners__actions{
    justify-content:flex-start;
  }
}
@media (max-width: 980px){
  .panel.cryptoAth .cryptoAthInsights{
    grid-template-columns:1fr;
  }
  .panel.cryptoAth .cryptoAthOwners__left{
    display:flex;
    flex-wrap:wrap;
    gap:7px;
  }
  .panel.cryptoAth .cryptoAthAlloc__chart{
    grid-template-columns:1fr;
  }
  .panel.cryptoAth .cryptoAthAlloc__ring{
    width:210px;
    height:210px;
  }
  .panel.cryptoAth .cryptoAthOwners__label{
    width:100%;
  }
  .panel.cryptoAth .cryptoAthOwners__left .chip{
    white-space:normal;
  }
  .panel.cryptoAth .cryptoAth__section--toolbar{
    grid-template-columns:1fr;
  }
  .panel.cryptoAth .cryptoAth__section--toolbar .cryptoAthAdd,
  .panel.cryptoAth .cryptoAth__section--toolbar .cryptoAthTools{
    display:grid;
    grid-template-columns:1fr;
  }
  .panel.cryptoAth .cryptoAthTable{
    min-width:1020px;
  }
}

@media (max-width: 1280px){
  .cryptoPlanToolbar{
    grid-template-columns:1fr;
  }
  .cryptoPlanAdd{
    grid-template-columns:minmax(220px, 1fr) minmax(130px, 170px) minmax(130px, 170px) auto;
  }
  .cryptoPlanTools{
    grid-template-columns:minmax(220px, 1fr) minmax(150px, 210px) auto auto;
  }
}
@media (max-width: 980px){
  .cryptoPlanAdd,
  .cryptoPlanTools{
    grid-template-columns:1fr;
  }
  .cryptoPlanTable{
    min-width:1020px;
  }
}

/* =========================
   Wishlist
   ========================= */
.panel.wishlistPage{
  background:
    radial-gradient(120% 180% at 0% 0%, rgba(245,158,11,0.11) 0%, rgba(255,255,255,0.90) 42%),
    radial-gradient(120% 160% at 100% 0%, rgba(59,130,246,0.10) 0%, rgba(255,255,255,0.94) 44%),
    rgba(255,255,255,0.96);
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 16px 32px rgba(15,23,42,0.08);
}
.wishlistPage{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.wishlistHead{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:18px;
  border:1px solid rgba(148,163,184,0.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.97), rgba(248,250,255,0.92));
  box-shadow:
    0 10px 20px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.84);
}
.wishlistHead__left{
  min-width:0;
  min-height:auto;
  display:flex;
  align-items:flex-start;
}
.wishlistHead__titleWrap{
  display:flex;
  flex-direction:column;
  gap:0;
}
.wishlistHead__left .panel__title{
  font-size:clamp(24px, 3vw, 34px);
  line-height:1;
  margin:0;
  letter-spacing:-0.045em;
}
.wishlistHead__mid{
  display:flex;
  align-items:center;
  justify-content:center;
  justify-self:center;
}
.wishlistHead__right{
  display:flex;
  gap:6px;
  align-items:center;
  flex-wrap:wrap;
  justify-content:flex-end;
  justify-self:end;
}
.wishlistHead__right .primaryBtn,
.wishlistHead__right .ghostBtn{
  min-height:38px;
  padding:0 12px;
  border-radius:12px;
  font-weight:800;
  box-shadow:none;
}
.wishlistPool{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,248,252,0.94));
  box-shadow:
    0 6px 14px rgba(15,23,42,0.04),
    inset 0 1px 0 rgba(255,255,255,0.90);
  padding:8px 10px;
  min-width:170px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.wishlistPool__label{
  font-size:10px;
  color:#5b6b83;
  font-weight:800;
  display:flex;
  align-items:center;
  gap:6px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.wishlistPool__value{
  margin-top:4px;
  font-size:16px;
  line-height:1;
  font-weight:900;
}
.wishlistPool__meta{
  display:none;
}
.wishlistNotice{
  padding:9px 11px;
  border-radius:12px;
  border:1px solid var(--border);
  font-size:13px;
}
.wishlistNotice.isWarn{background:rgba(239,68,68,0.10); border-color:rgba(239,68,68,0.24)}
.wishlistNotice.isOk{background:rgba(34,197,94,0.10); border-color:rgba(34,197,94,0.20)}
.wishlistNotice.isHidden{display:none}
.wishlistStatusLine{
  font-size:12px;
  color:#55637a;
  border:1px solid rgba(148,163,184,0.18);
  border-radius:999px;
  padding:4px 10px;
  background:rgba(255,255,255,0.82);
  width:max-content;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.9);
}

.wishlistStats{
  display:grid;
  grid-template-columns:repeat(4, minmax(150px, 1fr));
  gap:8px;
}
.wishlistStat{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.97), rgba(243,247,251,0.90));
  box-shadow:
    0 6px 14px rgba(15,23,42,0.04),
    inset 0 1px 0 rgba(255,255,255,0.86);
  min-height:64px;
  padding:8px 10px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.wishlistStat__label{
  font-size:10px;
  color:#7c8aa0;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.wishlistStat__value{
  margin-top:3px;
  font-size:clamp(17px, 1.35vw, 24px);
  font-weight:900;
  line-height:1;
  letter-spacing:-0.03em;
}
.wishlistStat--accent{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(239,246,255,0.94));
  border-color:rgba(96,165,250,0.20);
}

.wishlistNext,
.wishlistItems{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.wishlistSplit{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  align-items:start;
}
.wishlistSection__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:2px;
}
.wishlistSection__title{
  font-weight:900;
  display:flex;
  align-items:center;
  gap:8px;
  font-size:18px;
  line-height:1.1;
  letter-spacing:-0.03em;
}
.wishlistSection__title .infoBtn{
  width:20px;
  height:20px;
}

.wishlistPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:0 8px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.16);
  background:rgba(248,250,252,0.86);
  color:#475569;
  font-size:10px;
  font-weight:800;
  line-height:1;
  white-space:nowrap;
}
.wishlistPill--soft{
  color:#334155;
}
.wishlistPill--deadline{
  border-color:rgba(245,158,11,0.18);
  background:rgba(255,247,237,0.88);
  color:#9a3412;
}

.wishlistNext__card{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,248,252,0.92));
  box-shadow:
    0 8px 18px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.88);
  padding:10px 12px;
  display:flex;
  flex-direction:column;
  gap:7px;
  align-items:stretch;
  text-align:left;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.wishlistNext__card:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.22);
  box-shadow:
    0 12px 24px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.90);
}
.wishlistNext__top{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  flex-wrap:wrap;
  width:100%;
}
.wishlistNext__eyebrow{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  flex-wrap:wrap;
}
.wishlistNext__pills{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:4px;
  flex-wrap:wrap;
}
.wishlistNext__name{
  font-size:clamp(17px, 1.6vw, 22px);
  font-weight:900;
  line-height:1.06;
  letter-spacing:-0.03em;
  width:100%;
  max-width:none;
  text-align:left;
  align-self:flex-start;
}
.wishlistNext__desc{
  font-size:11px;
  line-height:1.45;
  width:100%;
  max-width:none;
  text-align:left;
  align-self:flex-start;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.wishlistPriority{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:22px;
  padding:0 9px;
  border-radius:999px;
  border:1px solid rgba(59,130,246,0.18);
  background:rgba(59,130,246,0.08);
  color:#1d4ed8;
  font-size:9px;
  font-weight:800;
  min-width:52px;
}

.wishlistStatus{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:22px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,0.14);
  padding:0 9px;
  font-size:9px;
  font-weight:800;
  letter-spacing:.04em;
  white-space:nowrap;
}
.wishlistStatus--active{background:rgba(59,130,246,0.10); border-color:rgba(59,130,246,0.28); color:#1f3d8a}
.wishlistStatus--paused{background:rgba(148,163,184,0.12); border-color:rgba(148,163,184,0.28); color:#334155}
.wishlistStatus--ready{background:rgba(16,185,129,0.12); border-color:rgba(16,185,129,0.30); color:#065f46}
.wishlistStatus--purchased{background:rgba(17,24,39,0.10); border-color:rgba(17,24,39,0.22); color:#111827}

.wishlistProgress{
  height:8px;
  border-radius:999px;
  background:rgba(15,23,42,0.08);
  overflow:hidden;
}
.wishlistProgress--hero{
  height:8px;
}
.wishlistProgress__bar{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(59,130,246,0.90), rgba(16,185,129,0.90));
}

.wishlistFacts{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:6px;
  width:100%;
}
.wishlistFacts--hero{
  gap:6px;
}
.wishlistFact{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:12px;
  background:rgba(255,255,255,0.72);
  padding:6px 8px;
  display:flex;
  flex-direction:column;
  gap:3px;
  align-items:center;
  text-align:center;
}
.wishlistFact--accent{
  background:rgba(239,246,255,0.86);
  border-color:rgba(96,165,250,0.20);
}
.wishlistFact__label{
  font-size:9px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#8b9ab0;
}
.wishlistFact__value{
  font-size:11px;
  font-weight:900;
  line-height:1.1;
  color:#0f172a;
  letter-spacing:-0.02em;
}

.wishlistCards{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.wishlistCard{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.97), rgba(243,247,251,0.90));
  box-shadow:
    0 8px 18px rgba(15,23,42,0.045),
    inset 0 1px 0 rgba(255,255,255,0.86);
  padding:10px 12px;
  display:flex;
  flex-direction:column;
  gap:7px;
  align-items:stretch;
  text-align:left;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.wishlistCard:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.22);
  box-shadow:
    0 12px 24px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.90);
}
.wishlistCard__top{
  display:grid;
  grid-template-columns:1fr;
  justify-content:flex-start;
  gap:6px;
  align-items:start;
  width:100%;
}
.wishlistCard__topMain{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:5px;
  align-items:flex-start;
}
.wishlistCard__topSide{
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  width:100%;
}
.wishlistCard__eyebrow{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:4px;
  flex-wrap:wrap;
}
.wishlistCard__name{
  font-size:clamp(15px, 1.3vw, 20px);
  font-weight:900;
  line-height:1.1;
  letter-spacing:-0.035em;
  color:#0f172a;
  width:100%;
  max-width:none;
  text-align:left;
}
.wishlistCard__link{
  color:#1f3d8a;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
  width:max-content;
  align-self:flex-start;
  text-align:left;
}
.wishlistCard__link:hover{text-decoration:underline}
.wishlistCard__link--hero{
  margin-top:0;
}
.wishlistCard__notes{
  font-size:11px;
  line-height:1.45;
  width:100%;
  max-width:none;
  text-align:left;
  align-self:flex-start;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.wishlistCard__actions{
  display:flex;
  gap:4px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.wishlistCard__actions .ghostBtn,
.wishlistCard__actions .primaryBtn,
.wishlistCard__actions .dangerBtn{
  min-height:30px;
  padding:3px 8px;
  border-radius:10px;
  font-size:11px;
  font-weight:800;
}
.wishlistCard__actions--compact .wishlistActionIcon{
  width:30px;
  height:30px;
  min-height:30px;
  padding:0;
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-color:rgba(148,163,184,0.16);
  background:rgba(248,250,252,0.86);
  box-shadow:none;
}
.wishlistCard__actions--compact .wishlistActionIcon svg{
  width:14px;
  height:14px;
}
.wishlistCard__actions--compact .wishlistActionIcon--danger{
  border-color:rgba(239,68,68,0.24);
  background:rgba(254,242,242,0.88);
}
.wishlistCard__actions--compact .wishlistActionIcon:hover{
  background:rgba(241,245,249,0.98);
}
.wishlistCard__actions--compact .primaryBtn.wishlistActionIcon{
  background:rgba(16,185,129,0.10);
  border-color:rgba(16,185,129,0.20);
  color:#047857;
}

.wishlistActivity{
  min-width:0;
  position:static;
  border:1px solid rgba(148,163,184,0.18);
  border-radius:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(243,247,251,0.90));
  box-shadow:
    0 8px 18px rgba(15,23,42,0.045),
    inset 0 1px 0 rgba(255,255,255,0.86);
  padding:10px 12px;
}
.wishlistActivityList{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.wishlistActCard{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:12px;
  background:rgba(255,255,255,0.84);
  padding:9px 10px;
  display:flex;
  flex-direction:column;
  gap:6px;
  text-align:center;
}
.wishlistActCard__top{
  display:flex;
  justify-content:center;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.wishlistActCard__title{
  font-weight:800;
  color:#0f172a;
}
.wishlistActCard__allocs{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.wishlistActCard__alloc{
  font-size:13px;
  color:#334155;
}

.wishlistModal{
  display:flex;
  flex-direction:column;
  gap:7px;
}
.wishlistModal .formLabel{
  font-size:12px;
  font-weight:700;
  color:#55637b;
}
.wishlistModal .input{
  min-height:38px;
  border-radius:8px;
}
.wishlistAllocResult{
  display:flex;
  flex-direction:column;
  gap:7px;
}
.wishlistAllocResult__line{
  font-size:14px;
}

@media (max-width: 1120px){
  .wishlistHead{
    grid-template-columns:1fr;
    align-items:stretch;
  }
  .wishlistHead__left{
    min-height:auto;
    justify-content:flex-start;
  }
  .wishlistHead__mid{
    justify-content:flex-start;
    justify-self:stretch;
  }
  .wishlistHead__right{
    justify-content:flex-start;
  }
}
@media (max-width: 900px){
  .wishlistStats{grid-template-columns:repeat(2, minmax(150px, 1fr))}
  .wishlistFacts{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 620px){
  .wishlistHead__mid,
  .wishlistHead__right{width:100%}
  .wishlistPool{width:100%}
  .wishlistStats{grid-template-columns:1fr}
  .wishlistStatusLine{width:100%}
  .wishlistSection__title{
    font-size:16px;
  }
  .wishlistNext__card,
  .wishlistCard,
  .wishlistActivity{
    border-radius:14px;
    padding:11px;
  }
  .wishlistCard__topSide{
    align-items:center;
    justify-content:space-between;
  }
  .wishlistCard__actions{
    justify-content:center;
  }
  .wishlistCard__actions .ghostBtn,
  .wishlistCard__actions .primaryBtn,
  .wishlistCard__actions .dangerBtn{flex:0 0 auto}
  .wishlistFacts{
    grid-template-columns:1fr;
  }
}

/* =========================
   Utile (Notes / PKB)
   ========================= */
.panel.utilePage{
  background:
    radial-gradient(120% 165% at 0% 0%, rgba(59,130,246,0.08) 0%, rgba(255,255,255,0.88) 44%),
    radial-gradient(115% 145% at 100% 0%, rgba(16,185,129,0.08) 0%, rgba(255,255,255,0.92) 48%),
    rgba(255,255,255,0.95);
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 16px 34px rgba(15,23,42,0.10);
}
.utilePage{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.utileHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.utileHead__right{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.utileToolbar{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:14px;
  background:rgba(255,255,255,0.82);
  padding:10px;
  display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(170px, 240px) auto;
  gap:8px;
  align-items:center;
}
.utileToolbar__search{min-width:0}
.utileToolbar__pin{
  margin:0;
  min-height:36px;
  padding:0 8px;
  border:1px solid rgba(17,24,39,0.14);
  border-radius:11px;
  background:rgba(255,255,255,0.85);
}
.utileNotice{
  padding:9px 11px;
  border-radius:12px;
  border:1px solid var(--border);
  font-size:13px;
}
.utileNotice.isWarn{background:rgba(239,68,68,0.10); border-color:rgba(239,68,68,0.24)}
.utileNotice.isOk{background:rgba(34,197,94,0.10); border-color:rgba(34,197,94,0.20)}
.utileNotice.isHidden{display:none}
.utileStatus{font-size:12px}

.utileList{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.utileRow{
  border:1px solid rgba(15,23,42,0.10);
  border-radius:14px;
  background:rgba(255,255,255,0.86);
  padding:10px 12px;
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:center;
  gap:10px;
  min-width:0;
}
.utileRow.isPinned{
  border-color:rgba(59,130,246,0.28);
}
.utileRow__main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:7px;
}
.utileRow__titleWrap{
  min-width:0;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
}
.utileRow__title{
  margin:0;
  font-size:16px;
  font-weight:800;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.utileRow__pinned{
  background:rgba(59,130,246,0.12);
  border-color:rgba(59,130,246,0.28);
  color:#1f3d8a;
}
.utileRow__snippet{
  font-size:13px;
  line-height:1.45;
  color:#334155;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  word-break:break-word;
}
.utileRow__snippet a{
  color:#1f3d8a;
  text-decoration:underline;
}
.utileRow__meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.utileRow__chips{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.utileRow__updated{
  font-size:11px;
}
.utileRow__actions{
  display:flex;
  align-items:center;
  gap:7px;
  justify-content:flex-end;
}
.utileActionIcon{
  width:34px;
  height:34px;
  min-height:34px;
  border-radius:10px;
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.utileActionIcon svg{
  width:16px;
  height:16px;
  display:block;
  fill:currentColor;
}
.utileEmpty{
  width:100%;
}

.utileEditor{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.utileEditor__status{
  min-height:18px;
  font-size:12px;
}

@media (max-width: 860px){
  .utileToolbar{grid-template-columns:1fr}
  .utileRow{
    grid-template-columns:1fr;
    align-items:flex-start;
  }
  .utileRow__actions{
    width:100%;
    justify-content:flex-start;
  }
}
@media (max-width: 520px){
  .utileRow__snippet{-webkit-line-clamp:3}
}

/* Utile compact premium pass */
.utilePage{gap:8px}
.utileHead{
  padding-bottom:4px;
  border-bottom:1px solid rgba(148,163,184,0.28);
}
.utileHead__right .primaryBtn{
  min-height:33px;
  padding:6px 10px;
  border-radius:9px;
  font-weight:700;
}
.utileToolbar{
  border-color:rgba(148,163,184,0.26);
  border-radius:12px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(247,250,255,0.90));
  box-shadow:
    0 10px 20px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.80);
  padding:8px;
  gap:6px;
}
.utileToolbar .input{
  min-height:34px;
  border-radius:9px;
}
.utileToolbar__pin{
  min-height:34px;
  border-radius:9px;
  border-color:rgba(148,163,184,0.34);
  background:rgba(255,255,255,0.92);
}
.utileStatus{
  display:inline-flex;
  align-items:center;
  width:max-content;
  border:1px solid rgba(148,163,184,0.30);
  border-radius:999px;
  background:rgba(255,255,255,0.92);
  padding:5px 10px;
  font-size:11px;
}
.utileNotice{
  border-radius:10px;
  padding:8px 10px;
  font-size:12px;
}
.utileList{
  gap:7px;
}
.utileRow{
  border-color:rgba(148,163,184,0.24);
  border-radius:12px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,245,249,0.86));
  box-shadow:
    0 8px 16px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.80);
  padding:8px 10px;
  gap:8px;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.utileRow__main{gap:5px}
.utileRow:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.30);
  box-shadow:
    0 12px 24px rgba(15,23,42,0.09),
    inset 0 1px 0 rgba(255,255,255,0.84);
}
.utileRow__title{
  font-size:14px;
}
.utileRow__snippet{
  font-size:12px;
  line-height:1.36;
  -webkit-line-clamp:2;
}
.utileRow__chips .chip{
  border-radius:999px;
  border-color:rgba(148,163,184,0.30);
  background:rgba(255,255,255,0.88);
  font-size:11px;
  padding:3px 8px;
}
.utileRow__actions{
  gap:5px;
}
.utileActionIcon{
  width:30px;
  height:30px;
  min-height:30px;
  border-radius:8px;
}
.utileActionIcon svg{width:14px; height:14px}
.utileRow__updated{
  font-size:10px;
}
.utileEditor{
  gap:9px;
}
.utileEditor .input{
  border-radius:10px;
}
.utileEditor__status{
  display:inline-flex;
  align-items:center;
  width:max-content;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(15,23,42,0.06);
}

@media (max-width: 860px){
  .utileHead{border-bottom:0; padding-bottom:0}
  .utileToolbar{grid-template-columns:1fr}
  .utileStatus{width:100%; justify-content:center}
}

/* Utile premium refresh */
.panel.utilePage{
  background:
    radial-gradient(135% 170% at 0% 0%, rgba(37,99,235,0.14) 0%, rgba(255,255,255,0.92) 44%),
    radial-gradient(125% 155% at 100% 0%, rgba(14,165,233,0.12) 0%, rgba(255,255,255,0.95) 46%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,255,0.96));
  border-color: rgba(15,23,42,0.10);
  box-shadow: 0 24px 48px rgba(15,23,42,0.10);
}
.utilePage{
  gap:14px;
}
.utileHero{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:18px;
  align-items:start;
  padding:20px 22px;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:24px;
  background:
    radial-gradient(120% 160% at 0% 0%, rgba(59,130,246,0.16) 0%, rgba(255,255,255,0) 50%),
    radial-gradient(115% 145% at 100% 0%, rgba(45,212,191,0.16) 0%, rgba(255,255,255,0) 52%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(241,245,249,0.92));
  box-shadow:
    0 16px 32px rgba(15,23,42,0.08),
    inset 0 1px 0 rgba(255,255,255,0.88);
}
.utileHero::after{
  content:"";
  position:absolute;
  inset:auto -80px -120px auto;
  width:240px;
  height:240px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(14,165,233,0.12), rgba(14,165,233,0));
  pointer-events:none;
}
.utileHero__main{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}
.utileHero__eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(15,23,42,0.07);
  color:#0f172a;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.utileHero__title{
  margin:0;
  font-size:30px;
  line-height:1;
  letter-spacing:-0.04em;
  font-weight:900;
  color:#0f172a;
}
.utileHero__subtitle{
  margin:0;
  max-width:760px;
  font-size:15px;
  line-height:1.6;
  color:#334155;
}
.utileHero__hint{
  font-size:13px;
  font-weight:700;
  color:#1d4ed8;
}
.utileHero__actions{
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.utileHero__actions .primaryBtn{
  min-height:44px;
  padding:0 16px;
  border-radius:14px;
  font-weight:800;
  box-shadow:0 10px 20px rgba(37,99,235,0.14);
}
.utileToolbar{
  border-color:rgba(148,163,184,0.24);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,255,0.94));
  padding:10px;
  grid-template-columns:minmax(260px, 1.3fr) minmax(180px, .65fr) auto auto;
  gap:10px;
  box-shadow:
    0 12px 24px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.88);
}
.utileToolbar .input{
  min-height:42px;
  border-radius:13px;
  border-color:rgba(148,163,184,0.26);
  background:rgba(255,255,255,0.94);
}
.utileToolbar__pin,
.utileUtilityBtn{
  min-height:42px;
  padding:0 12px;
  border-radius:13px;
  border-color:rgba(148,163,184,0.26);
  background:rgba(255,255,255,0.92);
  font-weight:700;
}
.utileInsights{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.utileSummary{
  display:flex;
  align-items:stretch;
  gap:10px;
  flex-wrap:wrap;
}
.utileMetric{
  min-width:110px;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(148,163,184,0.22);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(240,246,255,0.90));
  box-shadow:
    0 8px 18px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.88);
}
.utileMetric__value{
  font-size:19px;
  line-height:1;
  font-weight:900;
  color:#0f172a;
}
.utileMetric__label{
  margin-top:5px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#64748b;
}
.utileFilterTrail{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.utileFilterChip{
  border-color:rgba(59,130,246,0.18);
  background:rgba(219,234,254,0.52);
  color:#1d4ed8;
}
.utileStatus{
  padding:7px 12px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.24);
  background:rgba(255,255,255,0.94);
  font-size:12px;
  font-weight:700;
}
.utileStatusActions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-left:auto;
}
.utileList{
  gap:14px;
}
.utileCard{
  position:relative;
  border:1px solid rgba(148,163,184,0.22);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(241,245,249,0.92));
  padding:16px 18px;
  box-shadow:
    0 14px 28px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.88);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.utileCard:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.22);
  box-shadow:
    0 18px 34px rgba(15,23,42,0.08),
    inset 0 1px 0 rgba(255,255,255,0.92);
}
.utileCard.isPinned{
  border-color:rgba(59,130,246,0.28);
  box-shadow:
    0 18px 34px rgba(37,99,235,0.08),
    inset 0 1px 0 rgba(255,255,255,0.92);
}
.utileCard.isExpanded{
  border-color:rgba(37,99,235,0.30);
}
.utileCard__layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:16px;
  align-items:start;
}
.utileCard__main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.utileCard__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.utileCard__heading{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.utileCard__titleBtn{
  width:100%;
  padding:0;
  border:0;
  background:none;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  text-align:left;
  color:inherit;
  cursor:pointer;
}
.utileCard__titleBtn:focus-visible{
  outline:2px solid rgba(37,99,235,0.55);
  outline-offset:4px;
  border-radius:16px;
}
.utileCard__titleText{
  display:block;
  font-size:22px;
  font-weight:900;
  line-height:1.08;
  letter-spacing:-0.03em;
  color:#0f172a;
}
.utileCard__titleArrow{
  flex:0 0 38px;
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:13px;
  border:1px solid rgba(148,163,184,0.22);
  background:rgba(255,255,255,0.90);
  color:#1d4ed8;
  box-shadow:0 6px 14px rgba(15,23,42,0.05);
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.utileCard.isExpanded .utileCard__titleArrow{
  transform:rotate(180deg);
  border-color:rgba(59,130,246,0.24);
  background:rgba(219,234,254,0.66);
}
.utileCard__titleArrow svg{
  width:15px;
  height:15px;
  fill:currentColor;
}
.utileCard__badges{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.utileChip{
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  line-height:1;
  padding:6px 10px;
}
button.utileChip{
  cursor:pointer;
}
.utileChip--category{
  border-color:rgba(37,99,235,0.18);
  background:rgba(219,234,254,0.52);
  color:#1d4ed8;
}
.utileChip--tag{
  border-color:rgba(15,23,42,0.12);
  background:rgba(248,250,252,0.98);
  color:#334155;
}
.utileChip--pinned{
  border-color:rgba(250,204,21,0.22);
  background:rgba(254,249,195,0.92);
  color:#854d0e;
}
.utileChip--neutral{
  border-color:rgba(148,163,184,0.24);
  background:rgba(255,255,255,0.86);
  color:#64748b;
}
.utileCard__updated{
  font-size:11px;
  font-weight:700;
  color:#64748b;
  white-space:nowrap;
}
.utileCard__preview{
  font-size:14px;
  line-height:1.65;
  color:#334155;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  word-break:break-word;
}
.utileCard__preview a,
.utileCard__content a{
  color:#1d4ed8;
  text-decoration:underline;
}
.utileCard__body{
  display:none;
}
.utileCard.isExpanded .utileCard__preview{
  display:none;
}
.utileCard.isExpanded .utileCard__body{
  display:grid;
  grid-template-columns:minmax(0, 1.35fr) minmax(240px, .85fr);
  gap:18px;
  padding-top:14px;
  border-top:1px solid rgba(148,163,184,0.22);
}
.utileCard__contentPanel,
.utileCard__metaCard{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:18px;
  background:rgba(255,255,255,0.82);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.88);
}
.utileCard__contentPanel{
  padding:16px 16px 14px;
}
.utileCard__sectionLabel,
.utileCard__metaLabel{
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#64748b;
}
.utileCard__content{
  margin-top:10px;
  font-size:14px;
  line-height:1.72;
  color:#1e293b;
  word-break:break-word;
}
.utileCard__metaPanel{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.utileCard__metaCard{
  padding:12px 14px;
}
.utileCard__metaValue{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  min-width:0;
}
.utileCard__metaValue--text{
  font-size:13px;
  line-height:1.5;
  color:#1e293b;
}
.utileCard__tagList{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.utileCard__actions{
  display:flex;
  align-items:flex-start;
  gap:8px;
  justify-content:flex-end;
}
.utileActionIcon{
  width:38px;
  height:38px;
  min-height:38px;
  border-radius:12px;
  box-shadow:0 8px 16px rgba(15,23,42,0.05);
}

@media (max-width: 1080px){
  .utileToolbar{
    grid-template-columns:minmax(0, 1fr) minmax(180px, .7fr);
  }
  .utileStatusActions{
    width:100%;
    margin-left:0;
    justify-content:flex-start;
  }
}
@media (max-width: 860px){
  .utileHero{
    grid-template-columns:1fr;
    padding:18px;
  }
  .utileHero__actions{
    justify-content:flex-start;
  }
  .utileToolbar{
    grid-template-columns:1fr;
  }
  .utileCard__layout{
    grid-template-columns:1fr;
  }
  .utileCard__header{
    flex-direction:column;
    align-items:flex-start;
  }
  .utileCard.isExpanded .utileCard__body{
    grid-template-columns:1fr;
  }
  .utileCard__actions{
    width:100%;
    justify-content:flex-start;
  }
  .utileStatus{
    width:100%;
    justify-content:center;
  }
}
@media (max-width: 520px){
  .utileHero__title{
    font-size:24px;
  }
  .utileMetric{
    min-width:calc(50% - 5px);
  }
  .utileCard{
    padding:14px;
    border-radius:18px;
  }
  .utileCard__titleText{
    font-size:18px;
  }
  .utileCard__titleArrow{
    flex-basis:34px;
    width:34px;
    height:34px;
  }
  .utileCard__preview{
    -webkit-line-clamp:3;
  }
  .utileActionIcon{
    width:34px;
    height:34px;
    min-height:34px;
  }
}

/* Utile compact weekly-use override */
.utileCompactHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  padding-bottom:4px;
  border-bottom:1px solid rgba(148,163,184,0.22);
}
.utileCompactHead__titleWrap{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:3px;
}
.utileCompactHead__subtitle{
  font-size:12px;
}
.utileCompactHead__actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.utileToolbar--compact{
  grid-template-columns:minmax(240px,1fr) minmax(170px,220px) auto auto;
  padding:8px;
  gap:8px;
}
.utileToolbar--compact .input,
.utileToolbar--compact .utileToolbar__pin,
.utileToolbar--compact .utileUtilityBtn{
  min-height:36px;
  border-radius:10px;
}
.utileToolbar--compact .utileUtilityBtn{
  padding:0 10px;
}
.utileCompactCard{
  width:100%;
  border:1px solid rgba(148,163,184,0.24);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.97), rgba(245,248,252,0.92));
  box-shadow:0 8px 18px rgba(15,23,42,0.05);
  padding:10px 12px;
}
.utileCompactCard.isPinned{
  border-color:rgba(59,130,246,0.26);
}
.utileCompactCard__top{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:start;
}
.utileCompactCard__main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.utileCompactCard__line{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.utileCompactCard__heading{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:5px;
}
.utileCompactTitleBtn{
  padding:0;
  border:0;
  background:none;
  display:flex;
  align-items:center;
  gap:8px;
  text-align:left;
  cursor:pointer;
  color:inherit;
}
.utileCompactTitleText{
  font-size:16px;
  line-height:1.2;
  font-weight:800;
  color:#0f172a;
  word-break:break-word;
}
.utileCompactToggle{
  flex:0 0 18px;
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(15,23,42,0.08);
  color:#1d4ed8;
  font-size:14px;
  font-weight:900;
  line-height:1;
}
.utileCompactCard__chips{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.utileCompactCard__updated{
  font-size:11px;
  white-space:nowrap;
}
.utileCompactCard__preview{
  font-size:13px;
  line-height:1.45;
  color:#334155;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  word-break:break-word;
}
.utileCompactCard__actions{
  display:flex;
  align-items:center;
  gap:6px;
}
.utileCompactCard__details{
  margin-top:8px;
  padding-top:8px;
  border-top:1px solid rgba(148,163,184,0.18);
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(240px,.9fr);
  gap:12px;
}
.utileCompactCard__content{
  font-size:13px;
  line-height:1.55;
  color:#0f172a;
  word-break:break-word;
}
.utileCompactCard__content a{
  color:#1d4ed8;
  text-decoration:underline;
}
.utileCompactCard__meta{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.utileCompactCard__metaRow{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.utileCompactCard__metaLabel{
  font-size:10px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#64748b;
}
.utileCompactCard__metaValue{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.utileCompactCard__metaText{
  font-size:12px;
  color:#1e293b;
}

@media (max-width: 860px){
  .utileCompactHead{
    align-items:flex-start;
  }
  .utileCompactHead__actions{
    width:100%;
    justify-content:flex-start;
  }
  .utileToolbar--compact{
    grid-template-columns:1fr;
  }
  .utileCompactCard__top{
    grid-template-columns:1fr;
  }
  .utileCompactCard__line{
    flex-direction:column;
    gap:6px;
  }
  .utileCompactCard__updated{
    white-space:normal;
  }
  .utileCompactCard__actions{
    width:100%;
    justify-content:flex-start;
  }
  .utileCompactCard__details{
    grid-template-columns:1fr;
  }
}

/* Utile clean accordion override */
.utilePage{
  gap:12px;
}
.utileCompactHead{
  padding-bottom:4px;
  border-bottom:0;
}
.utileCompactHead__subtitle{
  font-size:14px;
  color:#64748b;
  max-width:760px;
}
.utileCompactHead__actions .utileStatus{
  font-size:11px;
  padding:5px 10px;
  border-color:rgba(148,163,184,0.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.9);
}
.utileToolbar--compact{
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.94));
  box-shadow:
    0 10px 22px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.92);
  border-color:rgba(148,163,184,0.20);
}
.utileAccordion{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.985), rgba(247,250,252,0.96));
  padding:14px 16px;
  box-shadow:
    0 10px 24px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.88);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.utileAccordion:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.18);
  box-shadow:
    0 14px 28px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.92);
}
.utileAccordion.isPinned{
  border-color:rgba(59,130,246,0.26);
  box-shadow:
    0 12px 26px rgba(37,99,235,0.07),
    inset 0 1px 0 rgba(255,255,255,0.92);
}
.utileAccordion__top{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}
.utileAccordion__main{
  min-width:0;
}
.utileAccordion__heading{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}
button.utileAccordion__titleBtn,
.utileAccordion__titleBtn{
  appearance:none;
  -webkit-appearance:none;
  width:100%;
  margin:0;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  outline:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  text-align:left;
  cursor:pointer;
  color:inherit;
  font:inherit;
  min-height:auto;
}
button.utileAccordion__titleBtn:hover,
button.utileAccordion__titleBtn:active,
button.utileAccordion__titleBtn:focus{
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
.utileAccordion__titleBtn:hover .utileAccordion__titleText{
  color:#1d4ed8;
}
.utileAccordion__titleBtn:focus-visible{
  outline:2px solid rgba(37,99,235,0.45);
  outline-offset:4px;
  border-radius:10px;
}
.utileAccordion__titleText{
  font-size:18px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:-0.02em;
  color:#0f172a;
  word-break:break-word;
}
.utileAccordion__toggle{
  flex:0 0 30px;
  width:30px;
  height:30px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(241,245,249,0.98), rgba(226,232,240,0.92));
  color:#2563eb;
  font-size:0;
  font-weight:900;
  line-height:1;
  border:1px solid rgba(148,163,184,0.18);
  box-shadow:
    0 6px 14px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.92);
  transition:transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
}
.utileAccordion__toggle svg{
  width:14px;
  height:14px;
  fill:currentColor;
}
.utileAccordion.isExpanded .utileAccordion__toggle{
  transform:rotate(180deg);
  background:linear-gradient(180deg, rgba(219,234,254,0.9), rgba(191,219,254,0.86));
  border-color:rgba(59,130,246,0.24);
  color:#1d4ed8;
}
.utileAccordion__chips{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.utileAccordion__chips .chip{
  border-radius:999px;
  padding:6px 11px;
  font-size:11px;
  border-color:rgba(148,163,184,0.18);
  background:rgba(248,250,252,0.96);
}
.utileAccordion__actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.utileAccordion__actions .iconBtn{
  width:42px;
  height:42px;
  min-height:42px;
  border-radius:14px;
  box-shadow:
    0 8px 18px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.92);
}
.utileAccordion__actions .ghostBtn.iconBtn{
  border-color:rgba(148,163,184,0.22);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.92));
  color:#0f172a;
}
.utileAccordion__actions .ghostBtn.iconBtn:hover{
  background:linear-gradient(180deg, rgba(255,255,255,1), rgba(241,245,249,0.98));
}
.utileAccordion__actions .primaryBtn.iconBtn{
  border-color:rgba(59,130,246,0.18);
  background:linear-gradient(180deg, rgba(239,246,255,0.98), rgba(219,234,254,0.88));
  color:#2563eb;
}
.utileAccordion__actions .primaryBtn.iconBtn:hover{
  background:linear-gradient(180deg, rgba(219,234,254,0.95), rgba(191,219,254,0.9));
}
.utileAccordion__actions .dangerBtn.iconBtn{
  border-color:rgba(248,113,113,0.28);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(254,242,242,0.92));
  color:#dc2626;
}
.utileAccordion__actions .dangerBtn.iconBtn:hover{
  background:linear-gradient(180deg, rgba(254,242,242,0.98), rgba(254,226,226,0.92));
}
.utileAccordion__body{
  margin-top:12px;
  padding-top:14px;
  border-top:1px solid rgba(148,163,184,0.16);
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(240px,.95fr);
  gap:16px;
}
.utileAccordion__content{
  font-size:14px;
  line-height:1.7;
  color:#0f172a;
  white-space:pre-wrap;
  word-break:break-word;
  padding:2px 0;
  max-width:78ch;
}
.utileAccordion__content a{
  color:#1d4ed8;
  text-decoration:underline;
}
.utileAccordion__meta{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px 14px;
  border:1px solid rgba(148,163,184,0.16);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(248,250,252,0.92), rgba(241,245,249,0.84));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.92);
}
.utileAccordion__metaRow{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.utileAccordion__metaLabel{
  font-size:10px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#64748b;
}
.utileAccordion__metaValue{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.utileAccordion__metaText{
  font-size:12px;
  font-weight:600;
  color:#334155;
}

@media (max-width: 860px){
  .utileAccordion__top{
    grid-template-columns:1fr;
    align-items:start;
  }
  .utileAccordion__actions{
    width:100%;
    justify-content:flex-start;
  }
  .utileAccordion__body{
    grid-template-columns:1fr;
  }
}

/* Utile premium list + detail view */
.utileCompactHead{
  align-items:flex-end;
  justify-content:space-between;
  gap:8px;
}
.utileCompactHead__titleWrap{
  display:flex;
  flex-direction:column;
  gap:3px;
}
.utileCompactHead__subtitle{
  font-size:12px;
  line-height:1.35;
}
.utileCompactHead__actions{
  display:flex;
  align-items:center;
  gap:7px;
  flex-wrap:wrap;
}
.utileCompactHead__actions.isDetail{
  align-items:flex-start;
}
.utileCompactHead__actions .primaryBtn,
.utileCompactHead__actions .ghostBtn{
  min-height:38px;
  border-radius:12px;
  padding:0 14px;
  font-weight:800;
}
.utileCompactHead__actions.isDetail .utileUtilityBtn{
  min-height:36px;
  border-radius:999px;
  padding:0 15px;
  font-size:13px;
  font-weight:700;
  color:#334155;
  border-color:rgba(148,163,184,0.16);
  background:rgba(248,250,252,0.72);
  box-shadow:none;
}
.utileCompactHead__actions.isDetail .utileUtilityBtn:hover{
  background:rgba(241,245,249,0.92);
  border-color:rgba(148,163,184,0.22);
}
.utileList{
  display:flex;
  flex-direction:column;
  gap:7px;
}
.utileListCard{
  border:1px solid rgba(148,163,184,0.14);
  border-radius:15px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(249,251,253,0.96));
  box-shadow:
    0 4px 10px rgba(15,23,42,0.032),
    inset 0 1px 0 rgba(255,255,255,0.88);
  padding:10px 12px;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.utileListCard:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.16);
  box-shadow:
    0 8px 14px rgba(15,23,42,0.04),
    inset 0 1px 0 rgba(255,255,255,0.92);
}
.utileListCard.isPinned{
  border-color:rgba(59,130,246,0.18);
}
.utileListCard__head{
  display:block;
}
.utileListCard__main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:0;
}
button.utileListCard__titleBtn,
.utileListCard__titleBtn{
  appearance:none;
  -webkit-appearance:none;
  width:100%;
  margin:0;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color:inherit;
  text-align:left;
  cursor:pointer;
  min-width:0;
}
.utileListCard__titleBtn:focus-visible{
  outline:2px solid rgba(37,99,235,0.42);
  outline-offset:4px;
  border-radius:10px;
}
.utileListCard__titleText{
  flex:1 1 auto;
  min-width:0;
  font-size:15px;
  line-height:1.12;
  font-weight:900;
  letter-spacing:-0.02em;
  color:#0f172a;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.utileListCard__titleBtn:hover .utileListCard__titleText{
  color:#1e40af;
}
.utileListCard__inlineMeta{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:4px;
  min-width:0;
}
.utileListCard__inlineMeta .chip{
  border-radius:999px;
  padding:3px 8px;
  font-size:10px;
  border-color:rgba(148,163,184,0.14);
  background:rgba(249,251,253,0.92);
  max-width:120px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.utileDetailPage{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.utileDetailPage__hero{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  padding:4px 0 14px;
  border-bottom:1px solid rgba(148,163,184,0.14);
}
.utileDetailPage__heroLeft{
  flex:1 1 720px;
  min-width:0;
  max-width:min(100%, 980px);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.utileDetailPage__crumb{
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#94a3b8;
}
.utileDetailPage__title{
  margin:0;
  font-size:clamp(28px, 3.4vw, 40px);
  line-height:.96;
  letter-spacing:-0.045em;
  font-weight:900;
  color:#0f172a;
  max-width:30ch;
  text-wrap:balance;
}
.utileDetailPage__subtitle{
  margin:0;
  font-size:13px;
  line-height:1.5;
  color:#64748b;
  max-width:54ch;
}
.utileDetailPage__heroMeta{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  padding-top:2px;
}
.utileDetailPage__heroMeta .chip{
  border-radius:999px;
  padding:5px 10px;
  font-size:10px;
  border-color:rgba(148,163,184,0.14);
  background:rgba(248,250,252,0.92);
}
.utileDetailPage__heroStamp{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.14);
  background:rgba(248,250,252,0.78);
  color:#64748b;
  font-size:10px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.utileDetailPage__actionsWrap{
  flex:0 0 auto;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
  padding-top:4px;
}
.utileDetailPage__actionsLabel{
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#94a3b8;
  padding-right:2px;
}
.utileDetailPage__actions{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.utileDetailPage__actions .utileActionIcon{
  width:34px;
  height:34px;
  min-height:34px;
  border-radius:11px;
  border-color:rgba(148,163,184,0.16);
  background:rgba(248,250,252,0.78);
  color:#475569;
  box-shadow:none;
  opacity:.88;
}
.utileDetailPage__actions .utileActionIcon:hover{
  background:rgba(241,245,249,0.98);
  border-color:rgba(148,163,184,0.24);
  color:#0f172a;
  opacity:1;
}
.utileDetailPage__actions .utileActionIcon svg{
  width:15px;
  height:15px;
}
.utileDetailPage__actions .primaryBtn.utileActionIcon{
  background:rgba(59,130,246,0.10);
  border-color:rgba(59,130,246,0.18);
  color:#2563eb;
}
.utileDetailPage__actions .dangerBtn.utileActionIcon{
  background:rgba(254,242,242,0.86);
  border-color:rgba(248,113,113,0.26);
  color:#dc2626;
}
.utileDetailPage__body{
  display:grid;
  grid-template-columns:minmax(0, 1.75fr) minmax(250px, .82fr);
  gap:16px;
}
.utileDetailPage__contentCard,
.utileDetailPage__metaCard{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.99), rgba(249,251,253,0.97));
  box-shadow:
    0 10px 24px rgba(15,23,42,0.045),
    inset 0 1px 0 rgba(255,255,255,0.88);
}
.utileDetailPage__contentCard{
  padding:20px 22px;
}
.utileDetailPage__sectionLabel,
.utileDetailPage__metaLabel{
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#94a3b8;
}
.utileDetailPage__content{
  margin-top:14px;
  font-size:15px;
  line-height:1.9;
  color:#0f172a;
  white-space:pre-wrap;
  word-break:break-word;
  max-width:72ch;
}
.utileDetailPage__content a{
  color:#1d4ed8;
  text-decoration:underline;
  text-underline-offset:3px;
}
.utileDetailPage__metaCard{
  position:sticky;
  top:14px;
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:0;
}
.utileDetailPage__metaRow{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:12px 0;
}
.utileDetailPage__metaRow + .utileDetailPage__metaRow{
  border-top:1px solid rgba(148,163,184,0.12);
}
.utileDetailPage__metaValue{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.utileDetailPage__metaText{
  font-size:13px;
  font-weight:700;
  color:#334155;
}

@media (max-width: 860px){
  .utileCompactHead{
    align-items:flex-start;
  }
  .utileCompactHead__actions{
    width:100%;
    justify-content:flex-start;
  }
  .utileCompactHead__actions.isDetail{
    justify-content:flex-end;
  }
  .utileListCard__titleBtn{
    gap:8px;
  }
  .utileDetailPage__hero{
    flex-direction:column;
    padding-bottom:12px;
  }
  .utileDetailPage__heroLeft{
    flex-basis:auto;
    max-width:100%;
  }
  .utileDetailPage__actionsWrap{
    align-items:flex-start;
    padding-top:0;
  }
  .utileDetailPage__actions{
    justify-content:flex-start;
  }
  .utileDetailPage__body{
    grid-template-columns:1fr;
  }
  .utileDetailPage__metaCard{
    position:static;
  }
}

@media (max-width: 520px){
  .utileListCard{
    padding:9px 10px;
    border-radius:14px;
  }
  .utileListCard__titleText{
    font-size:13px;
  }
  .utileListCard__inlineMeta .chip{
    max-width:88px;
    padding:3px 7px;
  }
  .utileDetailPage__title{
    font-size:24px;
    max-width:none;
  }
  .utileDetailPage__contentCard,
  .utileDetailPage__metaCard{
    border-radius:15px;
  }
  .utileDetailPage__contentCard{
    padding:16px;
  }
  .utileDetailPage__content{
    font-size:14px;
    line-height:1.8;
  }
}

/* =========================
   Hobby: premium compact toolbar refresh
   ========================= */
.hobbyToolbar{
  position: relative;
  top: 0;
  z-index: 8;
  margin-top: 10px;
  padding: 8px 10px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,0.08);
  background:
    radial-gradient(120% 160% at 0% 0%, rgba(59,130,246,0.07) 0%, rgba(255,255,255,0.86) 42%),
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,250,252,0.90));
  box-shadow: 0 8px 24px rgba(15,23,42,0.08);
  backdrop-filter: blur(12px);
}
.hobbyToolbar__row{display:flex; align-items:center; justify-content:space-between; gap:6px; flex-wrap:wrap}
.hobbyToolbar__row--top{
  display:grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items:center;
  gap:6px;
}
.hobbyToolbar__topMain{
  min-width:0;
  display:grid;
  grid-template-columns: auto minmax(260px, 1fr);
  align-items:center;
  gap:6px;
}
.hobbyToolbar__row--bottom{
  display:grid;
  grid-template-columns: minmax(340px, 1fr) auto;
  align-items:center;
  gap:6px;
}
.hobbyToolbar__search{min-width:200px}
.hobbyToolbar__search--top{min-width:220px}
.hobbyToolbar__controlsGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(140px, 1fr));
  gap:6px;
  width:100%;
}
.hobbyToolbar__actions{display:flex; gap:6px; flex-wrap:wrap; align-items:center; justify-content:flex-end}
.hobbyToolbar__bottomRight{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.hobbyDisplayControls{display:flex; align-items:center; gap:6px; flex-wrap:wrap; justify-content:flex-end}
.hobbyDisplayControls .chip--db{font-weight:700}
.hobbyToolbar .input{
  height:44px;
  border-radius:13px;
}
.hobbyToolbar .primaryBtn,
.hobbyToolbar .ghostBtn{
  height:42px;
  border-radius:13px;
}
.hobbyToolbar .subTabs .segBtn{
  height:40px;
  border-radius:12px;
  min-width: auto;
  padding: 0 16px;
}
.hobbyToolbar .hobbyStats{
  font-size: 13px;
  letter-spacing: .01em;
}
.hobbyToolbar .subTabs{
  flex-wrap:nowrap;
  overflow-x:auto;
  overflow-y:hidden;
  padding-bottom:2px;
  scrollbar-width:thin;
}

.hobbyAddBtn{
  font-weight:800;
  padding:0 14px;
}

.segGroup{
  display:inline-flex;
  gap:6px;
  padding:3px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,0.12);
  background: rgba(255,255,255,0.78);
}
.segBtn{
  padding:7px 12px;
  border-radius:9px;
  border:1px solid transparent;
  background: transparent;
  cursor:pointer;
  line-height:1;
  min-width:64px;
  font-weight:600;
}
.segBtn:hover{background: rgba(15,23,42,0.05)}
.segBtn.isActive{
  background: rgba(59,130,246,0.16);
  border-color: rgba(59,130,246,0.30);
  box-shadow: none;
}

.hobbyToggleBtn{
  padding:7px 10px;
  border-radius:10px;
  font-size:13px;
  white-space:nowrap;
}
.hobbyToggleBtn.isActive{
  background: rgba(59,130,246,0.12);
  border-color: rgba(59,130,246,0.35);
}

.hobbySelectBtn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 11px;
  font-size:13px;
  font-weight:700;
  white-space:nowrap;
}
.hobbySelectBtn__icon{
  width:16px;
  height:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.hobbySelectBtn__icon svg{width:16px; height:16px; display:block; fill:currentColor}
.hobbySelectBtn.isActive{
  background: rgba(59,130,246,0.12);
  border-color: rgba(59,130,246,0.35);
}

.hobbyList .hobbyCard__actions{
  min-width: 126px;
  flex: 0 0 126px;
  padding: 8px;
  gap: 6px;
  border-left: 1px solid rgba(15,23,42,0.06);
  background: linear-gradient(180deg, rgba(255,255,255,0.42), rgba(248,250,252,0.20));
  box-shadow: none;
  justify-content: center;
  align-items: center;
}
.hobbyCard__actions .iconBtn{width:32px; height:32px; border-radius:10px}
.hobbyWrap.isCompact .hobbyCard__actions .iconBtn{width:30px; height:30px}
.hobbyList .hobbyCard{
  border-radius: 16px;
}
.hobbyList .hobbyCard__media{
  width: 86px;
}
.hobbyList .hobbyCard__media,
.hobbyList .hobbyCard__img,
.hobbyList .hobbyCard__ph{
  height: 120px;
}
.hobbyList .hobbyCard__body{
  padding: 10px 12px;
  gap: 5px;
}
.hobbyList .hobbyCard__title{
  font-size: 17px;
  line-height: 1.18;
}
.hobbyList .hobbyCard__chips .chip{
  padding: 5px 9px;
  font-size: 11px;
}
.hobbyList .hobbyCard .muted{
  font-size: 13px;
}
.hobbyCard.hasCover::before{
  opacity: 0.13;
}

/* Audiobooks: extra compact premium list profile */
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList{
  gap: 7px;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard{
  border-radius: 14px;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__media{
  width: 64px;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__media,
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__img,
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__ph{
  height: 92px;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__body{
  padding: 9px 10px;
  gap: 4px;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__title{
  font-size: 18px;
  -webkit-line-clamp: 1;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__chips{
  margin-top: 4px;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__actions{
  min-width: 112px;
  flex: 0 0 112px;
  padding: 7px;
  gap: 5px;
}
.hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__actions .iconBtn{
  width: 30px;
  height: 30px;
}
.hobbyWrap--audiobooks .hobbyCard__ph{
  gap: 5px;
  background: linear-gradient(180deg, rgba(59,130,246,0.06), rgba(255,255,255,0.78));
}
.hobbyWrap--audiobooks .hobbyCard__phIcon{
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .04em;
}
.hobbyWrap--audiobooks .hobbyCard__phLetter{
  width: 30px;
  height: 30px;
  border-radius: 9px;
  font-size: 17px;
}

/* Films: compact premium list profile (poster-focused) */
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList{
  gap: 8px;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard{
  border-radius: 15px;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__media{
  width: 78px;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__media,
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__img,
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__ph{
  height: 110px;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__body{
  padding: 9px 11px;
  gap: 4px;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__title{
  font-size: 18px;
  -webkit-line-clamp: 1;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__chips{
  margin-top: 4px;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__actions{
  min-width: 118px;
  flex: 0 0 118px;
  padding: 7px;
  gap: 5px;
}
.hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__actions .iconBtn{
  width: 30px;
  height: 30px;
}
.hobbyWrap--films .hobbyCard.hasCover::before{
  opacity: 0.16;
}
.hobbyWrap--films .hobbyCard__progressBar{
  background: linear-gradient(90deg, rgba(59,130,246,0.70), rgba(37,99,235,0.78));
}
.hobbyWrap--films .hobbyCard__ph{
  background: linear-gradient(180deg, rgba(15,23,42,0.07), rgba(255,255,255,0.80));
}
.hobbyWrap--films .hobbyCard__phIcon{
  font-size: 14px;
}
.hobbyWrap--films .hobbyCard__phLetter{
  width: 32px;
  height: 32px;
  border-radius: 10px;
  font-size: 16px;
}

@media (max-width: 1180px){
  .hobbyToolbar__topMain{grid-template-columns: 1fr;}
  .hobbyToolbar__row--top{grid-template-columns: 1fr;}
  .hobbyToolbar__actions{justify-content:flex-start}
  .hobbyToolbar__row--bottom{grid-template-columns: 1fr;}
  .hobbyToolbar__controlsGrid{grid-template-columns: repeat(3, minmax(130px, 1fr));}
  .hobbyToolbar__bottomRight{justify-content:flex-start}
  .hobbyDisplayControls{justify-content:flex-start}
}
@media (max-width: 860px){
  .hobbyToolbar{padding:8px}
  .hobbyToolbar__controlsGrid{grid-template-columns: 1fr;}
  .hobbyToolbar__bottomRight{gap:8px}
  .hobbyList .hobbyCard__actions{flex:0 0 118px; min-width:118px}
  .hobbyWrap--audiobooks.hobbyWrap.isCompact .hobbyList .hobbyCard__actions{
    flex:0 0 104px;
    min-width:104px;
  }
  .hobbyWrap--films.hobbyWrap.isCompact .hobbyList .hobbyCard__actions{
    flex:0 0 108px;
    min-width:108px;
  }
}
@media (max-width: 640px){
  .hobbyList .hobbyCard__actions{
    flex: 0 0 auto;
    min-width: 0;
    width: 100%;
    box-shadow: none;
    border-top: 1px solid rgba(15,23,42,0.06);
    border-left: 0;
    background: transparent;
  }
}

/* === Credit === */
.panel.creditPage{
  border:1px solid rgba(59,130,246,0.16);
  box-shadow:0 18px 36px rgba(15,23,42,0.10);
  background:
    radial-gradient(720px 220px at 8% 0%, rgba(59,130,246,0.12), transparent 62%),
    radial-gradient(720px 220px at 92% 0%, rgba(16,185,129,0.09), transparent 62%),
    rgba(255,255,255,0.86);
}
.creditPage{
  --credit-shadow:0 18px 36px rgba(15,23,42,0.08);
  --credit-shadow-soft:0 10px 24px rgba(15,23,42,0.05);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.creditHead{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:end;
  gap:12px;
  padding:8px 11px 10px;
  border:1px solid rgba(255,255,255,0.72);
  border-radius:22px;
  background:
    radial-gradient(300px 120px at 0% 0%, rgba(59,130,246,0.10), transparent 68%),
    radial-gradient(260px 120px at 100% 0%, rgba(16,185,129,0.08), transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,0.78), rgba(255,255,255,0.56));
  box-shadow:var(--credit-shadow-soft);
}
.creditHead__right{
  display:flex;
  gap:7px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  align-self:center;
}
.creditHead__left{
  min-width:0;
  display:block;
}
.creditHead__left .panel__title{
  margin:0;
  font-size:clamp(34px, 3vw, 48px);
  line-height:0.96;
  letter-spacing:-0.04em;
}
.creditToolbar{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  align-items:center;
}
.creditToolbar--main{
  padding:4px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.82), rgba(255,255,255,0.56));
  border:1px solid rgba(255,255,255,0.72);
  box-shadow:var(--credit-shadow-soft);
}
.creditToolbar--secondary{
  padding:4px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.72), rgba(255,255,255,0.40));
  border:1px solid rgba(255,255,255,0.64);
  box-shadow:var(--credit-shadow-soft);
}
.creditNotice{
  border:1px solid rgba(59,130,246,0.24);
  border-radius:13px;
  padding:8px 10px;
  font-size:13px;
  box-shadow:0 10px 20px rgba(15,23,42,0.06);
  background:rgba(59,130,246,0.08);
}
.creditNotice.isWarn{background:rgba(239,68,68,0.10); border-color:rgba(239,68,68,0.24)}
.creditNotice.isOk{background:rgba(34,197,94,0.10); border-color:rgba(34,197,94,0.24)}
.creditNotice.isHidden{display:none}
.creditStatus{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11px;
  font-weight:700;
  color:#42546f;
  border:1px solid rgba(255,255,255,0.72);
  border-radius:999px;
  padding:4px 9px;
  background:linear-gradient(180deg, rgba(255,255,255,0.86), rgba(248,250,252,0.78));
  box-shadow:var(--credit-shadow-soft);
  align-self:flex-start;
}
.creditStatus:before{
  content:'';
  width:7px;
  height:7px;
  border-radius:999px;
  background:linear-gradient(180deg, #3b82f6, #18b77a);
  box-shadow:0 0 0 4px rgba(59,130,246,0.10);
}

.creditStats{display:grid; grid-template-columns:repeat(4, minmax(120px, 1fr)) minmax(250px, 1.45fr); gap:8px; align-items:stretch}
.creditStat{
  border:1px solid rgba(255,255,255,0.84);
  border-radius:20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(241,245,249,0.90));
  box-shadow:
    0 14px 28px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.80);
  min-height:80px;
  padding:10px 12px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  position:relative;
  overflow:hidden;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  gap:7px;
}
.creditStat:before{
  content:'';
  position:absolute;
  inset:0 0 auto 0;
  height:3px;
  background:linear-gradient(90deg, rgba(59,130,246,0.74), rgba(16,185,129,0.42));
}
.creditStat--total{
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,247,252,0.92));
}
.creditStat--active{
  background:
    radial-gradient(140px 70px at 100% 0%, rgba(59,130,246,0.12), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(241,246,253,0.92));
}
.creditStat--closing{
  background:
    radial-gradient(140px 70px at 100% 0%, rgba(245,158,11,0.12), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(252,248,241,0.92));
}
.creditStat--closed{
  background:
    radial-gradient(140px 70px at 100% 0%, rgba(16,185,129,0.12), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(242,250,247,0.92));
}
.creditStat__label{
  font-size:11px;
  color:#5e6f89;
  letter-spacing:0.08px;
  text-transform:uppercase;
  font-weight:800;
}
.creditStat__value{
  font-size:clamp(20px, 1.65vw, 26px);
  font-weight:900;
  margin-top:0;
  line-height:1;
  letter-spacing:-0.02em;
}
.creditStat:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.20);
  box-shadow:
    0 18px 30px rgba(15,23,42,0.08),
    inset 0 1px 0 rgba(255,255,255,0.84);
}
.creditStat--balance{
  align-items:center;
  text-align:center;
  justify-content:center;
  padding:10px 16px;
  background:
    radial-gradient(180px 90px at 100% 0%, rgba(59,130,246,0.12), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(241,247,253,0.94));
}
.creditStat--balance .creditStat__label{
  font-size:11.5px;
}
.creditStat--balance .creditStat__value{
  font-size:clamp(28px, 2.15vw, 36px);
  letter-spacing:-0.04em;
}

.creditSplit{
  display:grid;
  grid-template-columns:minmax(300px, 0.90fr) minmax(0, 1.36fr);
  gap:7px;
  align-items:start;
}
.creditSplit.creditSplit--stack{
  grid-template-columns:1fr;
}
.creditSplit.creditSplit--detailOnly{
  grid-template-columns:1fr;
}
.creditLoansGrid{
  display:flex;
  flex-direction:column;
  gap:7px;
  border:1px solid rgba(255,255,255,0.68);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(248,250,252,0.72), rgba(244,248,252,0.56));
  padding:7px;
  box-shadow:var(--credit-shadow-soft, 0 10px 24px rgba(15,23,42,0.05));
}
.creditLoansGrid.isHidden{
  display:none;
}
.creditLoansGrid.creditLoansGrid--stack{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(340px, 1fr));
  gap:8px;
  border-radius:14px;
}
.creditLoanCard{
  border:1px solid rgba(255,255,255,0.88);
  border-radius:20px;
  background:
    radial-gradient(180px 80px at 100% 0%, rgba(59,130,246,0.10), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(243,247,252,0.94));
  box-shadow:
    0 18px 30px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.84);
  padding:12px 12px 11px;
  cursor:pointer;
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease;
  position:relative;
  overflow:hidden;
}
.creditLoanCard:before{
  content:'';
  position:absolute;
  inset:0 auto 0 0;
  width:3px;
  background:linear-gradient(180deg, rgba(59,130,246,0.85), rgba(16,185,129,0.65));
  opacity:0.55;
}
.creditLoanCard:hover{
  border-color:rgba(59,130,246,0.28);
  box-shadow:0 22px 34px rgba(15,23,42,0.09);
  transform:translateY(-2px);
}
.creditLoanCard.isActive{
  border-color:rgba(59,130,246,0.34);
  background:
    radial-gradient(260px 90px at 0% 0%, rgba(59,130,246,0.16), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,0.995), rgba(240,246,253,0.96));
}
.creditLoanCard.isActive:before{opacity:1}
.creditLoanCard__top{display:flex; justify-content:space-between; align-items:flex-start; gap:10px}
.creditLoanCard__head{min-width:0}
.creditLoanCard__name{
  font-weight:800;
  font-size:18px;
  line-height:1.08;
}
.creditLoanCard__sub{
  margin-top:4px;
  font-size:12px;
  color:#617189;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.creditLoanCard__balance{
  margin-top:12px;
  padding:12px 13px;
  border:1px solid rgba(148,163,184,0.20);
  border-radius:16px;
  background:rgba(255,255,255,0.78);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.85);
}
.creditLoanCard__balanceLabel{
  font-size:11px;
  font-weight:700;
  letter-spacing:0.18px;
  color:#6c7b92;
}
.creditLoanCard__balanceValue{
  margin-top:4px;
  font-size:clamp(24px, 2vw, 30px);
  line-height:1;
  font-weight:900;
  letter-spacing:-0.03em;
  color:#0f172a;
}
.creditLoanCard__facts{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  margin-top:10px;
}
.creditMiniFact{
  border:1px solid rgba(148,163,184,0.20);
  border-radius:14px;
  padding:9px 10px;
  background:rgba(248,250,252,0.86);
}
.creditMiniFact__label{
  font-size:10px;
  font-weight:700;
  letter-spacing:0.2px;
  text-transform:uppercase;
  color:#708099;
}
.creditMiniFact__value{
  margin-top:4px;
  font-size:13px;
  font-weight:800;
  line-height:1.15;
  color:#10233f;
}
.creditLoanCard__foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  margin-top:12px;
}
.creditLoanCard__eta{
  min-width:0;
}
.creditLoanCard__etaLabel{
  font-size:11px;
  color:#6a7890;
}
.creditLoanCard__etaValue{
  margin-top:2px;
  font-size:15px;
  font-weight:800;
  color:#0f172a;
}

.creditStatusChip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,0.18);
  font-size:11px;
  font-weight:700;
  white-space:nowrap;
}
.creditStatusChip--active{background:rgba(59,130,246,0.10); border-color:rgba(59,130,246,0.28); color:#1f3d8a}
.creditStatusChip--closing{background:rgba(245,158,11,0.12); border-color:rgba(245,158,11,0.30); color:#7c3e06}
.creditStatusChip--closed{background:rgba(16,185,129,0.12); border-color:rgba(16,185,129,0.30); color:#065f46}

.creditDetailWrap{display:flex; flex-direction:column; gap:6px}
.creditDetailHead{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  flex-wrap:wrap;
  border:1px solid rgba(255,255,255,0.84);
  border-radius:18px;
  background:rgba(255,255,255,0.84);
  padding:9px 10px;
  box-shadow:var(--credit-shadow, 0 18px 36px rgba(15,23,42,0.08));
}
.creditDetailHead__right{display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.creditDetailHead__meta{
  margin:4px 0 0;
  font-size:12px;
  color:#5f6f86;
}
.creditHero{
  border-radius:22px;
  padding:10px 12px;
  background:
    radial-gradient(420px 180px at 0% 0%, rgba(59,130,246,0.14), transparent 72%),
    radial-gradient(360px 180px at 100% 0%, rgba(16,185,129,0.10), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,0.995), rgba(244,248,252,0.96));
  box-shadow:
    0 20px 36px rgba(15,23,42,0.07),
    inset 0 1px 0 rgba(255,255,255,0.88);
  transition:box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.creditHero:hover{
  transform:translateY(-1px);
  box-shadow:
    0 26px 40px rgba(15,23,42,0.10),
    inset 0 1px 0 rgba(255,255,255,0.90);
}
.creditHero__row{
  display:grid;
  grid-template-columns:minmax(440px, 1.15fr) minmax(340px, 0.96fr) 136px;
  gap:7px;
  align-items:stretch;
  width:100%;
}
.creditHero__main{
  min-width:0;
  display:grid;
  grid-template-columns:minmax(180px, 0.58fr) minmax(260px, 1fr);
  align-items:center;
  gap:7px;
}
.creditHero__identity{
  min-width:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.creditHero__title{
  margin:0;
  font-size:clamp(20px, 1.55vw, 26px);
  line-height:1.02;
  letter-spacing:-0.03em;
}
.creditHero__meta{
  margin-top:5px;
  max-width:250px;
  font-size:11.5px;
  line-height:1.35;
  color:#61718a;
}
.creditHero__balanceInline{
  min-width:0;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,0.92);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.94), rgba(245,248,252,0.86));
  box-shadow:0 10px 18px rgba(15,23,42,0.04);
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.creditHero__balanceLabel{
  font-size:10.5px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.18px;
  color:#6c7b92;
}
.creditHero__balanceValue{
  margin-top:4px;
  font-size:clamp(24px, 1.95vw, 34px);
  font-weight:950;
  letter-spacing:-0.05em;
  line-height:0.92;
  color:#0f172a;
  white-space:nowrap;
}
.creditHero__metrics{
  display:grid;
  grid-template-columns:repeat(2, minmax(160px, 1fr));
  align-content:center;
  gap:7px;
}
.creditHero__metric{
  display:grid;
  align-content:center;
  justify-items:center;
  gap:4px;
  min-height:52px;
  min-width:0;
  padding:8px 9px;
  border:1px solid rgba(255,255,255,0.90);
  border-radius:13px;
  background:linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,250,252,0.84));
  box-shadow:0 8px 18px rgba(15,23,42,0.04);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  text-align:center;
}
.creditHero__metric:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.18);
  box-shadow:0 12px 22px rgba(15,23,42,0.06);
}
.creditHero__metricLabel{
  font-size:10.5px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.16px;
  color:#6d7c92;
}
.creditHero__metricValue{
  margin-top:0;
  font-size:14px;
  font-weight:900;
  line-height:1.08;
  color:#10233f;
  white-space:nowrap;
}
.creditHero__actions{
  display:flex;
  flex-direction:column;
  gap:7px;
  justify-content:center;
  align-items:center;
  align-self:stretch;
  min-width:0;
}
.creditHero__actions .creditStatusChip{
  align-self:center;
}
.creditHero__actions .ghostBtn{
  min-width:118px;
  justify-content:center;
}
.creditHero__progress{
  margin-top:5px;
  width:100%;
}
.creditHero__progressBar{
  height:7px;
  border-radius:999px;
  background:rgba(148,163,184,0.20);
  overflow:hidden;
}
.creditHero__progressBar span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, #3b82f6, #18b77a);
  box-shadow:0 6px 14px rgba(59,130,246,0.22);
}
.creditHero__progressMeta{
  margin-top:4px;
  font-size:10.5px;
  text-align:center;
}

.creditInlineFacts{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.creditInlineFacts__chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:0 12px;
  border:1px solid rgba(148,163,184,0.20);
  border-radius:999px;
  background:rgba(255,255,255,0.82);
  box-shadow:0 8px 18px rgba(15,23,42,0.04);
  color:#12253f;
}
.creditInlineFacts__chip strong{
  font-size:12.5px;
  font-weight:800;
}
.creditInlineFacts__label{
  font-size:11px;
  font-weight:700;
  color:#6c7b92;
}
.creditInlineFacts--soft{
  margin-bottom:8px;
}
.creditInlineFacts--soft .creditInlineFacts__chip{
  min-height:38px;
  background:rgba(248,250,252,0.88);
  box-shadow:none;
}
.creditMetaBar{
  display:flex;
  flex-wrap:nowrap;
  gap:6px;
  align-items:center;
  min-height:26px;
  padding:0 0 2px;
  color:#4f6078;
  font-size:11px;
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:thin;
}
.creditMetaBar__item{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  min-height:28px;
  padding:0 11px;
  white-space:nowrap;
  border:1px solid rgba(148,163,184,0.16);
  border-radius:999px;
  background:rgba(255,255,255,0.66);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.82);
  flex:0 0 auto;
  transition:transform .14s ease, border-color .14s ease, background-color .14s ease, box-shadow .14s ease;
  text-align:center;
}
.creditMetaBar__item:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.16);
  background:rgba(255,255,255,0.82);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.88),
    0 8px 16px rgba(15,23,42,0.04);
}
.creditMetaBar__label{
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.16px;
  color:#72819a;
}
.creditMetaBar__item strong{
  color:#0f172a;
  font-weight:900;
}
.creditMetaBar::-webkit-scrollbar{
  height:6px;
}
.creditMetaBar::-webkit-scrollbar-thumb{
  background:rgba(148,163,184,0.32);
  border-radius:999px;
}

.creditDoneBanner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:40px;
  padding:0 12px;
  border:1px solid rgba(16,185,129,0.32);
  background:rgba(16,185,129,0.10);
  border-radius:999px;
  flex:0 0 auto;
}
.creditDoneBanner__text{font-weight:600}

.creditSection{
  border:1px solid rgba(255,255,255,0.84);
  border-radius:18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.97), rgba(248,250,252,0.90));
  box-shadow:
    0 16px 28px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.82);
  padding:6px;
  transition:box-shadow .16s ease, border-color .16s ease;
}
.creditSection:hover{
  border-color:rgba(255,255,255,0.92);
  box-shadow:
    0 18px 30px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.84);
}
.creditSection__head{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:center;
  gap:7px;
  margin-bottom:4px;
  padding:0 0 5px;
  border-bottom:1px solid rgba(148,163,184,0.12);
}
.creditSection__head > :first-child{
  flex:0 1 auto;
  min-width:0;
}
.creditSection__head > :last-child{
  justify-self:end;
}
.creditSection__title{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-weight:900;
  font-size:15px;
  color:#10233f;
  letter-spacing:-0.02em;
  line-height:1.05;
}
.creditSection__title:before{
  content:'';
  width:8px;
  height:8px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(59,130,246,0.92), rgba(16,185,129,0.76));
  box-shadow:0 0 0 4px rgba(59,130,246,0.08);
}
.creditSection__hint{
  font-size:10.5px;
  color:#61728c;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:22px;
  padding:0 7px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.14);
  background:rgba(255,255,255,0.60);
  letter-spacing:0.01em;
  white-space:nowrap;
}

.creditInsightGrid{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:7px;
}
.creditInsightCard{
  display:grid;
  align-content:start;
  gap:4px;
  min-height:72px;
  padding:9px 10px;
  border:1px solid rgba(255,255,255,0.92);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(246,249,252,0.88));
  box-shadow:0 8px 18px rgba(15,23,42,0.04);
  text-align:center;
}
.creditInsightCard--blue{background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(240,246,253,0.92))}
.creditInsightCard--green{background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,250,247,0.92))}
.creditInsightCard--amber{background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(252,248,240,0.92))}
.creditInsightCard--violet{background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(245,244,253,0.92))}
.creditInsightCard__label{
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.16px;
  color:#6c7b92;
}
.creditInsightCard__value{
  font-size:clamp(15px, 1.15vw, 18px);
  font-weight:900;
  line-height:1.08;
  color:#10233f;
}
.creditInsightCard__meta{
  font-size:10.5px;
  line-height:1.3;
}

.creditTargetForm,
.creditScenarioSave{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) 200px;
  gap:7px;
  align-items:center;
}
.creditTargetGrid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:7px;
  margin-top:5px;
}
.creditTargetCard{
  display:grid;
  align-content:start;
  gap:4px;
  min-height:78px;
  padding:9px 10px;
  border:1px solid rgba(255,255,255,0.92);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(246,249,252,0.88));
  box-shadow:0 8px 18px rgba(15,23,42,0.04);
  text-align:center;
}
.creditTargetCard__label{
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.16px;
  color:#6c7b92;
}
.creditTargetCard__value{
  font-size:clamp(14px, 1.05vw, 17px);
  font-weight:900;
  line-height:1.12;
  color:#10233f;
}
.creditTargetCard__meta{
  font-size:10.5px;
  line-height:1.28;
}
.creditTargetCard .ghostBtn{
  min-height:30px;
  margin-top:2px;
  padding:0 10px;
  justify-self:center;
  font-size:12px;
}

.creditScenarioList{
  display:grid;
  gap:6px;
  margin-top:4px;
}
.creditScenarioCard{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:10px;
  align-items:center;
  padding:9px 10px;
  border:1px solid rgba(148,163,184,0.16);
  border-radius:15px;
  background:rgba(255,255,255,0.70);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.84);
}
.creditScenarioCard__title{
  font-size:13px;
  font-weight:900;
  color:#10233f;
}
.creditScenarioCard__meta{
  margin-top:3px;
  font-size:10.8px;
  line-height:1.35;
}
.creditScenarioCard__actions{
  display:flex;
  align-items:center;
  gap:6px;
}

.creditCalendarGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:7px;
}
.creditCalendarCard{
  display:grid;
  gap:5px;
  min-height:94px;
  padding:9px 10px;
  border:1px solid rgba(255,255,255,0.92);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(246,249,252,0.88));
  box-shadow:0 8px 18px rgba(15,23,42,0.04);
  text-align:center;
  align-content:start;
}
.creditCalendarCard__due{
  font-size:11px;
  font-weight:800;
  color:#6c7b92;
  text-transform:uppercase;
  letter-spacing:0.15px;
}
.creditCalendarCard__total{
  font-size:18px;
  font-weight:900;
  line-height:1.08;
  color:#10233f;
}
.creditCalendarCard__split{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:8px;
  font-size:10.8px;
  color:#5f6f86;
}
.creditCalendarCard__actions{
  margin-top:2px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:6px;
}
.creditCalendarCard__actions .ghostBtn{
  min-height:28px;
  padding:0 8px;
  font-size:11px;
  letter-spacing:0;
}

.creditSimForm{display:grid; grid-template-columns:minmax(240px, 1fr) minmax(240px, 1fr) 220px; gap:7px; align-items:center}
.creditPage .input.creditInput{
  min-height:38px;
  padding:8px 12px;
  border-radius:13px;
  border-color:rgba(255,255,255,0.88);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,248,252,0.90));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.84),
    0 6px 14px rgba(15,23,42,0.035);
  transition:border-color .14s ease, box-shadow .14s ease, transform .14s ease;
}
.creditPage .input.creditInput:focus{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.88),
    0 0 0 3px rgba(59,130,246,0.14),
    0 10px 22px rgba(59,130,246,0.10);
}
.creditPage .input.creditInput:hover{
  border-color:rgba(59,130,246,0.16);
}
.creditActionBtn--primary{
  min-width:178px;
  justify-content:center;
}
.creditSimCompact{
  display:grid;
  grid-template-columns:minmax(260px, 1.05fr) minmax(0, 1.95fr);
  align-items:stretch;
  gap:7px;
  margin-top:5px;
}
.creditSimCompact__cluster{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:7px;
}
.creditSimCompact__item{
  display:grid;
  align-content:center;
  justify-items:center;
  gap:4px;
  min-height:54px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,0.90);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.92), rgba(247,250,252,0.84));
  box-shadow:0 8px 18px rgba(15,23,42,0.04);
  transition:transform .14s ease, border-color .14s ease, box-shadow .14s ease;
  white-space:normal;
  text-align:center;
}
.creditSimCompact__item:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.18);
  box-shadow:0 12px 22px rgba(15,23,42,0.06);
}
.creditSimCompact__item--result{
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,245,249,0.90));
}
.creditSimCompact__label{
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.16px;
  color:#6c7b92;
}
.creditSimCompact__value{
  margin-top:0;
  font-size:clamp(14px, 1.1vw, 17px);
  font-weight:900;
  line-height:1.08;
  color:#10233f;
  white-space:nowrap;
}
.creditSimCompact__item--result .creditSimCompact__value{
  font-size:clamp(18px, 1.45vw, 22px);
}
.creditSimCompact__context{
  margin-top:3px;
  font-size:11px;
}
.creditSuggestionRail{
  margin-top:3px;
  display:flex;
  flex-wrap:wrap;
  gap:5px;
}
.creditSuggestionPill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:30px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.16);
  background:rgba(248,250,252,0.78);
  transition:transform .14s ease, border-color .14s ease, background-color .14s ease, box-shadow .14s ease;
}
.creditSuggestionPill:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.18);
  background:rgba(255,255,255,0.88);
  box-shadow:0 8px 16px rgba(15,23,42,0.04);
}
.creditSuggestionPill__title{
  font-size:11px;
  font-weight:800;
  color:#10233f;
}
.creditSuggestionPill__meta{
  font-size:10.5px;
}

.creditTableWrap{
  overflow:auto;
  border:1px solid rgba(255,255,255,0.84);
  border-radius:20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(247,250,252,0.92));
  box-shadow:
    0 12px 26px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.84);
}
.creditTableWrap--payments{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,252,0.94));
}
.creditTableWrap--future{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
}
.creditTableWrap--imports{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(247,250,252,0.92));
}
.creditTable{width:100%; border-collapse:collapse; min-width:620px; font-size:11.15px}
.creditTable--payments{font-variant-numeric:tabular-nums}
.creditTable th,
.creditTable td{padding:4px 7px; border-bottom:1px solid rgba(17,24,39,0.09); text-align:left; vertical-align:middle}
.creditTable th{padding:7px 7px; border-bottom:1px solid rgba(17,24,39,0.10); text-align:left; vertical-align:middle}
.creditTable th{
  font-size:9.8px;
  font-weight:900;
  color:#61728c;
  text-transform:uppercase;
  letter-spacing:0.24px;
  background:linear-gradient(180deg, rgba(242,246,250,0.98), rgba(233,239,246,0.94));
  position:sticky;
  top:0;
  z-index:1;
}
.creditTable tbody tr:nth-child(even) td{background:rgba(248,250,252,0.68)}
.creditTable tbody tr:hover td{background:rgba(59,130,246,0.045)}
.creditTable tr:last-child td{border-bottom:0}
.creditTable--payments tbody td:nth-child(3),
.creditTable--payments tbody td:nth-child(4),
.creditTable--payments tbody td:nth-child(5){
  font-weight:700;
  color:#10233f;
  text-align:center;
}
.creditTable--payments thead th:nth-child(3),
.creditTable--payments thead th:nth-child(4),
.creditTable--payments thead th:nth-child(5){
  text-align:center;
}
.creditTable--payments thead th:first-child,
.creditTable--payments thead th:nth-child(2),
.creditTable--payments thead th:nth-child(6),
.creditTable--payments tbody td:first-child,
.creditTable--payments tbody td:nth-child(2),
.creditTable--payments tbody td:nth-child(6){
  text-align:center;
}
.creditTable--payments tbody td:last-child{
  color:#5f6f86;
  font-size:10.8px;
  text-transform:uppercase;
  letter-spacing:0.06em;
}
.creditTable--payments .creditTableRow--interactive td:first-child{
  width:144px;
}
.creditTable--payments .creditTableRow--interactive td:first-child .creditTableToggle{
  width:100%;
  justify-content:center;
}
.creditTable--payments .creditTableRow--interactive td:first-child .creditTableToggle__text{
  font-weight:800;
  letter-spacing:0.01em;
}
.creditTable--payments .creditTableRow--interactive td:nth-child(2){
  width:104px;
}
.creditTable--payments .creditTableRow--interactive td:nth-child(6){
  text-align:center;
}
.creditTable--payments .creditTableRow--interactive td{
  background-image:linear-gradient(90deg, rgba(59,130,246,0.00), rgba(59,130,246,0.00));
}
.creditTable--payments .creditTableRow--interactive td:nth-child(6){
  max-width:128px;
}
.creditTable--payments .creditTableRow--interactive.isOpen td{
  box-shadow:inset 2px 0 0 rgba(59,130,246,0.36);
}
.creditTableRow--interactive{
  cursor:pointer;
  transition:background-color .16s ease, transform .12s ease;
}
.creditTableRow--interactive:hover td{
  background:rgba(59,130,246,0.06);
}
.creditTableRow--interactive.isOpen td{
  background:rgba(59,130,246,0.08);
}
.creditTableToggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0;
  min-height:24px;
  padding:0 4px;
  border:0;
  background:transparent;
  color:#10233f;
  font:inherit;
  cursor:pointer;
  border-radius:10px;
  transition:background-color .14s ease, color .14s ease;
}
.creditTableToggle__caret{
  display:none;
}
.creditTableToggle__caret.isOpen{
  display:none;
}
.creditTableToggle__text{
  font-weight:800;
  line-height:1.1;
  font-variant-numeric:tabular-nums;
  letter-spacing:-0.01em;
}
.creditTableRow--interactive:hover .creditTableToggle{
  background:rgba(59,130,246,0.06);
}
.creditTableRow--interactive.isOpen .creditTableToggle{
  background:rgba(59,130,246,0.10);
  color:#1f3d8a;
}
.creditTableDetailsRow td{
  padding:0;
  background:rgba(248,250,252,0.92);
}
.creditPaymentDetails{
  display:grid;
  grid-template-columns:minmax(220px, 0.9fr) minmax(0, 1.1fr);
  gap:6px;
  padding:6px 8px 8px;
  background:linear-gradient(180deg, rgba(248,250,252,0.92), rgba(243,247,252,0.88));
}
.creditTable--payments .creditPaymentDetails{
  background:
    radial-gradient(180px 90px at 0% 0%, rgba(59,130,246,0.08), transparent 72%),
    linear-gradient(180deg, rgba(248,250,252,0.94), rgba(243,247,252,0.90));
}
.creditPaymentDetails__summary,
.creditExpandedDetails__summary{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}
.creditExpandedDetails{
  display:grid;
  grid-template-columns:minmax(220px, 0.9fr) minmax(0, 1.1fr);
  gap:6px;
  padding:6px 8px 8px;
  background:linear-gradient(180deg, rgba(248,250,252,0.92), rgba(243,247,252,0.88));
}
.creditPaymentDetails__title{
  font-size:12.5px;
  font-weight:900;
  color:#12253f;
}
.creditTable--payments .creditPaymentDetails__title{
  font-size:13px;
}
.creditExpandedDetails__title{
  font-size:12.5px;
  font-weight:900;
  color:#12253f;
}
.creditPaymentDetails__meta{
  margin-top:0;
  font-size:11px;
  line-height:1.35;
}
.creditExpandedDetails__meta{
  margin-top:0;
  font-size:11px;
  line-height:1.35;
}
.creditPaymentDetails__bars{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.creditExpandedDetails__facts{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:6px;
}
.creditExpandedFact{
  border:1px solid rgba(255,255,255,0.88);
  border-radius:14px;
  padding:6px 8px;
  background:rgba(255,255,255,0.92);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.84);
}
.creditExpandedFact__label{
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.18px;
  color:#6b7b92;
}
.creditExpandedFact__value{
  margin-top:4px;
  font-size:12.5px;
  font-weight:900;
  line-height:1.14;
  color:#10233f;
}
.creditPaymentBar__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:2px;
  font-size:10.5px;
  color:#5f6f86;
}
.creditPaymentBar__head strong{
  color:#10233f;
  font-weight:800;
}
.creditTableWrap--future .creditTable tbody td:nth-child(3),
.creditTableWrap--future .creditTable tbody td:nth-child(4),
.creditTableWrap--future .creditTable tbody td:nth-child(5),
.creditTableWrap--future .creditTable thead th:nth-child(3),
.creditTableWrap--future .creditTable thead th:nth-child(4),
.creditTableWrap--future .creditTable thead th:nth-child(5),
.creditTableWrap--imports .creditTable tbody td:nth-child(3),
.creditTableWrap--imports .creditTable tbody td:nth-child(4),
.creditTableWrap--imports .creditTable tbody td:nth-child(5),
.creditTableWrap--imports .creditTable thead th:nth-child(3),
.creditTableWrap--imports .creditTable thead th:nth-child(4),
.creditTableWrap--imports .creditTable thead th:nth-child(5){
  text-align:center;
}
.creditTableWrap--future .creditTable thead th:first-child,
.creditTableWrap--future .creditTable thead th:nth-child(2),
.creditTableWrap--future .creditTable tbody td:first-child,
.creditTableWrap--future .creditTable tbody td:nth-child(2),
.creditTableWrap--imports .creditTable thead th:first-child,
.creditTableWrap--imports .creditTable thead th:nth-child(2),
.creditTableWrap--imports .creditTable tbody td:first-child,
.creditTableWrap--imports .creditTable tbody td:nth-child(2){
  text-align:center;
}
.creditTableWrap--future .creditTable .creditTableRow--interactive td:first-child .creditTableToggle,
.creditTableWrap--imports .creditTable .creditTableRow--interactive td:first-child .creditTableToggle{
  width:100%;
  justify-content:center;
}
.creditTableWrap--imports .creditTable tbody td:nth-child(2){
  font-weight:700;
  color:#10233f;
}
.creditPaymentBar__track{
  height:7px;
  border-radius:999px;
  background:rgba(148,163,184,0.18);
  overflow:hidden;
}
.creditPaymentBar__track span{
  display:block;
  height:100%;
  border-radius:999px;
}
.creditPaymentBar__track--principal span{
  background:linear-gradient(90deg, #18b77a, #35c895);
}
.creditPaymentBar__track--interest span{
  background:linear-gradient(90deg, #f59e0b, #f97316);
}
.creditPager{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-top:6px;
  padding:1px 2px 0;
}
.creditPager--payments{
  border-top:1px solid rgba(148,163,184,0.14);
  margin-top:0;
  padding:7px 8px 5px;
  background:linear-gradient(180deg, rgba(255,255,255,0.42), rgba(248,250,252,0.70));
}
.creditPager__actions{
  display:flex;
  align-items:center;
  gap:8px;
}

.creditTypeChip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:84px;
  min-height:24px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,0.12);
  font-size:10.5px;
  font-weight:900;
  letter-spacing:0.08px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.72),
    0 4px 10px rgba(15,23,42,0.04);
}
.creditTypeChip--monthly{
  background:linear-gradient(180deg, rgba(59,130,246,0.12), rgba(59,130,246,0.06));
  border-color:rgba(59,130,246,0.22);
  color:#1f3d8a;
}
.creditTypeChip--early{
  background:linear-gradient(180deg, rgba(16,185,129,0.12), rgba(16,185,129,0.06));
  border-color:rgba(16,185,129,0.22);
  color:#065f46;
}

.creditModal{
  display:flex;
  flex-direction:column;
  gap:9px;
  padding:2px 1px 0;
}
.creditModal__intro{
  padding:8px 10px;
  border-radius:14px;
  border:1px solid rgba(148,163,184,0.14);
  background:linear-gradient(180deg, rgba(248,250,252,0.88), rgba(243,247,252,0.78));
}
.creditModal .formLabel{
  font-size:12px;
  font-weight:700;
  color:#55637b;
}
.creditModal .input{
  min-height:42px;
}
.creditModal .grid2{
  gap:8px;
}
.creditModal .formRow,
.creditModal .grid2 > div{
  padding:8px 10px;
  border:1px solid rgba(148,163,184,0.12);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.94), rgba(247,250,252,0.88));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.84);
}
.creditModal .grid2{
  gap:8px;
}
.creditModal .formCtrl{
  margin-top:6px;
}
.creditModal .muted:last-child{
  padding:2px 4px 0;
}

.creditPage .ghostBtn,
.creditPage .primaryBtn,
.creditPage .dangerBtn{
  min-height:38px;
  padding:0 13px;
  border-radius:13px;
  font-size:14px;
  font-weight:900;
  letter-spacing:-0.01em;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease, background-color .14s ease;
}
.creditPage .ghostBtn{
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,247,252,0.92));
  border-color:rgba(255,255,255,0.88);
  box-shadow:0 8px 16px rgba(15,23,42,0.04);
}
.creditPage .primaryBtn{
  background:linear-gradient(180deg, #ffffff, #eef4ff);
  border-color:rgba(255,255,255,0.92);
  box-shadow:0 10px 22px rgba(59,130,246,0.16);
}
.creditPage .dangerBtn{
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(254,242,242,0.94));
  border-color:rgba(248,113,113,0.22);
  box-shadow:0 8px 18px rgba(239,68,68,0.08);
}
.creditPage .ghostBtn:hover,
.creditPage .primaryBtn:hover,
.creditPage .dangerBtn:hover{
  transform:translateY(-1px);
}
.creditPage .ghostBtn:hover{
  box-shadow:0 12px 20px rgba(15,23,42,0.055);
}
.creditPage .primaryBtn:hover{
  box-shadow:0 14px 24px rgba(59,130,246,0.20);
}
.creditPage .dangerBtn:hover{
  box-shadow:0 12px 22px rgba(239,68,68,0.11);
}
.creditPage .creditActionBtn{
  min-width:114px;
}
.creditPage .emptyState{
  border-radius:14px;
  border-color:rgba(148,163,184,0.30);
  background:rgba(255,255,255,0.84);
}

@media (min-width: 1281px){
  .creditLoansGrid:not(.creditLoansGrid--stack){
    position:sticky;
    top:10px;
  }
}

@media (max-width: 1280px){
  .creditSplit{grid-template-columns:1fr}
}
@media (max-width: 900px){
  .creditHead{
    grid-template-columns:1fr;
  }
  .creditStats{grid-template-columns:repeat(2, minmax(140px, 1fr))}
  .creditStat--balance{grid-column:1 / -1}
  .creditHero__row{grid-template-columns:1fr}
  .creditHero__main{display:grid; grid-template-columns:1fr}
  .creditHero__identity{min-width:0}
  .creditHero__balanceInline{min-width:0}
  .creditHero__metrics{display:grid; grid-template-columns:repeat(2, minmax(0, 1fr))}
  .creditHero__actions{
    flex-direction:row;
    justify-content:center;
    align-items:center;
  }
  .creditSection__head{
    grid-template-columns:1fr;
  }
  .creditSection__head > :last-child{
    justify-self:start;
  }
  .creditMetaBar{flex-wrap:wrap; overflow:visible; padding-bottom:1px}
  .creditInsightGrid,
  .creditTargetGrid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .creditTargetForm,
  .creditScenarioSave{grid-template-columns:1fr}
  .creditCalendarGrid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .creditCalendarCard__actions{grid-template-columns:1fr}
  .creditSimForm{grid-template-columns:1fr}
  .creditSimCompact{display:grid; grid-template-columns:1fr}
  .creditSimCompact__cluster{display:grid; grid-template-columns:repeat(3, minmax(0, 1fr))}
  .creditPaymentDetails,
  .creditExpandedDetails{grid-template-columns:1fr}
  .creditExpandedDetails__facts{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .creditLoanCard__facts{grid-template-columns:1fr}
  .creditLoansGrid.creditLoansGrid--stack{grid-template-columns:1fr}
  .creditHead{
    align-items:flex-start;
  }
}
@media (max-width: 720px){
  .panel.creditPage{
    box-shadow:0 14px 28px rgba(15,23,42,0.08);
  }
  .creditPage{
    gap:6px;
  }
  .creditStatus{
    font-size:10.5px;
    padding:4px 8px;
  }
  .creditLoanCard{
    padding:10px 10px 9px;
    border-radius:16px;
  }
  .creditLoanCard__name{
    font-size:16px;
  }
  .creditLoanCard__balance{
    margin-top:10px;
    padding:10px 11px;
  }
  .creditLoanCard__balanceValue{
    font-size:clamp(22px, 7vw, 28px);
  }
  .creditMiniFact{
    padding:8px 9px;
    border-radius:12px;
  }
  .creditHero{
    padding:10px;
    border-radius:18px;
  }
  .creditHero__row{
    gap:8px;
  }
  .creditHero__main{
    gap:8px;
  }
  .creditHero__title{
    font-size:clamp(22px, 8vw, 28px);
  }
  .creditHero__meta{
    font-size:12px;
  }
  .creditHero__balanceValue{
    font-size:clamp(28px, 9vw, 38px);
  }
  .creditHero__metrics{
    display:grid;
    grid-template-columns:1fr;
    gap:6px;
  }
  .creditHero__metric{
    display:grid;
    min-height:52px;
    border-radius:12px;
  }
  .creditHero__actions{
    flex-direction:column;
    align-items:stretch;
  }
  .creditInsightGrid,
  .creditTargetGrid,
  .creditCalendarGrid{
    grid-template-columns:1fr;
  }
  .creditSimCompact{
    display:grid;
    grid-template-columns:1fr;
  }
  .creditSimCompact__cluster{
    display:grid;
    grid-template-columns:1fr;
  }
  .creditSimCompact__item{
    display:grid;
    min-height:52px;
    border-radius:12px;
    white-space:normal;
  }
  .creditSection{
    border-radius:16px;
    padding:7px;
  }
  .creditSection__title{
    font-size:14px;
  }
  .creditTable{
    font-size:11.5px;
    min-width:560px;
  }
  .creditTable th,
  .creditTable td{
    padding:6px 7px;
  }
  .creditTableToggle{
    gap:5px;
  }
  .creditPaymentBar__head{
    font-size:11px;
  }
}
@media (max-width: 560px){
  .creditHead{
    gap:10px;
    padding:10px 11px;
  }
  .creditHead__left .panel__title{
    font-size:clamp(28px, 10vw, 36px);
  }
  .creditStats{grid-template-columns:1fr}
  .creditStat{
    min-height:74px;
    padding:9px;
  }
  .creditStat__value{
    font-size:clamp(18px, 7vw, 24px);
  }
  .creditStat--balance{
    padding:11px 12px;
  }
  .creditStat--balance .creditStat__value{
    font-size:clamp(26px, 9vw, 34px);
  }
  .creditMetaBar{
    gap:6px;
    font-size:11px;
  }
  .creditMetaBar__item{
    white-space:normal;
    flex:1 1 calc(50% - 6px);
    min-height:auto;
    padding:6px 9px;
    align-items:center;
    flex-direction:column;
    border-radius:12px;
    text-align:center;
  }
  .creditSuggestionPill,
  .creditSimCompact__context,
  .creditSection__hint{
    font-size:11px;
  }
  .creditScenarioCard{
    grid-template-columns:1fr;
  }
  .creditScenarioCard__actions{
    width:100%;
  }
  .creditInlineFacts{flex-direction:column}
  .creditInlineFacts__chip,
  .creditDoneBanner{
    width:100%;
    border-radius:16px;
    justify-content:space-between;
  }
  .creditInlineFacts__chip{
    min-height:36px;
    padding:0 11px;
  }
  .creditPager,
  .creditPager__actions{
    flex-direction:column;
    align-items:stretch;
  }
  .creditLoanCard__foot,
  .creditHero__actions{
    flex-direction:column;
    align-items:stretch;
  }
  .creditExpandedDetails__facts{grid-template-columns:1fr}
  .creditPaymentDetails,
  .creditExpandedDetails{
    padding:9px 10px 10px;
  }
  .creditSuggestion,
  .creditExpandedFact{
    border-radius:12px;
  }
  .creditPage .ghostBtn,
  .creditPage .primaryBtn,
  .creditPage .dangerBtn{width:100%}
  .creditHead__right{width:100%}
  .creditToolbar,
  .creditToolbar--main,
  .creditToolbar--secondary{
    width:100%;
  }
  .creditToolbar--main,
  .creditToolbar--secondary{
    padding:3px;
    border-radius:14px;
  }
}

/* === Taxe ANAF === */
.panel.taxeAnafPage{
  border:1px solid rgba(17,24,39,0.14);
  background:
    radial-gradient(780px 240px at 10% -5%, rgba(16,185,129,0.10), transparent 60%),
    radial-gradient(780px 240px at 90% 0%, rgba(59,130,246,0.10), transparent 60%),
    rgba(255,255,255,0.84);
}
.taxeAnafPage{display:flex; flex-direction:column; gap:12px}
.taxeAnafHead{display:flex; justify-content:space-between; align-items:flex-start; gap:12px; flex-wrap:wrap}
.taxeAnafHead__right{display:flex; gap:8px; flex-wrap:wrap}

.taxeAnafToolbar{
  display:grid;
  grid-template-columns:minmax(320px, 1fr) minmax(320px, 1fr);
  gap:10px;
  align-items:start;
}
.taxeAnafToolbar__left,
.taxeAnafToolbar__right{display:flex; gap:8px; flex-wrap:wrap; align-items:center}
.taxeAnafYear{min-width:110px; max-width:150px}
.taxeAnafPath{min-width:260px; flex:1 1 300px}
.taxeAnafWipe{margin:0}
.taxeAnafHints{display:flex; flex-direction:column; gap:4px}

.taxeAnafNotice{
  border:1px solid rgba(59,130,246,0.24);
  border-radius:12px;
  padding:8px 10px;
  font-size:13px;
  background:rgba(59,130,246,0.08);
}
.taxeAnafNotice.isWarn{background:rgba(239,68,68,0.10); border-color:rgba(239,68,68,0.24)}
.taxeAnafNotice.isOk{background:rgba(34,197,94,0.10); border-color:rgba(34,197,94,0.24)}
.taxeAnafNotice.isHidden{display:none}
.taxeAnafStatus{font-size:12px}

.taxeAnafSummary{display:grid; grid-template-columns:repeat(3, minmax(150px, 1fr)); gap:10px}
.taxeAnafCard{
  border:1px solid rgba(17,24,39,0.10);
  border-radius:14px;
  background:rgba(255,255,255,0.82);
  padding:10px;
}
.taxeAnafCard__label{font-size:12px; color:var(--muted)}
.taxeAnafCard__value{font-size:20px; font-weight:800; margin-top:4px; line-height:1.2}
.taxeAnafCard--total{
  border-color:rgba(16,185,129,0.30);
  background:rgba(16,185,129,0.10);
}

.taxeAnafSection{
  border:1px solid rgba(17,24,39,0.10);
  border-radius:14px;
  background:rgba(255,255,255,0.82);
  padding:12px;
}
.taxeAnafSection__head{display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px}
.taxeAnafSection__title{font-weight:800}

.taxeAnafTableWrap{overflow:auto; border:1px solid rgba(17,24,39,0.10); border-radius:12px; background:rgba(255,255,255,0.90)}
.taxeAnafTable{width:100%; border-collapse:collapse; min-width:860px; font-size:13px}
.taxeAnafTable th,
.taxeAnafTable td{padding:8px 9px; border-bottom:1px solid rgba(17,24,39,0.10); text-align:left; vertical-align:top}
.taxeAnafTable th{font-size:12px; color:var(--muted); font-weight:700; background:rgba(17,24,39,0.03)}
.taxeAnafTable tr:last-child td{border-bottom:0}

.taxeAnafImportList{display:flex; flex-direction:column; gap:8px}
.taxeAnafImportItem{border:1px solid rgba(17,24,39,0.10); border-radius:12px; background:rgba(255,255,255,0.90); padding:9px}
.taxeAnafImportItem__name{font-weight:700}

@media (max-width: 980px){
  .taxeAnafToolbar{grid-template-columns:1fr}
  .taxeAnafSummary{grid-template-columns:repeat(2, minmax(130px, 1fr))}
}
@media (max-width: 620px){
  .taxeAnafSummary{grid-template-columns:1fr}
  .taxeAnafToolbar__right .taxeAnafPath{min-width:0; width:100%}
}

/* Taxe ANAF compact premium pass */
.taxeAnafPage{
  gap:8px;
}
.taxeAnafHead{
  padding-bottom:4px;
  border-bottom:1px solid rgba(148,163,184,0.28);
  align-items:center;
}
.taxeAnafHead__left .panel__title{
  margin:0;
  line-height:1.08;
}
.taxeAnafHead__right{
  gap:7px;
}
.taxeAnafHead__right .ghostBtn,
.taxeAnafHead__right .primaryBtn{
  min-height:34px;
  padding:7px 10px;
  border-radius:10px;
  font-weight:700;
}

.taxeAnafToolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  border:1px solid rgba(148,163,184,0.28);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(247,250,255,0.90));
  box-shadow:0 8px 20px rgba(15,23,42,0.06);
  padding:8px;
  gap:7px;
}
.taxeAnafToolbar__left .input,
.taxeAnafToolbar__right .input{
  min-height:34px;
  border-radius:10px;
}
.taxeAnafToolbar__left .ghostBtn,
.taxeAnafToolbar__left .primaryBtn,
.taxeAnafToolbar__right .ghostBtn,
.taxeAnafToolbar__right .primaryBtn{
  min-height:33px;
  padding:6px 9px;
  border-radius:10px;
}
.taxeAnafToolbar__left{
  flex:1 1 460px;
  min-width:320px;
}
.taxeAnafToolbar__right{
  flex:1 1 420px;
  min-width:280px;
  justify-content:flex-end;
}

.taxeAnafHints{
  gap:3px;
}
.taxeAnafStatus{
  display:inline-flex;
  align-items:center;
  width:max-content;
  border:1px solid rgba(148,163,184,0.30);
  border-radius:999px;
  background:rgba(255,255,255,0.9);
  padding:5px 10px;
  font-size:11px;
}

.taxeAnafSummary{
  gap:8px;
}
.taxeAnafCard{
  min-height:84px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  border-radius:14px;
  border-color:rgba(148,163,184,0.28);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,245,249,0.84));
  box-shadow:
    0 8px 16px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.8);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.taxeAnafCard:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.30);
  box-shadow:
    0 12px 24px rgba(15,23,42,0.09),
    inset 0 1px 0 rgba(255,255,255,0.84);
}
.taxeAnafCard__label{
  text-align:center;
  font-size:11px;
  letter-spacing:0.2px;
}
.taxeAnafCard__value{
  text-align:center;
  font-size:clamp(21px, 1.7vw, 28px);
  line-height:1.05;
  margin-top:3px;
  font-weight:900;
}
.taxeAnafCard--total{
  border-color:rgba(16,185,129,0.38);
  background:
    linear-gradient(180deg, rgba(236,253,245,0.94), rgba(209,250,229,0.86));
}

.taxeAnafSection{
  border-radius:13px;
  padding:9px;
  border-color:rgba(148,163,184,0.24);
  background:rgba(255,255,255,0.86);
}
.taxeAnafSection__head{
  margin-bottom:6px;
}
.taxeAnafTableWrap{
  border-radius:11px;
}
.taxeAnafTable{
  min-width:740px;
  font-size:12.5px;
}
.taxeAnafTable th,
.taxeAnafTable td{
  padding:7px 8px;
}
.taxeAnafTable th{
  position:sticky;
  top:0;
  z-index:1;
  backdrop-filter:blur(5px);
}
.taxeAnafTable tbody tr:hover{
  background:rgba(59,130,246,0.05);
}

.taxeAnafImportList{
  gap:7px;
}
.taxeAnafImportItem{
  border-radius:12px;
  padding:9px 10px;
  border-color:rgba(148,163,184,0.24);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.9));
  box-shadow:
    0 8px 16px rgba(15,23,42,0.05),
    inset 0 1px 0 rgba(255,255,255,0.82);
  display:flex;
  flex-direction:column;
  gap:7px;
}
.taxeAnafImportItem__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.taxeAnafImportItem__name{
  font-weight:800;
  font-size:15px;
  color:#0f172a;
}
.taxeAnafImportItem__badge{
  display:inline-flex;
  align-items:center;
  padding:3px 10px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.36);
  background:rgba(241,245,249,0.92);
  font-size:11px;
  font-weight:800;
  color:#475569;
}
.taxeAnafImportItem__badge.isOk{
  border-color:rgba(16,185,129,0.36);
  background:rgba(220,252,231,0.92);
  color:#047857;
}
.taxeAnafImportItem__badge.isWarn{
  border-color:rgba(239,68,68,0.34);
  background:rgba(254,242,242,0.92);
  color:#b91c1c;
}
.taxeAnafImportItem__meta{
  display:flex;
  align-items:center;
  gap:7px;
  flex-wrap:wrap;
}
.taxeAnafImportItem__chip{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:3px 9px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.30);
  background:rgba(255,255,255,0.94);
  font-size:12px;
  font-weight:700;
  color:#334155;
}
.taxeAnafImportItem__file{
  font-size:11px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

@media (max-width: 980px){
  .taxeAnafHead{
    border-bottom:0;
    padding-bottom:0;
  }
  .taxeAnafToolbar{
    display:grid;
    grid-template-columns:1fr;
  }
  .taxeAnafToolbar__left,
  .taxeAnafToolbar__right{
    min-width:0;
    width:100%;
    justify-content:flex-start;
  }
  .taxeAnafStatus{
    width:100%;
    justify-content:center;
  }
  .taxeAnafImportItem__top{
    align-items:flex-start;
    flex-direction:column;
  }
}

/* === Stocks === */
.panel.stocksPage{
  border:1px solid rgba(17,24,39,0.14);
  align-self:flex-start;
  background:
    radial-gradient(900px 260px at 8% -10%, rgba(59,130,246,0.12), transparent 60%),
    radial-gradient(900px 260px at 92% -12%, rgba(14,165,233,0.10), transparent 62%),
    rgba(255,255,255,0.84);
  flex:0 0 auto;
}
.stocksPage{display:flex; flex-direction:column; gap:12px}
.stocksHero{
  display:grid;
  grid-template-columns:minmax(320px, 1fr) auto;
  gap:12px;
  align-items:start;
}
.stocksHero__value{
  font-size:34px;
  font-weight:900;
  letter-spacing:-0.02em;
  line-height:1.1;
}
.stocksHero__sub{margin-top:4px; font-size:14px; color:var(--muted)}
.stocksHero__right{display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end}
.stocksAccountSel{min-width:210px}
.stocksExposure{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}

.stocksRange,
.stocksViewTabs{align-self:flex-start}

.stocksNotice{
  border:1px solid rgba(59,130,246,0.24);
  border-radius:12px;
  padding:8px 10px;
  font-size:13px;
  background:rgba(59,130,246,0.08);
}
.stocksNotice.isWarn{background:rgba(239,68,68,0.10); border-color:rgba(239,68,68,0.24)}
.stocksNotice.isOk{background:rgba(34,197,94,0.10); border-color:rgba(34,197,94,0.24)}
.stocksNotice.isHidden{display:none}
.stocksStatus{font-size:12px}

.stocksTab{display:flex; flex-direction:column; gap:12px}
.stocksKpi{display:grid; grid-template-columns:repeat(4, minmax(130px, 1fr)); gap:10px}
.stocksKpi__card{
  border:1px solid rgba(17,24,39,0.10);
  border-radius:14px;
  background:rgba(255,255,255,0.84);
  padding:10px;
}
.stocksKpi__label{font-size:12px; color:var(--muted)}
.stocksKpi__value{font-size:24px; font-weight:900; margin-top:4px; line-height:1.1}

.stocksCard{
  border:1px solid rgba(17,24,39,0.10);
  border-radius:14px;
  background:rgba(255,255,255,0.84);
  padding:12px;
}
.stocksCard__head{display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px}
.stocksCard__title{font-weight:800}
.stocksHeadPills{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.stocksInlineFacts{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  margin:0 0 4px;
}
.stocksInlineFacts--dividends{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:8px;
  margin:2px 0 10px;
}
.stocksInlineFacts__chip{
  display:inline-flex;
  align-items:center;
  min-height:20px;
  padding:2px 7px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.18);
  background:rgba(255,255,255,0.88);
  font-size:10px;
  font-weight:800;
  color:#334155;
  white-space:nowrap;
}
.stocksInlineFacts--dividends .stocksInlineFacts__chip{
  min-height:40px;
  justify-content:center;
  padding:8px 12px;
  border-radius:14px;
  border-color:rgba(148,163,184,0.16);
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  box-shadow:0 10px 24px rgba(15,23,42,0.04);
  font-size:11px;
}
.stocksInlineFacts--dividends .stocksInlineFacts__chip--total{
  border-color:rgba(37,99,235,0.14);
  background:linear-gradient(180deg, rgba(248,250,255,0.98), rgba(239,246,255,0.92));
  color:#163b7a;
}
.stocksInlineFacts--dividends .stocksInlineFacts__chip--planned{
  border-color:rgba(239,68,68,0.16);
  background:linear-gradient(180deg, rgba(255,250,250,0.98), rgba(254,242,242,0.92));
  color:#b91c1c;
}
.stocksInlineFacts--dividends .stocksInlineFacts__chip--received{
  border-color:rgba(34,197,94,0.18);
  background:linear-gradient(180deg, rgba(247,254,249,0.98), rgba(240,253,244,0.92));
  color:#166534;
}
.stocksInlineFacts--dividends .stocksInlineFacts__chip--average{
  border-color:rgba(14,165,233,0.16);
  background:linear-gradient(180deg, rgba(249,252,255,0.98), rgba(240,249,255,0.92));
  color:#0f4c81;
}
.stocksInlineFacts--dividends .stocksInlineFacts__chip--next{
  border-color:rgba(245,158,11,0.18);
  background:linear-gradient(180deg, rgba(255,252,245,0.98), rgba(254,249,195,0.56));
  color:#92400e;
}
.stocksMiniToggle{
  appearance:none;
  border:1px solid rgba(148,163,184,0.24);
  background:rgba(255,255,255,0.88);
  color:#475569;
  border-radius:999px;
  padding:4px 8px;
  font-size:11px;
  font-weight:800;
  line-height:1;
  cursor:pointer;
}
.stocksMiniToggle.isActive{
  border-color:rgba(59,130,246,0.28);
  background:rgba(59,130,246,0.08);
  color:#1d4ed8;
}
.stocksUpcomingBlock--premium .stocksTopPill{
  padding:4px 8px;
  font-size:11px;
}

.stocksLineChart{
  min-height:260px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.stocksLineChart__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}
.stocksLineChart__headMain{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.stocksLineChart__trend{
  font-size:12px;
  font-weight:900;
  border-radius:999px;
  padding:4px 10px;
  border:1px solid transparent;
}
.stocksLineChart__trend.isUp{
  color:#14532d;
  background:rgba(22,163,74,0.14);
  border-color:rgba(22,163,74,0.30);
}
.stocksLineChart__trend.isDown{
  color:#7f1d1d;
  background:rgba(220,38,38,0.14);
  border-color:rgba(220,38,38,0.30);
}
.stocksLineChart__meta{font-size:12px}
.stocksLineChart__svgWrap{height:236px}
.stocksLineChart__svgWrap svg{width:100%; height:100%; display:block}
.stocksLineChart__svgWrap.isUp{
  background:linear-gradient(180deg, rgba(22,163,74,0.015), rgba(255,255,255,0));
}
.stocksLineChart__svgWrap.isDown{
  background:linear-gradient(180deg, rgba(220,38,38,0.015), rgba(255,255,255,0));
}
.stocksLineChart__grid{
  stroke:rgba(100,116,139,0.14);
  stroke-width:.85;
  stroke-dasharray:3 5;
}
.stocksLineChart__yLabel{
  fill:#64748b;
  font-size:10px;
  font-weight:600;
}
.stocksLineChart__snap{
  fill:#1d4ed8;
  opacity:0.45;
}
.stocksLineChart__axis{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  color:#64748b;
  font-size:11px;
  font-weight:600;
}
.stocksLineChart__tooltip{
  position:absolute;
  left:0;
  top:0;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:1px;
  min-width:88px;
  padding:6px 8px;
  border:1px solid rgba(148,163,184,0.18);
  border-radius:10px;
  background:rgba(255,255,255,0.96);
  box-shadow:0 8px 18px rgba(15,23,42,0.10);
  pointer-events:none;
  transform:translateY(calc(-100% - 10px));
  backdrop-filter:blur(8px);
}
.stocksLineChart__tooltip.isHidden,
.stocksLineChart__crosshair.isHidden,
.stocksLineChart__activeDot.isHidden{
  display:none;
}
.stocksLineChart__tooltipDate{
  font-size:10px;
  font-weight:700;
  color:#64748b;
  white-space:nowrap;
}
.stocksLineChart__tooltipVal{
  font-size:12px;
  font-weight:900;
  color:#0f172a;
  white-space:nowrap;
}
.stocksLineChart__crosshair{
  position:absolute;
  top:8px;
  bottom:10px;
  width:1px;
  background:linear-gradient(180deg, rgba(148,163,184,0.05), rgba(148,163,184,0.28), rgba(148,163,184,0.05));
  pointer-events:none;
  transform:translateX(-50%);
}
.stocksLineChart__activeDot{
  position:absolute;
  width:8px;
  height:8px;
  border-radius:999px;
  pointer-events:none;
  transform:translate(-50%, -50%);
}
.stocksLineChart__mode{
  display:inline-flex;
  align-items:center;
  gap:2px;
  padding:2px;
  border:1px solid rgba(148,163,184,0.16);
  border-radius:999px;
  background:rgba(248,250,252,0.94);
}
.stocksLineChart__modeBtn{
  border:0;
  background:transparent;
  min-height:22px;
  padding:0 8px;
  border-radius:999px;
  font-size:10px;
  font-weight:800;
  color:#64748b;
  cursor:pointer;
}
.stocksLineChart__modeBtn.isActive{
  background:#ffffff;
  color:#0f172a;
  box-shadow:0 1px 3px rgba(15,23,42,0.06);
}

.stocksTableWrap{
  overflow:auto;
  border:1px solid rgba(17,24,39,0.10);
  border-radius:12px;
  background:rgba(255,255,255,0.92);
}
.stocksTable{width:100%; border-collapse:collapse; min-width:1150px; font-size:13px}
.stocksTable th,
.stocksTable td{padding:8px 9px; border-bottom:1px solid rgba(17,24,39,0.10); text-align:left; vertical-align:top}
.stocksTable th{font-size:12px; color:var(--muted); font-weight:700; background:rgba(17,24,39,0.03)}
.stocksTable tr:last-child td{border-bottom:0}
.stocksTable tbody tr{cursor:pointer; transition:background .12s ease}
.stocksTable tbody tr:hover{background:rgba(59,130,246,0.06)}
.stocksSymbol{display:flex; flex-direction:column; gap:2px}
.stocksActions{display:flex; gap:6px; flex-wrap:wrap}

.stocksSafety{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:68px;
  padding:4px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  border:1px solid rgba(17,24,39,0.20);
}
.stocksSafety--safe{background:rgba(34,197,94,0.14); color:#14532d; border-color:rgba(34,197,94,0.34)}
.stocksSafety--medium{background:rgba(245,158,11,0.14); color:#78350f; border-color:rgba(245,158,11,0.34)}
.stocksSafety--risky{background:rgba(239,68,68,0.14); color:#7f1d1d; border-color:rgba(239,68,68,0.34)}
.stocksSafety--na{background:rgba(100,116,139,0.14); color:#334155; border-color:rgba(100,116,139,0.30)}

.stocksDrawer{display:flex; flex-direction:column; gap:12px}
.stocksDrawer__head{display:flex; flex-direction:column; gap:4px}
.stocksDrawer__title{font-size:20px; font-weight:900}
.stocksDrawer__grid{display:grid; grid-template-columns:repeat(2, minmax(180px, 1fr)); gap:8px}
.stocksDrawer__card{
  border:1px solid rgba(17,24,39,0.10);
  border-radius:12px;
  background:rgba(255,255,255,0.82);
  padding:10px;
}
.stocksDrawer__val{font-size:20px; font-weight:900; line-height:1.12; margin-top:4px}
.stocksDrawer__sec{
  border:1px solid rgba(17,24,39,0.10);
  border-radius:12px;
  background:rgba(255,255,255,0.82);
  padding:10px;
}
.stocksDrawer__secTitle{font-weight:800; margin-bottom:8px}
.stocksDrawer__list{margin:0; padding-left:18px; display:flex; flex-direction:column; gap:4px}
.stocksDrawer__actions{
  margin-top:10px;
  display:flex;
  justify-content:flex-end;
}
.stocksDrawer__val.isPos{color:#166534}
.stocksDrawer__val.isNeg{color:#b91c1c}
.stocksTxnPreview{margin-top:10px}

.stocksMiniTable{width:100%; border-collapse:collapse; font-size:12px}
.stocksMiniTable th,
.stocksMiniTable td{padding:6px 6px; border-bottom:1px solid rgba(17,24,39,0.10); text-align:left}
.stocksMiniTable tr:last-child td{border-bottom:0}

.stocksDivMatrixWrap{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:10px;
}
.stocksDivSyncScroll{
  --stocks-div-col-symbol: 110px;
  --stocks-div-col-total: 90px;
  overflow-x:auto;
  overflow-y:visible;
  padding-bottom:2px;
}
.stocksDivLegend{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.stocksDivLegend--inline{
  gap:6px;
  align-items:center;
  margin-left:4px;
}
.stocksDivLegend--calendar{
  justify-content:flex-start;
  gap:6px;
  margin-top:8px;
  padding-top:8px;
  border-top:1px solid rgba(148,163,184,0.12);
}
.stocksDivLegend--inline .stocksDivLegend__item{
  font-size:11px;
  padding:3px 8px;
}
.stocksDivLegend__item{
  font-size:11px;
  font-weight:800;
  padding:3px 8px;
  border-radius:6px;
  border:0;
  background:#e2e8f0;
  color:#334155;
  box-shadow:none;
}
.stocksDivLegend__item--confirmed{
  border-color:rgba(37,99,235,0.45);
  background:rgba(37,99,235,0.12);
  color:#1d4ed8;
}
.stocksDivLegend__item--planned{
  border-color:rgba(239,68,68,0.30);
  background:rgba(255,236,236,0.95);
  color:#b91c1c;
}
.stocksDivLegend__item--estimated{
  border-color:rgba(245,158,11,0.42);
  background:rgba(245,158,11,0.12);
  color:#92400e;
}
.stocksDivLegend__item--received{
  background:#16a34a;
  color:#ffffff;
}
.stocksDivMatrixTableWrap{
  border:1px solid rgba(203,213,225,0.9);
  border-radius:10px;
  overflow:hidden;
  background:#ffffff;
  box-shadow:none;
}
.stocksDivMatrixTableWrap--compact{
  border-radius:10px;
}
.stocksDivMatrixTable{
  width:max-content;
  min-width:100%;
  border-collapse:separate;
  border-spacing:0;
  table-layout:fixed;
  font-size:11px;
}
.stocksDivCol--symbol{width:var(--stocks-div-col-symbol)}
.stocksDivCol--total{width:var(--stocks-div-col-total)}
.stocksDivCol--month{width:104px}
.stocksDivMatrixTable th,
.stocksDivMatrixTable td{
  padding:7px 8px;
  border-bottom:1px solid rgba(226,232,240,0.95);
  text-align:center;
  white-space:nowrap;
}
.stocksDivMatrixTable th{
  background:linear-gradient(180deg, rgba(239,246,255,0.96), rgba(248,250,252,0.98));
  font-weight:800;
  color:#163b7a;
  position:sticky;
  top:0;
  z-index:1;
  font-size:11px;
  letter-spacing:0;
  text-transform:none;
  box-shadow:inset 0 -1px 0 rgba(191,219,254,0.85);
}
.stocksDivMatrixTable td:first-child,
.stocksDivMatrixTable th:first-child{
  text-align:left;
  position:sticky;
  left:0;
  z-index:2;
  background:#ffffff;
}
.stocksDivMatrixTable td:nth-child(2),
.stocksDivMatrixTable th:nth-child(2){
  font-weight:800;
}
.stocksDivMatrixTable__sym{
  font-weight:800;
  color:#0f172a;
}
.stocksDivMatrixTable__total{
  font-variant-numeric:tabular-nums;
  color:#0b3d91;
}
.stocksDivMatrixTable td{
  font-size:12px;
}
.stocksDivCell{
  font-variant-numeric:tabular-nums;
  border-left:1px solid rgba(241,245,249,0.9);
}
.stocksDivCell--confirmed{
  background:#bbf7d0;
  color:#166534;
  font-weight:700;
}
.stocksDivCell--planned{
  background:#fecaca;
  color:#b91c1c;
  font-weight:700;
}
.stocksDivCell--estimated{
  background:#bfdbfe;
  color:#1d4ed8;
  font-weight:700;
}
.stocksDivCell--received{
  background:#dcfce7;
  color:#166534;
  font-weight:700;
}
.stocksDivCell--mixed{
  background:#dbeafe;
  color:#1d4ed8;
  font-weight:700;
}
.stocksDivMatrixTable__grand td{
  background:rgba(255,255,255,0.98);
  font-weight:800;
  border-top:1px solid rgba(203,213,225,0.95);
}
.stocksDivMatrixTable__grand td:first-child,
.stocksDivMatrixTable__grand td:nth-child(2){
  color:#163b7a;
}
.stocksDivMatrixCollapsed{
  margin-bottom:8px;
  padding:9px 11px;
  border:1px dashed rgba(148,163,184,0.24);
  border-radius:12px;
  font-size:11px;
  background:rgba(255,255,255,0.72);
}

.stocksUpcomingBlock{
  margin-top:6px;
}
.stocksUpcomingBlock__title{
  font-size:22px;
  font-weight:700;
  line-height:1.1;
  color:#1f2937;
  margin:8px 0 10px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(148,163,184,0.34);
}
.stocksUpcomingTable{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
  background:transparent;
  table-layout:fixed;
}
.stocksUpcomingTableWrap{
  border:1px solid rgba(148,163,184,0.24);
  border-radius:12px;
  background:rgba(255,255,255,0.82);
  overflow:auto;
}
.stocksUpcomingTable th,
.stocksUpcomingTable td{
  text-align:left;
  padding:5px 6px;
  border-bottom:1px solid rgba(148,163,184,0.24);
  vertical-align:middle;
}
.stocksUpcomingTable th.stocksUpcomingAmount,
.stocksUpcomingTable td.stocksUpcomingAmount{
  text-align:right;
  padding-right:14px;
  white-space:nowrap;
}
.stocksUpcomingTable th{
  font-size:11px;
  font-weight:800;
  color:#334155;
  letter-spacing:0.04em;
  text-transform:uppercase;
}
.stocksUpcomingTable td:last-child,
.stocksUpcomingTable th:last-child{
  text-align:right;
  white-space:nowrap;
}
.stocksUpcomingTable tbody tr{
  background:rgba(255,255,255,0.56);
}
.stocksUpcomingTable tbody tr:nth-child(2n){
  background:rgba(248,250,252,0.74);
}
.stocksUpcomingStatus{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:64px;
  padding:2px 7px;
  border-radius:999px;
  font-size:9px;
  font-weight:800;
  border:1px solid rgba(100,116,139,0.28);
  background:rgba(241,245,249,0.8);
  color:#334155;
}
.stocksUpcomingStatus--confirmed{
  background:rgba(34,197,94,0.14);
  border-color:rgba(34,197,94,0.34);
  color:#166534;
}
.stocksUpcomingStatus--planned{
  background:rgba(37,99,235,0.14);
  border-color:rgba(37,99,235,0.34);
  color:#1d4ed8;
}
.stocksUpcomingStatus--estimated{
  background:rgba(245,158,11,0.14);
  border-color:rgba(245,158,11,0.34);
  color:#92400e;
}
.stocksUpcomingStatus--received{
  background:rgba(34,197,94,0.14);
  border-color:rgba(34,197,94,0.34);
  color:#166534;
}
.stocksSourcePill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:20px;
  padding:2px 7px;
  border-radius:999px;
  font-size:10px;
  font-weight:800;
  letter-spacing:0.02em;
  border:1px solid rgba(148,163,184,0.22);
  background:rgba(255,255,255,0.92);
  color:#475569;
  white-space:nowrap;
}
.stocksUpcomingCompany{
  min-width:0;
  white-space:normal;
  overflow:visible;
}
.stocksUpcomingListWrap{
  padding:6px;
}
.stocksUpcomingList{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.stocksUpcomingMonth{
  border:1px solid rgba(148,163,184,0.14);
  border-radius:8px;
  background:linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,250,252,0.86));
  box-shadow:none;
  overflow:hidden;
}
.stocksUpcomingMonth__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:4px 9px;
  border-bottom:1px solid rgba(148,163,184,0.12);
  background:linear-gradient(180deg, rgba(248,250,252,0.92), rgba(255,255,255,0.9));
}
.stocksUpcomingMonth__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:#334155;
}
.stocksUpcomingMonth__meta{
  display:flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}
.stocksUpcomingMonth__count{
  font-size:9px;
  font-weight:700;
  color:#64748b;
}
.stocksUpcomingMonth__total{
  font-size:10px;
  font-weight:900;
  color:#0f172a;
}
.stocksUpcomingMonth__rows{
  display:flex;
  flex-direction:column;
}
.stocksUpcomingItem{
  display:grid;
  grid-template-columns:68px 74px minmax(0, 1fr) auto auto;
  gap:6px;
  align-items:center;
  padding:5px 8px;
}
.stocksUpcomingItem.isReceived{
  background:rgba(34,197,94,0.04);
}
.stocksUpcomingItem + .stocksUpcomingItem{
  border-top:1px solid rgba(148,163,184,0.10);
}
.stocksUpcomingItem__dateWrap{
  display:flex;
  flex-direction:column;
  gap:0;
}
.stocksUpcomingItem__dateLabel{
  display:none;
}
.stocksUpcomingItem__date{
  font-size:9px;
  font-weight:800;
  color:#334155;
  white-space:nowrap;
  line-height:1.1;
}
.stocksUpcomingCompany__title{
  font-size:11px;
  font-weight:800;
  color:#0f172a;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.15;
}
.stocksUpcomingCompany__meta{
  margin-top:0;
  font-size:8px;
  color:#64748b;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.1;
}
.stocksUpcomingItem .stocksUpcomingAmount{
  flex:0 0 auto;
  font-size:11px;
  font-weight:900;
  color:#0f172a;
  padding-right:0;
  white-space:nowrap;
}
.stocksUpcomingActions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:3px;
}
.stocksDivActionBtn{
  min-width:26px;
  min-height:26px;
  padding:0;
  border-radius:8px;
}
.stocksDivActionBtn.isReceived{
  border-color:rgba(34,197,94,0.3);
  background:rgba(34,197,94,0.10);
  color:#166534;
}
.stocksDivActionBtn--danger{
  color:#dc2626;
}
.stocksDivAddBtn{
  min-height:32px;
  padding:0 12px;
  border-radius:10px;
  font-size:11px;
  font-weight:800;
}
.stocksCard--dividends .stocksHeadPills{
  gap:6px;
}
.stocksCard--dividends .stocksCard__title{
  font-size:14px;
}
.stocksUpcomingBlock--premium .stocksCard__head{
  margin-bottom:6px;
}
.stocksUpcomingListWrap{
  padding:6px;
}
.stocksSourcePill.isIssuer{
  background:rgba(16,185,129,0.12);
  border-color:rgba(16,185,129,0.24);
  color:#065f46;
}
.stocksSourcePill.isFmp{
  background:rgba(59,130,246,0.10);
  border-color:rgba(59,130,246,0.22);
  color:#1d4ed8;
}
.stocksSourcePill.isYahoo{
  background:rgba(139,92,246,0.10);
  border-color:rgba(139,92,246,0.20);
  color:#6d28d9;
}
.stocksSourcePill.isModel{
  background:rgba(245,158,11,0.12);
  border-color:rgba(245,158,11,0.22);
  color:#92400e;
}

.stocksDonut{
  display:grid;
  grid-template-columns:minmax(240px, 320px) minmax(0, 1fr);
  gap:18px;
  align-items:center;
}
.stocksDonut--compact{
  grid-template-columns:minmax(0, 1fr) auto minmax(0, 1fr);
  justify-content:stretch;
  align-items:center;
  min-height:0;
  gap:18px;
  width:100%;
}
.stocksDonut__ring{
  width:240px;
  height:240px;
  border-radius:999px;
  box-shadow:inset 0 0 0 26px rgba(255,255,255,0.90);
  border:1px solid rgba(17,24,39,0.10);
  justify-self:center;
}
.stocksDonut__ring--pie{
  position:relative;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.34),
    inset 0 -14px 24px rgba(15,23,42,0.06),
    0 20px 44px rgba(29,78,216,0.12);
  border:0;
}
.stocksDonut__ring--pie::after{
  content:'';
  position:absolute;
  inset:10px;
  border-radius:999px;
  background:
    radial-gradient(circle at 30% 24%, rgba(255,255,255,0.24), transparent 34%),
    radial-gradient(circle at 68% 76%, rgba(255,255,255,0.08), transparent 38%);
  pointer-events:none;
}
.stocksDonut__side{
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
  align-self:center;
}
.stocksDonut__summary{
  display:flex;
  flex-direction:column;
  gap:3px;
  padding:11px 13px;
  border:1px solid rgba(148,163,184,0.12);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  box-shadow:0 10px 22px rgba(15,23,42,0.04);
  position:relative;
  overflow:hidden;
}
.stocksDonut__summary::before{
  content:'';
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg, rgba(37,99,235,0.54), rgba(37,99,235,0.08));
}
.stocksDonut__summaryLabel{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksDonut__summaryValue{
  font-size:28px;
  line-height:1.02;
  font-weight:900;
  letter-spacing:-0.03em;
  color:#0f295d;
}
.stocksDonut__summaryMeta{
  font-size:11px;
  color:#64748b;
}
.stocksDonut__legend{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-self:center;
}
.stocksDonut--compact .stocksDonut__legend{
  width:100%;
  max-width:320px;
}
.stocksDonut--compact .stocksDonut__ring{
  width:168px;
  height:168px;
}
.stocksDonut--compact .stocksDonut__side{
  gap:8px;
  align-self:center;
  justify-self:end;
}
.stocksDonut--compact .stocksDonut__summary{
  gap:3px;
  padding:8px 10px;
  border-radius:14px;
  align-self:center;
  justify-self:start;
  width:min(100%, 280px);
  align-items:center;
  text-align:center;
}
.stocksDonut--compact .stocksDonut__summaryValue{
  font-size:21px;
}
.stocksDonut--compact .stocksDonut__summaryMeta{
  font-size:11px;
}
.stocksDonut__legendRow{
  border:1px solid rgba(17,24,39,0.10);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  padding:9px 11px;
  display:grid;
  grid-template-columns:12px minmax(80px, 1fr) auto auto;
  gap:9px;
  align-items:center;
  font-size:12px;
  box-shadow:0 8px 18px rgba(15,23,42,0.03);
  position:relative;
  overflow:hidden;
}
.stocksDonut__legendRow::before{
  content:'';
  position:absolute;
  inset:0 auto 0 0;
  width:3px;
  background:linear-gradient(180deg, rgba(37,99,235,0.55), rgba(14,165,233,0.18));
}
.stocksDonut__dot{
  display:inline-block;
  width:11px;
  height:11px;
  border-radius:99px;
  box-shadow:0 0 0 3px rgba(255,255,255,0.92), 0 4px 10px rgba(15,23,42,0.06);
}
.stocksDonut__lab{font-weight:800; color:#0f172a; font-size:12px}
.stocksDonut__pct{font-variant-numeric:tabular-nums; color:#475569; font-weight:700; font-size:12px}
.stocksDonut__val{font-weight:900; color:#0f172a; font-size:12px}
.stocksDonut--compact .stocksDonut__legendRow{
  min-height:42px;
  padding:8px 10px;
  border-radius:12px;
  font-size:12px;
}
.stocksDonut--compact .stocksDonut__lab{
  font-size:12px;
}
.stocksDonut--compact .stocksDonut__pct,
.stocksDonut--compact .stocksDonut__val{
  font-size:12px;
}

.stocksModal{display:flex; flex-direction:column; gap:10px}
.stocksModal--holding{
  width:min(620px, 100%);
  margin:0 auto;
  gap:12px;
}
.stocksModal--holding .formLabel{margin-bottom:4px}
.stocksModal--holding .input{border-radius:12px}
.stocksModal__status{
  min-height:18px;
  font-size:12px;
}
.stocksTxnModal{
  width:min(980px, 100%);
  margin:0 auto;
}
.stocksTxnMeta{
  font-size:12px;
  font-weight:700;
  color:#475569;
}
.stocksTxnListTitle{
  font-size:13px;
  font-weight:800;
  color:#334155;
  margin-top:4px;
}
.stocksTxnTableWrap{
  max-height:300px;
  overflow:auto;
  border:1px solid rgba(148,163,184,0.28);
  border-radius:12px;
  background:rgba(255,255,255,0.94);
}
.grid2{display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:10px}
.stocksMetaModal{
  width:min(940px, 100%);
  margin:0 auto;
}
.stocksMetaHint{
  display:flex;
  align-items:center;
  font-size:12px;
}
.stocksMetaListTitle{
  font-size:13px;
  font-weight:800;
  color:#334155;
  margin-top:4px;
}
.stocksMetaTableWrap{
  max-height:280px;
  overflow:auto;
}
.stocksMetaTable{
  min-width:680px;
}
.stocksSuggestWrap{position:relative}
.stocksSuggest{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 6px);
  z-index:30;
  border:1px solid rgba(17,24,39,0.14);
  border-radius:12px;
  background:#fff;
  box-shadow:0 12px 34px rgba(17,24,39,0.18);
  overflow:hidden;
  max-height:280px;
  overflow-y:auto;
}
.stocksSuggest.isHidden{display:none}
.stocksSuggest__item{
  width:100%;
  border:0;
  background:transparent;
  display:grid;
  grid-template-columns:72px minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  padding:9px 10px;
  text-align:left;
  cursor:pointer;
}
.stocksSuggest__item:hover{background:rgba(59,130,246,0.09)}
.stocksSuggest__sym{font-weight:900}
.stocksSuggest__name{font-size:13px}
.stocksSuggest__meta{font-size:11px; color:var(--muted)}

@media (max-width: 1150px){
  .stocksHero{grid-template-columns:1fr}
  .stocksHero__right{justify-content:flex-start}
  .stocksKpi{grid-template-columns:repeat(2, minmax(130px, 1fr))}
  .stocksDonut{grid-template-columns:1fr}
  .stocksDonut--compact{
    grid-template-columns:1fr;
    justify-items:center;
    min-height:0;
  }
}
@media (max-width: 700px){
  .stocksHero__value{font-size:28px}
  .stocksKpi{grid-template-columns:1fr}
  .stocksDrawer__grid{grid-template-columns:1fr}
  .stocksDivSyncScroll{
    --stocks-div-col-symbol: 72px;
    --stocks-div-col-total: 76px;
    overflow-x:auto;
  }
  .stocksBarsAlign__barWrap{height:92px}
  .stocksUpcomingItem{
    grid-template-columns:72px minmax(0, 1fr) auto;
    grid-template-areas:
      "date company amount"
      "status source source";
    row-gap:5px;
  }
  .stocksUpcomingItem__date{grid-area:date}
  .stocksUpcomingItem .stocksUpcomingStatus{grid-area:status}
  .stocksUpcomingItem .stocksSourcePill{grid-area:source; justify-self:start}
  .stocksUpcomingItem .stocksUpcomingCompany{grid-area:company}
  .stocksUpcomingItem .stocksUpcomingAmount{grid-area:amount}
  .stocksDonut__ring{width:200px; height:200px; margin:0 auto}
  .stocksDonut--compact{
    gap:14px;
  }
  .stocksDonut__summaryValue{font-size:24px}
  .grid2{grid-template-columns:1fr}
}

/* Stocks premium polish */
.stocksHero{
  border:1px solid rgba(37,99,235,0.16);
  border-radius:16px;
  padding:14px;
  background:linear-gradient(130deg, rgba(255,255,255,0.88), rgba(246,250,255,0.92));
  box-shadow:0 12px 28px rgba(15,23,42,0.06);
}
.stocksHero__left .panel__title{margin-bottom:4px}
.stocksKpi__card{
  border:1px solid rgba(148,163,184,0.20);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.92), rgba(247,250,255,0.90));
  box-shadow:0 8px 20px rgba(15,23,42,0.04);
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  min-height:104px;
}
.stocksKpi__card .stocksKpi__label,
.stocksKpi__card .stocksKpi__value,
.stocksKpi__card .muted{width:100%; text-align:center}
.stocksCard{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:16px;
  box-shadow:0 10px 22px rgba(15,23,42,0.05);
}

.stocksTableWrap{
  border:0;
  background:transparent;
  overflow-x:hidden;
  padding:2px;
}
.stocksTable{
  width:100%;
  border-collapse:separate;
  border-spacing:0 10px;
  min-width:0;
  table-layout:auto;
  font-size:13px;
}
.stocksTable th.col-company, .stocksTable td.col-company{min-width:220px}
.stocksTable th.col-shares, .stocksTable td.col-shares{min-width:74px}
.stocksTable th.col-price, .stocksTable td.col-price{min-width:108px}
.stocksTable th.col-dca, .stocksTable td.col-dca{min-width:126px}
.stocksTable th.col-52w, .stocksTable td.col-52w{min-width:158px}
.stocksTable th.col-yield, .stocksTable td.col-yield{min-width:92px}
.stocksTable th.col-values, .stocksTable td.col-values{min-width:170px}
.stocksTable th.col-pl, .stocksTable td.col-pl{min-width:120px}
.stocksTable th.col-safety, .stocksTable td.col-safety{min-width:128px}
.stocksTable th.col-actions, .stocksTable td.col-actions{min-width:92px}
.stocksTable thead th{
  border:0;
  background:transparent;
  padding:0 10px 6px;
  font-size:12px;
  color:#64748b;
  font-weight:800;
  letter-spacing:0.01em;
}
.stocksTable tbody td{
  border-top:1px solid rgba(148,163,184,0.24);
  border-bottom:1px solid rgba(148,163,184,0.24);
  border-right:0;
  border-left:0;
  background:rgba(255,255,255,0.92);
  padding:11px 10px;
  vertical-align:middle;
  word-break:break-word;
}
.stocksTable td.col-shares,
.stocksTable td.col-price,
.stocksTable td.col-dca,
.stocksTable td.col-yield,
.stocksTable td.col-values,
.stocksTable td.col-pl{white-space:nowrap}
.stocksTable td.col-52w{white-space:normal}
.stocksTable tbody td:first-child{
  border-left:1px solid rgba(148,163,184,0.24);
  border-radius:14px 0 0 14px;
}
.stocksTable tbody td:last-child{
  border-right:1px solid rgba(148,163,184,0.24);
  border-radius:0 14px 14px 0;
}
.stocksTable__row{cursor:pointer}
.stocksTable__row td{transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease}
.stocksTable__row:hover td{
  border-top-color:rgba(59,130,246,0.38);
  border-bottom-color:rgba(59,130,246,0.38);
  box-shadow:0 12px 24px rgba(37,99,235,0.10);
}
.stocksTable__row:hover td:first-child{border-left-color:rgba(59,130,246,0.38)}
.stocksTable__row:hover td:last-child{border-right-color:rgba(59,130,246,0.38)}

.stocksCompany{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.stocksCompany__media{
  width:36px;
  height:36px;
  border-radius:11px;
  border:1px solid rgba(148,163,184,0.30);
  background:rgba(255,255,255,0.95);
  box-shadow:0 5px 12px rgba(15,23,42,0.08);
  overflow:hidden;
  display:grid;
  place-items:center;
  flex:0 0 auto;
}
.stocksCompany__logo{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.stocksCompany__logoFallback{
  width:100%;
  height:100%;
  display:none;
  place-items:center;
  font-size:13px;
  font-weight:900;
  color:#1e293b;
  background:linear-gradient(180deg, rgba(59,130,246,0.16), rgba(14,165,233,0.10));
}
.stocksCompany__text{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.stocksCompany__symbolRow{
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
}
.stocksCompany__symbol{
  font-weight:900;
  font-size:16px;
  letter-spacing:-0.01em;
  color:#0f172a;
  line-height:1.05;
}
.stocksCutBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:18px;
  padding:1px 6px;
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  color:#9f1239;
  background:rgba(244,63,94,0.10);
  border:1px solid rgba(244,63,94,0.18);
  white-space:nowrap;
}
.stocksCompany__name{
  font-size:13px;
  color:#64748b;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.stocksCellStack{display:flex; flex-direction:column; gap:2px}
.stocksCellMain{font-weight:700; color:#0f172a}
.stocksCellSub{font-size:11px; color:#64748b}

.stocks52Range{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:140px;
}
.stocks52Range__trackWrap{
  position:relative;
  padding-top:2px;
}
.stocks52Range__track{
  height:3px;
  border-radius:999px;
  background:rgba(148,163,184,0.55);
}
.stocks52Range__pin{
  position:absolute;
  top:-4px;
  width:10px;
  height:10px;
  border-radius:999px;
  background:#2563eb;
  box-shadow:0 0 0 2px rgba(219,234,254,0.95);
  transform:translateX(-50%);
}
.stocks52Range__pin::after{
  content:'';
  position:absolute;
  left:50%;
  top:8px;
  width:2px;
  height:5px;
  border-radius:2px;
  background:#2563eb;
  transform:translateX(-50%);
}
.stocks52Range__vals{
  display:flex;
  justify-content:space-between;
  gap:8px;
  font-size:11px;
  line-height:1;
  color:#334155;
  font-weight:700;
  font-variant-numeric:tabular-nums;
}

.stocksDelta,
.stocksProfit .stocksCellMain{font-weight:800}
.stocksDelta.isPos,
.stocksProfit.isPos .stocksCellMain{color:#166534}
.stocksDelta.isNeg,
.stocksProfit.isNeg .stocksCellMain{color:#b91c1c}

.stocksActions{display:flex; justify-content:flex-end; gap:8px; flex-wrap:nowrap}
.stocksActionIcon{
  width:36px;
  height:36px;
  border-radius:10px;
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:700;
  line-height:1;
}
.stocksActionIcon--danger{font-size:22px}

.stocksSafety{
  min-width:104px;
  justify-content:center;
  border-radius:999px;
  font-size:12px;
  padding:6px 10px;
  letter-spacing:0.01em;
}
.stocksTxnTable.stocksTable{
  width:100%;
  min-width:0;
  table-layout:fixed;
  border-collapse:collapse;
  border-spacing:0;
  font-size:12px;
}
.stocksTxnTable.stocksTable thead th{
  border:0;
  background:rgba(15,23,42,0.04);
  padding:8px 8px;
  font-size:12px;
  color:#475569;
  letter-spacing:0;
}
.stocksTxnTable.stocksTable tbody td{
  padding:8px 8px;
  border-top:0;
  border-left:0;
  border-right:0;
  border-bottom:1px solid rgba(148,163,184,0.22);
  background:transparent;
  white-space:nowrap;
}
.stocksTxnTable.stocksTable tbody td:first-child,
.stocksTxnTable.stocksTable tbody td:last-child{
  border-radius:0;
}
.stocksTxnTable.stocksTable tbody tr{
  cursor:default;
}
.stocksTxnTable.stocksTable tbody tr:hover td{
  box-shadow:none;
  border-top-color:transparent;
  border-bottom-color:rgba(59,130,246,0.28);
}
.stocksLineChart--empty{
  min-height:94px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
}
.stocksLineChart__emptyTitle{font-weight:800; font-size:13px}

@media (max-width: 700px){
  .stocksHero{padding:10px}
  .stocksCompany__name{font-size:12px}
  .stocksActionIcon{width:34px; height:34px}
  .stocksSafety{min-width:92px}
}
@media (max-width: 1360px){
  .stocksTable th.col-52w,
  .stocksTable td.col-52w{display:none}
}
@media (max-width: 1200px){
  .stocksTable th.col-yield,
  .stocksTable td.col-yield{display:none}
}

/* Stocks top zone premium refresh */
.stocksPage .stocksHero{
  border:1px solid rgba(59,130,246,0.24);
  border-radius:20px;
  padding:18px;
  background:
    radial-gradient(620px 180px at 12% 0%, rgba(59,130,246,0.14), transparent 68%),
    radial-gradient(620px 180px at 92% 0%, rgba(14,165,233,0.10), transparent 74%),
    linear-gradient(140deg, rgba(255,255,255,0.94), rgba(247,251,255,0.98));
  box-shadow:
    0 18px 38px rgba(15,23,42,0.08),
    inset 0 1px 0 rgba(255,255,255,0.9);
}
.stocksPage .stocksHero__value{
  font-size:52px;
  line-height:1.02;
  font-weight:900;
  letter-spacing:-0.02em;
  color:#0c214f;
}
.stocksPage .stocksHero__sub{
  margin-top:6px;
  font-size:15px;
  color:#465b7c;
}
.stocksPage .stocksExposureChip{
  border:1px solid rgba(148,163,184,0.34);
  border-radius:999px;
  background:rgba(255,255,255,0.9);
  box-shadow:0 6px 14px rgba(15,23,42,0.05);
  font-size:13px;
  font-weight:650;
}

.stocksPage .stocksHero__right{
  min-width:430px;
  display:grid;
  grid-template-columns:repeat(4, minmax(110px, 1fr));
  gap:10px;
  align-content:start;
}
.stocksPage .stocksHero__right .stocksAccountSel{
  grid-column:1 / -1;
  min-width:0;
}
.stocksPage .stocksTopBtn{
  height:46px;
  border-radius:12px;
  font-size:15px;
  font-weight:750;
}
.stocksPage .stocksTopBtn--primary{
  box-shadow:0 10px 18px rgba(59,130,246,0.24);
}

.stocksPage .stocksTopDeck{
  border:1px solid rgba(148,163,184,0.26);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(247,250,255,0.92));
  box-shadow:0 10px 22px rgba(15,23,42,0.06);
  padding:10px 12px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.stocksPage .stocksTopDeck__tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.stocksPage .stocksTopDeck__meta{
  margin-left:auto;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.stocksPage .stocksStatusWrap{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.stocksPage .stocksStatus{
  margin:0;
  border:1px solid rgba(148,163,184,0.28);
  border-radius:999px;
  background:rgba(255,255,255,0.95);
  font-size:13px;
  color:#475569;
  padding:7px 12px;
}
.stocksTopPill{
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(148,163,184,0.28);
  border-radius:999px;
  background:rgba(255,255,255,0.95);
  font-size:12px;
  font-weight:700;
  color:#334155;
  padding:7px 10px;
}
.stocksTopPill--final{
  border-color:rgba(34,197,94,0.38);
  background:rgba(34,197,94,0.10);
  color:#166534;
}
.stocksTopPill--draft{
  border-color:rgba(245,158,11,0.36);
  background:rgba(245,158,11,0.10);
  color:#92400e;
}
.stocksTopPill--warn{
  border-color:rgba(239,68,68,0.36);
  background:rgba(239,68,68,0.10);
  color:#991b1b;
}
.stocksSnapshotBadge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.3);
  background:rgba(255,255,255,0.9);
  padding:5px 10px;
  font-size:12px;
  font-weight:700;
  color:#334155;
}
.stocksSnapshotBadge.isFinal{
  border-color:rgba(34,197,94,0.34);
  background:rgba(34,197,94,0.12);
  color:#166534;
}
.stocksSnapshotBadge.isDraft{
  border-color:rgba(245,158,11,0.34);
  background:rgba(245,158,11,0.12);
  color:#92400e;
}
.stocksAlertsCard.isWarn{
  border-color:rgba(239,68,68,0.30);
  background:linear-gradient(180deg, rgba(255,255,255,0.97), rgba(254,242,242,0.92));
}
.stocksAlertsCard.isClear{
  border-color:rgba(34,197,94,0.28);
}
.stocksAlertsTableWrap{
  border:1px solid rgba(148,163,184,0.24);
  border-radius:12px;
  overflow:auto;
  background:rgba(255,255,255,0.92);
}
.stocksAlertsTable .stocksAlertsTable__row{
  cursor:pointer;
}
.stocksAlertsTable .stocksAlertsTable__row:hover{
  background:rgba(239,68,68,0.08);
}
.stocksPage--simple .stocksKpi__card--advanced,
.stocksPage--simple .stocksAlertsCard,
.stocksPage--simple .stocksDrawer__sec--ledger,
.stocksPage--simple .stocksTopPill--advanced,
.stocksPage--simple .stocksTopBtn--meta{
  display:none !important;
}

.stocksPage .stocksViewTabs,
.stocksPage .stocksRange{
  align-self:auto;
  background:rgba(15,23,42,0.04);
  border:1px solid rgba(148,163,184,0.28);
  border-radius:12px;
  padding:4px;
}
.stocksPage .stocksViewTabs .segBtn,
.stocksPage .stocksRange .segBtn{
  border:0;
  background:transparent;
  border-radius:9px;
  min-width:98px;
  height:36px;
  font-size:16px;
  font-weight:750;
}
.stocksPage .stocksViewTabs .segBtn.isActive,
.stocksPage .stocksRange .segBtn.isActive{
  background:linear-gradient(180deg, #f8fbff, #e9f2ff);
  border:1px solid rgba(59,130,246,0.34);
  color:#143569;
  box-shadow:0 7px 14px rgba(59,130,246,0.16);
}

@media (max-width: 980px){
  .stocksPage .stocksHero{
    padding:12px;
  }
  .stocksPage .stocksHero__value{
    font-size:42px;
  }
  .stocksPage .stocksHero__right{
    min-width:0;
    grid-template-columns:1fr;
  }
  .stocksPage .stocksTopDeck{
    padding:8px;
  }
  .stocksPage .stocksTopDeck__meta{
    margin-left:0;
    width:100%;
  }
  .stocksPage .stocksStatusWrap{
    width:100%;
    justify-content:flex-start;
  }
  .stocksPage .stocksStatus{
    width:auto;
    text-align:center;
  }
}

/* Stocks UI refinement */
.stocksPage{
  gap:14px;
}
.stocksPage .stocksHero{
  position:relative;
  overflow:hidden;
  align-items:stretch;
}
.stocksPage .stocksHero::after{
  content:'';
  position:absolute;
  inset:auto -40px -46px auto;
  width:220px;
  height:220px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(59,130,246,0.11) 0%, rgba(59,130,246,0.03) 42%, transparent 70%);
  pointer-events:none;
}
.stocksPage .stocksHero__left{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:10px;
  padding:4px 8px 2px 4px;
}
.stocksPage .stocksHero__left .panel__title{
  margin:0;
  font-size:15px;
  font-weight:900;
  letter-spacing:-0.01em;
}
.stocksPage .stocksHero__value{
  font-size:clamp(46px, 5vw, 68px);
  text-shadow:0 10px 24px rgba(37,99,235,0.08);
}
.stocksPage .stocksHero__sub{
  max-width:560px;
  line-height:1.45;
}
.stocksPage .stocksExposure{
  margin-top:2px;
}
.stocksPage .stocksExposureChip{
  min-height:34px;
  padding:0 12px;
  display:inline-flex;
  align-items:center;
}
.stocksPage .stocksHeroMeta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.stocksPage .stocksHeroMeta__chip{
  min-height:42px;
  padding:8px 12px;
  border-radius:14px;
  border:1px solid rgba(148,163,184,0.24);
  background:rgba(255,255,255,0.76);
  box-shadow:0 8px 18px rgba(15,23,42,0.04);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:2px;
}
.stocksPage .stocksHeroMeta__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksPage .stocksHeroMeta__value{
  font-size:14px;
  font-weight:900;
  color:#0f172a;
}
.stocksPage .stocksHeroMeta__chip.isPos .stocksHeroMeta__value{color:#166534}
.stocksPage .stocksHeroMeta__chip.isNeg .stocksHeroMeta__value{color:#b91c1c}
.stocksPage .stocksHero__right{
  min-width:460px;
  grid-template-columns:repeat(2, minmax(150px, 1fr));
  gap:12px;
  padding:12px;
  border-radius:18px;
  border:1px solid rgba(148,163,184,0.22);
  background:linear-gradient(180deg, rgba(255,255,255,0.84), rgba(242,247,255,0.72));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.8);
  position:relative;
  z-index:1;
}
.stocksPage .stocksAccountSel{
  min-height:48px;
  border-radius:14px;
  border-color:rgba(148,163,184,0.30);
  background:rgba(255,255,255,0.94);
  box-shadow:0 8px 16px rgba(15,23,42,0.04);
}
.stocksPage .stocksTopBtn{
  height:48px;
  border-radius:14px;
  border-color:rgba(148,163,184,0.28);
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(243,247,253,0.92));
  box-shadow:0 10px 18px rgba(15,23,42,0.05);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.stocksPage .stocksTopBtn:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.28);
  box-shadow:0 14px 24px rgba(37,99,235,0.08);
}
.stocksPage .stocksTopBtn--primary{
  background:linear-gradient(180deg, #f8fbff, #eaf3ff);
  border-color:rgba(59,130,246,0.34);
  color:#123b7a;
}
.stocksPage .stocksTopDeck{
  border-radius:18px;
  padding:12px 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,248,255,0.94));
}
.stocksPage .stocksTopDeck__tabs{
  gap:12px;
}
.stocksPage .stocksViewTabs,
.stocksPage .stocksRange{
  background:linear-gradient(180deg, rgba(248,250,252,0.88), rgba(241,245,249,0.82));
  border-radius:14px;
  padding:5px;
}
.stocksPage .stocksViewTabs .segBtn,
.stocksPage .stocksRange .segBtn{
  min-width:116px;
  height:40px;
  font-size:15px;
  font-weight:800;
  color:#334155;
}
.stocksPage .stocksViewTabs .segBtn:hover,
.stocksPage .stocksRange .segBtn:hover{
  background:rgba(255,255,255,0.72);
}
.stocksPage .stocksStatus,
.stocksPage .stocksTopPill{
  min-height:40px;
  padding:0 14px;
  box-shadow:0 6px 14px rgba(15,23,42,0.04);
}
.stocksPage .stocksKpi{
  gap:12px;
}
.stocksPage .stocksKpi__card{
  position:relative;
  min-height:120px;
  padding:16px 16px 14px;
  align-items:flex-start;
  text-align:left;
  overflow:hidden;
}
.stocksPage .stocksKpi__card::before{
  content:'';
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg, rgba(148,163,184,0.3), rgba(148,163,184,0.08));
}
.stocksPage .stocksKpi__card .stocksKpi__label,
.stocksPage .stocksKpi__card .stocksKpi__value,
.stocksPage .stocksKpi__card .muted{
  text-align:left;
}
.stocksPage .stocksKpi__label{
  font-size:11px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksPage .stocksKpi__value{
  margin-top:10px;
  font-size:clamp(30px, 2.8vw, 40px);
  line-height:1;
  letter-spacing:-0.03em;
}
.stocksPage .stocksKpi__card .muted{
  margin-top:8px;
  font-size:13px;
}
.stocksPage .stocksKpi__card--pl.isPos{
  border-color:rgba(34,197,94,0.28);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(240,253,244,0.94));
}
.stocksPage .stocksKpi__card--pl.isPos::before{
  background:linear-gradient(90deg, rgba(34,197,94,0.78), rgba(34,197,94,0.1));
}
.stocksPage .stocksKpi__card--pl.isNeg{
  border-color:rgba(239,68,68,0.24);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(254,242,242,0.94));
}
.stocksPage .stocksKpi__card--pl.isNeg::before{
  background:linear-gradient(90deg, rgba(239,68,68,0.72), rgba(239,68,68,0.08));
}
.stocksPage .stocksKpi__card--income::before{
  background:linear-gradient(90deg, rgba(14,165,233,0.75), rgba(14,165,233,0.08));
}
.stocksPage .stocksKpi__card--yield::before{
  background:linear-gradient(90deg, rgba(245,158,11,0.75), rgba(245,158,11,0.08));
}
.stocksPage .stocksCard{
  border-radius:18px;
  padding:14px;
}
.stocksPage .stocksCard--chart{
  padding:16px 16px 14px;
}
.stocksPage .stocksCard__head{
  margin-bottom:12px;
}
.stocksPage .stocksCard__title{
  font-size:16px;
  letter-spacing:-0.01em;
}
.stocksPage .stocksLineChart{
  gap:12px;
}
.stocksPage .stocksLineChart__head{
  padding-bottom:2px;
}
.stocksPage .stocksLineChart__stats{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
}
.stocksPage .stocksLineChart__stat{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:12px;
  background:rgba(255,255,255,0.84);
  padding:8px 10px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.stocksPage .stocksLineChart__statLabel{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:#64748b;
  font-weight:800;
}
.stocksPage .stocksLineChart__statValue{
  font-size:14px;
  font-weight:900;
  color:#0f172a;
}
.stocksPage .stocksLineChart__trend{
  min-height:34px;
  padding:0 12px;
  display:inline-flex;
  align-items:center;
}
.stocksPage .stocksLineChart__svgWrap{
  height:240px;
  border-radius:16px;
  padding:6px 4px 2px;
  background:
    linear-gradient(180deg, rgba(248,250,252,0.8), rgba(255,255,255,0.94));
  border:1px solid rgba(148,163,184,0.18);
}
.stocksHoldingsList{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.stocksHoldingCard{
  border:1px solid rgba(148,163,184,0.22);
  border-radius:18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.97), rgba(246,250,255,0.94));
  box-shadow:0 14px 28px rgba(15,23,42,0.05);
  padding:14px;
  display:grid;
  grid-template-columns:minmax(0, 1fr) 200px;
  gap:14px;
  cursor:pointer;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.stocksHoldingCard:hover{
  transform:translateY(-1px);
  border-color:rgba(59,130,246,0.28);
  box-shadow:0 18px 34px rgba(37,99,235,0.08);
}
.stocksHoldingCard__main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.stocksCompany--hero{
  align-items:flex-start;
}
.stocksCompany__media--lg{
  width:44px;
  height:44px;
  border-radius:13px;
}
.stocksHoldingCard__meta{
  margin-top:3px;
  font-size:12px;
}
.stocksHoldingCard__grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;
}
.stocksHoldingStat{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:14px;
  background:rgba(255,255,255,0.8);
  padding:10px 11px;
  min-width:0;
}
.stocksHoldingStat__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksHoldingStat__value{
  margin-top:6px;
  font-size:18px;
  line-height:1.05;
  font-weight:900;
  color:#0f172a;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.stocksHoldingStat__sub{
  margin-top:6px;
  font-size:12px;
  color:#64748b;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.stocksHoldingStat--pl.isPos .stocksHoldingStat__value,
.stocksHoldingStat--pl.isPos .stocksHoldingStat__sub{color:#166534}
.stocksHoldingStat--pl.isNeg .stocksHoldingStat__value,
.stocksHoldingStat--pl.isNeg .stocksHoldingStat__sub{color:#b91c1c}
.stocksHoldingCard__side{
  border-left:1px solid rgba(148,163,184,0.16);
  padding-left:14px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:12px;
}
.stocksHoldingCard__safety{
  display:flex;
  justify-content:flex-end;
}
.stocksHoldingCard__range{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.stocks52Range--card{
  min-width:0;
}
.stocksActions--card{
  justify-content:flex-end;
}
.stocksHoldingCard--compact{
  padding:10px 12px;
  border-radius:16px;
  grid-template-columns:1fr;
  gap:0;
  box-shadow:0 10px 20px rgba(15,23,42,0.04);
}
.stocksHoldingCard--compact:hover{
  box-shadow:0 14px 24px rgba(37,99,235,0.07);
}
.stocksHoldingRow{
  display:grid;
  grid-template-columns:minmax(220px, 1.35fr) repeat(5, minmax(110px, .7fr)) minmax(120px, .7fr) auto;
  gap:10px;
  align-items:center;
}
.stocksCompany--compact{
  align-items:center;
}
.stocksHoldingCell{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:3px;
}
.stocksHoldingCell--identity{
  padding-right:4px;
}
.stocksHoldingCell__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksHoldingCell__value{
  font-size:14px;
  line-height:1.15;
  font-weight:900;
  color:#0f172a;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.stocksHoldingCell__sub{
  font-size:11px;
  line-height:1.35;
  color:#64748b;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.stocksHoldingCell__sub.isPos,
.stocksHoldingCell--pl.isPos .stocksHoldingCell__value,
.stocksHoldingCell--pl.isPos .stocksHoldingCell__sub{
  color:#166534;
}
.stocksHoldingCell__sub.isNeg,
.stocksHoldingCell--pl.isNeg .stocksHoldingCell__value,
.stocksHoldingCell--pl.isNeg .stocksHoldingCell__sub{
  color:#b91c1c;
}
.stocksHoldingCell--range{
  gap:5px;
}
.stocks52Range--compact{
  min-width:0;
  gap:4px;
}
.stocks52Range--compact .stocks52Range__trackWrap{
  height:14px;
}
.stocks52Range--compact .stocks52Range__vals{
  font-size:11px;
}
.stocksHoldingCell--status{
  align-items:flex-start;
}
.stocksActions--compact{
  justify-content:flex-end;
}
/* Stocks holdings tight mode */
.stocksHoldingCard--compact{
  padding:7px 10px;
  border-radius:14px;
  box-shadow:0 8px 16px rgba(15,23,42,0.035);
}
.stocksHoldingCard--compact:hover{
  box-shadow:0 10px 18px rgba(37,99,235,0.06);
}
.stocksHoldingRow{
  grid-template-columns:minmax(220px, 1.55fr) repeat(4, minmax(92px, .62fr)) minmax(150px, .95fr) auto;
  gap:8px;
}
.stocksCompany--compact .stocksCompany__media{
  width:32px;
  height:32px;
  border-radius:10px;
}
.stocksCompany--compact .stocksCompany__symbol{
  font-size:14px;
  line-height:1.05;
}
.stocksCompany--compact .stocksCompany__name{
  font-size:12px;
  line-height:1.2;
}
.stocksCompany--compact .stocksHoldingCard__meta{
  margin-top:1px;
  font-size:11px;
}
.stocksHoldingCell{
  gap:2px;
}
.stocksHoldingCell--identity{
  padding-right:2px;
}
.stocksHoldingCell__label{
  font-size:9px;
  letter-spacing:0.07em;
}
.stocksHoldingCell__value{
  font-size:13px;
  line-height:1.1;
}
.stocksHoldingCell__sub{
  font-size:10px;
  line-height:1.25;
}
.stocks52Range--compact{
  gap:3px;
}
.stocks52Range--compact .stocks52Range__trackWrap{
  height:10px;
}
.stocks52Range--compact .stocks52Range__vals{
  font-size:10px;
}
.stocksHoldingCell--market{
  gap:3px;
}
.stocksHoldingMarket{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.stocksHoldingCell--market .stocksSafety{
  min-width:88px;
  min-height:26px;
  padding:4px 8px;
  font-size:11px;
}
.stocksActions--compact{
  gap:6px;
}
.stocksActions--compact .stocksActionIcon{
  width:30px;
  height:30px;
  border-radius:9px;
  font-size:15px;
}
.stocksActions--compact .stocksActionIcon--danger{
  font-size:18px;
}
@media (max-width: 980px){
  .stocksPage .stocksHero__right{
    min-width:0;
    grid-template-columns:1fr;
    padding:10px;
  }
  .stocksPage .stocksViewTabs .segBtn,
  .stocksPage .stocksRange .segBtn{
    min-width:96px;
  }
  .stocksPage .stocksLineChart__stats{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .stocksHoldingCard{
    grid-template-columns:1fr;
  }
  .stocksHoldingRow{
    grid-template-columns:minmax(0, 1fr) repeat(3, minmax(0, 1fr));
    align-items:start;
  }
  .stocksHoldingCell--identity{
    grid-column:1 / -1;
    padding-right:0;
  }
  .stocksHoldingCell--market{
    grid-column:1 / -1;
  }
  .stocksHoldingCard__side{
    border-left:0;
    border-top:1px solid rgba(148,163,184,0.16);
    padding-left:0;
    padding-top:12px;
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    align-items:start;
  }
  .stocksHoldingCard__safety,
  .stocksActions--card{
    justify-content:flex-start;
  }
  .stocksHoldingCard__range{
    grid-column:1 / -1;
  }
}
@media (max-width: 700px){
  .stocksPage .stocksHero__left{
    padding-right:0;
  }
  .stocksPage .stocksKpi__card{
    min-height:108px;
    padding:14px;
  }
  .stocksPage .stocksKpi__value{
    font-size:34px;
  }
  .stocksPage .stocksTopBtn,
  .stocksPage .stocksAccountSel{
    min-height:44px;
    height:44px;
  }
  .stocksPage .stocksHeroMeta{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .stocksPage .stocksLineChart__stats,
  .stocksHoldingCard__grid,
  .stocksHoldingCard__side{
    grid-template-columns:1fr;
  }
  .stocksHoldingRow{
    grid-template-columns:1fr;
    gap:6px;
  }
  .stocksHoldingCard--compact{
    padding:8px 9px;
  }
  .stocksActions--compact .stocksActionIcon{
    width:28px;
    height:28px;
    font-size:14px;
  }
  .stocksActions--compact .stocksActionIcon--danger{
    font-size:17px;
  }
  .stocksActions--compact{
    justify-content:flex-start;
  }
}

/* Stocks ultra compact premium */
.stocksPage--compactUi{
  --stocks-holdings-grid:minmax(240px, 1.72fr) minmax(80px, .5fr) minmax(108px, .74fr) minmax(126px, .88fr) minmax(96px, .66fr) minmax(96px, .66fr) minmax(308px, 1.9fr) 84px;
  gap:10px;
}
.stocksPage--compactUi .stocksHero{
  padding:8px 10px;
  border-radius:14px;
  gap:10px;
  box-shadow:0 6px 14px rgba(15,23,42,0.035);
}
.stocksPage--compactUi .stocksHero::after{
  width:120px;
  height:120px;
  inset:auto -24px -28px auto;
  opacity:.45;
}
.stocksPage--compactUi .stocksHero__left{
  gap:4px;
  padding:2px 4px 0 2px;
}
.stocksPage--compactUi .stocksHero__left .panel__title{
  font-size:14px;
}
.stocksPage--compactUi .stocksHero__value{
  font-size:clamp(34px, 4vw, 52px);
  line-height:.98;
  text-shadow:none;
}
.stocksPage--compactUi .stocksHero__sub{
  font-size:12px;
  line-height:1.35;
  max-width:720px;
}
.stocksPage--compactUi .stocksExposure{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.stocksPage--compactUi .stocksExposureChip{
  min-height:28px;
  padding:0 10px;
  font-size:12px;
}
.stocksPage--compactUi .stocksHeroMeta{
  gap:6px;
}
.stocksPage--compactUi .stocksHeroMeta__chip{
  min-height:34px;
  padding:6px 10px;
  border-radius:12px;
  box-shadow:none;
}
.stocksPage--compactUi .stocksHeroMeta__label{
  font-size:9px;
}
.stocksPage--compactUi .stocksHeroMeta__value{
  font-size:13px;
}
.stocksPage--compactUi .stocksHero__right{
  min-width:400px;
  gap:6px;
  padding:6px;
  border-radius:14px;
}
.stocksPage--compactUi .stocksAccountSel{
  min-height:38px;
  border-radius:12px;
  box-shadow:none;
}
.stocksPage--compactUi .stocksTopBtn{
  height:38px;
  border-radius:12px;
  box-shadow:none;
  font-size:13px;
}
.stocksPage--compactUi .stocksTopDeck{
  padding:7px 9px;
  border-radius:14px;
}
.stocksPage--compactUi .stocksTopDeck__tabs{
  gap:6px;
}
.stocksPage--compactUi .stocksViewTabs,
.stocksPage--compactUi .stocksRange{
  padding:4px;
  border-radius:12px;
}
.stocksPage--compactUi .stocksViewTabs .segBtn,
.stocksPage--compactUi .stocksRange .segBtn{
  min-width:88px;
  height:34px;
  font-size:13px;
  font-weight:780;
}
.stocksPage--compactUi .stocksStatus,
.stocksPage--compactUi .stocksTopPill{
  min-height:30px;
  padding:0 10px;
  font-size:11px;
  box-shadow:none;
}
.stocksPage--compactUi .stocksKpi--inline{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.stocksPage--compactUi .stocksKpi--inline .stocksKpi__card{
  min-height:0;
  padding:6px 9px;
  border-radius:12px;
  display:grid;
  grid-auto-flow:column;
  grid-template-columns:auto auto auto;
  gap:8px;
  align-items:center;
  width:auto;
  box-shadow:none;
}
.stocksPage--compactUi .stocksKpi--inline .stocksKpi__card::before{
  display:none;
}
.stocksPage--compactUi .stocksKpi--inline .stocksKpi__label{
  font-size:9px;
  white-space:nowrap;
}
.stocksPage--compactUi .stocksKpi--inline .stocksKpi__value{
  margin-top:0;
  font-size:13px;
  line-height:1;
  letter-spacing:-0.01em;
}
.stocksPage--compactUi .stocksKpi--inline .stocksKpi__card .muted{
  margin-top:0;
  font-size:10px;
  white-space:nowrap;
}
.stocksPage--compactUi .stocksCard{
  border-radius:13px;
  padding:9px;
  box-shadow:0 6px 14px rgba(15,23,42,0.035);
}
.stocksPage--compactUi .stocksCard--chart{
  padding:9px;
}
.stocksPage--compactUi .stocksCard__head{
  margin-bottom:6px;
}
.stocksPage--compactUi .stocksCard__title{
  font-size:13px;
}
.stocksPage--compactUi .stocksLineChart{
  gap:8px;
}
.stocksPage--compactUi .stocksLineChart__trend{
  min-height:30px;
  padding:0 10px;
  font-size:13px;
}
.stocksPage--compactUi .stocksLineChart__meta{
  font-size:11px;
}
.stocksPage--compactUi .stocksLineChart__stats{
  gap:6px;
}
.stocksPage--compactUi .stocksLineChart__stat{
  padding:6px 8px;
  border-radius:10px;
}
.stocksPage--compactUi .stocksLineChart__statLabel{
  font-size:9px;
}
.stocksPage--compactUi .stocksLineChart__statValue{
  font-size:12px;
}
.stocksPage--compactUi .stocksLineChart__svgWrap{
  height:184px;
  border-radius:12px;
  padding:4px 2px 1px;
}
.stocksPage--compactUi .stocksHoldingsList{
  gap:4px;
  padding:5px 8px;
  border:1px solid rgba(148,163,184,0.14);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
}
.stocksPage--compactUi .stocksHoldingsHead{
  display:grid;
  grid-template-columns:var(--stocks-holdings-grid);
  gap:10px;
  align-items:center;
  padding:0 2px 5px;
  border-bottom:1px solid rgba(148,163,184,0.14);
}
.stocksPage--compactUi .stocksHoldingsHead__cell{
  font-size:8.5px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksPage--compactUi .stocksHoldingsHead__cell--market{
  padding-inline:8px;
}
.stocksPage--compactUi .stocksMarketHead{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
  width:100%;
}
.stocksPage--compactUi .stocksMarketHead__title{
  font:inherit;
  color:inherit;
}
.stocksPage--compactUi .stocksMarketHead__meta{
  width:100%;
  display:grid;
  grid-template-columns:92px minmax(148px, 1fr);
  align-items:center;
  gap:12px;
  padding-inline:2px;
}
.stocksPage--compactUi .stocksMarketHead__metaItem{
  font-size:7px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#94a3b8;
  text-align:center;
}
.stocksPage--compactUi .stocksHoldingsHead__cell:nth-child(2),
.stocksPage--compactUi .stocksHoldingsHead__cell:nth-child(3),
.stocksPage--compactUi .stocksHoldingsHead__cell:nth-child(4),
.stocksPage--compactUi .stocksHoldingsHead__cell:nth-child(5),
.stocksPage--compactUi .stocksHoldingsHead__cell:nth-child(6),
.stocksPage--compactUi .stocksHoldingsHead__cell:nth-child(7),
.stocksPage--compactUi .stocksHoldingsHead__cell:nth-child(8){
  text-align:center;
}
.stocksPage--compactUi .stocksHoldingsHead__cell--actions{
  text-align:center;
}
.stocksPage--compactUi .stocksHoldingRow{
  grid-template-columns:var(--stocks-holdings-grid);
  gap:8px;
  align-items:center;
}
.stocksPage--compactUi .stocksHoldingCard{
  border-radius:0;
  border:0;
  background:transparent;
  box-shadow:none;
}
.stocksPage--compactUi .stocksHoldingCard--compact{
  padding:4px 2px;
  border-top:1px solid rgba(148,163,184,0.10);
}
.stocksPage--compactUi .stocksCompany--compact .stocksCompany__media{
  width:28px;
  height:28px;
}
.stocksPage--compactUi .stocksCompany--compact .stocksCompany__symbol{
  font-size:13px;
}
.stocksPage--compactUi .stocksCompany--compact .stocksCompany__name{
  font-size:11px;
  line-height:1.15;
}
.stocksPage--compactUi .stocksCompany--compact .stocksHoldingCard__meta{
  margin-top:0;
  font-size:10px;
}
.stocksPage--compactUi .stocksCompany--compact .stocksCompany__text{
  display:flex;
  flex-direction:column;
  gap:1px;
}
.stocksPage--compactUi .stocksHoldingCell{
  gap:1px;
  justify-content:center;
}
.stocksPage--compactUi .stocksHoldingRow > .stocksHoldingCell:not(.stocksHoldingCell--identity):not(.stocksHoldingCell--market){
  align-items:center;
  text-align:center;
}
.stocksPage--compactUi .stocksHoldingCell__label{
  display:none;
}
.stocksPage--compactUi .stocksHoldingCell__value{
  font-size:12px;
  line-height:1.1;
}
.stocksPage--compactUi .stocksHoldingCell__sub{
  font-size:10px;
  line-height:1.2;
}
.stocksPage--compactUi .stocksHoldingRow > .stocksHoldingCell:not(.stocksHoldingCell--identity):not(.stocksHoldingCell--market) .stocksHoldingCell__sub{
  display:none;
}
.stocksPage--compactUi .stocksHoldingCell--pl,
.stocksPage--compactUi .stocksHoldingRow > .stocksHoldingCell:nth-child(6){
  gap:0;
}
.stocksPage--compactUi .stocksHoldingCell--pl .stocksHoldingCell__value,
.stocksPage--compactUi .stocksHoldingRow > .stocksHoldingCell:nth-child(6) .stocksHoldingCell__value{
  font-size:11.5px;
}
.stocksPage--compactUi .stocksHoldingCell--pl .stocksHoldingCell__sub,
.stocksPage--compactUi .stocksHoldingRow > .stocksHoldingCell:nth-child(6) .stocksHoldingCell__sub{
  font-size:9px;
  line-height:1.05;
}
.stocksPage--compactUi .stocksHoldingCell--shares .stocksHoldingCell__value{
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum" 1, "lnum" 1;
  letter-spacing:-0.01em;
  font-size:12.5px;
  font-weight:900;
}
.stocksPage--compactUi .stocksHoldingCell--market{
  align-items:center;
  text-align:center;
  justify-content:center;
  padding-inline:8px;
}
.stocksPage--compactUi .stocksHoldingMarket{
  display:grid;
  grid-template-columns:auto minmax(0, 1fr);
  align-items:center;
  gap:10px;
  min-width:0;
  justify-items:center;
}
.stocksPage--compactUi .stocksHoldingMarket__rangeLine{
  display:grid;
  grid-template-columns:auto minmax(138px, 1fr) auto;
  align-items:center;
  gap:8px;
  width:100%;
}
.stocksPage--compactUi .stocksHoldingCell--market .stocksSafety{
  min-width:92px;
  min-height:18px;
  padding:1px 7px;
  font-size:8px;
  letter-spacing:0.05em;
  border-radius:999px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.7);
}
.stocksPage--compactUi .stocks52Range--compact{
  gap:0;
  min-width:0;
  padding:2px 6px;
  border:1px solid rgba(148,163,184,0.12);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.9));
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__trackWrap{
  height:7px;
  padding-top:0;
  position:relative;
  display:flex;
  align-items:center;
}
.stocksPage--compactUi .stocks52Range--market{
  padding:2px 6px;
  border-color:rgba(148,163,184,0.14);
  background:linear-gradient(90deg, rgba(248,250,252,0.96) 0%, rgba(239,246,255,0.94) 50%, rgba(248,250,252,0.96) 100%);
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__trackWrap::before,
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__trackWrap::after{
  content:'';
  position:absolute;
  top:50%;
  width:4px;
  height:4px;
  border-radius:999px;
  background:rgba(148,163,184,0.55);
  transform:translateY(-50%);
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__trackWrap::before{
  left:0;
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__trackWrap::after{
  right:0;
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__track{
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(203,213,225,0.9) 0%, rgba(147,197,253,0.68) 52%, rgba(203,213,225,0.9) 100%);
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__pin{
  top:50%;
  width:9px;
  height:9px;
  margin-top:-4.5px;
  background:#2563eb;
  box-shadow:0 0 0 2px rgba(239,246,255,0.96), 0 2px 6px rgba(37,99,235,0.28);
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__pin::after{
  display:none;
}
.stocksPage--compactUi .stocks52Range--compact .stocks52Range__vals{
  display:none;
}
.stocksPage--compactUi .stocksHoldingMarket__val{
  font-size:7px;
  line-height:1;
  font-weight:700;
  color:#64748b;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
  letter-spacing:0.01em;
}
.stocksPage--compactUi .stocksHoldingMarket__empty{
  min-height:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 8px;
  border:1px dashed rgba(148,163,184,0.18);
  border-radius:999px;
  font-size:9px;
  color:#64748b;
  background:rgba(248,250,252,0.8);
}
.stocksPage--compactUi .stocksActions--compact .stocksActionIcon{
  width:24px;
  height:24px;
  font-size:12px;
  border-radius:8px;
  opacity:1;
  transform:none;
  pointer-events:auto;
  transition:opacity .14s ease, transform .14s ease, border-color .14s ease, background-color .14s ease;
}
.stocksPage--compactUi .stocksActions--compact{
  justify-content:center;
  gap:6px;
}
.stocksPage--compactUi .stocksActions--compact .stocksActionIcon--danger{
  font-size:14px;
}
@media (max-width: 980px){
  .stocksPage--compactUi{
    --stocks-holdings-grid:minmax(0, 1fr) repeat(4, minmax(0, 1fr));
  }
  .stocksPage--compactUi .stocksHero{
    padding:9px 10px;
  }
  .stocksPage--compactUi .stocksHero__right{
    min-width:0;
    grid-template-columns:1fr;
    padding:8px;
  }
  .stocksPage--compactUi .stocksHoldingsHead{
    display:none;
  }
  .stocksPage--compactUi .stocksHoldingsList{
    padding:0;
    border:0;
    background:transparent;
  }
  .stocksPage--compactUi .stocksHoldingCell__label{
    display:block;
  }
  .stocksPage--compactUi .stocksHoldingRow > .stocksHoldingCell:not(.stocksHoldingCell--identity):not(.stocksHoldingCell--market) .stocksHoldingCell__sub{
    display:block;
  }
  .stocksPage--compactUi .stocksHoldingRow > .stocksHoldingCell:not(.stocksHoldingCell--identity):not(.stocksHoldingCell--market){
    align-items:flex-start;
    text-align:left;
  }
  .stocksPage--compactUi .stocksHoldingCell--market{
    align-items:flex-start;
    text-align:left;
  }
  .stocksPage--compactUi .stocksHoldingMarket{
    justify-items:stretch;
    grid-template-columns:1fr;
    gap:4px;
  }
  .stocksPage--compactUi .stocksHoldingMarket__rangeLine{
    grid-template-columns:auto minmax(0, 1fr) auto;
  }
  .stocksPage--compactUi .stocksActions--compact .stocksActionIcon{
    opacity:1;
    transform:none;
    pointer-events:auto;
  }
}
@media (max-width: 700px){
  .stocksPage--compactUi .stocksHero__value{
    font-size:30px;
  }
  .stocksPage--compactUi .stocksHeroMeta{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .stocksPage--compactUi .stocksTopBtn,
  .stocksPage--compactUi .stocksAccountSel{
    min-height:38px;
    height:38px;
  }
  .stocksPage--compactUi .stocksViewTabs .segBtn,
  .stocksPage--compactUi .stocksRange .segBtn{
    min-width:72px;
    height:32px;
    font-size:12px;
  }
  .stocksPage--compactUi .stocksKpi__card{
    min-height:0;
    padding:6px 8px;
  }
  .stocksPage--compactUi .stocksLineChart__svgWrap{
    height:154px;
  }
  .stocksPage--compactUi .stocksHoldingCard--compact{
    padding:6px 0;
  }
}

/* Dashboard */
.dashboardPage{
  display:grid;
  gap:10px;
  position:relative;
  isolation:isolate;
}
.dashboardPage::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:
    radial-gradient(circle at top left, rgba(59,130,246,0.06), transparent 28%),
    radial-gradient(circle at top right, rgba(15,118,110,0.05), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0));
  z-index:-1;
}
.dashboardHead{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:12px;
  align-items:center;
  padding-bottom:8px;
  border-bottom:1px solid rgba(226,232,240,0.75);
}
.dashboardHead .panel__title{
  margin:0;
  font-size:17px;
  line-height:1;
  letter-spacing:-0.02em;
}
.dashboardHead__right{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:flex-end;
  margin-left:0;
}
.dashboardYearWrap{
  display:flex;
  flex-direction:row;
  gap:10px;
  align-items:center;
  padding:0;
}
.dashboardYearWrap .muted{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-weight:800;
  white-space:nowrap;
}
.dashboardYearSelect{
  width:108px;
  min-height:38px;
}
.dashboardSectionTitle{
  margin:0;
  display:flex;
  align-items:center;
  gap:10px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:#7b8aa1;
  font-weight:800;
  line-height:1;
}
.dashboardSectionTitle::after{
  content:"";
  height:1px;
  flex:1 1 auto;
  background:linear-gradient(90deg, rgba(191,219,254,0.8), rgba(226,232,240,0.2));
}

.dashboardHeroGrid{
  display:grid;
  grid-template-columns:1.16fr 0.96fr 1fr 1.14fr;
  gap:10px;
}
.dashboardHeroCard{
  border:1px solid rgba(191,219,254,0.58);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,250,252,0.96));
  box-shadow:0 8px 18px rgba(148,163,184,0.08);
  min-height:74px;
  padding:10px 12px 9px;
  text-align:center;
  font:inherit;
  color:inherit;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:center;
  position:relative;
  overflow:hidden;
  --dashboard-hero-accent:rgba(148,163,184,0.7);
}
.dashboardHeroCard::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:3px;
  background:linear-gradient(90deg, var(--dashboard-hero-accent), rgba(255,255,255,0));
}
.dashboardHeroCard::after{
  content:"";
  position:absolute;
  inset:auto -18% -42% auto;
  width:124px;
  height:124px;
  border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb, var(--dashboard-hero-accent) 18%, transparent), transparent 70%);
  pointer-events:none;
}
button.dashboardHeroCard{
  cursor:pointer;
}
button.dashboardHeroCard:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 24px rgba(148,163,184,0.13);
  border-color:rgba(96,165,250,0.48);
}
button.dashboardHeroCard:focus-visible{
  outline:2px solid rgba(59,130,246,0.28);
  outline-offset:2px;
}
.dashboardHeroCard.iswarn{
  border-color:rgba(251,191,36,0.45);
  --dashboard-hero-accent:rgba(217,119,6,0.88);
}
.dashboardHeroCard.isdanger{
  border-color:rgba(248,113,113,0.38);
  --dashboard-hero-accent:rgba(220,38,38,0.88);
}
.dashboardHeroCard.issuccess{
  border-color:rgba(52,211,153,0.34);
  --dashboard-hero-accent:rgba(15,118,110,0.82);
}
.dashboardHeroCard.isinfo{
  border-color:rgba(125,211,252,0.4);
  --dashboard-hero-accent:rgba(37,99,235,0.8);
}
.dashboardHeroCard__label{
  font-size:10px;
  color:#60738f;
  text-transform:uppercase;
  letter-spacing:0.11em;
  font-weight:800;
}
.dashboardHeroCard__value{
  margin-top:4px;
  font-size:16px;
  line-height:1.06;
  font-weight:850;
  color:#0f172a;
  max-width:none;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  text-align:center;
}
.dashboardHeroCard__value.isNumeric{
  font-size:19px;
  letter-spacing:-0.03em;
  display:block;
}
.dashboardHeroCard__value.isLong{
  font-size:13px;
  line-height:1.12;
  -webkit-line-clamp:3;
}
.dashboardHeroCard__sub{
  margin-top:3px;
  font-size:9.5px;
  line-height:1.25;
  color:#6b7b91;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
.dashboardHeroCard:not(:has(.dashboardHeroCard__sub)){
  justify-content:center;
}

.dashboardAction{
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  padding:0;
}
.dashboardAction__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.dashboardAction__btnSecondary{
  height:32px;
  padding:0 10px;
  font-size:11px;
}
.dashboardAction__label{
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-size:10px;
  font-weight:800;
}
.dashboardAction__grid{
  margin-top:0;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  align-items:stretch;
}
.dashboardAction__grid .dashboardModule{
  background:rgba(255,255,255,0.88);
  padding:8px 10px;
  box-shadow:0 8px 18px rgba(148,163,184,0.07);
  height:100%;
}
.dashboardAction__title{
  margin-top:6px;
  font-size:23px;
  line-height:1.08;
  font-weight:840;
  color:#0f172a;
  max-width:24ch;
}
.dashboardAction__reason{
  margin-top:6px;
  font-size:14px;
  max-width:54ch;
}
.dashboardAction__btn{
  margin-top:0;
}

.dashboardChartGrid,
.dashboardModuleGrid{
  display:grid;
  gap:8px;
  align-items:stretch;
}
.dashboardChartGrid{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}
.dashboardModuleGrid{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}
.dashboardModule{
  border:1px solid rgba(191,219,254,0.56);
  border-radius:14px;
  background:rgba(255,255,255,0.96);
  box-shadow:0 8px 18px rgba(148,163,184,0.07);
  padding:8px 10px;
  position:relative;
  overflow:hidden;
  --dashboard-module-tint:rgba(148,163,184,0.12);
}
.dashboardModule::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:100%;
  pointer-events:none;
  background:
    radial-gradient(circle at top right, var(--dashboard-module-tint), transparent 42%);
  opacity:.8;
}
.dashboardModule--chart{
  min-height:0;
}
.dashboardModule--action{
  background:linear-gradient(135deg, rgba(239,246,255,0.96), rgba(255,255,255,0.98));
}
.dashboardModuleGrid .dashboardModule,
.dashboardChartGrid .dashboardModule{
  min-height:0;
  height:100%;
}
.dashboardModule__head{
  display:flex;
  justify-content:space-between;
  gap:6px;
  align-items:flex-start;
  position:relative;
  z-index:1;
}
.dashboardModule__title{
  font-size:11.5px;
  line-height:1.15;
  font-weight:820;
  color:#0f172a;
  letter-spacing:-0.01em;
}
.dashboardModule__open{
  height:24px;
  padding:0 9px;
  font-size:9.5px;
  border-radius:999px;
  border-color:rgba(203,213,225,0.9);
  background:rgba(255,255,255,0.72);
  color:#334155;
  box-shadow:none;
  transition:border-color .16s ease, background-color .16s ease, color .16s ease, transform .16s ease;
}
.dashboardModule__open:hover{
  border-color:rgba(148,163,184,0.95);
  background:rgba(248,250,252,0.96);
  color:#0f172a;
  transform:translateY(-1px);
}
.dashboardModule__open:focus-visible{
  outline:2px solid rgba(59,130,246,0.18);
  outline-offset:2px;
}
.dashboardModule__body{
  margin-top:3px;
  display:grid;
  gap:0;
  position:relative;
  z-index:1;
}
.dashboardModule__meta{
  margin-top:3px;
  font-size:10px;
  position:relative;
  z-index:1;
}

.dashboardMetric{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  font-size:10px;
  padding:2px 0;
}
.dashboardMetric + .dashboardMetric{
  border-top:1px solid rgba(226,232,240,0.76);
}
.dashboardMetric__value{
  font-weight:760;
  color:#0f172a;
  text-align:right;
}
.dashboardMetric__label{
  color:#52647d;
}

.dashboardSpark{
  margin-top:8px;
  border:1px solid rgba(191,219,254,0.5);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(247,250,255,0.96), rgba(255,255,255,0.94));
  padding:8px 10px 6px;
}
.dashboardSpark__svg{
  display:block;
  width:100%;
  height:34px;
}
.dashboardSpark__svg--large{
  height:52px;
}
.dashboardSpark__line{
  vector-effect:non-scaling-stroke;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.dashboardSpark__meta{
  margin-top:2px;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.05em;
}
.dashboardSpark.isUp .dashboardSpark__meta{ color:#0f766e; }
.dashboardSpark.isDown .dashboardSpark__meta{ color:#b45309; }
.dashboardSpark--empty{
  margin-top:8px;
  border:1px dashed rgba(148,163,184,0.28);
  border-radius:12px;
  padding:10px;
  font-size:12px;
}

.dashboardDonut{
  margin-top:3px;
  display:grid;
  grid-template-columns:114px minmax(0, 1fr);
  gap:18px;
  align-items:center;
  position:relative;
  z-index:1;
}
.dashboardDonut__chart{
  position:relative;
  width:114px;
  height:114px;
  border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(226,232,240,0.76);
}
.dashboardDonut__chart::before{
  content:"";
  position:absolute;
  inset:17px;
  border-radius:50%;
  background:rgba(255,255,255,0.97);
  box-shadow:0 0 0 1px rgba(226,232,240,0.72);
}
.dashboardDonut__center{
  position:absolute;
  inset:17px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  text-align:center;
  pointer-events:none;
  z-index:1;
}
.dashboardDonut__label{
  font-size:8.5px;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:#64748b;
  font-weight:800;
}
.dashboardDonut__value{
  margin-top:2px;
  font-size:9px;
  line-height:1.02;
  font-weight:850;
  color:#0f172a;
  max-width:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  letter-spacing:-0.02em;
}
.dashboardDonut__legend{
  display:grid;
  gap:6px;
  align-self:center;
  width:auto;
  padding-top:2px;
}
.dashboardLegendRow{
  display:grid;
  grid-template-columns:auto minmax(0, 1fr) auto;
  gap:6px;
  align-items:center;
  font-size:9.5px;
}
.dashboardLegendRow__dot{
  width:9px;
  height:9px;
  border-radius:999px;
}
.dashboardLegendRow__name{
  color:#334155;
  font-weight:700;
}
.dashboardLegendRow__value{
  font-weight:760;
  color:#0f172a;
  text-align:right;
  justify-self:end;
}

.dashboardProgressList{
  margin-top:3px;
  display:grid;
  gap:4px;
}
.dashboardProgressRow__top{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  font-size:10px;
}
.dashboardProgressRow__label{
  color:#334155;
}
.dashboardProgressRow__value{
  font-weight:760;
  color:#0f172a;
}
.dashboardProgressRow__track{
  margin-top:3px;
  height:4px;
  border-radius:999px;
  background:rgba(226,232,240,0.78);
  overflow:hidden;
}
.dashboardProgressRow__bar{
  height:100%;
  border-radius:999px;
  background:#2563eb;
}
.dashboardProgressRow__bar.iswarn{ background:#d97706; }
.dashboardProgressRow__bar.isdanger{ background:#dc2626; }
.dashboardProgressRow__bar.isinfo{ background:#0891b2; }
.dashboardProgressRow__bar.isneutral{ background:#94a3b8; }

.dashboardPulse{
  margin-top:3px;
  display:grid;
  gap:8px;
  position:relative;
  z-index:1;
}
.dashboardPulse__bars{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;
  align-items:start;
  min-height:118px;
}
.dashboardPulseBar{
  display:grid;
  justify-items:center;
  gap:6px;
}
.dashboardPulseBar__track{
  position:relative;
  width:100%;
  max-width:48px;
  height:74px;
  border-radius:16px;
  background:rgba(226,232,240,0.78);
  overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(203,213,225,0.66);
}
.dashboardPulseBar__fill{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(37,99,235,0.52), rgba(37,99,235,0.92));
}
.dashboardPulseBar__track.iswarn .dashboardPulseBar__fill{
  background:linear-gradient(180deg, rgba(245,158,11,0.48), rgba(217,119,6,0.9));
}
.dashboardPulseBar__track.isdanger .dashboardPulseBar__fill{
  background:linear-gradient(180deg, rgba(248,113,113,0.48), rgba(220,38,38,0.9));
}
.dashboardPulseBar__track.issuccess .dashboardPulseBar__fill{
  background:linear-gradient(180deg, rgba(52,211,153,0.44), rgba(15,118,110,0.88));
}
.dashboardPulseBar__track.isinfo .dashboardPulseBar__fill{
  background:linear-gradient(180deg, rgba(56,189,248,0.44), rgba(8,145,178,0.88));
}
.dashboardPulseBar__track.isneutral .dashboardPulseBar__fill{
  background:linear-gradient(180deg, rgba(203,213,225,0.52), rgba(100,116,139,0.88));
}
.dashboardPulseBar__value{
  font-size:9.5px;
  font-weight:760;
  color:#0f172a;
  text-align:center;
  line-height:1.1;
  min-height:22px;
  display:flex;
  align-items:flex-start;
  justify-content:center;
}
.dashboardPulseBar__label{
  font-size:8px;
  text-transform:uppercase;
  letter-spacing:0.09em;
  color:#64748b;
  font-weight:800;
  text-align:center;
  min-height:18px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
}
.dashboardPulse__meta{
  font-size:9.5px;
  color:#6b7b91;
}

.dashboardPressure{
  margin-top:3px;
  display:grid;
  gap:7px;
  position:relative;
  z-index:1;
}
.dashboardPressure__bars{
  display:grid;
  gap:7px;
  max-width:560px;
  width:100%;
  margin:16px auto 0;
  align-content:center;
}
.dashboardPressureBar{
  display:grid;
  gap:4px;
}
.dashboardPressureBar__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.dashboardPressureBar__label{
  font-size:10px;
  font-weight:760;
  color:#334155;
}
.dashboardPressureBar__value{
  font-size:10px;
  font-weight:800;
  color:#0f172a;
  text-align:right;
  white-space:nowrap;
}
.dashboardPressureBar__track{
  position:relative;
  height:8px;
  border-radius:999px;
  background:rgba(226,232,240,0.78);
  overflow:hidden;
}
.dashboardPressureBar__fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(37,99,235,0.44), rgba(37,99,235,0.92));
}
.dashboardPressureBar__track.iswarn .dashboardPressureBar__fill{
  background:linear-gradient(90deg, rgba(245,158,11,0.42), rgba(217,119,6,0.92));
}
.dashboardPressureBar__track.isdanger .dashboardPressureBar__fill{
  background:linear-gradient(90deg, rgba(248,113,113,0.44), rgba(220,38,38,0.92));
}
.dashboardPressureBar__track.isinfo .dashboardPressureBar__fill{
  background:linear-gradient(90deg, rgba(56,189,248,0.42), rgba(8,145,178,0.92));
}
.dashboardPressureBar__track.isneutral .dashboardPressureBar__fill{
  background:linear-gradient(90deg, rgba(203,213,225,0.52), rgba(100,116,139,0.92));
}

.dashboardList{
  margin-top:3px;
  display:grid;
  gap:2px;
  position:relative;
  z-index:1;
}
.dashboardListRow{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:8px;
  align-items:center;
  padding:4px 0;
  border-top:1px solid rgba(226,232,240,0.8);
}
.dashboardListRow:first-child{
  border-top:0;
  padding-top:0;
}
.dashboardListRow__title{
  font-size:10px;
  font-weight:760;
  color:#0f172a;
}
.dashboardListRow__meta{
  margin-top:1px;
  font-size:8px;
}
.dashboardListRow__value{
  font-size:9px;
  font-weight:760;
  color:#0f172a;
  text-align:right;
  white-space:nowrap;
}
.dashboardModule--monitor .dashboardListRow__value{
  min-width:74px;
}
.dashboardModule--distribution .dashboardDonut{
  align-items:center;
  justify-content:center;
  max-width:360px;
  margin:8px auto 0;
}
.dashboardModule--distribution .dashboardDonut__legend{
  min-width:0;
  justify-self:center;
  align-content:center;
}
.dashboardModule--distribution .dashboardLegendRow{
  padding:1px 0;
  grid-template-columns:auto auto auto;
  justify-content:center;
  min-width:150px;
}
.dashboardModule--distribution .dashboardLegendRow__value{
  justify-self:start;
  text-align:left;
}
.dashboardModule--distribution .dashboardModule__head{
  align-items:center;
}
.dashboardAction__grid .dashboardModule:nth-child(1){
  --dashboard-module-tint:rgba(37,99,235,0.08);
}
.dashboardAction__grid .dashboardModule:nth-child(2){
  --dashboard-module-tint:rgba(15,118,110,0.08);
}
.dashboardAction__grid .dashboardModule:nth-child(3){
  --dashboard-module-tint:rgba(245,158,11,0.08);
}
.dashboardModule--distribution{
  --dashboard-module-tint:rgba(37,99,235,0.10);
}
.dashboardModule--pressure{
  --dashboard-module-tint:rgba(245,158,11,0.10);
}
.dashboardModule--signals{
  --dashboard-module-tint:rgba(8,145,178,0.10);
}
.dashboardModule--plan{
  --dashboard-module-tint:rgba(14,116,144,0.08);
}
.dashboardModule--ath{
  --dashboard-module-tint:rgba(59,130,246,0.08);
}
.dashboardModule--monitor{
  --dashboard-module-tint:rgba(100,116,139,0.08);
}
.dashboardModule--distribution .dashboardModule__head,
.dashboardModule--pressure .dashboardModule__head,
.dashboardModule--signals .dashboardModule__head,
.dashboardModule--plan .dashboardModule__head,
.dashboardModule--ath .dashboardModule__head,
.dashboardModule--monitor .dashboardModule__head{
  margin-bottom:2px;
}
.dashboardModule--pressure .dashboardModule__head{
  align-items:center;
}
.dashboardModule--spotlight{
  min-height:102px;
}
.dashboardModule--plan,
.dashboardModule--ath,
.dashboardModule--monitor{
  min-height:0;
}
.dashboardListEmpty{
  font-size:13px;
  padding:6px 0 2px;
}

@media (max-width: 1180px){
  .dashboardHeroGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .dashboardAction__grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .dashboardChartGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .dashboardModuleGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 900px){
  .dashboardChartGrid,
  .dashboardDonut{
    grid-template-columns:1fr;
  }
  .dashboardPulse__bars{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .dashboardModuleGrid{
    grid-template-columns:1fr;
  }
}
@media (max-width: 760px){
  .dashboardHead__right{
    width:100%;
    justify-content:flex-start;
  }
  .dashboardYearWrap{
    flex:1 1 auto;
    flex-direction:column;
    align-items:flex-start;
  }
  .dashboardHeroGrid,
  .dashboardAction__grid,
  .dashboardChartGrid,
  .dashboardModuleGrid{
    grid-template-columns:1fr;
  }
  .dashboardHeroCard{
    grid-column:auto;
    min-height:0;
  }
  .dashboardDonut__chart{
    margin:0 auto;
  }
}

/* Stocks premium continuation */
.stocksModal--shell{
  width:min(940px, 100%);
  margin:0 auto;
  gap:12px;
}
.stocksDrawer--premium{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.stocksCompany__media--xl{
  width:56px;
  height:56px;
  border-radius:16px;
}
.stocksDrawerHero{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:14px;
  padding:14px;
  border:1px solid rgba(148,163,184,0.18);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,248,255,0.92));
}
.stocksDrawerHero__identity{
  min-width:0;
}
.stocksDrawerHero__eyebrow{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksDrawerHero__title{
  margin-top:4px;
  font-size:30px;
  line-height:1;
  font-weight:900;
  color:#0f172a;
}
.stocksDrawerHero__name{
  margin-top:5px;
  font-size:14px;
  font-weight:700;
  color:#334155;
}
.stocksDrawerHero__meta{
  margin-top:6px;
  font-size:12px;
  color:#64748b;
}
.stocksDrawerHero__side{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:space-between;
  gap:8px;
  text-align:right;
}
.stocksDrawerHero__pl{
  font-size:28px;
  line-height:1;
  font-weight:900;
  letter-spacing:-0.03em;
}
.stocksDrawerHero__pl.isPos{color:#166534}
.stocksDrawerHero__pl.isNeg{color:#b91c1c}
.stocksDrawerHero__plSub{
  font-size:12px;
  color:#64748b;
}
.stocksDrawerMetricGrid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;
}
.stocksDrawerMetricGrid--ledger{
  grid-template-columns:repeat(3, minmax(0, 1fr));
  margin-bottom:12px;
}
.stocksDrawerMetric{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:16px;
  background:rgba(255,255,255,0.88);
  padding:12px;
  min-width:0;
}
.stocksDrawerMetric__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksDrawerMetric__value{
  margin-top:6px;
  font-size:18px;
  line-height:1.1;
  font-weight:900;
  color:#0f172a;
}
.stocksDrawerMetric__sub{
  margin-top:6px;
  min-height:16px;
  font-size:12px;
  color:#64748b;
}
.stocksDrawerMetric.isPos .stocksDrawerMetric__value,
.stocksDrawerMetric.isPos .stocksDrawerMetric__sub{color:#166534}
.stocksDrawerMetric.isNeg .stocksDrawerMetric__value,
.stocksDrawerMetric.isNeg .stocksDrawerMetric__sub{color:#b91c1c}
.stocksDrawerDeck{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}
.stocksDrawerPanel{
  border-radius:18px;
  padding:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.9));
  border:1px solid rgba(148,163,184,0.16);
}
.stocksDrawerPanel__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
.stocksDrawerPanel__meta{
  margin-bottom:8px;
}
.stocksDrawerPanel__chip{
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.18);
  background:rgba(255,255,255,0.86);
  display:inline-flex;
  align-items:center;
  font-size:11px;
  font-weight:800;
  color:#334155;
}
.stocksDrawerEmpty{
  padding:10px 12px;
  border-radius:12px;
  background:rgba(248,250,252,0.8);
  border:1px dashed rgba(148,163,184,0.22);
}
.stocksProfileFacts{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}
.stocksProfileFact{
  border:1px solid rgba(148,163,184,0.14);
  border-radius:14px;
  background:rgba(255,255,255,0.82);
  padding:10px 11px;
}
.stocksProfileFact__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksProfileFact__value{
  margin-top:6px;
  font-size:14px;
  line-height:1.35;
  font-weight:800;
  color:#0f172a;
  word-break:break-word;
}
.stocksNextDivList{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:10px;
}
.stocksNextDivItem{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:8px 10px;
  border:1px solid rgba(148,163,184,0.14);
  border-radius:12px;
  background:rgba(255,255,255,0.74);
}
.stocksNextDivItem__date{
  font-size:12px;
  font-weight:800;
  color:#334155;
  white-space:nowrap;
}
.stocksNextDivItem__main{
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.stocksNextDivItem__value{
  font-size:12px;
  font-weight:800;
  color:#0f172a;
  white-space:nowrap;
}
.stocksNextDivItem__stock{
  font-size:12px;
  color:#475569;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:320px;
}
.stocksNextDivItem--wide{
  gap:12px;
}
.stocksNextDivList--wide .stocksNextDivItem__main{
  justify-content:space-between;
  width:100%;
}
.stocksInfoNote--cut{
  color:#9f1239;
  background:rgba(244,63,94,0.08);
  border-color:rgba(244,63,94,0.18);
}
.stocksEmptyState{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(148,163,184,0.18);
  border-radius:18px;
  padding:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,248,255,0.92));
  box-shadow:0 14px 28px rgba(15,23,42,0.04);
}
.stocksEmptyState::after{
  content:'';
  position:absolute;
  inset:auto -24px -30px auto;
  width:120px;
  height:120px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(59,130,246,0.10) 0%, rgba(59,130,246,0.02) 48%, transparent 70%);
  pointer-events:none;
}
.stocksEmptyState--danger{
  border-color:rgba(239,68,68,0.20);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(254,242,242,0.94));
}
.stocksEmptyState__eyebrow{
  position:relative;
  z-index:1;
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksEmptyState__title{
  position:relative;
  z-index:1;
  margin:6px 0 0;
  font-size:22px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:-0.02em;
  color:#0f172a;
}
.stocksEmptyState__text{
  position:relative;
  z-index:1;
  margin:8px 0 0;
  font-size:13px;
  line-height:1.55;
  color:#475569;
  max-width:560px;
}
.stocksModalHero{
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(148,163,184,0.18);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,248,255,0.92));
  box-shadow:0 12px 24px rgba(15,23,42,0.04);
}
.stocksModalHero__eyebrow{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksModalHero__title{
  margin-top:5px;
  font-size:28px;
  line-height:1.02;
  font-weight:900;
  letter-spacing:-0.02em;
  color:#0f172a;
}
.stocksModalHero__text{
  margin-top:8px;
  font-size:13px;
  line-height:1.5;
  color:#475569;
  max-width:760px;
}
.stocksModalPanel{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:18px;
  background:rgba(255,255,255,0.94);
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.stocksModalHintCard{
  min-height:44px;
  padding:10px 12px;
  border-radius:14px;
  border:1px dashed rgba(148,163,184,0.24);
  background:rgba(248,250,252,0.82);
}
.stocksQuickStats{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
.stocksQuickStat{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:14px;
  background:rgba(255,255,255,0.82);
  padding:10px 12px;
}
.stocksQuickStat.isBuy{
  border-color:rgba(34,197,94,0.22);
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(240,253,244,0.92));
}
.stocksQuickStat.isSell{
  border-color:rgba(239,68,68,0.22);
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(254,242,242,0.92));
}
.stocksQuickStat__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksQuickStat__value{
  margin-top:6px;
  font-size:16px;
  line-height:1.1;
  font-weight:900;
  color:#0f172a;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.stocksDivSummary,
.stocksAllocStats{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
}
.stocksAllocTabs{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  padding:4px;
  border:1px solid rgba(148,163,184,0.12);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,250,252,0.92));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.96);
}
.stocksAllocTabs .segBtn{
  min-height:40px;
  padding:0 18px;
  border-radius:12px;
  font-weight:800;
}
.stocksDivSummary--compact{
  gap:10px;
}
.stocksDivSummary__card,
.stocksAllocStats__card{
  border:1px solid rgba(148,163,184,0.18);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,248,255,0.92));
  padding:11px 12px;
  box-shadow:0 10px 22px rgba(15,23,42,0.035);
}
.stocksAllocStats{
  grid-template-columns:repeat(4, minmax(220px, 1fr));
  gap:10px;
}
.stocksAllocStats__card{
  position:relative;
  overflow:hidden;
  min-height:102px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.stocksAllocStats__card::before{
  content:'';
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg, rgba(148,163,184,0.26), rgba(148,163,184,0.05));
}
.stocksAllocStats__card--focus::before{
  background:linear-gradient(90deg, rgba(59,130,246,0.55), rgba(59,130,246,0.08));
}
.stocksAllocStats__card--total::before{
  background:linear-gradient(90deg, rgba(14,165,233,0.54), rgba(14,165,233,0.08));
}
.stocksAllocStats__card--leader::before{
  background:linear-gradient(90deg, rgba(16,185,129,0.54), rgba(16,185,129,0.08));
}
.stocksAllocStats__card--concentration::before{
  background:linear-gradient(90deg, rgba(245,158,11,0.56), rgba(245,158,11,0.08));
}
.stocksDivSummary--compact .stocksDivSummary__card{
  border-radius:14px;
  padding:9px 10px;
}
.stocksDivSummary__label,
.stocksAllocStats__label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksDivSummary--compact .stocksDivSummary__label{
  font-size:9px;
  letter-spacing:0.06em;
}
.stocksDivSummary__value,
.stocksAllocStats__value{
  margin-top:6px;
  font-size:22px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:-0.02em;
  color:#0f172a;
}
.stocksDivSummary--compact .stocksDivSummary__value{
  margin-top:4px;
  font-size:18px;
}
.stocksDivSummary__sub,
.stocksAllocStats__sub{
  margin-top:5px;
  font-size:11px;
  color:#64748b;
}
.stocksAllocStats__label,
.stocksAllocStats__value,
.stocksAllocStats__sub{
  width:100%;
  text-align:center;
}
.stocksDivSummary--compact .stocksDivSummary__sub{
  margin-top:3px;
  font-size:10px;
  line-height:1.25;
}
.stocksCard--dividends,
.stocksCard--alloc{
  padding:13px;
}
.stocksCard--alloc{
  border-radius:18px;
  background:
    radial-gradient(520px 180px at 0% 0%, rgba(59,130,246,0.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(246,249,255,0.96));
  border-color:rgba(148,163,184,0.14);
  display:flex;
  flex-direction:column;
  gap:8px;
}
.stocksCard--dividends .stocksCard__head{
  align-items:center;
  gap:10px;
}
.stocksCard__head--alloc{
  align-items:center;
  gap:10px;
  margin-bottom:2px;
}
.stocksTxnModal{
  width:min(980px, 100%);
}
.stocksTxnPanel{
  gap:10px;
}
.stocksTxnMeta{
  font-size:12px;
  font-weight:700;
  color:#475569;
}
.stocksTxnListTitle{
  font-size:13px;
  font-weight:800;
  color:#334155;
}
.stocksTxnTableWrap{
  max-height:340px;
  overflow:auto;
  border:1px solid rgba(148,163,184,0.18);
  border-radius:14px;
  background:rgba(255,255,255,0.96);
  padding:8px;
}
.stocksTxnTable{
  border-spacing:0 8px;
}
.stocksTxnTable thead th{
  padding:0 10px 8px;
}
.stocksTxnTable tbody td{
  padding:10px;
}
.stocksTxnTable tbody tr:hover td{
  border-top-color:rgba(14,165,233,0.34);
  border-bottom-color:rgba(14,165,233,0.34);
  box-shadow:0 10px 22px rgba(14,165,233,0.08);
}
.stocksPage .stocksKpi__card,
.stocksPage .stocksCard,
.stocksHoldingCard,
.stocksModalHero,
.stocksModalPanel{
  animation:stocksFadeUp .22s ease both;
}
.stocksPage .stocksKpi__card:nth-child(2),
.stocksPage .stocksCard:nth-child(2),
.stocksHoldingCard:nth-child(2),
.stocksModalPanel:nth-child(2){
  animation-delay:.03s;
}
.stocksPage .stocksKpi__card:nth-child(3),
.stocksPage .stocksCard:nth-child(3),
.stocksHoldingCard:nth-child(3){
  animation-delay:.06s;
}
@keyframes stocksFadeUp{
  from{
    opacity:0;
    transform:translateY(6px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}
@media (prefers-reduced-motion: reduce){
  .stocksPage .stocksKpi__card,
  .stocksPage .stocksCard,
  .stocksHoldingCard,
  .stocksModalHero,
  .stocksModalPanel{
    animation:none !important;
  }
}
.stocksDivSubhead{
  margin-top:-4px;
  margin-bottom:5px;
  font-size:10px;
  line-height:1.25;
}
.stocksDivPremiumBlock{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,250,252,0.84));
  padding:10px 10px 8px;
}
.stocksUpcomingBlock--premium{
  margin-top:8px;
  padding:10px;
}
.stocksUpcomingBlock--premium .stocksTableWrap{
  border:1px solid rgba(148,163,184,0.16);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.9));
}
.stocksDivForm textarea.input{
  min-height:88px;
  resize:vertical;
}
.stocksDivForm__hint{
  margin-top:6px;
  font-size:11px;
  line-height:1.35;
}
.stocksDonut{
  align-items:center;
}
.stocksDonut__ring{
  display:grid;
  place-items:center;
  position:relative;
  margin:0 auto;
}
.stocksDonut__ring--pie{
  place-items:unset;
}
.stocksDonut__center{
  width:132px;
  height:132px;
  border-radius:999px;
  background:rgba(255,255,255,0.96);
  box-shadow:0 10px 20px rgba(15,23,42,0.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:12px;
}
.stocksDonut__centerLabel{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.stocksDonut__centerValue{
  margin-top:6px;
  font-size:18px;
  line-height:1.1;
  font-weight:900;
  color:#0f172a;
}
.stocksDonut__centerMeta{
  margin-top:5px;
  font-size:11px;
  color:#64748b;
}
@media (max-width: 980px){
  .stocksDrawerHero,
  .stocksDrawerDeck,
  .stocksDivSummary,
  .stocksAllocStats{
    grid-template-columns:1fr;
  }
  .stocksDonut__side{
    width:100%;
  }
  .stocksProfileFacts{
    grid-template-columns:1fr;
  }
  .stocksQuickStats{
    grid-template-columns:1fr;
  }
  .stocksDrawerHero__side{
    align-items:flex-start;
    text-align:left;
  }
  .stocksDrawerMetricGrid,
  .stocksDrawerMetricGrid--ledger{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 700px){
  .stocksModalHero__title{
    font-size:24px;
  }
  .stocksTxnTableWrap{
    max-height:300px;
    padding:6px;
  }
  .stocksDrawerMetricGrid,
  .stocksDrawerMetricGrid--ledger{
    grid-template-columns:1fr;
  }
  .stocksDonut__center{
    width:120px;
    height:120px;
  }
}

/* Stocks professional skin */
.stocksPage--pro{
  color:#0f172a;
}
.stocksPage--pro,
.stocksPage--pro .stocksKpi__value,
.stocksPage--pro .stocksHoldingCell__value,
.stocksPage--pro .stocksHoldingCell__sub,
.stocksPage--pro .stocksLineChart__statValue,
.stocksPage--pro .stocksHero__value,
.stocksPage--pro .stocksDrawerMetric__value{
  font-variant-numeric:tabular-nums;
}
.stocksPage--pro .stocksHero,
.stocksPage--pro .stocksTopDeck,
.stocksPage--pro .stocksCard,
.stocksPage--pro .stocksHoldingsList,
.stocksPage--pro .stocksModalPanel,
.stocksPage--pro .stocksModalHero,
.stocksPage--pro .stocksDrawerPanel{
  background:#ffffff;
  border-color:rgba(148,163,184,0.16);
  box-shadow:0 4px 12px rgba(15,23,42,0.035);
}
.stocksPage--pro .stocksHero::after{
  display:none;
}
.stocksPage--pro .stocksHero,
.stocksPage--pro .stocksTopDeck,
.stocksPage--pro .stocksCard,
.stocksPage--pro .stocksHoldingsList{
  border-radius:12px;
}
.stocksPage--pro .stocksAccountSel,
.stocksPage--pro .stocksTopBtn,
.stocksPage--pro .stocksViewTabs,
.stocksPage--pro .stocksRange,
.stocksPage--pro .stocksHeroMeta__chip,
.stocksPage--pro .stocksLineChart__stat{
  background:#f8fafc;
  border-color:rgba(148,163,184,0.18);
  box-shadow:none;
}
.stocksPage--pro .stocksTopBtn{
  color:#0f172a;
}
.stocksPage--pro .stocksTopBtn--primary{
  background:#eff6ff;
  color:#0f3a78;
  border-color:rgba(59,130,246,0.22);
}
.stocksPage--pro .stocksTopBtn:hover,
.stocksPage--pro .stocksViewTabs .segBtn:hover,
.stocksPage--pro .stocksRange .segBtn:hover{
  transform:none;
  box-shadow:none;
  border-color:rgba(59,130,246,0.18);
  background:#f1f5f9;
}
.stocksPage--pro .stocksViewTabs .segBtn.isActive,
.stocksPage--pro .stocksRange .segBtn.isActive{
  background:#ffffff;
  color:#0f172a;
  border-color:rgba(148,163,184,0.22);
  box-shadow:inset 0 0 0 1px rgba(148,163,184,0.08);
}
.stocksPage--pro .stocksKpi--inline .stocksKpi__card{
  background:#f8fafc;
  border-color:rgba(148,163,184,0.16);
}
.stocksPage--pro .stocksKpi--inline .stocksKpi__card.isPos{
  background:#f0fdf4;
  border-color:rgba(34,197,94,0.16);
}
.stocksPage--pro .stocksKpi--inline .stocksKpi__card.isNeg{
  background:#fef2f2;
  border-color:rgba(239,68,68,0.16);
}
.stocksPage--pro .stocksCard__head{
  align-items:center;
}
.stocksPage--pro .stocksCard__title,
.stocksPage--pro .stocksDrawer__secTitle,
.stocksPage--pro .stocksTxnListTitle{
  font-weight:850;
  letter-spacing:-0.01em;
}
.stocksPage--pro .stocksLineChart__svgWrap{
  background:#fbfdff;
  border-color:rgba(148,163,184,0.14);
}
.stocksPage--pro .stocksHoldingsList{
  overflow:hidden;
}
.stocksPage--pro .stocksHoldingsHead{
  position:sticky;
  top:0;
  z-index:2;
  background:rgba(248,250,252,0.96);
  backdrop-filter:blur(8px);
}
.stocksPage--pro .stocksHoldingsHead__cell{
  color:#475569;
}
.stocksPage--pro .stocksHoldingCard{
  transition:background-color .12s ease, border-color .12s ease;
}
.stocksPage--pro .stocksHoldingCard--compact{
  border-top-color:rgba(148,163,184,0.08);
}
.stocksPage--pro .stocksHoldingCard--compact:hover{
  background:rgba(248,250,252,0.72);
  box-shadow:none;
}
.stocksPage--pro .stocksCompany__media{
  border-color:rgba(148,163,184,0.18);
  background:#ffffff;
  box-shadow:none;
}
.stocksPage--pro .stocksHoldingCell__label,
.stocksPage--pro .stocksHeroMeta__label,
.stocksPage--pro .stocksKpi__label{
  color:#64748b;
}
.stocksPage--pro .stocksSafety{
  border-width:1px;
  box-shadow:none;
}
.stocksPage--pro .stocksActions--compact .stocksActionIcon{
  background:#ffffff;
  border-color:rgba(148,163,184,0.18);
}
.stocksPage--pro .stocksActions--compact .stocksActionIcon:hover{
  background:#f8fafc;
}
.stocksPage--pro .stocksEmptyState{
  background:#ffffff;
  border-color:rgba(148,163,184,0.16);
  box-shadow:0 4px 12px rgba(15,23,42,0.03);
}
.stocksPage--pro .stocksEmptyState::after{
  display:none;
}
.stocksPage--pro .stocksDivSummary__card,
.stocksPage--pro .stocksAllocStats__card{
  background:#ffffff;
  border-color:rgba(148,163,184,0.16);
  border-radius:12px;
  box-shadow:0 4px 12px rgba(15,23,42,0.03);
}
.stocksPage--pro .stocksDivSummary__value,
.stocksPage--pro .stocksAllocStats__value{
  font-size:20px;
  letter-spacing:-0.01em;
}
.stocksPage--pro .stocksDivSummary__sub,
.stocksPage--pro .stocksAllocStats__sub{
  font-size:11px;
}
.stocksPage--pro .stocksDivPremiumBlock,
.stocksPage--pro .stocksUpcomingBlock--premium .stocksTableWrap{
  background:#ffffff;
  border-color:rgba(148,163,184,0.14);
  border-radius:12px;
}
.stocksPage--pro .stocksCard--alloc{
  background:
    radial-gradient(520px 180px at 0% 0%, rgba(59,130,246,0.06), transparent 60%),
    radial-gradient(460px 160px at 100% 100%, rgba(15,118,110,0.05), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(246,249,255,0.96));
  box-shadow:
    0 12px 28px rgba(15,23,42,0.035),
    inset 0 1px 0 rgba(255,255,255,0.96);
}
.stocksPage--pro .stocksDonut__ring--pie{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.34),
    inset 0 -14px 24px rgba(15,23,42,0.06),
    0 20px 44px rgba(29,78,216,0.12);
}
.stocksPage--pro .stocksDonut__summary{
  background:#ffffff;
  border-color:rgba(148,163,184,0.14);
  box-shadow:0 10px 22px rgba(15,23,42,0.04);
}
.stocksPage--pro .stocksDonut__legendRow{
  background:#ffffff;
  border-color:rgba(148,163,184,0.14);
  box-shadow:0 8px 18px rgba(15,23,42,0.03);
}
.stocksPage--pro .stocksAllocStats__card{
  background:linear-gradient(180deg, rgba(255,255,255,0.99), rgba(247,250,255,0.94));
  border-color:rgba(148,163,184,0.14);
  border-radius:14px;
  box-shadow:0 6px 16px rgba(15,23,42,0.035);
}
.stocksPage--pro .stocksUpcomingTable thead th{
  font-size:12px;
  color:#475569;
}
@media (max-width: 1150px){
  .stocksAllocStats{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 700px){
  .stocksAllocTabs{
    gap:6px;
    padding:4px;
  }
  .stocksAllocTabs .segBtn{
    min-height:36px;
    padding:0 14px;
  }
  .stocksAllocStats{
    grid-template-columns:1fr;
  }
  .stocksDonut{
    grid-template-columns:1fr;
    gap:14px;
  }
}
.stocksPage--pro .stocksUpcomingTable tbody tr{
  background:rgba(248,250,252,0.7);
}
.stocksPage--pro .stocksUpcomingTable tbody tr:nth-child(2n){
  background:rgba(241,245,249,0.72);
}
.stocksPage--pro .stocksDonut__ring{
  border-color:rgba(148,163,184,0.16);
  box-shadow:inset 0 0 0 24px rgba(255,255,255,0.98);
}
.stocksPage--pro .stocksDonut__ring--pie{
  border:0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.42),
    0 16px 34px rgba(37,99,235,0.08);
}
.stocksPage--pro .stocksDonut__center{
  background:#ffffff;
  box-shadow:none;
  border:1px solid rgba(148,163,184,0.14);
}
.stocksPage--pro .stocksDonut__summary{
  background:#ffffff;
  border-color:rgba(148,163,184,0.14);
}
.stocksPage--pro .stocksDonut__legendRow{
  background:#ffffff;
  border-color:rgba(148,163,184,0.14);
  border-radius:10px;
}
.stocksPage--pro .stocksModalHero,
.stocksPage--pro .stocksDrawerHero{
  background:#ffffff;
  border-color:rgba(148,163,184,0.16);
  border-radius:12px;
  box-shadow:0 4px 12px rgba(15,23,42,0.03);
}
.stocksPage--pro .stocksModalHero__title,
.stocksPage--pro .stocksDrawerHero__title{
  font-size:24px;
  letter-spacing:-0.02em;
}
.stocksPage--pro .stocksModalHero__text,
.stocksPage--pro .stocksDrawerHero__meta,
.stocksPage--pro .stocksDrawerHero__plSub{
  font-size:11px;
  color:#64748b;
}
.stocksPage--pro .stocksDrawerHero__pl{
  font-size:22px;
}
.stocksPage--pro .stocksModalPanel,
.stocksPage--pro .stocksDrawerPanel,
.stocksPage--pro .stocksProfileFact,
.stocksPage--pro .stocksDrawerMetric{
  background:#ffffff;
  border-color:rgba(148,163,184,0.14);
  border-radius:12px;
  box-shadow:none;
}
.stocksPage--pro .stocksDrawerMetric{
  padding:10px;
}
.stocksPage--pro .stocksDrawerMetric__value{
  font-size:15px;
}
.stocksPage--pro .stocksDrawerMetric__sub{
  font-size:11px;
}
.stocksPage--pro .stocksProfileFact__value{
  font-size:13px;
}
.stocksPage--pro .stocksMiniTable thead th,
.stocksPage--pro .stocksTxnTable thead th,
.stocksPage--pro .stocksMetaTable thead th{
  font-size:11px;
  color:#475569;
  background:#f8fafc;
}
.stocksPage--pro .stocksTxnTableWrap,
.stocksPage--pro .stocksMetaTableWrap{
  background:#ffffff;
  border-color:rgba(148,163,184,0.14);
}
.stocksPage--pro .stocksNotice{
  border-radius:12px;
}
.stocksPage--pro .stocksKpi__card,
.stocksPage--pro .stocksCard,
.stocksPage--pro .stocksHoldingCard,
.stocksPage--pro .stocksModalHero,
.stocksPage--pro .stocksModalPanel{
  animation:none;
}

/* Stocks drawer polish */
.modal.stocksDrawerModal.isDrawer .modal__panel{
  width:min(680px, calc(100vw - 14px));
  border-radius:20px 0 0 20px;
  border-color:rgba(148,163,184,0.16);
  background:#f8fafc;
  box-shadow:0 20px 48px rgba(15,23,42,0.18);
}
.modal.stocksDrawerModal.isDrawer .modal__head{
  padding:12px 14px;
  background:rgba(255,255,255,0.98);
  border-bottom:1px solid rgba(148,163,184,0.16);
}
.modal.stocksDrawerModal.isDrawer .modal__title{
  font-size:15px;
  font-weight:800;
  letter-spacing:-0.01em;
}
.modal.stocksDrawerModal.isDrawer .modal__body{
  padding:12px 14px 10px;
}
.modal.stocksDrawerModal.isDrawer .modal__foot{
  padding:10px 14px 12px;
  justify-content:flex-end;
  gap:8px;
  border-top:1px solid rgba(148,163,184,0.16);
  background:rgba(255,255,255,0.98);
}
.modal.stocksDrawerModal.isDrawer .modal__foot .ghostBtn,
.modal.stocksDrawerModal.isDrawer .modal__foot .primaryBtn{
  min-height:40px;
  padding:0 14px;
  border-radius:12px;
  font-size:13px;
  font-weight:800;
}
.modal.stocksDrawerModal .iconBtn{
  width:32px;
  height:32px;
  border-radius:10px;
  background:rgba(15,23,42,0.03);
}
.modal.stocksPositionModal .modal__panel{
  width:min(980px, calc(100vw - 28px));
  margin:3.5vh auto;
  border-radius:22px;
  border:1px solid rgba(148,163,184,0.18);
  background:#f8fafc;
  box-shadow:0 26px 60px rgba(15,23,42,0.18);
  max-height:min(88vh, 820px);
}
.modal.stocksPositionModal .modal__backdrop{
  background:rgba(15,23,42,0.42);
  backdrop-filter:blur(6px);
}
.modal.stocksPositionModal--simple .modal__head{
  padding:10px 12px;
  position:sticky;
  top:0;
  z-index:4;
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.98));
  backdrop-filter:blur(8px);
}
.modal.stocksPositionModal--simple .modal__body{
  padding:10px 12px 8px;
  background:linear-gradient(180deg, #f8fafc 0%, #f4f7fb 100%);
}
.modal.stocksPositionModal--simple .modal__foot{
  padding:8px 12px 10px;
  gap:6px;
  justify-content:flex-end;
  background:linear-gradient(180deg, rgba(248,250,252,0.96), rgba(255,255,255,0.98));
}
.modal.stocksPositionModal--simple .modal__title{
  font-size:10px;
  font-weight:900;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:#64748b;
}
.modal.stocksPositionModal--simple .modal__foot .ghostBtn,
.modal.stocksPositionModal--simple .modal__foot .primaryBtn{
  min-height:38px;
  padding:0 12px;
  font-size:12px;
}
.modal.stocksPositionModal--simple .stocksDrawer--premium{
  gap:8px;
}
.modal.stocksPositionModal--simple .stocksCompany__media--xl{
  width:40px;
  height:40px;
  border-radius:10px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero{
  gap:8px;
  padding:8px 10px;
  border-radius:10px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero--compact{
  display:flex;
  align-items:center;
  justify-content:space-between;
  border:1px solid rgba(148,163,184,0.16);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,247,252,0.94));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.9), 0 6px 16px rgba(15,23,42,0.04);
}
.modal.stocksPositionModal--simple .stocksCompany--heroCompact{
  min-width:0;
  align-items:center;
  gap:8px;
}
.modal.stocksPositionModal--simple .stocksCompany__text--compact{
  min-width:0;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__inlineTop{
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__symbolMini{
  font-size:14px;
  line-height:1;
  font-weight:900;
  color:#0f172a;
  letter-spacing:-0.02em;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__accountMini{
  font-size:9px;
  font-weight:800;
  color:#64748b;
  text-transform:uppercase;
  letter-spacing:0.05em;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__companyMini{
  margin-top:1px;
  font-size:10.5px;
  font-weight:700;
  color:#334155;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__metaMini{
  margin-top:1px;
  font-size:9.5px;
  color:#64748b;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__eyebrow{
  font-size:8.5px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__title{
  margin-top:1px;
  font-size:16px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__name{
  margin-top:1px;
  font-size:11px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__meta{
  margin-top:2px;
  font-size:10px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__side{
  gap:2px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__side--compact{
  flex:0 0 auto;
  align-items:flex-end;
  justify-content:center;
  text-align:right;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__pl{
  font-size:15px;
}
.modal.stocksPositionModal--simple .stocksDrawerHero__plSub{
  font-size:10px;
}
.modal.stocksPositionModal--simple .stocksDrawerMetricGrid{
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:5px;
}
.modal.stocksPositionModal--simple .stocksDrawerMetricGrid--slim{
  align-items:stretch;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric{
  padding:7px 8px;
  border-radius:9px;
  border-color:rgba(148,163,184,0.14);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,252,0.94));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.85);
  position:relative;
  text-align:center;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric::before{
  content:'';
  position:absolute;
  left:8px;
  right:8px;
  top:0;
  height:1px;
  background:linear-gradient(90deg, rgba(59,130,246,0.20), rgba(59,130,246,0.02));
  pointer-events:none;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__label{
  font-size:8px;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__value{
  margin-top:2px;
  font-size:12px;
  line-height:1.12;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__sub{
  margin-top:2px;
  min-height:0;
  font-size:10px;
  line-height:1.25;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__labelRow{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__miniSafety{
  min-height:18px;
  padding:0 6px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.18);
  display:inline-flex;
  align-items:center;
  font-size:9px;
  font-weight:800;
  letter-spacing:0.03em;
  color:#334155;
  background:#ffffff;
  white-space:nowrap;
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__miniSafety.stocksSafety--safe{
  border-color:rgba(34,197,94,0.24);
  color:#166534;
  background:rgba(240,253,244,0.9);
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__miniSafety.stocksSafety--medium{
  border-color:rgba(245,158,11,0.28);
  color:#92400e;
  background:rgba(255,247,237,0.94);
}
.modal.stocksPositionModal--simple .stocksDrawerMetric__miniSafety.stocksSafety--risky,
.modal.stocksPositionModal--simple .stocksDrawerMetric__miniSafety.stocksSafety--na{
  border-color:rgba(239,68,68,0.22);
  color:#b91c1c;
  background:rgba(254,242,242,0.92);
}
.modal.stocksPositionModal--simple .stocksDrawerMetric--yield{
  border-color:rgba(245,158,11,0.20);
}
.modal.stocksPositionModal--simple .stocksDrawerDeck{
  grid-template-columns:minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap:8px;
}
.modal.stocksPositionModal--simple .stocksDrawerPanel{
  padding:9px;
  border-radius:10px;
  border-color:rgba(148,163,184,0.14);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,252,0.94));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.88);
}
.modal.stocksPositionModal--simple .stocksDrawerPanel__head{
  margin-bottom:5px;
  gap:8px;
}
.modal.stocksPositionModal--simple .stocksDrawerPanel__chip{
  min-height:24px;
  padding:0 8px;
  font-size:10px;
}
.modal.stocksPositionModal--simple .stocksDrawer__secTitle{
  font-size:11px;
  line-height:1.2;
}
.modal.stocksPositionModal--simple .stocksDrawer__list{
  gap:4px;
  padding-left:14px;
}
.modal.stocksPositionModal--simple .stocksDrawer__list li{
  font-size:10.5px;
  line-height:1.3;
}
.modal.stocksPositionModal--simple .stocksProfileFacts{
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:5px;
}
.modal.stocksPositionModal--simple .stocksProfileFacts--dense{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}
.modal.stocksPositionModal--simple .stocksProfileFact{
  padding:7px;
  border-radius:9px;
  border-color:rgba(148,163,184,0.12);
  background:#ffffff;
  text-align:center;
}
.modal.stocksPositionModal--simple .stocksDrawerPanel--simpleInfo{
  padding:10px;
}
.modal.stocksPositionModal--simple .stocksDrawerSplit{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(290px, 0.85fr);
  gap:8px;
  align-items:start;
}
.modal.stocksPositionModal--simple .stocksDrawerSplit__main{
  display:grid;
  gap:6px;
}
.modal.stocksPositionModal--simple .stocksProfileFacts--premium .stocksProfileFact{
  background:linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,250,252,0.94));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.92);
}
.modal.stocksPositionModal--simple .stocksProfileFact--accent{
  border-color:rgba(59,130,246,0.16);
  background:linear-gradient(180deg, rgba(239,246,255,0.8), rgba(255,255,255,0.96));
}
.modal.stocksPositionModal--simple .stocksProfileFact__label{
  font-size:8px;
}
.modal.stocksPositionModal--simple .stocksProfileFact__value{
  margin-top:2px;
  font-size:10.5px;
  line-height:1.2;
  word-break:normal;
  overflow-wrap:anywhere;
}
.modal.stocksPositionModal--simple .stocksMiniTable thead th,
.modal.stocksPositionModal--simple .stocksMiniTable tbody td{
  font-size:11px;
  padding:7px 8px;
}
.modal.stocksPositionModal--simple .stocksInfoNotes{
  margin-top:5px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:5px;
}
.modal.stocksPositionModal--simple .stocksInfoNotes--inline{
  margin-top:0;
  grid-template-columns:repeat(2, minmax(0, 1fr));
}
.modal.stocksPositionModal--simple .stocksInfoNote{
  min-width:0;
  padding:6px 7px;
  border:1px solid rgba(148,163,184,0.14);
  border-radius:9px;
  background:rgba(255,255,255,0.96);
  font-size:10px;
  line-height:1.25;
  color:#475569;
  box-shadow:inset 2px 0 0 rgba(59,130,246,0.18);
  text-align:center;
}
.modal.stocksPositionModal--simple .stocksDrawerSubpanel{
  min-width:0;
  padding:8px;
  border:1px solid rgba(148,163,184,0.14);
  border-radius:10px;
  background:linear-gradient(180deg, rgba(255,255,255,0.99), rgba(246,249,253,0.95));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.9);
}
.modal.stocksPositionModal--simple .stocksDrawerSubpanel__title{
  margin:0 0 6px;
  font-size:10px;
  font-weight:900;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#64748b;
}
.modal.stocksPositionModal--simple .stocksNextDivRail{
  display:grid;
  gap:6px;
}
.modal.stocksPositionModal--simple .stocksNextDivRail__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  min-width:0;
  padding:7px 8px;
  border:1px solid rgba(148,163,184,0.12);
  border-radius:9px;
  background:#ffffff;
}
.modal.stocksPositionModal--simple .stocksNextDivRail__date{
  flex:0 0 auto;
  font-size:11px;
  font-weight:800;
  color:#0f172a;
}
.modal.stocksPositionModal--simple .stocksNextDivRail__meta{
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
}
.modal.stocksPositionModal--simple .stocksNextDivRail__value{
  font-size:11px;
  font-weight:800;
  color:#0f172a;
  white-space:nowrap;
}
.modal.stocksPositionModal--simple .stocksDrawerAction{
  min-width:78px;
  border-radius:11px;
  font-weight:800;
  letter-spacing:-0.01em;
}
.modal.stocksPositionModal--simple .stocksDrawerAction--div,
.modal.stocksPositionModal--simple .stocksDrawerAction--close{
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,246,250,0.94));
  border-color:rgba(148,163,184,0.18);
  color:#334155;
}
.modal.stocksPositionModal--simple .stocksDrawerAction--sell{
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(254,242,242,0.92));
  border-color:rgba(239,68,68,0.18);
  color:#991b1b;
}
.modal.stocksPositionModal--simple .stocksDrawerAction--buy{
  background:linear-gradient(180deg, #173b72, #0f2749);
  border-color:#173b72;
  color:#ffffff;
  box-shadow:0 8px 18px rgba(23,59,114,0.16);
}
@media (max-width: 720px){
  .modal.stocksPositionModal .modal__panel{
    width:calc(100vw - 10px);
    margin:8px auto;
    max-height:calc(100vh - 16px);
    border-radius:18px;
  }
  .modal.stocksDrawerModal.isDrawer .modal__panel{
    width:100vw;
    border-radius:0;
  }
  .modal.stocksPositionModal--simple .stocksDrawerHero{
    grid-template-columns:minmax(0, 1fr);
  }
  .modal.stocksPositionModal--simple .stocksDrawerHero__side{
    align-items:flex-start;
    text-align:left;
  }
  .modal.stocksPositionModal--simple .stocksDrawerMetricGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .modal.stocksPositionModal--simple .stocksDrawerDeck,
  .modal.stocksPositionModal--simple .stocksProfileFacts,
  .modal.stocksPositionModal--simple .stocksProfileFacts--dense,
  .modal.stocksPositionModal--simple .stocksInfoNotes,
  .modal.stocksPositionModal--simple .stocksInfoNotes--inline,
  .modal.stocksPositionModal--simple .stocksDrawerSplit{
    grid-template-columns:minmax(0, 1fr);
  }
  .modal.stocksPositionModal--simple .stocksNextDivRail__row{
    align-items:flex-start;
    flex-direction:column;
  }
  .modal.stocksPositionModal--simple .stocksNextDivRail__meta{
    width:100%;
    justify-content:space-between;
  }
  .modal.stocksPositionModal--simple .modal__foot{
    justify-content:stretch;
  }
  .modal.stocksPositionModal--simple .modal__foot .ghostBtn,
  .modal.stocksPositionModal--simple .modal__foot .primaryBtn{
    flex:1 1 auto;
  }
}

/* Stocks top zone - compact institutional layout */
.stocksPage--compactUi.stocksPage--pro .stocksHero{
  grid-template-columns:minmax(0, 1.24fr) minmax(340px, 0.76fr);
  gap:10px;
  align-items:stretch;
  padding:10px;
  border-radius:16px;
  border-color:rgba(148,163,184,0.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,250,252,0.96));
  box-shadow:
    0 8px 18px rgba(15,23,42,0.04),
    inset 0 1px 0 rgba(255,255,255,0.96);
}
.stocksPage--compactUi.stocksPage--pro .stocksHero::after{
  display:none;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__left{
  min-width:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:stretch;
  gap:5px;
  padding:2px 2px 2px 4px;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__heading{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:0;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__left .panel__title{
  margin:0;
  font-size:12px;
  font-weight:900;
  letter-spacing:0;
  color:#0f172a;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__mainRow{
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(280px, .92fr);
  gap:10px;
  align-items:stretch;
  min-width:0;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__summary{
  min-width:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:flex-start;
  gap:2px;
  padding:0;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__value{
  font-size:clamp(34px, 3.4vw, 46px);
  line-height:0.96;
  letter-spacing:-0.03em;
  color:#0f295d;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__sub{
  margin-top:0;
  font-size:10px;
  line-height:1.18;
  color:#5b6b82;
  max-width:none;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__summarySide{
  min-width:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:6px;
  padding:3px 0 0 0;
  border-left:1px solid rgba(148,163,184,0.12);
  padding-left:10px;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta{
  display:grid;
  grid-template-columns:repeat(3, minmax(72px, 1fr));
  gap:4px;
  width:100%;
  max-width:none;
  flex:0 0 auto;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta__chip{
  min-height:0;
  padding:4px 7px;
  border-radius:9px;
  background:#f8fafc;
  border:1px solid rgba(148,163,184,0.14);
  position:relative;
  overflow:hidden;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta__chip::before{
  content:'';
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:2px;
  background:linear-gradient(90deg, rgba(148,163,184,0.22), rgba(148,163,184,0.06));
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta__chip.isPos::before{
  background:linear-gradient(90deg, rgba(34,197,94,0.44), rgba(34,197,94,0.06));
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta__chip.isNeg::before{
  background:linear-gradient(90deg, rgba(239,68,68,0.42), rgba(239,68,68,0.06));
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta__label{
  font-size:8px;
  letter-spacing:0.08em;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta__value{
  font-size:12px;
  font-weight:900;
}
.stocksPage--compactUi.stocksPage--pro .stocksExposure{
  margin-top:0;
  justify-content:flex-start;
  gap:3px;
  flex:0 1 auto;
}
.stocksPage--compactUi.stocksPage--pro .stocksExposureChip{
  min-height:16px;
  padding:0 5px;
  border-radius:999px;
  border-color:rgba(148,163,184,0.08);
  background:rgba(248,250,252,0.84);
  box-shadow:none;
  font-size:8px;
  font-weight:700;
  color:#475569;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__right{
  min-width:0;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel{
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:6px;
  align-content:start;
  padding:8px;
  border:1px solid rgba(148,163,184,0.15);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(249,251,255,0.98), rgba(255,255,255,0.96));
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel .stocksAccountSel{
  min-height:40px;
  border-radius:12px;
  background:#ffffff;
  border-color:rgba(148,163,184,0.12);
  font-size:13px;
  padding-inline:14px 40px;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel .stocksTopBtn{
  height:36px;
  border-radius:12px;
  font-size:12px;
  font-weight:800;
  border-color:rgba(148,163,184,0.12);
  background:#ffffff;
  color:#0f172a;
  box-shadow:none;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel .stocksTopBtn:hover{
  border-color:rgba(59,130,246,0.22);
  background:#f8fbff;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:6px;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel .stocksTopBtn--primary{
  justify-content:center;
  box-shadow:none;
  border-color:rgba(59,130,246,0.18);
  background:#f8fbff;
  color:#143569;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions--primary{
  grid-template-columns:1.15fr 1fr 1fr;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions--primary .stocksTopBtn{
  min-width:0;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions--secondary{
  grid-template-columns:minmax(0, 1fr);
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions--secondary .stocksTopBtn{
  min-width:0;
  height:30px;
  font-size:10px;
}
.stocksPage--compactUi.stocksPage--pro .stocksTopDeck{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px 10px;
  padding:7px 9px;
  border-radius:14px;
  border-color:rgba(148,163,184,0.16);
  background:#ffffff;
  box-shadow:0 4px 12px rgba(15,23,42,0.03);
}
.stocksPage--compactUi.stocksPage--pro .stocksTopDeck__tabs{
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
  flex-wrap:wrap;
  flex:0 1 auto;
}
.stocksPage--compactUi.stocksPage--pro .stocksTopDeck__rail{
  min-width:0;
  flex:1 1 auto;
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.stocksPage--compactUi.stocksPage--pro .stocksTopDeck__rail:empty{
  display:none;
}
.stocksPage--compactUi.stocksPage--pro .stocksViewTabs,
.stocksPage--compactUi.stocksPage--pro .stocksRange{
  padding:3px;
  border-radius:12px;
  border-color:rgba(148,163,184,0.16);
  background:#f8fafc;
}
.stocksPage--compactUi.stocksPage--pro .stocksViewTabs .segBtn,
.stocksPage--compactUi.stocksPage--pro .stocksRange .segBtn{
  min-width:78px;
  height:30px;
  padding:0 12px;
  border-radius:10px;
  font-size:12px;
  font-weight:800;
}
.stocksPage--compactUi.stocksPage--pro .stocksStatus,
.stocksPage--compactUi.stocksPage--pro .stocksTopPill{
  min-height:24px;
  padding:0 8px;
  border-radius:999px;
  font-size:10px;
  box-shadow:none;
}
.stocksPage--compactUi.stocksPage--pro .stocksKpi--inline{
  gap:4px;
  margin-top:0;
  width:auto;
  max-width:100%;
  align-self:auto;
  justify-content:flex-end;
  flex-wrap:wrap;
}
.stocksPage--compactUi.stocksPage--pro .stocksKpi--inline .stocksKpi__card{
  padding:4px 6px;
  border-radius:10px;
  gap:4px;
}
.stocksPage--compactUi.stocksPage--pro .stocksKpi--inline .stocksKpi__label{
  font-size:8px;
}
.stocksPage--compactUi.stocksPage--pro .stocksKpi--inline .stocksKpi__value{
  font-size:11px;
}
.stocksPage--compactUi.stocksPage--pro .stocksKpi--inline .stocksKpi__card .muted{
  font-size:8px;
}
.stocksPage--compactUi.stocksPage--pro .stocksCard{
  padding:8px;
  border-radius:12px;
}
.stocksPage--compactUi.stocksPage--pro .stocksCard--chart{
  padding:7px 8px 7px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart{
  min-height:0;
  gap:4px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart--mini{
  gap:3px;
}
.stocksPage--compactUi.stocksPage--pro .stocksCard--chartMinimal{
  border-color:rgba(148,163,184,0.14);
}
.stocksPage--compactUi.stocksPage--pro .stocksCard--chart .stocksLineChart__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:1px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__head--inline{
  min-height:22px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__title{
  font-size:12px;
  font-weight:850;
  letter-spacing:-0.01em;
  color:#0f172a;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__headMain{
  flex:1 1 auto;
  min-width:0;
  gap:6px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__trend{
  min-height:24px;
  padding:0 8px;
  font-size:11px;
  border-radius:999px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__meta{
  font-size:10px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__stats{
  gap:5px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__stat{
  padding:5px 7px;
  border-radius:9px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__statLabel{
  font-size:8px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__statValue{
  font-size:11px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__svgWrap{
  height:156px;
  border-radius:10px;
  padding:2px 1px 0;
  position:relative;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__axis{
  margin-top:0;
  padding:0 2px;
  font-size:9px;
  line-height:1.1;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__axis span{
  opacity:0.88;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__tooltip{
  min-width:82px;
  padding:5px 7px;
  border-radius:9px;
  box-shadow:0 6px 14px rgba(15,23,42,0.08);
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__tooltipDate{
  font-size:9px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__tooltipVal{
  font-size:11px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__crosshair{
  top:6px;
  bottom:8px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__activeDot{
  width:7px;
  height:7px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__mode{
  padding:1px;
}
.stocksPage--compactUi.stocksPage--pro .stocksLineChart__modeBtn{
  min-height:20px;
  padding:0 7px;
  font-size:9px;
}
@media (max-width: 1080px){
  .stocksPage--compactUi.stocksPage--pro .stocksHero{
    grid-template-columns:1fr;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksHero__mainRow{
    grid-template-columns:1fr;
    gap:7px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksHero__summarySide{
    border-left:0;
    border-top:1px solid rgba(148,163,184,0.12);
    padding-left:0;
    padding-top:8px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksTopDeck{
    width:100%;
    align-items:flex-start;
    flex-direction:column;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksTopDeck__rail{
    width:100%;
    justify-content:flex-start;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksKpi--inline{
    width:100%;
    justify-content:flex-start;
  }
}
@media (max-width: 760px){
  .stocksPage--compactUi.stocksPage--pro .stocksHero__heading{
    align-items:flex-start;
    flex-direction:column;
    gap:6px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksHeroMeta{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
  .stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions{
    grid-template-columns:1fr;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions--primary{
    grid-template-columns:1fr;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksTopDeck__tabs{
    flex-direction:column;
    align-items:stretch;
    width:100%;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksLineChart__head{
    align-items:flex-start;
    flex-direction:column;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksLineChart__headMain{
    width:100%;
    justify-content:space-between;
  }
}
@media (max-width: 560px){
  .stocksPage--compactUi.stocksPage--pro .stocksHeroMeta{
    grid-template-columns:1fr;
  }
  .stocksUpcomingItem{
    grid-template-columns:1fr;
    gap:7px;
    align-items:flex-start;
  }
  .stocksInlineFacts--dividends{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
  .stocksUpcomingActions{
    justify-content:flex-start;
  }
}
@media (max-width: 640px){
  .stocksInlineFacts--dividends{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

/* Stocks top zone - final fine tuning */
.stocksPage--compactUi.stocksPage--pro .stocksHero{
  border-color:rgba(148,163,184,0.12);
  box-shadow:0 6px 14px rgba(15,23,42,0.03), inset 0 1px 0 rgba(255,255,255,0.96);
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__summary{
  padding-top:3px;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__summarySide{
  padding:6px;
  border:1px solid rgba(148,163,184,0.12);
  border-radius:11px;
  background:linear-gradient(180deg, rgba(248,250,252,0.98), rgba(255,255,255,0.96));
  box-shadow:none;
  border-left-color:rgba(148,163,184,0.12);
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta__chip{
  border-color:rgba(148,163,184,0.10);
  min-height:32px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.stocksPage--compactUi.stocksPage--pro .stocksExposureChip{
  width:100%;
  justify-content:center;
  border-color:rgba(148,163,184,0.12);
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroMeta{
  gap:5px;
  align-items:stretch;
}
.stocksPage--compactUi.stocksPage--pro .stocksExposure{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:5px;
  width:100%;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__summary .stocksExposure{
  margin-top:4px;
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel{
  border-color:rgba(148,163,184,0.12);
}
.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel .stocksAccountSel{
  border-color:rgba(148,163,184,0.12);
}
.stocksPage--compactUi.stocksPage--pro .stocksTopDeck{
  padding:4px 6px;
  border-radius:10px;
  border-color:rgba(148,163,184,0.10);
  background:rgba(255,255,255,0.94);
  box-shadow:none;
}
.stocksPage--compactUi.stocksPage--pro .stocksViewTabs,
.stocksPage--compactUi.stocksPage--pro .stocksRange{
  padding:1px;
  border-radius:9px;
  border-color:rgba(148,163,184,0.10);
}
.stocksPage--compactUi.stocksPage--pro .stocksViewTabs .segBtn,
.stocksPage--compactUi.stocksPage--pro .stocksRange .segBtn{
  height:26px;
  border-radius:7px;
}
.stocksPage--compactUi.stocksPage--pro .stocksViewTabs .segBtn.isActive,
.stocksPage--compactUi.stocksPage--pro .stocksRange .segBtn.isActive{
  box-shadow:none;
  border-color:rgba(148,163,184,0.12);
  background:#ffffff;
}
.stocksPage--compactUi.stocksPage--pro .stocksKpi--inline .stocksKpi__card{
  border-color:rgba(148,163,184,0.10);
}
.stocksPage--compactUi.stocksPage--pro .stocksHoldingsList{
  padding:4px 6px;
  border-color:rgba(148,163,184,0.10);
  border-radius:12px;
  box-shadow:none;
}
.stocksPage--compactUi.stocksPage--pro .stocksHoldingsHead{
  gap:8px;
  padding:0 2px 4px;
  border-bottom-color:rgba(148,163,184,0.10);
}
.stocksPage--compactUi.stocksPage--pro .stocksHoldingCard--compact{
  padding:3px 2px;
  border-top-color:rgba(148,163,184,0.08);
}
.stocksPage--compactUi.stocksPage--pro .stocksHoldingRow{
  gap:6px;
}
.stocksPage--compactUi.stocksPage--pro .stocksActions--compact .stocksActionIcon{
  border-color:rgba(148,163,184,0.12);
  background:#ffffff;
  box-shadow:none;
}
@media (max-width: 1080px){
  .stocksPage--compactUi.stocksPage--pro .stocksHero__summarySide{
    border-left:0;
    padding-left:6px;
  }
}
@media (max-width: 560px){
  .stocksPage--compactUi.stocksPage--pro .stocksExposure{
    grid-template-columns:1fr;
  }
}
.stocksPage--simple.stocksPage--compactUi.stocksPage--pro .stocksHeroPanel__actions--secondary{
  display:none;
}

/* Stocks currency exposure - ultra compact under summary text */
.stocksPage--compactUi.stocksPage--pro .stocksHero__summary .stocksExposure{
  display:inline-grid;
  grid-template-columns:repeat(3, auto);
  width:auto;
  max-width:100%;
  gap:4px;
  margin-top:3px;
  justify-content:flex-start;
  align-self:flex-start;
}
.stocksPage--compactUi.stocksPage--pro .stocksHero__summary .stocksExposureChip{
  width:auto;
  min-height:16px;
  padding:0 5px;
  font-size:8px;
  line-height:1;
  font-weight:700;
  border-radius:999px;
  white-space:nowrap;
}
@media (max-width: 560px){
  .stocksPage--compactUi.stocksPage--pro .stocksHero__summary .stocksExposure{
    grid-template-columns:repeat(3, auto);
  }
}

/* Stocks overview - narrow screens */
@media (max-width: 760px){
  .stocksPage--compactUi.stocksPage--pro .stocksTopDeck{
    padding:4px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksTopDeck__tabs{
    width:100%;
    gap:6px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksViewTabs,
  .stocksPage--compactUi.stocksPage--pro .stocksRange{
    width:100%;
    max-width:100%;
    overflow-x:auto;
    overflow-y:hidden;
    flex-wrap:nowrap;
    justify-content:flex-start;
    scrollbar-width:none;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksViewTabs::-webkit-scrollbar,
  .stocksPage--compactUi.stocksPage--pro .stocksRange::-webkit-scrollbar{
    display:none;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksViewTabs .segBtn,
  .stocksPage--compactUi.stocksPage--pro .stocksRange .segBtn{
    flex:0 0 auto;
    min-width:max-content;
    padding-inline:12px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksKpi--inline{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    width:100%;
    justify-content:stretch;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksKpi--inline .stocksKpi__card{
    min-width:0;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksCard,
  .stocksPage--compactUi.stocksPage--pro .stocksCard--chart{
    padding:8px;
    border-radius:14px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksLineChart__headMain{
    min-width:0;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksLineChart__title{
    white-space:normal;
    overflow-wrap:anywhere;
    line-height:1.1;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksLineChart__trend{
    align-self:flex-start;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksLineChart__svgWrap{
    height:142px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview{
    min-width:0;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingsList{
    padding:0;
    border:0;
    background:transparent;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingCard--compact{
    padding:8px 0;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingRow{
    grid-template-columns:minmax(0, 1fr);
    gap:8px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingCell,
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingRow > .stocksHoldingCell:not(.stocksHoldingCell--identity):not(.stocksHoldingCell--market),
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingCell--market{
    align-items:flex-start;
    text-align:left;
    justify-content:flex-start;
    padding-inline:0;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingCell__label{
    display:block;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingRow > .stocksHoldingCell:not(.stocksHoldingCell--identity):not(.stocksHoldingCell--market) .stocksHoldingCell__sub{
    display:block;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingMarket{
    justify-items:stretch;
    grid-template-columns:1fr;
    gap:4px;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksHoldingMarket__rangeLine{
    grid-template-columns:auto minmax(0, 1fr) auto;
  }
  .stocksPage--compactUi.stocksPage--pro .stocksOverview .stocksActions--compact{
    justify-content:flex-start;
  }
}
@media (max-width: 520px){
  .stocksPage--compactUi.stocksPage--pro .stocksKpi--inline{
    grid-template-columns:minmax(0, 1fr);
  }
  .stocksPage--compactUi.stocksPage--pro .stocksLineChart__svgWrap{
    height:132px;
  }
}
