* {
    box-sizing: border-box;
}

:root {
    color-scheme: dark;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --bg: #08111f;
    --bg-2: #101a2e;
    --panel: rgba(15, 26, 45, .82);
    --panel-strong: rgba(18, 32, 55, .94);
    --text: #f4f9ff;
    --muted: #9fb2ca;
    --border: rgba(132, 173, 221, .24);
    --primary: #2f6bff;
    --accent: #14d3ae;
    --danger: #ff5370;
    --success: #36d399;
    --control: rgba(8, 17, 31, .78);
    --control-border: rgba(154, 197, 255, .28);
    --shadow: 0 20px 55px rgba(0, 0, 0, .34);
    --glow: 0 0 0 1px color-mix(in srgb, var(--primary) 34%, transparent), 0 0 36px color-mix(in srgb, var(--primary) 16%, transparent);
    background:
        linear-gradient(120deg, color-mix(in srgb, var(--primary) 12%, transparent), transparent 30%),
        linear-gradient(220deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 34%),
        radial-gradient(circle at top left, color-mix(in srgb, var(--primary) 18%, transparent), transparent 32%),
        linear-gradient(180deg, var(--bg), var(--bg-2));
    color: var(--text);
    letter-spacing: 0;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .035) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, .7), transparent 78%);
}

main {
    position: relative;
    width: min(1180px, calc(100% - 32px));
    margin: 22px auto 48px;
}

nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin: 0 0 22px;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
    box-shadow: var(--shadow);
    backdrop-filter: blur(16px);
}

nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    border: 1px solid color-mix(in srgb, var(--primary) 24%, var(--border));
    border-radius: 8px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--primary) 18%, transparent), color-mix(in srgb, var(--panel) 82%, transparent));
    color: color-mix(in srgb, var(--text) 92%, var(--primary));
    padding: 0 14px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

nav a:hover,
nav a:focus-visible {
    border-color: color-mix(in srgb, var(--accent) 58%, var(--primary));
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--primary) 34%, transparent), color-mix(in srgb, var(--accent) 14%, var(--panel)));
    box-shadow: var(--glow);
    transform: translateY(-1px);
    outline: none;
}

header {
    position: relative;
    overflow: hidden;
    margin-bottom: 18px;
    padding: 28px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--primary) 18%, transparent), transparent 42%),
        linear-gradient(225deg, color-mix(in srgb, var(--accent) 16%, transparent), transparent 38%),
        color-mix(in srgb, var(--panel-strong) 90%, transparent);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
}

header::after {
    content: "";
    position: absolute;
    inset: auto 24px 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent), var(--primary), transparent);
    opacity: .75;
}

h1,
h2,
h3,
p {
    margin-top: 0;
}

h1 {
    max-width: 760px;
    margin-bottom: 10px;
    font-size: clamp(34px, 5vw, 62px);
    line-height: .98;
    letter-spacing: 0;
    text-wrap: balance;
}

header p:not(.eyebrow) {
    max-width: 760px;
    color: var(--muted);
    font-size: 18px;
}

.brand-logo {
    max-width: 260px;
    max-height: 82px;
    object-fit: contain;
    margin-bottom: 14px;
}

.eyebrow {
    color: var(--accent);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0;
}

.panel {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 18px;
    box-shadow: var(--shadow);
    backdrop-filter: blur(14px);
}

form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: end;
}

label {
    grid-column: 1 / -1;
    font-weight: 700;
}

input,
button,
select {
    min-height: 44px;
    border-radius: 8px;
    font: inherit;
}

input,
select,
textarea {
    width: 100%;
    border: 1px solid var(--control-border);
    border-radius: 8px;
    background: var(--control);
    color: var(--text);
    padding: 0 12px;
    outline: none;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

textarea {
    min-height: 120px;
    padding: 12px;
}

input:focus,
select:focus,
textarea:focus {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--primary));
    box-shadow: var(--glow);
}

input::placeholder,
textarea::placeholder {
    color: color-mix(in srgb, var(--muted) 70%, transparent);
}

button {
    border: 1px solid color-mix(in srgb, var(--primary) 50%, transparent);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--primary) 94%, #ffffff 6%), color-mix(in srgb, var(--primary) 78%, #000000 22%));
    color: #fff;
    padding: 0 18px;
    cursor: pointer;
    font-weight: 800;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--primary) 24%, transparent), inset 0 1px 0 rgba(255, 255, 255, .16);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

button:hover,
button:focus-visible {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--primary));
    box-shadow: var(--glow);
    transform: translateY(-1px);
    outline: none;
}

.secondary-button {
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--panel) 86%, transparent);
    color: var(--primary);
    font-weight: 700;
}

.run-tool-button {
    justify-self: start;
    min-width: 120px;
    font-weight: 700;
}

.button-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    border: 1px solid color-mix(in srgb, var(--primary) 45%, var(--border));
    border-radius: 8px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 14%, transparent), color-mix(in srgb, var(--panel) 86%, transparent));
    color: color-mix(in srgb, var(--text) 90%, var(--primary));
    padding: 0 14px;
    text-decoration: none;
    font-weight: 800;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.button-link:hover,
.button-link:focus-visible {
    border-color: color-mix(in srgb, var(--accent) 65%, var(--primary));
    box-shadow: var(--glow);
    transform: translateY(-1px);
    outline: none;
}

.score {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 16px 0;
}

.score span {
    display: grid;
    place-items: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent), var(--primary));
    color: #fff;
    font-size: 22px;
    font-weight: 700;
}

.grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.card {
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
    border-radius: 8px;
    padding: 14px;
    background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.card.ok {
    border-left-color: var(--primary);
}

table {
    width: 100%;
    border-collapse: collapse;
    overflow-x: auto;
}

th,
td {
    text-align: left;
    padding: 10px;
    border-bottom: 1px solid var(--border);
    overflow-wrap: anywhere;
}

th {
    color: color-mix(in srgb, var(--text) 90%, var(--accent));
    font-size: 13px;
    text-transform: uppercase;
}

.settings h2 {
    margin-bottom: 12px;
}

.theme-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 10px;
}

.theme-option {
    min-height: 38px;
    background: color-mix(in srgb, var(--panel) 82%, transparent);
    color: var(--text);
    border: 1px solid var(--border);
}

.theme-option.active {
    background: var(--primary);
    color: #fff;
}

.tool-category h2 {
    margin-bottom: 12px;
}

.tool-mode-toggle {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
    grid-column: 1 / -1;
    margin-bottom: 12px;
}

.tool-help-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: space-between;
    grid-column: 1 / -1;
    margin: 0 0 14px;
}

.tooltip-toggle {
    display: inline-flex;
    grid-column: auto;
    align-items: center;
    gap: 8px;
    width: auto;
    min-height: 42px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--panel-strong) 78%, transparent);
    color: var(--text);
    padding: 0 12px;
    font-size: 13px;
    font-weight: 800;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.tooltip-toggle input {
    width: auto;
    min-height: 0;
    accent-color: var(--primary);
}

.tool-mode-option {
    min-height: 38px;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--panel) 82%, transparent);
    color: var(--primary);
    font-weight: 700;
}

.tool-mode-option.active {
    background: var(--primary);
    color: #fff;
}

.tool-dropdown-panel {
    grid-column: 1 / -1;
}

.tool-dropdown-panel select {
    width: min(520px, 100%);
}

.is-hidden {
    display: none !important;
}

.tool-button-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 10px;
}

.tool-runner {
    display: inline-grid;
    gap: 4px;
    align-content: center;
    min-height: 44px;
    background: color-mix(in srgb, var(--panel) 78%, transparent);
    color: var(--text);
    border: 1px solid var(--border);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.tool-runner span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.tool-runner.active {
    background: var(--primary);
    color: #fff;
}

.tool-runner.active span {
    color: #fff;
}

.tool-tooltip {
    position: fixed;
    z-index: 1000;
    display: grid;
    gap: 6px;
    width: min(320px, calc(100vw - 24px));
    border: 1px solid color-mix(in srgb, var(--accent) 48%, var(--border));
    border-radius: 8px;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--primary) 16%, transparent), transparent 48%),
        color-mix(in srgb, var(--panel-strong) 96%, #000);
    color: var(--text);
    padding: 12px 14px;
    box-shadow: var(--shadow), var(--glow);
    opacity: 0;
    transform: translateY(4px);
    pointer-events: none;
    transition: opacity .14s ease, transform .14s ease;
}

.tool-tooltip.visible {
    opacity: 1;
    transform: translateY(0);
}

.tool-tooltip strong {
    font-size: 14px;
}

.tool-tooltip span {
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
}

.guide-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    align-items: center;
    justify-content: space-between;
}

.guide-summary h2,
.guide-summary p {
    flex: 1 1 100%;
}

.tool-guide-section h2 {
    margin-bottom: 14px;
}

.tool-guide-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 14px;
}

.tool-guide-card {
    display: grid;
    gap: 12px;
    align-content: start;
    min-height: 300px;
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
    border-radius: 8px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--primary) 8%, transparent), transparent 44%),
        color-mix(in srgb, var(--panel-strong) 86%, transparent);
    padding: 16px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.tool-guide-card-head {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    justify-content: space-between;
}

.tool-guide-card h3,
.tool-guide-card p,
.tool-guide-card dl {
    margin: 0;
}

.tool-guide-card-head span {
    flex: 0 0 auto;
    border: 1px solid color-mix(in srgb, var(--primary) 48%, var(--border));
    border-radius: 999px;
    background: color-mix(in srgb, var(--primary) 18%, transparent);
    color: var(--text);
    padding: 4px 9px;
    font-size: 12px;
    font-weight: 800;
}

.tool-guide-card dl {
    display: grid;
    gap: 5px;
    padding-top: 10px;
    border-top: 1px solid var(--border);
}

.tool-guide-card dt {
    color: color-mix(in srgb, var(--text) 88%, var(--accent));
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.tool-guide-card dd {
    margin: 0 0 8px;
    color: var(--muted);
}

.tool-guide-card code {
    color: var(--text);
    overflow-wrap: anywhere;
}

.tool-access-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 10px;
}

.tool-access-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 12px;
    background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.tool-access-row legend {
    padding: 0 6px;
    font-weight: 700;
}

.tool-access-row label {
    display: inline-flex;
    grid-column: auto;
    align-items: center;
    gap: 6px;
}

.tool-access-row input {
    min-height: 0;
}

.pricing-panel h2 {
    margin-bottom: 8px;
}

.pricing-panel {
    scroll-margin-top: 18px;
}

.pricing-panel.plans-highlight {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 24%, transparent);
}

.pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 14px;
    margin-top: 16px;
}

.pricing-card {
    position: relative;
    display: grid;
    gap: 10px;
    align-content: start;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 16px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--primary) 7%, transparent), transparent 46%),
        color-mix(in srgb, var(--panel-strong) 86%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
}

.pricing-card.featured {
    border-color: var(--primary);
    box-shadow: var(--glow);
}

.plan-badge {
    justify-self: start;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent), var(--primary));
    color: #fff;
    padding: 4px 9px;
    font-size: 12px;
    font-weight: 700;
}

.plan-price {
    color: var(--text);
    font-size: 30px;
    font-weight: 800;
}

.plan-price span {
    color: var(--muted);
    font-size: 14px;
    font-weight: 700;
}

.pricing-card ul {
    margin: 0;
    padding-left: 18px;
    color: var(--muted);
}

.plan-button {
    width: 100%;
    margin-top: 4px;
}

.payment-plan-list,
.payment-method-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.payment-plan-option,
.payment-method-card,
.invoice-option {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 14px;
    background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.payment-plan-option {
    display: grid;
    gap: 4px;
    color: var(--text);
    text-decoration: none;
}

.payment-plan-option span {
    color: var(--muted);
    font-size: 14px;
    font-weight: 700;
}

.payment-plan-option.active {
    border-color: var(--primary);
    box-shadow: var(--glow);
}

.payment-summary ul {
    margin: 10px 0 0;
    padding-left: 18px;
    color: var(--muted);
}

.payment-method-card {
    display: grid;
    gap: 10px;
}

.payment-method-card h3,
.invoice-option h3 {
    margin: 0;
}

.invoice-option {
    margin-top: 14px;
}

button:disabled {
    cursor: not-allowed;
    opacity: .62;
}

.selected-tool {
    grid-column: 1 / -1;
    color: var(--muted);
    font-weight: 700;
}

.paywall-box {
    margin-top: 16px;
    border: 1px solid var(--border);
    border-left: 4px solid var(--primary);
    border-radius: 8px;
    padding: 16px;
    background: color-mix(in srgb, var(--panel-strong) 88%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.paywall-box h3,
.paywall-box p {
    margin: 0 0 10px;
}

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

.account-form {
    grid-template-columns: 1fr;
    max-width: 520px;
}

.account-form p {
    margin: 4px 0 0;
}

.password-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    grid-column: 1 / -1;
}

.password-row input {
    width: 100%;
}

.account-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.account-bar strong {
    overflow-wrap: anywhere;
}

.account-bar form {
    display: flex;
    gap: 10px;
    margin: 0;
}

.campaign-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 12px;
}

.campaign-card {
    display: grid;
    gap: 8px;
    align-content: start;
    min-height: 130px;
    border: 1px solid var(--border);
    border-left: 4px solid var(--primary);
    border-radius: 8px;
    padding: 14px;
    background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.campaign-card h3,
.campaign-card p {
    margin: 0;
}

.campaign-card p {
    color: var(--muted);
}

.campaign-card span {
    align-self: end;
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
}

.dashboard-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
}

.dashboard-stat-grid article {
    display: grid;
    gap: 6px;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 14px;
    background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
}

.dashboard-stat-grid span {
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}

.dashboard-stat-grid strong {
    color: var(--text);
    overflow-wrap: anywhere;
}

.admin-form {
    display: grid;
    grid-template-columns: 1fr;
}

.admin-form h2 {
    margin: 16px 0 0;
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

.admin-form h2:first-child {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
}

.admin-form label {
    display: grid;
    gap: 6px;
}

.admin-form input[type="checkbox"] {
    min-height: 0;
}

.admin-form input[type="file"] {
    min-height: 42px;
    padding: 8px 12px;
    background: var(--control);
}

.logo-preview {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
}

.logo-preview span {
    color: var(--muted);
    font-weight: 700;
}

.logo-preview img {
    max-width: 180px;
    max-height: 72px;
    object-fit: contain;
}

.gateway {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.gateway legend {
    padding: 0 6px;
    font-weight: 700;
}

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

.notice {
    border-left: 4px solid var(--primary);
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--primary) 12%, transparent), transparent 54%),
        var(--panel);
}

.powered {
    color: var(--muted);
    font-size: 13px;
    margin: 20px 0;
}

.powered a {
    color: var(--primary);
}

.theme-spunweb {
    --primary: #2f6bff;
    --accent: #14d3ae;
    --bg: #08111f;
    --bg-2: #101a2e;
    --panel: rgba(15, 26, 45, .82);
    --panel-strong: rgba(18, 32, 55, .94);
    --text: #f4f9ff;
    --muted: #9fb2ca;
    --border: rgba(132, 173, 221, .24);
    --control: rgba(8, 17, 31, .78);
    --control-border: rgba(154, 197, 255, .28);
}

.theme-neutral {
    --primary: #a6b4c7;
    --accent: #f1f5f9;
    --bg: #0b1018;
    --bg-2: #161d29;
    --panel: rgba(24, 31, 43, .84);
    --panel-strong: rgba(29, 38, 52, .94);
    --text: #f8fafc;
    --muted: #a3aebb;
    --border: rgba(226, 232, 240, .18);
    --control: rgba(9, 14, 22, .78);
    --control-border: rgba(226, 232, 240, .22);
}

.theme-slate {
    --primary: #38bdf8;
    --accent: #94a3b8;
    --bg: #08101b;
    --bg-2: #111827;
    --panel: rgba(15, 23, 42, .84);
    --panel-strong: rgba(21, 32, 52, .94);
    --text: #eef6ff;
    --muted: #a0aec0;
    --border: rgba(148, 163, 184, .25);
    --control: rgba(8, 13, 24, .78);
    --control-border: rgba(148, 163, 184, .3);
}

.theme-emerald {
    --primary: #10b981;
    --accent: #a3e635;
    --bg: #061411;
    --bg-2: #10231c;
    --panel: rgba(10, 36, 30, .84);
    --panel-strong: rgba(13, 48, 39, .94);
    --text: #f0fff8;
    --muted: #9fc9b9;
    --border: rgba(110, 231, 183, .24);
    --control: rgba(4, 18, 15, .78);
    --control-border: rgba(110, 231, 183, .3);
}

.theme-blue {
    --primary: #3b82f6;
    --accent: #22d3ee;
    --bg: #071126;
    --bg-2: #0d1b35;
    --panel: rgba(12, 28, 55, .84);
    --panel-strong: rgba(17, 38, 72, .94);
    --text: #eff6ff;
    --muted: #a4bddc;
    --border: rgba(125, 211, 252, .24);
    --control: rgba(5, 14, 30, .78);
    --control-border: rgba(125, 211, 252, .3);
}

.theme-violet {
    --primary: #8b5cf6;
    --accent: #f472b6;
    --bg: #120a24;
    --bg-2: #201133;
    --panel: rgba(35, 20, 58, .84);
    --panel-strong: rgba(46, 27, 75, .94);
    --text: #fbf7ff;
    --muted: #c4b5dc;
    --border: rgba(196, 181, 253, .24);
    --control: rgba(18, 10, 36, .78);
    --control-border: rgba(196, 181, 253, .3);
}

.theme-red {
    --primary: #ef4444;
    --accent: #f97316;
    --bg: #1b090d;
    --bg-2: #2a1011;
    --panel: rgba(48, 20, 24, .84);
    --panel-strong: rgba(64, 26, 28, .94);
    --text: #fff7f5;
    --muted: #e2b6ad;
    --border: rgba(253, 186, 116, .24);
    --control: rgba(25, 8, 11, .78);
    --control-border: rgba(253, 186, 116, .3);
}

.theme-gold {
    --primary: #f59e0b;
    --accent: #14b8a6;
    --bg: #171006;
    --bg-2: #241a0a;
    --panel: rgba(43, 31, 13, .84);
    --panel-strong: rgba(57, 41, 17, .94);
    --text: #fff9e8;
    --muted: #d9c899;
    --border: rgba(251, 191, 36, .25);
    --control: rgba(20, 14, 5, .78);
    --control-border: rgba(251, 191, 36, .3);
}

.theme-teal {
    --primary: #14b8a6;
    --accent: #60a5fa;
    --bg: #061918;
    --bg-2: #0d2828;
    --panel: rgba(11, 43, 42, .84);
    --panel-strong: rgba(15, 56, 55, .94);
    --text: #effefe;
    --muted: #9fc9c8;
    --border: rgba(94, 234, 212, .24);
    --control: rgba(4, 20, 20, .78);
    --control-border: rgba(94, 234, 212, .3);
}

.theme-dark {
    --primary: #38bdf8;
    --accent: #22c55e;
    --bg: #0b1220;
    --bg-2: #111827;
    --panel: rgba(17, 24, 39, .86);
    --panel-strong: rgba(22, 32, 50, .94);
    --text: #e5edf7;
    --muted: #9ca3af;
    --border: rgba(120, 141, 168, .24);
    --control: rgba(8, 13, 24, .78);
    --control-border: rgba(120, 141, 168, .3);
}

@media (max-width: 680px) {
    main {
        width: min(100% - 20px, 1180px);
        margin-top: 10px;
    }

    nav {
        gap: 7px;
        padding: 8px;
    }

    nav a {
        flex: 1 1 150px;
        min-height: 42px;
        padding: 0 10px;
        font-size: 13px;
    }

    header {
        padding: 20px;
    }

    form {
        grid-template-columns: 1fr;
    }

    .password-row {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 960px) {
    main {
        width: min(100% - 24px, 1180px);
    }

    .pricing-grid,
    .payment-plan-list,
    .payment-method-grid,
    .campaign-grid,
    .dashboard-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tool-button-grid,
    .tool-access-grid,
    .theme-grid {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    }

    table {
        display: block;
        white-space: nowrap;
    }
}

@media (max-width: 560px) {
    body {
        background-size: auto;
    }

    main {
        width: calc(100% - 16px);
        margin: 8px auto 28px;
    }

    nav {
        border-radius: 8px;
    }

    nav a,
    .button-link,
    button {
        width: 100%;
        min-width: 0;
    }

    header,
    .panel {
        padding: 16px;
    }

    h1 {
        font-size: 32px;
        line-height: 1.06;
    }

    header p:not(.eyebrow) {
        font-size: 16px;
    }

    .brand-logo {
        max-width: 190px;
        max-height: 68px;
    }

    .pricing-grid,
    .payment-plan-list,
    .payment-method-grid,
    .campaign-grid,
    .dashboard-stat-grid,
    .tool-button-grid,
    .tool-access-grid,
    .theme-grid,
    .grid {
        grid-template-columns: 1fr;
    }

    .tool-mode-toggle {
        display: grid;
        grid-template-columns: 1fr 1fr;
        width: 100%;
    }

    .tool-mode-option {
        width: auto;
    }

    .account-bar,
    .account-bar form,
    .paywall-actions,
    .logo-preview {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }

    .plan-price {
        font-size: 26px;
    }

    .score {
        align-items: flex-start;
    }

    .swt-shot-watermark {
        right: 12px !important;
        bottom: 12px !important;
        transform: scale(.82);
        transform-origin: right bottom;
    }
}
