:root {
    --bg: #04101f;
    --bg-soft: #07172c;
    --bg-strong: #0b1e38;
    --panel: rgba(11, 23, 44, 0.92);
    --panel-strong: rgba(14, 28, 52, 0.98);
    --panel-soft: rgba(255, 255, 255, 0.04);
    --line: rgba(164, 189, 233, 0.16);
    --line-strong: rgba(164, 189, 233, 0.28);
    --text: #f5f8ff;
    --text-soft: #c3d1ea;
    --muted: #8ea7cd;
    --brand: #27c7ff;
    --brand-strong: #147fe0;
    --accent: #8a5cf6;
    --success: #34d7a1;
    --warning: #f7b25b;
    --danger: #ff7a90;
    --shadow: 0 30px 90px rgba(2, 9, 21, 0.46);
    --radius-xl: 32px;
    --radius-lg: 24px;
    --radius-md: 18px;
    --radius-sm: 14px;
    --container-pad: clamp(18px, 2vw, 28px);
}

* {
    box-sizing: border-box;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at top left, rgba(39, 199, 255, 0.14), transparent 28%),
        radial-gradient(circle at 85% 10%, rgba(138, 92, 246, 0.12), transparent 22%),
        radial-gradient(circle at 80% 85%, rgba(20, 127, 224, 0.10), transparent 20%),
        linear-gradient(180deg, #04101f 0%, #061220 42%, #08101b 100%);
}

body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0)),
        linear-gradient(90deg, rgba(255, 255, 255, 0.012), rgba(255, 255, 255, 0));
    mask-image: radial-gradient(circle at center, black, transparent 72%);
}

[hidden] {
    display: none !important;
}

a {
    color: var(--brand);
    text-decoration: none;
}

a:hover {
    color: #7fe0ff;
}

img {
    max-width: 100%;
    display: block;
}

button,
input,
select,
textarea {
    font: inherit;
}

button {
    cursor: pointer;
}

textarea {
    resize: vertical;
}

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

p:last-child,
ul:last-child,
pre:last-child {
    margin-bottom: 0;
}

strong {
    color: var(--text);
}

ul {
    padding-left: 18px;
}

::selection {
    background: rgba(39, 199, 255, 0.24);
    color: #fff;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.eyebrow {
    display: inline-block;
    margin: 0 0 10px;
    color: var(--brand);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-size: 0.75rem;
    font-weight: 800;
}

.panel-surface,
.panel-soft {
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    backdrop-filter: blur(16px);
}

.panel-surface {
    background: linear-gradient(180deg, rgba(12, 24, 45, 0.96), rgba(7, 16, 30, 0.95));
    box-shadow: var(--shadow);
}

.panel-soft {
    background: rgba(255, 255, 255, 0.04);
}

.flash {
    padding: 16px 18px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--line-strong);
    line-height: 1.6;
}

.flash-success {
    background: rgba(52, 215, 161, 0.12);
    border-color: rgba(52, 215, 161, 0.28);
}

.flash-error {
    background: rgba(255, 122, 144, 0.13);
    border-color: rgba(255, 122, 144, 0.28);
}

.flash-warning {
    background: rgba(247, 178, 91, 0.14);
    border-color: rgba(247, 178, 91, 0.28);
}

.auth-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(0, 1.16fr) minmax(420px, 0.88fr);
}

.auth-visual {
    position: relative;
    padding: clamp(30px, 4vw, 58px);
    display: grid;
    align-content: space-between;
    gap: 40px;
    border-right: 1px solid rgba(255, 255, 255, 0.05);
}

.auth-brand {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.auth-logo {
    width: min(470px, 100%);
}

.auth-chip,
.pill-quiet,
.score-chip,
.hero-tags > span,
.hero-tags > a,
.tag-list span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.045);
    color: var(--text-soft);
    font-size: 0.88rem;
    line-height: 1.2;
}

.auth-copy {
    display: grid;
    gap: 24px;
    align-content: center;
    max-width: 720px;
}

.auth-copy h1 {
    margin: 0;
    font-size: clamp(2.4rem, 4vw, 4.4rem);
    line-height: 1.02;
    letter-spacing: -0.045em;
}

.auth-copy p {
    color: var(--text-soft);
    font-size: 1.05rem;
    line-height: 1.75;
}

.auth-feature-grid,
.hero-side,
.power-grid,
.history-grid,
.people-grid,
.process-list,
.loading-steps {
    display: grid;
    gap: 16px;
}

.auth-feature-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.auth-feature-grid article,
.hero-side article,
.power-card,
.person-card,
.process-list article,
.loading-step,
.history-card,
.attempt-card,
.detail-grid article,
.email-section.compact-grid article {
    padding: 20px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.04);
}

.auth-feature-grid strong,
.hero-side strong,
.power-card strong,
.section-heading h2,
.form-copy h2,
.history-card h3,
.hero-card h1,
.content-card h2 {
    display: block;
    margin: 0;
    font-size: 1.16rem;
    line-height: 1.3;
}

.auth-feature-grid span,
.hero-side span,
.form-copy p,
.summary-copy,
.profile-summary,
.helper-copy span,
.loading-intro,
.loading-footer span,
.loading-step p,
.history-card p,
.history-card-foot span,
.sidebar-brand p,
.sidebar-empty,
.empty-copy,
.email-section p,
.attempt-card > p,
.company-cell span,
.person-card span,
.person-card p,
.contact-strip span,
.admin-panel p,
.admin-panel li {
    color: var(--text-soft);
    line-height: 1.65;
}

.auth-panel {
    padding: clamp(22px, 3vw, 32px);
    display: grid;
    align-items: center;
}

.auth-panel-inner {
    width: min(100%, 500px);
    margin: 0 auto;
}

.auth-switcher,
.segmented-control {
    display: grid;
    gap: 12px;
}

.auth-switcher {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 28px;
}

.auth-switcher a,
.segmented-option {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 12px 16px;
    border-radius: 15px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.035);
    color: var(--text-soft);
    font-weight: 700;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.auth-switcher a.active,
.segmented-option.active {
    color: var(--text);
    border-color: rgba(39, 199, 255, 0.36);
    background: linear-gradient(135deg, rgba(39, 199, 255, 0.16), rgba(20, 127, 224, 0.18));
}

.segmented-control {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.segmented-option input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.form-copy {
    margin-bottom: 24px;
}

.stack-lg,
.stack-md {
    display: grid;
}

.stack-lg {
    gap: 24px;
}

.stack-md {
    gap: 16px;
}

label,
.checkbox-row {
    display: grid;
    gap: 10px;
}

label span,
.helper-copy strong,
.email-section-head strong,
.detail-grid span,
.history-card-foot a,
.history-card-head span,
.loading-step strong,
.sidebar-history-head a,
.list-label,
.attempt-head span,
.attempt-block strong,
.person-card strong,
.company-cell strong,
.power-card span,
.sidebar-user span,
.sidebar-user strong {
    font-size: 0.93rem;
}

label span,
.detail-grid span,
.power-card span,
.sidebar-user span,
.company-cell span,
.person-card span,
.list-label {
    color: var(--text-soft);
    font-weight: 650;
}

input,
select,
textarea {
    width: 100%;
    min-height: 56px;
    padding: 16px 18px;
    border-radius: 16px;
    border: 1px solid rgba(166, 189, 230, 0.20);
    background: rgba(255, 255, 255, 0.05);
    color: var(--text);
    outline: none;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

select {
    appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, var(--text-soft) 50%),
        linear-gradient(135deg, var(--text-soft) 50%, transparent 50%);
    background-position:
        calc(100% - 20px) calc(50% - 2px),
        calc(100% - 14px) calc(50% - 2px);
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
    padding-right: 40px;
}

textarea {
    min-height: 140px;
}

input::placeholder,
textarea::placeholder {
    color: rgba(195, 209, 234, 0.58);
}

input:focus,
select:focus,
textarea:focus {
    border-color: rgba(39, 199, 255, 0.48);
    box-shadow: 0 0 0 4px rgba(39, 199, 255, 0.12);
    background: rgba(255, 255, 255, 0.065);
}

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

.checkbox-row {
    grid-auto-flow: column;
    justify-content: start;
    align-items: start;
    gap: 12px;
    color: var(--text-soft);
}

.checkbox-row input {
    width: 18px;
    min-height: 18px;
    height: 18px;
    margin-top: 3px;
    padding: 0;
}

.primary-cta,
.ghost-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border-radius: 16px;
    padding: 14px 20px;
    border: 1px solid transparent;
    font-weight: 800;
    line-height: 1.2;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.primary-cta {
    background: linear-gradient(135deg, var(--brand), var(--brand-strong));
    color: #061220;
    box-shadow: 0 18px 34px rgba(20, 127, 224, 0.28);
}

.primary-cta:hover,
.ghost-button:hover {
    transform: translateY(-1px);
}

.primary-cta.full-width,
.ghost-button.full-width {
    width: 100%;
}

.ghost-button {
    background: rgba(255, 255, 255, 0.04);
    color: var(--text);
    border-color: var(--line);
}

.ghost-button.small {
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 0.86rem;
}

.ghost-button.done {
    border-color: rgba(52, 215, 161, 0.3);
    background: rgba(52, 215, 161, 0.14);
    color: #d8fff0;
}

.primary-cta.disabled,
.ghost-button.disabled,
a.disabled {
    opacity: 0.5;
    pointer-events: none;
}

.app-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    gap: 22px;
    padding: var(--container-pad);
}

.sidebar {
    position: sticky;
    top: var(--container-pad);
    height: calc(100vh - (var(--container-pad) * 2));
    overflow: auto;
    padding: 22px;
    display: grid;
    align-content: start;
    gap: 20px;
}

.sidebar-brand {
    display: grid;
    gap: 14px;
}

.sidebar-brand img {
    width: 100%;
}

.sidebar-brand p {
    margin: 0;
    font-size: 0.96rem;
}

.sidebar-nav,
.sidebar-history-list {
    display: grid;
    gap: 8px;
}

.sidebar-nav a,
.sidebar-history-item {
    padding: 14px 15px;
    border-radius: 14px;
    color: var(--text-soft);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid transparent;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.sidebar-nav a:hover,
.sidebar-nav a.active,
.sidebar-history-item:hover {
    color: var(--text);
    border-color: rgba(39, 199, 255, 0.24);
    background: rgba(39, 199, 255, 0.08);
    transform: translateY(-1px);
}

.sidebar-user {
    padding: 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    border-radius: var(--radius-md);
}

.sidebar-user div {
    display: grid;
    gap: 4px;
}

.sidebar-history {
    display: grid;
    gap: 14px;
}

.sidebar-history-head,
.section-actions,
.sticky-actions,
.email-controls,
.modal-foot,
.inline-foot,
.contact-strip,
.hero-tags,
.hero-side,
.history-card-foot,
.attempt-head,
.email-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.sidebar-empty,
.empty-copy {
    margin: 0;
}

.sidebar-history-item {
    display: grid;
    gap: 6px;
}

.sidebar-history-item strong {
    font-size: 0.94rem;
    line-height: 1.4;
}

.sidebar-history-item span {
    color: var(--muted);
    font-size: 0.82rem;
}

.app-main {
    display: grid;
    align-content: start;
    gap: 18px;
}

.hero-card,
.content-card,
.loading-footer {
    padding: 24px;
    border-radius: var(--radius-xl);
}

.hero-card {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
    gap: 24px;
    align-items: start;
}

.hero-card h1 {
    font-size: clamp(1.7rem, 2.2vw, 2.6rem);
    line-height: 1.08;
    letter-spacing: -0.03em;
}

.hero-card p,
.section-heading p,
.summary-box p,
.profile-summary-box p,
.admin-notes,
.copy-card-pre {
    color: var(--text-soft);
    line-height: 1.7;
}

.hero-side {
    align-content: start;
}

.hero-side article strong,
.power-card strong {
    font-size: 1.32rem;
}

.power-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

.power-bar {
    width: 100%;
    height: 10px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
}

.power-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand), var(--accent));
}

.layout-two {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: 18px;
}

.content-card {
    display: grid;
    gap: 22px;
}

.section-heading {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 16px;
}

.section-heading h2 {
    font-size: 1.42rem;
}

.section-heading p {
    margin: 6px 0 0;
}

.profile-summary-box,
.summary-box,
.loading-box,
.copy-card,
.html-preview,
.admin-panel,
.history-card,
.attempt-card {
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.04);
}

.profile-summary-box,
.summary-box,
.loading-box {
    padding: 18px;
}

.company-mark {
    width: auto;
    max-height: 64px;
    max-width: 220px;
    object-fit: contain;
}

.helper-copy {
    display: grid;
    gap: 12px;
}

.list-label {
    display: inline-block;
    margin-bottom: 10px;
}

.tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.contact-strip {
    justify-content: start;
}

.contact-strip a,
.contact-strip span {
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.04);
}

.process-list {
    grid-template-columns: 1fr;
}

.process-list article strong {
    display: block;
    margin-bottom: 10px;
}

.loading-screen {
    align-items: center;
}

.loading-status {
    padding: 18px 20px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(39, 199, 255, 0.24);
    background: rgba(39, 199, 255, 0.07);
    color: var(--text);
    line-height: 1.65;
}

.loading-status.error {
    border-color: rgba(255, 122, 144, 0.3);
    background: rgba(255, 122, 144, 0.12);
    color: #ffe1e7;
}

.loading-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.loading-step {
    min-height: 170px;
    transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease, opacity 0.18s ease;
}

.loading-step.current {
    border-color: rgba(39, 199, 255, 0.38);
    background: rgba(39, 199, 255, 0.11);
    transform: translateY(-2px);
}

.loading-step.done {
    border-color: rgba(52, 215, 161, 0.34);
    background: rgba(52, 215, 161, 0.10);
}

.loading-step.waiting {
    opacity: 0.72;
}

.loading-footer {
    display: flex;
    align-items: center;
}

.table-wrap {
    overflow: auto;
    border-radius: 18px;
    border: 1px solid var(--line);
}

.results-table {
    width: 100%;
    min-width: 920px;
    border-collapse: collapse;
    background: rgba(4, 10, 20, 0.36);
}

.results-table th,
.results-table td {
    padding: 16px 18px;
    text-align: left;
    vertical-align: top;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.results-table th {
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-soft);
    text-transform: uppercase;
    font-size: 0.82rem;
    letter-spacing: 0.07em;
}

.results-table td {
    color: var(--text);
    line-height: 1.6;
}

.results-table.compact {
    min-width: 760px;
}

.company-cell {
    display: grid;
    gap: 4px;
}

.score-chip {
    min-width: 68px;
    font-weight: 800;
}

.score-high {
    background: rgba(52, 215, 161, 0.16);
    border-color: rgba(52, 215, 161, 0.32);
    color: #d6fff0;
}

.score-mid {
    background: rgba(247, 178, 91, 0.16);
    border-color: rgba(247, 178, 91, 0.32);
    color: #ffe8c9;
}

.score-low {
    background: rgba(255, 122, 144, 0.16);
    border-color: rgba(255, 122, 144, 0.30);
    color: #ffe0e6;
}

.admin-panel {
    padding: 16px 18px;
}

.admin-panel summary {
    cursor: pointer;
    font-weight: 800;
    color: var(--text);
    list-style: none;
}

.admin-panel summary::-webkit-details-marker {
    display: none;
}

.admin-panel summary::after {
    content: '+';
    float: right;
    color: var(--brand);
}

.admin-panel[open] summary::after {
    content: '–';
}

.admin-notes {
    margin: 16px 0 0;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: inherit;
}

.attempt-head {
    margin-bottom: 12px;
}

.attempt-block {
    display: grid;
    gap: 8px;
}

.attempt-block ul {
    margin: 0;
}

.history-grid {
    grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
}

.history-card {
    display: grid;
    gap: 16px;
    padding: 20px;
}

.history-card-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 14px;
}

.history-card-head h3 {
    font-size: 1.1rem;
    line-height: 1.35;
}

.back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    color: var(--text-soft);
    font-weight: 700;
}

.company-layout {
    grid-template-columns: minmax(0, 1.18fr) minmax(360px, 0.82fr);
}

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

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

.person-card strong {
    font-size: 1rem;
}

.email-panel {
    align-content: start;
}

.email-panel.is-generating {
    border-color: rgba(39, 199, 255, 0.26);
    box-shadow: 0 20px 70px rgba(39, 199, 255, 0.08), var(--shadow);
}

.email-background-box {
    display: grid;
    gap: 12px;
    position: relative;
    overflow: hidden;
    border-color: rgba(39, 199, 255, 0.24);
    background: linear-gradient(135deg, rgba(39, 199, 255, 0.10), rgba(52, 215, 161, 0.06));
}

.email-background-box[hidden] {
    display: none !important;
}

.email-background-box::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.10) 48%, transparent 70%);
    transform: translateX(-100%);
    animation: loadingSweep 3s ease-in-out infinite;
}

.email-background-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    position: relative;
    z-index: 1;
}

.email-background-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(52, 215, 161, 0.14);
    border: 1px solid rgba(52, 215, 161, 0.28);
    color: rgba(255, 255, 255, 0.92);
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.email-tech-pulse {
    width: max-content;
    position: relative;
    z-index: 1;
}

.email-background-box span[data-email-status],
.email-background-box small {
    position: relative;
    z-index: 1;
}

.email-background-box small {
    color: rgba(255, 255, 255, 0.68);
    line-height: 1.45;
}

.email-section {
    display: grid;
    gap: 14px;
}

.email-section.compact-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.loading-box strong,
.email-section-head strong,
.summary-box strong,
.profile-summary-box strong {
    display: block;
    font-size: 1rem;
}

.copy-card,
.html-preview {
    padding: 16px 18px;
}

.copy-card {
    color: var(--text);
    background: rgba(255, 255, 255, 0.03);
}

.copy-card-pre {
    margin: 0;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: inherit;
}

.subject-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 10px;
}

.subject-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.03);
}

.subject-item span {
    color: var(--text);
    line-height: 1.5;
}

.html-preview {
    overflow: auto;
    color: #0d1b2f;
    background: linear-gradient(180deg, #ffffff, #f3f7ff);
}

.html-preview * {
    max-width: 100%;
}

.html-preview img {
    height: auto;
}

.inline-foot {
    justify-content: flex-start;
}

.research-layout .panel-surface,
.research-layout .content-card {
    height: 100%;
}

.small {
    font-size: 0.86rem;
}

@media (max-width: 1280px) {
    .power-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .hero-card,
    .layout-two,
    .company-layout {
        grid-template-columns: 1fr;
    }

    .app-shell {
        grid-template-columns: 280px minmax(0, 1fr);
    }
}

@media (max-width: 980px) {
    .auth-shell,
    .app-shell {
        grid-template-columns: 1fr;
    }

    .auth-visual {
        min-height: auto;
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    }

    .auth-feature-grid,
    .loading-steps {
        grid-template-columns: 1fr;
    }

    .sidebar {
        position: static;
        height: auto;
        overflow: visible;
    }

    .app-main {
        padding-bottom: 28px;
    }
}

@media (max-width: 720px) {
    :root {
        --radius-xl: 24px;
        --radius-lg: 20px;
        --radius-md: 16px;
    }

    .auth-visual,
    .auth-panel,
    .hero-card,
    .content-card,
    .loading-footer,
    .sidebar {
        padding: 20px;
    }

    .auth-feature-grid {
        grid-template-columns: 1fr;
    }

    .power-grid,
    .detail-grid,
    .compact-grid,
    .people-grid,
    .history-grid {
        grid-template-columns: 1fr;
    }

    .section-heading,
    .sticky-actions,
    .sidebar-user,
    .history-card-head,
    .subject-item,
    .email-section-head,
    .contact-strip {
        flex-direction: column;
        align-items: flex-start;
    }

    .auth-copy h1,
    .hero-card h1 {
        word-break: break-word;
    }
}

.loading-screen-manual {
    gap: 18px;
}

.inline-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.top-gap-sm {
    margin-top: 14px;
}

.inline-form {
    display: inline-flex;
    margin: 0;
}

.danger-inline {
    align-items: center;
}

.ghost-button.danger,
button.ghost-button.danger {
    color: #ffb4b4;
    border-color: rgba(255, 104, 104, 0.26);
    background: rgba(255, 104, 104, 0.07);
}

.ghost-button.danger:hover,
button.ghost-button.danger:hover {
    color: #fff1f1;
    border-color: rgba(255, 104, 104, 0.42);
    background: rgba(255, 104, 104, 0.12);
}

.financial-power-grid {
    margin-top: 2px;
}

.pagination-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    padding-top: 8px;
}

.mini-chart-grid {
    display: grid;
    gap: 12px;
}

.mini-chart-row {
    display: grid;
    grid-template-columns: 62px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
}

.mini-chart-row span,
.mini-chart-row strong {
    font-size: 0.92rem;
}

.mini-chart-track {
    position: relative;
    width: 100%;
    height: 12px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
}

.mini-chart-track i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand), var(--accent));
}

.admin-split {
    align-items: start;
}

.attempt-block ul {
    margin: 10px 0 0;
    padding-left: 18px;
    color: var(--text-soft);
}

.attempt-block li + li {
    margin-top: 8px;
}

.history-card .section-actions {
    justify-content: flex-end;
}

@media (max-width: 900px) {
    .mini-chart-row {
        grid-template-columns: 54px minmax(0, 1fr);
    }

    .mini-chart-row strong {
        grid-column: 1 / -1;
        padding-left: 66px;
    }

    .pagination-strip {
        align-items: stretch;
    }
}

.form-block {
    display: grid;
    gap: 12px;
}

.field-label {
    display: block;
    color: var(--text-soft);
    font-weight: 800;
}

.compact-segmented {
    width: fit-content;
    max-width: 100%;
}

.location-specific-field {
    margin-top: 2px;
}

.helper-copy.compact,
.empty-copy.compact,
.mini-meta {
    font-size: 0.9rem;
    line-height: 1.55;
}

.mini-meta {
    color: var(--muted);
    margin-bottom: 12px;
}

.financial-dashboard {
    display: grid;
    gap: 22px;
}

.financial-insight-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.financial-chart-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.financial-chart-panel {
    padding: 18px;
    display: grid;
    gap: 14px;
}

.financial-chart-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.financial-chart-title span {
    color: var(--muted);
    font-size: 0.9rem;
}

.no-empty-card p {
    min-height: 42px;
}

@media (max-width: 1100px) {
    .financial-insight-grid,
    .financial-chart-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .financial-insight-grid,
    .financial-chart-grid {
        grid-template-columns: 1fr;
    }

    .compact-segmented {
        width: 100%;
    }
}


.loading-screen-auto {
    position: relative;
    overflow: hidden;
}

.loading-screen-auto::before {
    content: '';
    position: absolute;
    inset: -1px;
    pointer-events: none;
    background: linear-gradient(120deg, transparent 0%, rgba(39, 199, 255, 0.08) 38%, rgba(52, 215, 161, 0.10) 50%, transparent 64%);
    transform: translateX(-100%);
    animation: loadingSweep 3.6s ease-in-out infinite;
}

.loading-telemetry {
    display: grid;
    gap: 14px;
}

.tech-pulse {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.035);
}

.tech-pulse span {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: currentColor;
    color: rgba(39, 199, 255, 0.9);
    box-shadow: 0 0 18px rgba(39, 199, 255, 0.35);
    animation: techPulse 1.2s ease-in-out infinite;
}

.tech-pulse span:nth-child(2) {
    color: rgba(52, 215, 161, 0.9);
    animation-delay: 0.18s;
}

.tech-pulse span:nth-child(3) {
    color: rgba(255, 255, 255, 0.8);
    animation-delay: 0.36s;
}

.loading-step.current {
    position: relative;
    overflow: hidden;
}

.loading-step.current::after {
    content: '';
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 14px;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(39, 199, 255, 0.2), rgba(52, 215, 161, 0.95), rgba(39, 199, 255, 0.2));
    background-size: 200% 100%;
    animation: loadingBar 1.35s linear infinite;
}

.auto-run-note {
    display: grid;
    gap: 6px;
}

.auto-run-note strong {
    color: var(--text);
}

@keyframes loadingSweep {
    0% { transform: translateX(-100%); }
    42% { transform: translateX(100%); }
    100% { transform: translateX(100%); }
}

@keyframes techPulse {
    0%, 100% { transform: scale(0.75); opacity: 0.45; }
    50% { transform: scale(1.12); opacity: 1; }
}

@keyframes loadingBar {
    0% { background-position: 0% 50%; }
    100% { background-position: 200% 50%; }
}

.auth-link {
    display: inline-flex;
    justify-content: center;
    color: #4f46e5;
    font-weight: 800;
    text-decoration: none;
    margin-top: -0.35rem;
}

.auth-link:hover {
    text-decoration: underline;
}

select option {
    color: #0f172a;
    background: #ffffff;
}

.outcome-chip {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 0.78rem;
    font-weight: 800;
    border: 1px solid var(--line);
    color: var(--text);
    background: rgba(255, 255, 255, 0.05);
    white-space: nowrap;
}

.outcome-chip.positive {
    color: #d8fff0;
    background: rgba(52, 215, 161, 0.14);
    border-color: rgba(52, 215, 161, 0.32);
}

.outcome-chip.warning {
    color: #fff3cf;
    background: rgba(245, 158, 11, 0.14);
    border-color: rgba(245, 158, 11, 0.34);
}

.outcome-chip.negative {
    color: #ffe2e2;
    background: rgba(248, 113, 113, 0.14);
    border-color: rgba(248, 113, 113, 0.34);
}

.outcome-chip.neutral {
    color: var(--text-soft);
    background: rgba(255, 255, 255, 0.04);
}


.outcome-history-card {
    border-color: rgba(52, 215, 161, 0.22);
}

.outcome-filter-form {
    align-items: end;
    gap: 10px;
}

.outcome-filter-form label {
    min-width: min(260px, 100%);
}

.outcome-filter-form label span {
    display: block;
    margin-bottom: 6px;
    color: var(--text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.outcome-results-table td:nth-child(6) {
    max-width: 280px;
    white-space: normal;
}

.lead-contact-card {
    border-color: rgba(39, 199, 255, 0.24);
}

.lead-contact-card p {
    line-height: 1.75;
}

.lead-contact-card a {
    color: inherit;
    font-weight: 800;
}

.lead-action-panel.is-priority {
    border-color: rgba(248, 113, 113, 0.56);
    box-shadow: var(--shadow), 0 0 0 1px rgba(248, 113, 113, 0.08), 0 0 34px rgba(248, 113, 113, 0.16);
}

.outcome-panel {
    border-color: rgba(52, 215, 161, 0.5);
    box-shadow: var(--shadow), 0 0 0 1px rgba(52, 215, 161, 0.08), 0 0 34px rgba(52, 215, 161, 0.14);
}

.stack-sm {
    display: grid;
    gap: 14px;
}

/* Free mode notes */
.free-inline-note {
    padding: 0.85rem 1rem;
    border-radius: 14px;
    background: rgba(16, 185, 129, 0.10);
    border: 1px solid rgba(16, 185, 129, 0.20);
    font-weight: 700;
}

/* Admin portal separato */
.admin-portal-body {
    background:
        radial-gradient(circle at 12% 8%, rgba(39, 199, 255, 0.20), transparent 28%),
        radial-gradient(circle at 92% 5%, rgba(138, 92, 246, 0.22), transparent 24%),
        linear-gradient(135deg, #030a16 0%, #071326 42%, #0d1324 100%);
}

.admin-auth-wrapper {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 2rem;
}

.admin-login-card {
    width: min(560px, 100%);
    padding: clamp(1.4rem, 4vw, 2.4rem);
    display: grid;
    gap: 1.4rem;
    border-color: rgba(39, 199, 255, 0.28);
    box-shadow: 0 40px 120px rgba(0, 0, 0, 0.55);
}

.admin-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 1.2rem;
    padding: var(--container-pad);
}

.admin-sidebar {
    position: sticky;
    top: var(--container-pad);
    height: calc(100vh - (var(--container-pad) * 2));
    display: flex;
    flex-direction: column;
    padding: 1.1rem;
}

.admin-main {
    display: grid;
    gap: 1rem;
    min-width: 0;
}

.admin-hero {
    padding: clamp(1.4rem, 3vw, 2.3rem);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-color: rgba(39, 199, 255, 0.26);
}

.admin-hero h1 {
    font-size: clamp(2rem, 4vw, 3.4rem);
    letter-spacing: -0.055em;
    margin-bottom: 0.45rem;
}

.admin-bi-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(150px, 1fr));
    gap: 1rem;
}

.admin-metric-card {
    padding: 1.05rem;
    display: grid;
    gap: 0.55rem;
    min-height: 170px;
}

.admin-metric-card span {
    color: var(--text-soft);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
}

.admin-metric-card strong {
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: 0.95;
    letter-spacing: -0.06em;
}

.admin-metric-card p {
    color: var(--muted);
    font-size: 0.86rem;
}

.admin-bar {
    height: 9px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.07);
    margin-top: auto;
}

.admin-bar i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand), var(--accent));
}

.admin-dashboard-split {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: 1rem;
}

.admin-donut-wrap {
    display: grid;
    grid-template-columns: 160px minmax(0, 1fr);
    gap: 1.2rem;
    align-items: center;
}

.admin-donut {
    width: 150px;
    aspect-ratio: 1;
    border-radius: 999px;
    background: conic-gradient(var(--success) 0 calc(var(--p1) * 1%), var(--warning) calc(var(--p1) * 1%) calc(var(--p2) * 1%), var(--danger) calc(var(--p2) * 1%) 100%);
    position: relative;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.10), 0 22px 50px rgba(0, 0, 0, 0.24);
}

.admin-donut::after {
    content: '';
    position: absolute;
    inset: 32px;
    border-radius: inherit;
    background: var(--bg-strong);
}

.admin-users-table .results-table td {
    vertical-align: top;
}

.admin-logout-form {
    margin-top: auto;
}

.inline-filter-form {
    display: flex;
    align-items: flex-end;
    gap: 0.75rem;
}

.inline-filter-form label {
    margin: 0;
    min-width: 220px;
}

@media (max-width: 1180px) {
    .admin-shell {
        grid-template-columns: 1fr;
    }
    .admin-sidebar {
        position: static;
        height: auto;
    }
    .admin-bi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .admin-dashboard-split {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .admin-bi-grid {
        grid-template-columns: 1fr;
    }
    .admin-hero {
        align-items: flex-start;
        flex-direction: column;
    }
    .admin-donut-wrap {
        grid-template-columns: 1fr;
    }
}

.comparison-chart-panel {
    border-color: rgba(14, 165, 233, 0.18);
    background: linear-gradient(180deg, rgba(14, 165, 233, 0.08), rgba(255, 255, 255, 0.035));
}

.comparison-chart-grid .mini-chart-row strong {
    white-space: nowrap;
}

/* payScore */
.payscore-entry-hero .hero-side article strong { font-size: 1.8rem; }
.payscore-report { display: grid; gap: 22px; margin-top: 18px; }
.payscore-hero { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 24px; align-items: stretch; padding: 28px; }
.payscore-meta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
.payscore-meta span { border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.06); border-radius: 999px; padding: 8px 11px; font-size: .88rem; }
.payscore-verdict { border-radius: 26px; padding: 24px; display: flex; flex-direction: column; justify-content: center; min-height: 180px; box-shadow: inset 0 0 0 1px rgba(255,255,255,.18); }
.payscore-verdict span { font-size: .76rem; text-transform: uppercase; letter-spacing: .12em; opacity: .82; }
.payscore-verdict strong { font-size: 2rem; line-height: 1.05; margin-top: 10px; }
.payscore-verdict.approved, .payscore-history-item.approved { background: linear-gradient(135deg, rgba(32, 201, 151, .30), rgba(32, 201, 151, .08)); border-color: rgba(32, 201, 151, .42); }
.payscore-verdict.conditional, .payscore-history-item.conditional { background: linear-gradient(135deg, rgba(32, 201, 151, .24), rgba(32, 201, 151, .07)); border-color: rgba(32, 201, 151, .40); }
.payscore-verdict.rejected, .payscore-history-item.rejected { background: linear-gradient(135deg, rgba(255, 77, 79, .32), rgba(255, 77, 79, .08)); border-color: rgba(255, 77, 79, .48); }
.payscore-kpi-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 16px; }
.payscore-kpi { padding: 22px; border-radius: 24px; }
.payscore-kpi span { display: block; font-size: .76rem; text-transform: uppercase; letter-spacing: .10em; opacity: .7; }
.payscore-kpi strong { display: block; font-size: 2rem; margin-top: 8px; }
.payscore-kpi.main strong { font-size: 3.4rem; }
.payscore-bar { height: 12px; border-radius: 999px; overflow: hidden; background: rgba(255,255,255,.11); margin: 14px 0 8px; }
.payscore-bar i { display: block; height: 100%; border-radius: inherit; background: currentColor; min-width: 4%; }
.payscore-approved .payscore-bar i { color: #20c997; }
.payscore-conditional .payscore-bar i { color: #20c997; }
.payscore-rejected .payscore-bar i { color: #ff4d4f; }
.payscore-section-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.payscore-section-grid.compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.payscore-section-grid h3 { margin-top: 0; }
.payscore-stress-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.payscore-stress-grid article { border: 1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.045); border-radius: 20px; padding: 18px; }
.payscore-decision h2 { margin-top: 6px; }
.payscore-history-list { display: grid; gap: 10px; }
.payscore-history-list.grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.payscore-history-item { display: grid; gap: 4px; padding: 14px 16px; border-radius: 18px; border: 1px solid rgba(255,255,255,.12); text-decoration: none; color: inherit; }
.payscore-history-item strong { font-size: .96rem; }
.payscore-history-item span { opacity: .78; font-size: .88rem; }
.payscore-history-item em { font-style: normal; font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; }
@media (max-width: 980px) {
  .payscore-hero, .payscore-kpi-grid, .payscore-section-grid, .payscore-section-grid.compact, .payscore-stress-grid, .payscore-history-list.grid { grid-template-columns: 1fr; }
}

/* payScore v2 report finale */
.payscore-executive { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 24px; align-items: stretch; padding: 30px; }
.payscore-executive-main h1 { margin: 8px 0 12px; font-size: clamp(2rem, 4vw, 4rem); line-height: .95; letter-spacing: -.05em; }
.payscore-executive-main p { max-width: 860px; font-size: 1.06rem; line-height: 1.7; color: rgba(255,255,255,.78); }
.payscore-meta.clean span { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.12); }
.payscore-verdict em { display: block; margin-top: 12px; font-style: normal; opacity: .86; font-weight: 700; }
.payscore-probability { display: grid; grid-template-columns: minmax(0, 1fr) 260px; gap: 22px; align-items: center; padding: 30px; }
.payscore-probability strong { display: block; font-size: clamp(4rem, 10vw, 8rem); line-height: .9; letter-spacing: -.08em; margin-top: 8px; }
.payscore-probability small { font-size: .34em; letter-spacing: -.04em; }
.payscore-probability p { color: rgba(255,255,255,.72); font-size: 1.05rem; line-height: 1.6; }
.payscore-gauge { height: 30px; border-radius: 999px; overflow: hidden; background: rgba(255,255,255,.10); box-shadow: inset 0 0 0 1px rgba(255,255,255,.10); }
.payscore-gauge i { display: block; width: var(--value); min-width: 4%; height: 100%; border-radius: inherit; background: linear-gradient(90deg, rgba(255,255,255,.72), currentColor); }
.payscore-approved .payscore-gauge i { color: #20c997; }
.payscore-conditional .payscore-gauge i { color: #20c997; }
.payscore-rejected .payscore-gauge i { color: #ff4d4f; }
.payscore-kpi-grid.refined { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.payscore-kpi p { margin: 8px 0 0; color: rgba(255,255,255,.66); line-height: 1.55; }
.payscore-decision-board h2 { font-size: clamp(1.6rem, 3vw, 2.5rem); margin: 8px 0 16px; }
.payscore-condition-list { display: flex; flex-wrap: wrap; gap: 10px; }
.payscore-condition-list span { padding: 10px 12px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.11); font-weight: 800; }
.payscore-section-grid.refined { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.payscore-section-grid.refined .wide { grid-column: 1 / -1; }
.payscore-stress-grid.refined article strong { display: block; margin-bottom: 8px; font-size: 1rem; }
.payscore-stress-grid.refined article p { line-height: 1.62; color: rgba(255,255,255,.72); }
.payscore-signal-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.payscore-signal-grid-top { grid-area: signals; }
.payscore-signal-grid .wide { grid-column: 1 / -1; }
.payscore-signal-grid ul { margin: 12px 0 0; padding-left: 18px; color: rgba(255,255,255,.74); line-height: 1.7; }
.payscore-pending-card { position: relative; overflow: hidden; min-height: 260px; display: grid; align-content: center; }
.payscore-pending-card h2 { font-size: clamp(1.8rem, 4vw, 3.3rem); margin: 8px 0 12px; }
.payscore-pending-card p { max-width: 680px; color: rgba(255,255,255,.72); line-height: 1.7; }
.payscore-pending-card.error { border-color: rgba(255,77,79,.35); }
@media (max-width: 980px) {
  .payscore-executive, .payscore-probability, .payscore-kpi-grid.refined, .payscore-section-grid.refined, .payscore-signal-grid { grid-template-columns: 1fr; }
  .payscore-section-grid.refined .wide { grid-column: auto; }
}

/* payScore v3: risultato e percentuale above-the-fold */
.payscore-report { gap: 16px; margin-top: 0; }
.payscore-abovefold {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, .62fr) minmax(280px, .62fr);
    grid-template-areas:
        "head head verdict"
        "probability snapshot verdict"
        "probability kpis kpis"
        "signals signals signals"
        "summary action action";
    gap: 14px;
    padding: clamp(18px, 2.5vw, 28px);
    min-height: min(650px, calc(100vh - 150px));
    align-content: stretch;
}
.payscore-abovefold-head { grid-area: head; display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.payscore-abovefold-head h1 { margin: 6px 0 0; font-size: clamp(1.7rem, 3.8vw, 3.4rem); line-height: .96; letter-spacing: -.045em; max-width: 980px; }
.payscore-primary-metric,
.payscore-verdict-card,
.payscore-snapshot-card,
.payscore-executive-summary,
.payscore-next-action,
.payscore-abovefold-kpis article {
    border: 1px solid rgba(255,255,255,.11);
    background: rgba(255,255,255,.055);
    border-radius: 24px;
    padding: clamp(16px, 2vw, 22px);
}
.payscore-primary-metric { grid-area: probability; display: grid; align-content: center; }
.payscore-primary-metric span,
.payscore-verdict-card span,
.payscore-snapshot-card span,
.payscore-executive-summary span,
.payscore-next-action span,
.payscore-abovefold-kpis span {
    display: block;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: rgba(255,255,255,.68);
    font-weight: 800;
}
.payscore-primary-metric strong { display: block; font-size: clamp(5.2rem, 12vw, 10.5rem); line-height: .82; letter-spacing: -.09em; margin: 10px 0 16px; }
.payscore-primary-metric small { font-size: .32em; letter-spacing: -.06em; }
.payscore-primary-metric p { margin: 12px 0 0; font-size: 1rem; line-height: 1.5; color: rgba(255,255,255,.75); }
.payscore-verdict-card { grid-area: verdict; display: grid; align-content: center; min-height: 220px; box-shadow: inset 0 0 0 1px rgba(255,255,255,.14); }
.payscore-verdict-card strong { display: block; font-size: clamp(2rem, 3.6vw, 3.3rem); line-height: .95; letter-spacing: -.05em; margin-top: 12px; }
.payscore-verdict-card em { display: block; font-style: normal; font-weight: 800; margin-top: 14px; color: rgba(255,255,255,.88); }
.payscore-verdict-card small { display: inline-flex; margin-top: 14px; width: fit-content; padding: 8px 11px; border-radius: 999px; background: rgba(255,255,255,.12); color: rgba(255,255,255,.82); font-weight: 800; }
.payscore-verdict-card.approved { background: linear-gradient(135deg, rgba(32, 201, 151, .34), rgba(32, 201, 151, .08)); border-color: rgba(32, 201, 151, .46); }
.payscore-verdict-card.conditional { background: linear-gradient(135deg, rgba(32, 201, 151, .24), rgba(32, 201, 151, .07)); border-color: rgba(32, 201, 151, .40); }
.payscore-verdict-card.rejected { background: linear-gradient(135deg, rgba(255, 77, 79, .34), rgba(255, 77, 79, .08)); border-color: rgba(255, 77, 79, .52); }
.payscore-snapshot-card { grid-area: snapshot; }
.payscore-snapshot-card strong { display: block; margin-top: 8px; font-size: clamp(1.8rem, 3vw, 2.6rem); letter-spacing: -.045em; }
.payscore-meta.compact { margin-top: 12px; gap: 8px; }
.payscore-meta.compact span { padding: 7px 9px; font-size: .8rem; }
.payscore-abovefold-kpis { grid-area: kpis; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.payscore-abovefold-kpis article { min-height: 112px; }
.payscore-abovefold-kpis strong { display: block; margin-top: 8px; font-size: clamp(1.35rem, 2.3vw, 2.1rem); letter-spacing: -.04em; }
.payscore-executive-summary { grid-area: summary; }
.payscore-executive-summary p { margin: 10px 0 0; line-height: 1.55; color: rgba(255,255,255,.76); display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }
.payscore-next-action { grid-area: action; }
.payscore-next-action strong { display: block; margin-top: 8px; font-size: clamp(1.25rem, 2vw, 1.9rem); line-height: 1.15; }
.payscore-condition-list.compact { margin-top: 12px; gap: 8px; }
.payscore-condition-list.compact span { padding: 8px 10px; font-size: .82rem; }
.payscore-approved .payscore-gauge i { color: #20c997; }
.payscore-conditional .payscore-gauge i { color: #20c997; }
.payscore-rejected .payscore-gauge i { color: #ff4d4f; }
@media (max-width: 1180px) {
    .payscore-abovefold {
        grid-template-columns: minmax(0, 1fr) minmax(260px, .65fr);
        grid-template-areas:
            "head head"
            "probability verdict"
            "snapshot kpis"
            "signals signals"
            "summary action";
        min-height: auto;
    }
    .payscore-abovefold-kpis { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
    .payscore-abovefold {
        grid-template-columns: 1fr;
        grid-template-areas: "head" "probability" "verdict" "snapshot" "kpis" "signals" "summary" "action";
    }
    .payscore-abovefold-head { flex-direction: column; }
    .payscore-primary-metric strong { font-size: clamp(4.6rem, 28vw, 8rem); }
}

/* payScore v4 financial dossier */
.payscore-wow-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  grid-column: 1 / -1;
}
.payscore-wow-kpis article {
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(145deg, rgba(255,255,255,.095), rgba(255,255,255,.035));
  border-radius: 22px;
  padding: 18px;
  min-height: 118px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.payscore-wow-kpis span,
.payscore-wow-kpis em {
  display: block;
  color: rgba(255,255,255,.68);
  font-size: .75rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-style: normal;
}
.payscore-wow-kpis strong {
  display: block;
  margin: 8px 0 6px;
  font-size: clamp(1.25rem, 2.2vw, 2rem);
  line-height: 1.05;
  letter-spacing: -.04em;
}
.payscore-financial-dossier {
  position: relative;
  overflow: hidden;
}
.payscore-financial-dossier::before {
  content: "";
  position: absolute;
  inset: -160px -120px auto auto;
  width: 360px;
  height: 360px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(32,201,151,.16), rgba(32,201,151,0) 64%);
  pointer-events: none;
}
.payscore-dossier-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  position: relative;
}
.payscore-dossier-grid article {
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.045);
  border-radius: 24px;
  padding: 20px;
}
.payscore-dossier-grid h3,
.payscore-history-table-wrap h3 {
  margin: 0 0 14px;
  font-size: 1.08rem;
}
.payscore-info-list {
  display: grid;
  gap: 9px;
}
.payscore-info-list div {
  display: grid;
  grid-template-columns: minmax(130px, .75fr) minmax(0, 1.25fr);
  gap: 12px;
  align-items: start;
  border-bottom: 1px solid rgba(255,255,255,.075);
  padding-bottom: 9px;
}
.payscore-info-list div:last-child { border-bottom: 0; padding-bottom: 0; }
.payscore-info-list span {
  color: rgba(255,255,255,.58);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.payscore-info-list strong {
  color: rgba(255,255,255,.92);
  font-size: .96rem;
  line-height: 1.35;
  text-align: right;
}
.payscore-history-table-wrap {
  margin-top: 18px;
  position: relative;
  overflow-x: auto;
}
.payscore-history-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 760px;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
}
.payscore-history-table th,
.payscore-history-table td {
  padding: 13px 14px;
  border-bottom: 1px solid rgba(255,255,255,.075);
  text-align: right;
}
.payscore-history-table th:first-child,
.payscore-history-table td:first-child { text-align: left; }
.payscore-history-table th {
  color: rgba(255,255,255,.62);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  background: rgba(255,255,255,.045);
}
.payscore-history-table td {
  color: rgba(255,255,255,.88);
  font-weight: 700;
}
.payscore-history-table tr:last-child td { border-bottom: 0; }
.payscore-history-table .positive { color: #20c997; }
.payscore-history-table .negative { color: #ff6b6b; }
.payscore-history-table .neutral { color: rgba(255,255,255,.78); }
@media (max-width: 1180px) {
  .payscore-wow-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .payscore-dossier-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .payscore-wow-kpis { grid-template-columns: 1fr; }
  .payscore-info-list div { grid-template-columns: 1fr; gap: 4px; }
  .payscore-info-list strong { text-align: left; }
}


/* v5 readability and containment hardening */
html, body, .app-shell, .admin-shell, .panel-surface, .panel-soft, .content-card, .hero-card,
.sidebar, .admin-sidebar, .app-main, .admin-main, .table-wrap, .copy-card, .history-card,
.payscore-report, .payscore-report *, .results-table, .results-table *, .admin-search-detail,
.helper-copy, .attempt-card, .admin-notes, .primary-cta, .ghost-button {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

pre, .admin-notes, .copy-card-pre {
    white-space: pre-wrap;
    overflow-x: auto;
    line-height: 1.55;
}

.table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.results-table th,
.results-table td {
    vertical-align: top;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.primary-cta, .ghost-button, .sidebar-nav a, .admin-sidebar .sidebar-nav a {
    white-space: normal;
    text-align: left;
}

.sidebar-nav a,
.admin-sidebar .sidebar-nav a {
    display: block;
    line-height: 1.25;
}

.sidebar-subnav {
    display: grid;
    gap: 7px;
    margin: -2px 0 6px 20px;
    padding-left: 16px;
    border-left: 1px solid rgba(164, 189, 233, 0.18);
}

.sidebar-subnav a {
    display: block;
    width: calc(100% - 4px);
    font-size: .92rem;
    padding: 10px 13px;
    opacity: .92;
}

.admin-search-detail {
    margin-top: 18px;
    padding: clamp(16px, 2vw, 24px);
    border-radius: var(--radius-lg);
}

.admin-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}

.admin-actions-form,
.inline-filter-form,
.section-actions {
    min-width: 0;
    flex-wrap: wrap;
}

@media (max-width: 760px) {
    .admin-detail-grid { grid-template-columns: 1fr; }
    .sidebar-subnav { margin-left: 12px; padding-left: 12px; }
}

/* PayScore v46 - prompt CFO pragmatico, probabilità divise e layout anti-overflow */
.payscore-report,
.payscore-report * {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: normal;
}
.payscore-abovefold {
  grid-template-areas:
    "head head verdict"
    "probability split verdict"
    "probability snapshot verdict"
    "kpis kpis kpis"
    "signals signals signals"
    "summary action action";
}
.payscore-probability-split {
  grid-area: split;
  display: grid;
  gap: 10px;
}
.payscore-probability-split article {
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.055);
  border-radius: 18px;
  padding: 12px;
  display: grid;
  gap: 7px;
}
.payscore-probability-split span {
  display: block;
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.64);
  font-weight: 800;
}
.payscore-probability-split strong {
  font-size: clamp(1.15rem, 2vw, 1.8rem);
  line-height: 1;
}
.payscore-probability-split i {
  display: block;
  width: var(--value);
  max-width: 100%;
  min-width: 4%;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.76);
}
.payscore-probability-split article:nth-child(1) i { background: #20c997; }
.payscore-probability-split article:nth-child(2) i { background: #f7b25b; }
.payscore-probability-split article:nth-child(3) i { background: #ff4d4f; }
.payscore-abovefold-kpis {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.payscore-abovefold-kpis article,
.payscore-wow-kpis article,
.payscore-dossier-grid article,
.payscore-stress-grid article,
.payscore-signal-grid article,
.payscore-section-grid article {
  overflow: hidden;
}
.payscore-abovefold-kpis strong {
  font-size: clamp(1.05rem, 1.9vw, 1.7rem);
  line-height: 1.12;
}
.payscore-condition-list span {
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: 1.3;
}
.payscore-info-list strong {
  overflow-wrap: anywhere;
}
.payscore-primary-metric strong,
.payscore-verdict-card strong,
.payscore-snapshot-card strong,
.payscore-wow-kpis strong {
  max-width: 100%;
}
@media (max-width: 1180px) {
  .payscore-abovefold {
    grid-template-areas:
      "head head"
      "probability verdict"
      "split split"
      "snapshot kpis"
      "signals signals"
      "summary action";
  }
  .payscore-probability-split { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .payscore-abovefold {
    grid-template-areas: "head" "probability" "split" "verdict" "snapshot" "kpis" "signals" "summary" "action";
  }
  .payscore-probability-split { grid-template-columns: 1fr; }
  .payscore-info-list div {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .payscore-info-list strong { text-align: left; }
}

/* GEOAI */
.geoai-entry-hero,
.geoai-report,
.geoai-report * {
    box-sizing: border-box;
    max-width: 100%;
    overflow-wrap: anywhere;
}
.geoai-service-grid,
.geoai-kpi-grid,
.geoai-grid,
.geoai-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 18px;
    min-width: 0;
}
.geoai-service-card {
    display: block;
    text-decoration: none;
    color: inherit;
    min-width: 0;
    transition: transform .18s ease, box-shadow .18s ease;
}
.geoai-service-card:hover { transform: translateY(-2px); }
.geoai-form-grid label,
.geoai-form-grid .full { min-width: 0; }
.geoai-form-grid .full { grid-column: 1 / -1; }
.geoai-form-grid textarea,
.geoai-form-grid input,
.geoai-form-grid select { width: 100%; min-width: 0; }
.geoai-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(240px, .6fr);
    gap: 24px;
    align-items: stretch;
    padding: clamp(22px, 4vw, 42px);
    border-radius: 30px;
    margin-bottom: 20px;
    overflow: hidden;
}
.geoai-hero h1 { font-size: clamp(28px, 4vw, 52px); line-height: 1.02; margin: 8px 0 14px; }
.geoai-hero p { font-size: clamp(15px, 1.6vw, 18px); line-height: 1.65; color: var(--muted); }
.geoai-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.geoai-score-panel {
    border-radius: 26px;
    padding: clamp(20px, 3vw, 32px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
    background: linear-gradient(135deg, rgba(59,130,246,.12), rgba(15,23,42,.04));
    border: 1px solid rgba(148,163,184,.25);
}
.geoai-score-panel.green { background: linear-gradient(135deg, rgba(34,197,94,.18), rgba(15,23,42,.04)); }
.geoai-score-panel.yellow { background: linear-gradient(135deg, rgba(245,158,11,.20), rgba(15,23,42,.04)); }
.geoai-score-panel.red { background: linear-gradient(135deg, rgba(239,68,68,.18), rgba(15,23,42,.04)); }
.geoai-score-panel span { font-weight: 800; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); font-size: 12px; }
.geoai-score-panel strong { font-size: clamp(54px, 8vw, 96px); line-height: .95; margin: 10px 0; }
.geoai-score-panel em { font-style: normal; font-weight: 800; color: var(--heading); }
.geoai-kpi-grid article,
.geoai-mini-card,
.geoai-card {
    min-width: 0;
    border-radius: 22px;
    padding: clamp(16px, 2.2vw, 24px);
    background: rgba(12,24,45,.94);
    border: 1px solid rgba(148,163,184,.22);
}
.geoai-kpi-grid article span { display: block; color: var(--muted); font-weight: 700; margin-bottom: 8px; }
.geoai-kpi-grid article strong { display: block; font-size: clamp(22px, 3vw, 36px); }
.geoai-kpi-grid article small { color: var(--muted); display: block; margin-top: 8px; }
.geoai-bar { height: 10px; border-radius: 999px; background: rgba(148,163,184,.2); overflow: hidden; margin-top: 14px; }
.geoai-bar i { display: block; width: var(--value); height: 100%; border-radius: inherit; background: currentColor; color: #2563eb; }
.geoai-card-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.geoai-dl { display: grid; grid-template-columns: minmax(110px, .45fr) minmax(0, 1fr); gap: 10px 14px; margin: 0; }
.geoai-dl dt { color: var(--muted); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; }
.geoai-dl dd { margin: 0; min-width: 0; line-height: 1.55; }
.geoai-list { margin: 0; padding-left: 18px; line-height: 1.6; }
.geoai-history-list { display: grid; gap: 12px; }
@media (max-width: 760px) {
    .geoai-hero { grid-template-columns: 1fr; padding: 20px; }
    .geoai-dl { grid-template-columns: 1fr; }
    .geoai-form-grid { grid-template-columns: 1fr; }
}


/* GEOAI City Scan v2 */
.geoai-report .content-card,
.geoai-report .panel-surface { min-width: 0; }
.geoai-section-title { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:16px; }
.geoai-section-title h2 { margin:0; }
.geoai-pill-row { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.geoai-pill { display:inline-flex; align-items:center; border-radius:999px; padding:7px 11px; font-size:12px; font-weight:800; background:rgba(59,130,246,.10); color:#1d4ed8; max-width:100%; overflow-wrap:anywhere; }
.geoai-city-hero-meta { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:10px; margin-top:18px; }
.geoai-city-hero-meta div { border:1px solid rgba(148,163,184,.24); background:rgba(12,24,45,.94); border-radius:16px; padding:12px; min-width:0; }
.geoai-city-hero-meta span { display:block; color:var(--muted); font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.05em; }
.geoai-city-hero-meta strong { display:block; margin-top:5px; font-size:15px; overflow-wrap:anywhere; }
.geoai-zone-ranking { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:16px; }
.geoai-zone-card { border:1px solid rgba(148,163,184,.24); background:rgba(12,24,45,.94); border-radius:24px; padding:18px; min-width:0; position:relative; overflow:hidden; }
.geoai-zone-rank { width:34px; height:34px; border-radius:999px; display:inline-grid; place-items:center; background:#111827; color:#fff; font-weight:900; margin-bottom:12px; }
.geoai-zone-card h3 { margin:0 0 8px; font-size:20px; overflow-wrap:anywhere; }
.geoai-zone-card p { color:var(--muted); line-height:1.55; margin:0 0 12px; }
.geoai-zone-card.green { border-color:rgba(34,197,94,.38); }
.geoai-zone-card.yellow { border-color:rgba(245,158,11,.42); }
.geoai-zone-card.red { border-color:rgba(239,68,68,.42); }
.geoai-metric-list { display:grid; gap:8px; margin-top:12px; }
.geoai-metric-list div { display:grid; grid-template-columns:minmax(90px,.7fr) minmax(0,1fr); gap:8px; align-items:start; }
.geoai-metric-list span { color:var(--muted); font-size:12px; font-weight:800; text-transform:uppercase; }
.geoai-metric-list strong { font-size:14px; line-height:1.35; overflow-wrap:anywhere; }
.geoai-location-table-wrap { width:100%; overflow-x:auto; border-radius:20px; border:1px solid rgba(148,163,184,.22); }
.geoai-location-table { width:100%; min-width:840px; border-collapse:collapse; background:rgba(12,24,45,.94); }
.geoai-location-table th,
.geoai-location-table td { padding:14px; text-align:left; border-bottom:1px solid rgba(148,163,184,.18); vertical-align:top; line-height:1.45; }
.geoai-location-table th { font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; }
.geoai-map-link { display:inline-flex; align-items:center; justify-content:center; padding:8px 11px; border-radius:999px; background:rgba(37,99,235,.10); color:#1d4ed8; text-decoration:none; font-weight:800; font-size:12px; white-space:nowrap; }
.geoai-score-chips { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:12px; }
.geoai-score-chip { border:1px solid rgba(148,163,184,.22); border-radius:20px; padding:15px; background:rgba(12,24,45,.94); min-width:0; }
.geoai-score-chip span { color:var(--muted); font-weight:800; font-size:12px; text-transform:uppercase; }
.geoai-score-chip strong { display:block; margin-top:6px; font-size:28px; }
.geoai-avoid-list { display:grid; gap:12px; }
.geoai-avoid-list article { border-left:4px solid #ef4444; background:rgba(239,68,68,.06); border-radius:16px; padding:14px; min-width:0; }
.geoai-avoid-list h3 { margin:0 0 6px; font-size:17px; }
.geoai-avoid-list p { margin:0; line-height:1.55; color:var(--muted); }
@media (max-width:760px){
  .geoai-section-title { display:block; }
  .geoai-metric-list div { grid-template-columns:1fr; }
}

/* GEOAI Step 5 premium refinements */
.geoai-report {
  --geoai-accent: #2563eb;
  --geoai-soft: rgba(37,99,235,.10);
  position: relative;
  display: grid;
  gap: 22px;
}
.geoai-report.geoai-green { --geoai-accent: #16a34a; --geoai-soft: rgba(22,163,74,.12); }
.geoai-report.geoai-yellow { --geoai-accent: #d97706; --geoai-soft: rgba(217,119,6,.14); }
.geoai-report.geoai-red { --geoai-accent: #dc2626; --geoai-soft: rgba(220,38,38,.12); }
.geoai-report .geoai-hero {
  border: 1px solid rgba(148,163,184,.22);
  box-shadow: 0 24px 70px rgba(15,23,42,.10);
  background:
    radial-gradient(circle at top right, var(--geoai-soft), transparent 42%),
    linear-gradient(180deg, rgba(12,24,45,.96), rgba(7,16,30,.96));
}
.geoai-score-panel {
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--geoai-accent) 34%, transparent);
  box-shadow: inset 0 1px 0 rgba(164,189,233,.10), 0 18px 50px rgba(2,9,21,.24);
}
.geoai-score-panel::after {
  content: '';
  position: absolute;
  inset: auto -20% -45% -20%;
  height: 80%;
  background: radial-gradient(circle, color-mix(in srgb, var(--geoai-accent) 22%, transparent), transparent 68%);
  pointer-events: none;
}
.geoai-wow-strip,
.geoai-admin-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 14px;
}
.geoai-wow-strip article,
.geoai-admin-kpis article {
  min-width: 0;
  border: 1px solid rgba(148,163,184,.22);
  border-radius: 24px;
  padding: 18px;
  background: linear-gradient(180deg, rgba(12,24,45,.96), rgba(7,16,30,.96));
  box-shadow: 0 14px 40px rgba(15,23,42,.07);
  overflow-wrap: anywhere;
}
.geoai-wow-strip span,
.geoai-admin-kpis span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.geoai-wow-strip strong,
.geoai-admin-kpis strong {
  display: block;
  margin-top: 8px;
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1.08;
  color: var(--heading);
}
.geoai-wow-strip em {
  display: block;
  margin-top: 8px;
  font-style: normal;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}
.geoai-score-chip {
  position: relative;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(15,23,42,.06);
}
.geoai-score-chip.green { border-color: rgba(22,163,74,.34); }
.geoai-score-chip.yellow { border-color: rgba(217,119,6,.38); }
.geoai-score-chip.red { border-color: rgba(220,38,38,.35); }
.geoai-score-chip.green .geoai-bar i { color: #16a34a; }
.geoai-score-chip.yellow .geoai-bar i { color: #d97706; }
.geoai-score-chip.red .geoai-bar i { color: #dc2626; }
.geoai-card h2,
.geoai-mini-card h2,
.geoai-zone-card h3 {
  line-height: 1.15;
}
.geoai-card,
.geoai-mini-card,
.geoai-zone-card,
.geoai-location-table td,
.geoai-location-table th {
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: auto;
}
.geoai-filter-row,
.admin-geoai-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: end;
  margin-bottom: 18px;
}
.admin-geoai-filters label {
  display: grid;
  gap: 6px;
  min-width: min(220px, 100%);
}
.admin-geoai-filters input,
.admin-geoai-filters select {
  width: 100%;
  min-width: 0;
  border: 1px solid rgba(148,163,184,.35);
  border-radius: 14px;
  padding: 11px 12px;
  background: #fff;
}
.geoai-filter-row .active,
.ghost-button.active {
  border-color: rgba(37,99,235,.35);
  background: rgba(37,99,235,.10);
  color: #1d4ed8;
}
.geoai-history-premium {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.geoai-history-card {
  border-radius: 20px;
  border: 1px solid rgba(148,163,184,.22);
  background: linear-gradient(180deg, rgba(12,24,45,.96), rgba(7,16,30,.96));
}
.geoai-admin-section {
  scroll-margin-top: 20px;
}
.geoai-admin-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.geoai-admin-status.green { background: rgba(22,163,74,.12); color: #166534; }
.geoai-admin-status.yellow { background: rgba(217,119,6,.13); color: #92400e; }
.geoai-admin-status.red { background: rgba(220,38,38,.12); color: #991b1b; }
.geoai-admin-preview .geoai-report {
  margin-top: 18px;
}
.geoai-admin-preview .geoai-hero {
  grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
}
@media (max-width: 760px) {
  .geoai-wow-strip,
  .geoai-admin-kpis { grid-template-columns: 1fr; }
  .admin-geoai-filters { display: grid; grid-template-columns: 1fr; }
  .geoai-admin-preview .geoai-hero { grid-template-columns: 1fr; }
}

/* GEOAI v13 - leggibilità, sfondo coerente e campi obbligatori/opzionali */
.geoai-report {
  --geoai-accent: var(--brand);
  --geoai-soft: rgba(39, 199, 255, 0.10);
  color: var(--text);
  gap: 20px;
}
.geoai-report.geoai-green { --geoai-accent: var(--success); --geoai-soft: rgba(52, 215, 161, 0.13); }
.geoai-report.geoai-yellow { --geoai-accent: var(--warning); --geoai-soft: rgba(247, 178, 91, 0.14); }
.geoai-report.geoai-red { --geoai-accent: var(--danger); --geoai-soft: rgba(255, 122, 144, 0.14); }
.geoai-report .geoai-hero,
.geoai-report .content-card,
.geoai-report .panel-surface,
.geoai-kpi-grid article,
.geoai-mini-card,
.geoai-card,
.geoai-zone-card,
.geoai-wow-strip article,
.geoai-admin-kpis article,
.geoai-history-card,
.geoai-service-card {
  background: linear-gradient(180deg, rgba(12, 24, 45, 0.96), rgba(7, 16, 30, 0.95)) !important;
  color: var(--text) !important;
  border-color: var(--line) !important;
  box-shadow: 0 18px 50px rgba(2, 9, 21, 0.24);
}
.geoai-report .geoai-hero {
  background:
    linear-gradient(180deg, rgba(12, 24, 45, 0.96), rgba(7, 16, 30, 0.95)) !important;
}
.geoai-score-panel,
.geoai-score-panel.green,
.geoai-score-panel.yellow,
.geoai-score-panel.red {
  background: linear-gradient(180deg, color-mix(in srgb, var(--geoai-accent) 24%, rgba(12,24,45,.92)), rgba(7,16,30,.96)) !important;
  color: var(--text) !important;
  border-color: color-mix(in srgb, var(--geoai-accent) 42%, transparent) !important;
  justify-content: flex-start !important;
  align-items: flex-start !important;
}
.geoai-score-panel::after { display: none !important; }
.geoai-score-panel span,
.geoai-score-panel em,
.geoai-kpi-grid article span,
.geoai-kpi-grid article small,
.geoai-dl dt,
.geoai-wow-strip span,
.geoai-wow-strip em,
.geoai-admin-kpis span,
.geoai-avoid-list p,
.geoai-zone-card p,
.geoai-hero p {
  color: var(--text-soft) !important;
}
.geoai-score-panel strong,
.geoai-kpi-grid article strong,
.geoai-wow-strip strong,
.geoai-admin-kpis strong,
.geoai-card h2,
.geoai-mini-card h2,
.geoai-zone-card h3,
.geoai-dl dd,
.geoai-dl dd span,
.geoai-list,
.geoai-list span {
  color: var(--text) !important;
}
.geoai-kpi-grid > article,
.geoai-card-list > article,
.geoai-grid > article,
.geoai-wow-strip > article,
.geoai-admin-kpis > article,
.geoai-service-card,
.geoai-history-card,
.geoai-zone-card,
.payscore-history-item,
.content-card {
  align-self: stretch;
  align-content: start;
  justify-content: flex-start;
  vertical-align: top;
}
.geoai-kpi-grid > article,
.geoai-card-list > article,
.geoai-wow-strip > article,
.geoai-admin-kpis > article,
.geoai-service-card,
.geoai-history-card,
.geoai-zone-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.geoai-card {
  display: block;
}
.geoai-dl,
.geoai-list,
.geoai-dl dd,
.geoai-dl dt,
.geoai-mini-card,
.geoai-card,
.geoai-zone-card,
.geoai-kpi-grid article,
.geoai-wow-strip article {
  text-align: left;
}
.geoai-dl dd,
.geoai-list li,
.geoai-card p,
.geoai-mini-card p,
.geoai-zone-card p {
  line-height: 1.62;
}
.geoai-wow-strip article {
  min-height: auto;
}
.geoai-map-link {
  background: rgba(39,199,255,.12) !important;
  color: #7fe0ff !important;
  border: 1px solid rgba(39,199,255,.24);
}
.geoai-form-grid {
  align-items: start;
}
.geoai-form-grid label {
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.03);
}
.geoai-form-grid label span {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-weight: 800;
}
.field-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 4px 8px;
  font-style: normal;
  font-size: 10px;
  line-height: 1;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.field-badge.required { background: rgba(52,215,161,.15); color: var(--success); border: 1px solid rgba(52,215,161,.28); }
.field-badge.optional { background: rgba(164,189,233,.10); color: var(--text-soft); border: 1px solid rgba(164,189,233,.20); }
.geoai-form-section {
  display: grid;
  gap: 4px;
  align-content: start;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(52,215,161,.22);
  background: rgba(52,215,161,.08);
}
.geoai-form-section.optional {
  border-color: rgba(164,189,233,.18);
  background: rgba(255,255,255,.025);
}
.geoai-form-section .eyebrow {
  margin: 0;
}
.geoai-form-section p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.5;
}
.geoai-hero,
.geoai-report .geoai-hero {
  align-items: start !important;
}
.geoai-hero > div,
.geoai-report .geoai-hero > div {
  align-self: start;
}
@media (max-width: 760px) {
  .field-badge { white-space: normal; text-align: center; }
  .geoai-form-grid label { padding: 12px; }
}


/* GEOAI v14 - leggibilità testi lunghi e rimozione box chiari */
.geoai-report .geoai-city-hero-meta div,
.geoai-report .geoai-location-table,
.geoai-report .geoai-location-table th,
.geoai-report .geoai-location-table td,
.geoai-report .geoai-score-chip,
.geoai-report .geoai-zone-card,
.geoai-report .geoai-mini-card,
.geoai-report .geoai-card,
.geoai-report .geoai-wow-strip article,
.geoai-report .geoai-kpi-grid article,
.geoai-report .geoai-history-card,
.geoai-admin-preview .geoai-city-hero-meta div,
.geoai-admin-preview .geoai-location-table,
.geoai-admin-preview .geoai-score-chip,
.geoai-admin-preview .geoai-zone-card,
.geoai-admin-preview .geoai-mini-card,
.geoai-admin-preview .geoai-card {
  background: linear-gradient(180deg, rgba(12, 24, 45, 0.97), rgba(7, 16, 30, 0.96)) !important;
  color: var(--text) !important;
  border-color: var(--line) !important;
}
.geoai-report .geoai-location-table-wrap {
  background: rgba(7, 16, 30, .96) !important;
  border-color: var(--line) !important;
}
.geoai-report .geoai-location-table th,
.geoai-report .geoai-location-table td {
  border-bottom-color: rgba(164,189,233,.13) !important;
  vertical-align: top;
}
.geoai-report .geoai-rich-text {
  display: grid;
  gap: 10px;
  min-width: 0;
  max-width: 100%;
  color: var(--text-soft);
  line-height: 1.68;
  overflow-wrap: anywhere;
  word-break: normal;
}
.geoai-report .geoai-rich-text p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.68;
}
.geoai-report .geoai-rich-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
  color: var(--text-soft);
}
.geoai-report .geoai-rich-list li {
  padding-left: 2px;
  line-height: 1.58;
}
.geoai-report .geoai-dl {
  gap: 14px 16px;
}
.geoai-report .geoai-dl dt {
  padding-top: 3px;
}
.geoai-report .geoai-dl dd {
  display: grid;
  gap: 8px;
}
.geoai-report .geoai-list > li {
  margin-bottom: 10px;
}
.geoai-report .geoai-list > li::marker,
.geoai-report .geoai-rich-list > li::marker {
  color: var(--geoai-accent);
}
.geoai-report .geoai-empty {
  color: var(--text-soft);
  font-style: italic;
}
.geoai-report .geoai-card,
.geoai-report .geoai-mini-card,
.geoai-report .geoai-zone-card,
.geoai-report .geoai-kpi-grid article,
.geoai-report .geoai-wow-strip article,
.geoai-report .content-card,
.geoai-admin-preview .geoai-card,
.geoai-admin-preview .geoai-mini-card,
.geoai-admin-preview .geoai-zone-card {
  align-content: start !important;
  justify-content: flex-start !important;
  align-items: flex-start !important;
}
.geoai-report .geoai-zone-card .geoai-rich-text,
.geoai-report .geoai-avoid-list .geoai-rich-text {
  margin: 0 0 12px;
}
.geoai-report .geoai-avoid-list article {
  background: rgba(255, 122, 144, .08) !important;
  border: 1px solid rgba(255, 122, 144, .18) !important;
  border-left: 4px solid var(--danger) !important;
}
.geoai-report .geoai-city-hero-meta strong,
.geoai-report .geoai-location-table strong,
.geoai-report .geoai-location-table td,
.geoai-report .geoai-location-table th {
  color: var(--text) !important;
}
.geoai-report .geoai-city-hero-meta span,
.geoai-report .geoai-location-table th {
  color: var(--text-soft) !important;
}


/* v15 - scrollbar Apple-style, free Hub, GeoAI/PayScore layout polish */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(164, 189, 233, .34) transparent;
}
*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
*::-webkit-scrollbar-track {
  background: transparent;
}
*::-webkit-scrollbar-thumb {
  background: rgba(164, 189, 233, .24);
  border: 3px solid transparent;
  border-radius: 999px;
  background-clip: padding-box;
}
*::-webkit-scrollbar-thumb:hover {
  background: rgba(164, 189, 233, .42);
  border: 2px solid transparent;
  background-clip: padding-box;
}
*::-webkit-scrollbar-corner { background: transparent; }
.sidebar { scrollbar-gutter: stable; }

.research-layout-free,
.payscore-layout {
  grid-template-columns: minmax(0, 1.42fr) minmax(320px, .58fr);
}
.hub-form-card,
.payscore-form-card,
.geoai-form-card { min-width: 0; }
.hub-form-card form,
.payscore-form-card form {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 16px;
}
.hub-form-card form > label,
.payscore-form-card form > label,
.hub-form-card form > .form-block,
.hub-form-card form > .free-inline-note,
.hub-form-card form > .credit-inline-note,
.payscore-form-card form > .free-inline-note,
.payscore-form-card form > .credit-inline-note {
  grid-column: span 6;
  min-width: 0;
}
.hub-form-card form > label:first-of-type,
.hub-form-card form > label:nth-of-type(2),
.hub-form-card form > .form-block,
.hub-form-card form > .free-inline-note,
.hub-form-card form > .credit-inline-note,
.hub-form-card form > button,
.payscore-form-card form > label:has(textarea),
.payscore-form-card form > .free-inline-note,
.payscore-form-card form > .credit-inline-note,
.payscore-form-card form > button {
  grid-column: 1 / -1;
}
.hub-form-card textarea,
.payscore-form-card textarea { min-height: 132px; }
.free-note,
.free-inline-note.free-note,
.credit-inline-note.free-note {
  background: rgba(52, 215, 161, .10);
  border-color: rgba(52, 215, 161, .26);
  color: #d7fff1;
}

.geoai-form-card { padding: clamp(20px, 2.4vw, 30px); }
.geoai-form-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: 16px !important;
  width: 100%;
}
.geoai-form-grid > label {
  grid-column: span 4;
  min-width: 0;
}
.geoai-form-grid > .full,
.geoai-form-grid > .geoai-form-section.full,
.geoai-form-grid > button { grid-column: 1 / -1 !important; }
.geoai-form-grid > label.full textarea { min-height: 118px; }
.geoai-form-grid label {
  height: 100%;
  justify-content: start;
}
.geoai-form-grid input,
.geoai-form-grid select,
.geoai-form-grid textarea,
.hub-form-card input,
.hub-form-card select,
.hub-form-card textarea,
.payscore-form-card input,
.payscore-form-card select,
.payscore-form-card textarea { min-width: 0; }

.geoai-report { --geoai-card-min: 330px; }
.geoai-report .geoai-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--geoai-card-min)), 1fr)) !important;
  align-items: stretch;
}
.geoai-report .geoai-card-list,
.geoai-report .geoai-zone-ranking {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr)) !important;
}
.geoai-report .geoai-score-chips,
.geoai-report .geoai-kpi-grid,
.geoai-report .geoai-wow-strip {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr)) !important;
}
.geoai-report .geoai-card,
.geoai-report .geoai-mini-card,
.geoai-report .geoai-zone-card {
  gap: 14px;
  min-height: 0;
}
.geoai-report .geoai-dl {
  grid-template-columns: minmax(132px, .34fr) minmax(0, 1fr);
  gap: 14px 18px;
}
.geoai-report .geoai-dl dt,
.geoai-report .geoai-dl dd {
  align-self: start;
  line-height: 1.55;
}
.geoai-report .geoai-dl dd { line-height: 1.68; }
.geoai-report .geoai-list {
  display: grid;
  gap: 10px;
}
.geoai-report .geoai-list > li { padding-left: 2px; }
.geoai-report .geoai-list > li > .geoai-dl { margin-top: 4px; }
.geoai-report .geoai-rich-text p + p { margin-top: 2px; }
.geoai-report .content-card > h2,
.geoai-report .geoai-card > h2,
.geoai-report .geoai-mini-card > h2 { margin-bottom: 2px; }
.geoai-location-table-wrap,
.payscore-history-table-wrap,
.table-wrap { scrollbar-gutter: stable both-edges; }

.payscore-history-list.grid.payscore-history-full {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.payscore-history-item { align-content: start; }
.payscore-archive-hero .hero-actions {
  align-self: start;
  justify-self: end;
}

@media (max-width: 1280px) {
  .research-layout-free,
  .payscore-layout { grid-template-columns: 1fr; }
  .geoai-form-grid > label { grid-column: span 6; }
}
@media (max-width: 780px) {
  .hub-form-card form,
  .payscore-form-card form,
  .geoai-form-grid { grid-template-columns: 1fr !important; }
  .hub-form-card form > label,
  .payscore-form-card form > label,
  .hub-form-card form > .form-block,
  .hub-form-card form > .credit-inline-note,
  .payscore-form-card form > .free-inline-note,
  .payscore-form-card form > .credit-inline-note,
  .geoai-form-grid > label,
  .geoai-form-grid > .full,
  .geoai-form-grid > .geoai-form-section.full,
  .geoai-form-grid > button { grid-column: 1 / -1 !important; }
  .geoai-report .geoai-dl { grid-template-columns: 1fr; }
}

/* v15.1 - GEOAI: mai testi lunghi in 3 colonne */
@media (min-width: 1021px) {
  .geoai-report .geoai-grid,
  .geoai-report .geoai-card-list,
  .geoai-report .geoai-zone-ranking {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 1020px) {
  .geoai-report .geoai-grid,
  .geoai-report .geoai-card-list,
  .geoai-report .geoai-zone-ranking {
    grid-template-columns: 1fr !important;
  }
}


/* v16 dashboard links e note GEOAI guidate */
.service-launchpad {
  display: grid;
  gap: 18px;
  margin-bottom: 22px;
}

.service-launchpad-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px;
  align-items: stretch;
}

.service-launch-card {
  display: grid;
  align-content: start;
  gap: 8px;
  min-width: 0;
  min-height: 150px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: inherit;
  text-decoration: none;
  overflow-wrap: anywhere;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.service-launch-card:hover {
  transform: translateY(-2px);
  border-color: rgba(52,215,161,.28);
  background: rgba(52,215,161,.055);
}

.service-launch-card span {
  color: var(--muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
  font-size: 11px;
}

.service-launch-card strong {
  color: var(--heading);
  font-size: 1.02rem;
  line-height: 1.25;
}

.service-launch-card em {
  color: var(--text-soft);
  font-style: normal;
  line-height: 1.55;
}

.service-launch-card.dashboard-card {
  border-color: rgba(96,165,250,.28);
  background: linear-gradient(135deg, rgba(37,99,235,.10), rgba(255,255,255,.035));
}

.service-launch-card.disabled {
  opacity: .68;
  cursor: default;
}

.service-launch-card.disabled:hover {
  transform: none;
  border-color: rgba(96,165,250,.20);
}

.geoai-guided-notes {
  display: grid !important;
  gap: 12px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(52,215,161,.18);
  background: rgba(52,215,161,.045);
  align-content: start;
}

.geoai-guided-notes .note-helper {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.55;
  font-size: .95rem;
  font-weight: 500;
}

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

.note-prompt-grid small {
  display: block;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.035);
  color: var(--muted);
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.geoai-guided-notes textarea {
  min-height: 150px;
  resize: vertical;
  line-height: 1.65;
}

@media (max-width: 760px) {
  .service-launch-card {
    min-height: auto;
  }

  .note-prompt-grid {
    grid-template-columns: 1fr;
  }
}

/* Fix full-width note blocks in grid forms */
.hub-form-card form > .free-inline-note,
.payscore-form-card form > .free-inline-note {
  grid-column: 1 / -1 !important;
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}

.payscore-signal-grid > .wide {
  grid-column: 1 / -1;
}

.payscore-linked-table th,
.payscore-linked-table td {
  text-align: left;
}

/* PayScore outcome tracking and report export */
.report-export-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin: 0 0 18px;
  flex-wrap: wrap;
}

.payscore-outcome-card {
  margin-top: 18px;
  border-color: rgba(96,165,250,.22);
}

.payscore-outcome-card.required {
  border-color: rgba(251,191,36,.42);
  background: linear-gradient(135deg, rgba(251,191,36,.12), rgba(255,255,255,.035));
}

.payscore-outcome-form {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.payscore-outcome-form label.full {
  grid-column: 1 / -1;
}

.payscore-outcome-form button {
  grid-column: 1 / -1;
  justify-self: start;
}

.free-inline-note.warning {
  border-color: rgba(251,191,36,.42);
  background: rgba(251,191,36,.10);
  color: #fde68a;
}

@media (max-width: 860px) {
  .report-export-actions {
    justify-content: stretch;
  }

  .report-export-actions > * {
    flex: 1 1 100%;
    text-align: center;
  }

  .payscore-outcome-form {
    grid-template-columns: 1fr;
  }
}

/* v22 PayScore export shell and outcome visibility */
.report-export-shell {
  display: block;
  width: min(1560px, calc(100vw - 48px));
  max-width: calc(100vw - 48px);
  margin: 0 auto;
  padding: 0;
}
.report-export-shell .payscore-report {
  width: 100%;
  margin: 0;
}
@media (min-width: 1181px) {
  .report-export-shell .payscore-abovefold {
    grid-template-columns: minmax(0, 1.14fr) minmax(300px, .60fr) minmax(340px, .64fr);
  }
}
@media (min-width: 1600px) {
  .report-export-shell {
    width: min(1680px, calc(100vw - 64px));
    max-width: calc(100vw - 64px);
  }
}
.payscore-outcome-dashboard {
  margin-bottom: 18px;
}
.payscore-outcome-card.required {
  scroll-margin-top: 24px;
}
.payscore-outcome-card h2 {
  margin-bottom: 8px;
}
.payscore-outcome-card .section-heading p {
  max-width: 920px;
}
@media print {
  .report-export-shell .ghost-button,
  .report-export-shell .report-export-actions {
    display: none !important;
  }
}

/* v23 PayScore Esito Fatture separated from report */
.payscore-outcome-center .payscore-outcome-card {
  margin-top: 0;
  box-shadow: none;
}
.payscore-outcome-list {
  display: grid;
  gap: 16px;
}
.payscore-outcome-item {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.035);
}
.payscore-outcome-item.required {
  border-color: rgba(251,191,36,.38);
  background: linear-gradient(135deg, rgba(251,191,36,.10), rgba(255,255,255,.035));
}
.payscore-outcome-item-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.payscore-outcome-item-head strong {
  display: block;
  font-size: 1.08rem;
  line-height: 1.25;
}
.payscore-outcome-item-head span {
  display: block;
  margin-top: 4px;
  color: var(--text-soft);
  line-height: 1.45;
}
.payscore-outcome-item .payscore-outcome-form {
  margin-top: 0;
}
.payscore-outcome-item .payscore-outcome-card {
  padding: 0;
  border: 0;
  background: transparent;
}

/* v26 PayScore Esito Fatture: searchable selector, no infinite invoice list */
.payscore-outcome-workbench {
  gap: 18px;
}

.payscore-outcome-picker {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(39, 199, 255, .18);
  background: rgba(39, 199, 255, .055);
}

.payscore-outcome-search-field {
  min-width: 0;
}

.payscore-outcome-search-field input {
  min-height: 62px;
  font-weight: 800;
  background: rgba(255,255,255,.075);
}

.payscore-outcome-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.payscore-outcome-selected,
.payscore-outcome-empty-selection {
  padding: clamp(18px, 2.2vw, 26px);
  border-radius: 26px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
}

.payscore-outcome-selected.required {
  border-color: rgba(251,191,36,.42);
  background: linear-gradient(135deg, rgba(251,191,36,.11), rgba(255,255,255,.04));
}

.payscore-outcome-selected-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.payscore-outcome-selected-head h2 {
  margin: 4px 0 8px;
  font-size: clamp(1.4rem, 2.6vw, 2.3rem);
  letter-spacing: -.035em;
}

.payscore-outcome-selected-head p,
.payscore-outcome-empty-selection span {
  display: block;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0;
}

.payscore-outcome-selected .payscore-outcome-card {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.payscore-outcome-selected .payscore-outcome-card > .eyebrow,
.payscore-outcome-selected .payscore-outcome-card > h2,
.payscore-outcome-selected .payscore-outcome-card > p {
  display: none;
}

.payscore-outcome-selected .payscore-outcome-form {
  margin-top: 0;
}

.payscore-outcome-empty-selection {
  display: grid;
  gap: 6px;
  min-height: 110px;
  align-content: center;
  border-style: dashed;
}

.payscore-outcome-compact-archive {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

@media (max-width: 780px) {
  .payscore-outcome-picker {
    grid-template-columns: 1fr;
  }
  .payscore-outcome-picker .primary-cta {
    width: 100%;
  }
}

/* v28 PayScore public website */
:root {
  --ps-site-bg: #06111f;
  --ps-site-panel: #0f2136;
  --ps-site-line: rgba(255, 255, 255, .12);
  --ps-site-text: #f6f9ff;
  --ps-site-muted: #9fb3ca;
  --ps-site-blue: #2d8cff;
  --ps-site-green: #24e6a8;
  --ps-site-cyan: #38dcff;
}
.ps-site-navbar,
.ps-hero,
.ps-page-main,
.ps-site-footer {
  color: var(--ps-site-text);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
.ps-site-navbar {
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(6, 17, 31, .84);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--ps-site-line);
}
.ps-site-navbar .navbar { min-height: 72px; }
.ps-site-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: #fff !important;
  text-decoration: none;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -.04em;
}
.ps-site-logo {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  background: linear-gradient(135deg, var(--ps-site-blue), var(--ps-site-green));
  box-shadow: 0 16px 34px rgba(45, 140, 255, .28);
  display: inline-block;
}
.ps-site-navbar .nav-link {
  color: rgba(246,249,255,.76) !important;
  font-weight: 800;
  border-radius: 999px;
  padding: 10px 12px !important;
}
.ps-site-navbar .nav-link:hover,
.ps-site-navbar .nav-link.active {
  color: #fff !important;
  background: rgba(255,255,255,.06);
}
.ps-site-nav-cta,
.ps-btn-primary,
.ps-buy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  font-weight: 900;
  text-decoration: none;
  border: 0;
}
.ps-site-nav-cta {
  background: #fff;
  color: #07111e !important;
  padding: 12px 18px;
}
.ps-hero,
.ps-page-main {
  background:
    radial-gradient(circle at 82% 0%, rgba(45, 140, 255, .30), transparent 34%),
    linear-gradient(180deg, #050d19, #06111f 52%, #081827);
}
.ps-hero { padding: 82px 0 56px; }
.ps-eyebrow {
  display: inline-block;
  color: var(--ps-site-cyan);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.ps-hero h1,
.ps-page-hero h1,
.ps-section h2 {
  color: #fff;
  letter-spacing: -.075em;
  font-weight: 900;
}
.ps-hero h1 {
  font-size: clamp(46px, 6vw, 72px);
  line-height: .94;
  margin: 0 0 22px;
}
.ps-hero h1 span {
  background: linear-gradient(90deg, #fff, var(--ps-site-cyan), var(--ps-site-green));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.ps-lead,
.ps-muted,
.ps-subtitle,
.ps-page-hero p,
.ps-section-heading p {
  color: #bed0e2;
  line-height: 1.65;
}
.ps-lead { font-size: 19px; max-width: 680px; }
.ps-hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.ps-btn-primary {
  padding: 15px 22px;
  background: var(--ps-site-blue);
  color: #fff !important;
  box-shadow: 0 20px 42px rgba(45, 140, 255, .26);
}
.ps-btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  padding: 15px 22px;
  color: #fff !important;
  border: 1px solid var(--ps-site-line);
  background: rgba(255,255,255,.05);
  font-weight: 900;
  text-decoration: none;
}
.ps-trust-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 24px;
}
.ps-trust-row span {
  border: 1px solid var(--ps-site-line);
  background: rgba(255,255,255,.05);
  border-radius: 999px;
  padding: 8px 11px;
  color: #d8e7f8;
  font-weight: 800;
  font-size: 13px;
}
.ps-preview-card {
  background: #fff;
  color: #07111e;
  border-radius: 28px;
  padding: clamp(22px, 3vw, 32px);
  box-shadow: 0 35px 90px rgba(0,0,0,.35);
}
.ps-approved {
  display: inline-block;
  background: #e8fff7;
  color: #087b58;
  border: 1px solid #b8f3dc;
  padding: 9px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.ps-preview-card h2 {
  color: #07885f;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.02;
  letter-spacing: -.06em;
  margin: 20px 0 10px;
  font-weight: 950;
}
.ps-preview-card p { color: #52667d; line-height: 1.55; }
.ps-kpi-preview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 20px 0;
}
.ps-kpi-preview article {
  background: #f4f8fd;
  border: 1px solid #dce7f2;
  border-radius: 16px;
  padding: 14px;
  text-align: center;
}
.ps-kpi-preview small,
.ps-report-snapshot small {
  display: block;
  color: #6f839a;
  font-size: 10px;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .08em;
}
.ps-kpi-preview strong { display: block; color: #07111e; font-size: 24px; }
.ps-preview-decision {
  border-radius: 16px;
  background: #eef7ff;
  border: 1px solid #d5e8ff;
  padding: 16px;
  color: #21344a;
}
.ps-section { padding: 76px 0; }
.ps-section-soft { background: rgba(255,255,255,.035); border-block: 1px solid var(--ps-site-line); }
.ps-section-heading { max-width: 820px; margin: 0 auto 38px; }
.ps-section h2,
.ps-page-hero h1 { font-size: clamp(38px, 4.4vw, 58px); line-height: .98; }
.ps-feature-card,
.ps-step-card,
.ps-plan,
.ps-legal-card,
.ps-pricing-note {
  background: rgba(255,255,255,.06);
  border: 1px solid var(--ps-site-line);
  border-radius: 28px;
  padding: 28px;
  height: 100%;
  color: var(--ps-site-text);
}
.ps-feature-card span,
.ps-step-card span {
  display: inline-flex;
  width: 38px;
  height: 38px;
  border-radius: 13px;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--ps-site-blue), var(--ps-site-green));
  color: #06111f;
  font-weight: 950;
  margin-bottom: 18px;
}
.ps-feature-card h3,
.ps-step-card h3,
.ps-plan h3 { color: #fff; font-weight: 900; letter-spacing: -.04em; }
.ps-feature-card p,
.ps-step-card p,
.ps-plan p { color: #b9cadc; line-height: 1.6; }
.ps-report-snapshot {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.ps-report-snapshot div {
  background: #fff;
  color: #07111e;
  border-radius: 22px;
  padding: 20px;
  box-shadow: 0 20px 54px rgba(0,0,0,.22);
}
.ps-report-snapshot div.wide { grid-column: 1 / -1; }
.ps-report-snapshot strong { display: block; color: #07111e; font-size: 22px; margin-top: 8px; }
.ps-report-snapshot p { color: #52667d; margin: 8px 0 0; }
.ps-pricing-row { margin-top: 34px; }
.ps-plan.featured {
  background: linear-gradient(180deg, rgba(45,140,255,.24), rgba(36,230,168,.08));
  border-color: rgba(56,220,255,.38);
  transform: translateY(-10px);
}
.ps-ribbon {
  display: inline-block;
  background: var(--ps-site-green);
  color: #052019;
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.ps-price {
  font-size: 48px;
  font-weight: 950;
  letter-spacing: -.07em;
  color: #fff;
  margin: 12px 0 4px;
}
.ps-plan ul { list-style: none; padding: 0; margin: 22px 0; display: grid; gap: 12px; color: #d8e4f2; }
.ps-plan li::before { content: '✓'; color: var(--ps-site-green); font-weight: 950; margin-right: 9px; }
.ps-buy { width: 100%; background: #fff; color: #07111e !important; padding: 14px 18px; }
.featured .ps-buy { background: var(--ps-site-blue); color: #fff !important; }
.ps-page-hero { padding: 78px 0 30px; }
.ps-page-hero p { font-size: 18px; max-width: 820px; }
.ps-faq .accordion-item { background: rgba(255,255,255,.06); color: #fff; border: 1px solid var(--ps-site-line); margin-bottom: 12px; border-radius: 18px; overflow: hidden; }
.ps-faq .accordion-button { background: transparent; color: #fff; font-weight: 900; box-shadow: none; }
.ps-faq .accordion-button:not(.collapsed) { background: rgba(45,140,255,.16); color: #fff; }
.ps-faq .accordion-body { color: #c4d4e6; line-height: 1.65; }
.ps-contact-strip,
.ps-pricing-note {
  margin-top: 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.ps-contact-strip a { color: #06111f; background: var(--ps-site-green); border-radius: 999px; padding: 10px 14px; font-weight: 900; text-decoration: none; }
.ps-legal-card { max-width: 920px; margin: 0 auto; }
.ps-legal-card h2,
.ps-legal-card h3 { color: #fff; font-weight: 900; letter-spacing: -.04em; }
.ps-legal-card p { color: #c2d2e5; line-height: 1.75; }
.ps-legal-card a { color: var(--ps-site-cyan); }
.ps-legal-updated { margin-top: 30px; font-size: 13px; color: var(--ps-site-muted) !important; }
.ps-site-footer {
  background: #050d19;
  border-top: 1px solid var(--ps-site-line);
  padding: 58px 0 34px;
}
.ps-site-footer h3 { font-size: 13px; text-transform: uppercase; letter-spacing: .12em; color: #fff; font-weight: 900; }
.ps-site-footer a { display: block; color: #9fb3ca; text-decoration: none; margin: 8px 0; }
.ps-site-footer a:hover { color: var(--ps-site-cyan); }
.ps-site-footer p { color: #9fb3ca; margin: 6px 0; line-height: 1.55; }
.ps-site-footer-copy { max-width: 360px; }
.ps-site-footer-bottom { border-top: 1px solid var(--ps-site-line); margin-top: 36px; padding-top: 22px; display: flex; justify-content: space-between; gap: 14px; color: #7f94ab; font-size: 12px; flex-wrap: wrap; }
.ps-cookie-box {
  position: fixed;
  left: 18px;
  bottom: 70px;
  z-index: 1000;
  width: min(390px, calc(100vw - 36px));
  padding: 18px;
  border-radius: 22px;
  background: rgba(15, 33, 54, .96);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 24px 70px rgba(0,0,0,.38);
  color: #fff;
  backdrop-filter: blur(18px);
}
.ps-cookie-box p { color: #b9cadc; line-height: 1.5; font-size: 13px; }
.ps-cookie-box div { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.ps-cookie-box a { color: var(--ps-site-cyan); font-weight: 800; }
.ps-cookie-btn {
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.08);
  color: #fff;
  border-radius: 999px;
  padding: 9px 12px;
  font-weight: 900;
}
.ps-cookie-accept { background: var(--ps-site-green); color: #052019; border-color: transparent; }
.ps-privacy-pill {
  position: fixed;
  left: 18px;
  bottom: 18px;
  z-index: 999;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(6,17,31,.92);
  color: #fff;
  border-radius: 999px;
  padding: 11px 14px;
  font-weight: 900;
  box-shadow: 0 16px 36px rgba(0,0,0,.28);
}
.auth-logo,
.sidebar-brand img,
.admin-sidebar .sidebar-brand img { max-height: 62px; object-fit: contain; }
@media (max-width: 991px) {
  .ps-plan.featured { transform: none; }
  .ps-hero { padding-top: 52px; }
  .ps-kpi-preview,
  .ps-report-snapshot { grid-template-columns: 1fr; }
  .ps-site-nav-cta { margin-top: 8px; width: 100%; }
}
@media (max-width: 575px) {
  .ps-hero h1 { font-size: 43px; }
  .ps-section { padding: 54px 0; }
  .ps-feature-card,
  .ps-step-card,
  .ps-plan,
  .ps-legal-card { padding: 22px; border-radius: 22px; }
  .ps-site-footer-bottom { display: grid; }
}

/* v31 PayScore UX/header/profile BI refinements */
.payscore-logo-img {
  display: block;
  width: min(220px, 56vw);
  height: auto;
  max-height: 54px;
  object-fit: contain;
}
.ps-site-nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.ps-site-brand {
  flex: 0 0 auto;
  padding: 0;
  margin-right: clamp(24px, 4vw, 64px);
}
.ps-site-menu {
  width: 100%;
  justify-content: flex-end;
}
.ps-login-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 15px;
  border-radius: 14px;
  border: 1px solid rgba(56, 220, 255, .34);
  color: #eaf9ff !important;
  background: rgba(56, 220, 255, .08);
  font-weight: 900;
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.ps-login-cta:hover {
  background: rgba(56, 220, 255, .14);
  color: #fff !important;
}
.ps-site-nav-cta {
  min-height: 44px;
  background: linear-gradient(135deg, var(--ps-site-blue), var(--ps-site-green));
  color: #04111f !important;
  box-shadow: 0 14px 32px rgba(36, 230, 168, .20);
}
.ps-btn-login {
  border-color: rgba(56, 220, 255, .30) !important;
  color: #f6fbff !important;
  background: rgba(56, 220, 255, .08) !important;
}
.auth-brand {
  align-items: flex-start;
}
.auth-logo,
.sidebar-brand img,
.admin-sidebar .sidebar-brand img {
  width: min(240px, 100%);
  max-height: 58px;
}
.login-cta-strong {
  background: linear-gradient(135deg, #24e6a8, #2d8cff) !important;
  color: #04111f !important;
  box-shadow: 0 20px 42px rgba(36, 230, 168, .22) !important;
}
.payscore-profile-hero {
  border-color: rgba(56, 220, 255, .22);
}
.payscore-bi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.payscore-bi-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.payscore-bi-card {
  padding: 22px;
  border-radius: 26px;
  display: grid;
  gap: 10px;
  min-height: 158px;
  align-content: start;
  overflow: hidden;
}
.payscore-bi-card span,
.payscore-bi-panel .payscore-bi-bars span {
  color: var(--text-soft);
  font-size: .74rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .10em;
}
.payscore-bi-card strong {
  display: block;
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: .95;
  letter-spacing: -.06em;
}
.payscore-bi-card p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.5;
}
.payscore-bi-card.primary {
  background: linear-gradient(135deg, rgba(36, 230, 168, .18), rgba(45, 140, 255, .08));
  border-color: rgba(36, 230, 168, .28);
}
.payscore-bi-card.alert-card {
  background: linear-gradient(135deg, rgba(247, 178, 91, .16), rgba(255,255,255,.035));
  border-color: rgba(247, 178, 91, .28);
}
.payscore-bi-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.payscore-bi-panel {
  min-width: 0;
}
.payscore-bi-bars {
  display: grid;
  gap: 14px;
}
.payscore-bi-bars div {
  display: grid;
  grid-template-columns: minmax(120px, .8fr) minmax(0, 1.2fr) 54px;
  gap: 12px;
  align-items: center;
}
.payscore-bi-bars i {
  display: block;
  height: 13px;
  min-width: 4%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--brand), var(--success));
  box-shadow: 0 0 24px rgba(39, 199, 255, .14);
}
.payscore-bi-bars strong {
  text-align: right;
  color: var(--text);
}
.payscore-bi-bars.outcome-bars i {
  background: linear-gradient(90deg, var(--success), var(--warning));
}
@media (max-width: 1180px) {
  .payscore-bi-grid,
  .payscore-bi-grid.three,
  .payscore-bi-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 991px) {
  .ps-site-brand { margin-right: 0; }
  .ps-site-menu { padding: 14px 0 4px; }
  .ps-login-cta,
  .ps-site-nav-cta { width: 100%; margin-top: 8px; }
  .payscore-logo-img { width: 190px; }
}
@media (max-width: 720px) {
  .payscore-bi-grid,
  .payscore-bi-grid.three,
  .payscore-bi-layout {
    grid-template-columns: 1fr;
  }
  .payscore-bi-bars div {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .payscore-bi-bars strong { text-align: left; }
  .auth-logo,
  .sidebar-brand img,
  .admin-sidebar .sidebar-brand img { width: 190px; max-height: 52px; }
}

/* v35 account/company dashboard and clickable branding */
.auth-logo-link,
.sidebar-brand-link {
  color: inherit;
  text-decoration: none;
}
.sidebar-brand-link:hover {
  color: inherit;
  transform: translateY(-1px);
}
.sidebar-brand-link {
  transition: transform .18s ease, opacity .18s ease;
}
.company-account-dashboard {
  display: grid;
  gap: 22px;
}
.company-account-layout {
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(0, 1.4fr);
  gap: 16px;
  align-items: stretch;
}
.company-invoice-card,
.company-meta-strip {
  padding: 20px;
}
.section-heading.compact {
  margin-bottom: 12px;
}
.section-heading.compact h3 {
  margin: 4px 0 0;
  font-size: 1.25rem;
}
.company-data-list {
  display: grid;
  gap: 10px;
}
.company-data-list div {
  display: grid;
  gap: 4px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.company-data-list div:last-child {
  border-bottom: 0;
}
.company-data-list span,
.company-meta-strip span {
  color: var(--text-soft);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .10em;
  text-transform: uppercase;
}
.company-data-list strong {
  font-size: .98rem;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.company-kpi-wrap {
  display: grid;
  gap: 16px;
}
.company-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.company-kpi-grid .power-card strong {
  font-size: clamp(1.55rem, 3vw, 2.45rem);
}
.company-meta-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.company-meta-strip div {
  min-width: 0;
}
.company-meta-strip strong {
  display: block;
  margin: 6px 0 4px;
  font-size: 1.05rem;
  overflow-wrap: anywhere;
}
.company-meta-strip p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.5;
}
@media (max-width: 1100px) {
  .company-account-layout,
  .company-kpi-grid,
  .company-meta-strip { grid-template-columns: 1fr; }
}

/* Billing and Stripe checkout */
.billing-hero .hero-side article strong {
    font-size: 1.9rem;
}

.billing-layout {
    align-items: start;
}

.billing-profile-card .form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.credit-package-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.credit-package-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.25rem;
    min-height: 100%;
    overflow: hidden;
    border: 1px solid rgba(148, 163, 184, .22);
    background:
        radial-gradient(circle at top right, rgba(20, 184, 166, .13), transparent 32%),
        linear-gradient(145deg, rgba(255,255,255,.96), rgba(248,250,252,.92));
}

.credit-package-card.featured {
    border-color: rgba(20, 184, 166, .45);
    box-shadow: 0 22px 55px rgba(15, 23, 42, .13);
    transform: translateY(-4px);
}

.package-topline,
.package-price-row,
.package-credit-pill {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .8rem;
}

.package-badge,
.package-secure {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: .35rem .65rem;
    font-size: .72rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.package-badge {
    background: rgba(20, 184, 166, .12);
    color: #0f766e;
}

.package-secure {
    background: rgba(15, 23, 42, .06);
    color: var(--muted);
}

.package-header h3 {
    margin: 0 0 .35rem;
    font-size: 1.45rem;
    letter-spacing: -.03em;
}

.package-header p,
.package-price-row span,
.package-credit-pill span {
    color: var(--muted);
    margin: 0;
    line-height: 1.45;
}

.package-price-row {
    padding: 1rem 0 .65rem;
    border-top: 1px solid rgba(148, 163, 184, .18);
}

.package-price-row strong {
    font-size: 2rem;
    letter-spacing: -.05em;
}

.package-credit-pill {
    padding: .85rem 1rem;
    border-radius: 18px;
    background: #0f172a;
    color: white;
}

.package-credit-pill strong {
    font-size: 1.55rem;
}

.package-credit-pill span {
    color: rgba(255,255,255,.72);
    font-weight: 700;
    text-align: right;
}

.package-feature-list {
    display: grid;
    gap: .55rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.package-feature-list li {
    position: relative;
    padding-left: 1.45rem;
    color: #334155;
    font-weight: 700;
    line-height: 1.35;
}

.package-feature-list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    color: #0f766e;
    font-weight: 900;
}

.package-action-form {
    margin-top: auto;
}

button[disabled], .primary-cta[disabled] {
    cursor: not-allowed;
    opacity: .55;
    filter: grayscale(.25);
}

.free-note.success {
    border-color: rgba(34, 197, 94, .35);
    background: rgba(34, 197, 94, .09);
}

@media (max-width: 900px) {
    .billing-profile-card .form-grid,
    .credit-package-grid {
        grid-template-columns: 1fr;
    }
}

/* v39 billing: pacchetti non schiacciati, stile pricing del sito */
.billing-layout {
    grid-template-columns: minmax(0, 1fr);
}

.credit-package-grid.pricing-style {
    grid-template-columns: repeat(3, minmax(240px, 1fr));
    align-items: stretch;
}

.credit-package-card {
    min-height: 0;
    border-radius: 28px;
    padding: 1.35rem;
    gap: .9rem;
    box-shadow: 0 18px 42px rgba(15, 23, 42, .08);
}

.credit-package-card.featured {
    transform: none;
    border-color: rgba(20, 184, 166, .55);
    box-shadow: 0 22px 58px rgba(15, 23, 42, .13);
}

.package-header h3 {
    font-size: 1.6rem;
}

.package-header p {
    min-height: 0;
}

.package-metrics-row {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: .75rem;
}

.package-credit-block,
.package-price-block {
    border-radius: 20px;
    padding: .95rem;
    border: 1px solid rgba(148, 163, 184, .18);
    background: rgba(255, 255, 255, .72);
}

.package-credit-block {
    background: #0f172a;
    color: #fff;
}

.package-credit-block strong,
.package-price-block strong {
    display: block;
    font-size: 1.75rem;
    line-height: 1;
    letter-spacing: -.05em;
}

.package-credit-block span,
.package-price-block span {
    display: block;
    margin-top: .4rem;
    font-size: .82rem;
    font-weight: 800;
    color: var(--muted);
}

.package-credit-block span {
    color: rgba(255, 255, 255, .76);
}

.package-feature-list.compact {
    gap: .45rem;
    padding-top: .1rem;
}

.package-feature-list.compact li {
    font-size: .9rem;
    font-weight: 750;
}

.package-action-form {
    margin-top: .25rem;
}

@media (max-width: 1100px) {
    .credit-package-grid.pricing-style {
        grid-template-columns: repeat(2, minmax(240px, 1fr));
    }
}

@media (max-width: 760px) {
    .credit-package-grid.pricing-style,
    .package-metrics-row {
        grid-template-columns: 1fr;
    }
}

/* v40 billing: profilo fiscale + pricing identico al sito */
.billing-rule-card {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border-radius: 20px;
    border: 1px solid rgba(45, 140, 255, .18);
    background: linear-gradient(135deg, rgba(45,140,255,.10), rgba(36,230,168,.10));
    color: #0f172a;
}
.billing-rule-card strong { font-size: .92rem; font-weight: 950; }
.billing-rule-card span { color: var(--muted); font-weight: 750; line-height: 1.45; }
.billing-form label small {
    display: block;
    margin-top: .35rem;
    color: var(--muted);
    font-size: .78rem;
    font-weight: 650;
    line-height: 1.35;
}
.billing-checkbox {
    display: flex !important;
    align-items: flex-start;
    gap: .7rem;
    padding: .95rem 1rem;
    border: 1px solid rgba(148, 163, 184, .22);
    border-radius: 18px;
    background: rgba(248, 250, 252, .92);
    color: #0f172a;
    font-weight: 800;
}
.billing-checkbox input { width: auto !important; margin-top: .2rem; }
.app-pricing-row { margin-top: 1.25rem; }
.app-pricing-row .ps-plan {
    background: #07111e;
    border-color: rgba(56, 220, 255, .16);
    box-shadow: 0 24px 70px rgba(15, 23, 42, .20);
}
.app-pricing-row .ps-plan.featured {
    background: linear-gradient(180deg, rgba(45,140,255,.28), rgba(36,230,168,.10)), #07111e;
    border-color: rgba(56, 220, 255, .42);
    transform: none;
}
.app-plan-foot {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: .75rem;
    margin: .25rem 0 1rem;
    padding: .85rem 1rem;
    border-radius: 18px;
    background: rgba(255,255,255,.08);
    color: #fff;
}
.app-plan-foot strong { font-size: 1.6rem; font-weight: 950; letter-spacing: -.05em; }
.app-plan-foot span { color: #b9cadc; font-size: .85rem; font-weight: 800; }
.app-buy {
    border: 0;
    text-align: center;
    font-weight: 950;
}
.app-buy:disabled {
    opacity: .45;
    cursor: not-allowed;
}

/* v41: maggiore leggibilità profilo fatturazione e piani app allineati al sito */
.billing-checkbox span {
    color: #0f172a !important;
    font-weight: 900;
    line-height: 1.45;
}
.billing-checkbox input {
    accent-color: #24e6a8;
    flex: 0 0 auto;
}
.app-pricing-row .ps-plan {
    display: flex;
    flex-direction: column;
}
.app-pricing-row .ps-plan ul {
    flex: 1 1 auto;
}

/* v42 admin dashboard, orders and invoicing */
.admin-bi-grid-wide {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.admin-chart-card {
    overflow: hidden;
}
.admin-horizontal-chart {
    display: grid;
    gap: 14px;
}
.admin-chart-row {
    display: grid;
    grid-template-columns: 110px 1fr 120px;
    gap: 12px;
    align-items: center;
    color: #d7f7ef;
    font-size: 0.9rem;
}
.admin-chart-row > div {
    height: 12px;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
    overflow: hidden;
}
.admin-chart-row i,
.admin-month-bar i {
    display: block;
    border-radius: 999px;
    background: linear-gradient(135deg, #2ff0a2, #36d7ff);
    box-shadow: 0 0 18px rgba(47,240,162,0.25);
}
.admin-chart-row i {
    height: 100%;
}
.admin-chart-row strong {
    color: #ffffff;
    text-align: right;
}
.admin-month-bars {
    display: grid;
    grid-template-columns: repeat(6, minmax(48px, 1fr));
    gap: 12px;
    min-height: 220px;
    align-items: end;
}
.admin-month-bar {
    display: grid;
    gap: 8px;
    text-align: center;
    color: #cde7e0;
    font-size: 0.78rem;
}
.admin-month-bar > div {
    height: 150px;
    padding: 6px;
    border-radius: 18px;
    background: rgba(255,255,255,0.07);
    display: flex;
    align-items: end;
    justify-content: center;
}
.admin-month-bar i {
    width: 100%;
    min-height: 8px;
}
.admin-month-bar strong {
    color: #ffffff;
}
.status-chip {
    display: inline-flex;
    align-items: center;
    border: 1px solid rgba(47,240,162,0.32);
    color: #bbffe9;
    background: rgba(47,240,162,0.10);
    padding: 8px 12px;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 800;
}
.alert-box.warning {
    border-color: rgba(255,214,102,0.45);
    background: rgba(255,214,102,0.12);
    color: #fff0b3;
}
.danger-text {
    color: #ffb4b4;
    font-weight: 700;
}
.primary-cta.small {
    padding: 8px 12px;
    font-size: 0.82rem;
    min-height: auto;
}
@media (max-width: 1100px) {
    .admin-bi-grid-wide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .admin-chart-row { grid-template-columns: 90px 1fr; }
    .admin-chart-row strong { grid-column: 2; text-align: left; }
}
@media (max-width: 760px) {
    .admin-bi-grid-wide { grid-template-columns: 1fr; }
    .admin-month-bars { grid-template-columns: repeat(3, minmax(48px, 1fr)); }
}


/* PayScore hardening UX/accessibility additions */
:where(a, button, input, select, textarea, [tabindex]):focus-visible {
    outline: 3px solid var(--brand);
    outline-offset: 3px;
    box-shadow: 0 0 0 6px rgba(39, 199, 255, 0.18);
}

.admin-filter-bar {
    display: grid;
    grid-template-columns: repeat(4, minmax(150px, 1fr));
    gap: 12px;
    align-items: end;
    margin: 16px 0 18px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.035);
}

.admin-filter-bar label {
    display: grid;
    gap: 6px;
    margin: 0;
}

.admin-filter-bar label span {
    color: var(--text-soft);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.admin-filter-bar input,
.admin-filter-bar select {
    min-height: 42px;
}

.ps-cookie-box {
    max-height: min(80vh, 620px);
    overflow: auto;
}

.ps-cookie-preferences {
    display: grid !important;
    gap: 10px !important;
    margin: 14px 0;
}

.ps-cookie-toggle {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 10px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    background: rgba(255,255,255,.055);
    cursor: pointer;
}

.ps-cookie-toggle input {
    margin-top: 4px;
    inline-size: 18px;
    block-size: 18px;
    accent-color: var(--ps-site-green, var(--success));
}

.ps-cookie-toggle span {
    display: grid;
    gap: 3px;
}

.ps-cookie-toggle strong {
    color: #fff;
    font-size: 13px;
}

.ps-cookie-toggle small {
    color: #b9cadc;
    line-height: 1.4;
}

.ps-cookie-actions {
    display: flex !important;
    gap: 8px !important;
    align-items: center !important;
    flex-wrap: wrap !important;
}

.payment-funnel-card {
    border: 1px solid rgba(39, 199, 255, 0.22);
    background: linear-gradient(135deg, rgba(39, 199, 255, 0.09), rgba(138, 92, 246, 0.06));
}

.payment-funnel-steps {
    display: grid;
    gap: 10px;
    margin: 16px 0 0;
}

.payment-funnel-step {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: start;
    padding: 12px;
    border-radius: 16px;
    background: rgba(255,255,255,.045);
    border: 1px solid rgba(255,255,255,.09);
}

.payment-funnel-step b {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: rgba(39,199,255,.16);
    color: var(--brand);
}

.danger-text {
    color: var(--danger);
}

@media (max-width: 900px) {
    .admin-filter-bar {
        grid-template-columns: 1fr;
    }
}

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

/* Patch: admin a sezioni e billing a due colonne */
[data-admin-page][hidden] {
    display: none !important;
}

.admin-sidebar .sidebar-nav a.active,
.admin-sidebar .sidebar-nav a[aria-current="page"] {
    color: #fff;
    background: rgba(39, 199, 255, 0.14);
    border-color: rgba(39, 199, 255, 0.32);
}

.admin-log-pre {
    white-space: pre-wrap;
    overflow: auto;
    max-height: 360px;
    padding: .85rem;
    border-radius: 14px;
    background: rgba(2, 8, 23, .72);
    border: 1px solid rgba(148, 163, 184, .2);
    color: #dbeafe;
    font-size: 12px;
    line-height: 1.5;
}

.billing-layout {
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr) !important;
    align-items: start;
}

.billing-layout > .stack-lg {
    display: flex;
    flex-direction: column;
}

.billing-layout > .stack-lg > .payment-funnel-card {
    order: 2;
}

.billing-layout > .stack-lg > section:not(.payment-funnel-card) {
    order: 1;
}

.billing-layout .app-pricing-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin: 0;
}

.billing-layout .app-pricing-row > [class*="col-"] {
    width: 100%;
    max-width: 100%;
    padding: 0;
    flex: none;
}

@media (max-width: 1100px) {
    .billing-layout {
        grid-template-columns: 1fr !important;
    }
}

/* Admin 2.0 PayScore */
.admin2-body {
  background:
    radial-gradient(circle at 18% 0%, rgba(39, 199, 255, .18), transparent 32rem),
    radial-gradient(circle at 90% 18%, rgba(138, 92, 246, .20), transparent 30rem),
    linear-gradient(135deg, #020817 0%, #061326 48%, #03101d 100%);
}
.admin2-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 292px minmax(0, 1fr);
  gap: 22px;
  padding: 18px;
}
.admin2-sidebar {
  position: sticky;
  top: 18px;
  height: calc(100vh - 36px);
  overflow: auto;
  border: 1px solid rgba(125, 211, 252, .20);
  background: linear-gradient(180deg, rgba(6, 22, 43, .94), rgba(3, 12, 24, .92));
  box-shadow: 0 30px 90px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255,255,255,.05);
}
.admin2-sidebar .sidebar-brand {
  align-items: flex-start;
  gap: 10px;
  border-bottom: 1px solid rgba(148, 163, 184, .14);
  padding-bottom: 18px;
}
.admin2-sidebar .sidebar-brand img { max-width: 154px; }
.admin2-sidebar .sidebar-brand p { margin: 8px 0 0; font-weight: 900; letter-spacing: .02em; }
.admin2-sidebar .sidebar-brand small { color: var(--brand); font-weight: 800; text-transform: uppercase; letter-spacing: .16em; }
.admin2-nav { gap: 7px; }
.admin2-nav a {
  border-radius: 16px;
  padding: 12px 14px;
  color: #dbeafe;
  border: 1px solid transparent;
  background: rgba(255,255,255,.02);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.admin2-nav a:hover,
.admin2-nav a.active {
  transform: translateX(3px);
  border-color: rgba(39, 199, 255, .34);
  background: linear-gradient(135deg, rgba(39, 199, 255, .16), rgba(138, 92, 246, .10));
  color: #fff;
}
.admin2-main {
  min-width: 0;
  display: grid;
  gap: 22px;
  align-content: start;
}
.admin2-hero {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  padding: clamp(24px, 4vw, 38px);
  border: 1px solid rgba(39, 199, 255, .24);
  background:
    linear-gradient(135deg, rgba(39, 199, 255, .18), rgba(138, 92, 246, .12)),
    rgba(7, 23, 44, .90);
  box-shadow: 0 28px 90px rgba(8, 15, 31, .48);
  overflow: hidden;
  position: relative;
}
.admin2-hero::after {
  content: "";
  position: absolute;
  inset: auto -70px -90px auto;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(39,199,255,.22), transparent 65%);
  pointer-events: none;
}
.admin2-hero h1 { margin: 6px 0 8px; font-size: clamp(2rem, 4vw, 4rem); line-height: .98; letter-spacing: -.06em; }
.admin2-hero p { max-width: 720px; color: var(--text-soft); font-size: 1.05rem; }
.admin2-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.admin2-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.admin2-kpi-grid.compact { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.admin2-kpi-card {
  border-radius: 24px;
  padding: 20px;
  border: 1px solid rgba(148, 163, 184, .18);
  background:
    linear-gradient(160deg, rgba(255,255,255,.07), rgba(255,255,255,.02)),
    rgba(6, 22, 43, .82);
  box-shadow: 0 20px 60px rgba(0,0,0,.28);
  position: relative;
  overflow: hidden;
  min-height: 142px;
}
.admin2-kpi-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 88% 10%, rgba(39,199,255,.18), transparent 36%);
  opacity: .8;
}
.admin2-kpi-card > * { position: relative; z-index: 1; }
.admin2-kpi-card span { display: block; color: #9fb5d4; font-size: .78rem; text-transform: uppercase; letter-spacing: .13em; font-weight: 900; }
.admin2-kpi-card strong { display: block; color: #fff; font-size: clamp(1.75rem, 4vw, 2.7rem); line-height: 1; margin: 14px 0 8px; letter-spacing: -.04em; }
.admin2-kpi-card p { margin: 0; color: var(--text-soft); }
.admin2-kpi-card i { position: absolute; left: 20px; right: 20px; bottom: 0; height: 4px; border-radius: 999px; background: linear-gradient(90deg, var(--brand), rgba(138,92,246,.9)); }
.admin2-kpi-card.tone-success i { background: linear-gradient(90deg, #24e6a8, var(--brand)); }
.admin2-kpi-card.tone-warning i { background: linear-gradient(90deg, #ffd166, #ff9f1c); }
.admin2-kpi-card.tone-danger i { background: linear-gradient(90deg, #ff5c7a, #ff2e63); }
.admin2-grid-2 { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr); gap: 18px; }
.admin2-chart-card { min-height: 340px; }
.admin2-column-chart { display: flex; align-items: end; gap: 14px; min-height: 220px; padding-top: 20px; }
.admin2-col { flex: 1; min-width: 44px; text-align: center; display: grid; gap: 8px; color: var(--text-soft); }
.admin2-col > div { height: 170px; border-radius: 18px; background: rgba(255,255,255,.05); display: flex; align-items: end; overflow: hidden; border: 1px solid rgba(148, 163, 184, .13); }
.admin2-col i { display: block; width: 100%; border-radius: 18px 18px 0 0; background: linear-gradient(180deg, var(--brand), rgba(138,92,246,.8)); box-shadow: 0 0 28px rgba(39,199,255,.25); }
.admin2-col span { font-size: .76rem; }
.admin2-col strong { color: #fff; font-size: .86rem; }
.admin2-plan-bars .admin-chart-row { grid-template-columns: 135px 1fr 110px; }
.admin2-smart-list, .admin2-mini-list, .admin2-alert-stack { display: grid; gap: 10px; }
.admin2-smart-item, .admin2-alert-stack a, .admin2-mini-list > a, .admin2-mini-list > div {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 13px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, .13);
  background: rgba(255,255,255,.035);
  color: var(--text);
  text-decoration: none;
}
.admin2-mini-list > div { grid-template-columns: 1fr auto; }
.admin2-mini-list small { grid-column: 1 / -1; color: var(--muted); }
.admin2-avatar {
  width: 44px; height: 44px; border-radius: 16px;
  display: inline-grid; place-items: center;
  background: linear-gradient(135deg, rgba(39,199,255,.26), rgba(138,92,246,.22));
  border: 1px solid rgba(39,199,255,.26);
  color: #fff; font-weight: 950; letter-spacing: -.04em;
}
.admin2-smart-item strong, .admin2-user-cell strong { display: block; color: #fff; }
.admin2-smart-item small, .admin2-user-cell small { display: block; color: var(--muted); }
.admin2-smart-item em { font-style: normal; color: var(--brand); font-weight: 900; }
.admin2-user-cell { display: flex; align-items: center; gap: 12px; }
.admin-status-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 28px; padding: 6px 10px; border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(148, 163, 184, .11);
  color: #dbeafe; font-size: .78rem; font-weight: 900;
}
.admin-status-badge.tone-success { color: #b7ffdf; background: rgba(36,230,168,.12); border-color: rgba(36,230,168,.28); }
.admin-status-badge.tone-warning { color: #ffe6a6; background: rgba(255,209,102,.12); border-color: rgba(255,209,102,.28); }
.admin-status-badge.tone-danger { color: #ffc2cf; background: rgba(255,92,122,.12); border-color: rgba(255,92,122,.28); }
.admin2-filter-bar { align-items: end; background: rgba(255,255,255,.03); border: 1px solid rgba(148,163,184,.14); border-radius: 22px; padding: 14px; }
.admin2-table tbody tr { transition: background .18s ease, transform .18s ease; }
.admin2-table tbody tr:hover { background: rgba(39,199,255,.055); }
.admin2-user-detail { border-color: rgba(39,199,255,.25); }
.admin2-inner-card { padding: 18px; border-radius: 22px; }
.admin2-inner-card h3 { margin-top: 0; }
.admin2-action-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)) auto; gap: 10px; align-items: end; }
.admin2-form-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.mt-2 { margin-top: 1rem; }
.admin-log-pre { max-height: 420px; overflow: auto; border-radius: 18px; padding: 16px; background: #020817; color: #dbeafe; border: 1px solid rgba(148,163,184,.18); white-space: pre-wrap; }
@media (max-width: 1180px) {
  .admin2-shell { grid-template-columns: 1fr; }
  .admin2-sidebar { position: relative; height: auto; }
  .admin2-nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin2-kpi-grid, .admin2-kpi-grid.compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin2-grid-2 { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .admin2-shell { padding: 10px; }
  .admin2-hero { display: grid; }
  .admin2-kpi-grid, .admin2-kpi-grid.compact, .admin2-form-grid { grid-template-columns: 1fr; }
  .admin2-action-grid { grid-template-columns: 1fr; }
  .admin2-col { min-width: 34px; }
}

/* Follow-up patch: billing layout, enterprise request and visible support contacts */
.billing-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr) !important;
  gap: 22px !important;
  align-items: start !important;
}
.billing-layout > .stack-lg {
  min-width: 0;
}
.billing-checkbox.billing-checkbox-top {
  align-items: center !important;
  margin: .25rem 0 .65rem;
}
.billing-checkbox.billing-checkbox-top input {
  margin-top: 0 !important;
}
.billing-checkbox.billing-checkbox-top span {
  display: block;
  line-height: 1.35;
}
@media (max-width: 860px) {
  .billing-layout {
    grid-template-columns: 1fr !important;
  }
}
.app-support-card {
  display: grid;
  gap: .72rem;
  padding: 1.05rem;
  border-color: rgba(39, 199, 255, .22) !important;
  background: linear-gradient(155deg, rgba(39,199,255,.14), rgba(36,230,168,.08)) !important;
  box-shadow: 0 18px 42px rgba(2, 12, 26, .28);
}
.app-support-card span {
  color: rgba(230, 247, 255, .82);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.app-support-title {
  display: block;
  color: #fff;
  font-size: 1.02rem;
  font-weight: 950;
  letter-spacing: -.02em;
}
.app-support-card p {
  margin: 0;
  color: rgba(230, 247, 255, .8);
  line-height: 1.55;
  font-size: .88rem;
}
.app-support-card a,
.app-contact-strip a,
.ps-footer-hotline-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  border-radius: 999px;
  padding: .7rem 1rem;
  text-decoration: none;
  font-size: .9rem;
  font-weight: 950;
  color: #06111f;
  background: linear-gradient(135deg, #24e6a8, #39c7ff);
  border: 1px solid rgba(255, 255, 255, .16);
  box-shadow: 0 14px 30px rgba(36, 230, 168, .18);
}
.app-support-card a:hover,
.app-contact-strip a:hover,
.ps-footer-hotline-link:hover {
  color: #06111f;
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(57, 199, 255, .22);
}
.app-support-call {
  width: 100%;
}
.enterprise-request-layout {
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
}
.enterprise-benefits-card .process-list article {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.10);
}
.app-contact-strip {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
}
.ps-footer-hotline-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.15rem 1.25rem;
  margin-top: .35rem;
  border-radius: 22px;
  border: 1px solid rgba(57, 199, 255, .18);
  background: linear-gradient(145deg, rgba(18, 38, 64, .96), rgba(6, 17, 31, .98));
  box-shadow: 0 20px 44px rgba(0, 0, 0, .22);
}
.ps-footer-hotline-copy {
  display: grid;
  gap: .3rem;
}
.ps-footer-hotline-eyebrow {
  color: #91a9c3;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.ps-footer-hotline-card strong {
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: -.03em;
}
.ps-footer-hotline-card p {
  margin: 0;
  max-width: 700px;
  color: #9fb3ca;
}
@media (max-width: 860px) {
  .ps-footer-hotline-card {
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (max-width: 900px) {
  .enterprise-request-layout {
    grid-template-columns: 1fr;
  }
}

/* Accessibility/readability fixes: keep dark text inside light preview/report cards and override footer link specificity. */
.ps-preview-card,
.ps-preview-card strong,
.ps-preview-decision,
.ps-preview-decision strong,
.ps-kpi-preview strong,
.ps-report-snapshot,
.ps-report-snapshot strong {
  color: #07111e;
}

.ps-preview-card p,
.ps-report-snapshot p,
.ps-preview-decision p {
  color: #31465d;
}

.ps-preview-decision {
  background: #ffffff;
  border-color: #b7d3ef;
}

.ps-site-footer a {
  color: #c2d2e5;
}

.ps-site-footer p {
  color: #c2d2e5;
}

.ps-site-footer-bottom {
  color: #aebfd2;
}

.ps-site-footer .ps-footer-hotline-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #06111f !important;
  background: linear-gradient(135deg, #24e6a8, #39c7ff);
  border: 1px solid rgba(255, 255, 255, .16);
  box-shadow: 0 14px 30px rgba(36, 230, 168, .18);
  text-decoration: none;
  font-weight: 950;
}

.ps-site-footer .ps-footer-hotline-link:hover,
.ps-site-footer .ps-footer-hotline-link:focus-visible {
  color: #06111f !important;
}

.ps-site-footer a:focus-visible,
.ps-btn-primary:focus-visible,
.ps-btn-ghost:focus-visible,
.ps-site-nav-cta:focus-visible,
.ps-login-cta:focus-visible,
.primary-cta:focus-visible,
.ghost-button:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid #38dcff;
  outline-offset: 3px;
}

/* PayScore v46: binary signal readability, accessibility and responsive containment */
.payscore-signal-grid article.signal-positive {
  border-color: rgba(32, 201, 151, .38);
  background: linear-gradient(180deg, rgba(32, 201, 151, .10), rgba(255,255,255,.035));
}
.payscore-signal-grid article.signal-negative {
  border-color: rgba(255, 77, 79, .42);
  background: linear-gradient(180deg, rgba(255, 77, 79, .11), rgba(255,255,255,.035));
}
.payscore-signal-grid article.signal-alert {
  border-color: rgba(255, 77, 79, .42);
  background: linear-gradient(180deg, rgba(255, 77, 79, .11), rgba(255,255,255,.035));
}
.payscore-signal-grid ul {
  list-style: none;
  padding-left: 0;
}
.payscore-signal-grid li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  margin: 10px 0;
  color: rgba(255,255,255,.86);
}
.signal-semaphore {
  display: inline-grid;
  place-items: center;
  width: 1.65rem;
  height: 1.65rem;
  line-height: 1;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.16);
  flex: 0 0 auto;
}
.signal-positive .eyebrow { color: #7ee2c2; }
.signal-negative .eyebrow { color: #ff9aaa; }
.signal-alert .eyebrow { color: #ff9aaa; }
@media (prefers-contrast: more) {
  .payscore-signal-grid li { color: #fff; }
  .signal-semaphore { background: #fff; }
}


/* PayScore v46: responsive report fixes, Apple-style horizontal scrolling, no vertical word stacking. */
.payscore-report,
.payscore-report * {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}
.payscore-report p,
.payscore-report li,
.payscore-report small,
.payscore-report em,
.payscore-report strong,
.payscore-report span,
.payscore-report td,
.payscore-report th {
  overflow-wrap: break-word;
  word-break: normal;
}
.payscore-history-table-wrap,
.table-wrap,
.results-table-wrap,
.payscore-scroll-x {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.32) rgba(255,255,255,.08);
}
.payscore-history-table-wrap::-webkit-scrollbar,
.table-wrap::-webkit-scrollbar,
.results-table-wrap::-webkit-scrollbar,
.payscore-scroll-x::-webkit-scrollbar {
  height: 8px;
}
.payscore-history-table-wrap::-webkit-scrollbar-track,
.table-wrap::-webkit-scrollbar-track,
.results-table-wrap::-webkit-scrollbar-track,
.payscore-scroll-x::-webkit-scrollbar-track {
  background: rgba(255,255,255,.06);
  border-radius: 999px;
}
.payscore-history-table-wrap::-webkit-scrollbar-thumb,
.table-wrap::-webkit-scrollbar-thumb,
.results-table-wrap::-webkit-scrollbar-thumb,
.payscore-scroll-x::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.28);
  border-radius: 999px;
  border: 2px solid rgba(6,17,31,.82);
}
.payscore-history-table th,
.payscore-history-table td,
.results-table th,
.results-table td {
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
}
.payscore-history-table td:first-child,
.payscore-linked-table td:first-child {
  white-space: normal;
  min-width: 220px;
}
.payscore-signal-grid-top {
  margin: 0;
}
.payscore-signal-grid-top article {
  min-width: 0;
}
.payscore-signal-grid li span:last-child {
  min-width: 0;
  line-height: 1.55;
}
@media (max-width: 760px) {
  .payscore-report {
    overflow-x: hidden;
  }
  .payscore-abovefold,
  .payscore-section-grid,
  .payscore-section-grid.refined,
  .payscore-stress-grid,
  .payscore-dossier-grid,
  .payscore-wow-kpis,
  .payscore-signal-grid {
    min-width: 0;
  }
  .payscore-abovefold-kpis,
  .payscore-wow-kpis,
  .payscore-dossier-grid,
  .payscore-signal-grid,
  .payscore-section-grid.refined,
  .payscore-stress-grid.refined {
    grid-template-columns: 1fr;
  }
  .payscore-condition-list,
  .payscore-meta.clean,
  .app-contact-strip {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .payscore-condition-list span,
  .payscore-meta.clean span,
  .app-contact-strip a {
    flex: 0 0 auto;
    white-space: nowrap;
  }
  .payscore-abovefold-head h1,
  .payscore-verdict-card strong,
  .payscore-snapshot-card strong,
  .payscore-abovefold-kpis strong,
  .payscore-wow-kpis strong,
  .payscore-next-action strong {
    overflow-wrap: break-word;
    word-break: normal;
  }
}


/* PayScore v47 - archivio affiancato e filtri accessibili */
.payscore-report-filter {
  display: grid;
  grid-template-columns: minmax(150px, .7fr) minmax(150px, .7fr) minmax(260px, 1.5fr) auto;
  gap: 12px;
  align-items: end;
  margin: 18px 0 20px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  background: rgba(255,255,255,.045);
}
.payscore-report-filter label { display: grid; gap: 6px; min-width: 0; }
.payscore-report-filter label span { font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.72); }
.payscore-report-filter input {
  width: 100%;
  min-height: 42px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.08);
  color: #fff;
  padding: 10px 12px;
}
.payscore-report-filter input::placeholder { color: rgba(255,255,255,.56); }
.payscore-report-filter input:focus-visible,
.payscore-reports-scroll:focus-visible {
  outline: 3px solid rgba(32,201,151,.65);
  outline-offset: 3px;
}
.payscore-report-filter-actions { display: flex; gap: 8px; align-items: center; white-space: nowrap; }
.payscore-reports-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.32) rgba(255,255,255,.08);
  padding-bottom: 8px;
}
.payscore-reports-scroll::-webkit-scrollbar { height: 8px; }
.payscore-reports-scroll::-webkit-scrollbar-track { background: rgba(255,255,255,.06); border-radius: 999px; }
.payscore-reports-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,.28); border-radius: 999px; border: 2px solid rgba(6,17,31,.82); }
.payscore-report-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
  gap: 14px;
  min-width: 0;
}
.payscore-report-card {
  display: grid;
  gap: 12px;
  min-width: 0;
  min-height: 190px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.055);
  color: inherit;
  text-decoration: none;
  align-content: start;
}
.payscore-report-card.approved,
.payscore-report-card.conditional { background: linear-gradient(135deg, rgba(32,201,151,.22), rgba(255,255,255,.045)); border-color: rgba(32,201,151,.35); }
.payscore-report-card.rejected { background: linear-gradient(135deg, rgba(255,77,79,.22), rgba(255,255,255,.045)); border-color: rgba(255,77,79,.42); }
.payscore-report-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.payscore-report-card-top strong { font-size: 1rem; line-height: 1.25; overflow-wrap: break-word; word-break: normal; }
.payscore-report-card-top em {
  flex: 0 0 auto;
  max-width: 46%;
  border-radius: 999px;
  padding: 5px 8px;
  background: rgba(255,255,255,.10);
  font-style: normal;
  font-size: .68rem;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: .06em;
  text-align: right;
}
.payscore-report-card-meta { font-size: .86rem; color: rgba(255,255,255,.74); white-space: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.payscore-report-card-data { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.payscore-report-card-data span { display: grid; gap: 3px; padding: 9px; border-radius: 14px; background: rgba(255,255,255,.08); font-size: .82rem; min-width: 0; }
.payscore-report-card-data b { display: block; font-size: .68rem; text-transform: uppercase; letter-spacing: .07em; color: rgba(255,255,255,.62); }
.payscore-report-card small { color: rgba(255,255,255,.68); }
@media (max-width: 980px) {
  .payscore-report-filter { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .payscore-report-filter-search, .payscore-report-filter-actions { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .payscore-report-filter { grid-template-columns: 1fr; }
  .payscore-report-filter-search, .payscore-report-filter-actions { grid-column: auto; }
  .payscore-report-filter-actions { justify-content: stretch; }
  .payscore-report-filter-actions .primary-cta,
  .payscore-report-filter-actions .ghost-button { flex: 1 1 0; justify-content: center; }
  .payscore-reports-scroll { margin-left: -18px; margin-right: -18px; padding-left: 18px; padding-right: 18px; scroll-snap-type: x proximity; }
  .payscore-report-card-grid { display: flex; gap: 12px; min-width: max-content; }
  .payscore-report-card { width: min(84vw, 330px); flex: 0 0 min(84vw, 330px); scroll-snap-align: start; }
  .payscore-report-card-data { grid-template-columns: 1fr; }
}

/* v50 - ultimo bilancio depositato da aziendeDati */
.financial-statement-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
  min-width: 0;
}
.financial-statement-card {
  min-width: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.financial-statement-card.wide { grid-column: 1 / -1; }
.financial-statement-card h3 {
  margin: 0 0 12px;
  color: var(--text, #f8fbff);
}
.financial-statement-card .company-data-list,
.payscore-dossier-grid article.wide {
  min-width: 0;
}
.payscore-dossier-grid article.wide { grid-column: 1 / -1; }
.payscore-history-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
@media (max-width: 900px) {
  .financial-statement-grid { grid-template-columns: 1fr; }
  .financial-statement-card.wide { grid-column: auto; }
}
@media print {
  .financial-statement-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); break-inside: avoid; }
  .financial-statement-card { overflow: visible; break-inside: avoid; }
}

.payscore-abovefold-kpis article.payscore-money-card {
    background: linear-gradient(180deg, rgba(39,199,255,.10), rgba(255,255,255,.055));
    border-color: rgba(39,199,255,.24);
}
.payscore-abovefold-kpis article.payscore-money-card em {
    display: inline-flex;
    margin-top: 10px;
    padding: 6px 9px;
    border-radius: 999px;
    background: rgba(255,255,255,.09);
    color: rgba(255,255,255,.76);
    font-size: .76rem;
    font-style: normal;
    font-weight: 750;
    line-height: 1.2;
}


/* v57 - PayScore archivio wide, semaforo arancione e countdown report */
.app-shell.app-shell-wide {
  grid-template-columns: minmax(0, 1fr);
}
.app-shell.app-shell-wide .sidebar {
  display: none;
}
.app-shell.app-shell-wide .app-main {
  width: 100%;
  max-width: none;
}
.payscore-reports-panel {
  width: 100%;
}
.payscore-report-card-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.payscore-report-card {
  min-height: 210px;
}
.payscore-verdict.conditional,
.payscore-history-item.conditional,
.payscore-verdict-card.conditional,
.payscore-report-card.conditional {
  background: linear-gradient(135deg, rgba(247, 178, 91, .30), rgba(255, 255, 255, .045));
  border-color: rgba(247, 178, 91, .46);
}
.payscore-conditional .payscore-bar i,
.payscore-conditional .payscore-gauge i {
  color: #f7b25b;
}
.payscore-countdown {
  display: grid;
  gap: 8px;
  margin: 18px 0;
  padding: clamp(18px, 2vw, 24px);
  border-radius: 24px;
  border: 1px solid rgba(39, 199, 255, .28);
  background: linear-gradient(135deg, rgba(39, 199, 255, .12), rgba(138, 92, 246, .09));
  max-width: 680px;
}
.payscore-countdown span {
  color: var(--text-soft);
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.payscore-countdown strong {
  display: block;
  font-size: clamp(3rem, 8vw, 5.6rem);
  line-height: .9;
  letter-spacing: -.075em;
  color: var(--text);
}
.payscore-countdown em {
  color: var(--text-soft);
  font-style: normal;
  line-height: 1.6;
  font-weight: 700;
}
.payscore-countdown.is-expired {
  border-color: rgba(52, 215, 161, .34);
  background: linear-gradient(135deg, rgba(52, 215, 161, .12), rgba(39, 199, 255, .07));
}
.payscore-pending-card-timed {
  min-height: 420px;
}
@media (max-width: 1380px) {
  .payscore-report-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 980px) {
  .app-shell.app-shell-wide .sidebar { display: grid; }
  .app-shell.app-shell-wide { grid-template-columns: 1fr; }
  .payscore-report-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .payscore-report-card-grid { display: flex; gap: 12px; min-width: max-content; }
}


/* v58 PayScore negatività, segnali critici e nota legale */
.payscore-critical-kpi,
.payscore-critical-signal {
  border-color: rgba(255, 122, 144, .48) !important;
  background: linear-gradient(135deg, rgba(255, 122, 144, .18), rgba(255, 255, 255, .045)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 18px 44px rgba(255, 122, 144, .08);
}
.payscore-critical-kpi strong,
.payscore-critical-signal strong {
  color: #ffe1e7;
}
.payscore-critical-signal .eyebrow {
  color: #ffb8c4;
}
.payscore-critical-signal ul,
.payscore-signal-grid ul {
  margin: 10px 0 0;
  padding-left: 18px;
  display: grid;
  gap: 10px;
}
.payscore-critical-signal li,
.payscore-signal-grid li {
  line-height: 1.55;
}
.payscore-legal-note {
  padding: clamp(18px, 2vw, 24px);
  border-radius: 22px;
  border-color: rgba(164, 189, 233, .22);
  background: rgba(255,255,255,.035);
}
.payscore-legal-note strong {
  display: block;
  color: var(--text);
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.payscore-legal-note p {
  color: var(--text-soft);
  font-size: .96rem;
  line-height: 1.72;
  margin: 0;
}

/* v59 - archivio PayScore: mantiene menu laterale e sfrutta meglio lo spazio */
.app-shell.app-shell-wide {
  grid-template-columns: minmax(230px, 280px) minmax(0, 1fr);
  gap: 18px;
}
.app-shell.app-shell-wide .sidebar {
  display: grid;
}
.app-shell.app-shell-wide .app-main {
  width: 100%;
  max-width: none;
}
.app-shell.app-shell-wide .payscore-report-card-grid {
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 14px;
}
@media (min-width: 1760px) {
  .app-shell.app-shell-wide .payscore-report-card-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 1180px) {
  .app-shell.app-shell-wide {
    grid-template-columns: 1fr;
  }
  .app-shell.app-shell-wide .sidebar {
    position: static;
    height: auto;
  }
  .app-shell.app-shell-wide .payscore-report-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .app-shell.app-shell-wide .payscore-report-card-grid {
    display: flex;
    gap: 12px;
    min-width: max-content;
  }
}

/* v60 - archivio PayScore: sidebar sempre visibile anche dopo regole wide precedenti */
.app-shell.app-shell-wide {
  grid-template-columns: minmax(240px, 300px) minmax(0, 1fr) !important;
}
.app-shell.app-shell-wide > .sidebar {
  display: grid !important;
  visibility: visible !important;
}
.app-shell.app-shell-wide > .app-main {
  width: 100% !important;
  max-width: none !important;
}
@media (max-width: 1180px) {
  .app-shell.app-shell-wide {
    grid-template-columns: 1fr !important;
  }
  .app-shell.app-shell-wide > .sidebar {
    display: grid !important;
    position: static;
    height: auto;
  }
}


/* v61 - coerenza colori PayScore: verde approvata, arancione condizioni/attenzione, rosso non consigliata */
.payscore-verdict.conditional,
.payscore-history-item.conditional,
.payscore-verdict-card.conditional,
.payscore-report-card.conditional {
  background: linear-gradient(135deg, rgba(247, 178, 91, .30), rgba(255, 255, 255, .045));
  border-color: rgba(247, 178, 91, .46);
}
.payscore-conditional .payscore-bar i,
.payscore-conditional .payscore-gauge i {
  color: #f7b25b;
}
.payscore-probability-split article:nth-child(1) i { background: #20c997; }
.payscore-probability-split article:nth-child(2) i { background: #f7b25b; }
.payscore-probability-split article:nth-child(3) i { background: #ff4d4f; }

/* PayScore v67: audience report tabs */
.payscore-audience-tabs {
  display: grid;
  gap: 18px;
  padding: clamp(18px, 2.4vw, 28px);
}
.payscore-tab-radio {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  opacity: 0;
  pointer-events: none;
}
.payscore-tab-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 22px;
  background: rgba(255,255,255,.055);
}
.payscore-tab-nav label {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 14px;
  border-radius: 16px;
  color: rgba(255,255,255,.72);
  font-weight: 900;
  text-align: center;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}
.payscore-tab-nav label:hover,
.payscore-tab-radio:focus-visible + .payscore-tab-radio + .payscore-tab-radio + .payscore-tab-nav label,
.payscore-tab-nav label:focus-visible {
  color: #fff;
}
.payscore-tab-panels {
  display: grid;
}
.payscore-tab-panel {
  display: none;
  gap: 18px;
}
.payscore-tab-radio:nth-of-type(1):checked ~ .payscore-tab-nav label:nth-child(1),
.payscore-tab-radio:nth-of-type(2):checked ~ .payscore-tab-nav label:nth-child(2),
.payscore-tab-radio:nth-of-type(3):checked ~ .payscore-tab-nav label:nth-child(3) {
  color: #fff;
  background: linear-gradient(135deg, rgba(32,201,151,.28), rgba(255,255,255,.075));
  border-color: rgba(32,201,151,.38);
  box-shadow: 0 16px 34px rgba(0,0,0,.18);
}
.payscore-tab-radio:nth-of-type(1):checked ~ .payscore-tab-panels .payscore-tab-panel-cfo,
.payscore-tab-radio:nth-of-type(2):checked ~ .payscore-tab-panels .payscore-tab-panel-commerciale,
.payscore-tab-radio:nth-of-type(3):checked ~ .payscore-tab-panels .payscore-tab-panel-credit-risk {
  display: grid;
}
.payscore-view-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: 16px;
  align-items: stretch;
}
.payscore-view-hero > div,
.payscore-view-locked,
.payscore-view-card {
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.055);
  border-radius: 24px;
  padding: clamp(16px, 2vw, 22px);
}
.payscore-view-hero h2 {
  margin: 8px 0 12px;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 1;
  letter-spacing: -.045em;
}
.payscore-view-hero p,
.payscore-view-card p,
.payscore-view-card li {
  color: rgba(255,255,255,.76);
  line-height: 1.6;
}
.payscore-view-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.payscore-view-pills span {
  display: inline-flex;
  padding: 8px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.10);
  font-size: .82rem;
  font-weight: 900;
}
.payscore-view-locked .payscore-info-list {
  margin-top: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.payscore-view-locked .payscore-info-list div {
  min-width: 0;
}
.payscore-view-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.payscore-view-card h3 {
  margin: 8px 0 10px;
  font-size: 1.08rem;
}
.payscore-view-card ul {
  margin: 10px 0 0;
  padding-left: 18px;
}
.payscore-view-card li + li {
  margin-top: 8px;
}
.payscore-view-card.wide {
  grid-column: 1 / -1;
}
.payscore-client-message p {
  font-weight: 800;
  color: rgba(255,255,255,.88);
}
@media (max-width: 1180px) {
  .payscore-view-hero,
  .payscore-view-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 760px) {
  .payscore-tab-nav {
    display: flex;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
  }
  .payscore-tab-nav label {
    min-width: max-content;
    flex: 0 0 auto;
    scroll-snap-align: start;
  }
  .payscore-view-locked .payscore-info-list {
    grid-template-columns: 1fr;
  }
}
@media print {
  .payscore-tab-radio,
  .payscore-tab-nav { display: none !important; }
  .payscore-tab-panel { display: grid !important; break-inside: avoid; margin-top: 18px; }
}

/* PayScore v68: audience dashboards and neutral report cover */
.payscore-analysis-cover {
  min-height: auto;
  grid-template-columns: 1fr;
  grid-template-areas:
    "head"
    "covergrid"
    "covernote";
  align-content: start;
}
.payscore-cover-subtitle {
  margin: 12px 0 0;
  max-width: 860px;
  color: rgba(255,255,255,.76);
  line-height: 1.6;
}
.payscore-cover-grid {
  grid-area: covergrid;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.payscore-cover-grid article,
.payscore-cover-note,
.payscore-preview-dashboard {
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.055);
  border-radius: 24px;
  padding: clamp(16px, 2vw, 22px);
}
.payscore-cover-grid span,
.payscore-cover-note span,
.payscore-preview-card span {
  display: block;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.68);
  font-weight: 800;
}
.payscore-cover-grid strong {
  display: block;
  margin-top: 8px;
  font-size: clamp(1.15rem, 2vw, 1.85rem);
  letter-spacing: -.035em;
}
.payscore-cover-grid em,
.payscore-preview-card em {
  display: block;
  margin-top: 8px;
  color: rgba(255,255,255,.62);
  font-style: normal;
  line-height: 1.35;
}
.payscore-cover-note {
  grid-area: covernote;
}
.payscore-cover-note p {
  margin: 8px 0 0;
  color: rgba(255,255,255,.76);
  line-height: 1.62;
}
.payscore-view-hero-single {
  grid-template-columns: 1fr;
}
.payscore-preview-dashboard {
  display: grid;
  gap: 16px;
}
.payscore-preview-dashboard-head h3 {
  margin: 8px 0 8px;
  font-size: clamp(1.3rem, 2.2vw, 2rem);
  letter-spacing: -.035em;
}
.payscore-preview-dashboard-head p {
  margin: 0;
  color: rgba(255,255,255,.72);
  line-height: 1.55;
}
.payscore-preview-cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.payscore-preview-credit-risk .payscore-preview-cards {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.payscore-preview-card {
  min-height: 132px;
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.06);
  border-radius: 20px;
  padding: 16px;
  display: grid;
  align-content: space-between;
  gap: 10px;
}
.payscore-preview-card strong {
  display: block;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: .92;
  letter-spacing: -.07em;
}
.payscore-preview-card.positive {
  border-color: rgba(32,201,151,.38);
  background: linear-gradient(135deg, rgba(32,201,151,.18), rgba(255,255,255,.055));
}
.payscore-preview-card.warning {
  border-color: rgba(247,178,91,.40);
  background: linear-gradient(135deg, rgba(247,178,91,.18), rgba(255,255,255,.055));
}
.payscore-preview-card.negative {
  border-color: rgba(255,77,79,.40);
  background: linear-gradient(135deg, rgba(255,77,79,.18), rgba(255,255,255,.055));
}
.payscore-preview-card.neutral {
  border-color: rgba(39,199,255,.24);
}
@media (max-width: 1180px) {
  .payscore-cover-grid,
  .payscore-preview-cards,
  .payscore-preview-credit-risk .payscore-preview-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .payscore-cover-grid,
  .payscore-preview-cards,
  .payscore-preview-credit-risk .payscore-preview-cards {
    grid-template-columns: 1fr;
  }
}
@media print {
  .payscore-preview-cards,
  .payscore-preview-credit-risk .payscore-preview-cards,
  .payscore-cover-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}


/* PayScore v69: hero verdict cards + faster report/tab rendering */
.payscore-preview-dashboard {
  overflow: hidden;
  contain: layout paint style;
}
.payscore-preview-cards {
  grid-template-columns: minmax(320px, 1.55fr) repeat(3, minmax(0, 1fr));
  align-items: stretch;
}
.payscore-preview-credit-risk .payscore-preview-cards {
  grid-template-columns: minmax(320px, 1.35fr) repeat(5, minmax(0, 1fr));
}
.payscore-preview-card {
  transform: translateZ(0);
  backface-visibility: hidden;
  box-shadow: none;
  transition: border-color .12s ease, background .12s ease;
}
.payscore-preview-card.primary {
  min-height: 190px;
  padding: clamp(20px, 2.6vw, 30px);
  border-radius: 28px;
  grid-row: span 1;
  position: relative;
  isolation: isolate;
}
.payscore-preview-card.primary::after {
  content: "";
  position: absolute;
  inset: auto 18px 18px auto;
  inline-size: 92px;
  block-size: 92px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  filter: blur(.1px);
  z-index: -1;
}
.payscore-preview-card.primary span {
  color: rgba(255,255,255,.78);
}
.payscore-preview-card.primary strong {
  font-size: clamp(3.2rem, 7vw, 6.4rem);
  letter-spacing: -.085em;
  line-height: .84;
}
.payscore-preview-card.primary b {
  display: block;
  margin-top: 10px;
  font-size: clamp(1.15rem, 2vw, 1.85rem);
  line-height: 1.05;
  letter-spacing: -.045em;
  color: #fff;
}
.payscore-preview-card.primary em {
  max-width: 34ch;
  color: rgba(255,255,255,.76);
}
.payscore-tab-panels,
.payscore-tab-panel,
.payscore-view-grid,
.payscore-dossier-grid,
.payscore-stress-grid {
  contain: layout paint style;
}
.payscore-tab-panel {
  content-visibility: hidden;
  contain-intrinsic-size: 780px;
}
.payscore-tab-radio:nth-of-type(1):checked ~ .payscore-tab-panels .payscore-tab-panel-cfo,
.payscore-tab-radio:nth-of-type(2):checked ~ .payscore-tab-panels .payscore-tab-panel-commerciale,
.payscore-tab-radio:nth-of-type(3):checked ~ .payscore-tab-panels .payscore-tab-panel-credit-risk {
  content-visibility: visible;
}
.payscore-report > section.panel-surface:not(.payscore-analysis-cover):not(.payscore-audience-tabs),
.payscore-report > section.content-card:not(.payscore-audience-tabs) {
  content-visibility: auto;
  contain-intrinsic-size: 960px;
}
.payscore-tab-nav label {
  transition: background .12s ease, border-color .12s ease, color .12s ease;
}
.payscore-tab-radio:nth-of-type(1):checked ~ .payscore-tab-nav label:nth-child(1),
.payscore-tab-radio:nth-of-type(2):checked ~ .payscore-tab-nav label:nth-child(2),
.payscore-tab-radio:nth-of-type(3):checked ~ .payscore-tab-nav label:nth-child(3) {
  box-shadow: none;
}
@media (max-width: 1180px) {
  .payscore-preview-cards,
  .payscore-preview-credit-risk .payscore-preview-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .payscore-preview-card.primary {
    grid-column: 1 / -1;
  }
}
@media (max-width: 760px) {
  .payscore-preview-cards,
  .payscore-preview-credit-risk .payscore-preview-cards {
    grid-template-columns: 1fr;
  }
  .payscore-preview-card.primary {
    min-height: 168px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .payscore-preview-card,
  .payscore-tab-nav label {
    transition: none !important;
  }
}
@media print {
  .payscore-tab-panel,
  .payscore-report > section.panel-surface,
  .payscore-report > section.content-card {
    content-visibility: visible !important;
    contain: none !important;
  }
}

/* PayScore v70: semafori, score no-wrap, dossier tecnico alleggerito */
.payscore-card-semaphore {
  display: inline-flex;
  align-items: center;
  width: max-content;
  gap: 6px;
  margin-top: 2px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.105);
  border: 1px solid rgba(255,255,255,.13);
  color: rgba(255,255,255,.9);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .01em;
}
.payscore-score-value {
  display: inline-flex !important;
  align-items: baseline;
  flex-wrap: nowrap;
  white-space: nowrap;
  gap: .04em;
  letter-spacing: -.07em;
}
.payscore-score-value span { display: inline-block; }
.payscore-score-value small {
  display: inline-block;
  font-size: .38em;
  line-height: 1;
  letter-spacing: -.035em;
  white-space: nowrap;
}
.payscore-preview-card.primary .payscore-score-value {
  line-height: .84;
}
.payscore-technical-details {
  display: block;
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.035);
  border-radius: 28px;
  padding: 0;
  overflow: clip;
  contain: layout paint style;
}
.payscore-technical-details > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: clamp(18px, 2.2vw, 26px);
  border-radius: 28px;
  color: #fff;
}
.payscore-technical-details > summary::-webkit-details-marker { display: none; }
.payscore-technical-details > summary span {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: rgba(255,255,255,.62);
  font-weight: 900;
}
.payscore-technical-details > summary strong {
  font-size: clamp(1.05rem, 1.8vw, 1.45rem);
  letter-spacing: -.035em;
}
.payscore-technical-details > summary::after {
  content: "+";
  display: inline-grid;
  place-items: center;
  inline-size: 34px;
  block-size: 34px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  font-weight: 900;
}
.payscore-technical-details[open] > summary::after { content: "−"; }
.payscore-technical-details > section {
  margin: 0 clamp(12px, 1.6vw, 18px) clamp(12px, 1.6vw, 18px);
}
.payscore-tab-nav label {
  cursor: pointer !important;
  pointer-events: auto !important;
  user-select: none;
  touch-action: manipulation;
}
.payscore-audience-tabs {
  content-visibility: visible;
  contain-intrinsic-size: auto;
}
@media (max-width: 760px) {
  .payscore-score-value small { font-size: .34em; }
  .payscore-technical-details > summary { align-items: flex-start; flex-direction: column; }
}
@media print {
  .payscore-technical-details > summary { display: none !important; }
  .payscore-technical-details,
  .payscore-technical-details > section {
    display: block !important;
    contain: none !important;
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    margin: 0 !important;
  }
  .payscore-technical-details:not([open]) > :not(summary) { display: block !important; }
}

/* PayScore v71 - grafica precedente above-the-fold per ogni tab + local tabs */
.payscore-audience-tabs[data-payscore-local-tabs] {
  gap: 14px;
}
.payscore-audience-tabs[data-payscore-local-tabs] script {
  display: none !important;
}
.payscore-audience-abovefold {
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, .62fr) minmax(280px, .62fr);
  grid-template-areas:
    "head head verdict"
    "probability split verdict"
    "probability snapshot verdict"
    "kpis kpis kpis"
    "summary action action";
  min-height: min(610px, calc(100vh - 170px));
  width: 100%;
  margin: 0;
  border: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at top right, rgba(39,199,255,.08), transparent 34%),
    rgba(255,255,255,.025);
  border-radius: 28px;
  contain: layout paint style;
}
.payscore-audience-abovefold .payscore-abovefold-head h1 {
  font-size: clamp(1.8rem, 3.6vw, 3.35rem);
}
.payscore-audience-abovefold .payscore-primary-metric {
  min-height: 310px;
}
.payscore-audience-abovefold .payscore-primary-metric strong {
  font-size: clamp(5.1rem, 11vw, 10.2rem);
}
.payscore-audience-abovefold .payscore-primary-metric .payscore-score-value {
  display: grid !important;
  align-items: start;
  justify-items: start;
  gap: 0;
  white-space: nowrap;
  line-height: .78;
}
.payscore-audience-abovefold .payscore-primary-metric .payscore-score-value span {
  display: block;
}
.payscore-audience-abovefold .payscore-primary-metric .payscore-score-value small {
  display: block;
  margin-top: .08em;
  font-size: .22em;
  line-height: 1;
  letter-spacing: -.035em;
}
.payscore-audience-abovefold .payscore-gauge {
  margin-top: 4px;
}
.payscore-audience-abovefold .payscore-probability-split article {
  align-content: start;
}
.payscore-audience-abovefold .payscore-probability-split em,
.payscore-audience-abovefold .payscore-abovefold-kpis p {
  display: block;
  margin: 2px 0 0;
  color: rgba(255,255,255,.62);
  font-style: normal;
  line-height: 1.35;
  font-size: .82rem;
}
.payscore-audience-abovefold .payscore-verdict-card.approved {
  background: linear-gradient(135deg, rgba(32, 201, 151, .34), rgba(32, 201, 151, .08));
  border-color: rgba(32, 201, 151, .46);
}
.payscore-audience-abovefold .payscore-verdict-card.conditional {
  background: linear-gradient(135deg, rgba(247, 178, 91, .30), rgba(255, 255, 255, .045));
  border-color: rgba(247, 178, 91, .46);
}
.payscore-audience-abovefold .payscore-verdict-card.rejected {
  background: linear-gradient(135deg, rgba(255, 77, 79, .34), rgba(255, 77, 79, .08));
  border-color: rgba(255, 77, 79, .52);
}
.payscore-audience-abovefold .payscore-condition-list.compact span {
  display: inline-flex;
  align-items: center;
}
.payscore-tab-loading {
  min-height: 360px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.045);
  border-radius: 24px;
  color: rgba(255,255,255,.72);
  font-weight: 900;
}
.payscore-tab-panel {
  content-visibility: visible;
  contain-intrinsic-size: auto;
}
.payscore-tab-nav label {
  cursor: pointer !important;
  will-change: background, border-color, color;
}
@media (max-width: 1180px) {
  .payscore-audience-abovefold {
    grid-template-columns: minmax(0, 1fr) minmax(260px, .65fr);
    grid-template-areas:
      "head head"
      "probability verdict"
      "split split"
      "snapshot kpis"
      "summary action";
    min-height: auto;
  }
  .payscore-audience-abovefold .payscore-probability-split {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .payscore-audience-abovefold {
    grid-template-columns: 1fr;
    grid-template-areas: "head" "probability" "split" "verdict" "snapshot" "kpis" "summary" "action";
    padding: 16px;
    border-radius: 22px;
  }
  .payscore-audience-abovefold .payscore-primary-metric {
    min-height: 220px;
  }
  .payscore-audience-abovefold .payscore-primary-metric strong {
    font-size: clamp(4.4rem, 26vw, 7.6rem);
  }
  .payscore-audience-abovefold .payscore-probability-split {
    grid-template-columns: 1fr;
  }
}
@media print {
  .payscore-audience-abovefold {
    min-height: auto !important;
    contain: none !important;
  }
}

/* PayScore v73 - embedded static report, triad KPI card, larger Credit Risk score */
.payscore-static-report-fragment {
  display: block;
  width: 100%;
  min-width: 0;
}
.payscore-static-report-fragment .payscore-report {
  margin-top: 0;
}
.payscore-static-report-fragment .payscore-analysis-cover {
  margin-top: 0;
}
.payscore-cover-score-triad {
  grid-column: span 2;
  background:
    radial-gradient(circle at top right, rgba(39,199,255,.12), transparent 40%),
    rgba(255,255,255,.055) !important;
  border-color: rgba(39,199,255,.22) !important;
}
.payscore-triad-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.payscore-triad-metrics div {
  min-width: 0;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.045);
}
.payscore-triad-metrics div.tone-positive { border-color: rgba(32,201,151,.34); background: rgba(32,201,151,.09); }
.payscore-triad-metrics div.tone-warning { border-color: rgba(247,178,91,.34); background: rgba(247,178,91,.09); }
.payscore-triad-metrics div.tone-negative { border-color: rgba(255,77,79,.34); background: rgba(255,77,79,.09); }
.payscore-triad-metrics strong {
  margin: 0 !important;
  font-size: clamp(1.8rem, 3.2vw, 3rem) !important;
  line-height: .9;
  letter-spacing: -.07em;
}
.payscore-triad-metrics em,
.payscore-triad-metrics small {
  display: block;
  font-style: normal;
  margin-top: 6px;
  line-height: 1.25;
}
.payscore-triad-metrics em {
  color: rgba(255,255,255,.88);
  font-weight: 900;
}
.payscore-triad-metrics small {
  color: rgba(255,255,255,.62);
  font-size: .78rem;
}
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
  font-size: clamp(6.8rem, 14vw, 12.8rem);
}
.payscore-preview-credit-risk .payscore-primary-metric .payscore-score-value small {
  font-size: .28em;
  margin-top: .06em;
}
.admin-danger-zone {
  border-color: rgba(255,122,144,.34) !important;
  background: linear-gradient(135deg, rgba(255,122,144,.10), rgba(255,255,255,.035)) !important;
}
@media (max-width: 1180px) {
  .payscore-cover-score-triad { grid-column: 1 / -1; }
}
@media (max-width: 760px) {
  .payscore-triad-metrics { grid-template-columns: 1fr; }
  .payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
    font-size: clamp(5.2rem, 30vw, 8.4rem);
  }
}

/* v74 - registration legal consent, OTP containment and Credit Risk score emphasis */
.auth-legal-consent {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(164, 189, 233, 0.18);
  background: rgba(255, 255, 255, 0.035);
}
.auth-legal-consent p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.55;
  font-size: .94rem;
}
.auth-legal-consent a,
.consent-row a {
  color: #7fe0ff;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.consent-row {
  grid-auto-flow: column;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 12px;
  margin: 0;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}
.consent-row input {
  flex: 0 0 auto;
  width: 19px;
  height: 19px;
  min-height: 19px;
  margin-top: 2px;
}
.consent-row span {
  min-width: 0;
  color: var(--text);
  line-height: 1.45;
  font-size: .92rem;
  font-weight: 750;
}
.auth-otp-box {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(39, 199, 255, .18);
  background: rgba(39, 199, 255, .055);
  min-width: 0;
  overflow: hidden;
}
.auth-otp-form,
.auth-resend-form {
  min-width: 0;
  width: 100%;
  margin: 0;
}
.auth-otp-input {
  text-align: center;
  font-size: clamp(1.4rem, 5vw, 2.1rem);
  font-weight: 900;
  letter-spacing: .28em;
  padding-inline: 18px;
  overflow: hidden;
}
.auth-otp-box .primary-cta,
.auth-otp-box .ghost-button,
.auth-otp-box .auth-link {
  width: 100%;
  min-width: 0;
  text-align: center;
}
.auth-otp-box .auth-link {
  margin-top: 0;
  color: var(--text-soft);
}
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
  font-size: clamp(8.8rem, 18vw, 16rem) !important;
  line-height: .68 !important;
  letter-spacing: -.09em;
}
.payscore-preview-credit-risk .payscore-primary-metric .payscore-score-value span {
  font-size: 1em !important;
  line-height: .68 !important;
}
.payscore-preview-credit-risk .payscore-primary-metric .payscore-score-value small {
  font-size: .15em !important;
  line-height: 1 !important;
  margin-top: .18em !important;
  letter-spacing: -.025em;
}
@media (max-width: 760px) {
  .consent-row { padding: 11px; }
  .auth-otp-input { letter-spacing: .20em; }
  .payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
    font-size: clamp(6rem, 34vw, 10rem) !important;
  }
}

/* v75 - report readability, score sizing, gauge color and reports pagination */
.payscore-audience-abovefold .payscore-executive-summary p {
  display: block !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: initial !important;
  overflow: visible !important;
  max-height: none !important;
  line-height: 1.58 !important;
}
.payscore-audience-abovefold .payscore-executive-summary {
  align-content: start;
}
.payscore-audience-abovefold .payscore-primary-metric > span,
.payscore-preview-credit-risk .payscore-primary-metric > span {
  font-size: .76rem !important;
  line-height: 1.2 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}
.payscore-audience-abovefold .payscore-primary-metric strong.payscore-score-value > span,
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value > span {
  display: block !important;
  font-size: 1em !important;
  line-height: .68 !important;
  letter-spacing: -.09em !important;
  color: inherit !important;
  text-transform: none !important;
}
.payscore-audience-abovefold .payscore-primary-metric strong.payscore-score-value > small,
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value > small {
  display: block !important;
  font-size: .16em !important;
  line-height: 1 !important;
  margin-top: .16em !important;
  letter-spacing: -.025em !important;
  color: inherit !important;
}
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
  font-size: clamp(9rem, 18vw, 16rem) !important;
  line-height: .68 !important;
}
.payscore-audience-abovefold.payscore-approved .payscore-gauge i,
.payscore-audience-abovefold.payscore-approved .payscore-probability-split article i {
  color: #20c997 !important;
  background: linear-gradient(90deg, rgba(255,255,255,.72), #20c997) !important;
}
.payscore-audience-abovefold.payscore-conditional .payscore-gauge i,
.payscore-audience-abovefold.payscore-conditional .payscore-probability-split article i {
  color: #f7b25b !important;
  background: linear-gradient(90deg, rgba(255,255,255,.72), #f7b25b) !important;
}
.payscore-audience-abovefold.payscore-rejected .payscore-gauge i,
.payscore-audience-abovefold.payscore-rejected .payscore-probability-split article i {
  color: #ff4d4f !important;
  background: linear-gradient(90deg, rgba(255,255,255,.72), #ff4d4f) !important;
}
.payscore-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.payscore-pagination a,
.payscore-pagination span {
  min-width: 42px;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 13px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.045);
  color: var(--text-soft);
  font-weight: 900;
}
.payscore-pagination a:hover,
.payscore-pagination .active {
  color: var(--text);
  border-color: rgba(39,199,255,.34);
  background: rgba(39,199,255,.12);
}
.payscore-pagination .disabled {
  opacity: .45;
}
@media (max-width: 760px) {
  .payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
    font-size: clamp(6.4rem, 36vw, 10.5rem) !important;
  }
}

/* v76 - login copy, billing validation notes and uniform Credit Risk score */
.billing-form input:invalid {
  border-color: rgba(255, 122, 144, .44);
}
.billing-form input:valid {
  border-color: rgba(164, 189, 233, .20);
}
.billing-checkbox-top span {
  line-height: 1.45;
}
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value,
.payscore-audience-abovefold.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
  display: inline-flex !important;
  align-items: baseline !important;
  justify-items: initial !important;
  gap: .06em !important;
  white-space: nowrap !important;
  font-size: clamp(5.1rem, 11vw, 10.2rem) !important;
  line-height: .82 !important;
  letter-spacing: -.08em !important;
}
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value > span,
.payscore-audience-abovefold.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value > span {
  display: inline-block !important;
  font-size: 1em !important;
  line-height: .82 !important;
  letter-spacing: -.08em !important;
}
.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value > small,
.payscore-audience-abovefold.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value > small {
  display: inline-block !important;
  font-size: .36em !important;
  line-height: 1 !important;
  margin-top: 0 !important;
  letter-spacing: -.035em !important;
}
@media (max-width: 760px) {
  .payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value,
  .payscore-audience-abovefold.payscore-preview-credit-risk .payscore-primary-metric strong.payscore-score-value {
    font-size: clamp(4.4rem, 26vw, 7.6rem) !important;
  }
}

/* v77 - colori per singolo indicatore e fatturazione aziendale precompilata */
.payscore-audience-abovefold .tone-positive {
  border-color: rgba(32, 201, 151, .34) !important;
}
.payscore-audience-abovefold .tone-warning {
  border-color: rgba(247, 178, 91, .38) !important;
}
.payscore-audience-abovefold .tone-negative {
  border-color: rgba(255, 77, 79, .38) !important;
}
.payscore-audience-abovefold .payscore-primary-metric.tone-positive,
.payscore-audience-abovefold .payscore-probability-split article.tone-positive,
.payscore-audience-abovefold .payscore-abovefold-kpis article.tone-positive {
  background: linear-gradient(145deg, rgba(32, 201, 151, .13), rgba(255,255,255,.035)) !important;
}
.payscore-audience-abovefold .payscore-primary-metric.tone-warning,
.payscore-audience-abovefold .payscore-probability-split article.tone-warning,
.payscore-audience-abovefold .payscore-abovefold-kpis article.tone-warning {
  background: linear-gradient(145deg, rgba(247, 178, 91, .14), rgba(255,255,255,.035)) !important;
}
.payscore-audience-abovefold .payscore-primary-metric.tone-negative,
.payscore-audience-abovefold .payscore-probability-split article.tone-negative,
.payscore-audience-abovefold .payscore-abovefold-kpis article.tone-negative {
  background: linear-gradient(145deg, rgba(255, 77, 79, .15), rgba(255,255,255,.035)) !important;
}
.payscore-audience-abovefold .payscore-gauge.tone-positive i,
.payscore-audience-abovefold .payscore-probability-split article.tone-positive i {
  color: #20c997 !important;
  background: linear-gradient(90deg, rgba(255,255,255,.72), #20c997) !important;
}
.payscore-audience-abovefold .payscore-gauge.tone-warning i,
.payscore-audience-abovefold .payscore-probability-split article.tone-warning i {
  color: #f7b25b !important;
  background: linear-gradient(90deg, rgba(255,255,255,.72), #f7b25b) !important;
}
.payscore-audience-abovefold .payscore-gauge.tone-negative i,
.payscore-audience-abovefold .payscore-probability-split article.tone-negative i {
  color: #ff4d4f !important;
  background: linear-gradient(90deg, rgba(255,255,255,.72), #ff4d4f) !important;
}
.payscore-audience-abovefold .payscore-gauge.tone-neutral i,
.payscore-audience-abovefold .payscore-probability-split article.tone-neutral i {
  color: var(--brand) !important;
  background: linear-gradient(90deg, rgba(255,255,255,.72), var(--brand)) !important;
}
.billing-prefill-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(39,199,255,.24);
  background: rgba(39,199,255,.055);
}
.billing-prefill-card strong {
  font-size: 1rem;
}
.billing-prefill-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}
.billing-prefill-form label { min-width: 0; }
.billing-prefill-form .ghost-button { min-height: 56px; white-space: nowrap; }
.billing-company-only {
  transition: opacity .16s ease;
}
.billing-form[data-billing-type="personal"] .billing-company-only,
.billing-prefill-card[data-billing-type="personal"] {
  display: none;
}
.billing-personal-hint,
.billing-company-hint {
  display: none;
  margin: 0;
  color: var(--text-soft);
  line-height: 1.5;
}
.billing-form[data-billing-type="personal"] .billing-personal-hint,
.billing-form[data-billing-type="company"] .billing-company-hint {
  display: block;
}
@media (max-width: 760px) {
  .billing-prefill-form { grid-template-columns: 1fr; }
  .billing-prefill-form .ghost-button { width: 100%; }
}

/* v78 - app shell fixed sidebar + independent right scroll */
@media (min-width: 981px) {
  body.app-layout-page {
    height: 100vh;
    overflow: hidden;
  }

  body.app-layout-page .app-shell {
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
    align-items: stretch;
  }

  body.app-layout-page .app-shell > .sidebar {
    position: relative;
    top: auto;
    height: calc(100vh - (var(--container-pad) * 2));
    max-height: calc(100vh - (var(--container-pad) * 2));
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
  }

  body.app-layout-page .app-shell > .app-main {
    height: calc(100vh - (var(--container-pad) * 2));
    max-height: calc(100vh - (var(--container-pad) * 2));
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scroll-behavior: smooth;
    padding-right: 8px;
    scrollbar-gutter: stable;
  }

  body.app-layout-page .ps-site-footer {
    display: none;
  }
}

.app-scroll-top-button {
  position: fixed;
  right: clamp(18px, 2vw, 30px);
  bottom: clamp(18px, 2vw, 30px);
  z-index: 950;
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  border: 1px solid rgba(164, 189, 233, .26);
  background: rgba(7, 16, 30, .76);
  color: var(--text);
  box-shadow: 0 18px 46px rgba(2, 9, 21, .34);
  backdrop-filter: blur(14px);
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity .16s ease, transform .16s ease, background .16s ease, border-color .16s ease;
}

.app-scroll-top-button::before {
  content: '↑';
  font-size: 1.65rem;
  line-height: 1;
  font-weight: 900;
}

.app-scroll-top-button.is-visible {
  opacity: .88;
  transform: translateY(0);
  pointer-events: auto;
}

.app-scroll-top-button:hover,
.app-scroll-top-button:focus-visible {
  opacity: 1;
  background: rgba(39, 199, 255, .18);
  border-color: rgba(39, 199, 255, .38);
  outline: none;
}

@media (max-width: 980px) {
  .app-scroll-top-button {
    right: 16px;
    bottom: 16px;
    width: 48px;
    height: 48px;
    border-radius: 12px;
  }
}

/* v79 - Mobile App Experience: topbar, bottom navigation, drawer, cards and report readability */
.mobile-app-chrome {
  display: none;
}

@media (max-width: 980px) {
  html.mobile-menu-open,
  html.mobile-menu-open body {
    overflow: hidden;
  }

  body.app-layout-page {
    min-height: 100vh;
    overflow-x: hidden;
    background:
      radial-gradient(circle at 10% -10%, rgba(39, 199, 255, .18), transparent 34%),
      radial-gradient(circle at 95% 12%, rgba(138, 92, 246, .14), transparent 32%),
      var(--bg);
  }

  body.app-layout-page .ps-site-footer {
    display: none;
  }

  .mobile-app-chrome {
    display: block;
  }

  .mobile-app-topbar {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 1100;
    height: calc(64px + env(safe-area-inset-top));
    padding: calc(10px + env(safe-area-inset-top)) 14px 10px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 10px;
    background: rgba(5, 13, 26, .82);
    border-bottom: 1px solid rgba(164, 189, 233, .14);
    box-shadow: 0 18px 44px rgba(0, 0, 0, .28);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .mobile-app-logo {
    width: min(146px, 44vw);
    min-width: 0;
    display: flex;
    align-items: center;
  }

  .mobile-app-logo img {
    width: 100%;
    max-height: 38px;
    object-fit: contain;
    object-position: left center;
  }

  .mobile-credit-pill {
    min-height: 42px;
    padding: 6px 11px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--text);
    text-decoration: none;
    background: linear-gradient(135deg, rgba(39, 199, 255, .18), rgba(138, 92, 246, .13));
    border: 1px solid rgba(39, 199, 255, .24);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
  }

  .mobile-credit-pill span {
    font-size: 1.05rem;
    font-weight: 950;
    line-height: 1;
  }

  .mobile-credit-pill small {
    color: var(--text-soft);
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
  }

  .mobile-menu-toggle,
  .mobile-drawer-close {
    border: 0;
    color: var(--text);
    background: rgba(255, 255, 255, .07);
    border: 1px solid rgba(164, 189, 233, .16);
    cursor: pointer;
  }

  .mobile-menu-toggle {
    width: 44px;
    height: 44px;
    border-radius: 15px;
    display: grid;
    place-items: center;
    gap: 3px;
  }

  .mobile-menu-toggle span {
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    display: block;
  }

  .mobile-menu-toggle em {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .mobile-menu-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1110;
    background: rgba(0, 0, 0, .48);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
  }

  .mobile-app-drawer {
    position: fixed;
    z-index: 1120;
    inset: 0 0 0 auto;
    width: min(88vw, 360px);
    height: 100vh;
    border-radius: 26px 0 0 26px;
    padding: calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 18px;
    overflow-y: auto;
    transform: translateX(108%);
    transition: transform .22s ease;
    box-shadow: -24px 0 70px rgba(0, 0, 0, .42);
  }

  .mobile-app-drawer.is-open {
    transform: translateX(0);
  }

  .mobile-drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(164, 189, 233, .14);
  }

  .mobile-drawer-head strong,
  .mobile-drawer-head span {
    display: block;
  }

  .mobile-drawer-head strong {
    font-size: 1.02rem;
    line-height: 1.2;
  }

  .mobile-drawer-head span {
    margin-top: 4px;
    color: var(--muted);
    font-size: .84rem;
  }

  .mobile-drawer-close {
    flex: 0 0 42px;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    font-size: 1.55rem;
    line-height: 1;
  }

  .mobile-drawer-nav {
    display: grid;
    align-content: start;
    gap: 9px;
  }

  .mobile-drawer-nav a {
    padding: 14px 15px;
    border-radius: 16px;
    color: var(--text-soft);
    text-decoration: none;
    font-weight: 850;
    background: rgba(255, 255, 255, .045);
    border: 1px solid rgba(164, 189, 233, .1);
  }

  .mobile-drawer-nav a.active,
  .mobile-drawer-nav a:hover,
  .mobile-drawer-nav a:focus-visible {
    color: var(--text);
    border-color: rgba(39, 199, 255, .3);
    background: rgba(39, 199, 255, .1);
    outline: none;
  }

  .mobile-bottom-nav {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: max(10px, env(safe-area-inset-bottom));
    z-index: 1090;
    min-height: 64px;
    padding: 8px;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    align-items: center;
    gap: 6px;
    border-radius: 24px;
    background: rgba(5, 13, 26, .86);
    border: 1px solid rgba(164, 189, 233, .16);
    box-shadow: 0 22px 58px rgba(0, 0, 0, .36);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .mobile-bottom-nav a {
    min-width: 0;
    min-height: 46px;
    border-radius: 17px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    color: var(--muted);
    text-decoration: none;
    font-size: .73rem;
    font-weight: 900;
    letter-spacing: -.01em;
  }

  .mobile-bottom-nav a.active {
    color: var(--text);
    background: rgba(39, 199, 255, .11);
  }

  .mobile-bottom-nav .mobile-bottom-primary {
    background: linear-gradient(135deg, var(--brand), rgba(138, 92, 246, .98));
    color: #03101d;
    box-shadow: 0 12px 28px rgba(39, 199, 255, .26);
  }

  .mobile-bottom-nav .mobile-bottom-primary strong {
    width: 20px;
    height: 20px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, .36);
    font-size: 1rem;
    line-height: 1;
  }

  body.app-layout-page .app-shell,
  body.app-layout-page .app-shell.app-shell-wide {
    display: block;
    min-height: 100vh;
    padding: calc(78px + env(safe-area-inset-top)) 12px calc(96px + env(safe-area-inset-bottom));
  }

  body.app-layout-page .app-shell > .sidebar,
  body.app-layout-page .app-shell.app-shell-wide > .sidebar {
    display: none !important;
  }

  body.app-layout-page .app-main,
  body.app-layout-page .app-shell.app-shell-wide > .app-main {
    display: grid;
    gap: 14px;
    padding: 0 !important;
    width: 100%;
    max-width: 100%;
    overflow: visible;
  }

  .flash {
    border-radius: 18px;
    padding: 13px 14px;
    font-size: .92rem;
  }

  .hero-card,
  .content-card,
  .loading-footer,
  .panel-surface.content-card,
  .payscore-form-card,
  .payscore-reports-panel {
    padding: 17px;
    border-radius: 23px;
  }

  .hero-card,
  .layout-two,
  .research-layout,
  .payscore-layout,
  .company-layout,
  .payscore-bi-layout,
  .payscore-section-grid,
  .payscore-dossier-grid,
  .payscore-metric-grid,
  .payscore-profile-hero,
  .payscore-bi-grid,
  .payscore-report-card-grid,
  .form-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 13px !important;
  }

  .hero-card h1,
  .section-heading h1 {
    font-size: clamp(1.55rem, 8vw, 2.2rem);
    line-height: 1.02;
    letter-spacing: -.045em;
  }

  .hero-card h2,
  .content-card h2,
  .section-heading h2 {
    font-size: clamp(1.25rem, 6vw, 1.62rem);
    line-height: 1.08;
    letter-spacing: -.035em;
  }

  .hero-card p,
  .section-heading p,
  .content-card p {
    line-height: 1.55;
  }

  .hero-actions,
  .section-actions,
  .sticky-actions,
  .report-export-actions,
  .payscore-report-filter-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 9px;
    width: 100%;
  }

  .primary-cta,
  .ghost-button,
  .hero-actions a,
  .section-actions a,
  .report-export-actions a,
  .payscore-report-filter-actions a,
  .payscore-report-filter-actions button {
    min-height: 46px;
    justify-content: center;
    width: 100%;
    text-align: center;
  }

  .payscore-entry-hero .hero-side,
  .payscore-archive-hero .hero-actions {
    margin-top: 2px;
  }

  .payscore-entry-hero .hero-side article,
  .payscore-bi-card,
  .power-card,
  .payscore-history-item,
  .payscore-report-card {
    border-radius: 20px;
  }

  .payscore-form-card form {
    gap: 13px;
  }

  .payscore-form-card form::before {
    content: 'Nuova analisi in 3 step';
    display: block;
    padding: 12px 13px;
    border-radius: 16px;
    color: var(--text);
    font-weight: 950;
    letter-spacing: -.02em;
    background: linear-gradient(135deg, rgba(39, 199, 255, .14), rgba(138, 92, 246, .12));
    border: 1px solid rgba(39, 199, 255, .18);
  }

  label span {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--muted);
    font-weight: 900;
  }

  input,
  select,
  textarea {
    min-height: 48px;
    font-size: 16px;
    border-radius: 16px;
  }

  .payscore-report-filter {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    position: sticky;
    top: calc(70px + env(safe-area-inset-top));
    z-index: 12;
    padding: 12px;
    margin-left: -4px;
    margin-right: -4px;
    border-radius: 20px;
    background: rgba(5, 13, 26, .78);
    border: 1px solid rgba(164, 189, 233, .12);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }

  .payscore-reports-scroll {
    overflow: visible !important;
  }

  .payscore-report-card-grid {
    min-width: 0 !important;
  }

  .payscore-report-card {
    width: 100%;
    min-width: 0;
    padding: 16px;
    box-shadow: 0 18px 40px rgba(2, 9, 21, .18);
  }

  .payscore-report-card-data {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .payscore-report-card-data span {
    padding: 10px 8px;
    border-radius: 14px;
  }

  .payscore-history-list,
  .payscore-history-list.grid,
  .payscore-history-full {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .payscore-history-item {
    padding: 15px;
    display: grid;
    gap: 6px;
    min-height: 0;
  }

  .payscore-history-item strong {
    font-size: 1.02rem;
  }

  .payscore-static-report-fragment,
  .payscore-report {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  .payscore-report {
    display: grid;
    gap: 14px;
  }

  .report-export-actions {
    position: sticky;
    top: calc(72px + env(safe-area-inset-top));
    z-index: 20;
    grid-template-columns: 1fr 1fr;
    padding: 10px;
    margin: 0 -2px;
    border-radius: 20px;
    background: rgba(5, 13, 26, .82);
    border: 1px solid rgba(164, 189, 233, .14);
    box-shadow: 0 16px 40px rgba(0, 0, 0, .25);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }

  .payscore-abovefold,
  .payscore-hero,
  .payscore-executive-grid,
  .payscore-summary-grid,
  .payscore-kpi-grid,
  .payscore-operations-grid,
  .payscore-flag-grid,
  .payscore-stress-grid,
  .payscore-dossier-grid,
  .payscore-section-grid,
  .payscore-tab-grid,
  .payscore-audience-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .payscore-abovefold,
  .payscore-hero {
    padding: 18px !important;
    border-radius: 26px !important;
  }

  .payscore-hero h1,
  .payscore-abovefold h1,
  .payscore-report h1 {
    font-size: clamp(1.6rem, 8vw, 2.28rem) !important;
    line-height: 1.02 !important;
  }

  .payscore-hero .decision,
  .payscore-decision-card,
  .payscore-main-decision,
  .payscore-semaphore-card {
    position: relative;
    overflow: hidden;
    border-radius: 24px !important;
  }

  .payscore-metric-card,
  .payscore-kpi-card,
  .payscore-summary-card,
  .payscore-section-grid > article,
  .payscore-dossier-grid > article,
  .payscore-financial-dossier article,
  .payscore-decision-board,
  .payscore-technical-details,
  .payscore-audience-card,
  .payscore-tab-panel {
    border-radius: 22px !important;
    padding: 16px !important;
  }

  .payscore-technical-details summary {
    cursor: pointer;
    display: grid;
    gap: 6px;
    padding: 16px;
    border-radius: 22px;
    background: rgba(39, 199, 255, .08);
    border: 1px solid rgba(39, 199, 255, .18);
  }

  .payscore-history-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 18px;
  }

  .payscore-history-table {
    min-width: 620px;
  }

  .table-wrap,
  .admin-table-wrap,
  .payscore-history-table-wrap {
    margin-left: -2px;
    margin-right: -2px;
  }

  .app-support-card {
    display: none;
  }

  .app-scroll-top-button {
    right: 18px;
    bottom: calc(88px + env(safe-area-inset-bottom));
    width: 46px;
    height: 46px;
    border-radius: 15px;
  }
}

@media (max-width: 520px) {
  .mobile-bottom-nav {
    left: 8px;
    right: 8px;
    gap: 4px;
    padding: 7px;
  }

  .mobile-bottom-nav a {
    font-size: .68rem;
  }

  .mobile-credit-pill small {
    display: none;
  }

  .payscore-report-card-data {
    grid-template-columns: 1fr;
  }

  .report-export-actions {
    grid-template-columns: 1fr;
  }

  .hero-card,
  .content-card,
  .panel-surface.content-card,
  .payscore-form-card,
  .payscore-reports-panel {
    padding: 15px;
  }
}

/* v80 - Mobile dock, cleaner bottom navigation, archive tones and PDF action cleanup */
@media (max-width: 980px) {
  body.app-layout-page .ps-privacy-pill,
  body.app-layout-page .ps-cookie-box {
    display: none !important;
  }

  body.app-layout-page .app-shell,
  body.app-layout-page .app-shell.app-shell-wide {
    padding-bottom: calc(104px + env(safe-area-inset-bottom)) !important;
  }

  .mobile-bottom-nav.mobile-bottom-dock,
  .mobile-bottom-nav {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    min-height: calc(74px + env(safe-area-inset-bottom));
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
    border-radius: 24px 24px 0 0;
    gap: 4px;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    background: linear-gradient(180deg, rgba(9, 21, 40, .96), rgba(4, 10, 20, .98));
    box-shadow: 0 -18px 45px rgba(0, 0, 0, .42);
  }

  .mobile-bottom-nav a {
    min-height: 54px;
    border-radius: 18px;
    display: grid;
    grid-template-rows: 24px auto;
    justify-items: center;
    align-content: center;
    gap: 2px;
    color: rgba(210, 222, 242, .72);
    font-size: .66rem;
    letter-spacing: .01em;
    position: relative;
  }

  .mobile-bottom-nav a i,
  .mobile-bottom-nav a strong {
    width: 26px;
    height: 26px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    font-style: normal;
    font-size: 1rem;
    line-height: 1;
    background: rgba(255, 255, 255, .055);
    border: 1px solid rgba(255, 255, 255, .075);
  }

  .mobile-bottom-nav a.active:not(.mobile-bottom-primary) {
    color: var(--text);
    background: rgba(39, 199, 255, .10);
  }

  .mobile-bottom-nav a.active:not(.mobile-bottom-primary)::before {
    content: '';
    position: absolute;
    top: 5px;
    width: 18px;
    height: 3px;
    border-radius: 999px;
    background: var(--brand);
    box-shadow: 0 0 18px rgba(39, 199, 255, .75);
  }

  .mobile-bottom-nav .mobile-bottom-primary {
    transform: translateY(-13px);
    min-height: 66px;
    border-radius: 24px;
    color: #03101d;
    background: linear-gradient(135deg, var(--brand), rgba(32, 201, 151, .98));
    box-shadow: 0 18px 38px rgba(39, 199, 255, .30);
  }

  .mobile-bottom-nav .mobile-bottom-primary strong {
    width: 34px;
    height: 34px;
    border-radius: 16px;
    font-size: 1.35rem;
    background: rgba(255, 255, 255, .42);
    border: 1px solid rgba(255, 255, 255, .36);
  }

  .app-scroll-top-button {
    bottom: calc(102px + env(safe-area-inset-bottom)) !important;
  }
}

.payscore-report-card.approved,
.payscore-history-item.approved {
  background: linear-gradient(135deg, rgba(32, 201, 151, .28), rgba(255,255,255,.045)) !important;
  border-color: rgba(32, 201, 151, .52) !important;
}

.payscore-report-card.conditional,
.payscore-history-item.conditional {
  background: linear-gradient(135deg, rgba(247, 178, 91, .30), rgba(255,255,255,.045)) !important;
  border-color: rgba(247, 178, 91, .48) !important;
}

.payscore-report-card.rejected,
.payscore-history-item.rejected {
  background: linear-gradient(135deg, rgba(255, 77, 79, .30), rgba(255,255,255,.045)) !important;
  border-color: rgba(255, 77, 79, .54) !important;
}

.payscore-report-card.pending,
.payscore-history-item.pending {
  background: linear-gradient(135deg, rgba(39, 199, 255, .16), rgba(255,255,255,.045)) !important;
  border-color: rgba(39, 199, 255, .32) !important;
}

.report-export-actions.report-export-actions-single {
  justify-content: flex-end;
}

@media (max-width: 520px) {
  .report-export-actions.report-export-actions-single {
    grid-template-columns: 1fr;
  }
}


/* v81 - Dashboard triad, VIES UX, priority signal cards and mobile refinements */
select {
  background-color: rgba(8, 19, 36, .98);
  color: var(--text);
  border-color: rgba(164, 189, 233, .28);
}
select option,
select optgroup {
  background: #081324;
  color: #f5f8ff;
}
select option:checked,
select option:hover {
  background: #153153;
  color: #ffffff;
}

.payscore-history-triad {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.billing-prefill-form-vies {
  display: grid;
  grid-template-columns: minmax(160px, .8fr) minmax(120px, .55fr) minmax(220px, 1fr) auto;
  align-items: end;
  gap: 12px;
}
.billing-prefill-form-vies .billing-foreign-toggle {
  align-self: center;
  min-height: 54px;
}
.billing-prefill-card[data-foreign-eu="0"] .billing-prefill-country {
  opacity: .52;
}
.billing-prefill-card[data-foreign-eu="0"] .billing-prefill-country input {
  pointer-events: none;
}
.billing-rule-card {
  border-color: rgba(39, 199, 255, .28);
  background: linear-gradient(135deg, rgba(39, 199, 255, .12), rgba(255,255,255,.045));
}

.payscore-priority-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}
.payscore-priority-card {
  min-height: 154px;
  padding: clamp(16px, 2vw, 22px);
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.055);
  display: grid;
  align-content: start;
  gap: 8px;
}
.payscore-priority-card span {
  color: var(--text-soft);
  font-size: .74rem;
  font-weight: 950;
  letter-spacing: .095em;
  text-transform: uppercase;
}
.payscore-priority-card strong {
  font-size: clamp(1.15rem, 2vw, 1.7rem);
  line-height: 1.05;
}
.payscore-priority-card p {
  color: rgba(255,255,255,.76);
  line-height: 1.55;
  font-weight: 650;
}
.payscore-priority-success {
  border-color: rgba(32, 201, 151, .48);
  background: linear-gradient(135deg, rgba(32, 201, 151, .22), rgba(255,255,255,.045));
}
.payscore-priority-warning {
  border-color: rgba(247, 178, 91, .52);
  background: linear-gradient(135deg, rgba(247, 178, 91, .26), rgba(255,255,255,.045));
}
.payscore-priority-danger {
  border-color: rgba(255, 77, 79, .56);
  background: linear-gradient(135deg, rgba(255, 77, 79, .30), rgba(255,255,255,.045));
}
.payscore-priority-neutral {
  border-color: rgba(164, 189, 233, .26);
  background: linear-gradient(135deg, rgba(164, 189, 233, .12), rgba(255,255,255,.045));
}

.payscore-view-card.flag-card {
  position: relative;
  overflow: hidden;
  padding-left: clamp(18px, 2.4vw, 26px);
}
.payscore-view-card.flag-card::before {
  content: '';
  position: absolute;
  inset: 14px auto 14px 0;
  width: 5px;
  border-radius: 999px;
  background: rgba(164, 189, 233, .42);
}
.payscore-view-card.flag-card .eyebrow::before {
  margin-right: 7px;
}
.payscore-view-card.red-flag {
  border-color: rgba(255, 77, 79, .54);
  background: linear-gradient(135deg, rgba(255, 77, 79, .22), rgba(255,255,255,.045));
}
.payscore-view-card.red-flag::before { background: #ff4d4f; }
.payscore-view-card.red-flag .eyebrow::before { content: '🔴'; }
.payscore-view-card.green-flag {
  border-color: rgba(32, 201, 151, .52);
  background: linear-gradient(135deg, rgba(32, 201, 151, .20), rgba(255,255,255,.045));
}
.payscore-view-card.green-flag::before { background: #20c997; }
.payscore-view-card.green-flag .eyebrow::before { content: '🟢'; }

.payscore-pending-card {
  overflow: visible;
  isolation: isolate;
}
.payscore-pending-card .tech-pulse {
  z-index: 0;
  opacity: .46;
  pointer-events: none;
}
.payscore-pending-card > :not(.tech-pulse) {
  position: relative;
  z-index: 1;
}
.payscore-pending-card-timed {
  align-content: start;
  padding-top: clamp(22px, 4vw, 34px);
}
.payscore-countdown {
  position: relative;
  z-index: 2;
}

@media (max-width: 1180px) {
  .billing-prefill-form-vies,
  .payscore-priority-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
  body.app-layout-page .app-shell,
  body.app-layout-page .app-shell.app-shell-wide {
    padding-bottom: calc(94px + env(safe-area-inset-bottom)) !important;
  }
  .mobile-bottom-nav.mobile-bottom-dock,
  .mobile-bottom-nav {
    min-height: calc(68px + env(safe-area-inset-bottom)) !important;
    padding: 6px 8px calc(6px + env(safe-area-inset-bottom)) !important;
    border-radius: 22px 22px 0 0 !important;
    background: linear-gradient(180deg, rgba(8, 20, 38, .985), rgba(3, 8, 17, .995)) !important;
  }
  .mobile-bottom-nav a {
    min-height: 50px !important;
    border-radius: 16px !important;
    grid-template-rows: 21px auto !important;
    font-size: .62rem !important;
  }
  .mobile-bottom-nav a i,
  .mobile-bottom-nav a strong {
    width: 23px !important;
    height: 23px !important;
    border-radius: 10px !important;
    background: transparent !important;
    border: 0 !important;
  }
  .mobile-bottom-nav .mobile-bottom-primary {
    transform: none !important;
    min-height: 52px !important;
    border-radius: 18px !important;
    color: #03101d !important;
    background: linear-gradient(135deg, var(--brand), #20c997) !important;
  }
  .mobile-bottom-nav .mobile-bottom-primary strong {
    width: 26px !important;
    height: 26px !important;
    border-radius: 13px !important;
    font-size: 1.05rem !important;
    background: rgba(255,255,255,.42) !important;
  }
  .mobile-bottom-nav a.active:not(.mobile-bottom-primary)::before {
    top: 3px !important;
    height: 2px !important;
  }
  .app-scroll-top-button {
    bottom: calc(86px + env(safe-area-inset-bottom)) !important;
  }
  .payscore-history-triad {
    display: flex !important;
    grid-template-columns: none !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }
  .payscore-history-triad .payscore-history-item {
    flex: 0 0 min(84vw, 330px);
    scroll-snap-align: start;
  }
  .payscore-pending-card-timed {
    min-height: auto;
    gap: 12px;
  }
  .payscore-countdown {
    max-width: none;
    margin: 12px 0 0;
    padding: 16px;
  }
  .payscore-countdown strong {
    font-size: clamp(2.45rem, 16vw, 4rem);
    letter-spacing: -.055em;
  }
}

@media (max-width: 560px) {
  .payscore-priority-card {
    min-height: 0;
  }
  .billing-prefill-form-vies {
    gap: 10px;
  }
}


/* v82 - Processing timer, annual subscriptions and redesigned VAT prefill */
.payscore-processing-card {
  overflow: visible !important;
  min-height: 0 !important;
  align-content: stretch !important;
  margin-top: clamp(14px, 2.5vw, 24px);
  padding: clamp(18px, 3vw, 32px) !important;
  position: relative;
  z-index: 1;
}
.payscore-processing-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: clamp(18px, 3vw, 34px);
  align-items: center;
}
.payscore-processing-copy {
  display: grid;
  gap: 12px;
  align-content: start;
}
.payscore-processing-copy h1 {
  margin: 0;
  font-size: clamp(1.1rem, 2vw, 1.45rem);
  color: var(--text-soft);
}
.payscore-processing-copy h2 {
  margin: 0;
  font-size: clamp(1.95rem, 4vw, 3.6rem);
  line-height: .98;
}
.payscore-processing-copy p {
  max-width: 720px;
  margin: 0;
}
.payscore-processing-timer {
  display: grid;
  gap: 12px;
  min-width: 0;
  position: relative;
  z-index: 2;
}
.payscore-processing-card .payscore-countdown {
  margin: 0 !important;
  max-width: none !important;
  min-width: 0;
  overflow-wrap: anywhere;
  box-shadow: 0 18px 44px rgba(0,0,0,.22);
}
.payscore-processing-card .tech-pulse {
  position: static !important;
  z-index: 1 !important;
  justify-self: start;
  opacity: .9 !important;
}
.billing-prefill-card-modern {
  padding: clamp(16px, 2.4vw, 24px);
  border-radius: 28px;
  border: 1px solid rgba(39, 199, 255, .24);
  background: linear-gradient(135deg, rgba(39, 199, 255, .10), rgba(255,255,255,.045));
  box-shadow: 0 18px 44px rgba(0,0,0,.14);
}
.billing-prefill-head {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}
.billing-prefill-head strong {
  display: block;
  margin: 4px 0 6px;
  font-size: clamp(1.18rem, 2vw, 1.55rem);
  letter-spacing: -.035em;
}
.billing-prefill-head p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.55;
}
.billing-prefill-form-modern {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
}
.billing-prefill-mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.billing-prefill-mode {
  display: grid;
  cursor: pointer;
  min-height: 96px;
}
.billing-prefill-mode input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.billing-prefill-mode span {
  display: grid;
  gap: 7px;
  padding: 15px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,255,255,.055);
  color: var(--text);
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
}
.billing-prefill-mode b {
  font-size: .98rem;
}
.billing-prefill-mode small {
  color: var(--text-soft);
  line-height: 1.35;
}
.billing-prefill-mode.active span,
.billing-prefill-mode:has(input:checked) span {
  border-color: rgba(39, 199, 255, .56);
  background: linear-gradient(135deg, rgba(39, 199, 255, .18), rgba(32, 201, 151, .10));
  transform: translateY(-1px);
}
.billing-prefill-input-grid {
  display: grid;
  grid-template-columns: minmax(96px, 140px) minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}
.billing-prefill-input-grid label {
  min-width: 0;
}
.billing-prefill-submit {
  min-height: 56px;
  white-space: nowrap;
}
.billing-prefill-card-modern[data-foreign-eu="0"] .billing-prefill-country {
  opacity: .46;
}
.billing-prefill-card-modern[data-foreign-eu="0"] .billing-prefill-country input {
  pointer-events: none;
}
.app-plan-renewal {
  margin-top: -4px !important;
  color: rgba(52, 215, 161, .92) !important;
  font-weight: 850;
  font-size: .86rem;
}
@media (max-width: 980px) {
  .payscore-processing-layout,
  .billing-prefill-mode-grid,
  .billing-prefill-input-grid {
    grid-template-columns: 1fr;
  }
  .payscore-processing-card {
    margin-top: 10px;
    padding: 18px !important;
  }
  .payscore-processing-copy h2 {
    font-size: clamp(2rem, 11vw, 3rem);
  }
  .payscore-processing-card .payscore-countdown strong {
    font-size: clamp(2.65rem, 18vw, 4.2rem) !important;
    line-height: .9 !important;
  }
  .billing-prefill-submit {
    width: 100%;
  }
}
@media (max-width: 560px) {
  .payscore-processing-card .tech-pulse {
    width: 100%;
    justify-content: center;
  }
  .billing-prefill-mode {
    min-height: 0;
  }
}

/* PayScore v88: indicatori coerenti anteprime/report */
.payscore-mini-score-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
  opacity: 1 !important;
  width: 100%;
}
.payscore-mini-score-grid > span {
  display: grid;
  gap: 3px;
  padding: 8px 9px;
  border-radius: 13px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.10);
  min-width: 0;
  opacity: 1 !important;
}
.payscore-mini-score-grid b {
  display: block;
  font-size: .62rem;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.64);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.payscore-mini-score-grid strong {
  display: block;
  font-size: .98rem;
  line-height: 1.05;
  color: #fff;
}
.payscore-mini-score-grid.report-card > span {
  padding: 10px 9px;
  background: rgba(255,255,255,.085);
}
.payscore-mini-score-grid.report-card strong {
  font-size: 1.08rem;
}
@media (max-width: 520px) {
  .payscore-mini-score-grid {
    gap: 6px;
  }
  .payscore-mini-score-grid > span {
    padding: 8px 6px;
  }
  .payscore-mini-score-grid b {
    font-size: .56rem;
    letter-spacing: .04em;
  }
}

/* PayScore performance: meno reflow su report statici, tab e dossier tecnico. */
.payscore-audience-tabs.is-js-tabs .payscore-tab-panel:not([hidden]) {
  display: grid !important;
  content-visibility: auto;
  contain: layout style paint;
  contain-intrinsic-size: 780px;
}
.payscore-audience-tabs.is-js-tabs .payscore-tab-panel[hidden] {
  display: none !important;
}
.payscore-audience-tabs.is-js-tabs .payscore-tab-nav [aria-selected="true"] {
  color: #fff;
  background: linear-gradient(135deg, rgba(32,201,151,.28), rgba(255,255,255,.075));
  border-color: rgba(32,201,151,.38);
  box-shadow: 0 10px 24px rgba(0,0,0,.14);
}
.payscore-static-report-fragment,
.payscore-report {
  contain: layout style;
}
.payscore-technical-details:not([open]) > :not(summary) {
  display: none !important;
}
.payscore-technical-details[open] > section,
.payscore-technical-details[open] > .payscore-section-grid,
.payscore-technical-details[open] > .panel-surface {
  content-visibility: auto;
  contain: layout style paint;
  contain-intrinsic-size: 900px;
}
.payscore-history-table-wrap,
.payscore-linked-table,
.payscore-info-list {
  content-visibility: auto;
  contain-intrinsic-size: 420px;
}


/* HUB v12 - allineamento PayScore senza cambiare logo ReportAziende */
.ps-site-brand img,
.auth-logo,
.sidebar-brand img,
.mobile-app-logo img,
.ps-footer-logo,
.payscore-logo-img {
    object-fit: contain;
    height: auto;
}
.ps-brand-wordmark { display: none !important; }
.sidebar-brand-link { text-decoration: none; }
.sidebar-brand-link p { margin: 10px 0 0; }
.sidebar-nav > a:first-child { border-style: dashed; }
.ra-bonus-note {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: rgba(52, 215, 161, 0.08);
    color: var(--text-soft);
}
.ra-bonus-note.personal { background: rgba(247, 178, 91, 0.08); }
.ra-bonus-dot {
    width: 10px;
    height: 10px;
    margin-top: 6px;
    flex: 0 0 auto;
    border-radius: 999px;
    background: var(--success);
    box-shadow: 0 0 0 5px rgba(52, 215, 161, 0.12);
}
.ra-bonus-note.personal .ra-bonus-dot { background: var(--warning); box-shadow: 0 0 0 5px rgba(247, 178, 91, 0.12); }
.ps-site-footer .row { width: 100%; }


/* HUB v13 emergency visual fix: keep original ReportAziende logo, PayScore menu/CTA structure and stable app shell. */
body.public-site-page,
body.auth-page,
body.app-layout-page {
  background: var(--bg, #04101f);
  color: var(--text, #f7fbff);
}
.ps-site-navbar .ps-site-nav-inner {
  min-height: 72px;
}
.ps-site-navbar .ps-site-menu {
  flex-wrap: nowrap;
  white-space: nowrap;
}
.ps-site-navbar .navbar-nav {
  gap: .5rem;
}
.ps-site-navbar .nav-link,
.ps-login-cta,
.ps-site-nav-cta {
  white-space: nowrap;
}
.ps-site-navbar .ps-site-brand {
  min-width: 0;
  flex: 0 0 auto;
  margin-right: clamp(18px, 4vw, 56px);
}
.ps-site-navbar .hub-header-logo,
.ps-site-brand .hub-header-logo,
.ps-site-brand .payscore-logo-img,
.auth-logo,
.sidebar-brand img,
.mobile-app-logo img,
.ps-site-footer .payscore-logo-img {
  display: block;
  object-fit: contain !important;
  object-position: left center;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.ps-site-navbar .hub-header-logo,
.ps-site-brand .hub-header-logo {
  width: clamp(220px, 20vw, 300px) !important;
  max-width: 300px !important;
  height: auto !important;
  max-height: 46px !important;
}
.auth-logo {
  width: min(430px, 100%) !important;
  max-height: 76px !important;
}
.sidebar-brand img {
  width: min(240px, 100%) !important;
  max-height: 58px !important;
}
.ps-site-footer .payscore-logo-img {
  width: min(300px, 100%) !important;
  max-height: 54px !important;
}
.app-shell {
  display: grid !important;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: var(--container-pad, 22px);
  visibility: visible !important;
  opacity: 1 !important;
}
.app-shell > .sidebar,
.app-shell > .app-main {
  visibility: visible !important;
  opacity: 1 !important;
}
.app-main {
  color: var(--text, #f7fbff) !important;
  min-width: 0;
}
.mobile-app-chrome {
  display: none;
}
@media (max-width: 1180px) {
  .ps-site-navbar .ps-site-menu {
    white-space: normal;
    flex-wrap: wrap;
  }
  .ps-site-navbar .hub-header-logo {
    width: clamp(190px, 32vw, 270px) !important;
  }
}
@media (max-width: 991px) {
  .ps-site-navbar .ps-site-menu {
    display: grid;
    gap: 8px;
    padding-top: 14px;
    white-space: normal;
  }
  .ps-login-cta,
  .ps-site-nav-cta {
    width: 100%;
    justify-content: center;
  }
  .app-shell {
    grid-template-columns: 1fr;
    min-height: 100vh;
    padding-top: calc(78px + env(safe-area-inset-top));
  }
  .mobile-app-chrome {
    display: block;
  }
  .sidebar {
    display: none !important;
  }
  body.app-layout-page {
    height: auto !important;
    overflow: auto !important;
  }
  body.app-layout-page .app-shell,
  body.app-layout-page .app-shell > .app-main {
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }
}
@media (min-width: 992px) {
  body.app-layout-page .mobile-app-chrome {
    display: none !important;
  }
}


/* HUB v14: registrazione pulita + app shell non nera. */
.auth-legal-consent > p { display: none !important; }
.ra-bonus-note { display: none !important; }
body.app-layout-page .app-shell { background: transparent !important; }
body.app-layout-page .app-main { background: transparent !important; color: var(--text, #f7fbff) !important; }
body.app-layout-page .panel-surface,
body.app-layout-page .content-card,
body.app-layout-page .hero-card { color: var(--text, #f7fbff); }


/* HUB v17: sidebar support card aligned to PayScore family */
.sidebar-support-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(39, 199, 255, .24);
  background:
    radial-gradient(circle at 20% 0%, rgba(39,199,255,.18), transparent 36%),
    linear-gradient(135deg, rgba(15,23,42,.92), rgba(30,58,138,.55));
  box-shadow: 0 20px 54px rgba(0,0,0,.22);
  color: var(--text);
}
.sidebar-support-copy { display: grid; gap: 6px; min-width: 0; }
.sidebar-support-eyebrow {
  color: rgba(125, 211, 252, .9);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 900;
}
.sidebar-support-copy strong {
  color: #fff;
  font-size: 1rem;
  line-height: 1.12;
  letter-spacing: -.02em;
}
.sidebar-support-copy small {
  color: rgba(226,232,240,.78);
  line-height: 1.45;
  font-size: .82rem;
}
.sidebar-support-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 14px;
  border-radius: 16px;
  background: linear-gradient(135deg, #27c7ff, #20c997);
  color: #06121f !important;
  text-decoration: none;
  font-weight: 950;
  box-shadow: 0 16px 36px rgba(39,199,255,.20);
}
.sidebar-support-link:hover { transform: translateY(-1px); filter: brightness(1.04); }
.auth-otp-copy { margin-bottom: 4px; }
.auth-link-button {
  appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  color: var(--text-soft);
  text-decoration: none;
  padding: 8px 0 0;
}
.auth-link-button:hover { color: var(--text); text-decoration: underline; }
.billing-vies-status { line-height: 1.45; }

/* HUB v18: card Movimenti crediti aligned to PayScore/HUB visual language */
.credit-movements-card {
  display: grid;
  gap: 20px;
  overflow: hidden;
}
.credit-movements-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}
.credit-movements-head h2 {
  margin: 4px 0 8px;
  color: #fff;
  font-size: clamp(1.28rem, 2.2vw, 1.7rem);
  letter-spacing: -.04em;
}
.credit-movements-head p {
  margin: 0;
  max-width: 620px;
  color: rgba(226, 232, 240, .76);
  line-height: 1.55;
}
.credit-balance-chip {
  flex: 0 0 auto;
  min-width: 148px;
  padding: 14px 16px;
  border-radius: 22px;
  border: 1px solid rgba(39, 199, 255, .24);
  background:
    radial-gradient(circle at 20% 10%, rgba(39,199,255,.20), transparent 38%),
    linear-gradient(135deg, rgba(15,23,42,.88), rgba(15,118,110,.42));
  box-shadow: 0 16px 40px rgba(0,0,0,.18);
  text-align: right;
}
.credit-balance-chip strong {
  display: block;
  color: #fff;
  font-size: 1.75rem;
  line-height: 1;
  letter-spacing: -.05em;
}
.credit-balance-chip span {
  display: block;
  margin-top: 5px;
  color: rgba(226,232,240,.78);
  font-size: .78rem;
  font-weight: 800;
}
.credit-movements-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.credit-movements-kpis article {
  min-width: 0;
  padding: 14px 15px;
  border-radius: 20px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(15, 23, 42, .52);
}
.credit-movements-kpis span {
  display: block;
  color: rgba(203,213,225,.72);
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.credit-movements-kpis strong {
  display: block;
  margin-top: 7px;
  color: #fff;
  font-size: 1.05rem;
  line-height: 1.15;
}
.credit-movement-list {
  display: grid;
  gap: 10px;
}
.credit-movement-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  align-items: center;
  gap: 13px;
  padding: 13px;
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, .16);
  background: rgba(15, 23, 42, .50);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.035);
}
.credit-movement-item:hover {
  border-color: rgba(39,199,255,.28);
  background: rgba(15, 23, 42, .66);
}
.credit-movement-icon {
  width: 42px;
  height: 42px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-size: 1.15rem;
  font-weight: 950;
  color: #06121f;
  background: linear-gradient(135deg, #27c7ff, #20c997);
  box-shadow: 0 14px 30px rgba(39,199,255,.16);
}
.credit-movement-item.is-negative .credit-movement-icon {
  color: #fff;
  background: linear-gradient(135deg, rgba(248,113,113,.92), rgba(251,146,60,.86));
  box-shadow: 0 14px 30px rgba(248,113,113,.13);
}
.credit-movement-main {
  min-width: 0;
}
.credit-movement-main strong {
  display: block;
  color: #fff;
  font-weight: 900;
  letter-spacing: -.02em;
}
.credit-movement-main p {
  margin: 4px 0 0;
  color: rgba(226,232,240,.70);
  font-size: .86rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.credit-movement-main time {
  display: block;
  margin-top: 6px;
  color: rgba(148,163,184,.82);
  font-size: .76rem;
  font-weight: 750;
}
.credit-movement-amount {
  min-width: 74px;
  text-align: right;
  font-size: 1.05rem;
  font-weight: 950;
  letter-spacing: -.02em;
  color: #8fffe4;
}
.credit-movement-amount.is-negative {
  color: #fecaca;
}
.credit-empty-state {
  padding: 18px;
  border-radius: 22px;
  border: 1px dashed rgba(148,163,184,.28);
  background: rgba(15,23,42,.46);
}
.credit-empty-state strong {
  display: block;
  color: #fff;
  font-size: 1rem;
}
.credit-empty-state p {
  margin: 6px 0 0;
  color: rgba(226,232,240,.72);
  line-height: 1.5;
}
@media (max-width: 860px) {
  .credit-movements-head {
    flex-direction: column;
  }
  .credit-balance-chip {
    width: 100%;
    text-align: left;
  }
  .credit-movements-kpis {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 560px) {
  .credit-movement-item {
    grid-template-columns: 38px minmax(0, 1fr);
  }
  .credit-movement-amount {
    grid-column: 2;
    text-align: left;
    margin-top: -4px;
  }
}

/* HUB v19 public site expansion: SEO pages, accessibility and visual structure. */
.ps-skip-link {
  position: fixed;
  left: 16px;
  top: 12px;
  z-index: 2000;
  transform: translateY(-140%);
  padding: 10px 14px;
  border-radius: 12px;
  background: #ffffff;
  color: #06111f !important;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 18px 40px rgba(0, 0, 0, .28);
}
.ps-skip-link:focus {
  transform: translateY(0);
}
.ps-btn-secondary,
.ps-login-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  padding: 14px 18px;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  font-weight: 900;
  text-decoration: none;
}
.ps-login-cta {
  padding: 10px 12px;
  color: rgba(246,249,255,.84) !important;
}
.ps-btn-primary:hover,
.ps-btn-secondary:hover,
.ps-site-nav-cta:hover,
.ps-login-cta:hover {
  transform: translateY(-1px);
}
.ps-hero-enhanced {
  position: relative;
  overflow: hidden;
}
.ps-hero-enhanced::before,
.ps-page-main::before {
  content: '';
  position: absolute;
  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: 42px 42px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.55), transparent 62%);
}
.ps-page-main {
  position: relative;
  overflow: hidden;
}
.ps-page-main > * {
  position: relative;
  z-index: 1;
}
.ps-hub-visual-card,
.ps-dashboard-preview,
.ps-worker-card,
.ps-page-stat,
.ps-contact-card-main,
.ps-contact-method,
.ps-contact-note,
.ps-contact-strip-card,
.ps-footer-company-card {
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.045));
  box-shadow: 0 28px 80px rgba(0,0,0,.28);
  border-radius: 30px;
  color: #f6f9ff;
}
.ps-hub-visual-card {
  position: relative;
  overflow: hidden;
  padding: clamp(24px, 4vw, 36px);
}
.ps-orbit {
  position: absolute;
  inset: -45px -50px auto auto;
  width: 210px;
  height: 210px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(36,230,168,.26), transparent 62%);
}
.ps-orbit span {
  position: absolute;
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 999px;
  inset: 18px;
}
.ps-orbit span:nth-child(2) { inset: 48px; }
.ps-orbit span:nth-child(3) { inset: 78px; background: rgba(56,220,255,.20); }
.ps-card-label {
  display: inline-flex;
  margin-bottom: 14px;
  color: #06111f;
  background: linear-gradient(135deg, #24e6a8, #38dcff);
  border-radius: 999px;
  padding: 8px 11px;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.ps-hub-visual-card h2,
.ps-dashboard-preview strong,
.ps-contact-strip-card h2,
.ps-contact-method h2,
.ps-contact-note h2,
.ps-worker-card span,
.ps-page-stat strong,
.ps-contact-card-main strong {
  color: #ffffff;
  font-weight: 950;
  letter-spacing: -.04em;
}
.ps-hub-pipeline {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 24px 0;
}
.ps-hub-pipeline article {
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  background: rgba(6,17,31,.42);
}
.ps-hub-pipeline strong {
  display: block;
  color: #38dcff;
  font-size: 22px;
  line-height: 1;
}
.ps-hub-pipeline span,
.ps-visual-result span,
.ps-page-stat span,
.ps-page-stat small,
.ps-worker-card p,
.ps-contact-card-main span,
.ps-contact-method p,
.ps-contact-note li,
.ps-contact-strip-card p,
.ps-footer-company-card span {
  color: #c2d2e5;
  line-height: 1.6;
}
.ps-visual-result {
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 18px;
}
.ps-visual-result b {
  display: block;
  color: #24e6a8;
  margin-bottom: 4px;
}
.ps-feature-card-visual {
  position: relative;
  overflow: hidden;
}
.ps-feature-card-visual::after {
  content: '';
  position: absolute;
  right: -40px;
  bottom: -48px;
  width: 150px;
  height: 150px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(56,220,255,.22), transparent 68%);
}
.ps-dashboard-preview {
  overflow: hidden;
  padding: 16px;
}
.ps-preview-topbar {
  display: flex;
  gap: 8px;
  padding: 4px 4px 16px;
}
.ps-preview-topbar span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.34);
}
.ps-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.ps-preview-grid article {
  min-height: 128px;
  border-radius: 22px;
  padding: 20px;
  background: #ffffff;
  color: #06111f;
}
.ps-preview-grid article.wide { grid-column: 1 / -1; }
.ps-preview-grid article.muted { background: rgba(255,255,255,.10); color: #f6f9ff; border: 1px solid rgba(255,255,255,.12); }
.ps-preview-grid small,
.ps-pricing-benefits strong,
.ps-footer-hotline-eyebrow {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 950;
  color: #2d8cff;
}
.ps-preview-grid strong {
  display: block;
  margin: 8px 0;
  font-size: 24px;
  color: #06111f;
}
.ps-preview-grid p { color: #53687f; margin: 0; line-height: 1.55; }
.ps-preview-grid article.muted small,
.ps-preview-grid article.muted p { color: #c2d2e5; }
.ps-page-hero-grid { padding-bottom: 58px; }
.ps-page-stat {
  padding: 28px;
}
.ps-page-stat strong {
  display: block;
  font-size: clamp(58px, 8vw, 92px);
  line-height: .85;
  color: #24e6a8;
}
.ps-page-stat span {
  display: block;
  margin-top: 10px;
  font-weight: 900;
  color: #ffffff;
}
.ps-process-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.ps-process-grid article {
  min-height: 230px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 26px;
  padding: 24px;
  background: rgba(255,255,255,.06);
  color: #f6f9ff;
}
.ps-process-grid b {
  display: inline-flex;
  width: 48px;
  height: 48px;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: linear-gradient(135deg, #2d8cff, #24e6a8);
  color: #06111f;
  font-weight: 950;
  margin-bottom: 16px;
}
.ps-process-grid h3,
.ps-faq-grid h3 {
  color: #ffffff;
  font-weight: 950;
  letter-spacing: -.03em;
}
.ps-process-grid p,
.ps-faq-grid p { color: #c2d2e5; line-height: 1.65; }
.ps-worker-card {
  padding: 30px;
}
.ps-worker-bars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin: 24px 0;
}
.ps-worker-bars i {
  display: block;
  min-height: 90px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(56,220,255,.45), rgba(36,230,168,.08));
}
.ps-worker-bars i:nth-child(2) { min-height: 132px; }
.ps-worker-bars i:nth-child(3) { min-height: 112px; }
.ps-worker-bars i:nth-child(4) { min-height: 156px; }
.ps-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.ps-faq-grid article {
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 24px;
  padding: 24px;
  background: rgba(255,255,255,.06);
}
.ps-pricing-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 26px;
}
.ps-pricing-benefits article {
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 20px;
  padding: 20px;
  background: rgba(255,255,255,.055);
}
.ps-pricing-benefits span { display: block; color: #c2d2e5; margin-top: 6px; line-height: 1.55; }
.ps-contact-strip-section {
  padding: 40px 0 78px;
  background: #06111f;
}
.ps-contact-strip-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 24px;
  padding: clamp(24px, 4vw, 38px);
}
.ps-contact-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.ps-contact-card-main,
.ps-contact-method,
.ps-contact-note,
.ps-footer-company-card {
  padding: 26px;
}
.ps-contact-card-main span,
.ps-footer-company-card span,
.ps-footer-company-card a {
  display: block;
  margin-top: 8px;
}
.ps-contact-method span {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: linear-gradient(135deg, #2d8cff, #24e6a8);
  color: #06111f;
  font-weight: 950;
  margin-bottom: 16px;
}
.ps-contact-method a,
.ps-footer-company-card a {
  color: #38dcff;
  font-weight: 900;
  text-decoration: none;
}
.ps-contact-note {
  margin-top: 22px;
}
.ps-footer-mini-badges {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 16px;
}
.ps-footer-mini-badges span {
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 7px 10px;
  color: #c2d2e5;
  font-size: 12px;
  font-weight: 850;
}
.ps-footer-hotline-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  padding: 20px;
  background: rgba(255,255,255,.055);
}
.ps-footer-hotline-copy strong { display: block; color: #ffffff; }
.ps-footer-company-card { min-height: 100%; }
/* Override the legacy emergency rule that hid keyboard focus indicators. */
.ps-site-footer a:focus-visible,
.ps-btn-primary:focus-visible,
.ps-btn-secondary:focus-visible,
.ps-btn-ghost:focus-visible,
.ps-site-nav-cta:focus-visible,
.ps-login-cta:focus-visible,
.primary-cta:focus-visible,
.ghost-button:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.nav-link:focus-visible,
.ps-cookie-btn:focus-visible,
.ps-privacy-pill:focus-visible {
  display: inline-flex !important;
  outline: 3px solid #38dcff !important;
  outline-offset: 3px !important;
  box-shadow: 0 0 0 6px rgba(56,220,255,.18) !important;
}
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  display: block !important;
}
.ps-site-footer a:focus-visible,
.nav-link:focus-visible {
  display: block !important;
}
@media (max-width: 991px) {
  .ps-process-grid,
  .ps-pricing-benefits,
  .ps-contact-strip-card { grid-template-columns: 1fr; }
  .ps-contact-actions { justify-content: flex-start; }
  .ps-preview-grid,
  .ps-faq-grid { grid-template-columns: 1fr; }
  .ps-hub-pipeline { grid-template-columns: 1fr; }
}
@media (max-width: 575px) {
  .ps-contact-actions a,
  .ps-hero-actions a { width: 100%; }
  .ps-footer-hotline-card { display: grid; }
}

/* HUB v20 - footer stabile, FAQ accordion, prezzi/servizi compatti */
.ps-site-footer {
  background:
    radial-gradient(circle at 88% 0%, rgba(45,140,255,.18), transparent 34%),
    #050d19;
  border-top: 1px solid rgba(255,255,255,.12);
  padding: clamp(44px, 6vw, 72px) 0 30px;
}
.ps-footer-shell {
  display: grid;
  grid-template-columns: minmax(250px, .95fr) minmax(320px, 1.15fr) minmax(280px, .9fr);
  gap: clamp(18px, 3vw, 34px);
  align-items: stretch;
}
.ps-footer-brand-panel,
.ps-footer-contact-panel {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 26px;
  background: linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
  padding: clamp(22px, 3vw, 30px);
  min-width: 0;
}
.ps-footer-brand-link,
.ps-site-footer .ps-footer-brand-link {
  display: inline-flex !important;
  align-items: center;
  width: auto;
  max-width: 100%;
  margin: 0 0 18px;
  text-decoration: none;
}
.ps-footer-brand-link .payscore-logo-img,
.ps-site-footer .ps-footer-brand-link .payscore-logo-img {
  width: min(270px, 100%) !important;
  max-height: 52px !important;
  object-fit: contain !important;
  object-position: left center;
}
.ps-footer-brand-panel p,
.ps-footer-contact-panel p {
  color: #c2d2e5;
  line-height: 1.65;
  margin: 0;
}
.ps-footer-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  min-width: 0;
}
.ps-footer-nav > div {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 22px;
  background: rgba(255,255,255,.04);
  padding: 22px;
}
.ps-footer-nav h3,
.ps-footer-contact-panel > strong,
.ps-footer-company-meta strong {
  color: #fff;
}
.ps-footer-nav h3 {
  margin: 0 0 14px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .13em;
  font-weight: 950;
}
.ps-site-footer .ps-footer-nav a,
.ps-footer-company-meta a,
.ps-footer-email-link {
  display: block;
  width: fit-content;
  color: #c2d2e5;
  text-decoration: none;
  margin: 10px 0 0;
  line-height: 1.35;
}
.ps-site-footer .ps-footer-nav a:hover,
.ps-footer-company-meta a:hover,
.ps-footer-email-link:hover {
  color: #38dcff;
}
.ps-footer-contact-panel {
  display: grid;
  gap: 14px;
  align-content: start;
}
.ps-footer-contact-panel > strong {
  display: block;
  font-size: 1.3rem;
  line-height: 1.05;
  letter-spacing: -.04em;
}
.ps-footer-contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.ps-site-footer .ps-footer-hotline-link,
.ps-site-footer .ps-footer-hotline-link:focus-visible {
  display: inline-flex !important;
  width: auto;
  margin: 0;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: .72rem 1rem;
  color: #06111f !important;
  background: linear-gradient(135deg, #24e6a8, #39c7ff);
  font-weight: 950;
  text-decoration: none;
}
.ps-site-footer .ps-footer-email-link,
.ps-site-footer .ps-footer-email-link:focus-visible {
  display: inline-flex !important;
  margin: 0;
  padding: .7rem .9rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,255,255,.055);
  color: #eaf4ff;
  font-weight: 850;
}
.ps-footer-company-meta {
  border-top: 1px solid rgba(255,255,255,.10);
  padding-top: 14px;
  margin-top: 2px;
}
.ps-footer-company-meta span,
.ps-footer-company-meta a {
  display: block;
  color: #aebfd2;
  margin-top: 6px;
  line-height: 1.55;
}
.ps-site-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.12);
  margin-top: 28px;
  padding-top: 20px;
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
  gap: 16px;
  color: #aebfd2;
  font-size: 12px;
}

.ps-pricing-layout {
  display: grid;
  grid-template-columns: minmax(300px, .86fr) minmax(0, 1.14fr);
  gap: clamp(18px, 3vw, 28px);
  align-items: stretch;
}
.ps-pricing-card-compact {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(56,220,255,.32);
  border-radius: 30px;
  padding: clamp(24px, 4vw, 34px);
  background:
    radial-gradient(circle at 90% 8%, rgba(36,230,168,.24), transparent 30%),
    linear-gradient(180deg, rgba(45,140,255,.22), rgba(255,255,255,.055));
  box-shadow: 0 24px 60px rgba(0,0,0,.24);
}
.ps-pricing-card-compact h2 {
  color: #fff;
  font-size: clamp(28px, 3.4vw, 42px);
  line-height: 1;
  letter-spacing: -.06em;
  font-weight: 950;
  margin: 0 0 12px;
}
.ps-plan-headline p,
.ps-price-note,
.ps-pricing-fineprint {
  color: #c2d2e5;
  line-height: 1.6;
}
.ps-pricing-card-compact .ps-price {
  margin-top: 22px;
  font-size: clamp(44px, 5vw, 64px);
}
.ps-price small {
  font-size: .32em;
  letter-spacing: 0;
  margin-left: 6px;
  color: #c2d2e5;
}
.ps-pricing-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 22px 0;
}
.ps-pricing-metrics span {
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 18px;
  background: rgba(6,17,31,.32);
  padding: 14px;
  color: #c2d2e5;
  line-height: 1.25;
}
.ps-pricing-metrics strong {
  display: block;
  color: #24e6a8;
  font-size: 1.45rem;
  line-height: 1;
}
.ps-service-stack {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.ps-service-stack article {
  min-height: 210px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 26px;
  padding: 24px;
  background: rgba(255,255,255,.06);
  color: #f6f9ff;
}
.ps-service-stack article span {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: linear-gradient(135deg, #2d8cff, #24e6a8);
  color: #06111f;
  font-weight: 950;
  margin-bottom: 18px;
}
.ps-service-stack h3 {
  color: #fff;
  font-weight: 950;
  letter-spacing: -.035em;
  margin-bottom: 8px;
}
.ps-service-stack p {
  color: #c2d2e5;
  line-height: 1.62;
  margin: 0;
}
.ps-pricing-credit-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.ps-pricing-credit-strip article {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  padding: 20px;
  background: rgba(255,255,255,.045);
}
.ps-pricing-credit-strip strong {
  display: block;
  color: #38dcff;
  font-size: 1.7rem;
  font-weight: 950;
  line-height: 1;
  margin-bottom: 8px;
}
.ps-pricing-credit-strip span {
  color: #c2d2e5;
  line-height: 1.52;
}
.ps-pricing-benefits-wide {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ps-faq-accordion {
  display: grid;
  gap: 22px;
}
.ps-faq-group {
  display: grid;
  grid-template-columns: minmax(210px, .34fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.ps-faq-group-heading {
  position: sticky;
  top: 96px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 24px;
  padding: 22px;
  background: rgba(255,255,255,.055);
}
.ps-faq-group-heading span {
  display: inline-flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: #06111f;
  background: linear-gradient(135deg, #2d8cff, #24e6a8);
  font-weight: 950;
  margin-bottom: 14px;
}
.ps-faq-group-heading h2 {
  color: #fff;
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1;
  letter-spacing: -.04em;
  margin: 0;
}
.ps-faq-items {
  display: grid;
  gap: 12px;
}
.ps-faq-item {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  background: rgba(255,255,255,.055);
  overflow: hidden;
}
.ps-faq-item[open] {
  background: linear-gradient(180deg, rgba(45,140,255,.16), rgba(255,255,255,.055));
  border-color: rgba(56,220,255,.26);
}
.ps-faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  cursor: pointer;
  list-style: none;
  padding: 20px 22px;
  color: #fff;
  font-weight: 950;
  letter-spacing: -.02em;
}
.ps-faq-item summary::-webkit-details-marker {
  display: none;
}
.ps-faq-item summary::after {
  content: '+';
  flex: 0 0 auto;
  display: inline-flex;
  width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: #38dcff;
  font-size: 22px;
  line-height: 1;
}
.ps-faq-item[open] summary::after {
  content: '-';
  color: #24e6a8;
}
.ps-faq-answer {
  padding: 0 22px 22px;
}
.ps-faq-answer p {
  margin: 0;
  color: #c2d2e5;
  line-height: 1.7;
}

.ps-footer-brand-link:focus-visible,
.ps-footer-nav a:focus-visible,
.ps-footer-hotline-link:focus-visible,
.ps-footer-email-link:focus-visible,
.ps-footer-company-meta a:focus-visible,
.ps-faq-item summary:focus-visible {
  outline: 3px solid #38dcff !important;
  outline-offset: 4px !important;
  box-shadow: 0 0 0 6px rgba(56,220,255,.16) !important;
}

@media (max-width: 1100px) {
  .ps-footer-shell,
  .ps-pricing-layout,
  .ps-faq-group {
    grid-template-columns: 1fr;
  }
  .ps-footer-nav,
  .ps-pricing-benefits-wide {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ps-faq-group-heading {
    position: static;
  }
}
@media (max-width: 760px) {
  .ps-footer-nav,
  .ps-service-stack,
  .ps-pricing-metrics,
  .ps-pricing-credit-strip,
  .ps-pricing-benefits-wide,
  .ps-site-footer-bottom {
    grid-template-columns: 1fr;
  }
  .ps-pricing-card-compact .ps-btn-primary,
  .ps-footer-contact-actions a {
    width: 100%;
  }
}

/* HUB v21 - ripristino footer iniziale */
.ps-site-footer {
  background: #050d19;
  border-top: 1px solid var(--ps-site-line);
  padding: 58px 0 34px;
}
.ps-site-footer .row {
  width: 100%;
}
.ps-site-footer h3 {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #fff;
  font-weight: 900;
}
.ps-site-footer a {
  display: block;
  color: #9fb3ca;
  text-decoration: none;
  margin: 8px 0;
}
.ps-site-footer a:hover {
  color: var(--ps-site-cyan);
}
.ps-site-footer p {
  color: #9fb3ca;
  margin: 6px 0;
  line-height: 1.55;
}
.ps-site-footer-copy {
  max-width: 360px;
}
.ps-site-footer-bottom {
  border-top: 1px solid var(--ps-site-line);
  margin-top: 36px;
  padding-top: 22px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  color: #7f94ab;
  font-size: 12px;
  flex-wrap: wrap;
}
.ps-site-footer .payscore-logo-img {
  width: min(300px, 100%) !important;
  max-height: 54px !important;
  object-fit: contain !important;
  object-position: left center;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.ps-footer-hotline-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.15rem 1.25rem;
  margin-top: .35rem;
  border-radius: 22px;
  border: 1px solid rgba(57, 199, 255, .18);
  background: linear-gradient(145deg, rgba(18, 38, 64, .96), rgba(6, 17, 31, .98));
  box-shadow: 0 20px 44px rgba(0, 0, 0, .22);
}
.ps-footer-hotline-copy {
  display: grid;
  gap: .3rem;
}
.ps-footer-hotline-eyebrow {
  color: #91a9c3;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.ps-footer-hotline-card strong {
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: -.03em;
}
.ps-footer-hotline-card p {
  margin: 0;
  max-width: 700px;
  color: #9fb3ca;
}
.ps-site-footer .ps-footer-hotline-link,
.ps-site-footer .ps-footer-hotline-link:focus-visible {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  width: auto;
  border-radius: 999px;
  padding: .7rem 1rem;
  margin: 0;
  text-decoration: none;
  font-size: .9rem;
  font-weight: 950;
  color: #06111f !important;
  background: linear-gradient(135deg, #24e6a8, #39c7ff);
  border: 1px solid rgba(255, 255, 255, .16);
  box-shadow: 0 14px 30px rgba(36, 230, 168, .18);
}
.ps-site-footer .ps-footer-hotline-link:hover,
.ps-site-footer .ps-footer-hotline-link:focus-visible {
  color: #06111f !important;
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(57, 199, 255, .22);
}
@media (max-width: 860px) {
  .ps-footer-hotline-card {
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (max-width: 575px) {
  .ps-site-footer-bottom {
    display: grid;
  }
}

/* v23 - Responsive sito + app navigation dock */
:root {
  --mobile-dock-height: 86px;
}

.ps-mobile-sticky-cta {
  display: none;
}

@media (max-width: 980px) {
  body.app-layout-page .mobile-bottom-nav {
    display: grid;
  }

  .mobile-bottom-nav a:focus-visible,
  .mobile-menu-toggle:focus-visible,
  .mobile-drawer-close:focus-visible,
  .mobile-drawer-nav a:focus-visible {
    outline: 3px solid rgba(39, 199, 255, .72);
    outline-offset: 3px;
  }

  .mobile-bottom-nav a[aria-current="page"] {
    color: var(--text);
  }

  .mobile-bottom-nav .mobile-bottom-primary[aria-current="page"] {
    outline: 2px solid rgba(255,255,255,.56);
    outline-offset: 2px;
  }

  .mobile-drawer-logout {
    padding-top: 6px;
  }

  body.app-layout-page .app-shell,
  body.app-layout-page .app-shell.app-shell-wide {
    padding-bottom: calc(var(--mobile-dock-height) + 28px + env(safe-area-inset-bottom)) !important;
  }

  body.app-layout-page .app-main > section,
  body.app-layout-page .app-main > div {
    min-width: 0;
  }

  .service-launchpad-grid,
  .power-grid,
  .history-grid,
  .results-grid,
  .company-data-grid,
  .company-kpi-grid,
  .lead-list,
  .email-section.compact-grid,
  .pricing-status-grid,
  .credits-kpi-grid,
  .credit-movements-grid,
  .ps-pricing-credit-strip,
  .ps-pricing-layout,
  .ps-service-stack {
    grid-template-columns: 1fr !important;
  }

  .service-launch-card,
  .history-card,
  .result-card,
  .company-card,
  .credit-movement-row,
  .billing-prefill-card,
  .ps-pricing-card-compact,
  .ps-service-stack article {
    border-radius: 22px;
  }

  .section-heading,
  .history-card-head,
  .history-card-foot,
  .company-card-head,
  .email-section-head,
  .billing-prefill-form-vies,
  .inline-filter-form {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 10px !important;
  }

  .history-card-foot .section-actions,
  .inline-form,
  .danger-inline {
    width: 100%;
  }

  .table-wrap,
  .admin-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 20px;
  }

  .results-table,
  .outcome-results-table,
  .compact.results-table {
    min-width: 760px;
  }

  .hero-card .hero-side article,
  .process-list article,
  .helper-copy,
  .free-inline-note,
  .summary-copy,
  .copy-card {
    border-radius: 18px;
  }

  textarea[name="question_offer"] {
    min-height: 190px;
  }

  .segmented-control,
  .profile-segmented,
  .compact-segmented {
    grid-template-columns: 1fr !important;
  }

  .segmented-option {
    min-height: 48px;
  }

  .copy-card-pre,
  pre.copy-card,
  .admin-notes {
    white-space: pre-wrap;
    word-break: break-word;
  }
}

@media (max-width: 575px) {
  body.public-site-page {
    padding-bottom: calc(76px + env(safe-area-inset-bottom));
  }

  .ps-site-navbar {
    position: sticky;
    top: 0;
    z-index: 1040;
    background: rgba(5, 13, 25, .92);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
  }

  .ps-site-navbar .navbar {
    min-height: 62px;
    padding-left: 14px;
    padding-right: 14px;
  }

  .hub-header-logo,
  .payscore-logo-img.hub-header-logo {
    max-width: 178px;
    max-height: 48px;
  }

  .ps-site-menu {
    padding: 12px 14px 16px;
    border-radius: 0 0 22px 22px;
    background: rgba(5, 13, 25, .96);
    border-top: 1px solid rgba(255,255,255,.08);
  }

  .ps-site-navbar .nav-link,
  .ps-login-cta,
  .ps-site-nav-cta {
    width: 100%;
    min-height: 46px;
    display: flex !important;
    align-items: center;
    justify-content: center;
  }

  .ps-mobile-sticky-cta {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: max(10px, env(safe-area-inset-bottom));
    z-index: 1030;
    display: grid;
    grid-template-columns: .86fr 1.14fr;
    gap: 8px;
    padding: 8px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(5, 13, 25, .90);
    box-shadow: 0 18px 46px rgba(0,0,0,.36);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .ps-mobile-sticky-cta a {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    font-weight: 950;
    text-decoration: none;
  }

  .ps-mobile-sticky-primary {
    background: linear-gradient(135deg, var(--ps-site-blue), var(--ps-site-green));
    color: #04111f !important;
  }

  .ps-mobile-sticky-secondary {
    background: rgba(255,255,255,.08);
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.10);
  }

  .ps-mobile-sticky-cta a:focus-visible {
    outline: 3px solid rgba(56, 220, 255, .78);
    outline-offset: 3px;
  }

  .ps-hero,
  .ps-page-hero {
    padding-top: 44px;
  }

  .ps-hero-actions,
  .ps-contact-strip,
  .ps-pricing-note,
  .ps-site-footer-bottom {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .ps-hero-actions a,
  .ps-contact-strip a,
  .ps-btn-primary,
  .ps-btn-secondary,
  .ps-btn-ghost {
    width: 100%;
    justify-content: center;
  }

  .ps-section-heading,
  .ps-legal-card,
  .ps-site-footer-copy {
    max-width: none;
  }

  .ps-site-footer {
    padding-bottom: 112px;
  }

  .ps-cookie-box {
    left: 10px;
    right: 10px;
    width: auto;
    bottom: calc(86px + env(safe-area-inset-bottom));
  }

  .ps-privacy-pill {
    bottom: calc(86px + env(safe-area-inset-bottom));
    left: 10px;
  }
}

@media (max-width: 420px) {
  .mobile-bottom-nav a span {
    font-size: .61rem;
  }

  .mobile-bottom-nav a i,
  .mobile-bottom-nav a strong {
    width: 24px;
    height: 24px;
    border-radius: 10px;
  }

  .mobile-bottom-nav .mobile-bottom-primary strong {
    width: 31px;
    height: 31px;
  }

  .mobile-app-logo {
    width: min(132px, 40vw);
  }

  .mobile-credit-pill {
    padding-inline: 9px;
  }

  .ps-hero h1,
  .ps-page-hero h1 {
    font-size: 38px;
  }
}


/* v24 - Bottom mobile navigation solo testo + link home pubblica corretto */
@media (max-width: 900px) {
  .mobile-bottom-nav.mobile-bottom-dock,
  .mobile-bottom-nav {
    min-height: calc(66px + env(safe-area-inset-bottom));
    padding: 9px 8px calc(9px + env(safe-area-inset-bottom));
    align-items: stretch;
  }

  .mobile-bottom-nav a {
    min-height: 48px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    grid-template-rows: none !important;
    gap: 0;
    padding: 0 6px;
    font-size: .72rem;
    line-height: 1.05;
    text-align: center;
  }

  .mobile-bottom-nav a i,
  .mobile-bottom-nav a strong {
    display: none !important;
  }

  .mobile-bottom-nav a span {
    display: block;
    white-space: nowrap;
  }

  .mobile-bottom-nav .mobile-bottom-primary {
    transform: translateY(-8px);
    min-height: 58px;
    border-radius: 22px;
    padding-inline: 4px;
    font-size: .78rem;
  }

  .mobile-bottom-nav .mobile-bottom-primary span {
    font-weight: 950;
  }

  .mobile-bottom-nav a.active:not(.mobile-bottom-primary)::before {
    top: 7px;
    width: 22px;
  }

  body.app-layout-page .app-shell,
  body.app-layout-page .app-shell.app-shell-wide {
    padding-bottom: calc(92px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width: 374px) {
  .mobile-bottom-nav a {
    font-size: .64rem;
    padding-inline: 2px;
  }
  .mobile-bottom-nav .mobile-bottom-primary {
    font-size: .68rem;
  }
}


/* v25 - Mobile site menu centering and app dock refinements */
@media (max-width: 991px) {
  body.public-site-page .ps-site-nav-inner {
    justify-content: center;
    padding-left: 16px;
    padding-right: 16px;
  }

  body.public-site-page .ps-site-brand {
    margin-right: 0;
  }

  body.public-site-page .ps-site-navbar .navbar-toggler {
    margin-left: auto;
    border-radius: 14px;
  }

  body.public-site-page #hubSiteNav {
    width: 100%;
    flex-basis: 100%;
    margin-top: 12px;
  }

  body.public-site-page .ps-site-menu {
    width: 100%;
    align-items: stretch !important;
    justify-content: center;
    text-align: center;
    gap: 8px !important;
    padding: 14px;
    border-radius: 24px;
    background: rgba(5, 13, 25, .96);
    border: 1px solid rgba(255, 255, 255, .10);
    box-shadow: 0 18px 46px rgba(0, 0, 0, .28);
  }

  body.public-site-page .ps-site-menu .nav-item {
    width: 100%;
  }

  body.public-site-page .ps-site-navbar .nav-link,
  body.public-site-page .ps-login-cta,
  body.public-site-page .ps-site-nav-cta {
    width: 100%;
    min-height: 46px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    margin: 0;
    text-align: center;
    border-radius: 16px;
  }
}

@media (max-width: 980px) {
  :root {
    --mobile-dock-height: 82px;
  }

  .mobile-bottom-nav {
    left: 0;
    right: 0;
    bottom: 0;
    min-height: calc(var(--mobile-dock-height) + env(safe-area-inset-bottom));
    padding: 8px 8px calc(8px + env(safe-area-inset-bottom));
    border-radius: 24px 24px 0 0;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    box-shadow: 0 -18px 54px rgba(0, 0, 0, .42);
  }

  .mobile-bottom-nav a {
    min-height: 50px;
    flex-direction: column;
    gap: 3px;
    padding: 7px 4px;
    line-height: 1.05;
    font-size: .67rem;
  }

  .mobile-bottom-nav a span {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-bottom-nav .mobile-bottom-primary {
    min-height: 58px;
    margin-top: -18px;
    border-radius: 22px;
    color: #03101d;
    transform: translateY(-4px);
  }

  .mobile-bottom-nav .mobile-bottom-primary strong {
    width: 24px;
    height: 24px;
    display: grid !important;
    place-items: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, .42);
    font-size: 1.15rem;
    line-height: 1;
    font-weight: 950;
  }

  .mobile-bottom-nav .mobile-bottom-primary span {
    font-size: .72rem;
    font-weight: 950;
  }

  body.app-layout-page .app-shell,
  body.app-layout-page .app-shell.app-shell-wide {
    padding-bottom: calc(var(--mobile-dock-height) + 30px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width: 360px) {
  .mobile-bottom-nav a {
    font-size: .61rem;
  }

  .mobile-bottom-nav .mobile-bottom-primary span {
    font-size: .66rem;
  }
}


/* v29 - fix UX: billing plan visible, modern history, wrapped lead motivations */
.billing-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.12fr) minmax(360px, .88fr) !important;
  gap: 24px !important;
  align-items: start !important;
}
.billing-side-panel {
  position: sticky;
  top: 18px;
  align-self: start;
  display: grid !important;
  gap: 18px !important;
}
.billing-plan-card {
  order: -2 !important;
  border-color: rgba(39, 199, 255, .28) !important;
  box-shadow: 0 28px 80px rgba(2, 8, 23, .24), inset 0 1px 0 rgba(255,255,255,.06);
}
.payment-funnel-card { order: 1 !important; }
.billing-plan-card .app-plan {
  margin: 0;
}

.lead-results-grid {
  display: grid;
  gap: 14px;
}
.lead-result-card {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, .18);
  background:
    radial-gradient(circle at top right, rgba(39, 199, 255, .10), transparent 30%),
    rgba(255,255,255,.045);
}
.lead-result-score {
  display: grid;
  gap: 8px;
  justify-items: start;
}
.lead-result-score small,
.lead-result-meta span,
.lead-result-meta a {
  color: var(--text-soft);
  font-size: .86rem;
  font-weight: 800;
  text-decoration: none;
}
.lead-result-main {
  min-width: 0;
  display: grid;
  gap: 10px;
}
.lead-result-main h3 {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.lead-result-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.lead-result-meta span,
.lead-result-meta a {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: 100%;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .16);
  background: rgba(255,255,255,.045);
  overflow-wrap: anywhere;
  word-break: break-word;
}
.lead-result-reason {
  padding: 13px 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(148, 163, 184, .13);
  min-width: 0;
}
.lead-result-reason strong {
  display: block;
  margin-bottom: 6px;
  font-size: .78rem;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--brand);
}
.lead-result-reason p {
  margin: 0;
  line-height: 1.6;
  white-space: pre-line !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}
.lead-result-actions {
  display: flex;
  justify-content: flex-end;
  align-items: start;
}
.results-table td:nth-child(5),
.results-table th:nth-child(5),
.outcome-results-table td:nth-child(6) {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  min-width: 260px;
  max-width: 520px;
}

.search-history-modern {
  grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
  gap: 18px;
}
.search-history-card {
  position: relative;
  overflow: hidden;
  min-height: 230px;
  padding: 22px !important;
  border-radius: 26px !important;
  border-color: rgba(39,199,255,.18) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(39,199,255,.12), transparent 34%),
    linear-gradient(160deg, rgba(255,255,255,.07), rgba(255,255,255,.025)) !important;
  box-shadow: 0 20px 70px rgba(2,8,23,.23);
}
.search-history-card::after {
  content: "";
  position: absolute;
  inset: auto 18px 0 18px;
  height: 3px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(90deg, var(--brand), rgba(138,92,246,.85));
  opacity: .82;
}
.search-history-card h3 {
  font-size: 1.22rem !important;
  letter-spacing: -.02em;
}
.search-history-card > p:not(.mini-meta) {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.search-history-card .history-card-foot {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid rgba(148,163,184,.13);
}
.search-history-card .history-card-foot a:not(.ghost-button) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--brand), rgba(138,92,246,.9));
  color: #fff;
  font-weight: 900;
  text-decoration: none;
}

@media (max-width: 1120px) {
  .billing-layout { grid-template-columns: 1fr !important; }
  .billing-side-panel { position: static; }
}
@media (max-width: 760px) {
  .lead-result-card {
    grid-template-columns: 1fr;
  }
  .lead-result-actions {
    justify-content: stretch;
  }
  .lead-result-actions .primary-cta {
    width: 100%;
    justify-content: center;
  }
  .search-history-modern { grid-template-columns: 1fr; }
}


/* v31 - cache-busted public CSS, lead table restored, billing CTA always visible, modern searches */
.lead-results-table-wrap {
  overflow-x: auto;
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, .14);
  background: rgba(255,255,255,.025);
}
.lead-results-table {
  min-width: 1060px;
  table-layout: fixed;
}
.lead-results-table th:nth-child(1),
.lead-results-table td:nth-child(1) { width: 82px; }
.lead-results-table th:nth-child(2),
.lead-results-table td:nth-child(2) { width: 220px; }
.lead-results-table th:nth-child(3),
.lead-results-table td:nth-child(3) { width: 140px; }
.lead-results-table th:nth-child(4),
.lead-results-table td:nth-child(4) { width: 170px; }
.lead-results-table th:nth-child(5),
.lead-results-table td:nth-child(5) { width: 92px; }
.lead-results-table th:nth-child(7),
.lead-results-table td:nth-child(7) { width: 118px; }
.lead-results-table th,
.lead-results-table td {
  vertical-align: top !important;
}
.lead-results-table .lead-company-cell strong,
.lead-results-table .lead-vat-cell,
.lead-results-table .lead-site-cell,
.lead-results-table .lead-reason-cell,
.lead-results-table .lead-reason-cell div {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}
.lead-results-table .lead-reason-cell {
  min-width: 360px;
}
.lead-results-table .lead-reason-cell div {
  line-height: 1.55;
  max-width: 100%;
}
.rank-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(39,199,255,.12);
  border: 1px solid rgba(39,199,255,.22);
  color: #dff7ff;
  font-weight: 900;
}
.lead-action-cell .primary-cta.small {
  white-space: nowrap;
}
.billing-side-panel .billing-plan-card {
  order: -10 !important;
}
.billing-plan-card .primary-cta {
  width: 100%;
  justify-content: center;
}
.search-history-modern.history-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
  gap: 18px !important;
}
.search-history-modern .search-history-card {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}
.search-history-modern .history-card-head,
.search-history-modern .history-card-foot {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
}
@media (max-width: 760px) {
  .lead-results-table { min-width: 920px; }
  .lead-results-table .lead-reason-cell { min-width: 300px; }
}


/* v32 - acquisto piano/crediti extra sempre visibile e fatturazione più ordinata */
.billing-layout { grid-template-columns: minmax(0, 1.18fr) minmax(390px, .82fr) !important; }
.billing-card .section-heading { margin-bottom: 16px; }
.billing-form .form-grid { display: grid !important; grid-template-columns: repeat(12, minmax(0, 1fr)) !important; gap: 14px !important; align-items: start !important; }
.billing-form .form-grid > label { grid-column: span 6; min-width: 0; display: grid; gap: 8px; padding: 14px; border: 1px solid rgba(148,163,184,.14); border-radius: 18px; background: rgba(255,255,255,.035); }
.billing-form .form-grid > label.billing-field-third { grid-column: span 4; }
.billing-form .form-grid > label.billing-field-half { grid-column: span 6; }
.billing-form .form-grid > label.billing-field-two-thirds { grid-column: span 8; }
.billing-form .form-grid > label input, .billing-form .form-grid > label select, .billing-form .form-grid > label textarea { width: 100%; min-width: 0; }
.billing-form .form-grid > label span { font-weight: 900; color: #e7f0ff; }
.billing-form .form-grid > label small { min-height: 18px; line-height: 1.35; }
.billing-purchase-card { position: relative; overflow: hidden; }
.billing-purchase-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: linear-gradient(90deg, var(--brand), rgba(138,92,246,.88)); opacity: .95; }
.app-buy-card { position: relative; display: grid; gap: 16px; padding: 20px; border-radius: 24px; border: 1px solid rgba(148,163,184,.18); background: radial-gradient(circle at top right, rgba(39,199,255,.13), transparent 36%), rgba(255,255,255,.04); }
.app-buy-card.featured { border-color: rgba(39,199,255,.28); }
.app-buy-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.app-buy-head h3 { margin: 0; max-width: 230px; line-height: 1.15; }
.app-buy-list { display: grid; gap: 9px; margin: 0; padding-left: 18px; color: var(--text-soft); font-weight: 750; }
.billing-buy-form { display: grid; gap: 10px; margin: 0; }
.billing-buy-form .primary-cta[disabled] { opacity: .58; cursor: not-allowed; filter: saturate(.72); }
.billing-buy-form small { color: var(--text-soft); line-height: 1.4; font-weight: 750; }
.extra-credit-form label { display: grid; gap: 8px; }
.extra-credit-form select { width: 100%; }
.billing-extra-card { border-color: rgba(138,92,246,.24) !important; }
@media (max-width: 1180px) { .billing-layout { grid-template-columns: 1fr !important; } }
@media (max-width: 820px) { .billing-form .form-grid { grid-template-columns: 1fr !important; } .billing-form .form-grid > label, .billing-form .form-grid > label.billing-field-third, .billing-form .form-grid > label.billing-field-half, .billing-form .form-grid > label.billing-field-two-thirds { grid-column: 1 / -1 !important; } .app-buy-head { flex-direction: column; } }


/* v34 - acquisto piano/solo crediti sempre visibile accanto alla fatturazione */
.billing-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px) !important;
  gap: 24px !important;
  align-items: start !important;
}
.billing-card {
  min-width: 0 !important;
}
.billing-side-panel {
  display: grid !important;
  gap: 18px !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: sticky !important;
  top: 18px !important;
  z-index: 2 !important;
  align-self: start !important;
}
.billing-side-panel .billing-purchase-card,
.billing-side-panel .billing-plan-card,
.billing-side-panel .billing-extra-card {
  display: grid !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.billing-extra-card .primary-cta,
.billing-plan-card .primary-cta {
  width: 100% !important;
  justify-content: center !important;
}
@media (max-width: 980px) {
  .billing-layout {
    grid-template-columns: 1fr !important;
  }
  .billing-side-panel {
    position: static !important;
    order: -1 !important;
  }
  .billing-card {
    order: 0 !important;
  }
}

/* v35 - pricing pacchetti crediti progressivi e colonna acquisti più ampia */
.billing-layout {
  grid-template-columns: minmax(0, .92fr) minmax(420px, 500px) !important;
  gap: 26px !important;
}
.billing-side-panel {
  gap: 20px !important;
}
.billing-premium-card {
  border-color: rgba(39,199,255,.20) !important;
  background: radial-gradient(circle at top left, rgba(39,199,255,.08), transparent 34%), rgba(255,255,255,.035) !important;
}
.app-buy-card-v35 {
  gap: 18px;
  padding: 22px;
  overflow: hidden;
}
.app-buy-card-v35::after {
  content: "";
  position: absolute;
  width: 190px;
  height: 190px;
  right: -95px;
  top: -95px;
  border-radius: 999px;
  background: rgba(39,199,255,.12);
  pointer-events: none;
}
.app-buy-head-v35 {
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
.app-buy-head-v35 p {
  margin: 8px 0 0;
  color: var(--text-soft);
  line-height: 1.45;
  font-weight: 750;
}
.ps-price-large {
  min-width: 126px;
  text-align: right;
  line-height: 1;
}
.ps-price-large small {
  display: block;
  margin-top: 6px;
  font-size: .76rem;
  color: var(--text-soft);
}
.billing-mode-badge {
  width: fit-content;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(39,199,255,.12);
  border: 1px solid rgba(39,199,255,.24);
  color: #dff7ff;
  font-weight: 950;
  font-size: .75rem;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.billing-mode-badge.one-shot {
  background: rgba(138,92,246,.13);
  border-color: rgba(138,92,246,.28);
}
.billing-plan-saving {
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(15,23,42,.46);
  border: 1px solid rgba(148,163,184,.14);
  color: var(--text-soft);
  font-weight: 800;
}
.billing-plan-highlights,
.extra-credit-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  position: relative;
  z-index: 1;
}
.billing-plan-highlights article,
.extra-credit-feature-grid article {
  display: grid;
  gap: 3px;
  padding: 13px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(148,163,184,.14);
}
.billing-plan-highlights strong,
.extra-credit-feature-grid strong {
  font-size: 1.2rem;
  color: #fff;
  line-height: 1;
}
.billing-plan-highlights span,
.extra-credit-feature-grid span {
  color: var(--text-soft);
  font-size: .78rem;
  font-weight: 850;
}
.extra-credit-feature-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
.extra-credit-feature-grid article {
  text-align: center;
  padding: 12px 8px;
}
.extra-credit-feature-grid b {
  color: #dff7ff;
  font-size: .92rem;
}
.extra-credit-form select {
  min-height: 50px;
  border-radius: 16px;
  font-weight: 850;
}
.extra-credit-note {
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(138,92,246,.10);
  border: 1px solid rgba(138,92,246,.20);
  color: var(--text-soft);
  font-weight: 800;
  line-height: 1.4;
}
@media (max-width: 1180px) {
  .billing-layout {
    grid-template-columns: 1fr !important;
  }
  .billing-side-panel {
    position: static !important;
  }
}
@media (max-width: 560px) {
  .billing-plan-highlights,
  .extra-credit-feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .app-buy-head-v35 {
    flex-direction: column;
  }
  .ps-price-large {
    text-align: left;
  }
}

/* v36 admin control room: schede singole, dashboard powerBI e scheda cliente completa */
.admin-page-stack {
    display: grid;
    gap: 1rem;
}
.admin-portal-body .admin-main > [data-admin-page] {
    animation: adminPageIn .22s ease both;
}
@keyframes adminPageIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
.admin-super-hero {
    background:
        radial-gradient(circle at 15% 10%, rgba(39,199,255,.26), transparent 32%),
        radial-gradient(circle at 92% 8%, rgba(36,230,168,.16), transparent 26%),
        linear-gradient(135deg, rgba(6,23,42,.92), rgba(7,30,49,.84));
    border: 1px solid rgba(39,199,255,.28);
}
.admin-portal-body .admin-mini-grid {
    gap: 14px;
}
.admin-portal-body .admin-mini-card {
    background: linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.035)) !important;
    border: 1px solid rgba(148,163,184,.16) !important;
    box-shadow: 0 24px 70px rgba(0,0,0,.22) !important;
    color: #fff !important;
}
.admin-portal-body .admin-mini-card span {
    color: #a7f3d0 !important;
}
.admin-portal-body .admin-mini-card strong {
    color: #fff !important;
}
.admin-portal-body .admin-mini-card small {
    color: #cbd5e1 !important;
}
.admin-kpi-supergrid {
    grid-template-columns: repeat(6, minmax(130px, 1fr));
}
.admin-powerbi-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(280px, .82fr);
    gap: 1rem;
}
.admin-super-card {
    padding: clamp(1rem, 2vw, 1.35rem);
    display: grid;
    gap: 1rem;
    min-height: 260px;
    border-color: rgba(39,199,255,.2);
    background:
        linear-gradient(145deg, rgba(15,23,42,.88), rgba(8,47,73,.42)),
        radial-gradient(circle at 100% 0%, rgba(36,230,168,.14), transparent 34%);
}
.admin-super-card h3 {
    margin: .25rem 0 0;
    color: #fff;
    letter-spacing: -.03em;
}
.admin-big-number {
    display: grid;
    gap: 6px;
    padding: 18px;
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(39,199,255,.14), rgba(36,230,168,.10));
    border: 1px solid rgba(39,199,255,.22);
}
.admin-big-number strong {
    font-size: clamp(2rem, 4vw, 3.2rem);
    color: #fff;
    line-height: 1;
    letter-spacing: -.06em;
}
.admin-big-number span {
    color: #cbd5e1;
    font-weight: 700;
}
.admin-mini-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
}
.admin-client-matrix {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin: 14px 0;
}
.admin-client-matrix > div {
    padding: 12px;
    border-radius: 18px;
    background: rgba(255,255,255,.055);
    border: 1px solid rgba(148,163,184,.14);
}
.admin-client-matrix span {
    display: block;
    color: var(--text-soft);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.admin-client-matrix strong {
    display: block;
    margin-top: 5px;
    color: #fff;
}
.admin-client-data {
    margin: 12px 0 16px;
    padding: 14px;
    border-radius: 20px;
    border: 1px solid rgba(39,199,255,.18);
    background: rgba(39,199,255,.055);
}
.admin-client-data summary {
    cursor: pointer;
    color: #fff;
    font-weight: 900;
}
.admin-client-data dl {
    display: grid;
    grid-template-columns: minmax(120px, .32fr) minmax(0, 1fr);
    gap: 8px 14px;
    margin: 14px 0 0;
}
.admin-client-data dt {
    color: var(--text-soft);
    font-weight: 900;
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: .06em;
}
.admin-client-data dd {
    margin: 0;
    color: #fff;
    overflow-wrap: anywhere;
}
.admin-portal-body .admin-section {
    margin-bottom: 0 !important;
}
.admin-portal-body .content-card[data-admin-page],
.admin-portal-body #audit[data-admin-page] {
    min-height: min(760px, calc(100vh - 56px));
}
.admin-portal-body .admin-tabs {
    background: rgba(255,255,255,.035);
    border: 1px solid rgba(148,163,184,.14);
    border-radius: 24px;
    padding: 12px;
}
.admin-portal-body .admin-tabs a {
    background: rgba(255,255,255,.06) !important;
    color: #dbeafe !important;
    border-color: rgba(148,163,184,.18) !important;
}
.admin-portal-body .admin-tabs a.active,
.admin-portal-body .admin-tabs a[aria-current="page"] {
    color: #03131f !important;
    background: linear-gradient(135deg, var(--brand), var(--success)) !important;
    border-color: rgba(39,199,255,.4) !important;
}
@media (max-width: 1280px) {
    .admin-kpi-supergrid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .admin-powerbi-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
    .admin-kpi-supergrid,
    .admin-client-matrix,
    .admin-client-data dl { grid-template-columns: 1fr; }
    .admin-mini-grid.compact { grid-template-columns: 1fr; }
}

/* v58 - Public checkout Abbonati / 500 Lead */
.checkout-shell {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    padding: 28px 0 54px;
    color: #fff;
}
.checkout-shell a { color: inherit; }
.checkout-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 24px;
}
.checkout-brand { display: inline-flex; align-items: center; text-decoration: none; }
.checkout-logo { display: block; width: min(245px, 62vw); height: auto; object-fit: contain; }
.checkout-hotline {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    border: 1px solid rgba(2,195,146,.55);
    background: linear-gradient(135deg, rgba(2,195,146,.18), rgba(6,84,162,.16));
    box-shadow: 0 12px 34px rgba(2,195,146,.16);
    border-radius: 999px;
    padding: 10px 18px;
    white-space: nowrap;
}
.checkout-hotline span { display: block; color: rgba(255,255,255,.64); font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .12em; }
.checkout-hotline strong { display: block; color: #fff; font-size: clamp(18px, 2.2vw, 27px); line-height: 1; letter-spacing: -.03em; }
.checkout-hero {
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.035)), rgba(7,10,21,.78);
    box-shadow: 0 28px 80px rgba(0,0,0,.38);
    overflow: hidden;
    position: relative;
    display: grid;
    grid-template-columns: minmax(0,1.25fr) minmax(320px,.75fr);
    gap: 28px;
    padding: 34px;
    margin-bottom: 22px;
}
.checkout-hero::before { content: ""; position: absolute; inset: -160px auto auto -160px; width: 420px; height: 420px; background: radial-gradient(circle, rgba(6,84,162,.72), transparent 70%); pointer-events: none; }
.checkout-hero::after { content: ""; position: absolute; inset: auto -120px -160px auto; width: 360px; height: 360px; background: radial-gradient(circle, rgba(2,195,146,.42), transparent 70%); pointer-events: none; }
.checkout-hero > * { position: relative; z-index: 1; }
.checkout-badge { display: inline-flex; align-items: center; gap: 8px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.065); border-radius: 999px; padding: 6px 15px; font-size: 11px; text-transform: uppercase; letter-spacing: .10em; font-weight: 800; color: rgba(255,255,255,.88); margin-bottom: 16px; }
.checkout-badge i { width: 7px; height: 7px; border-radius: 999px; background: #02c392; box-shadow: 0 0 10px #02c392; }
.checkout-hero-copy h1 { margin: 0 0 14px; font-size: clamp(31px,4.3vw,58px); line-height: .98; letter-spacing: -.055em; color: #fff; }
.checkout-hero-copy h1 span { background: linear-gradient(45deg,#02c392,#37d3ff,#0654a2); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.checkout-hero-copy p, .checkout-offer-card p { color: rgba(255,255,255,.72); font-size: 16px; line-height: 1.65; max-width: 680px; margin: 0 0 22px; }
.checkout-hero-copy p strong { color: #fff; }
.checkout-benefits { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 9px; }
.checkout-benefits em { font-style: normal; border: 1px solid rgba(255,255,255,.09); background: rgba(255,255,255,.055); border-radius: 13px; padding: 12px 13px; color: rgba(255,255,255,.67); font-size: 13px; }
.checkout-offer-card { border: 1px solid rgba(2,195,146,.48); background: rgba(255,255,255,.10); border-radius: 20px; padding: 24px; box-shadow: 0 0 42px rgba(2,195,146,.12); display: flex; flex-direction: column; justify-content: space-between; min-height: 100%; }
.checkout-card-head { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; margin-bottom: 20px; }
.checkout-card-head span { display: inline-flex; border-radius: 999px; padding: 6px 12px; background: #0654a2; font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .10em; }
.checkout-card-head small { color: rgba(255,255,255,.46); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; font-weight: 800; text-align: right; }
.checkout-big-number { display: flex; align-items: flex-end; gap: 10px; margin: 0 0 8px; }
.checkout-big-number strong { font-size: clamp(74px,9vw,104px); line-height: .82; letter-spacing: -.075em; }
.checkout-big-number span { color: rgba(255,255,255,.82); font-size: 18px; font-weight: 800; padding-bottom: 8px; }
.checkout-offer-card p { font-size: 13px; color: rgba(255,255,255,.58); }
.checkout-price-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 22px; }
.checkout-price-grid div { border: 1px solid rgba(2,195,146,.42); background: rgba(2,195,146,.10); border-radius: 14px; text-align: center; padding: 14px 10px; }
.checkout-price-grid strong { display: block; font-size: 26px; line-height: 1; margin-bottom: 5px; }
.checkout-price-grid span { color: rgba(255,255,255,.48); font-size: 10px; text-transform: uppercase; letter-spacing: .10em; font-weight: 800; }
.checkout-layout { display: grid; grid-template-columns: minmax(0,1fr) 360px; gap: 22px; align-items: start; }
.checkout-section, .checkout-summary { border: 1px solid rgba(255,255,255,.10); background: rgba(7,10,21,.72); backdrop-filter: blur(8px); border-radius: 18px; box-shadow: 0 16px 48px rgba(0,0,0,.22); padding: 24px; margin-bottom: 18px; }
.checkout-section-title { display: flex; align-items: flex-start; gap: 13px; margin-bottom: 18px; }
.checkout-section-title b { width: 32px; height: 32px; display: grid; place-items: center; border-radius: 12px; background: linear-gradient(135deg, rgba(2,195,146,.95), rgba(6,84,162,.95)); font-weight: 900; flex: 0 0 auto; }
.checkout-section-title h2 { margin: 0; font-size: 20px; letter-spacing: -.025em; color: #fff; }
.checkout-section-title p { margin: 4px 0 0; color: rgba(255,255,255,.46); font-size: 13px; line-height: 1.55; }
.checkout-plan-box { border: 1px solid rgba(2,195,146,.62); background: linear-gradient(135deg, rgba(2,195,146,.14), rgba(6,84,162,.15)), rgba(255,255,255,.055); border-radius: 16px; padding: 18px; display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: center; }
.checkout-plan-box h3 { margin: 0 0 5px; font-size: 18px; letter-spacing: -.02em; color: #fff; }
.checkout-plan-box p { margin: 0; color: rgba(255,255,255,.58); font-size: 13px; }
.checkout-plan-box > strong { color: #fff; font-size: 30px; line-height: 1; text-align: right; }
.checkout-plan-box small { display: block; color: rgba(255,255,255,.46); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; margin-top: 5px; }
.checkout-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; margin-top: 14px; }
.checkout-checks span { color: rgba(255,255,255,.66); font-size: 12.5px; line-height: 1.45; }
.checkout-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
.checkout-grid[hidden] { display: none !important; }
.checkout-grid label { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.checkout-grid label span { color: rgba(255,255,255,.78); font-size: 12px; font-weight: 800; letter-spacing: .02em; }
.checkout-grid input, .checkout-grid select, .checkout-prefill-card input { width: 100%; border: 1px solid rgba(255,255,255,.105); background: rgba(255,255,255,.075); border-radius: 13px; color: #fff; padding: 13px; font: inherit; font-size: 14px; outline: none; }
.checkout-grid select { color: #fff; }
.checkout-grid option { background: #111728; color: #fff; }
.checkout-grid input::placeholder, .checkout-prefill-card input::placeholder { color: rgba(255,255,255,.32); }
.checkout-grid input:focus, .checkout-grid select:focus, .checkout-prefill-card input:focus { border-color: rgba(2,195,146,.66); box-shadow: 0 0 0 4px rgba(2,195,146,.11); background: rgba(255,255,255,.095); }
.checkout-full { grid-column: 1 / -1; }
.checkout-wide { grid-column: span 1; }
.checkout-segmented { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 16px; }
.checkout-segmented label { display: block; cursor: pointer; }
.checkout-segmented input, .checkout-prefill-mode input { position: absolute; opacity: 0; pointer-events: none; }
.checkout-segmented label > span { display: block; border: 1px solid rgba(255,255,255,.11); background: rgba(255,255,255,.055); border-radius: 15px; padding: 15px; min-height: 88px; }
.checkout-segmented label.active > span, .checkout-segmented input:checked + span { border-color: rgba(2,195,146,.66); background: rgba(2,195,146,.09); box-shadow: 0 0 0 4px rgba(2,195,146,.08); }
.checkout-segmented strong { display: block; color: #fff; font-size: 15px; margin-bottom: 5px; }
.checkout-segmented small { display: block; color: rgba(255,255,255,.50); font-size: 12px; line-height: 1.45; font-weight: 500; }
.checkout-prefill-card { border: 1px solid rgba(2,195,146,.24); background: rgba(2,195,146,.06); border-radius: 16px; padding: 16px; margin: 0 0 16px; }
.checkout-prefill-card > strong { display: block; font-size: 13px; font-weight: 900; margin-bottom: 5px; color: #fff; }
.checkout-prefill-card p { color: rgba(255,255,255,.54); font-size: 12.5px; line-height: 1.5; margin: 0 0 13px; }
.checkout-prefill-mode { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; margin-bottom: 12px; }
.checkout-prefill-mode label { cursor: pointer; display: block; }
.checkout-prefill-mode span { display: block; border: 1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.045); border-radius: 13px; padding: 12px; color: #fff; font-size: 12.5px; font-weight: 800; }
.checkout-prefill-mode label.active span, .checkout-prefill-mode input:checked + span { border-color: rgba(2,195,146,.55); background: rgba(2,195,146,.10); }
.checkout-prefill-row { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 10px; }
.checkout-prefill-row[data-eu="1"] { grid-template-columns: 110px minmax(0,1fr) auto; }
.checkout-prefill-row:not([data-eu="1"]) [data-checkout-eu-country] { display: none; }
.checkout-prefill-status { display: none; border-radius: 12px; padding: 11px 12px; font-size: 12.5px; line-height: 1.5; margin-top: 12px; }
.checkout-prefill-status.ok { display: block; border: 1px solid rgba(2,195,146,.42); background: rgba(2,195,146,.10); color: rgba(255,255,255,.82); }
.checkout-prefill-status.warn { display: block; border: 1px solid rgba(255,159,28,.42); background: rgba(255,159,28,.10); color: rgba(255,255,255,.82); }
.checkout-summary { position: sticky; top: 18px; margin-bottom: 0; }
.checkout-summary h3 { margin: 0 0 14px; font-size: 17px; color: #fff; }
.checkout-summary dl { margin: 0; }
.checkout-summary dl div { display: flex; justify-content: space-between; gap: 14px; color: rgba(255,255,255,.66); font-size: 13px; padding: 11px 0; border-bottom: 1px solid rgba(255,255,255,.075); }
.checkout-summary dt { margin: 0; font-weight: 500; }
.checkout-summary dd { margin: 0; color: #fff; text-align: right; font-weight: 800; }
.checkout-total { display: flex; justify-content: space-between; align-items: flex-end; gap: 14px; margin: 16px 0 8px; padding-top: 8px; }
.checkout-total span { color: rgba(255,255,255,.72); font-size: 13px; font-weight: 800; }
.checkout-total strong { font-size: 31px; line-height: 1; letter-spacing: -.04em; }
.checkout-vat-note { margin: 0 0 16px; color: rgba(255,255,255,.42); font-size: 11.5px; text-align: right; }
.checkout-consents { border-top: 1px solid rgba(255,255,255,.075); padding-top: 14px; margin-top: 10px; display: grid; gap: 11px; }
.checkout-consents p { margin: 0; color: rgba(255,255,255,.62); line-height: 1.5; font-size: 12px; }
.checkout-consents a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }
.checkout-consents label { display: flex; gap: 10px; align-items: flex-start; color: rgba(255,255,255,.68); line-height: 1.45; cursor: pointer; font-size: 12px; }
.checkout-consents input { width: 17px; height: 17px; margin: 1px 0 0; accent-color: #02c392; flex: 0 0 auto; }
.checkout-secure-note { display: flex; align-items: flex-start; gap: 9px; margin: 14px 0 0; color: rgba(255,255,255,.48); font-size: 11.5px; line-height: 1.48; }
@media (max-width: 980px) {
    .checkout-hero, .checkout-layout { grid-template-columns: 1fr; }
    .checkout-summary { position: static; }
}
@media (max-width: 680px) {
    .checkout-shell { width: min(100% - 22px, 1180px); padding-top: 18px; }
    .checkout-topbar { align-items: stretch; flex-direction: column; }
    .checkout-hotline { justify-content: center; border-radius: 18px; }
    .checkout-hero, .checkout-section, .checkout-summary { padding: 20px; }
    .checkout-benefits, .checkout-grid, .checkout-checks, .checkout-price-grid, .checkout-segmented, .checkout-prefill-mode, .checkout-prefill-row, .checkout-prefill-row[data-eu="1"] { grid-template-columns: 1fr; }
    .checkout-plan-box { grid-template-columns: 1fr; }
    .checkout-plan-box > strong { text-align: left; }
    .checkout-big-number strong { font-size: 78px; }
}
