/* ====================================
   00 - VARIABLES
==================================== */
:root{
  --bg:#f6f7fb;
  --surface:#ffffff;
  --surface-soft:#f1f4fb;
  --line:#e6eaf5;
  --text:#11183f;
  --muted:#67708e;
  --muted-2:#8a91aa;
  --primary:#0b1e5b;
  --primary-2:#1e5cff;
  --green:#34d399;
  --orange:#ff9a34;
  --shadow-soft:0 20px 60px rgba(18, 32, 84, .08);
  --shadow-card:0 18px 40px rgba(18, 32, 84, .07);
  --shadow-strong:0 34px 80px rgba(18, 32, 84, .14);
  --radius-sm:14px;
  --radius-md:22px;
  --radius-lg:32px;
  --container:1180px;
  --ease: cubic-bezier(.2,.8,.2,1);
}

/* ====================================
   01 - RESET / BASE
==================================== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Sora',sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
.container{width:min(calc(100% - 42px), var(--container));margin-inline:auto}
.section-pad{padding:88px 0}
.section-white{background:linear-gradient(180deg,#fff,#f8faff)}
.center{text-align:center}.center-action{display:flex;justify-content:center;margin-top:34px}.center-actions{justify-content:center}.light{color:#dce5ff!important}
.eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--primary-2)}
.eyebrow.center{justify-content:center}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--primary-2);box-shadow:0 0 0 5px rgba(30,92,255,.08)}
h1,h2,h3,p{margin-top:0}h1,h2,h3{letter-spacing:-.045em;line-height:1.02}p{line-height:1.75;color:var(--muted)}
.section-head{max-width:850px;margin:0 auto 42px}.section-head h2{font-size:clamp(30px,4vw,52px);margin:0 0 18px}.section-head p{font-size:16px;margin:0 auto;max-width:760px}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.in-view{opacity:1;transform:translateY(0)}.delay-1{transition-delay:.12s}.delay-2{transition-delay:.22s}

/* ====================================
   02 - HEADER
==================================== */
.site-header{position:sticky;top:0;z-index:1000;padding:14px 0;background:rgba(246,247,251,.58);backdrop-filter:blur(18px);border-bottom:1px solid rgba(230,234,245,.55);transition:background .28s ease,box-shadow .28s ease,border-color .28s ease,padding .28s ease}
.site-header.is-scrolled{padding:10px 0;background:rgba(255,255,255,.88);box-shadow:0 18px 48px rgba(11,30,91,.08);border-bottom-color:rgba(220,226,240,.92)}
.header-inner{min-height:70px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:26px}
.brand{display:inline-flex;align-items:center;gap:12px;min-width:max-content;color:var(--primary)}
.brand-mark{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:rgba(255,255,255,.82);border:1px solid rgba(226,232,245,.9);box-shadow:0 14px 36px rgba(11,30,91,.08);overflow:hidden}
.site-logo{height:34px;width:auto;display:block}
.brand-copy{display:grid;gap:1px;line-height:1}
.brand-copy strong{font-size:13px;font-weight:800;letter-spacing:-.02em;color:var(--primary)}
.brand-copy small{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.main-nav{justify-self:center;display:inline-flex;align-items:center;gap:6px;padding:6px;background:rgba(255,255,255,.66);border:1px solid rgba(226,232,245,.8);border-radius:999px;box-shadow:0 14px 44px rgba(11,30,91,.06)}
.main-nav a{font-size:12px;font-weight:800;color:#33406d;position:relative;padding:11px 14px;border-radius:999px;transition:color .22s ease,background .22s ease,transform .22s ease;text-decoration:none}
.main-nav a:hover{color:var(--primary-2);background:rgba(232,238,252,.8);transform:translateY(-1px)}
.main-nav a.is-active{color:#fff;background:var(--primary);box-shadow:0 10px 24px rgba(11,30,91,.16)}
.main-nav a::after{display:none}
.nav-mobile-cta{display:none!important}
.header-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:0 18px;border-radius:999px;background:var(--primary);color:#fff;font-size:12px;font-weight:800;box-shadow:0 16px 34px rgba(11,30,91,.2);transition:.25s ease;white-space:nowrap}
.header-cta:hover{transform:translateY(-2px);box-shadow:0 22px 44px rgba(11,30,91,.26);background:#061946}
.header-cta i{width:16px;height:16px;stroke-width:2.4}
.menu-toggle{display:none;width:46px;height:46px;border:0;border-radius:16px;background:#fff;box-shadow:0 14px 34px rgba(11,30,91,.12);cursor:pointer}
.menu-toggle span{display:block;width:18px;height:2px;background:var(--primary);margin:4px auto;border-radius:999px;transition:.2s ease}
.menu-toggle.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.menu-toggle.is-open span:nth-child(2){opacity:0}
.menu-toggle.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ====================================
   03 - BUTTONS
==================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:0 22px;border-radius:999px;font-size:13px;font-weight:800;line-height:1;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease;white-space:nowrap}.btn svg{width:17px;height:17px;stroke-width:2.3}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 14px 34px rgba(11,30,91,.18)}.btn-primary:hover{box-shadow:0 22px 46px rgba(11,30,91,.26)}.btn-secondary{background:#fff;color:var(--primary);border:1px solid var(--line);box-shadow:0 12px 28px rgba(18,32,84,.05)}.btn-secondary:hover{box-shadow:0 18px 38px rgba(18,32,84,.09)}.btn-small{min-height:46px;padding:0 19px}.btn-white{background:#fff;color:var(--primary);box-shadow:0 18px 42px rgba(0,0,0,.16)}.btn-outline-light{border:1px solid rgba(255,255,255,.4);color:#fff;background:rgba(255,255,255,.08)}

/* ====================================
   04 - HOME HERO
==================================== */
.home-hero{padding:92px 0 84px;background:radial-gradient(circle at 18% 18%,rgba(30,92,255,.11),transparent 30%),linear-gradient(180deg,#f8faff 0%,#f4f6fb 100%)}.home-hero-grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(420px,.88fr);gap:64px;align-items:center}.home-hero-copy h1{font-size:clamp(42px,6.2vw,76px);max-width:760px;margin:0 0 22px}.home-hero-copy p{font-size:18px;max-width:630px;margin:0 0 30px}.home-hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.home-hero-proof{display:flex;align-items:center;gap:14px;margin-top:28px;max-width:590px}.proof-avatars{display:flex;min-width:82px}.proof-avatars span{width:34px;height:34px;border-radius:50%;border:3px solid var(--bg);background:linear-gradient(135deg,#dbe5ff,#fff);box-shadow:0 8px 18px rgba(18,32,84,.12);margin-left:-10px}.proof-avatars span:first-child{margin-left:0}.proof-avatars span:nth-child(2){background:linear-gradient(135deg,#dff8ef,#fff)}.proof-avatars span:nth-child(3){background:linear-gradient(135deg,#ffe8d2,#fff)}.home-hero-proof small{font-size:12px;line-height:1.5;color:#69728f}.strategy-panel{background:linear-gradient(145deg,#071d3a 0%,#0b3470 54%,#1455a8 100%);border:1px solid rgba(137,180,255,.28);border-radius:30px;padding:24px;box-shadow:0 28px 72px rgba(10,37,92,.26);position:relative;overflow:hidden;color:#fff}.strategy-panel::before{content:"";position:absolute;inset:-120px -80px auto auto;width:260px;height:260px;border-radius:50%;background:rgba(80,147,255,.34);filter:blur(10px)}.strategy-panel::after{content:"";position:absolute;inset:auto auto -120px -100px;width:260px;height:260px;border-radius:50%;background:rgba(56,217,150,.16);filter:blur(16px)}.strategy-panel-head{position:relative;z-index:1;display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:18px}.strategy-panel-head small{display:block;color:rgba(220,232,255,.72);font-size:10px;font-weight:800;letter-spacing:.14em}.strategy-panel-head strong{display:block;margin-top:6px;font-size:17px;color:#fff}.strategy-panel-head>span{font-size:11px;font-weight:800;color:#dffcf0;background:rgba(23,191,119,.16);border:1px solid rgba(157,245,207,.35);padding:7px 10px;border-radius:999px}.strategy-chart{position:relative;z-index:1;background:linear-gradient(180deg,rgba(255,255,255,.13),rgba(255,255,255,.07)),radial-gradient(circle at 72% 20%,rgba(56,217,150,.16),transparent 34%);border:1px solid rgba(218,230,255,.20);border-radius:22px;padding:18px;margin-bottom:16px;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.14)}.strategy-chart::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.075) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.075) 1px,transparent 1px);background-size:46px 38px;mask-image:linear-gradient(180deg,rgba(0,0,0,.88),rgba(0,0,0,.22));pointer-events:none}.strategy-chart::after{content:"";position:absolute;left:18px;right:18px;top:70px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);box-shadow:0 42px 0 rgba(255,255,255,.10),0 84px 0 rgba(255,255,255,.08);pointer-events:none}.strategy-chart-top{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.strategy-chart-top span{font-size:12px;color:rgba(230,238,255,.72);font-weight:700}.strategy-chart-top strong{font-size:28px;color:#fff}.strategy-chart svg{position:relative;z-index:2;width:100%;height:auto;filter:drop-shadow(0 12px 18px rgba(0,0,0,.18))}.chart-area{fill:url(#heroArea)}.chart-line{fill:none;stroke:url(#heroLine);stroke-width:5;stroke-linecap:round}.strategy-chart circle{fill:#fff;stroke:#8db4ff;stroke-width:4}.strategy-chart .chart-dot-last{stroke:var(--green)}.strategy-chart-labels{position:relative;z-index:2;display:flex;justify-content:space-between;color:rgba(230,238,255,.68);font-size:11px;font-weight:700}.strategy-metrics{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.strategy-metrics div{padding:15px 12px;border-radius:18px;background:rgba(255,255,255,.11);border:1px solid rgba(218,230,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.10)}.strategy-metrics strong{display:block;font-size:22px;color:#fff;letter-spacing:-.04em}.strategy-metrics span{display:block;margin-top:4px;font-size:11px;color:rgba(230,238,255,.72);line-height:1.35}.strategy-note{position:relative;z-index:1;margin:14px 0 0;font-size:12px;line-height:1.55;color:rgba(230,238,255,.74)}

/* ====================================
   05 - HOME PORTFOLIO
==================================== */
.home-portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.case-card{background:#fff;border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:var(--shadow-card);transition:.25s ease}.case-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-strong)}.case-cover{min-height:190px;padding:18px;display:flex;align-items:flex-start;justify-content:flex-start;background:linear-gradient(135deg,#e9eeff,#f9fbff)}.case-cover-2{background:linear-gradient(135deg,#e7fbf2,#f8fffc)}.case-cover-3{background:linear-gradient(135deg,#e7efff,#eef4ff)}.case-cover span{display:inline-flex;padding:8px 12px;border-radius:999px;background:#fff;color:var(--primary);font-size:11px;font-weight:800;box-shadow:0 10px 24px rgba(18,32,84,.08)}.case-body{padding:24px}.case-body small{font-size:11px;font-weight:800;color:var(--muted-2);text-transform:uppercase;letter-spacing:.12em}.case-body h3{font-size:24px;margin:10px 0 10px}.case-body p{font-size:14px;margin-bottom:20px}.case-body a,.blog-preview-card a{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:800;color:var(--primary-2)}.case-body svg,.blog-preview-card svg{width:16px;height:16px}

/* ====================================
   06 - HOME PROOF
==================================== */
.proof-box{border-radius:32px;background:linear-gradient(135deg,#0b1e5b,#183a96);color:#fff;padding:42px;box-shadow:var(--shadow-strong);overflow:hidden;position:relative}.proof-box::after{content:"";position:absolute;right:-80px;top:-90px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.11)}.proof-content{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:44px;align-items:center}.proof-copy h2{font-size:clamp(28px,3.6vw,48px);margin:0 0 16px}.proof-copy p{color:#d6ddf5;margin:0;max-width:650px}.proof-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.proof-stats article{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:19px 16px;min-height:126px;display:flex;flex-direction:column;justify-content:center}.proof-stats strong{font-size:32px;letter-spacing:-.05em}.proof-stats span{font-size:12px;color:#dce5ff;line-height:1.45;margin-top:6px}.proof-context{position:relative;margin:22px 0 0;color:#dce5ff;font-size:13px;max-width:590px}.proof-logos{position:relative;display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}.proof-logos span{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);font-size:11px;font-weight:800;color:#e8eeff}

/* ====================================
   07 - HOME SERVICES
==================================== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}.service-card{position:relative;background:#f8faff;border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:var(--shadow-card);transition:.25s ease}.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-strong)}.service-featured{background:#fff;transform:translateY(-10px);box-shadow:var(--shadow-strong);border-color:rgba(30,92,255,.18)}.service-featured:hover{transform:translateY(-16px)}.service-badge{position:absolute;right:22px;top:22px;display:inline-flex;padding:7px 11px;border-radius:999px;background:var(--primary);color:#fff;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.service-icon{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,#edf3ff,#dfe9ff);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--primary)}.service-featured .service-icon{background:linear-gradient(135deg,var(--primary),#2f6bff);color:#fff}.service-icon svg{width:27px;height:27px;stroke-width:2.2}.service-kicker{display:block;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--primary-2);margin-bottom:10px}.service-card h3{font-size:25px;margin:0 0 12px}.service-card p{font-size:14px;margin:0 0 20px}.service-card ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}.service-card li{position:relative;padding-left:20px;font-size:13px;color:#3f496a;line-height:1.45}.service-card li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:50%;background:var(--primary-2)}

/* ====================================
   08 - HOME PROBLEM
==================================== */
.problem-grid,.positioning-grid{display:grid;grid-template-columns:1fr .9fr;gap:60px;align-items:center}.problem-copy h2,.positioning-copy h2{font-size:clamp(30px,4vw,52px);margin:0 0 18px}.problem-copy p,.positioning-copy p{font-size:16px;margin-bottom:24px}.problem-list{display:grid;gap:10px;margin:0 0 26px}.problem-list span{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;background:#fff;border:1px solid var(--line);color:#3f496a;font-size:14px;font-weight:700}.problem-list svg{width:16px;height:16px;color:#e05252;stroke-width:2.4}.problem-panel{background:#fff;border:1px solid var(--line);border-radius:30px;padding:28px;box-shadow:var(--shadow-strong)}.problem-panel-top{display:flex;flex-direction:column;gap:7px;margin-bottom:20px}.problem-panel-top small{font-size:10px;font-weight:800;letter-spacing:.14em;color:var(--muted-2)}.problem-panel-top strong{font-size:22px;letter-spacing:-.04em}.problem-score{display:flex;align-items:center;justify-content:space-between;background:#f7f9fe;border:1px solid var(--line);border-radius:20px;padding:18px;margin-bottom:18px}.problem-score span{font-size:13px;color:var(--muted);font-weight:700}.problem-score strong{font-size:16px;color:var(--primary)}.problem-bars{display:grid;gap:16px}.problem-bars div{display:grid;gap:8px}.problem-bars span{font-size:13px;font-weight:800;color:#2d3564}.problem-bars i{display:block;width:100%;height:11px;border-radius:999px;background:#eef2fb;overflow:hidden;position:relative}.problem-bars i::after{content:"";display:block;width:var(--w);height:100%;border-radius:999px;background:linear-gradient(90deg,#ff9a34,#1e5cff)}.problem-panel-note{margin-top:22px;padding:16px;border-radius:18px;background:#0b1e5b;color:#e8eeff;font-size:13px;line-height:1.6}

/* ====================================
   09 - HOME POSITIONING
==================================== */
.positioning-grid{grid-template-columns:.9fr 1fr}.positioning-visual{position:relative;min-height:370px}.positioning-card{position:absolute;left:0;top:20px;width:min(330px,100%);background:#fff;border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:var(--shadow-strong)}.positioning-card.secondary{left:130px;top:170px;background:#0b1e5b;color:#fff}.positioning-card svg{width:34px;height:34px;color:var(--primary-2);margin-bottom:18px}.positioning-card.secondary svg{color:#7bdba8}.positioning-card strong{display:block;font-size:24px;letter-spacing:-.04em;margin-bottom:8px}.positioning-card span{font-size:14px;line-height:1.6;color:var(--muted)}.positioning-card.secondary span{color:#dce5ff}.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px}.mini-grid div{padding:18px;border-radius:18px;background:#fff;border:1px solid var(--line)}.mini-grid strong{display:block;font-size:15px;margin-bottom:6px}.mini-grid small{color:var(--muted);line-height:1.55}

/* ====================================
   10 - HOME BENEFITS
==================================== */
.benefits-box{background:#fff;border:1px solid var(--line);border-radius:32px;padding:42px;box-shadow:var(--shadow-card)}.benefits-box>h2{font-size:clamp(30px,4vw,52px);max-width:930px;margin:0 0 34px}.benefits-box>h2 span{color:var(--primary-2)}.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.benefits-grid article{padding:24px;border-radius:24px;background:#f8faff;border:1px solid var(--line)}.benefits-grid svg{width:30px;height:30px;color:var(--primary-2);margin-bottom:16px}.benefits-grid h3{font-size:22px;margin:0 0 10px}.benefits-grid p{font-size:14px;margin:0}

/* ====================================
   11 - HOME TESTIMONIALS
==================================== */
.testimonials-grid{display:grid;grid-template-columns:.9fr 1fr 1fr;gap:24px;align-items:stretch}.testimonial-intro h2{font-size:clamp(28px,3.2vw,44px);margin:0 0 16px}.quote-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:var(--shadow-card)}.quote-card>span{font-size:72px;line-height:.7;color:#dce5ff;font-weight:800}.quote-card p{font-size:15px;color:#35405f}.quote-card strong,.quote-card small{display:block}.quote-card strong{margin-top:22px}.quote-card small{color:var(--muted);margin-top:4px}

/* ====================================
   12 - HOME BLOG
==================================== */
.blog-preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.blog-preview-card{background:#fff;border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:var(--shadow-card);transition:.25s ease}.blog-preview-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-strong)}.blog-preview-card>div:last-child{padding:24px}.blog-cover{height:170px;background:linear-gradient(135deg,#dfe8ff,#fff)}.cover-b{background:linear-gradient(135deg,#e5fbf1,#fff)}.cover-c{background:linear-gradient(135deg,#fff0df,#fff)}.blog-preview-card span{font-size:10px;font-weight:800;letter-spacing:.13em;color:var(--primary-2)}.blog-preview-card h3{font-size:21px;line-height:1.18;margin:10px 0 10px}.blog-preview-card p{font-size:14px}

/* ====================================
   13 - CTA FINAL
==================================== */
.home-final-cta{background:#f6f7fb}.final-cta-box{border-radius:34px;padding:58px 42px;text-align:center;color:#fff;background:radial-gradient(circle at 18% 0%,rgba(56,217,150,.22),transparent 26%),linear-gradient(135deg,#071847,#12328d);box-shadow:var(--shadow-strong)}.final-cta-box h2{font-size:clamp(32px,4.4vw,58px);max-width:940px;margin:0 auto 18px}.final-cta-box p{color:#dce5ff;max-width:760px;margin:0 auto 30px}

/* ====================================
   14 - FOOTER / FLOATS
==================================== */
.site-footer{background:#07102d;color:#fff;padding:54px 0 24px}.footer-main{display:grid;grid-template-columns:1fr 1fr;gap:40px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.1)}.footer-logo{height:42px;width:auto;margin-bottom:16px}.footer-brand p{max-width:430px;color:#cdd6ee;margin:0}.footer-links{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}.footer-links strong{display:block;margin-bottom:14px}.footer-links a,.footer-links span{display:block;color:#cdd6ee;font-size:14px;margin-bottom:10px}.footer-links a:hover{color:#fff}.footer-bottom{display:flex;justify-content:space-between;gap:20px;align-items:center;padding-top:22px;color:#b8c2df;font-size:13px}.floating-actions{position:fixed;right:22px;bottom:22px;z-index:90;display:grid;gap:12px;justify-items:end}.float-button{border:0;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-width:52px;height:52px;border-radius:999px;background:#fff;box-shadow:0 16px 36px rgba(0,0,0,.16);cursor:pointer}.float-button img{width:25px;height:25px;object-fit:contain}.float-top{opacity:0;pointer-events:none;transform:translateY(8px);transition:.25s ease}.float-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.float-whatsapp {
  bottom: 24px;
  background: linear-gradient(135deg, #0b1f4b, #1d4ed8);
  color: #fff;
  box-shadow: 0 18px 36px rgba(11, 31, 75, .22);
}.float-whatsapp span{font-size:12px;font-weight:800;color:#15204a}

/* ====================================
   15 - GENERIC PAGE SUPPORT
==================================== */
.page-hero,.internal-hero{padding:84px 0;background:linear-gradient(180deg,#f8faff,#f4f6fb)}.page-hero h1,.internal-hero h1{font-size:clamp(38px,5vw,68px);margin:0 0 18px}.page-hero p,.internal-hero p{font-size:17px;max-width:760px}.content-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:var(--shadow-card)}

/* ====================================
   16 - RESPONSIVE
==================================== */
@media (max-width: 1040px){
  .home-hero-grid,.problem-grid,.positioning-grid{grid-template-columns:1fr;gap:42px}.home-hero-visual{max-width:620px}.proof-content,.footer-main{grid-template-columns:1fr}.services-grid,.home-portfolio-grid,.benefits-grid,.testimonials-grid,.blog-preview-grid{grid-template-columns:1fr 1fr}.service-featured{transform:none}.service-featured:hover{transform:translateY(-6px)}.positioning-visual{min-height:330px}.positioning-card.secondary{left:100px}.main-nav{gap:18px}.header-cta{display:none}
}
@media (max-width: 760px){
  .container{width:min(calc(100% - 28px), var(--container))}.section-pad{padding:64px 0}.header-inner{grid-template-columns:auto auto;justify-content:space-between}.menu-toggle{display:block}.main-nav{position:absolute;left:14px;right:14px;top:76px;display:none;flex-direction:column;align-items:flex-start;gap:4px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:var(--shadow-strong)}.main-nav.is-open{display:flex}.main-nav a{width:100%;padding:12px 10px}.home-hero{padding-top:70px}.home-hero-copy h1{font-size:42px}.home-hero-copy p{font-size:16px}.home-hero-actions{align-items:stretch}.home-hero-actions .btn{width:100%}.home-hero-proof{align-items:flex-start}.strategy-metrics,.proof-stats,.services-grid,.home-portfolio-grid,.benefits-grid,.testimonials-grid,.blog-preview-grid,.footer-links,.mini-grid{grid-template-columns:1fr}.proof-box,.benefits-box,.final-cta-box{padding:28px}.proof-content{gap:28px}.problem-panel{padding:22px}.positioning-visual{min-height:auto;display:grid;gap:16px}.positioning-card,.positioning-card.secondary{position:relative;left:auto;top:auto;width:100%}.footer-bottom{flex-direction:column;align-items:flex-start}.float-whatsapp span{display:none}.service-badge{position:static;margin-bottom:16px}.service-card{padding:24px}
}


/* ====================================
   HEADER PREMIUM - RESPONSIVE OVERRIDES
==================================== */
@media (max-width: 1080px){
  .brand-copy{display:none}
  .main-nav{gap:2px}
  .main-nav a{padding:10px 11px}
}
@media (max-width: 760px){
  .site-header{padding:10px 0;background:rgba(255,255,255,.9)}
  .header-inner{min-height:62px;grid-template-columns:auto auto;justify-content:space-between}
  .brand-mark{width:44px;height:44px;border-radius:14px}
  .site-logo{height:32px}
  .menu-toggle{display:block}
  .header-cta{display:none}
  .main-nav{position:absolute;left:14px;right:14px;top:78px;display:none;flex-direction:column;align-items:stretch;gap:6px;background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:22px;padding:12px;box-shadow:var(--shadow-strong)}
  .main-nav.is-open{display:flex}
  .main-nav a{width:100%;padding:13px 14px}
  .nav-mobile-cta{display:flex!important;align-items:center;justify-content:center;margin-top:4px;background:var(--primary)!important;color:#fff!important}
}


/* ====================================
   06.1 - HOME PROOF LOGO SLOTS
   Correção segura: substitui nomes por campos de logos retangulares.
==================================== */
.proof-logos{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:18px;
  margin-top:28px;
  padding-top:24px;
}
.proof-logo-slot{
  width:158px;
  height:52px;
  border-radius:12px;
  background:rgba(255,255,255,.065);
  border:1px solid rgba(255,255,255,.13);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 16px;
  transition:.25s ease;
}
.proof-logo-slot:hover{
  background:rgba(255,255,255,.12);
  transform:translateY(-2px);
}
.proof-logo-slot img{
  max-width:120px;
  max-height:25px;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:grayscale(100%) brightness(0) invert(1);
  opacity:.72;
  transition:.25s ease;
}
.proof-logo-slot:hover img{opacity:1;}
@media (max-width:760px){
  .proof-logos{gap:10px;}
  .proof-logo-slot{width:calc(50% - 5px);height:48px;border-radius:10px;}
}


/* ====================================
   HEADER - LOGO FIX DEFINITIVO
   Corrige a logo real no topo sem afetar prova social ou demais blocos.
==================================== */
.brand.brand-logo-only{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  gap:0;
  min-width:132px;
  line-height:1;
}
.brand-logo-only .site-logo-header{
  height:28px;
  width:auto;
  max-width:150px;
  object-fit:contain;
  display:block;
}
.site-header .header-inner{
  align-items:center;
}
@media (max-width: 760px){
  .brand.brand-logo-only{min-width:118px;}
  .brand-logo-only .site-logo-header{height:25px;max-width:130px;}
}

/* ====================================
   11B - HOME TESTIMONIALS ROTATIVOS
   Cards com foto preparada para integração futura no painel.
==================================== */
.quote-card{
  position:relative;
  overflow:hidden;
}
.quote-card::after{
  content:"";
  position:absolute;
  right:-46px;
  top:-46px;
  width:150px;
  height:150px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(71,114,255,.12), rgba(255,255,255,0));
  pointer-events:none;
}
.quote-card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
  position:relative;
  z-index:1;
}
.quote-avatar{
  width:58px;
  height:58px;
  border-radius:18px;
  object-fit:cover;
  border:1px solid rgba(16,31,84,.08);
  box-shadow:0 14px 30px rgba(16,31,84,.10);
  background:#eef3ff;
}
.quote-card .quote-mark{
  font-size:64px;
  line-height:.7;
  color:#dce5ff;
  font-weight:800;
}
.quote-card>span{
  display:none;
}
.quote-card p{
  position:relative;
  z-index:1;
}
.quote-author{
  margin-top:22px;
  position:relative;
  z-index:1;
}
.quote-author strong,
.quote-author small{
  display:block;
}
.quote-author small{
  color:var(--muted);
  margin-top:4px;
}
@media (max-width:760px){
  .quote-avatar{width:52px;height:52px;border-radius:16px}
  .quote-card .quote-mark{font-size:54px}
}


/* ====================================
   11.1 - HOME TESTIMONIALS CAROUSEL / COMPACT
==================================== */
.testimonials-carousel-layout{
  display:grid;
  grid-template-columns:.82fr 1.6fr;
  gap:34px;
  align-items:center;
}
.testimonials-carousel-layout .testimonial-intro h2{
  max-width:430px;
}
.testimonials-carousel{
  overflow:hidden;
  position:relative;
  padding:4px;
}
.testimonial-track{
  display:flex;
  gap:18px;
  transition:transform .65s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.testimonial-slide{
  flex:0 0 calc((100% - 18px) / 2);
  min-height:260px;
}
.home-testimonials .quote-card{
  padding:24px;
  border-radius:24px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  box-shadow:0 18px 45px rgba(11,24,75,.06);
}
.home-testimonials .quote-card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:16px;
}
.home-testimonials .quote-avatar{
  width:54px;
  height:54px;
  border-radius:18px;
  object-fit:cover;
  background:#eef3ff;
  border:1px solid var(--line);
}
.home-testimonials .quote-mark{
  font-size:54px;
  line-height:1;
  color:#dfe7ff;
  font-weight:800;
}
.home-testimonials .quote-card p{
  font-size:15px;
  line-height:1.65;
  margin:0 0 18px;
  color:#263252;
}
.home-testimonials .quote-author strong{
  display:block;
  margin:0;
  font-size:15px;
}
.home-testimonials .quote-author small{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:13px;
}
.testimonial-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:18px;
}
.testimonial-dots button{
  width:7px;
  height:7px;
  padding:0;
  border:0;
  border-radius:999px;
  background:#cfd8f3;
  cursor:pointer;
  transition:.25s ease;
}
.testimonial-dots button.is-active{
  width:22px;
  background:var(--blue);
}
@media (max-width: 980px){
  .testimonials-carousel-layout{grid-template-columns:1fr;gap:26px;}
  .testimonial-slide{flex-basis:calc((100% - 18px) / 2);}
}
@media (max-width: 680px){
  .testimonial-slide{flex-basis:100%;}
  .home-testimonials .quote-card{min-height:auto;padding:22px;}
}


/* ====================================
   HOME TESTIMONIALS - RANDOM 2 CARDS
   Exibe 2 depoimentos por reload, sem carrossel.
==================================== */
.testimonials-random-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  align-items: stretch;
}

.testimonial-random-card {
  min-height: auto !important;
  height: auto !important;
  padding: 28px !important;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.testimonial-random-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

.testimonial-photo {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  object-fit: cover;
  display: block;
  box-shadow: 0 14px 30px rgba(16, 35, 92, .10);
}

.testimonial-quote-icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(39, 98, 255, .08);
  color: rgba(39, 98, 255, .35);
  font-size: 42px;
  line-height: 1;
  font-weight: 800;
  font-family: Georgia, serif;
}

.testimonial-random-card p {
  font-size: 15px;
  line-height: 1.65;
  margin-bottom: 20px;
}

.testimonial-author {
  margin-top: auto;
}

.testimonial-author strong,
.testimonial-author small {
  display: block;
}

.testimonial-author small {
  margin-top: 4px;
  opacity: .72;
}

@media (max-width: 980px) {
  .testimonials-random-grid {
    grid-template-columns: 1fr;
  }
}


/* ====================================
   HOME TESTIMONIALS - STATIC RANDOM
   Exibe apenas 2 depoimentos por carregamento.
   Sem carrossel, sem track, sem dots.
==================================== */
.testimonials-static-layout {
  display: grid;
  grid-template-columns: .82fr 1.45fr;
  gap: 34px;
  align-items: center;
}

.testimonials-static-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.testimonial-static-card {
  min-height: auto !important;
  height: auto !important;
  padding: 24px !important;
  border-radius: 24px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  box-shadow: 0 18px 45px rgba(11,24,75,.06);
}

.testimonial-static-card .quote-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.testimonial-static-card .quote-avatar {
  width: 50px;
  height: 50px;
  border-radius: 16px;
  object-fit: cover;
  background: #eef3ff;
  border: 1px solid var(--line);
}

.testimonial-static-card .quote-mark {
  font-size: 48px;
  line-height: 1;
  color: #dfe7ff;
  font-weight: 800;
}

.testimonial-static-card p {
  font-size: 14px;
  line-height: 1.58;
  margin: 0 0 16px;
  color: #263252;
}

.testimonial-static-card .quote-author {
  margin-top: auto;
}

.testimonial-static-card .quote-author strong {
  display: block;
  margin: 0;
  font-size: 14px;
}

.testimonial-static-card .quote-author small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

@media (max-width: 980px) {
  .testimonials-static-layout {
    grid-template-columns: 1fr;
    gap: 26px;
  }
}

@media (max-width: 680px) {
  .testimonials-static-grid {
    grid-template-columns: 1fr;
  }

  .testimonial-static-card {
    padding: 22px !important;
  }
}


/* ====================================
   FOOTER - CLARO PREMIUM
   Rodapé global limpo, centralizado e sem crédito externo.
==================================== */
.site-footer {
  position: relative;
  overflow: hidden;
  padding: 72px 0 34px;
  background:
    radial-gradient(circle at 18% 18%, rgba(39, 98, 255, .07), transparent 30%),
    radial-gradient(circle at 82% 12%, rgba(255, 140, 66, .055), transparent 28%),
    #f8f9fc;
  border-top: 1px solid rgba(16, 35, 92, .08);
  color: var(--text);
}

.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .45;
  background-image:
    linear-gradient(rgba(16, 35, 92, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(16, 35, 92, .035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(to bottom, transparent, #000 18%, #000 82%, transparent);
}

.footer-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.footer-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
  text-decoration: none;
}

.footer-logo img {
  width: auto;
  height: 38px;
  max-width: 190px;
  object-fit: contain;
  display: block;
}

.footer-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px 24px;
  flex-wrap: wrap;
  margin-bottom: 30px;
}

.footer-nav a {
  color: rgba(16, 35, 92, .72);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: .22s ease;
}

.footer-nav a:hover {
  color: var(--blue);
  transform: translateY(-1px);
}

.footer-cta {
  max-width: 620px;
  margin: 0 auto 34px;
}

.footer-cta p {
  margin: 0 auto 18px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.75;
}

.btn-footer {
  min-height: 46px;
  padding: 0 20px;
  border-radius: 999px;
  background: var(--blue);
  color: #fff;
  box-shadow: 0 18px 34px rgba(39, 98, 255, .18);
}

.btn-footer:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 42px rgba(39, 98, 255, .24);
}

.footer-bottom {
  width: 100%;
  padding-top: 26px;
  border-top: 1px solid rgba(16, 35, 92, .08);
}

.footer-bottom p {
  margin: 0;
  color: rgba(16, 35, 92, .55);
  font-size: 13px;
  text-align: center;
}

@media (max-width: 760px) {
  .site-footer {
    padding: 56px 0 28px;
  }

  .footer-logo img {
    height: 34px;
  }

  .footer-nav {
    gap: 10px 18px;
    margin-bottom: 26px;
  }

  .footer-cta p {
    font-size: 14px;
  }
}


/* ====================================
   FOOTER - AJUSTE FINO FINAL
   Corrige alinhamento e legibilidade do botão.
==================================== */
.site-footer {
  padding: 64px 0 30px !important;
}

.footer-inner {
  max-width: 980px;
  margin: 0 auto;
  align-items: center !important;
  justify-content: center;
  gap: 0;
}

.footer-logo {
  margin-bottom: 24px !important;
}

.footer-logo img {
  height: 34px !important;
  max-width: 180px;
}

.footer-nav {
  margin-bottom: 24px !important;
  gap: 12px 26px !important;
}

.footer-nav a {
  line-height: 1;
}

.footer-cta {
  max-width: 560px !important;
  margin-bottom: 32px !important;
}

.footer-cta p {
  max-width: 540px;
  margin: 0 auto 18px !important;
  line-height: 1.65 !important;
}

.btn-footer {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 24px;
  border-radius: 999px;
  background: #06185f !important;
  color: #ffffff !important;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none !important;
  border: 1px solid rgba(6, 24, 95, .12);
  box-shadow: 0 18px 34px rgba(6, 24, 95, .18);
  opacity: 1 !important;
}

.btn-footer:hover {
  background: #10297a !important;
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: 0 22px 42px rgba(6, 24, 95, .24);
}

.btn-footer i {
  width: 17px;
  height: 17px;
  stroke-width: 2.4;
}

.footer-bottom {
  max-width: 980px;
  margin: 0 auto;
  padding-top: 24px !important;
}

.footer-bottom p {
  text-align: center !important;
  line-height: 1.4;
}

@media (max-width: 760px) {
  .site-footer {
    padding: 52px 0 26px !important;
  }

  .footer-nav {
    gap: 12px 18px !important;
  }

  .footer-cta {
    margin-bottom: 28px !important;
  }

  .btn-footer {
    width: auto;
    max-width: 100%;
  }
}


/* ====================================
   FOOTER FINAL - TEXTO INSTITUCIONAL + COPY CENTRAL
   Mantém o texto institucional, remove CTA e preserva botões flutuantes.
==================================== */
.footer-cta {
  max-width: 620px !important;
  margin: 0 auto 32px !important;
  text-align: center !important;
}

.footer-cta p {
  max-width: 560px;
  margin: 0 auto !important;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.75;
  text-align: center !important;
}

.footer-cta .btn,
.footer-cta .btn-footer,
.footer-cta a {
  display: none !important;
}

.footer-bottom {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
}

.footer-bottom p {
  width: 100% !important;
  text-align: center !important;
}


/* ====================================
   FOOTER SOCIAL PREMIUM - SVGs SÓLIDOS
   Ícones de redes sociais monocromáticos, sem círculos e sem aparência linear.
==================================== */
.footer-social {
  margin: -6px auto 30px;
  text-align: center;
  font-size: 14px;
  color: var(--muted);
}

.footer-social span {
  display: block;
  margin-bottom: 12px;
  line-height: 1.4;
}

.footer-social strong {
  color: var(--text);
  font-weight: 800;
}

.footer-social-icons {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 18px;
}

.footer-social-icons a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: 22px;
  color: var(--text);
  opacity: .68;
  text-decoration: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  transition: opacity .22s ease, color .22s ease, transform .22s ease;
}

.footer-social-icons .social-svg {
  display: block;
  width: 20px;
  height: 20px;
  fill: currentColor;
  stroke: none !important;
}

.footer-social-icons .social-behance {
  width: 24px;
}

.footer-social-icons a:hover {
  color: var(--blue);
  opacity: 1;
  transform: translateY(-2px);
}

@media (max-width: 760px) {
  .footer-social {
    margin-bottom: 26px;
  }

  .footer-social-icons {
    gap: 16px;
  }
}

/* Botões flutuantes preservados */
.floating-whatsapp,
.back-to-top {
  position: fixed;
  right: 20px;
  z-index: 999;
}

.floating-whatsapp {
  bottom: 22px;
}

.back-to-top {
  bottom: 82px;
}


/* ====================================
   FLOATING ACTIONS - PREMIUM FIX
   WhatsApp + voltar ao topo no padrão visual do site.
==================================== */

/* neutraliza versões antigas */
.floating-whatsapp,
.back-to-top {
  display: none !important;
}

.float-action {
  position: fixed;
  right: 22px;
  width: 48px;
  height: 48px;
  border-radius: 18px;
  z-index: 9999;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: transform .22s ease, box-shadow .22s ease, opacity .22s ease, background .22s ease;
}

.float-action i {
  width: 21px;
  height: 21px;
  stroke-width: 2.4;
}

.float-whatsapp {
  bottom: 24px;
  background: linear-gradient(135deg, #0b1f4b, #1d4ed8);
  color: #fff;
  box-shadow: 0 18px 36px rgba(11, 31, 75, .22);
}

.float-top {
  bottom: 84px;
  background: rgba(255,255,255,.88);
  color: var(--blue);
  box-shadow: 0 16px 34px rgba(8, 24, 74, .12);
  border-color: rgba(8, 24, 74, .08);
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
}

.float-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.float-action:hover {
  transform: translateY(-3px);
}

.float-top.is-visible:hover {
  transform: translateY(-3px);
}

.float-whatsapp:hover {
  box-shadow: 0 22px 44px rgba(11, 31, 75, .26);
}

.float-top:hover {
  background: #fff;
  box-shadow: 0 20px 42px rgba(8, 24, 74, .16);
}

@media (max-width: 760px) {
  .float-action {
    right: 16px;
    width: 44px;
    height: 44px;
    border-radius: 16px;
  }

  .float-whatsapp {
  bottom: 24px;
  background: linear-gradient(135deg, #0b1f4b, #1d4ed8);
  color: #fff;
  box-shadow: 0 18px 36px rgba(11, 31, 75, .22);
}

  .float-top {
    bottom: 72px;
  }

  .float-action i {
    width: 20px;
    height: 20px;
  }
}


/* ====================================
   SOBRE PAGE
   Página institucional premium da Agência Underline.
==================================== */
.about-page {
  overflow: hidden;
}

.about-hero {
  padding-top: 150px;
  background:
    radial-gradient(circle at 78% 20%, rgba(39, 98, 255, .11), transparent 34%),
    linear-gradient(180deg, #f8faff 0%, #ffffff 82%);
}

.about-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 56px;
  align-items: center;
}

.about-hero-copy h1 {
  max-width: 760px;
  margin: 14px 0 18px;
  font-size: clamp(38px, 5vw, 68px);
  line-height: .98;
  letter-spacing: -2.8px;
}

.about-hero-copy p {
  max-width: 640px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75;
}

.about-hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.about-hero-card {
  position: relative;
  padding: 30px;
  border-radius: 32px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(248,250,255,.92));
  border: 1px solid var(--line);
  box-shadow: 0 30px 80px rgba(11,24,75,.10);
}

.about-hero-card::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 24px;
  border: 1px solid rgba(39,98,255,.08);
  pointer-events: none;
}

.about-card-top {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 28px;
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.about-card-top strong {
  color: var(--blue);
}

.about-card-body {
  display: grid;
  gap: 14px;
  margin-bottom: 24px;
}

.about-card-body div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 16px 0;
  border-bottom: 1px solid rgba(16,35,92,.08);
}

.about-card-body strong {
  color: var(--blue);
  font-size: 32px;
  letter-spacing: -1px;
}

.about-card-body span {
  color: var(--muted);
  font-size: 14px;
}

.about-hero-card p {
  position: relative;
  z-index: 1;
  color: var(--muted);
  line-height: 1.75;
}

.about-split {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 56px;
  align-items: start;
}

.about-text {
  display: grid;
  gap: 18px;
}

.about-text p {
  margin: 0;
  color: var(--muted);
  line-height: 1.85;
  font-size: 17px;
}

.about-principles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 42px;
}

.about-principle {
  padding: 30px;
  border-radius: 28px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 18px 45px rgba(11,24,75,.055);
  transition: .25s ease;
}

.about-principle.featured {
  transform: translateY(-10px);
  background: linear-gradient(180deg, #ffffff, #f7faff);
  box-shadow: 0 26px 64px rgba(11,24,75,.09);
}

.about-principle:hover {
  transform: translateY(-6px);
}

.about-principle.featured:hover {
  transform: translateY(-14px);
}

.principle-icon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  margin-bottom: 18px;
}

.principle-icon i {
  width: 24px;
  height: 24px;
  stroke-width: 2.3;
}

.about-principle h3 {
  margin: 0 0 10px;
  font-size: 20px;
  letter-spacing: -.5px;
}

.about-principle p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}

.about-difference-box {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 48px;
  padding: 44px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 12% 18%, rgba(39,98,255,.10), transparent 30%),
    #f8f9fc;
  border: 1px solid var(--line);
}

.about-difference-box h2 {
  margin: 12px 0 0;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.08;
  letter-spacing: -1.5px;
}

.difference-list {
  display: grid;
  gap: 14px;
}

.difference-list div {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,35,92,.06);
}

.difference-list i {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-top: 2px;
  color: var(--blue);
  stroke-width: 2.5;
}

.difference-list span {
  color: #263252;
  font-weight: 600;
  line-height: 1.55;
}

.about-cta .cta-box {
  text-align: center;
}

@media (max-width: 980px) {
  .about-hero-grid,
  .about-split,
  .about-difference-box {
    grid-template-columns: 1fr;
  }

  .about-principles-grid {
    grid-template-columns: 1fr;
  }

  .about-principle.featured {
    transform: none;
  }

  .about-principle.featured:hover {
    transform: translateY(-6px);
  }
}

@media (max-width: 680px) {
  .about-hero {
    padding-top: 128px;
  }

  .about-hero-copy h1 {
    letter-spacing: -1.8px;
  }

  .about-hero-actions {
    flex-direction: column;
  }

  .about-hero-actions .btn {
    width: 100%;
  }

  .about-hero-card,
  .about-difference-box {
    padding: 26px;
    border-radius: 26px;
  }
}


/* ====================================
   SOBRE PAGE V2 - REDESIGN PREMIUM
   Estrutura modular da página Sobre.
==================================== */

.about-page {
  overflow: hidden;
}

/* 01 - SOBRE HERO */
.about-hero-v2 {
  padding-top: 150px;
  background:
    radial-gradient(circle at 84% 14%, rgba(39, 98, 255, .12), transparent 32%),
    radial-gradient(circle at 10% 22%, rgba(255, 140, 66, .08), transparent 28%),
    linear-gradient(180deg, #f8faff 0%, #ffffff 84%);
}

.about-hero-v2-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 60px;
  align-items: center;
}

.about-hero-v2-copy h1 {
  max-width: 780px;
  margin: 14px 0 20px;
  font-size: clamp(40px, 5.3vw, 72px);
  line-height: .96;
  letter-spacing: -3px;
}

.about-hero-v2-copy p {
  max-width: 640px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75;
}

.about-hero-v2-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 30px;
}

.about-hero-v2-visual {
  position: relative;
}

.about-signature-card {
  position: relative;
  overflow: hidden;
  min-height: 440px;
  padding: 34px;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,250,255,.92));
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 34px 90px rgba(11,24,75,.12);
}

.about-signature-card::after {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 26px;
  border: 1px solid rgba(39,98,255,.08);
  pointer-events: none;
}

.about-glow {
  position: absolute;
  width: 220px;
  height: 220px;
  right: -70px;
  top: -70px;
  border-radius: 999px;
  background: rgba(39,98,255,.16);
  filter: blur(8px);
}

.signature-top {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
}

.signature-top small {
  color: var(--muted);
  font-size: 12px;
  letter-spacing: .16em;
  font-weight: 800;
}

.signature-top strong {
  font-size: 22px;
  color: var(--text);
  letter-spacing: -.6px;
}

.signature-lines {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
  margin: 42px 0;
}

.signature-lines span {
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(39,98,255,.22), rgba(39,98,255,.055));
}

.signature-metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 22px;
}

.signature-metrics article {
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.07);
}

.signature-metrics strong {
  display: block;
  color: var(--blue);
  font-size: 34px;
  letter-spacing: -1px;
}

.signature-metrics span {
  color: var(--muted);
  font-size: 13px;
}

.signature-note {
  position: relative;
  z-index: 1;
  padding: 18px;
  border-radius: 22px;
  background: rgba(16,35,92,.045);
  color: var(--muted);
  line-height: 1.65;
  font-size: 14px;
}

/* 02 - QUEM SOMOS */
.about-manifest-grid {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 58px;
  align-items: start;
}

.about-manifest-title h2 {
  margin-top: 12px;
  font-size: clamp(30px, 3.8vw, 54px);
  line-height: 1.04;
  letter-spacing: -2px;
}

.about-manifest-text {
  display: grid;
  gap: 18px;
  padding: 34px;
  border-radius: 30px;
  background: #f8f9fc;
  border: 1px solid var(--line);
}

.about-manifest-text p {
  margin: 0;
  color: var(--muted);
  line-height: 1.85;
  font-size: 17px;
}

/* 03 - MÉTODO */
.method-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 44px;
}

.method-step {
  position: relative;
  overflow: hidden;
  padding: 28px;
  border-radius: 28px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 18px 45px rgba(11,24,75,.055);
  transition: .25s ease;
}

.method-step::before {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 4px;
  background: linear-gradient(90deg, var(--blue), rgba(39,98,255,.12));
  opacity: .65;
}

.method-step:hover {
  transform: translateY(-6px);
  box-shadow: 0 26px 60px rgba(11,24,75,.085);
}

.method-step span {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  margin-bottom: 22px;
  border-radius: 14px;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  font-weight: 800;
  font-size: 13px;
}

.method-step h3 {
  margin: 0 0 10px;
  font-size: 20px;
  letter-spacing: -.5px;
}

.method-step p {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
  font-size: 14px;
}


/* 04 - NOSSA EQUIPE */
.about-team {
  position: relative;
  background:
    radial-gradient(circle at 88% 18%, rgba(39,98,255,.10), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f7f9ff 100%);
}

.about-team-panel {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 42px;
  align-items: end;
  margin-bottom: 34px;
  padding: 46px;
  border-radius: 36px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 28px 80px rgba(11,24,75,.075);
  overflow: hidden;
  position: relative;
}

.about-team-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 88% 12%, rgba(39,98,255,.13), transparent 28%),
    linear-gradient(90deg, rgba(255,255,255,.72), rgba(255,255,255,0));
  pointer-events: none;
}

.about-team-intro,
.about-team-mini {
  position: relative;
  z-index: 1;
}

.about-team-intro h2 {
  max-width: 820px;
  margin: 12px 0 18px;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.02;
  letter-spacing: -2px;
}

.about-team-intro p {
  max-width: 660px;
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: 16px;
}

.about-team-signature {
  display: grid;
  gap: 12px;
}

.about-team-signature span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 58px;
  padding: 0 20px;
  border-radius: 18px;
  color: var(--ink);
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 18px 46px rgba(11,24,75,.055);
  font-size: 14px;
  font-weight: 900;
}

.about-team-signature span::after {
  content: "→";
  color: var(--blue);
}


/* MINI EQUIPE NO PAINEL PRINCIPAL */
.about-team-mini {
  align-self: center;
  padding: 22px;
  border-radius: 28px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 70px rgba(11,24,75,.07);
  backdrop-filter: blur(14px);
}

.about-team-mini-head {
  margin-bottom: 18px;
}

.about-team-mini-head .mini-label {
  display: inline-flex;
  align-items: center;
  margin-bottom: 10px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.about-team-mini-head strong {
  display: block;
  max-width: 360px;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
  letter-spacing: -.4px;
}

.about-team-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.mini-member {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 76px;
  padding: 12px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 16px 40px rgba(11,24,75,.05);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.mini-member:hover {
  transform: translateY(-3px);
  border-color: rgba(39,98,255,.16);
  box-shadow: 0 22px 56px rgba(11,24,75,.085);
}

.mini-photo {
  flex: 0 0 46px;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
  color: #fff;
  background:
    radial-gradient(circle at 76% 18%, rgba(255,255,255,.28), transparent 30%),
    linear-gradient(135deg, #071b63, #2463ff);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 12px 26px rgba(11,24,75,.14);
}

.mini-photo span {
  position: relative;
  z-index: 1;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
}

.mini-member h4 {
  margin: 0 0 3px;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.1;
}

.mini-member p {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.about-team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.about-team-card {
  position: relative;
  overflow: hidden;
  min-height: 330px;
  padding: 28px;
  border-radius: 32px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 64px rgba(11,24,75,.075);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.about-team-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 12%, rgba(39,98,255,.12), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,0));
  pointer-events: none;
}

.about-team-card:hover {
  transform: translateY(-6px);
  border-color: rgba(39,98,255,.18);
  box-shadow: 0 34px 82px rgba(11,24,75,.11);
}

.about-team-card.featured {
  background: linear-gradient(135deg, #06185f, #1557e6);
  color: #fff;
}

.about-team-card.featured::before {
  background:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px),
    radial-gradient(circle at 86% 14%, rgba(255,255,255,.18), transparent 28%);
  background-size: 44px 44px, 44px 44px, auto;
  opacity: .5;
}

.team-avatar {
  position: relative;
  z-index: 1;
  width: 72px;
  height: 72px;
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 70px;
  background: rgba(39,98,255,.09);
  color: var(--blue);
  border: 1px solid rgba(39,98,255,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.55);
}

.team-avatar span {
  font-size: 15px;
  font-weight: 900;
  letter-spacing: .08em;
}

.about-team-card.featured .team-avatar {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: rgba(255,255,255,.18);
}

.team-card-content {
  position: relative;
  z-index: 1;
}

.team-card-content small {
  display: block;
  margin-bottom: 12px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.about-team-card.featured .team-card-content small {
  color: rgba(255,255,255,.72);
}

.team-card-content h3 {
  margin: 0 0 12px;
  font-size: 24px;
  line-height: 1.12;
  letter-spacing: -.8px;
}

.team-card-content p {
  margin: 0;
  color: var(--muted);
  line-height: 1.72;
  font-size: 15px;
}

.about-team-card.featured .team-card-content p {
  color: rgba(255,255,255,.76);
}

/* 04 - MISSÃO VISÃO VALORES */
.mvv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 42px;
}

.mvv-card {
  position: relative;
  padding: 32px;
  border-radius: 30px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 20px 50px rgba(11,24,75,.055);
}

.mvv-card.featured {
  background:
    radial-gradient(circle at 20% 18%, rgba(39,98,255,.12), transparent 34%),
    #ffffff;
  transform: translateY(-10px);
  box-shadow: 0 30px 72px rgba(11,24,75,.10);
}

.mvv-icon {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  background: rgba(39,98,255,.08);
  color: var(--blue);
}

.mvv-icon i {
  width: 25px;
  height: 25px;
  stroke-width: 2.3;
}

.mvv-card small {
  display: block;
  margin-bottom: 12px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
}

.mvv-card h3 {
  margin: 0 0 12px;
  font-size: 22px;
  line-height: 1.18;
  letter-spacing: -.75px;
}

.mvv-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.72;
}

/* 05 - PRINCÍPIOS */
.about-principles-box {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 48px;
  align-items: center;
  padding: 46px;
  border-radius: 36px;
  background:
    linear-gradient(135deg, #06185f, #12358f);
  color: #fff;
  box-shadow: 0 30px 80px rgba(6,24,95,.18);
}

.principles-copy .eyebrow {
  color: rgba(255,255,255,.72);
}

.principles-copy h2 {
  margin: 14px 0 16px;
  font-size: clamp(30px, 3.4vw, 50px);
  line-height: 1.03;
  letter-spacing: -1.8px;
  color: #fff;
}

.principles-copy p {
  margin: 0;
  color: rgba(255,255,255,.74);
  line-height: 1.75;
}

.principles-list-v2 {
  display: grid;
  gap: 12px;
}

.principles-list-v2 div {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
}

.principles-list-v2 i {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  color: #fff;
  stroke-width: 2.6;
}

.principles-list-v2 span {
  color: rgba(255,255,255,.9);
  font-weight: 700;
  line-height: 1.45;
}

/* 06 - CTA FINAL */
.about-final-cta .cta-box {
  text-align: center;
}

/* RESPONSIVO */
@media (max-width: 1080px) {
  .method-steps {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 980px) {
  .about-hero-v2-grid,
  .about-manifest-grid,
  .about-principles-box {
    grid-template-columns: 1fr;
  }

  .mvv-grid {
    grid-template-columns: 1fr;
  }

  .about-team-head,
  
/* MINI EQUIPE NO PAINEL PRINCIPAL */
.about-team-mini {
  align-self: center;
  padding: 22px;
  border-radius: 28px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 70px rgba(11,24,75,.07);
  backdrop-filter: blur(14px);
}

.about-team-mini-head {
  margin-bottom: 18px;
}

.about-team-mini-head .mini-label {
  display: inline-flex;
  align-items: center;
  margin-bottom: 10px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.about-team-mini-head strong {
  display: block;
  max-width: 360px;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
  letter-spacing: -.4px;
}

.about-team-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.mini-member {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 76px;
  padding: 12px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 16px 40px rgba(11,24,75,.05);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.mini-member:hover {
  transform: translateY(-3px);
  border-color: rgba(39,98,255,.16);
  box-shadow: 0 22px 56px rgba(11,24,75,.085);
}

.mini-photo {
  flex: 0 0 46px;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
  color: #fff;
  background:
    radial-gradient(circle at 76% 18%, rgba(255,255,255,.28), transparent 30%),
    linear-gradient(135deg, #071b63, #2463ff);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 12px 26px rgba(11,24,75,.14);
}

.mini-photo span {
  position: relative;
  z-index: 1;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
}

.mini-member h4 {
  margin: 0 0 3px;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.1;
}

.mini-member p {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.about-team-grid {
    grid-template-columns: 1fr;
  }

  .mvv-card.featured {
    transform: none;
  }
}

@media (max-width: 680px) {
  .about-hero-v2 {
    padding-top: 126px;
  }

  .about-hero-v2-copy h1 {
    letter-spacing: -1.8px;
  }

  .about-hero-v2-actions {
    flex-direction: column;
  }

  .about-hero-v2-actions .btn {
    width: 100%;
  }

  .about-signature-card,
  .about-manifest-text,
  .about-principles-box,
  .about-team-card {
    padding: 26px;
    border-radius: 26px;
  }

  .team-avatar {
    margin-bottom: 48px;
  }

  .signature-metrics,
  .method-steps {
    grid-template-columns: 1fr;
  }
}


/* ====================================
   SOBRE PAGE - REFINO FINAL DE BLOCOS
   Hero visual, Quem Somos e CTA final.
==================================== */

/* HERO VISUAL DIREITO */
.about-signature-card.premium {
  min-height: 470px;
  padding: 32px;
}

.about-signature-card.premium .signature-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.signature-status {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(37, 211, 102, .10);
  color: #15934f;
  font-size: 12px;
  font-weight: 800;
}

.signature-status::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #25d366;
  box-shadow: 0 0 0 5px rgba(37, 211, 102, .13);
}

.signature-orbit {
  position: relative;
  z-index: 1;
  height: 172px;
  margin: 32px 0 24px;
  border-radius: 28px;
  background:
    radial-gradient(circle at center, rgba(39,98,255,.13), transparent 36%),
    linear-gradient(135deg, rgba(39,98,255,.055), rgba(255,255,255,.75));
  border: 1px solid rgba(16,35,92,.07);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.signature-orbit::before,
.signature-orbit::after {
  content: "";
  position: absolute;
  border: 1px solid rgba(39,98,255,.13);
  border-radius: 999px;
}

.signature-orbit::before {
  width: 220px;
  height: 92px;
  transform: rotate(-12deg);
}

.signature-orbit::after {
  width: 160px;
  height: 160px;
}

.orbit-core {
  position: relative;
  z-index: 2;
  width: 118px;
  height: 118px;
  border-radius: 32px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 60px rgba(11,24,75,.10);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.orbit-core i {
  width: 28px;
  height: 28px;
  color: var(--blue);
  stroke-width: 2.3;
}

.orbit-core strong {
  font-size: 12px;
  color: var(--text);
  letter-spacing: -.2px;
}

.orbit-dot {
  position: absolute;
  z-index: 3;
  width: 13px;
  height: 13px;
  border-radius: 999px;
  background: var(--blue);
  box-shadow: 0 0 0 8px rgba(39,98,255,.10);
}

.orbit-dot.dot-1 { top: 38px; left: 64px; }
.orbit-dot.dot-2 { right: 72px; top: 54px; background: #ff8c42; box-shadow: 0 0 0 8px rgba(255,140,66,.12); }
.orbit-dot.dot-3 { bottom: 38px; left: 50%; transform: translateX(-50%); background: #25d366; box-shadow: 0 0 0 8px rgba(37,211,102,.12); }

.about-signature-card.premium .signature-metrics {
  grid-template-columns: repeat(3, 1fr);
}

.about-signature-card.premium .signature-metrics article {
  padding: 16px 14px;
}

.about-signature-card.premium .signature-metrics strong {
  font-size: 28px;
}

.about-signature-card.premium .signature-metrics span {
  font-size: 12px;
  line-height: 1.35;
}

/* QUEM SOMOS DIREITO */
.about-manifest-panel {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 18px;
  padding: 34px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 85% 10%, rgba(39,98,255,.12), transparent 28%),
    #f8f9fc;
  border: 1px solid var(--line);
  box-shadow: 0 18px 50px rgba(11,24,75,.055);
}

.about-manifest-panel::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 24px;
  border: 1px solid rgba(16,35,92,.055);
  pointer-events: none;
}

.manifest-panel-head {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(16,35,92,.08);
}

.manifest-panel-head span {
  color: var(--blue);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 900;
}

.manifest-panel-head strong {
  font-size: 24px;
  line-height: 1.15;
  letter-spacing: -.8px;
  color: var(--text);
}

.about-manifest-panel p {
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--muted);
  line-height: 1.82;
  font-size: 16px;
}

.manifest-highlights {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.manifest-highlights div {
  min-height: 96px;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.065);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 14px;
}

.manifest-highlights i {
  width: 20px;
  height: 20px;
  color: var(--blue);
  stroke-width: 2.4;
}

.manifest-highlights span {
  color: #263252;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.35;
}

/* CTA FINAL SOBRE - PREMIUM REFINADO */
.about-final-cta {
  padding: 94px 0 86px;
  background: #f6f8fc;
}

.about-next-box {
  position: relative;
  overflow: hidden;
  padding: 54px;
  border-radius: 34px;
  background:
    linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px),
    radial-gradient(circle at 18% 22%, rgba(255,255,255,.14), transparent 28%),
    linear-gradient(145deg, #071a50 0%, #082c79 56%, #0b57df 100%);
  background-size: 56px 56px, 56px 56px, auto, auto;
  color: #fff;
  box-shadow: 0 34px 90px rgba(6,24,95,.20);
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 54px;
  align-items: center;
}

.about-next-box::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.13);
  pointer-events: none;
}

.next-glow {
  position: absolute;
  width: 240px;
  height: 240px;
  left: 98px;
  top: 64px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,255,255,.18), rgba(255,255,255,.04) 58%, transparent 70%);
  filter: blur(.5px);
  pointer-events: none;
}

.about-next-content {
  position: relative;
  z-index: 1;
  max-width: 560px;
  justify-self: end;
  order: 2;
}

.about-next-content .eyebrow {
  display: inline-flex;
  margin-bottom: 16px;
}

.about-next-content h2 {
  color: #fff;
  margin: 0 0 18px;
  font-size: clamp(34px, 4.1vw, 56px);
  line-height: 1.02;
  letter-spacing: -2px;
}

.about-next-content p {
  max-width: 520px;
  margin: 0 0 28px;
  color: rgba(255,255,255,.78);
  font-size: 16px;
  line-height: 1.72;
}

.about-next-content .center-actions {
  justify-content: flex-start;
}

.about-next-proof {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 14px;
  width: 100%;
  max-width: 430px;
  align-self: end;
  order: 1;
}

.about-next-proof div {
  min-height: 58px;
  padding: 16px 20px;
  border-radius: 16px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.about-next-proof strong {
  color: #fff;
  font-size: 17px;
  letter-spacing: -.3px;
}

.about-next-proof span {
  color: rgba(255,255,255,.86);
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 980px) {
  .about-next-box {
    grid-template-columns: 1fr;
    padding: 42px;
    gap: 34px;
  }

  .about-next-content,
  .about-next-proof {
    order: initial;
    justify-self: start;
    max-width: 100%;
  }

  .manifest-highlights {
    grid-template-columns: 1fr;
  }

  .about-signature-card.premium .signature-metrics {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .about-final-cta {
    padding: 72px 0;
  }

  .about-next-box {
    padding: 32px 24px;
    border-radius: 28px;
  }

  .about-next-content h2 {
    letter-spacing: -1.3px;
  }

  .about-next-content .center-actions {
    align-items: stretch;
  }

  .about-next-content .center-actions .btn {
    width: 100%;
  }

  .signature-orbit {
    height: 150px;
  }

  .orbit-core {
    width: 104px;
    height: 104px;
  }
}

/* ====================================
   SOBRE - HERO INSTITUCIONAL FINAL
   Força a fusão visual do Hero + Quem Somos.
==================================== */
.about-hero-institutional {
  padding-top: 150px;
  background:
    radial-gradient(circle at 82% 12%, rgba(39, 98, 255, .14), transparent 34%),
    radial-gradient(circle at 10% 18%, rgba(255, 140, 66, .08), transparent 28%),
    linear-gradient(180deg, #f8faff 0%, #ffffff 86%);
}

.about-hero-institutional-grid {
  display: grid;
  grid-template-columns: 1.04fr .96fr;
  gap: 64px;
  align-items: center;
}

.about-hero-institutional-copy h1 {
  max-width: 760px;
  margin: 14px 0 20px;
  font-size: clamp(42px, 5.4vw, 74px);
  line-height: .95;
  letter-spacing: -3px;
}

.about-lead {
  max-width: 660px;
  margin: 0 0 24px;
  color: #263252;
  font-size: 19px;
  line-height: 1.72;
  font-weight: 600;
}

.about-institutional-text {
  position: relative;
  max-width: 690px;
  display: grid;
  gap: 14px;
  margin: 0 0 30px;
  padding: 22px 24px;
  border-radius: 26px;
  background: rgba(255,255,255,.66);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 18px 50px rgba(11,24,75,.045);
}

.about-institutional-text::before {
  content: "";
  position: absolute;
  left: 0;
  top: 24px;
  bottom: 24px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--blue), rgba(39,98,255,.16));
}

.about-institutional-text p {
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.78;
}

/* Esconde qualquer bloco antigo de Quem Somos que ainda tenha sobrado por cache/classe */
.about-manifest,
.about-story {
  display: none !important;
}

@media (max-width: 980px) {
  .about-hero-institutional-grid {
    grid-template-columns: 1fr;
    gap: 42px;
  }
}

@media (max-width: 680px) {
  .about-hero-institutional {
    padding-top: 126px;
  }

  .about-hero-institutional-copy h1 {
    letter-spacing: -1.9px;
  }

  .about-lead {
    font-size: 17px;
  }

  .about-institutional-text {
    padding: 20px;
    border-radius: 22px;
  }
}




/* =========================
   SOBRE INTRO PREMIUM
========================= */
.sobre-intro-premium {
  padding-top: 136px;
  padding-bottom: 78px;
  background:
    radial-gradient(circle at 86% 10%, rgba(0, 102, 255, 0.10), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
  overflow: hidden;
}

.sobre-intro-premium-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(360px, 0.72fr);
  gap: 56px;
  align-items: center;
}

.sobre-intro-copy h1 {
  margin: 16px 0 18px;
  max-width: 740px;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.02;
  letter-spacing: -2.4px;
}

.sobre-intro-copy p {
  max-width: 680px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75;
}

.sobre-intro-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 30px;
}

.sobre-intro-panel {
  position: relative;
  padding: 28px;
  border-radius: 30px;
  color: #ffffff;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.22), transparent 32%),
    linear-gradient(145deg, #06175f 0%, #082a86 52%, #005cff 100%);
  box-shadow: 0 26px 70px rgba(8, 31, 112, 0.24);
  overflow: hidden;
}

.sobre-intro-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.075) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.075) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.72), transparent 86%);
  pointer-events: none;
}

.sobre-intro-panel::after {
  content: '';
  position: absolute;
  width: 220px;
  height: 220px;
  right: -70px;
  bottom: -90px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  filter: blur(2px);
  pointer-events: none;
}

.sobre-panel-top,
.sobre-panel-flow,
.sobre-panel-bottom {
  position: relative;
  z-index: 1;
}

.sobre-panel-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 18px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.20);
  color: rgba(255, 255, 255, 0.88);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.sobre-panel-top strong {
  display: block;
  max-width: 380px;
  font-size: 26px;
  line-height: 1.14;
  letter-spacing: -0.8px;
}

.sobre-panel-top p {
  margin-top: 14px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.7;
}

.sobre-panel-flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 28px 0;
}

.sobre-panel-flow div {
  padding: 16px 12px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(10px);
}

.sobre-panel-flow span {
  display: block;
  margin-bottom: 8px;
  color: rgba(255, 255, 255, 0.58);
  font-size: 12px;
  font-weight: 800;
}

.sobre-panel-flow strong {
  font-size: 13px;
  color: #ffffff;
}

.sobre-panel-bottom {
  display: grid;
  gap: 12px;
}

.sobre-panel-bottom div {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.sobre-panel-bottom i {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.sobre-panel-bottom span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 14px;
  font-weight: 700;
}

@media (max-width: 920px) {
  .sobre-intro-premium-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .sobre-intro-panel {
    max-width: 560px;
  }
}

@media (max-width: 720px) {
  .sobre-intro-premium {
    padding-top: 118px;
    padding-bottom: 54px;
  }

  .sobre-intro-copy h1 {
    letter-spacing: -1.6px;
  }

  .sobre-intro-actions {
    flex-direction: column;
  }

  .sobre-intro-actions .btn {
    width: 100%;
    justify-content: center;
  }

  .sobre-intro-panel {
    padding: 22px;
    border-radius: 24px;
  }

  .sobre-panel-flow {
    grid-template-columns: 1fr;
  }
}

/* HERO MINIMAL PREMIUM */
.about-hero-minimal {
  padding-top: 140px;
}

.about-hero-minimal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.hero-minimal-left h1 {
  font-size: 52px;
  line-height: 1.05;
  margin: 15px 0;
}

.hero-minimal-left p {
  font-size: 18px;
  color: #555;
  max-width: 500px;
}

.hero-actions {
  margin-top: 25px;
  display: flex;
  gap: 12px;
}

.hero-glass-card {
  position: relative;
  height: 320px;
  border-radius: 30px;
  background: rgba(255,255,255,0.6);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(0,0,0,0.05);
  box-shadow: 0 30px 80px rgba(0,0,0,0.08);
  overflow: hidden;
}

.glass-layer {
  position: absolute;
  width: 200px;
  height: 200px;
  background: rgba(0, 102, 255, 0.15);
  filter: blur(80px);
  top: -40px;
  right: -40px;
}

.glass-content {
  position: relative;
  padding: 30px;
}

.glass-line {
  height: 10px;
  background: #eaeaea;
  border-radius: 20px;
  margin-bottom: 10px;
}

.glass-line.short {
  width: 60%;
}

.glass-blocks {
  display: flex;
  gap: 10px;
  margin-top: 20px;
}

.glass-blocks span {
  flex: 1;
  height: 40px;
  background: #f1f1f1;
  border-radius: 12px;
}

@media(max-width: 900px){
  .about-hero-minimal-grid{
    grid-template-columns: 1fr;
  }
}


/* FIX VISUAL HERO RIGHT */
.hero-glass-card {
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(0,0,0,0.08);
}

.glass-line {
  height: 12px;
  background: linear-gradient(90deg, #dcdcdc, #f5f5f5);
}

.glass-blocks span {
  background: linear-gradient(135deg, #e6e6e6, #f8f8f8);
}

.hero-glass-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 30px;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.04);
}


/* ====================================
   SOBRE HERO - APPLE BRAND VISUAL
   Visual direito novo, clean premium, sem dashboard genérico.
==================================== */
.hero-glass-card,
.hero-value-dashboard,
.about-strategy-panel {
  display: none !important;
}

.apple-brand-visual {
  position: relative;
  min-height: 470px;
  display: flex;
  align-items: center;
  justify-content: center;
  isolation: isolate;
}

.apple-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(8px);
  pointer-events: none;
  z-index: 0;
}

.apple-glow-a {
  width: 280px;
  height: 280px;
  top: 12px;
  right: 18px;
  background: rgba(39, 98, 255, .16);
}

.apple-glow-b {
  width: 220px;
  height: 220px;
  left: 26px;
  bottom: 18px;
  background: rgba(255, 140, 66, .10);
}

.brand-window {
  position: relative;
  z-index: 2;
  width: min(100%, 520px);
  min-height: 390px;
  border-radius: 34px;
  background: rgba(255, 255, 255, .78);
  border: 1px solid rgba(16, 35, 92, .08);
  box-shadow:
    0 38px 90px rgba(11, 24, 75, .13),
    inset 0 1px 0 rgba(255,255,255,.7);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  overflow: hidden;
}

.brand-window::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 12%, rgba(39,98,255,.11), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.50), rgba(247,250,255,.55));
  pointer-events: none;
}

.brand-window::after {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 26px;
  border: 1px solid rgba(16,35,92,.055);
  pointer-events: none;
}

.brand-window-top {
  position: relative;
  z-index: 2;
  height: 54px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 24px;
  border-bottom: 1px solid rgba(16,35,92,.06);
  background: rgba(255,255,255,.42);
}

.brand-window-top span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(16,35,92,.18);
}

.brand-window-top span:nth-child(1) { background: rgba(255, 95, 86, .72); }
.brand-window-top span:nth-child(2) { background: rgba(255, 189, 46, .72); }
.brand-window-top span:nth-child(3) { background: rgba(39, 201, 63, .72); }

.brand-window-body {
  position: relative;
  z-index: 2;
  padding: 28px;
}

.brand-focus-card {
  max-width: 330px;
  padding: 24px;
  border-radius: 26px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 22px 55px rgba(11,24,75,.075);
}

.brand-focus-card small {
  display: block;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
}

.brand-focus-card strong {
  display: block;
  color: var(--text);
  font-size: 25px;
  line-height: 1.1;
  letter-spacing: -1px;
  margin-bottom: 12px;
}

.brand-focus-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.brand-flow {
  position: absolute;
  right: 28px;
  top: 122px;
  width: 142px;
  display: grid;
  gap: 10px;
}

.brand-flow div {
  min-height: 48px;
  padding: 0 13px;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 14px 34px rgba(11,24,75,.06);
  display: flex;
  align-items: center;
  gap: 9px;
}

.brand-flow i {
  width: 17px;
  height: 17px;
  color: var(--blue);
  stroke-width: 2.5;
}

.brand-flow span {
  color: #263252;
  font-size: 12px;
  font-weight: 800;
}

.flow-line {
  width: 1px;
  height: 16px;
  margin-left: 24px;
  background: rgba(39,98,255,.20);
}

.brand-floating-card {
  position: absolute;
  z-index: 3;
  min-width: 170px;
  padding: 16px 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 20px 50px rgba(11,24,75,.08);
}

.brand-floating-card strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  letter-spacing: -.3px;
}

.brand-floating-card span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.brand-floating-card.card-a {
  left: 30px;
  bottom: 34px;
}

.brand-floating-card.card-b {
  right: 28px;
  bottom: 54px;
}

.brand-bottom-pill {
  position: absolute;
  z-index: 4;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 42%);
  width: min(92%, 430px);
  min-height: 58px;
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 22px 52px rgba(11,24,75,.10);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  display: flex;
  align-items: center;
  gap: 10px;
}

.brand-bottom-pill i {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  color: #25b866;
  stroke-width: 2.5;
}

.brand-bottom-pill span {
  color: #263252;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

@media (max-width: 980px) {
  .apple-brand-visual {
    min-height: 500px;
  }
}

@media (max-width: 680px) {
  .apple-brand-visual {
    min-height: auto;
    padding-bottom: 34px;
  }

  .brand-window {
    min-height: auto;
    border-radius: 28px;
  }

  .brand-window-body {
    padding: 22px;
  }

  .brand-focus-card {
    max-width: none;
  }

  .brand-flow {
    position: static;
    width: auto;
    margin-top: 16px;
  }

  .brand-flow .flow-line {
    display: none;
  }

  .brand-floating-card {
    position: static;
    margin-top: 12px;
  }

  .brand-bottom-pill {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    width: 100%;
    margin-top: 14px;
    border-radius: 22px;
  }
}


/* ====================================
   SOBRE HERO - APPLE VISUAL ALINHADO FINAL
   Corrige grid, eixo visual e respiro do bloco direito.
==================================== */

/* neutraliza itens flutuantes desalinhados da versão anterior */
.brand-flow,
.brand-floating-card,
.flow-line {
  display: none !important;
}

.brand-window {
  min-height: 376px !important;
}

.brand-window-body-aligned {
  position: relative;
  z-index: 2;
  padding: 28px !important;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.brand-grid-aligned {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 148px;
  gap: 16px;
  align-items: stretch;
}

.brand-focus-card.aligned {
  max-width: none !important;
  width: 100%;
  min-height: 178px;
  padding: 24px !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.88) !important;
  border: 1px solid rgba(16,35,92,.07) !important;
  box-shadow: 0 22px 55px rgba(11,24,75,.075) !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.brand-focus-card.aligned small {
  display: block;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
}

.brand-focus-card.aligned strong {
  display: block;
  color: var(--text);
  font-size: 25px;
  line-height: 1.12;
  letter-spacing: -1px;
  margin-bottom: 12px;
}

.brand-focus-card.aligned p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
}

.brand-side-aligned {
  display: grid;
  gap: 10px;
}

.brand-pill-aligned {
  min-height: 52px;
  padding: 0 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 14px 34px rgba(11,24,75,.055);
  display: flex;
  align-items: center;
  gap: 9px;
}

.brand-pill-aligned i {
  width: 17px;
  height: 17px;
  color: var(--blue);
  stroke-width: 2.5;
}

.brand-pill-aligned span {
  color: #263252;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: -.1px;
}

.brand-footer-aligned {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.brand-tag-aligned {
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.065);
  box-shadow: 0 16px 40px rgba(11,24,75,.055);
}

.brand-tag-aligned strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  letter-spacing: -.35px;
}

.brand-tag-aligned span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
}

/* pill inferior mais alinhada e menos invasiva */
.brand-bottom-pill {
  bottom: -14px !important;
  width: min(88%, 430px) !important;
  min-height: 54px !important;
  transform: translate(-50%, 28%) !important;
}

@media (max-width: 680px) {
  .brand-grid-aligned {
    grid-template-columns: 1fr;
  }

  .brand-side-aligned {
    grid-template-columns: 1fr;
  }

  .brand-footer-aligned {
    grid-template-columns: 1fr;
  }

  .brand-window {
    min-height: auto !important;
  }

  .brand-bottom-pill {
    position: relative !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    width: 100% !important;
    margin-top: 14px !important;
  }
}


/* ====================================
   PORTFÓLIO PAGE
   Página de portfólio modular, clean e premium.
==================================== */

.portfolio-page {
  overflow: hidden;
}

/* 01 - HERO */
.portfolio-hero {
  padding-top: 150px;
  background:
    radial-gradient(circle at 82% 14%, rgba(39, 98, 255, .13), transparent 32%),
    radial-gradient(circle at 12% 18%, rgba(255, 140, 66, .075), transparent 28%),
    linear-gradient(180deg, #f8faff 0%, #ffffff 86%);
}

.portfolio-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 64px;
  align-items: center;
}

.portfolio-hero-copy h1 {
  max-width: 800px;
  margin: 14px 0 20px;
  font-size: clamp(42px, 5.3vw, 72px);
  line-height: .96;
  letter-spacing: -3px;
}

.portfolio-hero-copy p {
  max-width: 660px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75;
}

.portfolio-hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.portfolio-hero-tags span {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(16,35,92,.08);
  color: #263252;
  font-size: 13px;
  font-weight: 800;
}

.portfolio-visual-card {
  position: relative;
  overflow: hidden;
  padding: 30px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 82% 14%, rgba(39,98,255,.13), transparent 32%),
    rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.09);
  box-shadow: 0 34px 90px rgba(11,24,75,.12);
  backdrop-filter: blur(18px);
}

.portfolio-visual-card::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 26px;
  border: 1px solid rgba(39,98,255,.075);
  pointer-events: none;
}

.portfolio-visual-top {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 24px;
}

.portfolio-visual-top span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.portfolio-visual-top strong {
  color: var(--blue);
  font-size: 13px;
}

.portfolio-mini-list {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
}

.portfolio-mini-list article {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border-radius: 22px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 14px 34px rgba(11,24,75,.045);
}

.portfolio-mini-list small {
  width: 44px;
  height: 44px;
  border-radius: 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  font-weight: 900;
}

.portfolio-mini-list strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  margin-bottom: 4px;
}

.portfolio-mini-list span {
  color: var(--muted);
  font-size: 13px;
}

/* 02 - FILTROS */
.portfolio-filter-section {
  padding: 12px 0 0;
}

.portfolio-filter-bar {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}

.portfolio-filter-bar span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.portfolio-filter-bar span.active {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
}

/* 03 - PROJETOS */
.portfolio-projects {
  background: #f8f9fc;
}

.portfolio-grid-v2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 42px;
}

.portfolio-card-v2 {
  min-height: 100%;
}

.portfolio-card-link {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 30px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 20px 52px rgba(11,24,75,.06);
  text-decoration: none;
  color: inherit;
  transition: .25s ease;
}

.portfolio-card-link:hover {
  transform: translateY(-7px);
  box-shadow: 0 30px 70px rgba(11,24,75,.10);
}

.portfolio-card-cover {
  position: relative;
  min-height: 190px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 20px;
  overflow: hidden;
}

.portfolio-card-cover::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.42);
}

.portfolio-card-cover::after {
  content: "";
  position: absolute;
  right: -40px;
  bottom: -60px;
  width: 180px;
  height: 180px;
  border-radius: 999px;
  background: rgba(255,255,255,.35);
  filter: blur(2px);
}

.portfolio-card-cover span {
  position: relative;
  z-index: 1;
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  color: #263252;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.cover-underline {
  background:
    radial-gradient(circle at 82% 16%, rgba(39,98,255,.22), transparent 32%),
    linear-gradient(135deg, #edf4ff, #f8f0ff);
}

.cover-panel {
  background:
    radial-gradient(circle at 82% 16%, rgba(37,211,102,.18), transparent 32%),
    linear-gradient(135deg, #edf7ff, #f1fbf7);
}

.cover-sports {
  background:
    radial-gradient(circle at 82% 16%, rgba(255,140,66,.20), transparent 32%),
    linear-gradient(135deg, #fff4eb, #f3f6ff);
}

.portfolio-card-body {
  flex: 1;
  padding: 26px;
  display: flex;
  flex-direction: column;
}

.portfolio-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.portfolio-card-meta small {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(39,98,255,.07);
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
}

.portfolio-card-body h3 {
  margin: 0 0 12px;
  font-size: 24px;
  line-height: 1.1;
  letter-spacing: -.8px;
}

.portfolio-card-body p {
  margin: 0 0 20px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.72;
}

.portfolio-card-result {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  padding-top: 4px;
}

.portfolio-card-result span {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  background: #f8f9fc;
  border: 1px solid rgba(16,35,92,.06);
  color: #263252;
  font-size: 11px;
  font-weight: 800;
}

.portfolio-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 22px;
  color: var(--blue);
  font-size: 14px;
}

.portfolio-card-cta i {
  width: 16px;
  height: 16px;
  stroke-width: 2.4;
}

/* 04 - THINKING */
.portfolio-thinking-box {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 44px;
  align-items: center;
  padding: 46px;
  border-radius: 36px;
  background:
    radial-gradient(circle at 12% 18%, rgba(39,98,255,.10), transparent 30%),
    #f8f9fc;
  border: 1px solid var(--line);
}

.portfolio-thinking-copy h2 {
  margin: 12px 0 16px;
  font-size: clamp(30px, 3.5vw, 50px);
  line-height: 1.04;
  letter-spacing: -1.8px;
}

.portfolio-thinking-copy p {
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
}

.portfolio-thinking-list {
  display: grid;
  gap: 13px;
}

.portfolio-thinking-list div {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(16,35,92,.065);
}

.portfolio-thinking-list i {
  width: 19px;
  height: 19px;
  color: var(--blue);
  stroke-width: 2.5;
}

.portfolio-thinking-list span {
  color: #263252;
  font-weight: 800;
  line-height: 1.4;
}

/* 05 - CTA */
.portfolio-cta .cta-box {
  text-align: center;
}

/* RESPONSIVO */
@media (max-width: 1080px) {
  .portfolio-grid-v2 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 980px) {
  .portfolio-hero-grid,
  .portfolio-thinking-box {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .portfolio-hero {
    padding-top: 126px;
  }

  .portfolio-hero-copy h1 {
    letter-spacing: -1.8px;
  }

  .portfolio-grid-v2 {
    grid-template-columns: 1fr;
  }

  .portfolio-thinking-box {
    padding: 28px;
    border-radius: 28px;
  }
}


/* ====================================
   PORTFÓLIO PAGE V3 - AGÊNCIA PREMIUM
   Sem hero decorativo. Projetos como protagonistas.
==================================== */

.portfolio-page-v3 {
  overflow: hidden;
  background: #f8f9fc;
}

/* 01 - INTRO */
.portfolio-intro-v3 {
  padding-top: 150px;
  padding-bottom: 58px;
  background:
    radial-gradient(circle at 82% 8%, rgba(39,98,255,.12), transparent 32%),
    radial-gradient(circle at 10% 12%, rgba(255,140,66,.07), transparent 26%),
    linear-gradient(180deg, #f8faff 0%, #f8f9fc 100%);
}

.portfolio-intro-shell {
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

.portfolio-intro-shell h1 {
  margin: 14px auto 18px;
  max-width: 900px;
  font-size: clamp(38px, 5vw, 68px);
  line-height: .98;
  letter-spacing: -2.8px;
}

.portfolio-intro-shell p {
  max-width: 720px;
  margin: 0 auto;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.76;
}

.portfolio-filter-bar-v3 {
  width: fit-content;
  max-width: 100%;
  margin: 34px auto 0;
  padding: 8px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 18px 48px rgba(11,24,75,.06);
}

.portfolio-filter-bar-v3 button {
  border: 0;
  min-height: 38px;
  padding: 0 15px;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font-family: inherit;
  font-size: 13px;
  font-weight: 850;
  cursor: default;
}

.portfolio-filter-bar-v3 button.active {
  background: var(--blue);
  color: #fff;
  box-shadow: 0 10px 24px rgba(39,98,255,.18);
}

/* 02 - PROJECTS */
.portfolio-projects-v3 {
  padding-top: 32px;
  background: #f8f9fc;
}

.portfolio-grid-v3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}

.portfolio-card-v3 {
  height: 100%;
}

.portfolio-card-link-v3 {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 34px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 62px rgba(11,24,75,.07);
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.portfolio-card-link-v3:hover {
  transform: translateY(-8px);
  box-shadow: 0 36px 86px rgba(11,24,75,.12);
  border-color: rgba(39,98,255,.16);
}

.portfolio-card-cover-v3 {
  position: relative;
  min-height: 210px;
  padding: 22px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  overflow: hidden;
}

.portfolio-card-cover-v3::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.48);
}

.portfolio-card-cover-v3::after {
  content: "";
  position: absolute;
  right: -50px;
  bottom: -70px;
  width: 210px;
  height: 210px;
  border-radius: 999px;
  background: rgba(255,255,255,.42);
}

.portfolio-card-cover-v3 > span,
.project-year {
  position: relative;
  z-index: 2;
}

.portfolio-card-cover-v3 > span {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  color: #263252;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.project-year {
  width: 48px;
  height: 48px;
  border-radius: 17px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(255,255,255,.56);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  font-size: 12px;
  font-weight: 950;
}

.portfolio-card-content-v3 {
  flex: 1;
  padding: 28px;
  display: flex;
  flex-direction: column;
}

.project-type {
  width: fit-content;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 11px;
  margin-bottom: 16px;
  border-radius: 999px;
  background: rgba(39,98,255,.07);
  color: var(--blue);
  font-size: 11px;
  font-weight: 950;
}

.portfolio-card-content-v3 h2 {
  margin: 0 0 12px;
  font-size: 26px;
  line-height: 1.05;
  letter-spacing: -1px;
}

.portfolio-card-content-v3 p {
  margin: 0 0 24px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.72;
}

.project-impact {
  margin-top: auto;
  padding: 18px;
  border-radius: 22px;
  background: #f8f9fc;
  border: 1px solid rgba(16,35,92,.06);
}

.project-impact strong {
  display: block;
  margin-bottom: 11px;
  color: var(--text);
  font-size: 13px;
  letter-spacing: -.2px;
}

.project-impact ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.project-impact li {
  position: relative;
  padding-left: 17px;
  color: #44506f;
  font-size: 12px;
  line-height: 1.4;
  font-weight: 750;
}

.project-impact li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--blue);
}

.project-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 22px;
  color: var(--blue);
  font-size: 14px;
  font-weight: 900;
}

.project-card-footer i {
  width: 17px;
  height: 17px;
  stroke-width: 2.5;
}

/* 03 - THINKING PREMIUM */
.portfolio-thinking-v3 {
  background: #f8f9fc;
}

.portfolio-thinking-panel-v3 {
  position: relative;
  overflow: hidden;
  padding: 56px;
  border-radius: 42px;
  background:
    radial-gradient(circle at 14% 16%, rgba(255,255,255,.18), transparent 30%),
    linear-gradient(135deg, #06185f, #12358f 58%, #2762ff);
  color: #fff;
  box-shadow: 0 36px 94px rgba(6,24,95,.22);
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 48px;
  align-items: center;
}

.portfolio-thinking-panel-v3::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 32px;
  border: 1px solid rgba(255,255,255,.13);
  pointer-events: none;
}

.thinking-premium-copy,
.thinking-premium-grid {
  position: relative;
  z-index: 1;
}

.thinking-premium-copy .eyebrow {
  color: rgba(255,255,255,.70);
}

.thinking-premium-copy h2 {
  margin: 14px 0 18px;
  color: #fff;
  font-size: clamp(32px, 4vw, 58px);
  line-height: 1.02;
  letter-spacing: -2px;
}

.thinking-premium-copy p {
  max-width: 590px;
  margin: 0;
  color: rgba(255,255,255,.74);
  font-size: 16px;
  line-height: 1.75;
}

.thinking-premium-grid {
  display: grid;
  gap: 14px;
}

.thinking-premium-grid article {
  padding: 20px 22px;
  border-radius: 24px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.13);
  backdrop-filter: blur(12px);
  display: grid;
  grid-template-columns: 42px 1fr;
  column-gap: 14px;
  row-gap: 4px;
  align-items: center;
}

.thinking-premium-grid i {
  grid-row: span 2;
  width: 42px;
  height: 42px;
  padding: 10px;
  border-radius: 15px;
  background: rgba(255,255,255,.12);
  color: #fff;
  stroke-width: 2.35;
}

.thinking-premium-grid strong {
  color: #fff;
  font-size: 16px;
  letter-spacing: -.3px;
}

.thinking-premium-grid span {
  color: rgba(255,255,255,.72);
  font-size: 13px;
  line-height: 1.45;
}

/* 04 - CTA FINAL PREMIUM */
.portfolio-cta-v3 {
  background: linear-gradient(180deg, #f8f9fc 0%, #ffffff 100%);
}

.portfolio-close-box {
  position: relative;
  overflow: hidden;
  max-width: 1080px;
  margin: 0 auto;
  padding: 64px 52px;
  border-radius: 42px;
  background:
    radial-gradient(circle at 80% 18%, rgba(39,98,255,.14), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.90));
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 34px 90px rgba(11,24,75,.10);
  text-align: center;
}

.portfolio-close-box::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 32px;
  border: 1px solid rgba(39,98,255,.07);
  pointer-events: none;
}

.portfolio-close-box > * {
  position: relative;
  z-index: 1;
}

.portfolio-close-box .eyebrow {
  color: var(--blue);
}

.portfolio-close-box h2 {
  max-width: 760px;
  margin: 14px auto 18px;
  font-size: clamp(32px, 4.2vw, 58px);
  line-height: 1.02;
  letter-spacing: -2px;
}

.portfolio-close-box p {
  max-width: 660px;
  margin: 0 auto 28px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.75;
}

.portfolio-close-box .btn-white {
  background: var(--blue);
  color: #fff;
  box-shadow: 0 18px 40px rgba(39,98,255,.22);
}

.portfolio-close-box .btn-outline-light {
  color: var(--blue);
  border-color: rgba(39,98,255,.18);
  background: rgba(255,255,255,.70);
}

/* RESPONSIVO */
@media (max-width: 1080px) {
  .portfolio-grid-v3 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 980px) {
  .portfolio-thinking-panel-v3 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .portfolio-intro-v3 {
    padding-top: 126px;
  }

  .portfolio-intro-shell h1,
  .thinking-premium-copy h2,
  .portfolio-close-box h2 {
    letter-spacing: -1.5px;
  }

  .portfolio-filter-bar-v3 {
    width: 100%;
    border-radius: 26px;
  }

  .portfolio-grid-v3 {
    grid-template-columns: 1fr;
  }

  .portfolio-thinking-panel-v3,
  .portfolio-close-box {
    padding: 32px 24px;
    border-radius: 30px;
  }

  .thinking-premium-grid article {
    grid-template-columns: 1fr;
  }
}


/* ====================================
   PORTFÓLIO V4 - REFINO CLEAN PREMIUM
   Topo menos gritante, filtros melhores e fechamento unificado.
==================================== */

/* Topo mais elegante */
.portfolio-page-v3 .portfolio-intro-v3 {
  padding-top: 140px !important;
  padding-bottom: 44px !important;
}

.portfolio-page-v3 .portfolio-intro-shell {
  max-width: 860px !important;
}

.portfolio-page-v3 .portfolio-intro-shell h1 {
  max-width: 760px !important;
  font-size: clamp(34px, 4.1vw, 56px) !important;
  line-height: 1.04 !important;
  letter-spacing: -2.1px !important;
  margin-bottom: 16px !important;
}

.portfolio-page-v3 .portfolio-intro-shell p {
  max-width: 650px !important;
  font-size: 16px !important;
  line-height: 1.72 !important;
}

/* Filtros com presença, sem pesar */
.portfolio-page-v3 .portfolio-filter-bar-v3 {
  margin-top: 28px !important;
  padding: 10px !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.86) !important;
  border: 1px solid rgba(16,35,92,.09) !important;
  box-shadow: 0 20px 55px rgba(11,24,75,.075) !important;
}

.portfolio-page-v3 .portfolio-filter-bar-v3 button {
  min-height: 40px !important;
  padding: 0 16px !important;
  border: 1px solid rgba(16,35,92,.06) !important;
  background: #f8f9fc !important;
  color: #263252 !important;
  transition: .22s ease;
}

.portfolio-page-v3 .portfolio-filter-bar-v3 button.active {
  background: var(--blue) !important;
  border-color: var(--blue) !important;
  color: #fff !important;
  box-shadow: 0 12px 28px rgba(39,98,255,.20) !important;
}

.portfolio-page-v3 .portfolio-filter-bar-v3 button:not(.active):hover {
  background: #fff !important;
  border-color: rgba(39,98,255,.16) !important;
  color: var(--blue) !important;
}

/* Menos distância depois da entrada */
.portfolio-page-v3 .portfolio-projects-v3 {
  padding-top: 20px !important;
}

/* Fechamento unificado premium claro */
.portfolio-close-premium-v4 {
  background: linear-gradient(180deg, #f8f9fc 0%, #ffffff 100%);
}

.portfolio-close-panel-v4 {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 44px;
  align-items: center;
  padding: 48px;
  border-radius: 38px;
  background:
    radial-gradient(circle at 86% 16%, rgba(39,98,255,.11), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.92));
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 30px 82px rgba(11,24,75,.10);
}

.portfolio-close-panel-v4::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 30px;
  border: 1px solid rgba(39,98,255,.07);
  pointer-events: none;
}

.close-copy-v4,
.close-points-v4 {
  position: relative;
  z-index: 1;
}

.close-copy-v4 h2 {
  max-width: 610px;
  margin: 12px 0 16px;
  font-size: clamp(30px, 3.5vw, 48px);
  line-height: 1.04;
  letter-spacing: -1.8px;
}

.close-copy-v4 p {
  max-width: 560px;
  margin: 0 0 24px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.76;
}

.close-points-v4 {
  display: grid;
  gap: 14px;
}

.close-points-v4 article {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 14px;
  align-items: center;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(16,35,92,.065);
}

.close-points-v4 i {
  width: 46px;
  height: 46px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  stroke-width: 2.4;
}

.close-points-v4 strong {
  display: block;
  color: var(--text);
  font-size: 16px;
  letter-spacing: -.3px;
  margin-bottom: 4px;
}

.close-points-v4 span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

@media (max-width: 980px) {
  .portfolio-close-panel-v4 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .portfolio-page-v3 .portfolio-intro-v3 {
    padding-top: 126px !important;
  }

  .portfolio-page-v3 .portfolio-intro-shell h1 {
    letter-spacing: -1.4px !important;
  }

  .portfolio-close-panel-v4 {
    padding: 30px 24px;
    border-radius: 30px;
  }

  .close-points-v4 article {
    grid-template-columns: 1fr;
  }
}


/* ====================================
   PORTFÓLIO V4 - AJUSTES FINOS UI
   Filtros, ano dos cards e CTA principal.
==================================== */

/* 1. Filtros com destaque real */
.portfolio-page-v3 .portfolio-filter-bar-v3 {
  background: rgba(255,255,255,.96) !important;
  border: 1px solid rgba(16,35,92,.10) !important;
  box-shadow: 0 22px 58px rgba(11,24,75,.10) !important;
}

.portfolio-page-v3 .portfolio-filter-bar-v3 button {
  background: #eef3ff !important;
  color: #263252 !important;
  border: 1px solid rgba(39,98,255,.10) !important;
  box-shadow: none !important;
}

.portfolio-page-v3 .portfolio-filter-bar-v3 button.active,
.portfolio-page-v3 .portfolio-filter-bar-v3 button:first-child {
  background: #06185f !important;
  color: #ffffff !important;
  border-color: #06185f !important;
  box-shadow: 0 12px 28px rgba(6,24,95,.22) !important;
}

.portfolio-page-v3 .portfolio-filter-bar-v3 button:not(.active):not(:first-child):hover {
  background: #ffffff !important;
  color: #06185f !important;
  border-color: rgba(6,24,95,.18) !important;
}

/* 2. Ano/data do projeto com destaque forte */
.portfolio-page-v3 .project-year {
  background: #06185f !important;
  color: #ffffff !important;
  border-color: rgba(255,255,255,.45) !important;
  box-shadow: 0 14px 30px rgba(6,24,95,.22) !important;
}

/* 3. CTA do bloco final azul e legível */
.portfolio-page-v3 .portfolio-close-panel-v4 .btn,
.portfolio-page-v3 .portfolio-close-panel-v4 .btn-primary {
  background: #06185f !important;
  color: #ffffff !important;
  border-color: #06185f !important;
  box-shadow: 0 18px 38px rgba(6,24,95,.24) !important;
}

.portfolio-page-v3 .portfolio-close-panel-v4 .btn:hover,
.portfolio-page-v3 .portfolio-close-panel-v4 .btn-primary:hover {
  background: #10297a !important;
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: 0 24px 48px rgba(6,24,95,.30) !important;
}

.portfolio-page-v3 .portfolio-close-panel-v4 .btn i {
  color: currentColor !important;
}


/* ====================================
   PORTFÓLIO - BOTÕES DE AÇÃO DEFINITIVOS
   Transforma "Ver detalhes" em botão real e força CTA principal azul.
==================================== */

/* Botão dos cards */
.portfolio-page-v3 .project-card-footer {
  width: fit-content !important;
  min-height: 42px !important;
  margin-top: 24px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  background: #06185f !important;
  color: #ffffff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  box-shadow: 0 14px 30px rgba(6,24,95,.18) !important;
  transition: .22s ease !important;
}

.portfolio-page-v3 .portfolio-card-link-v3:hover .project-card-footer {
  background: #10297a !important;
  transform: translateY(-2px);
  box-shadow: 0 18px 38px rgba(6,24,95,.25) !important;
}

.portfolio-page-v3 .project-card-footer span {
  color: #ffffff !important;
}

.portfolio-page-v3 .project-card-footer i {
  color: #ffffff !important;
  width: 16px !important;
  height: 16px !important;
  stroke-width: 2.6 !important;
}

/* CTA principal do bloco final */
.portfolio-page-v3 .close-copy-v4 > a.btn,
.portfolio-page-v3 .close-copy-v4 > a.btn-primary,
.portfolio-page-v3 .portfolio-close-panel-v4 a.btn,
.portfolio-page-v3 .portfolio-close-panel-v4 a.btn-primary {
  background: #06185f !important;
  color: #ffffff !important;
  border: 1px solid #06185f !important;
  box-shadow: 0 18px 40px rgba(6,24,95,.24) !important;
}

.portfolio-page-v3 .close-copy-v4 > a.btn:hover,
.portfolio-page-v3 .close-copy-v4 > a.btn-primary:hover,
.portfolio-page-v3 .portfolio-close-panel-v4 a.btn:hover,
.portfolio-page-v3 .portfolio-close-panel-v4 a.btn-primary:hover {
  background: #10297a !important;
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: 0 24px 52px rgba(6,24,95,.30) !important;
}

.portfolio-page-v3 .close-copy-v4 > a.btn i,
.portfolio-page-v3 .portfolio-close-panel-v4 a.btn i {
  color: #ffffff !important;
  stroke: currentColor !important;
}


/* ====================================
CTA AZUL CORREÇÃO REAL (SOBREPOE TUDO)
==================================== */

/* força TODOS os botões primários */
.btn-primary,
a.btn-primary,
button.btn-primary {
  background: #06185f !important;
  color: #ffffff !important;
  border: none !important;
}

/* força especificamente no bloco */
.portfolio-close-panel-v4 a,
.portfolio-close-panel-v4 .btn,
.portfolio-close-panel-v4 .btn-primary {
  background: #06185f !important;
  color: #ffffff !important;
  border: none !important;
}

/* força texto interno */
.portfolio-close-panel-v4 a *,
.btn-primary * {
  color: #ffffff !important;
}

/* hover */
.portfolio-close-panel-v4 a:hover,
.btn-primary:hover {
  background: #0c2a8a !important;
  color: #ffffff !important;
}


/* ====================================
BLOCO AZUL PREMIUM (CORREÇÃO FINAL)
==================================== */

/* fundo do bloco inteiro */
.portfolio-close-panel-v4 {
  background: linear-gradient(135deg, #06185f, #0c2a8a) !important;
  color: #ffffff !important;
}

/* borda interna */
.portfolio-close-panel-v4::before {
  border: 1px solid rgba(255,255,255,.15) !important;
}

/* textos */
.portfolio-close-panel-v4 * {
  color: #ffffff !important;
}

/* cards da direita */
.close-points-v4 article {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}

/* botão agora branco */
.portfolio-close-panel-v4 a,
.portfolio-close-panel-v4 .btn,
.portfolio-close-panel-v4 .btn-primary {
  background: #ffffff !important;
  color: #06185f !important;
  border: none !important;
  box-shadow: 0 18px 40px rgba(0,0,0,.15) !important;
}

.portfolio-close-panel-v4 a * {
  color: #06185f !important;
}

.portfolio-close-panel-v4 a:hover {
  background: #f2f4ff !important;
  transform: translateY(-2px);
}


/* ====================================
VERSÃO FINAL PREMIUM - BLOCO + CTA
==================================== */

/* bloco azul híbrido premium */
.portfolio-close-panel-v4 {
  background:
    radial-gradient(circle at 80% 20%, rgba(255,255,255,0.08), transparent 40%),
    linear-gradient(135deg, #041347, #0b2a8f) !important;
  color: #ffffff !important;
}

/* texto branco garantido */
.portfolio-close-panel-v4 * {
  color: #ffffff !important;
}

/* cards internos mais refinados */
.close-points-v4 article {
  background: rgba(255,255,255,0.10) !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  backdrop-filter: blur(6px);
}

/* BOTÃO PREMIUM */
.portfolio-close-panel-v4 a,
.portfolio-close-panel-v4 .btn {
  background: #ffffff !important;
  color: #041347 !important;
  border-radius: 999px !important;
  padding: 0 24px !important;
  min-height: 50px !important;
  font-weight: 900 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  box-shadow: 0 18px 40px rgba(0,0,0,.18) !important;
  transition: all .25s ease !important;
}

/* força cor interna */
.portfolio-close-panel-v4 a * {
  color: #041347 !important;
}

/* hover premium */
.portfolio-close-panel-v4 a:hover {
  transform: translateY(-3px);
  box-shadow: 0 26px 60px rgba(0,0,0,.25) !important;
  background: #f4f7ff !important;
}


/* ====================================
   PORTFÓLIO - CTA BRANCO REAL / FINAL
   Classe exclusiva para não herdar .btn global.
==================================== */

.portfolio-close-panel-v4 .portfolio-premium-cta,
.portfolio-page-v3 .portfolio-premium-cta,
a.portfolio-premium-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: fit-content !important;
  min-height: 52px !important;
  padding: 0 26px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  background-color: #ffffff !important;
  color: #041347 !important;
  text-decoration: none !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  border: 1px solid rgba(255,255,255,.70) !important;
  box-shadow:
    0 18px 40px rgba(0,0,0,.20),
    inset 0 1px 0 rgba(255,255,255,.85) !important;
  opacity: 1 !important;
  mix-blend-mode: normal !important;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease !important;
}

.portfolio-close-panel-v4 .portfolio-premium-cta *,
.portfolio-page-v3 .portfolio-premium-cta *,
a.portfolio-premium-cta * {
  color: #041347 !important;
  stroke: #041347 !important;
  opacity: 1 !important;
}

.portfolio-premium-cta i {
  width: 17px !important;
  height: 17px !important;
  stroke-width: 2.6 !important;
}

.portfolio-close-panel-v4 .portfolio-premium-cta:hover,
.portfolio-page-v3 .portfolio-premium-cta:hover,
a.portfolio-premium-cta:hover {
  background: #f4f7ff !important;
  background-color: #f4f7ff !important;
  color: #041347 !important;
  transform: translateY(-3px) !important;
  box-shadow:
    0 28px 58px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.95) !important;
}

/* reforço visual do bloco para o botão branco se destacar */
.portfolio-close-panel-v4 {
  background:
    radial-gradient(circle at 82% 18%, rgba(255,255,255,.12), transparent 38%),
    linear-gradient(135deg, #03113f 0%, #071f72 54%, #0b2f9a 100%) !important;
}

.portfolio-close-panel-v4 .close-copy-v4 p {
  color: rgba(255,255,255,.78) !important;
}

.portfolio-close-panel-v4 .close-points-v4 article {
  background: rgba(255,255,255,.11) !important;
  border-color: rgba(255,255,255,.16) !important;
}


/* ====================================
   SERVIÇOS PAGE - REBUILD PREMIUM REAL
   CSS modular e isolado da página Serviços.
==================================== */

.services-page-real-premium {
  overflow: hidden;
  background: #f8f9fc;
}

/* 01 - INTRO */
.services-intro-real {
  padding-top: 150px;
  background:
    radial-gradient(circle at 82% 12%, rgba(39,98,255,.13), transparent 32%),
    radial-gradient(circle at 12% 18%, rgba(255,140,66,.07), transparent 28%),
    linear-gradient(180deg, #f8faff 0%, #ffffff 86%);
}

.services-intro-grid-real {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 64px;
  align-items: center;
}

.services-intro-copy-real h1 {
  max-width: 820px;
  margin: 14px 0 20px;
  font-size: clamp(42px, 5.25vw, 72px);
  line-height: .96;
  letter-spacing: -3px;
}

.services-intro-copy-real p {
  max-width: 660px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75;
}

.services-intro-actions-real {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 30px;
}

.services-intro-visual-real {
  position: relative;
}

.services-visual-window-real {
  position: relative;
  overflow: hidden;
  min-height: 430px;
  border-radius: 36px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 38px 90px rgba(11,24,75,.13), inset 0 1px 0 rgba(255,255,255,.7);
  backdrop-filter: blur(20px);
}

.services-visual-window-real::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 12%, rgba(39,98,255,.12), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.50), rgba(247,250,255,.55));
}

.services-window-top-real {
  position: relative;
  z-index: 2;
  height: 54px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 24px;
  border-bottom: 1px solid rgba(16,35,92,.06);
  background: rgba(255,255,255,.42);
}

.services-window-top-real span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.services-window-top-real span:nth-child(1) { background: rgba(255, 95, 86, .72); }
.services-window-top-real span:nth-child(2) { background: rgba(255, 189, 46, .72); }
.services-window-top-real span:nth-child(3) { background: rgba(39, 201, 63, .72); }

.services-window-body-real {
  position: relative;
  z-index: 2;
  padding: 28px;
}

.services-main-card-real {
  padding: 26px;
  border-radius: 28px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 24px 58px rgba(11,24,75,.08);
}

.services-main-card-real small {
  display: block;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
}

.services-main-card-real strong {
  display: block;
  color: var(--text);
  font-size: 26px;
  line-height: 1.1;
  letter-spacing: -1px;
  margin-bottom: 12px;
}

.services-main-card-real p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.services-mini-grid-real {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 11px;
  margin-top: 16px;
}

.services-mini-grid-real div {
  min-height: 84px;
  padding: 14px;
  border-radius: 22px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.065);
  box-shadow: 0 16px 40px rgba(11,24,75,.055);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.services-mini-grid-real i {
  width: 21px;
  height: 21px;
  color: var(--blue);
  stroke-width: 2.5;
}

.services-mini-grid-real strong {
  color: #263252;
  font-size: 13px;
}

.services-mini-grid-real span {
  color: var(--muted);
  font-size: 11px;
}

.services-visual-note-real {
  margin-top: 16px;
  min-height: 58px;
  padding: 13px 16px;
  border-radius: 22px;
  background: rgba(16,35,92,.045);
  border: 1px solid rgba(16,35,92,.055);
  display: flex;
  align-items: center;
  gap: 10px;
}

.services-visual-note-real i {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  color: #25b866;
  stroke-width: 2.5;
}

.services-visual-note-real span {
  color: #263252;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.4;
}

/* 02 - SOLUÇÕES */
.services-solutions-real {
  background: #f8f9fc;
}

.services-grid-real {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 42px;
}

.service-real-card {
  position: relative;
  padding: 30px;
  border-radius: 32px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 62px rgba(11,24,75,.065);
  transition: .25s ease;
}

.service-real-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 34px 84px rgba(11,24,75,.11);
}

.service-real-featured {
  background:
    radial-gradient(circle at 82% 12%, rgba(39,98,255,.11), transparent 32%),
    #fff;
  transform: translateY(-12px);
  box-shadow: 0 34px 90px rgba(11,24,75,.12);
}

.service-real-featured:hover {
  transform: translateY(-18px);
}

.service-real-badge {
  position: absolute;
  right: 24px;
  top: 24px;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  background: var(--blue);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
}

.service-real-icon {
  width: 58px;
  height: 58px;
  border-radius: 20px;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}

.service-real-icon i {
  width: 26px;
  height: 26px;
  stroke-width: 2.35;
}

.service-real-kicker {
  display: block;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.service-real-card h3 {
  margin: 0 0 12px;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: -1px;
}

.service-real-card p {
  margin: 0 0 22px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.72;
}

.service-real-card ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 18px;
  list-style: none;
  border-radius: 22px;
  background: #f8f9fc;
  border: 1px solid rgba(16,35,92,.06);
}

.service-real-card li {
  position: relative;
  padding-left: 18px;
  color: #44506f;
  font-size: 13px;
  font-weight: 750;
  line-height: 1.42;
}

.service-real-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--blue);
}

/* 03 - MÉTODO */
.services-method-panel-real {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 44px;
  align-items: center;
  padding: 48px;
  border-radius: 38px;
  background:
    radial-gradient(circle at 86% 16%, rgba(39,98,255,.10), transparent 30%),
    #f8f9fc;
  border: 1px solid var(--line);
  box-shadow: 0 28px 76px rgba(11,24,75,.08);
}

.services-method-copy-real h2 {
  margin: 12px 0 16px;
  font-size: clamp(30px, 3.5vw, 50px);
  line-height: 1.04;
  letter-spacing: -1.8px;
}

.services-method-copy-real p {
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
}

.services-method-steps-real {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.services-method-steps-real article {
  padding: 20px;
  border-radius: 24px;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(16,35,92,.065);
}

.services-method-steps-real span {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  border-radius: 15px;
  background: rgba(39,98,255,.08);
  color: var(--blue);
  font-weight: 900;
  font-size: 13px;
}

.services-method-steps-real strong {
  display: block;
  margin-bottom: 8px;
  color: var(--text);
  font-size: 17px;
}

.services-method-steps-real p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

/* 04 - FIT */
.services-fit-real {
  background: #f8f9fc;
}

.services-fit-grid-real {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 44px;
  align-items: center;
}

.services-fit-copy-real h2 {
  margin: 12px 0 16px;
  font-size: clamp(32px, 3.8vw, 54px);
  line-height: 1.02;
  letter-spacing: -2px;
}

.services-fit-copy-real p {
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
}

.services-fit-list-real {
  display: grid;
  gap: 14px;
}

.services-fit-list-real div {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.075);
  box-shadow: 0 18px 45px rgba(11,24,75,.045);
}

.services-fit-list-real i {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  color: var(--blue);
  stroke-width: 2.5;
}

.services-fit-list-real span {
  color: #263252;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.45;
}

/* 05 - CTA */
.services-final-real {
  background: linear-gradient(180deg, #f8f9fc 0%, #ffffff 100%);
}

.services-final-box-real {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 42px;
  align-items: center;
  padding: 56px;
  border-radius: 42px;
  background:
    radial-gradient(circle at 82% 18%, rgba(255,255,255,.12), transparent 38%),
    linear-gradient(135deg, #03113f 0%, #071f72 54%, #0b2f9a 100%);
  color: #fff;
  box-shadow: 0 36px 94px rgba(6,24,95,.24);
}

.services-final-box-real::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 32px;
  border: 1px solid rgba(255,255,255,.14);
  pointer-events: none;
}

.services-final-copy-real,
.services-final-points-real {
  position: relative;
  z-index: 1;
}

.services-final-copy-real .eyebrow {
  color: rgba(255,255,255,.72);
}

.services-final-copy-real h2 {
  max-width: 760px;
  margin: 14px 0 18px;
  color: #fff;
  font-size: clamp(32px, 4.2vw, 58px);
  line-height: 1.02;
  letter-spacing: -2px;
}

.services-final-copy-real p {
  max-width: 640px;
  margin: 0 0 28px;
  color: rgba(255,255,255,.76);
  font-size: 16px;
  line-height: 1.76;
}

.services-final-cta-real {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 26px;
  border-radius: 999px;
  background: #fff;
  color: #041347;
  text-decoration: none;
  font-size: 14px;
  font-weight: 900;
  box-shadow: 0 18px 40px rgba(0,0,0,.20);
  transition: .25s ease;
}

.services-final-cta-real:hover {
  transform: translateY(-3px);
  background: #f4f7ff;
  box-shadow: 0 28px 58px rgba(0,0,0,.28);
}

.services-final-cta-real i {
  width: 17px;
  height: 17px;
  stroke-width: 2.6;
}

.services-final-points-real {
  display: grid;
  gap: 14px;
}

.services-final-points-real div {
  padding: 20px 22px;
  border-radius: 22px;
  background: rgba(255,255,255,.11);
  border: 1px solid rgba(255,255,255,.16);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.services-final-points-real strong {
  color: #fff;
  font-size: 20px;
}

.services-final-points-real span {
  color: rgba(255,255,255,.82);
  font-size: 14px;
  font-weight: 800;
}

/* RESPONSIVO */
@media (max-width: 1080px) {
  .services-grid-real {
    grid-template-columns: 1fr;
  }

  .service-real-featured {
    transform: none;
  }

  .service-real-featured:hover {
    transform: translateY(-7px);
  }
}

@media (max-width: 980px) {
  .services-intro-grid-real,
  .services-method-panel-real,
  .services-fit-grid-real,
  .services-final-box-real {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .services-intro-real {
    padding-top: 126px;
  }

  .services-intro-copy-real h1,
  .services-fit-copy-real h2,
  .services-final-copy-real h2 {
    letter-spacing: -1.5px;
  }

  .services-intro-actions-real {
    flex-direction: column;
  }

  .services-intro-actions-real .btn {
    width: 100%;
  }

  .services-mini-grid-real,
  .services-method-steps-real {
    grid-template-columns: 1fr;
  }

  .services-final-box-real,
  .services-method-panel-real {
    padding: 30px 24px;
    border-radius: 30px;
  }
}


/* ====================================
   SERVIÇOS - FRENTES ESTRATÉGICAS
   Mostra atuação completa sem transformar a página em lista de serviços.
==================================== */
.services-spectrum-real {
  background: #ffffff;
}

.services-spectrum-panel {
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: 42px;
  align-items: center;
  padding: 48px;
  border-radius: 38px;
  background:
    radial-gradient(circle at 86% 14%, rgba(39,98,255,.11), transparent 30%),
    linear-gradient(180deg, #ffffff, #f7faff);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 30px 82px rgba(11,24,75,.09);
}

.services-spectrum-copy h2 {
  margin: 12px 0 16px;
  font-size: clamp(30px, 3.6vw, 52px);
  line-height: 1.03;
  letter-spacing: -1.9px;
}

.services-spectrum-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.76;
}

.services-spectrum-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.services-spectrum-grid article {
  min-height: 150px;
  padding: 20px;
  border-radius: 24px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.065);
  box-shadow: 0 16px 40px rgba(11,24,75,.045);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.services-spectrum-grid i {
  width: 24px;
  height: 24px;
  color: var(--blue);
  stroke-width: 2.35;
  margin-bottom: 16px;
}

.services-spectrum-grid strong {
  display: block;
  color: var(--text);
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: -.4px;
  margin-bottom: 8px;
}

.services-spectrum-grid span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

@media (max-width: 980px) {
  .services-spectrum-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .services-spectrum-panel {
    padding: 30px 24px;
    border-radius: 30px;
  }

  .services-spectrum-grid {
    grid-template-columns: 1fr;
  }
}


/* ====================================
REFINOS SOLICITADOS
==================================== */

/* 1. ÍCONES MAIS DESTACADOS (SOLUÇÕES) */
.service-real-icon {
  background: linear-gradient(135deg, #06185f, #0b2f9a) !important;
  color: #ffffff !important;
  box-shadow: 0 18px 40px rgba(6,24,95,.25) !important;
}

.service-real-icon i {
  color: #ffffff !important;
}

/* 2. BLOCO ATUAÇÃO COMPLETA (CARDS AZUIS) */
.services-spectrum-grid article {
  background: linear-gradient(135deg, #041347, #0b2f9a) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  color: #ffffff !important;
}

.services-spectrum-grid article * {
  color: #ffffff !important;
}

.services-spectrum-grid i {
  color: #ffffff !important;
}

/* 3. BLOCO NOSSA ENTREGA COMO CTA */
.services-method-panel-real {
  background: linear-gradient(135deg, #03113f, #0b2f9a) !important;
  color: #ffffff !important;
  box-shadow: 0 36px 90px rgba(6,24,95,.25) !important;
}

.services-method-panel-real * {
  color: #ffffff !important;
}

.services-method-steps-real article {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
}

.services-method-steps-real span {
  background: rgba(255,255,255,.15) !important;
  color: #ffffff !important;
}



/* ====================================
REFINO FINAL - BLOCO PARA QUEM FAZ SENTIDO
==================================== */

.services-fit-list-real div {
  background: linear-gradient(135deg, #041347, #0b2f9a) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  color: #ffffff !important;
  box-shadow: 0 20px 45px rgba(6,24,95,.18) !important;
}

.services-fit-list-real div * {
  color: #ffffff !important;
}

.services-fit-list-real i {
  color: #ffffff !important;
}



/* ====================================
REFINO FINAL - FIT BLOCK CLEAN PREMIUM
==================================== */

/* cards fundo branco com borda azul */
.services-fit-list-real div {
  background: #ffffff !important;
  border: 2px solid #0b2f9a !important;
  color: #263252 !important;
  box-shadow: 0 14px 32px rgba(11,24,75,.06) !important;
}

/* texto normal */
.services-fit-list-real div span {
  color: #263252 !important;
}

/* ícone verde (check) */
.services-fit-list-real i {
  color: #25b866 !important;
}



/* ====================================
REFINO FINAL 4 - BORDA FINA + CHECK VISÍVEL
==================================== */

/* borda mais fina */
.services-fit-list-real div {
  border: 1px solid #0b2f9a !important;
}

/* garante que o ícone apareça corretamente */
.services-fit-list-real i {
  display: inline-flex !important;
  width: 20px !important;
  height: 20px !important;
  color: #25b866 !important;
  stroke: #25b866 !important;
  stroke-width: 3 !important;
}

/* garante alinhamento */
.services-fit-list-real div {
  align-items: center !important;
}

/* melhora espaçamento */
.services-fit-list-real div span {
  margin-left: 6px;
}



/* ====================================
HERO LADO DIREITO AZUL PREMIUM
==================================== */

.services-visual-window-real {
  background: linear-gradient(135deg, #03113f, #0b2f9a) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  color: #ffffff !important;
}

/* conteúdo interno branco */
.services-visual-window-real * {
  color: #ffffff !important;
}

/* cards internos estilo glass */
.services-main-card-real {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
}

.services-mini-grid-real div {
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
}

.services-visual-note-real {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
}

/* manter ícone verde */
.services-visual-note-real i {
  color: #25b866 !important;
}



/* ====================================
   SERVIÇOS - HERO REFINO PREMIUM
   Reduz peso visual, melhora proporção e deixa o bloco direito mais elegante.
==================================== */

/* Hero menos agressivo */
.services-intro-real {
  padding-top: 138px !important;
  padding-bottom: 86px !important;
}

.services-intro-grid-real {
  grid-template-columns: 0.98fr 1.02fr !important;
  gap: 72px !important;
}

/* Headline com menos peso e melhor leitura */
.services-intro-copy-real h1 {
  max-width: 660px !important;
  font-size: clamp(38px, 4.7vw, 62px) !important;
  line-height: 1.01 !important;
  letter-spacing: -2.4px !important;
  margin-bottom: 22px !important;
}

.services-intro-copy-real p {
  max-width: 610px !important;
  font-size: 17px !important;
  line-height: 1.72 !important;
}

/* Botões mais alinhados */
.services-intro-actions-real {
  margin-top: 28px !important;
}

/* Bloco direito menor e mais refinado */
.services-visual-window-real {
  max-width: 520px !important;
  min-height: auto !important;
  margin-left: auto !important;
  border-radius: 32px !important;
  background:
    radial-gradient(circle at 84% 16%, rgba(255,255,255,.12), transparent 34%),
    linear-gradient(135deg, #041347, #0b2f9a) !important;
  box-shadow: 0 32px 82px rgba(6,24,95,.22) !important;
}

/* Topo mais discreto */
.services-window-top-real {
  height: 46px !important;
  background: rgba(255,255,255,.14) !important;
  border-bottom: 1px solid rgba(255,255,255,.12) !important;
}

.services-window-top-real span {
  width: 9px !important;
  height: 9px !important;
}

/* Corpo com respiro melhor */
.services-window-body-real {
  padding: 26px !important;
}

/* Card principal mais elegante */
.services-main-card-real {
  padding: 26px !important;
  border-radius: 26px !important;
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: none !important;
}

.services-main-card-real small {
  color: rgba(255,255,255,.72) !important;
}

.services-main-card-real strong {
  max-width: 360px !important;
  color: #fff !important;
  font-size: 28px !important;
  line-height: 1.05 !important;
  letter-spacing: -1.2px !important;
}

.services-main-card-real p {
  max-width: 400px !important;
  color: rgba(255,255,255,.76) !important;
}

/* Mini cards mais premium e menos grandes */
.services-mini-grid-real {
  gap: 12px !important;
  margin-top: 16px !important;
}

.services-mini-grid-real div {
  min-height: 86px !important;
  padding: 16px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.11) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: none !important;
}

.services-mini-grid-real i,
.services-mini-grid-real strong,
.services-mini-grid-real span {
  color: #ffffff !important;
}

.services-mini-grid-real span {
  color: rgba(255,255,255,.72) !important;
}

/* Nota inferior mais limpa */
.services-visual-note-real {
  margin-top: 16px !important;
  padding: 14px 16px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
}

.services-visual-note-real span {
  color: rgba(255,255,255,.86) !important;
}

/* Check verde garantido */
.services-visual-note-real i {
  color: #25d366 !important;
  stroke: #25d366 !important;
}

/* Responsivo */
@media (max-width: 980px) {
  .services-intro-grid-real {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }

  .services-visual-window-real {
    margin-left: 0 !important;
    max-width: 100% !important;
  }
}

@media (max-width: 680px) {
  .services-intro-real {
    padding-top: 126px !important;
    padding-bottom: 64px !important;
  }

  .services-intro-copy-real h1 {
    font-size: clamp(36px, 11vw, 48px) !important;
    letter-spacing: -1.6px !important;
  }

  .services-mini-grid-real {
    grid-template-columns: 1fr !important;
  }
}


/* ====================================
FIX OVERLAY BRANCO NO HERO
==================================== */

/* remove overlay branco */
.services-visual-window-real::before {
  display: none !important;
  content: none !important;
}

/* remove qualquer camada lavada */
.services-visual-window-real {
  backdrop-filter: none !important;
}

/* garante azul puro */
.services-visual-window-real {
  background: linear-gradient(135deg, #03113f, #0b2f9a) !important;
}



/* ====================================
FIX FINAL CHECK (AZUL FORÇADO)
==================================== */

/* força visibilidade total do ícone */
.services-fit-list-real i {
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  color: #0b2f9a !important;
  stroke: #0b2f9a !important;
  stroke-width: 3 !important;
  opacity: 1 !important;
}

/* garante alinhamento */
.services-fit-list-real div {
  gap: 10px !important;
}



/* ====================================
CHECK VISÍVEL SEM DEPENDER DO LUCIDE
==================================== */

/* esconde o svg vazio/quebrado, se existir */
.services-fit-list-real div > i {
  display: none !important;
}

/* cria check real via CSS */
.services-fit-list-real div {
  position: relative !important;
  padding-left: 54px !important;
}

.services-fit-list-real div::before {
  content: "✓";
  position: absolute;
  left: 22px;
  top: 50%;
  transform: translateY(-50%);
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(11,47,154,.10);
  color: #0b2f9a;
  border: 1px solid rgba(11,47,154,.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
}

.services-fit-list-real div span {
  margin-left: 0 !important;
}


/* ====================================
CHECKS NOS ITENS DOS CARDS DE SERVIÇOS
==================================== */

.service-real-card li {
  position: relative !important;
  padding-left: 28px !important;
}

/* remove bolinha antiga */
.service-real-card li::before {
  content: "✓" !important;
  position: absolute !important;
  left: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  background: rgba(11,47,154,.10) !important;
  color: #0b2f9a !important;
  border: 1px solid rgba(11,47,154,.18) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}


/* ====================================
   INDEX - AUTORIDADE EM AZUL
   Destaque visual no card "Autoridade" do bloco de posicionamento.
==================================== */

.home-page .authority-card {
  background:
    radial-gradient(circle at 84% 14%, rgba(255,255,255,.12), transparent 34%),
    linear-gradient(135deg, #03113f 0%, #071f72 54%, #0b2f9a 100%) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: 0 28px 70px rgba(6,24,95,.20) !important;
}

.home-page .authority-card *,
.home-page .authority-card strong,
.home-page .authority-card span,
.home-page .authority-card p,
.home-page .authority-card h3,
.home-page .authority-card h4 {
  color: #ffffff !important;
}

.home-page .authority-card i,
.home-page .authority-card svg {
  color: #ffffff !important;
  stroke: #ffffff !important;
}

/* fallback: caso o HTML use classes em inglês/português */
.home-page [class*="authority"],
.home-page [class*="autoridade"] {
  background:
    radial-gradient(circle at 84% 14%, rgba(255,255,255,.12), transparent 34%),
    linear-gradient(135deg, #03113f 0%, #071f72 54%, #0b2f9a 100%) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: 0 28px 70px rgba(6,24,95,.20) !important;
}

.home-page [class*="authority"] *,
.home-page [class*="autoridade"] * {
  color: #ffffff !important;
}

.home-page [class*="authority"] i,
.home-page [class*="autoridade"] i,
.home-page [class*="authority"] svg,
.home-page [class*="autoridade"] svg {
  color: #ffffff !important;
  stroke: #ffffff !important;
}

/* ====================================
   CONTATO - CONVERSÃO PREMIUM
   Bloco isolado da página de contato.
==================================== */
.contato-hero {
  position: relative;
  overflow: hidden;
  padding: 108px 0 70px;
  background:
    radial-gradient(circle at 82% 10%, rgba(30,92,255,.055), transparent 34%),
    linear-gradient(180deg, #fbfcff 0%, #f6f8fd 100%);
}

.contato-hero::after {
  content: "";
  position: absolute;
  right: -160px;
  bottom: -190px;
  width: 390px;
  height: 390px;
  border-radius: 50%;
  background: rgba(11,47,154,.04);
  filter: blur(18px);
  pointer-events: none;
}

.contato-hero-wrap {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 42px;
  align-items: end;
}

.contato-hero-copy h1 {
  max-width: 860px;
  margin: 0 0 20px;
  font-size: clamp(38px, 4.4vw, 64px);
  line-height: 1;
  letter-spacing: -2.7px;
}

.contato-hero-copy p {
  max-width: 720px;
  margin: 0;
  font-size: 16.5px;
  line-height: 1.75;
  color: #5f6b88;
}

.contato-hero-card {
  position: relative;
  overflow: hidden;
  padding: 28px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 90% 0%, rgba(255,255,255,.14), transparent 34%),
    linear-gradient(135deg, #03113f 0%, #071f72 54%, #0b2f9a 100%);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 30px 70px rgba(6,24,95,.18);
  color: #fff;
}

.contato-hero-card span {
  display: inline-flex;
  margin-bottom: 52px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.11);
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.82);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.contato-hero-card strong {
  display: block;
  margin-bottom: 10px;
  font-size: 24px;
  line-height: 1.05;
  letter-spacing: -1px;
  color: #fff;
}

.contato-hero-card p {
  margin: 0;
  color: rgba(255,255,255,.72);
  font-size: 13px;
  line-height: 1.65;
}

.contato-main-definitivo {
  padding: 78px 0 88px;
  background: #f6f7fb;
}

.contato-grid-v4 {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, .72fr);
  gap: 28px;
  align-items: start;
}

.contato-form-box {
  grid-row: span 2;
  padding: 34px;
  border-radius: 34px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 24px 70px rgba(18,32,84,.09);
}

.contato-form {
  display: grid;
  gap: 18px;
}

.form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.form-group {
  display: grid;
  gap: 9px;
}

.form-group label {
  font-size: 12px;
  font-weight: 800;
  color: #26315e;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  border: 1px solid #dfe5f2;
  border-radius: 18px;
  background: #f9fbff;
  color: #11183f;
  outline: 0;
  transition: border-color .22s ease, box-shadow .22s ease, background .22s ease;
}

.form-group input,
.form-group select {
  min-height: 54px;
  padding: 0 16px;
}

.form-group textarea {
  min-height: 132px;
  resize: vertical;
  padding: 16px;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  background: #fff;
  border-color: rgba(30,92,255,.55);
  box-shadow: 0 0 0 5px rgba(30,92,255,.09);
}

.form-note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  padding: 10px 13px;
  border-radius: 999px;
  background: rgba(11,47,154,.06);
  color: #445075;
  font-size: 12px;
  font-weight: 700;
}

.contato-form .btn-big {
  width: fit-content;
  min-height: 56px;
  padding-inline: 28px;
  border: 0;
  cursor: pointer;
}

.site-alert {
  margin-bottom: 18px;
  padding: 14px 16px;
  border-radius: 18px;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}

.site-alert.success {
  background: #e9fbf3;
  color: #126b45;
  border: 1px solid #c9f3df;
}

.site-alert.error {
  background: #fff0f0;
  color: #a33434;
  border: 1px solid #ffd5d5;
}

.contato-side-box-premium {
  position: sticky;
  top: 118px;
  padding: 30px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 92% 4%, rgba(255,255,255,.14), transparent 30%),
    linear-gradient(135deg, #03113f 0%, #071f72 52%, #0b2f9a 100%);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 28px 70px rgba(6,24,95,.18);
  color: #fff;
}

.contato-side-box-premium h3 {
  margin: 0 0 14px;
  font-size: 27px;
  line-height: 1.08;
  letter-spacing: -1.4px;
  color: #fff;
}

.contato-side-box-premium h3 span {
  display: inline-flex;
  margin-right: 5px;
}

.contato-side-box-premium p,
.contato-side-box-premium small {
  color: rgba(255,255,255,.74);
}

.contato-side-box-premium > p {
  margin: 0 0 24px;
  font-size: 14px;
}

.contato-steps {
  display: grid;
  gap: 12px;
  margin: 0 0 22px;
}

.contato-steps-title {
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.68);
}

.contato-step {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 12px;
  padding: 14px;
  border-radius: 20px;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.13);
}

.contato-step-icon {
  width: 42px;
  height: 42px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.12);
}

.contato-step-copy strong {
  display: block;
  margin-bottom: 4px;
  color: #fff;
  font-size: 13px;
}

.contato-step-copy span {
  display: block;
  color: rgba(255,255,255,.68);
  font-size: 12px;
  line-height: 1.55;
}

.contato-whats-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 54px;
  padding: 0 18px;
  border-radius: 999px;
  background: #fff;
  color: #071f72;
  font-size: 13px;
  font-weight: 900;
  box-shadow: 0 18px 44px rgba(0,0,0,.16);
  transition: transform .22s ease, box-shadow .22s ease;
}

.contato-whats-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 24px 54px rgba(0,0,0,.22);
}

.contato-whats-note {
  display: block;
  margin-top: 11px;
  font-size: 11px;
}

.contato-benefits-box {
  padding: 28px;
  border-radius: 34px;
  background: #fff;
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 20px 58px rgba(18,32,84,.07);
}

.contato-benefit {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}

.contato-benefit-icon {
  width: 42px;
  height: 42px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  background: rgba(11,47,154,.08);
  color: #0b2f9a;
  font-weight: 900;
}

.contato-benefit strong {
  display: block;
  color: #11183f;
  font-size: 18px;
  line-height: 1.2;
}

.contato-benefits-grid {
  display: grid;
  gap: 12px;
}

.contato-benefit-card {
  padding: 18px;
  border-radius: 22px;
  background: #f8faff;
  border: 1px solid #e6eaf5;
}

.contato-benefit-mini-icon {
  width: 34px;
  height: 34px;
  margin-bottom: 12px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  background: #fff;
  color: #0b2f9a;
  box-shadow: 0 10px 22px rgba(18,32,84,.06);
}

.contato-benefit-card h4 {
  margin: 0 0 7px;
  color: #11183f;
  font-size: 15px;
  letter-spacing: -.04em;
}

.contato-benefit-card p {
  margin: 0;
  color: #67708e;
  font-size: 13px;
  line-height: 1.6;
}

.contato-cta {
  padding: 0 0 90px;
  background: #f6f7fb;
}

.contato-cta .cta-box {
  text-align: center;
  padding: 54px 38px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 20% 0%, rgba(52,211,153,.18), transparent 28%),
    linear-gradient(135deg, #071847 0%, #12328d 100%);
  box-shadow: 0 34px 80px rgba(18,32,84,.15);
  color: #fff;
}

.contato-cta .cta-box h2 {
  max-width: 940px;
  margin: 0 auto 26px;
  color: #fff;
  font-size: clamp(28px, 3.7vw, 52px);
  line-height: 1.06;
  letter-spacing: -2px;
}



/* =========================
   CONTATO - REFINO NÍVEL 2
   Hero visual inspirado no padrão Serviços + diferenciais como seção completa.
========================= */
.contato-hero-visual-real {
  position: relative;
}

.contato-visual-window-real {
  position: relative;
  overflow: hidden;
  min-height: 390px;
  border-radius: 34px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,35,92,.075);
  box-shadow: 0 24px 68px rgba(11,24,75,.095), inset 0 1px 0 rgba(255,255,255,.82);
  backdrop-filter: blur(18px);
}

.contato-visual-window-real::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 82% 10%, rgba(39,98,255,.075), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.7), rgba(248,250,255,.66));
}

.contato-window-top-real {
  position: relative;
  z-index: 2;
  height: 54px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 24px;
  border-bottom: 1px solid rgba(16,35,92,.06);
  background: rgba(255,255,255,.42);
}

.contato-window-top-real span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.contato-window-top-real span:nth-child(1) { background: rgba(255, 95, 86, .72); }
.contato-window-top-real span:nth-child(2) { background: rgba(255, 189, 46, .72); }
.contato-window-top-real span:nth-child(3) { background: rgba(39, 201, 63, .72); }

.contato-window-body-real {
  position: relative;
  z-index: 2;
  padding: 28px;
}

.contato-main-card-real {
  padding: 24px;
  border-radius: 26px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(16,35,92,.065);
  box-shadow: 0 16px 42px rgba(11,24,75,.06);
}

.contato-main-card-real small {
  display: block;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
}

.contato-main-card-real strong {
  display: block;
  color: var(--text);
  font-size: 23px;
  line-height: 1.14;
  letter-spacing: -.8px;
  margin-bottom: 12px;
}

.contato-main-card-real p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.contato-mini-grid-real {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 11px;
  margin-top: 16px;
}

.contato-mini-grid-real div {
  min-height: 80px;
  padding: 14px;
  border-radius: 22px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,35,92,.06);
  box-shadow: 0 10px 30px rgba(11,24,75,.04);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform .22s ease, box-shadow .22s ease;
}

.contato-mini-grid-real div:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 48px rgba(11,24,75,.085);
}

.contato-mini-grid-real i {
  width: 21px;
  height: 21px;
  color: var(--blue);
  stroke-width: 2.5;
}

.contato-mini-grid-real strong {
  color: #263252;
  font-size: 13px;
}

.contato-mini-grid-real span {
  color: var(--muted);
  font-size: 11px;
}

.contato-visual-note-real {
  margin-top: 16px;
  min-height: 58px;
  padding: 13px 16px;
  border-radius: 22px;
  background: rgba(30,92,255,.035);
  border: 1px solid rgba(30,92,255,.065);
  display: flex;
  align-items: center;
  gap: 10px;
}

.contato-visual-note-real i {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  color: #25b866;
  stroke-width: 2.5;
}

.contato-visual-note-real span {
  color: #263252;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.4;
}

.contato-benefits-section {
  padding: 0 0 88px;
  background: #f6f7fb;
}

.contato-benefits-section .contato-benefits-box {
  padding: 40px;
  border-radius: 38px;
  background:
    radial-gradient(circle at 92% 0%, rgba(39,98,255,.08), transparent 28%),
    #fff;
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 24px 70px rgba(18,32,84,.08);
}

.contato-benefits-head {
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 18px;
  align-items: start;
  max-width: 920px;
  margin-bottom: 28px;
}

.contato-benefits-head h2 {
  margin: 8px 0 12px;
  color: #11183f;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.05;
  letter-spacing: -1.8px;
}

.contato-benefits-head p {
  max-width: 790px;
  margin: 0;
  color: #67708e;
  font-size: 16px;
  line-height: 1.72;
}

.contato-benefits-section .contato-benefits-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.contato-benefits-section .contato-benefit-card {
  min-height: 100%;
  padding: 24px;
  border-radius: 26px;
  background: #f8faff;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.contato-benefits-section .contato-benefit-card:hover {
  transform: translateY(-4px);
  border-color: rgba(30,92,255,.18);
  box-shadow: 0 20px 54px rgba(18,32,84,.09);
}

.contato-cta .cta-box p {
  max-width: 780px;
  margin: -12px auto 28px;
  color: rgba(255,255,255,.76);
  font-size: 16px;
  line-height: 1.7;
}

@media (max-width: 1040px) {
  .contato-hero-wrap,
  .contato-grid-v4 {
    grid-template-columns: 1fr;
  }

  .contato-hero-card {
    max-width: 560px;
  }

  .contato-form-box {
    grid-row: auto;
  }

  .contato-side-box-premium {
    position: relative;
    top: auto;
  }
}


@media (max-width: 1040px) {
  .contato-visual-window-real {
    max-width: 620px;
  }

  .contato-benefits-section .contato-benefits-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .contato-hero {
    padding: 92px 0 54px;
  }

  .contato-hero-copy h1 {
    letter-spacing: -2px;
  }

  .contato-form-box,
  .contato-side-box-premium,
  .contato-benefits-box,
  .contato-visual-window-real,
  .contato-cta .cta-box {
    padding: 24px;
    border-radius: 26px;
  }

  .form-row,
  .contato-mini-grid-real,
  .contato-benefits-head {
    grid-template-columns: 1fr;
  }

  .contato-window-body-real,
  .contato-benefits-section .contato-benefits-box {
    padding: 22px;
  }

  .contato-benefits-section {
    padding-bottom: 64px;
  }

  .form-note,
  .contato-form .btn-big,
  .contato-whats-btn {
    width: 100%;
  }
}

/* =========================
   CONTATO - VERSÃO SEM HERO / ALTA CONVERSÃO
   Bloco incremental: remove o peso visual do hero e traz o formulário para o foco.
========================= */
.contato-main-definitivo {
  padding: 104px 0 88px;
  background:
    radial-gradient(circle at 82% 0%, rgba(30,92,255,.055), transparent 32%),
    linear-gradient(180deg, #fbfcff 0%, #f6f7fb 64%, #f6f7fb 100%);
}

.contato-conversion-head {
  max-width: 980px;
  margin: 0 auto 42px;
  text-align: center;
}

.contato-conversion-head .eyebrow {
  justify-content: center;
}

.contato-conversion-head h1 {
  max-width: 920px;
  margin: 12px auto 18px;
  color: #11183f;
  font-size: clamp(34px, 4.4vw, 62px);
  line-height: 1.02;
  letter-spacing: -2.7px;
}

.contato-conversion-head p {
  max-width: 760px;
  margin: 0 auto;
  color: #5f6b88;
  font-size: 17px;
  line-height: 1.72;
}

.contato-trust-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 24px;
}

.contato-trust-row span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(226,232,245,.95);
  color: #34405f;
  font-size: 12px;
  font-weight: 850;
  box-shadow: 0 12px 28px rgba(18,32,84,.055);
}

.contato-trust-row i {
  width: 16px;
  height: 16px;
  color: var(--blue);
  stroke-width: 2.5;
}

.contato-form-head {
  margin-bottom: 24px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(226,232,245,.95);
}

.contato-form-head span {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(30,92,255,.075);
  color: var(--blue);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.contato-form-head h2 {
  margin: 0 0 8px;
  color: #11183f;
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.08;
  letter-spacing: -1.2px;
}

.contato-form-head p {
  max-width: 620px;
  margin: 0;
  color: #66708d;
  font-size: 14px;
  line-height: 1.65;
}

.contato-form .form-group {
  padding: 14px;
  border-radius: 22px;
  background: #fbfcff;
  border: 1px solid rgba(226,232,245,.75);
}

.contato-form .form-row .form-group {
  min-width: 0;
}

.contato-form .form-group label {
  color: #18234a;
  font-size: 13px;
  letter-spacing: -.01em;
}

.contato-form .form-group input,
.contato-form .form-group select,
.contato-form .form-group textarea {
  background: #fff;
  border-radius: 16px;
}

.contato-form .btn-big {
  width: 100%;
  justify-content: center;
  font-size: 14px;
}

.contato-side-box-premium {
  background:
    radial-gradient(circle at 92% 4%, rgba(30,92,255,.08), transparent 30%),
    #fff;
  color: #11183f;
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 24px 70px rgba(18,32,84,.08);
}

.contato-side-box-premium h3 {
  color: #11183f;
}

.contato-side-box-premium p,
.contato-side-box-premium small,
.contato-step-copy span,
.contato-steps-title {
  color: #66708d;
}

.contato-step {
  background: #f8faff;
  border-color: #e6eaf5;
}

.contato-step-icon {
  background: #fff;
}

.contato-step-copy strong {
  color: #11183f;
}

.contato-whats-btn {
  background: linear-gradient(135deg, #071f72 0%, #0b2f9a 100%);
  color: #fff;
  box-shadow: 0 18px 44px rgba(11,47,154,.18);
}

@media (max-width: 680px) {
  .contato-main-definitivo {
    padding-top: 92px;
  }

  .contato-conversion-head {
    text-align: left;
    margin-bottom: 28px;
  }

  .contato-conversion-head .eyebrow,
  .contato-trust-row {
    justify-content: flex-start;
  }

  .contato-conversion-head h1 {
    letter-spacing: -2px;
  }

  .contato-trust-row span {
    width: 100%;
  }

  .contato-form .form-group {
    padding: 12px;
  }
}

/* ====================================
   SOBRE HERO - VISUAL INTERNACIONAL
   Bloco direito refinado, isolado e sem impacto nas demais páginas.
==================================== */
.hero-minimal-right .apple-brand-visual {
  display: none !important;
}

.about-global-visual {
  position: relative;
  min-height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
  isolation: isolate;
}

.about-global-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(10px);
  pointer-events: none;
  z-index: 0;
}

.about-global-glow.glow-one {
  width: 320px;
  height: 320px;
  top: 8px;
  right: -10px;
  background: rgba(39, 98, 255, .16);
}

.about-global-glow.glow-two {
  width: 230px;
  height: 230px;
  left: 18px;
  bottom: 24px;
  background: rgba(255, 140, 66, .10);
}

.global-card-main {
  position: relative;
  z-index: 2;
  width: min(100%, 540px);
  padding: 26px;
  border-radius: 36px;
  background:
    radial-gradient(circle at 84% 10%, rgba(39,98,255,.16), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(247,250,255,.78));
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 42px 100px rgba(11,24,75,.13);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  overflow: hidden;
}

.global-card-main::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(16,35,92,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(16,35,92,.045) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: radial-gradient(circle at 72% 32%, #000 0%, transparent 66%);
  pointer-events: none;
}

.global-card-header,
.global-card-body,
.global-proof-row {
  position: relative;
  z-index: 2;
}

.global-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 22px;
}

.global-kicker,
.global-status {
  display: inline-flex;
  min-height: 36px;
  align-items: center;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
}

.global-kicker {
  padding: 0 14px;
  color: var(--blue);
  background: rgba(39,98,255,.09);
  letter-spacing: .12em;
  text-transform: uppercase;
}

.global-status {
  gap: 7px;
  padding: 0 13px;
  color: #263252;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,35,92,.07);
}

.global-status i {
  width: 15px;
  height: 15px;
  color: var(--blue);
}

.global-card-body {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr);
  gap: 22px;
  align-items: center;
}

.global-orbit {
  position: relative;
  height: 190px;
  display: grid;
  place-items: center;
}

.orbit-ring {
  position: absolute;
  border-radius: 999px;
  border: 1px solid rgba(39,98,255,.18);
}

.orbit-ring.ring-one {
  width: 174px;
  height: 174px;
  background: rgba(255,255,255,.28);
}

.orbit-ring.ring-two {
  width: 124px;
  height: 124px;
  border-style: dashed;
}

.orbit-core {
  position: relative;
  width: 112px;
  height: 112px;
  border-radius: 32px;
  background: linear-gradient(145deg, #0A2540, #123D72);
  box-shadow: 0 24px 56px rgba(10,37,64,.26);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.orbit-core strong {
  color: #fff;
  font-size: 17px;
  letter-spacing: -.4px;
}

.orbit-core small {
  width: 80px;
  margin-top: 5px;
  color: rgba(255,255,255,.72);
  font-size: 10px;
  line-height: 1.25;
  font-weight: 800;
}

.global-copy-card {
  padding: 24px;
  border-radius: 26px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,35,92,.07);
  box-shadow: 0 22px 54px rgba(11,24,75,.07);
}

.global-copy-card small {
  display: block;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.global-copy-card h3 {
  margin: 0 0 12px;
  color: var(--text);
  font-size: 25px;
  line-height: 1.12;
  letter-spacing: -1px;
}

.global-copy-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.global-proof-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 22px;
}

.global-proof-row div {
  padding: 16px;
  border-radius: 22px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(16,35,92,.065);
  box-shadow: 0 16px 40px rgba(11,24,75,.055);
}

.global-proof-row strong {
  display: block;
  color: var(--text);
  font-size: 17px;
  letter-spacing: -.35px;
}

.global-proof-row span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.global-floating-note {
  position: absolute;
  z-index: 4;
  left: 50%;
  bottom: 8px;
  transform: translateX(-50%);
  width: min(88%, 420px);
  min-height: 58px;
  padding: 13px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 58px rgba(11,24,75,.11);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.global-floating-note i {
  width: 20px;
  height: 20px;
  color: #25b866;
  stroke-width: 2.5;
}

.global-floating-note span {
  color: #263252;
  font-size: 13px;
  font-weight: 850;
}

@media (max-width: 980px) {
  .about-global-visual {
    min-height: 520px;
  }
}

@media (max-width: 680px) {
  .about-global-visual {
    min-height: auto;
    padding-bottom: 28px;
  }

  .global-card-main {
    padding: 22px;
    border-radius: 30px;
  }

  .global-card-header,
  .global-card-body,
  .global-proof-row {
    grid-template-columns: 1fr;
  }

  .global-card-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .global-orbit {
    height: 160px;
  }

  .orbit-ring.ring-one {
    width: 150px;
    height: 150px;
  }

  .orbit-ring.ring-two {
    width: 108px;
    height: 108px;
  }

  .orbit-core {
    width: 100px;
    height: 100px;
    border-radius: 28px;
  }

  .global-floating-note {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    width: 100%;
    margin-top: 14px;
    border-radius: 22px;
  }
}

/* ====================================
   SERVIÇOS - HERO VISUAL PREMIUM AZUL
   Bloco isolado do visual lateral da página Serviços.
==================================== */
.services-intro-panel-premium {
  position: relative;
  padding: 30px;
  border-radius: 32px;
  color: #ffffff;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.22), transparent 32%),
    linear-gradient(145deg, #06175f 0%, #082a86 52%, #005cff 100%);
  box-shadow: 0 30px 76px rgba(8, 31, 112, 0.25);
  overflow: hidden;
}

.services-intro-panel-premium::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.075) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.075) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.76), transparent 88%);
  pointer-events: none;
}

.services-intro-panel-premium::after {
  content: '';
  position: absolute;
  width: 230px;
  height: 230px;
  right: -72px;
  bottom: -92px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  filter: blur(2px);
  pointer-events: none;
}

.services-panel-top-premium,
.services-panel-flow-premium,
.services-panel-bottom-premium {
  position: relative;
  z-index: 1;
}

.services-panel-kicker-premium {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 18px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.20);
  color: rgba(255, 255, 255, 0.88);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.services-panel-top-premium strong {
  display: block;
  max-width: 420px;
  font-size: 28px;
  line-height: 1.12;
  letter-spacing: -0.9px;
}

.services-panel-top-premium p {
  margin-top: 14px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.7;
}

.services-panel-flow-premium {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 28px 0;
}

.services-panel-flow-premium div {
  padding: 16px 12px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(10px);
}

.services-panel-flow-premium span {
  display: block;
  margin-bottom: 8px;
  color: rgba(255, 255, 255, 0.58);
  font-size: 12px;
  font-weight: 800;
}

.services-panel-flow-premium strong {
  font-size: 13px;
  color: #ffffff;
}

.services-panel-bottom-premium {
  display: grid;
  gap: 12px;
}

.services-panel-bottom-premium div {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.services-panel-bottom-premium i {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.services-panel-bottom-premium span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
}

@media (max-width: 920px) {
  .services-intro-panel-premium {
    max-width: 620px;
  }
}

@media (max-width: 680px) {
  .services-intro-panel-premium {
    padding: 24px;
    border-radius: 26px;
  }

  .services-panel-top-premium strong {
    font-size: 23px;
  }

  .services-panel-flow-premium {
    grid-template-columns: 1fr;
  }
}

/* ====================================
   SERVIÇOS - INFRAESTRUTURA PREMIUM
   Bloco isolado para Hospedagem e Servidores/VPS.
==================================== */
.services-infra-premium {
  background:
    radial-gradient(circle at top left, rgba(0, 92, 255, 0.055), transparent 34%),
    #ffffff;
}

.services-infra-grid-premium {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  margin-top: 42px;
}

.services-infra-card-premium {
  position: relative;
  min-height: 100%;
  padding: 34px;
  border-radius: 30px;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 22px 56px rgba(15, 23, 42, 0.075);
  overflow: hidden;
}

.services-infra-card-premium::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0, 92, 255, 0.06), transparent 46%);
  pointer-events: none;
}

.services-infra-card-premium > * {
  position: relative;
  z-index: 1;
}

.services-infra-icon-premium {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin-bottom: 20px;
  border-radius: 18px;
  color: #005cff;
  background: rgba(0, 92, 255, 0.09);
}

.services-infra-icon-premium i {
  width: 22px;
  height: 22px;
}

.services-infra-kicker-premium {
  display: block;
  margin-bottom: 10px;
  color: #005cff;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.services-infra-card-premium h3 {
  margin: 0 0 14px;
  color: #06111f;
  font-size: 27px;
  line-height: 1.15;
  letter-spacing: -0.7px;
}

.services-infra-card-premium p {
  margin: 0 0 24px;
  color: rgba(15, 23, 42, 0.68);
  line-height: 1.7;
}

.services-infra-card-premium ul {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.services-infra-card-premium li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: rgba(15, 23, 42, 0.78);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
}

.services-infra-card-premium li i {
  width: 18px;
  height: 18px;
  margin-top: 1px;
  flex: 0 0 auto;
  color: #005cff;
}

.services-infra-card-blue-premium {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.12);
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.22), transparent 32%),
    linear-gradient(145deg, #06175f 0%, #082a86 52%, #005cff 100%);
  box-shadow: 0 30px 76px rgba(8, 31, 112, 0.24);
}

.services-infra-card-blue-premium::before {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.075) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.075) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.76), transparent 88%);
}

.services-infra-card-blue-premium .services-infra-icon-premium {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.16);
}

.services-infra-card-blue-premium .services-infra-kicker-premium,
.services-infra-card-blue-premium h3,
.services-infra-card-blue-premium li i {
  color: #ffffff;
}

.services-infra-card-blue-premium p,
.services-infra-card-blue-premium li {
  color: rgba(255, 255, 255, 0.84);
}

.services-infra-btn-premium {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 26px;
  padding: 13px 18px;
  border-radius: 999px;
  color: #ffffff;
  background: #005cff;
  border: 1px solid rgba(0, 92, 255, 0.16);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 16px 34px rgba(0, 92, 255, 0.20);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.services-infra-btn-premium:hover {
  transform: translateY(-2px);
  background: #004fdb;
  box-shadow: 0 20px 42px rgba(0, 92, 255, 0.26);
  text-decoration: none;
}

.services-infra-btn-premium i {
  width: 17px;
  height: 17px;
}

.services-infra-btn-light-premium {
  color: #06175f;
  background: #ffffff;
  border-color: rgba(255, 255, 255, 0.34);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.16);
}

.services-infra-btn-light-premium:hover {
  color: #06175f;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.20);
}


@media (max-width: 860px) {
  .services-infra-grid-premium {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .services-infra-card-premium {
    padding: 26px;
    border-radius: 26px;
  }

  .services-infra-card-premium h3 {
    font-size: 23px;
  }
}

/* ====================================
   TEXTURA AZUL UNDERLINE - PADRÃO PREMIUM SUTIL
   Aplicada apenas em blocos azuis existentes, sem afetar cards claros.
   Regra: textura deve ser percebida como acabamento, nunca competir com o conteúdo.
==================================== */
.strategy-panel,
.proof-box,
.final-cta-box,
.about-principles-box,
.portfolio-thinking-panel-v3,
.portfolio-close-panel-v4,
.services-method-panel-real,
.services-visual-window-real,
.home-page .authority-card,
.home-page [class*="autoridade"],
.contato-hero-card,
.contato-side-box-premium,
.contato-cta .cta-box,
.sobre-intro-panel,
.services-intro-panel-premium,
.services-infra-card-blue-premium {
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px),
    radial-gradient(circle at 18% 0%, rgba(82,140,255,.10), transparent 34%),
    radial-gradient(circle at 92% 8%, rgba(255,255,255,.075), transparent 38%),
    linear-gradient(145deg, #071a50 0%, #082c79 56%, #0b57df 100%) !important;
  background-size: 56px 56px, 56px 56px, auto, auto, auto !important;
  background-position: center, center, center, center, center !important;
}

.strategy-panel,
.proof-box,
.final-cta-box,
.about-principles-box,
.portfolio-thinking-panel-v3,
.portfolio-close-panel-v4,
.services-method-panel-real,
.services-visual-window-real,
.home-page .authority-card,
.home-page [class*="autoridade"],
.contato-hero-card,
.contato-side-box-premium,
.contato-cta .cta-box,
.sobre-intro-panel,
.services-intro-panel-premium,
.services-infra-card-blue-premium {
  position: relative;
  overflow: hidden;
}

.strategy-panel > *,
.proof-box > *,
.final-cta-box > *,
.about-principles-box > *,
.portfolio-thinking-panel-v3 > *,
.portfolio-close-panel-v4 > *,
.services-method-panel-real > *,
.services-visual-window-real > *,
.home-page .authority-card > *,
.home-page [class*="autoridade"] > *,
.contato-hero-card > *,
.contato-side-box-premium > *,
.contato-cta .cta-box > *,
.sobre-intro-panel > *,
.services-intro-panel-premium > *,
.services-infra-card-blue-premium > * {
  position: relative;
  z-index: 1;
}

/* ====================================
   SOBRE - CTA GRÁFICO PREMIUM
   Ajuste incremental: adiciona elemento visual no lado esquerdo do CTA final.
==================================== */
.about-next-visual {
  position: relative;
  z-index: 1;
  order: 1;
  display: grid;
  gap: 18px;
  align-self: stretch;
  align-content: end;
  min-height: 390px;
}

.about-next-visual .next-glow {
  left: 52px;
  top: 36px;
  width: 260px;
  height: 260px;
  opacity: .82;
}

.about-next-chart {
  position: relative;
  z-index: 1;
  width: min(100%, 430px);
  min-height: 236px;
  padding: 22px;
  border-radius: 26px;
  background: linear-gradient(145deg, rgba(255,255,255,.105), rgba(255,255,255,.045));
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14), 0 24px 60px rgba(0,0,0,.12);
  backdrop-filter: blur(10px);
  overflow: hidden;
}

.about-next-chart::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 84% 18%, rgba(255,255,255,.16), transparent 28%),
    linear-gradient(rgba(255,255,255,.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.032) 1px, transparent 1px);
  background-size: auto, 44px 44px, 44px 44px;
  opacity: .72;
  pointer-events: none;
}

.chart-header {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.chart-header span {
  color: rgba(255,255,255,.70);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.chart-header strong {
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
}

.chart-kpis {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}

.chart-kpis div {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.10);
}

.chart-kpis span {
  display: block;
  color: rgba(255,255,255,.62);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.chart-kpis strong {
  color: #fff;
  font-size: 17px;
  line-height: 1;
  letter-spacing: -.4px;
}

.chart-board {
  position: relative;
  z-index: 2;
  min-height: 150px;
  padding: 4px 0 0;
}

.chart-board svg {
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}

.chart-grid-lines line {
  stroke: rgba(255,255,255,.11);
  stroke-width: 1;
}

.growth-area {
  fill: url(#growthArea);
  opacity: .9;
}

.growth-path {
  fill: none;
  stroke: url(#growthLine);
  stroke-width: 5;
  stroke-linecap: round;
  filter: drop-shadow(0 0 14px rgba(255,255,255,.22));
}

.growth-points circle {
  fill: #fff;
  stroke: rgba(255,255,255,.22);
  stroke-width: 8;
  filter: drop-shadow(0 0 12px rgba(255,255,255,.30));
}

.chart-axis-labels {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: -10px;
  color: rgba(255,255,255,.58);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .04em;
}

.about-next-visual .about-next-proof {
  width: min(100%, 430px);
  max-width: 430px;
  align-self: end;
  order: initial;
}

@media (max-width: 980px) {
  .about-next-visual {
    min-height: auto;
    align-content: start;
  }

  .about-next-chart,
  .about-next-visual .about-next-proof {
    width: 100%;
    max-width: 100%;
  }
}

@media (max-width: 560px) {
  .about-next-chart {
    min-height: 162px;
    padding: 18px;
  }

  .chart-stage {
    height: 88px;
  }

  .chart-bar {
    width: 36px;
  }

  .bar-1 { left: 0; height: 32px; }
  .bar-2 { left: 52px; height: 48px; }
  .bar-3 { left: 104px; height: 66px; }
  .bar-4 { left: 156px; height: 84px; }
}

/* ====================================
   HOTFIX CONTATO - ISOLAMENTO DO BLOCO AZUL
   Corrige conflito causado por ajustes no CTA da página Sobre.
   Escopo fechado somente na página Contato.
==================================== */
.contato-main-definitivo .contato-grid-v4 {
  max-width: 1040px;
  margin-left: auto;
  margin-right: auto;
  grid-template-columns: minmax(0, 1.04fr) minmax(330px, .76fr);
  gap: 34px;
  align-items: start !important;
}

.contato-main-definitivo .contato-form-box,
.contato-main-definitivo .contato-side-definitivo {
  align-self: start !important;
}

.contato-main-definitivo .contato-side-definitivo {
  margin-top: 0 !important;
  padding-top: 0 !important;
  height: 100%;
}

.contato-main-definitivo .contato-side-box-premium {
  position: relative !important;
  top: auto !important;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 32px;
  border-radius: 32px;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 30px 76px rgba(8,31,112,.20);
}

.contato-main-definitivo .contato-side-box-premium h3,
.contato-main-definitivo .contato-side-box-premium h3 span,
.contato-main-definitivo .contato-step-copy strong {
  color: #ffffff !important;
}

.contato-main-definitivo .contato-side-box-premium > p,
.contato-main-definitivo .contato-side-box-premium small,
.contato-main-definitivo .contato-step-copy span,
.contato-main-definitivo .contato-steps-title {
  color: rgba(255,255,255,.74) !important;
}

.contato-main-definitivo .contato-side-box-premium h3 {
  font-size: clamp(22px, 2vw, 29px);
  line-height: 1.08;
  letter-spacing: -1.2px;
}

.contato-main-definitivo .contato-step {
  background: rgba(255,255,255,.10) !important;
  border-color: rgba(255,255,255,.13) !important;
}

.contato-main-definitivo .contato-step-icon {
  background: rgba(255,255,255,.14) !important;
  color: #ffffff !important;
}

.contato-main-definitivo .contato-whats-btn {
  margin-top: 4px;
  background: rgba(255,255,255,.98) !important;
  color: #071f72 !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.16);
}

.contato-main-definitivo .contato-whats-btn * {
  color: #071f72 !important;
}

@media (max-width: 980px) {
  .contato-main-definitivo .contato-grid-v4 {
    max-width: 760px;
    grid-template-columns: 1fr;
  }

  .contato-main-definitivo .contato-side-box-premium {
    min-height: auto;
  }
}

/* ====================================
   BLOG - AUTORIDADE MÁXIMA
   Blocos isolados da página Blog e Post.
==================================== */
.blog-authority-page .section,
.post-authority-page .section {
  padding: 76px 0;
}

.blog-authority-hero {
  padding: 96px 0 54px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(30,92,255,.10), transparent 34%),
    linear-gradient(180deg, #f8faff 0%, #f4f6fb 100%);
}

.blog-authority-hero-wrap {
  max-width: 930px;
  margin: 0 auto;
  text-align: center;
}

.blog-authority-hero-wrap h1 {
  font-size: clamp(44px, 6vw, 78px);
  max-width: 930px;
  margin: 0 auto 20px;
}

.blog-authority-hero-wrap p {
  max-width: 760px;
  margin: 0 auto 30px;
  font-size: 17px;
}

.blog-search {
  width: min(100%, 680px);
  margin: 0 auto 18px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 8px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(226,232,245,.95);
  border-radius: 999px;
  box-shadow: 0 18px 46px rgba(18,32,84,.08);
}

.blog-search input {
  min-height: 48px;
  border: 0;
  outline: none;
  background: transparent;
  padding: 0 18px;
  color: var(--text);
  font-size: 14px;
}

.blog-search button {
  min-height: 48px;
  border: 0;
  border-radius: 999px;
  padding: 0 24px;
  background: var(--primary);
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 14px 28px rgba(11,30,91,.18);
}

.blog-authority-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.blog-authority-pills span,
.blog-filter {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 16px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  color: #33406d;
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 10px 26px rgba(18,32,84,.05);
}

.blog-authority-featured {
  padding-top: 40px !important;
}

.blog-authority-featured-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .78fr);
  gap: 34px;
  align-items: stretch;
  padding: 28px;
  border-radius: 34px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 34px 86px rgba(18,32,84,.09);
}

.blog-authority-featured-content {
  padding: clamp(26px, 4vw, 54px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.blog-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 18px;
  padding: 8px 13px;
  border-radius: 999px;
  background: rgba(30,92,255,.08);
  color: var(--primary-2);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.blog-authority-featured-content h2 {
  font-size: clamp(32px, 4.4vw, 54px);
  margin: 0 0 18px;
}

.blog-authority-featured-content p {
  font-size: 16px;
  max-width: 640px;
}

.blog-featured-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.blog-featured-actions span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.blog-authority-featured-visual {
  position: relative;
  min-height: 410px;
  border-radius: 28px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-color: #0b1e5b;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
}

.blog-authority-featured-visual.has-gradient {
  background:
    radial-gradient(circle at 72% 18%, rgba(65,128,255,.55), transparent 30%),
    linear-gradient(145deg, #071f54 0%, #0b2d78 52%, #1764ff 100%);
}

.blog-authority-featured-visual::before,
.blog-cta-box::before,
.post-sidebar-blue::before,
.post-cover-gradient::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}

.featured-visual-card {
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 26px;
  padding: 24px;
  border-radius: 22px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(12px);
  color: #fff;
}

.featured-visual-card strong {
  display: block;
  margin-bottom: 8px;
  font-size: 20px;
  letter-spacing: -.04em;
}

.featured-visual-card span {
  color: rgba(255,255,255,.78);
  font-size: 14px;
  line-height: 1.55;
}

.blog-authority-categories {
  padding: 28px 0 26px !important;
}

.blog-filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.blog-filter.is-active,
.blog-filter:hover {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}

.blog-authority-listing {
  padding-top: 50px !important;
}

.blog-section-title {
  max-width: 760px;
  margin: 0 auto 34px;
  text-align: center;
}

.blog-section-title span {
  display: inline-flex;
  margin-bottom: 14px;
  color: var(--primary-2);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.blog-section-title h2 {
  font-size: clamp(30px, 4vw, 50px);
  margin-bottom: 14px;
}

.blog-authority-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.blog-authority-card {
  overflow: hidden;
  border-radius: 28px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 20px 46px rgba(18,32,84,.07);
  transition: transform .25s ease, box-shadow .25s ease;
}

.blog-authority-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 70px rgba(18,32,84,.12);
}

.blog-authority-card .blog-page-cover {
  min-height: 205px;
  display: flex;
  align-items: flex-start;
  padding: 18px;
  background: linear-gradient(135deg, #dfe8ff, #ffffff);
}

.blog-authority-card .cover-b { background: linear-gradient(135deg, #e7fbf2, #ffffff); }
.blog-authority-card .cover-c { background: linear-gradient(135deg, #fff1df, #ffffff); }
.blog-authority-card .cover-d { background: linear-gradient(135deg, #edf0ff, #ffffff); }
.blog-authority-card .cover-e { background: linear-gradient(135deg, #e5f7ff, #ffffff); }
.blog-authority-card .cover-f { background: linear-gradient(135deg, #f2e9ff, #ffffff); }

.blog-authority-card .blog-page-cover span {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff;
  color: var(--primary);
  font-size: 11px;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(18,32,84,.08);
}

.blog-authority-card .blog-page-body {
  padding: 24px;
}

.blog-card-meta {
  color: var(--primary-2);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.blog-authority-card h3 {
  margin: 11px 0 12px;
  font-size: 23px;
  line-height: 1.13;
}

.blog-authority-card p {
  font-size: 14px;
  margin-bottom: 20px;
}

.blog-authority-card a {
  color: var(--primary-2);
  font-size: 13px;
  font-weight: 900;
}

.blog-authority-cta {
  padding-top: 54px !important;
}

.blog-cta-box {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 36px;
  padding: clamp(34px, 5vw, 66px);
  border-radius: 34px;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 54%, #1455e8 100%);
  box-shadow: 0 32px 80px rgba(8,31,112,.20);
  color: #fff;
}

.blog-cta-box > * {
  position: relative;
  z-index: 1;
}

.blog-cta-box h2 {
  max-width: 780px;
  margin-bottom: 14px;
  font-size: clamp(30px, 4vw, 52px);
  color: #fff;
}

.blog-cta-box p {
  max-width: 680px;
  margin: 0;
  color: rgba(255,255,255,.78);
}

/* ====================================
   POST - LEITURA AUTORIDADE
==================================== */
.post-authority-hero {
  padding: 92px 0 50px !important;
  background: linear-gradient(180deg, #f8faff, #f3f6fb);
}

.post-hero-wrap {
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

.post-back {
  display: inline-flex;
  margin-bottom: 20px;
  color: var(--primary-2);
  font-size: 13px;
  font-weight: 900;
}

.post-hero-wrap h1 {
  font-size: clamp(42px, 6vw, 74px);
  margin: 0 auto 20px;
}

.post-hero-wrap p {
  max-width: 760px;
  margin: 0 auto 22px;
  font-size: 17px;
}

.post-hero-meta {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.post-hero-meta span {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  color: #33406d;
  font-size: 12px;
  font-weight: 800;
}

.post-grid {
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(280px, 340px);
  gap: 42px;
  align-items: start;
}

.post-content {
  min-width: 0;
}

.post-cover {
  min-height: 380px;
  margin-bottom: 28px;
  border-radius: 32px;
  overflow: hidden;
  background: #0b1e5b;
  box-shadow: 0 26px 70px rgba(18,32,84,.10);
}

.post-cover-gradient {
  position: relative;
  display: grid;
  place-items: end start;
  padding: 36px;
  color: #fff;
  background:
    radial-gradient(circle at 72% 20%, rgba(65,128,255,.48), transparent 34%),
    linear-gradient(145deg, #071f54 0%, #0b2d78 52%, #1764ff 100%);
}

.post-cover-gradient > div {
  position: relative;
  z-index: 1;
  max-width: 420px;
}

.post-cover-gradient span {
  display: inline-flex;
  margin-bottom: 12px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
}

.post-cover-gradient strong {
  display: block;
  font-size: 38px;
  line-height: 1.05;
  letter-spacing: -.05em;
}

.post-body-content {
  padding: 42px;
  border-radius: 30px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 20px 50px rgba(18,32,84,.06);
}

.post-body-content h2,
.post-content h2 {
  margin: 42px 0 14px;
  font-size: clamp(26px, 3vw, 36px);
}

.post-body-content h2:first-child {
  margin-top: 0;
}

.post-body-content p,
.post-content p,
.post-body-content li {
  font-size: 17px;
  line-height: 1.82;
  color: var(--muted);
}

.post-body-content ul {
  padding-left: 22px;
}

.blog-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 28px 0;
}

.blog-gallery img {
  width: 100%;
  border-radius: 22px;
  border: 1px solid var(--line);
  box-shadow: 0 18px 40px rgba(18,32,84,.07);
}

.post-cta-inline {
  margin-top: 30px;
  padding: 34px;
  border-radius: 30px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 24px 60px rgba(18,32,84,.08);
}

.post-cta-inline span {
  display: inline-flex;
  margin-bottom: 12px;
  color: var(--primary-2);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.post-cta-inline h3 {
  font-size: 30px;
  margin-bottom: 12px;
}

.post-sidebar {
  position: sticky;
  top: 112px;
  display: grid;
  gap: 18px;
}

.post-sidebar-box {
  padding: 24px;
  border-radius: 24px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 18px 42px rgba(18,32,84,.06);
}

.post-sidebar-box h3 {
  margin-bottom: 12px;
  font-size: 20px;
}

.post-sidebar-box p {
  font-size: 14px;
  margin-bottom: 12px;
}

.post-sidebar-box a:not(.btn) {
  display: block;
  padding: 12px 0;
  border-top: 1px solid var(--line);
  color: var(--primary);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.4;
}

.post-sidebar-blue {
  position: relative;
  overflow: hidden;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 54%, #1455e8 100%);
  color: #fff;
}

.post-sidebar-blue > * {
  position: relative;
  z-index: 1;
}

.post-sidebar-blue h3 {
  color: #fff;
}

.post-sidebar-blue p {
  color: rgba(255,255,255,.78);
}

.post-sidebar-blue .btn {
  width: 100%;
}

@media (max-width: 980px) {
  .blog-authority-featured-card,
  .blog-cta-box,
  .post-grid {
    grid-template-columns: 1fr;
  }

  .blog-authority-featured-visual {
    min-height: 320px;
  }

  .blog-authority-grid {
    grid-template-columns: 1fr 1fr;
  }

  .post-sidebar {
    position: static;
  }
}

@media (max-width: 680px) {
  .blog-authority-page .section,
  .post-authority-page .section {
    padding: 58px 0;
  }

  .blog-search {
    grid-template-columns: 1fr;
    border-radius: 24px;
  }

  .blog-search button {
    width: 100%;
  }

  .blog-authority-featured-card,
  .post-body-content,
  .post-cta-inline {
    padding: 22px;
    border-radius: 24px;
  }

  .blog-authority-grid,
  .blog-gallery {
    grid-template-columns: 1fr;
  }

  .post-cover {
    min-height: 260px;
    border-radius: 24px;
  }

  .blog-cta-box {
    text-align: center;
  }

  .blog-cta-box .btn {
    width: 100%;
  }
}


/* ====================================
   BLOG - CLEAN PREMIUM SEM DESTAQUE
   Remove o comportamento de artigo em destaque e mantém o grid como foco.
==================================== */
.blog-authority-featured {
  display: none !important;
}

.blog-authority-categories {
  padding-top: 40px !important;
}

.blog-authority-listing {
  padding-top: 46px !important;
}

.blog-authority-grid .blog-authority-card:first-child {
  grid-column: span 2;
}

.blog-authority-grid .blog-authority-card:first-child .blog-page-cover {
  min-height: 260px;
}

.blog-authority-grid .blog-authority-card:first-child h3 {
  font-size: clamp(26px, 3vw, 34px);
  max-width: 720px;
}

@media (max-width: 980px) {
  .blog-authority-grid .blog-authority-card:first-child {
    grid-column: span 2;
  }
}

@media (max-width: 680px) {
  .blog-authority-grid .blog-authority-card:first-child {
    grid-column: span 1;
  }

  .blog-authority-grid .blog-authority-card:first-child .blog-page-cover {
    min-height: 205px;
  }
}

/* ====================================
   BLOG - GERAÇÃO DE LEADS / TOPO CLEAN FINAL
   Escopo isolado para a página Blog.
==================================== */
.blog-lead-topo {
  padding: 104px 0 34px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(30,92,255,.08), transparent 32%),
    linear-gradient(180deg, #f8faff 0%, #f6f8fc 100%);
}

.blog-lead-header {
  max-width: 1060px;
  margin: 0 auto;
  text-align: center;
}

.blog-lead-header h1 {
  max-width: 900px;
  margin: 0 auto 30px;
  font-size: clamp(42px, 6vw, 76px);
  line-height: .98;
  letter-spacing: -.07em;
}

.blog-lead-filter-card {
  max-width: 920px;
  margin: 0 auto;
  padding: 12px;
  border-radius: 30px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(226,232,245,.96);
  box-shadow: 0 26px 74px rgba(18,32,84,.09);
  backdrop-filter: blur(16px);
}

.blog-lead-search {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  margin-bottom: 12px;
}

.blog-lead-search input {
  min-height: 54px;
  width: 100%;
  border: 1px solid rgba(226,232,245,.96);
  border-radius: 999px;
  outline: none;
  background: #fff;
  padding: 0 20px;
  color: var(--text);
  font-family: inherit;
  font-size: 14px;
}

.blog-lead-search input:focus {
  border-color: rgba(30,92,255,.34);
  box-shadow: 0 0 0 4px rgba(30,92,255,.08);
}

.blog-lead-search button {
  min-height: 54px;
  border: 0;
  border-radius: 999px;
  padding: 0 26px;
  background: var(--primary);
  color: #fff;
  font-family: inherit;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 16px 34px rgba(11,30,91,.18);
}

.blog-lead-filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.blog-lead-filter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  color: #33406d;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(18,32,84,.05);
  transition: .2s ease;
}

.blog-lead-filter:hover,
.blog-lead-filter.is-active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
  transform: translateY(-1px);
}

.blog-lead-listing {
  padding-top: 44px !important;
}

.blog-lead-listing .blog-listing-wrap {
  position: relative;
}

.blog-lead-listing .blog-authority-grid {
  align-items: stretch;
}

.blog-lead-listing .blog-authority-card {
  display: flex;
  flex-direction: column;
}

.blog-lead-listing .blog-page-body {
  display: flex;
  flex: 1;
  flex-direction: column;
}

.blog-lead-listing .blog-page-body a {
  margin-top: auto;
}

.blog-lead-cta-section {
  padding-top: 42px !important;
}

.blog-lead-cta-box {
  grid-template-columns: minmax(0, 1fr) auto;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 54%, #1455e8 100%);
}

.blog-lead-cta-box .btn {
  white-space: nowrap;
}

@media (max-width: 760px) {
  .blog-lead-topo {
    padding: 82px 0 28px !important;
  }

  .blog-lead-header h1 {
    font-size: clamp(38px, 12vw, 56px);
  }

  .blog-lead-filter-card {
    border-radius: 24px;
  }

  .blog-lead-search {
    grid-template-columns: 1fr;
  }

  .blog-lead-search button,
  .blog-lead-cta-box .btn {
    width: 100%;
  }

  .blog-lead-cta-box {
    grid-template-columns: 1fr;
    text-align: center;
  }
}

/* BLOG - GRID SEM DESTAQUE INDIVIDUAL */
.blog-lead-listing .blog-authority-grid .blog-authority-card:first-child {
  grid-column: span 1;
}

.blog-lead-listing .blog-authority-grid .blog-authority-card:first-child .blog-page-cover {
  min-height: 205px;
}

.blog-lead-listing .blog-authority-grid .blog-authority-card:first-child h3 {
  font-size: 23px;
  max-width: none;
}

/* ====================================
   PROJETO + POST DETALHE PREMIUM
   Blocos isolados para projeto.php e navegação dos posts.
==================================== */
.case-card-link {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  color: inherit;
}

.case-cover.has-image,
.portfolio-card-cover-v3.has-image {
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}

.case-cover.has-image::before,
.portfolio-card-cover-v3.has-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8,24,62,.12), rgba(8,24,62,.54));
}

.case-cover.has-image span,
.portfolio-card-cover-v3.has-image span,
.portfolio-card-cover-v3.has-image .project-year {
  position: relative;
  z-index: 1;
}

.case-link-text {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 800;
  color: var(--primary-2);
}

.portfolio-load-wrap {
  margin-top: 38px;
}

.project-detail-page .section,
.post-navigation-section {
  padding: 76px 0;
}

.project-detail-hero {
  padding: 98px 0 54px !important;
  background:
    radial-gradient(circle at 76% 8%, rgba(30,92,255,.12), transparent 34%),
    linear-gradient(180deg, #f8faff 0%, #f3f6fb 100%);
}

.project-detail-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(380px, .72fr);
  gap: 54px;
  align-items: center;
}

.project-detail-copy h1 {
  max-width: 760px;
  margin: 0 0 22px;
  font-size: clamp(42px, 6vw, 74px);
}

.project-detail-copy p {
  max-width: 680px;
  margin: 0 0 30px;
  font-size: 17px;
}

.project-detail-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.project-detail-panel {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: 34px;
  color: #fff;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 54%, #1455e8 100%);
  box-shadow: 0 30px 80px rgba(11,30,91,.24);
  border: 1px solid rgba(137,180,255,.28);
}

.project-detail-panel::before,
.project-cta-inline::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}

.project-detail-panel::after {
  content: "";
  position: absolute;
  width: 210px;
  height: 210px;
  border-radius: 50%;
  right: -80px;
  top: -90px;
  background: rgba(255,255,255,.13);
  filter: blur(4px);
}

.project-detail-panel > * {
  position: relative;
  z-index: 1;
}

.panel-kicker {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  color: #dce7ff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.project-detail-panel h2 {
  margin: 0 0 24px;
  font-size: clamp(27px, 3vw, 38px);
  color: #fff;
}

.project-detail-metrics {
  display: grid;
  gap: 12px;
}

.project-detail-metrics article {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.13);
}

.project-detail-metrics small {
  display: block;
  margin-bottom: 6px;
  color: rgba(230,238,255,.68);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.project-detail-metrics strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.45;
}

.project-detail-cover-section {
  padding-top: 26px !important;
}

.project-detail-cover {
  min-height: clamp(340px, 52vw, 620px);
  margin: 0;
  border-radius: 34px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-color: #0b1e5b;
  box-shadow: var(--shadow-strong);
  border: 1px solid rgba(226,232,245,.92);
}

.project-detail-cover.is-placeholder {
  display: flex;
  align-items: flex-end;
  padding: 34px;
  color: #fff;
  background:
    radial-gradient(circle at 72% 18%, rgba(65,128,255,.55), transparent 30%),
    linear-gradient(145deg, #071f54 0%, #0b2d78 52%, #1764ff 100%);
}

.project-detail-cover.is-placeholder span {
  display: block;
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #dce7ff;
}

.project-detail-cover.is-placeholder strong {
  display: block;
  max-width: 760px;
  font-size: clamp(32px, 5vw, 58px);
  letter-spacing: -.055em;
  line-height: 1;
}

.project-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.project-summary-card {
  min-height: 150px;
  padding: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: var(--shadow-card);
}

.project-summary-card small {
  display: block;
  margin-bottom: 14px;
  color: var(--primary-2);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.project-summary-card strong {
  display: block;
  color: var(--text);
  font-size: 18px;
  line-height: 1.35;
  letter-spacing: -.03em;
}

.project-case-section {
  padding-top: 36px !important;
}

.project-case-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 34px;
  align-items: start;
}

.project-case-content {
  padding: clamp(28px, 4vw, 52px);
  border-radius: 32px;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: var(--shadow-card);
}

.project-case-block + .project-case-block {
  margin-top: 44px;
  padding-top: 44px;
  border-top: 1px solid var(--line);
}

.project-case-block h2 {
  margin: 0 0 18px;
  font-size: clamp(28px, 3vw, 42px);
}

.project-rich-text p,
.post-body-content p {
  font-size: 16px;
  margin-bottom: 18px;
}

.project-rich-text ul,
.post-body-content ul,
.project-rich-text ol,
.post-body-content ol {
  margin: 20px 0;
  padding-left: 22px;
  color: var(--muted);
  line-height: 1.8;
}

.project-cta-inline {
  position: relative;
  overflow: hidden;
  margin-top: 46px;
  border: 0;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 54%, #1455e8 100%);
  color: #fff;
}

.project-cta-inline > * {
  position: relative;
  z-index: 1;
}

.project-cta-inline h3,
.project-cta-inline p,
.project-cta-inline span {
  color: #fff;
}

.project-detail-sidebar {
  position: sticky;
  top: 108px;
}

.project-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.project-gallery-item {
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-card);
}

.project-gallery-item img {
  width: 100%;
  height: 260px;
  object-fit: cover;
}

.project-navigation-section,
.post-navigation-section {
  padding-top: 10px !important;
}

.project-navigation-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.project-nav-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 138px;
  padding: 24px;
  border-radius: 26px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-card);
  transition: .25s ease;
}

.project-nav-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-strong);
}

.project-nav-card span {
  display: block;
  margin-bottom: 10px;
  color: var(--muted-2);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.project-nav-card strong {
  color: var(--text);
  font-size: clamp(18px, 2.4vw, 25px);
  line-height: 1.2;
  letter-spacing: -.04em;
}

.project-nav-card.is-next {
  text-align: right;
}

.project-nav-card.is-disabled {
  opacity: .56;
  pointer-events: none;
  background: #f8faff;
}

@media (max-width: 980px) {
  .project-detail-hero-grid,
  .project-case-grid {
    grid-template-columns: 1fr;
  }

  .project-detail-sidebar {
    position: static;
  }

  .project-summary-grid,
  .project-gallery-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .project-navigation-grid {
    grid-template-columns: 1fr;
  }

  .project-nav-card.is-next {
    text-align: left;
  }

  .project-detail-actions {
    flex-direction: column;
  }

  .project-detail-actions .btn {
    width: 100%;
  }
}

/* ====================================
   PROJETO - PORTFÓLIO QUE VENDE
   Remove o hero tradicional e abre o case com imagem + informação comercial.
==================================== */
.project-selling-hero {
  padding: 104px 0 34px !important;
  background:
    radial-gradient(circle at 78% 8%, rgba(30,92,255,.10), transparent 34%),
    linear-gradient(180deg, #f8faff 0%, #f3f6fb 100%);
}

.project-selling-back {
  margin-bottom: 22px;
}

.project-selling-cover {
  position: relative;
  min-height: clamp(520px, 64vw, 720px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  align-items: end;
  gap: 28px;
  padding: clamp(28px, 5vw, 58px);
  border-radius: 36px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-color: #081d45;
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 34px 92px rgba(11,30,91,.20);
}

.project-selling-cover.is-placeholder {
  background:
    radial-gradient(circle at 70% 18%, rgba(65,128,255,.55), transparent 30%),
    linear-gradient(145deg, #071f54 0%, #0b2d78 52%, #1764ff 100%);
}

.project-selling-cover.has-cover {
  background-blend-mode: normal;
  background-position: center;
}

.project-selling-cover.has-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 72% 14%, rgba(30,92,255,.28), transparent 34%),
    linear-gradient(145deg, rgba(5,19,51,.82) 0%, rgba(6,28,76,.62) 45%, rgba(12,74,190,.28) 100%);
  z-index: 0;
  pointer-events: none;
}

.project-selling-cover.has-cover .project-selling-overlay {
  background:
    linear-gradient(90deg, rgba(4,13,38,.90) 0%, rgba(4,13,38,.66) 42%, rgba(4,13,38,.28) 100%),
    linear-gradient(180deg, rgba(4,13,38,.10) 0%, rgba(4,13,38,.82) 100%);
}

.project-selling-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(4,13,38,.86) 0%, rgba(4,13,38,.60) 44%, rgba(4,13,38,.22) 100%),
    linear-gradient(180deg, rgba(4,13,38,.08) 0%, rgba(4,13,38,.74) 100%);
  pointer-events: none;
}

.project-selling-overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px);
  background-size: 48px 48px;
}

.project-selling-content,
.project-selling-card {
  position: relative;
  z-index: 1;
}

.project-selling-content {
  max-width: 790px;
}

.project-selling-content .eyebrow {
  color: #dce7ff;
}

.project-selling-content h1 {
  margin: 0 0 18px;
  color: #fff;
  font-size: clamp(42px, 6.4vw, 78px);
  line-height: .94;
  letter-spacing: -.07em;
}

.project-selling-content p {
  max-width: 690px;
  margin: 0 0 30px;
  color: rgba(238,244,255,.86);
  font-size: clamp(16px, 1.5vw, 19px);
  line-height: 1.75;
}

.project-selling-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.project-selling-actions .btn-secondary {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: rgba(255,255,255,.22);
  backdrop-filter: blur(14px);
}

.project-selling-card {
  padding: 22px;
  border-radius: 26px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 22px 54px rgba(0,0,0,.18);
  backdrop-filter: blur(18px);
}

.project-selling-card > span {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.13);
  color: #dce7ff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.project-selling-card div {
  padding: 16px 0;
  border-top: 1px solid rgba(255,255,255,.14);
}

.project-selling-card small {
  display: block;
  margin-bottom: 6px;
  color: rgba(230,238,255,.68);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.project-selling-card strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.45;
}

.project-detail-summary {
  padding-top: 34px !important;
  padding-bottom: 34px !important;
}

.project-case-section {
  padding-top: 42px !important;
}

@media (max-width: 980px) {
  .project-selling-cover {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .project-selling-card {
    max-width: none;
  }
}

@media (max-width: 680px) {
  .project-selling-hero {
    padding-top: 84px !important;
  }

  .project-selling-cover {
    border-radius: 26px;
    padding: 24px;
  }

  .project-selling-actions {
    flex-direction: column;
  }

  .project-selling-actions .btn {
    width: 100%;
  }
}

/* ====================================
   PROJETO - SIDEBAR INTERNACIONAL
   Remove redundância visual e transforma a lateral do case em apoio comercial.
==================================== */
.project-detail-summary {
  display: none !important;
}

.project-case-section {
  padding-top: 54px !important;
}

.project-international-sidebar {
  position: sticky;
  top: 108px;
  display: grid;
  gap: 18px;
}

.project-info-card,
.project-sidebar-cta-card,
.project-related-card {
  border-radius: 28px;
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 22px 60px rgba(11,30,91,.08);
}

.project-info-card {
  padding: 24px;
  background:
    radial-gradient(circle at 86% 8%, rgba(30,92,255,.10), transparent 32%),
    rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
}

.project-info-pill,
.project-sidebar-cta-card > span,
.project-related-card > span {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 16px;
  padding: 7px 11px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.project-info-pill {
  color: var(--primary-2);
  background: rgba(25,91,255,.08);
}

.project-info-row {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 13px;
  align-items: center;
  padding: 17px 0;
  border-top: 1px solid rgba(226,232,245,.92);
}

.project-info-row:first-of-type {
  border-top: 0;
  padding-top: 2px;
}

.project-info-row i,
.project-info-row svg {
  width: 42px;
  height: 42px;
  padding: 11px;
  border-radius: 15px;
  color: var(--primary-2);
  background: linear-gradient(180deg, rgba(25,91,255,.12), rgba(25,91,255,.04));
  border: 1px solid rgba(25,91,255,.12);
}

.project-info-row small {
  display: block;
  margin-bottom: 5px;
  color: var(--muted-2);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.project-info-row strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  line-height: 1.42;
}

.project-sidebar-cta-card {
  position: relative;
  overflow: hidden;
  padding: 26px;
  color: #fff;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 56%, #1455e8 100%);
}

.project-sidebar-cta-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.032) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
}

.project-sidebar-cta-card > * {
  position: relative;
  z-index: 1;
}

.project-sidebar-cta-card > span {
  color: #dce7ff;
  background: rgba(255,255,255,.12);
}

.project-sidebar-cta-card h3 {
  margin: 0 0 12px;
  color: #fff;
  font-size: 24px;
  line-height: 1.08;
  letter-spacing: -.045em;
}

.project-sidebar-cta-card p {
  margin: 0 0 18px;
  color: rgba(238,244,255,.78);
  font-size: 14px;
  line-height: 1.65;
}

.project-sidebar-cta-card .btn {
  width: 100%;
  justify-content: center;
}

.project-related-card {
  padding: 24px;
  background: rgba(255,255,255,.88);
}

.project-related-card > span {
  color: var(--primary-2);
  background: rgba(25,91,255,.08);
}

.project-related-card h3 {
  margin: 0 0 14px;
  font-size: 21px;
  letter-spacing: -.04em;
}

.project-related-card a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0;
  color: var(--text);
  border-top: 1px solid rgba(226,232,245,.92);
}

.project-related-card a strong {
  font-size: 14px;
  line-height: 1.35;
}

.project-related-card a i,
.project-related-card a svg {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  color: var(--primary-2);
}

.project-related-card a:hover strong {
  color: var(--primary-2);
}

@media (max-width: 980px) {
  .project-international-sidebar {
    position: static;
  }
}

/* ====================================
   PROJETO - SIDEBAR FINAL + RELACIONADOS PREMIUM
   Sidebar sem informações repetidas e projetos relacionados com capa visual.
==================================== */
.project-international-sidebar .project-info-card {
  display: none !important;
}

.project-related-card-premium {
  padding: 22px;
}

.project-related-card-premium h3 {
  margin-bottom: 16px;
}

.project-related-premium-list {
  display: grid;
  gap: 12px;
}

.project-related-card .project-related-premium-item,
.project-related-premium-item {
  position: relative;
  display: block;
  height: 112px;
  overflow: hidden;
  padding: 0 !important;
  border: 1px solid rgba(226,232,245,.92);
  border-radius: 18px;
  background: linear-gradient(135deg, #071d3a, #1455e8);
  box-shadow: 0 14px 36px rgba(11,30,91,.10);
  isolation: isolate;
}

.project-related-card .project-related-premium-item + .project-related-premium-item,
.project-related-premium-item + .project-related-premium-item {
  border-top: 1px solid rgba(226,232,245,.92);
}

.project-related-premium-thumb {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.01);
  transition: transform .45s ease, filter .45s ease;
}

.project-related-premium-item.is-placeholder .project-related-premium-thumb {
  background:
    radial-gradient(circle at 78% 12%, rgba(255,255,255,.22), transparent 30%),
    linear-gradient(135deg, #071d3a, #1455e8);
}

.project-related-premium-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(7,24,52,.08), rgba(7,24,52,.78)),
    linear-gradient(90deg, rgba(7,24,52,.70), rgba(7,24,52,.16));
}

.project-related-premium-content {
  position: absolute;
  left: 14px;
  right: 42px;
  bottom: 13px;
  z-index: 2;
}

.project-related-premium-content small {
  display: block;
  margin-bottom: 4px;
  color: rgba(255,255,255,.72);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.project-related-card .project-related-premium-content strong,
.project-related-premium-content strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.18;
  letter-spacing: -.035em;
}

.project-related-card .project-related-premium-item i,
.project-related-card .project-related-premium-item svg,
.project-related-premium-item i,
.project-related-premium-item svg {
  position: absolute;
  right: 14px;
  bottom: 15px;
  z-index: 2;
  width: 18px;
  height: 18px;
  color: #fff;
  opacity: .9;
  transition: transform .25s ease, opacity .25s ease;
}

.project-related-premium-item:hover .project-related-premium-thumb {
  transform: scale(1.08);
  filter: saturate(1.06) contrast(1.03);
}

.project-related-premium-item:hover i,
.project-related-premium-item:hover svg {
  transform: translate(2px, -2px);
  opacity: 1;
}

.project-related-premium-item:hover .project-related-premium-content strong {
  color: #fff;
}

@media (max-width: 980px) {
  .project-related-card .project-related-premium-item,
  .project-related-premium-item {
    height: 130px;
  }
}

/* ====================================
   POST - BLOG QUE CONVERTE
   Detalhe do post com capa dinâmica, sidebar de conversão e relacionados premium.
==================================== */
.post-selling-page .post-selling-hero {
  padding: 104px 0 34px !important;
  background:
    radial-gradient(circle at 78% 8%, rgba(30,92,255,.10), transparent 34%),
    linear-gradient(180deg, #f8faff 0%, #f3f6fb 100%);
}

.post-reading-cover {
  position: relative;
  min-height: clamp(520px, 64vw, 720px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  align-items: end;
  gap: 28px;
  padding: clamp(28px, 5vw, 58px);
  border-radius: 36px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-color: #081d45;
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 34px 92px rgba(11,30,91,.20);
}

.post-reading-cover.is-placeholder {
  background:
    radial-gradient(circle at 70% 18%, rgba(65,128,255,.55), transparent 30%),
    linear-gradient(145deg, #071f54 0%, #0b2d78 52%, #1764ff 100%);
}

.post-reading-cover.has-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 72% 14%, rgba(30,92,255,.28), transparent 34%),
    linear-gradient(145deg, rgba(5,19,51,.82) 0%, rgba(6,28,76,.62) 45%, rgba(12,74,190,.28) 100%);
  z-index: 0;
  pointer-events: none;
}

.post-reading-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(4,13,38,.88) 0%, rgba(4,13,38,.64) 42%, rgba(4,13,38,.22) 100%),
    linear-gradient(180deg, rgba(4,13,38,.08) 0%, rgba(4,13,38,.76) 100%);
  pointer-events: none;
}

.post-reading-overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px);
  background-size: 48px 48px;
}

.post-reading-content,
.post-reading-card {
  position: relative;
  z-index: 1;
}

.post-reading-content {
  max-width: 820px;
}

.post-reading-content .eyebrow {
  color: #dce7ff;
}

.post-reading-content h1 {
  margin: 0 0 18px;
  color: #fff;
  font-size: clamp(40px, 6.1vw, 72px);
  line-height: .96;
  letter-spacing: -.07em;
}

.post-reading-content p {
  max-width: 720px;
  margin: 0 0 30px;
  color: rgba(238,244,255,.86);
  font-size: clamp(16px, 1.5vw, 19px);
  line-height: 1.75;
}

.post-reading-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.post-reading-actions .btn-secondary {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: rgba(255,255,255,.22);
  backdrop-filter: blur(14px);
}

.post-reading-card {
  padding: 22px;
  border-radius: 26px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 22px 54px rgba(0,0,0,.18);
  backdrop-filter: blur(18px);
}

.post-reading-card > span {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.13);
  color: #dce7ff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.post-reading-card div {
  padding: 16px 0;
  border-top: 1px solid rgba(255,255,255,.14);
}

.post-reading-card small {
  display: block;
  margin-bottom: 6px;
  color: rgba(230,238,255,.68);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.post-reading-card strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.45;
}

.post-reading-section {
  padding-top: 54px !important;
}

.post-reading-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 34px;
  align-items: start;
}

.post-body-premium {
  padding: clamp(30px, 4vw, 54px);
  border-radius: 32px;
}

.post-body-premium > :first-child {
  margin-top: 0;
}

.post-cta-premium {
  position: relative;
  overflow: hidden;
  margin-top: 46px;
  border: 0;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 54%, #1455e8 100%);
  color: #fff;
}

.post-cta-premium::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.032) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
}

.post-cta-premium > * {
  position: relative;
  z-index: 1;
}

.post-cta-premium h3,
.post-cta-premium p,
.post-cta-premium span {
  color: #fff;
}

.post-international-sidebar {
  position: sticky;
  top: 108px;
  display: grid;
  gap: 18px;
}

.post-sidebar-cta-card,
.post-related-card {
  border-radius: 28px;
  border: 1px solid rgba(226,232,245,.95);
  box-shadow: 0 22px 60px rgba(11,30,91,.08);
}

.post-sidebar-cta-card {
  position: relative;
  overflow: hidden;
  padding: 26px;
  color: #fff;
  background: linear-gradient(145deg, #071d3a 0%, #0b3470 56%, #1455e8 100%);
}

.post-sidebar-cta-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.032) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
}

.post-sidebar-cta-card > * {
  position: relative;
  z-index: 1;
}

.post-sidebar-cta-card > span,
.post-related-card > span {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 16px;
  padding: 7px 11px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.post-sidebar-cta-card > span {
  color: #dce7ff;
  background: rgba(255,255,255,.12);
}

.post-sidebar-cta-card h3 {
  margin: 0 0 12px;
  color: #fff;
  font-size: 24px;
  line-height: 1.08;
  letter-spacing: -.045em;
}

.post-sidebar-cta-card p {
  margin: 0 0 18px;
  color: rgba(238,244,255,.78);
  font-size: 14px;
  line-height: 1.65;
}

.post-sidebar-cta-card .btn {
  width: 100%;
  justify-content: center;
}

.post-related-card {
  padding: 22px;
  background: rgba(255,255,255,.88);
}

.post-related-card > span {
  color: var(--primary-2);
  background: rgba(25,91,255,.08);
}

.post-related-card h3 {
  margin: 0 0 16px;
  font-size: 21px;
  letter-spacing: -.04em;
}

.post-related-premium-list {
  display: grid;
  gap: 12px;
}

.post-related-premium-item {
  position: relative;
  display: block;
  height: 122px;
  overflow: hidden;
  border: 1px solid rgba(226,232,245,.92);
  border-radius: 18px;
  background: linear-gradient(135deg, #071d3a, #1455e8);
  box-shadow: 0 14px 36px rgba(11,30,91,.10);
  isolation: isolate;
}

.post-related-premium-thumb {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.01);
  transition: transform .45s ease, filter .45s ease;
}

.post-related-premium-item.is-placeholder .post-related-premium-thumb {
  background:
    radial-gradient(circle at 78% 12%, rgba(255,255,255,.22), transparent 30%),
    linear-gradient(135deg, #071d3a, #1455e8);
}

.post-related-premium-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(7,24,52,.08), rgba(7,24,52,.78)),
    linear-gradient(90deg, rgba(7,24,52,.70), rgba(7,24,52,.16));
}

.post-related-premium-content {
  position: absolute;
  left: 14px;
  right: 42px;
  bottom: 13px;
  z-index: 2;
}

.post-related-premium-content small {
  display: block;
  margin-bottom: 4px;
  color: rgba(255,255,255,.72);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.post-related-premium-content strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.18;
  letter-spacing: -.035em;
}

.post-related-premium-item i,
.post-related-premium-item svg {
  position: absolute;
  right: 14px;
  bottom: 15px;
  z-index: 2;
  width: 18px;
  height: 18px;
  color: #fff;
  opacity: .9;
  transition: transform .25s ease, opacity .25s ease;
}

.post-related-premium-item:hover .post-related-premium-thumb {
  transform: scale(1.08);
  filter: saturate(1.06) contrast(1.03);
}

.post-related-premium-item:hover i,
.post-related-premium-item:hover svg {
  transform: translate(2px, -2px);
  opacity: 1;
}

@media (max-width: 980px) {
  .post-reading-cover,
  .post-reading-grid {
    grid-template-columns: 1fr;
  }

  .post-reading-cover {
    min-height: auto;
  }

  .post-international-sidebar {
    position: static;
  }
}

@media (max-width: 680px) {
  .post-selling-page .post-selling-hero {
    padding-top: 84px !important;
  }

  .post-reading-cover {
    border-radius: 26px;
    padding: 24px;
  }

  .post-reading-actions {
    flex-direction: column;
  }

  .post-reading-actions .btn {
    width: 100%;
  }

  .post-related-premium-item {
    height: 135px;
  }
}

/* ====================================
   PORTFÓLIO - REFINO VISUAL DO CASE E CARDS
   Ajuste incremental para mostrar melhor a capa real do projeto.
==================================== */
.project-selling-cover.is-placeholder {
  background:
    radial-gradient(circle at 82% 12%, rgba(54, 110, 255, .18), transparent 34%),
    linear-gradient(145deg, #061834 0%, #0a2858 48%, #0d4ed8 100%) !important;
}

.project-selling-cover.has-cover::before {
  display: none !important;
}

.project-selling-cover {
  min-height: auto;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .82fr);
  align-items: center;
  padding: clamp(30px, 5vw, 58px);
}

.project-selling-overlay {
  background:
    linear-gradient(90deg, rgba(4,13,38,.58) 0%, rgba(4,13,38,.18) 100%),
    linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(4,13,38,.26) 100%);
}

.project-selling-side {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 18px;
}

.project-selling-media {
  margin: 0;
  padding: 16px;
  border-radius: 28px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(255,255,255,.38);
  box-shadow: 0 26px 70px rgba(0,0,0,.22);
  backdrop-filter: blur(16px);
}

.project-selling-media img {
  display: block;
  width: 100%;
  height: clamp(230px, 25vw, 320px);
  object-fit: contain;
  border-radius: 20px;
  background: #f4f7fb;
}

.project-selling-card {
  padding: 20px;
  border-radius: 24px;
  background: rgba(255,255,255,.10);
  box-shadow: 0 18px 44px rgba(0,0,0,.14);
}

.project-selling-card div {
  padding: 13px 0;
}

.portfolio-card-cover-v3.has-image {
  min-height: 235px;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-color: #eef3fb;
}

.portfolio-card-cover-v3.has-image::before {
  inset: 18px;
  background: transparent !important;
  border: 1px solid rgba(255,255,255,.66);
  box-shadow: inset 0 0 70px rgba(255,255,255,.38);
}

.portfolio-card-cover-v3.has-image::after {
  opacity: .36;
}

.portfolio-card-cover-v3.has-image > span,
.portfolio-card-cover-v3.has-image .project-year {
  box-shadow: 0 10px 24px rgba(11,24,75,.08);
}

.portfolio-card-content-v3 {
  padding: 26px 26px 24px;
}

.portfolio-card-content-v3 h2 {
  font-size: 24px;
}

.portfolio-card-content-v3 p {
  margin-bottom: 22px;
}

.portfolio-card-v3 .project-impact {
  display: none;
}

.portfolio-card-v3 .project-card-footer {
  margin-top: auto;
}

@media (max-width: 980px) {
  .project-selling-cover {
    grid-template-columns: 1fr;
  }

  .project-selling-media img {
    height: auto;
    max-height: 360px;
  }
}

@media (max-width: 680px) {
  .project-selling-media {
    padding: 10px;
    border-radius: 22px;
  }

  .project-selling-media img {
    border-radius: 16px;
  }
}

/* ====================================
   REFINO CAPAS PORTFÓLIO/PROJETO - SEM BLUR
   Mantém a arte completa e remove camadas que escondiam a capa.
==================================== */
.portfolio-card-cover-v3.has-image {
  min-height: 250px !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-color: #f7f9fc !important;
  border: 1px solid rgba(224, 231, 245, .9) !important;
  overflow: hidden !important;
}

.portfolio-card-cover-v3.has-image::before,
.portfolio-card-cover-v3.has-image::after {
  display: none !important;
  content: none !important;
}

.portfolio-card-cover-v3.has-image > span,
.portfolio-card-cover-v3.has-image .project-year {
  position: relative;
  z-index: 2;
  box-shadow: 0 14px 30px rgba(11, 24, 75, .10) !important;
}

.project-selling-cover.has-cover {
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-color: #f7f9fc !important;
  border: 1px solid rgba(224, 231, 245, .95) !important;
}

.project-selling-cover.has-cover::before,
.project-selling-cover.has-cover .project-selling-overlay,
.project-selling-cover.has-cover .project-selling-overlay::after {
  display: none !important;
  content: none !important;
}

.project-selling-cover.has-cover .project-selling-content {
  padding: clamp(22px, 3vw, 34px);
  border-radius: 28px;
  background: linear-gradient(145deg, rgba(5, 16, 48, .92), rgba(7, 31, 84, .84));
  border: 1px solid rgba(255, 255, 255, .16);
  box-shadow: 0 24px 64px rgba(8, 24, 69, .22);
}

.project-selling-cover.has-cover .project-selling-card {
  background: linear-gradient(145deg, rgba(5, 16, 48, .90), rgba(7, 31, 84, .80));
  border: 1px solid rgba(255, 255, 255, .16);
  box-shadow: 0 24px 64px rgba(8, 24, 69, .20);
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.project-selling-cover.has-cover .project-selling-media {
  display: none !important;
}

@media (max-width: 760px) {
  .portfolio-card-cover-v3.has-image {
    min-height: 210px !important;
  }

  .project-selling-cover.has-cover {
    background-position: center top !important;
    align-items: end;
  }
}


/* ====================================
   PROJETO / PORTFÓLIO - CAPA FINAL LIMPA
   Capa real como fundo do bloco, sem blur, sem textura e sem overlay azul.
==================================== */
.project-selling-cover.has-cover {
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-color: transparent !important;
  min-height: clamp(520px, 58vw, 680px) !important;
  border: 1px solid rgba(224, 231, 245, .9) !important;
  box-shadow: 0 34px 92px rgba(11, 30, 91, .16) !important;
}

.project-selling-cover.has-cover::before,
.project-selling-cover.has-cover .project-selling-overlay,
.project-selling-cover.has-cover .project-selling-overlay::after {
  display: none !important;
  opacity: 0 !important;
  content: none !important;
  background: none !important;
}

.project-selling-cover.has-cover .project-selling-content {
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-shadow: 0 3px 22px rgba(0, 0, 0, .76) !important;
}

.project-selling-cover.has-cover .project-selling-content h1,
.project-selling-cover.has-cover .project-selling-content p,
.project-selling-cover.has-cover .project-selling-content .eyebrow {
  text-shadow: 0 3px 22px rgba(0, 0, 0, .76) !important;
}

.project-selling-cover.has-cover .project-selling-card {
  background: rgba(5, 13, 34, .48) !important;
  border: 1px solid rgba(255, 255, 255, .22) !important;
  box-shadow: 0 24px 64px rgba(0, 0, 0, .22) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.project-selling-cover.has-cover .project-selling-media {
  display: none !important;
}

.portfolio-card-cover-v3.has-image {
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-color: #eef3fb !important;
}

.portfolio-card-cover-v3.has-image::before,
.portfolio-card-cover-v3.has-image::after {
  display: none !important;
  content: none !important;
  background: none !important;
}

@media (max-width: 760px) {
  .project-selling-cover.has-cover {
    min-height: 560px !important;
    background-position: center !important;
  }
}


/* ====================================
   PROJETO - HERO NO PONTO IDEAL
   Capa real em fundo full com controle de luz neutro.
   Sem blur, sem textura e sem overlay azul pesado.
==================================== */
.project-selling-cover.has-cover {
  position: relative !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-color: #081327 !important;
  min-height: clamp(560px, 60vw, 700px) !important;
  border: 1px solid rgba(224, 231, 245, .92) !important;
  box-shadow: 0 34px 92px rgba(11, 30, 91, .18) !important;
  isolation: isolate !important;
}

/* overlay neutro, quase invisível, só para leitura */
.project-selling-cover.has-cover::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(3, 10, 28, .72) 0%, rgba(3, 10, 28, .48) 40%, rgba(3, 10, 28, .16) 100%),
    linear-gradient(180deg, rgba(3, 10, 28, .10) 0%, rgba(3, 10, 28, .42) 100%) !important;
  opacity: 1 !important;
}

.project-selling-cover.has-cover .project-selling-overlay,
.project-selling-cover.has-cover .project-selling-overlay::after {
  display: none !important;
  content: none !important;
  background: none !important;
  opacity: 0 !important;
}

.project-selling-cover.has-cover .project-selling-content,
.project-selling-cover.has-cover .project-selling-card,
.project-selling-cover.has-cover .project-selling-side {
  position: relative !important;
  z-index: 2 !important;
}

.project-selling-cover.has-cover .project-selling-content {
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-shadow: 0 4px 22px rgba(0, 0, 0, .60) !important;
}

.project-selling-cover.has-cover .project-selling-content h1,
.project-selling-cover.has-cover .project-selling-content p,
.project-selling-cover.has-cover .project-selling-content .eyebrow {
  text-shadow: 0 4px 22px rgba(0, 0, 0, .60) !important;
}

.project-selling-cover.has-cover .project-selling-card {
  background: rgba(255, 255, 255, .12) !important;
  border: 1px solid rgba(255, 255, 255, .22) !important;
  box-shadow: 0 24px 64px rgba(0, 0, 0, .22) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.project-selling-cover.has-cover .project-selling-media {
  display: none !important;
}

/* Cards do portfólio: capa preenchendo sem blur/textura pesada */
.portfolio-card-cover-v3.has-image {
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-color: #eef3fb !important;
}

.portfolio-card-cover-v3.has-image::before,
.portfolio-card-cover-v3.has-image::after {
  display: none !important;
  content: none !important;
  background: none !important;
}

@media (max-width: 980px) {
  .project-selling-cover.has-cover {
    grid-template-columns: 1fr !important;
    min-height: 620px !important;
    align-items: end !important;
  }
}

@media (max-width: 760px) {
  .project-selling-cover.has-cover {
    min-height: 560px !important;
    background-position: center !important;
  }
}

/* 04.1 - COLABORADORES PRINCIPAIS */
.team-members-area {
  margin-top: 34px;
  padding: 34px;
  border-radius: 34px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 24px 70px rgba(11,24,75,.065);
}

.team-members-head {
  max-width: 760px;
  margin-bottom: 26px;
}

.team-members-head h3 {
  margin: 10px 0 12px;
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.08;
  letter-spacing: -1.3px;
  color: var(--ink);
}

.team-members-head p {
  margin: 0;
  max-width: 640px;
  color: var(--muted);
  line-height: 1.75;
  font-size: 15px;
}

.team-members-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.team-member-card {
  overflow: hidden;
  border-radius: 26px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 18px 48px rgba(11,24,75,.06);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.team-member-card:hover {
  transform: translateY(-5px);
  border-color: rgba(39,98,255,.16);
  box-shadow: 0 28px 70px rgba(11,24,75,.105);
}

.member-photo {
  aspect-ratio: 1 / 1;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.placeholder-photo {
  background:
    radial-gradient(circle at 78% 18%, rgba(255,255,255,.34), transparent 28%),
    linear-gradient(135deg, #071b63, #2463ff);
}

.placeholder-photo::after {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.16);
}

.placeholder-photo span {
  position: relative;
  z-index: 1;
  color: rgba(255,255,255,.9);
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -.06em;
}

.member-info {
  padding: 20px;
}

.member-info h4 {
  margin: 0 0 6px;
  font-size: 17px;
  line-height: 1.2;
  color: var(--ink);
}

.member-info span {
  display: block;
  margin-bottom: 12px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.member-info p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
  font-size: 13px;
}

.team-members-action {
  display: flex;
  justify-content: center;
  margin-top: 28px;
}

@media (max-width: 1080px) {
  .team-members-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 680px) {
  .team-members-area {
    padding: 24px;
    border-radius: 28px;
  }

  .team-members-grid {
    grid-template-columns: 1fr;
  }
}


/* RESPONSIVO - MINI EQUIPE NO PAINEL PRINCIPAL */
@media (max-width: 980px) {
  .about-team-mini-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 620px) {
  .about-team-mini {
    padding: 18px;
    border-radius: 24px;
  }

  .about-team-mini-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================
   EQUIPE PAGE - HERO
========================= */
.team-page {
  background: linear-gradient(180deg, #f8faff 0%, #ffffff 38%, #f7f9ff 100%);
}

.team-hero {
  padding-top: 82px;
  padding-bottom: 34px;
}

.team-hero-box {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr);
  gap: 28px;
  align-items: center;
  padding: 34px;
  border-radius: 30px;
  background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(245,248,255,.86));
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 22px 64px rgba(11,24,75,.07);
  overflow: hidden;
  position: relative;
}

.team-hero-box::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(16,35,92,.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(16,35,92,.026) 1px, transparent 1px);
  background-size: 54px 54px;
  opacity: .42;
  pointer-events: none;
}

.team-hero-copy,
.team-hero-panel {
  position: relative;
  z-index: 1;
}

.team-hero-copy h1 {
  max-width: 760px;
  margin: 14px 0 16px;
  color: var(--ink);
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.03;
  letter-spacing: -.065em;
}

.team-hero-copy p {
  max-width: 650px;
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.72;
}

.team-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.team-hero-panel {
  padding: 24px;
  border-radius: 24px;
  color: #fff;
  background:
    radial-gradient(circle at 78% 12%, rgba(255,255,255,.14), transparent 26%),
    linear-gradient(135deg, #071b63 0%, #1457e8 100%);
  box-shadow: 0 20px 54px rgba(10,37,64,.15);
  overflow: hidden;
}

.team-hero-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 42px 42px;
  opacity: .26;
  pointer-events: none;
}

.team-panel-orbit {
  position: relative;
  height: 82px;
  margin-bottom: 18px;
}

.team-panel-orbit span {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.23);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(6px);
}

.team-panel-orbit span:nth-child(1) {
  width: 52px;
  height: 52px;
  left: 4px;
  top: 14px;
}

.team-panel-orbit span:nth-child(2) {
  width: 74px;
  height: 74px;
  right: 10px;
  top: 0;
}

.team-panel-orbit span:nth-child(3) {
  width: 34px;
  height: 34px;
  left: 45%;
  bottom: 0;
}

.team-hero-panel strong {
  display: block;
  max-width: 330px;
  font-size: 22px;
  line-height: 1.14;
  letter-spacing: -.045em;
}

.team-hero-panel p {
  margin: 12px 0 18px;
  color: rgba(255,255,255,.78);
  line-height: 1.62;
  font-size: 14px;
}

.team-panel-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.team-panel-metrics div {
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.12);
}

.team-panel-metrics b {
  display: block;
  font-size: 21px;
  line-height: 1;
}

.team-panel-metrics small {
  display: block;
  margin-top: 7px;
  color: rgba(255,255,255,.72);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}

/* =========================
   EQUIPE PAGE - DIRECTORY
========================= */
.team-directory-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 44px;
}

.team-profile-card {
  overflow: hidden;
  border-radius: 30px;
  background: #fff;
  border: 1px solid rgba(16,35,92,.08);
  box-shadow: 0 18px 55px rgba(11,24,75,.065);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.team-profile-card:hover {
  transform: translateY(-6px);
  border-color: rgba(39,98,255,.18);
  box-shadow: 0 30px 80px rgba(11,24,75,.11);
}

.team-profile-photo {
  aspect-ratio: 1 / .82;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.team-profile-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.team-profile-photo.is-placeholder {
  background:
    radial-gradient(circle at 76% 20%, rgba(255,255,255,.36), transparent 26%),
    radial-gradient(circle at 18% 72%, rgba(255,255,255,.18), transparent 24%),
    linear-gradient(135deg, #071b63, #2463ff);
}

.team-profile-photo.is-placeholder::after {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.18);
}

.team-profile-photo span {
  position: relative;
  z-index: 1;
  color: rgba(255,255,255,.92);
  font-size: 44px;
  font-weight: 900;
  letter-spacing: -.075em;
}

.team-profile-body {
  padding: 24px;
}

.team-profile-area {
  display: inline-flex;
  align-items: center;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(39,98,255,.09);
  color: var(--blue);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 18px;
}

.team-profile-body h3 {
  margin: 0 0 7px;
  color: var(--ink);
  font-size: 22px;
  line-height: 1.14;
  letter-spacing: -.04em;
}

.team-profile-body strong {
  display: block;
  color: var(--ink);
  font-size: 13px;
  margin-bottom: 14px;
}

.team-profile-body p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.7;
}

.team-socials {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}

.team-socials a {
  width: 38px;
  height: 38px;
  border-radius: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
  background: #f6f8ff;
  border: 1px solid rgba(16,35,92,.08);
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}

.team-socials a:hover {
  transform: translateY(-2px);
  color: #fff;
  background: var(--blue);
  border-color: var(--blue);
}

.team-socials i {
  width: 17px;
  height: 17px;
}

/* =========================
   EQUIPE PAGE - CTA
========================= */
.team-cta-box {
  text-align: center;
  padding: 62px 34px;
  border-radius: 34px;
  color: #fff;
  background:
    radial-gradient(circle at 85% 12%, rgba(255,255,255,.16), transparent 28%),
    linear-gradient(135deg, #071b63 0%, #1457e8 100%);
  box-shadow: 0 30px 90px rgba(10,37,64,.14);
  position: relative;
  overflow: hidden;
}

.team-cta-box::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 42px 42px;
  opacity: .35;
  pointer-events: none;
}

.team-cta-box > * {
  position: relative;
  z-index: 1;
}

.team-cta-box h2 {
  max-width: 820px;
  margin: 16px auto;
  font-size: clamp(32px, 4.5vw, 56px);
  line-height: 1.02;
  letter-spacing: -.065em;
}

.team-cta-box p {
  max-width: 640px;
  margin: 0 auto;
  color: rgba(255,255,255,.78);
  line-height: 1.75;
}

.team-cta-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.team-cta-box .btn-secondary {
  background: rgba(255,255,255,.08);
  color: #fff;
  border-color: rgba(255,255,255,.22);
}

@media (max-width: 980px) {
  .team-hero-box {
    grid-template-columns: 1fr;
    padding: 34px;
  }

  .team-directory-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .team-hero {
    padding-top: 76px;
    padding-bottom: 26px;
  }

  .team-hero-box,
  .team-cta-box {
    border-radius: 24px;
    padding: 24px;
  }

  .team-directory-grid {
    grid-template-columns: 1fr;
  }

  .team-panel-metrics {
    grid-template-columns: 1fr;
  }
}


/* ====================================
HOME SERVICES - ALINHADO AO PADRÃO DE SERVIÇOS
==================================== */
.home-services .services-grid-real{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:26px;
  align-items:stretch;
  margin-top:42px;
}
.home-services .service-real-card{
  min-height:100%;
}
.home-services .service-real-featured{
  transform:translateY(-6px);
}
.home-services .service-real-featured:hover{
  transform:translateY(-12px);
}
@media (max-width: 980px){
  .home-services .services-grid-real{grid-template-columns:1fr;}
  .home-services .service-real-featured{transform:none;}
  .home-services .service-real-featured:hover{transform:translateY(-6px);}
}

.float-whatsapp svg {
  width: 22px;
  height: 22px;
}

.float-tooltip {
  position: absolute;
  right: 62px;
  top: 50%;
  transform: translate(10px, -50%);
  background: #0b1f4b;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  padding: 9px 12px;
  border-radius: 999px;
  opacity: 0;
  pointer-events: none;
  box-shadow: 0 14px 30px rgba(8, 24, 74, .18);
  transition: opacity .2s ease, transform .2s ease;
}

.float-whatsapp:hover .float-tooltip {
  opacity: 1;
  transform: translate(0, -50%);
}

@media (max-width: 760px) {
  .float-tooltip {
    display: none;
  }
}


/* ====================================
   WHATSAPP FLOAT + TOOLTIP FINAL
   Correção definitiva: 1 botão, sem verde antigo, tooltip funcionando.
==================================== */
.floating-whatsapp,
.back-to-top,
.whatsapp-float {
  display: none !important;
}

.float-action {
  position: fixed !important;
  right: 22px !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 18px !important;
  z-index: 9999 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-decoration: none !important;
  border: 1px solid rgba(255,255,255,.55) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: transform .22s ease, box-shadow .22s ease, opacity .22s ease, background .22s ease !important;
}

.float-whatsapp {
  bottom: 24px !important;
  background: linear-gradient(135deg, #0b1f4b, #1d4ed8) !important;
  color: #fff !important;
  box-shadow: 0 18px 36px rgba(11,31,75,.22) !important;
}

.float-whatsapp svg {
  width: 22px !important;
  height: 22px !important;
}

.float-tooltip {
  position: absolute !important;
  right: 62px !important;
  top: 50% !important;
  transform: translate(10px, -50%) !important;
  background: #0b1f4b !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  padding: 9px 12px !important;
  border-radius: 999px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  box-shadow: 0 14px 30px rgba(8,24,74,.18) !important;
  transition: opacity .2s ease, transform .2s ease !important;
}

.float-whatsapp:hover .float-tooltip {
  opacity: 1 !important;
  transform: translate(0, -50%) !important;
}

.float-top {
  bottom: 84px !important;
  background: rgba(255,255,255,.88) !important;
  color: #071847 !important;
  box-shadow: 0 16px 34px rgba(8,24,74,.12) !important;
  border-color: rgba(8,24,74,.08) !important;
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
}

.float-top.is-visible {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateY(0) !important;
}

.float-action:hover,
.float-top.is-visible:hover {
  transform: translateY(-3px) !important;
}

@media (max-width: 760px) {
  .float-action {
    right: 16px !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 16px !important;
  }
  .float-whatsapp { bottom: 20px !important; }
  .float-top { bottom: 72px !important; }
  .float-tooltip { display: none !important; }
}
