/* ═══════════════════════════════════════════════
   CAJC – SHARED STYLES  |  Pintura de Construção Civil
   Cores: Azul #1a3f8f, Azul escuro #0d2260, Branco #ffffff, Cinza #f4f6fb
   ═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Outfit:wght@300;400;500;600;700;800&display=swap');

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
:root {
  --blue:        #1a3f8f;
  --blue-dark:   #0d2260;
  --blue-mid:    #1e4db7;
  --blue-light:  #e8eef8;
  --blue-glow:   rgba(26,63,143,.18);
  --white:       #ffffff;
  --off-white:   #f4f6fb;
  --text:        #3a3a4a;
  --text-light:  #7a7a90;
  --border:      rgba(26,63,143,.12);
  --nav-h:       80px;
  --r:           12px;
  --shadow:      0 8px 32px rgba(13,34,96,.12);
  --shadow-lg:   0 20px 60px rgba(13,34,96,.2);
}
html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family:'Outfit',sans-serif; background:var(--white); color:var(--text); overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
img { display:block; max-height:100%; object-fit:cover; }

/* ─── CURSOR (desactivado — cursor normal) ─── */
#cur-dot, #cur-ring { display:none !important; }

/* ─── NAVBAR ─── */
#navbar {
  position:fixed; top:0; left:0; right:0; height:var(--nav-h);
  display:flex; align-items:center; padding:0 5%;
  z-index:1000; transition:background .35s,box-shadow .35s;
  background:rgba(255,255,255,0);
}
#navbar.scrolled { background:rgba(255,255,255,.97); box-shadow:0 2px 20px rgba(13,34,96,.1); backdrop-filter:blur(14px); }
.nav-logo { display:flex; align-items:center; gap:.7rem; flex-shrink:0; }
/* ─── NAVBAR LOGO IMAGE ─── */
.nav-logo-img {
  display: block;
  height: 70px;
  width: auto !important;
  max-width: none !important;
  object-fit: contain;
  transition: opacity .3s;
  background: transparent;
}
/* por defeito (sobre hero escuro): mostra logo branco, esconde logo escuro */
.nav-logo-dark  { display:none !important; }
.nav-logo-white { display:block !important; }
/* após scroll (fundo branco): mostra logo escuro, esconde logo branco */
#navbar.scrolled .nav-logo-dark  { display:block !important; }
#navbar.scrolled .nav-logo-white { display:none !important; }
/* footer logo */
.footer-logo-img { display:block !important; height:52px; width:auto !important; max-width:none !important; object-fit:contain; margin-bottom:.9rem; background:transparent; }
.nav-links { display:flex; gap:2rem; list-style:none; margin-left:auto; align-items:center; }
.nav-links > li { position:relative; }
.nav-links > li > a {
  font-size:.82rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase;
  color:#fff; transition:color .2s; display:flex; align-items:center; gap:.35rem; padding:.4rem 0.9rem;
}
.nav-links > li > a:hover, .nav-links > li > a.active { color:rgba(255,255,255,.65); }
/* após scroll: links ficam escuros sobre fundo branco */
#navbar.scrolled .nav-links > li > a { color:var(--text); }
#navbar.scrolled .nav-links > li > a:hover,
#navbar.scrolled .nav-links > li > a.active { color:var(--blue); }
.nav-links > li > a::after {
  content:''; position:absolute; bottom:-2px; left:0; right:0; height:2px;
  background:#fff; transform:scaleX(0); transform-origin:right; transition:transform .25s;
  border-radius:2px;
}
.nav-links > li > a:hover::after, .nav-links > li > a.active::after { transform:scaleX(1); transform-origin:left; }
#navbar.scrolled .nav-links > li > a::after { background:var(--blue); }
/* dropdown */
.has-drop { position:relative; }
.dropdown {
  position:absolute; top:calc(100% + 4px); left:50%; transform:translateX(-50%);
  background:var(--white); border:1px solid var(--border); border-radius:var(--r);
  box-shadow:var(--shadow-lg); min-width:220px; padding:.5rem 0;
  opacity:0; pointer-events:none; transform:translateX(-50%) translateY(-8px);
  transition:opacity .3s,transform .3s;
  margin-top:0;
}
/* Ponte invisível que preenche o gap entre o link e o dropdown */
.has-drop::after {
  content:''; position:absolute; top:100%; left:0; right:0; height:16px;
  background:transparent;
}
.has-drop:hover .dropdown,
.has-drop.open .dropdown {
  opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0);
}
.dropdown a {
  display:flex; align-items:center; gap:.8rem; padding:.65rem 1.2rem;
  font-size:.83rem; font-weight:500; color:var(--text);
  transition:background .15s,color .15s;
}
.dropdown a:hover { background:var(--blue-light); color:var(--blue); }
.dropdown a .dd-icon {
  width:28px; height:28px; background:var(--blue-light); border-radius:6px;
  display:flex; align-items:center; justify-content:center; color:var(--blue); flex-shrink:0;
}
.dropdown a:hover .dd-icon { background:var(--blue); color:#fff; }
.nav-cta {
  margin-left:1.5rem; padding:.55rem 1.8rem;
  background:rgba(255,255,255,.15); color:#fff !important;
  border:1.5px solid rgba(255,255,255,.5);
  font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  border-radius:50px; transition:background .2s,box-shadow .2s,border-color .2s;
  display:inline-flex; align-items:center;
}
.nav-cta:hover { background:rgba(255,255,255,.28); border-color:#fff; }
#navbar.scrolled .nav-cta { background:var(--blue); color:#fff !important; border-color:var(--blue); }
#navbar.scrolled .nav-cta:hover { background:var(--blue-dark); box-shadow:0 6px 20px var(--blue-glow); }
.nav-cta::after { display:none !important; }
.caret { font-size:.6rem; transition:transform .2s; }
.has-drop:hover .caret { transform:rotate(180deg); }

/* ─── HAMBURGER ─── */
#hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; margin-left:auto; z-index:1100; }
#hamburger span { display:block; width:25px; height:2px; background:#fff; border-radius:2px; transition:transform .3s,opacity .3s,background .3s; }
#navbar.scrolled #hamburger span { background:var(--blue-dark); }
#hamburger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
#hamburger.open span:nth-child(2){ opacity:0; }
#hamburger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ─── MOBILE MENU ─── */
#mobile-menu {
  display:none; position:fixed; inset:0; background:var(--blue-dark);
  z-index:1050; flex-direction:column; align-items:center; justify-content:center; gap:2rem;
  opacity:0; pointer-events:none; transition:opacity .35s;
}
#mobile-menu.open { opacity:1; pointer-events:all; }
#mob-close { position:absolute; top:1.5rem; right:1.5rem; background:rgba(255,255,255,.1); border:none; color:#fff; width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s; }
#mob-close:hover { background:rgba(255,255,255,.2); }
#mobile-menu a { font-family:'Bebas Neue',sans-serif; font-size:2.2rem; letter-spacing:.1em; color:#fff; transition:color .2s; }
#mobile-menu a:hover { color:var(--blue-mid); }
#mobile-menu .mob-divider { width:40px; height:1px; background:rgba(255,255,255,.2); }
#mobile-menu .mob-cta { padding:.8rem 2.4rem; border:2px solid #fff; border-radius:50px; font-family:'Outfit',sans-serif; font-size:.85rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-top:.5rem; }
#mobile-menu .mob-sub { font-family:'Outfit',sans-serif; font-size:.9rem; font-weight:500; color:rgba(255,255,255,.6); letter-spacing:.04em; }

/* ─── BUTTONS ─── */
.btn { display:inline-flex; align-items:center; gap:.6rem; border-radius:50px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; transition:all .25s; border:none; }
.btn-blue { background:var(--blue); color:#fff; padding:.85rem 2rem; font-size:.8rem; }
.btn-blue:hover { background:var(--blue-dark); box-shadow:0 10px 30px var(--blue-glow); transform:translateY(-2px); }
.btn-outline { background:transparent; color:var(--blue); border:2px solid var(--blue); padding:.8rem 1.9rem; font-size:.8rem; }
.btn-outline:hover { background:var(--blue); color:#fff; }
.btn-white { background:#fff; color:var(--blue); padding:.85rem 2rem; font-size:.8rem; }
.btn-white:hover { background:var(--off-white); box-shadow:0 10px 30px rgba(0,0,0,.15); transform:translateY(-2px); }
.btn svg { transition:transform .25s; }
.btn:hover svg { transform:translateX(4px); }

/* ─── SECTION LABELS ─── */
.tag {
  display:inline-flex; align-items:center; gap:.5rem;
  font-size:.7rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--blue); background:var(--blue-light); padding:.35rem .9rem; border-radius:50px;
  margin-bottom:1rem;
}
.tag-white { color:#fff; background:rgba(255,255,255,.15); }
h1.sec-title, h2.sec-title {
  font-family:'Bebas Neue',sans-serif; font-size:3.4rem;
  line-height:1; letter-spacing:.03em; color:var(--blue-dark);
}
h1.sec-title em, h2.sec-title em { font-style:normal; color:var(--blue); }
.sec-title-white { color:#fff !important; }
.sec-title-white em { color:var(--blue-mid) !important; }
.sec-desc { font-size:.95rem; font-weight:400; color:var(--text-light); line-height:1.8; max-width:500px; }
.sec-desc-white { color:rgba(255,255,255,.75); }

/* ─── MARQUEE ─── */
.marquee-wrap { background:var(--blue); padding:.75rem 0; overflow:hidden; }
.marquee-track { display:flex; gap:2.5rem; white-space:nowrap; animation:mScroll 24s linear infinite; }
.marquee-track span { font-family:'Bebas Neue',sans-serif; font-size:1rem; letter-spacing:.14em; color:rgba(255,255,255,.7); display:inline-flex; align-items:center; gap:1.5rem; }
.marquee-track span.hi { color:#fff; }
.marquee-track span::after { content:'✦'; font-size:.6rem; }
@keyframes mScroll { from{transform:translateX(0)}to{transform:translateX(-50%)} }

/* ─── PAGE HERO (inner pages) ─── */
.page-hero {
  min-height:340px; display:flex; align-items:flex-end; padding:0 5% 60px;
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 60%,var(--blue-mid) 100%);
  padding-top:var(--nav-h);
}
.page-hero-bg {
  position:absolute; inset:0; opacity:.07;
  background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(255,255,255,.5) 39px,rgba(255,255,255,.5) 40px),
    repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(255,255,255,.5) 39px,rgba(255,255,255,.5) 40px);
}
.page-hero-content { position:relative; z-index:2; }
.breadcrumb { display:flex; align-items:center; gap:.5rem; font-size:.75rem; color:rgba(255,255,255,.55); margin-bottom:.8rem; }
.breadcrumb a { color:rgba(255,255,255,.55); transition:color .2s; }
.breadcrumb a:hover { color:#fff; }
.breadcrumb span { color:rgba(255,255,255,.3); }

/* ─── FOOTER ─── */
footer { background:var(--blue-dark); color:#fff; padding:72px 5% 36px; }
.footer-top { display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.1); margin-bottom:36px; }
.footer-brand p { font-size:.83rem; color:rgba(255,255,255,.55); line-height:1.75; margin-top:.9rem; max-width:280px; }
.footer-logo { font-family:'Bebas Neue',sans-serif; font-size:2rem; letter-spacing:.1em; color:#fff; }
.footer-logo span { color:var(--blue-mid); }
.footer-col h5 { font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:1.2rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.65rem; }
.footer-col ul li a { font-size:.83rem; color:rgba(255,255,255,.65); transition:color .2s; }
.footer-col ul li a:hover { color:#fff; }
.footer-socials { display:flex; gap:.8rem; }
.footer-socials a { width:36px; height:36px; border:1px solid rgba(255,255,255,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.5); transition:all .2s; }
.footer-socials a:hover { border-color:#fff; color:#fff; background:rgba(255,255,255,.08); }
.footer-contact-items { display:flex; flex-direction:column; gap:.8rem; }
.footer-contact-items a { font-size:.83rem; color:rgba(255,255,255,.65); display:flex; align-items:center; gap:.6rem; transition:color .2s; }
.footer-contact-items a:hover { color:#fff; }

/* ─── FOOTER BOTTOM ─── */
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:.8rem; }
.footer-bottom > p { font-size:.75rem; color:rgba(255,255,255,.35); }
.footer-bottom-links { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.footer-bottom-links a, .footer-bottom-links span { font-size:.72rem; color:rgba(255,255,255,.35); }
.footer-bottom-links a:hover { color:rgba(255,255,255,.7); }
.footer-certs { display:flex; gap:1.4rem; flex-wrap:wrap; align-items:center; margin-top:1rem; }
.footer-seal-link { display:inline-flex; align-items:center; opacity:.85; transition:opacity .2s; }
.footer-seal-link:hover { opacity:1; }
.footer-seal { height:42px; width:auto; max-width:130px; object-fit:contain; }
.footer-seal-text { font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.6); background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.15); border-radius:6px; padding:.3rem .7rem; white-space:nowrap; }


/* ─── LANGUAGE TOGGLE ─── */
#lang-toggle {
  background:transparent; border:1.5px solid rgba(255,255,255,.5); color:#fff;
  font-family:'Outfit',sans-serif; font-size:.72rem; font-weight:700; letter-spacing:.12em;
  padding:.35rem .8rem; border-radius:50px; cursor:pointer; transition:all .2s;
}
#lang-toggle:hover { background:rgba(255,255,255,.15); border-color:#fff; }
#navbar.scrolled #lang-toggle { border-color:var(--blue); color:var(--blue); }
#navbar.scrolled #lang-toggle:hover { background:var(--blue-light); }

/* ─── BACK TO TOP ─── */
#back-top { position:fixed; bottom:2rem; right:2rem; width:44px; height:44px; background:var(--blue); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; z-index:500; opacity:0; pointer-events:none; transition:opacity .3s,transform .3s; box-shadow:var(--shadow); }
#back-top.show { opacity:1; pointer-events:all; }
#back-top:hover { transform:translateY(-3px); background:var(--blue-dark); }

/* ─── UTILITIES ─── */
.container { max-width:1240px; margin:0 auto; padding:0 5%; }
.text-center { text-align:center; }
.flex-center { display:flex; align-items:center; justify-content:center; }

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){ .footer-top{grid-template-columns:1fr 1fr;} }
@media(max-width:768px){
  .nav-links{display:none;}
  #hamburger{display:flex;}
  #mobile-menu{display:flex;}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){ .footer-top{grid-template-columns:1fr;} }