@import url("https://cdn.jsdelivr.net/npm/pretendard@1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css");

:root {
  --bg: #f2f4f6;
  --surface: #ffffff;
  --surface2: #f8fafc;
  --sub: #f2f4f6;
  --soft: #f7f8fa;
  --text: #191f28;
  --text2: #4e5968;
  --text3: #8b95a1;
  --text4: #b0b8c1;
  --line: #e5e8eb;
  --line2: #dfe4ea;
  --hair: #f0f2f4;
  --blue: #3182f6;
  --blue2: #5aa0ff;
  --blue-bg: #e8f3ff;
  --down: #2864d8;
  --down-bg: #e8f3ff;
  --buy: #3182f6;
  --buy-bg: #e8f3ff;
  --up: #f04452;
  --up2: #f04452;
  --up-bg: #fff1f2;
  --sell: #f04452;
  --sell-bg: #fff1f2;
  --good: #00a86b;
  --good-bg: #eafaf1;
  --green: #00a86b;
  --green-bg: #eafaf1;
  --amber: #f59f00;
  --amber-bg: #fff6db;
  --hold: #f59f00;
  --hold-bg: #fff6db;
  --primary: #3182f6;
  --success: #00a86b;
  --muted: #8b95a1;
  --warn-bg: #fff7e6;
  --warn-line: #ffe2a8;
  --warn-tx: #92670f;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-2xl: 24px;
  --shadow: 0 1px 2px rgba(0, 0, 0, .04), 0 6px 18px rgba(17, 24, 39, .05);
  --shadow-soft: 0 1px 2px rgba(0, 0, 0, .035), 0 6px 16px rgba(17, 24, 39, .045);
  --shadow-float: 0 10px 28px -18px rgba(17, 24, 39, .44);
  --ease: cubic-bezier(.2, .8, .2, 1);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bg: #101114;
    --surface: #181a1f;
    --surface2: #202329;
    --sub: #202329;
    --soft: #1d2128;
    --text: #f2f4f6;
    --text2: #c9d1d9;
    --text3: #8e98a8;
    --text4: #657080;
    --line: #2b2f36;
    --line2: #363b44;
    --hair: #242932;
    --blue: #5a9bff;
    --blue2: #7ab0ff;
    --blue-bg: #17263d;
    --down: #6ea2ff;
    --down-bg: #17263d;
    --buy: #5a9bff;
    --buy-bg: #17263d;
    --up: #ff6b7a;
    --up2: #ff6b7a;
    --up-bg: #3a2025;
    --sell: #ff6b7a;
    --sell-bg: #3a2025;
    --good: #33d399;
    --good-bg: #143329;
    --green: #33d399;
    --green-bg: #143329;
    --amber: #fbbf24;
    --amber-bg: #34270e;
    --hold: #fbbf24;
    --hold-bg: #34270e;
    --primary: #5a9bff;
    --success: #33d399;
    --muted: #8e98a8;
    --warn-bg: #2f2710;
    --warn-line: #4d3c14;
    --warn-tx: #ffd479;
    --shadow: 0 18px 38px -22px rgba(0, 0, 0, .72);
    --shadow-soft: 0 12px 30px -22px rgba(0, 0, 0, .62);
    --shadow-float: 0 18px 38px -22px rgba(0, 0, 0, .76);
  }
}

:root[data-theme="dark"] {
  --bg: #101114;
  --surface: #181a1f;
  --surface2: #202329;
  --sub: #202329;
  --soft: #1d2128;
  --text: #f2f4f6;
  --text2: #c9d1d9;
  --text3: #8e98a8;
  --text4: #657080;
  --line: #2b2f36;
  --line2: #363b44;
  --hair: #242932;
  --blue: #5a9bff;
  --blue2: #7ab0ff;
  --blue-bg: #17263d;
  --down: #6ea2ff;
  --down-bg: #17263d;
  --buy: #5a9bff;
  --buy-bg: #17263d;
  --up: #ff6b7a;
  --up2: #ff6b7a;
  --up-bg: #3a2025;
  --sell: #ff6b7a;
  --sell-bg: #3a2025;
  --good: #33d399;
  --good-bg: #143329;
  --green: #33d399;
  --green-bg: #143329;
  --amber: #fbbf24;
  --amber-bg: #34270e;
  --hold: #fbbf24;
  --hold-bg: #34270e;
  --primary: #5a9bff;
  --success: #33d399;
  --muted: #8e98a8;
  --warn-bg: #2f2710;
  --warn-line: #4d3c14;
  --warn-tx: #ffd479;
  --shadow: 0 18px 38px -22px rgba(0, 0, 0, .72);
  --shadow-soft: 0 12px 30px -22px rgba(0, 0, 0, .62);
  --shadow-float: 0 18px 38px -22px rgba(0, 0, 0, .76);
}

@keyframes sndDraw {
  from { stroke-dashoffset: 1; }
  to { stroke-dashoffset: 0; }
}

@keyframes sndFade {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes sndRise {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes sndGrow {
  from { transform: scaleY(0); }
  to { transform: scaleY(1); }
}

@keyframes sndGrowX {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

@keyframes sndPop {
  0% { transform: scale(.92); }
  60% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

@keyframes sndPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.45); opacity: .55; }
}

@keyframes sndSpin {
  to { transform: rotate(360deg); }
}

@keyframes sndSheetUp {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}

@keyframes sndBackdropIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

[data-rise] {
  animation: sndRise .42s var(--ease) both;
}

[data-draw] {
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  animation: sndDraw .8s var(--ease) both;
}

[data-fade] {
  animation: sndFade .46s ease-out both;
}

[data-grow] {
  transform-origin: bottom;
  animation: sndGrow .42s var(--ease) both;
}

[data-grow-x] {
  transform-origin: left;
  animation: sndGrowX .56s var(--ease) both;
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  background: var(--bg) !important;
  color: var(--text) !important;
  font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", system-ui, sans-serif !important;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0;
  word-break: keep-all;
  overflow-x: hidden;
}

button,
input,
select,
textarea {
  font-family: inherit !important;
  letter-spacing: 0;
}

[style*="letter-spacing:-"],
[style*="letter-spacing: -"] {
  letter-spacing: 0 !important;
}

button,
a,
input,
select,
textarea {
  -webkit-tap-highlight-color: transparent;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--blue) 28%, transparent) !important;
  outline-offset: 2px;
}

.num,
.snd-num,
.adm-num,
[id*="price" i],
[id*="amount" i],
[id*="rate" i] {
  font-variant-numeric: tabular-nums;
}

.snd-enhanced .appbar h1,
.snd-enhanced .top h1 {
  display: inline-flex !important;
  align-items: center;
  gap: 9px;
  min-width: 0;
}

.snd-logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  border-radius: 9px;
  overflow: hidden;
  background: #e8262d;
  box-shadow: 0 2px 8px rgba(232, 38, 45, .30);
}

.snd-logo-mark img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.snd-member .wrap,
.snd-auth .wrap,
.snd-doc .wrap {
  max-width: 440px;
}

.snd-member main.wrap {
  gap: 12px !important;
  padding-top: 12px !important;
}

.wrap,
.page,
.box {
  width: 100%;
  max-width: 440px;
}

.card,
.hero,
.preview,
.step,
.metric,
.tcard,
.group,
.box form,
.finalbox,
details.card {
  min-width: 0;
  max-width: 100%;
}

.appbar,
.top {
  position: sticky;
  top: 0;
  z-index: 25;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg) 96%, transparent) 0%,
    color-mix(in srgb, var(--bg) 88%, transparent) 78%,
    transparent 100%
  ) !important;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 78%, transparent) !important;
  backdrop-filter: blur(18px);
}

.appbar h1,
.top h1,
.brand h1,
main > h1,
.main h1 {
  letter-spacing: 0 !important;
}

.appbar h1 span[style*="gradient"],
.intro .pill,
h1 span[style*="gradient"] {
  background: var(--blue) !important;
  border-radius: 8px !important;
  letter-spacing: 0 !important;
  box-shadow: 0 8px 18px -12px color-mix(in srgb, var(--blue) 70%, transparent);
}

.free-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: max-content;
  max-width: 100%;
  margin: 0 auto 16px;
  padding: 6px 11px;
  border-radius: 999px;
  background: var(--blue-bg);
  color: var(--blue);
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1;
}

.free-badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--blue);
  animation: sndPulse 1.8s ease-in-out infinite;
}

.card,
.hero,
.preview,
.step,
.metric,
.tcard,
.group,
.box form,
.finalbox,
details.card {
  background: var(--surface) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--shadow-soft) !important;
}

.hero,
.preview,
.finalbox {
  border-radius: var(--r-xl) !important;
  box-shadow: var(--shadow) !important;
}

.home-finalbox {
  min-width: 0;
  max-width: 100%;
  background: linear-gradient(155deg, #171d28 0%, #253349 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, .10) !important;
  border-radius: 24px !important;
  box-shadow: var(--shadow-float) !important;
}

.home-finalbox h2 {
  color: #fff !important;
}

.home-finalbox p {
  color: rgba(255, 255, 255, .74) !important;
}

.home-finalbox .btn.secondary {
  background: rgba(255, 255, 255, .10) !important;
  border-color: rgba(255, 255, 255, .16) !important;
  color: #fff !important;
}

.card .card,
.hero .card {
  box-shadow: none !important;
}

.btn,
button.pri,
form button[type="submit"],
#donateBtn,
#pushInstallBtn,
.cta button,
.cta .btn {
  border-radius: var(--r-lg) !important;
  font-weight: 800 !important;
}

.btn.primary,
button.pri,
form button[type="submit"],
#donateBtn,
#pushInstallBtn {
  background: var(--blue) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: 0 12px 22px -14px color-mix(in srgb, var(--blue) 72%, transparent) !important;
}

.btn.secondary,
.btn.ghost,
.alt,
button.ghost {
  background: var(--surface2) !important;
  color: var(--text2) !important;
  border: 1px solid var(--line) !important;
}

.home-finalbox.home-finalbox {
  display: grid !important;
  gap: 16px !important;
  min-height: 0 !important;
  padding: 20px !important;
  background: linear-gradient(155deg, #171d28 0%, #253349 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, .10) !important;
  border-radius: 24px !important;
  box-shadow: var(--shadow-float) !important;
}

.home-finalbox.home-finalbox .cta {
  margin-top: 0 !important;
}

.home-finalbox.home-finalbox .btn.primary {
  background: #3182f6 !important;
  color: #fff !important;
  border-color: transparent !important;
}

.home-finalbox.home-finalbox .btn.secondary {
  background: rgba(255, 255, 255, .10) !important;
  border-color: rgba(255, 255, 255, .16) !important;
  color: #fff !important;
}

.home-final-checks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.home-final-checks span {
  min-width: 0;
  border-radius: 15px;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .10);
  padding: 10px 11px;
  color: rgba(255, 255, 255, .82);
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1.35;
}

input,
select,
textarea {
  background: var(--surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--line) !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--blue) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--blue) 14%, transparent) !important;
}

.chip,
.chip-b,
.chip-n,
.badge,
.b,
.nstate {
  border-radius: 999px !important;
  letter-spacing: 0 !important;
}

.chip-b,
.tab.active,
.tcard .tt .h,
.metric .v.fair,
a.back,
.back {
  color: var(--blue) !important;
}

.row {
  min-width: 0;
}

.row .v {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.chip-b,
.down-bg,
.ico,
.nav a.login {
  background: var(--blue-bg) !important;
}

.tabbar {
  left: 50% !important;
  right: auto !important;
  bottom: calc(8px + env(safe-area-inset-bottom)) !important;
  width: min(416px, calc(100% - 24px)) !important;
  max-width: 416px;
  transform: translateX(-50%);
  align-items: center;
  gap: 0;
  padding: 7px 4px !important;
  background: color-mix(in srgb, var(--surface) 96%, transparent) !important;
  border: 1px solid var(--line) !important;
  border-radius: 22px !important;
  box-shadow: var(--shadow-float) !important;
  backdrop-filter: blur(18px);
}

.tab {
  color: var(--text4) !important;
  min-width: 0;
  padding: 3px 2px !important;
  border-radius: 15px;
  font-size: 10.5px !important;
  line-height: 1.15;
  transition: color .18s ease, background .18s ease, transform .12s ease;
}

.tab svg {
  width: 21px !important;
  height: 21px !important;
}

.tab.active {
  color: var(--blue) !important;
  font-weight: 800 !important;
}

.tab.active svg {
  background: var(--blue-bg);
  border-radius: 12px;
  box-sizing: content-box;
  padding: 4px 12px;
  margin: -4px 0 0;
  animation: sndPop .45s var(--ease) both;
}

.tab:active {
  transform: scale(.97);
}

.snd-member {
  padding-bottom: calc(148px + env(safe-area-inset-bottom)) !important;
}

.snd-member main.wrap {
  padding-bottom: 72px;
}

.snd-member.snd-has-tabbar::after {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  height: calc(128px + env(safe-area-inset-bottom));
  pointer-events: none;
  z-index: 19;
  background: linear-gradient(180deg, rgba(246, 248, 251, 0), var(--bg) 44%, var(--bg) 100%);
  transition: opacity .2s ease;
}

.snd-member.snd-has-tabbar.snd-tabbar-hidden::after {
  opacity: 0;
}

.snd-member .kfab {
  bottom: calc(env(safe-area-inset-bottom, 0px) + 112px) !important;
}

@media (max-width: 430px) {
  .snd-member .kfab {
    bottom: calc(env(safe-area-inset-bottom, 0px) + 108px) !important;
    right: 14px !important;
  }
}

.snd-member .appbar .wrap {
  padding-top: 2px;
}

.snd-member .appbar .chips {
  gap: 6px !important;
}

.snd-member .appbar .chip-b,
.snd-member .appbar .chip-n,
.snd-member .appbar .chip-sub {
  font-size: 11.5px !important;
}

.snd-member .card,
.snd-member .hero,
.snd-member .metric,
.snd-member .preview,
.snd-member .group,
.snd-member details.card {
  border-radius: 16px !important;
}

.snd-member .hero {
  border-radius: 20px !important;
}

.snd-member .metric {
  padding: 14px 13px !important;
}

.snd-member .metric .lb,
.snd-member .card .sect,
.snd-section-title {
  color: var(--text3) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.snd-member .metric .v {
  font-size: 21px !important;
  letter-spacing: 0 !important;
}

.snd-section-title {
  margin: 8px 4px 8px;
}

.seg,
.pills,
#psPeriod {
  background: var(--surface2) !important;
  border-radius: var(--r-md) !important;
  padding: 4px !important;
  gap: 4px !important;
}

.seg button,
.pills button,
#psPeriod button {
  min-height: 36px;
  border-radius: 11px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  transition: background .18s ease, color .18s ease, box-shadow .18s ease, transform .12s ease;
}

.seg button.on,
.pills button.on,
#psPeriod button[style*="box-shadow"] {
  background: var(--surface) !important;
  color: var(--blue) !important;
  box-shadow: 0 1px 5px rgba(17, 24, 39, .12) !important;
}

.tiles {
  grid-template-columns: 1fr !important;
  gap: 10px !important;
}

.plan {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-rows: auto auto;
  align-items: center;
  gap: 2px 12px;
  min-height: 70px;
  padding: 14px 16px !important;
  text-align: left !important;
  border-radius: var(--r-lg) !important;
  border: 1px solid var(--line) !important;
  background: var(--surface) !important;
  box-shadow: none !important;
  transition: transform .12s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.plan:active {
  transform: scale(.985);
}

.plan .d {
  grid-column: 1;
  grid-row: 1;
  font-size: 14.5px !important;
  color: var(--text) !important;
}

.plan .pr {
  grid-column: 2;
  grid-row: 1 / 3;
  margin: 0 !important;
  align-self: center;
  white-space: nowrap;
  color: var(--blue) !important;
  font-size: 17px !important;
}

.plan .per {
  grid-column: 1;
  grid-row: 2;
  margin-top: 0 !important;
  color: var(--text3) !important;
  font-size: 12px !important;
  font-weight: 700;
}

.plan.sel {
  border-color: color-mix(in srgb, var(--blue) 42%, var(--line)) !important;
  background: var(--blue-bg) !important;
  box-shadow: 0 10px 24px -22px color-mix(in srgb, var(--blue) 70%, transparent) !important;
}

.plan.sel .d,
.plan.sel .pr {
  color: var(--blue) !important;
}

.settings-status {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 15px 16px !important;
  background: var(--good-bg) !important;
  border-color: color-mix(in srgb, var(--good) 16%, var(--line)) !important;
}

.settings-status .status-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 38px;
  height: 38px;
  border-radius: 11px;
  background: var(--good);
  color: #fff;
}

.settings-status b {
  display: block;
  color: color-mix(in srgb, var(--good) 78%, #064e3b);
  font-size: 14.5px;
  font-weight: 900;
  line-height: 1.3;
}

.settings-status span[data-sub] {
  display: block;
  margin-top: 2px;
  color: color-mix(in srgb, var(--good) 76%, var(--text2));
  font-size: 12px;
  font-weight: 700;
}

.donation-card .donation-note {
  margin: 0 0 12px;
  padding: 11px 13px;
  border-radius: 12px;
  background: var(--blue-bg);
  color: var(--blue);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.55;
}

.donation-card .plans {
  margin-top: 0 !important;
}

.donation-card .tiles {
  display: flex !important;
  flex-direction: column;
  gap: 10px !important;
}

.donation-card .plan {
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  grid-template-rows: auto auto !important;
  min-height: 64px;
  padding: 13px 14px !important;
  gap: 1px 11px;
}

.donation-card .plan::before {
  content: attr(data-emoji);
  grid-column: 1;
  grid-row: 1 / 3;
  align-self: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 11px;
  background: var(--surface2);
  color: var(--text);
  font-size: 18px;
}

.donation-card .plan .d {
  grid-column: 2 !important;
  grid-row: 1 !important;
  font-size: 14.5px !important;
}

.donation-card .plan .pr {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
  align-self: center !important;
  font-size: 15px !important;
}

.donation-card .plan .per {
  grid-column: 2 !important;
  grid-row: 2 !important;
  color: var(--text3) !important;
}

.donation-card .btn {
  margin-top: 12px;
}

.settings-list {
  padding: 0 !important;
  overflow: hidden;
}

.settings-list .settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 50px;
  padding: 14px 16px;
  color: inherit;
  text-decoration: none;
}

.settings-list .settings-row + .settings-row {
  border-top: 1px solid var(--hair);
}

.settings-list .settings-row b {
  display: block;
  font-size: 14px;
  font-weight: 800;
}

.settings-list .settings-row span {
  min-width: 0;
}

.settings-list .settings-row small {
  display: block;
  margin-top: 2px;
  color: var(--text3);
  font-size: 12px;
  font-weight: 600;
}

.settings-list .settings-row svg {
  flex: 0 0 auto;
}

.settings-actions {
  display: flex;
  gap: 10px;
}

.settings-actions .btn,
.settings-actions .withdraw {
  flex: 1;
  min-height: 46px;
  margin: 0;
  border-radius: 13px !important;
  text-decoration: none;
}

.settings-actions .withdraw {
  background: var(--surface) !important;
  border: 1px solid color-mix(in srgb, var(--up) 24%, var(--line)) !important;
  color: var(--up) !important;
  font: inherit;
  font-size: 13.5px;
  font-weight: 800;
  cursor: pointer;
}

.settings-account .row {
  min-height: 44px;
}

.trow,
.hist,
.rows .row,
.row {
  min-height: 42px;
}

.snd-route-simulation #btResult > div,
.snd-route-simulation #btResult [style*="display:flex"] {
  min-width: 0;
}

.snd-route-simulation #btResult > div:first-child > div[style*="top:-30px"] {
  right: 0 !important;
  width: 80px !important;
  height: 80px !important;
}

.snd-route-simulation #btResult [style*="font-size:38px"] {
  font-size: clamp(30px, 8vw, 38px) !important;
  line-height: 1.08 !important;
  overflow-wrap: anywhere;
}

.snd-route-simulation #btResult [style*="font-size:25px"] {
  font-size: clamp(20px, 6vw, 25px) !important;
  line-height: 1.12 !important;
}

.snd-route-info .grid3 {
  grid-template-columns: 1fr !important;
}

.snd-route-info .grid3 .m,
.snd-route-info .grid3 .m .v,
.snd-route-info .grid3 .m .sub {
  min-width: 0;
  max-width: 100%;
}

.snd-route-info .grid3 .m .v,
.snd-route-info .grid3 .m .sub {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  overflow-wrap: anywhere;
}

.snd-route-schedule .tcard {
  gap: 12px !important;
}

.snd-route-schedule .tcard .tt {
  width: 76px !important;
  min-width: 76px !important;
}

.snd-route-schedule .tcard .tt .h {
  white-space: nowrap;
  font-size: clamp(20px, 5.4vw, 23px) !important;
}

.gauge .bub {
  min-width: 36px;
  text-align: center;
}

.gauge .segs span.on {
  min-width: 38px;
}

.segs span,
.gauge i,
.distrow .fill,
svg path,
svg circle,
svg polyline,
svg line {
  transition: color .18s ease, background .18s ease, border-color .18s ease, opacity .18s ease, transform .18s ease, stroke .18s ease, fill .18s ease;
}

.gauge .segs span.on,
.gauge i.on {
  animation: sndPop .5s var(--ease) .18s both;
}

.chart svg,
.shot svg,
svg[role="img"] {
  overflow: visible;
}

.skel {
  background-size: 340px 100% !important;
}

.toast,
[role="status"].toast {
  background: var(--text) !important;
  color: var(--surface) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: 0 18px 34px -18px rgba(0, 0, 0, .48) !important;
}

dialog {
  border-radius: var(--r-xl) var(--r-xl) 0 0 !important;
  background: var(--surface) !important;
  color: var(--text) !important;
}

dialog::backdrop {
  background: rgba(15, 20, 30, .46) !important;
}

.investment-note {
  color: var(--text3) !important;
  letter-spacing: 0;
}

/* Auth and utility screens that were not covered by the imported mobile mockup */
.snd-auth .box,
.snd-auth main {
  max-width: 440px !important;
}

.snd-auth form,
.snd-route-select .box {
  border-radius: var(--r-xl) !important;
  box-shadow: var(--shadow) !important;
}

.snd-auth input {
  min-height: 52px;
  border-radius: var(--r-md) !important;
}

.snd-auth button,
.snd-auth .alt,
.snd-route-select .card,
.snd-route-select .logout {
  min-height: 50px;
  border-radius: var(--r-lg) !important;
}

.snd-route-select .cards {
  gap: 10px !important;
}

.snd-route-select .card {
  border: 1px solid var(--line) !important;
  background: var(--surface) !important;
  box-shadow: var(--shadow-soft) !important;
}

.snd-doc .paybox {
  max-width: 440px;
  border-radius: var(--r-xl);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

/* Legal and document pages */
body > main:not(.wrap):not(.page):not(.main):not(.box) {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-soft);
  padding: 24px;
}

body > main:not(.wrap):not(.page):not(.main):not(.box) h1 {
  font-size: 26px !important;
  line-height: 1.25;
}

body > main:not(.wrap):not(.page):not(.main):not(.box) h2 {
  color: var(--text) !important;
}

body > main:not(.wrap):not(.page):not(.main):not(.box) p,
body > main:not(.wrap):not(.page):not(.main):not(.box) li {
  color: var(--text2) !important;
  word-break: keep-all;
}

/* Admin console */
.side {
  width: 248px !important;
  background: #16181d !important;
  border-right: 0 !important;
  padding: 22px 14px !important;
  gap: 2px !important;
}

.side .brand {
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  padding: 6px 10px 22px !important;
}

.side .brand span {
  display: flex;
  min-width: 0;
  flex-direction: column;
  line-height: 1.15;
}

.side .brand b {
  color: #fff;
  font-size: 15px;
  font-weight: 800;
}

.side .brand small {
  color: #5a9bff;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .03em;
}

.side .brand img {
  background: #000;
  border-radius: 9px !important;
  object-fit: cover;
}

.side a {
  color: #aeb6c0 !important;
  border-radius: 9px !important;
  font-size: 13.5px !important;
  font-weight: 700 !important;
  padding: 10px 12px !important;
  transition: background .14s ease, color .14s ease, transform .14s ease;
}

.side a:hover {
  background: #20242b !important;
  color: #f2f4f6 !important;
}

.side a.on {
  background: #222b3a !important;
  color: #fff !important;
}

.side .out {
  color: #ff8a95 !important;
}

.main {
  background: var(--bg) !important;
  padding: 24px 28px 44px !important;
}

.main h1 {
  font-size: 22px !important;
  font-weight: 800 !important;
}

.main .sub {
  color: var(--text3) !important;
}

.kpi {
  background: var(--surface) !important;
  border: 1px solid var(--line) !important;
  border-radius: 12px !important;
  box-shadow: var(--shadow-soft) !important;
  padding: 16px 18px !important;
}

.kpi .v {
  font-size: 27px !important;
  letter-spacing: 0 !important;
}

.main .card {
  border-radius: 12px !important;
  padding: 18px !important;
}

.tools {
  align-items: center;
}

.tools input,
.tools select {
  background: var(--surface) !important;
  min-height: 40px;
}

.main button,
.tools button,
#pager button,
#payPager button {
  border-radius: 9px !important;
}

table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

th {
  background: var(--surface2) !important;
  color: var(--text3) !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  position: sticky;
  top: 0;
  z-index: 1;
}

td,
th {
  border-top-color: var(--hair) !important;
}

tbody tr {
  transition: background .12s ease;
}

tbody tr:hover {
  background: color-mix(in srgb, var(--blue-bg) 40%, transparent);
}

.chwrap {
  border-radius: 10px;
}

.snd-admin .scroll {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
}

.snd-admin .scroll table {
  margin: 0;
}

.snd-admin .tools {
  gap: 8px !important;
}

.snd-admin .tools input,
.snd-admin .tools select {
  border-radius: 9px !important;
}

.snd-admin button.mini {
  min-height: 32px;
}

.distrow .track {
  background: var(--surface2) !important;
}

.distrow .fill {
  background: linear-gradient(180deg, var(--blue2), var(--blue)) !important;
}

@media (max-width: 620px) {
  .side {
    width: 100% !important;
    padding: 8px !important;
    border-bottom: 0 !important;
  }

  .side a {
    flex: 0 0 auto;
  }

  .main {
    padding: 16px 14px 48px !important;
  }

  .wrap,
  .page,
  .box {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  body > main:not(.wrap):not(.page):not(.main):not(.box) {
    border-radius: var(--r-lg);
    padding: 20px 18px;
  }
}

.snd-ui-icon {
  display: inline-block;
  width: 1.05em;
  height: 1.05em;
  flex: none;
  color: currentColor;
  vertical-align: -0.18em;
}

.ico .snd-ui-icon,
.card .ic .snd-ui-icon {
  width: 19px;
  height: 19px;
}

.arr,
.back {
  display: inline-flex !important;
  align-items: center;
  gap: 5px;
}

.arr {
  justify-content: center;
  min-width: 18px;
  font-size: 0 !important;
}

.arr .snd-ui-icon {
  width: 18px;
  height: 18px;
}

.back .snd-ui-icon {
  width: 16px;
  height: 16px;
}

[style*="#F0334B"][style*="color"],
[style*="#f0334b"][style*="color"] {
  color: var(--up) !important;
}

[style*="#2F6BFF"][style*="color"],
[style*="#2f6bff"][style*="color"] {
  color: var(--blue) !important;
}

.appbar h1 span[style*="gradient"],
.intro .pill,
h1 span[style*="gradient"] {
  color: #fff !important;
}

body.snd-route-simulation .hero.profit {
  background: linear-gradient(160deg, var(--up-bg), var(--surface)) !important;
  border-color: color-mix(in srgb, var(--up) 28%, var(--line)) !important;
  box-shadow: 0 12px 28px -22px color-mix(in srgb, var(--up) 62%, transparent) !important;
}

body.snd-route-simulation .hero.profit::after {
  background: color-mix(in srgb, var(--up) 21%, transparent) !important;
}

body.snd-route-simulation .hero.profit .ret {
  background: color-mix(in srgb, var(--up-bg) 82%, var(--surface)) !important;
  color: var(--up) !important;
}

body.snd-route-simulation .hero.loss {
  background: linear-gradient(160deg, var(--down-bg), var(--surface)) !important;
  border-color: color-mix(in srgb, var(--down) 24%, var(--line)) !important;
}

body.snd-route-simulation .hero.loss::after {
  background: color-mix(in srgb, var(--down) 24%, transparent) !important;
}

body.snd-route-simulation .hero.loss .ret {
  background: color-mix(in srgb, var(--down-bg) 82%, var(--surface)) !important;
  color: var(--down) !important;
}

body.snd-route-simulation .hero.flat {
  background: linear-gradient(160deg, var(--surface2), var(--surface)) !important;
  border-color: var(--line) !important;
}

body.snd-route-simulation .hero.flat .ret {
  background: var(--surface2) !important;
  color: var(--text3) !important;
}

body.snd-route-simulation .mode-toggle.on.profit {
  background: linear-gradient(160deg, var(--up-bg), var(--surface)) !important;
  border-color: color-mix(in srgb, var(--up) 38%, var(--line)) !important;
}

body.snd-route-simulation .mode-toggle.on.profit .mode-state,
body.snd-route-simulation .mode-toggle.profit .switch[aria-checked="true"] {
  background: var(--up) !important;
  color: #fff !important;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }

  [data-draw] {
    stroke-dashoffset: 0 !important;
  }
}
