/* ========== FB BEAUTY CLINIC — CASE STUDY PAGE (LIGHT MODE) ========== */

@keyframes fb-float-1 { 0%,100% { transform: translate(0,0) rotate(-8deg); } 50% { transform: translate(8px,-16px) rotate(-4deg); } }
@keyframes fb-float-2 { 0%,100% { transform: translate(0,0) rotate(12deg); } 50% { transform: translate(-10px,-20px) rotate(16deg); } }
@keyframes fb-float-3 { 0%,100% { transform: translate(0,0) rotate(-10deg); } 50% { transform: translate(12px,-14px) rotate(-6deg); } }
@keyframes fb-float-4 { 0%,100% { transform: translate(0,0) rotate(15deg); } 50% { transform: translate(-8px,-18px) rotate(20deg); } }
@keyframes fb-float-5 { 0%,100% { transform: translate(0,0) rotate(-5deg); } 50% { transform: translate(10px,-22px) rotate(2deg); } }
@keyframes fb-glow-pulse { 0%,100% { opacity: 0.55; } 50% { opacity: 0.85; } }
@keyframes fb-emoji-bob { 0%,100% { transform: translateY(0) rotate(-8deg); } 50% { transform: translateY(-10px) rotate(-4deg); } }

.fb-anim { opacity: 0; transform: translateY(24px); transition: opacity 1s cubic-bezier(0.16,1,0.3,1), transform 1s cubic-bezier(0.16,1,0.3,1); }
.fb-anim.visible { opacity: 1; transform: translateY(0); }

/* LIGHT MODE BASE */
.fb-page { background: #0a0a0a; color: #F5F1E8; font-family: 'Inter', sans-serif; position: relative; }

.fb-kicker { font-size: 11px; letter-spacing: 3.5px; text-transform: uppercase; font-weight: 700; color: #86967E; display: inline-flex; align-items: center; gap: 8px; margin: 0 auto 22px; justify-content: center; }
.fb-kicker::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: #86967E; box-shadow: 0 0 10px rgba(134,150,126,0.7); }
.fb-kicker.gold { color: #C9A96E; }
.fb-kicker.gold::before { background: #C9A96E; box-shadow: 0 0 10px rgba(201,169,110,0.7); }

.fb-block__head { text-align: center; margin-bottom: 42px; }
.fb-block__emoji-big { font-size: 84px; line-height: 0.9; display: block; text-align: center; margin: 4px auto 14px; animation: fb-emoji-bob 3.5s ease-in-out infinite; filter: drop-shadow(0 4px 12px rgba(26,26,26,0.15)); }
.fb-block__title { font-size: 50px; font-weight: 800; line-height: 1.05; letter-spacing: -0.03em; color: #F5F1E8; text-align: center; margin: 0 auto 20px; max-width: 720px; text-transform: lowercase; }
.fb-block__lead { font-size: 16px; line-height: 1.65; color: rgba(245,241,232,0.72); text-align: center; margin: 0 auto; max-width: 560px; }
.fb-block__lead strong { color: #F5F1E8; font-weight: 800; }
.fb-block__lead em { color: #C9A96E; font-style: normal; font-weight: 700; }

.fb-grad { background: linear-gradient(135deg, #86967E 0%, #B5C4B1 35%, #C9A96E 70%, #F5F1E8 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.fb-grad-gold { background: linear-gradient(135deg, #86967E 0%, #C9A96E 40%, #E0C598 75%, #F5F1E8 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* HERO */
.fb-hero { position: relative; background: #0a0a0a; padding: 130px 0 90px; overflow: hidden; min-height: 90vh; text-align: center; }
.fb-hero__content { max-width: 760px; margin: 0 auto; position: relative; z-index: 3; }
.fb-hero__glow { position: absolute; border-radius: 50%; pointer-events: none; }
.fb-hero__glow--1 { top: -10%; right: -10%; width: 800px; height: 800px; background: radial-gradient(circle, rgba(134,150,126,0.28) 0%, transparent 60%); animation: fb-glow-pulse 6s ease-in-out infinite; }
.fb-hero__glow--2 { bottom: -15%; left: -10%; width: 560px; height: 560px; background: radial-gradient(circle, rgba(201,169,110,0.22) 0%, transparent 60%); }

.fb-hero__emoji-big { font-size: 120px; line-height: 0.9; display: block; text-align: center; margin: 8px auto 20px; animation: fb-emoji-bob 4s ease-in-out infinite; filter: drop-shadow(0 8px 18px rgba(26,26,26,0.2)); }
.fb-hero__title { font-size: 68px; font-weight: 800; line-height: 1; letter-spacing: -0.035em; margin: 0 auto 22px; max-width: 720px; text-transform: lowercase; color: #F5F1E8; }
.fb-hero__lead { font-size: 17px; line-height: 1.55; color: rgba(245,241,232,0.75); margin: 0 auto 40px; max-width: 560px; }
.fb-hero__lead strong { color: #F5F1E8; font-weight: 800; }
.fb-hero__media { width: 100%; max-width: 900px; aspect-ratio: 16/9; object-fit: cover; border-radius: 16px; border: 1px solid rgba(134,150,126,0.3); margin: 0 auto 36px; display: block; box-shadow: 0 10px 40px rgba(26,26,26,0.08); }

.fb-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; max-width: 640px; margin: 36px auto 0; text-align: left; }
.fb-kpi { background: rgba(134,150,126,0.08); border: 1px solid rgba(134,150,126,0.32); border-top: 2px solid #86967E; border-radius: 12px; padding: 22px 20px; }
.fb-kpi--gold { background: rgba(201,169,110,0.1); border-color: rgba(201,169,110,0.38); border-top-color: #C9A96E; }
.fb-kpi__n { font-size: 32px; font-weight: 800; line-height: 1; letter-spacing: -0.02em; color: #F5F1E8; }
.fb-kpi__s { font-size: 18px; color: #86967E; margin-left: 2px; }
.fb-kpi--gold .fb-kpi__s { color: #C9A96E; }
.fb-kpi__l { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(245,241,232,0.6); margin-top: 10px; font-weight: 700; }

/* EMOJI FLOATING */
.fb-hero__floaty-wrap { position: absolute; inset: 0; pointer-events: none; z-index: 1; }
.fb-floaty { position: absolute; font-size: 42px; pointer-events: none; filter: drop-shadow(0 4px 10px rgba(26,26,26,0.12)) drop-shadow(0 0 12px rgba(134,150,126,0.35)); }
.fb-floaty--1 { top: 8%; left: 8%; animation: fb-float-1 5s ease-in-out infinite; }
.fb-floaty--2 { top: 12%; right: 10%; animation: fb-float-2 6s ease-in-out infinite; }
.fb-floaty--3 { top: 28%; left: 4%; animation: fb-float-3 5.5s ease-in-out infinite; font-size: 36px; }
.fb-floaty--4 { top: 32%; right: 6%; animation: fb-float-4 6.5s ease-in-out infinite; font-size: 38px; }
.fb-floaty--5 { bottom: 28%; left: 6%; animation: fb-float-5 5.2s ease-in-out infinite; font-size: 34px; }
.fb-floaty--6 { bottom: 32%; right: 8%; animation: fb-float-1 6.2s ease-in-out infinite; font-size: 36px; }
.fb-floaty--7 { top: 48%; left: 2%; animation: fb-float-2 5.8s ease-in-out infinite; font-size: 32px; }
.fb-floaty--8 { top: 52%; right: 3%; animation: fb-float-3 6.4s ease-in-out infinite; font-size: 34px; }
.fb-floaty--9 { bottom: 10%; left: 12%; animation: fb-float-4 5.6s ease-in-out infinite; font-size: 36px; }
.fb-floaty--10 { bottom: 12%; right: 14%; animation: fb-float-5 6.8s ease-in-out infinite; font-size: 34px; }

.fb-floaty-amb { position: absolute; pointer-events: none; font-size: 34px; opacity: 0.55; filter: drop-shadow(0 3px 8px rgba(26,26,26,0.12)) drop-shadow(0 0 10px rgba(134,150,126,0.4)); z-index: 1; }
.fb-floaty-amb--1 { top: 8%; left: 6%; animation: fb-float-1 6s ease-in-out infinite; }
.fb-floaty-amb--2 { top: 10%; right: 7%; animation: fb-float-2 7s ease-in-out infinite; }
.fb-floaty-amb--3 { top: 14%; left: 8%; animation: fb-float-3 6.5s ease-in-out infinite; }
.fb-floaty-amb--4 { top: 16%; right: 9%; animation: fb-float-4 7.5s ease-in-out infinite; }
.fb-floaty-amb--5 { top: 12%; left: 5%; animation: fb-float-5 6.8s ease-in-out infinite; }
.fb-floaty-amb--6 { top: 14%; right: 6%; animation: fb-float-1 7.2s ease-in-out infinite; }
.fb-floaty-amb--7 { top: 12%; left: 7%; animation: fb-float-2 6.6s ease-in-out infinite; }
.fb-floaty-amb--8 { top: 16%; right: 8%; animation: fb-float-3 7.4s ease-in-out infinite; }
.fb-floaty-amb--9 { top: 14%; left: 9%; animation: fb-float-4 6.9s ease-in-out infinite; }
.fb-floaty-amb--10 { top: 16%; right: 10%; animation: fb-float-5 7.1s ease-in-out infinite; }

/* SEZIONI LIGHT */
.fb-brand, .fb-dottore, .fb-tratt, .fb-ads, .fb-feed, .fb-voce, .fb-cta { position: relative; padding: 100px 0; overflow: hidden; background: #0a0a0a; }
.fb-brand { background: radial-gradient(ellipse at 80% 30%, rgba(134,150,126,0.15) 0%, transparent 55%), #0a0a0a; }
.fb-dottore { background: radial-gradient(ellipse at 20% 40%, rgba(201,169,110,0.12) 0%, transparent 55%), #0a0a0a; }
.fb-tratt { background: radial-gradient(ellipse at 80% 60%, rgba(134,150,126,0.14) 0%, transparent 55%), #0a0a0a; }
.fb-ads { background: radial-gradient(ellipse at 30% 30%, rgba(201,169,110,0.2) 0%, transparent 55%), radial-gradient(ellipse at 70% 70%, rgba(134,150,126,0.14) 0%, transparent 55%), #0a0a0a; }
.fb-ads::before { content: ''; position: absolute; top: 20%; right: -5%; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(201,169,110,0.2) 0%, transparent 60%); pointer-events: none; }
.fb-feed { background: radial-gradient(ellipse at 50% 20%, rgba(134,150,126,0.13) 0%, transparent 55%), #0a0a0a; }
.fb-voce { background: radial-gradient(ellipse at 50% 50%, rgba(134,150,126,0.22) 0%, transparent 55%), #0a0a0a; }
.fb-cta { background: radial-gradient(ellipse at 50% 30%, rgba(134,150,126,0.28) 0%, transparent 55%), radial-gradient(ellipse at 50% 80%, rgba(201,169,110,0.15) 0%, transparent 55%), #0a0a0a; padding: 100px 0 120px; }

/* BRAND GRID */
.fb-brand__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; max-width: 1000px; margin: 0 auto 36px; }
.fb-brand__img { aspect-ratio: 1; border-radius: 14px; overflow: hidden; border: 1px solid rgba(134,150,126,0.3); }
.fb-brand__img img { width: 100%; height: 100%; object-fit: cover; display: block; }

.fb-brand__pillars { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; max-width: 900px; margin: 0 auto 36px; }
.fb-pillar { background: rgba(255,255,255,0.025); border: 1px solid rgba(134,150,126,0.28); border-radius: 12px; padding: 22px 10px; text-align: center; transition: all 0.3s; }
.fb-pillar:hover { border-color: #86967E; transform: translateY(-4px); box-shadow: 0 8px 24px rgba(134,150,126,0.3); }
.fb-pillar__e { font-size: 34px; line-height: 1; display: block; margin-bottom: 12px; }
.fb-pillar:nth-child(1) .fb-pillar__e { transform: rotate(-6deg); }
.fb-pillar:nth-child(2) .fb-pillar__e { transform: rotate(8deg); }
.fb-pillar:nth-child(3) .fb-pillar__e { transform: rotate(-4deg); }
.fb-pillar:nth-child(4) .fb-pillar__e { transform: rotate(10deg); }
.fb-pillar:nth-child(5) .fb-pillar__e { transform: rotate(-8deg); }
.fb-pillar:nth-child(6) .fb-pillar__e { transform: rotate(6deg); }
.fb-pillar__t { font-size: 11px; font-weight: 700; color: rgba(245,241,232,0.88); letter-spacing: 0.3px; text-transform: lowercase; }

.fb-brand__clinics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; max-width: 800px; margin: 0 auto; }
.fb-clinic { background: rgba(134,150,126,0.1); color: #F5F1E8; border: 1px solid rgba(134,150,126,0.35); border-radius: 100px; padding: 12px 18px; display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; letter-spacing: 0.02em; transition: all 0.3s; }
.fb-clinic:hover { background: #86967E; border-color: #86967E; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(134,150,126,0.35); }
.fb-clinic__pin { font-size: 14px; }
.fb-clinic__name { text-transform: lowercase; }

/* DOTTORE GRID */
.fb-dottore__grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-flow: dense; gap: 10px; max-width: 1100px; margin: 0 auto; }
.fb-dottore__item { position: relative; overflow: hidden; border-radius: 12px; border: 1px solid rgba(134,150,126,0.25); aspect-ratio: 1; transition: all 0.4s; }
.fb-dottore__item:hover { transform: scale(1.02); border-color: #86967E; box-shadow: 0 8px 28px rgba(134,150,126,0.3); }
.fb-dottore__item--big { grid-column: span 2; grid-row: span 2; aspect-ratio: 1; }
.fb-dottore__item img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* TRATTAMENTI GRID */
.fb-tratt__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; max-width: 1100px; margin: 0 auto; }
.fb-tratt__item { position: relative; overflow: hidden; border-radius: 12px; border: 1px solid rgba(201,169,110,0.28); aspect-ratio: 4/5; transition: all 0.4s; }
.fb-tratt__item:hover { transform: scale(1.02); border-color: #C9A96E; box-shadow: 0 8px 28px rgba(201,169,110,0.3); }
.fb-tratt__item img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ADS SPECIAL */
.fb-ads__steps { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; max-width: 900px; margin: 0 auto 40px; }
.fb-ads__step { background: rgba(255,255,255,0.02); border: 1px solid rgba(201,169,110,0.28); border-radius: 14px; padding: 28px 24px; text-align: left; position: relative; transition: all 0.3s; }
.fb-ads__step:hover { border-color: #C9A96E; transform: translateY(-4px); box-shadow: 0 10px 28px rgba(201,169,110,0.22); }
.fb-ads__step-num { position: absolute; top: 18px; right: 20px; font-size: 11px; font-weight: 800; color: rgba(201,169,110,0.7); letter-spacing: 2px; }
.fb-ads__step-emoji { font-size: 44px; line-height: 1; margin-bottom: 16px; display: block; transform: rotate(-6deg); }
.fb-ads__step:nth-child(even) .fb-ads__step-emoji { transform: rotate(8deg); }
.fb-ads__step-t { font-size: 18px; font-weight: 800; color: #F5F1E8; margin-bottom: 10px; letter-spacing: -0.01em; text-transform: lowercase; }
.fb-ads__step-d { font-size: 13px; color: rgba(245,241,232,0.68); line-height: 1.6; }

.fb-ads__results { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; max-width: 900px; margin: 0 auto; }
.fb-ads__result { background: rgba(201,169,110,0.08); border: 1px solid rgba(201,169,110,0.3); color: #F5F1E8; border-radius: 14px; padding: 20px 16px; text-align: center; border-top: 3px solid #C9A96E; }
.fb-ads__result-n { font-size: 28px; font-weight: 800; color: #C9A96E; line-height: 1; letter-spacing: -0.02em; }
.fb-ads__result-l { font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(245,241,232,0.65); margin-top: 8px; font-weight: 700; }

/* FEED GRID Instagram style */
.fb-feed__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; max-width: 900px; margin: 0 auto; }
.fb-feed__item { aspect-ratio: 1; border-radius: 8px; overflow: hidden; border: 1px solid rgba(134,150,126,0.25); position: relative; transition: all 0.3s; }
.fb-feed__item:hover { transform: scale(1.03); border-color: #86967E; box-shadow: 0 6px 18px rgba(134,150,126,0.3); }
.fb-feed__item img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* VOCE video */
.fb-voce__video-wrap { max-width: 820px; margin: 0 auto 30px; }
.fb-voce__video { width: 100%; aspect-ratio: 16/9; display: block; border-radius: 16px; border: 1px solid rgba(134,150,126,0.3); background: #1A1A1A; }
.fb-voce__video-ph { width: 100%; aspect-ratio: 16/9; border-radius: 16px; border: 1.5px dashed rgba(134,150,126,0.5); background: linear-gradient(135deg, rgba(134,150,126,0.1), rgba(201,169,110,0.08)); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px; text-align: center; }
.fb-voce__play { width: 72px; height: 72px; border-radius: 50%; background: #F5F1E8; color: #0a0a0a; display: flex; align-items: center; justify-content: center; font-size: 26px; font-weight: 800; padding-left: 6px; margin-bottom: 16px; box-shadow: 0 10px 30px rgba(245,241,232,0.2), 0 0 40px rgba(134,150,126,0.25); }
.fb-voce__label { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; color: #86967E; margin-bottom: 10px; }
.fb-voce__desc { font-size: 12px; color: rgba(245,241,232,0.62); max-width: 380px; line-height: 1.55; margin: 0 0 12px; }
.fb-voce__auth { display: flex; align-items: center; gap: 14px; max-width: 820px; margin: 0 auto; padding-left: 4px; }
.fb-voce__avatar { width: 54px; height: 54px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(134,150,126,0.4); }
.fb-voce__avatar--ph { background: linear-gradient(135deg, #86967E, #C9A96E); display: flex; align-items: center; justify-content: center; font-size: 22px; color: #0a0a0a; border: 2px dashed rgba(255,255,255,0.4); }
.fb-voce__name { font-size: 15px; font-weight: 800; color: #F5F1E8; }
.fb-voce__role { font-size: 10px; color: rgba(245,241,232,0.6); letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700; margin-top: 3px; }

/* CTA finale */
.fb-cta__content { text-align: center; max-width: 620px; margin: 0 auto; }
.fb-cta__btn { background: #F5F1E8 !important; color: #0a0a0a !important; box-shadow: 0 8px 28px rgba(245,241,232,0.25), 0 0 50px rgba(134,150,126,0.2) !important; margin-top: 20px; font-weight: 800 !important; }
.fb-cta__btn:hover { background: #86967E !important; color: #F5F1E8 !important; box-shadow: 0 12px 40px rgba(134,150,126,0.5), 0 0 70px rgba(134,150,126,0.3) !important; }

/* PLACEHOLDER LIGHT MODE */
.fb-ph { border: 1.5px dashed rgba(134,150,126,0.5); border-radius: 14px; background: rgba(134,150,126,0.05); padding: 30px 18px; text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.fb-ph--gold { border-color: rgba(201,169,110,0.5); background: rgba(201,169,110,0.08); }
.fb-ph--hero { aspect-ratio: 16/9; max-width: 900px; margin: 0 auto 36px; }
.fb-ph--square { aspect-ratio: 1; }
.fb-ph--fill { position: absolute; inset: 0; border-radius: 0; border: none; background: rgba(134,150,126,0.04); }
.fb-ph__icon { font-size: 38px; display: block; margin-bottom: 10px; }
.fb-ph__label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; color: #86967E; margin-bottom: 10px; }
.fb-ph__label.gold { color: #B08E3C; }
.fb-ph__label-sm { font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700; color: rgba(134,150,126,0.85); margin-top: 4px; }
.fb-ph__desc { font-size: 11px; color: rgba(245,241,232,0.55); line-height: 1.5; margin: 0 0 10px; max-width: 280px; }
.fb-ph__spec { font-size: 9px; color: rgba(245,241,232,0.4); font-family: monospace; background: rgba(255,255,255,0.04); padding: 4px 10px; border-radius: 4px; }

/* Responsive */
@media (max-width: 1024px) {
  .fb-hero { padding: 100px 0 80px; }
  .fb-hero__title { font-size: 52px; }
  .fb-hero__emoji-big { font-size: 94px; }
  .fb-block__title { font-size: 40px; }
  .fb-block__emoji-big { font-size: 68px; }
  .fb-brand__grid { grid-template-columns: repeat(2, 1fr); }
  .fb-brand__pillars { grid-template-columns: repeat(3, 1fr); }
  .fb-brand__clinics { grid-template-columns: repeat(2, 1fr); }
  .fb-dottore__grid { grid-template-columns: repeat(3, 1fr); }
  .fb-dottore__item--big { grid-column: span 2; grid-row: span 2; }
  .fb-tratt__grid { grid-template-columns: repeat(2, 1fr); }
  .fb-ads__results { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .fb-hero { padding: 80px 0 60px; min-height: auto; }
  .fb-hero__title { font-size: 38px; }
  .fb-hero__emoji-big { font-size: 72px; }
  .fb-hero__lead { font-size: 15px; }
  .fb-block__title { font-size: 30px; }
  .fb-block__emoji-big { font-size: 56px; }
  .fb-brand, .fb-dottore, .fb-tratt, .fb-ads, .fb-feed, .fb-voce, .fb-cta { padding: 70px 0; }
  .fb-dottore__grid { grid-template-columns: repeat(2, 1fr); }
  .fb-dottore__item--big { grid-column: span 2; grid-row: span 1; aspect-ratio: 2/1; }
  .fb-ads__steps { grid-template-columns: 1fr; }
  .fb-feed__grid { grid-template-columns: repeat(3, 1fr); }
  .fb-kpis { grid-template-columns: 1fr; }
  .fb-kpi__n { font-size: 28px; }
  .fb-floaty { font-size: 30px; }
  .fb-floaty-amb { font-size: 26px; }
  .fb-voce__play { width: 58px; height: 58px; font-size: 20px; }
}
@media (max-width: 480px) {
  .fb-hero__title { font-size: 30px; }
  .fb-hero__emoji-big { font-size: 58px; }
  .fb-block__title { font-size: 24px; letter-spacing: -0.02em; }
  .fb-block__emoji-big { font-size: 46px; }
  .fb-brand__grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .fb-brand__pillars { grid-template-columns: repeat(2, 1fr); }
  .fb-brand__clinics { grid-template-columns: 1fr; }
  .fb-tratt__grid { grid-template-columns: 1fr 1fr; }
  .fb-ads__results { grid-template-columns: 1fr 1fr; }
  .fb-feed__grid { gap: 4px; }
}

/* REBUILD maggio 2026 — sezione Reel */
.fb-reel { position: relative; padding: 100px 0; overflow: hidden; background: radial-gradient(ellipse at 30% 40%, rgba(201,169,110,0.14) 0%, transparent 55%), radial-gradient(ellipse at 70% 70%, rgba(134,150,126,0.12) 0%, transparent 55%), #0a0a0a; }
.fb-reel__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; max-width: 1100px; margin: 0 auto; }
.fb-reel__item { position: relative; aspect-ratio: 9/16; border-radius: 16px; overflow: hidden; background: #000; border: 1px solid rgba(134,150,126,0.25); transition: all 0.4s; }
.fb-reel__item:hover { transform: translateY(-4px); border-color: #C9A96E; box-shadow: 0 10px 30px rgba(201,169,110,0.25); }
.fb-reel__item video { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 768px) {
  .fb-reel__grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}


/* ========================================== */
/* FIX MAGGIO 2026 — Rebuild Bellucci (FIX-3) */
/* Override per layout compatto + foto vert.  */
/* ========================================== */

/* 1. HERO: 2 colonne + foto verticale 3:4 */
.fb-hero{
  padding:80px 0 60px !important;
  min-height:auto !important;
  text-align:left !important;
}
.fb-hero .container-soul{
  display:grid !important;
  grid-template-columns:1.1fr 0.9fr !important;
  gap:60px !important;
  align-items:center !important;
  max-width:1240px !important;
}
.fb-hero__content{
  text-align:left !important;
  max-width:none !important;
}
.fb-hero__title{
  text-align:left !important;
}
.fb-hero__lead{
  text-align:left !important;
  margin:0 !important;
  max-width:520px !important;
}
.fb-hero__media{
  aspect-ratio:3/4 !important;
  max-width:440px !important;
  width:100% !important;
  height:auto !important;
  margin:0 !important;
  justify-self:center !important;
  object-fit:cover !important;
  object-position:center top !important;
}

/* Mobile fallback */
@media (max-width:780px){
  .fb-hero .container-soul{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
  .fb-hero,
  .fb-hero__content,
  .fb-hero__title,
  .fb-hero__lead{
    text-align:center !important;
  }
  .fb-hero__lead{
    margin:0 auto !important;
  }
  .fb-hero__media{
    max-width:320px !important;
    justify-self:center !important;
  }
}

/* 2. SEZIONI: padding verticale ridotto */
.fb-brand,
.fb-feed,
.fb-reel{
  padding:60px 0 !important;
}
.fb-cta{
  padding:80px 0 100px !important;
}

/* 3. Header sezione: margine sotto più stretto */
.fb-block__head{
  margin-bottom:24px !important;
}

/* 4. Lead sezione: max-width ottimale leggibilità */
.fb-block__lead{
  max-width:640px !important;
}


/* ========================================== */
/* FIX MAGGIO 2026 — Bottone CTA pill (form)  */
/* Estende .fb-cta__btn con proprietà base    */
/* (palette panna+sage già definita sopra)    */
/* ========================================== */

.fb-cta__btn{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  padding:16px 32px !important;
  border-radius:999px !important;
  font-family:'Inter',sans-serif !important;
  font-size:15px !important;
  letter-spacing:.3px !important;
  text-decoration:none !important;
  border:none !important;
  cursor:pointer !important;
  transition:all .25s ease !important;
}


/* FB MOBILE SPAZI SEZIONI — sezioni molto piu' vicine solo su mobile (<=768px).
   Stessa specificita' + !important della regola globale, ma in fondo e dentro
   media query: vince SOLO su mobile. Desktop resta 60px (regola globale). */
@media (max-width: 768px){
  .fb-brand,
  .fb-feed,
  .fb-reel,
  .fb-dottore,
  .fb-tratt,
  .fb-ads,
  .fb-voce{
    padding:24px 0 !important;
  }
  .fb-cta{
    padding:40px 0 50px !important;
  }
}
/* ============================================================ */