/* FC Praia Branca — Main Stylesheet v2 */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Montserrat:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --primary:       #0D47A1;
  --primary-dark:  #0a3575;
  --primary-mid:   #1565C0;
  --primary-light: #1976D2;
  --accent:        #C9A84C;
  --accent-dark:   #a8893a;
  --white:         #FFFFFF;
  --off-white:     #F8FAFC;
  --light:         #EDF2F7;
  --mid:           #CBD5E1;
  --text:          #0F172A;
  --text-secondary:#475569;
  --text-muted:    #94A3B8;
  --success:       #059669;
  --warning:       #D97706;
  --danger:        #DC2626;
  --info:          #2563EB;

  --font-display:  'Bebas Neue', sans-serif;
  --font-ui:       'Montserrat', sans-serif;
  --font-body:     'Inter', sans-serif;

  --radius-sm:     4px;
  --radius:        8px;
  --radius-lg:     16px;
  --radius-xl:     24px;

  --shadow-sm:     0 1px 3px rgba(0,0,0,.08);
  --shadow:        0 4px 16px rgba(0,0,0,.1);
  --shadow-lg:     0 16px 48px rgba(0,0,0,.16);
  --shadow-xl:     0 24px 64px rgba(0,0,0,.2);

  --transition:    all .25s ease;
  --nav-height:    72px;
}

/* ─── Reset ─────────────────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font-body); color:var(--text); background:var(--white); line-height:1.6; -webkit-font-smoothing:antialiased; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:inherit; }
ul, ol { list-style:none; }
input, select, textarea { font-family:inherit; }

/* ─── Typography ─────────────────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6 { font-family:var(--font-ui); font-weight:800; line-height:1.2; color:var(--text); }
.display { font-family:var(--font-display); letter-spacing:2px; line-height:1; }
.text-sm  { font-size:.875rem; }
.text-xs  { font-size:.75rem; }
.text-lg  { font-size:1.125rem; }
.text-xl  { font-size:1.25rem; }
.text-muted { color:var(--text-muted); }
.text-secondary { color:var(--text-secondary); }
.text-primary { color:var(--primary); }
.text-accent  { color:var(--accent); }
.text-center  { text-align:center; }
.fw-600 { font-weight:600; }
.fw-700 { font-weight:700; }

/* ─── Layout ─────────────────────────────────────────────────────────────── */
.container { width:100%; max-width:1200px; margin:0 auto; padding:0 24px; }
.container-sm { max-width:860px; }
.section { padding:80px 0; }
.section-sm { padding:48px 0; }
.section-lg { padding:120px 0; }
.grid { display:grid; gap:24px; }
.grid-2 { grid-template-columns:repeat(2,1fr); }
.grid-3 { grid-template-columns:repeat(3,1fr); }
.grid-4 { grid-template-columns:repeat(4,1fr); }
.flex { display:flex; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.gap-1 { gap:8px; }
.gap-2 { gap:16px; }
.gap-3 { gap:24px; }
.gap-4 { gap:32px; }
.mt-1 { margin-top:8px; }
.mt-2 { margin-top:16px; }
.mt-3 { margin-top:24px; }
.mt-4 { margin-top:32px; }
.mb-1 { margin-bottom:8px; }
.mb-2 { margin-bottom:16px; }
.mb-3 { margin-bottom:24px; }
.mb-4 { margin-bottom:32px; }

/* ─── Navigation ─────────────────────────────────────────────────────────── */
.site-header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-height);
  background:rgba(13,71,161,.97);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:var(--transition);
}
.site-header.scrolled {
  background:rgba(10,53,117,.99);
  box-shadow:0 4px 32px rgba(0,0,0,.3);
}
.nav-inner {
  display:flex; align-items:center; justify-content:space-between;
  height:var(--nav-height); gap:32px;
}
.nav-brand { display:flex; align-items:center; gap:14px; flex-shrink:0; }
.nav-logo {
  width:46px; height:46px; border-radius:50%;
  background:var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:1.1rem; color:var(--primary);
  font-weight:900; letter-spacing:1px;
}
.nav-brand-text { color:var(--white); }
.nav-brand-name { font-family:var(--font-display); font-size:1.25rem; letter-spacing:1px; display:block; }
.nav-brand-sub  { font-size:.65rem; opacity:.6; letter-spacing:2px; text-transform:uppercase; font-family:var(--font-ui); font-weight:500; }
.nav-links { display:flex; align-items:center; gap:4px; flex:1; justify-content:center; }
.nav-link {
  color:rgba(255,255,255,.8); font-family:var(--font-ui); font-size:.82rem;
  font-weight:600; letter-spacing:.5px; text-transform:uppercase;
  padding:8px 14px; border-radius:var(--radius-sm);
  transition:var(--transition); position:relative;
}
.nav-link:hover, .nav-link.active { color:var(--white); background:rgba(255,255,255,.1); }
.nav-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.hamburger { display:none; background:none; border:none; color:var(--white); padding:8px; }
.hamburger .material-icons { font-size:1.6rem; }

/* ─── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 28px; border-radius:var(--radius); border:2px solid transparent;
  font-family:var(--font-ui); font-size:.875rem; font-weight:700;
  letter-spacing:.5px; text-transform:uppercase;
  transition:var(--transition); cursor:pointer; white-space:nowrap;
}
.btn-primary   { background:var(--primary); color:var(--white); border-color:var(--primary); }
.btn-primary:hover { background:var(--primary-dark); border-color:var(--primary-dark); transform:translateY(-1px); box-shadow:0 8px 24px rgba(13,71,161,.4); }
.btn-accent    { background:var(--accent); color:var(--primary); border-color:var(--accent); }
.btn-accent:hover { background:var(--accent-dark); border-color:var(--accent-dark); transform:translateY(-1px); box-shadow:0 8px 24px rgba(201,168,76,.4); }
.btn-outline   { background:transparent; color:var(--primary); border-color:var(--primary); }
.btn-outline:hover { background:var(--primary); color:var(--white); }
.btn-outline-white { background:transparent; color:var(--white); border-color:rgba(255,255,255,.6); }
.btn-outline-white:hover { background:var(--white); color:var(--primary); border-color:var(--white); }
.btn-white     { background:var(--white); color:var(--primary); border-color:var(--white); }
.btn-white:hover { background:var(--off-white); }
.btn-danger    { background:var(--danger); color:var(--white); border-color:var(--danger); }
.btn-sm        { padding:8px 18px; font-size:.78rem; }
.btn-lg        { padding:16px 40px; font-size:1rem; }
.btn-block     { width:100%; }
.btn:disabled  { opacity:.5; cursor:not-allowed; transform:none !important; }

/* ─── Cards ─────────────────────────────────────────────────────────────── */
.card {
  background:var(--white); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); overflow:hidden;
  transition:var(--transition);
}
.card:hover { box-shadow:var(--shadow-lg); }
.card-body  { padding:28px; }
.card-img   { width:100%; aspect-ratio:16/9; object-fit:cover; }

/* ─── Hero ───────────────────────────────────────────────────────────────── */
.hero {
  min-height:100vh; position:relative; overflow:hidden;
  display:flex; align-items:center;
  background:linear-gradient(160deg, var(--primary-dark) 0%, var(--primary) 50%, var(--primary-light) 100%);
  padding-top:var(--nav-height);
}
.hero-bg {
  position:absolute; inset:0;
  background:url('../images/hero-bg.jpg') center/cover no-repeat;
  opacity:.15; mix-blend-mode:luminosity;
}
.hero-pattern {
  position:absolute; inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.06) 1px, transparent 0);
  background-size:32px 32px;
}
.hero-content { position:relative; z-index:1; padding:80px 0; }
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(201,168,76,.15); border:1px solid rgba(201,168,76,.4);
  color:var(--accent); padding:6px 16px; border-radius:50px;
  font-size:.75rem; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  margin-bottom:24px;
}
.hero-title { font-size:clamp(3rem,8vw,6rem); color:var(--white); margin-bottom:16px; }
.hero-subtitle { font-size:1.1rem; color:rgba(255,255,255,.75); max-width:540px; line-height:1.7; margin-bottom:40px; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; }
.hero-stats {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
  margin-top:64px; padding-top:40px;
  border-top:1px solid rgba(255,255,255,.1);
}
.hero-stat-value { font-family:var(--font-display); font-size:3rem; color:var(--accent); }
.hero-stat-label { font-size:.8rem; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:1px; margin-top:4px; font-weight:600; }

/* ─── Section headers ────────────────────────────────────────────────────── */
.section-header { margin-bottom:56px; }
.section-tag {
  display:inline-block; font-size:.72rem; font-weight:700;
  letter-spacing:3px; text-transform:uppercase; color:var(--accent);
  background:rgba(201,168,76,.1); padding:4px 14px; border-radius:50px;
  border:1px solid rgba(201,168,76,.25); margin-bottom:16px;
}
.section-title { font-size:clamp(1.8rem,4vw,2.8rem); }
.section-desc  { color:var(--text-secondary); font-size:1.05rem; max-width:600px; margin-top:12px; line-height:1.7; }
.divider-accent {
  width:56px; height:3px; background:var(--accent);
  border-radius:2px; margin-top:16px;
}

/* ─── Results strip ──────────────────────────────────────────────────────── */
.results-strip { background:var(--primary); padding:16px 0; overflow:hidden; }
.results-marquee { display:flex; gap:48px; animation:marquee 30s linear infinite; white-space:nowrap; }
.results-marquee:hover { animation-play-state:paused; }
.result-item { display:flex; align-items:center; gap:16px; flex-shrink:0; }
.result-item .teams { color:rgba(255,255,255,.9); font-size:.82rem; font-weight:600; }
.result-item .score {
  font-family:var(--font-display); font-size:1.1rem; color:var(--accent);
  background:rgba(255,255,255,.1); padding:3px 12px; border-radius:4px;
}
.result-item .comp { font-size:.7rem; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:1px; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ─── Match card ─────────────────────────────────────────────────────────── */
.match-card { background:var(--white); border-radius:var(--radius); padding:20px 24px; border:1px solid var(--light); transition:var(--transition); }
.match-card:hover { border-color:var(--primary); box-shadow:var(--shadow); }
.match-teams { display:flex; align-items:center; justify-content:center; gap:20px; margin:12px 0; }
.match-team-name { font-weight:700; font-size:.9rem; text-align:center; flex:1; }
.match-score { font-family:var(--font-display); font-size:1.8rem; color:var(--primary); text-align:center; min-width:80px; }
.match-vs { font-size:.75rem; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; }
.match-meta { font-size:.75rem; color:var(--text-muted); text-align:center; }
.match-result-w { color:var(--success); }
.match-result-d { color:var(--warning); }
.match-result-l { color:var(--danger); }

/* ─── Player card ────────────────────────────────────────────────────────── */
.player-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--light); transition:var(--transition); }
.player-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--primary); }
.player-photo { position:relative; height:260px; background:linear-gradient(160deg,var(--primary),var(--primary-mid)); overflow:hidden; }
.player-photo img { width:100%; height:100%; object-fit:cover; object-position:top; }
.player-number { position:absolute; top:16px; right:16px; font-family:var(--font-display); font-size:2.5rem; color:rgba(255,255,255,.15); line-height:1; }
.player-position-badge {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent, rgba(13,71,161,.9));
  padding:24px 16px 12px;
}
.player-position { font-size:.7rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--accent); }
.player-info { padding:20px; }
.player-name { font-size:1.05rem; font-weight:800; }
.player-nationality { font-size:.78rem; color:var(--text-muted); margin-top:4px; }

/* ─── Project card ───────────────────────────────────────────────────────── */
.project-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--light); transition:var(--transition); }
.project-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.project-img { height:220px; overflow:hidden; }
.project-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.project-card:hover .project-img img { transform:scale(1.05); }
.project-body { padding:24px; }
.project-status { font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; margin-bottom:10px; }
.project-title { font-size:1.1rem; font-weight:800; margin-bottom:10px; }
.project-desc  { font-size:.875rem; color:var(--text-secondary); line-height:1.6; }
.progress { height:6px; background:var(--light); border-radius:3px; margin:16px 0 8px; overflow:hidden; }
.progress-bar { height:100%; background:linear-gradient(90deg,var(--primary),var(--accent)); border-radius:3px; transition:width 1s ease; }
.progress-info { display:flex; justify-content:space-between; font-size:.78rem; }
.progress-raised { color:var(--primary); font-weight:700; }
.progress-pct    { color:var(--text-muted); }

/* ─── Blog card ──────────────────────────────────────────────────────────── */
.post-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--light); transition:var(--transition); }
.post-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.post-img { height:200px; overflow:hidden; }
.post-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.post-card:hover .post-img img { transform:scale(1.05); }
.post-body { padding:24px; }
.post-cat { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--primary); }
.post-title { font-size:1rem; font-weight:800; margin:8px 0; line-height:1.4; }
.post-meta  { font-size:.75rem; color:var(--text-muted); margin-top:12px; }

/* ─── Badges ─────────────────────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; padding:3px 12px;
  border-radius:50px; font-size:.68rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.5px;
}
.badge-success { background:rgba(5,150,105,.1); color:#059669; }
.badge-warning { background:rgba(217,119,6,.1); color:#D97706; }
.badge-danger  { background:rgba(220,38,38,.1); color:#DC2626; }
.badge-info    { background:rgba(37,99,235,.1); color:#2563EB; }
.badge-primary { background:rgba(13,71,161,.1); color:var(--primary); }
.badge-accent  { background:rgba(201,168,76,.15); color:#a8893a; }
.badge-neutral { background:var(--light); color:var(--text-secondary); }

/* ─── Forms ──────────────────────────────────────────────────────────────── */
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:20px; }
.form-label { font-size:.82rem; font-weight:700; color:var(--text); letter-spacing:.3px; }
.form-label span { color:var(--danger); }
.form-control {
  width:100%; padding:12px 16px;
  border:2px solid var(--light); border-radius:var(--radius);
  font-family:var(--font-body); font-size:.9rem; color:var(--text);
  background:var(--white); transition:var(--transition);
  outline:none;
}
.form-control:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(13,71,161,.1); }
.form-control.error { border-color:var(--danger); }
textarea.form-control { resize:vertical; min-height:120px; }
.form-hint { font-size:.75rem; color:var(--text-muted); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }

/* ─── Alerts ─────────────────────────────────────────────────────────────── */
.alert {
  display:flex; align-items:center; gap:12px;
  padding:14px 20px; border-radius:var(--radius); font-size:.875rem;
  margin-bottom:20px; font-weight:500;
}
.alert .material-icons { font-size:1.2rem; flex-shrink:0; }
.alert-success { background:rgba(5,150,105,.1); color:#065f46; border:1px solid rgba(5,150,105,.2); }
.alert-danger  { background:rgba(220,38,38,.1); color:#991b1b; border:1px solid rgba(220,38,38,.2); }
.alert-warning { background:rgba(217,119,6,.1); color:#92400e; border:1px solid rgba(217,119,6,.2); }
.alert-info    { background:rgba(37,99,235,.1); color:#1e3a8a; border:1px solid rgba(37,99,235,.2); }

/* ─── Membership plans ───────────────────────────────────────────────────── */
.plan-card {
  background:var(--white); border-radius:var(--radius-xl);
  border:2px solid var(--light); padding:40px 36px;
  transition:var(--transition); position:relative; overflow:hidden;
}
.plan-card.popular {
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(13,71,161,.08), var(--shadow-lg);
}
.plan-card.premium-plan {
  background:linear-gradient(160deg, var(--primary-dark), var(--primary));
  border-color:var(--accent);
  color:var(--white);
}
.plan-badge {
  position:absolute; top:20px; right:20px;
  background:var(--accent); color:var(--primary);
  font-size:.65rem; font-weight:900; letter-spacing:2px;
  text-transform:uppercase; padding:4px 12px; border-radius:50px;
}
.plan-name  { font-size:1.3rem; font-weight:800; margin-bottom:8px; }
.plan-price { font-family:var(--font-display); font-size:3.5rem; line-height:1; }
.plan-price small { font-family:var(--font-ui); font-size:.85rem; font-weight:500; opacity:.7; }
.plan-benefits { margin:28px 0; }
.plan-benefits li {
  padding:8px 0; border-bottom:1px solid rgba(0,0,0,.05);
  font-size:.875rem; display:flex; align-items:center; gap:10px;
}
.plan-card.premium-plan .plan-benefits li { border-bottom-color:rgba(255,255,255,.1); }
.plan-benefits li .material-icons { font-size:1rem; color:var(--success); flex-shrink:0; }
.plan-card.premium-plan .plan-benefits li .material-icons { color:var(--accent); }

/* ─── Payment method selector ────────────────────────────────────────────── */
.payment-methods { display:grid; gap:12px; }
.payment-method-option { position:relative; }
.payment-method-option input[type=radio] { position:absolute; opacity:0; }
.payment-method-label {
  display:flex; align-items:center; gap:16px;
  padding:16px 20px; border:2px solid var(--light);
  border-radius:var(--radius); cursor:pointer; transition:var(--transition);
  font-weight:600; font-size:.875rem;
}
.payment-method-label:hover { border-color:var(--primary); }
.payment-method-option input:checked + .payment-method-label {
  border-color:var(--primary); background:rgba(13,71,161,.04);
}
.payment-method-icon { width:40px; height:28px; object-fit:contain; }
.payment-method-info { flex:1; }
.payment-method-name { font-weight:700; font-size:.9rem; }
.payment-method-desc { font-size:.75rem; color:var(--text-muted); font-weight:400; }
.payment-details { background:var(--off-white); border-radius:var(--radius); padding:20px; margin-top:16px; display:none; }
.payment-details.active { display:block; }
.bank-details { font-size:.875rem; }
.bank-details .detail-row { display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid var(--light); }
.bank-details .detail-label { color:var(--text-secondary); }
.bank-details .detail-value { font-weight:700; font-family:monospace; }

/* ─── Donations ──────────────────────────────────────────────────────────── */
.amount-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:16px; }
.amount-btn {
  padding:14px 8px; border:2px solid var(--light);
  border-radius:var(--radius); background:var(--white);
  font-family:var(--font-ui); font-size:.9rem; font-weight:700;
  text-align:center; cursor:pointer; transition:var(--transition);
  color:var(--text);
}
.amount-btn:hover { border-color:var(--primary); color:var(--primary); }
.amount-btn.active { border-color:var(--primary); background:var(--primary); color:var(--white); }

/* ─── Stats ──────────────────────────────────────────────────────────────── */
.stat-block { text-align:center; }
.stat-value { font-family:var(--font-display); font-size:3.5rem; color:var(--primary); line-height:1; }
.stat-label { font-size:.8rem; font-weight:600; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-top:8px; }

/* ─── Page hero ──────────────────────────────────────────────────────────── */
.page-hero {
  background:linear-gradient(160deg, var(--primary-dark) 0%, var(--primary) 100%);
  padding:120px 0 64px; margin-top:var(--nav-height);
  position:relative; overflow:hidden;
}
.page-hero::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:60px;
  background:var(--white); clip-path:ellipse(55% 100% at 50% 100%);
}
.page-hero-title { font-family:var(--font-display); font-size:clamp(2.5rem,6vw,4.5rem); color:var(--white); }
.page-hero-subtitle { color:rgba(255,255,255,.7); margin-top:12px; font-size:1rem; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:.8rem; color:rgba(255,255,255,.5); margin-bottom:16px; }
.breadcrumb a { color:rgba(255,255,255,.7); }
.breadcrumb a:hover { color:var(--white); }
.breadcrumb .sep { opacity:.4; }

/* ─── Tables ─────────────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
th { text-align:left; padding:12px 16px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--text-secondary); border-bottom:2px solid var(--light); background:var(--off-white); }
td { padding:14px 16px; border-bottom:1px solid var(--light); font-size:.875rem; vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:var(--off-white); }

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.site-footer { background:var(--text); color:rgba(255,255,255,.7); padding:72px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:56px; }
.footer-brand .nav-logo { margin-bottom:16px; background:rgba(201,168,76,.15); border:1px solid rgba(201,168,76,.3); }
.footer-title { font-family:var(--font-display); font-size:1.4rem; color:var(--white); margin-bottom:6px; letter-spacing:1px; }
.footer-desc { font-size:.875rem; line-height:1.7; max-width:300px; }
.footer-col-title { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,.4); margin-bottom:20px; }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-link { font-size:.875rem; color:rgba(255,255,255,.65); transition:color .2s; }
.footer-link:hover { color:var(--accent); }
.footer-socials { display:flex; gap:10px; margin-top:20px; }
.footer-social { width:38px; height:38px; border-radius:var(--radius-sm); background:rgba(255,255,255,.07); display:flex; align-items:center; justify-content:center; transition:var(--transition); }
.footer-social:hover { background:var(--accent); color:var(--primary); }
.footer-social .material-icons { font-size:1.1rem; color:inherit; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding:24px 0; display:flex; align-items:center; justify-content:space-between; font-size:.78rem; color:rgba(255,255,255,.35); flex-wrap:wrap; gap:12px; }

/* ─── Modals ─────────────────────────────────────────────────────────────── */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:2000; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(4px); }
.modal-overlay.open { display:flex; animation:fadeIn .2s; }
.modal { background:var(--white); border-radius:var(--radius-xl); width:100%; max-width:560px; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-xl); }
.modal-header { padding:28px 32px 20px; border-bottom:1px solid var(--light); display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; background:var(--white); z-index:1; }
.modal-title { font-size:1.1rem; font-weight:800; }
.modal-close { background:none; border:none; color:var(--text-muted); cursor:pointer; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:var(--transition); }
.modal-close:hover { background:var(--light); color:var(--text); }
.modal-close .material-icons { font-size:1.3rem; }
.modal-body { padding:28px 32px; }
.modal-footer { padding:20px 32px 28px; display:flex; gap:12px; justify-content:flex-end; }

/* ─── Animations ─────────────────────────────────────────────────────────── */
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes slideUp  { from{transform:translateY(30px);opacity:0} to{transform:translateY(0);opacity:1} }
@keyframes shimmer  { 0%{background-position:-1000px 0} 100%{background-position:1000px 0} }

.animate-in { opacity:0; transform:translateY(28px); transition:opacity .6s ease, transform .6s ease; }
.animate-in.visible { opacity:1; transform:translateY(0); }

/* ─── Utilities ──────────────────────────────────────────────────────────── */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
.hidden { display:none !important; }

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width:1024px) {
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:768px) {
  :root { --nav-height:64px; }
  .nav-links, .nav-actions .btn { display:none; }
  .hamburger { display:flex; }
  .nav-links.open {
    display:flex; flex-direction:column;
    position:fixed; top:var(--nav-height); left:0; right:0;
    background:var(--primary-dark); padding:20px;
    border-top:1px solid rgba(255,255,255,.1);
    gap:4px; z-index:999;
  }
  .nav-link { width:100%; padding:12px 16px; }
  .grid-2, .grid-3 { grid-template-columns:1fr; }
  .hero-stats { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
  .amount-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .plan-card { padding:28px 24px; }
}
@media (max-width:480px) {
  .hero-stats { grid-template-columns:1fr; }
  .hero-actions { flex-direction:column; }
  .btn-lg { padding:14px 24px; font-size:.9rem; }
}
