/* Landing pages stylesheet — Poliambulatorio San Luigi Orione */
/* Set --acc, --acc-soft, --acc-dot, --acc-soft-bg in each landing page */

.sp-hero{position:relative;background:linear-gradient(180deg,var(--acc-soft-bg) 0%,#fbfbfd 60%);padding:48px 0 56px;overflow:hidden}
@media(min-width:735px){.sp-hero{padding:72px 0 72px}}
.sp-hero::before{content:'';position:absolute;top:-100px;right:-80px;width:380px;height:380px;border-radius:50%;background:var(--acc-glow);filter:blur(40px);pointer-events:none}
.sp-hero-in{position:relative;display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
@media(min-width:960px){.sp-hero-in{grid-template-columns:1.4fr 1fr;gap:48px}}
.sp-eye{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:980px;background:rgba(255,255,255,.65);border:.5px solid rgba(0,0,0,.06);font-size:13px;font-weight:600;color:var(--acc);letter-spacing:-.005em;backdrop-filter:saturate(180%) blur(10px);margin-bottom:14px}
.sp-eye .sp-dot{width:8px;height:8px;border-radius:50%;background:var(--acc-dot)}
.sp-hero h1{font-size:clamp(34px,6vw,52px);font-weight:600;line-height:1.05;letter-spacing:-.014em;color:var(--ink);margin-bottom:14px;text-wrap:balance}
.sp-hero h1 .sub{color:var(--acc)}
.sp-hero .lead{font-size:clamp(17px,2vw,20px);line-height:1.5;color:var(--ink2);max-width:580px;margin-bottom:22px}
.sp-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}
.sp-tags{display:flex;gap:6px;flex-wrap:wrap}
.hero-tag{display:inline-flex;padding:4px 12px;border-radius:980px;background:rgba(255,255,255,.7);border:.5px solid rgba(0,0,0,.06);font-size:12px;color:var(--ink2);font-weight:500;letter-spacing:-.005em;backdrop-filter:saturate(180%) blur(10px)}

.sp-price-card{background:rgba(255,255,255,.7);border:.5px solid rgba(0,0,0,.06);border-radius:22px;padding:28px;backdrop-filter:saturate(180%) blur(20px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.sp-price-card .sp-eye-mini{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px;display:block}
.sp-price-row{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:.5px solid var(--rule2);gap:14px}
.sp-price-row:last-child{border-bottom:none}
.sp-price-name{font-size:14px;color:var(--ink2);line-height:1.35;letter-spacing:-.005em}
.sp-price-val{font-size:22px;font-weight:600;color:var(--acc);font-variant-numeric:tabular-nums;letter-spacing:-.014em;white-space:nowrap}
.sp-price-note{font-size:13px;color:var(--ink3);margin-top:14px;line-height:1.5}

.sp-info{display:grid;grid-template-columns:repeat(2,1fr);gap:0;padding:24px 28px;background:var(--bg);border-radius:16px;margin:32px 0}
@media(min-width:735px){.sp-info{grid-template-columns:repeat(4,1fr);padding:28px 32px}}
.sp-info-item{display:flex;flex-direction:column;gap:4px;padding:12px 0}
@media(min-width:735px){.sp-info-item:not(:last-child){border-right:.5px solid var(--rule2);padding-right:18px}.sp-info-item:not(:first-child){padding-left:18px}}
.sp-info-k{font-size:12px;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.04em}
.sp-info-v{font-size:15px;color:var(--ink);font-weight:500;letter-spacing:-.005em}

.sp-section-eye{font-size:13px;font-weight:600;color:var(--acc);letter-spacing:-.005em;margin-bottom:8px;display:block}
.sp-section-h{font-size:32px;font-weight:600;letter-spacing:-.014em;color:var(--ink);margin-bottom:8px;line-height:1.1}
@media(min-width:735px){.sp-section-h{font-size:40px}}
.sp-section-p{font-size:17px;color:var(--ink2);line-height:1.5;max-width:620px}

.sp-prose{max-width:680px;font-size:17px;line-height:1.55;color:var(--ink2);letter-spacing:-.005em}
.sp-prose p{margin-top:14px}
.sp-prose p:first-child{margin-top:0}
.sp-prose strong{color:var(--ink);font-weight:600}
.sp-prose h3{font-size:21px;font-weight:600;letter-spacing:-.014em;color:var(--ink);margin-top:28px;margin-bottom:8px;line-height:1.2}
.sp-prose ul.inline{margin:10px 0;padding-left:0;list-style:none}
.sp-prose ul.inline li{padding:6px 0}

.sp-two{display:grid;grid-template-columns:1fr;gap:32px;margin-top:48px}
@media(min-width:735px){.sp-two{grid-template-columns:1fr 1fr;gap:48px}}
.sp-block h2{font-size:24px;font-weight:600;letter-spacing:-.014em;margin-bottom:18px;color:var(--ink)}
.sp-block ul{list-style:none;padding:0;margin:0}
.sp-block ul li{display:flex;gap:12px;padding:10px 0;border-bottom:.5px solid var(--rule2);font-size:15px;color:var(--ink2);line-height:1.45;align-items:flex-start}
.sp-block ul li:last-child{border-bottom:none}
.check{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--acc-soft);color:var(--acc);font-size:11px;font-weight:700;flex-shrink:0;margin-top:2px}

.faqs{margin-top:24px}
details.faq{border-bottom:.5px solid var(--rule2);padding:18px 0}
details.faq:first-of-type{border-top:.5px solid var(--rule2)}
details.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;font-size:17px;font-weight:500;letter-spacing:-.014em;color:var(--ink)}
details.faq summary::-webkit-details-marker{display:none}
.faq-mark{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:var(--bg2);position:relative;transition:transform .2s}
.faq-mark::before,.faq-mark::after{content:'';position:absolute;top:50%;left:50%;background:var(--ink3);transition:transform .2s}
.faq-mark::before{width:10px;height:1.5px;transform:translate(-50%,-50%)}
.faq-mark::after{width:1.5px;height:10px;transform:translate(-50%,-50%)}
details.faq[open] .faq-mark::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-q{flex:1}
.faq-a{margin-top:10px;font-size:15px;line-height:1.5;color:var(--ink2);max-width:680px}

.rel-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg2);border-radius:980px;font-size:13px;color:var(--ink);font-weight:500;letter-spacing:-.005em;text-decoration:none;transition:background .15s var(--ease),transform .12s var(--ease-out)}
.rel-link:hover{background:var(--bg3)}
.rel-link:active{transform:scale(.97)}
.rel-link::after{content:' ›'}

.sede-callout{background:var(--bg2);border-radius:18px;padding:24px 28px;margin-top:36px;display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:735px){.sede-callout{grid-template-columns:1fr auto;align-items:center;gap:24px}}
.sede-callout-eye{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3);margin-bottom:6px;display:block}
.sede-callout-h{font-size:18px;font-weight:600;letter-spacing:-.014em;color:var(--ink);margin-bottom:6px}
.sede-callout p{font-size:14px;color:var(--ink2);line-height:1.5}
