@layer reset {
  html { scroll-behavior: smooth; }
  @media screen and (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
  *, *::before, *::after {    
    margin: 0; padding: 0; box-sizing: border-box;
    list-style: none; text-align: start;
  }
}

@font-face {
  font-family: 'Roboto-Thin';
  src: url('https://fonts.gstatic.com/s/roboto/v51/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3yUBA.woff2') format('woff2');
  font-weight: 100;
  font-style: normal;
  font-display: optional; /* 'auto' | 'block' | 'swap' | 'fallback' | 'optional' */
}

@layer variables {
  :root {
    --font-size: 1rem;
    --fnt-sign: "Saira", sans-serif;
    --fnt-body: "Jost", sans-serif;
    --clr-current_mix: color-mix(in srgb, currentColor 70%, transparent);
    --clr-1: #FFFAFA;
    --clr-2: #B9CFD4;
    --clr-3: #120D0F;
    --clr-4: #fba002;
    --clr-4-light: hsl(from var(--clr-4) h s l / .5);

    --clr-transp: #120d0f31;
    --clr-smooth-line: 1px solid color-mix(in hsl shorter hue, var(--clr-4) 30%, var(--clr-transp) 90%);
    --blur: blur(1.5px);
    --backdrop-filter: blur(5px);
    --glass-frost: 5px;
    --glass-surface: rgba(251, 160, 2, 0.15);
    --glass-iridescent-opacity: 1.8;

    /* form */
    --clr-aviso: #ff6b6b;
    --clr-aviso-brdr: color-mix(in srgb, var(--clr-aviso) 35%, var(--clr-transp) 65%) !important;
    --clr-aviso-bg: color-mix(in srgb, var(--clr-aviso) 25%, var(--clr-transp) 85%) !important;
    --clr-sucesso: #64c878;
    --clr-sucesso-bg: color-mix(in srgb, var(--clr-sucesso) 25%, var(--clr-transp) 85%);

    /* social */
    --clr-social_wa:#25D366;
    --clr-social_wa_shdw:0 0 20px 5px color-mix(in hsl shorter hue, var(--clr-social_wa) 30%, transparent 90%);

    --clr-social_ig:hsl(322, 70%, 49%);
    --clr-social_ig_shdw:0 0 20px 5px color-mix(in hsl shorter hue, var(--clr-social_ig) 30%, transparent 90%);

    --clr-social_fb:#3b5998;
    --clr-social_fb_shdw:0 0 20px 5px color-mix(in hsl shorter hue, var(--clr-social_fb) 30%, transparent 90%);

    --clr-social_tt:#2590d3;
    --clr-social_tt_shdw:0 0 20px 5px color-mix(in hsl shorter hue, var(--clr-social_tt) 30%, transparent 90%);

    /* light/dark mode */
    --light-bg: var(--clr-2);
    --dark-bg: var(--clr-1);

    --bg_pattrn: url(./src/logo/logo_dark2.svg);
    --bg_pttrn_size: 1;
    --bg_pttrn_calc: calc(var(--icon-size-logo) * var(--bg_pttrn_size));

    --tempo: 300ms;
    --section-anim-in: 10%;
    --section-anim-full: 35%;

    --icon-size: 2rem ;
    --icon-font-size: 1.5rem;
    --icon-padding: .5rem 1rem;
    --icon-font-size-small: 1rem;
    --icon-size-logo: 3rem;
    --icon-logo-hamb-size: 2.5rem;    
    --size-user-avatar: 1.625rem;

    --fs-h1: clamp(2rem, 4vw, 5rem);
    --fs-h1-big: clamp(2.5rem, 5vw, 6rem);
    --fs-h2: calc(var(--fs-h1) - 0.5rem);
    --fs-h2-big: var(--fs-h1);
    --fs-h3: calc(var(--fs-h2) - 0.25rem);
    --fs-h4: calc(var(--fs-h3) - 0.25rem);
    --fs-h5: calc(var(--fs-h4) - 0.125rem);
    --fs-h6: calc(var(--fs-h5) - 0.125rem);

    --font-weight: 800;
    --margin-block-element: 2rem;
    --margin-block-section: 1rem;
    --container-max: 1440px;
    --container-mid: 1024px;
    --container-height: 100svh;
    --gap-items: 1.2rem;
    --border-size: 1.5px solid;
    --border-radius: 0.25rem 0.75rem 0.25rem 1.125rem;
    --bx-sdw: inset 0 0 0 1px var(--clr-3), 0 2px 4px var(--clr-3), 0 8px 14px var(--clr-3);
    interpolate-size: allow-keywords;

  }
}

@layer global {
  html {
    color-scheme: light dark;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    * { scroll-margin-top: 1rem; scroll-behavior: smooth; }
  }
  h1, h2, h3, h4, h5, h6, .title { color: var(--clr-1); }
  body, ul, li, p, h1, a { color: var(--clr-2); }
  body, ul, li, a, .title { margin: 0; padding: 0; list-style: none; text-decoration: none; }
  body, p, .eyebrow { font-family: var(--fnt-body); }
  h1, .h1-big, h2, h3, .title { text-wrap: balance; font-family: var(--fnt-sign); }
  h1, h2, h3, ul, li, .title { font-weight: 500; text-transform: uppercase; }
  body { font-size: clamp(.75rem, .3361vw + .6975rem, 1rem); background: light-dark(var(--light-bg), var(--dark-bg)); }
  h1, h2, h3, h4, h5, h6, .title { line-height: 1.2; text-align: center; letter-spacing: .1em; }
  h1 { font-size: var(--fs-h1); }
  .h1-big { font-size: var(--fs-h1-big); font-weight: 600; line-height: 1.04em; text-align: left; letter-spacing: -0.01em; }
  h2 { margin-block: 20px .35em; font-size: var(--fs-h2); }
  .h2-big { font-size: var(--fs-h2-big); font-weight: 600; }
  h3 { font-size: var(--fs-h3); }
  h4 { font-size: var(--fs-h4); font-weight: 400; }
  h5 { font-size: var(--fs-h5); font-weight: 300; }
  h6, .eyebrow-small { font-size: var(--fs-h6); font-weight: 200; }
  .title { font-size: clamp(1.5rem, 3vw, 4rem); font-weight: 600; }
  p, .p-small, .p-large { line-height: 1.5; text-align: center; letter-spacing: .1em; }
  p { margin-bottom: .7em; font-size: 1rem; font-weight: 500; text-wrap: balance; }
  .p-small { font-size: 0.6rem; font-weight: 300; }
  .p-large { font-size: 1.2rem; font-weight: 600; }
  .eyebrow { margin-bottom: 1.25rem; font-size: 0.9rem; font-weight: 400; line-height: 1.3; text-align: center; letter-spacing: .01em; text-transform: uppercase; color: var(--clr-current_mix); }
  .eyebrow-small { margin-bottom: 1.25rem; font-size: 0.6rem; font-weight: 300; line-height: 1.3; text-align: center; letter-spacing: .01em; text-transform: uppercase; color: var(--clr-current_mix); }
  li, a { font-size: 1.2rem; font-weight: 400; font-family: var(--fnt-body); cursor: pointer; color: var(--clr-1); &:hover { text-decoration: underline; } }

  .golden-border {
    position: relative;
    border-radius: 4px 12px 4px 18px;
    padding: 1rem;
    background-image:
            linear-gradient(var(--clr-3), var(--clr-3)),
            linear-gradient(
              145deg,
              rgba(185, 207, 212, 0.836) 10%,
              rgba(251,160,2,0.3) 60%,
              rgba(255,255,255,0.1));
    background-origin: border-box;
    background-clip: padding-box, border-box;
    border: 1px solid var(--clr-transp);
    overflow: hidden;
  } 

  main, footer { 
    margin-block: var(--margin-block-element); 
    max-width: 1440px;
    text-align: center; 
  }
  section, .container {    
    scroll-margin-top: 2.5rem;
    width: 100%; max-width: var(--container-max);
    padding: 1rem;
    margin-inline: auto; 
    display: grid; gap: var(--gap-items);
    place-items: center; text-align: center;

    &.glass { padding-inline: var(--margin-block-section);
      scroll-margin-top: 3rem; 
    }
    &:has(.golden-border) { padding-inline: var(--margin-block-section); }
  }

  section {
    view-timeline-name: --reveal;
    view-timeline-axis: block;
    animation: reveal linear both;
    animation-timeline: --reveal;
    animation-range: entry var(--section-anim-in) cover var(--section-anim-full);
  }

  .modalidade-item, button, a {
    transition: color var(--tempo) ease,
                background-color var(--tempo) ease,
                box-shadow var(--tempo) ease,
                border-color var(--tempo) ease,
                transform var(--tempo) ease,
                backdrop-filter var(--tempo) ease;
  }
  .fatia {
    will-change: opacity, transform, flex;
    transition: clip-path 500ms cubic-bezier(0.4, 0, 0.2, 1),
                flex 500ms cubic-bezier(0.4, 0, 0.2, 1),
                opacity 300ms ease;
  }
}

@layer multimedia {
  img, video { width: 100%; height: 100%; display: block; object-fit: cover; }
  img { vertical-align: middle; }
  [popover] { position: relative; position-anchor: auto; width: fit-content;
    height: fit-content; color: canvastext; background-color: var(--clr-transp);
    inset: 0px; border: var(--clr-transp); padding: 0.25em; overflow: auto;
  }
  a { align-items: center; }
}

@layer actions {
  button, .btn {
    padding: 0.5rem 0.8rem;
    place-items: center;
    font-size: var(--font-size);
    font-family: var(--fnt-body);
    text-decoration: none;
    text-align: center;
    text-transform: uppercase;
    cursor: pointer;
    list-style: none;
    color: var(--clr-4);
    background: none;
    border-radius: var(--border-radius);
    transition: color var(--tempo) ease, background-color var(--tempo) ease, box-shadow var(--tempo) ease, border-color var(--tempo) ease, transform var(--tempo) ease, backdrop-filter var(--tempo) ease;
    * { fill: var(--clr-4); }
    &:hover { backdrop-filter: var(--backdrop-filter); box-shadow: var(--bx-sdw); color: var(--clr-2); fill: var(--clr-2) !important; }
    &:active { transform: scale(0.95); color: var(--clr-2); background: var(--clr-4); }
    &:focus-visible, &:focus { outline: var(--border-size) var(--clr-5); backdrop-filter: var(--backdrop-filter); outline-offset: 2px; border-color: var(--clr-4) !important; }
    &.btn-primary { margin-top: 2rem; }
    &.btn-small { padding: 5px 10px; font-size: 0.8rem; }
    &.btn_large { padding: 16px 24px; font-size: 1.2rem; }
    
  }

  .icon, .icon-small {
    padding: var(--icon-padding);
    background-color: var(--clr-3);
  }
  .icon { font-size: var(--icon-font-size); }
  .icon-small { font-size: var(--icon-font-size-small); }

  .logo {
    height: var(--icon-size-logo);
    padding: 0px; border: var(--clr-transp);
    inline-size: 4rem; aspect-ratio: 1; object-fit: contain;
    image { height: auto; width: auto; }
    &::after { background: none; }
    &.btn { * { fill: var(--clr-3) !important; color: var(--clr-3); } }
    &.btn:active { transform: scale(0.95); color: var(--clr-2); background: var(--clr-4); }
    &.btn:focus-visible, .logo.btn:focus { outline: var(--border-size) var(--clr-4); outline-offset: -1px; }
  }
  .hamburger {
    padding: 10px;
    height: var(--icon-logo-hamb-size);
    width: calc(var(--icon-size) + 10px);
    display: none; flex-direction: column;
    justify-content: space-between; align-items: stretch; gap: 5px;
    cursor: pointer; border-radius: var(--border-radius);
    border: var(--border-size) transparent;
    transition: transform var(--tempo) ease, box-shadow var(--tempo) ease, backdrop-filter var(--tempo) ease;
    z-index: 100; list-style: none;
    &::-webkit-details-marker { display: none; }
    span {
      display: block; width: 100%; height: 2px;
      background: var(--clr-1); border-radius: 2px;
      transition: transform var(--tempo) ease, opacity var(--tempo) ease, background-color var(--tempo) ease;
    }
    &:hover { span { background-color: var(--clr-2); } }
    &:active { transform: scale(0.95); }
    &:focus-visible { outline: var(--border-size) var(--clr-4); outline-offset: 4px; backdrop-filter: var(--backdrop-filter); box-shadow: var(--bx-sdw); }
  }
  /* .btn-primary { margin-top: 2rem; }
  .btn-small { padding: 5px 10px; font-size: 0.8rem; }
  .btn_large { padding: 16px 24px; font-size: 1.2rem; } */
  .link-btn {
    padding-inline: 7px; color: var(--clr-1); font-weight: 400; letter-spacing: .01em; font-size: 0.9rem;
    background: transparent; border: var(--border-size) transparent;
    border-radius: calc(var(--border-radius) / 2); cursor: pointer;
    transition: color var(--tempo) ease, box-shadow var(--tempo) ease, backdrop-filter var(--tempo) ease;
    &:hover { color: var(--clr-2); backdrop-filter: var(--backdrop-filter); border: var(--border-size) transparent; border-radius: var(--border-radius); text-decoration-color: var(--clr-4); text-underline-offset: .725rem; box-shadow: var(--bx-sdw); }
    &:focus-visible, :active { color: var(--clr-4); text-decoration: underline; text-decoration-color: var(--clr-4); text-underline-offset: .725rem; }
  }
}

@layer glass {
  .glass {
    position: relative; overflow: hidden; border-radius: var(--border-radius);
    background: var(--clr-transp); border-color: transparent;
    * { position: relative; z-index: 2; }

  }
  .glass::before {
    content: ""; position: absolute; inset: 0; border-radius: inherit;
    backdrop-filter: blur(var(--glass-frost)) !important; -webkit-backdrop-filter: blur(var(--glass-frost)) !important;
    filter: url(#glass-filter);
    background: linear-gradient(145deg, var(--glass-surface) 0%, rgba(185,207,212,0.04) 40%, rgba(251,160,2,0.03) 100%);
    pointer-events: none; z-index: -1;
  }
  .glass::after {
    content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px;
    background: linear-gradient(145deg, rgba(255,255,255, var(--glass-iridescent-opacity)), rgba(185,207,212,0.2) 30%, rgba(251,160,2,0.3) 60%, rgba(255,255,255,0.1));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; z-index: 1;
  }
}

@layer animations {
  @keyframes change {
    0%   { transform: translateY(0); }
    20%  { transform: translateY(-1em); }
    40%  { transform: translateY(-2em); color: var(--clr-1); }
    60%  { transform: translateY(-3em); }
    80%  { transform: translateY(-4em); color: var(--clr-4); }
    100% { transform: translateY(0); }
  }
  @keyframes reveal {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  @keyframes pop-in {
    from { opacity: 0; transform: translateX(-50%) translateY(0) scale(0.9); }
    to   { opacity: 1; transform: translateX(-50%) translateY(-10px) scale(1); }
  }
  @starting-style {
    details[open] .local { opacity: 0; transform: translateY(-15px); }
  }
}
.hidden { display: none !important; }

body {
  position: relative; background: var(--clr-3);
  &::before {
    content: ""; position: absolute; inset: 0;
    background: var(--bg_pattrn) top left / var(--bg_pttrn_calc) auto repeat;
    opacity: 0.05; z-index: -1;
  }
  .welcome-intro {
    position: relative; z-index: 3; margin-inline: auto;
    width: 100%; height: 100vh;
    display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 1rem;
  }
  .q_a { 
    position: fixed; z-index: 150; bottom: 1rem; right: 1rem; 
    display: grid;
    justify-items: end;
    color: var(--clr-4); gap: var(--gap-items);  
  }
}

@layer media {
  @media ( prefered-color-scheme: light) {
    :root {
      --clr-4: red;
      --clr-2: blue ;
      --clr-3: lime ;
      --clr-1: oldlace ;
      --bg_pattrn: url(./src/logo/logo_light2.svg);
    }
  }
}

/* ============================================
   AUTH.CSS
   Depende de style.css: variáveis, .btn, .glass,
   .hidden, tipografia, .campo (definido aqui)
   
   TRUQUE CSS — toggle Login/Signup sem JS:
   #mode-login e #mode-signup são filhos de
   .welcome (antes de .welcome-panel), logo são
   irmãos de .welcome-panel com o selector ~.
   Nestado dentro de .welcome {} funciona porque
   CSS nesting resolve para:
   .welcome #mode-signup:checked ~ .welcome-panel
   ============================================ */

.welcome {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: grid;
  place-items: center;
  padding: 1rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease, visibility 0.5s;

  /* ── Estado visível (JS adiciona .visible) ── */
  &.visible {
    opacity: 1;
    visibility: visible;

    & .welcome-panel {
      transform: translateY(0) scale(1);
    }
  }

  /* ── Fundo escuro clicável ────────────────── */
  & .welcome-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(18, 13, 15, 0.88);
    backdrop-filter: blur(4px);
    cursor: pointer;
  }

  /* ── Painel central ───────────────────────── */
  & .welcome-panel {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 480px;
    max-height: 92svh;
    overflow-y: auto;
    padding: 2rem;
    border-radius: 0.25rem 1.5rem 0.25rem 2rem;
    border: 1.5px solid var(--glass-surface);
    background: var(--clr-transp);
    transform: translateY(20px) scale(0.97);
    transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
    scrollbar-width: thin;
    scrollbar-color: var(--clr-4) transparent;

    /* Cabeçalho: logo + botão fechar */
    & .welcome-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 1.5rem;

      & .welcome-logo {
        height: 2.5rem;
        width: auto;
        object-fit: contain;
      }

      /* Herda .btn .icon .glass de style.css */
      & #welcome-skip {
        opacity: 0.6;
        &:hover { opacity: 1; }
      }
    }

    /* Título */
    & .welcome-hero {
      margin-bottom: 1.75rem;

      & h2 {
        font-size: clamp(1.1rem, 3vw, 1.5rem);
        letter-spacing: 0.12em;
        color: var(--clr-2);
        line-height: 1.3;

        & span { color: var(--clr-4); font-style: italic; }
      }
    }

    /* Tabs Login / Criar Conta */
    & .auth-tabs {
      display: flex;
      margin-bottom: 1.5rem;
      border-bottom: 1.5px solid rgba(251, 160, 2, 0.2);

      & .auth-tab {
        flex: 1;
        padding: 0.6rem 1rem;
        text-align: center;
        font-size: 0.78rem;
        font-weight: 500;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: var(--clr-2);
        cursor: pointer;
        opacity: 0.55;
        border-bottom: 2px solid transparent;
        position: relative;
        bottom: -1.5px;
        transition: color var(--tempo) ease,
                    opacity var(--tempo) ease,
                    border-color var(--tempo) ease;

        &:hover { opacity: 0.85; color: var(--clr-1); }
      }
    }

    /* Botão de submissão — herda .btn .glass */
    & .auth-form {
      gap: 1rem;

      & button[type="submit"] {
        margin-top: 0.5rem;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.5rem;
      }
    }
  }

  /* ── Toggle formulários (CSS-only) ──────────
     Os radios são filhos de .welcome, antes de
     .welcome-panel → são irmãos dele via ~
  ── */
  & .login-form  { display: grid; }
  & .signup-form { display: none; }

  & #mode-signup:checked ~ .welcome-panel {
    & .signup-form { display: grid; }
    & .login-form  { display: none; }
  }

  /* Tab activa */
  & #mode-login:checked  ~ .welcome-panel label[for="mode-login"]  {
    color: var(--clr-4);
    opacity: 1;
    border-bottom-color: var(--clr-4);
  }
  & #mode-signup:checked ~ .welcome-panel label[for="mode-signup"] {
    color: var(--clr-4);
    opacity: 1;
    border-bottom-color: var(--clr-4);
  }
}

/* ============================================
   COMPONENTES REUTILIZÁVEIS
   Usados em: auth, user/perfil, user/treinos,
   contactos — definidos UMA vez aqui
   ============================================ */

/* Campo (label + input/select/textarea) */
.campo {
  display: grid;
  gap: 0.35rem;

  & label {
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--clr-2);
    opacity: 0.7;
    cursor: default;
  }

  & input,
  & select,
  & textarea {
    width: 100%;
    padding: 0.6rem 0.85rem;
    background: rgba(18, 13, 15, 0.6);
    border: 1.5px solid rgba(185, 207, 212, 0.12);
    border-bottom-color: var(--clr-smooth-line);
    border-radius: 0.25rem 0.5rem 0.25rem 0.75rem;
    color: var(--clr-1);
    font-family: var(--fnt-body);
    font-size: 0.9rem;
    outline: none;
    resize: none;
    transition: border-color var(--tempo) ease,
                box-shadow var(--tempo) ease;

    &:focus {
      border-color: var(--clr-4);
      box-shadow: 0 0 0 2px rgba(251, 160, 2, 0.1);
    }

    &::placeholder {
      color: var(--clr-2);
      opacity: 0.35;
    }

    & option { background: var(--clr-3); color: var(--clr-1); }
  }
}

/* Dois campos lado a lado */
.campos-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;

  @media (max-width: 420px) { grid-template-columns: 1fr; }
}

/* Texto "(opcional)" junto à label */
.opt {
  color: var(--clr-4);
  font-size: 0.6rem;
  opacity: 0.7;
  text-transform: lowercase;
  letter-spacing: 0;
}

/* Mensagem de erro inline */
.form-error {
  font-size: 0.75rem;
  color: var(--clr-aviso);
  padding: 0.5rem 0.75rem;
  background: rgba(255, 107, 107, 0.08);
  border-left: 2px solid var(--clr-aviso);
  border-radius: 4px;
  margin: 0;
}



header {
  position: relative; height: var(--container-height);
  display: grid; align-content: space-between; z-index: 2;

  .bg {
    position: absolute; height: calc(var(--container-height) - 30px);
    top: 0; left: 0; z-index: -1;
    border-radius: 0 0 4px 18px; box-shadow: var(--bx-sdw); filter: brightness(0.5);
  }

  nav {
    width: 100%; max-width: 1440px; margin-inline: auto; padding: var(--gap-items);
    display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end;
    justify-content: space-between;
    * { text-transform: uppercase; }

    .mobile-nav { display: none; }

    .nav-content {
      max-width: 1200px; padding: 0.5rem 1rem;
      display: inline-flex; box-shadow: var(--bx-sdw); justify-content: space-around;
      .menu { display: inline-flex; align-items: center; }
      span { border-left: var(--border-size) var(--clr-4); border-right: var(--border-size) var(--clr-4); }

      .login-sign_up { 
        margin-inline: .5rem; display: flex;

        /* Avatar no nav após login */
        .nav-user-avatar {
          display: inline-flex;
          align-items: center;
          text-decoration: none;
          border: none;
          background: transparent;
          cursor: pointer;

          & .coach-avatar {
            width: var(--size-user-avatar);
            height: var(--size-user-avatar);
            border-radius: 50%;
            border: 2px solid var(--clr-4);
            background-size: cover;
            background-position: center;
            background-color: var(--clr-3);
            display: grid;
            place-items: center;
            font-size: 0.75rem;
            font-weight: 700;
            color: var(--clr-4);
            transition: transform var(--tempo) ease, border-color var(--tempo) ease;
          }

          &:hover .coach-avatar {
            transform: scale(1.1);
            border-color: var(--clr-1);
          }
        }
      }
    }

    @media (max-width: 700px) {
      .mobile-nav { display: block; }
      .nav-content {
        display: none; position: absolute; top: 70px; left: 0; right: 0; padding: 2rem 1rem;
        flex-direction: column; align-items: center; gap: 2rem;
        border-radius: var(--border-radius); box-shadow: var(--bx-sdw); z-index: 99;
      }
      .login-sign_up { display: flex; gap: var(--gap-items); }
      .menu { flex-direction: column; align-items: center; gap: var(--gap-items); }
      &:has(.mobile-nav[open]) .nav-content {
        display: flex; margin-inline: auto;
        span { width: 200px; border: var(--border-size) var(--clr-4); }
      }
      .mobile-nav[open] > summary span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
      .mobile-nav[open] > summary span:nth-child(2) { opacity: 0; }
      .mobile-nav[open] > summary span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
      .hamburger { display: flex; }
    }
  }

  .hero {
    position: relative;
    padding: 0px 16px 150px 16px;
    display: flex; flex-direction: column; justify-content: flex-end; align-items: flex-start;
    gap: 4rem; container-type: inline-size;
    * { padding-inline: 20px; }
    .text_anim {
      width: 100%; padding: 0px; display: flex; flex-wrap: wrap; align-items: flex-start;
      text-transform: uppercase; gap: 10px; font-size: clamp(2.5rem, 5vw, 6rem); line-height: 1;
      * { margin: 0px; padding: 0px; line-height: inherit; }
      .hiit { font-style: italic; color: var(--clr-2); }
      .list_text {
        height: 0.8em; display: grid; justify-items: start; align-items: start; overflow: hidden; position: relative;
        .text { color: var(--clr-1); animation: change 3.5s ease-in-out infinite; white-space: nowrap; }
      }
    }
  }
  #map {
    position: absolute; width: 100%; padding-inline: 1rem; margin-inline: auto;
    max-width: var(--container-mid); transform: translateY(200rem); top: calc(var(--container-height) -20px);
    display: grid; justify-items: stretch; z-index: 10; gap: 1rem; place-self: center;
  
    summary {
      place-self: center; 
      &::-webkit-details-marker { display: none; }    
    }
    .local {
      --min-height: 400px;
      position: relative; width: 100%; max-width: var(--container-max);
      min-height: var(--min-height); padding: 1px; margin-inline: auto;
      border-radius: var(--border-radius); overflow: unset; box-shadow: var(--bx-sdw);
      opacity: 1; transform: translateY(0);
      transition: opacity 0.35s ease, transform 0.35s ease;

      &::before {
        content: ' ';
        position: absolute; width: 100%; height: 100%; z-index: -1;
        border-radius: var(--border-radius);
        box-shadow: 0px 0px 150px 200px rgba(0, 0, 0, 0.5);
      }

      
      iframe { width: 100%; min-height: var(--min-height); border-radius: var(--border-radius); }
      
      &.closing { opacity: 0; transform: translateY(-15px); pointer-events: none; }
      .local-info {
        position: absolute; max-width: 300px; width: auto; height: auto;
        padding: 1rem; margin: 1rem; display: flex; flex-wrap: wrap; justify-content: center;
        gap: var(--gap-items); right: 0; top: 0; background: var(--clr-3);
        border-radius: var(--border-radius); box-shadow: var(--bx-sdw); align-items: flex-end;
        * { margin: 0px; padding: 0px; }
        .link-btn { text-wrap: nowrap; }
      }
      
      
    }
    
  }
}

main {
  position: relative; margin-inline: auto; width: 100%;
  display: grid; place-items: center; gap: 5rem; z-index: 1;

  /* *{border: var(--border-size);} */
  .sobre {
    --sobre_bg_blocks: color-mix(in srgb, var(--clr-3) 70%, var(--clr-transp) 30%);

    scroll-margin-top: 6rem;
    min-height: calc(var(--container-height) - 5.125rem);
    margin-top: -4rem;

    display: flex;
    flex-wrap: wrap; 
    justify-content: space-between; 
    align-items: flex-end; 
    gap: var(--gap-items);

    color: var(--clr-1);
    * { text-align: start; }
    video {
      background-size: cover; height: auto; min-width: 100%; min-height: 100%;
      -webkit-transform: translateX(-50%) translateY(-50%);
              transform: translateX(-50%) translateY(-50%);
      width: 100%; position: absolute; top: 50%; right: 0; bottom: 0; left: 50%;
    }
    .sobre-text {
      padding: 1rem; max-width: 515px; display: grid; gap: var(--gap-items);
      background: var(--sobre_bg_blocks); z-index: 0;
      h2 { color: var(--clr-2); font-size: clamp(1.25rem, 3vw, 3.125rem);}
      h3 { font-size: clamp(1rem, 2.5vw, 2.125rem); }
    }
    .facts { 
      display: grid;
      grid-template-columns: repeat(2, 1fr); 
      gap: var(--gap-items); z-index: 1; 

      .card {
        padding: 1rem; border: var(--border-size) var(--clr-4);
        border-radius: var(--border-radius); background: var(--sobre_bg_blocks);
        h4 { color: var(--clr-4); font-size: clamp(1rem, 2.275vw, 2rem);} h5 { color: var(--clr-2); font-size: clamp(0.875rem, 2.5vw, 1.5rem);}
      }
    }
  }/* ok */

  .app-promo {
    min-height: 50svh;
    width: 100%;
    max-width: var(--container-max);
    padding: 3rem 2rem;
    margin-inline: auto;

    /* Layout: texto à esquerda, mockup à direita */
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 3rem;

    /* ── Conteúdo (texto + botões) ─────────────── */
    & .app-promo-content {
      flex: 1;
      min-width: 280px;
      max-width: 560px;
      display: grid;
      gap: 1.25rem;
      text-align: start;

      & * { text-align: start; }

      /* Eyebrow */
      & .app-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
        font-size: 0.72rem;
        letter-spacing: 0.2em;
        text-transform: uppercase;
        color: var(--clr-4);

        & i { font-size: 0.9rem; }
      }

      /* Título */
      & h2 {
        font-size: clamp(1.75rem, 4vw, 3rem);
        color: var(--clr-1);
        text-align: start;
        letter-spacing: -0.01em;
        line-height: 1.15;
        margin: 0;

        & span { color: var(--clr-4); font-style: italic; }
      }

      /* Descrição */
      & > p {
        font-size: 0.92rem;
        color: var(--clr-2);
        opacity: 0.8;
        line-height: 1.7;
        max-width: 440px;
        margin: 0;
      }

      /* Botões de acção — herdam .btn .glass */
      & .app-promo-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 0.75rem;
        margin-top: 0.25rem;

        & .btn {
          display: inline-flex;
          align-items: center;
          gap: 0.5rem;

          & i { font-size: 1rem; }
        }
      }

      /* Lista de features */
      & .app-promo-features {
        display: flex;
        flex-wrap: wrap;
        gap: 0.5rem 1.5rem;
        margin-top: 0.25rem;

        & li {
          font-size: 0.78rem;
          color: var(--clr-2);
          opacity: 0.75;
          display: flex;
          align-items: center;
          gap: 0.4rem;
          text-transform: none;
          font-weight: 400;
          letter-spacing: 0.02em;

          & i { color: var(--clr-4); font-size: 0.65rem; }
        }
      }

      /* Fallback de instalação manual */
      & .app-fallback {
        font-size: 0.78rem;
        color: var(--clr-2);
        opacity: 0.6;
        line-height: 1.6;
        margin: 0;
        padding: 0.75rem 1rem;
        border-left: 2px solid rgba(251, 160, 2, 0.3);

        & i    { color: var(--clr-4); margin-right: 0.35rem; }
        & strong { color: var(--clr-1); }
      }
    }

    /* ── Decoração: mockup de telemóvel ─────────── */
    & .app-promo-visual {
      flex-shrink: 0;
      display: flex;
      justify-content: center;
      align-items: center;

      & .app-phone-mock {
        width: 200px;
        height: 360px;
        border-radius: 28px;
        border: 2px solid rgba(251, 160, 2, 0.35);
        padding: 0.75rem;
        position: relative;
        box-shadow:
          inset 0 0 0 1px rgba(255,255,255,0.04),
          0 24px 60px rgba(0,0,0,0.5),
          0 0 0 1px rgba(18,13,15,0.8);

        /* Notch */
        &::before {
          content: '';
          position: absolute;
          top: 10px;
          left: 50%;
          transform: translateX(-50%);
          width: 50px;
          height: 6px;
          background: rgba(251, 160, 2, 0.2);
          border-radius: 100px;
        }

        & .app-phone-screen {
          width: 100%;
          height: 100%;
          border-radius: 20px;          
          background: url(src/screen-app.jpg) no-repeat center / contain;
          border: 1px solid var(--glass-surface);
          display: flex;
          flex-direction: column;
          align-items: center;
          justify-content: center;
          gap: 1.5rem;
          padding: 1.5rem 1rem;
        }
      }
    }

    /* ── Responsividade ─────────────────────────── */
    @media (max-width: 700px) {
      min-height: auto;
      padding: 2.5rem 1.25rem;
      flex-direction: column;
      align-items: flex-start;

      & .app-promo-visual { display: none; }
    }
  }

  .modalidades {
    height: minmax(var(--container-height), auto);

    h2{ font-size: clamp(1.25rem, 2.5vw, 3.5rem); margin-block: 18px 12px;}
    h3{ font-size: clamp(0.75rem, 1.5vw, .8125rem); color: var(--clr-2); 
      margin-top: -1rem; max-width: var(--container-mid); }

    .actividades {
      width: 100%;
      display: grid;
      grid-template-columns: 280px 1fr;
      gap: 2rem; align-items: stretch; min-height: 420px;

      .col-esquerda {
        display: flex; flex-direction: column; position: relative;

        .escolhas {
          display: flex; flex-direction: column;
          padding: 1rem 0 1.5rem 1.5rem; flex: 1;

          .modalidade-item {
            padding: 0.7rem 0; cursor: pointer;

            .link-btn {
              display: block; font-size: 0.78rem; font-weight: 400;
              letter-spacing: 0.14em; text-transform: uppercase; color: var(--clr-1);
              transition: color var(--tempo) ease; padding: 0; border: none; box-shadow: none; backdrop-filter: none;
            }

            .horario-hover {
              display: flex; flex-direction: column; gap: 0.05rem; padding-top: .5rem;
              max-height: 0; opacity: 0; overflow: hidden;
              transition: max-height 0.25s ease, opacity 0.2s ease;
              span { font-size: 0.68rem; font-weight: 300; letter-spacing: 0.08em; text-transform: uppercase; color: var(--clr-2); line-height: 1.9; }
            }

            &:hover {
              .link-btn { color: var(--clr-4); text-decoration: underline; text-decoration-color: var(--clr-4); text-underline-offset: 0.5rem; }
              .horario-hover { max-height: 60px; opacity: 1; }
            }
          }
        }

        #painel {
          display: flex; flex-direction: column; justify-content: space-between;
          align-items: center; gap: 1rem;
          border-left: var(--border-size) var(--clr-4);
          border-bottom: var(--border-size) var(--clr-4);
          border-radius: 0 0 0 1rem; padding: 1.5rem; flex: 1;

          #painel-titulo { color: var(--clr-4); font-size: clamp(1rem, 2vw, 2rem); letter-spacing: 0.08em; text-transform: uppercase; }

          .painel-horarios-bloco {
            display: flex; flex-direction: column; gap: 0.1rem;
            span { font-size: 0.72rem; color: var(--clr-2); font-weight: 300; letter-spacing: 0.08em; text-transform: uppercase; }
          }

          #painel-coaches-lista {
            display: flex; flex-direction: column; gap: 0.35rem; margin-top: 0.25rem;
            li {
              font-size: 0.82rem; color: var(--clr-2); font-weight: 300; letter-spacing: 0.04em;
              &::before { content: "· "; color: var(--clr-4); font-weight: 700; }
            }
          }
        }
      }

      .col-direita {
        min-height: 480px; margin-block: 1rem; margin-right: 1rem;
        display: flex; flex-direction: column; gap: 1rem;

        .imagem-principal {
          flex: 1; display: flex; flex-direction: row; overflow: hidden;
          align-items: stretch;
          border-radius: var(--border-radius); position: relative;
          min-height: 380px; background-color: var(--clr-3);

          &.ativo {
            .fatia:not(.selecionada) { display: none !important; }
            .fatia.selecionada {
              flex: 1;
              clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%) !important;
              .fatia-video { opacity: 1; }
            }
          }

          .fatia {
            flex: 1; position: relative; background-size: cover; background-position: center;
            height: minmax(auto, 380px);
            clip-path: polygon(8% 0%, 100% 0%, 92% 100%, 0% 100%);
            transition: clip-path 500ms cubic-bezier(0.4, 0, 0.2, 1), flex 500ms cubic-bezier(0.4, 0, 0.2, 1), opacity 300ms ease, filter 300ms ease;
            &:first-child { clip-path: polygon(0% 0%, 100% 0%, 92% 100%, 0% 100%); }
            &:last-child  { clip-path: polygon(8% 0%, 100% 0%, 100% 100%, 0% 100%); }
            &::after {
              content: ""; position: absolute; inset: 0;
              background: linear-gradient(to bottom, transparent 40%, rgba(18,13,15,0.7) 100%);
              pointer-events: none; z-index: 1;
            }
            .fatia-video {
              position: absolute; inset: 0; width: 100%; height: 100%;
              object-fit: cover; opacity: 0; z-index: 2;
              transition: opacity 400ms ease 200ms;
            }
          }

          .descricao-overlay {
            position: absolute; padding-block: var(--gap-items);
            bottom: 1.2rem; left: 1.4rem; right: 1.4rem; z-index: 10;
            font-size: 0.75rem; color: var(--clr-1); line-height: 1.8; text-transform: uppercase;
            background: color-mix(in srgb, var(--clr-3) 35%, var(--clr-transp) 65%);
            border-radius: var(--border-radius); backdrop-filter: var(--blur);
            opacity: 0; transform: translateY(8px);
            transition: opacity 0.3s ease, transform 0.3s ease;
            &.visivel { opacity: 1; transform: translateY(0); }
          }
        }

        .coaches-row {
          display: flex; flex-wrap: wrap; gap: 1rem; padding-block: 0.5rem;
          align-items: stretch;

          .coach-wrapper {
            position: relative; display: inline-block;

            .coach-tooltip {
              position: absolute; bottom: calc(100% + 8px); left: 50%;
              transform: translateX(-50%);
              background: var(--clr-4); color: var(--clr-3);
              padding: 0.4rem 0.8rem; border-radius: 4px;
              font-size: 0.72rem; font-weight: 600; text-transform: uppercase;
              white-space: nowrap; pointer-events: none; opacity: 0;
              transition: opacity var(--tempo) ease; z-index: 20;
            }
            &:hover .coach-tooltip { opacity: 1; }

            .coach-avatar {
              width: 50px; height: 50px; border-radius: 50%;
              border: 2px solid var(--clr-4);
              background-size: cover; background-position: center; background-color: var(--clr-3);
              display: grid; place-items: center; cursor: pointer;
              color: var(--clr-4); font-weight: 700; font-size: 0.9rem;
              transition: transform var(--tempo) ease, border-color var(--tempo) ease;
              &:hover { transform: scale(1.1) rotate(5deg); border-color: var(--clr-1); }
            }
          }
        }
      }

      &:has(.modalidade-item:hover) .fatia { opacity: 0.2; }
      &:has([data-modal="musculacao"]:hover)   .fatia[data-modal="musculacao"],
      &:has([data-modal="cardio"]:hover)       .fatia[data-modal="cardio"],
      &:has([data-modal="yoga_pilates"]:hover) .fatia[data-modal="yoga_pilates"],
      &:has([data-modal="lutas"]:hover)        .fatia[data-modal="lutas"],
      &:has([data-modal="zumba_danca"]:hover)  .fatia[data-modal="zumba_danca"],
      &:has([data-modal="natacao"]:hover)      .fatia[data-modal="natacao"] {
        opacity: 1; transform: scaleY(1.02); flex: 1.6;
      }
    }

    @media (max-width: 768px) {
      .modalidades { 
        max-height: auto; 
      }
      .actividades {
        grid-template-columns: 185px 1fr; 
        gap: var(--gap-items);
        .col-direita { min-height: 300px; 
          .imagem-principal { 
            min-height: 260px;
            flex-direction: column;
            gap: .5rem;

            .descricao-overlay { font-size: 0.65rem; line-height: 2; }
          } 
        }
        .col-esquerda { 
          #painel { 
            align-items: flex-start; padding: 1.5rem; 

            #painel-fechar { font-size: var(--icon-font-size-small); } 
            #painel-titulo { text-align: start; } 
          }
        } 
      }
    }
    @media (max-width: 460px) {
      .modalidades { max-height: auto; }
      .actividades {
        grid-template-columns: 1fr; 
        gap: var(--gap-items);
        .col-direita {
          min-height: 420px;
          margin: 0;

          .imagem-principal { 
            min-height: 180px;
            flex-direction: row;
            gap: 0;
          } 
        }
        .col-esquerda {
          .escolhas {padding: 0; .modalidade-item { padding: 0.2rem 0; } }
          position: relative;
          #painel { 
            display: grid;
            min-height: auto;
            align-content: space-around;
            grid-template-columns: 1fr;
            row-gap: var(--gap-items);
            justify-items: center;
            border-left: 0;

            #painel-fechar { margin-left: -1.8rem; grid-area: 1/1; place-self: start; font-size: var(--icon-font-size-small); } 

            #painel-titulo { margin-left: 3.2rem; grid-area: 1/1; place-self: end; font-size: x-large; text-wrap: wrap; text-align: end; align-self: center; } 

            #painel-horarios-bloco { grid-area: 2/1; span { font-size: large;} }

            #painel-coaches-lista { display: none; }

            #painel-inscrever { grid-area: 3/1; align-self: stretch; font-size: x-large; margin-block: 1rem; a { width: 100%; } }

          } 
        }
      }
    }
  }/* ok */

  .planos {
    max-width: var(--container-mid);
    transition: background-color var(--tempo) ease-in-out, 
                box-shadow var(--tempo) ease-in-out, 
                border var(--tempo) ease-in-out;

    &:hover {
      border-radius: var(--border-radius);
      .planos-lista .planos.popular {
        transform: scale(1.05); box-shadow: var(--bx-sdw);
        background-color: color-mix(in srgb, var(--clr-2) 15%, var(--clr-transp) 55%);
      }
      .planos-lista .planos:not(.popular) {
        background: var(--clr-3); border-radius: var(--border-radius); opacity: .65; box-shadow: var(--bx-sdw);
      }
    }

    .planos-lista {
      display: flex; justify-content: space-evenly; flex-wrap: wrap; width: 100%;

      .planos {
        min-height: 350px; padding: 1rem; margin-block: var(--gap-items);
        min-width: fit-content; max-width: 400px;
        display: grid; gap: var(--gap-items); place-items: center;
        transition: border var(--tempo) ease-in-out;

        &.popular {
          border-inline: 2px solid var(--clr-4);
          transition: border-radius var(--tempo) ease-in-out, background-color var(--tempo) ease-in-out;
        }

        .valor {
          padding: 1rem; gap: 0.5rem;
          h5 { padding: 1rem; text-transform: uppercase; }
          .valor_mes {
            display: flex; align-items: flex-end;
            h4 { font-size: xx-large; font-weight: 900; color: var(--clr-4); }
            h4, h6 { line-height: 1.2; }
          }
        }

        .acessos {
          padding: 1rem;
          li {
            margin-top: var(--gap-items); padding-bottom: 0.5rem; gap: 0.5rem;
            border-bottom: var(--clr-smooth-line); text-transform: none; color: var(--clr-2);
            font-size: medium; text-underline-offset: 50rem; pointer-events: none;
            span { color: var(--clr-4); padding-right: calc(var(--gap-items) / 2); }
          }
        }
      }
    }
  }

  .equipa {
    overflow: visible !important; scroll-margin-top: 8rem;
    
    .equipa-carousel {
      width: 100%; display: flex; align-items: center; gap: 0.75rem;
              min-width: 100%; 

      .carousel-viewport {
        flex: 1; overflow-x: auto;
        scroll-snap-type: x mandatory; scroll-behavior: smooth;
        scrollbar-width: none;
        &::-webkit-scrollbar { display: none; }
        display: flex; gap: 1rem; padding-block: 0.5rem;
      }

      .equipa-card {
        flex: 0 0 calc(33.333% - 0.667rem);
        scroll-snap-align: start;
        position: relative !important;
        height: 420px;
        border-radius: var(--border-radius);
        overflow: hidden !important;
        cursor: pointer;
        background-size: cover; background-position: center; background-color: var(--clr-3);
        transition: transform var(--tempo) ease, box-shadow var(--tempo) ease;

        &::after {
          content: ""; position: absolute; inset: 0;
          background: linear-gradient(to bottom, transparent 40%, var(--clr-transp) 100%);
          z-index: 1; pointer-events: none;
        }

        .equipa-card-iniciais {
          position: absolute !important;
          top: 50%; left: 50%; transform: translate(-50%, -50%);
          z-index: 2; font-family: var(--fnt-sign);
          font-size: 3rem; font-weight: 700; color: var(--clr-4);
          opacity: 0.4; pointer-events: none;
        }

        .equipa-info {
          position: absolute !important;
          bottom: 0; left: 0; right: 0;
          padding: 1.25rem 1rem;
          z-index: 3 !important;
          display: flex; flex-direction: column; gap: 0.3rem;
        }

        .equipa-nome {
          font-family: var(--fnt-sign);
          font-size: clamp(0.85rem, 1.2vw, 1.1rem);
          font-style: italic; font-weight: 700; color: var(--clr-1);
          text-transform: uppercase; letter-spacing: 0.05em;
        }

        .equipa-tags {
          font-size: 0.68rem; color: var(--clr-4);
          text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600;
        }

        &:hover { transform: translateY(-4px); box-shadow: var(--bx-sdw); }
      }
    }

    @media (max-width: 900px) {
      .equipa-card { flex: 0 0 calc(50% - 0.5rem) !important; }
    }
    @media (max-width: 500px) {
      .equipa-card { flex: 0 0 85% !important; }
    }
  }
  
  .contactos {
    width: 100%; padding: 1rem;
    display: grid; gap: var(--gap-items);
  
    .contactos-grid { 
      display: grid;  grid-template-columns: 1fr 380px;
       gap: 2rem; align-items: start;
  
       @media (max-width: 768px) { grid-template-columns: 1fr; }
    }
  
    .contactos-form {
      display: grid;
      gap: 1.25rem;
      padding: 2rem;
      border-left: var(--border-size) var(--clr-4);
      border-bottom: var(--border-size) var(--clr-4);
      border-radius: 0 0 0 1rem;
  
      .campo {
        display: grid;
        gap: 0.4rem;
  
        label {
            font-size: 0.72rem;
            font-weight: 400;
            letter-spacing: 0.1em;
            text-transform: uppercase;
            color: var(--clr-2);
            cursor: default;
        }
  
        input, select, textarea {
          width: 100%;
          padding: 0.65rem 0.9rem;
          background: rgba(18, 13, 15, 0.5);
          border: var(--border-size) var(--clr-transp);
          border-bottom-color: var(--clr-4);
          border-radius: var(--border-radius);
          color: var(--clr-1);
          font-family: var(--fnt-body);
          font-size: 0.9rem;
          outline: none;
          resize: none;
          transition: border-color var(--tempo) ease, box-shadow var(--tempo) ease;
  
          &:focus {
            border-color: var(--clr-4);
            box-shadow: 0 0 0 2px var(--glass-surface);
          }
  
          &::placeholder {
            color: var(--clr-2);
            opacity: 0.5;
            font-size: 0.85rem;
          }
  
          option { background: var(--clr-3); color: var(--clr-1); }
        }
      }
    }
  
    .contactos-info {
      display: flex;
      flex-direction: column;
      gap: 1.25rem;
  
      .info-bloco {
        display: flex;
        flex-direction: column;
        gap: 1.25rem;
        padding: 1.5rem;
  
        .info-item {
          display: flex;
          align-items: flex-start;
          gap: 0.9rem;
  
          i {
              color: var(--clr-4);
              font-size: 1rem;
              margin-top: 0.15rem;
              flex-shrink: 0;
              width: 1.1rem;
              text-align: center;
          }
  
          div {
              display: flex;
              flex-direction: column;
              gap: 0.1rem;
          }
  
          .info-label {
              font-size: 0.68rem;
              font-weight: 400;
              letter-spacing: 0.12em;
              text-transform: uppercase;
              color: var(--clr-4);
          }
  
          span:not(.info-label), a {
              font-size: 0.85rem;
              color: var(--clr-2);
              font-weight: 300;
              letter-spacing: 0.02em;
              text-decoration: none;
              transition: color var(--tempo) ease;
          }
  
          a:hover { color: var(--clr-4); }
        }
      }
  
      .sociais {
        display: flex;
        gap: 0.75rem;
        flex-wrap: wrap;
  
        .btn.icon {
          width: 2.5rem;
          height: 2.5rem;
          padding: 0;
          display: grid;
          place-items: center;
          font-size: 1.1rem;
        }
  
        .social-wa {
          color: var(--clr-4) !important;
          &:hover { color: var(--clr-social_wa) !important; box-shadow: var(--clr-social_wa_shdw) !important; }
          &:active { background-color: var(--clr-4); color: var(--clr-2) !important; box-shadow: var(--clr-social_wa_shdw) !important; }
          &:focus-visible, &:focus { box-shadow: var(--clr-social_wa_shdw) !important; } 
        }
        .social-ig {
          color: var(--clr-4) !important;
          &:hover { color: var(--clr-social_ig) !important; box-shadow: var(--clr-social_ig_shdw) !important; }
          &:active { background-color: var(--clr-4); color: var(--clr-2) !important; box-shadow: var(--clr-social_ig_shdw) !important; }
          &:focus-visible, &:focus { box-shadow: var(--clr-social_ig_shdw) !important; } 
        }
        .social-fb {
          color: var(--clr-4) !important;
          &:hover { color: var(--clr-social_fb) !important; box-shadow: var(--clr-social_fb_shdw) !important; }
          &:active { background-color: var(--clr-4); color: var(--clr-2) !important; box-shadow: var(--clr-social_fb_shdw) !important; }
          &:focus-visible, &:focus { box-shadow: var(--clr-social_fb_shdw) !important; }
        }
        .social-tt {
          color: var(--clr-4) !important;
          &:hover { color: var(--clr-social_tt) !important; box-shadow: var(--clr-social_tt_shdw) !important; }
          &:active { background-color: var(--clr-4); color: var(--clr-2) !important; box-shadow: var(--clr-social_tt_shdw) !important; }
          &:focus-visible, &:focus { box-shadow: var(--clr-social_tt_shdw) !important; }
        }
      }
    }
  }
}

footer {
  width: 100%;     
  position: relative;  margin-inline: auto; 
  margin-top: 4rem; padding: 3rem 1rem 0;
  display: grid; align-content: space-between;
  z-index: 2; place-items: center; background: var(--clr-3);
  border-top: var(--border-size) var(--clr-4);

  .footer-grid {
    max-width: var(--container-max);
    margin-inline: auto;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 3rem;
    padding-bottom: 2.5rem;

    @media (max-width: 768px) {
      grid-template-columns: 1fr 1fr;
      gap: 2rem;
    }

    @media (max-width: 480px) { grid-template-columns: 1fr; }
  }

  .footer-titulo {
    display: block;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--clr-4);
    margin-bottom: 0.5rem;
  }

  .footer-marca {
    display: flex;
    flex-direction: column;
    gap: 1rem;

    @media (max-width: 768px) { grid-column: 1 / -1; }

    .logo { border: none; padding: 0; width: 3.5rem; }

    p {
      font-size: 0.8rem;
      font-weight: 300;
      color: var(--clr-2);
      opacity: 0.7;
      text-align: start;
      max-width: 240px;
      line-height: 1.7;
      margin: 0;
    }
  }

  .footer-nav {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
  }

  .footer-extra {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;

    p {
      font-size: 0.82rem;
      font-weight: 300;
      color: var(--clr-2);
      text-align: start;
      margin: 0;
      line-height: 1.8;

      strong { color: var(--clr-1); font-weight: 500; }
    }

    .footer-titulo { margin-top: 1.5rem; }

    .footer-sociais {
      display: flex;
      gap: 1rem;
      margin-top: 0.25rem;

      a {
        font-size: 1.1rem;
        color: var(--clr-2);
        opacity: 0.7;
        text-decoration: none;
        transition: color var(--tempo) ease, opacity var(--tempo) ease;

        &:hover { color: var(--clr-4); opacity: 1; text-decoration: none; }
      }
    }
  }

  .footer-bar {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-block: 1rem;
    border-top: 1px solid rgba(251, 160, 2, 0.2);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;

    @media (max-width: 480px) { flex-direction: column; text-align: center; }

    span, a {
      font-size: 0.72rem;
      color: var(--clr-2);
      opacity: 0.5;
      font-weight: 300;
      letter-spacing: 0.04em;
      text-decoration: none;
      transition: opacity var(--tempo) ease;

      &:hover { opacity: 1; color: var(--clr-4); text-decoration: none; }
    }

    div { display: flex; gap: 0.75rem; align-items: center; }
  }
}
