/* Waplix global theme tokens */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    color-scheme: dark;
}

html[data-theme="light"] {
    color-scheme: light;
}

html[data-theme="dark"],
html:not([data-theme]) {
    --waplix-page-bg: #05080f;
    --waplix-page-bg-soft: #070b12;
    --waplix-surface: rgba(15, 23, 42, 0.82);
    --waplix-surface-soft: rgba(255, 255, 255, 0.045);
    --waplix-surface-elevated: rgba(8, 20, 33, 0.98);
    --waplix-border: rgba(148, 163, 184, 0.16);
    --waplix-border-strong: rgba(0, 240, 106, 0.28);
    --waplix-text: #f8fafc;
    --waplix-text-secondary: #cbd5e1;
    --waplix-text-muted: #94a3b8;
    --waplix-accent-green: #00f06a;
    --waplix-accent-cyan: #00d4ff;
    --waplix-accent-green-soft: rgba(0, 240, 106, 0.14);
    --waplix-accent-cyan-soft: rgba(0, 212, 255, 0.1);
    --waplix-danger: #ff3b5c;
    --waplix-warning: #ffc857;
    --waplix-success: #00f06a;
    --waplix-input-bg: rgba(255, 255, 255, 0.055);
    --waplix-input-border: rgba(148, 163, 184, 0.18);
    --waplix-sidebar-bg: linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(5, 8, 15, 0.98));
    --waplix-header-bg: rgba(5, 8, 15, 0.82);
    --waplix-dropdown-bg: rgba(15, 23, 42, 0.99);
    --waplix-shadow: 0 22px 70px rgba(0, 0, 0, 0.24);
    --waplix-shadow-soft: 0 16px 36px rgba(0, 0, 0, 0.18);
    --waplix-bg-gradient: radial-gradient(circle at 82% 0%, rgba(0, 240, 106, 0.16), transparent 34%), radial-gradient(circle at 12% 30%, rgba(0, 212, 255, 0.1), transparent 28%), #05080f;
    --waplix-card-gradient: linear-gradient(135deg, rgba(0, 240, 106, 0.075), rgba(0, 212, 255, 0.04));
    --waplix-hero-glow: radial-gradient(circle at 78% 16%, rgba(0, 240, 106, 0.3), transparent 32%);
    --waplix-code-bg: #070b12;
    --waplix-code-text: #cbd5e1;
    --waplix-table-head: rgba(255, 255, 255, 0.04);
    --waplix-table-row-hover: rgba(255, 255, 255, 0.03);
    --waplix-focus-ring: 0 0 0 4px rgba(0, 240, 106, 0.13);
    --waplix-btn-text-on-accent: #03140a;
    --waplix-primary: #146c43;
    --waplix-ink: #f8fafc;
    --waplix-muted: #94a3b8;
    --waplix-bg: #05080f;
    --waplix-row-bg: rgba(255, 255, 255, 0.04);
    --waplix-row-border: rgba(255, 255, 255, 0.075);
    --waplix-row-hover-shadow: 0 22px 70px rgba(0, 0, 0, 0.24), 0 0 34px rgba(0, 240, 106, 0.06);
    --waplix-card-inset: inset 0 1px 0 rgba(255, 255, 255, 0.04);
    --waplix-card-shadow: 0 22px 70px rgba(0, 0, 0, 0.24);
    --waplix-panel-bg: linear-gradient(135deg, rgba(0, 240, 106, 0.075), rgba(0, 212, 255, 0.04)), var(--dash-panel);
    --waplix-detail-hero-bg:
        radial-gradient(circle at top right, rgba(0, 240, 106, 0.16), transparent 34%),
        linear-gradient(135deg, rgba(0, 240, 106, 0.075), rgba(0, 212, 255, 0.04)),
        var(--dash-panel);

    --dash-bg: #05080f;
    --dash-panel: rgba(15, 23, 42, 0.82);
    --dash-panel-soft: rgba(255, 255, 255, 0.045);
    --dash-line: rgba(148, 163, 184, 0.16);
    --dash-line-hot: rgba(0, 240, 106, 0.34);
    --dash-green: #00f06a;
    --dash-cyan: #00d4ff;
    --dash-text: #f8fafc;
    --dash-muted: #cbd5e1;
    --dash-soft: #94a3b8;

    --login-bg: #05080f;
    --login-card: rgba(6, 17, 15, 0.42);
    --login-line: rgba(0, 240, 106, 0.14);
    --login-line-hot: rgba(0, 240, 106, 0.36);
    --login-green: #00f06a;
    --login-cyan: #00d4ff;
    --login-text: #f8fafc;
    --login-muted: #cbd5e1;
    --login-soft: #94a3b8;
    --login-page-gradient: radial-gradient(circle at 78% 16%, rgba(0, 240, 106, 0.3), transparent 32%), radial-gradient(circle at 12% 76%, rgba(0, 212, 255, 0.16), transparent 34%), linear-gradient(135deg, #05080f 0%, #07111f 48%, #081421 100%);
    --login-form-panel-bg: transparent;
    --login-card-shadow: 0 18px 48px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    --login-card-inner-border: rgba(255, 255, 255, 0.06);
    --login-card-blur: blur(22px) saturate(168%);
    --login-card-accent: linear-gradient(135deg, rgba(0, 240, 106, 0.08), rgba(0, 212, 255, 0.05));
    --login-input-bg: rgba(10, 22, 19, 0.94);
    --login-input-bg-focus: rgba(12, 28, 24, 0.98);
    --login-input-border: rgba(0, 240, 106, 0.28);
    --login-input-card-bg: rgba(7, 18, 15, 0.62);
    --login-input-card-border: rgba(0, 240, 106, 0.18);
    --login-input-card-shadow: 0 10px 28px rgba(0, 0, 0, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.06);
    --login-input-placeholder: rgba(203, 213, 225, 0.46);
    --login-mockup-panel-bg: radial-gradient(circle at 68% 28%, rgba(0, 240, 106, 0.2), transparent 34%), linear-gradient(135deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.012));
    --login-mockup-card-bg: rgba(7, 18, 15, 0.52);
    --login-mockup-tile-bg: rgba(7, 18, 15, 0.34);
    --login-mockup-tile-border: rgba(0, 240, 106, 0.12);
    --login-mockup-chart-bg: rgba(7, 18, 15, 0.34);
    --login-auth-back-bg: rgba(7, 18, 15, 0.42);
    --login-auth-back-shadow: 0 16px 44px rgba(0, 0, 0, 0.22);
    --login-trial-highlight-bg: linear-gradient(135deg, rgba(0, 240, 106, 0.16), rgba(0, 212, 255, 0.1));
    --login-trial-highlight-border: rgba(0, 240, 106, 0.22);
    --login-check-icon-bg: rgba(0, 240, 106, 0.16);
    --login-trial-qr-bg: #effff6;
    --login-trial-qr-dot: #07111f;

    --docs-bg: #070b12;
    --docs-panel: #0f141d;
    --docs-panel-2: #111925;
    --docs-border: rgba(255, 255, 255, 0.08);
    --docs-text: #f8fafc;
    --docs-muted: #94a3b8;
    --docs-accent: #00f06a;
    --docs-accent-2: #00d4ff;
    --docs-active: rgba(0, 240, 106, 0.14);

    --bg-primary: var(--waplix-page-bg);
    --bg-secondary: var(--waplix-page-bg-soft);
    --bg-gradient: var(--waplix-bg-gradient);
    --surface: var(--waplix-surface);
    --surface-soft: var(--waplix-surface-soft);
    --surface-elevated: var(--waplix-surface-elevated);
    --surface-glass: var(--waplix-surface-soft);
    --text-primary: var(--waplix-text);
    --text-secondary: var(--waplix-text-secondary);
    --text-muted: var(--waplix-text-muted);
    --border: var(--waplix-border);
    --border-strong: var(--waplix-border-strong);
    --input-bg: var(--waplix-input-bg);
    --input-text: var(--waplix-text);
    --input-border: var(--waplix-input-border);
    --sidebar-bg: var(--waplix-sidebar-bg);
    --header-bg: var(--waplix-header-bg);
    --card-gradient: var(--waplix-card-gradient);
    --shadow: var(--waplix-shadow);
    --shadow-soft: var(--waplix-shadow-soft);
    --accent: var(--waplix-accent-green);
    --accent-2: var(--waplix-accent-cyan);
    --btn-primary-bg: linear-gradient(135deg, var(--dash-green), var(--dash-cyan));
    --btn-primary-text: #03140a;
    --btn-primary-shadow: 0 16px 46px rgba(0, 240, 106, 0.2);
    --btn-secondary-bg: var(--surface-soft);
    --btn-secondary-text: var(--text-primary);
    --btn-secondary-border: var(--border);
    --btn-secondary-shadow: none;
    --btn-danger-text: #ffb3c1;
    --btn-danger-bg: rgba(255, 59, 92, 0.08);
    --btn-danger-border: rgba(255, 59, 92, 0.24);
    --btn-outline-text: var(--text-primary);
    --btn-outline-bg: transparent;
    --btn-outline-border: var(--border-strong);
    --btn-copy-bg: var(--surface-soft);
    --btn-copy-text: var(--text-primary);
    --btn-copy-border: var(--border);
    --btn-pill-bg: rgba(255, 255, 255, 0.055);
    --btn-pill-text: var(--text-primary);
    --btn-pill-border: rgba(255, 255, 255, 0.09);
}

html[data-theme="light"] {
    --waplix-page-bg: #f6fff9;
    --waplix-page-bg-soft: #ecfff6;
    --waplix-surface: rgba(255, 255, 255, 0.88);
    --waplix-surface-soft: rgba(241, 255, 249, 0.78);
    --waplix-surface-elevated: rgba(255, 255, 255, 0.94);
    --waplix-border: rgba(0, 150, 95, 0.16);
    --waplix-border-strong: rgba(0, 190, 120, 0.28);
    --waplix-text: #09271c;
    --waplix-text-secondary: #345f50;
    --waplix-text-muted: #6b8b80;
    --waplix-accent-green: #00c853;
    --waplix-accent-cyan: #00a8cc;
    --waplix-accent-green-soft: rgba(0, 232, 125, 0.16);
    --waplix-accent-cyan-soft: rgba(0, 194, 255, 0.14);
    --waplix-danger: #e11d48;
    --waplix-warning: #d97706;
    --waplix-success: #059669;
    --waplix-input-bg: rgba(255, 255, 255, 0.96);
    --waplix-input-border: rgba(0, 150, 95, 0.18);
    --waplix-sidebar-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(234, 255, 246, 0.88));
    --waplix-header-bg: rgba(255, 255, 255, 0.82);
    --waplix-dropdown-bg: rgba(255, 255, 255, 0.96);
    --waplix-shadow: 0 18px 45px rgba(16, 82, 70, 0.13);
    --waplix-shadow-soft: 0 10px 28px rgba(16, 82, 70, 0.09);
    --waplix-bg-gradient:
        radial-gradient(circle at 12% 8%, rgba(0, 232, 125, 0.18), transparent 34%),
        radial-gradient(circle at 88% 10%, rgba(0, 194, 255, 0.16), transparent 30%),
        linear-gradient(135deg, #f8fffb 0%, #eafff5 45%, #f5fbff 100%);
    --waplix-card-gradient:
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(232, 255, 246, 0.84)),
        radial-gradient(circle at top right, rgba(0, 232, 125, 0.13), transparent 42%);
    --waplix-hero-glow: radial-gradient(circle at 78% 16%, rgba(0, 232, 125, 0.22), transparent 34%);
    --waplix-code-bg: #e8f7f2;
    --waplix-code-text: #0d4a3a;
    --waplix-table-head: rgba(0, 232, 125, 0.1);
    --waplix-table-row-hover: rgba(0, 232, 125, 0.06);
    --waplix-focus-ring: 0 0 0 4px rgba(0, 200, 83, 0.16);
    --waplix-btn-text-on-accent: #052014;
    --waplix-primary: #0f9d58;
    --waplix-ink: #09271c;
    --waplix-muted: #6b8b80;
    --waplix-bg: #f6fff9;
    --waplix-row-bg: rgba(255, 255, 255, 0.82);
    --waplix-row-border: rgba(0, 150, 95, 0.14);
    --waplix-row-hover-shadow: 0 14px 32px rgba(16, 82, 70, 0.12), 0 0 0 1px rgba(0, 190, 120, 0.12);
    --waplix-card-inset: inset 0 1px 0 rgba(255, 255, 255, 0.85);
    --waplix-card-shadow: 0 18px 45px rgba(16, 82, 70, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.85);
    --waplix-panel-bg: var(--card-gradient), var(--surface);
    --waplix-detail-hero-bg:
        radial-gradient(circle at top right, rgba(0, 232, 125, 0.16), transparent 38%),
        radial-gradient(circle at 10% 88%, rgba(0, 194, 255, 0.12), transparent 32%),
        var(--card-gradient),
        var(--surface);

    --dash-bg: #f6fff9;
    --dash-panel: rgba(255, 255, 255, 0.88);
    --dash-panel-soft: rgba(241, 255, 249, 0.78);
    --dash-line: rgba(0, 150, 95, 0.16);
    --dash-line-hot: rgba(0, 190, 120, 0.28);
    --dash-green: #00c853;
    --dash-cyan: #00a8cc;
    --dash-text: #09271c;
    --dash-muted: #345f50;
    --dash-soft: #6b8b80;

    --login-bg: #ecfff6;
    --login-card: linear-gradient(145deg, rgba(255, 255, 255, 0.36), rgba(255, 255, 255, 0.18));
    --login-line: rgba(255, 255, 255, 0.52);
    --login-line-hot: rgba(0, 190, 120, 0.34);
    --login-green: #00c853;
    --login-cyan: #00a8cc;
    --login-text: #09271c;
    --login-muted: #345f50;
    --login-soft: #6b8b80;
    --login-page-gradient: radial-gradient(circle at 78% 16%, rgba(0, 200, 120, 0.2), transparent 32%), radial-gradient(circle at 12% 76%, rgba(0, 180, 220, 0.14), transparent 34%), linear-gradient(135deg, #ecfff6 0%, #f6fff9 48%, #eef8ff 100%);
    --login-form-panel-bg: transparent;
    --login-card-shadow: 0 22px 56px rgba(16, 82, 70, 0.09), inset 0 1px 0 rgba(255, 255, 255, 0.72);
    --login-card-inner-border: rgba(255, 255, 255, 0.58);
    --login-card-blur: blur(26px) saturate(185%);
    --login-card-accent: linear-gradient(135deg, rgba(0, 200, 120, 0.07), rgba(0, 180, 220, 0.04));
    --login-input-bg: rgba(255, 255, 255, 0.72);
    --login-input-bg-focus: rgba(255, 255, 255, 0.88);
    --login-input-border: rgba(0, 150, 95, 0.28);
    --login-input-card-bg: rgba(255, 255, 255, 0.58);
    --login-input-card-border: rgba(0, 150, 95, 0.22);
    --login-input-card-shadow: 0 10px 28px rgba(16, 82, 70, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.82);
    --login-input-placeholder: rgba(52, 95, 80, 0.45);
    --login-mockup-panel-bg: radial-gradient(circle at 68% 28%, rgba(0, 200, 120, 0.12), transparent 34%), linear-gradient(135deg, rgba(255, 255, 255, 0.55), rgba(241, 255, 249, 0.42));
    --login-mockup-card-bg: linear-gradient(145deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.22));
    --login-mockup-tile-bg: rgba(255, 255, 255, 0.26);
    --login-mockup-tile-border: rgba(255, 255, 255, 0.62);
    --login-mockup-chart-bg: rgba(255, 255, 255, 0.26);
    --login-auth-back-bg: linear-gradient(145deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.24));
    --login-auth-back-shadow: 0 12px 32px rgba(16, 82, 70, 0.08);
    --login-trial-highlight-bg: linear-gradient(135deg, rgba(0, 200, 120, 0.1), rgba(0, 180, 220, 0.08));
    --login-trial-highlight-border: rgba(0, 150, 95, 0.22);
    --login-check-icon-bg: rgba(0, 200, 120, 0.14);
    --login-trial-qr-bg: #f0fff8;
    --login-trial-qr-dot: #09271c;

    --docs-bg: #f6fff9;
    --docs-panel: rgba(255, 255, 255, 0.92);
    --docs-panel-2: rgba(241, 255, 249, 0.88);
    --docs-border: rgba(0, 150, 95, 0.16);
    --docs-text: #09271c;
    --docs-muted: #6b8b80;
    --docs-accent: #00c853;
    --docs-accent-2: #00a8cc;
    --docs-active: rgba(0, 232, 125, 0.14);

    --bg-primary: #f6fff9;
    --bg-secondary: #ecfff6;
    --bg-gradient: var(--waplix-bg-gradient);
    --surface: rgba(255, 255, 255, 0.88);
    --surface-soft: rgba(241, 255, 249, 0.78);
    --surface-elevated: rgba(255, 255, 255, 0.94);
    --surface-glass: rgba(255, 255, 255, 0.72);
    --text-primary: #09271c;
    --text-secondary: #345f50;
    --text-muted: #6b8b80;
    --border: rgba(0, 150, 95, 0.16);
    --border-strong: rgba(0, 190, 120, 0.28);
    --input-bg: var(--waplix-input-bg);
    --input-text: var(--waplix-text);
    --input-border: var(--waplix-input-border);
    --sidebar-bg: var(--waplix-sidebar-bg);
    --header-bg: var(--waplix-header-bg);
    --card-gradient: var(--waplix-card-gradient);
    --shadow: 0 18px 45px rgba(16, 82, 70, 0.13);
    --shadow-soft: 0 10px 28px rgba(16, 82, 70, 0.09);
    --accent: var(--waplix-accent-green);
    --accent-2: var(--waplix-accent-cyan);
    --btn-primary-bg: linear-gradient(135deg, var(--accent), var(--accent-2));
    --btn-primary-text: var(--waplix-btn-text-on-accent);
    --btn-primary-shadow: 0 14px 32px rgba(16, 82, 70, 0.14);
    --btn-secondary-bg: var(--surface-elevated);
    --btn-secondary-text: var(--text-primary);
    --btn-secondary-border: var(--border-strong);
    --btn-secondary-shadow: var(--shadow-soft), var(--waplix-card-inset);
    --btn-danger-text: #be123c;
    --btn-danger-bg: rgba(225, 29, 72, 0.08);
    --btn-danger-border: rgba(225, 29, 72, 0.22);
    --btn-outline-text: var(--text-primary);
    --btn-outline-bg: var(--surface-elevated);
    --btn-outline-border: var(--border-strong);
    --btn-copy-bg: var(--surface-elevated);
    --btn-copy-text: var(--text-primary);
    --btn-copy-border: var(--border-strong);
    --btn-pill-bg: var(--surface-elevated);
    --btn-pill-text: var(--text-primary);
    --btn-pill-border: var(--border);
}

/* Theme-aware logos */
.logo-dark,
.logo-light {
    width: auto;
    max-width: 100%;
    object-fit: contain;
    vertical-align: middle;
}

html[data-theme="dark"] .logo-light,
html:not([data-theme]) .logo-light {
    display: none !important;
}

html[data-theme="dark"] .logo-dark,
html:not([data-theme]) .logo-dark {
    display: inline-block;
}

html[data-theme="light"] .logo-dark {
    display: none !important;
}

html[data-theme="light"] .logo-light {
    display: inline-block !important;
}

.landing-logo-img.logo-dark,
.landing-logo-img.logo-light,
.login-brand .logo-dark,
.login-brand .logo-light,
.docs-public-brand .logo-dark,
.docs-public-brand .logo-light {
    height: 32px;
    max-width: 160px;
}

.docs-public-brand .logo-dark,
.docs-public-brand .logo-light {
    height: 34px;
    max-width: 160px;
}

.app-topbar-brand .logo-dark,
.app-topbar-brand .logo-light {
    height: 34px;
    max-width: 160px;
}

.app-sidebar .brand .logo-dark,
.app-sidebar .brand .logo-light,
.sidebar-logo-img {
    height: 28px;
    max-width: 150px;
}

.app-sidebar .brand {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
}

body:not(.landing-page):not(.login-page):not(.documentation-body) {
    background: var(--bg-primary);
    color: var(--text-primary);
}

.theme-segmented-control {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 6px;
    border-radius: 16px;
    background: var(--waplix-surface-soft);
    border: 1px solid var(--waplix-border);
}

.theme-segmented-control button,
.theme-segmented-control label {
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid transparent;
    border-radius: 12px;
    background: transparent;
    color: var(--waplix-text-secondary);
    font-size: 0.9rem;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.theme-segmented-control button:hover,
.theme-segmented-control label:hover {
    color: var(--waplix-text);
    border-color: var(--waplix-border);
}

.theme-segmented-control button.active,
.theme-segmented-control label.active,
.theme-segmented-control input:checked + span {
    color: var(--waplix-btn-text-on-accent);
    background: linear-gradient(135deg, var(--waplix-accent-green), var(--waplix-accent-cyan));
    border-color: transparent;
    box-shadow: var(--waplix-shadow-soft);
}

.theme-segmented-control input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.theme-segmented-option {
    position: relative;
    display: inline-flex;
}

.theme-segmented-option span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 12px;
}

.theme-current-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    color: var(--waplix-text-muted);
    font-size: 0.86rem;
}

.theme-current-label strong {
    color: var(--waplix-accent-green);
}

/* 3D pill theme switch — matches reference toggle */
button.waplix-theme-switch,
.waplix-theme-switch {
    --ts-blue: #0047ff;
    --ts-track-w: 88px;
    --ts-track-h: 40px;
    --ts-thumb: 32px;
    --ts-gap: 4px;
    --ts-bed-dark: #141414;
    --ts-bed-light: #b8c0cc;
    appearance: none;
    -webkit-appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--ts-track-w);
    min-width: var(--ts-track-w);
    max-width: var(--ts-track-w);
    height: calc(var(--ts-track-h) + 5px);
    padding: 0;
    margin: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
    flex-shrink: 0;
    overflow: visible;
    line-height: 0;
    vertical-align: middle;
    -webkit-tap-highlight-color: transparent;
    box-sizing: border-box;
}

button.waplix-theme-switch:focus-visible,
.waplix-theme-switch:focus-visible {
    outline: none;
}

button.waplix-theme-switch:focus-visible .waplix-theme-switch__track,
.waplix-theme-switch:focus-visible .waplix-theme-switch__track {
    outline: 2px solid rgba(0, 71, 255, 0.45);
    outline-offset: 2px;
}

.waplix-theme-switch__bed {
    display: block;
    width: var(--ts-track-w);
    padding: 0 0 5px;
    border-radius: 999px;
    background: var(--ts-bed-dark);
    box-sizing: border-box;
    line-height: 0;
    transition: background 0.25s ease;
}

.waplix-theme-switch.is-light .waplix-theme-switch__bed {
    background: var(--ts-bed-light);
}

.waplix-theme-switch__track {
    position: relative;
    display: block;
    width: var(--ts-track-w);
    height: var(--ts-track-h);
    border-radius: 999px;
    background: #222222;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
    box-sizing: border-box;
    overflow: hidden;
    transition: background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.waplix-theme-switch.is-light .waplix-theme-switch__track {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.14);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.98),
        0 1px 3px rgba(15, 23, 42, 0.08);
}

.waplix-theme-switch__bg-icon {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    pointer-events: none;
    z-index: 1;
    transition: opacity 0.2s ease, color 0.2s ease;
}

.waplix-theme-switch__bg-icon svg {
    width: 16px;
    height: 16px;
    display: block;
}

.waplix-theme-switch__bg-icon--sun {
    left: 12px;
    color: rgba(255, 255, 255, 0.95);
    opacity: 1;
}

.waplix-theme-switch__bg-icon--moon {
    right: 12px;
    color: rgba(255, 255, 255, 0.34);
    opacity: 1;
}

.waplix-theme-switch.is-light .waplix-theme-switch__bg-icon--sun {
    opacity: 0;
}

.waplix-theme-switch.is-light .waplix-theme-switch__bg-icon--moon {
    color: #94a3b8;
    opacity: 1;
}

.waplix-theme-switch__thumb {
    position: absolute;
    top: var(--ts-gap);
    width: var(--ts-thumb);
    height: var(--ts-thumb);
    border-radius: 50%;
    background: var(--ts-blue);
    box-shadow: 0 2px 10px rgba(0, 71, 255, 0.38);
    display: block;
    z-index: 2;
    transition: left 0.28s cubic-bezier(0.4, 0, 0.2, 1), right 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

.waplix-theme-switch.is-dark .waplix-theme-switch__thumb {
    left: auto;
    right: var(--ts-gap);
}

.waplix-theme-switch.is-light .waplix-theme-switch__thumb {
    left: var(--ts-gap);
    right: auto;
}

.waplix-theme-switch__thumb-icon {
    position: absolute;
    inset: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    transition: opacity 0.2s ease;
}

.waplix-theme-switch__thumb-icon svg {
    width: 15px;
    height: 15px;
    display: block;
}

.waplix-theme-switch__thumb-icon--sun {
    opacity: 0;
}

.waplix-theme-switch__thumb-icon--moon {
    opacity: 1;
}

.waplix-theme-switch.is-light .waplix-theme-switch__thumb-icon--sun {
    opacity: 1;
}

.waplix-theme-switch.is-light .waplix-theme-switch__thumb-icon--moon {
    opacity: 0;
}

.app-topbar .topbar-actions {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
}

.app-topbar .topbar-actions input[type="hidden"] {
    display: none !important;
}

.topbar-profile-menu-theme {
    display: flex;
    align-items: center;
    gap: 14px;
    overflow: visible;
}

.topbar-profile-menu-theme .menu-item-label {
    flex: 1 1 auto;
    min-width: 0;
}

.topbar-profile-menu-theme .waplix-theme-switch {
    --ts-track-w: 64px;
    --ts-track-h: 30px;
    --ts-thumb: 24px;
    --ts-gap: 3px;
    flex: 0 0 64px;
    width: 64px;
    min-width: 64px;
    max-width: 64px;
    height: calc(30px + 4px);
    margin-left: auto;
}

.topbar-profile-menu-theme .waplix-theme-switch__bed {
    padding-bottom: 4px;
}

.topbar-profile-menu-theme .waplix-theme-switch__bg-icon svg,
.topbar-profile-menu-theme .waplix-theme-switch__thumb-icon svg {
    width: 12px;
    height: 12px;
}

.topbar-profile-menu-theme .waplix-theme-switch__bg-icon--sun {
    left: 9px;
}

.topbar-profile-menu-theme .waplix-theme-switch__bg-icon--moon {
    right: 9px;
}

.docs-topbar-left .waplix-theme-switch {
    margin-left: .5rem;
    padding-left: .85rem;
    border-left: 1px solid var(--border, rgba(15, 23, 42, 0.12));
}

.docs-public-topbar nav {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    flex-shrink: 0;
    margin-left: auto;
}

@media (max-width: 640px) {
    button.waplix-theme-switch,
    .waplix-theme-switch {
        --ts-track-w: 78px;
        --ts-track-h: 36px;
        --ts-thumb: 28px;
        width: var(--ts-track-w);
        min-width: var(--ts-track-w);
        max-width: var(--ts-track-w);
        height: calc(var(--ts-track-h) + 5px);
    }

    .docs-topbar-left .waplix-theme-switch {
        margin-left: .35rem;
        padding-left: .65rem;
    }

    .docs-public-topbar nav {
        gap: .65rem;
    }
}
