/* =================================================================
   IATE CLUBE DE ITACURUÇÁ — seção "O Clube" (index.html)
   Intro premium · selo 81 anos · linha do tempo · galeria de
   memórias com modal/lightbox · fechamento. CSS próprio.
   Depende das variáveis de css/styles.css.
   ================================================================= */

.oclube{display:block}

/* placeholder do leme (data-fallback) — global */
.mem__media.is-empty,.memlb__media.is-empty{
  background-color:var(--navy-800);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.22' stroke-width='2'%3E%3Ccircle cx='50' cy='50' r='46'/%3E%3Ccircle cx='50' cy='50' r='20'/%3E%3Cg stroke-width='4'%3E%3Cline x1='50' y1='2' x2='50' y2='30'/%3E%3Cline x1='50' y1='70' x2='50' y2='98'/%3E%3Cline x1='2' y1='50' x2='30' y2='50'/%3E%3Cline x1='70' y1='50' x2='98' y2='50'/%3E%3Cline x1='15' y1='15' x2='35' y2='35'/%3E%3Cline x1='65' y1='65' x2='85' y2='85'/%3E%3Cline x1='85' y1='15' x2='65' y2='35'/%3E%3Cline x1='35' y1='65' x2='15' y2='85'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-position:center;background-repeat:no-repeat;background-size:46%;
}
.mem__media.is-empty img,.memlb__media.is-empty img{display:none}

/* =========================== 1. INTRO =========================== */
.oclube-intro__grid{
  display:grid;grid-template-columns:1.35fr .65fr;gap:clamp(32px,5vw,72px);align-items:center;
}
.oclube-intro .eyebrow{color:var(--coral-deep);display:flex;align-items:center;gap:14px;margin-bottom:18px}
.oclube-intro__title{
  font-family:var(--serif);font-weight:500;color:var(--ink);
  font-size:clamp(2.6rem,6vw,4.4rem);line-height:1;margin-bottom:24px;
}
.oclube-intro__lead{color:var(--muted);font-size:clamp(1rem,1.4vw,1.12rem);line-height:1.8;max-width:60ch}
.oclube-intro__lead + .oclube-intro__lead{margin-top:18px}

/* selo 81 anos */
.oclube-seal{display:flex;flex-direction:column;align-items:center;gap:18px}
.oclube-seal__ring{
  position:relative;width:clamp(170px,20vw,220px);aspect-ratio:1;border-radius:50%;
  display:grid;place-items:center;text-align:center;color:#fff;
  background:radial-gradient(circle at 30% 25%,var(--navy-700),var(--navy-950));
  box-shadow:0 26px 60px rgba(8,24,38,.34),inset 0 0 0 1px rgba(255,255,255,.08);
}
.oclube-seal__ring::before{
  content:"";position:absolute;inset:11px;border-radius:50%;
  border:1px solid rgba(207,111,97,.55);
}
.oclube-seal__ring::after{
  content:"";position:absolute;inset:20px;border-radius:50%;
  border:1px dashed rgba(255,255,255,.18);
}
.oclube-seal__num{
  font-family:var(--serif);font-weight:500;font-size:clamp(3.4rem,5vw,4.4rem);line-height:.9;
  color:var(--coral-bright);position:relative;z-index:1;
}
.oclube-seal__lbl{
  font-family:var(--sans);font-size:.7rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--white-70);position:relative;z-index:1;margin-top:6px;padding-left:.42em;
}
.oclube-seal__cap{
  font-family:var(--sans);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--coral-deep);
}

/* palavras interativas do selo — miniatura redonda (a própria foto vira botão) */
.seal-words__lead{font-family:var(--sans);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.seal-words{display:flex;justify-content:center;gap:clamp(18px,2.8vw,34px);flex-wrap:wrap}
.seal-word{display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;background:none;border:0;padding:0}
.seal-thumb{
  position:relative;width:clamp(88px,12vw,116px);aspect-ratio:1;border-radius:50%;overflow:hidden;
  border:3px solid #fff;background:var(--navy-800);box-shadow:0 14px 32px rgba(8,24,38,.24);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.seal-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s var(--ease)}
.seal-thumb::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:inset 0 0 0 0 var(--coral);transition:box-shadow .35s var(--ease);pointer-events:none}
.seal-word:hover .seal-thumb,.seal-word:focus-visible .seal-thumb{transform:translateY(-6px) scale(1.05);box-shadow:0 26px 46px rgba(8,24,38,.32)}
.seal-word:hover .seal-thumb img{transform:scale(1.1)}
.seal-word:hover .seal-thumb::after,.seal-word:focus-visible .seal-thumb::after{box-shadow:inset 0 0 0 3px var(--coral)}
.seal-thumb.is-empty{
  background-color:var(--navy-800);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.28' stroke-width='3'%3E%3Ccircle cx='50' cy='50' r='40'/%3E%3Ccircle cx='50' cy='50' r='12'/%3E%3Cline x1='50' y1='38' x2='50' y2='14'/%3E%3Cline x1='62' y1='50' x2='86' y2='50'/%3E%3Cline x1='50' y1='62' x2='50' y2='86'/%3E%3Cline x1='38' y1='50' x2='14' y2='50'/%3E%3C/g%3E%3C/svg%3E");
  background-position:center;background-repeat:no-repeat;background-size:62%;
}
.seal-thumb.is-empty img{display:none}
.seal-word__txt{font-family:var(--sans);font-weight:500;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--coral-deep)}
.seal-word__hint{font-family:var(--sans);font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);opacity:0;transform:translateY(-3px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.seal-word:hover .seal-word__hint,.seal-word:focus-visible .seal-word__hint{opacity:1;transform:none}
.seal-word:focus-visible{outline:none}
.seal-word:focus-visible .seal-thumb{outline:3px solid var(--coral);outline-offset:3px}
@media (prefers-reduced-motion:reduce){.seal-thumb,.seal-thumb img{transition:none}.seal-word:hover .seal-thumb{transform:none}}

/* ===== Bloco "Mais de oito décadas no mar" (header da timeline) ===== */
.decades{
  display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(28px,4vw,60px);align-items:center;
  margin-bottom:clamp(40px,5vw,62px);text-align:left;
}
.decades .eyebrow{color:var(--coral-bright);display:flex;align-items:center;gap:14px;margin-bottom:14px}
.decades__title{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4.6vw,3.3rem);color:#fff;line-height:1.04;margin-bottom:16px}
.decades__text{color:var(--white-70);font-size:clamp(1rem,1.4vw,1.14rem);line-height:1.7;max-width:48ch}
.decades__feature{position:relative;display:flex;flex-direction:column;align-items:center;justify-self:end}
.decades__num{position:relative;z-index:1;font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(5rem,12vw,9rem);line-height:.82;color:var(--coral-bright);text-shadow:0 10px 44px rgba(207,111,97,.28)}
.decades__num-lbl{position:relative;z-index:1;font-family:var(--sans);font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--white-70);margin-top:12px}
@media (max-width:760px){
  .decades{grid-template-columns:1fr;text-align:center}
  .decades .eyebrow{justify-content:center}
  .decades__text{margin-left:auto;margin-right:auto}
  .decades__feature{justify-self:center;margin-top:6px}
}

/* ======================= 2. LINHA DO TEMPO ====================== */
.section-head--center{text-align:center;margin-left:auto;margin-right:auto;max-width:680px}
.section-head--center .eyebrow{justify-content:center}
.oclube-timeline .section-head h2{color:#fff}
.oclube-timeline .section-head .eyebrow{color:var(--coral-bright)}

.tl{list-style:none;position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.5vw,32px);margin-top:56px}
.tl::before{content:"";position:absolute;left:0;right:0;top:9px;height:2px;
  background:linear-gradient(90deg,rgba(255,255,255,.05),rgba(255,255,255,.22),rgba(255,255,255,.05))}
.tl__item{position:relative;padding-top:40px;text-align:center}
.tl__node{position:absolute;top:0;left:50%;transform:translateX(-50%)}
.tl__dot{display:block;width:20px;height:20px;border-radius:50%;background:var(--coral);
  box-shadow:0 0 0 6px rgba(207,111,97,.20);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.tl__item:hover .tl__dot{transform:scale(1.15);box-shadow:0 0 0 8px rgba(207,111,97,.28)}
.tl__year{display:block;font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(1.9rem,3vw,2.6rem);color:var(--coral-bright);line-height:1}
.tl__title{font-family:var(--serif);font-weight:500;font-size:1.3rem;color:#fff;margin:6px 0 8px}
.tl__text{color:var(--white-70);font-size:.92rem;line-height:1.6;max-width:30ch;margin:0 auto}
/* stagger do reveal */
.tl__item[data-reveal]{transition-delay:.05s}
.tl__item:nth-child(2)[data-reveal]{transition-delay:.16s}
.tl__item:nth-child(3)[data-reveal]{transition-delay:.27s}
.tl__item:nth-child(4)[data-reveal]{transition-delay:.38s}

/* ===================== 3. GALERIA DE MEMÓRIAS =================== */
.memories{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,1.6vw,22px);margin-top:14px}
.mem{
  position:relative;grid-column:span 12;display:block;width:100%;padding:0;border:0;cursor:pointer;
  overflow:hidden;border-radius:18px;background:var(--navy-800);color:#fff;
  box-shadow:0 16px 36px rgba(8,24,38,.16);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
  aspect-ratio:4/3;
}
.mem--wide{grid-column:span 6}
.mem--third{grid-column:span 4;aspect-ratio:4/5}
.mem--full{grid-column:span 12;aspect-ratio:16/6}
.mem:hover{transform:translateY(-7px);box-shadow:0 34px 64px rgba(8,24,38,.30)}
.mem__media{position:absolute;inset:0}
.mem__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.mem:hover .mem__media img{transform:scale(1.09)}
.mem__cap{
  position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;
  padding:clamp(18px,2vw,26px);text-align:left;
  background:linear-gradient(transparent 38%,rgba(8,24,38,.55) 70%,rgba(8,24,38,.9));
}
.mem__title{font-family:var(--serif);font-weight:500;font-size:clamp(1.2rem,1.8vw,1.55rem);line-height:1.12}
.mem__hint{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--sans);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--coral-bright);
  opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.mem__hint::before{content:"";width:18px;height:1px;background:currentColor;display:inline-block}
.mem:hover .mem__hint,.mem:focus-visible .mem__hint{opacity:1;transform:none}
.mem:focus-visible{outline:3px solid var(--coral);outline-offset:3px}

/* ======================== 4. FECHAMENTO ======================== */
.oclube-closing{position:relative;overflow:hidden}
.oclube-closing__inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}
.oclube-closing__rule{display:block;width:48px;height:2px;background:var(--coral);border-radius:2px}
.oclube-closing__eyebrow{font-family:var(--sans);font-weight:400;font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--coral-bright)}
.oclube-closing__tag{
  font-family:var(--serif);font-style:italic;font-weight:400;color:#fff;
  font-size:clamp(1.5rem,2.8vw,2.2rem);line-height:1.4;max-width:26ch;
}
.oclube-closing .actbtn{width:auto;margin-top:4px}
/* stagger do reveal */
.oclube-closing__rule[data-reveal]{transition-delay:.04s}
.oclube-closing__eyebrow[data-reveal]{transition-delay:.12s}
.oclube-closing__tag[data-reveal]{transition-delay:.22s}
.oclube-closing .actbtn[data-reveal]{transition-delay:.34s}

/* ===== Brasão do clube (logo) — sobre os elementos de marca de O Clube ===== */
.club-crest{display:inline-flex;align-items:center;justify-content:center;line-height:0}
.club-crest__img{
  width:100%;height:100%;object-fit:contain;display:block;
  filter:drop-shadow(0 12px 26px rgba(8,24,38,.5));
}
/* fallback do leme caso a logo falhe ao carregar */
.club-crest.is-empty{
  border-radius:50%;background-color:var(--navy-800);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.5' stroke-width='3' stroke-linecap='round'%3E%3Ccircle cx='50' cy='50' r='40'/%3E%3Ccircle cx='50' cy='50' r='8'/%3E%3Cline x1='50' y1='42' x2='50' y2='18'/%3E%3Cline x1='58' y1='50' x2='82' y2='50'/%3E%3Cline x1='50' y1='58' x2='50' y2='82'/%3E%3Cline x1='42' y1='50' x2='18' y2='50'/%3E%3C/g%3E%3C/svg%3E");
  background-position:center;background-repeat:no-repeat;background-size:66%;
}
.club-crest.is-empty .club-crest__img{display:none}
/* brasão que coroa o fechamento (centralizado) */
.oclube-closing__crest{width:clamp(60px,8.5vw,92px);aspect-ratio:1;margin-bottom:6px}
/* emblema discreto no canto do card Secretaria */
.finalcta__crest{
  position:absolute;top:16px;right:16px;z-index:0;
  width:clamp(46px,7vw,64px);aspect-ratio:1;opacity:.92;
}

/* =============== CHAMADA FINAL (Sua próxima travessia) =========== */
.finalcta{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(32px,5vw,72px);align-items:center}
.finalcta .eyebrow{color:var(--coral-bright);display:flex;align-items:center;gap:14px;margin-bottom:16px}
.finalcta__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,5vw,3.6rem);color:#fff;line-height:1.04;margin-bottom:18px}
.finalcta__lead{color:var(--white-70);font-size:clamp(1rem,1.4vw,1.16rem);line-height:1.7;max-width:46ch;margin-bottom:32px}
.finalcta .actbtn{width:auto}
.finalcta__card{
  position:relative;overflow:hidden;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:18px;
  padding:clamp(24px,3vw,36px);
}
.finalcta__card-label{position:relative;z-index:1;font-family:var(--sans);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--coral-bright);margin-bottom:14px}
.finalcta__hours{position:relative;z-index:1;list-style:none;display:flex;flex-direction:column}
.finalcta__hours li{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:12px 0;border-bottom:1px dashed rgba(255,255,255,.16)}
.finalcta__hours li:last-child{border-bottom:0}
.finalcta__hours .d{font-family:var(--sans);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--white-70)}
.finalcta__hours .t{font-family:var(--sans);font-weight:500;color:#fff;white-space:nowrap}
.finalcta__link{position:relative;z-index:1;display:inline-flex;align-items:center;gap:9px;margin-top:18px;
  color:var(--coral-bright);font-family:var(--sans);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.finalcta__link svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.finalcta__link:hover svg{transform:translateX(4px)}
.finalcta__link:focus-visible,.oclube-closing .actbtn:focus-visible{outline:3px solid var(--coral-bright);outline-offset:3px}
@media (max-width:760px){.finalcta{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){.finalcta__link svg{transition:none}}

/* ===================== MODAL / LIGHTBOX ======================== */
.memlb{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,52px)}
.memlb.is-open{display:flex}
.memlb__backdrop{position:absolute;inset:0;background:rgba(6,16,26,.86);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.memlb__dialog{
  position:relative;z-index:1;width:min(940px,100%);max-height:90vh;overflow:auto;
  background:var(--paper);border-radius:22px;box-shadow:0 40px 110px rgba(0,0,0,.55);
  transform:translateY(16px) scale(.97);opacity:0;
  transition:transform .42s var(--ease),opacity .42s var(--ease);
}
.memlb.is-open .memlb__dialog{transform:none;opacity:1}
.memlb__media{position:relative;background:var(--navy-900);aspect-ratio:16/10;max-height:58vh}
.memlb__media img{width:100%;height:100%;object-fit:cover;display:block}
.memlb__cap{padding:clamp(22px,3vw,38px)}
.memlb__count{display:block;font-family:var(--sans);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--coral-deep);margin-bottom:12px}
.memlb__title{font-family:var(--serif);font-weight:500;color:var(--ink);
  font-size:clamp(1.7rem,3.2vw,2.4rem);line-height:1.08;margin-bottom:14px}
.memlb__text{color:var(--muted);font-size:clamp(1rem,1.3vw,1.08rem);line-height:1.75;max-width:64ch}
.memlb__close{
  position:absolute;top:16px;right:16px;z-index:4;width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(8,24,38,.55);color:#fff;font-size:1.6rem;line-height:1;display:grid;place-items:center;
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  transition:background .3s var(--ease),transform .3s var(--ease);
}
.memlb__close:hover{background:var(--coral);transform:rotate(90deg)}
.memlb__nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:4;
  width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.5);cursor:pointer;
  background:rgba(8,24,38,.42);color:#fff;font-size:1.6rem;line-height:1;display:grid;place-items:center;
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);transition:background .3s var(--ease),border-color .3s var(--ease)}
.memlb__nav:hover{background:var(--coral);border-color:var(--coral)}
.memlb__prev{left:16px}
.memlb__next{right:16px}
.memlb__close:focus-visible,.memlb__nav:focus-visible{outline:3px solid var(--coral-bright);outline-offset:2px}

/* ========================= RESPONSIVO ========================== */
@media (max-width:880px){
  .oclube-intro__grid{grid-template-columns:1fr;justify-items:start}
  .oclube-seal{flex-direction:column;align-items:center;gap:16px;width:100%;margin-top:8px}
  .mem--wide,.mem--third{grid-column:span 6}
  .mem,.mem--third{aspect-ratio:1/1}
  .mem--wide{aspect-ratio:4/3}
  .mem--full{grid-column:span 12;aspect-ratio:16/8}
}
@media (max-width:760px){
  .tl{grid-template-columns:1fr;gap:0;margin-top:40px}
  .tl::before{left:9px;right:auto;top:6px;bottom:6px;width:2px;height:auto;
    background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.22),rgba(255,255,255,.05))}
  .tl__item{text-align:left;padding:0 0 36px 42px}
  .tl__node{top:4px;left:9px;transform:translateX(-50%)}
  .tl__text{margin:0;max-width:46ch}
}
@media (max-width:560px){
  .mem,.mem--wide,.mem--third,.mem--full{grid-column:span 12;aspect-ratio:4/3}
  .oclube-seal{flex-direction:column}
}

@media (prefers-reduced-motion:reduce){
  .mem,.mem__media img,.mem__hint,.memlb__dialog,.tl__dot{transition:none}
  .memlb__dialog{transform:none}
  .mem:hover{transform:none}
  .mem:hover .mem__media img{transform:none}
}
