/* ═══════════════════════════════════════════════════════════════
   CPMP — Caridade Portuguesa Maria Pia
   Design: Azul marinho institucional + Dourado + Branco
   Fontes: Cormorant Garamond (display) + Work Sans (corpo)
   ═══════════════════════════════════════════════════════════════ */

/* ── TOKENS ─────────────────────────────────────────────────── */
:root,[data-theme=light]{
  /* Tipografia */
  --text-xs:clamp(.75rem,.7rem + .25vw,.875rem);
  --text-sm:clamp(.875rem,.8rem + .35vw,1rem);
  --text-base:1rem;
  --text-lg:clamp(1.125rem,1rem + .75vw,1.5rem);
  --text-xl:clamp(1.5rem,1.2rem + 1.25vw,2.25rem);
  --text-2xl:clamp(2rem,1.2rem + 2.5vw,3.5rem);
  --text-3xl:clamp(2.5rem,1rem + 4vw,5rem);
  --text-hero:clamp(2.2rem,.5rem + 5vw,5rem);

  /* Espaçamento */
  --space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;
  --space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;
  --space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;

  /* Paleta CPMP — Azul marinho + Dourado */
  --color-navy:#0d1f4f;
  --color-navy-deep:#081540;
  --color-navy-light:#1a2f6e;
  --color-gold:#c8a84b;
  --color-gold-light:#dfc27a;
  --color-gold-pale:#f5efd0;

  /* Superfícies */
  --color-bg:#fafaf8;
  --color-surface:#ffffff;
  --color-surface-2:#f7f6f2;
  --color-surface-offset:#f0ede6;
  --color-divider:#e0ddd6;
  --color-border:#d4d0c8;

  /* Texto */
  --color-text:#1a1710;
  --color-text-muted:#5a5750;
  --color-text-faint:#aaa89f;
  --color-text-inverse:#fafaf8;

  /* Primário */
  --color-primary:var(--color-navy);
  --color-primary-hover:var(--color-navy-deep);
  --color-primary-highlight:rgba(13,31,79,.08);

  /* Accent dourado */
  --color-accent:var(--color-gold);
  --color-accent-hover:var(--color-gold-light);

  /* Status */
  --color-success:#2e7d32;--color-error:#c62828;--color-warning:#e65100;

  /* Raio */
  --radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;

  /* Sombras */
  --shadow-sm:0 1px 3px rgba(13,31,79,.08);
  --shadow-md:0 4px 16px rgba(13,31,79,.1);
  --shadow-lg:0 12px 40px rgba(13,31,79,.14);

  /* Transição */
  --transition-interactive:180ms cubic-bezier(.16,1,.3,1);

  /* Larguras */
  --content-narrow:640px;--content-default:960px;--content-wide:1200px;

  /* Fontes */
  --font-display:'Cormorant Garamond','Georgia',serif;
  --font-body:'Work Sans','Helvetica Neue',sans-serif;
  --font-weight-display:700;
  --font-weight-body:400;
  --letter-spacing-display:0em;
  --line-height-body:1.7;
}

[data-theme=dark]{
  --color-bg:#111218;--color-surface:#17191f;--color-surface-2:#1c1e27;
  --color-surface-offset:#1f2130;--color-divider:#2a2d3a;--color-border:#333649;
  --color-text:#e8e6df;--color-text-muted:#8a8880;--color-text-faint:#55534e;
  --color-text-inverse:#111218;
  --color-navy:#3a5bbd;--color-navy-deep:#2d4da0;--color-navy-light:#4a6dd0;
  --color-gold:#e8c76a;--color-gold-light:#f0d48a;--color-gold-pale:#2a2415;
  --color-primary:var(--color-navy);--color-primary-hover:var(--color-navy-deep);
  --color-primary-highlight:rgba(58,91,189,.15);
  --color-accent:var(--color-gold);--color-accent-hover:var(--color-gold-light);
  --shadow-sm:0 1px 3px rgba(0,0,0,.3);
  --shadow-md:0 4px 16px rgba(0,0,0,.35);
  --shadow-lg:0 12px 40px rgba(0,0,0,.45);
}

@media(prefers-color-scheme:dark){
  :root:not([data-theme]){
    --color-bg:#111218;--color-surface:#17191f;--color-surface-2:#1c1e27;
    --color-surface-offset:#1f2130;--color-divider:#2a2d3a;--color-border:#333649;
    --color-text:#e8e6df;--color-text-muted:#8a8880;--color-text-faint:#55534e;
    --color-text-inverse:#111218;
    --color-navy:#3a5bbd;--color-navy-deep:#2d4da0;--color-navy-light:#4a6dd0;
    --color-gold:#e8c76a;--color-gold-light:#f0d48a;
    --color-primary:var(--color-navy);--color-primary-hover:var(--color-navy-deep);
    --color-accent:var(--color-gold);
    --shadow-sm:0 1px 3px rgba(0,0,0,.3);
    --shadow-md:0 4px 16px rgba(0,0,0,.35);
    --shadow-lg:0 12px 40px rgba(0,0,0,.45);
  }
}

/* ── LAYOUT UTILITÁRIOS ─────────────────────────────────────── */
.container{max-width:var(--content-default);margin-inline:auto;padding-inline:var(--space-6)}
.container--wide{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--space-6)}
.container--narrow{max-width:var(--content-narrow);margin-inline:auto;padding-inline:var(--space-6)}
section{padding-block:clamp(var(--space-12),7vw,var(--space-24))}

/* ── HEADER / NAV ───────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:100;
  background:oklch(from #0d1f4f l c h / .97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(200,168,75,.18);
  box-shadow:var(--shadow-sm);
}
.site-header .inner{
  max-width:var(--content-wide);margin-inline:auto;
  padding-inline:var(--space-6);padding-block:var(--space-3);
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);
}
.logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;flex-shrink:0}
.logo svg{width:44px;height:44px}
.logo-text{display:flex;flex-direction:column;line-height:1.2;align-items:center;text-align:center}
.logo-text .name{font-family:'Cinzel','Cormorant Garamond',serif;font-size:var(--text-base);font-weight:600;color:#ffffff;letter-spacing:.04em}
.logo-text .name-line2{margin-top:1px}
.logo-text .tagline{font-size:0.6rem;color:var(--color-gold);letter-spacing:.12em;text-transform:uppercase;margin-top:1px}

nav.main-nav{display:flex;align-items:center;gap:0;flex-wrap:nowrap}
nav.main-nav a{
  font-family:var(--font-body);font-size:0.78rem;
  font-weight:500;color:rgba(255,255,255,.82);
  text-decoration:none;padding:var(--space-2) 0.55rem;
  border-radius:var(--radius-md);letter-spacing:.01em;
  transition:color var(--transition-interactive),background var(--transition-interactive);
  white-space:nowrap;
}
nav.main-nav a:hover,nav.main-nav a.active{color:#ffffff;background:rgba(200,168,75,.15)}
nav.main-nav a.active{color:var(--color-gold)}

.header-actions{display:flex;align-items:center;gap:var(--space-2)}
.btn-member{
  font-size:var(--text-sm);font-weight:600;
  padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);
  background:var(--color-gold);color:#0d1f4f;border:none;cursor:pointer;
  text-decoration:none;transition:background var(--transition-interactive),transform var(--transition-interactive);
  white-space:nowrap;
}
.btn-member:hover{background:var(--color-gold-light);transform:translateY(-1px)}

.btn-theme{
  background:transparent;border:1px solid rgba(255,255,255,.2);
  border-radius:var(--radius-full);padding:var(--space-2);
  color:rgba(255,255,255,.7);cursor:pointer;display:flex;align-items:center;
  transition:color var(--transition-interactive),border-color var(--transition-interactive);
}
.btn-theme:hover{color:#fff;border-color:rgba(255,255,255,.5)}

.hamburger{display:none;background:transparent;border:none;cursor:pointer;padding:var(--space-2);color:#fff}

/* Mobile nav */
@media(max-width:900px){
  .hamburger{display:flex;align-items:center}
  .btn-member{display:none}
  nav.main-nav{
    display:none;position:fixed;inset:0;top:70px;
    flex-direction:column;align-items:flex-start;
    background:var(--color-navy-deep);padding:var(--space-6);
    gap:var(--space-2);z-index:99;
  }
  nav.main-nav.open{display:flex}
  nav.main-nav a{font-size:var(--text-base);padding:var(--space-3) var(--space-4);width:100%}
  .logo-text .tagline{display:none}
}

/* ── BOTÕES ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);
  font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);
  text-decoration:none;border-radius:var(--radius-md);cursor:pointer;
  padding:var(--space-3) var(--space-6);border:2px solid transparent;
  transition:all var(--transition-interactive);white-space:nowrap;
}
.btn--primary{background:var(--color-navy);color:#fff;border-color:var(--color-navy)}
.btn--primary:hover{background:var(--color-navy-deep);border-color:var(--color-navy-deep);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--gold{background:var(--color-gold);color:var(--color-navy-deep);border-color:var(--color-gold)}
.btn--gold:hover{background:var(--color-gold-light);border-color:var(--color-gold-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--outline{background:transparent;color:var(--color-navy);border-color:var(--color-navy)}
.btn--outline:hover{background:var(--color-primary-highlight)}
.btn--outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--outline-white:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn--lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}
.btn--sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}

/* ── HERO ───────────────────────────────────────────────────── */
.hero{
  position:relative;min-height:90vh;display:flex;align-items:flex-end;
  overflow:hidden;background:var(--color-navy-deep);
}
.hero__bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(.5) saturate(.8);transition:transform 8s ease-out;
}
.hero:hover .hero__bg{transform:scale(1.03)}
.hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,21,64,.95) 0%,rgba(8,21,64,.4) 50%,transparent 100%);
}
.hero__content{position:relative;z-index:2;padding:var(--space-20) var(--space-6);width:100%;max-width:var(--content-wide);margin-inline:auto}
.hero__eyebrow{
  font-size:var(--text-xs);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--color-gold);margin-bottom:var(--space-4);
  display:flex;align-items:center;gap:var(--space-3);
}
.hero__eyebrow::before{content:'';display:block;width:2rem;height:2px;background:var(--color-gold)}
.hero__title{
  font-family:'Cinzel','Georgia',serif;font-size:var(--text-hero);font-weight:var(--font-weight-display);
  color:#ffffff;line-height:1;margin-bottom:var(--space-6);letter-spacing:var(--letter-spacing-display);
}
.hero__title em{font-style:italic;color:var(--color-gold)}
.hero__subtitle{
  font-size:var(--text-lg);color:rgba(255,255,255,.78);
  max-width:52ch;margin-bottom:var(--space-8);line-height:1.55;
}
.hero__actions{display:flex;gap:var(--space-4);flex-wrap:wrap}
.hero__since{
  margin-top:var(--space-8);font-size:var(--text-xs);color:rgba(255,255,255,.4);
  letter-spacing:.1em;text-transform:uppercase;
}
.hero--inner{min-height:42vh;align-items:center}
.hero--inner .hero__content{padding-block:var(--space-20) var(--space-12)}

/* ── SEÇÃO TÍTULO ─────────────────────────────────────────── */
.section-header{text-align:center;max-width:600px;margin-inline:auto;margin-bottom:var(--space-12)}
.section-header .eyebrow{
  font-size:var(--text-xs);font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--color-gold);margin-bottom:var(--space-3);
}
.section-header h2{
  font-family:var(--font-display);font-size:var(--text-2xl);
  font-weight:700;color:var(--color-text);margin-bottom:var(--space-4);
}
.section-header p{font-size:var(--text-base);color:var(--color-text-muted);max-width:52ch;margin-inline:auto}

/* ── CARDS ──────────────────────────────────────────────────── */
.card{
  background:var(--color-surface);border-radius:var(--radius-xl);
  overflow:hidden;box-shadow:var(--shadow-sm);
  border:1px solid oklch(from var(--color-text) l c h / .06);
  transition:box-shadow var(--transition-interactive),transform var(--transition-interactive);
}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.card__img{width:100%;height:220px;object-fit:contain;background:var(--color-surface-2)}
.card__body{padding:var(--space-6)}
.card__tag{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-2)}
.card__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-weight-display);color:var(--color-text);margin-bottom:var(--space-3);line-height:1.2}
.card__text{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}

/* ── STATS ──────────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-6)}
.stat-item{text-align:center;padding:var(--space-8);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border)}
.stat-number{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-weight-display);color:var(--color-navy);line-height:1}
[data-theme=dark] .stat-number{color:var(--color-gold)}
.stat-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2)}

/* ── FORMULÁRIOS ────────────────────────────────────────────── */
.form-section{background:var(--color-surface-2);border-radius:var(--radius-xl);padding:clamp(var(--space-8),5vw,var(--space-12))}
.form-grid{display:grid;gap:var(--space-5)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:var(--space-2)}
.field label{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}
.field label .req{color:var(--color-error);margin-left:2px}
.field input,.field select,.field textarea{
  padding:var(--space-3) var(--space-4);
  border:1.5px solid var(--color-border);
  border-radius:var(--radius-md);
  background:var(--color-surface);
  font-size:var(--text-base);color:var(--color-text);
  transition:border-color var(--transition-interactive),box-shadow var(--transition-interactive);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--color-navy);
  box-shadow:0 0 0 3px var(--color-primary-highlight);
}
.field textarea{resize:vertical;min-height:100px}
.form-msg{padding:var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;display:none}
.form-msg.success{background:rgba(46,125,50,.1);color:var(--color-success);border:1px solid rgba(46,125,50,.2);display:block}
.form-msg.error{background:rgba(198,40,40,.1);color:var(--color-error);border:1px solid rgba(198,40,40,.2);display:block}

/* ── EXPOSIÇÕES ─────────────────────────────────────────────── */
.expo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));gap:var(--space-6)}
.expo-card{background:var(--color-surface);border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-interactive),transform var(--transition-interactive)}
.expo-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.expo-card__img{height:260px;object-fit:contain;width:100%;background:var(--color-surface-2);padding:var(--space-3)}
.expo-card__body{padding:var(--space-5)}
.expo-card__status{display:inline-block;font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);margin-bottom:var(--space-3)}
.expo-card__status--em-cartaz{background:rgba(46,125,50,.12);color:var(--color-success)}
.expo-card__status--prevista{background:rgba(200,168,75,.12);color:var(--color-gold)}
.expo-card__status--realizada{background:var(--color-surface-offset);color:var(--color-text-muted)}
.expo-card__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-weight-display);color:var(--color-text);margin-bottom:var(--space-2);line-height:1.2}
.expo-card__artist{font-size:var(--text-sm);color:var(--color-gold);font-weight:600;margin-bottom:var(--space-3)}
.expo-card__desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.55}

/* ── EQUIPE ─────────────────────────────────────────────────── */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));gap:var(--space-6)}
.team-card{text-align:center;padding:var(--space-6);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border)}
.team-card__avatar{width:80px;height:80px;border-radius:var(--radius-full);background:var(--color-navy);color:var(--color-gold);font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-weight-display);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4)}
.team-card__name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-weight-display);color:var(--color-text);margin-bottom:var(--space-1)}
.team-card__role{font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-3)}
.team-card__bio{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.55}

/* ── NAVEGANTES (cor especial) ──────────────────────────────── */
.nav-section{background:linear-gradient(135deg,#1a3a8f 0%,#0d1f4f 60%,#c8a84b15 100%)}
.nav-wave{width:100%;height:60px;display:block}

/* ── MODAL / OVERLAY ─────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;
  display:flex;align-items:center;justify-content:center;padding:var(--space-4);
  opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;
}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{
  background:var(--color-surface);border-radius:var(--radius-xl);
  padding:var(--space-8);max-width:520px;width:100%;max-height:90vh;
  overflow-y:auto;box-shadow:var(--shadow-lg);
  transform:translateY(16px);transition:transform .25s cubic-bezier(.16,1,.3,1);
}
.modal-overlay.open .modal{transform:translateY(0)}
.modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}
.modal__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-weight-display);color:var(--color-text)}
.modal__close{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:var(--space-2);border-radius:var(--radius-md)}
.modal__close:hover{color:var(--color-text);background:var(--color-surface-2)}

/* ── TABS ────────────────────────────────────────────────────── */
.tabs{display:flex;border-bottom:2px solid var(--color-border);margin-bottom:var(--space-8)}
.tab-btn{
  padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:600;
  color:var(--color-text-muted);background:none;border:none;cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:color var(--transition-interactive),border-color var(--transition-interactive);
}
.tab-btn.active,.tab-btn:hover{color:var(--color-navy);border-bottom-color:var(--color-navy)}
[data-theme=dark] .tab-btn.active,[data-theme=dark] .tab-btn:hover{color:var(--color-gold);border-bottom-color:var(--color-gold)}
.tab-panel{display:none}.tab-panel.active{display:block}

/* ── ÁREA DE MEMBROS ─────────────────────────────────────────── */
.member-area{
  min-height:60vh;display:flex;align-items:center;justify-content:center;
  padding:var(--space-12) var(--space-6);
}
.member-card{
  background:var(--color-surface);border-radius:var(--radius-xl);
  padding:var(--space-10);max-width:440px;width:100%;
  box-shadow:var(--shadow-lg);border:1px solid var(--color-border);
}
.member-card__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-weight-display);color:var(--color-navy);margin-bottom:var(--space-2);text-align:center}
[data-theme=dark] .member-card__title{color:var(--color-gold)}
.member-card__sub{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-8)}

.dashboard{padding:var(--space-12) var(--space-6);max-width:var(--content-wide);margin:0 auto;display:none}
.dashboard.visible{display:block}
.dashboard__welcome{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-weight-display);color:var(--color-text);margin-bottom:var(--space-2)}
.dashboard__role{display:inline-block;font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--color-navy);color:#fff;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);margin-bottom:var(--space-8)}
[data-theme=dark] .dashboard__role{background:var(--color-gold);color:var(--color-navy-deep)}

.info-box{background:var(--color-surface-2);border-radius:var(--radius-lg);padding:var(--space-6);border-left:4px solid var(--color-gold)}
.info-box h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-weight-display);color:var(--color-text);margin-bottom:var(--space-3)}
.info-box ul{list-style:disc;padding-left:var(--space-5)}
.info-box ul li{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-2)}

.admin-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{background:var(--color-navy);color:#fff;font-size:var(--text-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:var(--space-3) var(--space-4);text-align:left}
.admin-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text);border-bottom:1px solid var(--color-divider)}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--color-surface-offset)}

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer{
  background:var(--color-navy-deep);color:rgba(255,255,255,.7);
  padding-block:var(--space-12) var(--space-6);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-8);
  margin-bottom:var(--space-8);
}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .logo-text .name{color:#fff;font-size:var(--text-lg)}
.footer-brand .logo-text .tagline{color:var(--color-gold)}
.footer-desc{font-size:var(--text-sm);line-height:1.65;margin-top:var(--space-4);max-width:38ch}
.footer-col h4{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-4)}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}
.footer-col a{font-size:var(--text-sm);color:rgba(255,255,255,.6);text-decoration:none;transition:color var(--transition-interactive)}
.footer-col a:hover{color:#fff}
.footer-col p{font-size:var(--text-sm);line-height:var(--line-height-body)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:var(--space-6);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}
.footer-bottom p{font-size:var(--text-xs);color:rgba(255,255,255,.4)}
.social-links{display:flex;gap:var(--space-3)}
.social-links a{color:rgba(255,255,255,.5);transition:color var(--transition-interactive)}
.social-links a:hover{color:var(--color-gold)}

/* ── DETALHE DECORATIVO ─────────────────────────────────────── */
.gold-divider{height:3px;background:linear-gradient(90deg,transparent,var(--color-gold),transparent)}
.navy-bg{background:var(--color-navy);color:#fff}
.navy-bg .section-header h2{color:#fff}
.navy-bg .section-header p{color:rgba(255,255,255,.72)}

/* ── PÁGINA DE CONTEÚDO ─────────────────────────────────────── */
.prose{max-width:72ch;margin-inline:auto}
.prose h2{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-weight-display);color:var(--color-navy);margin-top:var(--space-10);margin-bottom:var(--space-4)}
[data-theme=dark] .prose h2{color:var(--color-gold)}
.prose p{margin-bottom:var(--space-5);line-height:var(--line-height-body);color:var(--color-text)}
.prose blockquote{border-left:4px solid var(--color-gold);padding-left:var(--space-5);margin-block:var(--space-6);font-family:var(--font-display);font-size:var(--text-lg);font-style:italic;color:var(--color-text-muted)}

/* ── BADGES E CHIPS ─────────────────────────────────────────── */
.badge{display:inline-block;font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}
.badge--navy{background:var(--color-navy);color:#fff}
.badge--gold{background:var(--color-gold);color:var(--color-navy-deep)}
.badge--outline{border:1.5px solid var(--color-border);color:var(--color-text-muted)}

/* ── NOTÍCIAS ───────────────────────────────────────────────── */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:var(--space-6)}
.news-card{background:var(--color-surface);border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all var(--transition-interactive)}
.news-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.news-card__img{height:180px;object-fit:cover;width:100%}
.news-card__body{padding:var(--space-5)}
.news-card__date{font-size:var(--text-xs);color:var(--color-text-faint);margin-bottom:var(--space-2)}
.news-card__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-weight-display);color:var(--color-text);margin-bottom:var(--space-3);line-height:1.25}
.news-card__excerpt{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}

/* ── CONTATO ─────────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:var(--space-10);align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}
.contact-info-item{display:flex;gap:var(--space-4);padding:var(--space-4) 0;border-bottom:1px solid var(--color-divider)}
.contact-info-item:last-child{border-bottom:none}
.contact-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-primary-highlight);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-navy)}
[data-theme=dark] .contact-icon{color:var(--color-gold)}
.contact-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-1)}
.contact-value{font-size:var(--text-base);color:var(--color-text)}

/* ── ANIMAÇÕES ──────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeUp .5s cubic-bezier(.16,1,.3,1) both}
.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}

/* ── RESPONSIVE HELPERS ─────────────────────────────────────── */
@media(max-width:640px){
  .hero__title{font-size:clamp(2.2rem,.5rem + 9vw,4rem)}
  .section-header h2{font-size:clamp(1.8rem,1rem + 3vw,2.5rem)}
  .hero__actions{flex-direction:column;align-items:flex-start}
}
