
        :root {
            --sg-orange: #ff3d00;
            --sg-orange-soft: rgba(255, 61, 0, .15);
            --sg-dark: #101010;
            --sg-dark-2: #171717;
            --sg-card: #202020;
            --sg-card-2: #262626;
            --sg-text: #f4f4f4;
            --sg-muted: rgba(255, 255, 255, .68);
            --sg-border: rgba(255, 255, 255, .12);
            --sg-radius: 28px;
        }

        body.contatti {
            background: var(--sg-dark);
        }

        .sg-contact-modern {
            color: var(--sg-text);
            overflow: hidden;
        }

        .sg-contact-container {
            width: min(1320px, calc(100% - 32px));
            margin: 0 auto;
        }

        .sg-contact-hero {
            position: relative;
            padding: 150px 0 80px;
            background:
                radial-gradient(circle at 12% 12%, rgba(255, 61, 0, .22), transparent 32%),
                radial-gradient(circle at 82% 20%, rgba(255, 255, 255, .08), transparent 28%),
                linear-gradient(180deg, #111 0%, #161616 55%, #101010 100%);
        }

        .sg-contact-hero::after {
            content: "";
            position: absolute;
            inset: auto -10% -120px -10%;
            height: 240px;
            background: radial-gradient(ellipse at center, rgba(255, 61, 0, .18), transparent 62%);
            pointer-events: none;
        }

        .sg-contact-hero-grid {
            display: grid;
            grid-template-columns: minmax(0, 1.05fr) minmax(360px, .75fr);
            gap: 52px;
            align-items: center;
            position: relative;
            z-index: 1;
        }

        .sg-contact-kicker {
            display: inline-flex;
            align-items: center;
            gap: 10px;
            width: fit-content;
            padding: 10px 16px;
            border: 1px solid rgba(255, 61, 0, .45);
            background: var(--sg-orange-soft);
            color: #fff;
            border-radius: 999px;
            font-size: 14px;
            line-height: 1;
            letter-spacing: .02em;
            margin-bottom: 22px;
        }

        .sg-contact-kicker::before {
            content: "";
            width: 8px;
            height: 8px;
            border-radius: 50%;
            background: var(--sg-orange);
            box-shadow: 0 0 0 6px rgba(255, 61, 0, .15);
        }

        .sg-contact-title {
            margin: 0;
            max-width: 920px;
            font-size: clamp(48px, 7.2vw, 112px);
            line-height: .92;
            letter-spacing: -.06em;
            font-weight: 800;
        }

        .sg-contact-title span {
            color: var(--sg-orange);
        }

        .sg-contact-lead {
            max-width: 760px;
            margin: 28px 0 0;
            font-size: clamp(18px, 2vw, 24px);
            line-height: 1.45;
            color: var(--sg-muted);
        }

        .sg-contact-actions {
            display: flex;
            gap: 14px;
            flex-wrap: wrap;
            margin-top: 34px;
        }

        .sg-contact-btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
            min-height: 54px;
            padding: 15px 24px;
            border-radius: 999px;
            text-decoration: none;
            font-weight: 700;
            transition: transform .25s ease, background .25s ease, border-color .25s ease;
        }

        .sg-contact-btn:hover {
            transform: translateY(-2px);
        }

        .sg-contact-btn-primary {
            background: var(--sg-orange);
            color: #fff;
            border: 1px solid var(--sg-orange);
        }

        .sg-contact-btn-outline {
            background: rgba(255, 255, 255, .06);
            color: #fff;
            border: 1px solid var(--sg-border);
        }

        .sg-contact-hero-card {
            background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
            border: 1px solid var(--sg-border);
            border-radius: var(--sg-radius);
            padding: 30px;
            box-shadow: 0 30px 90px rgba(0,0,0,.35);
            backdrop-filter: blur(12px);
        }

        .sg-contact-hero-card h2 {
            font-size: 30px;
            line-height: 1.08;
            margin: 0 0 14px;
            letter-spacing: -.03em;
        }

        .sg-contact-hero-card p {
            color: var(--sg-muted);
            margin: 0 0 24px;
            line-height: 1.55;
        }

        .sg-contact-mini-list {
            display: grid;
            gap: 12px;
            margin: 0;
            padding: 0;
            list-style: none;
        }

        .sg-contact-mini-list li {
            display: flex;
            gap: 12px;
            align-items: flex-start;
            padding: 14px;
            border-radius: 18px;
            background: rgba(255,255,255,.055);
            border: 1px solid rgba(255,255,255,.08);
            color: rgba(255,255,255,.82);
        }

        .sg-contact-mini-list strong {
            display: block;
            color: #fff;
            line-height: 1.2;
            margin-bottom: 2px;
        }

        .sg-contact-dot {
            flex: 0 0 auto;
            width: 11px;
            height: 11px;
            margin-top: 5px;
            border-radius: 50%;
            background: var(--sg-orange);
            box-shadow: 0 0 0 7px rgba(255,61,0,.12);
        }

        .sg-contact-info-section,
        .sg-contact-form-section,
        .sg-contact-method-section,
        .sg-contact-newsletter-section {
            padding: 70px 0;
        }

        .sg-contact-info-grid {
            display: grid;
            grid-template-columns: repeat(4, minmax(0, 1fr));
            gap: 18px;
        }

        .sg-contact-info-card {
            min-height: 220px;
            padding: 26px;
            border-radius: 24px;
            background: var(--sg-card);
            border: 1px solid var(--sg-border);
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            transition: transform .25s ease, border-color .25s ease, background .25s ease;
        }

        .sg-contact-info-card:hover {
            transform: translateY(-4px);
            border-color: rgba(255,61,0,.55);
            background: #252525;
        }

        .sg-contact-info-icon {
            width: 48px;
            height: 48px;
            border-radius: 16px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            background: var(--sg-orange-soft);
            color: var(--sg-orange);
            margin-bottom: 22px;
        }

        .sg-contact-info-card h3 {
            font-size: 22px;
            margin: 0 0 10px;
            letter-spacing: -.02em;
        }

        .sg-contact-info-card p,
        .sg-contact-info-card a {
            margin: 0;
            color: var(--sg-muted);
            text-decoration: none;
            line-height: 1.45;
            word-break: break-word;
        }

        .sg-contact-info-card a:hover {
            color: #fff;
        }

        .sg-contact-section-heading {
            max-width: 860px;
            margin-bottom: 34px;
        }

        .sg-contact-section-heading .sg-contact-kicker {
            margin-bottom: 16px;
        }

        .sg-contact-section-heading h2 {
            margin: 0;
            font-size: clamp(38px, 5vw, 72px);
            line-height: .98;
            letter-spacing: -.05em;
        }

        .sg-contact-section-heading p {
            max-width: 720px;
            margin: 18px 0 0;
            color: var(--sg-muted);
            font-size: 18px;
            line-height: 1.55;
        }

        .sg-contact-form-grid {
            display: grid;
            grid-template-columns: minmax(320px, .72fr) minmax(0, 1fr);
            gap: 28px;
            align-items: start;
        }

        .sg-contact-aside {
            position: sticky;
            top: 110px;
            display: grid;
            gap: 18px;
        }

        .sg-contact-aside-card,
        .sg-contact-form-card,
        .sg-contact-newsletter-card {
            border-radius: var(--sg-radius);
            border: 1px solid var(--sg-border);
            background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035));
            padding: 30px;
        }

        .sg-contact-aside-card h3,
        .sg-contact-newsletter-card h3 {
            margin: 0 0 12px;
            font-size: 28px;
            letter-spacing: -.03em;
        }

        .sg-contact-aside-card p,
        .sg-contact-newsletter-card p {
            margin: 0;
            color: var(--sg-muted);
            line-height: 1.55;
        }

        .sg-contact-steps {
            display: grid;
            gap: 14px;
            margin-top: 22px;
        }

        .sg-contact-step {
            display: grid;
            grid-template-columns: 44px 1fr;
            gap: 14px;
            align-items: start;
            padding: 16px;
            border-radius: 18px;
            background: rgba(255,255,255,.055);
            border: 1px solid rgba(255,255,255,.08);
        }

        .sg-contact-step span {
            width: 44px;
            height: 44px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: 15px;
            background: var(--sg-orange);
            color: #fff;
            font-weight: 800;
        }

        .sg-contact-step strong {
            display: block;
            color: #fff;
            margin-bottom: 4px;
        }

        .sg-contact-step small {
            display: block;
            color: var(--sg-muted);
            line-height: 1.45;
        }

        .sg-contact-form-card form,
        .sg-contact-newsletter-card form {
            margin: 0;
        }

        .sg-contact-formwrap {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 18px;
        }

        .sg-contact-formfield {
            display: grid;
            gap: 9px;
        }

        .sg-contact-formfield.full,
        .sg-contact-formfield.message,
        .sg-contact-privacy,
        .sg-contact-alerts,
        .sg-contact-submit {
            grid-column: 1 / -1;
        }

        .sg-contact-formfield label,
        .sg-contact-privacy label {
            color: rgba(255,255,255,.78);
            font-size: 14px;
            margin: 0;
        }

        .sg-contact-formfield input,
        .sg-contact-formfield select,
        .sg-contact-formfield textarea {
            width: 100%;
            border: 1px solid rgba(255,255,255,.13);
            background: rgba(255,255,255,.055);
            color: #fff;
            border-radius: 18px;
            min-height: 58px;
            padding: 15px 17px;
            outline: none;
            transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
        }

        .sg-contact-formfield select {
            min-height: 144px;
        }

        .sg-contact-formfield textarea {
            min-height: 220px;
            resize: vertical;
        }

        .sg-contact-formfield input:focus,
        .sg-contact-formfield select:focus,
        .sg-contact-formfield textarea:focus {
            border-color: rgba(255,61,0,.75);
            background: rgba(255,255,255,.08);
            box-shadow: 0 0 0 4px rgba(255,61,0,.11);
        }

        .sg-contact-formfield input::placeholder,
        .sg-contact-formfield textarea::placeholder {
            color: rgba(255,255,255,.42);
        }

        .sg-contact-formfield option {
            color: #111;
        }

        .sg-contact-privacy {
            padding: 4px 0 0;
        }

        .sg-contact-privacy .form-check-input {
            cursor: pointer;
        }

        .sg-contact-privacy a {
            color: #fff;
            text-decoration: underline;
            text-decoration-color: rgba(255,61,0,.7);
        }

        .sg-contact-submit .sg-contact-btn {
            border: 0;
            width: fit-content;
            cursor: pointer;
            font-family: inherit;
        }

        .sg-contact-method-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 18px;
        }

        .sg-contact-method-card {
            border-radius: 24px;
            background: var(--sg-card-2);
            border: 1px solid var(--sg-border);
            padding: 28px;
        }

        .sg-contact-method-card h3 {
            margin: 0 0 12px;
            font-size: 24px;
            letter-spacing: -.02em;
        }

        .sg-contact-method-card p {
            color: var(--sg-muted);
            line-height: 1.55;
            margin: 0 0 18px;
        }

        .sg-contact-method-card a {
            color: #fff;
            text-decoration: none;
            font-weight: 700;
        }

        .sg-contact-method-card a:hover {
            color: var(--sg-orange);
        }

        .sg-contact-newsletter-section {
            padding-bottom: 110px;
        }

        .sg-contact-newsletter-grid {
            display: grid;
            grid-template-columns: minmax(320px, .8fr) minmax(0, 1fr);
            gap: 22px;
            align-items: stretch;
        }

        .sg-contact-newsletter-card.highlight {
            background: linear-gradient(135deg, rgba(255,61,0,.95), rgba(255,122,0,.75));
            border-color: rgba(255,255,255,.18);
        }

        .sg-contact-newsletter-card.highlight p {
            color: rgba(255,255,255,.86);
        }

        .sg-contact-newsletter-form-grid {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 18px;
        }

        .sg-contact-social-links {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-top: 22px;
        }

        .sg-contact-social-links a {
            display: inline-flex;
            align-items: center;
            min-height: 42px;
            padding: 10px 15px;
            border-radius: 999px;
            border: 1px solid rgba(255,255,255,.18);
            color: #fff;
            text-decoration: none;
            background: rgba(255,255,255,.07);
        }

        .sg-contact-social-links a:hover {
            border-color: rgba(255,255,255,.42);
            background: rgba(255,255,255,.12);
        }

        .sg-contact-work-link {
            display: inline-flex;
            margin-top: 22px;
        }

        @media (max-width: 1199px) {
            .sg-contact-hero-grid,
            .sg-contact-form-grid,
            .sg-contact-newsletter-grid {
                grid-template-columns: 1fr;
            }

            .sg-contact-aside {
                position: static;
            }

            .sg-contact-info-grid {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }
        }

        @media (max-width: 767px) {
            .sg-contact-hero {
                padding: 120px 0 58px;
            }

            .sg-contact-container {
                width: min(100% - 22px, 1320px);
            }

            .sg-contact-title,
            .sg-contact-lead,
            .sg-contact-section-heading h2,
            .sg-contact-section-heading p {
                text-align: left;
            }

            .sg-contact-hero-card,
            .sg-contact-aside-card,
            .sg-contact-form-card,
            .sg-contact-newsletter-card {
                padding: 22px;
                border-radius: 22px;
            }

            .sg-contact-info-grid,
            .sg-contact-method-grid,
            .sg-contact-formwrap,
            .sg-contact-newsletter-form-grid {
                grid-template-columns: 1fr;
            }

            .sg-contact-info-section,
            .sg-contact-form-section,
            .sg-contact-method-section,
            .sg-contact-newsletter-section {
                padding: 48px 0;
            }

            .sg-contact-actions,
            .sg-contact-submit .sg-contact-btn {
                width: 100%;
            }

            .sg-contact-btn {
                width: 100%;
            }
        }
