/* =========================================================
   Nascortec – CSS base organizado (versão limpa)
   ========================================================= */

/* ---------- Variáveis & Reset ---------- */
:root{
  --accent:#f79b72;   /* laranja */
  --ink:#3a5363;      /* azul-cinza principal */
  --soft:#eeeeee;     /* cinza claro */
}
*{ box-sizing:border-box; }

/* ---------- Base tipográfica ---------- */
.ntc-body{
  font-family:'Montserrat',system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;
  color:var(--ink);
  margin:0;
  background:#fff;
}
.ntc-container{ max-width:1200px; margin:0 auto; padding:0 24px; }
.c-accent{ color:var(--accent); }

/* =========================================================
   Header / Navegação
   ========================================================= */
.ntc-header{ position:sticky; top:0; z-index:50; background:#fff; border-bottom:1px solid #f1f1f1; }
.ntc-header-inner{ display:flex; align-items:center; justify-content:space-between; height:72px; gap:16px; }
.ntc-logo{ font-weight:800; letter-spacing:1px; text-decoration:none; color:var(--ink); }
.ntc-nav a{ margin:0 12px; text-decoration:none; color:var(--ink); font-weight:600; }
.ntc-nav a:hover{ color:var(--accent); }
.ntc-lang a{ margin:0 6px; text-decoration:none; color:var(--ink); font-weight:600; }
.ntc-lang a.active{ color:var(--accent); }
.ntc-burger{ display:none; background:none; border:0; padding:8px; }
.ntc-burger span{ display:block; width:22px; height:2px; background:var(--ink); margin:4px 0; }

@media (max-width:900px){
  .ntc-nav{ display:none; position:fixed; inset:72px 0 auto 0; background:#fff; border-bottom:1px solid #eee; padding:16px; }
  .ntc-nav a{ display:block; padding:10px 16px; }
  .ntc-burger{ display:block; }
  body.ntc-open .ntc-nav{ display:block; }
}

/* =========================================================
   Heros
   ========================================================= */

/* --- Hero da Home (alto) --- */
.ntc-hero{
  position:relative;
  height:100vh;
  max-height:640px;
  overflow:hidden;
}
.ntc-hero-bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
}
.ntc-hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(58,83,99,.2), rgba(58,83,99,.7));
}
.ntc-hero-content{
  position:relative; z-index:1;
  display:flex; flex-direction:column; gap:16px;
  align-items:flex-start; justify-content:center;
  height:100%; color:#fff;
}
.ntc-hero h1{ font-size:clamp(32px,6vw,72px); line-height:1.05; margin:0; }
.ntc-hero p{ font-size:clamp(16px,2.6vw,24px); margin:0; max-width:800px; }

/* --- Hero de Páginas Internas (Sobre nós + Atividades) --- */
.ntc-page-hero{
  --hero-min-h:50vh;   /* mais baixo que o da Home */
  --hero-max-h:350px;
  position:relative;
  min-height:var(--hero-min-h);
  max-height:var(--hero-max-h);
  width:100%;
  overflow:hidden;
}
.ntc-page-hero__bg{
  position:absolute; inset:0;
  background-image:var(--page-hero-image);
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
  filter:saturate(.95);
}
.ntc-page-hero__overlay{
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,0) 25%, rgba(63,81,96,0.55) 85%);
}
.ntc-page-hero__title{
  position:absolute;
  left:clamp(16px,4vw,32px);
  bottom:clamp(8px,2vw,16px);
  margin:0;
  color:#E6E6E6;
  font-weight:800;
  line-height:.9;
  letter-spacing:.5px;
  font-size:clamp(36px,9vw,110px);
  text-wrap:balance;
}

/* =========================================================
   Secções / Títulos / Grids
   ========================================================= */
.ntc-main{ min-height:60vh; }
.ntc-section{ padding:56px 0; }
.ntc-title{ font-size:clamp(28px,4.8vw,56px); text-align:center; margin:0 0 12px; }
.ntc-subtitle{ text-align:center; opacity:.9; max-width:900px; margin:0 auto 28px; }

.ntc-grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:1024px){ .ntc-grid-3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .ntc-grid-3{ grid-template-columns:1fr; } }

/* =========================================================
   Cards (genéricos + clicáveis)
   ========================================================= */
.ntc-card{
  background:#efefef;
  border-radius:20px;
  padding:28px;
  text-decoration:none;
  color:inherit;
  display:block; /* torna todo o card clicável quando for <a> */
  box-shadow:0 0 0 rgba(0,0,0,0);
  transition:transform .15s ease, box-shadow .15s ease;
}
.ntc-card:hover{ transform:translateY(-2px); box-shadow:0 10px 20px rgba(0,0,0,.08); }
.ntc-card .ntc-card-icon{ width:96px; height:96px; border-radius:999px; background:var(--accent); margin-bottom:8px; }
.ntc-card h3{ margin:.2rem 0 0; font-size:20px; }
.ntc-card p{ margin:0; opacity:.9; }

/* Atividades: centragem forçada + ícones brancos */
a.ntc-card.ntc-card--activity{
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center;
}
.ntc-card--activity .ntc-card-icon{
  width:116px; height:116px; margin:8px auto 14px;
  display:grid; place-items:center;
  background:var(--accent); border-radius:50%;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
  color:#fff; line-height:0;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease; 
}
.ntc-card--activity .ntc-card-icon svg{
  width:56px; height:56px; display:block; fill:currentColor; pointer-events:none;
}
.ntc-card--activity h3{ margin-top:8px; font-weight:800; }
.ntc-card--activity:hover{ transform:translateY(-3px); box-shadow:0 14px 28px rgba(0,0,0,.10); }
.ntc-card--activity:hover .ntc-card-icon{ background:#ffb493; transform:scale(1.03); }
.ntc-card--activity p{ display:none; }

/* (Opcional) Ícone via máscara (se usares sprites externos) */
.ntc-activity-icon{
  display:block; width:56px; height:56px; background:#fff;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
  -webkit-mask-position:center;   mask-position:center;
  -webkit-mask-size:contain;      mask-size:contain;
}

/* Título “O que fazemos” com mais espaço ao hero */
.ntc-whatwedo{
  margin-top:70px;
  margin-bottom:20px;
  font-size:clamp(36px,5.5vw,52px);
  font-weight:700;
  text-align:center;
}

/* =========================================================
   Contactos
   ========================================================= */
.ntc-contacts-grid{ display:grid; grid-template-columns:1fr 2fr; gap:24px; }
@media (max-width:900px){ .ntc-contacts-grid{ grid-template-columns:1fr; } }

.ntc-info-card{ background:#efefef; border-radius:16px; padding:20px; }
.ntc-info-card + .ntc-info-card{ margin-top:5px; }
.ntc-contact-cards{ display:flex; flex-direction:column; gap:5px; }

.ntc-form-card{ background:#f7f7f7; border-radius:16px; padding:20px; }
.ntc-form-card h2{ margin:0 0 16px; }
.ntc-form-card form{ display:grid; gap:12px; }
.ntc-form-card input, .ntc-form-card textarea{
  width:100%; padding:12px 14px; border-radius:12px;
  border:1px solid #d7d7d7; background:#e5e5e5; font:inherit;
}
.ntc-consent{ display:flex; align-items:flex-start; gap:8px; font-size:14px; }
.ntc-form-card button{
  padding:12px 18px; border-radius:12px; border:0;
  background:var(--accent); color:#fff; font-weight:700; cursor:pointer;
}
.ntc-success{ margin-top:8px; color:#207227; }

/* =========================================================
   Notícias / Blog
   ========================================================= */
.ntc-news-card{
  background:#fff; border-radius:16px; padding:0;
  text-decoration:none; color:var(--ink);
  border:1px solid #eee; overflow:hidden;
  display:flex; flex-direction:column; gap:10px;
  transition:box-shadow .15s ease, transform .15s ease;
}
.ntc-news-card:hover{ box-shadow:0 10px 20px rgba(0,0,0,.08); transform:translateY(-2px); }
.ntc-thumb16x9{ background:#ddd; aspect-ratio:16/9; width:100%; }
.ntc-news-meta{ padding:8px 16px 0; opacity:.8; font-size:14px; }
.ntc-news-card h3{ padding:0 16px; margin:0; font-size:18px; }
.ntc-news-card p{ padding:0 16px 16px; margin:0; opacity:.9; }
.ntc-pagination{ display:flex; gap:8px; justify-content:center; margin-top:24px; }
.ntc-pagination a{
  padding:8px 12px; border-radius:8px; border:1px solid #ddd;
  text-decoration:none; color:var(--ink);
}
.ntc-pagination a.active{ background:var(--ink); color:#fff; border-color:var(--ink); }

.ntc-article .ntc-title{ text-align:left; }
.ntc-article-meta{ opacity:.7; margin-bottom:16px; }
.ntc-article-body p{ line-height:1.7; }
.ntc-article-nav{ display:flex; justify-content:space-between; margin-top:24px; }

/* =========================================================
   CTA (frase + botão) – secção antes do footer
   ========================================================= */
.ntc-cta-quote{
  padding:120px 20px;
  text-align:center;
  background:#fff;
}
.ntc-quote{
  font-size:32px; font-style:italic; color:#3f5160;
  line-height:1.5; margin-bottom:50px;
}
.ntc-cta-btn-wrapper{ display:flex; justify-content:center; }
.ntc-cta-btn{
  display:inline-block; background-color:#3f5160; color:#fff;
  padding:18px 48px; font-size:20px; font-weight:500;
  border-radius:16px; text-decoration:none;
  transition:background .2s ease, transform .2s ease;
}
.ntc-cta-btn:hover{ background-color:#f28b5e; transform:translateY(-2px); }

/* =========================================================
   FOOTER — Corrigido e harmonizado
   ========================================================= */
.ntc-footer {
  background:#fff;
  border-top:1px solid #e6e6e6;
  padding:60px 0 30px;
  color:#3f5160;
  font-size:16px;
}
.ntc-footer .ntc-container {
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
}
.ntc-footer-grid {
  display:grid;
  grid-template-columns:1.2fr 1fr 1.2fr;
  gap:48px;
  align-items:flex-start;
}
@media (max-width:980px){
  .ntc-footer-grid{ grid-template-columns:1fr; gap:32px; text-align:center; }
  .ntc-footer-nav{ align-items:center; }
}

/* Logo e redes */
.ntc-footer-logo { height:48px; width:auto; margin-bottom:16px; }
.ntc-footer-social-label { font-size:18px; margin-bottom:12px; }
.ntc-footer-social { display:flex; gap:16px; flex-wrap:wrap; justify-content:flex-start; }
@media (max-width:980px){ .ntc-footer-social{ justify-content:center; } }

.ntc-social-circle {
  width:42px; height:42px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#3f5160;
  color:#fff;
  transition:background .2s, transform .2s;
}
.ntc-social-circle:hover { background:#f79b72; transform:translateY(-2px); }
.ntc-social-circle svg { width:18px; height:18px; }

/* Navegação central */
.ntc-footer-nav {
  display:flex;
  flex-direction:column;
  gap:10px;
  font-weight:600;
}
.ntc-footer-nav a {
  color:#3f5160;
  text-decoration:none;
  font-size:18px;
  transition:color .2s;
}
.ntc-footer-nav a:hover { color:#f79b72; }

/* Cartões de contacto à direita */
.ntc-footer-right {
  display:flex;
  flex-direction:column;
  gap:14px;
}
.ntc-info-card {
  background:#f8f8f8;
  border:1px solid #e0e0e0;
  border-radius:12px;
  padding:16px;
}
.ntc-info-card-title {
  font-size:18px;
  font-weight:700;
  margin-bottom:6px;
}
.ntc-info-card-body a {
  color:#3f5160;
  text-decoration:none;
}
.ntc-info-card-body a:hover { color:#f79b72; }

/* Copyright */
.ntc-footer-copy {
  text-align:center;
  font-size:13px;
  color:#9aa7af;
  margin-top:40px;
}

/* =========================================================
   Sobre nós – 2 colunas + galeria
   ========================================================= */
.ntc-about-2cols{
  background:#fff;
  padding: clamp(28px, 5vw, 56px) 0;
}
.ntc-about-grid{
  max-width:1200px; margin:0 auto; padding:0 20px;
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(20px, 4vw, 48px);
}
@media (max-width: 980px){
  .ntc-about-grid{ grid-template-columns: 1fr; }
}

.ntc-about-text h2{ margin:0 0 12px; font-size: clamp(22px, 2.6vw, 32px); }
.ntc-about-text p{ font-size: clamp(16px, 1.9vw, 20px); line-height:1.6; color:#22313d; margin: 0 0 14px; }
.ntc-about-bullets{ margin:14px 0 0; padding:0 0 0 18px; font-size:clamp(15px,1.7vw,18px); }
.ntc-about-bullets li{ margin-bottom:8px; }

/* Galeria 2x2 (default) */
.ntc-about-gallery{
  display:grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 1fr;
  gap: clamp(10px, 2vw, 16px);
}
.ntc-about-photo img {
  width: 100%;
  height: auto;
  max-height: 600px; /* podes ajustar entre 400–600px conforme quiseres */
  object-fit: cover;
  border-radius: 12px;
}


/* Masonry opcional */
.ntc-about-gallery.is-masonry{ column-count:2; column-gap:clamp(10px,2vw,16px); }
.ntc-about-gallery.is-masonry .ntc-about-photo{
  break-inside:avoid; margin:0 0 clamp(10px,2vw,16px) 0; aspect-ratio:auto;
}

@media (max-width:640px){
  .ntc-about-gallery{ grid-template-columns:1fr; }
  .ntc-about-gallery.is-masonry{ column-count:1; }
}

/* =========================================================
   Carrossel (Splide) – skin
   ========================================================= */
.splide__arrow{
  width:48px; height:48px; border-radius:50%;
  display:grid; place-items:center;
  background:rgba(58,83,99,.95);
  border:0;
  box-shadow:0 10px 24px rgba(0,0,0,.15);
  transition:background .2s ease;
}
.splide__arrow:hover{ background:#f28b5e; }
.splide__arrow--prev{ left:8px; }
.splide__arrow--next{ right:8px; }

.splide__pagination{ margin-top:14px; gap:10px; }
.splide__pagination__page{
  width:9px; height:9px; border-radius:999px;
  background:#c7d0d6; opacity:1; transform:scale(1);
  transition:transform .2s, background .2s;
}
.splide__pagination__page.is-active{ background:#3a5363; transform:scale(1.2); }

@media (max-width:768px){
  .splide__arrow{ width:42px; height:42px; }
}

.ntc-activity-icon {
  display: block;
  width: 44px;
  height: 44px;
  background-color: #3a5363; /* cinza escuro dos ícones */
}

/* === NTCarrossel === */
.ntc-carousel { margin: 28px 0 8px; }
.ntc-carousel .splide { --btn: #3a5363; --btnHover: #5b6f7b; }
.ntc-carousel .splide__track { overflow: visible; }

.ntc-carousel .ntc-carousel-item{
  height: var(--h, 420px);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
  margin: 0;
  background: #f3f3f3;
}
.ntc-carousel .ntc-carousel-item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.01);
}
.ntc-carousel .ntc-carousel-item figcaption{
  position: absolute; left: 10px; bottom: 10px;
  background: rgba(0,0,0,.55);
  color: #fff; padding: 6px 10px; border-radius: 10px;
  font-size: 14px;
}

/* setas */
.ntc-carousel .splide__arrow{
  width: 42px; height: 42px; border-radius: 999px;
  background: var(--btn);
  opacity: 1; box-shadow: 0 6px 16px rgba(0,0,0,.16);
  transition: transform .15s ease, background .15s ease;
}
.ntc-carousel .splide__arrow:hover{ background: var(--btnHover); transform: translateY(-1px); }
.ntc-carousel .splide__arrow svg{ fill:#fff; width: 18px; height: 18px; }

/* paginadores */
.ntc-carousel .splide__pagination__page{
  background:#cfd6db; opacity:1; width:9px; height:9px;
}
.ntc-carousel .splide__pagination__page.is-active{ background:#3a5363; transform: none; }

/* mobile */
@media (max-width: 640px){
  .ntc-carousel .ntc-carousel-item{ height: 280px; }
}

