/* ============================================================
   Giramundo — Páginas internas (Direção D)
   Depende de: giramundo-base.css + direcao-d.css
   ============================================================ */

/* ---- nav: 7 itens + estado ativo + menu mobile ---- */
.d-nav a{ font-size:15px; }
.d-nav a.active{ color:#fff; }
.d-nav a.active::after{ right:0; }
.d-burger{ display:none; margin-left:14px; width:46px; height:46px; border-radius:12px; border:2px solid rgba(255,255,255,.4); background:transparent; cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.d-burger span{ width:20px; height:2px; background:#fff; display:block; transition:transform .25s, opacity .2s; }
.d-burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.d-burger.open span:nth-child(2){ opacity:0; }
.d-burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
.d-mnav{ position:fixed; inset:0; z-index:70; background:var(--d-ink); display:flex; flex-direction:column; justify-content:center; gap:6px; padding:40px; opacity:0; pointer-events:none; transform:translateY(-12px); transition:opacity .3s, transform .3s; }
.d-mnav.open{ opacity:1; pointer-events:auto; transform:none; }
.d-mnav a{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:clamp(28px,7vw,46px); color:#fff; text-decoration:none; line-height:1.18; letter-spacing:-.01em; }
.d-mnav a:hover,.d-mnav a.active{ color:var(--coral); }
.d-mnav .mwa{ margin-top:24px; align-self:flex-start; font-size:18px; }
.d-mnav .mclose{ position:absolute; top:26px; right:26px; width:46px; height:46px; border-radius:50%; border:2px solid rgba(255,255,255,.4); background:transparent; color:#fff; font-size:22px; cursor:pointer; }

/* ---- page hero ---- */
.p-hero{ background:var(--d-ink); color:#fff; position:relative; overflow:hidden; padding:150px 0 72px; }
.p-hero-bg{ position:absolute; inset:0; z-index:0; }
.p-hero-bg .ps{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1.6s ease-in-out; }
.p-hero-bg .ps.active{ opacity:1; }
.p-hero-ov{ position:absolute; inset:0; z-index:1; background:linear-gradient(100deg, rgba(18,19,26,.95) 0%, rgba(18,19,26,.85) 42%, rgba(18,19,26,.6) 100%), linear-gradient(0deg, rgba(18,19,26,.5), rgba(18,19,26,0) 40%); }
.p-hero .blob{ position:absolute; border-radius:50%; filter:blur(8px); opacity:.8; z-index:2; }
.p-hero .blob.x1{ width:340px; height:340px; background:radial-gradient(circle,var(--azul) 0%,rgba(0,144,180,.5) 35%,transparent 70%); top:-120px; right:-60px; }
.p-hero .blob.x2{ width:300px; height:300px; background:radial-gradient(circle,var(--coral) 0%,rgba(247,82,32,.5) 35%,transparent 70%); bottom:-120px; left:-90px; }
.p-hero .wrap{ position:relative; z-index:3; }
.p-crumb{ display:flex; align-items:center; gap:9px; font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:13px; letter-spacing:.04em; color:rgba(255,255,255,.6); margin-bottom:24px; }
.p-crumb a{ color:rgba(255,255,255,.6); text-decoration:none; } .p-crumb a:hover{ color:#fff; }
.p-crumb .sep{ opacity:.5; }
.p-hero .kick{ color:var(--coral); margin-bottom:22px; }
.p-hero h1{ font-size:clamp(40px,6.4vw,86px); line-height:.96; max-width:18ch; }
.p-hero h1 em{ font-style:normal; color:var(--turq); }
.p-hero .sub{ font-size:19px; line-height:1.6; color:rgba(255,255,255,.82); max-width:54ch; margin-top:24px; font-weight:500; }
.p-hero .cta-row{ display:flex; gap:14px; flex-wrap:wrap; margin-top:32px; }

/* ---- generic section ---- */
.sec{ padding:clamp(64px,8vw,108px) 0; }
.sec.cream{ background:var(--d-cream); }
.sec.ink{ background:var(--d-ink); color:#fff; }
.sec.coral{ background:var(--coral); color:#fff; }
.sec.azul{ background:var(--azul); color:#fff; }
.sec-head{ max-width:64ch; margin-bottom:46px; }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.sec-head .kick{ color:var(--coral); }
.sec.ink .sec-head .kick,.sec.azul .sec-head .kick,.sec.coral .sec-head .kick{ color:#fff; opacity:.85; }
.sec-head h2{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; letter-spacing:-.02em; line-height:1.04; font-size:clamp(30px,4.2vw,54px); margin:16px 0 0; }
.sec-head p{ font-size:18px; line-height:1.6; color:var(--ink-soft); margin-top:18px; font-weight:500; }
.sec.ink .sec-head p,.sec.azul .sec-head p,.sec.coral .sec-head p{ color:rgba(255,255,255,.85); }

/* ---- intro split ---- */
.p-split{ display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }
.p-split.rev{ grid-template-columns:.95fr 1.05fr; }
.p-split .kick{ color:var(--coral); }
.p-split h2{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; letter-spacing:-.02em; line-height:1.05; font-size:clamp(28px,3.8vw,48px); margin:16px 0 20px; }
.p-split p{ font-size:17px; line-height:1.7; color:var(--ink-soft); margin-bottom:16px; }
.p-split p:last-child{ margin-bottom:0; }
.p-art{ position:relative; }
.p-art .pmain{ aspect-ratio:4/5; border-radius:22px; --ph-bg:#dfe7ee; background-size:cover; background-position:center; }
.p-art .psub{ position:absolute; width:52%; aspect-ratio:1/1; border-radius:16px; right:-24px; bottom:-24px; --ph-bg:#f0dcc7; border:7px solid var(--d-cream); background-size:cover; background-position:center; }
.p-art .pdot{ position:absolute; width:120px; height:120px; border-radius:50%; filter:blur(6px); opacity:.7; z-index:-1; }
.p-art .pdot.a{ background:var(--coral); top:-28px; left:-28px; } .p-art .pdot.b{ background:var(--azul); bottom:30px; right:-40px; }
.p-art .tag{ position:absolute; top:-22px; left:-18px; z-index:2; background:var(--coral); color:#fff; border-radius:50%; width:112px; height:112px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; font-family:"Bricolage Grotesque",sans-serif; transform:rotate(-8deg); box-shadow:0 14px 30px rgba(247,82,32,.4); }
.p-art .tag b{ font-size:32px; line-height:.9; } .p-art .tag small{ font-size:11px; font-weight:600; margin-top:3px; }

/* ---- bullets ---- */
.p-bullets{ display:grid; gap:2px; margin-top:8px; }
.p-bullet{ display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-top:1px solid rgba(21,22,29,.12); }
.p-bullet:last-child{ border-bottom:1px solid rgba(21,22,29,.12); }
.sec.ink .p-bullet,.sec.azul .p-bullet,.sec.coral .p-bullet{ border-color:rgba(255,255,255,.18); }
.p-bullet .ic{ width:32px; height:32px; border-radius:50%; flex:0 0 auto; background:var(--turq); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:14px; }
.p-bullet h4{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:17.5px; margin:2px 0 4px; }
.p-bullet p{ font-size:15px; color:var(--ink-soft); line-height:1.5; margin:0; }
.sec.ink .p-bullet p,.sec.azul .p-bullet p,.sec.coral .p-bullet p{ color:rgba(255,255,255,.8); }

/* ---- feature cards ---- */
.p-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.p-card{ background:#fff; border:1px solid #ECE6D9; border-radius:24px; padding:34px 30px; box-shadow:0 14px 40px rgba(40,40,60,.07); display:flex; flex-direction:column; }
.sec.ink .p-card{ background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.12); color:#fff; }
.p-card .ic{ width:60px; height:60px; border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:28px; margin-bottom:20px; background:rgba(247,82,32,.12); }
.p-card.c2 .ic{ background:rgba(0,144,180,.12); } .p-card.c3 .ic{ background:rgba(19,176,206,.14); }
.sec.ink .p-card .ic{ background:rgba(255,255,255,.1); }
.p-card h3{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:22px; margin:0 0 10px; }
.p-card p{ font-size:15.5px; line-height:1.6; color:var(--ink-soft); margin:0; }
.sec.ink .p-card p{ color:rgba(255,255,255,.8); }

/* ---- process steps ---- */
.p-steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.p-step{ position:relative; padding-top:14px; }
.p-step .n{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:18px; width:46px; height:46px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--coral); color:#fff; margin-bottom:18px; }
.p-step:nth-child(2) .n{ background:var(--azul); } .p-step:nth-child(3) .n{ background:var(--turq); color:var(--d-ink); } .p-step:nth-child(4) .n{ background:var(--coral); } .p-step:nth-child(5) .n{ background:var(--azul); }
.p-step h4{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:20px; margin:0 0 8px; }
.p-step p{ font-size:14.5px; line-height:1.55; color:var(--ink-soft); margin:0; }
.sec.ink .p-step p{ color:rgba(255,255,255,.78); }

/* ---- gallery ---- */
.p-gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px; }
.p-gallery .g{ border-radius:16px; --ph-bg:#dfe7ee; background-size:cover; background-position:center; }
.p-gallery .g.tall{ grid-row:span 2; } .p-gallery .g.wide{ grid-column:span 2; }

/* ---- mission / vision / values ---- */
.p-mvv{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.p-mvv .m{ border-radius:24px; padding:38px 32px; color:#fff; min-height:240px; display:flex; flex-direction:column; }
.p-mvv .m.a{ background:linear-gradient(150deg,var(--coral),var(--coral-d)); }
.p-mvv .m.b{ background:linear-gradient(150deg,var(--azul),var(--azul-d)); }
.p-mvv .m.c{ background:linear-gradient(150deg,var(--turq),var(--turq-d)); }
.p-mvv .m .lab{ font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:13px; letter-spacing:.18em; text-transform:uppercase; opacity:.85; }
.p-mvv .m h3{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:28px; margin:6px 0 14px; }
.p-mvv .m p{ font-size:16px; line-height:1.6; font-weight:500; margin:0; }
.p-mvv .m.values ul{ margin:0; padding:0; list-style:none; display:flex; flex-wrap:wrap; gap:9px; }
.p-mvv .m.values li{ background:rgba(255,255,255,.2); border-radius:999px; padding:8px 15px; font-weight:700; font-size:14.5px; }

/* ---- team ---- */
.p-team{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.p-member{ background:#fff; border:1px solid #ECE6D9; border-radius:24px; overflow:hidden; box-shadow:0 14px 40px rgba(40,40,60,.07); display:flex; flex-direction:column; }
.p-member .ph{ aspect-ratio:1/1; --ph-bg:#dfe7ee; background-size:cover; background-position:center top; }
.p-member .b{ padding:26px 26px 30px; }
.p-member .role{ font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--coral-d); }
.p-member h3{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:24px; margin:6px 0 12px; }
.p-member p{ font-size:14.5px; line-height:1.6; color:var(--ink-soft); margin:0; }

/* ---- next services ---- */
.p-next{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.p-nextcard{ display:flex; flex-direction:column; justify-content:space-between; gap:30px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:22px; padding:28px; text-decoration:none; color:#fff; min-height:170px; transition:transform .18s, background .18s; }
.p-nextcard:hover{ transform:translateY(-4px); background:rgba(255,255,255,.1); }
.p-nextcard .lab{ font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; opacity:.6; }
.p-nextcard h4{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:24px; margin:8px 0 0; }
.p-nextcard .go{ font-size:22px; }

/* ---- contact ---- */
.p-contact{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:start; }
.p-cinfo .item{ display:flex; gap:16px; align-items:flex-start; padding:22px 0; border-top:1px solid rgba(21,22,29,.12); }
.p-cinfo .item:first-child{ border-top:0; padding-top:0; }
.p-cinfo .ic{ width:48px; height:48px; border-radius:14px; flex:0 0 auto; background:rgba(247,82,32,.12); display:flex; align-items:center; justify-content:center; font-size:22px; }
.p-cinfo .item.c2 .ic{ background:rgba(0,144,180,.12); } .p-cinfo .item.c3 .ic{ background:rgba(19,176,206,.14); } .p-cinfo .item.c4 .ic{ background:rgba(247,82,32,.12); }
.p-cinfo h4{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:17px; margin:4px 0 4px; }
.p-cinfo p,.p-cinfo a{ font-size:15.5px; line-height:1.6; color:var(--ink-soft); text-decoration:none; margin:0; }
.p-cinfo a:hover{ color:var(--coral-d); }
.p-form{ background:#fff; border:1px solid #ECE6D9; border-radius:26px; padding:38px; box-shadow:0 18px 50px rgba(40,40,60,.09); box-sizing:border-box; width:100%; overflow:hidden; }
.p-form .row{ display:grid; gap:18px; }
.p-form label{ font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:14px; display:block; margin-bottom:7px; }
.p-form input,.p-form select,.p-form textarea{ width:100%; font-family:"Nunito",sans-serif; font-size:15.5px; padding:13px 15px; border:2px solid #E7E0D2; border-radius:12px; background:var(--d-cream); color:var(--ink); transition:border-color .15s; box-sizing:border-box; }
.p-form input:focus,.p-form select:focus,.p-form textarea:focus{ outline:none; border-color:var(--azul); }
.p-form textarea{ min-height:120px; resize:vertical; }
.p-form .full{ grid-column:1 / -1; }
.p-form .two{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.p-form .btn{ width:100%; justify-content:center; margin-top:4px; border:0; }
.p-form .note{ font-size:13px; color:var(--ink-soft); text-align:center; margin:14px 0 0; }
.p-map{ margin-top:18px; border-radius:18px; overflow:hidden; border:1px solid #ECE6D9; }
.p-map iframe{ width:100%; height:280px; border:0; display:block; }

/* ============================================================
   TEMAS DE COR POR SERVIÇO
   laranja → Estudo do Meio · azul → Festa, Colônia, Hotelaria
   ============================================================ */
body.theme-laranja{ --th:#F75220; --th-d:#DD3F12; --th-soft:rgba(247,82,32,.12); --th-em:#FF8A5C; --th-rgb:247,82,32; }
body.theme-azul{ --th:#0090B4; --th-d:#006E8C; --th-soft:rgba(0,144,180,.14); --th-em:#22B6D6; --th-rgb:0,144,180; }

/* kicker + destaques */
.theme-laranja .p-hero .kick,.theme-azul .p-hero .kick,
.theme-laranja .sec.cream .sec-head .kick,.theme-azul .sec.cream .sec-head .kick,
.theme-laranja .p-split .kick,.theme-azul .p-split .kick{ color:var(--th); }
.theme-laranja .p-hero h1 em,.theme-azul .p-hero h1 em{ color:var(--th-em); }

/* blobs do hero (dois tons do tema) */
.theme-laranja .p-hero .blob.x1{ background:radial-gradient(circle,#F75220 0%,rgba(247,82,32,.5) 35%,transparent 70%); }
.theme-laranja .p-hero .blob.x2{ background:radial-gradient(circle,#FF8A5C 0%,rgba(255,138,92,.45) 35%,transparent 70%); }
.theme-azul .p-hero .blob.x1{ background:radial-gradient(circle,#0090B4 0%,rgba(0,144,180,.5) 35%,transparent 70%); }
.theme-azul .p-hero .blob.x2{ background:radial-gradient(circle,#22B6D6 0%,rgba(34,182,214,.45) 35%,transparent 70%); }

/* bullets, steps, badges, dots */
.theme-laranja .p-bullet .ic,.theme-azul .p-bullet .ic{ background:var(--th); }
.theme-laranja .p-step .n{ background:var(--th); }
.theme-laranja .p-step:nth-child(2) .n,.theme-laranja .p-step:nth-child(4) .n{ background:var(--th-d); }
.theme-laranja .p-art .tag,.theme-azul .p-art .tag{ background:var(--th); box-shadow:0 14px 30px rgba(var(--th-rgb),.4); }
.theme-laranja .p-art .pdot.a{ background:#F75220; } .theme-laranja .p-art .pdot.b{ background:#FF8A5C; }
.theme-azul .p-art .pdot.a{ background:#0090B4; } .theme-azul .p-art .pdot.b{ background:#22B6D6; }
.theme-laranja .sec.cream .p-card .ic,.theme-azul .sec.cream .p-card .ic{ background:var(--th-soft); }

/* CTA + botões temáticos */
.theme-azul .btn-coral{ background:var(--th); box-shadow:0 14px 30px rgba(var(--th-rgb),.4); }
.theme-azul .d-cta .ov{ background:linear-gradient(120deg, rgba(21,22,29,.92) 0%, rgba(21,22,29,.7) 46%, rgba(0,144,180,.5) 100%); }
.theme-azul .d-cta h2 .u{ color:var(--th-em); }

/* avatar com iniciais (equipe) */
.p-member .ph.mono{ display:flex; align-items:center; justify-content:center; font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:62px; color:#fff; letter-spacing:.02em; }
.p-member .ph.mono.c1{ background:linear-gradient(150deg,#F75220,#DD3F12); }
.p-member .ph.mono.c2{ background:linear-gradient(150deg,#0090B4,#006E8C); }
.p-member .ph.mono.c3{ background:linear-gradient(150deg,#13B0CE,#018BA8); }

/* ---- selo do logo no canto das fotos (ref. marketing) ---- */
.p-badge{ position:absolute; z-index:4; top:0; left:0; width:86px; height:86px; background:var(--th,#0090B4);
  display:flex; align-items:center; justify-content:center; box-shadow:0 14px 30px rgba(0,0,0,.28); border-bottom-right-radius:18px; }
.p-badge img{ width:56px; height:auto; display:block; }
.p-badge.tr{ left:auto; right:0; border-bottom-right-radius:0; border-bottom-left-radius:18px; }
@media (max-width:620px){ .p-badge{ width:66px; height:66px; } .p-badge img{ width:42px; } }

/* vídeos */
.p-videos{ display:flex; flex-wrap:wrap; gap:20px; justify-content:center; }
.p-video{ height:min(560px,72vh); max-width:100%; border-radius:20px; background:#000; display:block;
  box-shadow:0 20px 50px rgba(0,0,0,.4); border:1px solid rgba(255,255,255,.1); }
@media (max-width:620px){ .p-video{ height:auto; width:100%; } }

/* instagram card */
.p-insta{ display:flex; flex-direction:column; align-items:center; gap:24px; }
.ig-card{ background:#111; border-radius:20px; overflow:hidden; width:100%; max-width:380px; box-shadow:0 24px 60px rgba(0,0,0,.5); }
.ig-preview{ position:relative; aspect-ratio:9/16; background-size:cover; background-position:center; max-height:520px; }
.ig-ov{ position:absolute; inset:0; background:linear-gradient(to bottom, rgba(0,0,0,.15) 0%, rgba(0,0,0,.65) 100%); }
.ig-badge{ position:absolute; top:14px; left:14px; background:rgba(0,0,0,.6); color:#fff; font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:13px; padding:6px 12px; border-radius:999px; display:flex; align-items:center; gap:7px; }
.ig-play{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:2; }
.ig-play:hover svg circle{ fill:rgba(247,82,32,.85); }
.ig-foot{ padding:18px 20px 22px; display:flex; flex-direction:column; gap:10px; background:#111; }
.ig-user{ display:flex; align-items:center; gap:8px; font-family:"Bricolage Grotesque",sans-serif; font-size:14.5px; color:#fff; }
.ig-desc{ font-size:14.5px; color:rgba(255,255,255,.75); margin:0; line-height:1.5; }
.ig-full{ position:absolute; bottom:14px; right:14px; background:rgba(0,0,0,.6); color:#fff; font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:12.5px; padding:7px 13px; border-radius:999px; text-decoration:none; z-index:2; }
.ig-full:hover{ background:var(--coral); }

/* responsive */
@media (max-width:1000px){
  .d-nav{ display:none; }
  .d-burger{ display:flex; }
  .p-split,.p-split.rev,.p-contact{ grid-template-columns:1fr; gap:48px; }
  .p-art{ margin-bottom:30px; }
  .p-cards,.p-mvv,.p-team,.p-next{ grid-template-columns:1fr 1fr; }
  .p-steps{ grid-template-columns:repeat(2,1fr); gap:26px 18px; }
  .p-gallery{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px){
  .p-form .two{ grid-template-columns:1fr; }
  .p-form{ padding:24px 18px; }
}
@media (max-width:620px){
  .d-head .d-headwa{ display:none; }
  .p-cards,.p-mvv,.p-team,.p-next,.p-steps,.p-gallery,.p-form .two{ grid-template-columns:1fr; }
  .p-gallery{ grid-auto-rows:170px; }
  .p-gallery .g.wide{ grid-column:span 1; }
}

/* ============================================================
   Dropdown — Estudo do Meio (nav desktop)
   ============================================================ */
.d-drop{ position:relative; align-self:center; }
.d-drop-btn{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:15px;
  color:rgba(255,255,255,.9); background:none; border:0; cursor:pointer;
  padding:4px 0; display:inline-flex; align-items:center; gap:5px;
  position:relative; line-height:1.2; letter-spacing:0;
}
.d-drop-btn::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background:var(--coral); transition:right .25s; }
.d-drop:hover .d-drop-btn::after,.d-drop-btn.active::after{ right:0; }
.d-caret{ font-size:9px; opacity:.65; transition:transform .22s cubic-bezier(.2,.8,.2,1); display:inline-block; margin-top:1px; }
.d-drop:hover .d-caret{ transform:rotate(180deg); }

.d-drop-panel{
  position:absolute; top:calc(100% + 2px); left:50%;
  transform:translateX(-50%) translateY(-8px);
  background:#fff; border-radius:16px;
  box-shadow:0 20px 56px rgba(21,22,29,.16),0 2px 6px rgba(21,22,29,.07);
  padding:6px; min-width:262px; opacity:0; pointer-events:none;
  transition:opacity .2s cubic-bezier(.2,.8,.2,1),transform .2s cubic-bezier(.2,.8,.2,1);
  z-index:200;
}
.d-drop:hover .d-drop-panel{ opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0); }
/* hover bridge — cobre o gap de 2px para evitar fechamento ao mover o mouse */
.d-drop-panel::after{ content:""; position:absolute; top:-10px; left:-20px; right:-20px; height:10px; }

/* reset dos estilos de .d-nav a para os links do painel */
.d-nav .d-drop-panel a,
.d-nav .d-drop-panel a.active{
  display:flex; flex-direction:column; gap:2px; padding:12px 14px; border-radius:10px;
  text-decoration:none; color:var(--d-ink,#15161D); transition:background .14s;
}
.d-nav .d-drop-panel a::after,
.d-nav .d-drop-panel a.active::after{ display:none; }
.d-nav .d-drop-panel a:hover{ background:var(--d-cream,#F6F1E7); }
.d-drop-panel a strong{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:14.5px;
  display:block; white-space:nowrap; color:var(--d-ink,#15161D);
}
.d-nav .d-drop-panel a:hover strong,
.d-nav .d-drop-panel a.active strong{ color:var(--coral,#F75220); }
.d-drop-panel a span{
  font-family:"Nunito",sans-serif; font-size:12px; color:#74788a; font-weight:600;
  display:block; white-space:nowrap;
}
.d-drop-sep{ height:1px; background:#EDE7DD; margin:4px 6px; }
.d-nav .d-drop-panel a.d-drop-feat{
  background:linear-gradient(135deg,rgba(247,82,32,.07),rgba(247,82,32,.02));
  border:1px solid rgba(247,82,32,.13);
}
.d-nav .d-drop-panel a.d-drop-feat:hover{ background:rgba(247,82,32,.11); }
.d-nav .d-drop-panel a.d-drop-feat strong{ color:var(--coral-d,#DD3F12); }
.d-nav .d-drop-panel a.d-drop-feat span{ color:rgba(221,63,18,.6); }

/* ============================================================
   Submenu mobile — Estudo do Meio
   ============================================================ */
.d-msub{ display:flex; flex-direction:column; }
.d-msub-btn{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:clamp(28px,7vw,46px);
  color:#fff; background:none; border:0; cursor:pointer; display:flex; align-items:center; gap:12px;
  padding:0; line-height:1.18; letter-spacing:-.01em; text-align:left; transition:color .15s;
}
.d-msub-btn:hover,.d-msub-btn.active{ color:var(--coral,#F75220); }
.d-msub-arr{ font-size:18px; opacity:.55; transition:transform .22s cubic-bezier(.2,.8,.2,1); display:inline-block; }
.d-msub-btn[aria-expanded="true"] .d-msub-arr{ transform:rotate(180deg); }
.d-msub-panel{
  display:flex; flex-direction:column; gap:2px; padding:10px 0 6px 22px;
  max-height:0; overflow:hidden; opacity:0;
  transition:max-height .32s cubic-bezier(.2,.8,.2,1),opacity .28s;
}
.d-msub-panel.open{ max-height:160px; opacity:1; }
.d-mnav .d-msub-panel a{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:600;
  font-size:clamp(16px,3.8vw,22px); color:rgba(255,255,255,.68);
  text-decoration:none; line-height:1.3; letter-spacing:0; padding:5px 0;
  transition:color .15s;
}
.d-mnav .d-msub-panel a:hover,
.d-mnav .d-msub-panel a.active{ color:var(--coral,#F75220); }
