/*
Theme Name: Minas Safe
Theme URI: https://minassafe.com.br
Author: Minas Safe Dev Team
Author URI: https://minassafe.com.br
Description: Tema WordPress institucional e profissional para empresas de Consultoria em Segurança do Trabalho (SST). Desenvolvido do zero com PHP 8+, HTML5, CSS3, JavaScript ES6, GSAP e SwiperJS. Pronto para WooCommerce e WPML.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: minas-safe
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, accessibility-ready, block-styles, wide-blocks, e-commerce, one-column, two-columns, right-sidebar, footer-widgets
*/

/* =========================================================
   0. DESIGN TOKENS
   ========================================================= */
:root{
  --ms-dark: #0c1b1e;
  --ms-dark-2: #10262a;
  --ms-dark-header: #0b1e21;
  --ms-green: #22c55e;
  --ms-green-dark: #16a34a;
  --ms-green-light: #4ade80;
  --ms-green-bg: rgba(34,197,94,.10);
  --ms-white: #ffffff;
  --ms-gray-50: #f7f9f9;
  --ms-gray-100: #eef2f2;
  --ms-gray-200: #e2e8e8;
  --ms-gray-400: #94a3a3;
  --ms-gray-600: #5b6b6b;
  --ms-gray-800: #263334;
  --ms-text-dark: #101c1d;
  --ms-radius-sm: 8px;
  --ms-radius-md: 14px;
  --ms-radius-lg: 20px;
  --ms-shadow-sm: 0 2px 8px rgba(16,28,29,.06);
  --ms-shadow-md: 0 8px 24px rgba(16,28,29,.10);
  --ms-shadow-lg: 0 20px 48px rgba(16,28,29,.16);
  --ms-container: 1240px;
  --ms-header-h: 84px;
  --ms-font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ms-font-heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ms-transition: 220ms cubic-bezier(.4,0,.2,1);
}

/* =========================================================
   1. RESET / BASE
   ========================================================= */
*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--ms-font-body);
  color: var(--ms-text-dark);
  background: var(--ms-white);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color: inherit; text-decoration: none; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family: inherit; cursor:pointer; }
h1,h2,h3,h4,h5,h6{ font-family: var(--ms-font-heading); margin:0; line-height:1.2; color: var(--ms-text-dark); }
p{ margin:0; }
input, textarea, select{ font-family: inherit; font-size: 16px; }
:focus-visible{ outline: 3px solid var(--ms-green); outline-offset: 2px; }
.skip-link{
  position:absolute; left:-9999px; top:0; background:var(--ms-green); color:#fff;
  padding:12px 20px; z-index:10000; border-radius:0 0 8px 0;
}
.skip-link:focus{ left:0; }

.ms-container{
  width:100%;
  max-width: var(--ms-container);
  margin:0 auto;
  padding: 0 24px;
}
.ms-section{ padding: 96px 0; }
@media (max-width: 782px){ .ms-section{ padding: 56px 0; } }

.ms-eyebrow{
  display:inline-block;
  color: var(--ms-green);
  font-weight:700;
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.ms-title-lg{
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 800;
  letter-spacing: -0.02em;
}
.ms-text-muted{ color: var(--ms-gray-600); }

/* =========================================================
   2. BUTTONS
   ========================================================= */
.ms-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 15px 26px;
  border-radius: var(--ms-radius-sm);
  font-weight: 700;
  font-size: 15px;
  border: 2px solid transparent;
  transition: transform var(--ms-transition), box-shadow var(--ms-transition), background var(--ms-transition), color var(--ms-transition), border-color var(--ms-transition);
  white-space: nowrap;
}
.ms-btn svg, .ms-btn i{ flex-shrink:0; }
.ms-btn-primary{
  background: var(--ms-green);
  color: #06210f;
  box-shadow: 0 6px 20px rgba(34,197,94,.35);
}
.ms-btn-primary:hover{ background: var(--ms-green-dark); transform: translateY(-2px); box-shadow: 0 10px 26px rgba(34,197,94,.45); }
.ms-btn-outline{
  background: transparent;
  border-color: rgba(255,255,255,.35);
  color: #fff;
}
.ms-btn-outline:hover{ border-color: var(--ms-green); color: var(--ms-green); transform: translateY(-2px); }
.ms-btn-outline-dark{
  background: transparent;
  border-color: var(--ms-gray-200);
  color: var(--ms-text-dark);
}
.ms-btn-outline-dark:hover{ border-color: var(--ms-green); color: var(--ms-green-dark); }
.ms-btn-block{ width:100%; }
.ms-link-arrow{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:700; color: var(--ms-green-dark);
  transition: gap var(--ms-transition);
}
.ms-link-arrow:hover{ gap: 12px; color: var(--ms-green); }

/* =========================================================
   3. HEADER
   ========================================================= */
.ms-header{
  position: fixed;
  top:0; left:0; right:0;
  z-index: 999;
  height: var(--ms-header-h);
  background: var(--ms-dark-header);
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: background var(--ms-transition), box-shadow var(--ms-transition), height var(--ms-transition);
}
.ms-header.is-scrolled{
  height: 68px;
  background: rgba(11,30,33,.97);
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.ms-header-inner{
  max-width: var(--ms-container);
  margin: 0 auto;
  height:100%;
  padding: 0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 20px;
}
.ms-logo{ display:flex; align-items:center; gap:10px; color:#fff; flex-shrink:0; }
.ms-logo img{ height: 40px; width:auto; }
.ms-logo-mark{ display:flex; align-items:center; justify-content:center; width:40px; height:40px; color: var(--ms-green); }
.ms-logo-text{ display:flex; flex-direction:column; line-height:1.1; }
.ms-logo-text b{ font-size:19px; font-weight:800; letter-spacing:-.01em; }
.ms-logo-text b span{ color: var(--ms-green); }
.ms-logo-text small{ font-size: 10px; letter-spacing:.14em; color: var(--ms-gray-400); text-transform:uppercase; font-weight:600; }

.ms-nav{ flex:1; display:flex; justify-content:center; }
.ms-nav ul{ display:flex; align-items:center; gap: 34px; }
.ms-nav a{
  position:relative;
  color: rgba(255,255,255,.82);
  font-weight:600;
  font-size: 14.5px;
  padding: 8px 2px;
  transition: color var(--ms-transition);
}
.ms-nav a::after{
  content:'';
  position:absolute; left:0; right:0; bottom:-2px;
  height:2px; background: var(--ms-green);
  transform: scaleX(0); transform-origin:left;
  transition: transform var(--ms-transition);
}
.ms-nav a:hover{ color:#fff; }
.ms-nav a:hover::after{ transform: scaleX(1); }
.ms-nav li.current-menu-item > a,
.ms-nav li.current_page_item > a{ color: var(--ms-green); }
.ms-nav li.current-menu-item > a::after,
.ms-nav li.current_page_item > a::after{ transform: scaleX(1); }

.ms-header-cta{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.ms-whatsapp-btn{
  display:inline-flex; align-items:center; gap:10px;
  border: 1.5px solid var(--ms-green);
  color:#fff;
  padding: 10px 18px;
  border-radius: var(--ms-radius-sm);
  font-weight:700; font-size:14.5px;
  transition: background var(--ms-transition), transform var(--ms-transition);
}
.ms-whatsapp-btn:hover{ background: var(--ms-green-bg); transform: translateY(-2px); }
.ms-whatsapp-btn svg{ color: var(--ms-green); }

.ms-burger{
  display:none;
  width:44px; height:44px;
  border:none; background:transparent;
  align-items:center; justify-content:center;
  color:#fff;
}
.ms-burger span, .ms-burger span::before, .ms-burger span::after{
  content:''; display:block; width:24px; height:2px; background:#fff; position:relative; transition: all var(--ms-transition);
}
.ms-burger span::before{ position:absolute; top:-8px; }
.ms-burger span::after{ position:absolute; top:8px; }
.ms-header.nav-open .ms-burger span{ background: transparent; }
.ms-header.nav-open .ms-burger span::before{ top:0; transform: rotate(45deg); background:#fff; }
.ms-header.nav-open .ms-burger span::after{ top:0; transform: rotate(-45deg); background:#fff; }

/* =========================================================
   4. HERO
   ========================================================= */
.ms-hero{
  position:relative;
  background: linear-gradient(180deg, var(--ms-dark) 0%, var(--ms-dark-2) 100%);
  padding-top: calc(var(--ms-header-h) + 70px);
  padding-bottom: 90px;
  overflow:hidden;
}
.ms-hero::before{
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(60% 60% at 85% 30%, rgba(34,197,94,.14) 0%, transparent 60%),
    radial-gradient(40% 40% at 10% 90%, rgba(34,197,94,.08) 0%, transparent 60%);
  pointer-events:none;
}
.ms-hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  align-items:center;
  gap: 40px;
}
.ms-hero-content .ms-eyebrow{ color: var(--ms-green-light); }
.ms-hero-title{
  color:#fff;
  font-size: clamp(32px, 4.4vw, 52px);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height:1.15;
  margin-bottom: 22px;
}
.ms-hero-title .accent{ color: var(--ms-green); }
.ms-hero-subtitle{
  color: rgba(255,255,255,.72);
  font-size: 17px;
  max-width: 560px;
  margin-bottom: 34px;
}
.ms-hero-benefits{
  display:flex;
  flex-wrap:wrap;
  gap: 28px;
  margin-bottom: 38px;
}
.ms-hero-benefit{ display:flex; align-items:center; gap:12px; color:#fff; }
.ms-hero-benefit .ico{
  width:38px; height:38px; flex-shrink:0;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background: var(--ms-green-bg);
  color: var(--ms-green);
}
.ms-hero-benefit span{ font-size:14px; font-weight:600; line-height:1.3; }
.ms-hero-actions{ display:flex; flex-wrap:wrap; gap:16px; }

.ms-hero-media{ position:relative; }
.ms-hero-media-frame{
  position:relative;
  border-radius: var(--ms-radius-lg);
  overflow:hidden;
  aspect-ratio: 4/4.6;
  box-shadow: var(--ms-shadow-lg);
}
.ms-hero-media-frame img{ width:100%; height:100%; object-fit:cover; }
.ms-hero-media-frame::after{
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(12,27,30,0) 40%, rgba(12,27,30,.55) 100%);
}
.ms-hero-dot{
  position:absolute;
  width:120px; height:120px;
  border-radius:50%;
  background: rgba(34,197,94,.18);
  filter: blur(4px);
  z-index:0;
}

@media (max-width: 992px){
  .ms-hero-grid{ grid-template-columns:1fr; }
  .ms-hero-media{ order:-1; max-width:420px; margin:0 auto 30px; }
}

/* =========================================================
   5. ABOUT + STATS
   ========================================================= */
.ms-about{ background: var(--ms-gray-50); }
.ms-about-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 56px;
}
.ms-about-text p{ margin-top:18px; color: var(--ms-gray-600); }
.ms-about-text p + p{ margin-top:12px; }
.ms-about-text .ms-title-lg{ max-width: 620px; }
.ms-about-text .ms-btn{ margin-top: 26px; }

.ms-stats-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.ms-stat-card{
  background:#fff;
  border-radius: var(--ms-radius-md);
  padding: 30px 22px;
  text-align:left;
  box-shadow: var(--ms-shadow-sm);
  border: 1px solid var(--ms-gray-100);
  transition: transform var(--ms-transition), box-shadow var(--ms-transition);
}
.ms-stat-card:hover{ transform: translateY(-6px); box-shadow: var(--ms-shadow-md); }
.ms-stat-card .ico{
  width:44px; height:44px;
  border-radius:10px;
  background: var(--ms-green-bg);
  color: var(--ms-green-dark);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:16px;
}
.ms-stat-card .num{ font-size: 30px; font-weight:800; letter-spacing:-.02em; }
.ms-stat-card .label{ font-size:14px; color: var(--ms-gray-600); margin-top:4px; }

@media (max-width: 992px){ .ms-stats-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .ms-stats-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   6. SERVICES
   ========================================================= */
.ms-services{ background:#fff; }
.ms-section-head{ text-align:center; max-width: 640px; margin: 0 auto 52px; }
.ms-section-head .ms-eyebrow, .ms-section-head .ms-title-lg{ display:block; }
.ms-section-head p{ margin-top:14px; color: var(--ms-gray-600); }

.ms-services-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.ms-service-card{
  background: var(--ms-gray-50);
  border: 1px solid var(--ms-gray-100);
  border-radius: var(--ms-radius-md);
  padding: 32px 26px;
  transition: transform var(--ms-transition), box-shadow var(--ms-transition), background var(--ms-transition), border-color var(--ms-transition);
}
.ms-service-card:hover{
  transform: translateY(-8px);
  box-shadow: var(--ms-shadow-md);
  background:#fff;
  border-color: var(--ms-green);
}
.ms-service-card .ico{
  width:52px; height:52px;
  border-radius: 12px;
  background: var(--ms-dark);
  color: var(--ms-green);
  display:flex; align-items:center; justify-content:center;
  font-size: 22px;
  margin-bottom: 20px;
  transition: background var(--ms-transition);
}
.ms-service-card:hover .ico{ background: var(--ms-green); color: #06210f; }
.ms-service-card h3{ font-size:18px; font-weight:700; margin-bottom:10px; }
.ms-service-card p{ font-size:14.5px; color: var(--ms-gray-600); margin-bottom:18px; }

@media (max-width: 1100px){ .ms-services-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .ms-services-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   7. TRAININGS
   ========================================================= */
.ms-trainings{ background: var(--ms-gray-50); }
.ms-trainings-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}
.ms-training-card{
  background:#fff;
  border-radius: var(--ms-radius-md);
  overflow:hidden;
  box-shadow: var(--ms-shadow-sm);
  transition: transform var(--ms-transition), box-shadow var(--ms-transition);
}
.ms-training-card:hover{ transform: translateY(-6px); box-shadow: var(--ms-shadow-md); }
.ms-training-thumb{ position:relative; aspect-ratio: 16/10; overflow:hidden; background: var(--ms-dark); }
.ms-training-thumb img{ width:100%; height:100%; object-fit:cover; transition: transform 500ms ease; }
.ms-training-card:hover .ms-training-thumb img{ transform: scale(1.06); }
.ms-training-badge{
  position:absolute; top:14px; left:14px;
  background: var(--ms-green); color:#06210f;
  font-size:12px; font-weight:700;
  padding: 6px 12px; border-radius:20px;
}
.ms-training-body{ padding: 22px; }
.ms-training-body h3{ font-size:17px; font-weight:700; margin-bottom:8px; }
.ms-training-meta{ display:flex; align-items:center; gap:8px; color: var(--ms-gray-600); font-size:13.5px; margin-bottom:16px; }

@media (max-width: 992px){ .ms-trainings-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 620px){ .ms-trainings-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   8. BLOG
   ========================================================= */
.ms-blog{ background:#fff; }
.ms-blog-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}
.ms-blog-card{
  border: 1px solid var(--ms-gray-100);
  border-radius: var(--ms-radius-md);
  overflow:hidden;
  transition: transform var(--ms-transition), box-shadow var(--ms-transition);
}
.ms-blog-card:hover{ transform: translateY(-6px); box-shadow: var(--ms-shadow-md); }
.ms-blog-thumb{ aspect-ratio: 16/10; overflow:hidden; background: var(--ms-gray-100); }
.ms-blog-thumb img{ width:100%; height:100%; object-fit:cover; transition: transform 500ms ease; }
.ms-blog-card:hover .ms-blog-thumb img{ transform: scale(1.06); }
.ms-blog-body{ padding: 22px; }
.ms-blog-cat{ color: var(--ms-green-dark); font-weight:700; font-size:12.5px; text-transform:uppercase; letter-spacing:.06em; }
.ms-blog-body h3{ font-size:17px; font-weight:700; margin: 10px 0; }
.ms-blog-body p{ color: var(--ms-gray-600); font-size:14.5px; margin-bottom:16px; }

@media (max-width: 992px){ .ms-blog-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 620px){ .ms-blog-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   9. FAQ
   ========================================================= */
.ms-faq{ background: var(--ms-gray-50); }
.ms-faq-list{ max-width: 800px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.ms-faq-item{
  background:#fff;
  border: 1px solid var(--ms-gray-100);
  border-radius: var(--ms-radius-sm);
  overflow:hidden;
}
.ms-faq-question{
  width:100%;
  display:flex; align-items:center; justify-content:space-between;
  padding: 20px 24px;
  background:transparent; border:none;
  text-align:left;
  font-weight:700; font-size:15.5px;
  color: var(--ms-text-dark);
}
.ms-faq-question .plus{
  flex-shrink:0; width:26px; height:26px;
  border-radius:50%;
  background: var(--ms-green-bg); color: var(--ms-green-dark);
  display:flex; align-items:center; justify-content:center;
  transition: transform var(--ms-transition), background var(--ms-transition);
}
.ms-faq-item.is-open .ms-faq-question .plus{ transform: rotate(45deg); background: var(--ms-green); color:#06210f; }
.ms-faq-answer{ max-height:0; overflow:hidden; transition: max-height 320ms ease; }
.ms-faq-answer-inner{ padding: 0 24px 22px; color: var(--ms-gray-600); font-size:14.5px; }

/* =========================================================
   10. CONTACT
   ========================================================= */
.ms-contact{ background:#fff; }
.ms-contact-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  align-items:start;
}
.ms-contact-info-list{ display:flex; flex-direction:column; gap:18px; margin-top:28px; }
.ms-contact-info-item{ display:flex; gap:16px; align-items:flex-start; }
.ms-contact-info-item .ico{
  width:44px; height:44px; flex-shrink:0;
  border-radius:10px; background: var(--ms-dark); color: var(--ms-green);
  display:flex; align-items:center; justify-content:center;
}
.ms-contact-info-item strong{ display:block; font-size:14px; margin-bottom:2px; }
.ms-contact-info-item span, .ms-contact-info-item a{ color: var(--ms-gray-600); font-size:14.5px; }
.ms-contact-map{ margin-top:30px; border-radius: var(--ms-radius-md); overflow:hidden; box-shadow: var(--ms-shadow-sm); }
.ms-contact-map iframe{ width:100%; height:260px; border:0; display:block; }

.ms-contact-form{
  background: var(--ms-gray-50);
  border-radius: var(--ms-radius-lg);
  padding: 34px;
  border: 1px solid var(--ms-gray-100);
}
.ms-form-row{ margin-bottom:18px; }
.ms-form-row label{ display:block; font-size:13.5px; font-weight:700; margin-bottom:7px; }
.ms-form-row input, .ms-form-row textarea{
  width:100%;
  padding: 13px 15px;
  border-radius: var(--ms-radius-sm);
  border: 1.5px solid var(--ms-gray-200);
  background:#fff;
  transition: border-color var(--ms-transition), box-shadow var(--ms-transition);
}
.ms-form-row input:focus, .ms-form-row textarea:focus{
  border-color: var(--ms-green);
  box-shadow: 0 0 0 4px var(--ms-green-bg);
  outline:none;
}
.wpcf7-form-control-wrap{ display:block; }
.wpcf7-not-valid-tip{ color:#dc2626; font-size:12.5px; margin-top:4px; }
.wpcf7 form.invalid .wpcf7-response-output{ border-color:#dc2626; color:#dc2626; }
.wpcf7 form.sent .wpcf7-response-output{ border-color: var(--ms-green); color: var(--ms-green-dark); }
.wpcf7-response-output{ border-radius: var(--ms-radius-sm); padding:12px 16px; font-size:13.5px; margin-top:14px !important; }

@media (max-width: 900px){ .ms-contact-grid{ grid-template-columns:1fr; } }

/* =========================================================
   11. CTA STRIP
   ========================================================= */
.ms-cta-strip{
  background: linear-gradient(120deg, var(--ms-dark) 0%, #0e2a20 100%);
  padding: 60px 0;
}
.ms-cta-strip-inner{
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.ms-cta-strip h3{ color:#fff; font-size: clamp(20px,2.4vw,28px); font-weight:800; max-width:560px; }
.ms-cta-strip .actions{ display:flex; gap:16px; flex-wrap:wrap; }

/* =========================================================
   12. FOOTER
   ========================================================= */
.ms-footer{ background: var(--ms-dark-header); color: rgba(255,255,255,.72); padding-top: 76px; }
.ms-footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: 40px;
  padding-bottom: 50px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ms-footer .ms-logo{ margin-bottom:16px; }
.ms-footer-about p{ font-size:14px; line-height:1.7; max-width:320px; }
.ms-footer-social{ display:flex; gap:10px; margin-top:20px; }
.ms-footer-social a{
  width:38px; height:38px; border-radius:50%;
  background: rgba(255,255,255,.06);
  display:flex; align-items:center; justify-content:center;
  transition: background var(--ms-transition), color var(--ms-transition), transform var(--ms-transition);
}
.ms-footer-social a:hover{ background: var(--ms-green); color:#06210f; transform: translateY(-3px); }
.ms-footer h4{ color:#fff; font-size:15px; font-weight:700; margin-bottom:20px; }
.ms-footer-links li{ margin-bottom:12px; }
.ms-footer-links a{ font-size:14px; transition: color var(--ms-transition), padding-left var(--ms-transition); }
.ms-footer-links a:hover{ color: var(--ms-green); padding-left:4px; }
.ms-footer-contact li{ display:flex; gap:10px; margin-bottom:14px; font-size:14px; align-items:flex-start; }
.ms-footer-contact svg{ flex-shrink:0; color: var(--ms-green); margin-top:2px; }
.ms-footer-bottom{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
  padding: 22px 0; font-size:13px; color: rgba(255,255,255,.5);
}
.ms-footer-bottom a{ color: rgba(255,255,255,.5); }
.ms-footer-bottom a:hover{ color: var(--ms-green); }

@media (max-width: 992px){ .ms-footer-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .ms-footer-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   13. FLOATING WHATSAPP
   ========================================================= */
.ms-float-whatsapp{
  position:fixed; right:24px; bottom:24px; z-index:900;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 10px 26px rgba(37,211,102,.5);
  transition: transform var(--ms-transition);
}
.ms-float-whatsapp:hover{ transform: scale(1.08); }

/* =========================================================
   14. INNER PAGES (archive/single/page/search/404)
   ========================================================= */
.ms-page-header{
  background: var(--ms-dark);
  padding: calc(var(--ms-header-h) + 60px) 0 60px;
  text-align:center;
}
.ms-page-header h1{ color:#fff; font-size: clamp(28px,3.6vw,42px); font-weight:800; }
.ms-breadcrumb{ color: rgba(255,255,255,.6); font-size:13.5px; margin-top:12px; }
.ms-breadcrumb a{ color: rgba(255,255,255,.8); }
.ms-breadcrumb a:hover{ color: var(--ms-green); }

.ms-content-area{ padding: 80px 0; }
.ms-content-layout{ display:grid; grid-template-columns: 2fr 1fr; gap: 50px; }
@media (max-width: 900px){ .ms-content-layout{ grid-template-columns:1fr; } }

.ms-single-article img{ border-radius: var(--ms-radius-md); margin: 20px 0; }
.ms-single-article h2{ font-size:26px; font-weight:800; margin: 30px 0 14px; }
.ms-single-article h3{ font-size:20px; font-weight:700; margin: 24px 0 12px; }
.ms-single-article p{ margin-bottom:16px; color: var(--ms-gray-800); }
.ms-single-article ul, .ms-single-article ol{ margin: 0 0 16px 22px; list-style: disc; }
.ms-single-article a{ color: var(--ms-green-dark); text-decoration:underline; }

.ms-sidebar-widget{ background: var(--ms-gray-50); border-radius: var(--ms-radius-md); padding:26px; margin-bottom:24px; }
.ms-sidebar-widget h3{ font-size:16px; font-weight:800; margin-bottom:16px; }

.ms-pagination{ display:flex; gap:8px; margin-top:40px; flex-wrap:wrap; }
.ms-pagination a, .ms-pagination span{
  display:flex; align-items:center; justify-content:center;
  min-width:40px; height:40px; padding:0 10px;
  border-radius:8px; border:1.5px solid var(--ms-gray-200); font-size:14px; font-weight:600;
}
.ms-pagination .current{ background: var(--ms-green); border-color: var(--ms-green); color:#06210f; }
.ms-pagination a:hover{ border-color: var(--ms-green); color: var(--ms-green-dark); }

.ms-comments{ margin-top: 50px; }
.ms-comment-list{ list-style:none; margin:0; padding:0; }
.ms-comment{ border-bottom:1px solid var(--ms-gray-100); padding: 20px 0; }
.ms-comment-form input, .ms-comment-form textarea{
  width:100%; padding:13px 15px; border-radius:8px; border:1.5px solid var(--ms-gray-200); margin-bottom:14px;
}

.ms-404{ text-align:center; padding: 140px 0; }
.ms-404 h1{ font-size: 96px; font-weight:800; color: var(--ms-green); }
.ms-404 p{ color: var(--ms-gray-600); margin: 16px 0 30px; font-size:17px; }

/* =========================================================
   15. WOOCOMMERCE READY (base overrides)
   ========================================================= */
.woocommerce ul.products li.product{ text-align:left; }
.woocommerce a.button, .woocommerce button.button, .woocommerce #respond input#submit{
  background: var(--ms-green) !important; color:#06210f !important;
  border-radius: var(--ms-radius-sm) !important; font-weight:700 !important; border:none !important;
}
.woocommerce a.button:hover, .woocommerce button.button:hover{ background: var(--ms-green-dark) !important; }
.woocommerce span.onsale{ background: var(--ms-dark) !important; }
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current{ background: var(--ms-green) !important; color:#06210f !important; }

/* =========================================================
   16. SCROLLBAR / SELECTION / ACCESSIBILITY EXTRAS
   ========================================================= */
::selection{ background: var(--ms-green); color:#06210f; }
.screen-reader-text{
  position:absolute !important; width:1px; height:1px; overflow:hidden;
  clip: rect(1px,1px,1px,1px); white-space:nowrap; border:0; padding:0; margin:-1px;
}
[data-aos]{ opacity:0; }
.aos-in{ opacity:1; }

/* =========================================================
   17. RESPONSIVE — NAV / HERO / GENERAL
   ========================================================= */
@media (max-width: 992px){
  .ms-nav{
    position: fixed; top: var(--ms-header-h); left:0; right:0; bottom:0;
    background: var(--ms-dark-header);
    transform: translateX(100%);
    transition: transform var(--ms-transition);
    padding: 30px 24px;
    overflow-y:auto;
  }
  .ms-header.nav-open .ms-nav{ transform: translateX(0); }
  .ms-nav ul{ flex-direction:column; align-items:flex-start; gap:6px; width:100%; }
  .ms-nav a{ display:block; width:100%; padding:14px 4px; font-size:16px; border-bottom:1px solid rgba(255,255,255,.06); }
  .ms-nav a::after{ display:none; }
  .ms-header-cta .ms-whatsapp-btn span{ display:none; }
  .ms-burger{ display:flex; }
}
@media (max-width: 560px){
  .ms-header-cta .ms-whatsapp-btn{ padding:10px; }
  .ms-cta-strip-inner{ flex-direction:column; text-align:center; }
}
