/* Extracted from public-redesign.css lines 3295-3668. Keep load order in components/head.php. */

.public-site.page-contatti .contact-page {
    position: relative;
    padding: clamp(140px, 14vw, 200px) 0 clamp(80px, 10vw, 140px);
    background:
        linear-gradient(var(--public-on-dark-05) 1px, transparent 1px),
        linear-gradient(90deg, var(--public-on-dark-05) 1px, transparent 1px),
        radial-gradient(54% 46% at 82% 16%, rgba(var(--public-blue-rgb), 0.12), transparent 60%),
        radial-gradient(46% 46% at 16% 88%, rgba(var(--public-orange-rgb), 0.08), transparent 62%),
        var(--public-dark);
    background-size: 54px 54px, 54px 54px, auto, auto, auto;
    color: #ffffff;
    min-height: calc(100vh - 200px);
    overflow: hidden;
}

.public-site.page-contatti .contact-page::before {
    content: "";
    position: absolute;
    right: max(24px, calc((100vw - 1240px) / 2));
    top: 22%;
    width: min(34vw, 460px);
    height: min(46vw, 620px);
    background:
        linear-gradient(var(--public-on-dark-06) 1px, transparent 1px),
        linear-gradient(90deg, var(--public-on-dark-06) 1px, transparent 1px),
        radial-gradient(circle at 58% 42%, rgba(var(--public-blue-rgb), 0.18), transparent 58%);
    background-size: 34px 34px, 34px 34px, auto;
    border-radius: var(--public-radius-28);
    opacity: 0.5;
    transform: rotate(-4deg);
    mask-image: linear-gradient(90deg, transparent 0, #000 26%, #000 72%, transparent 100%);
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 26%, #000 72%, transparent 100%);
    pointer-events: none;
}

.public-site.page-contatti .contact-page__intro {
    max-width: 760px;
    margin: 0 auto clamp(48px, 6vw, 80px);
    text-align: center;
}

.public-site.page-contatti .contact-page__intro .public-heading {
    margin-bottom: 16px;
    color: #ffffff;
    font-size: clamp(2.4rem, 4vw, 3.8rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
}

.public-site.page-contatti .contact-page__intro .public-copy {
    color: var(--public-on-dark-72);
    font-size: 1.08rem;
    max-width: 580px;
    margin: 0 auto;
}

.public-site.page-contatti .contact-page__layout {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 720px) minmax(240px, 1fr);
    align-items: start;
    max-width: 1080px;
    margin: 0 auto;
    gap: clamp(24px, 3vw, 40px);
}

.public-site.page-contatti .contact-page__form {
    position: relative;
    padding: clamp(28px, 3vw, 40px);
    background:
        radial-gradient(44% 44% at 88% 80%, rgba(var(--public-blue-rgb), 0.10), transparent 64%),
        linear-gradient(180deg, var(--public-on-dark-026), var(--public-on-dark-012)),
        rgba(8, 9, 12, 0.72);
    border: 1px solid var(--public-on-dark-08);
    border-radius: var(--public-radius-20);
    box-shadow: var(--public-shadow-card);
    color: #ffffff;
    overflow: hidden;
}

.public-site.page-contatti .contact-page__form::before {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: var(--public-radius-cta);
    border: 1px solid var(--public-on-dark-045);
    pointer-events: none;
}

.public-site.page-contatti .contact-page__form::after {
    content: "";
    position: absolute;
    right: -80px;
    bottom: -96px;
    width: 320px;
    aspect-ratio: 1;
    background:
        linear-gradient(var(--public-on-dark-055) 1px, transparent 1px),
        linear-gradient(90deg, var(--public-on-dark-055) 1px, transparent 1px),
        radial-gradient(circle at center, rgba(var(--public-blue-rgb), 0.16), transparent 64%);
    background-size: 28px 28px, 28px 28px, auto;
    opacity: 0.55;
    mask-image: radial-gradient(circle at center, #000 0 48%, transparent 74%);
    -webkit-mask-image: radial-gradient(circle at center, #000 0 48%, transparent 74%);
    pointer-events: none;
}

.public-site.page-contatti .contact-page__form .contact-form {
    position: relative;
    z-index: 1;
    max-width: 620px;
    margin: 0 auto;
}

.public-site.page-contatti .contact-page__aside {
    position: relative;
    padding: clamp(28px, 3vw, 36px);
    background:
        radial-gradient(44% 44% at 88% 80%, rgba(var(--public-blue-rgb), 0.10), transparent 64%),
        linear-gradient(180deg, var(--public-on-dark-026), var(--public-on-dark-012)),
        rgba(8, 9, 12, 0.72);
    border: 1px solid var(--public-on-dark-08);
    border-radius: var(--public-radius-20);
    box-shadow: var(--public-shadow-card);
    color: #ffffff;
    overflow: hidden;
}

.public-site.page-contatti .contact-page__aside::after {
    content: "";
    position: absolute;
    right: -72px;
    bottom: -72px;
    width: 190px;
    aspect-ratio: 1;
    border-radius: var(--public-radius-circle);
    background: radial-gradient(circle, rgba(var(--public-orange-rgb), 0.14), transparent 68%);
    pointer-events: none;
}

.public-site.page-contatti .contact-page__aside-title {
    margin: 0 0 8px;
    font-size: 1.18rem;
    font-weight: var(--public-weight-medium);
    color: #ffffff;
    letter-spacing: -0.005em;
}

.public-site.page-contatti .contact-page__aside-body {
    margin: 0 0 22px;
    color: var(--public-on-dark-66);
    font-size: 0.94rem;
    line-height: 1.55;
}

.public-site.page-contatti .contact-page__links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.public-site.page-contatti .contact-page__link {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 14px 0;
    border-bottom: 1px solid var(--public-on-dark-10);
    color: var(--public-on-dark-85);
    text-decoration: none;
    transition: color 0.2s ease;
}

.public-site.page-contatti .contact-page__links li:last-child .contact-page__link {
    border-bottom: none;
}

.public-site.page-contatti .contact-page__link:hover {
    color: var(--public-blue);
}

.public-site.page-contatti .contact-page__link-label {
    font-size: 0.72rem;
    font-weight: var(--public-type-meta-label-weight);
    letter-spacing: var(--public-type-eyebrow-letter-spacing);
    text-transform: uppercase;
    color: var(--public-blue);
    font-family: var(--public-font-body);
}

.public-site.page-contatti .contact-page__link-value {
    font-size: 1rem;
    font-weight: var(--public-type-contact-link-weight);
    color: inherit;
}

.public-site.page-contatti .contact-page__form .contact-form__privacy-note {
    color: var(--public-on-dark-62);
}

.public-site.page-contatti .contact-page__form .contact-form__privacy-note a {
    color: var(--public-blue);
}

.public-site.page-contatti .contact-page__form .contact-form__privacy-note a:hover {
    color: var(--public-orange);
}

@media (max-width: 1024px) {
    .public-site.page-contatti .contact-page::before {
        width: 420px;
        height: 420px;
        right: -120px;
        top: 26%;
    }

    .public-site.page-contatti .contact-page__layout {
        grid-template-columns: 1fr;
        max-width: 760px;
    }

    .public-site.page-contatti .contact-page__form .contact-form {
        max-width: 100%;
    }
}

/* legacy contattaci styles (kept inactive) */

.public-site.page-contatti .contact-brief__hero {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(280px, 0.78fr);
    gap: clamp(28px, 5vw, 68px);
    align-items: center;
    padding-bottom: 52px;
}

.public-site.page-contatti .contact-brief__hero .public-copy {
    margin-top: 24px;
    max-width: 560px;
    color: var(--public-on-dark-70);
}

.public-site.page-contatti .contact-brief__panel {
    position: relative;
    padding: 30px;
    border-radius: var(--public-radius-30);
    border: 1px solid var(--public-on-dark-10);
    background: var(--public-on-dark-045);
    box-shadow: var(--public-shadow-strong);
    overflow: hidden;
}

.public-site.page-contatti .contact-brief__panel::before {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: var(--public-radius-22);
    border: 1px solid var(--public-on-dark-08);
}

.public-site.page-contatti .contact-brief__panel > * {
    position: relative;
    z-index: 1;
}

.public-site.page-contatti .contact-brief__panel strong {
    display: block;
    font-size: 1.18rem;
    font-weight: 600;
}

.public-site.page-contatti .contact-brief__panel p {
    margin: 14px 0 0;
    color: var(--public-on-dark-70);
    line-height: 1.72;
}

.public-site.page-contatti .contact-brief__stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 24px;
}

.public-site.page-contatti .contact-brief__stats div {
    padding: 16px 14px;
    border-radius: var(--public-radius-20);
    border: 1px solid var(--public-on-dark-10);
    background: var(--public-on-dark-04);
}

.public-site.page-contatti .contact-brief__stats span {
    display: block;
    color: var(--public-blue);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.public-site.page-contatti .contact-brief__stats strong {
    display: block;
    margin-top: 12px;
    font-size: 1.12rem;
}

.public-site.page-contatti .contact-brief__inner {
    grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.7fr);
    align-items: start;
}

.public-site.page-contatti .contact-form-card,
.public-site.page-contatti .contact-sidebar {
    border: 1px solid var(--public-line);
    border-radius: var(--public-radius-34);
    background: var(--public-on-dark-74);
    box-shadow: var(--public-shadow);
}

.public-site.page-contatti .contact-form-card {
    padding: 28px;
}

.public-site.page-contatti .contact-form-card h2,
.public-site.page-contatti .contact-sidebar h2 {
    margin: 0;
    font-size: 1.56rem;
    line-height: 1.12;
    font-weight: 600;
}

.public-site.page-contatti .contact-form-card p,
.public-site.page-contatti .contact-sidebar p {
    margin: 14px 0 0;
    color: var(--public-muted);
    line-height: 1.72;
}

.public-site.page-contatti .contact-form-card .calendar-wrapper {
    margin-top: 24px;
    padding: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.public-site.page-contatti .contact-form-card iframe {
    min-height: 620px;
}

.public-site.page-contatti .contact-sidebar {
    padding: 28px;
}

.public-site.page-contatti .contact-list,
.public-site.page-contatti .contact-links {
    display: grid;
    gap: 14px;
    margin-top: 22px;
}

.public-site.page-contatti .contact-list article {
    padding: 18px;
    border-radius: var(--public-radius-22);
    border: 1px solid rgba(var(--public-ink-rgb), 0.08);
    background: var(--public-on-dark-55);
}

.public-site.page-contatti .contact-list span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: var(--public-radius-pill);
    background: rgba(var(--public-orange-rgb), 0.1);
    color: var(--public-orange);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.public-site.page-contatti .contact-list strong {
    display: block;
    margin-top: 14px;
    font-size: 1.06rem;
    font-weight: 600;
}

.public-site.page-contatti .contact-list p {
    margin-top: 8px;
    font-size: 0.94rem;
}

.public-site.page-contatti .contact-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px;
    border-radius: var(--public-radius-22);
    border: 1px solid rgba(var(--public-ink-rgb), 0.08);
    background: var(--public-on-dark-55);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.public-site.page-contatti .contact-link:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--public-blue-rgb), 0.2);
}

.public-site.page-contatti .contact-link__meta strong,
.public-site.page-contatti .contact-link__meta span {
    display: block;
}

.public-site.page-contatti .contact-link__meta strong {
    font-size: 0.84rem;
    color: var(--public-blue);
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.public-site.page-contatti .contact-link__meta span {
    margin-top: 6px;
    color: var(--public-ink);
    font-weight: 600;
}

.public-site.page-contatti .contact-link__arrow {
    color: rgba(var(--public-ink-rgb), 0.44);
    font-size: 1rem;
}
