/* === Force full-width — defeat theme container === */
html body.page #page-container, html body.page #main-content, html body.page #content-area, html body.page #left-area, html body.page .container { 
  width: 100% !important; 
  max-width: 100% !important; 
  padding: 0 !important; 
  margin: 0 !important; 
}
html body.page #sidebar { display: none !important; }
html body.page article.page, html body.page .entry-content { padding: 0 !important; margin: 0 !important; }

/* === Hide WP-injected page title (main_title for private pages) === */
html body.page h1.main_title, html body.page .entry-title, html body.page .et_post_meta_wrapper, html body.page .et_pb_title_container { display: none !important; }

/* === Body typography === */
body { font-family: "Nunito Sans", -apple-system, sans-serif !important; color: #1A1A1A; }

/* === HERO section overlay & text colors === */
.et_pb_section_0 { position: relative !important; margin-top: 0 !important; }
.et_pb_section_0::before { 
  content: ""; 
  position: absolute; 
  inset: 0; 
  background: linear-gradient(135deg, rgba(0,40,60,0.75) 0%, rgba(0,20,30,0.55) 100%); 
  z-index: 1; 
  pointer-events: none; 
}
.et_pb_section_0 > .et_pb_row { position: relative !important; z-index: 2 !important; }
.et_pb_section_0 .et_pb_text, .et_pb_section_0 .et_pb_text *, .et_pb_section_0 h1, .et_pb_section_0 h2 { color: #FFFFFF !important; }
.et_pb_section_0 .et_pb_text:first-of-type, .et_pb_section_0 .et_pb_text:first-of-type * { color: #68CDEC !important; }

/* === TRUST BAR === */
.wo-trust-bar { background: #F4F6F8 !important; }
.wo-trust-bar img { filter: grayscale(1); opacity: 0.65; transition: all 0.3s ease; max-width: 140px; height: auto; }
.wo-trust-bar img:hover { filter: grayscale(0); opacity: 1; }
/* Force the second row (logos row) to display columns horizontally */
.wo-trust-bar .et_pb_row.et_pb_row_1, .wo-trust-bar .et_pb_row:nth-of-type(2) {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  justify-content: space-around !important;
  align-items: center !important;
  gap: 24px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}
.wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_column, .wo-trust-bar .et_pb_row:nth-of-type(2) .et_pb_column {
  width: auto !important;
  flex: 1 1 0 !important;
  max-width: 20% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 8px !important;
}
@media (max-width: 768px) {
  .wo-trust-bar .et_pb_row.et_pb_row_1, .wo-trust-bar .et_pb_row:nth-of-type(2) { flex-wrap: wrap !important; }
  .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_column, .wo-trust-bar .et_pb_row:nth-of-type(2) .et_pb_column { max-width: 33% !important; }
}

/* === SERVICE CARDS === */
.wo-services { background: #FFFFFF !important; }
.wo-services .et_pb_row:nth-of-type(2) { display: flex !important; flex-direction: row !important; flex-wrap: wrap !important; gap: 24px !important; max-width: 1200px !important; margin: 0 auto !important; justify-content: center !important; }
.wo-services .et_pb_row:nth-of-type(2) .et_pb_column.wo-service-card { flex: 1 1 250px !important; max-width: calc(25% - 18px) !important; min-width: 240px !important; background: #FFFFFF !important; border: 1px solid #E5E7EB !important; border-radius: 12px !important; overflow: hidden !important; transition: transform 0.3s, box-shadow 0.3s !important; }
.wo-services .et_pb_row:nth-of-type(2) .et_pb_column.wo-service-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.08); }
.wo-services .wo-service-card .et_pb_image { margin: 0 !important; }
.wo-services .wo-service-card .et_pb_image img { width: 100% !important; height: 200px !important; object-fit: cover !important; display: block; }
.wo-services .wo-card-body { padding: 24px !important; }
.wo-services .wo-card-body h3 { margin: 0 0 8px 0 !important; }
.wo-services .wo-card-body ul { list-style: none; padding: 0; margin: 16px 0; }
.wo-services .wo-card-body ul li { position: relative; padding-left: 24px; line-height: 2; }
.wo-services .wo-card-body ul { list-style: none !important; }
.wo-services .wo-card-body ul li::before { content: ""; position: absolute; left: 0; top: 8px; width: 16px; height: 16px; background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12l5 5l10 -10'/></svg>") no-repeat center; background-size: contain; }
.wo-services .wo-price-intro { margin: 0 !important; font-size: 12px !important; color: #808285 !important; text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.wo-services .wo-price-value { margin: 4px 0 16px 0 !important; font-size: 32px !important; font-weight: 700 !important; color: #1A1A1A; line-height: 1; }
.wo-services .wo-price-label { font-size: 14px !important; font-weight: 400 !important; color: #808285; }
@media (max-width: 980px) {
  .wo-services .et_pb_row:nth-of-type(2) .et_pb_column.wo-service-card { max-width: calc(50% - 12px) !important; }
}
@media (max-width: 600px) {
  .wo-services .et_pb_row:nth-of-type(2) .et_pb_column.wo-service-card { max-width: 100% !important; }
}

/* === LOCATIONS === */
.wo-locations { background: #F4F6F8 !important; }
.wo-locations .wo-loc-row { display: flex !important; flex-wrap: nowrap !important; align-items: stretch !important; max-width: 1200px !important; margin: 24px auto !important; background: #FFFFFF !important; border-radius: 16px !important; overflow: hidden !important; box-shadow: 0 8px 24px rgba(0,0,0,0.04) !important; }
/* removed row-reverse — markup order handles alternation */
.wo-locations .wo-loc-row .et_pb_column { width: 50% !important; max-width: 50% !important; flex: 1 1 50% !important; margin: 0 !important; padding: 0 !important; display: flex !important; flex-direction: column !important; justify-content: center !important; }
.wo-locations .wo-loc-img { padding: 0 !important; }
.wo-locations .wo-loc-img .et_pb_image { margin: 0 !important; height: 100% !important; }
.wo-locations .wo-loc-img .et_pb_image img { width: 100% !important; height: 100% !important; min-height: 400px !important; object-fit: cover !important; display: block !important; }
.wo-locations .wo-loc-info { padding: 48px !important; }
.wo-locations .wo-loc-info h3 { margin: 8px 0 16px 0 !important; }
.wo-locations .wo-loc-addr { color: #808285 !important; margin: 0 0 8px 0 !important; font-size: 15px; line-height: 1.5; }
.wo-locations .wo-loc-area { color: #1A1A1A !important; margin: 0 0 20px 0 !important; font-size: 15px; line-height: 1.6; }
.wo-locations .wo-loc-transports { padding: 16px 20px !important; margin: 16px 0 24px 0 !important; background: #F4F6F8 !important; border-radius: 10px !important; color: #1A1A1A !important; font-size: 15px !important; line-height: 2.2 !important; }
@media (max-width: 980px) {
  .wo-locations .wo-loc-row, .wo-locations .wo-loc-row.wo-loc-img-right { flex-direction: column !important; }
  .wo-locations .wo-loc-row .et_pb_column { width: 100% !important; max-width: 100% !important; flex: 1 1 100% !important; }
  .wo-locations .wo-loc-img .et_pb_image img { min-height: 280px !important; }
  .wo-locations .wo-loc-info { padding: 32px !important; }
}

/* === PILLARS === */
.wo-pillars { background: #FFFFFF !important; }
.wo-pillars .et_pb_row:nth-of-type(2) { display: flex !important; flex-direction: row !important; flex-wrap: wrap !important; gap: 24px !important; max-width: 1200px !important; margin: 0 auto !important; justify-content: center !important; }
.wo-pillars .wo-pillar { flex: 1 1 220px !important; max-width: calc(25% - 18px) !important; min-width: 220px !important; padding: 16px !important; text-align: center; }
.wo-pillars .wo-pillar-icon { font-size: 56px; line-height: 1; margin-bottom: 20px; display: block; }
.wo-pillars .wo-pillar-title { font-size: 22px !important; font-weight: 700 !important; color: #1A1A1A !important; margin: 0 0 12px 0 !important; }
.wo-pillars .wo-pillar-desc { font-size: 15px !important; color: #808285 !important; line-height: 1.6 !important; margin: 0 !important; }
@media (max-width: 980px) {
  .wo-pillars .wo-pillar { max-width: calc(50% - 12px) !important; }
}
@media (max-width: 600px) {
  .wo-pillars .wo-pillar { max-width: 100% !important; }
}

/* Icons via background-image data-URI */
.wo-pillar-icon { width: 56px; height: 56px; margin: 0 auto 20px; background-position: center; background-repeat: no-repeat; background-size: contain; }
.wo-icon-bolt { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><path d='M13 3l0 8l6 0l-8 10l0 -8l-6 0z'/></svg>"); }
.wo-icon-coin { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M14.5 9a3.5 4 0 1 0 0 6'/><path d='M8.5 11h6'/><path d='M8.5 13h6'/></svg>"); }
.wo-icon-users { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><circle cx='9' cy='7' r='4'/><path d='M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2'/><path d='M16 3.13a4 4 0 0 1 0 7.75'/><path d='M21 21v-2a4 4 0 0 0 -3 -3.85'/></svg>"); }
.wo-icon-world { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M3.6 9h16.8'/><path d='M3.6 15h16.8'/><path d='M11.5 3a17 17 0 0 0 0 18'/><path d='M12.5 3a17 17 0 0 1 0 18'/></svg>"); }
.wo-tr-icon { display: inline-block; width: 22px; height: 22px; vertical-align: middle; margin-right: 10px; background-position: center; background-repeat: no-repeat; background-size: contain; }
.wo-icon-train { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='5' y='3' width='14' height='14' rx='2'/><path d='M5 9h14'/><path d='M8 21l1.5-3'/><path d='M16 21l-1.5-3'/></svg>"); }
.wo-icon-subway { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M5 5a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2z'/><path d='M9 18l-2 3'/><path d='M15 18l2 3'/><path d='M5 11h14'/></svg>"); }
.wo-icon-parking { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='4' y='4' width='16' height='16' rx='3'/><path d='M9 17v-10h4a3 3 0 0 1 0 6h-4'/></svg>"); }
.wo-tr-line { display: block; padding: 6px 0; color: #1A1A1A; }
.wo-hb-check { display: inline-block; width: 20px; height: 20px; vertical-align: middle; margin-right: 10px; background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2368CDEC' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12l5 5l10 -10'/></svg>") center / contain no-repeat; }
.et_pb_section_0 .wo-hero-bullets { line-height: 1.8 !important; }
.et_pb_section_0 .wo-hb-line { display: block; padding: 6px 0; color: #FFFFFF !important; }


/* === STEPS === */
.wo-steps { background: #F4F6F8 !important; }
.wo-steps .et_pb_row:nth-of-type(2) { display: flex !important; flex-direction: row !important; flex-wrap: wrap !important; gap: 24px !important; max-width: 1200px !important; margin: 0 auto !important; justify-content: center !important; }
.wo-steps .wo-step { flex: 1 1 280px !important; max-width: calc(33.33% - 16px) !important; min-width: 260px !important; background: #FFFFFF !important; border-radius: 16px !important; padding: 40px 32px !important; box-shadow: 0 4px 16px rgba(0,0,0,0.04) !important; position: relative; }
.wo-steps .wo-step-num { font-size: 72px !important; font-weight: 900 !important; color: #68CDEC !important; line-height: 1 !important; margin: 0 0 16px 0 !important; opacity: 0.85; letter-spacing: -2px; }
.wo-steps .wo-step-title { font-size: 24px !important; font-weight: 700 !important; color: #1A1A1A !important; margin: 0 0 12px 0 !important; }
.wo-steps .wo-step-desc { font-size: 15px !important; color: #808285 !important; line-height: 1.7 !important; margin: 0 !important; }
@media (max-width: 980px) {
  .wo-steps .wo-step { max-width: 100% !important; }
}

/* === TESTIMONIALS === */
.wo-testimonials { background: #FFFFFF !important; }
.wo-testimonials .et_pb_row:nth-of-type(2) { display: flex !important; flex-direction: row !important; flex-wrap: wrap !important; gap: 24px !important; max-width: 1200px !important; margin: 0 auto !important; justify-content: center !important; }
.wo-testimonials .wo-test-card { flex: 1 1 320px !important; max-width: calc(33.33% - 16px) !important; min-width: 300px !important; background: #FFFFFF !important; border: 1px solid #E5E7EB !important; border-radius: 16px !important; overflow: hidden !important; transition: transform 0.3s, box-shadow 0.3s !important; }
.wo-testimonials .wo-test-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.10); }
.wo-test-link { display: block; color: inherit; text-decoration: none !important; }
.wo-test-thumb { position: relative; padding-top: 56.25%; background-position: center; background-size: cover; background-color: #1A1A1A; }
.wo-test-play { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 72px; height: 72px; border-radius: 50%; background: rgba(104,205,236,0.95) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><polygon points='8,5 19,12 8,19'/></svg>") center / 32px 32px no-repeat; box-shadow: 0 8px 24px rgba(0,0,0,0.3); transition: transform 0.2s; }
.wo-test-card:hover .wo-test-play { transform: translate(-50%, -50%) scale(1.1); }
.wo-test-body { padding: 28px 24px 24px 24px; }
.wo-test-tag { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #68CDEC; margin-bottom: 14px; }
.wo-test-quote { margin: 0 0 20px 0 !important; padding: 0 !important; border: 0 !important; font-size: 16px !important; line-height: 1.6 !important; color: #1A1A1A !important; font-style: normal !important; quotes: none; }
.wo-test-quote::before, .wo-test-quote::after { content: none; }
.wo-test-author { font-size: 14px; color: #1A1A1A; line-height: 1.5; }
.wo-test-author strong { font-weight: 700; }
.wo-test-company { color: #808285; }
.wo-test-watch { display: inline-block; margin-top: 14px; font-size: 13px; font-weight: 700; color: #68CDEC; letter-spacing: 0.5px; }
.wo-test-watch::after { content: "  →"; }
@media (max-width: 980px) {
  .wo-testimonials .wo-test-card { max-width: 100% !important; }
}


/* === FINAL CTA === */
.et_pb_section.wo-final-cta { background-color: #68CDEC !important; background-image: linear-gradient(135deg, #68CDEC 0%, #2D9CB8 100%) !important; color: #FFFFFF !important; position: relative; overflow: hidden; }
.wo-final-cta::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%, rgba(255,255,255,0.10), transparent 50%), radial-gradient(circle at 10% 80%, rgba(0,0,0,0.10), transparent 50%); pointer-events: none; }
.wo-final-cta .et_pb_row { position: relative; z-index: 2; }
.wo-cta-content { text-align: center; }
.wo-cta-pre { display: inline-block; font-size: 13px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,0.85); margin-bottom: 14px; }
.wo-cta-h2 { font-size: 48px !important; font-weight: 700 !important; color: #FFFFFF !important; margin: 0 0 16px 0 !important; line-height: 1.1 !important; }
.wo-cta-sub { font-size: 18px !important; color: rgba(255,255,255,0.92) !important; margin: 0 auto 36px !important; max-width: 720px; line-height: 1.6 !important; }
.wo-cta-actions { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-bottom: 28px; }
.wo-cta-btn { display: inline-flex; align-items: center; gap: 14px; padding: 18px 28px; border-radius: 14px; text-decoration: none !important; transition: transform 0.2s, box-shadow 0.2s; min-width: 240px; }
.wo-cta-btn:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(0,0,0,0.18); }
.wo-cta-btn-primary { background: #FFFFFF !important; color: #1A1A1A !important; }
.wo-cta-btn-primary .wo-cta-icon { background-color: #68CDEC; }
.wo-cta-btn-primary .wo-cta-line2 { color: #1A1A1A !important; }
.wo-cta-btn-secondary { background: rgba(255,255,255,0.12) !important; color: #FFFFFF !important; border: 1px solid rgba(255,255,255,0.30) !important; backdrop-filter: blur(4px); }
.wo-cta-btn-secondary .wo-cta-icon { background-color: rgba(255,255,255,0.20); }
.wo-cta-btn-secondary .wo-cta-line2 { color: #FFFFFF !important; }
.wo-cta-icon { display: inline-block; width: 44px; height: 44px; border-radius: 12px; background-position: center; background-repeat: no-repeat; background-size: 22px 22px; flex-shrink: 0; }
.wo-icon-phone { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2'/></svg>"); }
.wo-icon-chat { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 20l1.3 -3.9a9 8 0 1 1 3.4 2.9l-4.7 1'/></svg>"); }
.wo-icon-mail { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='5' width='18' height='14' rx='2'/><path d='M3 7l9 6l9 -6'/></svg>"); }
.wo-cta-label { text-align: left; display: flex; flex-direction: column; line-height: 1.2; }
.wo-cta-line1 { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; opacity: 0.7; }
.wo-cta-line2 { font-size: 16px !important; font-weight: 700; letter-spacing: -0.2px; margin-top: 4px; }
.wo-cta-hours { font-size: 14px !important; color: rgba(255,255,255,0.75) !important; margin: 0 !important; }
@media (max-width: 980px) {
  .wo-cta-h2 { font-size: 32px !important; }
  .wo-cta-btn { min-width: 100%; }
}


/* === Pedro feedback v1 fixes === */
/* (1) HERO full-screen */
.et_pb_section_0 { min-height: 100vh !important; display: flex !important; align-items: center !important; }

/* (2) TRUST BAR — left-align + container padding + bigger logos */
.wo-trust-bar { padding-left: 5vw !important; padding-right: 5vw !important; }
.wo-trust-bar .et_pb_row:first-of-type { max-width: 1280px !important; margin: 0 auto !important; }
.wo-trust-bar .et_pb_row:first-of-type .et_pb_text { text-align: left !important; }
.wo-trust-bar .et_pb_row:first-of-type .et_pb_text > * { text-align: left !important; }
/* (3) Bigger logos + horizontal scroll carousel */
.wo-trust-bar .et_pb_row:nth-of-type(2), .wo-trust-bar .et_pb_row.et_pb_row_1 { display: block !important; max-width: 1280px !important; margin: 16px auto 0 auto !important; overflow: hidden !important; position: relative; }
.wo-trust-bar .et_pb_row:nth-of-type(2)::before, .wo-trust-bar .et_pb_row:nth-of-type(2)::after { content: ""; position: absolute; top: 0; bottom: 0; width: 80px; z-index: 2; pointer-events: none; }
.wo-trust-bar .et_pb_row:nth-of-type(2)::before { left: 0; background: linear-gradient(to right, #F4F6F8, transparent); }
.wo-trust-bar .et_pb_row:nth-of-type(2)::after { right: 0; background: linear-gradient(to left, #F4F6F8, transparent); }
.wo-trust-bar .et_pb_row:nth-of-type(2) > * { display: inline-flex !important; vertical-align: middle !important; }
.wo-trust-bar .et_pb_row:nth-of-type(2) .et_pb_column { display: inline-flex !important; align-items: center !important; justify-content: center !important; flex: 0 0 auto !important; width: 200px !important; max-width: 200px !important; padding: 0 28px !important; }
.wo-trust-bar img { max-width: 100% !important; height: auto !important; max-height: 80px !important; object-fit: contain !important; }

/* (4) Card service Individual image — center cover */
.wo-services .wo-service-card .et_pb_image img { object-position: center center !important; }

/* (6) Locations: Porto height = Gaia. Force equal aspect on both */
.wo-locations .wo-loc-row .et_pb_column.wo-loc-img { aspect-ratio: 4/3 !important; }
.wo-locations .wo-loc-img .et_pb_image, .wo-locations .wo-loc-img .et_pb_image img { height: 100% !important; width: 100% !important; min-height: 0 !important; }
.wo-locations .wo-loc-img .et_pb_image img { object-fit: cover !important; object-position: center !important; }

/* (8) Container padding for all wo- sections (except hero, which is full-bleed) */
.wo-services, .wo-locations, .wo-pillars, .wo-steps, .wo-testimonials, .wo-final-cta { padding-left: 5vw !important; padding-right: 5vw !important; }
.wo-trust-bar { padding-left: 5vw !important; padding-right: 5vw !important; }
.wo-services > .et_pb_row, .wo-locations > .et_pb_row, .wo-pillars > .et_pb_row, .wo-steps > .et_pb_row, .wo-testimonials > .et_pb_row, .wo-final-cta > .et_pb_row { max-width: 1280px !important; margin-left: auto !important; margin-right: auto !important; }

/* (9) Cards locations: image edge-to-edge inside card */
.wo-locations .wo-loc-row { padding: 0 !important; }
.wo-locations .wo-loc-img { padding: 0 !important; margin: 0 !important; }
.wo-locations .wo-loc-img .et_pb_image { padding: 0 !important; margin: 0 !important; }


/* === FOOTER === */
.wo-footer { background: #0F1B26 !important; color: #C5D2DC !important; padding-top: 80px !important; padding-bottom: 32px !important; }
.wo-footer * { color: #C5D2DC; }
.wo-footer-grid { display: grid !important; grid-template-columns: 1.6fr 1fr 1fr 1.2fr 1.2fr !important; gap: 48px !important; max-width: 1280px !important; margin: 0 auto !important; padding-bottom: 56px !important; border-bottom: 1px solid rgba(255,255,255,0.1) !important; }
.wo-footer-logo { max-width: 200px !important; height: auto !important; margin-bottom: 16px !important; display: block; }
.wo-footer-tag { font-size: 13px !important; color: #68CDEC !important; text-transform: uppercase; letter-spacing: 2px; font-weight: 600; margin: 0 0 16px 0 !important; }
.wo-footer-desc { font-size: 14px !important; line-height: 1.7 !important; color: #95A4B0 !important; margin: 0 0 24px 0 !important; }
.wo-footer-h { font-size: 13px !important; font-weight: 700 !important; color: #FFFFFF !important; text-transform: uppercase; letter-spacing: 2px; margin: 0 0 20px 0 !important; }
.wo-footer ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.wo-footer li { padding: 6px 0 !important; font-size: 14px; }
.wo-footer a { color: #C5D2DC !important; text-decoration: none !important; transition: color 0.2s; }
.wo-footer a:hover { color: #68CDEC !important; }
.wo-footer-addr { font-style: normal !important; font-size: 13px !important; line-height: 1.7 !important; margin: 0 0 16px 0 !important; color: #95A4B0 !important; }
.wo-footer-addr strong { color: #FFFFFF !important; display: block; margin-bottom: 4px; }
.wo-footer-contacts li { font-size: 14px; padding: 6px 0; }
.wo-footer-contacts a { color: #FFFFFF !important; }
.wo-footer-label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: #68CDEC; margin-bottom: 2px; font-weight: 600; }
.wo-footer-hours { color: #95A4B0; }
.wo-footer-social { display: flex; gap: 12px; margin-top: 8px; }
.wo-footer-social-link { display: inline-block; width: 40px; height: 40px; border-radius: 50%; background-color: rgba(255,255,255,0.08); background-position: center; background-size: 18px 18px; background-repeat: no-repeat; transition: background-color 0.2s; }
.wo-footer-social-link:hover { background-color: #68CDEC; }
.wo-fs-fb { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M9 8h-3v4h3v12h5v-12h3.642l.358-4h-4v-1.667c0-.955.192-1.333 1.115-1.333h2.885v-5h-3.808c-3.596 0-5.192 1.583-5.192 4.615v3.385z'/></svg>"); }
.wo-fs-ig { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'><rect x='3' y='3' width='18' height='18' rx='5'/><circle cx='12' cy='12' r='4'/><circle cx='17.5' cy='6.5' r='1' fill='white'/></svg>"); }
.wo-fs-wa { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.71.306 1.263.489 1.695.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 01-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 01-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 012.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0012.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 005.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893a11.821 11.821 0 00-3.48-8.413z'/></svg>"); }
.wo-footer-fse { max-width: 1280px; margin: 0 auto; padding: 24px 0; border-bottom: 1px solid rgba(255,255,255,0.06); text-align: center; }
.wo-footer-fse-note { font-size: 11px !important; color: #5E6F7C !important; margin: 0 !important; letter-spacing: 1px; text-transform: uppercase; }
.wo-footer-bottom { display: flex !important; flex-wrap: wrap; justify-content: space-between; align-items: center; max-width: 1280px; margin: 24px auto 0 auto; gap: 16px; }
.wo-footer-copy { font-size: 12px !important; color: #5E6F7C !important; margin: 0 !important; }
.wo-footer-legal { display: flex !important; flex-wrap: wrap; gap: 24px; margin: 0 !important; }
.wo-footer-legal li { padding: 0 !important; font-size: 12px; }
.wo-footer-legal a { color: #95A4B0 !important; }
@media (max-width: 1024px) {
  .wo-footer-grid { grid-template-columns: 1fr 1fr !important; }
}

/* v122 — Mobile (≤768px): hide CTA "Fale Connosco" — burger menu acede ao mesmo link */
@media (max-width: 768px) {
  .wo-header-cta { display: none !important; }
  .wo-header-inner { gap: 12px; }
  .wo-logo img { max-height: 40px; width: auto; }
}
@media (max-width: 600px) {
  .wo-footer-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .wo-footer-bottom { flex-direction: column; align-items: flex-start; }
}


/* === LOCATIONS reinforced (Pedro feedback v2) === */
.wo-locations .wo-loc-row { padding: 0 !important; overflow: hidden !important; }
.wo-locations .wo-loc-row .et_pb_column { padding: 0 !important; margin: 0 !important; }
.wo-locations .wo-loc-img, .wo-locations .wo-loc-info { padding: 0 !important; margin: 0 !important; }
.wo-locations .wo-loc-img { aspect-ratio: 4/3 !important; max-height: 480px !important; overflow: hidden !important; }
.wo-locations .wo-loc-img .et_pb_image { margin: 0 !important; padding: 0 !important; height: 100% !important; width: 100% !important; display: block !important; }
.wo-locations .wo-loc-img .et_pb_image img { width: 100% !important; height: 100% !important; min-height: 0 !important; max-height: 480px !important; object-fit: cover !important; object-position: center !important; display: block !important; margin: 0 !important; }
.wo-locations .wo-loc-info { padding: 40px !important; display: flex !important; flex-direction: column !important; justify-content: center !important; }


/* === TRUST BAR — marquee carrossel + left-aligned title === */
.wo-trust-bar { background: #F4F6F8 !important; }
.wo-trust-bar > .et_pb_row { max-width: 1280px !important; margin: 0 auto !important; }
.wo-trust-bar .et_pb_text { text-align: left !important; }
.wo-trust-bar .et_pb_text > * { text-align: left !important; }
.wo-mq-wrap { overflow: hidden; width: 100%; padding: 24px 0 8px 0; position: relative; mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent); -webkit-mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent); }
.wo-mq-track { display: inline-flex; gap: 80px; align-items: center; animation: wo-marquee 32s linear infinite; will-change: transform; }
.wo-mq-item { flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; min-width: 280px; padding: 0 16px; }
.wo-mq-item img { max-height: 130px; max-width: 260px; width: auto; height: auto; object-fit: contain; filter: grayscale(1); opacity: 0.7; transition: filter 0.3s, opacity 0.3s; }
.wo-mq-item img:hover { filter: grayscale(0); opacity: 1; }
.wo-mq-wrap:hover .wo-mq-track { animation-play-state: paused; }
@keyframes wo-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-33.333%); }
}
@media (max-width: 600px) {
  .wo-mq-item { min-width: 200px; padding: 0 12px; }
  .wo-mq-item img { max-height: 90px; max-width: 180px; }
}


/* === LOCATIONS fix v3 — force image fill column + bigger side breathing === */
html body .wo-locations { padding-left: 8vw !important; padding-right: 8vw !important; }
html body .wo-locations > .et_pb_row { max-width: 1100px !important; margin-left: auto !important; margin-right: auto !important; }
html body .wo-locations .wo-loc-row { max-width: 1100px !important; margin: 24px auto !important; padding: 0 !important; }
html body .wo-locations .wo-loc-img { padding: 0 !important; margin: 0 !important; overflow: hidden !important; }
html body .wo-locations .wo-loc-img .et_pb_image { width: 100% !important; height: 100% !important; padding: 0 !important; margin: 0 !important; }
html body .wo-locations .wo-loc-img .et_pb_image > a, html body .wo-locations .wo-loc-img .et_pb_image > span { width: 100% !important; height: 100% !important; display: block !important; }
html body .wo-locations .wo-loc-img img,
html body .wo-locations .wo-loc-img .et_pb_image img,
html body .wo-locations .wo-loc-row .et_pb_column.wo-loc-img img {
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}


/* === Service card image: cover + center === */
html body .wo-services .wo-service-card .et_pb_image img { width: 100% !important; height: 200px !important; object-fit: cover !important; object-position: center center !important; max-width: none !important; display: block !important; }

/* v98 — Force image wrap full width (was inline-block collapsing to img natural width) */
html body .wo-services .wo-service-card .et_pb_image { display: block !important; width: 100% !important; }
html body .wo-services .wo-service-card .et_pb_image .et_pb_image_wrap { display: block !important; width: 100% !important; max-width: 100% !important; }


/* === LOC fix v4 — info padding restored, bigger gap === */
html body .wo-locations .wo-loc-row { margin: 48px auto !important; padding: 0 !important; gap: 0 !important; }
/* Image column: edge-to-edge */
html body .wo-locations .wo-loc-row .wo-loc-img { padding: 0 !important; margin: 0 !important; }
html body .wo-locations .wo-loc-row .wo-loc-img .et_pb_image { padding: 0 !important; margin: 0 !important; }
/* Info column: generous internal padding */
html body .wo-locations .wo-loc-row .wo-loc-info {
  padding: 56px 48px !important;
  margin: 0 !important;
}
@media (max-width: 768px) {
  html body .wo-locations .wo-loc-row .wo-loc-info { padding: 32px 28px !important; }
  html body .wo-locations .wo-loc-row { margin: 24px auto !important; }
}


/* === LOC fix v5 — foto stretch full height (encostada ao fundo do card) === */
html body .wo-locations .wo-loc-row { display: flex !important; align-items: stretch !important; }
html body .wo-locations .wo-loc-row .wo-loc-img {
  aspect-ratio: auto !important;
  max-height: none !important;
  height: auto !important;
  align-self: stretch !important;
  display: flex !important;
}
html body .wo-locations .wo-loc-row .wo-loc-img .et_pb_image {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  align-self: stretch !important;
}
html body .wo-locations .wo-loc-row .wo-loc-img .et_pb_image > * {
  height: 100% !important;
  width: 100% !important;
}
html body .wo-locations .wo-loc-row .wo-loc-img img {
  width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}


/* ============================================================
   ANIMAÇÕES UX — WebOffice (discreto, GPU-accelerated)
   ============================================================ */

/* (0) Respeitar prefers-reduced-motion: TUDO instant */
@media (prefers-reduced-motion: reduce) {
  .wo-anim-fade-up, .wo-anim-fade-up.wo-anim-in,
  .et_pb_section_0 .et_pb_text, .et_pb_section_0 .et_pb_code, .et_pb_section_0 .et_pb_button,
  .wo-cta-pulse, .wo-pillar-icon, .wo-tr-icon {
    animation: none !important;
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

/* (1) Reveal on scroll — fade-up suave */
.wo-anim-fade-up {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s ease-out, transform .6s ease-out;
  will-change: opacity, transform;
}
.wo-anim-fade-up.wo-anim-in {
  opacity: 1;
  transform: translateY(0);
}

/* (2) Hero stagger entrance — runs on page load */
.et_pb_section_0 .et_pb_text,
.et_pb_section_0 .et_pb_code,
.et_pb_section_0 .et_pb_button {
  opacity: 0;
  transform: translateY(12px);
  animation: wo-hero-enter 700ms ease-out forwards;
}
.et_pb_section_0 .et_pb_text:nth-of-type(1) { animation-delay: 100ms; }
.et_pb_section_0 .et_pb_text:nth-of-type(2) { animation-delay: 250ms; }
.et_pb_section_0 .et_pb_text:nth-of-type(3) { animation-delay: 400ms; }
.et_pb_section_0 .et_pb_code:nth-of-type(1) { animation-delay: 550ms; }
.et_pb_section_0 .et_pb_button:nth-of-type(1) { animation-delay: 700ms; }
.et_pb_section_0 .et_pb_button:nth-of-type(2) { animation-delay: 850ms; }
@keyframes wo-hero-enter {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* (4) CTA primário pulse — botão "Ver planos a partir de €25/mês" */
.et_pb_section_0 .et_pb_button:first-of-type {
  animation: wo-hero-enter 700ms ease-out 700ms forwards, wo-cta-pulse 2.4s ease-in-out 1.6s infinite;
  box-shadow: 0 0 0 0 rgba(104, 205, 236, 0.55);
}
.et_pb_section_0 .et_pb_button:first-of-type:hover {
  animation-play-state: paused, paused;
}
@keyframes wo-cta-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(104, 205, 236, 0.55); }
  50%      { transform: scale(1.03); box-shadow: 0 0 0 14px rgba(104, 205, 236, 0); }
}

/* (5) Icon hover micro-animation */
.wo-pillar { transition: transform 0.25s ease-out; }
.wo-pillar .wo-pillar-icon { transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); }
.wo-pillar:hover .wo-pillar-icon { transform: rotate(-6deg) scale(1.12); }
.wo-tr-icon { transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }
.wo-tr-line:hover .wo-tr-icon { transform: scale(1.2); }
.wo-test-card .wo-test-play { transition: transform 0.25s ease-out, box-shadow 0.25s ease-out; }
.wo-test-card:hover .wo-test-play { transform: translate(-50%, -50%) scale(1.15); box-shadow: 0 12px 32px rgba(104,205,236,0.4); }


/* === Hero bullets — maior + mais respiração === */
html body .et_pb_section_0 .wo-hero-bullets { line-height: 2 !important; font-size: 19px !important; }
html body .et_pb_section_0 .wo-hb-line { display: block; padding: 10px 0; color: #FFFFFF !important; font-size: 19px; }
html body .et_pb_section_0 .wo-hb-line strong { color: #FFFFFF !important; font-weight: 700; }
html body .et_pb_section_0 .wo-hb-check { width: 24px !important; height: 24px !important; margin-right: 14px !important; vertical-align: middle; }
@media (max-width: 768px) {
  html body .et_pb_section_0 .wo-hero-bullets,
  html body .et_pb_section_0 .wo-hb-line { font-size: 16px !important; }
  html body .et_pb_section_0 .wo-hb-check { width: 20px !important; height: 20px !important; margin-right: 10px !important; }
}


/* ============================================================
   HEADER — sticky, transparent-over-hero, white-on-scroll
   ============================================================ */
.wo-header { position: fixed; top: 0; left: 0; right: 0; z-index: 999; transition: background-color .35s ease, box-shadow .35s ease, padding .25s ease, backdrop-filter .35s ease; padding: 14px 0; background: rgba(255,255,255,0.55); backdrop-filter: blur(24px) saturate(180%); -webkit-backdrop-filter: blur(24px) saturate(180%); box-shadow: inset 0 -1px 0 rgba(255,255,255,0.4); }
/* Shift header down when WP admin bar is present (logged-in users only) */
body.admin-bar .wo-header { top: 32px; }
@media screen and (max-width: 782px) {
  body.admin-bar .wo-header { top: 46px; }
}
.wo-header.wo-scrolled { background: rgba(255,255,255,0.75); backdrop-filter: blur(28px) saturate(190%); -webkit-backdrop-filter: blur(28px) saturate(190%); box-shadow: 0 8px 32px rgba(0,0,0,0.06); padding: 10px 0; }
.wo-header-inner { max-width: none; width: 100%; margin: 0; padding: 0 5vw; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 24px; }
.wo-logo { display: inline-flex; align-items: center; flex-shrink: 0; justify-self: start; }
.wo-logo img { display: block; height: 60px; width: auto; max-width: 280px; transition: height .25s ease; filter: none; object-fit: contain; }
.wo-header.wo-scrolled .wo-logo img { height: 48px; }

/* Nav */
.wo-nav { display: flex; align-items: center; justify-content: center; justify-self: center; height: 100%; }
.wo-nav-list { list-style: none !important; padding: 0 !important; margin: 0 !important; display: flex; gap: 4px; align-items: center; }
.wo-nav-list > li { position: relative; padding: 0 !important; list-style: none !important; display: flex; align-items: center; align-self: center; }
.wo-nav-list > li::before, .wo-nav-list > li::marker { content: none !important; display: none !important; }
.wo-nav-list > li > a { display: inline-flex; align-items: center; padding: 12px 18px; color: #1A1A1A; font-family: "Nunito Sans", sans-serif; font-weight: 600; font-size: 17px; text-decoration: none !important; border-radius: 8px; transition: color .2s ease, background-color .2s ease; }
.wo-nav-list > li > a:hover, .wo-nav-list > li.wo-has-sub:hover > a { color: #68CDEC !important; background-color: rgba(104,205,236,0.08); }
.wo-caret { display: inline-block; width: 8px; height: 8px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg) translateY(-2px); margin-left: 8px; transition: transform .25s ease; }
.wo-has-sub:hover .wo-caret { transform: rotate(225deg) translateY(-2px); }

/* Sub menu */
.wo-sub-menu { position: absolute; top: 100%; left: 0; min-width: 240px; background: #FFFFFF; border-radius: 12px; box-shadow: 0 12px 40px rgba(0,0,0,0.12); padding: 8px; margin: 8px 0 0 0; list-style: none !important; opacity: 0; visibility: hidden; transform: translateY(-8px); transition: opacity .25s ease, transform .25s ease, visibility 0s linear .25s; }
.wo-has-sub:hover .wo-sub-menu, .wo-has-sub:focus-within .wo-sub-menu { opacity: 1; visibility: visible; transform: translateY(0); transition-delay: 0s; }
.wo-sub-menu li { padding: 0 !important; list-style: none !important; }
.wo-sub-menu li::before, .wo-sub-menu li::marker { content: none !important; display: none !important; }
.wo-sub-menu a { display: block; padding: 10px 16px; color: #1A1A1A; font-size: 14px; font-weight: 600; border-radius: 8px; text-decoration: none !important; transition: background-color .2s ease, color .2s ease; }
.wo-sub-menu a:hover { background-color: rgba(104,205,236,0.10); color: #68CDEC; }

/* Header actions */
.wo-header-actions { display: flex; align-items: center; gap: 12px; flex-shrink: 0; justify-self: end; }
.wo-header-phone { display: inline-flex; align-items: center; gap: 8px; color: #1A1A1A; text-decoration: none !important; font-weight: 700; font-size: 14px; padding: 6px 12px; border-radius: 8px; transition: color .2s ease, background-color .2s ease; }
.wo-header-phone:hover { color: #68CDEC !important; background-color: rgba(104,205,236,0.10); }
.wo-header-phone-icon { display: inline-block; width: 18px; height: 18px; background-position: center; background-repeat: no-repeat; background-size: contain; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2'/></svg>"); }
.wo-header-cta { display: inline-flex; align-items: center; padding: 12px 22px; background: #68CDEC; color: #1A1A1A !important; font-weight: 700; font-size: 14px; border-radius: 100px; text-decoration: none !important; transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease; }
.wo-header-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(104,205,236,0.4); background: #2D9CB8; color: #FFFFFF !important; }

/* Mobile burger */
.wo-burger { display: none; width: 44px; height: 44px; background: transparent; border: 0; cursor: pointer; padding: 0; flex-direction: column; justify-content: center; align-items: center; gap: 5px; }
.wo-burger span { display: block; width: 24px; height: 2px; background: #1A1A1A; border-radius: 2px; transition: transform .3s ease, opacity .2s ease; }
.wo-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.wo-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.wo-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu drawer */
.wo-mobile-menu { display: none; }
body.wo-menu-open { overflow: hidden; }

@media (max-width: 1024px) {
  .wo-nav, .wo-header-phone { display: none !important; }
  .wo-burger { display: flex; }
  .wo-mobile-menu { display: block; position: fixed; inset: 0; background: #0F1B26; padding: 100px 32px 40px; opacity: 0; visibility: hidden; transform: translateY(-12px); transition: opacity .3s ease, transform .3s ease, visibility 0s linear .3s; z-index: 998; overflow-y: auto; }
  body.wo-menu-open .wo-mobile-menu { opacity: 1; visibility: visible; transform: translateY(0); transition-delay: 0s; }
  .wo-mobile-menu ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
  .wo-mobile-menu li { padding: 0 !important; list-style: none !important; border-bottom: 1px solid rgba(255,255,255,0.08); }
  .wo-mobile-menu li::before, .wo-mobile-menu li::marker { content: none !important; display: none !important; }
  .wo-mobile-menu a { display: block; padding: 18px 0; color: #FFFFFF; font-family: "Nunito Sans", sans-serif; font-weight: 600; font-size: 18px; text-decoration: none !important; }
  .wo-mobile-menu a:hover { color: #68CDEC; }
  .wo-mobile-menu .wo-mm-cta { margin-top: 24px; border: 0; }
  .wo-mobile-menu .wo-mm-cta a { background: #68CDEC; color: #1A1A1A !important; padding: 16px 24px; border-radius: 100px; text-align: center; }
}


/* Hero gets pushed down by header (the hero already is min-height 100vh; header is fixed and overlays) */
.et_pb_section_0 { padding-top: 100px !important; }


/* ================================================== */
/* === v50: AUDITORIA MOBILE — fixes P0 + P1 ======== */
/* ================================================== */

/* P0-1: Burger close button must be visible above mobile menu overlay
   (the wp:divi/section wrapping breaks z-index stacking context, so we
   force the burger to position:fixed at top:0 when menu is open) */
body.wo-menu-open .wo-burger {
  position: fixed !important;
  top: 22px;
  right: 24px;
  z-index: 1001;
}
body.admin-bar.wo-menu-open .wo-burger { top: 54px; }
@media screen and (max-width: 782px) {
  body.admin-bar.wo-menu-open .wo-burger { top: 68px; }
}
body.wo-menu-open .wo-burger span { background: #FFFFFF !important; }

/* P0-2: Service cards image must fill 100% width on mobile (was ~50%) */
@media (max-width: 767px) {
  .wo-services .et_pb_row,
  .wo-services .et_pb_row .et_pb_column,
  .wo-services .wo-service-card {
    width: 100% !important;
    max-width: 100% !important;
    flex-basis: 100% !important;
  }
  .wo-services .wo-service-card .et_pb_image,
  .wo-services .wo-service-card .et_pb_image img {
    width: 100% !important;
    max-width: 100% !important;
  }
  html body .wo-services .wo-service-card .et_pb_image img {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 10 !important;
    object-fit: cover !important;
    object-position: center center !important;
  }
}

/* P1-1: Trust bar mobile — title centered + logos in horizontal scroll carousel */
@media (max-width: 767px) {
  .wo-trust-bar .wo-trust-title,
  .wo-trust-bar h2,
  .wo-trust-bar h3 {
    text-align: center !important;
    max-width: 100% !important;
    width: 100% !important;
  }
  .wo-trust-bar .et_pb_row.et_pb_row_1,
  .wo-trust-bar .et_pb_row:nth-of-type(2) {
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 24px !important;
    padding: 16px 5vw !important;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .wo-trust-bar .et_pb_row.et_pb_row_1::-webkit-scrollbar,
  .wo-trust-bar .et_pb_row:nth-of-type(2)::-webkit-scrollbar { display: none; }
  .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_column,
  .wo-trust-bar .et_pb_row:nth-of-type(2) .et_pb_column {
    flex: 0 0 auto !important;
    max-width: 140px !important;
    min-width: 100px !important;
    width: auto !important;
  }
  .wo-trust-bar img { max-width: 100px !important; }
}

/* P1-3: Hero content gets padding-right on mobile to avoid chat widget overlap */
@media (max-width: 767px) {
  .et_pb_section_0 .et_pb_row { padding-right: 60px !important; }
}

/* ================================================== */
/* === END v50 ====================================== */
/* ================================================== */


/* ================================================== */
/* === v52: Trust bar logos maiores + menos gap ===== */
/* ================================================== */

/* DESKTOP: logos bigger, less wasted space */
.wo-trust-bar .wo-mq-item {
  min-width: 200px !important;
  padding: 0 20px !important;
}
.wo-trust-bar img {
  max-width: 180px !important;
  max-height: 100px !important;
  object-fit: contain !important;
}

/* MOBILE: bump logos to 140px wide (was 100) and reduce item width */
@media (max-width: 767px) {
  .wo-trust-bar .wo-mq-item {
    min-width: 160px !important;
    padding: 0 12px !important;
  }
  .wo-trust-bar img {
    max-width: 140px !important;
    max-height: 70px !important;
  }
}

/* ================================================== */

/* ================================================== */
/* === FAQ Section ================================== */
/* ================================================== */
.wo-faq { background: #FFFFFF !important; padding: 100px 5vw !important; }
.wo-faq-inner { max-width: 1000px; margin: 0 auto; }
.wo-faq .wo-pre-headline {
  font-family: "Nunito Sans", sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #68CDEC;
  text-align: center;
  margin: 0 0 16px;
}
.wo-faq-title {
  font-family: "Nunito Sans", sans-serif;
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 800;
  color: #1A1A1A;
  text-align: center;
  margin: 0 0 12px !important;
  line-height: 1.2;
}
.wo-faq-subtitle {
  font-size: 17px;
  color: #808285;
  text-align: center;
  margin: 0 auto 48px !important;
  max-width: 600px;
}
.wo-faq-list { display: flex; flex-direction: column; gap: 12px; margin-bottom: 40px; }
.wo-faq-item {
  background: #F4F6F8;
  border: 1px solid rgba(0,0,0,0.04);
  border-radius: 12px;
  overflow: hidden;
  transition: background-color .25s ease, border-color .25s ease;
}
.wo-faq-item[open] {
  background: #FFFFFF;
  border-color: rgba(104,205,236,0.4);
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
}
.wo-faq-item summary {
  cursor: pointer;
  padding: 24px 32px;
  font-family: "Nunito Sans", sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #1A1A1A;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  user-select: none;
  transition: color .2s ease;
}
.wo-faq-item summary::-webkit-details-marker { display: none; }
.wo-faq-item summary::marker { content: none; display: none; }
.wo-faq-item summary::after {
  content: "+";
  font-size: 28px;
  font-weight: 300;
  color: #68CDEC;
  transition: transform .3s ease;
  flex-shrink: 0;
  line-height: 1;
}
.wo-faq-item[open] summary::after { transform: rotate(45deg); }
.wo-faq-item summary:hover { color: #68CDEC; }
.wo-faq-answer {
  padding: 0 32px 24px;
  font-size: 17px;
  line-height: 1.7;
  color: #4A4A4A;
}
.wo-faq-link-wrap { text-align: center; }
.wo-faq-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "Nunito Sans", sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: #68CDEC;
  text-decoration: none !important;
  transition: gap .25s ease, color .2s ease;
}
.wo-faq-link:hover { gap: 16px; color: #2D9CB8; }

/* Mobile FAQ */
@media (max-width: 767px) {
  .wo-faq { padding: 60px 5vw !important; }
  .wo-faq-item summary { padding: 20px 24px; font-size: 16px; }
  .wo-faq-answer { padding: 0 24px 20px; font-size: 16px; }
  .wo-faq-subtitle { margin-bottom: 32px !important; }
  .wo-faq-list { gap: 8px; margin-bottom: 32px; }
}
/* ================================================== */


/* =====================================================
   WO HERO v70 — fix: alignment + 2-col grid + lite-video
   ===================================================== */
.wo-hero-section {
  position: relative;
  background-image: url("https://staging.weboffice.pt/wp-content/uploads/2022/10/1porto.jpg") !important;
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-color: #0F1B26 !important;
  padding-left: 5vw !important;
  padding-right: 5vw !important;
  padding-top: 90px !important;
  padding-bottom: 30px !important;
  height: 100vh !important;
  height: 100dvh !important;
  display: grid !important;
  place-content: center !important;
  grid-template-columns: 1fr !important;
  overflow: hidden;
}
.wo-hero-section > * { width: 100%; }
body.admin-bar .wo-hero-section { height: calc(100vh - 32px) !important; height: calc(100dvh - 32px) !important; }
@media (max-width: 782px) {
  body.admin-bar .wo-hero-section { height: calc(100vh - 46px) !important; height: calc(100dvh - 46px) !important; }
}
/* Em viewports muito baixos (laptop com devtools) ou mobile, libertar height para que o conteúdo respire */
@media (max-height: 700px), (max-width: 900px) {
  .wo-hero-section {
    height: auto !important;
    min-height: 100vh !important;
    min-height: 100dvh !important;
  }
}
.wo-hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(0,20,30,0.78) 0%, rgba(0,20,30,0.55) 55%, rgba(0,20,30,0.30) 100%);
  z-index: 1;
  pointer-events: none;
}
.wo-hero-section > .et_pb_row { position: relative; z-index: 2; }
.wo-hero-section .et_pb_row {
  max-width: 100% !important;
  width: 100% !important;
  padding: 27px 0 !important;
  margin: 0 !important;
}
.wo-hero-section .et_pb_column {
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}
.wo-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, min(560px, 42%));
  gap: 64px;
  align-items: center;
  max-width: 100%;
}
.wo-hero-text { color: #FFFFFF; max-width: 620px; }
.wo-hero-pre {
  font-family: "Nunito Sans", sans-serif;
  font-size: 14px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: #68CDEC; margin: 0 0 12px;
}
.wo-hero-h1 {
  font-family: "Nunito Sans", sans-serif;
  font-size: clamp(40px, 5.6vw, 68px);
  line-height: 1.05; font-weight: 800;
  color: #FFFFFF; margin: 0 0 20px;
  letter-spacing: -0.02em;
}
.wo-hero-sub {
  font-family: "Nunito Sans", sans-serif;
  font-size: clamp(16px, 1.5vw, 19px);
  line-height: 1.55; font-weight: 400;
  color: #E8EDF2; margin: 0 0 28px;
}
.wo-hero-sub strong { color: #FFFFFF; font-weight: 700; }
.wo-hero-bullets-new {
  list-style: none; padding: 0 !important;
  margin: 0 0 32px !important;
  display: flex; flex-direction: column; gap: 10px;
}
.wo-hero-bullets-new li {
  display: flex; align-items: center; gap: 12px;
  font-family: "Nunito Sans", sans-serif;
  font-size: 16px; font-weight: 500;
  color: #FFFFFF; line-height: 1.5; margin: 0;
}
.wo-hero-bullets-new li strong { font-weight: 700; }
.wo-hb-check {
  display: inline-flex; flex: 0 0 22px;
  width: 22px; height: 22px;
  border-radius: 50%; background: #68CDEC;
  position: relative;
}
.wo-hb-check::after {
  content: ""; position: absolute;
  left: 6px; top: 4px; width: 6px; height: 11px;
  border: solid #0F1B26;
  border-width: 0 2.5px 2.5px 0;
  transform: rotate(45deg);
}
.wo-hero-actions {
  display: flex; flex-wrap: wrap; gap: 14px; align-items: center;
}
.wo-hero-btn-primary, .wo-hero-btn-ghost {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: "Nunito Sans", sans-serif;
  font-size: 16px; font-weight: 700;
  padding: 16px 28px; border-radius: 999px;
  text-decoration: none; transition: all .25s ease;
  white-space: nowrap; line-height: 1;
}
.wo-hero-btn-primary { background: #68CDEC; color: #0F1B26; }
.wo-hero-btn-primary:hover {
  background: #FFFFFF; transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(104, 205, 236, .35);
}
.wo-hero-btn-ghost {
  background: rgba(255, 255, 255, 0.08);
  color: #FFFFFF;
  border: 2px solid rgba(255, 255, 255, 0.6);
  padding: 14px 26px; font-weight: 600;
}
.wo-hero-btn-ghost:hover {
  background: #FFFFFF; color: #0F1B26;
  border-color: #FFFFFF; transform: translateY(-2px);
}
/* Video — todo o elemento é clicável; SVG/imagem com pointer-events:none */
.wo-hero-video {
  position: relative; width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 16px; overflow: hidden;
  cursor: pointer; background: #000;
  box-shadow:
    0 0 0 2px rgba(104, 205, 236, 0.75),                /* inner ring brand */
    0 0 0 7px rgba(104, 205, 236, 0.15),                /* halo */
    0 0 40px -2px rgba(104, 205, 236, 0.45),            /* soft outer glow */
    0 20px 50px rgba(0, 0, 0, 0.45);                    /* drop shadow */
  transition: transform .35s ease, box-shadow .35s ease;
  isolation: isolate;
}
.wo-hero-video:hover {
  transform: translateY(-3px);
  box-shadow:
    0 0 0 2px rgba(104, 205, 236, 1),
    0 0 0 10px rgba(104, 205, 236, 0.25),
    0 0 60px 0px rgba(104, 205, 236, 0.65),
    0 28px 60px rgba(0, 0, 0, 0.55);
}
.wo-hero-video:focus-visible { outline: 3px solid #68CDEC; outline-offset: 4px; }
.wo-hero-video-thumb {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .6s ease;
  pointer-events: none;
}
.wo-hero-video:hover .wo-hero-video-thumb {
  transform: scale(1.02);
}
.wo-hero-video-play {
  position: absolute; inset: 0; margin: auto;
  width: 96px; height: 96px;
  display: flex; align-items: center; justify-content: center;
  z-index: 2; pointer-events: none;
  transition: transform .25s ease;
  filter: drop-shadow(0 6px 20px rgba(0, 0, 0, 0.35));
}
.wo-hero-video:hover .wo-hero-video-play { transform: scale(1.08); }
.wo-hero-video-play svg {
  filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.4));
  pointer-events: none;
}
/* play button hover effect via parent .wo-hero-video:hover .wo-hero-video-play scale (defined above) */
.wo-hero-video iframe {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border: 0; z-index: 3;
}
@media (max-width: 1100px) {
  .wo-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .wo-hero-text { max-width: 100%; }
  .wo-hero-video { max-width: 600px; margin: 0 auto; }
}
@media (max-width: 640px) {
  .wo-hero-grid { gap: 32px; }
  .wo-hero-actions { flex-direction: column; align-items: stretch; }
  .wo-hero-actions a { width: 100%; text-align: center; }
  .wo-hero-bullets-new li { font-size: 15px; }
  .wo-hero-pre { font-size: 12px; letter-spacing: 0.14em; }
}



/* =====================================================
   WO LOCATIONS v72 — side-by-side cards (2-col / 1-col mobile)
   ===================================================== */
.wo-locations-v2 .et_pb_row {
  max-width: 1240px !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 auto !important;
}
.wo-locations-v2 .et_pb_column { max-width: 100% !important; padding: 0 !important; margin: 0 !important; }

.wo-loc-header { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.wo-loc-header .wo-loc-pre {
  font-family: "Nunito Sans", sans-serif;
  font-size: 15px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: #68CDEC; margin: 0 0 12px;
}
.wo-loc-header .wo-loc-h2 {
  font-family: "Nunito Sans", sans-serif;
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 800; color: #1A1A1A;
  margin: 0 0 16px; line-height: 1.15;
  letter-spacing: -0.01em;
}
.wo-loc-header .wo-loc-sub {
  font-family: "Nunito Sans", sans-serif;
  font-size: 17px; line-height: 1.55;
  color: #5A6470; margin: 0;
}

.wo-loc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: stretch;
}

.wo-loc-card {
  background: #FFFFFF;
  border-radius: 20px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04), 0 0 0 1px rgba(0, 0, 0, 0.03);
  transition: transform .35s ease, box-shadow .35s ease;
}
.wo-loc-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(104, 205, 236, 0.15);
}

.wo-loc-image {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #E5E8EC;
}
.wo-loc-image img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .8s ease;
}
.wo-loc-card:hover .wo-loc-image img { transform: scale(1.04); }

.wo-loc-body {
  padding: 32px 32px 36px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.wo-loc-tag {
  font-family: "Nunito Sans", sans-serif;
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: #68CDEC; margin: 0 0 8px;
}
.wo-loc-title {
  font-family: "Nunito Sans", sans-serif;
  font-size: 28px; font-weight: 800;
  color: #1A1A1A; margin: 0 0 16px;
  line-height: 1.2; letter-spacing: -0.01em;
}
.wo-loc-addr {
  font-family: "Nunito Sans", sans-serif;
  font-size: 15px; line-height: 1.6;
  color: #5A6470; margin: 0 0 16px;
}
.wo-loc-desc {
  font-family: "Nunito Sans", sans-serif;
  font-size: 15px; line-height: 1.6;
  color: #2A2F36; margin: 0 0 24px;
}
.wo-loc-desc strong { color: #1A1A1A; font-weight: 700; }

/* Transports list — compact with mini-icons */
.wo-loc-transports {
  list-style: none;
  padding: 18px 20px !important;
  margin: 0 0 28px;
  background: #F7F9FB;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.wo-loc-transports li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: "Nunito Sans", sans-serif;
  font-size: 14px;
  color: #2A2F36;
  line-height: 1.45;
  margin: 0;
}
.wo-loc-transports li strong { color: #1A1A1A; font-weight: 700; }
.wo-loc-transports .wo-tr-time { color: #5A6470; font-weight: 500; }
.wo-loc-meta { color: #5A6470; font-weight: 400; font-size: 13px; }

.wo-tr-icon {
  flex: 0 0 26px;
  width: 26px; height: 26px;
  border-radius: 50%;
  background: #E8F7FC;
  display: inline-block;
  margin-top: 1px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px 16px;
}
/* SVG icons inline via background-image (NÃO mask — mais robusto) */
.wo-tr-icon.wo-icon-train {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231A78A8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='4' y='4' width='16' height='16' rx='2'/><path d='M4 12h16'/><circle cx='8' cy='17' r='1'/><circle cx='16' cy='17' r='1'/><path d='M6 22l-2 2M18 22l2 2'/></svg>");
}
.wo-tr-icon.wo-icon-subway {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231A78A8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='4' y='3' width='16' height='16' rx='4'/><path d='M9 11h6'/><circle cx='9' cy='16' r='1'/><circle cx='15' cy='16' r='1'/></svg>");
}
.wo-tr-icon.wo-icon-parking {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231A78A8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='18' height='18' rx='2'/><path d='M9 17V7h4a3 3 0 0 1 0 6H9'/></svg>");
}
.wo-tr-icon.wo-icon-bus {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231A78A8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M4 17V6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v11l-2 2v2h-3v-2H9v2H6v-2l-2-2z'/><path d='M4 11h16'/><circle cx='8' cy='14.5' r='1'/><circle cx='16' cy='14.5' r='1'/></svg>");
}

/* CTA */
.wo-loc-cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #68CDEC;
  color: #0F1B26;
  font-family: "Nunito Sans", sans-serif;
  font-size: 15px; font-weight: 700;
  padding: 14px 24px;
  border-radius: 999px;
  text-decoration: none;
  transition: all .25s ease;
  align-self: flex-start;
}
.wo-loc-cta:hover {
  background: #0F1B26; color: #FFFFFF;
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(15, 27, 38, 0.2);
}
.wo-loc-cta-arrow {
  display: inline-block;
  transition: transform .25s ease;
}
.wo-loc-cta:hover .wo-loc-cta-arrow { transform: translateX(4px); }

/* Mobile — 1-col */
@media (max-width: 900px) {
  .wo-loc-grid { grid-template-columns: 1fr; gap: 28px; }
  .wo-loc-image { aspect-ratio: 16 / 10; }
  .wo-loc-body { padding: 24px 24px 28px; }
  .wo-loc-header { margin-bottom: 36px; }
}





/* =====================================================
   WO HEADER v77b — transparent override invertido
   ===================================================== */
/* Logo swap (default mostra dark; transparent mode mostra white) */
.wo-logo { position: relative; display: inline-block; }
.wo-logo-img { display: block; transition: opacity .25s ease; }
.wo-logo-light { position: absolute; top: 0; left: 0; opacity: 0; }
.wo-logo-dark { opacity: 1; }

/* Transparent variant — override do glass default */
.wo-header.wo-transparent {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.wo-header.wo-transparent .wo-nav-list > li > a,
.wo-header.wo-transparent .wo-header-phone,
.wo-header.wo-transparent .wo-header-phone-num { color: #FFFFFF !important; }
.wo-header.wo-transparent .wo-header-phone-icon {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.37 1.9.72 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.91.35 1.85.59 2.81.72A2 2 0 0 1 22 16.92z'/></svg>") !important;
}
.wo-header.wo-transparent .wo-burger span { background: #FFFFFF !important; }
.wo-header.wo-transparent .wo-caret { border-top-color: #FFFFFF !important; }
.wo-header.wo-transparent .wo-logo-light { opacity: 1; }
.wo-header.wo-transparent .wo-logo-dark { opacity: 0; }


/* Text-shadow for legibility on transparent header over varied bg */
.wo-header.wo-transparent .wo-nav-list > li > a,
.wo-header.wo-transparent .wo-header-phone,
.wo-header.wo-transparent .wo-header-phone-num {
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.55), 0 0 4px rgba(0, 0, 0, 0.3);
}
.wo-header.wo-transparent .wo-logo-light {
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.4));
}
/* Soft gradient under header to ensure readability even on light backgrounds */
.wo-header.wo-transparent::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0) 100%);
  z-index: -1;
  pointer-events: none;
}

/* ============================================================ */
/* === WC + Single Product overrides ========================== */
/* ============================================================ */

/* Header on non-hero pages — force non-transparent */
html body.woocommerce-cart .wo-header.wo-transparent,
html body.woocommerce-checkout .wo-header.wo-transparent,
html body.woocommerce-account .wo-header.wo-transparent,
html body.single-product .wo-header.wo-transparent {
  background: rgba(255,255,255,0.85) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-bottom: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 1px 12px rgba(0,0,0,0.04) !important;
}
html body.woocommerce-cart .wo-header.wo-transparent .wo-nav-list > li > a,
html body.woocommerce-checkout .wo-header.wo-transparent .wo-nav-list > li > a,
html body.woocommerce-account .wo-header.wo-transparent .wo-nav-list > li > a,
html body.single-product .wo-header.wo-transparent .wo-nav-list > li > a,
html body.woocommerce-cart .wo-header.wo-transparent .wo-header-phone-num,
html body.woocommerce-checkout .wo-header.wo-transparent .wo-header-phone-num,
html body.woocommerce-account .wo-header.wo-transparent .wo-header-phone-num,
html body.single-product .wo-header.wo-transparent .wo-header-phone-num { color: #0F1B26 !important; }
html body.woocommerce-cart .wo-header.wo-transparent .wo-logo-light,
html body.woocommerce-checkout .wo-header.wo-transparent .wo-logo-light,
html body.woocommerce-account .wo-header.wo-transparent .wo-logo-light,
html body.single-product .wo-header.wo-transparent .wo-logo-light { opacity: 0 !important; }
html body.woocommerce-cart .wo-header.wo-transparent .wo-logo-dark,
html body.woocommerce-checkout .wo-header.wo-transparent .wo-logo-dark,
html body.woocommerce-account .wo-header.wo-transparent .wo-logo-dark,
html body.single-product .wo-header.wo-transparent .wo-logo-dark { opacity: 1 !important; }

/* === SINGLE PRODUCT PAGE === */

/* Hide Divi default chrome on product page */
html body.single-product #main-header,
html body.single-product #et-secondary-menu,
html body.single-product #main-footer,
html body.single-product #et-footer-nav,
html body.single-product #footer-bottom,
html body.single-product #sidebar { display: none !important; }
html body.single-product #page-container { padding-top: 0 !important; }

/* Page font */
html body.single-product { font-family: "Nunito Sans", -apple-system, sans-serif !important; }

/* Main content area: keep visible, just adjust padding */
html body.single-product #main-content {
  background: #FFFFFF !important;
  padding: 140px 5vw 80px !important;
}
html body.single-product #left-area {
  width: 100% !important; max-width: 1280px !important;
  margin: 0 auto !important; padding: 0 !important; float: none !important;
}
html body.single-product #content-area { width: 100% !important; float: none !important; }
html body.single-product .et_pb_section_0 {
  padding: 0 !important; background: transparent !important; min-height: auto !important;
}
html body.single-product .et_pb_row { width: 100% !important; max-width: none !important; padding: 0 !important; }
html body.single-product .et_pb_column { width: 100% !important; padding: 0 !important; }

/* Product layout */
html body.single-product div.product { margin: 32px 0 !important; }
html body.single-product div.product > .clearfix {
  display: grid !important;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr) !important;
  gap: 56px !important;
  align-items: start !important;
}
/* In case there's no clearfix wrapper (some WC templates) — fallback */
html body.single-product div.product:not(:has(> .clearfix)) {
  display: grid !important;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr) !important;
  gap: 56px !important;
  align-items: start !important;
}
html body.single-product div.product .woocommerce-product-gallery {
  grid-column: 1 !important; width: 100% !important; float: none !important; margin: 0 !important;
}
html body.single-product div.product .woocommerce-product-gallery__image img {
  border-radius: 24px !important;
  box-shadow: 0 16px 48px rgba(15,27,38,0.08) !important;
  width: 100% !important; height: auto !important;
  aspect-ratio: 1/1 !important; object-fit: cover !important;
}
html body.single-product div.product .summary {
  grid-column: 2 !important; width: 100% !important; float: none !important;
  margin: 0 !important; padding: 8px 0 !important;
}
html body.single-product .product_title {
  font-size: clamp(32px, 4vw, 44px) !important;
  font-weight: 800 !important; color: #0F1B26 !important;
  line-height: 1.15 !important; margin: 0 0 16px !important;
}
html body.single-product .summary p.price,
html body.single-product .summary .price {
  font-size: 38px !important; font-weight: 800 !important;
  color: #0F1B26 !important; margin: 0 0 8px !important;
}
html body.single-product .summary .price::after {
  content: " + IVA"; font-size: 16px; font-weight: 500; color: #808285; margin-left: 6px;
}
html body.single-product .woocommerce-product-details__short-description {
  font-size: 17px !important; line-height: 1.6 !important; color: #4A4A4A !important;
  margin: 12px 0 28px !important; padding: 0 0 28px !important;
  border-bottom: 1px solid #F4F6F8 !important;
}
html body.single-product form.cart {
  display: flex !important; flex-wrap: wrap !important;
  align-items: stretch !important; gap: 12px !important; margin: 0 0 28px !important;
}
html body.single-product form.cart .quantity input.qty {
  width: 80px !important; height: 56px !important;
  border: 1px solid #E5E7EB !important; border-radius: 100px !important;
  text-align: center !important; font-size: 16px !important; font-weight: 700 !important;
  color: #0F1B26 !important; padding: 0 12px !important; background: #FFFFFF !important;
}
html body.single-product form.cart button.single_add_to_cart_button {
  flex: 1 1 auto !important; min-width: 240px !important; height: 56px !important;
  background: #68CDEC !important; color: #0F1B26 !important;
  font-size: 17px !important; font-weight: 800 !important;
  border-radius: 100px !important; border: none !important;
  padding: 0 32px !important; cursor: pointer !important;
  box-shadow: 0 8px 24px rgba(104,205,236,0.32) !important;
}
html body.single-product form.cart button.single_add_to_cart_button:hover {
  transform: translateY(-2px) !important; background: #4FB8D6 !important;
  box-shadow: 0 14px 32px rgba(104,205,236,0.42) !important;
}
html body.single-product .product_meta {
  padding: 24px 0 0 !important; border-top: 1px solid #F4F6F8 !important;
  font-size: 14px !important; color: #808285 !important;
}
html body.single-product .product_meta > span { display: block !important; margin: 6px 0 !important; }
html body.single-product .product_meta a, html body.single-product .product_meta .sku {
  color: #0F1B26 !important; font-weight: 600 !important; text-decoration: none !important;
}

/* Tabs */
html body.single-product .woocommerce-tabs {
  grid-column: 1 / -1 !important; margin-top: 60px !important;
  padding-top: 60px !important; border-top: 1px solid #EEF1F4 !important;
}
html body.single-product .woocommerce-tabs ul.tabs {
  border-bottom: 1px solid #EEF1F4 !important;
  padding: 0 !important; margin: 0 0 32px !important;
  display: flex !important; gap: 4px !important; list-style: none !important;
}
html body.single-product .woocommerce-tabs ul.tabs::before { display: none !important; }
html body.single-product .woocommerce-tabs ul.tabs li {
  background: transparent !important; border: none !important; margin: 0 !important;
}
html body.single-product .woocommerce-tabs ul.tabs li::before,
html body.single-product .woocommerce-tabs ul.tabs li::after { display: none !important; }
html body.single-product .woocommerce-tabs ul.tabs li a {
  display: block !important; padding: 14px 24px !important;
  font-size: 14px !important; font-weight: 700 !important;
  letter-spacing: 0.05em !important; text-transform: uppercase !important;
  color: #808285 !important; text-decoration: none !important;
  border-bottom: 2px solid transparent !important; margin-bottom: -1px !important;
}
html body.single-product .woocommerce-tabs ul.tabs li.active a,
html body.single-product .woocommerce-tabs ul.tabs li a:hover {
  color: #0F1B26 !important; border-bottom-color: #68CDEC !important;
}

/* Related products */
html body.single-product .related.products {
  grid-column: 1 / -1 !important; margin-top: 80px !important;
  padding-top: 60px !important; border-top: 1px solid #EEF1F4 !important; clear: both !important;
}
html body.single-product .related.products > h2 {
  font-size: 28px !important; font-weight: 800 !important;
  color: #0F1B26 !important; margin: 0 0 32px !important; text-align: center !important;
}
html body.single-product .related.products ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 24px !important; margin: 0 !important; padding: 0 !important; list-style: none !important;
}
html body.single-product .related.products ul.products li.product {
  width: 100% !important; margin: 0 !important; padding: 20px !important;
  background: #FFFFFF !important; border: 1px solid #EEF1F4 !important;
  border-radius: 20px !important; float: none !important;
  display: flex !important; flex-direction: column !important; text-align: left !important;
}
html body.single-product .related.products ul.products li.product::before,
html body.single-product .related.products ul.products li.product::after { display: none !important; }
html body.single-product .related.products ul.products li.product img {
  border-radius: 12px !important; margin: 0 0 16px !important;
  aspect-ratio: 1/1 !important; object-fit: cover !important;
  width: 100% !important; height: auto !important;
}
html body.single-product .related.products ul.products li.product h2,
html body.single-product .related.products ul.products li.product .woocommerce-loop-product__title {
  font-size: 17px !important; font-weight: 700 !important; color: #0F1B26 !important;
  margin: 0 0 8px !important; padding: 0 !important; text-transform: none !important;
}
html body.single-product .related.products ul.products li.product .price {
  font-size: 20px !important; font-weight: 800 !important;
  color: #0F1B26 !important; margin: 0 0 16px !important; display: block !important;
}
html body.single-product .related.products ul.products li.product .button {
  background: #68CDEC !important; color: #0F1B26 !important;
  font-size: 14px !important; font-weight: 700 !important;
  padding: 10px 22px !important; border-radius: 100px !important;
  text-decoration: none !important; margin: auto 0 0 !important;
  align-self: flex-start !important;
}

/* Injected footer container */
html body.single-product .wo-footer--injected {
  background: #0F1B26 !important; padding: 80px 5vw 32px !important;
  color: #FFFFFF !important; margin-top: 80px !important;
}
html body.single-product .wo-footer--injected .wo-footer-inner {
  max-width: 1280px !important; margin: 0 auto !important;
}

/* === CART / CHECKOUT / MY-ACCOUNT pages === */

html body #wpadminbar input.adminbar-button {
  background: transparent !important; color: #ccc !important; border: 0 !important;
  padding: 0 8px !important; border-radius: 0 !important;
  font-size: 13px !important; font-weight: 400 !important; height: 32px !important;
}

html body.woocommerce-cart .et_pb_section:not(.wo-footer),
html body.woocommerce-checkout .et_pb_section:not(.wo-footer),
html body.woocommerce-account .et_pb_section:not(.wo-footer) {
  padding: 0 !important; background: transparent !important; min-height: auto !important;
}
html body.woocommerce-cart .et_pb_row,
html body.woocommerce-checkout .et_pb_row,
html body.woocommerce-account .et_pb_row {
  width: 100% !important; max-width: none !important; padding: 0 !important; margin: 0 !important;
}
html body.woocommerce-cart .et_pb_column,
html body.woocommerce-checkout .et_pb_column,
html body.woocommerce-account .et_pb_column {
  width: 100% !important; padding: 0 !important; margin: 0 !important;
}

html body .wo-wc-page { padding: 160px 4vw 80px !important; }
html body .wo-wc-page .wo-wc-inner {
  width: 90% !important; max-width: 1600px !important; margin: 0 auto !important;
}
html body .wo-wc-page .wo-wc-title {
  font-size: clamp(28px, 4vw, 44px) !important;
  margin: 0 0 4px !important; color: #1A1A1A !important; font-weight: 800 !important;
}
html body .wo-wc-page .wo-wc-sub { margin: 0 0 40px !important; font-size: 16px !important; color: #4A4A4A !important; }

/* Cart 2-col */
html body.woocommerce-cart div.woocommerce.woocommerce,
html body.woocommerce-cart .wo-wc-page div.woocommerce.woocommerce {
  display: grid !important;
  grid-template-columns: 1fr 380px !important;
  gap: 32px !important; align-items: start !important;
}
html body.woocommerce-cart .woocommerce-cart-form { grid-column: 1 !important; min-width: 0 !important; }
html body.woocommerce-cart .cart-collaterals { grid-column: 2 !important; min-width: 0 !important; margin: 0 !important; }

@media (max-width: 1024px) {
  html body.woocommerce-cart div.woocommerce.woocommerce,
  html body.woocommerce-cart .wo-wc-page div.woocommerce.woocommerce {
    display: block !important;
  }
  html body.woocommerce-cart .cart-collaterals { width: 100% !important; margin-top: 24px !important; }
}

/* Cart card styles */
html body .wo-wc-page .shop_table {
  border-radius: 20px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.02), 0 12px 32px rgba(0,0,0,0.04) !important;
  border: 1px solid #EEF1F4 !important;
  background: #FFFFFF !important;
}
html body .wo-wc-page .cart_totals {
  background: #FBFCFD !important; border: 1px solid #EEF1F4 !important;
  border-radius: 20px !important; padding: 28px !important;
  width: 100% !important; box-sizing: border-box !important; margin: 0 !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.02), 0 12px 32px rgba(0,0,0,0.04) !important;
}
html body .wo-wc-page .checkout-button {
  background: #68CDEC !important; color: #0F1B26 !important;
  font-weight: 700 !important; font-size: 17px !important;
  padding: 18px 32px !important; border-radius: 100px !important;
  width: 100% !important; display: block !important; text-align: center !important;
  white-space: nowrap !important;
  box-shadow: 0 8px 24px rgba(104,205,236,0.28) !important;
}

html body .wo-wc-page .product-thumbnail a {
  display: block; width: 72px; height: 72px;
  border-radius: 12px; overflow: hidden; text-decoration: none;
}
html body .wo-wc-page .product-thumbnail img {
  display: block !important; width: 72px !important; height: 72px !important;
  object-fit: cover !important; border-radius: 12px !important; border: none !important;
}


/* === v114c — Eliminate Divi sidebar separator ghost line on product page === */
html body.single-product #main-content .container::before,
html body.single-product #main-content .container::after,
html body.single-product #content-area::before,
html body.single-product #content-area::after,
html body.single-product #left-area::before,
html body.single-product #left-area::after { 
  display: none !important; 
  content: none !important; 
  background: none !important;
  border: none !important;
}
html body.single-product #main-content .container,
html body.single-product #content-area,
html body.single-product #left-area,
html body.single-product article.product,
html body.single-product div.product,
html body.single-product .summary {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background-image: none !important;
}


/* === v114d — Hide WC clearfix pseudos on ul.products (they were occupying grid columns) === */
html body.single-product .related.products ul.products::before,
html body.single-product .related.products ul.products::after {
  display: none !important;
  content: none !important;
}


/* === v115 — wo-footer--injected styling for service pages with blank template === */
body.page .wo-footer--injected,
body.single-product .wo-footer--injected {
  background: #0F1B26 !important;
  padding: 80px 5vw 32px !important;
  color: #FFFFFF !important;
  margin-top: 0 !important;
}
body.page .wo-footer--injected .wo-footer-inner,
body.single-product .wo-footer--injected .wo-footer-inner {
  max-width: 1280px !important;
  margin: 0 auto !important;
}


/* === v118c — Cart cross-sells styling === */
html body.woocommerce-cart .cart-collaterals .cross-sells,
html body.woocommerce-cart div.woocommerce > .cross-sells {
  display: block !important;
  grid-column: 1 / -1 !important;
  margin: 56px 0 0 !important;
  padding: 56px 0 0 !important;
  border-top: 1px solid #EEF1F4 !important;
  width: 100% !important;
}
html body.woocommerce-cart .cross-sells > h2 {
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 24px !important;
  font-weight: 800 !important;
  color: #0F1B26 !important;
  margin: 0 0 24px !important;
  text-align: center !important;
  visibility: hidden;
  height: 0;
  overflow: hidden;
}
html body.woocommerce-cart .cross-sells::before {
  content: "TALVEZ GOSTE TAMBÉM — COMPLEMENTE COM SALAS DE REUNIÃO";
  display: block;
  color: #68CDEC;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 12px;
}
html body.woocommerce-cart .cross-sells::after {
  content: "Adicione horas de sala às suas reuniões com clientes";
  display: block;
  text-align: center;
  font-family: "Nunito Sans", sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #0F1B26;
  margin: -38px 0 28px;
}
/* Hide the original heading text (since we'll show our own pseudo) — but we still want SOMETHING visible. Let's just override the text-content via display none of the natural content + add our own. Simpler: keep original but rename via ::after. */
html body.woocommerce-cart .cross-sells ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
html body.woocommerce-cart .cross-sells ul.products::before,
html body.woocommerce-cart .cross-sells ul.products::after { display: none !important; }
html body.woocommerce-cart .cross-sells ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  padding: 20px !important;
  background: #FBFCFD !important;
  border: 1px solid #EEF1F4 !important;
  border-radius: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  transition: transform .2s ease, box-shadow .2s ease !important;
  list-style: none !important;
  float: none !important;
  text-align: left !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product::before,
html body.woocommerce-cart .cross-sells ul.products li.product::after { display: none !important; }
html body.woocommerce-cart .cross-sells ul.products li.product:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 12px 24px rgba(0,0,0,0.05) !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product .woocommerce-LoopProduct-link {
  text-decoration: none !important;
  color: inherit !important;
  display: block !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product img,
html body.woocommerce-cart .cross-sells ul.products li.product .et_shop_image img {
  border-radius: 10px !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1/1 !important;
  object-fit: cover !important;
  margin: 0 0 12px !important;
  display: block !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product .et_shop_image {
  display: block !important;
  width: 100% !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product .woocommerce-loop-product__title,
html body.woocommerce-cart .cross-sells ul.products li.product h2 {
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #0F1B26 !important;
  margin: 0 0 6px !important;
  padding: 0 !important;
  line-height: 1.3 !important;
  text-transform: none !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product .price {
  font-size: 17px !important;
  font-weight: 800 !important;
  color: #0F1B26 !important;
  margin: 0 0 12px !important;
  display: block !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product .price del,
html body.woocommerce-cart .cross-sells ul.products li.product .price ins { display: inline !important; text-decoration: none !important; }
html body.woocommerce-cart .cross-sells ul.products li.product .button,
html body.woocommerce-cart .cross-sells ul.products li.product a.add_to_cart_button,
html body.woocommerce-cart .cross-sells ul.products li.product a.added_to_cart {
  display: inline-block !important;
  background: #68CDEC !important;
  color: #0F1B26 !important;
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  padding: 8px 18px !important;
  border-radius: 100px !important;
  text-decoration: none !important;
  margin: auto 0 0 !important;
  align-self: flex-start !important;
  transition: transform .2s ease, background-color .2s ease !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  border: none !important;
}
html body.woocommerce-cart .cross-sells ul.products li.product .button:hover {
  background: #4FB8D6 !important;
  transform: translateY(-1px) !important;
}


/* === v118f — Notification messages (cart/checkout) === */
html body.woocommerce-cart .woocommerce-message,
html body.woocommerce-cart .woocommerce-info,
html body.woocommerce-cart .woocommerce-notices-wrapper .woocommerce-message,
html body.woocommerce-cart .woocommerce-notices-wrapper .woocommerce-info,
html body.woocommerce-checkout .woocommerce-message,
html body.woocommerce-checkout .woocommerce-info {
  background: rgba(104, 205, 236, 0.08) !important;
  border: 1px solid rgba(104, 205, 236, 0.3) !important;
  border-radius: 16px !important;
  padding: 16px 24px !important;
  color: #0F1B26 !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin: 0 0 24px !important;
}
html body.woocommerce-cart .woocommerce-message::before,
html body.woocommerce-cart .woocommerce-info::before,
html body.woocommerce-checkout .woocommerce-message::before,
html body.woocommerce-checkout .woocommerce-info::before { display: none !important; }
html body.woocommerce-cart .woocommerce-message *,
html body.woocommerce-cart .woocommerce-info * { color: inherit !important; }
html body.woocommerce-cart .woocommerce-message a.button.wc-forward,
html body.woocommerce-checkout .woocommerce-message a.button.wc-forward {
  background: #FFFFFF !important;
  color: #0F1B26 !important;
  border: 1px solid rgba(15, 27, 38, 0.15) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  padding: 10px 22px !important;
  border-radius: 100px !important;
  text-decoration: none !important;
  margin-left: auto !important;
  transition: transform .2s ease, border-color .2s ease !important;
}
html body.woocommerce-cart .woocommerce-message a.button.wc-forward:hover {
  border-color: #68CDEC !important;
  transform: translateY(-1px) !important;
}



/* ============================================================ */
/* === v119 — PRODUCT CATEGORY ARCHIVES (matriz comum) ======== */
/* === escritorio-virtual / coworking / salas-reuniao ========= */
/* ============================================================ */

/* --- 1. Header: glass + dark logo (como single-product) --- */
html body.tax-product_cat .wo-header.wo-transparent {
  background: rgba(255,255,255,0.85) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-bottom: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 1px 12px rgba(0,0,0,0.04) !important;
}
html body.tax-product_cat .wo-header.wo-transparent .wo-nav-list > li > a,
html body.tax-product_cat .wo-header.wo-transparent .wo-header-phone-num { color: #0F1B26 !important; }
html body.tax-product_cat .wo-header.wo-transparent .wo-logo-light { opacity: 0 !important; }
html body.tax-product_cat .wo-header.wo-transparent .wo-logo-dark  { opacity: 1 !important; }

/* --- 2. Hide Divi default chrome (sidebar + header + footer legacy) --- */
html body.tax-product_cat #main-header,
html body.tax-product_cat #et-secondary-menu,
html body.tax-product_cat #main-footer,
html body.tax-product_cat #et-footer-nav,
html body.tax-product_cat #footer-bottom,
html body.tax-product_cat #sidebar { display: none !important; }
html body.tax-product_cat #page-container { padding-top: 0 !important; }

/* Page font */
html body.tax-product_cat { font-family: "Nunito Sans", -apple-system, sans-serif !important; }

/* Hide Divi pseudo-elements that create ghost columns */
html body.tax-product_cat #main-content .container::before,
html body.tax-product_cat #main-content .container::after { display: none !important; }

/* Hide WC default products header (we have our own hero) */
html body.tax-product_cat .woocommerce-products-header,
html body.tax-product_cat .woocommerce-breadcrumb { display: none !important; }

/* --- 3. Layout area: full width, no sidebar --- */
html body.tax-product_cat #main-content {
  background: #FFFFFF !important;
  padding: 0 !important;
}
html body.tax-product_cat #main-content .container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}
html body.tax-product_cat #left-area {
  width: 100% !important;
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 60px 5vw 100px !important;
  float: none !important;
}
html body.tax-product_cat #content-area { width: 100% !important; float: none !important; }
html body.tax-product_cat .et_pb_section_0 {
  padding: 0 !important;
  background: transparent !important;
  min-height: auto !important;
}
html body.tax-product_cat .et_pb_row {
  width: 100% !important; max-width: none !important; padding: 0 !important;
}
html body.tax-product_cat .et_pb_column { width: 100% !important; padding: 0 !important; }

/* --- 4. Category hero (dark navy v82) --- */
.wo-cat-hero {
  background: #0F1B26;
  color: #FFFFFF;
  padding: 180px 5vw 100px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.wo-cat-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(104, 205, 236, 0.20) 0%, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(104, 205, 236, 0.12) 0%, transparent 60%);
  pointer-events: none;
}
.wo-cat-hero-inner {
  max-width: 880px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.wo-cat-hero-pre {
  font-family: "Nunito Sans", sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: #68CDEC;
  margin: 0 0 20px;
  text-transform: uppercase;
}
.wo-cat-hero-h1 {
  font-family: "Nunito Sans", sans-serif;
  font-size: clamp(40px, 5.6vw, 64px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: #FFFFFF;
  margin: 0 0 24px;
}
.wo-cat-hero-sub {
  font-family: "Nunito Sans", sans-serif;
  font-size: clamp(16px, 1.4vw, 18px);
  font-weight: 400;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  margin: 0 auto 16px;
  max-width: 680px;
}
.wo-cat-hero-count {
  font-family: "Nunito Sans", sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #68CDEC;
  margin: 24px 0 0;
}

/* --- 5. Products grid (3-col desktop) --- */
html body.tax-product_cat ul.products.columns-3,
html body.tax-product_cat ul.products.columns-4,
html body.tax-product_cat ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 32px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}
/* Hide WC clearfix pseudos that take grid cells */
html body.tax-product_cat ul.products::before,
html body.tax-product_cat ul.products::after,
html body.tax-product_cat ul.products li.product::before,
html body.tax-product_cat ul.products li.product::after { display: none !important; }

/* Product card */
html body.tax-product_cat ul.products li.product {
  background: #FFFFFF !important;
  border: 1px solid #E5E8EC !important;
  border-radius: 20px !important;
  padding: 24px !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  clear: none !important;
  display: flex !important;
  flex-direction: column !important;
  text-align: left !important;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04), 0 0 0 1px rgba(0, 0, 0, 0.02) !important;
  list-style: none !important;
}
html body.tax-product_cat ul.products li.product:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(104, 205, 236, 0.20) !important;
  border-color: rgba(104, 205, 236, 0.4) !important;
}

/* Product image / thumbnail */
html body.tax-product_cat ul.products li.product a {
  text-decoration: none !important;
  color: inherit !important;
  display: contents !important;
}
html body.tax-product_cat ul.products li.product img,
html body.tax-product_cat ul.products li.product .wp-post-image,
html body.tax-product_cat ul.products li.product .attachment-woocommerce_thumbnail {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  border-radius: 14px !important;
  margin: 0 0 20px !important;
  background: #F4F6F8 !important;
  display: block !important;
}

/* Product title */
html body.tax-product_cat ul.products li.product .woocommerce-loop-product__title,
html body.tax-product_cat ul.products li.product h2.woocommerce-loop-product__title,
html body.tax-product_cat ul.products li.product h3 {
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  color: #0F1B26 !important;
  margin: 0 0 12px !important;
  padding: 0 !important;
  letter-spacing: -0.01em !important;
}

/* Product price */
html body.tax-product_cat ul.products li.product .price {
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 26px !important;
  font-weight: 800 !important;
  color: #0F1B26 !important;
  margin: 0 0 20px !important;
  display: block !important;
}
html body.tax-product_cat ul.products li.product .price .woocommerce-Price-amount {
  font-size: inherit !important;
  font-weight: inherit !important;
  color: inherit !important;
}
html body.tax-product_cat ul.products li.product .price .woocommerce-Price-currencySymbol {
  font-size: 0.7em !important;
  font-weight: 600 !important;
  margin-left: 4px !important;
  color: #5A6470 !important;
  vertical-align: super !important;
}
html body.tax-product_cat ul.products li.product .price ins {
  text-decoration: none !important;
  display: inline !important;
}
html body.tax-product_cat ul.products li.product .price del {
  font-size: 0.6em !important;
  font-weight: 400 !important;
  color: #5A6470 !important;
  display: inline-block !important;
  margin-right: 8px !important;
  vertical-align: middle !important;
}

/* Star rating (hide — not used) */
html body.tax-product_cat ul.products li.product .star-rating { display: none !important; }

/* Add-to-cart button (cyan pill) */
html body.tax-product_cat ul.products li.product .button,
html body.tax-product_cat ul.products li.product a.add_to_cart_button,
html body.tax-product_cat ul.products li.product a.added_to_cart,
html body.tax-product_cat ul.products li.product .added_to_cart {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  background: #68CDEC !important;
  color: #0F1B26 !important;
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 12px 24px !important;
  border-radius: 100px !important;
  text-decoration: none !important;
  margin: auto 0 0 !important;
  align-self: flex-start !important;
  border: none !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  line-height: 1 !important;
  transition: background-color .25s ease, transform .25s ease, color .25s ease !important;
  cursor: pointer !important;
  min-height: 44px !important;
}
html body.tax-product_cat ul.products li.product .button:hover,
html body.tax-product_cat ul.products li.product a.add_to_cart_button:hover {
  background: #0F1B26 !important;
  color: #FFFFFF !important;
  transform: translateY(-2px) !important;
}
html body.tax-product_cat ul.products li.product .added_to_cart {
  background: #FFFFFF !important;
  color: #0F1B26 !important;
  border: 1.5px solid #0F1B26 !important;
  margin-top: 8px !important;
}
html body.tax-product_cat ul.products li.product .added_to_cart:hover {
  background: #0F1B26 !important;
  color: #FFFFFF !important;
}

/* Hide stock badges if present, keep clean look */
html body.tax-product_cat ul.products li.product .stock { display: none !important; }

/* "Sale" badge (top-right of card) */
html body.tax-product_cat ul.products li.product .onsale {
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  background: #68CDEC !important;
  color: #0F1B26 !important;
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 4px 10px !important;
  border-radius: 100px !important;
  margin: 0 !important;
  min-height: auto !important;
  line-height: 1.4 !important;
  min-width: 0 !important;
  width: auto !important;
  height: auto !important;
  z-index: 2 !important;
}
html body.tax-product_cat ul.products li.product { position: relative !important; }

/* --- 6. Pagination (cyan pills) --- */
html body.tax-product_cat .woocommerce-pagination {
  margin: 64px 0 0 !important;
  text-align: center !important;
}
html body.tax-product_cat .woocommerce-pagination ul.page-numbers {
  display: inline-flex !important;
  gap: 8px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}
html body.tax-product_cat .woocommerce-pagination ul.page-numbers li {
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
html body.tax-product_cat .woocommerce-pagination ul.page-numbers li .page-numbers {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 44px !important;
  height: 44px !important;
  padding: 0 14px !important;
  background: #FFFFFF !important;
  border: 1.5px solid #E5E8EC !important;
  border-radius: 100px !important;
  color: #0F1B26 !important;
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease !important;
}
html body.tax-product_cat .woocommerce-pagination ul.page-numbers li .page-numbers:hover {
  border-color: #68CDEC !important;
  background: rgba(104, 205, 236, 0.08) !important;
}
html body.tax-product_cat .woocommerce-pagination ul.page-numbers li .page-numbers.current {
  background: #68CDEC !important;
  border-color: #68CDEC !important;
  color: #0F1B26 !important;
}

/* --- 7. Sort dropdown (WC ordering form) — hide for now --- */
html body.tax-product_cat .woocommerce-ordering,
html body.tax-product_cat .woocommerce-result-count { display: none !important; }

/* --- 8. Responsive --- */
@media (max-width: 1024px) {
  html body.tax-product_cat ul.products,
  html body.tax-product_cat ul.products.columns-3,
  html body.tax-product_cat ul.products.columns-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 24px !important;
  }
  .wo-cat-hero { padding: 140px 5vw 80px; }
  html body.tax-product_cat #left-area { padding: 40px 5vw 80px !important; }
}
@media (max-width: 640px) {
  html body.tax-product_cat ul.products,
  html body.tax-product_cat ul.products.columns-3,
  html body.tax-product_cat ul.products.columns-4 {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  html body.tax-product_cat ul.products li.product { padding: 20px !important; }
  html body.tax-product_cat ul.products li.product img,
  html body.tax-product_cat ul.products li.product .wp-post-image { height: 200px !important; }
  .wo-cat-hero { padding: 120px 5vw 60px; }
  .wo-cat-hero-h1 { font-size: 36px !important; }
}

/* --- 9. Footer override for category pages (same as single-product) --- */
html body.tax-product_cat .wo-footer { width: 100% !important; padding: 0 !important; }
html body.tax-product_cat .wo-footer-inner { max-width: 1280px !important; margin: 0 auto !important; }

/* === END v119 ============================================== */


/* ============================================================ */
/* === v119b — FIXES: scope link wrap + price currency ======== */
/* ============================================================ */

/* Reset overly aggressive rule from v119 (any anchor became display:contents) */
html body.tax-product_cat ul.products li.product a {
  display: inline-flex !important;
  color: inherit !important;
}

/* The product loop link (wraps img+title+price) — make it contents so children flow as flex items */
html body.tax-product_cat ul.products li.product a.woocommerce-LoopProduct-link,
html body.tax-product_cat ul.products li.product a.woocommerce-loop-product__link {
  display: contents !important;
}

/* Currency symbol — keep inline, just slightly smaller and muted (no superscript) */
html body.tax-product_cat ul.products li.product .price .woocommerce-Price-currencySymbol {
  font-size: 0.85em !important;
  font-weight: 700 !important;
  color: #0F1B26 !important;
  margin-left: 2px !important;
  vertical-align: baseline !important;
}

/* Force "Adicionar" button visible at bottom of card */
html body.tax-product_cat ul.products li.product .button,
html body.tax-product_cat ul.products li.product a.button,
html body.tax-product_cat ul.products li.product a.add_to_cart_button,
html body.tax-product_cat ul.products li.product a.added_to_cart {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  margin-top: 16px !important;
  width: auto !important;
  max-width: 100% !important;
}

/* === END v119b ============================================== */


/* ============================================================ */
/* === v119c — Divi shop loop: card-as-link + CTA affordance == */
/* ============================================================ */

/* The whole card is a link via Divi template — make .product a flex column
   so we can pin "Ver plano →" affordance at bottom */
html body.tax-product_cat ul.products li.product {
  position: relative !important;
  padding: 24px !important;
}

/* Divi wraps image inside a <span class="et_shop_image"> — normalize it */
html body.tax-product_cat ul.products li.product .et_shop_image {
  display: block !important;
  width: 100% !important;
  height: 200px !important;
  margin: 0 0 20px !important;
  overflow: hidden !important;
  border-radius: 14px !important;
  position: relative !important;
}
html body.tax-product_cat ul.products li.product .et_shop_image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
/* Hide Divi's hover overlay icons on the image (shopping-cart svg) */
html body.tax-product_cat ul.products li.product .et_shop_image .et_overlay,
html body.tax-product_cat ul.products li.product .et_shop_image::after { display: none !important; }

/* Make the inner link behave as a flex column for nice layout */
html body.tax-product_cat ul.products li.product a.woocommerce-LoopProduct-link {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  text-decoration: none !important;
  color: inherit !important;
  width: 100% !important;
  padding: 0 !important;
  padding-bottom: 56px !important; /* leave room for the ::after CTA pinned at bottom */
}

/* CTA affordance — "Ver plano →" pinned at bottom-left of card */
html body.tax-product_cat ul.products li.product a.woocommerce-LoopProduct-link::after {
  content: "Ver plano \2192"; /* → arrow */
  position: absolute !important;
  bottom: 24px !important;
  left: 24px !important;
  right: 24px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  background: #68CDEC !important;
  color: #0F1B26 !important;
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  padding: 12px 20px !important;
  border-radius: 100px !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  line-height: 1 !important;
  transition: background-color .25s ease, color .25s ease, transform .25s ease !important;
  min-height: 44px !important;
  box-sizing: border-box !important;
}
html body.tax-product_cat ul.products li.product:hover a.woocommerce-LoopProduct-link::after {
  background: #0F1B26 !important;
  color: #FFFFFF !important;
}

/* Adjust price margin since now we have the CTA below */
html body.tax-product_cat ul.products li.product .price {
  margin: 0 0 8px !important;
}

/* === END v119c ============================================== */


/* ============================================================ */
/* === v119d — UX FIXES: title hierarchy + footer breathing === */
/* ============================================================ */

/* --- 1. Title hierarchy: smaller, lighter, less competing with price --- */
html body.tax-product_cat ul.products li.product .woocommerce-loop-product__title,
html body.tax-product_cat ul.products li.product h2.woocommerce-loop-product__title,
html body.tax-product_cat ul.products li.product h3 {
  font-size: 17px !important;          /* down from 22px */
  font-weight: 700 !important;          /* down from 800 */
  line-height: 1.35 !important;         /* tighter */
  color: #1A1A1A !important;            /* text-dark instead of navy */
  margin: 0 0 10px !important;          /* tighter spacing */
  letter-spacing: 0 !important;
}

/* --- 2. Price: now visually dominant within the card --- */
html body.tax-product_cat ul.products li.product .price {
  font-size: 26px !important;
  font-weight: 800 !important;
  color: #0F1B26 !important;
  margin: 0 0 4px !important;
  line-height: 1.1 !important;
}
/* Subtle "desde" or "/mês" prefix if needed in future — placeholder for now */

/* --- 3. Card padding tighter — less wasted space --- */
html body.tax-product_cat ul.products li.product {
  padding: 20px !important;
}
/* Re-align ::after CTA to new padding */
html body.tax-product_cat ul.products li.product a.woocommerce-LoopProduct-link {
  padding-bottom: 52px !important;
}
html body.tax-product_cat ul.products li.product a.woocommerce-LoopProduct-link::after {
  bottom: 20px !important;
  left: 20px !important;
  right: 20px !important;
  padding: 11px 18px !important;
  font-size: 13px !important;
  min-height: 40px !important;
}

/* Image slightly shorter — products are abstract placeholders, no need for 200px */
html body.tax-product_cat ul.products li.product .et_shop_image {
  height: 170px !important;
  margin: 0 0 16px !important;
}

/* --- 4. Footer breathing room — add real space below grid --- */
html body.tax-product_cat #left-area {
  padding: 60px 5vw 160px !important;  /* up from 100px bottom */
}

/* Extra margin on the footer to clearly separate from content */
html body.tax-product_cat .wo-footer.wo-footer--injected {
  margin-top: 40px !important;
}

/* On empty 2nd-row scenarios (4-product categories) make the gap less awkward —
   slight bg variation below the cards before the footer */
html body.tax-product_cat #main-content {
  background:
    linear-gradient(to bottom, #FFFFFF 0%, #FFFFFF 80%, #F4F6F8 100%) !important;
}

/* === END v119d ============================================== */


/* ============================================================ */
/* === v119e — Footer top padding restore + center align ====== */
/* ============================================================ */

/* --- 1. Restore footer top padding (DS v82: 80px top, 32px lateral bottom) --- */
/* v119 had a buggy `padding: 0 !important` that aniquilated the spec.
   The footer content was glued to the top edge of the navy bg ("encavalitado"). */
html body.tax-product_cat .wo-footer.wo-footer--injected {
  padding: 80px 0 0 !important;
  margin-top: 40px !important;
  width: 100% !important;
}
html body.tax-product_cat .wo-footer-inner {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 5vw !important;
}

/* --- 2. Center align text content in product cards --- */
/* Image is already full width. Title + price + CTA align centered.
   Pricing-card pattern: balanced, symmetrical, focal on price. */
html body.tax-product_cat ul.products li.product {
  text-align: center !important;
  align-items: center !important;
}
html body.tax-product_cat ul.products li.product a.woocommerce-LoopProduct-link {
  text-align: center !important;
  align-items: stretch !important;
}
html body.tax-product_cat ul.products li.product .woocommerce-loop-product__title,
html body.tax-product_cat ul.products li.product h2.woocommerce-loop-product__title,
html body.tax-product_cat ul.products li.product h3 {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
html body.tax-product_cat ul.products li.product .price {
  text-align: center !important;
  width: 100% !important;
  display: block !important;
}

/* === END v119e ============================================== */


/* v122c — 3 fixes mobile (trust title nowrap, partners logos visibility, FAQ width) */
@media (max-width: 768px) {
  /* (1) Trust bar — title row column = 100% width, override base 140px constraint */
  body .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_column {
    max-width: 100% !important;
    width: 100% !important;
    flex: 1 1 100% !important;
    min-width: 0 !important;
  }
  body .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_text {
    margin: 0 !important;
  }
  body .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_text_inner p,
  body .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_text_inner h1,
  body .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_text_inner h2,
  body .wo-trust-bar .et_pb_row.et_pb_row_1 .et_pb_text_inner h3 {
    font-size: 20px !important;
    line-height: 1.25 !important;
    margin: 0 !important;
    text-align: left !important;
    white-space: normal !important;
  }

  /* (2) Partners logos — full colour + opacity 1, ligeiramente maiores */
  .wo-mq-item img,
  .wo-trust-bar img {
    filter: none !important;
    opacity: 1 !important;
    max-height: 80px !important;
    max-width: 150px !important;
  }
  .wo-mq-item {
    min-width: 160px !important;
    padding: 0 16px !important;
  }

  /* (3) FAQs — mais largura útil em smartphones */
  .wo-faq {
    padding-left: 4vw !important;
    padding-right: 4vw !important;
  }
  .wo-faq-inner {
    max-width: 100% !important;
    width: 100% !important;
  }
  .wo-faq-item summary {
    padding: 16px 18px !important;
    font-size: 15px !important;
    gap: 12px;
  }
  .wo-faq-answer {
    padding: 0 18px 18px !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
  }
}


/* v128b — Fallback icons (lock, wifi, shield, trend, chair, thermometer, broom) via external SVG files */
.wo-icon-lock        { background-image: url("/wp-content/uploads/icons/lock.svg") !important; }
.wo-icon-wifi        { background-image: url("/wp-content/uploads/icons/wifi.svg") !important; }
.wo-icon-shield      { background-image: url("/wp-content/uploads/icons/shield.svg") !important; }
.wo-icon-trend       { background-image: url("/wp-content/uploads/icons/trend.svg") !important; }
.wo-icon-chair       { background-image: url("/wp-content/uploads/icons/chair.svg") !important; }
.wo-icon-thermometer { background-image: url("/wp-content/uploads/icons/thermometer.svg") !important; }
.wo-icon-broom       { background-image: url("/wp-content/uploads/icons/broom.svg") !important; }


/* v129 — WC notices (error/info/message) com texto legível */
.woocommerce-info,
.woocommerce-message,
.woocommerce-error,
.woocommerce-info *:not(a),
.woocommerce-message *:not(a),
.woocommerce-error *:not(a) {
  color: #1A1A1A !important;
}
.woocommerce-error {
  background-color: rgba(220, 53, 69, 0.08) !important;
  border-left: 3px solid #DC3545;
}
.woocommerce-info {
  background-color: rgba(104, 205, 236, 0.08) !important;
  border-left: 3px solid #68CDEC;
}
.woocommerce-message {
  background-color: rgba(16, 185, 129, 0.08) !important;
  border-left: 3px solid #10B981;
}
.woocommerce-info a,
.woocommerce-message a,
.woocommerce-error a {
  color: #2D9CB8 !important;
  text-decoration: underline;
  font-weight: 600;
}
.woocommerce-info a:hover,
.woocommerce-message a:hover,
.woocommerce-error a:hover {
  color: #1A78A8 !important;
}

/* Validation error on input labels (form-row.woocommerce-invalid label) */
.woocommerce form .form-row.woocommerce-invalid label,
.woocommerce-invalid input:invalid + label {
  color: #DC3545 !important;
}

/* =========================================================
   v132 — Single Product CTA above-the-fold + sticky mobile
   ========================================================= */

/* --- Hero CTA Block (acima do fold no summary) --- */
.wo-product-hero-cta {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 24px 28px;
    margin: 16px 0 28px;
    background: linear-gradient(135deg, #F4F8FB 0%, #E9F3F8 100%);
    border: 1px solid rgba(45, 156, 184, 0.18);
    border-radius: 20px;
    box-shadow:
        0 2px 8px rgba(15, 52, 70, 0.04),
        0 12px 32px -8px rgba(45, 156, 184, 0.12);
}

.wo-product-price-row {
    display: flex;
    align-items: baseline;
    gap: 4px;
    line-height: 1;
    font-family: var(--wo-font-display, 'Inter', sans-serif);
    color: #1A1A1A;
}
.wo-product-price-currency {
    font-size: 28px;
    font-weight: 600;
    color: #4A4A4A;
}
.wo-product-price-amount {
    font-size: 56px;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #1A1A1A;
}
.wo-product-price-period {
    font-size: 18px;
    font-weight: 600;
    color: #4A4A4A;
    margin-left: 4px;
}

/* Stock pill */
.wo-product-stock {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    align-self: flex-start;
    padding: 4px 12px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.wo-product-stock.wo-in-stock {
    background: rgba(16, 185, 129, 0.12);
    color: #047857;
}
.wo-product-stock.wo-in-stock::before {
    content: '';
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #10B981;
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.2);
}
.wo-product-stock.wo-out {
    background: rgba(239, 68, 68, 0.12);
    color: #B91C1C;
}

/* Buy-now button */
.wo-product-buy-now {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 18px 28px;
    background: linear-gradient(135deg, #2D9CB8 0%, #1F7A91 100%);
    color: #FFFFFF !important;
    font-family: var(--wo-font-display, 'Inter', sans-serif);
    font-size: 17px;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-decoration: none !important;
    border: 0;
    border-radius: 14px;
    cursor: pointer;
    box-shadow:
        0 4px 12px rgba(45, 156, 184, 0.32),
        0 2px 4px rgba(45, 156, 184, 0.18);
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.wo-product-buy-now:hover,
.wo-product-buy-now:focus-visible {
    transform: translateY(-2px);
    box-shadow:
        0 8px 20px rgba(45, 156, 184, 0.4),
        0 4px 8px rgba(45, 156, 184, 0.24);
    background: linear-gradient(135deg, #34AEC9 0%, #258298 100%);
}
.wo-product-buy-now:active {
    transform: translateY(0);
}
.wo-product-buy-arrow {
    font-size: 20px;
    font-weight: 400;
    transition: transform .2s ease;
}
.wo-product-buy-now:hover .wo-product-buy-arrow {
    transform: translateX(4px);
}

/* Trust line */
.wo-product-trust {
    margin: 0;
    font-size: 13px;
    color: #4A4A4A;
    text-align: center;
    line-height: 1.4;
}

/* --- Sticky CTA bar (mobile only, < 768px) --- */
.wo-product-sticky-cta {
    position: fixed;
    bottom: -100px;
    left: 0;
    right: 0;
    z-index: 9999;
    display: none; /* hidden on desktop */
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.12);
    transition: bottom .35s cubic-bezier(.2, .9, .3, 1);
    /* Safe-area inset for notch phones */
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0));
}

.wo-product-sticky-cta.is-visible {
    bottom: 0;
}

.wo-product-sticky-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
    flex: 1;
}
.wo-product-sticky-title {
    font-size: 13px;
    font-weight: 600;
    color: #4A4A4A;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}
.wo-product-sticky-price {
    display: inline-flex;
    align-items: baseline;
    gap: 2px;
    font-size: 18px;
    font-weight: 800;
    color: #1A1A1A;
    line-height: 1;
}
.wo-product-sticky-price small {
    font-size: 12px;
    font-weight: 600;
    color: #4A4A4A;
}

.wo-product-sticky-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 12px 22px;
    background: linear-gradient(135deg, #2D9CB8 0%, #1F7A91 100%);
    color: #FFFFFF !important;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none !important;
    border-radius: 12px;
    box-shadow: 0 4px 10px rgba(45, 156, 184, 0.32);
    transition: transform .15s ease, box-shadow .15s ease;
}
.wo-product-sticky-btn:active {
    transform: scale(0.96);
}

/* Mobile activation */
@media (max-width: 768px) {
    .wo-product-sticky-cta {
        display: flex;
    }
    .wo-product-hero-cta {
        padding: 20px;
        margin: 12px 0 24px;
    }
    .wo-product-price-amount {
        font-size: 48px;
    }
    .wo-product-buy-now {
        padding: 16px 24px;
        font-size: 16px;
    }
    /* extra bottom padding no body para o sticky bar não cobrir conteúdo */
    body.single-product.has-sticky-cta {
        padding-bottom: 80px;
    }
}

/* =========================================================
   v134 — Billing toggle pill (Mensal/Anual) inside single product hero CTA
   ========================================================= */

.wo-product-billing-pill {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    align-self: flex-start;
    padding: 4px;
    background: rgba(15, 52, 70, 0.06);
    border-radius: 100px;
    margin-bottom: 4px;
    position: relative;
    isolation: isolate;
}

.wo-pbp-btn {
    appearance: none;
    border: 0;
    background: transparent;
    padding: 8px 18px;
    font-family: inherit;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: #4A4A4A;
    border-radius: 100px;
    cursor: pointer;
    transition: color .15s ease, background .15s ease, box-shadow .15s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    line-height: 1;
}

.wo-pbp-btn[aria-pressed="true"] {
    background: #FFFFFF;
    color: #1A1A1A;
    box-shadow:
        0 1px 2px rgba(15, 52, 70, 0.08),
        0 2px 8px rgba(15, 52, 70, 0.08);
}

.wo-pbp-btn:hover:not([aria-pressed="true"]) {
    color: #1A1A1A;
    background: rgba(255, 255, 255, 0.5);
}

.wo-pbp-btn:focus-visible {
    outline: 2px solid #2D9CB8;
    outline-offset: 2px;
}

.wo-pbp-badge {
    background: #10B981;
    color: #FFFFFF;
    font-size: 10px;
    font-weight: 800;
    padding: 3px 7px;
    border-radius: 100px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1;
}

/* --- Savings line (visible only when Anual mode active) --- */
.wo-product-savings {
    display: none;
    margin: 0;
    padding: 8px 14px;
    background: rgba(16, 185, 129, 0.1);
    color: #047857;
    font-size: 13px;
    font-weight: 700;
    text-align: center;
    border-radius: 10px;
    border: 1px dashed rgba(16, 185, 129, 0.35);
    animation: wo-savings-fade-in .25s ease-out;
}

.wo-product-savings.is-visible {
    display: block;
}

@keyframes wo-savings-fade-in {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* --- Smooth transition on price change --- */
.wo-product-price-amount,
.wo-product-price-period,
.wo-product-sticky-amount,
.wo-product-sticky-period {
    transition: color .15s ease;
}

/* --- Mobile tweaks --- */
@media (max-width: 768px) {
    .wo-product-billing-pill {
        align-self: stretch;
        justify-content: center;
        gap: 4px;
    }
    .wo-pbp-btn {
        flex: 1;
        justify-content: center;
        padding: 10px 14px;
        font-size: 13px;
    }
    .wo-pbp-badge {
        font-size: 9px;
        padding: 2px 6px;
    }
}

