/*
Theme Name: Musica360 v2
Theme URI: https://musica360.local
Author: Codex
Description: Musica360 v2 — GSAP + Lenis + rediseno hero.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: musica360
*/

:root {
      --bg: #050505;
      --paper: #f8f6f3;
      --white: #fafafa;
      --orange: #fd603a;
      --pink: #e261ed;
      --yellow: #dce75c;
      --blue: #2451c4;
      --blue-soft: #7ba5d7;
      --text: #121212;
      --muted: #d8d8d8;
      --radius: 28px;
      --shadow: 0 20px 60px rgba(0,0,0,.16);
      --max: 1320px;
      --site-header-offset: 76px;
      --section-pad: 86px;
      --font-body: "Poppins", Arial, sans-serif;
      --font-display: "Poppins", Arial, sans-serif;
    }
    @font-face {
      font-family: "Yorkmade";
      src: url("assets/fonts/yorkmade/Yorkmade.woff2") format("woff2"),
           url("assets/fonts/yorkmade/Yorkmade.woff") format("woff");
      font-style: normal;
      font-weight: 400;
      font-display: block;
    }
    * { box-sizing: border-box; }
    html { scroll-behavior: auto; overflow-x: hidden; }
    body { margin: 0; padding-top: var(--site-header-offset, 0px); font-family: var(--font-body); background: var(--paper); color: var(--text); overflow-x: hidden; }
    img { max-width: 100%; height: auto; display: block; }
    a { color: inherit; text-decoration: none; }
    h1, h2, h3, h4, p, a, span { overflow-wrap: anywhere; }
    .hero-title-main,
    .hero-title-main span,
    .fun-title { overflow-wrap: normal; word-break: normal; }
    .container { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; }
    /* Elementor — quitar espacios extra en todos los wrappers del tema */
    .elementor-page-shell,
    main#top,
    main.page-shell { width: 100%; }
    .elementor-page-shell > .elementor,
    main#top > .elementor,
    main.page-shell > .elementor { width: 100%; }
    /* quitar margin/padding por defecto de Elementor en todas las páginas del tema */
    .elementor-page-shell .elementor-section,
    main#top .elementor-section,
    main.page-shell .elementor-section { margin-left: 0; margin-right: 0; }
    /* primer section pegado al header sin gap extra */
    main#top > .elementor > .elementor-section:first-child,
    main#top > .elementor > .e-con:first-child,
    main.page-shell > .elementor > .elementor-section:first-child,
    main.page-shell > .elementor > .e-con:first-child { margin-top: 0 !important; }

    .page-id-101 .elementor.elementor-101 .elementor-top-section,
    .page-id-101 .elementor.elementor-101 .elementor-top-section > .elementor-container,
    .page-id-101 .elementor.elementor-101 .elementor-top-column,
    .page-id-101 .elementor.elementor-101 .elementor-widget-wrap,
    .page-id-101 .elementor.elementor-101 .elementor-widget,
    .page-id-101 .elementor.elementor-101 .elementor-widget-container {
      margin: 0;
      padding: 0;
    }
    .page-id-101 .elementor.elementor-101 .elementor-widget,
    .page-id-101 .elementor.elementor-101 .elementor-widget-container {
      width: 100%;
    }
    .page-id-101 .elementor.elementor-101 .elementor-section.elementor-section-boxed > .elementor-container,
    .page-id-101 .elementor.elementor-101 .elementor-section.elementor-section-full_width > .elementor-container {
      max-width: 100%;
    }
    .page-id-101 .elementor.elementor-101 .elementor-column-gap-default > .elementor-column > .elementor-element-populated,
    .page-id-101 .elementor.elementor-101 .elementor-column-gap-no > .elementor-column > .elementor-element-populated,
    .page-id-101 .elementor.elementor-101 .elementor-column-gap-narrow > .elementor-column > .elementor-element-populated,
    .page-id-101 .elementor.elementor-101 .elementor-column-gap-extended > .elementor-column > .elementor-element-populated,
    .page-id-101 .elementor.elementor-101 .elementor-column-gap-wide > .elementor-column > .elementor-element-populated,
    .page-id-101 .elementor.elementor-101 .elementor-column-gap-wider > .elementor-column > .elementor-element-populated {
      padding: 0;
    }
    .fun-title { font-family: var(--font-display); font-weight: 800; letter-spacing: .018em; text-transform: uppercase; line-height: .94; text-wrap: balance; }
    .hero-title-brand { display:inline-block; font-family: "Yorkmade", var(--font-body); font-weight: 400; line-height: .82; }
    .eyebrow { display:inline-block; padding:10px 16px; border-radius:999px; background: var(--yellow); color: var(--text); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: .08em; }
    .soft-chip { display:inline-block; padding:8px 14px; border-radius:999px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); color:var(--white); font-size:13px; }
    .btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:52px; padding:0 22px; border-radius:999px; font-weight:800; border:2px solid transparent; transition:.25s ease; }
    .btn-primary { background: var(--orange); color:white; }
    .btn-secondary { background: transparent; color:white; border-color: rgba(255,255,255,.35); }
    .btn:hover { transform: translateY(-2px); }

    header { position: fixed; top: 0; left: 0; right: 0; width: 100%; z-index: 120; backdrop-filter: blur(16px); background: #f8f6f3; border-bottom:1px solid rgba(18,18,18,.08); transition: background .28s ease, box-shadow .28s ease, border-color .28s ease, transform .28s ease; }
    header.is-scrolled { background: #f8f6f3; box-shadow: 0 16px 40px rgba(18,18,18,.08); border-bottom-color: rgba(18,18,18,.12); }
    .nav { display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:58px; padding: 6px 0; flex-wrap:nowrap; }
    .brand { display:flex; align-items:center; gap:10px; font-weight:800; font-family: var(--font-body); text-transform: uppercase; letter-spacing:.02em; }
    .brand-badge { min-width:44px; min-height:44px; border-radius:50%; background:transparent; color:var(--white); display:grid; place-items:center; font-size:10px; font-weight:900; overflow:hidden; flex:0 0 auto; }
    .brand-badge img { width:100%; height:100%; object-fit:contain; }
    .brand-badge-text,
    .brand-badge-html { width:100%; height:100%; display:grid; place-items:center; padding:6px; text-align:center; line-height:1; }
    .nav-toggle { display:none; border:0; background:var(--bg); color:var(--white); width:44px; height:44px; border-radius:14px; padding:0; cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
    .nav-toggle span { display:block; width:20px; height:2px; background:currentColor; border-radius:999px; transition:.25s ease; }
    .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity:0; }
    .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
    .nav-links { display:flex; justify-content:flex-end; font-weight:700; font-size:12px; }
    .nav-links .nav-links-list { display:flex; align-items:center; gap:4px; margin:0; padding:0; list-style:none; }
    .nav-links .nav-links-list li { position:relative; margin:0; padding:0; list-style:none; }
    .nav-links .nav-links-list > li { display:flex; align-items:center; gap:6px; }
    .nav-links .nav-links-list a { display:inline-flex; align-items:center; min-height:38px; padding:0 12px; border-radius:999px; font-weight:800; font-size:11px; letter-spacing:.08em; text-transform:uppercase; }
    .nav-links .menu-item-has-children > a::after { content:""; width:8px; height:8px; margin-left:8px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform: rotate(45deg) translateY(-1px); opacity:.75; }
    .nav-links a { font-weight:800; font-size:11px; color:#111; transition: background .22s ease, color .22s ease, opacity .22s ease, transform .22s ease; }
    .nav-links a:hover { background: rgba(18,18,18,.05); transform: translateY(-1px); }
    .nav-links .is-current > a { background:#121212; color:#fafafa; }
    .nav-links .is-current.menu-item-has-children > a::after { border-color:currentColor; }
    .nav-links .sub-menu { position:absolute; top:calc(100% + 10px); left:0; min-width:260px; margin:0; padding:10px; list-style:none; border-radius:22px; background:rgba(255,255,255,.98); border:1px solid rgba(18,18,18,.06); box-shadow: 0 20px 40px rgba(18,18,18,.12); opacity:0; visibility:hidden; transform: translateY(10px); transition: opacity .22s ease, transform .22s ease, visibility .22s ease; }
    .nav-links .sub-menu li { width:100%; }
    .nav-links .sub-menu a { display:block; min-height:0; padding:12px 14px; border-radius:14px; font-size:11px; }
    .nav-links .sub-menu a:hover { background: rgba(18,18,18,.05); transform:none; }
    .nav-links .sub-menu .is-current > a { background: rgba(18,18,18,.08); color:#111; }
    .nav-links li:hover > .sub-menu,
    .nav-links li:focus-within > .sub-menu,
    .nav-links li.is-open > .sub-menu { opacity:1; visibility:visible; transform: translateY(0); }
    .home { padding-top: 0; --site-header-offset: 0px; }
    .home .site-header { background: #f8f6f3 !important; border-bottom: 1px solid rgba(17,17,17,.08) !important; box-shadow: 0 12px 28px rgba(17,17,17,.06) !important; backdrop-filter: blur(16px) !important; transition: background .28s ease, box-shadow .28s ease, border-color .28s ease, transform .28s ease; }
    .home .site-header.is-hero-top:not(.is-scrolled) { background: transparent !important; border-bottom-color: transparent !important; box-shadow: none !important; backdrop-filter: none !important; }
    .home .site-header.is-hero-top:not(.is-scrolled) .nav { background: transparent !important; box-shadow: none !important; }
    .home .site-header .nav { width: min(1380px, calc(100% - 24px)); min-height: 64px; padding-top: 16px; padding-bottom: 10px; transition: padding .28s ease; }
    .home .site-header .brand img { filter: none !important; transition: filter .28s ease, transform .28s ease; }
    .home .site-header .brand-badge { min-width: 58px; min-height: 58px; width:58px; height:58px; }
    .home .site-header .nav-toggle { color: #111 !important; background: rgba(17,17,17,.06) !important; border: 1px solid rgba(17,17,17,.1) !important; box-shadow: none !important; }
    .home .site-header .nav-links a { color: #111; text-shadow: none; }
    .home .site-header .nav-links a:hover { background: rgba(18,18,18,.05); color: #111; }
    .home .site-header .nav-links .is-current > a { background: rgba(17,17,17,.06); color: #111; border: 1px solid rgba(17,17,17,.08); }
    .home .site-header .nav-links .sub-menu { background: rgba(255,255,255,.98); border-color: rgba(18,18,18,.06); }
    .home .site-header .nav-links .sub-menu a { color: #111; }
    .home .site-header.is-hero-top:not(.is-scrolled) .brand img { filter: brightness(0) invert(1) !important; }
    .home .site-header.is-hero-top:not(.is-scrolled) .nav-toggle { color: #fff !important; background: transparent !important; border: 1px solid rgba(255,255,255,.18) !important; }
    .home .site-header.is-hero-top:not(.is-scrolled) .nav-links a { color: rgba(255,255,255,.96); text-shadow: 0 1px 12px rgba(0,0,0,.18); }
    .home .site-header.is-hero-top:not(.is-scrolled) .nav-links a:hover { background: rgba(255,255,255,.12); color: #fff; }
    .home .site-header.is-hero-top:not(.is-scrolled) .nav-links .is-current > a { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.2); }
    .home .site-header.is-hero-top:not(.is-scrolled) .nav-links .sub-menu { background: rgba(15,15,18,.96); border-color: rgba(255,255,255,.1); }
    .home .site-header.is-hero-top:not(.is-scrolled) .nav-links .sub-menu a { color: rgba(255,255,255,.92); text-shadow: none; }
    .home .site-header.is-scrolled { background: #f8f6f3; border-bottom: 1px solid rgba(17,17,17,.08); backdrop-filter: blur(16px); box-shadow: 0 18px 38px rgba(17,17,17,.08); }
    .home .site-header.is-scrolled .nav { padding-top: 10px; padding-bottom: 8px; }
    .home .site-header.is-scrolled .brand img { filter: none; transform: scale(.94); }
    .home .site-header.is-scrolled .nav-toggle,
    .home .site-header.is-scrolled .nav-links a { color: #111; text-shadow: none; }
    .home .site-header.is-scrolled .nav-links a:hover { background: rgba(18,18,18,.05); color:#111; }
    .home .site-header.is-scrolled .nav-links .is-current > a { background: rgba(17,17,17,.06); color: #111; border-color: rgba(17,17,17,.08); }
    .submenu-toggle { display:none; border:0; background:transparent; color:inherit; width:32px; height:32px; padding:0; border-radius:999px; cursor:pointer; }
    .submenu-toggle::before { content:"+"; font-size:18px; font-weight:800; line-height:1; }
    .menu-item-has-children.is-open > .submenu-toggle::before { content:"-"; }
    .home .hero {
      min-height: 100svh;
      background:
        radial-gradient(circle at 82% 18%, rgba(226,97,237,.28), transparent 20%),
        radial-gradient(circle at 20% 10%, rgba(36,81,196,.22), transparent 26%),
        radial-gradient(circle at 78% 78%, rgba(220,231,92,.12), transparent 18%),
        linear-gradient(180deg, #050505 0%, #09090c 48%, #111118 100%);
    }
    .home .hero::before {
      background:
        radial-gradient(ellipse 78% 58% at 50% 0%, rgba(36,81,196,.18), transparent 72%),
        linear-gradient(180deg, rgba(255,255,255,.02), transparent 30%);
    }
    .home .hero::after { display:none; }
    .home .hero-centered { overflow:hidden; }
    .home .hero-sticker-scene { display:none !important; }
    .home .hero-title-stack { position: relative; display: inline-block; isolation: isolate; }

    .hero { background: var(--bg); color: var(--white); position: relative; overflow: visible; }
    .hero::before { content:""; position:absolute; inset:0; background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(36,81,196,.18), transparent 70%); pointer-events:none; z-index:0; }
    .hero-cta { display:flex; gap:14px; flex-wrap:wrap; margin-top: 18px; }
    .hero-centered { padding: 0; position:relative; z-index:1; }
    .hero-centered-inner { padding: 104px 0 70px; display:flex; flex-direction:column; align-items:center; text-align:center; position:relative; isolation:isolate; min-height: min(84svh, 760px); justify-content:center; }
    .hero-sticker-scene { position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden; }
    .hero-sticker-wrap { position:relative; width:100%; max-width:min(920px, 74vw); padding: 0; z-index:3; margin:0 auto; }
    .hero-logo-sticker { position:absolute; top:var(--sticker-top, 50%); left:var(--sticker-left, 50%); width:var(--sticker-size, 92px); height:var(--sticker-size, 92px); transform:translate(-50%, -50%) rotate(var(--sticker-rotate, 0deg)); opacity:var(--sticker-opacity, .95); display:block; filter: drop-shadow(0 16px 30px rgba(0,0,0,.28)); }
    .hero-logo-sticker-disc { width:100%; height:100%; display:grid; place-items:center; border:0; border-radius:0; background:transparent; box-shadow:none; }
    .hero-logo-sticker img { width:100%; height:100%; object-fit:contain; display:block; background:transparent; }
    .hero-line-clip { display:block; overflow:visible; }
    .home .hero-sticker-wrap::after { display:none !important; content:none !important; }
    .home .hero-logo-sticker { display:none !important; opacity:0 !important; pointer-events:none !important; }
    .hero-title-main { font-family:"Yorkmade", var(--font-body); font-weight:400; font-size:clamp(76px,10.4vw,154px); text-transform:uppercase; letter-spacing:-.035em; color:var(--white); line-height:.88; display:block; width:100%; margin:0 auto; padding: .02em 0 0; position:relative; z-index:3; text-align:center; }
    .home .hero-title-main,
    .home .hero-title-main span { color:#fff !important; }
    .home .title-sticker {
      position: absolute;
      display: inline-block;
      padding: 0;
      background: transparent;
      border-radius: 0;
      box-shadow: none;
      z-index: 14;
      pointer-events: none;
      animation: title-sticker-float 4.4s ease-in-out infinite;
    }
    .home .title-sticker-logo {
      width: 100%;
      height: 100%;
      display: block;
      background: var(--sticker-color, #E261ED);
      -webkit-mask-image: url("assets/branding/logo-sf-n.png");
      mask-image: url("assets/branding/logo-sf-n.png");
      -webkit-mask-repeat: no-repeat;
      mask-repeat: no-repeat;
      -webkit-mask-position: center;
      mask-position: center;
      -webkit-mask-size: contain;
      mask-size: contain;
      filter: drop-shadow(0 12px 20px rgba(0,0,0,.22));
    }
    .home .title-sticker-logo img { display: none; }
    .home .title-sticker.sticker-1 {
      top: 8%;
      right: -4%;
      width: 92px;
      height: 92px;
      animation-delay: -.4s;
      --sticker-color: #E261ED;
      --float-rotate: 12deg;
    }
    .home .title-sticker.sticker-2 {
      left: 2%;
      bottom: 12%;
      width: 82px;
      height: 82px;
      animation-delay: -1.1s;
      --sticker-color: #2451C4;
      --float-rotate: -14deg;
    }
    .home .title-sticker.sticker-3 {
      top: 48%;
      right: 18%;
      width: 72px;
      height: 72px;
      animation-delay: -.8s;
      --sticker-color: #FD603A;
      --float-rotate: -7deg;
    }
    .home .title-sticker.sticker-4 {
      left: 28%;
      bottom: -4%;
      width: 66px;
      height: 66px;
      animation-delay: -1.6s;
      --sticker-color: #DCE75C;
      --float-rotate: 8deg;
    }
    @keyframes title-sticker-float {
      0%, 100% { transform: translateY(0) rotate(var(--float-rotate, 0deg)); }
      50% { transform: translateY(-6px) rotate(var(--float-rotate, 0deg)); }
    }
    .hero-desc { position:relative; z-index:3; max-width: 44ch; margin: -8px auto 0; font-size: clamp(18px, 1.22vw, 21px); line-height: 1.28; color: rgba(255,255,255,.9); }
    .hero-scroll-cue { position:absolute; left:50%; bottom:18px; transform:translateX(-50%); width:54px; height:54px; display:grid; place-items:center; border-radius:999px; text-decoration:none; color:rgba(255,255,255,.98); background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18); box-shadow: 0 12px 28px rgba(0,0,0,.16); z-index:4; opacity:.98; transition: transform .22s ease, opacity .22s ease, background .22s ease, border-color .22s ease; animation: hero-scroll-bob 1.8s ease-in-out infinite; backdrop-filter: blur(10px); }
    .hero-scroll-cue:hover { opacity:1; transform:translateX(-50%) translateY(2px); }
    .hero-scroll-cue:hover { background:rgba(255,255,255,.1); border-color: rgba(255,255,255,.26); }
    .hero-scroll-cue-icon { display:grid; place-items:center; width:24px; height:24px; }
    .hero-scroll-cue-icon svg { display:block; width:24px; height:24px; stroke: currentColor; stroke-width: 2.15; fill: none; stroke-linecap: round; stroke-linejoin: round; }
    @keyframes hero-scroll-bob {
      0%, 100% { transform: translateX(-50%) translateY(0); }
      50% { transform: translateX(-50%) translateY(8px); }
    }
    .home .hero-centered-inner::after,
    .home .hero-centered-inner::before { display:none; content:none; }
    .hero-note { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin-top:20px; }
    .hero-cta-centered { justify-content:center; margin-top:20px; }
    /* mini-cards v2: solo colores de marca, sin depender de inline styles */
    .v2-mini-card:nth-child(4n+1) { background: var(--yellow) !important; color: #111 !important; }
    .v2-mini-card:nth-child(4n+2) { background: var(--orange) !important; color: #fff !important; }
    .v2-mini-card:nth-child(4n+3) { background: var(--pink) !important; color: #fff !important; }
    .v2-mini-card:nth-child(4n+4) { background: var(--blue) !important; color: #fff !important; }
    /* banner recensioni */
    .recensioni-banner-section { padding: 0; background: var(--paper, #f5f5f0); }
    .recensioni-banner { display:flex; align-items:center; justify-content:space-between; gap:20px; color:#111; text-decoration:none; padding: 32px 0; border-top: 2px solid rgba(0,0,0,.08); border-bottom: 2px solid rgba(0,0,0,.08); transition: color .2s; }
    .recensioni-banner:hover { color: #000; }
    .recensioni-banner-title { font-family:var(--font-display); font-weight:800; font-size:clamp(18px,2.4vw,34px); text-transform:uppercase; letter-spacing:-.01em; line-height:1; color:inherit; }
    .recensioni-banner-arrow { display:inline-flex; align-items:center; justify-content:center; width:clamp(44px,4vw,58px); height:clamp(44px,4vw,58px); border-radius:50%; background:var(--yellow,#dce75c); color:#111; font-size:clamp(18px,1.8vw,26px); font-weight:800; flex-shrink:0; transition: transform .22s, box-shadow .22s; box-shadow: 0 2px 8px rgba(0,0,0,.12); }
    .recensioni-banner:hover .recensioni-banner-arrow { transform: translate(4px,-4px); box-shadow: 0 6px 18px rgba(0,0,0,.16); }
    .home .recensioni-banner-section { padding: 18px 0 8px; }
    .home .recensioni-banner {
      position: relative;
      padding: 20px 24px;
      border: 1px solid rgba(0,0,0,.08);
      border-radius: 30px;
      background: rgba(255,255,255,.78);
      box-shadow: 0 18px 34px rgba(18,18,18,.08);
      backdrop-filter: blur(10px);
    }
    .home .recensioni-banner::before {
      content: "RECENSIONI REALI";
      position: absolute;
      top: -11px;
      left: 24px;
      display: inline-flex;
      align-items: center;
      height: 28px;
      padding: 0 14px;
      border-radius: 999px;
      background: var(--yellow);
      color: #111;
      font-size: 11px;
      font-weight: 800;
      letter-spacing: .12em;
      text-transform: uppercase;
      box-shadow: 0 8px 16px rgba(18,18,18,.08);
    }
    .home .recensioni-banner-title {
      max-width: 18ch;
      font-size: clamp(24px, 3.5vw, 44px);
      line-height: .96;
    }
    .home .recensioni-banner-arrow {
      width: 56px;
      height: 56px;
      box-shadow: none;
    }

    .slider { position:relative; min-height: 440px; border-radius: 36px; overflow:hidden; box-shadow: var(--shadow); background:#111; }
    .slide { position:absolute; inset:0; opacity:0; pointer-events:none; transition: opacity .45s ease; }
    .slide.is-active { opacity:1; pointer-events:auto; z-index:1; }
    .slide img { width:100%; height:100%; object-fit:contain; object-position:center; background:#111; }
    .slide::after { content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.42), transparent 42%); }
    .slide-caption { position:absolute; left:22px; bottom:20px; right:22px; z-index:2; display:flex; justify-content:space-between; gap:14px; align-items:end; }
    .caption-box { background: rgba(250,250,250,.92); color:#111; padding:14px 16px; border-radius: 18px; max-width: 320px; box-shadow: var(--shadow); }
    .slider-controls { position:absolute; left:22px; right:22px; bottom:18px; z-index:3; display:flex; justify-content:space-between; align-items:center; gap:16px; pointer-events:none; }
    .dots { display:flex; gap:8px; align-items:center; pointer-events:auto; }
    .dot { width:12px; height:12px; border-radius:50%; border:0; padding:0; background: rgba(255,255,255,.4); cursor:pointer; transition: transform .2s ease, background .2s ease; }
    .dot.is-active { background: var(--yellow); transform: scale(1.15); }
    .slider-arrow { width:42px; height:42px; border:0; border-radius:999px; background: rgba(17,17,17,.72); color:#fff; display:grid; place-items:center; font-size:28px; line-height:1; cursor:pointer; backdrop-filter: blur(8px); pointer-events:auto; transition: transform .2s ease, background .2s ease, opacity .2s ease; }
    .slider-arrow:hover { transform: translateY(-1px); background: rgba(17,17,17,.88); }

    .story-strip { background: linear-gradient(90deg, var(--blue) 0 25%, var(--orange) 25% 50%, var(--pink) 50% 75%, var(--yellow) 75% 100%); padding: 11px 0 10px; color:#111; font-size: clamp(12px, 1.4vw, 15px); letter-spacing:.08em; text-transform:uppercase; overflow:hidden; white-space:nowrap; border-top: 2px solid rgba(0,0,0,.08); border-bottom: 2px solid rgba(0,0,0,.08); }
    .story-strip-track { display:flex; width:max-content; align-items:center; animation: story-strip-marquee 22s linear infinite; }
    .story-strip-group { display:flex; align-items:center; gap:18px; flex:0 0 auto; padding-right:18px; }
    .story-strip-item { display:inline-flex; align-items:center; gap:.42em; flex:0 0 auto; font-family: var(--font-body); font-weight:400; }
    .story-strip-item strong { font-weight:800; }
    .story-strip-item::after { content:"·"; font-weight:800; margin-left:.55em; }
    @keyframes story-strip-marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }

    section:not([class*="elementor"]) { padding: var(--section-pad) 0; }
    .intro-grid { display:grid; grid-template-columns: .95fr 1.05fr; gap: 26px; align-items:center; }
    .panel { background:white; border-radius: var(--radius); box-shadow: var(--shadow); overflow:hidden; }
    .panel.p-dark { background: var(--bg); color:var(--white); }
    .panel.pad { padding: 28px; }
    .home-intro-section { background: var(--paper); }
    .home-intro-section .intro-grid { grid-template-columns: 1fr; }
    .home-intro-section .intro-visual-panel { display:none; }
    .intro-visual-panel { border-radius: 40px 16px 40px 16px; transform: rotate(-1.2deg); box-shadow: 0 24px 46px rgba(36,81,196,.16); }
    .intro-copy-panel { border-radius: 32px; background: #ffffff; }
    .intro-content-columns { display:grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap:36px; align-items:center; }
    .intro-copy-column .eyebrow:empty { display:none; }
    .intro-highlights-column { display:flex; align-items:stretch; }
    .intro-highlights-column .mini-grid { width:100%; align-content:start; }
    .intro-grid h2 { font-size: clamp(34px, 5vw, 64px); margin: 14px 0; }
    .lead { font-size: 20px; line-height: 1.45; }
    .mini-grid { display:grid; grid-template-columns: repeat(2,1fr); gap:14px; margin-top: 0; width:100%; }
    .mini-card { padding:18px; border-radius: 24px; font-weight:700; min-height:92px; display:flex; align-items:center; justify-content:center; text-align:center; box-shadow: 0 14px 34px rgba(36,81,196,.08); }

    .section-head { display:flex; justify-content:space-between; gap:20px; align-items:end; margin-bottom: 28px; }
    .section-head h2 { font-size: clamp(30px, 4.8vw, 58px); margin: 0; max-width: 12ch; line-height: .98; }
    .section-head p { max-width: 520px; font-size: 18px; line-height: 1.5; margin: 0; }

    .cards { display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
    .service-section { background: #050505; }
    .service-section .section-head h2,
    .service-section .section-head p { color:#fff; }
    .service-card { position:relative; overflow:hidden; border-radius: 32px; background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(249,246,240,.98) 100%); box-shadow: 0 20px 45px rgba(18,18,18,.08); min-height: 100%; display:flex; flex-direction:column; transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease; border:1px solid rgba(36,81,196,.08); }
    .service-card:hover { transform: translateY(-8px); box-shadow: 0 24px 48px rgba(36,81,196,.14); border-color: rgba(226,97,237,.18); }
    .service-card .media { height: 290px; position:relative; overflow:hidden; }
    .service-card .media img { width:100%; height:100%; object-fit:cover; }
    .service-card .media::after { content:""; position:absolute; inset:0; background: linear-gradient(to top, rgba(0,0,0,.12), transparent 45%); }
    .sticker { position:absolute; top:16px; right:16px; padding:10px 14px; border-radius:999px; font-size:12px; font-weight:900; text-transform:uppercase; }
    .service-card .body { padding: 24px; display:flex; flex-direction:column; gap:14px; flex:1; }
    .service-card h3 { margin:0; font-size: 28px; line-height:1; }
    .service-card p { margin:0; line-height:1.5; font-size: 16px; }
    .tag-row { display:flex; gap:10px; flex-wrap:wrap; margin-top:auto; }
    .tag { border-radius:999px; padding:8px 12px; font-size:12px; font-weight:800; background:#eef2ff; color:var(--blue); }
    .service-card .tag:nth-child(3n+1) { background: var(--yellow); color:#111; }
    .service-card .tag:nth-child(3n+2) { background: var(--orange); color:#fff; }
    .service-card .tag:nth-child(3n+3) { background: var(--pink); color:#fff; }
    .inline-link { display:inline-flex; align-items:center; gap:8px; margin-top: 8px; font-weight:800; color: var(--blue); transition: transform .22s ease, color .22s ease; }
    .inline-link:hover { transform: translateX(4px); }
    .inline-link::after { content:"+"; display:inline-grid; place-items:center; width:22px; height:22px; border-radius:50%; background: var(--yellow); color:#111; }
    .service-showcase-wrap { position:relative; }
    .service-showcase { display:flex; gap:18px; align-items:stretch; overflow-x:auto; overflow-y:hidden; scroll-snap-type:x mandatory; scroll-behavior:smooth; padding-bottom:8px; scrollbar-width:none; -ms-overflow-style:none; }
    .service-showcase::-webkit-scrollbar { display:none; }
    .service-showcase .service-card { min-height:0; flex:0 0 min(320px, calc((100% - 54px) / 4)); scroll-snap-align:start; border-radius: 28px; background: linear-gradient(180deg, #fffdfa 0%, #fff 100%); border:1px solid rgba(255,255,255,.14); overflow:hidden; }
    .service-showcase .service-card .media { height: 224px; background: transparent; padding: 14px 14px 0; }
    .service-showcase .service-card .media::after { display:none; }
    .service-showcase .service-card .media img { object-fit:cover; object-position:center; background:#111; border-radius: 22px 22px 16px 16px; box-shadow: inset 0 0 0 1px rgba(255,255,255,.06); }
    .service-showcase .service-card h3 { font-size: 22px; }
    .service-showcase .service-card p { font-size: 15px; }
    .service-showcase .service-card .body { padding: 18px 18px 20px; gap:12px; }
    .service-showcase .tag { padding:7px 10px; font-size:11px; }
    .service-showcase .inline-link { margin-top: 2px; font-size: 14px; }
    .service-showcase-arrow { position:absolute; top:50%; transform:translateY(-50%); width:44px; height:44px; border:0; border-radius:999px; background: rgba(255,255,255,.96); color:#111; box-shadow: 0 14px 28px rgba(0,0,0,.16); display:grid; place-items:center; font-size:30px; line-height:1; cursor:pointer; z-index:3; transition: transform .2s ease, opacity .2s ease, background .2s ease; }
    .service-showcase-arrow:hover { background:#fff; }
    .service-showcase-arrow[disabled] { opacity:.35; cursor:default; }
    .service-showcase-prev { left:-18px; }
    .service-showcase-next { right:-18px; }
    .service-showcase .service-card:nth-child(4n+1) { background: linear-gradient(180deg, #fffdfa 0%, #fff 100%); }
    .service-showcase .service-card:nth-child(4n+2) { background: linear-gradient(180deg, #fff9f4 0%, #fff 100%); }
    .service-showcase .service-card:nth-child(4n+3) { background: linear-gradient(180deg, #fffdf4 0%, #fff 100%); }
    .service-showcase .service-card:nth-child(4n+4) { background: linear-gradient(180deg, #fcf8ff 0%, #fff 100%); }

    .testimonial { background: #f8f6f3; color: var(--text); overflow:hidden; position:relative; }
    .home-support-section.testimonial { background: #050505; color: #fff; }
    .testimonial-grid { display:grid; grid-template-columns: minmax(0, .94fr) minmax(0, 1.06fr); gap:42px; align-items:center; }
    .support-scene { position: relative; min-height: 430px; max-width: 540px; width: 100%; overflow: visible; }
    .support-person { position:absolute; }
    .support-person-card {
      position: relative;
      width: 190px;
      height: 250px;
      border-radius: 28px;
      overflow: hidden;
      box-shadow: 0 24px 44px rgba(0,0,0,.24);
      border: 1px solid rgba(255,255,255,.08);
      background: rgba(255,255,255,.04);
    }
    .support-person-photo {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      object-position: center bottom;
      display: block;
      filter: drop-shadow(0 14px 26px rgba(0,0,0,.22));
    }
    .support-person-logo {
      position: absolute;
      right: 16px;
      bottom: 16px;
      z-index: 2;
      width: 54px;
      height: 54px;
      border-radius: 18px;
      display:grid;
      place-items:center;
      box-shadow: 0 14px 24px rgba(0,0,0,.18);
    }
    .support-person-logo img {
      width: 30px;
      height: 30px;
      object-fit: contain;
      filter: brightness(0) invert(1);
    }
    .support-person-left { left: -6px; top: 132px; animation: supportFloatLeft 5.4s ease-in-out infinite; }
    .support-person-left .support-person-card { background: linear-gradient(180deg, rgba(220,231,92,.22) 0%, rgba(220,231,92,.08) 100%); }
    .support-person-right { right: -28px; bottom: 2px; animation: supportFloatRight 5.8s ease-in-out infinite; }
    .support-person-right .support-person-card { background: linear-gradient(180deg, rgba(36,81,196,.16) 0%, rgba(36,81,196,.05) 100%); }
    .support-chat-bubble {
      position: absolute;
      z-index: 3;
      max-width: 220px;
      border-radius: 22px;
      padding: 16px 18px;
      box-shadow: 0 18px 34px rgba(0,0,0,.16);
      font-size: 17px;
      line-height: 1.16;
      font-weight: 700;
      letter-spacing: -.01em;
      text-wrap: balance;
    }
    .support-chat-type {
      display: block;
      min-height: 5.7em;
      white-space: normal;
    }
    .support-chat-type.is-done::after,
    .support-chat-type::after {
      content: "";
      display: inline-block;
      width: 1px;
      height: 1em;
      margin-left: 4px;
      vertical-align: -0.12em;
      background: currentColor;
      animation: supportCaret .9s steps(1) infinite;
    }
    .support-chat-type.is-done::after {
      opacity: 0;
      animation: none;
    }
    .support-chat-bubble::after {
      content: "";
      position: absolute;
      width: 18px;
      height: 18px;
      border-radius: 5px;
      transform: rotate(45deg);
      background: inherit;
    }
    .support-chat-bubble-left {
      top: 6px;
      left: 118px;
      background: #F6E7CE;
      color: #121212;
      transform: rotate(-1.5deg);
      animation: supportFloatBubbleLeft 6.2s ease-in-out infinite;
    }
    .support-chat-bubble-left::after { left: 24px; bottom: -8px; }
    .support-chat-bubble-right {
      top: 182px;
      left: 188px;
      background: #5F6FF4;
      color: #fff;
      transform: rotate(1.4deg);
      animation: supportFloatBubbleRight 6.6s ease-in-out infinite;
    }
    .support-chat-bubble-right::after { right: 32px; bottom: -8px; }
    .quote-card { background:#ffffff; color:#131313; border-radius:32px; padding:28px; box-shadow: 0 12px 32px rgba(18,18,18,.08); border:1px solid rgba(18,18,18,.06); transition: transform .28s ease, box-shadow .28s ease; }
    .quote-card:hover { transform: translateY(-4px); }
    .quote-card h3 { margin: 0 0 10px; font-size: 28px; line-height: 1.05; }
    .quote-card p { font-size: 18px; line-height:1.35; margin:0; }
    .quote-meta { margin-top: 14px; font-weight: 800; color:#888; }
    .review-shot { border-radius:32px; overflow:hidden; box-shadow:var(--shadow); }
    .support-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top: 24px; }
    .support-card { background: linear-gradient(135deg, var(--yellow), #fff2a3); }
    .home-support-section .support-card { display: none; }
    .support-card h3 { font-size: 22px; line-height: 1.2; }
    .support-copy { padding-top: 10px; }
    .support-title { font-size: clamp(32px, 3.8vw, 52px); margin:14px 0 20px; letter-spacing: 0; color: var(--text); }
    .testimonial-copy { font-size: clamp(15px, 1.4vw, 18px); line-height:1.5; color:#666; max-width:560px; }
    .support-copy-text { color:#666; }
    .home-support-section .support-title,
    .home-support-section .support-copy,
    .home-support-section .support-copy-text,
    .home-support-section .testimonial-copy { color:#fff; }
    .home-support-section .testimonial-copy,
    .home-support-section .support-copy-text { color: rgba(255,255,255,.82); }
    .support-note-card {
      margin-top: 22px;
      background:#fff;
      color:#111;
      border-radius: 28px;
      padding: 22px 24px;
      box-shadow: 0 18px 34px rgba(0,0,0,.22);
      max-width: 560px;
    }
    .support-note-card h3 { margin: 0 0 8px; font-size: clamp(22px, 2.2vw, 28px); line-height: 1.02; }
    .support-note-card p { margin:0; font-size:17px; line-height:1.5; color:#222; }
    .page-dark-btn { background: rgba(18,18,18,.92); color:#fff; border-color: rgba(18,18,18,.92); box-shadow: 0 16px 32px rgba(18,18,18,.14); }
    .home-support-section .btn-secondary { background: rgba(18,18,18,.92); color:#fff; border-color: rgba(18,18,18,.92); box-shadow: 0 16px 32px rgba(18,18,18,.14); }
    .home-support-section .btn-secondary:hover { background:#000; border-color:#000; }
    @keyframes supportCaret {
      0%, 49% { opacity: 1; }
      50%, 100% { opacity: 0; }
    }
    @keyframes supportFloatLeft {
      0%, 100% { transform: translateY(0) rotate(-1.2deg); }
      50% { transform: translateY(-8px) rotate(.6deg); }
    }
    @keyframes supportFloatRight {
      0%, 100% { transform: translateY(0) rotate(1deg); }
      50% { transform: translateY(-10px) rotate(-.5deg); }
    }
    @keyframes supportFloatBubbleLeft {
      0%, 100% { transform: rotate(-1.5deg) translateY(0); }
      50% { transform: rotate(-1.5deg) translateY(-6px); }
    }
    @keyframes supportFloatBubbleRight {
      0%, 100% { transform: rotate(1.4deg) translateY(0); }
      50% { transform: rotate(1.4deg) translateY(-7px); }
    }

    .review-section { background: #050505; }
    .review-section-light { background: var(--paper); }
    .review-section-light .section-head h2,
    .review-section-light .section-head p,
    .review-section-light .review-footnote a { color: var(--text); }
    .review-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:22px; }
    .review-section .section-head h2,
    .review-section .section-head p { color:#fff; }
    .review-card { background:linear-gradient(180deg, #fffdfa 0%, #f7efe6 100%); border-radius: 30px; padding: 28px; box-shadow: 0 18px 34px rgba(18,18,18,.18); transition: transform .28s ease, box-shadow .28s ease; border:1px solid rgba(18,18,18,.05); }
    .review-card:hover { transform: translateY(-6px); box-shadow: 0 22px 38px rgba(18,18,18,.22); }
    .review-card h3 { margin:0 0 12px; font-size: 24px; line-height: 1.2; }
    .review-card p { margin:0; line-height:1.65; font-size: 16px; }
    .review-footnote { margin: 26px 0 0; text-align:center; font-weight:800; }
    .review-footnote a { color: var(--yellow); }
    .section-head-full { display:block; margin-bottom:36px; }
    .section-head-full h2 { max-width:none; }
    .section-head-proof { margin-bottom: 36px; }
    .section-head-proof h2 { font-size: clamp(24px, 5vw, 64px); line-height: 1; max-width: none; }
    .proof-copy { max-width: 640px; font-size: 18px; line-height: 1.45; color:#f4f4f4; margin:0; }
    .home-proof-section .section-head-proof { display: block; }
    .home-proof-section .section-head-proof h2 { font-size: clamp(22px, 5.2vw, 66px); white-space: nowrap; }
    .home-proof-section .proof-copy { display: none; }
    .home-proof-section .review-grid { align-items:start; overflow: visible; }
    .home-proof-section .review-card:nth-child(3n+1) { border-radius: 34px 22px 30px 30px; transform: rotate(-2.5deg) translateY(-14px); background: #2451c4; color: #ffffff; border-color: transparent; position: relative; z-index: 3; }
    .home-proof-section .review-card:nth-child(3n+2) { border-radius: 28px 34px 24px 28px; transform: rotate(1.8deg) translateY(18px); background: #fd603a; color: #ffffff; border-color: transparent; position: relative; z-index: 2; }
    .home-proof-section .review-card:nth-child(3n+3) { border-radius: 30px 30px 22px 34px; transform: rotate(-1.2deg) translateY(4px); background: #e261ed; color: #ffffff; border-color: transparent; position: relative; z-index: 1; }
    .statement-title em { font-style: italic; }
    .statement-title-strong { color: var(--yellow); }

    .cta-band { padding: 56px 0; }
    .cta-box { background: linear-gradient(135deg, #e261ed 0%, #2451c4 100%); color:white; border-radius:40px; padding: 36px; display:grid; grid-template-columns: 1.15fr .85fr; gap:24px; align-items:center; box-shadow: var(--shadow); }
    .cta-box h2 { font-size: clamp(36px, 6vw, 72px); margin:0 0 10px; }
    .cta-box p { font-size:20px; line-height:1.45; margin:0; max-width: 650px; }
    .cta-box .actions { display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end; }
    .home .cta-band { padding: 14px 0 34px; }
    .home .cta-box {
      padding: 28px 32px;
      gap: 20px;
      border-radius: 34px;
      grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
    }
    .home .cta-box h2 {
      margin-bottom: 6px;
      font-size: clamp(34px, 5.2vw, 76px);
      line-height: .92;
    }
    .home .cta-box p {
      max-width: 33ch;
      font-size: clamp(18px, 1.55vw, 21px);
      line-height: 1.4;
    }
    html.motion-ready .slider,
    html.motion-ready .page-hero-card,
    html.motion-ready .blog-feature-card,
    html.motion-ready .panel.p-dark,
    html.motion-ready .hero-copy,
    html.motion-ready .section-head,
    html.motion-ready .quote-card,
    html.motion-ready .review-card,
    html.motion-ready .service-card,
    html.motion-ready .mini-card,
    html.motion-ready .cta-box {
      will-change: transform, opacity, filter;
      backface-visibility: hidden;
    }
    html.reduced-motion { scroll-behavior: auto; }
    html.reduced-motion *,
    html.reduced-motion *::before,
    html.reduced-motion *::after {
      animation-duration: .01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: .01ms !important;
      scroll-behavior: auto !important;
    }
    html.reduced-motion .slide,
    html.reduced-motion .story-strip-track {
      animation: none !important;
    }
    .reveal-on-scroll { opacity: 0; transform: translateY(34px) scale(.985); transition: opacity .65s ease, transform .65s cubic-bezier(.22,1,.36,1); will-change: transform, opacity; }
    .reveal-on-scroll.is-visible { opacity: 1; transform: translateY(0) scale(1); }

    .blog-shell, .single-shell { background: var(--paper); }
    .blog-hero, .single-hero { background: var(--bg); color: var(--white); position: relative; overflow: hidden; }
    .blog-hero::before, .single-hero::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at top left, rgba(226,97,237,.16), transparent 30%), radial-gradient(circle at bottom right, rgba(220,231,92,.16), transparent 24%); pointer-events:none; }
    .blog-hero-grid { position:relative; z-index:1; display:grid; grid-template-columns: .9fr 1.1fr; gap:28px; align-items:center; padding: 54px 0 62px; }
    .blog-hero-compact .container, .single-hero-inner { position:relative; z-index:1; padding: 54px 0 62px; }
    .blog-hero h1, .single-hero h1 { font-size: clamp(42px, 8vw, 88px); margin: 14px 0 18px; max-width: 11ch; }
    .blog-hero p, .blog-archive-desc { font-size: 20px; line-height: 1.5; max-width: 650px; color:#e8e8e8; margin:0; }
    .blog-feature-card, .blog-card { border-radius: 32px; overflow:hidden; box-shadow: var(--shadow); background:#fff; }
    .blog-feature-card a, .blog-card a { display:block; }
    .blog-feature-media, .blog-card-media { background:#111; }
    .blog-feature-media { min-height: 360px; }
    .blog-card-media { aspect-ratio: 4 / 3; }
    .blog-feature-media img, .blog-card-media img { width:100%; height:100%; object-fit:cover; }
    .blog-feature-fallback, .blog-card-fallback { width:100%; height:100%; min-height:100%; background: linear-gradient(135deg, var(--blue), var(--pink) 55%, var(--yellow)); }
    .blog-feature-body, .blog-card-body { padding: 24px; }
    .blog-feature-body h2, .blog-card-body h2 { margin: 14px 0 12px; font-size: clamp(28px, 4vw, 46px); }
    .blog-card-body h2 { font-size: 30px; }
    .blog-feature-body p, .blog-card-body p { margin:0; line-height:1.6; font-size:16px; }
    .blog-chip-dark { background: rgba(0,0,0,.08); color:#111; border: 1px solid rgba(0,0,0,.08); }
    .blog-chip-light { background: var(--yellow); color:#111; border:0; }
    .blog-listing { padding: 34px 0 86px; }
    .blog-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:22px; }
    .blog-meta { display:flex; gap:14px; flex-wrap:wrap; margin-top:18px; font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#666; }
    .blog-meta-hero { color: rgba(255,255,255,.78); }
    .blog-pagination { display:flex; justify-content:center; margin-top:34px; }
    .blog-pagination .page-numbers { display:inline-flex; align-items:center; justify-content:center; min-width:44px; height:44px; padding:0 14px; margin:0 6px; border-radius:999px; background:#fff; color:#111; font-weight:800; box-shadow: var(--shadow); }
    .blog-pagination .current { background: var(--orange); color:#fff; }
    .single-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap:24px; padding: 36px 0 86px; align-items:start; }
    .single-cover { margin:0 0 24px; border-radius:28px; overflow:hidden; }
    .single-cover img { width:100%; height:auto; }
    .single-copy { font-size: 18px; line-height: 1.8; }
    .single-copy h2, .single-copy h3, .single-copy h4 { font-family: var(--font-display); line-height: 1; margin: 34px 0 14px; }
    .single-copy p { margin:0 0 18px; }
    .single-copy ul, .single-copy ol { padding-left: 22px; }
    .single-aside { display:grid; gap:22px; }
    .blog-back-btn { width:100%; }
    .blog-empty { text-align:center; }

    .page-shell { background: var(--paper); }
    .page-hero { background: var(--bg); color: var(--white); position:relative; overflow:hidden; }
    .page-hero::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at top right, rgba(226,97,237,.2), transparent 28%), radial-gradient(circle at bottom left, rgba(220,231,92,.15), transparent 26%); pointer-events:none; }
    .page-hero-sticker-scene { position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
    .page-hero-sticker { position:absolute; top:var(--sticker-top, 80%); left:var(--sticker-left, 50%); width:var(--sticker-size, 84px); height:var(--sticker-size, 84px); transform:translate(-50%, -50%) rotate(var(--sticker-rotate, 0deg)); opacity:var(--sticker-opacity, .92); display:block; filter: drop-shadow(0 16px 24px rgba(0,0,0,.18)); }
    .page-hero-sticker .hero-logo-sticker-disc { width:100%; height:100%; display:grid; place-items:center; border:0; border-radius:0; background:transparent; box-shadow:none; }
    .page-hero-sticker img { width:100%; height:100%; object-fit:contain; display:block; background:transparent; }
    .page-hero-grid { position:relative; z-index:1; display:grid; grid-template-columns: minmax(0, 1fr) minmax(360px, 520px); gap: clamp(24px, 3vw, 44px); align-items:center; padding: 22px 0 28px; }
    .page-hero-grid > div:first-child { max-width: 660px; }
    .page-hero-simple .container { position:relative; z-index:1; padding: 34px 0 42px; }
    .page-hero .eyebrow { margin-bottom: 10px; }
    .page-hero h1 { font-size: clamp(34px, 4.6vw, 56px); margin: 0 0 14px; max-width: 14ch; line-height: .98; letter-spacing: .004em; text-wrap: balance; }
    .page-hero-copy { margin: 0; font-size: clamp(15px, 1.08vw, 17px); line-height:1.56; max-width: 52ch; color:#ececec; text-wrap: pretty; }
    .page-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top: 18px; }
    .page-actions-gradient .btn { background: linear-gradient(135deg, #e261ed 0%, #2451c4 100%); color:#fff; border:0; box-shadow: 0 14px 28px rgba(36,81,196,.24); }
    .page-actions-gradient .btn:hover { box-shadow: 0 18px 34px rgba(226,97,237,.2); }
    .page-hero-card { background: rgba(255,255,255,.08); border-radius: 36px; overflow:hidden; height: min(clamp(320px, 31vw, 390px), var(--hero-media-height, 390px)); min-height: min(320px, var(--hero-media-height, 390px)); box-shadow: var(--shadow); transition: transform .35s ease, box-shadow .35s ease; }
    .page-hero-card img { width:100%; height:100%; object-fit:var(--hero-media-fit, cover); object-position:var(--hero-media-pos-x, 50%) var(--hero-media-pos-y, 50%); display:block; }
    .page-id-52 .page-hero-card img { object-position:center top; }
    .page-id-52 .page-hero-grid { grid-template-columns: minmax(0, 1fr) minmax(320px, 480px); gap: clamp(24px, 3vw, 40px); padding: 24px 0 30px; }
    .page-id-52 .page-hero h1 { max-width: 12ch; font-size: clamp(32px, 4.2vw, 52px); line-height: .98; }
    .page-id-52 .page-hero-copy { max-width: 42ch; color: rgba(255,255,255,.88); }
    .page-id-52 .page-hero-card { background: rgba(255,255,255,.03); }
    .page-id-54 .page-hero h1 { max-width: 8ch; }
    .page-id-54 .page-hero-copy { max-width: 34ch; }
    .page-id-54 .page-hero-grid { grid-template-columns: minmax(0, 1fr) minmax(340px, 500px); gap: clamp(20px, 2.6vw, 36px); align-items:center; padding: 20px 0 24px; }
    .page-id-54 .page-hero-card {
      background: rgba(255,255,255,.04);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 18px;
    }
    .page-id-54 .page-hero-card img {
      width: 100%;
      height: 100%;
      object-fit: contain;
      object-position: center center;
      background: #111;
      border-radius: 24px;
    }
    .page-id-36 .page-hero { background:
      radial-gradient(circle at top right, rgba(226,97,237,.16), transparent 26%),
      radial-gradient(circle at bottom left, rgba(220,231,92,.12), transparent 22%),
      linear-gradient(180deg, #050505 0%, #0e0e14 100%);
    }
    .page-id-36 .page-hero-grid { grid-template-columns: minmax(0, 1fr) minmax(360px, 500px); padding: 30px 0 36px; }
    .page-id-36 .page-hero-card { display:flex; align-items:center; justify-content:center; background: rgba(255,255,255,.05); }
    .page-id-36 .page-hero-card img { width:100%; height:100%; object-fit:cover; object-position:center 42%; background:#111; }
    .page-id-36 .page-hero h1 { font-size: clamp(36px, 5vw, 60px); max-width: 9ch; }
    .page-id-36 .page-hero-copy { max-width: 60ch; color: rgba(255,255,255,.88); }
    .page-id-36 .page-card-section .section-head { max-width: 980px; margin: 0 auto 24px; }
    .page-id-36 .page-card-section .section-head h2 { font-size: clamp(30px, 3.2vw, 46px); line-height: 1.08; letter-spacing: .01em; text-wrap: balance; }
    .page-hero-contact .page-hero-grid { grid-template-columns: 1fr; padding: 28px 0 36px; }
    .page-hero-contact h1 { max-width: none; }
    .page-hero-contact .page-hero-copy { max-width: 860px; }
    .page-hero-contact { background:
      radial-gradient(circle at top right, rgba(226,97,237,.16), transparent 28%),
      radial-gradient(circle at bottom left, rgba(220,231,92,.12), transparent 24%),
      linear-gradient(180deg, #050505 0%, #111 100%);
    }
    .page-hero-contact .page-hero-grid > div:first-child {
      width: 100%;
      box-sizing: border-box;
      max-width: 920px;
      margin: 0 auto;
      padding: 18px 22px;
      border-radius: 28px;
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.08);
      box-shadow: 0 20px 40px rgba(0,0,0,.18);
    }
    .page-stat-section { padding-top: 32px; }
    .stat-grid { display:grid; grid-template-columns: repeat(5, 1fr); gap:16px; }
    .stat-card { background:#fff; border-radius:24px; padding:20px; box-shadow: var(--shadow); font-weight:800; line-height:1.45; transition: transform .25s ease, box-shadow .25s ease; }
    .stat-card:hover { transform: translateY(-4px); box-shadow: 0 16px 28px rgba(0,0,0,.1); }
    .page-color-band { height: 22px; background: linear-gradient(90deg, var(--blue) 0 25%, var(--orange) 25% 50%, var(--pink) 50% 75%, var(--yellow) 75% 100%); border-top:2px solid rgba(0,0,0,.08); border-bottom:2px solid rgba(0,0,0,.08); }
    .page-card-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:22px; }
    .page-card-section-dark { background:#050505; }
    .page-card-section-dark .section-head h2,
    .page-card-section-dark .page-card h2,
    .page-card-section-dark .page-card p { color:#fff; }
    .page-card-section-dark .page-card { background:rgba(255,255,255,.07); box-shadow:none; border:1px solid rgba(255,255,255,.09); }
    .page-card-section .section-head,
    .video-section .section-head,
    .reason-section .section-head,
    .feature-line-section .section-head { margin-bottom: 16px; gap: 12px; }
    .page-card-section .section-head h2,
    .video-section .section-head h2,
    .reason-section .section-head h2 { font-size: clamp(28px, 3.5vw, 42px); line-height: 1.06; max-width: 15ch; }
    .page-card { display:grid; grid-template-rows:auto auto 1fr; gap:16px; align-content:start; min-height:100%; border-radius: 30px; transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease; }
    .page-card.panel.pad { padding: 24px; }
    .page-card.page-card-no-media { grid-template-rows: auto 1fr; padding-top: 30px; }
    .page-card.page-card-no-media::before { content:""; width:92px; height:8px; border-radius:999px; display:block; background: var(--yellow); margin-bottom: 4px; }
    .page-card-grid .page-card.page-card-no-media:nth-child(4n+1)::before { background: var(--yellow); }
    .page-card-grid .page-card.page-card-no-media:nth-child(4n+2)::before { background: var(--orange); }
    .page-card-grid .page-card.page-card-no-media:nth-child(4n+3)::before { background: var(--pink); }
    .page-card-grid .page-card.page-card-no-media:nth-child(4n+4)::before { background: var(--blue); }
    .page-card-media { width:100%; aspect-ratio: 16 / 10; min-height: 260px; border-radius: 22px; overflow:hidden; background:#fff; }
    .page-card-media img,
    .page-card .page-card-media img,
    .elementor .page-card-media img,
    .elementor .page-card .page-card-media img {
      width:100%;
      height:100% !important;
      max-width:none;
      object-fit:cover;
      object-position:center center;
      display:block;
    }
    .page-card-grid-carousel .page-card-media { background:transparent; }
    .page-card h2 { margin:0; font-size: clamp(21px, 1.75vw, 25px); line-height:1.02; text-wrap:balance; }
    .page-card p { margin:0; font-size:15.5px; line-height:1.62; color:#262626; }
    .page-card:hover { transform: translateY(-6px); box-shadow: 0 22px 38px rgba(17,17,17,.12); }
    .page-card-section-dark .page-card p { color:rgba(255,255,255,.9); }
    .page-card-section-dark .page-card:hover { box-shadow: 0 22px 42px rgba(0,0,0,.28); border-color: rgba(255,255,255,.18); }
    .section-head-single-line h2 { white-space:nowrap; }
    .page-card-grid-centered { max-width:1180px; margin:0 auto; justify-content:center; }
    .page-card-grid-featured-first .page-card:first-child { grid-column: span 2; }
    .page-card-grid-five-up { grid-template-columns: repeat(5, minmax(0, 1fr)); max-width: 100%; }
    .page-card-grid-five-up .page-card { gap:14px; padding:22px; }
    .page-card-grid-five-up .page-card h2 { font-size: 24px; }
    .page-card-grid-five-up .page-card p { font-size: 15px; line-height:1.55; }
    .page-card-grid-centered .page-card { max-width: none; }
    .page-card-carousel-wrap { position:relative; margin: 0; padding: 8px 64px 8px 18px; overflow:visible; background:transparent; box-shadow:none; border-radius:0; }
    .page-card-carousel-wrap::before,
    .page-card-carousel-wrap::after {
      content:"";
      position:absolute;
      top:0;
      bottom:0;
      width:48px;
      z-index:2;
      pointer-events:none;
    }
    .page-card-carousel-wrap::before {
      left:0;
      background: linear-gradient(90deg, var(--paper) 10%, rgba(248,246,243,0) 100%);
    }
    .page-card-carousel-wrap::after {
      right:0;
      background: linear-gradient(270deg, var(--paper) 10%, rgba(248,246,243,0) 100%);
    }
    .page-card-section-dark .page-card-carousel-wrap::before {
      background: linear-gradient(90deg, #050505 10%, rgba(5,5,5,0) 100%);
    }
    .page-card-section-dark .page-card-carousel-wrap::after {
      background: linear-gradient(270deg, #050505 10%, rgba(5,5,5,0) 100%);
    }
    .page-card-grid-carousel { display:flex; gap:22px; overflow-x:auto; overflow-y:hidden; padding: 6px 0 14px; scroll-snap-type:x proximity; scroll-padding-inline: 18px 64px; scrollbar-width:none; -ms-overflow-style:none; }
    .page-card-grid-carousel::-webkit-scrollbar { display:none; }
    .page-card-grid-carousel::after { content:""; flex:0 0 56px; }
    .page-card-grid-carousel .page-card { min-width: clamp(296px, 30vw, 348px); flex:0 0 clamp(296px, 30vw, 348px); scroll-snap-align:start; border-radius:28px; overflow:hidden; }
    .page-card-carousel-arrow { position:absolute; top:50%; transform:translateY(-50%); width:44px; height:44px; border:0; border-radius:999px; background: rgba(255,255,255,.96); color:#111; box-shadow: 0 14px 28px rgba(0,0,0,.16); display:grid; place-items:center; font-size:30px; line-height:1; cursor:pointer; z-index:3; transition: transform .2s ease, opacity .2s ease, background .2s ease; }
    .page-card-carousel-arrow:hover { background:#fff; }
    .page-card-carousel-arrow[disabled] { opacity:.35; cursor:default; }
    .page-card-carousel-prev { left:8px; }
    .page-card-carousel-next { right:8px; }
    .video-section { background: var(--paper); }
    .video-section-side .container { display:grid; grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr); gap:34px; align-items:start; }
    .video-section-side .section-head { display:grid; gap:16px; align-content:start; margin:0; }
    .video-section-side .video-preview-grid { margin-top:0; }
    .section-title-accent { color: var(--yellow); }
    .video-preview-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:22px; }
    .video-preview-card { overflow:hidden; border-radius:28px; background:#111; box-shadow: 0 18px 38px rgba(0,0,0,.12); transition: transform .28s ease, box-shadow .28s ease; }
    .video-preview-card:hover { transform: translateY(-6px); box-shadow: 0 24px 46px rgba(0,0,0,.18); }
    .video-preview-media { aspect-ratio: 9 / 17; background:#111; border-radius:20px; overflow:hidden; }
    .video-preview-media iframe,
    .video-preview-media img { width:100%; height:100%; object-fit:cover; }
    .video-preview-media iframe { border:0; display:block; }
    .page-id-36 .page-stat-section { padding-top: 26px; background:#050505; }
    .page-id-36 .stat-grid { gap:14px; }
    .page-id-36 .stat-card { border-radius: 22px; padding: 18px 18px 20px; }
    .page-id-36 .page-color-band { height: 18px; }
    .page-id-36 .video-section-side { background:#050505; color:#fff; }
    .page-id-36 .video-section-side .container { display:block; }
    .page-id-36 .video-section-side .section-head { max-width:780px; margin:0 auto 28px; text-align:center; gap:12px; }
    .page-id-36 .video-section-side .section-head h2 { font-size: clamp(28px, 3.2vw, 40px); line-height:1.04; max-width:14ch; margin:0 auto; color:#fff; text-wrap:balance; }
    .page-id-36 .video-section-side .section-head p { max-width:560px; margin:0 auto; font-size:16px; line-height:1.68; color:rgba(255,255,255,.78); }
    .page-id-36 .video-preview-grid { max-width:1020px; margin:0 auto; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:18px; align-items:start; }
    .page-id-36 .video-preview-card {
      padding:12px;
      border-radius:30px;
      background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
      border: 1px solid rgba(255,255,255,.08);
      box-shadow: 0 22px 50px rgba(0,0,0,.24);
      backdrop-filter: blur(8px);
    }
    .page-id-36 .video-preview-card:nth-child(3n+1) { transform: rotate(-.8deg) translateY(4px); }
    .page-id-36 .video-preview-card:nth-child(3n+2) { transform: translateY(-6px); }
    .page-id-36 .video-preview-card:nth-child(3n+3) { transform: rotate(.8deg) translateY(6px); }
    .page-id-36 .video-preview-media { aspect-ratio: 9 / 12.4; border-radius:24px; overflow:hidden; background:#0c0c0c; box-shadow: inset 0 0 0 1px rgba(255,255,255,.06); }
    .page-id-36 .video-preview-media iframe { background:#0c0c0c; }
    .page-id-36 .page-card-section.page-card-section-dark {
      background:
        radial-gradient(circle at top right, rgba(36,81,196,.18), transparent 26%),
        linear-gradient(180deg, #050505 0%, #0d0d11 100%);
    }
    .page-id-36 .page-card-grid-carousel .page-card {
      min-width: clamp(290px, 29vw, 340px);
      flex-basis: clamp(290px, 29vw, 340px);
    }
    .page-id-36 .page-card-section .section-head { max-width: 840px; margin: 0 auto 30px; text-align:center; }
    .page-id-36 .page-card-section .section-head > div { width:100%; }
    .page-id-36 .page-card-section .section-head h2 {
      max-width: none;
      font-size: clamp(30px, 3.6vw, 46px);
      line-height: 1.04;
      text-wrap: balance;
    }
    .page-id-36 .page-card-section .page-card {
      position: relative;
      padding-top: 26px;
      background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
      border: 1px solid rgba(255,255,255,.08);
    }
    .page-id-36 .page-card-section .page-card::before {
      content:"";
      width: 92px;
      height: 8px;
      border-radius: 999px;
      display:block;
      background: var(--yellow);
      margin-bottom: 8px;
    }
    .page-id-36 .page-card-section .page-card:nth-child(4n+1)::before { background: var(--yellow); }
    .page-id-36 .page-card-section .page-card:nth-child(4n+2)::before { background: var(--orange); }
    .page-id-36 .page-card-section .page-card:nth-child(4n+3)::before { background: var(--pink); }
    .page-id-36 .page-card-section .page-card:nth-child(4n+4)::before { background: var(--blue); }
    .page-id-36 .page-card-section .page-card h2 { font-size: clamp(21px, 1.8vw, 26px); line-height: 1.03; max-width: 12ch; }
    .page-id-36 .page-card-section .page-card p { font-size: 15px; line-height: 1.58; max-width: 28ch; }
    .page-id-36 .feature-line-section { background:#0f1015; }
    .page-id-36 .feature-line-stack { max-width: 980px; }
    .page-id-36 .feature-line-item { border-radius: 24px; border: 0; }
    .page-id-36 .feature-line-item:nth-child(3n+1) { background:#2451c4; }
    .page-id-36 .feature-line-item:nth-child(3n+2) { background:#fd603a; }
    .page-id-36 .feature-line-item:nth-child(3n+3) { background:#e261ed; }
    .page-id-36 .reason-section-light { background: var(--paper); }
    .page-id-36 .reason-section-light .reason-wrap {
      grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
      gap: 30px;
      align-items: center;
      background: #fff;
      border-radius: 32px;
      padding: 34px;
      box-shadow: var(--shadow);
    }
    .page-id-36 .reason-section-dark {
      background: radial-gradient(circle at top right, rgba(226,97,237,.16), transparent 28%), #050505;
    }
    .page-id-36 .reason-section-dark .reason-wrap {
      grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
      gap: 30px;
      align-items: center;
    }
    .page-id-36 .reason-wrap h2 {
      max-width: 9ch;
      font-size: clamp(30px, 4vw, 46px);
      line-height: 1.02;
      text-wrap: balance;
    }
    .page-id-36 .reason-list {
      max-width: none;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 16px;
    }
    .page-id-36 .reason-item {
      min-height: 92px;
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      padding: 18px 20px;
      border-radius: 24px;
      font-size: 16px;
      line-height: 1.35;
    }
    .page-id-36 .reason-list .reason-item:last-child:nth-child(odd) {
      grid-column: 1 / -1;
      max-width: 70%;
      justify-self: center;
    }
    .feature-line-section { background:#050505; }
    .feature-line-section-light { background: var(--paper); }
    .feature-line-stack { display:grid; gap:16px; max-width:780px; }
    .feature-line-item { padding:20px 24px; border-top:1px solid rgba(255,255,255,.18); color:#fff; font-size: clamp(20px, 2.4vw, 30px); font-weight:700; line-height:1.35; }
    .feature-line-item:last-child { border-bottom:1px solid rgba(255,255,255,.18); }
    .feature-line-section-centered .feature-line-stack { margin:0 auto; max-width:920px; }
    .feature-line-section-centered .feature-line-item { text-align:center; border:0; border-radius:24px; }
    .feature-line-section-centered .feature-line-item:nth-child(4n+1) { background:#2451c4; color:#fff; }
    .feature-line-section-centered .feature-line-item:nth-child(4n+2) { background:#fd603a; color:#fff; }
    .feature-line-section-centered .feature-line-item:nth-child(4n+3) { background:#e261ed; color:#fff; }
    .feature-line-section-centered .feature-line-item:nth-child(4n+4) { background:#dce75c; color:#111; }
    .page-copy { max-width: 900px; margin: 0 auto; border-radius: 30px; }
    .page-copy p { margin:0; font-size: 17px; line-height:1.72; }
    .page-body-split-section { background: var(--paper); }
    .page-body-split-section-dark { background: #050505; }
    .page-body-split-section-dark .page-body-split-copy h2,
    .page-body-split-section-dark .page-body-split-copy p { color: #fafafa; }
    .page-body-split-section-dark .page-body-split.panel { background: transparent; box-shadow: none; }
    .page-body-split-section-dark .page-body-split-media img { background: rgba(255,255,255,.06); box-shadow: 0 18px 38px rgba(0,0,0,.28); }
    .page-body-split { display:grid; grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr); gap:32px; align-items:center; border-radius: 32px; }
    .page-body-split-copy h2 { margin:0 0 12px; font-size: clamp(22px, 2.6vw, 32px); line-height:1.06; }
    .page-body-split-copy p { margin:0; font-size:16px; line-height:1.65; max-height: 18em; overflow-y: auto; }
    .page-body-split-media { border-radius: 28px; overflow:hidden; box-shadow: var(--shadow); max-height: 480px; }
    .page-body-split-media img { display:block; width:100%; height:100%; object-fit:cover; object-position: center top; }
    .reason-section { background: #050505; }
    .reason-section-light { background: var(--paper); }
    .reason-wrap { display:grid; grid-template-columns: .85fr 1.15fr; gap:24px; align-items:start; }
    .reason-wrap h2 { font-size: clamp(30px, 4vw, 50px); margin: 0; color:#fff; line-height:1.02; }
    .reason-wrap h2 span { color:var(--pink); }
    .reason-section-light .reason-wrap h2 { color:#111; }
    .reason-wrap-single { grid-template-columns: 1fr; justify-items:start; }
    .reason-wrap-single .reason-list { max-width:840px; }
    .reason-wrap-centered { justify-items:center; text-align:center; }
    .reason-wrap-centered .reason-list { margin:0 auto; max-width: 1120px; }
    .reason-wrap-centered .reason-item { text-align:center; }
    .reason-list { display:grid; gap:16px; max-width: 640px; }
    .reason-item { background:linear-gradient(135deg, #151515 0%, #262262 100%); color:#fff; border-radius:24px; padding:22px; line-height:1.6; transition: transform .25s ease, box-shadow .25s ease; box-shadow: 0 12px 26px rgba(21,21,21,.14); font-weight:800; }
    .reason-item:hover { transform: translateY(-4px); box-shadow: 0 18px 30px rgba(36,81,196,.18); }
    .reason-item:nth-child(1) { background:linear-gradient(135deg, var(--yellow) 0%, #f4f7b0 100%); color:#111; }
    .reason-item:nth-child(2) { background:linear-gradient(135deg, var(--pink) 0%, #f2b8f7 100%); color:#111; }
    .reason-item:nth-child(3) { background:linear-gradient(135deg, var(--orange) 0%, #ffb09d 100%); color:#111; }
    .reason-item:nth-child(4) { background:linear-gradient(135deg, var(--blue) 0%, #7da1ff 100%); color:#fff; }
    .reason-list-solid .reason-item:nth-child(4n+1) { background:#2451c4; color:#fff; }
    .reason-list-solid .reason-item:nth-child(4n+2) { background:#fd603a; color:#fff; }
    .reason-list-solid .reason-item:nth-child(4n+3) { background:#e261ed; color:#fff; }
    .reason-list-solid .reason-item:nth-child(4n+4) { background:#dce75c; color:#111; }
    .reason-section-light .reason-item { box-shadow: 0 14px 26px rgba(18,18,18,.08); }
    .page-id-110 .page-hero-card img { object-position: center 34%; }
    .page-id-110 .review-section { background: var(--paper); }
    .page-id-110 .review-section .section-head h2,
    .page-id-110 .review-section .section-head p,
    .page-id-110 .review-section .review-footnote a { color: #111; }
    .page-id-110 .review-grid { gap: 18px; }
    .page-id-110 .review-card {
      transform: none !important;
      background: #fff;
      color: #111;
      border-radius: 24px;
      padding: 22px;
      box-shadow: 0 14px 28px rgba(18,18,18,.08);
      border: 1px solid rgba(18,18,18,.06);
    }
    .page-id-110 .review-card h3 { font-size: 21px; line-height: 1.16; }
    .page-id-110 .review-card p { font-size: 15px; line-height: 1.58; }
    .page-id-38 .page-card-section,
    .page-id-40 .page-card-section,
    .page-id-42 .page-card-section,
    .page-id-44 .page-card-section,
    .page-id-46 .page-card-section { background: var(--paper); }
    .page-id-38 .page-card-grid-carousel .page-card,
    .page-id-40 .page-card-grid-carousel .page-card,
    .page-id-42 .page-card-grid-carousel .page-card,
    .page-id-44 .page-card-grid-carousel .page-card,
    .page-id-46 .page-card-grid-carousel .page-card { background:#fff; border:1px solid rgba(17,17,17,.06); box-shadow: 0 14px 30px rgba(17,17,17,.06); }
    .page-id-38 .page-card-grid-carousel .page-card-media,
    .page-id-40 .page-card-grid-carousel .page-card-media,
    .page-id-42 .page-card-grid-carousel .page-card-media,
    .page-id-44 .page-card-grid-carousel .page-card-media,
    .page-id-46 .page-card-grid-carousel .page-card-media { background:#fff; box-shadow:none; }
    .page-id-54 .page-hero-grid { padding: 18px 0 24px; }
    .page-id-54 .page-hero-copy { max-width: 30ch; }
    .page-id-56 .page-hero-grid { padding: 22px 0 28px; }
    .page-id-56 .contact-section { padding-top: calc(var(--section-pad) * .76); }
    .page-id-56 .contact-grid { gap: 18px; }
    .page-id-110 .page-hero-grid { padding: 20px 0 24px; }
    .page-id-110 .review-section { padding-top: calc(var(--section-pad) * .78); }
    .page-id-50 .blog-hero-grid { gap: 22px; padding: 18px 0 24px; }
    .page-id-34 .reason-section { background:#050505; }
    .page-id-34 .reason-wrap {
      grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
      gap: 32px;
      align-items: center;
      background: #fff;
      border-radius: 32px;
      padding: 34px;
      box-shadow: 0 26px 56px rgba(0,0,0,.26);
    }
    .page-id-34 .reason-wrap h2 {
      margin: 0;
      color: #111;
      font-size: clamp(30px, 4vw, 46px);
      line-height: 1.02;
      max-width: 10ch;
    }
    .page-id-34 .reason-wrap h2 span { color: var(--blue); }
    .page-id-34 .page-card-section { background: var(--paper); }
    .page-id-34 .page-card-section .section-head {
      align-items: start;
      gap: 14px;
      margin-bottom: 18px;
    }
    .page-id-34 .page-card-section .section-head h2 {
      max-width: 16ch;
    }
    .page-id-34 .page-card-section .section-head p {
      max-width: 58ch;
      font-size: 17px;
      line-height: 1.55;
      color: rgba(17,17,17,.72);
    }
    .page-id-34 .page-card-carousel-wrap {
      padding: 4px 64px 8px 18px;
      overflow: visible;
      background: transparent;
      box-shadow: none;
    }
    .page-id-34 .page-card-carousel-wrap::before,
    .page-id-34 .page-card-carousel-wrap::after { display:none; }
    .page-id-34 .page-card-carousel-arrow {
      display:grid;
      background: #111;
      color: #fff;
      box-shadow: 0 12px 28px rgba(0,0,0,.18);
    }
    .page-id-34 .page-card-carousel-arrow:hover {
      background: #000;
    }
    .page-id-34 .page-card-grid-carousel {
      display:flex;
      gap: 22px;
      overflow-x:auto;
      overflow-y:hidden;
      padding: 4px 0 14px;
      scroll-snap-type: x proximity;
      scroll-padding-inline: 18px 64px;
    }
    .page-id-34 .page-card-grid-carousel::after { content:""; flex:0 0 56px; }
    .page-id-34 .page-card-grid-carousel .page-card {
      min-width: clamp(296px, 30vw, 348px);
      flex: 0 0 clamp(296px, 30vw, 348px);
      background: #fff;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 32px rgba(17,17,17,.07);
      border-radius: 30px;
      padding: 24px 24px 22px;
      display:grid;
      grid-template-rows: auto 1fr;
      gap: 12px;
      position: relative;
      overflow: hidden;
      transition: transform .26s ease, box-shadow .26s ease, border-color .26s ease;
    }
    .page-id-34 .page-card-grid-carousel .page-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 22px 42px rgba(17,17,17,.1);
    }
    .page-id-34 .page-card-grid-carousel .page-card::before,
    .page-id-34 .page-card-grid-carousel .page-card::after {
      display: none;
    }
    .page-id-34 .page-card-grid-carousel .page-card-media { display:none; }
    .page-id-34 .page-card-grid-carousel .page-card h2 { font-size: clamp(22px, 2vw, 26px); line-height: 1.02; max-width: 12ch; margin:0; text-wrap: balance; }
    .page-id-34 .page-card-grid-carousel .page-card p { font-size: 15px; line-height: 1.58; max-width: 30ch; margin:0; color:#222; }
    .page-id-34 .page-card-grid-carousel .page-card h2,
    .page-id-34 .page-card-grid-carousel .page-card p {
      color: #111;
    }
    .page-id-52 .page-hero { background:#050505; }
    .page-id-52 .page-hero .eyebrow { background: var(--yellow); color:#111; }
    .page-id-52 .page-hero h1, .page-id-52 .page-hero .page-hero-copy { color:#fff; }
    .page-id-52 .page-card-section { background: var(--paper); }
    .page-id-52 .page-card-section.page-card-section-dark {
      background: var(--paper);
    }
    .page-id-52 .page-card-section.page-card-section-dark .container {
      background:#fff;
      border-radius:34px;
      box-shadow: 0 22px 48px rgba(0,0,0,.18);
      padding:34px;
    }
    .page-id-52 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-52 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-52 .page-card-section.page-card-section-dark .page-card p {
      color:#111;
    }
    .page-id-52 .page-card-section .section-head {
      max-width: 760px;
      margin: 0 auto 24px;
      text-align:center;
    }
    .page-id-52 .page-card-section .section-head > div { width:100%; }
    .page-id-52 .page-card-section .section-head h2 {
      color:#111;
      margin-inline:auto;
    }
    .page-id-52 .page-card-carousel-wrap {
      padding: 0;
      background: transparent;
      box-shadow: none;
    }
    .page-id-52 .page-card-carousel-wrap::before,
    .page-id-52 .page-card-carousel-wrap::after { display:none; }
    .page-id-52 .page-card-carousel-arrow { display:none; }
    .page-id-52 .page-card-grid-carousel {
      display:grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 22px;
      overflow: visible;
      padding: 0;
      scroll-snap-type: none;
    }
    .page-id-52 .page-card-grid-carousel::after { display:none; }
    .page-id-52 .page-card-grid-carousel .page-card {
      min-width: 0;
      flex: 1 1 auto;
      background:#fff;
      border:1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 32px rgba(17,17,17,.07);
      border-radius: 30px;
      padding: 24px 24px 22px;
      display:grid;
      grid-template-rows: auto 1fr;
      gap: 12px;
      position: relative;
      overflow: hidden;
      transition: transform .26s ease, box-shadow .26s ease, border-color .26s ease;
    }
    .page-id-52 .page-card-grid-carousel .page-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 22px 42px rgba(17,17,17,.1);
    }
    .page-id-52 .page-card-grid-carousel .page-card::before {
      content:"";
      width: 84px;
      height: 8px;
      border-radius: 999px;
      display:block;
      margin-bottom: 4px;
      background: var(--yellow);
    }
    .page-id-52 .page-card-grid-carousel .page-card::after {
      content: "";
      position: absolute;
      right: -18px;
      bottom: -18px;
      width: 82px;
      height: 82px;
      border-radius: 22px;
      background: rgba(17,17,17,.03);
      transform: rotate(18deg);
      pointer-events: none;
    }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+1)::before { background: var(--yellow); }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+2)::before { background: var(--orange); }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+3)::before { background: var(--pink); }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+4)::before { background: var(--blue); }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+1) { background: linear-gradient(180deg, #fffef4 0%, #fff 100%); }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+2) { background: linear-gradient(180deg, #fff8f3 0%, #fff 100%); }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+3) { background: linear-gradient(180deg, #fff8ff 0%, #fff 100%); }
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+4) { background: linear-gradient(180deg, #f8faff 0%, #fff 100%); }
    .page-id-52 .page-card-grid-carousel .page-card-media { display:none; }
    .page-id-52 .page-card-grid-carousel .page-card h2 {
      font-size: clamp(22px, 1.95vw, 26px);
      line-height: 1.02;
      max-width: 12ch;
      margin: 0;
    }
    .page-id-52 .page-card-grid-carousel .page-card p {
      font-size: 15px;
      line-height: 1.54;
      color: #222;
      max-width: 28ch;
      margin: 0;
    }
    .page-id-52 .page-body-split-section {
      background: #050505;
    }
    .page-id-52 .page-body-split-copy h2,
    .page-id-52 .page-body-split-copy p {
      color: #fff;
    }
    .page-id-52 .page-body-split-media .panel,
    .page-id-52 .page-body-split-media img {
      background: rgba(255,255,255,.06);
      box-shadow: 0 18px 38px rgba(0,0,0,.24);
    }
    .page-id-34 .reason-wrap-single { grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); justify-items:stretch; }
    .page-id-34 .reason-wrap-single .reason-list { max-width: none; }
    .page-id-34 .reason-list {
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }
    .page-id-34 .reason-item {
      border-radius: 22px;
      padding: 18px 20px;
      min-height: 112px;
      display: flex;
      align-items: center;
      font-size: 17px;
      line-height: 1.45;
      box-shadow: none;
    }
    .page-id-34 .reason-item:hover { transform: none; box-shadow: none; }
    .page-id-34 .elementor-element-orgreasonssec .page-card-section {
      background: #050505;
    }
    .page-id-34 .elementor-element-orgreasonssec .container {
      background:#fff;
      border-radius:34px;
      box-shadow: 0 22px 48px rgba(0,0,0,.18);
      padding:34px;
    }
    .page-id-34 .elementor-element-orgreasonssec .section-head {
      max-width: 760px;
      margin: 0 auto 24px;
      text-align: center;
    }
    .page-id-34 .elementor-element-orgreasonssec .section-head > div { width: 100%; }
    .page-id-34 .elementor-element-orgreasonssec .section-head h2 {
      color: #111;
      margin-inline: auto;
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 18px;
      max-width: 920px;
      margin: 0 auto;
      align-items: stretch;
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card {
      min-height: 152px;
      border-radius: 30px;
      padding: 24px 20px 22px;
      border: 0;
      box-shadow: none;
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      position: relative;
      overflow: hidden;
      transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 24px 42px rgba(0,0,0,.24);
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card h2 {
      color: #111;
      font-size: clamp(18px, 1.65vw, 22px);
      line-height: 1.02;
      max-width: 13ch;
      margin: 0;
      position: relative;
      z-index: 1;
      text-align: center;
      text-wrap: balance;
      letter-spacing: 0;
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card p {
      display: none;
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card::before {
      content: "";
      position: absolute;
      top: 20px;
      left: 22px;
      width: 86px;
      height: 7px;
      border-radius: 999px;
      transform: none;
      z-index: 1;
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(1) {
      background: #2451C4;
      transform: translateX(-8px);
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(2) {
      background: #FD603A;
      transform: translateX(8px);
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(3) {
      background: #E261ED;
      transform: translateX(8px);
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4) {
      background: #DCE75C;
      transform: translateX(-8px);
    }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(1) h2,
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(3) h2 { color:#fff; }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(2) h2,
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4) h2 { color:#111; }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(1)::before { background: var(--blue); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(2)::before { background: var(--orange); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(3)::before { background: var(--pink); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4)::before { background: var(--yellow); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(1):hover { transform: translateX(-8px) translateY(-4px); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(2):hover { transform: translateX(8px) translateY(-4px); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(3):hover { transform: translateX(8px) translateY(-4px); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4):hover { transform: translateX(-8px) translateY(-4px); }
    .contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap:22px; }
    .contact-grid p { line-height:1.65; }
    .contact-grid-form { align-items:start; }
    .contact-section { background: var(--paper); }
    .contact-section.contact-section-dark { background:#050505; }
    .contact-section.contact-section-dark .eyebrow,
    .contact-section.contact-section-dark .contact-form-panel h2 { color:#fff; }
    .contact-section.contact-section-dark .contact-info-panel,
    .contact-section.contact-section-dark .contact-form-panel { background:#fff; color:#111; border:1px solid rgba(18,18,18,.08); box-shadow: var(--shadow); }
    .contact-section.contact-section-dark .contact-info-item { background:#f7f2ea; }
    .contact-section.contact-section-dark .contact-info-item a,
    .contact-section.contact-section-dark .contact-info-item p,
    .contact-section.contact-section-dark .contact-map-link a { color:#111; }
    .contact-section.contact-section-dark .contact-info-label,
    .contact-section.contact-section-dark .contact-field span { color:#6d6762; }
    .contact-section.contact-section-dark .contact-field input,
    .contact-section.contact-section-dark .contact-field textarea { background:rgba(255,255,255,.96); color:#111; }
    .contact-info-panel,
    .contact-form-panel { border-radius: 32px; }
    .contact-info-list { display:grid; gap:14px; margin-top: 20px; }
    .contact-info-item { padding:16px 18px; border-radius:22px; background:#f7f2ea; }
    .contact-info-item a,
    .contact-info-item p { margin:6px 0 0; font-size:17px; line-height:1.6; }
    .contact-info-label { display:block; font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#6d6762; }
    .contact-map { margin-top: 22px; border-radius: 26px; overflow:hidden; box-shadow: var(--shadow); }
    .contact-map iframe { display:block; width:100%; height:260px; border:0; }
    .contact-map-link { margin:14px 0 0; font-weight:800; }
    .contact-form { display:grid; gap:16px; }
    .contact-field { display:grid; gap:8px; }
    .contact-field span { font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#6d6762; }
    .contact-field input,
    .contact-field textarea { width:100%; border:1px solid rgba(18,18,18,.12); border-radius:18px; background:#fcfaf6; color:#111; padding:16px 18px; font: inherit; }
    .contact-field textarea { resize: vertical; min-height: 150px; }
    .contact-field input:focus,
    .contact-field textarea:focus { outline:0; border-color: rgba(36,81,196,.45); box-shadow: 0 0 0 4px rgba(36,81,196,.08); }
    .contact-submit { width:100%; background: linear-gradient(135deg, #e261ed 0%, #2451c4 100%); border:0; color:#fff; }
    .contact-form-feedback { margin-bottom:16px; padding:14px 16px; border-radius:18px; font-weight:700; line-height:1.5; }
    .contact-form-feedback.is-success { background: rgba(220,231,92,.32); color:#111; }
    .contact-form-feedback.is-error { background: rgba(253,96,58,.14); color:#111; }
    .page-dark-btn { color:#111; border-color: rgba(0,0,0,.2); }
    .social-strip-section { padding-top: 0; }
    .social-strip { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
    .social-strip a { display:inline-flex; min-height:48px; align-items:center; justify-content:center; padding: 0 18px; background:#111; color:#fff; border-radius:999px; font-weight:800; }

    footer { background:#050505; color:#f2f2f2; padding: 40px 0 54px; }
    .footer-top { display:grid; gap:22px; }
    .footer-branding { display:grid; gap:16px; align-content:start; padding-top: 10px; }
    .footer-branding-lockup { display:grid; gap:14px; }
    .footer-badge-label { font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.72); }
    .footer-badge img { display:block; max-width:230px; height:auto; }
    .footer-grid { display:grid; grid-template-columns: 1.1fr .95fr .95fr .95fr; gap:42px; align-items:start; }
    .footer-column h4 { margin:0 0 14px; font-family: var(--font-display); font-size: clamp(18px, 2.2vw, 28px); line-height:1; color:#fff; }
    .footer-column p, .footer-column a, .footer-column span { margin:0; color:rgba(255,255,255,.86); line-height:1.6; font-size:14px; }
    .footer-links { display:grid; gap:10px; }
    .footer-links a { position:relative; padding-left:20px; }
    .footer-links a::before { content:"›"; position:absolute; left:0; top:0; color:#fff; font-size:20px; line-height:1.2; }
    .footer-legal-column { max-width:300px; }
    .footer-legal-stack { display:grid; gap:2px; }
    .footer-legal-title { display:block; margin-top:2px; font-size:17px; font-weight:800; line-height:1.45; color:#fff; }
    .footer-legal-text { font-size:15px; color:rgba(255,255,255,.9); line-height:1.55; }
    .footer-socials { display:flex; flex-wrap:wrap; gap:10px; }
    .footer-socials a { display:inline-flex; align-items:center; justify-content:center; min-height:44px; padding:0 16px; border-radius:999px; background: rgba(255,255,255,.08); }
    .footer-map { margin-top:18px; border-radius:24px; overflow:hidden; box-shadow: var(--shadow); }
    .footer-map iframe { display:block; width:100%; height:180px; border:0; filter: grayscale(.08) contrast(1.02); }
    .nav,
    .brand,
    .hero-wrap > *,
    .intro-grid > *,
    .testimonial-grid > *,
    .blog-hero-grid > *,
    .single-grid > *,
    .page-hero-grid > *,
    .reason-wrap > *,
    .contact-grid > *,
    .footer-grid > *,
    .slide-caption,
    .section-head > * { min-width: 0; }

    @media (max-width: 1080px) {
      .hero-wrap, .intro-grid, .testimonial-grid, .cta-box, .blog-hero-grid, .single-grid, .page-hero-grid, .reason-wrap { grid-template-columns: 1fr 1fr; }
      .cards { grid-template-columns: repeat(2, 1fr); }
      .page-card-grid, .review-grid, .stat-grid, .video-preview-grid, .page-card-grid-five-up { grid-template-columns: 1fr 1fr; }
      .blog-grid { grid-template-columns: 1fr 1fr; }
      .footer-grid { grid-template-columns: 1fr 1fr; gap:28px; }
      .service-showcase .service-card { flex-basis: 280px; }
      .video-section-side .container { grid-template-columns: 1fr; }
    }
    @media (max-width: 980px) {
      :root { --section-pad: 60px; }
      .container { width: min(var(--max), calc(100% - 20px)); }
      .site-header .nav { min-height: 54px; padding-top: 8px; padding-bottom: 6px; }
      .brand-badge { min-width: 46px; min-height: 46px; width:46px; height:46px; }
      .home .site-header {
        background: #f8f6f3 !important;
        border-bottom-color: rgba(17,17,17,.08) !important;
        box-shadow: 0 12px 28px rgba(17,17,17,.06) !important;
        backdrop-filter: blur(16px) !important;
      }
      .home .site-header.is-hero-top:not(.is-scrolled) {
        background: transparent !important;
        border-bottom-color: transparent !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
      }
      .home .site-header .nav {
        background: transparent !important;
        box-shadow: none !important;
      }
      .home .site-header .brand img { filter: none !important; }
      .home .site-header .nav { width: min(100%, calc(100% - 16px)); padding-top: 7px; padding-bottom: 5px; min-height: 52px; }
      .home .site-header .brand-badge { min-width: 44px; min-height: 44px; width:44px; height:44px; }
      .nav { align-items:center; flex-wrap:wrap; }
      .brand { flex:1; min-width:0; }
      .nav-toggle { display:inline-flex; }
      .home .site-header .nav-toggle { background:rgba(17,17,17,.06) !important; color:#111 !important; border:1px solid rgba(17,17,17,.1) !important; }
      .home .site-header.is-hero-top:not(.is-scrolled) .brand img { filter: brightness(0) invert(1) !important; }
      .home .site-header.is-hero-top:not(.is-scrolled) .nav-toggle { background:transparent !important; color:#fff !important; border:1px solid rgba(255,255,255,.18) !important; }
      .home .site-header.is-scrolled .nav-toggle { background:rgba(17,17,17,.06); color:#111; border-color:rgba(17,17,17,.1); }
      .nav-links { display:flex; width:100%; flex-direction:column; gap:0; padding:14px; border-radius:24px; background:rgba(255,255,255,.98); box-shadow: var(--shadow); max-height:0; overflow:hidden; opacity:0; visibility:hidden; pointer-events:none; transform: translateY(-10px) scale(.98); transition: opacity .25s ease, transform .25s ease, max-height .3s ease, visibility 0s .25s; }
      .nav-links.is-open { max-height:700px; overflow:visible; opacity:1; visibility:visible; pointer-events:auto; transform: translateY(0) scale(1); transition: opacity .25s ease, transform .25s ease, max-height .3s ease, visibility 0s 0s; }
      .nav-links .nav-links-list { width:100%; flex-direction:column; gap:0; font-size:13px; }
      .nav-links .nav-links-list > li { display:flex; flex-wrap:wrap; align-items:center; }
      .nav-links .nav-links-list > li > a,
      .nav-links a { display:block; flex:1 1 auto; min-height:0; padding:14px 4px; font-size:13px; letter-spacing:0; text-transform:none; border-bottom:1px solid rgba(0,0,0,.08); border-radius:0; }
      .nav-links .nav-links-list li:last-child a,
      .nav-links a:last-child { border-bottom:0; }
      .nav-links .is-current > a { background:transparent; color:#111; }
      .submenu-toggle { display:inline-flex; align-items:center; justify-content:center; margin-left:auto; }
      .nav-links .sub-menu { position:static; min-width:0; width:100%; padding:0 0 8px 12px; background:transparent; box-shadow:none; border-radius:0; opacity:1; visibility:visible; transform:none; display:none; }
      .nav-links .sub-menu li { width:100%; }
      .nav-links .sub-menu a { padding:10px 4px; border-bottom:1px solid rgba(0,0,0,.06); }
      .nav-links .menu-item-has-children.is-open > .sub-menu { display:block; }
      body.menu-open { overflow:hidden; }
      .hero-wrap, .intro-grid, .testimonial-grid, .cta-box, .cards, .footer-grid, .blog-hero-grid, .blog-grid, .single-grid, .page-hero-grid, .page-card-grid, .review-grid, .contact-grid, .reason-wrap, .stat-grid, .video-preview-grid, .page-card-grid-five-up, .page-body-split { grid-template-columns: 1fr; }
      .page-id-36 .video-preview-grid { grid-template-columns: 1fr; max-width:480px; }
      .intro-content-columns { grid-template-columns: 1fr; }
      .section-head-single-line h2 { white-space:normal; }
      .section-head-proof { grid-template-columns: 1fr; gap:20px; }
      .section-head-proof h2,
      .proof-copy { max-width: none; }
      .page-card-grid-featured-first .page-card:first-child { grid-column: span 1; }
      .slider { min-height: 340px; }
      .section-head { flex-direction:column; align-items:flex-start; }
      .hero-copy h1 { max-width: none; }
      .mini-grid { grid-template-columns: 1fr; }
      .cta-box .actions { justify-content:flex-start; }
      .blog-feature-media { min-height: 280px; }
      .intro-visual-panel { transform:none; }
      .slider-controls { left:16px; right:16px; }
      .service-showcase-arrow,
      .page-card-carousel-arrow { display:none; }
      .page-card-carousel-wrap::before,
      .page-card-carousel-wrap::after { display:none; }
      .service-showcase { gap: 14px; padding: 0 12px 10px 2px; scroll-padding-inline: 2px 12px; }
      .service-showcase .service-card { flex: 0 0 min(84vw, 284px); border-radius: 24px; }
      .service-showcase .service-card .media { height: 178px; padding: 12px 12px 0; }
      .service-showcase .service-card .media img { border-radius: 18px 18px 14px 14px; }
      .service-showcase .service-card .body { padding: 16px 16px 18px; gap: 10px; }
      .service-showcase .service-card h3 { font-size: 20px; }
      .service-showcase .service-card p { font-size: 14.5px; line-height: 1.54; }
      .home .service-showcase { gap: 12px; padding: 0 10px 8px 2px; scroll-padding-inline: 2px 10px; }
      .home .service-showcase .service-card { flex: 0 0 min(86vw, 276px); }
      .home .service-showcase .service-card .media { height: 170px; }
      .home .service-showcase .service-card h3 { font-size: 18px; line-height: 1.02; }
      .home .service-showcase .service-card p { font-size: 14px; line-height: 1.48; }
      .home .section-head { gap: 12px; margin-bottom: 20px; }
      .home .section-head h2 { font-size: clamp(26px, 8.4vw, 40px); max-width: 8ch; line-height: .98; }
      .page-card-carousel-wrap { padding: 0 0 0 2px; overflow: visible; }
      .page-card-grid-carousel { gap: 14px; padding: 6px 18px 10px 0; scroll-padding-inline: 2px 18px; }
      .page-card-grid-carousel::after { flex: 0 0 88px; }
      .page-card-grid-carousel .page-card { min-width: min(68vw, 244px); flex: 0 0 min(68vw, 244px); background:#fff; border:1px solid rgba(17,17,17,.06); box-shadow: 0 14px 28px rgba(0,0,0,.06); }
      .page-card-grid-carousel .page-card-media { background:#fff; }
      .page-card-grid-carousel .page-card-media img { background:#fff; }
      .page-card-section-dark .page-card-grid-carousel .page-card { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.1); box-shadow: 0 10px 28px rgba(0,0,0,.28); }
      .page-card-section-dark .page-card-grid-carousel .page-card-media { background:transparent; }
      .page-card-section-dark .page-card-grid-carousel .page-card-media img { background:transparent; }
      .page-card-grid-carousel .page-card h2 { font-size: clamp(18px, 5.4vw, 22px); line-height: 1.02; }
      .page-card-grid-carousel .page-card p { font-size: 14px; line-height: 1.5; }
      .support-scene {
        min-height: 352px;
        max-width: 450px;
        margin: 0 auto;
      }
      .support-person-card { width: 156px; height: 208px; }
      .support-person-left { left: -2px; top: 104px; }
      .support-person-right { right: -8px; bottom: 6px; }
      .support-chat-bubble { max-width: 200px; font-size: 15px; padding: 14px 16px; }
      .support-chat-type { min-height: 5.4em; }
      .support-chat-bubble-left { left: 86px; top: 8px; }
      .support-chat-bubble-right { left: 138px; top: 156px; }
      .home-proof-section .review-card:nth-child(n) { transform: none; }
      .home-proof-section .section-head-proof h2 { white-space: normal; font-size: clamp(24px, 8vw, 48px); }
      .slide-caption { left:16px; right:16px; flex-direction:column; align-items:flex-start; }
      .caption-box { max-width: 100%; }
      .dots { width:100%; justify-content:flex-start; }
      .hero-cta .btn,
      .page-actions .btn,
      .support-actions .btn,
      .cta-box .actions .btn { width:100%; max-width:100%; }
      .contact-map iframe { height:220px; }
      .blog-pagination { flex-wrap:wrap; gap:8px; }
      .blog-pagination .page-numbers { margin:0; }
      .page-hero-grid { gap: 8px; padding: 8px 0 12px; }
      .page-hero-grid > div:first-child { max-width: none; width: 100%; display:grid; justify-items:center; text-align:center; }
      .page-hero .eyebrow,
      .page-hero h1,
      .page-hero-copy { margin-inline:auto; text-align:center; }
      .page-actions { width:100%; justify-content:center; }
      .page-hero h1 { max-width: 12ch; font-size: clamp(23px, 7.6vw, 31px); line-height: .98; letter-spacing: -.015em; }
      .page-hero-copy { max-width: 30ch; font-size: 14px; line-height: 1.42; }
      .page-hero-card,
      .page-hero-media { display:none !important; }
      .page-hero-sticker { width: calc(var(--sticker-size, 84px) * .72); height: calc(var(--sticker-size, 84px) * .72); }
      .page-id-36 .page-hero-grid { grid-template-columns: 1fr !important; padding: 8px 0 12px; gap: 8px; }
      .page-id-36 .page-hero-grid > div:first-child { width: 100%; max-width: none; min-width: 0; }
      .page-id-36 .page-hero .eyebrow { white-space: nowrap; overflow-wrap: normal; word-break: keep-all; }
      .page-id-36 .page-hero h1 { max-width: 11ch; font-size: clamp(23px, 7.4vw, 31px); line-height: .98; text-wrap: balance; }
      .page-id-36 .page-hero-copy { max-width: 28ch; overflow-wrap: normal; word-break: normal; font-size: 14px; line-height: 1.38; }
      .page-id-36 .page-hero-card { display:none !important; }
      .page-id-36 .reason-section-light .reason-wrap,
      .page-id-36 .reason-section-dark .reason-wrap {
        grid-template-columns: 1fr;
        padding: 24px;
      }
      .page-id-36 .reason-wrap h2 {
        max-width: none;
        text-align: center;
      }
      .page-id-36 .reason-list {
        grid-template-columns: 1fr;
      }
      .page-id-36 .reason-list .reason-item:last-child:nth-child(odd) {
        grid-column: auto;
        max-width: none;
      }
      .page-id-36 .video-preview-card,
      .page-id-36 .video-preview-card:nth-child(3n+1),
      .page-id-36 .video-preview-card:nth-child(3n+2),
      .page-id-36 .video-preview-card:nth-child(3n+3) { transform:none; }
      .page-id-36 .page-card-section .section-head h2 { font-size: clamp(24px, 7.4vw, 34px); }
      .page-id-36 .page-card-section .page-card h2 { font-size: 20px; max-width:none; }
      .page-id-36 .page-card-section .page-card p { max-width:none; }
      .page-id-54 .page-hero-grid { grid-template-columns: 1fr !important; padding: 8px 0 12px; gap: 8px; }
      .page-id-54 .page-hero-grid > div:first-child { width: 100%; max-width: none; min-width: 0; }
      .page-id-54 .page-hero .eyebrow { white-space: nowrap; overflow-wrap: normal; word-break: keep-all; }
      .page-id-54 .page-hero h1 { max-width: 10ch; font-size: clamp(22px, 7vw, 29px); line-height: .98; text-wrap: balance; }
      .page-id-54 .page-hero-copy { max-width: 26ch; overflow-wrap: normal; word-break: normal; font-size: 13.5px; line-height: 1.38; }
      .page-id-54 .page-hero-card { display:none !important; }
      .page-id-54 .page-actions { gap: 10px; }
      .page-id-54 .page-actions .btn { min-height: 46px; font-size: 14px; padding: 0 14px; }
      .page-id-52 .page-hero-grid { padding: 8px 0 12px; gap: 8px; }
      .page-id-52 .page-hero h1 { max-width: 12ch; font-size: clamp(22px, 7.1vw, 30px); line-height: .98; text-wrap: balance; }
      .page-id-52 .page-hero-copy { max-width: 29ch; font-size: 13.5px; line-height: 1.38; }
      .page-id-52 .page-hero-card { display:none !important; }
      .page-id-52 .page-card-carousel-wrap {
        padding: 0 0 0 0;
      }
      .page-id-52 .page-card-grid-carousel {
        display:flex;
        gap: 14px;
        overflow-x:auto;
        overflow-y:hidden;
        padding: 4px 18px 10px 0;
        scroll-snap-type:x proximity;
        scroll-padding-inline: 0 18px;
      }
      .page-id-52 .page-card-grid-carousel::after { display:block; flex: 0 0 110px; content:""; }
      .page-id-52 .page-card-grid-carousel .page-card {
        min-width: min(76vw, 250px);
        flex: 0 0 min(76vw, 250px);
        padding: 22px 20px 20px;
      }
      .page-id-52 .page-card-section.page-card-section-dark .container {
        padding: 24px 18px;
        border-radius: 28px;
      }
      .page-id-52 .page-card-grid-carousel .page-card::after {
        width: 70px;
        height: 70px;
        right: -14px;
        bottom: -16px;
      }
      .page-id-52 .page-card-grid-carousel .page-card h2 { max-width: none; }
      .page-id-34 .page-hero-grid,
      .page-id-38 .page-hero-grid,
      .page-id-40 .page-hero-grid,
      .page-id-42 .page-hero-grid,
      .page-id-44 .page-hero-grid,
      .page-id-46 .page-hero-grid { padding: 8px 0 12px; gap: 8px; }
      .page-id-34 .page-hero h1,
      .page-id-38 .page-hero h1,
      .page-id-40 .page-hero h1,
      .page-id-42 .page-hero h1,
      .page-id-44 .page-hero h1,
      .page-id-46 .page-hero h1 { max-width: 11ch; font-size: clamp(22px, 7vw, 29px); line-height: .98; }
      .page-id-34 .page-hero-copy,
      .page-id-38 .page-hero-copy,
      .page-id-40 .page-hero-copy,
      .page-id-42 .page-hero-copy,
      .page-id-44 .page-hero-copy,
      .page-id-46 .page-hero-copy { max-width: 27ch; font-size: 13.5px; line-height: 1.38; }
      .page-id-34 .page-card-grid-carousel .page-card,
      .page-id-38 .page-card-grid-carousel .page-card,
      .page-id-40 .page-card-grid-carousel .page-card,
      .page-id-42 .page-card-grid-carousel .page-card,
      .page-id-44 .page-card-grid-carousel .page-card,
      .page-id-46 .page-card-grid-carousel .page-card { min-width: min(74vw, 252px); flex: 0 0 min(74vw, 252px); }
      .page-id-50 .blog-hero-grid,
      .page-id-56 .page-hero-grid,
      .page-id-110 .page-hero-grid { gap: 10px; padding: 10px 0 14px; }
      .page-id-110 .review-card { padding: 20px; }
      .page-id-34 .page-hero-card,
      .page-id-38 .page-hero-card,
      .page-id-40 .page-hero-card,
      .page-id-42 .page-hero-card,
      .page-id-44 .page-hero-card,
      .page-id-46 .page-hero-card { display:none !important; }
      .page-id-34 .page-hero-grid,
      .page-id-40 .page-hero-grid,
      .page-id-42 .page-hero-grid,
      .page-id-46 .page-hero-grid { padding: 8px 0 12px; gap: 8px; }
      .page-id-34 .page-hero h1,
      .page-id-40 .page-hero h1,
      .page-id-42 .page-hero h1,
      .page-id-46 .page-hero h1 { max-width: 11ch; font-size: clamp(21px, 6.9vw, 28px); line-height: .98; text-wrap: balance; }
      .page-id-34 .page-hero-copy,
      .page-id-40 .page-hero-copy,
      .page-id-42 .page-hero-copy,
      .page-id-46 .page-hero-copy { max-width: 27ch; font-size: 13.5px; line-height: 1.38; }
      .page-id-34 .page-hero-card,
      .page-id-40 .page-hero-card,
      .page-id-42 .page-hero-card,
      .page-id-46 .page-hero-card { display:none !important; }
      .page-id-40 .page-hero-grid { gap: 8px; }
      .page-id-40 .page-hero-copy { margin-bottom: 0; }
      .page-id-40 .page-hero-card { min-height: 144px; }
      .page-id-34 .page-hero .page-actions { gap: 8px; margin-top: 14px; }
      .page-id-34 .page-hero .page-actions .btn { min-height: 48px; padding: 0 18px; font-size: 15px; }
      .page-id-34 .page-hero-card { height: 150px; min-height: 0; max-height: 150px; }
      .page-id-34 .elementor-element-orgreasonssec .page-card-grid {
        grid-template-columns: 1fr;
        gap: 12px;
      }
      .page-id-34 .elementor-element-orgreasonssec .container {
        padding: 24px 18px;
        border-radius: 28px;
      }
      .page-id-34 .elementor-element-orgreasonssec .page-card {
        min-height: 98px;
        padding: 18px 18px;
        transform: none !important;
      }
      .page-id-34 .elementor-element-orgreasonssec .page-card h2 {
        font-size: 18px;
        max-width: none;
      }
      .page-hero-contact .page-hero-grid > div:first-child { padding: 10px 12px; border-radius: 24px; }
      .home .hero { min-height: auto; }
      .hero-centered-inner { padding: 30px 0 8px; min-height: 26svh; }
      .hero-sticker-wrap { max-width: min(100%, 92vw); }
      .hero-title-main { font-size: clamp(36px, 11.2vw, 52px); line-height: .94; letter-spacing: -.03em; padding: 0; max-width: none; width:100%; text-align:center; }
      .hero-logo-sticker { width: calc(var(--sticker-size, 92px) * .7); height: calc(var(--sticker-size, 92px) * .7); }
      .home .hero-sticker-wrap::after { display:none !important; content:none !important; }
      .home .hero-logo-sticker { display:none !important; }
      .home .title-sticker.sticker-1 { top: 4%; right: -1%; width: 60px; height: 60px; }
      .home .title-sticker.sticker-2 { left: 2%; bottom: 16%; width: 50px; height: 50px; }
      .home .title-sticker.sticker-3 { top: 54%; right: 12%; width: 44px; height: 44px; }
      .home .title-sticker.sticker-4 { left: 22%; bottom: -10%; width: 40px; height: 40px; }
      .hero-desc { font-size:13px; max-width:31ch; line-height:1.24; margin-top:0; padding:0 4px; }
      .hero-cta-centered .btn { width:100%; max-width:320px; }
      .home .story-strip { padding: 8px 0; font-size: 12px; }
      .cta-band { padding: 42px 0; }
      .hero-scroll-cue { display:none !important; }
      .hero-scroll-cue-icon,
      .hero-scroll-cue-icon svg { width:20px; height:20px; }
      .cta-box { padding: 24px 18px; border-radius: 28px; gap: 16px; }
      .cta-box h2 { font-size: clamp(28px, 9.2vw, 42px); margin: 0 0 8px; }
      .cta-box p { font-size: 15px; line-height: 1.5; max-width: none; }
      .cta-box .actions { width:100%; gap:10px; }
      .cta-box .actions .btn { width:100%; max-width:100%; min-height: 48px; padding: 0 18px; }
      .recensioni-banner { padding:22px 0; }
      .recensioni-banner-title { font-size:clamp(16px,5vw,26px); }
      .home .recensioni-banner-section { padding: 12px 0 6px; }
      .home .recensioni-banner { padding: 18px 18px 16px; border-radius: 24px; }
      .home .recensioni-banner::before { left: 18px; top: -10px; }
      .home .recensioni-banner-title { max-width: 10ch; font-size: clamp(18px, 6vw, 28px); }
      .home .recensioni-banner-arrow { width: 46px; height: 46px; font-size: 20px; }
      .home .cta-band { padding: 10px 0 24px; }
      .home .cta-box { padding: 24px 18px; border-radius: 28px; gap: 14px; }
      .home .cta-box h2 { margin-bottom: 8px; font-size: clamp(28px, 9vw, 42px); }
      .home .cta-box p { font-size: 15px; line-height: 1.46; }
      .home-intro-section .panel.pad,
      .testimonial .panel.pad,
      .support-card,
      .quote-card,
      .review-card,
      .support-note-card { padding: 22px; }
      .testimonial-grid,
      .review-grid { gap: 16px; }
      .testimonial-grid { grid-template-columns: 1fr; }
      .support-scene {
        min-height: 310px;
        max-width: 100%;
      }
      .support-person-card { width: 126px; height: 172px; border-radius: 22px; }
      .support-person-left { left: -2px; top: 120px; }
      .support-person-right { right: -8px; bottom: 6px; }
      .support-chat-bubble { max-width: 178px; font-size: 13px; line-height: 1.18; padding: 12px 14px; border-radius: 18px; }
      .support-chat-type { min-height: 5.2em; }
      .support-chat-bubble-left { left: 56px; top: 6px; }
      .support-chat-bubble-right { left: 106px; top: 136px; }
      .support-copy { text-align: center; }
      .support-copy .eyebrow,
      .support-title,
      .testimonial-copy,
      .support-copy-text { margin-inline: auto; text-align: center; }
      .support-actions { justify-content: center; }
      .support-note-card { margin: 18px auto 0; text-align: center; }
    }

    @media (prefers-reduced-motion: reduce) {
      html { scroll-behavior: auto; }
      .slide,
      .story-strip-track {
        animation: none !important;
      }
    }

    /* Founder editorial layout */
    .page-id-54 .page-hero {
      background: #050505;
      padding: 34px 0 14px;
    }
    .page-id-54 .page-hero-grid {
      max-width: 1180px;
      margin: 0 auto;
      grid-template-columns: minmax(320px, 490px) minmax(0, 1fr);
      gap: clamp(32px, 4.8vw, 72px);
      align-items: center;
      padding: 28px 0 8px;
    }
    .page-id-54 .page-hero-grid > div:first-child {
      order: 2;
      min-width: 0;
    }
    .page-id-54 .page-hero-card {
      order: 1;
      border-radius: 0;
      overflow: visible;
      background: transparent;
      box-shadow: none;
    }
    .page-id-54 .page-hero-card img {
      display: block;
      width: 100%;
      aspect-ratio: 0.82;
      object-fit: cover;
      object-position: center 18%;
      border-radius: 0;
      background: transparent;
      box-shadow: 0 26px 54px rgba(0,0,0,.28);
    }
    .page-id-54 .page-hero .eyebrow {
      background: transparent;
      color: rgba(255,255,255,.74);
      padding: 0;
      border-radius: 0;
      font-size: 15px;
      letter-spacing: .16em;
      text-transform: uppercase;
      font-weight: 800;
      margin: 0 0 22px;
    }
    .page-id-54 .page-hero h1 {
      max-width: none;
      margin: 0 0 22px;
      font-size: clamp(60px, 7.6vw, 104px);
      line-height: .9;
      letter-spacing: -.04em;
      text-wrap: initial;
    }
    .page-id-54 .page-hero-copy {
      max-width: 34ch;
      font-size: clamp(18px, 1.55vw, 24px);
      line-height: 1.5;
      color: rgba(255,255,255,.82);
    }
    .page-id-54 .elementor-widget-musica360_page_copy section {
      background: #050505;
      padding: 8px 0 84px;
    }
    .page-id-54 .elementor-widget-musica360_page_copy .container {
      max-width: 1180px;
    }
    .page-id-54 .page-copy {
      max-width: none;
      margin: 0 auto;
      background: transparent;
      box-shadow: none;
      border-radius: 0;
      padding: 0 0 0 calc(min(42vw, 490px) + clamp(32px, 4.8vw, 72px));
    }
    .page-id-54 .page-copy p {
      color: rgba(255,255,255,.8);
      font-size: clamp(18px, 1.42vw, 23px);
      line-height: 1.86;
      max-width: 42ch;
    }
    .page-id-54 .page-copy a {
      color: var(--yellow);
      font-weight: 800;
    }
    @media (max-width: 980px) {
      .page-id-54 .page-hero {
        padding: 24px 0 8px;
      }
      .page-id-54 .page-hero-grid {
        grid-template-columns: 1fr;
        justify-items: start;
        text-align: left;
        gap: 22px;
        padding: 18px 0 6px;
      }
      .page-id-54 .page-hero-grid > div:first-child,
      .page-id-54 .page-hero-card {
        order: initial;
      }
      .page-id-54 .page-hero-card {
        display: block !important;
        width: min(100%, 440px);
      }
      .page-id-54 .page-hero-card img {
        aspect-ratio: 0.82;
        border-radius: 24px;
      }
      .page-id-54 .page-hero .eyebrow,
      .page-id-54 .page-hero h1,
      .page-id-54 .page-hero-copy {
        margin-inline: 0;
        text-align: left;
      }
      .page-id-54 .page-hero h1 {
        max-width: 9ch;
        font-size: clamp(42px, 12vw, 62px);
        margin-bottom: 14px;
      }
      .page-id-54 .page-hero-copy {
        max-width: 30ch;
        font-size: 16px;
      }
      .page-id-54 .elementor-widget-musica360_page_copy section {
        padding: 4px 0 56px;
      }
      .page-id-54 .page-copy {
        padding: 0;
      }
      .page-id-54 .page-copy p {
        max-width: none;
        font-size: 16px;
        line-height: 1.72;
      }
    }

@media (max-width: 767px) {
      :root { --section-pad: 42px; }
      .container { width: min(var(--max), calc(100% - 16px)); }
      .site-header .nav { min-height: 50px; padding-top: 6px; padding-bottom: 5px; }
      .brand-badge { min-width: 42px; min-height: 42px; width:42px; height:42px; }
      .hero-centered-inner { padding: 24px 0 8px; min-height: 22svh; }
      .hero-title-main { font-size: clamp(32px, 10.5vw, 44px); line-height: .95; }
      .home .title-sticker.sticker-1 { top: 5%; right: 0; width: 48px; height: 48px; }
      .home .title-sticker.sticker-2 { left: 3%; bottom: 18%; width: 40px; height: 40px; }
      .home .title-sticker.sticker-3 { top: 56%; right: 10%; width: 34px; height: 34px; }
      .home .title-sticker.sticker-4 { left: 18%; bottom: -10%; width: 32px; height: 32px; }
      .hero-desc { max-width: 30ch; font-size: 12.5px; }
      .hero-scroll-cue { display:none !important; }
      .hero-scroll-cue-icon,
      .hero-scroll-cue-icon svg { width:18px; height:18px; }
      .page-hero h1 { font-size: clamp(22px, 8vw, 28px); }
      .page-hero-copy { font-size: 13.5px; line-height: 1.4; }
      .home .section-head { margin-bottom: 16px; }
      .home .service-showcase { padding-bottom: 4px; }
      .page-id-36 .page-hero-media,
      .page-id-54 .page-hero-media,
      .page-id-52 .page-hero-media { display: none; }
      .footer-column h4 { font-size: 16px; margin-bottom: 10px; }
      .footer-links { gap: 8px; }
      .footer-column p, .footer-column a, .footer-column span { font-size: 13px; }
}

/* Final normalization: page-card carousels like Musica per Matrimoni */
.page-id-34 .page-card-section,
.page-id-38 .page-card-section,
.page-id-40 .page-card-section,
.page-id-42 .page-card-section,
.page-id-44 .page-card-section,
.page-id-46 .page-card-section,
.page-id-52 .page-card-section {
    background: var(--paper);
}

.page-id-34 .page-card-section .section-head,
.page-id-38 .page-card-section .section-head,
.page-id-40 .page-card-section .section-head,
.page-id-42 .page-card-section .section-head,
.page-id-44 .page-card-section .section-head,
.page-id-46 .page-card-section .section-head,
.page-id-52 .page-card-section .section-head {
    max-width: 840px;
    margin: 0 auto 30px;
    text-align: center;
}

.page-id-34 .page-card-section .section-head > div,
.page-id-38 .page-card-section .section-head > div,
.page-id-40 .page-card-section .section-head > div,
.page-id-42 .page-card-section .section-head > div,
.page-id-44 .page-card-section .section-head > div,
.page-id-46 .page-card-section .section-head > div,
.page-id-52 .page-card-section .section-head > div {
    width: 100%;
}

.page-id-34 .page-card-section .section-head h2,
.page-id-38 .page-card-section .section-head h2,
.page-id-40 .page-card-section .section-head h2,
.page-id-42 .page-card-section .section-head h2,
.page-id-44 .page-card-section .section-head h2,
.page-id-46 .page-card-section .section-head h2,
.page-id-52 .page-card-section .section-head h2 {
    font-size: clamp(28px, 3.2vw, 40px);
    line-height: 1.04;
    max-width: 14ch;
    margin: 0 auto;
    text-wrap: balance;
    color: #111;
}

.page-id-34 .page-card-carousel-wrap,
.page-id-38 .page-card-carousel-wrap,
.page-id-40 .page-card-carousel-wrap,
.page-id-42 .page-card-carousel-wrap,
.page-id-44 .page-card-carousel-wrap,
.page-id-46 .page-card-carousel-wrap,
.page-id-52 .page-card-carousel-wrap {
    padding: 8px 56px 8px 12px;
    margin: 0;
    background: transparent;
    box-shadow: none;
    border-radius: 0;
}

.page-id-34 .page-card-carousel-wrap::before,
.page-id-34 .page-card-carousel-wrap::after,
.page-id-38 .page-card-carousel-wrap::before,
.page-id-38 .page-card-carousel-wrap::after,
.page-id-40 .page-card-carousel-wrap::before,
.page-id-40 .page-card-carousel-wrap::after,
.page-id-42 .page-card-carousel-wrap::before,
.page-id-42 .page-card-carousel-wrap::after,
.page-id-44 .page-card-carousel-wrap::before,
.page-id-44 .page-card-carousel-wrap::after,
.page-id-46 .page-card-carousel-wrap::before,
.page-id-46 .page-card-carousel-wrap::after,
.page-id-52 .page-card-carousel-wrap::before,
.page-id-52 .page-card-carousel-wrap::after {
    display: none;
}

.page-id-34 .page-card-grid-carousel,
.page-id-38 .page-card-grid-carousel,
.page-id-40 .page-card-grid-carousel,
.page-id-42 .page-card-grid-carousel,
.page-id-44 .page-card-grid-carousel,
.page-id-46 .page-card-grid-carousel,
.page-id-52 .page-card-grid-carousel {
    display: flex;
    gap: 18px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 6px 0 14px;
    scroll-snap-type: x proximity;
    scroll-padding-inline: 12px 56px;
}

.page-id-34 .page-card-grid-carousel::after,
.page-id-38 .page-card-grid-carousel::after,
.page-id-40 .page-card-grid-carousel::after,
.page-id-42 .page-card-grid-carousel::after,
.page-id-44 .page-card-grid-carousel::after,
.page-id-46 .page-card-grid-carousel::after,
.page-id-52 .page-card-grid-carousel::after {
    content: "";
    flex: 0 0 68px;
}

.page-id-34 .page-card-grid-carousel .page-card,
.page-id-38 .page-card-grid-carousel .page-card,
.page-id-40 .page-card-grid-carousel .page-card,
.page-id-42 .page-card-grid-carousel .page-card,
.page-id-44 .page-card-grid-carousel .page-card,
.page-id-46 .page-card-grid-carousel .page-card,
.page-id-52 .page-card-grid-carousel .page-card {
    position: relative;
    min-width: clamp(288px, 29vw, 340px);
    flex: 0 0 clamp(288px, 29vw, 340px);
    padding-top: 34px;
    border-radius: 28px;
    border: 1px solid rgba(17,17,17,.06);
    background: #fff;
    box-shadow: 0 18px 36px rgba(17,17,17,.07);
    overflow: hidden;
    scroll-snap-align: start;
}

.page-id-34 .page-card-grid-carousel .page-card::before,
.page-id-38 .page-card-grid-carousel .page-card::before,
.page-id-40 .page-card-grid-carousel .page-card::before,
.page-id-42 .page-card-grid-carousel .page-card::before,
.page-id-44 .page-card-grid-carousel .page-card::before,
.page-id-46 .page-card-grid-carousel .page-card::before,
.page-id-52 .page-card-grid-carousel .page-card::before {
    content: "";
    position: absolute;
    top: 18px;
    left: 22px;
    width: 58px;
    height: 7px;
    border-radius: 999px;
}

.page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
.page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
.page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
.page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
.page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
.page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
.page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+1)::before { background: var(--yellow); }

.page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
.page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
.page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
.page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
.page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
.page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
.page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+2)::before { background: var(--orange); }

.page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
.page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
.page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
.page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
.page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
.page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
.page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+3)::before { background: var(--pink); }

.page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
.page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
.page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
.page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
.page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
.page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
.page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+4)::before { background: var(--blue); }

.page-id-34 .page-card-grid-carousel .page-card-media,
.page-id-38 .page-card-grid-carousel .page-card-media,
.page-id-40 .page-card-grid-carousel .page-card-media,
.page-id-42 .page-card-grid-carousel .page-card-media,
.page-id-44 .page-card-grid-carousel .page-card-media,
.page-id-46 .page-card-grid-carousel .page-card-media,
.page-id-52 .page-card-grid-carousel .page-card-media {
    display: none;
}

.page-id-34 .page-card-grid-carousel .page-card h2,
.page-id-38 .page-card-grid-carousel .page-card h2,
.page-id-40 .page-card-grid-carousel .page-card h2,
.page-id-42 .page-card-grid-carousel .page-card h2,
.page-id-44 .page-card-grid-carousel .page-card h2,
.page-id-46 .page-card-grid-carousel .page-card h2,
.page-id-52 .page-card-grid-carousel .page-card h2 {
    font-size: clamp(21px, 1.8vw, 26px);
    line-height: 1.03;
    max-width: 12ch;
    margin: 0;
    color: #111;
}

.page-id-34 .page-card-grid-carousel .page-card p,
.page-id-38 .page-card-grid-carousel .page-card p,
.page-id-40 .page-card-grid-carousel .page-card p,
.page-id-42 .page-card-grid-carousel .page-card p,
.page-id-44 .page-card-grid-carousel .page-card p,
.page-id-46 .page-card-grid-carousel .page-card p,
.page-id-52 .page-card-grid-carousel .page-card p {
    margin: 0;
    max-width: 28ch;
    font-size: 15px;
    line-height: 1.58;
    color: #222;
}

.page-id-34 .page-card-grid-carousel .page-card:hover,
.page-id-38 .page-card-grid-carousel .page-card:hover,
.page-id-40 .page-card-grid-carousel .page-card:hover,
.page-id-42 .page-card-grid-carousel .page-card:hover,
.page-id-44 .page-card-grid-carousel .page-card:hover,
.page-id-46 .page-card-grid-carousel .page-card:hover,
.page-id-52 .page-card-grid-carousel .page-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 24px 44px rgba(17,17,17,.1);
}

    /* Tablets táctiles: submenús vía toggle en lugar de hover */
    @media (hover: none) and (pointer: coarse) {
      .submenu-toggle { display:inline-flex; align-items:center; justify-content:center; margin-left:auto; }
      .nav-links li:hover > .sub-menu { opacity:0; visibility:hidden; transform: translateY(10px); }
      .nav-links .sub-menu { position:static; min-width:0; width:100%; padding:0 0 8px 12px; background:transparent; box-shadow:none; border-radius:0; opacity:1; visibility:visible; transform:none; display:none; }
      .nav-links .sub-menu li { width:100%; }
      .nav-links .sub-menu a { padding:10px 4px; border-bottom:1px solid rgba(0,0,0,.06); }
      .nav-links .menu-item-has-children.is-open > .sub-menu { display:block; }
    }

    /* ======================================================
       SYSTEM NORMALIZATION LAYER
       Unifica header, heroes, cards y carruseles sin seguir
       sumando overrides aislados por página.
    ====================================================== */
    .page-id-34,
    .page-id-38,
    .page-id-40,
    .page-id-42,
    .page-id-44,
    .page-id-46,
    .page-id-52,
    .page-id-54,
    .page-id-56,
    .page-id-110 {
      --m360-hero-gap: clamp(24px, 3vw, 40px);
      --m360-hero-pad-y: 24px;
      --m360-hero-media-h: 380px;
      --m360-card-gap: 20px;
      --m360-card-min: clamp(300px, 30vw, 348px);
    }

    .page-id-34 .page-hero-grid,
    .page-id-38 .page-hero-grid,
    .page-id-40 .page-hero-grid,
    .page-id-42 .page-hero-grid,
    .page-id-44 .page-hero-grid,
    .page-id-46 .page-hero-grid,
    .page-id-52 .page-hero-grid,
    .page-id-54 .page-hero-grid,
    .page-id-110 .page-hero-grid {
      gap: var(--m360-hero-gap);
      padding: var(--m360-hero-pad-y) 0 calc(var(--m360-hero-pad-y) + 6px);
      align-items: center;
    }

    .page-id-34 .page-hero h1,
    .page-id-38 .page-hero h1,
    .page-id-40 .page-hero h1,
    .page-id-42 .page-hero h1,
    .page-id-44 .page-hero h1,
    .page-id-46 .page-hero h1,
    .page-id-52 .page-hero h1,
    .page-id-54 .page-hero h1,
    .page-id-110 .page-hero h1 {
      font-size: clamp(34px, 4.4vw, 54px);
      line-height: .98;
      max-width: 14ch;
      letter-spacing: 0;
      text-wrap: balance;
    }

    .page-id-34 .page-hero-copy,
    .page-id-38 .page-hero-copy,
    .page-id-40 .page-hero-copy,
    .page-id-42 .page-hero-copy,
    .page-id-44 .page-hero-copy,
    .page-id-46 .page-hero-copy,
    .page-id-52 .page-hero-copy,
    .page-id-54 .page-hero-copy,
    .page-id-110 .page-hero-copy {
      max-width: 34ch;
      font-size: 15px;
      line-height: 1.52;
    }

    .page-id-34 .page-hero-card,
    .page-id-38 .page-hero-card,
    .page-id-40 .page-hero-card,
    .page-id-42 .page-hero-card,
    .page-id-44 .page-hero-card,
    .page-id-46 .page-hero-card,
    .page-id-52 .page-hero-card,
    .page-id-54 .page-hero-card,
    .page-id-110 .page-hero-card {
      height: min(clamp(320px, 31vw, 390px), var(--m360-hero-media-h));
      min-height: min(320px, var(--m360-hero-media-h));
      border-radius: 32px;
      box-shadow: 0 18px 42px rgba(0,0,0,.18);
    }

    .page-id-34 .page-card-section,
    .page-id-38 .page-card-section,
    .page-id-40 .page-card-section,
    .page-id-42 .page-card-section,
    .page-id-44 .page-card-section,
    .page-id-46 .page-card-section,
    .page-id-52 .page-card-section {
      background: var(--paper);
    }

    .page-id-34 .page-card-carousel-wrap,
    .page-id-38 .page-card-carousel-wrap,
    .page-id-40 .page-card-carousel-wrap,
    .page-id-42 .page-card-carousel-wrap,
    .page-id-44 .page-card-carousel-wrap,
    .page-id-46 .page-card-carousel-wrap,
    .page-id-52 .page-card-carousel-wrap {
      padding: 0 22px 0 0;
      background: transparent;
      box-shadow: none;
    }

    .page-id-34 .page-card-carousel-wrap::before,
    .page-id-34 .page-card-carousel-wrap::after,
    .page-id-38 .page-card-carousel-wrap::before,
    .page-id-38 .page-card-carousel-wrap::after,
    .page-id-40 .page-card-carousel-wrap::before,
    .page-id-40 .page-card-carousel-wrap::after,
    .page-id-42 .page-card-carousel-wrap::before,
    .page-id-42 .page-card-carousel-wrap::after,
    .page-id-44 .page-card-carousel-wrap::before,
    .page-id-44 .page-card-carousel-wrap::after,
    .page-id-46 .page-card-carousel-wrap::before,
    .page-id-46 .page-card-carousel-wrap::after,
    .page-id-52 .page-card-carousel-wrap::before,
    .page-id-52 .page-card-carousel-wrap::after {
      display: none;
    }

    .page-id-34 .page-card-grid-carousel,
    .page-id-38 .page-card-grid-carousel,
    .page-id-40 .page-card-grid-carousel,
    .page-id-42 .page-card-grid-carousel,
    .page-id-44 .page-card-grid-carousel,
    .page-id-46 .page-card-grid-carousel,
    .page-id-52 .page-card-grid-carousel {
      gap: var(--m360-card-gap);
      padding: 2px 0 12px;
      scroll-padding-inline: 0 22px;
    }

    .page-id-34 .page-card-grid-carousel::after,
    .page-id-38 .page-card-grid-carousel::after,
    .page-id-40 .page-card-grid-carousel::after,
    .page-id-42 .page-card-grid-carousel::after,
    .page-id-44 .page-card-grid-carousel::after,
    .page-id-46 .page-card-grid-carousel::after,
    .page-id-52 .page-card-grid-carousel::after {
      flex: 0 0 64px;
    }

    .page-id-34 .page-card-grid-carousel .page-card,
    .page-id-38 .page-card-grid-carousel .page-card,
    .page-id-40 .page-card-grid-carousel .page-card,
    .page-id-42 .page-card-grid-carousel .page-card,
    .page-id-44 .page-card-grid-carousel .page-card,
    .page-id-46 .page-card-grid-carousel .page-card,
    .page-id-52 .page-card-grid-carousel .page-card {
      min-width: var(--m360-card-min);
      flex: 0 0 var(--m360-card-min);
      background: #fff;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 14px 30px rgba(17,17,17,.06);
      border-radius: 30px;
    }

    .page-id-34 .page-card-grid-carousel .page-card-media,
    .page-id-38 .page-card-grid-carousel .page-card-media,
    .page-id-40 .page-card-grid-carousel .page-card-media,
    .page-id-42 .page-card-grid-carousel .page-card-media,
    .page-id-44 .page-card-grid-carousel .page-card-media,
    .page-id-46 .page-card-grid-carousel .page-card-media,
    .page-id-52 .page-card-grid-carousel .page-card-media {
      background: #fff;
      box-shadow: none;
    }

    .page-id-34 .page-card-grid-carousel .page-card h2,
    .page-id-38 .page-card-grid-carousel .page-card h2,
    .page-id-40 .page-card-grid-carousel .page-card h2,
    .page-id-42 .page-card-grid-carousel .page-card h2,
    .page-id-44 .page-card-grid-carousel .page-card h2,
    .page-id-46 .page-card-grid-carousel .page-card h2,
    .page-id-52 .page-card-grid-carousel .page-card h2 {
      font-size: clamp(21px, 1.9vw, 26px);
      line-height: 1.03;
      max-width: 12ch;
    }

    .page-id-34 .page-card-grid-carousel .page-card p,
    .page-id-38 .page-card-grid-carousel .page-card p,
    .page-id-40 .page-card-grid-carousel .page-card p,
    .page-id-42 .page-card-grid-carousel .page-card p,
    .page-id-44 .page-card-grid-carousel .page-card p,
    .page-id-46 .page-card-grid-carousel .page-card p,
    .page-id-52 .page-card-grid-carousel .page-card p {
      font-size: 15px;
      line-height: 1.58;
      max-width: 30ch;
      color: #232323;
    }

    .page-id-34 .reason-section,
    .page-id-36 .reason-section-dark,
    .page-id-52 .page-body-split-section-dark,
    .page-id-56 .contact-section.contact-section-dark {
      background: #050505;
    }

    .page-id-34 .reason-wrap,
    .page-id-36 .reason-section-light .reason-wrap,
    .page-id-36 .reason-section-dark .reason-wrap,
    .page-id-56 .contact-info-panel,
    .page-id-56 .contact-form-panel {
      border-radius: 30px;
      box-shadow: 0 18px 42px rgba(0,0,0,.16);
    }

    @media (max-width: 980px) {
      .page-id-34,
      .page-id-38,
      .page-id-40,
      .page-id-42,
      .page-id-44,
      .page-id-46,
      .page-id-52,
      .page-id-54,
      .page-id-56,
      .page-id-110 {
        --m360-hero-pad-y: 10px;
        --m360-card-min: min(74vw, 252px);
      }

      .page-id-34 .page-hero-grid,
      .page-id-38 .page-hero-grid,
      .page-id-40 .page-hero-grid,
      .page-id-42 .page-hero-grid,
      .page-id-44 .page-hero-grid,
      .page-id-46 .page-hero-grid,
      .page-id-52 .page-hero-grid,
      .page-id-54 .page-hero-grid,
      .page-id-110 .page-hero-grid {
        grid-template-columns: 1fr !important;
        gap: 10px;
        padding: var(--m360-hero-pad-y) 0 14px;
      }

      .page-id-34 .page-hero-grid > div:first-child,
      .page-id-38 .page-hero-grid > div:first-child,
      .page-id-40 .page-hero-grid > div:first-child,
      .page-id-42 .page-hero-grid > div:first-child,
      .page-id-44 .page-hero-grid > div:first-child,
      .page-id-46 .page-hero-grid > div:first-child,
      .page-id-52 .page-hero-grid > div:first-child,
      .page-id-54 .page-hero-grid > div:first-child,
      .page-id-110 .page-hero-grid > div:first-child {
        width: 100%;
        max-width: none;
        min-width: 0;
        display: grid;
        justify-items: center;
        text-align: center;
      }

      .page-id-34 .page-hero h1,
      .page-id-38 .page-hero h1,
      .page-id-40 .page-hero h1,
      .page-id-42 .page-hero h1,
      .page-id-44 .page-hero h1,
      .page-id-46 .page-hero h1,
      .page-id-52 .page-hero h1,
      .page-id-54 .page-hero h1,
      .page-id-110 .page-hero h1 {
        max-width: 11ch;
        font-size: clamp(20px, 7vw, 29px);
        line-height: .97;
      }

      .page-id-34 .page-hero-copy,
      .page-id-38 .page-hero-copy,
      .page-id-40 .page-hero-copy,
      .page-id-42 .page-hero-copy,
      .page-id-44 .page-hero-copy,
      .page-id-46 .page-hero-copy,
      .page-id-52 .page-hero-copy,
      .page-id-54 .page-hero-copy,
      .page-id-110 .page-hero-copy {
        max-width: 29ch;
        font-size: 13px;
        line-height: 1.36;
        text-align: center;
      }

      .page-id-34 .page-hero-card,
      .page-id-38 .page-hero-card,
      .page-id-40 .page-hero-card,
      .page-id-42 .page-hero-card,
      .page-id-44 .page-hero-card,
      .page-id-46 .page-hero-card,
      .page-id-52 .page-hero-card,
      .page-id-54 .page-hero-card,
      .page-id-110 .page-hero-card {
        width: min(100%, 340px);
        margin-inline: auto;
        height: 156px;
        min-height: 0;
        max-height: 156px;
        border-radius: 28px;
      }

      .page-id-34 .page-card-carousel-wrap,
      .page-id-38 .page-card-carousel-wrap,
      .page-id-40 .page-card-carousel-wrap,
      .page-id-42 .page-card-carousel-wrap,
      .page-id-44 .page-card-carousel-wrap,
      .page-id-46 .page-card-carousel-wrap,
      .page-id-52 .page-card-carousel-wrap {
        padding: 0;
      }

      .page-id-34 .page-card-grid-carousel,
      .page-id-38 .page-card-grid-carousel,
      .page-id-40 .page-card-grid-carousel,
      .page-id-42 .page-card-grid-carousel,
      .page-id-44 .page-card-grid-carousel,
      .page-id-46 .page-card-grid-carousel,
      .page-id-52 .page-card-grid-carousel {
        display: flex;
        gap: 14px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px 18px 10px 0;
        scroll-snap-type: x proximity;
        scroll-padding-inline: 0 18px;
      }

      .page-id-34 .page-card-grid-carousel::after,
      .page-id-38 .page-card-grid-carousel::after,
      .page-id-40 .page-card-grid-carousel::after,
      .page-id-42 .page-card-grid-carousel::after,
      .page-id-44 .page-card-grid-carousel::after,
      .page-id-46 .page-card-grid-carousel::after,
      .page-id-52 .page-card-grid-carousel::after {
        display: block;
        flex: 0 0 108px;
        content: "";
      }
    }

    /* ======================================================
       EVENTI AZIENDALI TUNING
       Hero piu pulito, cards editoriali e spacing mas compacto.
    ====================================================== */
    .page-id-40 .page-hero-card {
      background:
        radial-gradient(circle at 78% 22%, rgba(226,97,237,.18), transparent 30%),
        radial-gradient(circle at 20% 78%, rgba(36,81,196,.14), transparent 34%),
        rgba(255,255,255,.04);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 18px;
    }

    .page-id-40 .page-hero-card img {
      width: 100%;
      height: 100%;
      object-fit: contain;
      object-position: center center;
      background: transparent;
      border-radius: 24px;
    }

    .page-id-40 .page-card-section .section-head {
      max-width: 760px;
      margin: 0 auto 22px;
      text-align: center;
    }

    .page-id-40 .page-card-section .section-head > div {
      width: 100%;
    }

    .page-id-40 .page-card-section .section-head h2 {
      margin-inline: auto;
      color: #111;
      max-width: 12ch;
    }

    .page-id-40 .page-card-carousel-wrap {
      padding: 0;
      overflow: visible;
      background: transparent;
      box-shadow: none;
    }

    .page-id-40 .page-card-carousel-wrap::before,
    .page-id-40 .page-card-carousel-wrap::after {
      display: none;
    }

    .page-id-40 .page-card-grid-carousel .page-card {
      background: #fff;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 34px rgba(17,17,17,.08);
      padding: 24px 24px 22px;
      display: grid;
      gap: 12px;
      position: relative;
      overflow: hidden;
      transition: transform .26s ease, box-shadow .26s ease;
    }

    .page-id-40 .page-card-grid-carousel .page-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 22px 42px rgba(17,17,17,.12);
    }

    .page-id-40 .page-card-grid-carousel .page-card::before {
      content: "";
      width: 84px;
      height: 8px;
      border-radius: 999px;
      display: block;
      margin-bottom: 4px;
      background: var(--yellow);
    }

    .page-id-40 .page-card-grid-carousel .page-card::after {
      content: "";
      position: absolute;
      right: -18px;
      bottom: -18px;
      width: 82px;
      height: 82px;
      border-radius: 22px;
      background: rgba(17,17,17,.03);
      transform: rotate(18deg);
      pointer-events: none;
    }

    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+1)::before { background: var(--yellow); }
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+2)::before { background: var(--orange); }
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+3)::before { background: var(--pink); }
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+4)::before { background: var(--blue); }
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+1) { background: linear-gradient(180deg, #fffef4 0%, #fff 100%); }
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+2) { background: linear-gradient(180deg, #fff8f3 0%, #fff 100%); }
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+3) { background: linear-gradient(180deg, #fff8ff 0%, #fff 100%); }
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+4) { background: linear-gradient(180deg, #f8faff 0%, #fff 100%); }

    .page-id-40 .page-card-grid-carousel .page-card h2,
    .page-id-40 .page-card-grid-carousel .page-card p {
      color: #111;
      margin: 0;
    }

    .page-id-40 .page-card-grid-carousel .page-card h2 {
      font-size: clamp(21px, 1.95vw, 26px);
      line-height: 1.03;
      max-width: 12ch;
    }

    .page-id-40 .page-card-grid-carousel .page-card p {
      font-size: 15px;
      line-height: 1.56;
      max-width: 28ch;
    }

    .page-id-40 .recensioni-banner-section {
      padding: calc(var(--section-pad) * .28) 0 0;
    }

    .page-id-40 .recensioni-banner {
      padding: 18px 28px;
      border-radius: 18px;
    }

    .page-id-40 .cta-band {
      padding: 40px 0;
    }

    .page-id-40 .cta-box {
      padding: 28px 30px;
      gap: 18px;
    }

    .page-id-40 .cta-box h2 {
      margin-bottom: 6px;
    }

    @media (max-width: 980px) {
      .page-id-40 .page-card-grid-carousel .page-card {
        padding: 22px 20px 20px;
      }

      .page-id-40 .recensioni-banner-section {
        padding-top: calc(var(--section-pad) * .22);
      }

      .page-id-40 .cta-band {
        padding: 34px 0;
      }

      .page-id-40 .cta-box {
        padding: 22px 18px;
      }
    }

    /* ======================================================
       ORGANIZZAZIONE - PERCHE SCEGLIERCI CLEANUP
       Sin caja blanca interna, cards claras sueltas sobre fondo dark.
    ====================================================== */
    .page-id-34 .elementor-element-orgreasonssec .page-card-section {
      background: #050505;
    }

    .page-id-34 .elementor-element-orgreasonssec .container {
      background: transparent;
      box-shadow: none;
      padding: 0;
      border-radius: 0;
    }

    .page-id-34 .elementor-element-orgreasonssec .section-head {
      display: block;
      max-width: 1080px;
      margin: 0 auto 24px;
      text-align: left;
    }

    .page-id-34 .elementor-element-orgreasonssec .section-head > div {
      width: 100%;
    }

    .page-id-34 .elementor-element-orgreasonssec .section-head h2 {
      margin: 0;
      max-width: 12ch;
      color: #fff;
      font-size: clamp(30px, 4.2vw, 48px);
      line-height: .98;
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 18px;
      max-width: 1080px;
      margin: 0 auto;
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card {
      min-height: 152px;
      padding: 22px 22px 20px;
      background: #fff;
      border: 0;
      border-radius: 28px;
      box-shadow: 0 16px 30px rgba(0,0,0,.16);
      transform: none !important;
      overflow: hidden;
      position: relative;
      transition: transform .24s ease, box-shadow .24s ease;
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card:hover {
      transform: translateY(-4px) !important;
      box-shadow: 0 20px 36px rgba(0,0,0,.22);
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card::before {
      display: none;
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card::after {
      display: none;
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4n+1) { background: var(--blue); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4n+2) { background: var(--orange); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4n+3) { background: var(--pink); }
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4n+4) { background: var(--yellow); }

    .page-id-34 .elementor-element-orgreasonssec .page-card h2 {
      color: #fff !important;
      font-size: clamp(20px, 1.8vw, 24px);
      line-height: 1.04;
      max-width: 12ch;
      margin: 0;
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4n+2) h2,
    .page-id-34 .elementor-element-orgreasonssec .page-card:nth-child(4n+4) h2 {
      color: #111 !important;
    }

    .page-id-34 .elementor-element-orgreasonssec .page-card p {
      display: none;
    }

    @media (max-width: 980px) {
      .page-id-34 .elementor-element-orgreasonssec .page-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
      }

      .page-id-34 .elementor-element-orgreasonssec .page-card {
        min-height: 124px;
        padding: 20px 18px 18px;
      }
    }

    @media (max-width: 767px) {
      .page-id-34 .elementor-element-orgreasonssec .section-head {
        text-align: left;
      }

      .page-id-34 .elementor-element-orgreasonssec .section-head h2 {
        font-size: clamp(26px, 8.4vw, 36px);
        max-width: 9ch;
      }

      .page-id-34 .elementor-element-orgreasonssec .page-card-grid {
        grid-template-columns: 1fr;
      }
    }

    /* ======================================================
       SERVICE SUBPAGES UNIFICATION
       Feste / Audio Luci / Allestimento / Backline
       Cards claras editoriales y spacing más parejo.
    ====================================================== */
    .page-id-38 .page-card-section.page-card-section-dark,
    .page-id-42 .page-card-section.page-card-section-dark,
    .page-id-44 .page-card-section.page-card-section-dark,
    .page-id-46 .page-card-section.page-card-section-dark {
      background: var(--paper);
    }

    .page-id-38 .page-card-section.page-card-section-dark .section-head,
    .page-id-42 .page-card-section.page-card-section-dark .section-head,
    .page-id-44 .page-card-section.page-card-section-dark .section-head,
    .page-id-46 .page-card-section.page-card-section-dark .section-head {
      max-width: 760px;
      margin: 0 auto 22px;
      text-align: center;
    }

    .page-id-38 .page-card-section.page-card-section-dark .section-head > div,
    .page-id-42 .page-card-section.page-card-section-dark .section-head > div,
    .page-id-44 .page-card-section.page-card-section-dark .section-head > div,
    .page-id-46 .page-card-section.page-card-section-dark .section-head > div {
      width: 100%;
    }

    .page-id-38 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-42 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-44 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-46 .page-card-section.page-card-section-dark .section-head h2 {
      margin-inline: auto;
      color: #111;
      max-width: 12ch;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-carousel-wrap,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-carousel-wrap,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-carousel-wrap,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-carousel-wrap {
      padding: 0;
      background: transparent;
      box-shadow: none;
      overflow: visible;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-38 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after {
      display: none;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card {
      background: #fff;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 34px rgba(17,17,17,.08);
      padding: 24px 24px 22px;
      position: relative;
      overflow: hidden;
      transition: transform .26s ease, box-shadow .26s ease;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:hover,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:hover,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:hover,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 22px 42px rgba(17,17,17,.12);
      border-color: rgba(17,17,17,.08);
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::before,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::before,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::before,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::before {
      content: "";
      width: 84px;
      height: 8px;
      border-radius: 999px;
      display: block;
      margin-bottom: 4px;
      background: var(--yellow);
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::after,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::after,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::after,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card::after {
      content: "";
      position: absolute;
      right: -18px;
      bottom: -18px;
      width: 82px;
      height: 82px;
      border-radius: 22px;
      background: rgba(17,17,17,.03);
      transform: rotate(18deg);
      pointer-events: none;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1)::before { background: var(--yellow); }
    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2)::before { background: var(--orange); }
    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3)::before { background: var(--pink); }
    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4)::before { background: var(--blue); }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1),
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1),
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1),
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+1) { background: linear-gradient(180deg, #fffef4 0%, #fff 100%); }
    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2),
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2),
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2),
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+2) { background: linear-gradient(180deg, #fff8f3 0%, #fff 100%); }
    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3),
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3),
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3),
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+3) { background: linear-gradient(180deg, #fff8ff 0%, #fff 100%); }
    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4),
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4),
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4),
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card:nth-child(4n+4) { background: linear-gradient(180deg, #f8faff 0%, #fff 100%); }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card h2,
    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card h2,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card h2,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card h2,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p {
      color: #111;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card p {
      max-width: 28ch;
    }

    .page-id-38 .recensioni-banner-section,
    .page-id-42 .recensioni-banner-section,
    .page-id-44 .recensioni-banner-section,
    .page-id-46 .recensioni-banner-section {
      padding-top: calc(var(--section-pad) * .28);
    }

    .page-id-38 .cta-band,
    .page-id-42 .cta-band,
    .page-id-44 .cta-band,
    .page-id-46 .cta-band {
      padding: 40px 0;
    }

    .page-id-38 .cta-box,
    .page-id-42 .cta-box,
    .page-id-44 .cta-box,
    .page-id-46 .cta-box {
      padding: 28px 30px;
      gap: 18px;
    }

    @media (max-width: 980px) {
      .page-id-38 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card,
      .page-id-42 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card,
      .page-id-44 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card,
      .page-id-46 .page-card-section.page-card-section-dark .page-card-grid-carousel .page-card {
        padding: 22px 20px 20px;
      }

      .page-id-38 .recensioni-banner-section,
      .page-id-42 .recensioni-banner-section,
      .page-id-44 .recensioni-banner-section,
      .page-id-46 .recensioni-banner-section {
        padding-top: calc(var(--section-pad) * .22);
      }

      .page-id-38 .cta-band,
      .page-id-42 .cta-band,
      .page-id-44 .cta-band,
      .page-id-46 .cta-band {
        padding: 34px 0;
      }

      .page-id-38 .cta-box,
      .page-id-42 .cta-box,
      .page-id-44 .cta-box,
      .page-id-46 .cta-box {
        padding: 22px 18px;
      }
    }

    /* ======================================================
       SERVICE SUBPAGES - FIRST CAROUSEL CLEANER
       Eventi Aziendali / Audio Luci / Allestimento / Backline
    ====================================================== */
    .page-id-40 .page-card-section .section-head,
    .page-id-42 .page-card-section .section-head,
    .page-id-44 .page-card-section .section-head,
    .page-id-46 .page-card-section .section-head {
      max-width: 820px;
      margin: 0 auto 24px;
      text-align: center;
    }

    .page-id-40 .page-card-section .section-head > div,
    .page-id-42 .page-card-section .section-head > div,
    .page-id-44 .page-card-section .section-head > div,
    .page-id-46 .page-card-section .section-head > div {
      width: 100%;
    }

    .page-id-40 .page-card-section .section-head h2,
    .page-id-42 .page-card-section .section-head h2,
    .page-id-44 .page-card-section .section-head h2,
    .page-id-46 .page-card-section .section-head h2 {
      margin-inline: auto;
      max-width: 13ch;
    }

    .page-id-40 .page-card-carousel-arrow,
    .page-id-42 .page-card-carousel-arrow,
    .page-id-44 .page-card-carousel-arrow,
    .page-id-46 .page-card-carousel-arrow {
      display: none;
    }

    .page-id-40 .page-card-carousel-wrap,
    .page-id-42 .page-card-carousel-wrap,
    .page-id-44 .page-card-carousel-wrap,
    .page-id-46 .page-card-carousel-wrap {
      padding: 0;
      overflow: visible;
    }

    .page-id-40 .page-card-grid-carousel,
    .page-id-42 .page-card-grid-carousel,
    .page-id-44 .page-card-grid-carousel,
    .page-id-46 .page-card-grid-carousel {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
      overflow: visible;
      padding: 0;
      scroll-snap-type: none;
    }

    .page-id-40 .page-card-grid-carousel::after,
    .page-id-42 .page-card-grid-carousel::after,
    .page-id-44 .page-card-grid-carousel::after,
    .page-id-46 .page-card-grid-carousel::after {
      display: none;
    }

    .page-id-40 .page-card-grid-carousel .page-card,
    .page-id-42 .page-card-grid-carousel .page-card,
    .page-id-44 .page-card-grid-carousel .page-card,
    .page-id-46 .page-card-grid-carousel .page-card {
      min-width: 0;
      flex: 1 1 auto;
      min-height: 188px;
      gap: 12px;
    }

    .page-id-40 .page-card-grid-carousel .page-card h2,
    .page-id-42 .page-card-grid-carousel .page-card h2,
    .page-id-44 .page-card-grid-carousel .page-card h2,
    .page-id-46 .page-card-grid-carousel .page-card h2 {
      max-width: 11ch;
      font-size: clamp(20px, 1.9vw, 24px);
      line-height: 1.04;
    }

    .page-id-40 .page-card-grid-carousel .page-card p,
    .page-id-42 .page-card-grid-carousel .page-card p,
    .page-id-44 .page-card-grid-carousel .page-card p,
    .page-id-46 .page-card-grid-carousel .page-card p {
      max-width: 28ch;
      font-size: 14.5px;
      line-height: 1.54;
    }

    @media (max-width: 980px) {
      .page-id-40 .page-card-grid-carousel,
      .page-id-42 .page-card-grid-carousel,
      .page-id-44 .page-card-grid-carousel,
      .page-id-46 .page-card-grid-carousel {
        display: flex;
        gap: 14px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px 18px 10px 0;
        scroll-snap-type: x proximity;
        scroll-padding-inline: 0 18px;
      }

      .page-id-40 .page-card-grid-carousel::after,
      .page-id-42 .page-card-grid-carousel::after,
      .page-id-44 .page-card-grid-carousel::after,
      .page-id-46 .page-card-grid-carousel::after {
        display: block;
        flex: 0 0 108px;
        content: "";
      }

      .page-id-40 .page-card-grid-carousel .page-card,
      .page-id-42 .page-card-grid-carousel .page-card,
      .page-id-44 .page-card-grid-carousel .page-card,
      .page-id-46 .page-card-grid-carousel .page-card {
        min-width: min(74vw, 252px);
        flex: 0 0 min(74vw, 252px);
        min-height: 0;
      }
    }

    /* ======================================================
       CHI SIAMO REFRAME
       Mas cercano al home: fondo dark limpio + cards claras.
    ====================================================== */
    .page-id-52 .page-card-section.page-card-section-dark {
      background: var(--paper);
    }

    .page-id-52 .page-card-section.page-card-section-dark .container {
      background: transparent;
      box-shadow: none;
      padding: 0;
      border-radius: 0;
    }

    .page-id-52 .page-card-section.page-card-section-dark .section-head {
      max-width: 820px;
      margin: 0 auto 24px;
      text-align: center;
    }

    .page-id-52 .page-card-section.page-card-section-dark .section-head > div {
      width: 100%;
    }

    .page-id-52 .page-card-section.page-card-section-dark .section-head h2 {
      margin-inline: auto;
      color: #111;
      max-width: 12ch;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-carousel-wrap {
      padding: 0;
      overflow: visible;
      background: transparent;
      box-shadow: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-52 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after {
      display: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
      overflow: visible;
      padding: 0;
      scroll-snap-type: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel::after {
      display: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card {
      min-width: 0;
      flex: 1 1 auto;
      background: #fff;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 34px rgba(17,17,17,.08);
      border-radius: 30px;
      padding: 24px 24px 22px;
      display: grid;
      gap: 12px;
      position: relative;
      overflow: hidden;
      transition: transform .26s ease, box-shadow .26s ease;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 22px 42px rgba(17,17,17,.12);
      border-color: rgba(17,17,17,.08);
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card::before {
      content: "";
      width: 84px;
      height: 8px;
      border-radius: 999px;
      display: block;
      margin-bottom: 4px;
      background: var(--yellow);
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card::after {
      content: "";
      position: absolute;
      right: -18px;
      bottom: -18px;
      width: 82px;
      height: 82px;
      border-radius: 22px;
      background: rgba(17,17,17,.03);
      transform: rotate(18deg);
      pointer-events: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+1)::before { background: var(--yellow); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+2)::before { background: var(--orange); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+3)::before { background: var(--pink); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+4)::before { background: var(--blue); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+1) { background: linear-gradient(180deg, #fffef4 0%, #fff 100%); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+2) { background: linear-gradient(180deg, #fff8f3 0%, #fff 100%); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+3) { background: linear-gradient(180deg, #fff8ff 0%, #fff 100%); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+4) { background: linear-gradient(180deg, #f8faff 0%, #fff 100%); }

    .page-id-52 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-52 .page-card-section.page-card-section-dark .page-card p {
      color: #111;
      margin: 0;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card h2 {
      font-size: clamp(22px, 2vw, 26px);
      line-height: 1.04;
      max-width: 12ch;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card p {
      font-size: 15px;
      line-height: 1.56;
      max-width: 28ch;
    }

    @media (max-width: 980px) {
      .page-id-52 .page-card-section.page-card-section-dark .page-card-carousel-wrap {
        padding: 0;
      }

      .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel {
        display: flex;
        gap: 14px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px 18px 10px 0;
        scroll-snap-type: x proximity;
        scroll-padding-inline: 0 18px;
      }

      .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel::after {
        display: block;
        flex: 0 0 108px;
        content: "";
      }

      .page-id-52 .page-card-section.page-card-section-dark .page-card {
        min-width: min(76vw, 250px);
        flex: 0 0 min(76vw, 250px);
        padding: 22px 20px 20px;
      }
    }

    /* ======================================================
       CHI SIAMO - CLEAN REBUILD
       Hero correcto; cards claras tipo home; split final oscuro real.
    ====================================================== */
    .page-id-52 .page-card-section.page-card-section-dark {
      background: var(--paper);
      padding: 72px 0;
    }

    .page-id-52 .page-card-section.page-card-section-dark .section-head {
      max-width: 760px;
      margin: 0 0 24px;
      text-align: left;
    }

    .page-id-52 .page-card-section.page-card-section-dark .section-head > div {
      width: 100%;
    }

    .page-id-52 .page-card-section.page-card-section-dark .section-head h2 {
      margin: 0;
      max-width: 13ch;
      color: #111;
      text-align: left;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-carousel-wrap {
      overflow: visible;
      padding: 0;
      background: transparent;
      box-shadow: none;
    }

    .page-id-52 .page-card-carousel-arrow {
      display: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
      overflow: visible;
      padding: 0;
      scroll-snap-type: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel::after {
      display: none;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card {
      background: #fff;
      border: 1px solid rgba(17,17,17,.06);
      border-radius: 28px;
      box-shadow: 0 16px 34px rgba(17,17,17,.08);
      padding: 24px 24px 22px;
      gap: 12px;
      min-width: 0;
      min-height: 0;
      position: relative;
      overflow: hidden;
      transition: transform .24s ease, box-shadow .24s ease;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 22px 42px rgba(17,17,17,.12);
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card::before {
      content: "";
      width: 84px;
      height: 8px;
      border-radius: 999px;
      display: block;
      margin-bottom: 4px;
      background: var(--yellow);
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+1)::before { background: var(--yellow); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+2)::before { background: var(--orange); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+3)::before { background: var(--pink); }
    .page-id-52 .page-card-section.page-card-section-dark .page-card:nth-child(4n+4)::before { background: var(--blue); }

    .page-id-52 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-52 .page-card-section.page-card-section-dark .page-card p {
      color: #111;
      margin: 0;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card h2 {
      font-size: clamp(22px, 2vw, 26px);
      line-height: 1.04;
      max-width: 11ch;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card p {
      font-size: 15px;
      line-height: 1.56;
      max-width: 29ch;
    }

    .page-id-52 .page-card-section.page-card-section-dark .page-card-media {
      display: none;
    }

    .page-id-52 .page-body-split-section {
      background: #050505;
      padding: 72px 0;
    }

    .page-id-52 .page-body-split.panel,
    .page-id-52 .page-body-split-section .page-body-split.panel {
      background: transparent;
      box-shadow: none;
      padding: 0;
      border-radius: 0;
    }

    .page-id-52 .page-body-split {
      grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr);
      gap: 28px;
      align-items: center;
    }

    .page-id-52 .page-body-split-copy h2,
    .page-id-52 .page-body-split-copy p {
      color: #fff;
    }

    .page-id-52 .page-body-split-copy h2 {
      max-width: 14ch;
    }

    .page-id-52 .page-body-split-copy p {
      max-width: 46ch;
      color: rgba(255,255,255,.84);
    }

    .page-id-52 .page-body-split-media {
      border-radius: 28px;
      overflow: hidden;
      background: rgba(255,255,255,.04);
      box-shadow: 0 22px 44px rgba(0,0,0,.24);
    }

    .page-id-52 .page-body-split-media img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    @media (max-width: 980px) {
      .page-id-52 .page-card-section.page-card-section-dark {
        padding: 50px 0;
      }

      .page-id-52 .page-card-section.page-card-section-dark .section-head {
        margin: 0 0 18px;
      }

      .page-id-52 .page-card-section.page-card-section-dark .section-head,
      .page-id-52 .page-card-section.page-card-section-dark .section-head h2 {
        text-align: left;
      }

      .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel {
        display: flex;
        gap: 14px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px 18px 10px 0;
        scroll-snap-type: x proximity;
        scroll-padding-inline: 0 18px;
      }

      .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel::after {
        display: block;
        flex: 0 0 96px;
        content: "";
      }

      .page-id-52 .page-card-section.page-card-section-dark .page-card {
        min-width: min(78vw, 270px);
        flex: 0 0 min(78vw, 270px);
        padding: 22px 20px 20px;
      }

      .page-id-52 .page-body-split-section {
        padding: 50px 0;
      }

      .page-id-52 .page-body-split {
        grid-template-columns: 1fr;
        gap: 18px;
      }
    }

    /* ======================================================
       V2 SYSTEM NORMALIZATION
       Heroes internos + cards editoriales + alternancia clara/oscura
    ====================================================== */
    .page-id-34 .page-hero,
    .page-id-36 .page-hero,
    .page-id-38 .page-hero,
    .page-id-40 .page-hero,
    .page-id-42 .page-hero,
    .page-id-44 .page-hero,
    .page-id-46 .page-hero,
    .page-id-52 .page-hero,
    .page-id-54 .page-hero,
    .page-id-56 .page-hero {
      background: #050505;
    }

    .page-id-34 .page-hero-grid,
    .page-id-36 .page-hero-grid,
    .page-id-38 .page-hero-grid,
    .page-id-40 .page-hero-grid,
    .page-id-42 .page-hero-grid,
    .page-id-44 .page-hero-grid,
    .page-id-46 .page-hero-grid,
    .page-id-52 .page-hero-grid,
    .page-id-54 .page-hero-grid,
    .page-id-56 .page-hero-grid {
      grid-template-columns: minmax(0, 1fr) minmax(320px, 460px);
      gap: clamp(24px, 3vw, 38px);
      padding: 22px 0 28px;
      align-items: center;
    }

    .page-id-34 .page-hero h1,
    .page-id-36 .page-hero h1,
    .page-id-38 .page-hero h1,
    .page-id-40 .page-hero h1,
    .page-id-42 .page-hero h1,
    .page-id-44 .page-hero h1,
    .page-id-46 .page-hero h1,
    .page-id-52 .page-hero h1,
    .page-id-54 .page-hero h1,
    .page-id-56 .page-hero h1 {
      max-width: 14ch;
      margin: 0 0 14px;
      font-size: clamp(34px, 4.6vw, 56px);
      line-height: .98;
      letter-spacing: .004em;
      text-wrap: balance;
    }

    .page-id-34 .page-hero-copy,
    .page-id-36 .page-hero-copy,
    .page-id-38 .page-hero-copy,
    .page-id-40 .page-hero-copy,
    .page-id-42 .page-hero-copy,
    .page-id-44 .page-hero-copy,
    .page-id-46 .page-hero-copy,
    .page-id-52 .page-hero-copy,
    .page-id-54 .page-hero-copy,
    .page-id-56 .page-hero-copy {
      max-width: 44ch;
      color: rgba(255,255,255,.88);
      font-size: 15px;
      line-height: 1.52;
    }

    .page-id-34 .page-hero-card,
    .page-id-36 .page-hero-card,
    .page-id-38 .page-hero-card,
    .page-id-40 .page-hero-card,
    .page-id-42 .page-hero-card,
    .page-id-44 .page-hero-card,
    .page-id-46 .page-hero-card,
    .page-id-52 .page-hero-card,
    .page-id-54 .page-hero-card,
    .page-id-56 .page-hero-card {
      border-radius: 30px;
      overflow: hidden;
      background: rgba(255,255,255,.04);
      box-shadow: 0 22px 44px rgba(0,0,0,.22);
    }

    .page-id-34 .page-card-section,
    .page-id-36 .page-card-section,
    .page-id-38 .page-card-section,
    .page-id-40 .page-card-section,
    .page-id-42 .page-card-section,
    .page-id-44 .page-card-section,
    .page-id-46 .page-card-section,
    .page-id-52 .page-card-section,
    .page-id-54 .page-card-section,
    .page-id-56 .page-card-section {
      padding: 68px 0;
    }

    .page-id-34 .page-card-section .section-head,
    .page-id-36 .page-card-section .section-head,
    .page-id-38 .page-card-section .section-head,
    .page-id-40 .page-card-section .section-head,
    .page-id-42 .page-card-section .section-head,
    .page-id-44 .page-card-section .section-head,
    .page-id-46 .page-card-section .section-head,
    .page-id-52 .page-card-section .section-head,
    .page-id-54 .page-card-section .section-head,
    .page-id-56 .page-card-section .section-head {
      max-width: 820px;
      margin: 0 auto 18px;
      text-align: center;
      gap: 8px;
    }

    .page-id-34 .page-card-section .section-head > div,
    .page-id-36 .page-card-section .section-head > div,
    .page-id-38 .page-card-section .section-head > div,
    .page-id-40 .page-card-section .section-head > div,
    .page-id-42 .page-card-section .section-head > div,
    .page-id-44 .page-card-section .section-head > div,
    .page-id-46 .page-card-section .section-head > div,
    .page-id-52 .page-card-section .section-head > div,
    .page-id-54 .page-card-section .section-head > div,
    .page-id-56 .page-card-section .section-head > div {
      width: 100%;
    }

    .page-id-34 .page-card-section .section-head h2,
    .page-id-36 .page-card-section .section-head h2,
    .page-id-38 .page-card-section .section-head h2,
    .page-id-40 .page-card-section .section-head h2,
    .page-id-42 .page-card-section .section-head h2,
    .page-id-44 .page-card-section .section-head h2,
    .page-id-46 .page-card-section .section-head h2,
    .page-id-52 .page-card-section .section-head h2,
    .page-id-54 .page-card-section .section-head h2,
    .page-id-56 .page-card-section .section-head h2 {
      margin-inline: auto;
      max-width: 14ch;
      text-wrap: balance;
    }

    .page-id-34 .page-card-section .section-head p,
    .page-id-36 .page-card-section .section-head p,
    .page-id-38 .page-card-section .section-head p,
    .page-id-40 .page-card-section .section-head p,
    .page-id-42 .page-card-section .section-head p,
    .page-id-44 .page-card-section .section-head p,
    .page-id-46 .page-card-section .section-head p,
    .page-id-52 .page-card-section .section-head p,
    .page-id-54 .page-card-section .section-head p,
    .page-id-56 .page-card-section .section-head p {
      max-width: 56ch;
      margin: 0 auto;
      line-height: 1.56;
    }

    .page-id-34 .page-card-carousel-wrap,
    .page-id-38 .page-card-carousel-wrap,
    .page-id-40 .page-card-carousel-wrap,
    .page-id-42 .page-card-carousel-wrap,
    .page-id-44 .page-card-carousel-wrap,
    .page-id-46 .page-card-carousel-wrap,
    .page-id-52 .page-card-carousel-wrap {
      background: transparent;
      box-shadow: none;
      padding: 0;
      overflow: visible;
    }

    .page-id-34 .page-card-carousel-wrap::before,
    .page-id-34 .page-card-carousel-wrap::after,
    .page-id-38 .page-card-carousel-wrap::before,
    .page-id-38 .page-card-carousel-wrap::after,
    .page-id-40 .page-card-carousel-wrap::before,
    .page-id-40 .page-card-carousel-wrap::after,
    .page-id-42 .page-card-carousel-wrap::before,
    .page-id-42 .page-card-carousel-wrap::after,
    .page-id-44 .page-card-carousel-wrap::before,
    .page-id-44 .page-card-carousel-wrap::after,
    .page-id-46 .page-card-carousel-wrap::before,
    .page-id-46 .page-card-carousel-wrap::after,
    .page-id-52 .page-card-carousel-wrap::before,
    .page-id-52 .page-card-carousel-wrap::after {
      display: none;
    }

    .page-id-34 .page-card-grid-carousel .page-card,
    .page-id-38 .page-card-grid-carousel .page-card,
    .page-id-40 .page-card-grid-carousel .page-card,
    .page-id-42 .page-card-grid-carousel .page-card,
    .page-id-44 .page-card-grid-carousel .page-card,
    .page-id-46 .page-card-grid-carousel .page-card,
    .page-id-52 .page-card-grid-carousel .page-card {
      border-radius: 28px;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 34px rgba(17,17,17,.08);
      background: #fff;
      padding: 24px 24px 22px;
      gap: 12px;
      min-height: 0;
    }

    .page-id-34 .page-card-grid-carousel .page-card::before,
    .page-id-38 .page-card-grid-carousel .page-card::before,
    .page-id-40 .page-card-grid-carousel .page-card::before,
    .page-id-42 .page-card-grid-carousel .page-card::before,
    .page-id-44 .page-card-grid-carousel .page-card::before,
    .page-id-46 .page-card-grid-carousel .page-card::before,
    .page-id-52 .page-card-grid-carousel .page-card::before {
      content: "";
      width: 84px;
      height: 8px;
      border-radius: 999px;
      display: block;
      margin-bottom: 4px;
      background: var(--yellow);
    }

    .page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+1)::before,
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+1)::before { background: var(--yellow); }

    .page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+2)::before,
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+2)::before { background: var(--orange); }

    .page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+3)::before,
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+3)::before { background: var(--pink); }

    .page-id-34 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-38 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-40 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-42 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-44 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-46 .page-card-grid-carousel .page-card:nth-child(4n+4)::before,
    .page-id-52 .page-card-grid-carousel .page-card:nth-child(4n+4)::before { background: var(--blue); }

    .page-id-34 .page-card-grid-carousel .page-card h2,
    .page-id-38 .page-card-grid-carousel .page-card h2,
    .page-id-40 .page-card-grid-carousel .page-card h2,
    .page-id-42 .page-card-grid-carousel .page-card h2,
    .page-id-44 .page-card-grid-carousel .page-card h2,
    .page-id-46 .page-card-grid-carousel .page-card h2,
    .page-id-52 .page-card-grid-carousel .page-card h2 {
      color: #111;
      font-size: clamp(22px, 2vw, 26px);
      line-height: 1.04;
      max-width: 12ch;
      margin: 0;
    }

    .page-id-34 .page-card-grid-carousel .page-card p,
    .page-id-38 .page-card-grid-carousel .page-card p,
    .page-id-40 .page-card-grid-carousel .page-card p,
    .page-id-42 .page-card-grid-carousel .page-card p,
    .page-id-44 .page-card-grid-carousel .page-card p,
    .page-id-46 .page-card-grid-carousel .page-card p,
    .page-id-52 .page-card-grid-carousel .page-card p {
      color: #111;
      font-size: 15px;
      line-height: 1.56;
      max-width: 30ch;
      margin: 0;
    }

    .page-id-34 .page-card-grid-carousel .page-card-media,
    .page-id-38 .page-card-grid-carousel .page-card-media,
    .page-id-40 .page-card-grid-carousel .page-card-media,
    .page-id-42 .page-card-grid-carousel .page-card-media,
    .page-id-44 .page-card-grid-carousel .page-card-media,
    .page-id-46 .page-card-grid-carousel .page-card-media,
    .page-id-52 .page-card-grid-carousel .page-card-media {
      display: none;
    }

    .page-id-52 .page-body-split-section {
      background: #050505;
    }

    .page-id-52 .page-body-split-copy h2,
    .page-id-52 .page-body-split-copy p {
      color: #fff;
    }

    .page-id-34 .recensioni-banner-section,
    .page-id-36 .recensioni-banner-section,
    .page-id-38 .recensioni-banner-section,
    .page-id-40 .recensioni-banner-section,
    .page-id-42 .recensioni-banner-section,
    .page-id-44 .recensioni-banner-section,
    .page-id-46 .recensioni-banner-section,
    .page-id-52 .recensioni-banner-section,
    .page-id-54 .recensioni-banner-section,
    .page-id-56 .recensioni-banner-section {
      padding-top: calc(var(--section-pad) * .28);
    }

    .page-id-34 .cta-band,
    .page-id-36 .cta-band,
    .page-id-38 .cta-band,
    .page-id-40 .cta-band,
    .page-id-42 .cta-band,
    .page-id-44 .cta-band,
    .page-id-46 .cta-band,
    .page-id-52 .cta-band,
    .page-id-54 .cta-band,
    .page-id-56 .cta-band {
      padding: 40px 0;
    }

    .page-id-34 .cta-box,
    .page-id-36 .cta-box,
    .page-id-38 .cta-box,
    .page-id-40 .cta-box,
    .page-id-42 .cta-box,
    .page-id-44 .cta-box,
    .page-id-46 .cta-box,
    .page-id-52 .cta-box,
    .page-id-54 .cta-box,
    .page-id-56 .cta-box {
      padding: 28px 30px;
      gap: 16px;
    }

    @media (max-width: 980px) {
      .site-header .nav {
        min-height: 50px;
        padding-top: 6px;
        padding-bottom: 4px;
      }

      .page-id-34 .page-hero-grid,
      .page-id-36 .page-hero-grid,
      .page-id-38 .page-hero-grid,
      .page-id-40 .page-hero-grid,
      .page-id-42 .page-hero-grid,
      .page-id-44 .page-hero-grid,
      .page-id-46 .page-hero-grid,
      .page-id-52 .page-hero-grid,
      .page-id-54 .page-hero-grid,
      .page-id-56 .page-hero-grid {
        grid-template-columns: 1fr !important;
        justify-items: center;
        text-align: center;
        padding: 10px 0 14px;
        gap: 8px;
      }

      .page-id-34 .page-hero .eyebrow,
      .page-id-36 .page-hero .eyebrow,
      .page-id-38 .page-hero .eyebrow,
      .page-id-40 .page-hero .eyebrow,
      .page-id-42 .page-hero .eyebrow,
      .page-id-44 .page-hero .eyebrow,
      .page-id-46 .page-hero .eyebrow,
      .page-id-52 .page-hero .eyebrow,
      .page-id-54 .page-hero .eyebrow,
      .page-id-56 .page-hero .eyebrow {
        margin-inline: auto;
      }

      .page-id-34 .page-hero h1,
      .page-id-36 .page-hero h1,
      .page-id-38 .page-hero h1,
      .page-id-40 .page-hero h1,
      .page-id-42 .page-hero h1,
      .page-id-44 .page-hero h1,
      .page-id-46 .page-hero h1,
      .page-id-52 .page-hero h1,
      .page-id-54 .page-hero h1,
      .page-id-56 .page-hero h1 {
        margin: 0 auto 10px;
        max-width: 14ch;
        font-size: clamp(24px, 7.2vw, 34px);
      }

      .page-id-34 .page-hero-copy,
      .page-id-36 .page-hero-copy,
      .page-id-38 .page-hero-copy,
      .page-id-40 .page-hero-copy,
      .page-id-42 .page-hero-copy,
      .page-id-44 .page-hero-copy,
      .page-id-46 .page-hero-copy,
      .page-id-52 .page-hero-copy,
      .page-id-54 .page-hero-copy,
      .page-id-56 .page-hero-copy {
        max-width: 31ch;
        margin: 0 auto;
        font-size: 14px;
        line-height: 1.42;
      }

      .page-id-34 .page-hero-card,
      .page-id-36 .page-hero-card,
      .page-id-38 .page-hero-card,
      .page-id-40 .page-hero-card,
      .page-id-42 .page-hero-card,
      .page-id-44 .page-hero-card,
      .page-id-46 .page-hero-card,
      .page-id-52 .page-hero-card,
      .page-id-54 .page-hero-card,
      .page-id-56 .page-hero-card {
        display: none !important;
      }

      .page-id-34 .page-card-section,
      .page-id-36 .page-card-section,
      .page-id-38 .page-card-section,
      .page-id-40 .page-card-section,
      .page-id-42 .page-card-section,
      .page-id-44 .page-card-section,
      .page-id-46 .page-card-section,
      .page-id-52 .page-card-section,
      .page-id-54 .page-card-section,
      .page-id-56 .page-card-section {
        padding: 48px 0;
      }

      .page-id-34 .page-card-grid-carousel,
      .page-id-38 .page-card-grid-carousel,
      .page-id-40 .page-card-grid-carousel,
      .page-id-42 .page-card-grid-carousel,
      .page-id-44 .page-card-grid-carousel,
      .page-id-46 .page-card-grid-carousel,
      .page-id-52 .page-card-grid-carousel {
        display: flex !important;
        gap: 14px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px 18px 10px 0;
        scroll-snap-type: x proximity;
        scroll-padding-inline: 0 18px;
      }

      .page-id-34 .page-card-grid-carousel::after,
      .page-id-38 .page-card-grid-carousel::after,
      .page-id-40 .page-card-grid-carousel::after,
      .page-id-42 .page-card-grid-carousel::after,
      .page-id-44 .page-card-grid-carousel::after,
      .page-id-46 .page-card-grid-carousel::after,
      .page-id-52 .page-card-grid-carousel::after {
        display: block;
        flex: 0 0 92px;
        content: "";
      }

      .page-id-34 .page-card-grid-carousel .page-card,
      .page-id-38 .page-card-grid-carousel .page-card,
      .page-id-40 .page-card-grid-carousel .page-card,
      .page-id-42 .page-card-grid-carousel .page-card,
      .page-id-44 .page-card-grid-carousel .page-card,
      .page-id-46 .page-card-grid-carousel .page-card,
      .page-id-52 .page-card-grid-carousel .page-card {
        min-width: min(78vw, 270px);
        flex: 0 0 min(78vw, 270px);
        padding: 22px 20px 20px;
      }

      .page-id-34 .cta-band,
      .page-id-36 .cta-band,
      .page-id-38 .cta-band,
      .page-id-40 .cta-band,
      .page-id-42 .cta-band,
      .page-id-44 .cta-band,
      .page-id-46 .cta-band,
      .page-id-52 .cta-band,
      .page-id-54 .cta-band,
      .page-id-56 .cta-band {
        padding: 30px 0;
      }

      .page-id-34 .cta-box,
      .page-id-36 .cta-box,
      .page-id-38 .cta-box,
      .page-id-40 .cta-box,
      .page-id-42 .cta-box,
      .page-id-44 .cta-box,
      .page-id-46 .cta-box,
      .page-id-52 .cta-box,
      .page-id-54 .cta-box,
      .page-id-56 .cta-box {
        padding: 20px 18px;
      }
    }

    /* Founder v2: stronger editorial treatment */
    .page-id-54 .page-hero {
      background:
        radial-gradient(circle at 20% 14%, rgba(220,231,92,.08), transparent 18%),
        radial-gradient(circle at 88% 18%, rgba(226,97,237,.12), transparent 24%),
        #050505;
      padding: 48px 0 18px;
    }
    .page-id-54 .page-hero-grid {
      max-width: 1220px;
      grid-template-columns: minmax(340px, 500px) minmax(0, 560px);
      gap: clamp(36px, 5vw, 82px);
      align-items: center;
      padding: 30px 0 16px;
    }
    .page-id-54 .page-hero-grid > div:first-child {
      order: 2;
      max-width: 560px;
    }
    .page-id-54 .page-hero-card {
      order: 1;
      position: relative;
      display: block !important;
      padding: 18px;
      border-radius: 36px;
      background: linear-gradient(180deg, rgba(255,255,255,.07) 0%, rgba(255,255,255,.02) 100%);
      border: 1px solid rgba(255,255,255,.08);
      box-shadow: 0 28px 58px rgba(0,0,0,.28);
      overflow: visible;
    }
    .page-id-54 .page-hero-card::before {
      content: "";
      position: absolute;
      inset: -18px 24px 24px -18px;
      border-radius: 42px;
      background: linear-gradient(135deg, rgba(226,97,237,.18), rgba(36,81,196,.12));
      z-index: 0;
      filter: blur(2px);
    }
    .page-id-54 .page-hero-card img {
      position: relative;
      z-index: 1;
      width: 100%;
      aspect-ratio: 0.82;
      object-fit: cover;
      object-position: center 18%;
      border-radius: 24px;
      box-shadow: 0 26px 54px rgba(0,0,0,.24);
    }
    .page-id-54 .page-hero .eyebrow {
      display: inline-flex;
      align-items: center;
      min-height: 34px;
      padding: 0 14px;
      border-radius: 999px;
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.12);
      color: rgba(255,255,255,.84);
      margin: 0 0 18px;
      font-size: 12px;
      letter-spacing: .14em;
    }
    .page-id-54 .page-hero h1 {
      margin: 0 0 16px;
      font-size: clamp(66px, 8vw, 118px);
      line-height: .9;
      letter-spacing: -.045em;
      text-shadow: 0 10px 26px rgba(0,0,0,.22);
    }
    .page-id-54 .page-hero-copy {
      max-width: 32ch;
      font-size: clamp(18px, 1.7vw, 25px);
      line-height: 1.46;
      color: rgba(255,255,255,.86);
    }
    .page-id-54 .elementor-widget-musica360_page_copy section {
      background: #050505;
      padding: 10px 0 88px;
    }
    .page-id-54 .elementor-widget-musica360_page_copy .container {
      max-width: 1220px;
    }
    .page-id-54 .page-copy {
      position: relative;
      max-width: 620px;
      margin: 0 0 0 auto;
      padding: 30px 0 0 28px;
      background: transparent;
      box-shadow: none;
      border-radius: 0;
    }
    .page-id-54 .page-copy::before {
      content: "";
      position: absolute;
      left: 0;
      top: 20px;
      bottom: 4px;
      width: 2px;
      background: linear-gradient(180deg, rgba(220,231,92,.88), rgba(226,97,237,.42));
      border-radius: 999px;
    }
    .page-id-54 .page-copy p {
      max-width: 40ch;
      color: rgba(255,255,255,.82);
      font-size: clamp(18px, 1.46vw, 22px);
      line-height: 1.9;
    }

    @media (max-width: 980px) {
      .page-id-54 .page-hero {
        padding: 24px 0 10px;
      }
      .page-id-54 .page-hero-grid {
        grid-template-columns: 1fr !important;
        justify-items: center;
        text-align: center;
        gap: 18px;
        padding: 14px 0 10px;
      }
      .page-id-54 .page-hero-grid > div:first-child,
      .page-id-54 .page-hero-card {
        order: initial;
        max-width: 100%;
      }
      .page-id-54 .page-hero-card {
        width: min(100%, 360px);
        padding: 12px;
        border-radius: 28px;
      }
      .page-id-54 .page-hero-card::before {
        inset: -10px 14px 16px -10px;
        border-radius: 30px;
      }
      .page-id-54 .page-hero-card img {
        border-radius: 18px;
        aspect-ratio: 0.84;
      }
      .page-id-54 .page-hero .eyebrow,
      .page-id-54 .page-hero h1,
      .page-id-54 .page-hero-copy {
        text-align: center;
        margin-inline: auto;
      }
      .page-id-54 .page-hero .eyebrow {
        margin-bottom: 14px;
      }
      .page-id-54 .page-hero h1 {
        max-width: 9ch;
        margin-bottom: 12px;
        font-size: clamp(40px, 12vw, 62px);
      }
      .page-id-54 .page-hero-copy {
        max-width: 28ch;
        font-size: 16px;
        line-height: 1.48;
      }
      .page-id-54 .elementor-widget-musica360_page_copy section {
        padding: 8px 0 54px;
      }
      .page-id-54 .page-copy {
        max-width: none;
        margin: 0;
        padding: 18px 0 0;
      }
      .page-id-54 .page-copy::before {
        left: 50%;
        top: 0;
        bottom: auto;
        width: 64px;
        height: 2px;
        transform: translateX(-50%);
      }
      .page-id-54 .page-copy p {
        max-width: none;
        text-align: left;
        font-size: 16px;
        line-height: 1.76;
      }
    }

    @media (max-width: 980px) {
      .home .site-header,
      .home .site-header.is-scrolled,
      .home .site-header.is-hero-top:not(.is-scrolled) {
        min-height: 0;
      }

      .home .site-header .nav,
      .home .site-header.is-scrolled .nav,
      .home .site-header.is-hero-top:not(.is-scrolled) .nav {
        min-height: 50px !important;
        height: 50px;
        padding-top: 4px !important;
        padding-bottom: 4px !important;
        align-items: center;
      }

      .home .site-header .brand-badge,
      .home .site-header.is-scrolled .brand-badge,
      .home .site-header.is-hero-top:not(.is-scrolled) .brand-badge {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        min-height: 40px !important;
      }

    .home .site-header .nav-toggle,
    .home .site-header.is-scrolled .nav-toggle,
    .home .site-header.is-hero-top:not(.is-scrolled) .nav-toggle {
        width: 40px;
        height: 40px;
        border-radius: 12px;
      }
    }

    /* Final page rhythm corrections */
    .page-id-34 .reason-section-light {
      background: #050505;
    }

    .page-id-34 .reason-section-light .reason-wrap {
      background: transparent;
      box-shadow: none;
      border-radius: 0;
      padding: 0;
      grid-template-columns: 1fr;
      gap: 22px;
    }

    .page-id-34 .reason-section-light .reason-wrap h2 {
      color: #fff;
      max-width: 12ch;
      margin: 0 auto;
      text-align: center;
    }

    .page-id-34 .reason-section-light .reason-list {
      max-width: 1120px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 18px;
    }

    .page-id-34 .reason-section-light .reason-item {
      min-height: 156px;
      padding: 24px 20px;
      border-radius: 30px;
      border: 0;
      box-shadow: 0 20px 38px rgba(0,0,0,.2);
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      font-size: clamp(18px, 1.7vw, 22px);
      line-height: 1.02;
      text-wrap: balance;
    }

    .page-id-34 .reason-section-light .reason-item:nth-child(1) {
      background: var(--blue);
      color: #fff;
    }

    .page-id-34 .reason-section-light .reason-item:nth-child(2) {
      background: var(--orange);
      color: #111;
    }

    .page-id-34 .reason-section-light .reason-item:nth-child(3) {
      background: var(--pink);
      color: #fff;
    }

    .page-id-34 .reason-section-light .reason-item:nth-child(4) {
      background: var(--yellow);
      color: #111;
    }

    .page-id-34 .reason-section-light .reason-item:hover {
      transform: translateY(-4px);
      box-shadow: 0 24px 44px rgba(0,0,0,.24);
    }

    /* Organizzazione Eventi aligned to Musica per Matrimoni */
    .page-id-34 .page-card-section {
      background:
        radial-gradient(circle at top right, rgba(36,81,196,.18), transparent 26%),
        linear-gradient(180deg, #050505 0%, #0d0d11 100%);
    }
    .page-id-34 .page-card-section .section-head {
      max-width: 840px;
      margin: 0 auto 30px;
      text-align: center;
    }
    .page-id-34 .page-card-section .section-head > div { width: 100%; }
    .page-id-34 .page-card-section .section-head h2 {
      max-width: none;
      font-size: clamp(30px, 3.6vw, 46px);
      line-height: 1.04;
      text-wrap: balance;
      color: #fff;
    }
    .page-id-34 .page-card-section .page-card-grid-carousel .page-card {
      min-width: clamp(290px, 29vw, 340px);
      flex-basis: clamp(290px, 29vw, 340px);
      position: relative;
      padding-top: 26px;
      background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
      border: 1px solid rgba(255,255,255,.08);
      color: #fff;
    }
    .page-id-34 .page-card-section .page-card::before {
      content: "";
      width: 92px;
      height: 8px;
      border-radius: 999px;
      display: block;
      background: var(--yellow);
      margin-bottom: 8px;
    }
    .page-id-34 .page-card-section .page-card:nth-child(4n+1)::before { background: var(--yellow); }
    .page-id-34 .page-card-section .page-card:nth-child(4n+2)::before { background: var(--orange); }
    .page-id-34 .page-card-section .page-card:nth-child(4n+3)::before { background: var(--pink); }
    .page-id-34 .page-card-section .page-card:nth-child(4n+4)::before { background: var(--blue); }
    .page-id-34 .page-card-section .page-card h2 {
      font-size: clamp(21px, 1.8vw, 26px);
      line-height: 1.03;
      max-width: 12ch;
      color: #fff;
    }
    .page-id-34 .page-card-section .page-card p {
      font-size: 15px;
      line-height: 1.58;
      max-width: 28ch;
      color: rgba(255,255,255,.82);
    }
    .page-id-34 .page-card-section .page-card-media {
      display: none;
    }
    .page-id-34 .reason-section-light {
      background: radial-gradient(circle at top right, rgba(226,97,237,.16), transparent 28%), #050505;
      padding-top: 18px;
    }
    .page-id-34 .reason-section-light .reason-wrap {
      grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
      gap: 30px;
      align-items: center;
    }
    .page-id-34 .reason-section-light .reason-wrap h2 {
      max-width: 9ch;
      margin: 0;
      text-align: left;
      font-size: clamp(30px, 4vw, 46px);
      line-height: 1.02;
      text-wrap: balance;
      color: #fff;
    }
    .page-id-34 .reason-section-light .reason-list {
      max-width: none;
      margin: 0;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 16px;
    }
    .page-id-34 .reason-section-light .reason-item {
      min-height: 140px;
      padding: 22px 20px;
      border-radius: 28px;
      font-size: clamp(18px, 1.5vw, 21px);
    }

    @media (max-width: 980px) {
      .page-id-34 .page-card-section .section-head h2 {
        font-size: clamp(24px, 7.4vw, 34px);
      }
      .page-id-34 .page-card-section .page-card h2 {
        font-size: 20px;
        max-width: none;
      }
      .page-id-34 .page-card-section .page-card p {
        max-width: none;
      }
      .page-id-34 .reason-section-light .reason-wrap {
        grid-template-columns: 1fr;
        gap: 22px;
      }
      .page-id-34 .reason-section-light .reason-wrap h2 {
        max-width: 12ch;
        margin: 0 auto;
        text-align: center;
      }
      .page-id-34 .reason-section-light .reason-list {
        grid-template-columns: 1fr;
      }
      .page-id-34 .reason-section-light .reason-item {
        min-height: 0;
      }
    }

    /* Chi Siamo aligned to the same family */
    .page-id-52 .page-card-section.page-card-section-dark {
      background: var(--paper);
      padding: 68px 0;
    }
    .page-id-52 .page-card-section.page-card-section-dark .section-head {
      max-width: 820px;
      margin: 0 auto 28px;
      text-align: center;
    }
    .page-id-52 .page-card-section.page-card-section-dark .section-head > div { width: 100%; }
    .page-id-52 .page-card-section.page-card-section-dark .section-head h2 {
      max-width: none;
      margin: 0 auto;
      color: #111;
      font-size: clamp(30px, 3.6vw, 46px);
      line-height: 1.04;
      text-wrap: balance;
    }
    .page-id-52 .page-card-section.page-card-section-dark .page-card-carousel-wrap {
      overflow: visible;
      padding: 0;
      background: transparent;
      box-shadow: none;
    }
    .page-id-52 .page-card-carousel-arrow {
      display: flex;
    }
    .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel {
      gap: 18px;
    }
    .page-id-52 .page-card-section.page-card-section-dark .page-card {
      border-radius: 30px;
      padding: 24px 24px 22px;
      box-shadow: 0 16px 34px rgba(17,17,17,.08);
    }
    .page-id-52 .page-card-section.page-card-section-dark .page-card::before {
      width: 92px;
      height: 8px;
      margin-bottom: 8px;
    }
    .page-id-52 .page-card-section.page-card-section-dark .page-card h2 {
      max-width: 12ch;
      font-size: clamp(21px, 1.9vw, 26px);
      line-height: 1.03;
    }
    .page-id-52 .page-card-section.page-card-section-dark .page-card p {
      max-width: 29ch;
      font-size: 15px;
      line-height: 1.58;
    }
    .page-id-52 .page-body-split-section {
      background:
        radial-gradient(circle at top right, rgba(226,97,237,.16), transparent 24%),
        #050505;
      padding: 72px 0;
    }
    .page-id-52 .page-body-split {
      grid-template-columns: minmax(0, 1.02fr) minmax(290px, .98fr);
      gap: 30px;
      align-items: center;
    }
    .page-id-52 .page-body-split-copy h2 {
      max-width: 13ch;
      margin-bottom: 14px;
      font-size: clamp(30px, 3.4vw, 44px);
      line-height: 1.04;
    }
    .page-id-52 .page-body-split-copy p {
      max-width: 45ch;
      font-size: 17px;
      line-height: 1.72;
      color: rgba(255,255,255,.84);
    }
    .page-id-52 .page-body-split-media {
      border-radius: 32px;
      overflow: hidden;
      box-shadow: 0 24px 46px rgba(0,0,0,.24);
    }
    .page-id-52 .page-body-split-media img {
      object-position: center top;
    }

    @media (max-width: 980px) {
      .page-id-52 .page-card-section.page-card-section-dark {
        padding: 50px 0;
      }
      .page-id-52 .page-card-section.page-card-section-dark .section-head {
        margin: 0 0 18px;
        text-align: left;
      }
      .page-id-52 .page-card-section.page-card-section-dark .section-head h2 {
        margin: 0;
        font-size: clamp(24px, 7.2vw, 34px);
        text-align: left;
      }
      .page-id-52 .page-card-carousel-arrow {
        display: none;
      }
      .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel {
        display: flex;
        gap: 14px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px 18px 10px 0;
        scroll-snap-type: x proximity;
        scroll-padding-inline: 0 18px;
      }
      .page-id-52 .page-card-section.page-card-section-dark .page-card-grid-carousel::after {
        display: block;
        flex: 0 0 108px;
        content: "";
      }
      .page-id-52 .page-card-section.page-card-section-dark .page-card {
        min-width: min(76vw, 250px);
        flex: 0 0 min(76vw, 250px);
        padding: 22px 20px 20px;
      }
      .page-id-52 .page-body-split-section {
        padding: 50px 0;
      }
      .page-id-52 .page-body-split {
        grid-template-columns: 1fr;
        gap: 22px;
      }
      .page-id-52 .page-body-split-copy h2 {
        max-width: 12ch;
        font-size: clamp(26px, 7.6vw, 34px);
      }
      .page-id-52 .page-body-split-copy p {
        font-size: 15px;
        line-height: 1.66;
      }
    }

    .page-id-52 .elementor-element-chicardssec .page-card-section.page-card-section-dark {
      background: var(--paper);
    }

    .page-id-52 .elementor-element-chicardssec .section-head,
    .page-id-52 .elementor-element-chicardssec .section-head h2,
    .page-id-52 .elementor-element-chicardssec .section-head p {
      color: #111;
      text-align: center;
    }

    .page-id-52 .elementor-element-chicardssec .page-card-carousel-wrap {
      background: transparent;
      box-shadow: none;
      padding: 0;
      overflow: visible;
    }

    .page-id-52 .elementor-element-chicardssec .page-card-carousel-wrap::before,
    .page-id-52 .elementor-element-chicardssec .page-card-carousel-wrap::after,
    .page-id-52 .elementor-element-chicardssec .page-card-carousel-arrow {
      display: none;
    }

    .page-id-52 .elementor-element-chicardssec .page-card-grid-carousel .page-card {
      background: #fff;
      color: #111;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 34px rgba(17,17,17,.08);
    }

    .page-id-52 .elementor-element-chicardssec .page-card-grid-carousel .page-card h2,
    .page-id-52 .elementor-element-chicardssec .page-card-grid-carousel .page-card p {
      color: #111;
    }

    .page-id-52 .elementor-element-chicardssec .page-card-grid-carousel .page-card-media {
      display: none;
    }

    .page-id-38 .page-card-section.page-card-section-dark,
    .page-id-40 .page-card-section.page-card-section-dark,
    .page-id-42 .page-card-section.page-card-section-dark,
    .page-id-44 .page-card-section.page-card-section-dark,
    .page-id-46 .page-card-section.page-card-section-dark {
      background: #050505;
    }

    .page-id-38 .page-card-section.page-card-section-dark .section-head,
    .page-id-40 .page-card-section.page-card-section-dark .section-head,
    .page-id-42 .page-card-section.page-card-section-dark .section-head,
    .page-id-44 .page-card-section.page-card-section-dark .section-head,
    .page-id-46 .page-card-section.page-card-section-dark .section-head {
      text-align: center;
      margin-bottom: 20px;
    }

    .page-id-38 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-40 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-42 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-44 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-46 .page-card-section.page-card-section-dark .section-head h2,
    .page-id-38 .page-card-section.page-card-section-dark .section-head p,
    .page-id-40 .page-card-section.page-card-section-dark .section-head p,
    .page-id-42 .page-card-section.page-card-section-dark .section-head p,
    .page-id-44 .page-card-section.page-card-section-dark .section-head p,
    .page-id-46 .page-card-section.page-card-section-dark .section-head p {
      color: #fff;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-carousel-wrap,
    .page-id-40 .page-card-section.page-card-section-dark .page-card-carousel-wrap,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-carousel-wrap,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-carousel-wrap,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-carousel-wrap {
      background: transparent;
      box-shadow: none;
      padding: 0;
      overflow: visible;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-38 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after,
    .page-id-40 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-40 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-carousel-wrap::before,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-carousel-wrap::after {
      display: none;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card,
    .page-id-40 .page-card-section.page-card-section-dark .page-card,
    .page-id-42 .page-card-section.page-card-section-dark .page-card,
    .page-id-44 .page-card-section.page-card-section-dark .page-card,
    .page-id-46 .page-card-section.page-card-section-dark .page-card {
      background: #fff;
      color: #111;
      border: 1px solid rgba(17,17,17,.06);
      box-shadow: 0 16px 34px rgba(0,0,0,.14);
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-40 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-42 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-44 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-46 .page-card-section.page-card-section-dark .page-card h2,
    .page-id-38 .page-card-section.page-card-section-dark .page-card p,
    .page-id-40 .page-card-section.page-card-section-dark .page-card p,
    .page-id-42 .page-card-section.page-card-section-dark .page-card p,
    .page-id-44 .page-card-section.page-card-section-dark .page-card p,
    .page-id-46 .page-card-section.page-card-section-dark .page-card p {
      color: #111;
    }

    .page-id-38 .page-card-section.page-card-section-dark .page-card-media,
    .page-id-40 .page-card-section.page-card-section-dark .page-card-media,
    .page-id-42 .page-card-section.page-card-section-dark .page-card-media,
    .page-id-44 .page-card-section.page-card-section-dark .page-card-media,
    .page-id-46 .page-card-section.page-card-section-dark .page-card-media {
      display: none;
    }

    @media (max-width: 980px) {
      .page-id-34 .reason-section-light .reason-list {
        grid-template-columns: 1fr;
      }

      .page-id-34 .reason-section-light .reason-item {
        min-height: 126px;
        font-size: 18px;
      }
    }
