/*!
 * Based on http://startbootstrap.com/template-overviews/grayscale
 */
body {
  width: 100%;
  height: 100%;
  font-family: "Lora", "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: whitesmoke;
  background-color: black;
}
html {
  width: 100%;
  height: 100%;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0 0 35px;
  text-transform: uppercase;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 700;
  letter-spacing: 1px;
}
p {
  margin: 0 0 25px;
  font-size: 15px;
  line-height: 1.65;
}
@media (min-width: 768px) {
  p {
    margin: 0 0 35px;
    font-size: 16px;
    line-height: 1.7;
  }
}
a {
  color: #9f7a3a;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
a:hover,
a:focus {
  text-decoration: none;
  color: rgba(159,122,58,0.70);
}
.heading-light {
  font-weight: 300;
  letter-spacing: 0.11em;
  font-size: 0.58em;
  line-height: 1.4;

  display: inline-block;

  margin-bottom: 18px;

  opacity: 0.92;
}
.light {
  font-weight: 300;
}
.navbar-custom {
  text-transform: uppercase;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  padding-top: 8px;
  padding-bottom: 8px;
}
.navbar-custom .navbar-toggle {
  color: white;
  background-color: rgba(255, 255, 255, 0.2);
  font-size: 12px;
}
.navbar-custom .navbar-toggle:focus,
.navbar-custom .navbar-toggle:active {
  outline: none;
}
.navbar-custom .navbar-brand {
  font-weight: 700;
  font-size: 14px;
  padding-left: 10px;
  padding-right: 10px;
}
.navbar-custom .navbar-brand:focus {
  outline: none;
}
.navbar-custom a {
  color: white;
}
.navbar-custom .nav li a {
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.92);
  padding-left: 10px;
  padding-right: 10px;
}
.navbar-custom .nav li a:hover {
  color: rgba(255, 255, 255, 0.8);
  outline: none;
  background-color: transparent;
}
.navbar-custom .nav li a:focus,
.navbar-custom .nav li a:active {
  outline: none;
  background-color: transparent;
}
.navbar-custom .nav li.active {
  outline: none;
}
.navbar-custom .nav li.active a {
  background-color: #9f7a3a;
}
.navbar-custom .nav li.active a:hover {
  color: rgba(255,255,255,1);

  opacity: 1;

  outline: none;

  background-color: transparent;
}
@media (min-width: 3000px) {
  .navbar-custom {
    padding: 20px 0;
    border-bottom: none;
    letter-spacing: 1px;
    background: transparent;
    -webkit-transition: background 0.5s ease-in-out, padding 0.5s ease-in-out;
    -moz-transition: background 0.5s ease-in-out, padding 0.5s ease-in-out;
    transition: background 0.5s ease-in-out, padding 0.5s ease-in-out;
  }
  .navbar-custom.top-nav-collapse {
    padding: 0;
    background: black;
    border-bottom: 1px solid #9f7a3a;
  }
}
.intro {
  display: table;
  width: 100%;
  height: 100vh;
  padding: 0;
  text-align: center;
  color: white;
  position: relative;
  overflow: hidden;

  background:
    radial-gradient(
      circle,
      rgba(0,0,0,0.35) 0%,
      rgba(0,0,0,0.55) 45%,
      rgba(0,0,0,0.88) 100%
    ),
    url(../img/intro-bg.jpg);

  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.intro::before {
  content: "";
  position: absolute;
  inset: 0;

  background:
    radial-gradient(
      circle at center,
      rgba(0,0,0,0.08) 0%,
      rgba(0,0,0,0.22) 40%,
      rgba(0,0,0,0.65) 100%
    );

  z-index: 1;
}
.intro .intro-body {
  display: table-cell;
  vertical-align: middle;
  position: relative;
  z-index: 2;
}
.intro .intro-body::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 700px;
  height: 700px;
  transform: translate(-50%, -50%);
  
  background: radial-gradient(
    circle,
    rgba(0,0,0,0.55) 0%,
    rgba(0,0,0,0.28) 42%,
    rgba(0,0,0,0.08) 62%,
    rgba(0,0,0,0) 78%
  );

  pointer-events: none;
  z-index: 1;
}
.intro .container,
.intro .row,
.intro .col-md-8 {
  position: relative;
  z-index: 2;
}
.intro .intro-body .brand-heading {
  font-size: 30px;
  letter-spacing: 0.04em;
  line-height: 1.08;
}
.intro .intro-body .intro-text {
  font-size: 16px;
}
.hero-logo {
  width: clamp(110px, 10vw, 170px);

  height: auto;

  margin: 8px 18px;

  opacity: 0.82;

  transition: all 0.3s ease;
}
@media (min-width: 768px) {
   .hero-logo {
    width: clamp(90px, 28vw, 140px);

    margin: 8px 10px;
  }

}
.intro {
    height: 100%;
    padding: 0;
    background-size: cover;
    background-position: center center;
  }

.intro .intro-body .brand-heading {
  font-size: clamp(26px, 2.05vw, 40px);
  line-height: 0.98;
  letter-spacing: 0.03em;
  margin-bottom: 34px;

  text-shadow:
    0 2px 4px rgba(0,0,0,0.95),
    0 10px 28px rgba(0,0,0,0.75);
}

  .intro .intro-body .intro-text {
  font-size: clamp(14px, 0.9vw, 18px);
  line-height: 1.45;

  text-shadow:
    0 2px 4px rgba(0,0,0,0.95),
    0 8px 22px rgba(0,0,0,0.7);
}
.btn-circle {
  width: 70px;
  height: 70px;
  margin-top: 28px;
  padding: 0;

  border: 2px solid rgba(255,255,255,0.85);
  border-radius: 50% !important;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  font-size: 34px;
  color: #fff;
  background: rgba(0,0,0,0.12);

  line-height: 1;
  opacity: 0.85;

  transition: all 0.3s ease;
}
.btn-circle:hover,
.btn-circle:focus {
  outline: none;
  color: #fff;
  opacity: 1;
  background: rgba(255,255,255,0.08);
}

.btn-circle i {
  line-height: 1;
  margin: 0;
  padding: 0;
}
.btn-circle:focus {
  outline: none;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}
.btn-circle i.animated {
  -webkit-transition-property: -webkit-transform;
  -webkit-transition-duration: 1s;
  -moz-transition-property: -moz-transform;
  -moz-transition-duration: 1s;
}
.btn-circle:hover i.animated {
  -webkit-animation-name: pulse;
  -moz-animation-name: pulse;
  -webkit-animation-duration: 1.5s;
  -moz-animation-duration: 1.5s;
  -webkit-animation-iteration-count: infinite;
  -moz-animation-iteration-count: infinite;
  -webkit-animation-timing-function: linear;
  -moz-animation-timing-function: linear;
}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  50% {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
@-moz-keyframes pulse {
  0% {
    -moz-transform: scale(1);
    transform: scale(1);
  }
  50% {
    -moz-transform: scale(1.2);
    transform: scale(1.2);
  }
  100% {
    -moz-transform: scale(1);
    transform: scale(1);
  }
}
.content-section {
  padding-top: 160px;
}
.download-section {	
  width: 100%;
  padding: 50px 0;
  color: whitesmoke;
  background-color: #050505;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
}

.equipa-section {
  width: 100%;
  padding: 50px 0;
  color: white;
  background-color: #0A0A0A;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
}

.equipa-img {
  width: 100%;
}

.noticias-section {
  width: 100%;
  padding: 50px 0;
  color: whitesmoke;
  background-color: #0A0A0A;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
}

.venue-section {
  width: 100%;
  padding: 50px 0;
  color: whitesmoke;
  background-color: #070707;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
}

#map {
  width: 100%;
  height: 200px;
  margin-top: 100px;
}
@media (min-width: 767px) {
  .content-section {
    padding-top: 250px;
  }
  .download-section {
    padding: 100px 0;
  }
  #map {
    height: 400px;
    margin-top: 250px;
  }
}
.btn {
  text-transform: uppercase;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 400;
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  border-radius: 0;
}
.btn-default {
  border: 1px solid rgba(29, 155, 108, 1);
  color: rgba(29, 155, 108, 1);
  background-color: transparent;
}
.btn-default:hover,
.btn-default:focus {
  border: 1px solid rgba(29, 155, 108, 0.5);
  outline: none;
  color: rgba(29, 155, 108, 0.5);
  background-color: #000;
}
ul.banner-social-buttons {
  margin-top: 0;
}
@media (max-width: 1199px) {
  ul.banner-social-buttons {
    margin-top: 15px;
  }
}
@media (max-width: 767px) {
  ul.banner-social-buttons li {
    display: block;
    margin-bottom: 20px;
    padding: 0;
  }
  ul.banner-social-buttons li:last-child {
    margin-bottom: 0;
  }
}
footer {
  padding: 25px 0;
}
footer p {
  margin: 0;
}
::-moz-selection {
  text-shadow: none;
  background: #fcfcfc;
  background: rgba(255, 255, 255, 0.2);
}
::selection {
  text-shadow: none;
  background: #fcfcfc;
  background: rgba(255, 255, 255, 0.2);
}
img::selection {
  background: transparent;
}
img::-moz-selection {
  background: transparent;
}
body {
  webkit-tap-highlight-color: rgba(255, 255, 255, 0.2);
}
.mapsInfo {
  color: black;
}
.style4 {
	color: #FE5000
}


/* =========================================================
   MDA FINAL OVERRIDES — aplicar no fim do ficheiro
   ========================================================= */

/* Fundo geral e áreas cinzentas mais escuras */
html,
body {
  background-color: #050505 !important;
}

.content-section {
  background-color: #050505 !important;
}

.download-section,
.noticias-section,
.venue-section,
.equipa-section {
  background-color: #070707 !important;
}

/* Barra de menu com fundo preto real */
.navbar,
.navbar-custom,
.navbar-fixed-top,
.navbar-custom.top-nav-collapse {
  background: #000 !important;
  background-color: #000 !important;
  border-bottom: 1px solid rgba(255,255,255,0.16) !important;
  box-shadow: 0 14px 30px rgba(0,0,0,0.65) !important;
}

/* Links do menu normais */
.navbar-custom .nav > li > a {
  color: rgba(255,255,255,0.9) !important;
  background: transparent !important;
  background-color: transparent !important;
}

/* Hover/ativo do menu sem amarelo antigo */
.navbar-custom .nav > li > a:hover,
.navbar-custom .nav > li > a:focus,
.navbar-custom .nav li.active a,
.navbar-custom .nav li.active a:hover,
.navbar-custom .nav li.active a:focus {
  color: #9f7a3a !important;
  background: transparent !important;
  background-color: transparent !important;
}

/* Títulos e links do conteúdo todos na mesma cor */
.style5,
.content-section h2,
.download-section h2,
.noticias-section h2,
.venue-section h2,
#sponsors h2,
a,
a:visited {
  color: #9f7a3a !important;
}

a:hover,
a:focus {
  color: rgba(159,122,58,0.72) !important;
}

/* Redução visível da fonte do hero e textos */
.intro .intro-body .brand-heading {
  font-size: clamp(26px, 2.05vw, 40px) !important;
  line-height: 1.02 !important;
}

.intro .intro-body .intro-text {
  font-size: clamp(14px, 0.9vw, 18px) !important;
}

p {
  font-size: 15px !important;
  line-height: 1.65 !important;
}

@media (min-width: 768px) {
  p {
    font-size: 16px !important;
    line-height: 1.7 !important;
  }
}

/* Compensação para menu fixo ao clicar nos anchors */
section {
  scroll-margin-top: 105px !important;
}

.content-section,
.venue-section {
  padding-top: 230px !important;
}

/* Sponsors centrado */
#sponsors,
#sponsors .row,
#sponsors p,
#sponsors h2 {
  text-align: center !important;
}

#sponsors p {
  margin-left: auto !important;
  margin-right: auto !important;
}


/* =========================================================
   MDA HERO RESPONSIVE REFINEMENTS
   Ajustes para janelas médias / portáteis
   ========================================================= */

/* Mantém o bloco do título com largura controlada */
.intro .intro-body .brand-heading {
  max-width: 980px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Dá mais presença à imagem do hero sem perder leitura */
.intro {
  background-position: center center !important;
  background-size: cover !important;
}

/* Breakpoint para janelas tipo portátil */
@media (max-width: 1400px) {

  /* Menu mais compacto para não competir com o hero */
  .navbar-custom .nav > li > a {
    font-size: 8px !important;
    padding-left: 7px !important;
    padding-right: 7px !important;
    letter-spacing: 0.055em !important;
  }

  .navbar-custom .navbar-brand {
    font-size: 13px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  /* Título com quebra mais elegante */
  .intro .intro-body .brand-heading {
    max-width: 760px !important;
    font-size: clamp(27px, 2.35vw, 42px) !important;
    line-height: 1.05 !important;
    letter-spacing: 0.035em !important;
    margin-bottom: 28px !important;
  }

  .heading-light {
    font-size: 0.48em !important;
    letter-spacing: 0.14em !important;
    margin-bottom: 14px !important;
  }

  /* Local/data um pouco mais presente */
  .intro .intro-body .intro-text {
    font-size: clamp(16px, 1.1vw, 22px) !important;
    line-height: 1.5 !important;
    margin-top: 20px !important;
  }

  /* Logos proporcionais */
  .hero-logo {
    width: clamp(105px, 10vw, 150px) !important;
    margin: 10px 16px !important;
  }

  /* Mais espaço antes do botão */
  .btn-circle {
    margin-top: 34px !important;
  }
}

/* Breakpoint intermédio: evita título demasiado horizontal */
@media (max-width: 1200px) {
  .intro .intro-body .brand-heading {
    max-width: 700px !important;
    font-size: clamp(25px, 2.5vw, 38px) !important;
  }

  .navbar-custom .nav > li > a {
    font-size: 7.5px !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
}

/* Mobile/tablet: mantém legibilidade e evita esmagamento */
@media (max-width: 768px) {
  .intro .intro-body .brand-heading {
    max-width: 88vw !important;
    font-size: clamp(24px, 7vw, 36px) !important;
    line-height: 1.08 !important;
  }

  .heading-light {
    font-size: 0.5em !important;
    letter-spacing: 0.1em !important;
  }

  .intro .intro-body .intro-text {
    font-size: 16px !important;
  }

  .hero-logo {
    width: clamp(90px, 28vw, 130px) !important;
    margin: 8px 10px !important;
  }
}


/* =========================================================
   MDA HERO FIX — medium width layout
   ========================================================= */

/* Força a primeira linha a separar-se do título principal */
.heading-light {
  display: block !important;
}

/* Evita que "7th International..." fique na mesma linha de "Materials Design" */
.intro .intro-body .brand-heading {
  max-width: 760px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

/* Ajuste específico para janelas médias, como a tua captura */
@media (min-width: 1000px) and (max-width: 1280px) {
  .intro .intro-body .brand-heading {
    max-width: 700px !important;
    font-size: clamp(30px, 3vw, 38px) !important;
    line-height: 1.08 !important;
    letter-spacing: 0.035em !important;
    margin-bottom: 30px !important;
  }

  .heading-light {
    display: block !important;
    font-size: 0.46em !important;
    letter-spacing: 0.14em !important;
    line-height: 1.4 !important;
    margin-bottom: 14px !important;
  }

  .intro .intro-body .intro-text {
    font-size: clamp(17px, 1.25vw, 21px) !important;
    line-height: 1.5 !important;
    margin-top: 22px !important;
  }

  .hero-logo {
    width: clamp(115px, 11vw, 145px) !important;
    margin: 10px 16px !important;
  }

  .btn-circle {
    margin-top: 36px !important;
  }
}

/* Em larguras um pouco maiores mantém a estrutura mais estável */
@media (min-width: 1281px) and (max-width: 1500px) {
  .intro .intro-body .brand-heading {
    max-width: 820px !important;
    font-size: clamp(32px, 2.6vw, 46px) !important;
    line-height: 1.06 !important;
  }

  .heading-light {
    display: block !important;
    font-size: 0.48em !important;
    margin-bottom: 14px !important;
  }
}


/* =========================================================
   MDA MENU BREAKPOINT — hamburger em larguras médias
   ========================================================= */

/* Mantém o menu legível quando está aberto */
@media (max-width: 1280px) {

  .navbar-custom .navbar-brand {
    font-size: 14px !important;
  }

  .navbar-custom .navbar-toggle {
    display: block !important;
    margin-right: 15px !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,0.35) !important;
    background: rgba(255,255,255,0.08) !important;
  }

  .navbar-header {
    float: none !important;
  }

  .navbar-left,
  .navbar-right {
    float: none !important;
  }

  .navbar-collapse {
    border-top: 1px solid rgba(255,255,255,0.12) !important;
    box-shadow: none !important;
  }

  .navbar-fixed-top .navbar-collapse {
    max-height: calc(100vh - 70px) !important;
    overflow-y: auto !important;
  }

  .navbar-collapse.collapse {
    display: none !important;
  }

  .navbar-collapse.collapse.in {
    display: block !important;
  }

  .navbar-nav {
    float: none !important;
    margin: 14px 0 10px !important;
  }

  .navbar-nav > li {
    float: none !important;
  }

  .navbar-custom .nav > li > a {
    font-size: 12px !important;
    letter-spacing: 0.06em !important;
    padding: 12px 0 !important;
    text-align: left !important;
  }

  .navbar-custom .container {
    width: 92% !important;
  }
}

/* Para desktop largo mantém menu horizontal, um pouco mais legível */
@media (min-width: 1281px) {
  .navbar-custom .nav > li > a {
    font-size: 10px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
    letter-spacing: 0.04em !important;
  }
}


/* =========================================================
   MDA MOBILE ALIGNMENT FIX
   Uniformiza margens laterais em mobile
   ========================================================= */

@media (max-width: 768px) {

  /* Mesmo comportamento para todas as secções */
  .content-section,
  .download-section,
  .noticias-section,
  .venue-section,
  .equipa-section {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Containers todos com a mesma largura/margem */
  .content-section > .container,
  .download-section > .container,
  .noticias-section > .container,
  .venue-section > .container,
  .equipa-section > .container,
  section.container.content-section {
    width: 100% !important;
    max-width: none !important;
    padding-left: 26px !important;
    padding-right: 26px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Remove margens negativas do Bootstrap que causam desalinhamentos */
  .content-section .row,
  .download-section .row,
  .noticias-section .row,
  .venue-section .row,
  .equipa-section .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Colunas sempre alinhadas pelo mesmo eixo */
  .content-section [class*="col-"],
  .download-section [class*="col-"],
  .noticias-section [class*="col-"],
  .venue-section [class*="col-"],
  .equipa-section [class*="col-"] {
    float: none !important;
    width: 100% !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Textos sem max-width/margens herdadas que deslocam blocos */
  .content-section p,
  .download-section p,
  .noticias-section p,
  .venue-section p,
  .equipa-section p,
  .content-section h2,
  .download-section h2,
  .noticias-section h2,
  .venue-section h2,
  .equipa-section h2 {
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: left !important;
  }

  /* Sponsors continua centrado */
  #sponsors,
  #sponsors h2,
  #sponsors p {
    text-align: center !important;
  }

  /* Evita excesso de espaço vertical em mobile */
  .content-section,
  .venue-section {
    padding-top: 150px !important;
    padding-bottom: 90px !important;
  }

  .download-section,
  .noticias-section,
  .venue-section {
    padding-top: 120px !important;
    padding-bottom: 90px !important;
  }
}


/* =========================================================
   MDA LOCATION / DATE REFINEMENT
   ========================================================= */

.intro .intro-body .intro-text {
    font-size: clamp(22px, 1.4vw, 28px) !important;
    line-height: 1.45 !important;
    margin-top: 28px !important;
    font-weight: 400 !important;
    text-shadow:
        0 0 10px rgba(0,0,0,0.9),
        0 0 20px rgba(0,0,0,0.7);
}

.intro .intro-body .intro-text .location {
    display: inline-block;
    font-size: 1em;
    opacity: 0.96;
}

.intro .intro-body .intro-text .date {
    display: inline-block;
    font-size: 0.92em;
    opacity: 0.88;
    margin-top: 2px;
}

/* Ajuste específico para larguras médias */
@media (min-width: 1000px) and (max-width: 1500px) {

    .intro .intro-body .intro-text {
        font-size: clamp(24px, 1.55vw, 30px) !important;
        line-height: 1.5 !important;
    }

    .intro .intro-body .intro-text .location {
        font-size: 1em !important;
    }

    .intro .intro-body .intro-text .date {
        font-size: 0.9em !important;
    }
}

/* Mobile */
@media (max-width: 768px) {

    .intro .intro-body .intro-text {
        font-size: 18px !important;
        line-height: 1.45 !important;
        margin-top: 22px !important;
    }

    .intro .intro-body .intro-text .location {
        font-size: 1em !important;
    }

    .intro .intro-body .intro-text .date {
        font-size: 0.9em !important;
    }
}


/* =========================================================
   MDA COMMITTEE LIST
   ========================================================= */

.committee-heading {
  display: block;
  margin-top: 42px;
  margin-bottom: 28px;
  color: #9f7a3a;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.95em;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.committee-list {
  column-count: 2;
  column-gap: 72px;
  max-width: 980px;
  margin-top: 8px;
}

.committee-member {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  margin-bottom: 24px;
}

.member-name {
  display: block;
  color: rgba(255,255,255,0.96);
  font-weight: 700;
  line-height: 1.28;
}

.member-affiliation {
  display: block;
  margin-top: 4px;
  color: rgba(255,255,255,0.58);
  font-size: 0.92em;
  line-height: 1.45;
}

@media (max-width: 900px) {
  .committee-list {
    column-count: 1;
    column-gap: 0;
  }

  .committee-member {
    margin-bottom: 22px;
  }
}


/* =========================================================
   MDA COMMITTEE LIST — SIZE FIX
   ========================================================= */

.committee-heading {
  margin-top: 56px !important;
  margin-bottom: 36px !important;
  font-size: 1.05em !important;
  letter-spacing: 0.09em !important;
}

.committee-list {
  column-count: 2 !important;
  column-gap: 78px !important;
  max-width: 1040px !important;
  font-size: 16px !important;
  line-height: 1.45 !important;
}

.committee-member {
  margin-bottom: 28px !important;
}

.member-name {
  font-size: 1em !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: rgba(255,255,255,0.96) !important;
}

.member-affiliation {
  font-size: 0.9em !important;
  line-height: 1.45 !important;
  margin-top: 5px !important;
  color: rgba(255,255,255,0.68) !important;
}

@media (min-width: 1200px) {
  .committee-list {
    font-size: 17px !important;
  }
}

@media (max-width: 900px) {
  .committee-list {
    column-count: 1 !important;
    font-size: 16px !important;
  }

  .committee-member {
    margin-bottom: 24px !important;
  }
}





/* =========================================================
   MDA TYPOGRAPHY BALANCED
   ========================================================= */

/* Texto geral ligeiramente maior */
body {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Conteúdo */
.content-section p,
.download-section p,
.venue-section p,
.equipa-section p,
.noticias-section p {
  font-size: 19px !important;
  line-height: 1.72 !important;
}

/* Menu desktop */
@media (min-width: 1200px) {

  .navbar-custom .nav > li > a {
    font-size: 11px !important;
    letter-spacing: 0.045em !important;
  }

  .committee-list {
    font-size: 18px !important;
  }

  .member-name {
    font-size: 1.02em !important;
  }

  .member-affiliation {
    font-size: 0.98em !important;
    line-height: 1.6 !important;
  }
}

/* Mobile mantém equilíbrio */
@media (max-width: 768px) {

  .content-section p,
  .download-section p,
  .venue-section p,
  .equipa-section p,
  .noticias-section p {
    font-size: 17px !important;
    line-height: 1.7 !important;
  }
}



.hero-logo-main{
    width: clamp(180px, 24vw, 420px);
    height:auto;
    display:block;
    margin:0 auto 2px auto;
    opacity:.94;
    transition:width .35s ease;
}

@media(max-width:1400px){
 .hero-logo-main{
   width:clamp(170px,26vw,380px);
 }
}

@media(max-width:768px){
 .hero-logo-main{
   width:min(52vw,260px);
   margin-bottom:0;
 }
}

@media(max-width:480px){
 .hero-logo-main{
   width:58vw;
 }
}



/* =========================================================
   MDA HERO LOGO — FINAL OVERRIDE
   ========================================================= */

.intro .intro-body .brand-heading .hero-logo-main,
.hero-logo-main {
    width: clamp(180px, 24vw, 420px) !important;
    max-width: 420px !important;
    height: auto !important;
    display: block !important;
    margin: 0 auto 2px auto !important;
    opacity: .94 !important;
}

@media(max-width:1400px){
    .intro .intro-body .brand-heading .hero-logo-main,
    .hero-logo-main {
        width: clamp(170px, 26vw, 380px) !important;
        max-width: 380px !important;
    }
}

@media(max-width:768px){
    .intro .intro-body .brand-heading .hero-logo-main,
    .hero-logo-main {
        width: min(52vw, 260px) !important;
        max-width: 260px !important;
        margin-bottom: 0 !important;
    }
}

@media(max-width:480px){
    .intro .intro-body .brand-heading .hero-logo-main,
    .hero-logo-main {
        width: 58vw !important;
        max-width: 240px !important;
    }
}


/* =========================================================
   MDA HERO — structural logo/title spacing fix
   Logo separado do H1 para controlar melhor o espaçamento
   ========================================================= */

.intro .intro-body .hero-logo-main {
    width: clamp(180px, 24vw, 420px) !important;
    max-width: 420px !important;
    height: auto !important;
    display: block !important;
    margin: 0 auto -34px auto !important;
    opacity: .94 !important;
}

.intro .intro-body .brand-heading {
    margin-top: 0 !important;
    margin-bottom: 26px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.intro .intro-body .brand-heading .heading-light {
    margin-top: 0 !important;
    margin-bottom: 10px !important;
}

@media(max-width:1400px){
    .intro .intro-body .hero-logo-main {
        width: clamp(170px, 26vw, 380px) !important;
        max-width: 380px !important;
        margin-bottom: -28px !important;
    }
}

@media(max-width:768px){
    .intro .intro-body .hero-logo-main {
        width: min(52vw, 260px) !important;
        max-width: 260px !important;
        margin-bottom: -18px !important;
    }

    .intro .intro-body .brand-heading {
        margin-bottom: 22px !important;
    }
}

@media(max-width:480px){
    .intro .intro-body .hero-logo-main {
        width: 58vw !important;
        max-width: 240px !important;
        margin-bottom: -12px !important;
    }
}


/* =========================================================
   MDA HERO — final optical adjustment
   Aproxima logo/subtítulo e sobe ligeiramente o bloco
   ========================================================= */

.intro .intro-body {
    transform: translateY(-35px) !important;
}

.intro .intro-body .hero-logo-main {
    margin-bottom: -48px !important;
}

@media(max-width:1400px){
    .intro .intro-body {
        transform: translateY(-30px) !important;
    }

    .intro .intro-body .hero-logo-main {
        margin-bottom: -40px !important;
    }
}

@media(max-width:768px){
    .intro .intro-body {
        transform: translateY(-20px) !important;
    }

    .intro .intro-body .hero-logo-main {
        margin-bottom: -24px !important;
    }
}

@media(max-width:480px){
    .intro .intro-body {
        transform: translateY(-12px) !important;
    }

    .intro .intro-body .hero-logo-main {
        margin-bottom: -18px !important;
    }
}


/* =========================================================
   MDA LOGO — sombra alinhada com o título
   ========================================================= */

.intro .intro-body .hero-logo-main{
    filter:
        drop-shadow(0 2px 4px rgba(0,0,0,0.95))
        drop-shadow(0 10px 28px rgba(0,0,0,0.75));

    opacity:.96 !important;
}
