/* ══════════════════════════════════════
   MUSEU JUDAICO RJ — Base Styles v1.0
   Compartilhado por todas as páginas
══════════════════════════════════════ */
:root {
  --navy:          #1B254F;
  --navy-deep:     #111830;
  --navy-mid:      #2A3870;
  --navy-tint:     rgba(27,37,79,.06);
  --gold:          #B49150;
  --gold-dark:     #8A6A35;
  --gold-light:    #D4B87A;
  --gold-pale:     #F0E4C8;
  --off-white:     #FAFAF7;
  --parchment:     #F2EDE3;
  --dark:          #0E0E14;
  --dark-2:        #16161F;
  --ink:           #14141C;
  --ink-2:         #2E2E3A;
  --ink-3:         #5A5A70;
  --ink-inv:       #FFFFFF;
  --inv-muted:     rgba(255,255,255,.60);
  --inv-faint:     rgba(255,255,255,.28);
  --border:        #DDD8CE;
  --border-dark:   rgba(255,255,255,.10);
  --success:       #2A7A4B;
  --success-bg:    #EBF5F0;
  --error:         #B03A2E;
  --error-bg:      #FDECEA;
  --serif:  'Cormorant Garamond', Georgia, serif;
  --sans:   'Source Sans 3', system-ui, sans-serif;
  --mono:   'JetBrains Mono', monospace;
  --container: 1200px;
  --gutter:    clamp(1.5rem, 5vw, 4rem);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--sans); background: var(--off-white); color: var(--ink); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; }

/* ── i18n FOUC prevention ── */
html.i18n-loading body { opacity: 0; }
body { transition: opacity 100ms ease; }

/* ── Skip-to-content ── */
.skip-link {
  position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden;
  background: var(--navy); color: #fff; padding: .75rem 1.5rem; font-weight: 600; font-size: .875rem;
  border-radius: 0 0 6px 0; z-index: 10000; text-decoration: none;
}
.skip-link:focus {
  position: fixed; left: 0; top: 0; width: auto; height: auto; overflow: visible;
}

.wrap { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

/* ── Ícones ── */
.icon { display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
.icon svg { display:block; fill:none; stroke:currentColor; stroke-linecap:round; stroke-linejoin:round; }
.icon-sm  svg { width:14px; height:14px; stroke-width:2; }
.icon-md  svg { width:18px; height:18px; stroke-width:1.75; }
.icon-lg  svg { width:24px; height:24px; stroke-width:1.5; }
.icon-xl  svg { width:40px; height:40px; stroke-width:1.25; }

/* ── Grain overlay ── */
.grain::after {
  content:''; position:absolute; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none; opacity:.55; mix-blend-mode:overlay;
}

/* ── Scroll progress ── */
#progress { position:fixed; top:0; left:0; height:2px; background:linear-gradient(to right,var(--gold),var(--gold-light)); width:0%; z-index:999; transition:width 100ms linear; }

/* ── NAVBAR ── */
.nav { position:fixed; top:0; left:0; right:0; z-index:200; height:60px; display:flex; align-items:center; transition:background 300ms ease,backdrop-filter 300ms ease,border-color 300ms ease; border-bottom:1px solid transparent; }
.nav.scrolled { background:rgba(27,37,79,.96); backdrop-filter:blur(16px) saturate(1.3); -webkit-backdrop-filter:blur(16px) saturate(1.3); border-bottom-color:rgba(255,255,255,.07); }
.nav.solid { background:var(--navy); border-bottom-color:rgba(255,255,255,.07); }
.nav-inner { max-width:var(--container); margin:0 auto; padding:0 var(--gutter); width:100%; display:flex; align-items:center; gap:2rem; }
.nav-logo { text-decoration:none; display:flex; align-items:center; flex-shrink:0; margin-right:.25rem; }
.nav-logo-img { height:36px; width:auto; display:block; mix-blend-mode:screen; filter:brightness(1.05); }
.nav-links { display:flex; list-style:none; flex:1; gap:0; }
.nav-links a { display:flex; align-items:center; gap:4px; padding:0 .9rem; height:60px; font-size:.8125rem; font-weight:400; color:rgba(255,255,255,.68); text-decoration:none; letter-spacing:.005em; transition:color 150ms; white-space:nowrap; }
.nav-links a:hover, .nav-links a.active { color:var(--gold-light); }
.nav-dd { position:relative; }
.nav-dd-btn { cursor:pointer; user-select:none; }
.dd-chev { color:rgba(255,255,255,.35); transition:transform 220ms ease,color 220ms ease; }
.nav-dd:hover .dd-chev { transform:rotate(180deg); color:var(--gold-light); }
.nav-dd-panel { position:absolute; top:calc(100% + 1px); left:0; min-width:236px; background:var(--off-white); border-top:2px solid var(--gold); border-radius:0 0 6px 6px; box-shadow:0 16px 40px rgba(14,14,20,.18),0 4px 8px rgba(14,14,20,.08); opacity:0; visibility:hidden; transform:translateY(-8px); transition:opacity 200ms ease,transform 200ms ease,visibility 200ms; }
.nav-dd:hover .nav-dd-panel { opacity:1; visibility:visible; transform:translateY(0); }
.nav-dd-panel a { display:flex; align-items:center; gap:.75rem; padding:.75rem 1.25rem; height:auto; font-size:.8rem; color:var(--ink-2); border-bottom:1px solid var(--parchment); transition:background 120ms,color 120ms; }
.nav-dd-panel a:hover, .nav-dd-panel a.active { background:var(--navy-tint); color:var(--navy); }
.nav-dd-panel .icon { color:var(--gold); }
.nav-dd-panel a:last-child { border-bottom:none; }
.nav-right { display:flex; align-items:center; gap:1rem; flex-shrink:0; }
.nav-assoc { display:inline-flex; align-items:center; height:30px; padding:0 .875rem; background:var(--gold); color:white; font-family:var(--sans); font-size:.7rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase; text-decoration:none; border-radius:3px; transition:background 150ms; }
.nav-assoc:hover, .nav-assoc.active { background:var(--gold-dark); }
.nav-lang { display:flex; align-items:center; gap:.375rem; font-family:var(--mono); font-size:.65rem; font-weight:400; letter-spacing:.08em; }
.nav-lang a { text-decoration:none; transition:color 150ms; }
.nav-lang .on  { color:var(--gold-light); }
.nav-lang .off { color:rgba(255,255,255,.3); }
.nav-lang .off:hover { color:rgba(255,255,255,.6); }
.nav-lang-sep { color:rgba(255,255,255,.18); }

/* ── PAGE HEADER ── */
.page-header { background:var(--navy); padding:calc(60px + 4.5rem) 0 4rem; position:relative; overflow:hidden; }
.page-header::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 15% 60%,rgba(42,56,112,.7) 0%,transparent 65%); pointer-events:none; }
.ph-pattern { position:absolute; inset:0; opacity:.022; background-image:url("data:image/svg+xml,%3Csvg width='80' height='92' viewBox='0 0 80 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.6'%3E%3Cpolygon points='40,4 60,36 80,36 60,56 68,88 40,72 12,88 20,56 0,36 20,36'/%3E%3C/g%3E%3C/svg%3E"); background-size:80px 92px; }
.ph-vline { position:absolute; left:var(--gutter); top:0; bottom:0; width:1px; background:linear-gradient(to bottom,transparent,var(--gold) 25%,var(--gold) 75%,transparent); opacity:.18; }
.ph-body { position:relative; z-index:1; }
.ph-eyebrow { display:inline-flex; align-items:center; gap:.625rem; font-family:var(--mono); font-size:.65rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-light); margin-bottom:1.25rem; }
.ph-eyebrow::before { content:''; display:block; width:28px; height:1px; background:var(--gold); }
.ph-h1 { font-family:var(--serif); font-size:clamp(2.75rem,6vw,5rem); font-weight:300; color:white; line-height:.95; letter-spacing:-.02em; }
.ph-h1 em { font-style:italic; font-weight:400; color:var(--gold-light); }
.ph-sub { font-size:.9375rem; color:rgba(255,255,255,.5); max-width:560px; line-height:1.65; margin-top:1.25rem; }
.ph-rule { height:1px; background:linear-gradient(to right,var(--gold) 0%,rgba(180,145,80,.2) 50%,transparent 100%); margin-top:2.5rem; }

/* ── BOTÕES ── */
.btn { display:inline-flex; align-items:center; gap:.5rem; font-family:var(--sans); font-weight:600; border:none; border-radius:3px; cursor:pointer; text-decoration:none; white-space:nowrap; transition:background 150ms,color 150ms,border-color 150ms,transform 150ms; }
.btn:active { transform:scale(.98); }
.btn-sm { height:36px; padding:0 1.125rem; font-size:.8125rem; }
.btn-md { height:42px; padding:0 1.5rem; font-size:.9rem; }
.btn-lg { height:50px; padding:0 2rem; font-size:.9375rem; }
.btn-primary   { background:var(--navy); color:white; }
.btn-primary:hover { background:var(--navy-deep); }
.btn-outline-inv { background:transparent; color:white; border:1px solid rgba(255,255,255,.4); }
.btn-outline-inv:hover { background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.65); }
.btn-outline  { background:transparent; color:var(--navy); border:1px solid var(--navy); }
.btn-outline:hover { background:var(--navy-tint); }
.btn-gold     { background:var(--gold); color:white; }
.btn-gold:hover { background:var(--gold-dark); }
.btn-navy     { background:var(--navy); color:white; }
.btn-navy:hover { background:var(--navy-deep); }
.btn-ghost    { background:transparent; color:var(--ink-3); border:1px solid var(--border); }
.btn-ghost:hover { border-color:var(--navy); color:var(--navy); }

/* ── SECTION HELPERS ── */
.section { position:relative; }
.section-light { background:var(--off-white); }
.section-parch { background:var(--parchment); }
.section-navy  { background:var(--navy); }
.section-dark  { background:var(--dark-2); }
.sp    { padding:clamp(4rem,8vw,7rem) 0; }
.sp-sm { padding:clamp(3rem,5vw,4.5rem) 0; }
.sp-xs { padding:clamp(2rem,4vw,3rem) 0; }

/* ── EYEBROW ── */
.eyebrow { display:flex; align-items:center; gap:.75rem; margin-bottom:1.5rem; }
.eyebrow-rule { flex:0 0 36px; height:1px; background:var(--gold); opacity:.7; }
.eyebrow-name { font-family:var(--mono); font-size:.6rem; font-weight:400; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.eyebrow-inv .eyebrow-rule { background:var(--gold-light); opacity:.6; }
.eyebrow-inv .eyebrow-name { color:rgba(255,255,255,.4); }

/* ── TÍTULOS ── */
.sec-title { font-family:var(--serif); font-size:clamp(2.25rem,4.5vw,3.75rem); font-weight:400; line-height:1.08; letter-spacing:-.015em; color:var(--ink); }
.sec-title em { font-style:italic; color:var(--navy-mid); }
.sec-title-inv { color:white; }
.sec-title-inv em { color:var(--gold-light); }
.sec-intro { font-size:1rem; color:var(--ink-3); line-height:1.7; max-width:580px; }
.sec-intro-inv { color:var(--inv-muted); }

/* ── FORMULÁRIOS ── */
.form-group { display:flex; flex-direction:column; gap:.5rem; }
.form-label { font-family:var(--mono); font-size:.65rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.form-label .req { color:var(--gold); margin-left:2px; }
.form-input, .form-textarea, .form-select {
  font-family:var(--sans); font-size:.9375rem; color:var(--ink);
  background:white; border:1px solid var(--border); border-radius:4px;
  padding:.75rem 1rem; width:100%;
  transition:border-color 150ms,box-shadow 150ms;
  outline:none; appearance:none;
}
.form-input:focus, .form-textarea:focus, .form-select:focus { border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,37,79,.08); }
.form-input::placeholder, .form-textarea::placeholder { color:var(--ink-3); }
.form-textarea { resize:vertical; min-height:140px; line-height:1.6; }
.form-select { background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235A5A70' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.5rem; }
.form-row { display:grid; gap:1.25rem; }
.form-row-2 { grid-template-columns:1fr 1fr; }
.form-row-3 { grid-template-columns:1fr 1fr 1fr; }
.form-success { display:none; padding:1.25rem 1.5rem; background:#EAF5EE; border:1px solid #7CC9A0; border-radius:4px; font-size:.9rem; color:#1A6B3C; }
.form-success.show { display:block; }

/* ── SEARCH BAR ── */
.search-bar { display:flex; gap:0; }
.search-input { flex:1; font-family:var(--mono); font-size:.875rem; color:var(--ink); background:white; border:1.5px solid var(--border); border-right:none; border-radius:4px 0 0 4px; padding:.875rem 1.25rem; outline:none; transition:border-color 150ms; }
.search-input:focus { border-color:var(--navy); }
.search-btn { background:var(--navy); color:white; border:none; border-radius:0 4px 4px 0; padding:0 1.5rem; cursor:pointer; display:flex; align-items:center; gap:.5rem; font-family:var(--sans); font-size:.875rem; font-weight:600; transition:background 150ms; white-space:nowrap; }
.search-btn:hover { background:var(--navy-deep); }
.search-select { font-family:var(--sans); font-size:.875rem; color:var(--ink); background:white; border:1.5px solid var(--border); border-right:none; padding:0 2rem 0 1rem; outline:none; cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235A5A70' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right .75rem center; transition:border-color 150ms; }
.search-select:focus { border-color:var(--navy); outline:none; }

/* ── FOOTER ── */
.footer { background:var(--dark); border-top:1px solid rgba(255,255,255,.04); }
.footer-main { padding:clamp(3.5rem,6vw,5.5rem) 0 clamp(3rem,5vw,4rem); }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1.5fr; gap:clamp(2rem,5vw,5rem); }
.ft-brand { font-family:var(--serif); font-size:1.75rem; font-style:italic; font-weight:500; color:white; line-height:1; margin-bottom:2px; }
.ft-brand-sub { font-family:var(--mono); font-size:.58rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.25); margin-bottom:1.75rem; }
.ft-rule { width:28px; height:1px; background:var(--gold); margin-bottom:1.5rem; opacity:.7; }
.ft-contact { display:flex; align-items:center; gap:.5rem; font-size:.8125rem; color:rgba(255,255,255,.55); text-decoration:none; margin-bottom:.625rem; transition:color 150ms; line-height:1.4; }
.ft-contact:hover { color:var(--gold-light); }
.ft-contact .icon { color:rgba(255,255,255,.28); flex-shrink:0; transition:color 150ms; }
.ft-contact:hover .icon { color:var(--gold-light); }
.ft-socials { display:flex; gap:.5rem; margin-top:1.5rem; }
.ft-soc { width:34px; height:34px; border-radius:50%; border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.38); text-decoration:none; transition:border-color 150ms,color 150ms,background 150ms; }
.ft-soc:hover { border-color:var(--gold); color:var(--gold-light); background:rgba(180,145,80,.08); }
.ft-col-title { font-family:var(--mono); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-light); margin-bottom:1.25rem; }
.ft-nav { list-style:none; }
.ft-nav li + li { margin-top:2px; }
.ft-nav a { font-size:.8125rem; color:rgba(255,255,255,.5); text-decoration:none; display:block; padding:.25rem 0; transition:color 150ms; }
.ft-nav a:hover { color:var(--gold-light); }
.ft-pix { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:8px; padding:1.5rem; }
.ft-pix-row { display:flex; gap:1rem; margin-bottom:1.25rem; align-items:flex-start; }
.ft-qr { width:72px; height:72px; background:white; border-radius:4px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--navy); }
.ft-pix-txt { font-size:.8rem; color:rgba(255,255,255,.55); line-height:1.6; }
.ft-pix-key { display:flex; align-items:flex-start; justify-content:space-between; gap:.75rem; padding-top:1rem; border-top:1px solid rgba(255,255,255,.07); font-family:var(--mono); font-size:.6rem; color:rgba(255,255,255,.3); line-height:1.6; }
.ft-copy-btn { display:inline-flex; align-items:center; gap:4px; font-family:var(--sans); font-size:.7rem; font-weight:600; color:rgba(255,255,255,.4); background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.09); border-radius:3px; padding:3px 8px; cursor:pointer; flex-shrink:0; transition:background 150ms,color 150ms; }
.ft-copy-btn:hover { background:rgba(255,255,255,.1); color:rgba(255,255,255,.75); }
.ft-assoc-link { display:inline-flex; align-items:center; gap:.375rem; margin-top:1.25rem; font-size:.8rem; font-weight:600; color:var(--gold-light); text-decoration:none; transition:color 150ms,gap 150ms; }
.ft-assoc-link:hover { color:white; gap:.625rem; }
.ft-bottom { border-top:1px solid rgba(255,255,255,.05); padding:1.25rem 0; }
.ft-bottom-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.ft-copy-txt  { font-family:var(--mono); font-size:.6rem; color:rgba(255,255,255,.2); }
.ft-policy    { font-family:var(--mono); font-size:.6rem; color:rgba(255,255,255,.2); text-decoration:none; transition:color 150ms; }
.ft-policy:hover { color:rgba(255,255,255,.45); }

/* ── FLOATING PIX CARD ── */
.pix-float {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:180;
  width:280px;
  background:var(--navy); border:1px solid rgba(180,145,80,.25);
  border-radius:10px; box-shadow:0 12px 40px rgba(14,14,20,.35);
  padding:1.25rem 1.375rem;
  transform:translateY(0); opacity:1;
  transition:opacity .4s ease,transform .4s ease;
}
.pix-float.hidden {
  opacity:0; transform:translateY(12px); pointer-events:none;
}
.pix-float-close {
  position:absolute; top:.625rem; right:.625rem;
  width:24px; height:24px; border-radius:50%;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.35); cursor:pointer;
  transition:background 150ms,color 150ms;
}
.pix-float-close:hover { background:rgba(255,255,255,.12); color:rgba(255,255,255,.7); }
.pix-float-close svg { width:12px; height:12px; stroke:currentColor; stroke-width:2; fill:none; stroke-linecap:round; }
.pix-float-label {
  font-family:var(--mono); font-size:.55rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--gold-light); margin-bottom:.75rem;
  display:flex; align-items:center; gap:.5rem;
}
.pix-float-label::before {
  content:''; width:16px; height:1px; background:var(--gold); opacity:.6;
}
.pix-float-key {
  font-family:var(--mono); font-size:.72rem; color:rgba(255,255,255,.55);
  line-height:1.7; margin-bottom:.875rem;
}
.pix-float-key strong { color:rgba(255,255,255,.85); font-weight:500; }
.pix-float-copy {
  width:100%; display:flex; align-items:center; justify-content:center; gap:.375rem;
  height:34px; background:var(--gold); color:white;
  font-family:var(--sans); font-size:.75rem; font-weight:600;
  border:none; border-radius:4px; cursor:pointer;
  transition:background 150ms;
}
.pix-float-copy:hover { background:var(--gold-dark); }
.pix-float-copy .icon svg { width:13px; height:13px; stroke-width:2; }

/* ── REVEAL ── */
.sr { opacity:0; transform:translateY(22px); transition:opacity .75s cubic-bezier(.22,1,.36,1),transform .75s cubic-bezier(.22,1,.36,1); }
.sr.in { opacity:1; transform:none; }
.sr-d1{transition-delay:.08s} .sr-d2{transition-delay:.16s} .sr-d3{transition-delay:.24s} .sr-d4{transition-delay:.32s}

/* ══════════════════════════════════════
   HAMBURGER TOGGLE (hidden on desktop)
══════════════════════════════════════ */
.nav-toggle { display:none; width:40px; height:40px; background:none; border:1px solid rgba(255,255,255,.15); border-radius:6px; cursor:pointer; align-items:center; justify-content:center; color:rgba(255,255,255,.8); flex-shrink:0; margin-left:auto; transition:border-color 150ms,color 150ms; }
.nav-toggle:hover { border-color:rgba(255,255,255,.35); color:white; }
.nav-toggle svg { width:20px; height:20px; stroke:currentColor; stroke-width:2; fill:none; stroke-linecap:round; }

/* ══════════════════════════════════════
   RESPONSIVE — Tablet (≤960px)
══════════════════════════════════════ */
@media (max-width:960px) {
  :root { --gutter:clamp(1.25rem,4vw,2.5rem); }

  /* ── Nav: hamburger ── */
  .nav-inner { flex-wrap:wrap; }
  .nav-logo { order:1; }
  .nav-toggle { display:flex; margin-left:auto; order:2; }
  .nav-links { display:none; width:100%; order:3; }
  .nav-right { display:none; width:100%; order:4; }
  .nav.open { background:var(--navy) !important; height:100vh; height:100dvh; overflow-y:auto; align-items:flex-start; }
  .nav.open .nav-inner { align-items:flex-start; align-content:flex-start; }
  .nav.open .nav-links { display:flex; flex-direction:column; padding:.5rem 0; border-top:1px solid rgba(255,255,255,.06); }
  .nav.open .nav-links > li > a { height:auto; padding:.75rem var(--gutter); font-size:.875rem; color:rgba(255,255,255,.75); white-space:normal; }
  .nav.open .nav-right { display:flex; padding:.75rem var(--gutter) 1rem; border-top:1px solid rgba(255,255,255,.06); flex-wrap:wrap; gap:.75rem; }

  /* Dropdown no mobile: flat/open */
  .nav.open .nav-dd-panel { position:static; opacity:1; visibility:visible; transform:none; background:transparent; border:none; box-shadow:none; border-radius:0; min-width:0; border-top:none; }
  .nav.open .nav-dd-panel a { color:rgba(255,255,255,.5); border-bottom:none; padding:.5rem var(--gutter) .5rem calc(var(--gutter) + 1.5rem); font-size:.8125rem; height:auto; }
  .nav.open .nav-dd-panel a:hover { background:rgba(255,255,255,.04); color:var(--gold-light); }
  .nav.open .nav-dd-panel .icon { color:var(--gold); }
  .nav.open .dd-chev { display:none; }

  /* ── Page header ── */
  .page-header { padding:calc(60px + 3rem) 0 3rem; }
  .ph-h1 { font-size:clamp(2.25rem,5vw,3.5rem); }

  /* ── Footer ── */
  .footer-grid { grid-template-columns:1fr; gap:2.5rem; }
  .ft-bottom-inner { flex-direction:column; text-align:center; gap:.5rem; }

  /* ── Search bar ── */
  .search-bar { flex-wrap:wrap; }
  .search-select { width:100%; border-right:1.5px solid var(--border); border-radius:4px 4px 0 0; border-bottom:none; }
  .search-input { border-radius:0; border-right:none; min-width:0; }
  .search-btn { border-radius:0 0 4px 4px; width:100%; justify-content:center; }

  /* ── Form rows ── */
  .form-row-2, .form-row-3 { grid-template-columns:1fr; }

  /* ── Pix float ── */
  .pix-float { width:260px; right:1rem; bottom:1rem; }
}

/* ══════════════════════════════════════
   RESPONSIVE — Mobile (≤600px)
══════════════════════════════════════ */
@media (max-width:600px) {
  html { font-size:15px; }
  .page-header { padding:calc(60px + 2.5rem) 0 2.5rem; }
  .ph-sub { font-size:.875rem; }
  .pix-float { width:calc(100% - 2rem); left:1rem; right:1rem; bottom:1rem; }
  .nav-logo-img { height:28px; }
}
