/* ================================================================
   ERTIA ERP — site.css
   Fuentes: Bricolage Grotesque (headings) + Plus Jakarta Sans (body)
           + DM Mono (etiquetas / código)
   ================================================================ */

/* ── TOKENS ─────────────────────────────────────────────────────── */
:root {
    --bg:        #F7F9FB;
    --bg2:       #EEF3F6;
    --surface:   #FFFFFF;
    --ink:       #1C2B3A;
    --ink-mid:   #243547;
    --muted:     #607080;
    --line:      #DDE4EB;
    --line-soft: #EDF2F6;

    --blue:      #007C7A;
    --blue-d:    #006664;
    --blue-m:    #009B99;
    --blue-l:    #E6F4F4;
    --blue-b:    rgba(0, 124, 122, .16);
    --blue-g:    rgba(0, 124, 122, .08);

    --sky:       #009B99;
    --sky-l:     #E8F8F7;
    --sky-b:     rgba(0, 155, 153, .16);

    --orange:    #E96A2A;
    --orange-l:  #FEF3ED;
    --orange-b:  rgba(233, 106, 42, .16);

    --night:     #162535;
    --night2:    #243547;
    --night3:    #3A526B;

    --fh: 'Bricolage Grotesque', system-ui, sans-serif;
    --fb: 'Plus Jakarta Sans', system-ui, sans-serif;
    --fm: 'DM Mono', 'Courier New', monospace;

    --r:  10px;
    --r2: 16px;
    --r3: 24px;
    --shadow-sm: 0 4px 18px rgba(22,37,53,.06);
    --shadow-md: 0 10px 36px rgba(22,37,53,.09);
    --shadow-lg: 0 18px 68px rgba(22,37,53,.12);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
    font-family: var(--fb);
    background: var(--bg);
    color: var(--ink);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    position: relative;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
textarea, input, select { font-family: inherit; }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--line); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--muted); }

.shell {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 clamp(20px, 5vw, 64px);
    padding-top: 35px; 
}

.site-stage {
    position: relative;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.site-body {
    position: relative;
    z-index: 2;
    flex: 1 0 auto;
}

.site-stage-glow {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: min(1400px, 100%);
    pointer-events: none;
    z-index: 0;
    opacity: .75;
}

.site-stage-glow-top {
    top: 0;
    height: 38rem;
    background:
        radial-gradient(circle at 18% 18%, rgba(0,155,153,.13), transparent 34%),
        radial-gradient(circle at 82% 8%, rgba(0,124,122,.14), transparent 30%),
        radial-gradient(circle at 50% 0%, rgba(255,255,255,.46), transparent 34%);
}

.site-stage-glow-bottom {
    bottom: 0;
    height: 42rem;
    background:
        radial-gradient(circle at 20% 75%, rgba(233,106,42,.11), transparent 26%),
        radial-gradient(circle at 78% 82%, rgba(0,124,122,.12), transparent 28%),
        radial-gradient(circle at 50% 100%, rgba(255,255,255,.56), transparent 38%);
}

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

h1, h2, h3, h4 {
    font-family: var(--fh);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.03em;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--fm);
    font-size: .68rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 20px;
}
.eyebrow .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}
.eyebrow-blue { color: var(--blue); }
.eyebrow-blue .dot { background: var(--blue); }
.eyebrow-orange { color: var(--orange); }
.eyebrow-orange .dot { background: var(--orange); }
.eyebrow-sky { color: var(--sky); }
.eyebrow-sky .dot { background: var(--sky); }
.eyebrow-night { color: rgba(255,255,255,.5); }
.eyebrow-night .dot { background: #6BA3FF; }

.card-soft-icon {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    border-radius: 12px;
    border: 1px solid rgba(0,124,122,.14);
    background: linear-gradient(180deg, rgba(0,124,122,.08), rgba(0,155,153,.08));
    color: var(--blue);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}
.card-soft-icon i {
    font-size: .92rem;
}
.card-soft-icon.is-sky {
    border-color: rgba(14,165,233,.16);
    background: linear-gradient(180deg, rgba(14,165,233,.09), rgba(18,70,200,.06));
    color: var(--sky);
}
.card-soft-icon.is-orange {
    border-color: rgba(245,124,32,.16);
    background: linear-gradient(180deg, rgba(245,124,32,.1), rgba(255,255,255,.5));
    color: var(--orange);
}
.card-soft-icon.is-night {
    border-color: rgba(255,255,255,.12);
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(107,163,255,.08));
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

.button {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 14px 30px;
    font-family: var(--fb);
    font-weight: 700;
    font-size: .9rem;
    border-radius: 999px;
    transition: transform .18s, box-shadow .22s, background .18s, border-color .18s, color .18s;
    white-space: nowrap;
}
.button:hover { transform: translateY(-2px); }
.button i { font-size: .78rem; }

.button-primary {
    background: linear-gradient(135deg, var(--blue), var(--blue-m));
    color: #fff;
    box-shadow: 0 8px 28px rgba(0,124,122,.22);
    position: relative;
    overflow: hidden;
}
.button-primary:hover {
    background: linear-gradient(135deg, var(--blue-d), var(--blue));
    box-shadow: 0 12px 34px rgba(0,124,122,.28);
}
.button-secondary {
    background: var(--surface);
    color: var(--ink-mid);
    border: 1.5px solid var(--line);
}
.button-secondary:hover {
    border-color: var(--blue);
    color: var(--blue);
    background: var(--blue-l);
    box-shadow: 0 8px 24px var(--blue-g);
}
.button-block {
    width: 100%;
    justify-content: center;
}

.section-light {
    position: relative;
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.98));
    padding: clamp(72px, 9vw, 120px) 0;
}
.section-soft {
    position: relative;
    background: linear-gradient(180deg, rgba(247,249,251,.92), rgba(238,243,246,.98));
    padding: clamp(72px, 9vw, 120px) 0;
}
.section-night {
    background: linear-gradient(180deg, #162535 0%, #1D2E40 100%);
    padding: clamp(72px, 9vw, 120px) 0;
    position: relative;
    overflow: hidden;
}
.section-night-compact {
    padding: clamp(60px, 7vw, 96px) 0;
}
.night-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
    background-size: 72px 72px;
    opacity: .34;
    -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 45%, black 24%, transparent 100%);
    mask-image: radial-gradient(ellipse 70% 60% at 50% 45%, black 24%, transparent 100%);
    pointer-events: none;
}
.night-glow {
    position: absolute;
    top: 50%;
    right: -120px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,155,153,.12) 0%, transparent 72%);
    transform: translateY(-50%);
    opacity: .9;
    pointer-events: none;
}
.night-glow-center {
    left: 50%;
    right: auto;
    transform: translate(-50%, -50%);
    opacity: .45;
}

.section-head {
    max-width: 680px;
    margin-bottom: 56px;
}
.section-head h2 {
    font-size: clamp(2rem, 3.8vw, 3.4rem);
    color: var(--ink);
    margin-bottom: 16px;
    line-height: 1.12;
}
.section-head p {
    font-size: 1.05rem;
    color: var(--muted);
    line-height: 1.78;
}
.section-head-center {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}
.section-night .section-head h2,
.section-night .section-head-center h2 { color: #fff; }
.section-night .section-head p { color: rgba(255,255,255,.42); }

.reveal {
    opacity: 0;
    transform: translateY(32px);
    transition: opacity .85s cubic-bezier(.16,1,.3,1),
                transform .85s cubic-bezier(.16,1,.3,1);
}
.reveal.is-visible { opacity: 1; transform: none; }
.reveal-right {
    opacity: 0;
    transform: translateX(28px);
    transition: opacity .85s cubic-bezier(.16,1,.3,1),
                transform .85s cubic-bezier(.16,1,.3,1);
}
.reveal-right.is-visible { opacity: 1; transform: none; }
.reveal-delay-1 { transition-delay: .12s; }
.reveal-delay-2 { transition-delay: .24s; }
.reveal-delay-3 { transition-delay: .36s; }

.scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 0%;
    height: 3px;
    background: linear-gradient(90deg, var(--blue), var(--sky), var(--blue-m));
    z-index: 1000;
    pointer-events: none;
    transform-origin: left center;
    transition: width .06s linear;
    box-shadow: 0 0 12px rgba(0,155,153,.5);
}

.page-aura,
.page-noise,
.cursor-aura {
    pointer-events: none;
    position: fixed;
}
.page-aura {
    inset: 0;
    z-index: 0;
    background:
        radial-gradient(circle at 12% 18%, rgba(0,155,153,.08), transparent 26%),
        radial-gradient(circle at 88% 14%, rgba(0,124,122,.08), transparent 24%),
        radial-gradient(circle at 55% 80%, rgba(233,106,42,.06), transparent 24%);
}
.page-noise {
    inset: 0;
    z-index: 0;
    opacity: .18;
    background-image:
        linear-gradient(rgba(255,255,255,.26) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px);
    background-size: 32px 32px;
    mask-image: radial-gradient(circle at center, #000 48%, transparent 100%);
}
.cursor-aura {
    z-index: 1;
    left: 0;
    top: 0;
    width: 420px;
    height: 420px;
    opacity: 0;
    transform: translate3d(var(--cursor-x, -999px), var(--cursor-y, -999px), 0) translate(-50%, -50%);
    background: radial-gradient(circle, rgba(0,155,153,.18) 0%, rgba(0,124,122,.12) 32%, rgba(0,124,122,.05) 48%, transparent 72%);
    filter: blur(10px);
    transition: opacity .25s ease;
}
.has-cursor-aura .cursor-aura {
    opacity: 1;
}
main,
header,
footer,
.cookie-banner,
.cookie-modal,
.cookie-floating-button {
    position: relative;
    z-index: 2;
}

.has-spotlight {
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.has-spotlight::before {
    content: "";
    position: absolute;
    inset: -1px;
    z-index: 0;
    opacity: 0;
    background: radial-gradient(280px circle at var(--mx, 50%) var(--my, 50%), rgba(255,255,255,.6), transparent 45%);
    transition: opacity .28s ease;
}
.has-spotlight::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(255,255,255,.16), transparent 34%);
    opacity: 0;
    transition: opacity .28s ease;
}
.has-spotlight:hover::before,
.has-spotlight:hover::after {
    opacity: 1;
}
.has-spotlight > * {
    position: relative;
    z-index: 1;
}

#nav {
    position: sticky;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 500;
    height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 clamp(20px, 5vw, 64px);
    background: rgba(247,249,251,.88);
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border-bottom: 1px solid var(--line);
    transition: transform .3s ease, background .3s, box-shadow .3s ease;
    transform: translateY(0);
    box-shadow: 0 2px 20px rgba(22,37,53,.05);
}

.brand {
    font-family: var(--fb);
    font-weight: 800;
    font-size: 1.24rem;
    color: var(--ink);
    letter-spacing: -0.03em;
    display: flex;
    align-items: center;
    gap: 1px;
}
.brand-dot {
    display: inline-block;
    width: 6px; height: 6px;
    background: var(--blue);
    border-radius: 50%;
    margin: 0 1px 6px;
    animation: dot-blink 2.4s ease-in-out infinite;
}
@keyframes dot-blink { 0%,100% { opacity:1 } 50% { opacity:.28 } }
.brand-sub {
    font-size: .7rem;
    font-weight: 600;
    color: var(--muted);
    letter-spacing: .04em;
    margin-left: 4px;
    font-family: var(--fm);
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 28px;
}
.nav-links a {
    font-size: .84rem;
    font-weight: 600;
    color: var(--muted);
    transition: color .2s;
}
.nav-links a:hover { color: var(--ink); }

.nav-cta {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 11px 22px;
    background: linear-gradient(135deg, var(--blue), var(--blue-m));
    color: #fff;
    font-weight: 700;
    font-size: .8rem;
    border-radius: 999px;
    transition: background .18s, transform .18s, box-shadow .2s;
}
.nav-cta:hover {
    background: linear-gradient(135deg, var(--blue-d), var(--blue));
    transform: translateY(-1px);
    box-shadow: 0 8px 26px rgba(0,124,122,.28);
}

.menu-button {
    display: none;
    font-size: 1.15rem;
    color: var(--ink);
    padding: 6px;
}

.mobile-overlay {
    position: fixed; inset: 0;
    background: rgba(11,23,48,.45);
    z-index: 600;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s;
}
.mobile-overlay.is-open { opacity: 1; pointer-events: auto; }

.mobile-panel {
    position: fixed;
    top: 0; right: -100%;
    width: min(88%, 320px);
    height: 100vh;
    background: var(--surface);
    border-left: 1px solid var(--line);
    z-index: 700;
    padding: 76px 28px 32px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    transition: right .38s cubic-bezier(.16,1,.3,1);
}
.mobile-panel.is-open { right: 0; }

.menu-close {
    position: absolute;
    top: 18px; right: 20px;
    color: var(--muted);
    font-size: 1.15rem;
    padding: 4px;
}
.mobile-link {
    font-size: 1rem;
    font-weight: 600;
    color: var(--muted);
    transition: color .2s;
    padding: 2px 0;
}
.mobile-link:hover { color: var(--ink); }

@media (max-width: 900px) {
    .nav-links { display: none; }
    .nav-cta { display: none; }
    .menu-button { display: block; }
}

#hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding: 100px clamp(20px,5vw,64px) 80px;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(247,249,251,.92), rgba(247,249,251,1)),
        var(--bg);
}
.hero-glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    pointer-events: none;
}
.hero-glow-a {
    width: 460px; height: 420px;
    background: rgba(0,155,153,.08);
    top: -4%; right: -6%;
    opacity: .72;
}
.hero-glow-b {
    width: 300px; height: 300px;
    background: rgba(233,106,42,.05);
    bottom: 8%; left: 4%;
    opacity: .62;
}
.hero-grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(0,124,122,.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,124,122,.018) 1px, transparent 1px);
    background-size: 72px 72px;
    opacity: .38;
    -webkit-mask-image: radial-gradient(ellipse 68% 58% at 50% 40%, black 18%, transparent 100%);
    mask-image: radial-gradient(ellipse 68% 58% at 50% 40%, black 18%, transparent 100%);
    pointer-events: none;
}
.hero-shell {
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 60px;
    align-items: center;
    position: relative;
    z-index: 2;
}
@media (max-width: 1080px) {
    .hero-shell { grid-template-columns: 1fr; }
    .hero-side { display: none; }
}

.home-hero-light {
    min-height: auto;
    padding-top: 94px;
    padding-bottom: 68px;
    background:
        radial-gradient(circle at 84% 14%, rgba(0,155,153,.1), transparent 28%),
        radial-gradient(circle at 8% 82%, rgba(233,106,42,.07), transparent 24%),
        linear-gradient(180deg, rgba(247,249,251,.96), rgba(247,249,251,1)),
        var(--bg);
}
.home-hero-shell {
    grid-template-columns: minmax(0, 1.02fr) minmax(340px, .98fr);
    gap: clamp(32px, 3.6vw, 52px);
    align-items: center;
}
.home-hero-shell .hero-copy {
    padding-top: 0;
}
.home-hero-light .hero-title {
    font-family: var(--fb);
    font-weight: 700;
    font-size: clamp(2.3rem, 4vw, 4.2rem);
    line-height: 1.08;
    letter-spacing: -0.035em;
    max-width: 12ch;
    margin-bottom: 18px;
}
.home-hero-light .hero-text {
    max-width: 620px;
    font-size: 1rem;
    line-height: 1.75;
    margin-bottom: 28px;
}
.home-hero-light .hero-actions {
    margin-bottom: 26px;
}
.home-hero-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin: 0 0 28px;
    max-width: 620px;
}
.home-hero-list-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 16px;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(221,228,235,.92);
    border-radius: 18px;
    box-shadow: 0 10px 22px rgba(22,37,53,.04);
    transition: transform .2s ease, border-color .2s ease, box-shadow .25s ease, background .2s ease;
}
.home-hero-list-item:hover {
    transform: translateY(-2px);
    border-color: rgba(0,124,122,.24);
    background: rgba(255,255,255,.96);
    box-shadow: 0 14px 28px rgba(22,37,53,.08);
}
.home-hero-list-item strong {
    display: block;
    margin-bottom: 5px;
    font-family: var(--fb);
    font-size: .92rem;
    color: var(--ink);
}
.home-hero-list-item p {
    color: var(--muted);
    line-height: 1.6;
    font-size: .81rem;
}
.home-hero-kpis {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.home-hero-kpi {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(221,228,235,.96);
    box-shadow: 0 8px 20px rgba(22,37,53,.05);
    color: var(--muted);
    font-size: .78rem;
    font-weight: 600;
}
.home-hero-kpi strong {
    color: var(--blue);
    font-family: var(--fb);
    font-size: .92rem;
}
.home-hero-visual {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 22px;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,248,250,.98));
    border: 1px solid rgba(221,228,235,.95);
    border-radius: 28px;
    box-shadow: 0 22px 54px rgba(22,37,53,.11), 0 8px 22px rgba(22,37,53,.05);
    overflow: hidden;
}
.home-hero-visual::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, rgba(0,124,122,.04), transparent 36%),
        radial-gradient(circle at top right, rgba(0,155,153,.1), transparent 34%);
    pointer-events: none;
}
.home-hero-visual > * {
    position: relative;
    z-index: 1;
}
.home-hero-visual-orbit {
    position: absolute;
    inset: auto -120px -140px auto;
    width: 340px;
    height: 340px;
    border-radius: 50%;
    border: 1px solid rgba(0,124,122,.08);
    opacity: .85;
}
.home-hero-visual-orbit::before,
.home-hero-visual-orbit::after {
    content: "";
    position: absolute;
    inset: 22px;
    border-radius: 50%;
    border: 1px dashed rgba(0,124,122,.08);
}
.home-hero-visual-orbit::after {
    inset: 64px;
    border-style: solid;
    opacity: .7;
}
.home-hero-visual-head,
.home-hero-visual-ribbon {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
}
.home-hero-mini-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
    border-radius: 999px;
    border: 1px solid rgba(0,124,122,.18);
    background: rgba(0,124,122,.07);
    color: var(--blue);
    font-size: .78rem;
    font-weight: 700;
    transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.home-hero-mini-link:hover {
    background: rgba(0,124,122,.12);
    border-color: rgba(0,124,122,.28);
    transform: translateY(-2px);
}
.home-hero-visual-core {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 20px;
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(0,124,122,.9), rgba(13,104,102,.92));
    color: #fff;
    box-shadow: 0 14px 36px rgba(0,124,122,.2);
}
.home-hero-core-icon {
    width: 54px;
    height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.18);
    flex-shrink: 0;
    font-size: 1.2rem;
}
.home-hero-visual-core h2 {
    font-family: var(--fb);
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 8px;
}
.home-hero-visual-core p {
    color: rgba(255,255,255,.82);
    line-height: 1.65;
    font-size: .84rem;
}
.home-hero-visual-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.home-hero-visual-card {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
    border-radius: 20px;
    background: rgba(255,255,255,.88);
    border: 1px solid rgba(221,228,235,.94);
    box-shadow: 0 10px 24px rgba(22,37,53,.05);
}
.home-hero-visual-card strong {
    display: block;
    margin-bottom: 4px;
    font-family: var(--fb);
    font-size: .88rem;
    color: var(--ink);
}
.home-hero-visual-card p {
    color: var(--muted);
    font-size: .78rem;
    line-height: 1.58;
}
.home-hero-visual-ribbon {
    justify-content: flex-start;
}
.home-hero-visual-ribbon span {
    display: inline-flex;
    align-items: center;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(0,124,122,.07);
    border: 1px solid rgba(0,124,122,.11);
    color: var(--blue);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .04em;
}
@media (max-width: 1080px) {
    .home-hero-shell .hero-side {
        display: block;
    }
    .home-hero-light .hero-title {
        max-width: 13ch;
    }
}
@media (max-width: 720px) {
    .home-hero-light {
        padding-top: 82px;
        padding-bottom: 52px;
    }
    .home-hero-visual-grid {
        grid-template-columns: 1fr;
    }
    .home-hero-visual {
        padding: 14px;
        border-radius: 24px;
    }
    .home-hero-visual-head {
        align-items: flex-start;
    }
    .home-hero-mini-link {
        width: 100%;
    }
    .home-hero-visual-core {
        padding: 16px;
        border-radius: 18px;
    }
}

.hero-copy .eyebrow { margin-bottom: 24px; }

.hero-title {
    font-family: var(--fh);
    font-weight: 800;
    font-size: clamp(2.8rem, 5.5vw, 5.6rem);
    line-height: 1.07;
    letter-spacing: -0.04em;
    color: var(--ink);
    margin-bottom: 24px;
}
.hero-accent {
    color: var(--blue);
}

.hero-text {
    font-size: 1.05rem;
    color: var(--muted);
    line-height: 1.78;
    max-width: 540px;
    margin-bottom: 36px;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 52px;
}

.hero-stats {
    display: flex;
    flex-wrap: wrap;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
    width: fit-content;
    box-shadow: 0 10px 32px rgba(22,37,53,.08);
}
.hero-stat {
    padding: 16px 24px;
    border-right: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.hero-stat:last-child { border-right: none; }
.hero-stat strong {
    font-family: var(--fb);
    font-weight: 800;
    font-size: 1.45rem;
    color: var(--blue);
    letter-spacing: -0.03em;
    line-height: 1;
}
.hero-stat span {
    font-family: var(--fm);
    font-size: .6rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .08em;
}

.hero-panel {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 20px;
    padding: 34px 30px;
    box-shadow: 0 16px 60px rgba(22,37,53,.1), 0 4px 16px rgba(22,37,53,.06);
}
.panel-topline {
    font-family: var(--fm);
    font-size: .65rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: 12px;
}
.hero-panel h2 {
    font-family: var(--fh);
    font-size: 1.4rem;
    color: var(--ink);
    margin-bottom: 10px;
    line-height: 1.2;
}
.hero-panel > p {
    font-size: .9rem;
    color: var(--muted);
    line-height: 1.7;
    margin-bottom: 24px;
}
.panel-stack { display: flex; flex-direction: column; gap: 12px; }
.mini-card {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 16px;
    background: linear-gradient(180deg, rgba(247,249,251,.96), rgba(255,255,255,1));
    border: 1px solid var(--line);
    border-radius: var(--r);
    transition: border-color .2s, transform .18s;
}
.mini-card:hover { border-color: var(--blue-b); transform: translateX(3px); }
.mini-icon {
    width: 34px; height: 34px;
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem;
    flex-shrink: 0;
}
.mini-icon-blue { background: var(--blue-l); color: var(--blue); }
.mini-icon-sky  { background: var(--sky-l);  color: var(--sky);  }
.mini-icon-orange { background: var(--orange-l); color: var(--orange); }
.mini-card > div strong {
    display: block;
    font-size: .85rem;
    font-weight: 700;
    color: var(--ink);
    margin-bottom: 2px;
}
.mini-card > div p { font-size: .78rem; color: var(--muted); line-height: 1.55; }

.ticker-band {
    overflow: hidden;
    white-space: nowrap;
    background: var(--blue);
    padding: 11px 0;
    border-top: 1px solid var(--blue-d);
    border-bottom: 1px solid var(--blue-d);
}
.ticker-track {
    display: inline-flex;
    animation: ticker 50s linear infinite;
}
.ticker-track:hover { animation-play-state: paused; }
@keyframes ticker { 0% { transform: translateX(0) } 100% { transform: translateX(-50%) } }
.ticker-track span {
    display: inline-block;
    padding: 0 28px;
    font-family: var(--fb);
    font-weight: 600;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(255,255,255,.7);
    position: relative;
}
.ticker-track span::after {
    content: '·';
    position: absolute;
    right: 0;
    color: rgba(255,255,255,.3);
}

.problem-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}
.problem-card {
    position: relative;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: 28px 24px;
    overflow: hidden;
    transition: border-color .25s, transform .2s, box-shadow .25s;
}
.problem-card:hover {
    border-color: var(--orange-b);
    transform: translateY(-4px);
    box-shadow: 0 14px 44px rgba(245,124,32,.07);
}
.problem-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 3px;
    background: linear-gradient(90deg, var(--orange), transparent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .3s;
}
.problem-card:hover::before { transform: scaleX(1); }

.card-index {
    position: absolute;
    top: 20px; right: 20px;
    font-family: var(--fm);
    font-size: .62rem;
    color: var(--line);
    letter-spacing: .06em;
}
.problem-icon {
    width: 42px; height: 42px;
    background: var(--orange-l);
    border-radius: var(--r);
    display: flex; align-items: center; justify-content: center;
    color: var(--orange);
    font-size: .95rem;
    margin-bottom: 16px;
    transition: background .2s, color .2s;
}
.problem-card:hover .problem-icon {
    background: var(--orange);
    color: #fff;
}
.problem-card h3 {
    font-family: var(--fb);
    font-weight: 700;
    font-size: .95rem;
    color: var(--ink);
    margin-bottom: 6px;
}
.problem-card p {
    font-size: .82rem;
    color: var(--muted);
    line-height: 1.68;
}

.solution-shell {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: start;
}
@media (max-width: 900px) { .solution-shell { grid-template-columns: 1fr; gap: 48px; } }

.solution-copy h2 {
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    color: #fff;
    margin-bottom: 16px;
    line-height: 1.12;
}
.solution-copy p { font-size: 1rem; color: rgba(255,255,255,.42); line-height: 1.78; }

.solution-metrics { display: flex; flex-direction: column; gap: 12px; }
.metric-card {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--r2);
    padding: 22px 20px;
    transition: border-color .25s, transform .2s, background .2s;
}
.metric-card:hover {
    border-color: rgba(107,163,255,.28);
    transform: translateX(4px);
    background: rgba(255,255,255,.07);
}
.metric-card strong {
    display: block;
    font-family: var(--fb);
    font-weight: 700;
    font-size: .93rem;
    color: #fff;
    margin-bottom: 5px;
}
.metric-card span { font-size: .82rem; color: rgba(255,255,255,.36); line-height: 1.65; }

.product-proof-section {
    position: relative;
    overflow: hidden;
}
.product-proof-spotlight {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, .92fr);
    gap: 18px;
    margin-bottom: 18px;
}
.product-proof-hero-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,248,255,.98));
    border: 1px solid var(--line);
    border-radius: 30px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform .2s, box-shadow .25s, border-color .25s;
}
.product-proof-hero-card:hover {
    transform: translateY(-5px);
    border-color: rgba(18,70,200,.24);
    box-shadow: var(--shadow-lg);
}
.product-proof-hero-card.is-secondary {
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(238,244,255,.98));
}
.product-proof-hero-media {
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid rgba(216,226,246,.9);
}
.product-proof-hero-media img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    object-position: top center;
}
.product-proof-hero-body {
    padding: 22px 22px 24px;
}
.product-proof-hero-body h3 {
    font-size: clamp(1.4rem, 2vw, 2rem);
    color: var(--ink);
    margin-bottom: 10px;
}
.product-proof-hero-body p {
    color: var(--muted);
    line-height: 1.82;
    font-size: .92rem;
}
.product-proof-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 10px;
}
.product-proof-card {
    display: block;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 26px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform .2s, box-shadow .25s, border-color .25s;
}
.product-proof-card:hover {
    transform: translateY(-5px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.product-proof-card,
.product-proof-hero-card {
    cursor: zoom-in;
}
.product-proof-media {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: linear-gradient(135deg, var(--bg2), #fff);
    border-bottom: 1px solid var(--line);
}
.product-proof-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.product-proof-body {
    padding: 18px 18px 20px;
}
.product-proof-tag {
    display: inline-block;
    margin-bottom: 10px;
    padding: 5px 10px;
    border-radius: 999px;
    background: var(--blue-l);
    border: 1px solid var(--blue-b);
    color: var(--blue);
    font-family: var(--fm);
    font-size: .62rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.product-proof-body h3 {
    font-family: var(--fb);
    font-size: 1rem;
    color: var(--ink);
    margin-bottom: 8px;
}
.product-proof-body p {
    font-size: .85rem;
    color: var(--muted);
    line-height: 1.7;
}

.verifactu-shell {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: start;
}
@media (max-width: 900px) { .verifactu-shell { grid-template-columns: 1fr; gap: 48px; } }

.verifactu-copy h2 {
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    color: var(--ink);
    margin-bottom: 16px;
    line-height: 1.12;
}
.verifactu-copy > p {
    font-size: 1rem;
    color: var(--muted);
    line-height: 1.78;
    margin-bottom: 24px;
}
.chip-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.chip {
    padding: 5px 14px;
    border-radius: 100px;
    background: var(--blue-l);
    border: 1px solid var(--blue-b);
    font-family: var(--fm);
    font-size: .66rem;
    color: var(--blue);
    letter-spacing: .07em;
    text-transform: uppercase;
}

.checklist { display: flex; flex-direction: column; gap: 10px; }
.check-row {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 18px 18px;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    transition: border-color .22s, transform .18s;
}
.check-row:hover { border-color: var(--blue-b); transform: translateX(4px); }
.check-icon {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: var(--blue-l);
    border: 1.5px solid var(--blue-b);
    display: flex; align-items: center; justify-content: center;
    color: var(--blue);
    font-size: .65rem;
    flex-shrink: 0;
    margin-top: 2px;
}
.check-row h3 {
    font-family: var(--fb);
    font-weight: 700;
    font-size: .88rem;
    color: var(--ink);
    margin-bottom: 3px;
}
.check-row p { font-size: .8rem; color: var(--muted); line-height: 1.6; }

.tab-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 32px;
    justify-content: center;
}
.tab-button {
    padding: 9px 22px;
    border-radius: 100px;
    font-family: var(--fb);
    font-weight: 600;
    font-size: .8rem;
    color: var(--muted);
    background: var(--surface);
    border: 1.5px solid var(--line);
    transition: all .2s;
}
.tab-button:hover { border-color: var(--blue-b); color: var(--blue); }
.tab-button.is-active {
    background: var(--blue);
    border-color: var(--blue);
    color: #fff;
    box-shadow: 0 4px 16px rgba(18,70,200,.22);
}

.tab-panel { display: none; }
.tab-panel.is-active { display: block; }

.tab-banner {
    border-radius: var(--r2);
    padding: 28px 28px;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.tab-banner > div span {
    font-family: var(--fm);
    font-size: .65rem;
    color: rgba(255,255,255,.55);
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 6px;
    display: block;
}
.tab-banner h3 {
    font-family: var(--fh);
    font-size: clamp(1.4rem, 2.5vw, 2rem);
    color: #fff;
    font-weight: 400;
    margin-bottom: 6px;
    line-height: 1.15;
}
.tab-banner p {
    font-size: .88rem;
    color: rgba(255,255,255,.55);
    max-width: 400px;
    line-height: 1.65;
}
.tab-banner-blue  { background: var(--blue); }
.tab-banner-sky   { background: var(--sky); }
.tab-banner-orange { background: var(--orange); }
.tab-banner-mix   { background: linear-gradient(130deg, var(--blue-d), var(--sky)); }
.tab-banner-night { background: var(--night2); border: 1px solid rgba(255,255,255,.07); }

.module-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(268px, 1fr));
    gap: 14px;
}
.module-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: 24px 22px;
    position: relative;
    overflow: hidden;
    transition: border-color .25s, transform .2s, box-shadow .25s;
}
.module-card:hover {
    border-color: var(--blue-b);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}
.module-card::after {
    content: '';
    position: absolute;
    left: 0; top: 0;
    width: 3px; height: 100%;
    background: var(--blue);
    border-radius: 0 2px 2px 0;
    opacity: 0;
    transition: opacity .25s;
}
.module-card:hover::after { opacity: 1; }

.module-icon {
    width: 40px; height: 40px;
    border-radius: var(--r);
    background: var(--blue-l);
    color: var(--blue);
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem;
    margin-bottom: 14px;
    transition: background .2s, color .2s;
}
.module-icon-sky    { background: var(--sky-l);    color: var(--sky); }
.module-icon-orange { background: var(--orange-l); color: var(--orange); }
.module-card:hover .module-icon     { background: var(--blue);   color: #fff; }
.module-card:hover .module-icon-sky { background: var(--sky);    color: #fff; }
.module-card:hover .module-icon-orange { background: var(--orange); color: #fff; }

.module-card h3 {
    font-family: var(--fb);
    font-weight: 700;
    font-size: .92rem;
    color: var(--ink);
    margin-bottom: 5px;
}
.module-card p { font-size: .8rem; color: var(--muted); line-height: 1.65; }

.sector-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(260px, 1fr));
    gap: 14px;
}
.sector-card {
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: 26px 22px;
    transition: border-color .25s, transform .2s, box-shadow .25s, background .2s;
}
.sector-card:hover {
    border-color: var(--blue-b);
    transform: translateY(-3px);
    box-shadow: var(--shadow-sm);
    background: var(--blue-l);
}
.sector-card h3 {
    font-family: var(--fb);
    font-weight: 700;
    font-size: .95rem;
    color: var(--ink);
    margin-bottom: 7px;
}
.sector-card p { font-size: .82rem; color: var(--muted); line-height: 1.68; }
.sector-card:hover h3 { color: var(--blue); }

.integration-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(128px, 1fr));
    gap: 12px;
}
.integration-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 22px 14px;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    text-align: center;
    transition: border-color .25s, transform .2s, box-shadow .22s, background .2s;
}
.integration-card:hover {
    border-color: var(--blue-b);
    transform: translateY(-3px);
    box-shadow: var(--shadow-sm);
}
.integration-card i {
    width: 40px; height: 40px;
    border-radius: var(--r);
    background: var(--blue-l);
    color: var(--blue);
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem;
    transition: background .2s, color .2s;
}
.integration-card:hover i { background: var(--blue); color: #fff; }
.integration-card span {
    font-family: var(--fb);
    font-weight: 600;
    font-size: .7rem;
    color: var(--muted);
    transition: color .2s;
}
.integration-card:hover span { color: var(--ink); }

.why-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 14px;
}
.why-card {
    padding: 28px 24px;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: var(--r2);
    background: rgba(255,255,255,.03);
    transition: border-color .25s, transform .2s, background .25s;
}
.why-card:hover {
    border-color: rgba(107,163,255,.25);
    transform: translateY(-4px);
    background: rgba(255,255,255,.055);
}
.why-card i {
    display: flex;
    width: 40px; height: 40px;
    border-radius: var(--r);
    background: rgba(18,70,200,.2);
    color: #6BA3FF;
    align-items: center; justify-content: center;
    font-size: .9rem;
    margin-bottom: 16px;
}
.why-card h3 {
    font-family: var(--fb);
    font-weight: 700;
    font-size: .95rem;
    color: #fff;
    margin-bottom: 7px;
}
.why-card p { font-size: .82rem; color: rgba(255,255,255,.36); line-height: 1.7; }

.contact-shell {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: start;
}
@media (max-width: 900px) { .contact-shell { grid-template-columns: 1fr; gap: 48px; } }

.contact-copy h2 {
    font-size: clamp(1.8rem, 3.2vw, 2.9rem);
    color: var(--ink);
    margin-bottom: 16px;
    line-height: 1.12;
}
.contact-copy > p {
    font-size: .98rem;
    color: var(--muted);
    line-height: 1.78;
    margin-bottom: 32px;
}
.contact-points {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.contact-points > div {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.contact-points span,
.contact-aside-label {
    font-family: var(--fm);
    font-size: .62rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .1em;
}
.contact-points a, .contact-points p {
    font-size: .95rem;
    font-weight: 600;
    color: var(--ink);
    transition: color .2s;
}
.page-breadcrumbs {
    padding: 94px 0 0;
}
.page-breadcrumbs-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.page-breadcrumbs-item {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: var(--muted);
    font-size: .78rem;
}
.page-breadcrumbs-item:not(:last-child)::after {
    content: "/";
    color: rgba(112, 124, 145, .55);
}
.page-breadcrumbs-item a {
    color: var(--muted);
    transition: color .2s;
}
.page-breadcrumbs-item a:hover {
    color: var(--blue);
}
.page-breadcrumbs-item span[aria-current="page"] {
    color: var(--ink);
    font-weight: 600;
}
.contact-points a:hover,
.contact-aside-card a:hover { color: var(--blue); }

.contact-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: 32px 28px;
    box-shadow: var(--shadow-md);
}
.form-topline {
    font-family: var(--fm);
    font-size: .66rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: 20px;
}
.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 14px;
}
@media (max-width: 500px) { .form-grid { grid-template-columns: 1fr; } }

.field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.field:last-of-type { margin-bottom: 18px; }
.field label {
    font-size: .78rem;
    font-weight: 600;
    color: var(--ink-mid);
    letter-spacing: .01em;
}
.field input,
.field textarea {
    padding: 11px 14px;
    background: var(--bg);
    border: 1.5px solid var(--line);
    border-radius: var(--r);
    font-size: .9rem;
    color: var(--ink);
    transition: border-color .2s, box-shadow .2s;
    outline: none;
    resize: vertical;
}
.field input::placeholder, .field textarea::placeholder { color: var(--muted); }
.field input:focus, .field textarea:focus {
    border-color: var(--blue);
    box-shadow: 0 0 0 3px rgba(18,70,200,.10);
    background: var(--surface);
}

.check-consent {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 20px;
    cursor: pointer;
}
.check-consent input[type="checkbox"] {
    margin-top: 3px;
    width: 16px;
    height: 16px;
    accent-color: var(--blue);
    flex-shrink: 0;
    cursor: pointer;
}
.check-consent span {
    font-size: .78rem;
    color: var(--muted);
    line-height: 1.6;
}
.check-consent a { color: var(--blue); }
.check-consent a:hover { text-decoration: underline; }

.form-feedback {
    margin-top: 14px;
    font-size: .82rem;
    color: var(--muted);
    min-height: 18px;
    text-align: center;
}
.form-feedback.success,
.form-feedback.is-success { color: #16a34a; }
.form-feedback.error,
.form-feedback.is-error { color: var(--orange); }

.contact-subtle-section {
    padding-top: clamp(56px, 7vw, 88px);
}
.contact-subtle-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
    gap: 42px;
    align-items: center;
}
.contact-subtle-copy h2 {
    font-size: clamp(1.9rem, 3vw, 3rem);
    color: var(--ink);
    margin-bottom: 14px;
}
.contact-subtle-copy p {
    font-size: .98rem;
    line-height: 1.8;
    color: var(--muted);
    max-width: 640px;
}
.contact-subtle-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}
.contact-quick-grid {
    display: grid;
    gap: 14px;
}
.contact-quick-card {
    background: linear-gradient(180deg, #fff, #f8fbff);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: 20px 20px;
    box-shadow: var(--shadow-sm);
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.contact-quick-card:hover {
    transform: translateY(-3px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.contact-quick-icon {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: var(--blue-l);
    color: var(--blue);
    margin-bottom: 14px;
}
.contact-quick-card strong {
    display: block;
    font-family: var(--fb);
    font-size: .95rem;
    color: var(--ink);
    margin-bottom: 5px;
}
.contact-quick-card p {
    font-size: .84rem;
    line-height: 1.65;
    color: var(--muted);
}

.contact-page {
    min-height: 100vh;
}
.contact-page-hero {
    position: relative;
    overflow: hidden;
    padding: 108px 0 64px;
}
.contact-page-hero-shell {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
    gap: 36px;
    align-items: center;
}
.contact-page-copy h1 {
    font-size: clamp(2.25rem, 4vw, 3.85rem);
    color: var(--ink);
    margin-bottom: 18px;
    line-height: 1.08;
    max-width: 14ch;
}
.contact-page-copy p {
    max-width: 720px;
    font-size: 1rem;
    line-height: 1.74;
    color: var(--muted);
}
.contact-page-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 28px;
}
.contact-page-hero-card {
    background: rgba(255,255,255,.9);
    border: 1px solid rgba(216,226,246,.95);
    border-radius: 20px;
    padding: 24px;
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.contact-hero-points {
    display: grid;
    gap: 16px;
}
.contact-hero-points strong {
    display: block;
    font-size: .94rem;
    color: var(--ink);
    margin-bottom: 4px;
}
.contact-hero-points p {
    font-size: .84rem;
    color: var(--muted);
    line-height: 1.68;
}

.contact-page-main {
    padding-top: clamp(48px, 6vw, 72px);
}
.contact-page-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.04fr) minmax(360px, .96fr);
    gap: 28px;
    align-items: start;
}
.contact-page-info {
    display: grid;
    gap: 18px;
}
.contact-page-info > .section-head {
    margin-bottom: 0;
    padding: 34px 34px 30px;
    border-radius: calc(var(--r2) + 8px);
    background:
        radial-gradient(circle at top right, rgba(0,124,122,.08), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,248,251,.98));
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
}
.contact-page-info > .section-head h2 {
    max-width: 16ch;
    margin-bottom: 14px;
}
.contact-page-info > .section-head p {
    max-width: 64ch;
}
.contact-page-story {
    display: grid;
    gap: 20px;
}
.contact-story-intro {
    padding: 34px 34px 30px;
    border-radius: calc(var(--r2) + 8px);
    background:
        radial-gradient(circle at top right, rgba(0,124,122,.08), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,248,251,.98));
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
}
.contact-story-intro h2 {
    font-size: clamp(1.95rem, 3vw, 3rem);
    color: var(--ink);
    margin-bottom: 14px;
    max-width: 15ch;
}
.contact-story-intro p {
    color: var(--muted);
    line-height: 1.82;
    max-width: 64ch;
}
.contact-story-flow {
    display: grid;
    gap: 12px;
}
.contact-story-step {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 16px;
    align-items: start;
    padding: 22px;
    background: rgba(255,255,255,.9);
    border: 1px solid var(--line);
    border-radius: calc(var(--r2) + 4px);
    box-shadow: var(--shadow-sm);
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.contact-story-step:hover {
    transform: translateY(-3px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-sm);
}
.contact-story-step-index {
    width: 58px;
    height: 58px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--blue), var(--blue-m));
    box-shadow: 0 10px 24px rgba(0,124,122,.18);
    color: #fff;
    font-family: var(--fm);
    font-size: .8rem;
    letter-spacing: .08em;
}
.contact-story-step h3 {
    font-family: var(--fb);
    font-weight: 700;
    font-size: 1rem;
    color: var(--ink);
    margin-bottom: 6px;
}
.contact-story-step p {
    font-size: .86rem;
    line-height: 1.72;
    color: var(--muted);
}
.contact-direct-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}
.contact-direct-card {
    min-height: 100%;
    padding: 22px 20px;
    background: linear-gradient(180deg, #fff, #f8fbff);
    border: 1px solid var(--line);
    border-radius: calc(var(--r2) + 2px);
    box-shadow: var(--shadow-sm);
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.contact-direct-card:hover {
    transform: translateY(-3px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.contact-direct-card.is-accent {
    background:
        radial-gradient(circle at top right, rgba(233,106,42,.1), transparent 34%),
        linear-gradient(180deg, #fff, #fff9f4);
}
.contact-direct-card a,
.contact-direct-card p {
    font-size: .92rem;
    color: var(--ink);
    line-height: 1.72;
}
.contact-direct-card a {
    display: inline-block;
    font-weight: 700;
    margin: 8px 0 5px;
}
.contact-direct-card p + p {
    margin-top: 4px;
    color: var(--muted);
}
.contact-page-form {
    position: sticky;
    top: 88px;
    padding: 28px 28px 30px;
    border-radius: calc(var(--r2) + 8px);
    background:
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,248,251,.98));
    border: 1px solid rgba(216,226,246,.95);
    box-shadow: 0 18px 48px rgba(22,37,53,.1);
}
.contact-form-head {
    margin-bottom: 20px;
}
.contact-form-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}
.contact-form-meta span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    border-radius: 999px;
    background: rgba(0,124,122,.07);
    border: 1px solid rgba(0,124,122,.11);
    color: var(--muted);
    font-size: .76rem;
    font-weight: 700;
}
.contact-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.contact-feature-card {
    padding: 22px 20px;
    background: rgba(255,255,255,.9);
    border: 1px solid var(--line);
    border-radius: calc(var(--r2) + 2px);
    box-shadow: var(--shadow-sm);
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.contact-feature-card:hover {
    transform: translateY(-3px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.contact-feature-icon {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    margin-bottom: 14px;
    background: linear-gradient(180deg, rgba(0,124,122,.08), rgba(0,155,153,.08));
    border: 1px solid rgba(0,124,122,.12);
    color: var(--blue);
}
.contact-feature-card h3 {
    font-family: var(--fb);
    font-size: .96rem;
    color: var(--ink);
    margin-bottom: 6px;
}
.contact-feature-card p {
    color: var(--muted);
    font-size: .84rem;
    line-height: 1.7;
}
.contact-form-title {
    font-size: clamp(1.9rem, 3vw, 2.6rem);
    color: var(--ink);
    margin-bottom: 10px;
}
.contact-form-intro {
    font-size: .95rem;
    color: var(--muted);
    line-height: 1.75;
    margin-bottom: 22px;
}
.seo-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.seo-action-grid > :last-child {
    grid-column: 1 / -1;
}
.seo-action-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 24px 22px;
    background:
        radial-gradient(circle at top right, rgba(0,124,122,.06), transparent 28%),
        linear-gradient(180deg, #fff, #f8fbff);
    border: 1px solid var(--line);
    border-radius: calc(var(--r2) + 2px);
    box-shadow: var(--shadow-sm);
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.seo-action-card:hover {
    transform: translateY(-3px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.seo-action-card strong {
    font-family: var(--fb);
    font-size: .96rem;
    color: var(--ink);
}
.seo-action-card p {
    color: var(--muted);
    font-size: .84rem;
    line-height: 1.7;
}
.seo-action-link {
    margin-top: auto;
    width: fit-content;
}
@media (max-width: 760px) {
    .seo-action-grid {
        grid-template-columns: 1fr;
    }
    .seo-action-grid > :last-child {
        grid-column: auto;
    }
}
.seo-form-compact .contact-form-title {
    font-size: clamp(1.55rem, 2.6vw, 2.1rem);
}
.seo-form-compact .contact-form-intro {
    font-size: .9rem;
    margin-bottom: 8px;
}
.seo-form-compact .contact-form-head {
    margin-bottom: 18px;
}
.seo-form-compact .contact-form-meta {
    margin-top: 12px;
}
.seo-form-grid {
    margin-bottom: 10px;
}
.seo-form-note {
    margin-top: 12px;
    font-size: .78rem;
    color: var(--muted);
    line-height: 1.65;
    text-align: center;
}

.image-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px;
}
.image-lightbox[hidden] {
    display: none;
}
.image-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(16, 24, 36, .46);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.image-lightbox-dialog {
    position: relative;
    z-index: 1;
    width: min(1120px, calc(100vw - 56px));
    max-height: calc(100vh - 56px);
    padding: 16px;
    border-radius: 28px;
    background: rgba(255,255,255,.82);
    border: 1px solid rgba(255,255,255,.5);
    box-shadow: 0 28px 80px rgba(16,24,36,.24);
}
.image-lightbox-frame {
    overflow: hidden;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(245,248,251,.96), rgba(255,255,255,.98));
    border: 1px solid rgba(221,228,235,.95);
}
.image-lightbox-frame img {
    display: block;
    width: 100%;
    max-height: calc(100vh - 120px);
    object-fit: contain;
    object-position: center;
}
.image-lightbox-close {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 2;
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(221,228,235,.95);
    color: var(--ink);
    box-shadow: 0 8px 22px rgba(16,24,36,.12);
    transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.image-lightbox-close:hover {
    transform: translateY(-1px);
    background: rgba(255,255,255,.98);
    border-color: rgba(0,124,122,.18);
}
body.image-lightbox-open {
    overflow: hidden;
}
@media (max-width: 760px) {
    .image-lightbox {
        padding: 14px;
    }
    .image-lightbox-dialog {
        width: min(100vw - 28px, 980px);
        max-height: calc(100vh - 28px);
        padding: 10px;
        border-radius: 20px;
    }
    .image-lightbox-frame {
        border-radius: 14px;
    }
    .image-lightbox-frame img {
        max-height: calc(100vh - 72px);
    }
}

.verifactu-actions,
.verifactu-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.verifactu-page {
    min-height: 100vh;
}
.verifactu-hero {
    position: relative;
    overflow: hidden;
    padding: 108px 0 72px;
}
.verifactu-hero-shell {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    gap: 36px;
    align-items: center;
}
.verifactu-hero-copy h1 {
    font-size: clamp(2.35rem, 4.1vw, 4rem);
    color: var(--ink);
    margin-bottom: 18px;
    line-height: 1.08;
    max-width: 14ch;
}
.verifactu-hero-copy p {
    max-width: 720px;
    font-size: 1rem;
    line-height: 1.75;
    color: var(--muted);
}
.verifactu-hero-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 28px;
}
.verifactu-hero-panel {
    background: rgba(255,255,255,.9);
    border: 1px solid rgba(216,226,246,.95);
    border-radius: 20px;
    padding: 26px 24px;
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.verifactu-hero-list {
    display: grid;
    gap: 16px;
}
.verifactu-hero-list strong {
    display: block;
    font-size: .95rem;
    color: var(--ink);
    margin-bottom: 4px;
}
.verifactu-hero-list p {
    font-size: .84rem;
    line-height: 1.68;
    color: var(--muted);
}

.verifactu-deadline-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}
.verifactu-deadline-card,
.verifactu-faq-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: 24px 22px;
    box-shadow: var(--shadow-sm);
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.verifactu-deadline-card:hover,
.verifactu-faq-card:hover {
    transform: translateY(-4px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.verifactu-deadline-date {
    display: inline-block;
    margin-bottom: 12px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--blue-l);
    border: 1px solid var(--blue-b);
    color: var(--blue);
    font-family: var(--fm);
    font-size: .67rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.verifactu-deadline-card h3,
.verifactu-faq-card h3 {
    font-family: var(--fb);
    font-size: .98rem;
    font-weight: 700;
    color: var(--ink);
    margin-bottom: 8px;
}
.verifactu-deadline-card p,
.verifactu-faq-card p {
    font-size: .85rem;
    line-height: 1.72;
    color: var(--muted);
}

.verifactu-requirements-shell,
.verifactu-practical-shell {
    display: grid;
    grid-template-columns: minmax(0, .94fr) minmax(0, 1.06fr);
    gap: 56px;
    align-items: start;
    position: relative;
    z-index: 1;
}
.verifactu-requirements-copy h2 {
    color: #fff;
    font-size: clamp(2rem, 3.7vw, 3.4rem);
    margin-bottom: 16px;
}
.verifactu-requirements-copy p {
    color: rgba(255,255,255,.45);
    line-height: 1.82;
}
.verifactu-requirements-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.verifactu-practical-copy h2 {
    font-size: clamp(2rem, 3.5vw, 3.1rem);
    color: var(--ink);
    margin-bottom: 16px;
}
.verifactu-practical-copy p {
    color: var(--muted);
    line-height: 1.82;
}

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

.software-vf-page {
    min-height: 100vh;
}
.software-vf-hero {
    padding-bottom: 92px;
}
.software-vf-intent-grid,
.software-vf-check-grid,
.software-vf-fit-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}
.software-vf-intent-card,
.software-vf-check-card,
.software-vf-fit-card,
.software-vf-link-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    box-shadow: var(--shadow-sm);
}
.software-vf-intent-card,
.software-vf-check-card,
.software-vf-fit-card {
    padding: 24px 22px;
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.software-vf-intent-card:hover,
.software-vf-check-card:hover,
.software-vf-fit-card:hover {
    transform: translateY(-4px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.software-vf-kicker {
    display: inline-block;
    margin-bottom: 12px;
    color: var(--blue);
    font-family: var(--fm);
    font-size: .68rem;
    letter-spacing: .1em;
    text-transform: uppercase;
}
.software-vf-intent-card h3,
.software-vf-check-card h3,
.software-vf-fit-card h3,
.software-vf-compare-card h3 {
    font-family: var(--fb);
    font-size: 1rem;
    color: var(--ink);
    margin-bottom: 10px;
}
.software-vf-intent-card p,
.software-vf-check-card p,
.software-vf-fit-card p {
    color: var(--muted);
    line-height: 1.76;
    font-size: .88rem;
}
.software-vf-compare-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
}
.software-vf-compare-card {
    border-radius: 24px;
    padding: 28px 26px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.04);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.software-vf-compare-card h3 {
    color: #fff;
}
.software-vf-compare-card.is-accent {
    background:
        radial-gradient(circle at top left, rgba(14,165,233,.16), transparent 46%),
        rgba(18,70,200,.14);
    border-color: rgba(14,165,233,.2);
}
.software-vf-list {
    margin: 0;
    padding-left: 18px;
    color: rgba(255,255,255,.72);
}
.software-vf-list li {
    line-height: 1.75;
}
.software-vf-list li + li {
    margin-top: 8px;
}
.software-vf-link-card {
    padding: 26px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}
.software-vf-link-card h2 {
    font-size: clamp(1.7rem, 3vw, 2.5rem);
    color: var(--ink);
    margin: 6px 0 0;
}

.legal-page {
    min-height: 100vh;
    padding: 44px 0 72px;
}
.legal-shell {
    max-width: 920px;
}
.legal-back {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    color: var(--blue);
    font-weight: 700;
    transition: color .2s, transform .18s;
}
.legal-back:hover {
    color: var(--blue-d);
    transform: translateX(-2px);
}
.legal-kicker {
    display: inline-block;
    font-family: var(--fm);
    font-size: .68rem;
    color: var(--blue);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 18px;
}
.legal-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: clamp(28px, 4vw, 40px);
    box-shadow: var(--shadow-md);
}
.legal-card h1 {
    font-size: clamp(2.4rem, 5vw, 4rem);
    color: var(--ink);
    margin-bottom: 18px;
}
.legal-card h2 {
    font-size: 1.35rem;
    color: var(--ink);
    margin: 28px 0 12px;
}
.legal-card p,
.legal-card li {
    font-size: .96rem;
    color: var(--muted);
    line-height: 1.8;
}
.legal-list {
    margin: 0;
    padding-left: 20px;
}
.legal-list li + li {
    margin-top: 6px;
}

.site-footer {
    position: relative;
    margin-top: auto;
    background:
        radial-gradient(circle at 8% 0%, rgba(0,155,153,.14), transparent 22%),
        linear-gradient(180deg, #162535, #1B2C3E 55%, #243547);
    border-top: 1px solid rgba(255,255,255,.08);
    padding: 46px 0 42px;
    overflow: hidden;
}
.site-footer::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,155,153,.45), transparent);
}
.site-footer::after {
    content: "";
    position: absolute;
    inset: auto auto 24px -80px;
    width: 240px;
    height: 240px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,155,153,.16), transparent 70%);
    pointer-events: none;
}
.footer-shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 20px 28px;
    align-items: center;
}
.footer-brand-block {
    display: grid;
    gap: 8px;
}
.footer-brand {
    font-family: var(--fb);
    font-weight: 800;
    font-size: 1.1rem;
    color: #fff;
    letter-spacing: -0.02em;
    display: flex;
    align-items: center;
}
.footer-note {
    color: rgba(255,255,255,.58);
    font-size: .84rem;
}
.footer-site-link {
    display: inline-flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 18px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.1);
    background: linear-gradient(135deg, rgba(0,124,122,.18), rgba(255,255,255,.04));
    transition: transform .2s, box-shadow .2s, border-color .2s;
}
.footer-site-link:hover {
    transform: translateY(-2px);
    border-color: rgba(0,155,153,.35);
    box-shadow: 0 14px 34px rgba(0,0,0,.18);
}
.footer-site-label {
    font-family: var(--fm);
    font-size: .64rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--blue);
}
.footer-site-link strong {
    color: #fff;
    font-size: .9rem;
}
.footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    grid-column: 1 / -1;
}
.footer-links a {
    font-size: .8rem;
    color: rgba(255,255,255,.5);
    transition: color .2s;
}
.footer-cookie-button {
    appearance: none;
    border: 0;
    padding: 0;
    background: transparent;
    font: inherit;
    font-size: .8rem;
    color: rgba(255,255,255,.5);
    cursor: pointer;
    transition: color .2s;
}
.footer-cookie-button:hover {
    color: var(--blue-m);
}
.footer-links a:hover { color: var(--blue-m); }
.footer-copy {
    font-family: var(--fm);
    font-size: .65rem;
    color: rgba(255,255,255,.28);
    letter-spacing: .04em;
    grid-column: 1 / -1;
}

.cookie-banner {
    position: fixed;
    inset: auto 24px 24px 24px;
    z-index: 1200;
}
.cookie-banner-card {
    max-width: 1180px;
    margin: 0 auto;
    background: rgba(255,255,255,.96);
    border: 1px solid var(--line);
    border-radius: 24px;
    box-shadow: var(--shadow-lg);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    padding: 22px 24px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px 24px;
    align-items: end;
}
.cookie-kicker {
    font-family: var(--fm);
    font-size: .66rem;
    color: var(--blue);
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.cookie-banner-copy h2,
.cookie-modal-card h2 {
    font-size: clamp(1.5rem, 2.5vw, 2.1rem);
    color: var(--ink);
    margin-bottom: 10px;
}
.cookie-banner-copy p,
.cookie-modal-intro {
    color: var(--muted);
    line-height: 1.75;
    font-size: .92rem;
}
.cookie-banner-actions,
.cookie-modal-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.button-ghost {
    border: 1px solid var(--line);
    background: transparent;
    color: var(--ink);
}
.button-ghost:hover {
    border-color: var(--blue-b);
    background: var(--blue-l);
}
.cookie-modal {
    position: fixed;
    inset: 0;
    z-index: 1250;
}
.cookie-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(11,23,48,.45);
}
.cookie-modal-card {
    position: relative;
    z-index: 1;
    width: min(860px, calc(100vw - 32px));
    margin: 72px auto;
    background: #fff;
    border-radius: 28px;
    border: 1px solid var(--line);
    box-shadow: var(--shadow-lg);
    padding: 28px;
}
.cookie-modal-close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--line);
    background: #fff;
    color: var(--ink);
}
.cookie-option-list {
    display: grid;
    gap: 14px;
    margin-top: 20px;
}
.cookie-option-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 18px 18px;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: var(--bg);
}
.cookie-option-card.is-locked {
    background: linear-gradient(135deg, rgba(18,70,200,.05), rgba(14,165,233,.06));
}
.cookie-option-card h3 {
    font-family: var(--fb);
    font-size: .98rem;
    color: var(--ink);
    margin-bottom: 6px;
}
.cookie-option-card p {
    color: var(--muted);
    line-height: 1.7;
    font-size: .86rem;
}
.cookie-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 124px;
    padding: 8px 12px;
    border-radius: 999px;
    font-family: var(--fm);
    font-size: .66rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    border: 1px solid var(--line);
    color: var(--muted);
}
.cookie-pill.is-active {
    background: var(--blue-l);
    border-color: var(--blue-b);
    color: var(--blue);
}
.cookie-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
}
.cookie-switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.cookie-switch span {
    width: 62px;
    height: 36px;
    border-radius: 999px;
    background: #d8e2f6;
    border: 1px solid var(--line);
    position: relative;
    transition: background .2s, border-color .2s;
}
.cookie-switch span::after {
    content: '';
    position: absolute;
    top: 4px;
    left: 4px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 4px 14px rgba(11,23,48,.12);
    transition: transform .2s;
}
.cookie-switch input:checked + span {
    background: rgba(18,70,200,.18);
    border-color: rgba(18,70,200,.25);
}
.cookie-switch input:checked + span::after {
    transform: translateX(26px);
}
.cookie-modal-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-top: 24px;
}
.cookie-legal-link {
    color: var(--blue);
    font-weight: 700;
}
.cookie-floating-button {
    position: fixed;
    left: 18px;
    bottom: 18px;
    z-index: 1190;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.96);
    color: var(--ink);
    box-shadow: var(--shadow-sm);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.cookie-floating-button:hover {
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.scroll-top-button {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 1190;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 999px;
    border: 1px solid rgba(18,70,200,.16);
    background: rgba(11,23,48,.9);
    color: #fff;
    box-shadow: 0 14px 34px rgba(11,23,48,.22);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    opacity: 0;
    transform: translateY(12px);
    transition: opacity .22s ease, transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.scroll-top-button.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.scroll-top-button:hover {
    border-color: rgba(107,163,255,.36);
    box-shadow: 0 18px 42px rgba(11,23,48,.28);
}
.scroll-top-button i {
    font-size: .82rem;
}
.scroll-top-button span {
    font-weight: 700;
    font-size: .84rem;
}
.cookie-modal-open {
    overflow: hidden;
}

.local-erp-page {
    min-height: 100vh;
}
.local-erp-hero {
    padding-bottom: 88px;
}
.local-erp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}
.local-context-block {
    max-width: 720px;
}
.local-context-text {
    font-size: 1.08rem;
    line-height: 1.82;
    color: var(--muted);
    margin-top: 18px;
}
.local-erp-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r2);
    padding: 24px 22px;
    box-shadow: var(--shadow-sm);
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.local-erp-card:hover {
    transform: translateY(-4px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-md);
}
.local-erp-kicker {
    display: inline-block;
    margin-bottom: 12px;
    color: var(--blue);
    font-family: var(--fm);
    font-size: .66rem;
    letter-spacing: .1em;
    text-transform: uppercase;
}
.local-erp-card h3 {
    font-family: var(--fb);
    font-size: 1rem;
    color: var(--ink);
    margin-bottom: 10px;
}
.local-erp-card p {
    color: var(--muted);
    line-height: 1.78;
    font-size: .88rem;
}
.local-erp-split {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 56px;
    align-items: start;
    position: relative;
    z-index: 1;
}
.local-erp-copy h2 {
    color: #fff;
    font-size: clamp(2rem, 3.8vw, 3.4rem);
    margin-bottom: 16px;
}
.local-erp-copy p {
    color: rgba(255,255,255,.45);
    line-height: 1.82;
}
.local-erp-points {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.local-erp-links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.local-erp-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 999px;
    background: var(--surface);
    border: 1px solid var(--line);
    color: var(--ink);
    font-size: .84rem;
    font-weight: 600;
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.local-erp-link:hover {
    transform: translateY(-2px);
    border-color: var(--blue-b);
    box-shadow: var(--shadow-sm);
}
.murcia-erp-page {
    min-height: 100vh;
}
.murcia-hero {
    padding-bottom: 76px;
}
.murcia-hero-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    gap: 34px;
    align-items: start;
}
.murcia-hero-copy h1 {
    max-width: 14ch;
}
.murcia-hero-copy p {
    max-width: 66ch;
}
.murcia-hero-panel {
    position: relative;
    padding: 24px 22px;
    border-radius: calc(var(--r2) + 4px);
    background: rgba(255,255,255,.9);
    border: 1px solid rgba(140, 164, 208, .24);
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.murcia-hero-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 18px;
}
.murcia-metric {
    padding: 18px 16px;
    border-radius: 18px;
    background: rgba(243, 247, 255, .86);
    border: 1px solid rgba(152, 175, 218, .28);
}
.murcia-metric strong {
    display: block;
    margin-bottom: 8px;
    color: var(--ink);
    font-family: var(--fb);
    font-size: .94rem;
}
.murcia-metric span {
    color: var(--muted);
    line-height: 1.7;
    font-size: .84rem;
}
.murcia-section {
    position: relative;
}
.murcia-highlight-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}
.murcia-highlight-card,
.murcia-link-group {
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,248,253,.98));
    border: 1px solid var(--line);
    border-radius: calc(var(--r2) + 2px);
    box-shadow: var(--shadow-sm);
}
.murcia-highlight-card {
    padding: 24px 22px;
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.murcia-highlight-card:hover {
    transform: translateY(-4px);
    border-color: rgba(56, 103, 214, .22);
    box-shadow: var(--shadow-md);
}
.murcia-highlight-card h3,
.murcia-link-group h3 {
    color: var(--ink);
    font-family: var(--fb);
}
.murcia-highlight-card h3 {
    font-size: 1.02rem;
    margin-bottom: 10px;
}
.murcia-highlight-card p {
    color: var(--muted);
    line-height: 1.78;
    font-size: .89rem;
}
.murcia-sector-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.murcia-proof-band {
    padding-bottom: 8px;
}
.murcia-link-groups {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}
.murcia-link-group {
    padding: 24px 22px;
}
.murcia-link-head {
    margin-bottom: 18px;
}
.murcia-link-head h3 {
    font-size: 1.02rem;
    margin-top: 4px;
}
.murcia-link-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.murcia-link-note {
    margin-top: 18px;
    color: var(--muted);
    line-height: 1.8;
    max-width: 74ch;
}
.local-sector-links,
.sector-local-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}
.sector-link-card,
.sector-local-card,
.sector-card-link {
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.sector-link-card,
.sector-local-card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 22px 20px;
    border-radius: calc(var(--r2) + 2px);
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,248,253,.98));
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
    color: var(--ink);
}
.sector-link-card strong,
.sector-local-card strong {
    font-family: var(--fb);
    font-size: 1rem;
    color: var(--ink);
}
.sector-link-card p,
.sector-local-card p {
    color: var(--muted);
    line-height: 1.75;
    font-size: .88rem;
}
.sector-link-card:hover,
.sector-local-card:hover,
.sector-card-link:hover {
    transform: translateY(-4px);
    border-color: rgba(56, 103, 214, .22);
    box-shadow: var(--shadow-md);
}
.sector-local-arrow {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--blue);
    font-size: .83rem;
    font-weight: 700;
}
.sector-erp-page {
    min-height: 100vh;
}
.sector-erp-hero {
    padding-bottom: 72px;
}
.sector-hero-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
    gap: 34px;
    align-items: start;
}
.home-sector-links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 20px;
}
.work-page {
    min-height: 100vh;
}
.work-hero {
    padding-bottom: 72px;
}
.work-hero-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.06fr) minmax(320px, .94fr);
    gap: 34px;
    align-items: start;
}
.work-hero-panel {
    padding: 24px 22px;
    border-radius: calc(var(--r2) + 4px);
    background: rgba(255,255,255,.9);
    border: 1px solid rgba(140, 164, 208, .24);
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.work-step-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
}
.work-step-card,
.work-pillar-card {
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,248,253,.98));
    border: 1px solid var(--line);
    border-radius: calc(var(--r2) + 2px);
    box-shadow: var(--shadow-sm);
}
.work-step-card {
    padding: 22px 18px;
}
.work-step-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    margin-bottom: 14px;
    border-radius: 12px;
    background: var(--blue-l);
    color: var(--blue);
    font-family: var(--fb);
    font-size: .92rem;
}
.work-step-card h3,
.work-pillar-card h3 {
    font-family: var(--fb);
    font-size: 1rem;
    color: var(--ink);
    margin-bottom: 8px;
}
.work-step-card p,
.work-pillar-card p,
.work-band-copy {
    color: var(--muted);
    line-height: 1.76;
    font-size: .88rem;
}
.work-split {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: 56px;
    align-items: start;
    position: relative;
    z-index: 1;
}
.work-pillars-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}
.work-pillar-card {
    padding: 24px 22px;
}
.ertia-brand-section {
    padding-top: 0;
}
.ertia-brand-block {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, .8fr) auto;
    gap: 22px;
    align-items: center;
    padding: 28px 30px;
    border-radius: calc(var(--r2) + 6px);
    background:
        radial-gradient(circle at top left, rgba(47, 138, 196, .14), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,248,253,.98));
    border: 1px solid rgba(140, 164, 208, .24);
    box-shadow: var(--shadow-md);
}
.ertia-brand-copy h2 {
    font-size: clamp(1.5rem, 2vw, 2rem);
    margin-bottom: 12px;
}
.ertia-brand-copy p {
    color: var(--muted);
    line-height: 1.8;
    max-width: 68ch;
}
.ertia-brand-points {
    display: grid;
    gap: 10px;
}
.ertia-brand-point {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(18, 30, 54, .04);
    border: 1px solid rgba(18, 30, 54, .08);
}
.ertia-brand-point strong {
    color: var(--ink);
    font-family: var(--fb);
    font-size: .95rem;
}
.ertia-brand-point span {
    color: var(--muted);
    font-size: .84rem;
    line-height: 1.6;
}
.ertia-brand-actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: stretch;
}
.ertia-page {
    min-height: 100vh;
}
.ertia-hero {
    padding-bottom: 72px;
}
.ertia-hero-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.04fr) minmax(320px, .96fr);
    gap: 34px;
    align-items: start;
}

@media (max-width: 1080px) {
    .contact-page-hero-shell,
    .contact-page-shell,
    .contact-subtle-shell,
    .verifactu-hero-shell,
    .verifactu-requirements-shell,
    .verifactu-practical-shell,
    .local-erp-split,
    .murcia-hero-shell,
    .murcia-link-groups {
        grid-template-columns: 1fr;
    }

    .contact-page-form {
        position: static;
    }

    .verifactu-deadline-grid,
    .verifactu-requirements-grid,
    .verifactu-faq-grid {
        grid-template-columns: 1fr;
    }

    .local-erp-points {
        grid-template-columns: 1fr;
    }

    .murcia-highlight-grid,
    .murcia-sector-grid,
    .murcia-hero-metrics,
    .local-sector-links,
    .sector-local-grid,
    .sector-hero-shell,
    .seo-action-grid,
    .work-hero-shell,
    .work-split,
    .ertia-brand-block,
    .ertia-hero-shell,
    .product-proof-spotlight {
        grid-template-columns: 1fr;
    }

    .work-step-grid,
    .work-pillars-grid {
        grid-template-columns: 1fr;
    }

    .software-vf-link-card {
        align-items: flex-start;
        flex-direction: column;
    }

    .ertia-brand-actions {
        flex-direction: row;
        flex-wrap: wrap;
    }

    .footer-shell {
        grid-template-columns: 1fr;
    }

    .footer-site-link {
        justify-self: start;
    }

    .cookie-banner {
        inset: auto 14px 14px 14px;
    }

    .cookie-banner-card,
    .cookie-option-card {
        grid-template-columns: 1fr;
    }

    .cookie-modal-actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .cookie-modal-card {
        width: min(860px, calc(100vw - 20px));
        margin: 22px auto;
        padding: 24px 18px;
    }
}

@media (min-width: 769px) and (max-width: 1140px) {
    .problem-grid,
    .module-grid,
    .why-grid,
    .product-proof-grid,
    .sector-grid,
    .software-vf-intent-grid,
    .software-vf-check-grid,
    .software-vf-fit-grid,
    .software-vf-compare-grid,
    .local-erp-grid,
    .murcia-highlight-grid,
    .local-sector-links,
    .sector-local-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .hero-stats { width: 100%; }
    .hero-stat { padding: 12px 16px; flex: 1; }
    .hero-stat strong { font-size: 1.2rem; }
    .footer-shell { flex-direction: column; align-items: flex-start; gap: 16px; }
    .legal-page { padding: 28px 0 56px; }
    .contact-direct-grid { grid-template-columns: 1fr; }
    .contact-page-hero { padding-top: 94px; }
    .verifactu-hero { padding-top: 94px; }
    .cookie-banner-actions,
    .cookie-modal-buttons {
        width: 100%;
        flex-direction: column;
    }
    .cookie-banner-actions .button,
    .cookie-modal-buttons .button {
        width: 100%;
        justify-content: center;
    }
    .cookie-floating-button {
        left: 14px;
        right: 14px;
        bottom: 14px;
        justify-content: center;
    }
    .scroll-top-button {
        right: 14px;
        bottom: 72px;
        padding-inline: 14px;
    }
    .cursor-aura,
    .page-noise {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
    .reveal, .reveal-right { opacity: 1; transform: none; }
    .scroll-progress { display: none; }
}
