/* ══ CONTACTS PAGE STYLES ══ */
#contact-page-overlay.cp-enter {
  animation: cpPageIn 0.45s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes cpPageIn {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}

#contact-page-overlay {
  --bg:#eef0f5; --bg2:#f5f6fa;
  --glass:rgba(255,255,255,0.55); --glass2:rgba(255,255,255,0.35);
  --glass-border:rgba(255,255,255,0.75);
  --blur:blur(22px); --blur2:blur(14px);
  --accent:#5b3fa0; --accent2:#8b5cf6;
  --gold:#c9a96e; --gold2:#e8c98a;
  --dark:#1a0d2e; --dark2:#0f0720;
  --text:#1a1a2e; --text2:#4a4a6a; --text3:#8888aa;
  --tr:all 0.45s cubic-bezier(0.23,1,0.32,1);
  font-family:'Nunito',sans-serif;
  color:#1a1a2e;
}

#contact-page-overlay * { box-sizing:border-box; }

/* ── hero aurora blobs ── */
#contact-page-overlay .cp-ab{position:absolute;border-radius:50%;filter:blur(24px);opacity:0.45;animation:cpAf 8s ease-in-out infinite}
#contact-page-overlay .cp-ab:nth-child(1){width:700px;height:600px;background:radial-gradient(circle,rgba(139,92,246,.5) 0%,rgba(167,139,250,.2) 60%,transparent 100%);top:-150px;left:-180px;animation-duration:9s}
#contact-page-overlay .cp-ab:nth-child(2){width:550px;height:500px;background:radial-gradient(circle,rgba(201,169,110,.4) 0%,rgba(232,201,138,.15) 60%,transparent 100%);top:0;right:-120px;animation-delay:-3s;animation-duration:11s}
#contact-page-overlay .cp-ab:nth-child(3){width:450px;height:450px;background:radial-gradient(circle,rgba(91,63,160,.35) 0%,rgba(139,92,246,.1) 60%,transparent 100%);bottom:0;left:35%;animation-delay:-5s;animation-duration:13s}
@keyframes cpAf{0%,100%{transform:translate(0,0) scale(1);opacity:.45}25%{transform:translate(30px,-20px) scale(1.08);opacity:.55}50%{transform:translate(-20px,30px) scale(.95);opacity:.4}75%{transform:translate(20px,10px) scale(1.05);opacity:.5}}

/* ── particles ── */
#contact-page-overlay .cp-particles{position:absolute;inset:0;pointer-events:none;z-index:1}
#contact-page-overlay .cp-particle{position:absolute;border-radius:50%;background:rgba(91,63,160,0.3);animation:cpParticleRise 6s ease-in-out infinite}
@keyframes cpParticleRise{0%{transform:translateY(0) scale(1);opacity:.4}50%{opacity:.7}100%{transform:translateY(-120px) scale(.4);opacity:0}}

/* ── HERO ── */
#contact-page-overlay .cp-hero{
  padding-top:70px;min-height:80vh;position:relative;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
#contact-page-overlay .cp-hero-aurora{position:absolute;inset:0;background:#eef0f5;overflow:hidden;z-index:0}
#contact-page-overlay .cp-hero-aurora::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(91,63,160,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(91,63,160,.04) 1px,transparent 1px);background-size:60px 60px}
#contact-page-overlay .cp-hero-inner{position:relative;z-index:2;text-align:center;padding:60px 40px 100px;max-width:900px;margin:0 auto}
#contact-page-overlay .cp-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(91,63,160,.08);border:1px solid rgba(91,63,160,.15);padding:6px 18px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#5b3fa0;margin-bottom:24px;opacity:0;animation:cpFadeUp 1s cubic-bezier(.16,1,.3,1) .2s forwards}
#contact-page-overlay .cp-eyebrow-dot{width:6px;height:6px;border-radius:50%;background:#5b3fa0;animation:cpDp 2s ease-in-out infinite;flex-shrink:0}
@keyframes cpDp{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}
#contact-page-overlay .cp-hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,7vw,5.5rem);font-weight:600;line-height:1.08;letter-spacing:-.5px;color:#1a1a2e;opacity:0;animation:cpFadeUp 1.1s cubic-bezier(.16,1,.3,1) .4s forwards}
#contact-page-overlay .cp-hero-title em{font-style:italic;color:#5b3fa0}
#contact-page-overlay .cp-hero-subtitle{font-size:16px;color:#4a4a6a;line-height:1.7;max-width:560px;margin:20px auto 0;opacity:0;animation:cpFadeUp 1.1s cubic-bezier(.16,1,.3,1) .65s forwards}
@keyframes cpFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── ARC ── */
#contact-page-overlay .cp-arc-wrap{position:relative;margin-top:-120px;z-index:3}
#contact-page-overlay .cp-arc-svg{display:block;width:100%;height:140px;margin-bottom:-2px}

/* ── DARK WORLD ── */
#contact-page-overlay .cp-dark-world{background:#05030a;position:relative;overflow:hidden;contain:paint layout style;isolation:isolate}
#contact-page-overlay .cp-stars-bg{position:absolute;inset:0;pointer-events:none;z-index:0}

/* ── ADDRESS SECTION ── */
#contact-page-overlay .cp-addr-section{position:relative;z-index:5;padding:100px 0 80px}
#contact-page-overlay .cp-section-hdr{text-align:center;margin-bottom:70px;padding:0 40px;opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease;position:relative;z-index:5}
#contact-page-overlay .cp-section-hdr.visible{opacity:1;transform:translateY(0)}
#contact-page-overlay .cp-sec-badge{display:inline-block;padding:5px 16px;border-radius:20px;background:rgba(201,169,110,.12);border:1px solid rgba(201,169,110,.25);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#c9a96e;margin-bottom:16px}
#contact-page-overlay .cp-sec-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.5rem);font-weight:600;color:#fff;line-height:1.2}
#contact-page-overlay .cp-sec-title em{font-style:italic;color:#e8c98a}
#contact-page-overlay .cp-sec-line{width:60px;height:2px;margin:20px auto 0;background:linear-gradient(90deg,transparent,#c9a96e,transparent)}

/* ── CONTACT CARDS ── */
#contact-page-overlay .cp-contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1100px;margin:0 auto;padding:0 40px}
#contact-page-overlay .cp-contact-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-top:1px solid rgba(255,255,255,.15);border-radius:24px;padding:32px;position:relative;overflow:hidden;opacity:0;transform:translateY(30px) scale(.97);transition:opacity .6s ease,transform .6s ease}
#contact-page-overlay .cp-contact-card.visible{opacity:1;transform:translateY(0) scale(1)}
#contact-page-overlay .cp-contact-card:hover{border-color:rgba(201,169,110,.25);box-shadow:0 20px 50px rgba(0,0,0,.35)}
#contact-page-overlay .cp-contact-card::before{content:'';position:absolute;inset:0;border-radius:24px;background:linear-gradient(135deg,rgba(201,169,110,.06),rgba(139,92,246,.04));opacity:0;transition:opacity .4s}
#contact-page-overlay .cp-contact-card:hover::before{opacity:1}
#contact-page-overlay .cp-contact-card.wide{grid-column:1/-1}

#contact-page-overlay .cp-card-icon-wrap{width:52px;height:52px;border-radius:16px;margin-bottom:20px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
#contact-page-overlay .cp-card-icon-wrap.gold{background:linear-gradient(135deg,rgba(201,169,110,.2),rgba(232,201,138,.1));border:1px solid rgba(201,169,110,.3)}
#contact-page-overlay .cp-card-icon-wrap.purple{background:linear-gradient(135deg,rgba(139,92,246,.2),rgba(91,63,160,.1));border:1px solid rgba(139,92,246,.3)}
#contact-page-overlay .cp-card-icon-wrap svg{width:24px;height:24px}
#contact-page-overlay .cp-card-dept{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#c9a96e;margin-bottom:10px}
#contact-page-overlay .cp-card-title{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:#fff;line-height:1.3;margin-bottom:20px}
#contact-page-overlay .cp-contact-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
#contact-page-overlay .cp-contact-item:last-child{margin-bottom:0}
#contact-page-overlay .cp-ci-icon{width:32px;height:32px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
#contact-page-overlay .cp-ci-icon svg{width:14px;height:14px;stroke:#c9a96e;fill:none;stroke-width:2;stroke-linecap:round}
#contact-page-overlay .cp-ci-label{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:3px}
#contact-page-overlay .cp-ci-value{font-size:14px;color:rgba(255,255,255,.85);line-height:1.5;font-weight:500}
#contact-page-overlay .cp-ci-value a{color:inherit;text-decoration:none;transition:color .3s}
#contact-page-overlay .cp-ci-value a:hover{color:#e8c98a}
#contact-page-overlay .cp-hours-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(201,169,110,.1);border:1px solid rgba(201,169,110,.2);padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;color:#c9a96e;margin-top:10px}
#contact-page-overlay .cp-hours-dot{width:5px;height:5px;border-radius:50%;background:#c9a96e;animation:cpDp 2s ease-in-out infinite}

/* ── VISIT SECTION ── */
#contact-page-overlay .cp-visit-section{position:relative;z-index:5;padding:20px 0 80px}
#contact-page-overlay .cp-visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:1100px;margin:0 auto;padding:0 40px}
#contact-page-overlay .cp-visit-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:24px 28px;display:flex;gap:16px;align-items:flex-start;opacity:0;transform:translateX(-20px);transition:opacity .6s ease,transform .6s ease}
#contact-page-overlay .cp-visit-card.visible{opacity:1;transform:translateX(0)}
#contact-page-overlay .cp-visit-card:hover{border-color:rgba(139,92,246,.25);background:rgba(255,255,255,.07)}
#contact-page-overlay .cp-visit-emoji{font-size:2rem;flex-shrink:0;line-height:1;margin-top:2px;filter:drop-shadow(0 0 12px rgba(201,169,110,.4))}
#contact-page-overlay .cp-visit-label{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#8b5cf6;margin-bottom:8px}
#contact-page-overlay .cp-route-steps{display:flex;flex-direction:column;gap:6px;margin-top:12px}
#contact-page-overlay .cp-route-step{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.55)}
#contact-page-overlay .cp-route-step::before{content:'';width:6px;height:6px;border-radius:50%;background:#c9a96e;flex-shrink:0;opacity:.7}
#contact-page-overlay .cp-route-step strong{color:rgba(255,255,255,.8)}

/* ── ARC DIV ── */
#contact-page-overlay .cp-arc-div{position:relative;z-index:1}

/* ── MAP SECTION ── */
#contact-page-overlay .cp-map-section{position:relative;z-index:5;padding:40px 0 80px}
#contact-page-overlay .cp-map-system{max-width:1100px;margin:0 auto;padding:0 40px}
#contact-page-overlay .cp-map-switcher{display:flex;justify-content:center;gap:16px;margin-bottom:32px;flex-wrap:wrap}
#contact-page-overlay .cp-map-btn{display:flex;align-items:center;gap:14px;padding:14px 28px;border-radius:20px;cursor:pointer;font-family:'Nunito',sans-serif;font-size:14px;font-weight:700;letter-spacing:.2px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:rgba(255,255,255,.45);transition:all .45s cubic-bezier(.23,1,.32,1);position:relative;overflow:hidden;white-space:nowrap;min-width:220px}
#contact-page-overlay .cp-map-btn::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .4s}
#contact-page-overlay .cp-map-btn:hover{border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.75);background:rgba(255,255,255,.07)}
#contact-page-overlay .cp-map-btn.active{color:#fff;border-color:transparent}
#contact-page-overlay .cp-map-btn.active::before{opacity:1}
#contact-page-overlay .cp-map-btn[data-map="google"].active{background:linear-gradient(135deg,rgba(66,133,244,.25),rgba(52,168,83,.15));border-color:rgba(66,133,244,.4);box-shadow:0 0 24px rgba(66,133,244,.2)}
#contact-page-overlay .cp-map-btn[data-map="apple"].active{background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(200,200,220,.07));border-color:rgba(255,255,255,.3);box-shadow:0 0 24px rgba(255,255,255,.1)}
#contact-page-overlay .cp-map-btn-icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:10px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.3)}
#contact-page-overlay .cp-map-btn-icon img{width:36px;height:36px;border-radius:10px;display:block}
#contact-page-overlay .cp-map-btn-label{display:flex;flex-direction:column;text-align:left}
#contact-page-overlay .cp-map-btn-name{font-size:14px;font-weight:700;line-height:1.2}
#contact-page-overlay .cp-map-btn-hint{font-size:10px;font-weight:500;opacity:.6;line-height:1;margin-top:1px;letter-spacing:.2px}
#contact-page-overlay .cp-map-container{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:28px;overflow:hidden;position:relative;box-shadow:0 40px 80px rgba(0,0,0,.4);opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
#contact-page-overlay .cp-map-container.visible{opacity:1;transform:translateY(0)}
#contact-page-overlay .cp-map-header{padding:16px 24px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.02);flex-wrap:wrap}
#contact-page-overlay .cp-map-dot{width:9px;height:9px;border-radius:50%;background:#c9a96e;box-shadow:0 0 8px #c9a96e;animation:cpDp 2s ease-in-out infinite;flex-shrink:0}
#contact-page-overlay .cp-map-header-info{flex:1;min-width:0}
#contact-page-overlay .cp-map-header-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;color:#fff;line-height:1}
#contact-page-overlay .cp-map-header-sub{font-size:11px;color:rgba(255,255,255,.4);margin-top:3px}
#contact-page-overlay .cp-map-provider-badge{display:flex;align-items:center;gap:7px;padding:6px 14px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.3px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);color:rgba(255,255,255,.5);transition:all .45s}
#contact-page-overlay .cp-map-provider-badge.google{background:rgba(66,133,244,.12);border-color:rgba(66,133,244,.3);color:rgba(130,185,255,.9)}
#contact-page-overlay .cp-map-provider-badge.apple{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.85)}
#contact-page-overlay .cp-map-provider-badge svg{width:13px;height:13px}
#contact-page-overlay .cp-map-open-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;border-radius:20px;cursor:pointer;font-family:'Nunito',sans-serif;font-size:12px;font-weight:700;background:rgba(201,169,110,.12);border:1px solid rgba(201,169,110,.3);color:#e8c98a;transition:all .45s;white-space:nowrap}
#contact-page-overlay .cp-map-open-btn:hover{background:rgba(201,169,110,.22);box-shadow:0 0 16px rgba(201,169,110,.2)}
#contact-page-overlay .cp-map-open-btn svg{width:13px;height:13px;flex-shrink:0}
#contact-page-overlay .cp-map-frame{width:100%;height:480px;border:none;display:block;filter:saturate(0.85) contrast(1.05);transition:opacity .4s}
#contact-page-overlay .cp-map-frame.loading{opacity:.4}
#contact-page-overlay .cp-map-apple-static{width:100%;height:480px;display:none;align-items:center;justify-content:center;flex-direction:column;gap:20px;background:linear-gradient(160deg,#1c1c2e 0%,#0f0f1a 100%);position:relative;overflow:hidden}
#contact-page-overlay .cp-map-apple-static.active{display:flex}
#contact-page-overlay .cp-apple-map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px}
#contact-page-overlay .cp-apple-map-roads{position:absolute;inset:0;pointer-events:none}
#contact-page-overlay .cp-apple-pin-wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;animation:cpPinBounce 2s ease-in-out infinite}
@keyframes cpPinBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
#contact-page-overlay .cp-apple-pin{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#fff 0%,#e8e8e8 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(0,0,0,.5),0 0 0 3px rgba(255,255,255,.2)}
#contact-page-overlay .cp-apple-pin svg{width:28px;height:28px}
#contact-page-overlay .cp-apple-pin-shadow{width:32px;height:8px;border-radius:50%;background:rgba(0,0,0,.4);filter:blur(4px);animation:cpShadowPulse 2s ease-in-out infinite}
@keyframes cpShadowPulse{0%,100%{transform:scaleX(1);opacity:.4}50%{transform:scaleX(.7);opacity:.2}}
#contact-page-overlay .cp-apple-map-info{position:relative;z-index:2;text-align:center;background:rgba(26,13,46,.85);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:18px 28px}
#contact-page-overlay .cp-apple-map-info-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:#fff;line-height:1.2}
#contact-page-overlay .cp-apple-map-info-addr{font-size:12px;color:#c9a96e;margin-top:6px}
#contact-page-overlay .cp-apple-open-cta{position:relative;z-index:2;display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
#contact-page-overlay .cp-apple-cta-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:50px;cursor:pointer;font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;transition:all .45s;text-decoration:none}
#contact-page-overlay .cp-apple-cta-primary{background:linear-gradient(135deg,#fff,#e8e8e8);color:#1a1a2e;box-shadow:0 8px 24px rgba(255,255,255,.15)}
#contact-page-overlay .cp-apple-cta-primary:hover{box-shadow:0 12px 32px rgba(255,255,255,.25);transform:translateY(-1px)}
#contact-page-overlay .cp-apple-cta-primary svg{width:16px;height:16px;color:#1a1a2e}
#contact-page-overlay .cp-apple-cta-secondary{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#fff}
#contact-page-overlay .cp-apple-cta-secondary:hover{background:rgba(255,255,255,.14)}
#contact-page-overlay .cp-apple-cta-secondary svg{width:16px;height:16px}
#contact-page-overlay .cp-map-overlay-badge{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:rgba(26,13,46,.9);border:1px solid rgba(201,169,110,.3);border-radius:50px;padding:10px 22px;display:flex;align-items:center;gap:10px;box-shadow:0 8px 32px rgba(0,0,0,.4);white-space:nowrap;animation:cpBadgeFloat 3s ease-in-out infinite}
@keyframes cpBadgeFloat{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-4px)}}
#contact-page-overlay .cp-badge-icon{font-size:1.4rem}
#contact-page-overlay .cp-badge-name{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;color:#fff;line-height:1}
#contact-page-overlay .cp-badge-addr{font-size:11px;color:#c9a96e;margin-top:2px}

/* ── iOS Banner ── */
#contact-page-overlay .cp-ios-banner{display:none;margin:0 0 20px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:16px 20px;align-items:center;gap:14px;animation:cpBannerSlide .5s cubic-bezier(.16,1,.3,1) forwards}
#contact-page-overlay .cp-ios-banner.show{display:flex}
@keyframes cpBannerSlide{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
#contact-page-overlay .cp-ios-banner-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#fff,#ddd);flex-shrink:0;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.3)}
#contact-page-overlay .cp-ios-banner-icon svg{width:24px;height:24px}
#contact-page-overlay .cp-ios-banner-text{flex:1}
#contact-page-overlay .cp-ios-banner-title{font-size:14px;font-weight:700;color:#fff;line-height:1.2}
#contact-page-overlay .cp-ios-banner-sub{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px}
#contact-page-overlay .cp-ios-banner-actions{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
#contact-page-overlay .cp-ios-action-btn{padding:9px 18px;border-radius:50px;cursor:pointer;font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;transition:all .3s;display:flex;align-items:center;gap:7px;text-decoration:none;border:none}
#contact-page-overlay .cp-ios-action-primary{background:linear-gradient(135deg,#fff,#e8e8e8);color:#1a1a2e}
#contact-page-overlay .cp-ios-action-dismiss{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15)!important;color:rgba(255,255,255,.5)}
#contact-page-overlay .cp-ios-action-dismiss:hover{background:rgba(255,255,255,.14)}
#contact-page-overlay .cp-ios-action-btn svg{width:14px;height:14px}

/* ── SOCIAL SECTION ── */
#contact-page-overlay .cp-social-section{position:relative;z-index:5;padding:40px 0 80px}
#contact-page-overlay .cp-social-grid{display:flex;flex-wrap:wrap;gap:16px;max-width:1100px;margin:0 auto;padding:0 40px}
#contact-page-overlay .cp-social-card{flex:1 1 280px;display:flex;align-items:center;gap:16px;padding:24px 28px;border-radius:22px;text-decoration:none;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.03);transition:all .4s cubic-bezier(.23,1,.32,1);opacity:0;transform:translateY(20px)}
#contact-page-overlay .cp-social-card.visible{opacity:1;transform:translateY(0)}
#contact-page-overlay .cp-social-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.4)}
#contact-page-overlay .cp-social-icon-wrap{width:56px;height:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
#contact-page-overlay .cp-social-icon-wrap svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
#contact-page-overlay .cp-social-card.instagram .cp-social-icon-wrap{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff}
#contact-page-overlay .cp-social-card.telegram .cp-social-icon-wrap{background:linear-gradient(135deg,#2ca5e0,#1a7abf);color:#fff}
#contact-page-overlay .cp-social-card.tiktok .cp-social-icon-wrap{background:linear-gradient(135deg,#010101,#2b2b2b);color:#fff}
#contact-page-overlay .cp-social-card.instagram:hover{border-color:rgba(228,64,95,.3);background:rgba(228,64,95,.06)}
#contact-page-overlay .cp-social-card.telegram:hover{border-color:rgba(44,165,224,.3);background:rgba(44,165,224,.06)}
#contact-page-overlay .cp-social-card.tiktok:hover{border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.06)}
#contact-page-overlay .cp-social-card.facebook .cp-social-icon-wrap{background:linear-gradient(135deg,#1877f2,#0c5dcf);color:#fff}
#contact-page-overlay .cp-social-card.facebook:hover{border-color:rgba(24,119,242,.3);background:rgba(24,119,242,.06)}
#contact-page-overlay .cp-social-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:#fff;line-height:1.2}
#contact-page-overlay .cp-social-handle{font-size:12px;color:rgba(255,255,255,.45);margin-top:4px}
#contact-page-overlay .cp-social-arrow{margin-left:auto;color:rgba(255,255,255,.25);transition:color .3s,transform .3s}
#contact-page-overlay .cp-social-card:hover .cp-social-arrow{color:#c9a96e;transform:translateX(4px) translateY(-4px)}

/* ── FOOTER ── */
#contact-page-overlay footer{background:#0a0514;padding:60px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px}
#contact-page-overlay .cp-footer-brand .cp-logo-text{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:#fff;margin-bottom:12px}
#contact-page-overlay .cp-footer-brand p{font-size:14px;color:rgba(255,255,255,.4);line-height:1.6}
#contact-page-overlay .cp-footer-col h4{font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#c9a96e;margin-bottom:16px}
#contact-page-overlay .cp-footer-col a{display:block;color:rgba(255,255,255,.5);text-decoration:none;font-size:14px;margin-bottom:8px;transition:color .3s}
#contact-page-overlay .cp-footer-col a:hover{color:#fff}
#contact-page-overlay .cp-footer-bottom{background:#060310;padding:20px 60px;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,255,255,.3);border-top:1px solid rgba(255,255,255,.05)}

/* ── RESPONSIVE ── */
@media(max-width:767px){
  #contact-page-overlay .cp-contacts-grid{grid-template-columns:1fr;padding:0 16px;gap:14px}
  #contact-page-overlay .cp-contact-card.wide{grid-column:1}
  #contact-page-overlay .cp-visit-grid{grid-template-columns:1fr;padding:0 16px}
  #contact-page-overlay .cp-map-system{padding:0 14px}
  #contact-page-overlay .cp-map-switcher{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:20px}
  #contact-page-overlay .cp-map-btn{min-width:unset;width:100%;padding:14px 20px;border-radius:16px}
  #contact-page-overlay .cp-map-frame,#contact-page-overlay .cp-map-apple-static{height:300px}
  #contact-page-overlay .cp-social-grid{padding:0 16px;gap:12px}
  #contact-page-overlay .cp-section-hdr{padding:0 18px;margin-bottom:48px}
  #contact-page-overlay footer{grid-template-columns:1fr;padding:36px 20px;gap:24px}
  #contact-page-overlay .cp-footer-bottom{flex-direction:column;gap:6px;padding:14px 20px;text-align:center;font-size:12px}
  #contact-page-overlay .cp-hero-inner{padding:40px 20px 80px}
  #contact-page-overlay .cp-ios-banner{flex-wrap:wrap;gap:10px}
  #contact-page-overlay .cp-ios-banner-actions{width:100%;justify-content:flex-start}
}
@media(max-width:480px){
  #contact-page-overlay .cp-map-frame,#contact-page-overlay .cp-map-apple-static{height:260px}
}

/* ══════════════════ БЕЗБАР'ЄРНІСТЬ OVERLAY ══════════════════ */
/* Scoped under #bb-page-overlay */

/* -- BB header nav -- */
#bb-page-overlay header {
  position: sticky; top:0; left:0; right:0; z-index:1000;
  height: 70px; padding: 0 40px;
  display: flex; align-items:center; justify-content:space-between;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: all 0.45s cubic-bezier(0.23,1,0.32,1);
}
#bb-page-overlay header.scrolled {
  background: rgba(5,3,10,0.85);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 4px 40px rgba(0,0,0,0.4);
}
#bb-page-overlay .hdr-logo { display:flex; align-items:center; gap:12px; text-decoration:none; color:#fff; }
#bb-page-overlay .hdr-logo-mark { width:42px; height:42px; border-radius:11px; background:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 16px rgba(91,63,160,0.3); overflow:hidden; flex-shrink:0; }
#bb-page-overlay .hdr-logo-text { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:600; letter-spacing:0.3px; color:#fff; }
#bb-page-overlay nav { display:flex; align-items:center; gap:4px; }
#bb-page-overlay nav a { text-decoration:none; color:rgba(255,255,255,0.55); font-family:'Montserrat',sans-serif; font-size:11px; font-weight:400; letter-spacing:0.18em; text-transform:uppercase; padding:8px 14px; border-radius:2px; transition:all 0.45s cubic-bezier(0.23,1,0.32,1); }
#bb-page-overlay nav a:hover { color:rgba(255,255,255,0.9); }
#bb-page-overlay nav a.active { color:#c9a96e; background:rgba(201,169,110,0.08); border-radius:6px; }
#bb-page-overlay .bb-burger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; border-radius:10px; background:var(--glass2); border:1px solid var(--glass-border); }
#bb-page-overlay .bb-burger span { width:22px; height:2px; background:var(--text); border-radius:2px; display:block; transition:var(--transition); }
#bb-page-overlay .bb-mobile-nav { display:none; position:sticky; top:0; left:0; right:0; background:rgba(238,240,245,0.97); border-bottom:1px solid rgba(255,255,255,0.7); padding:20px; flex-direction:column; gap:8px; z-index:999; box-shadow:0 8px 30px rgba(80,80,120,0.12); }
#bb-page-overlay .bb-mobile-nav.open { display:flex; }
#bb-page-overlay .bb-mobile-nav a { text-decoration:none; color:var(--text2); font-family:'Nunito',sans-serif; font-size:16px; font-weight:600; padding:12px 18px; border-radius:var(--radius2); transition:var(--transition); background:rgba(255,255,255,0.4); border:1px solid rgba(255,255,255,0.6); display:block; }
#bb-page-overlay .bb-mobile-nav a:hover { background:rgba(91,63,160,0.1); color:var(--accent); }
#bb-page-overlay .bb-mobile-nav a.active { color:var(--accent); }
@media(max-width:767px) {
  #bb-page-overlay header { padding:0 18px; height:60px; }
  #bb-page-overlay nav { display:none; }
  #bb-page-overlay .bb-burger { display:flex; }
  #bb-page-overlay .bb-mobile-nav { top:60px; }
}

/* ═══════════════════════════════════════════
   CSS VARS — inherit from main site palette
═══════════════════════════════════════════ */
/* bb :root vars — using main site vars */

/* * { margin:0; padding:0; box-sizing:border-box; } — global, skipped */
/* html { scroll-behavior:smooth; } — global, skipped */

/* body rule scoped to bb overlay */
#bb-page-overlay {
  font-family: 'Nunito', sans-serif;
  background: #05030a !important;
  color: #fff;
  min-height: 100vh;
}
#bb-page-overlay section,
#bb-page-overlay .main-section,
#bb-page-overlay footer,
#bb-page-overlay .footer-bottom {
  background-color: #05030a;
}
#bb-page-overlay .cat-nav-bg,
#bb-page-overlay .cat-nav {
  background: linear-gradient(
    180deg,
    rgba(5,3,10,0) 0%,
    rgba(5,3,10,0.92) 20%,
    rgba(5,3,10,0.92) 80%,
    rgba(5,3,10,0) 100%
  ) !important;
}

/* ::-webkit-scrollbar { width:5px; } — global, skipped */
#bb-page-overlay ::-webkit-scrollbar-track{ background: var(--dark); }
#bb-page-overlay ::-webkit-scrollbar-thumb{ background: rgba(91,63,160,0.4); border-radius:3px; }

/* ═══════════════════════════════════════════
   HEADER
═══════════════════════════════════════════ */
#bb-page-overlay header{
  position: sticky; top:0; left:0; right:0; z-index:1000;
  height: 70px; padding: 0 40px;
  display: flex; align-items:center; justify-content:space-between;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: var(--tr);
}
#bb-page-overlay header.scrolled{
  background: rgba(5,3,10,0.85);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 4px 40px rgba(0,0,0,0.4);
}

#bb-page-overlay .hdr-logo{
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:#fff;
}
#bb-page-overlay .hdr-logo-mark{
  width:42px; height:42px; border-radius:11px;
  background:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow: 0 4px 16px rgba(91,63,160,0.3), 0 0 0 1.5px rgba(91,63,160,0.15);
  overflow:hidden; flex-shrink:0;
}
#bb-page-overlay .hdr-logo-mark span{
  font-family:'Cormorant Garamond',serif; font-size:15px; font-weight:700;
  color: var(--accent); line-height:1;
}
#bb-page-overlay .hdr-logo-text{
  font-family:'Cormorant Garamond',serif;
  font-size:20px; font-weight:600; letter-spacing:0.3px;
}

#bb-page-overlay nav{ display:flex; align-items:center; gap:4px; }
#bb-page-overlay nav a{
  text-decoration:none; color:rgba(255,255,255,0.55);
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:400;
  letter-spacing:0.18em; text-transform:uppercase;
  padding:8px 14px; border-radius:2px;
  transition: var(--tr);
}
#bb-page-overlay nav a:hover{ color:rgba(255,255,255,0.9); }
#bb-page-overlay nav a.active{
  color: var(--gold);
  background: rgba(201,169,110,0.08);
  border-radius:6px;
}

#bb-page-overlay .burger{
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  padding:8px; border-radius:10px;
  background:var(--glass2); border:1px solid var(--glass-border);
}
#bb-page-overlay .burger span{ width:22px; height:2px; background:var(--text); border-radius:2px; display:block; transition:var(--transition); }

#bb-page-overlay .mobile-nav{
  display:none; position:sticky; top:0; left:0; right:0;
  background:rgba(238,240,245,0.97);
  border-bottom:1px solid rgba(255,255,255,0.7);
  padding:20px; flex-direction:column; gap:8px;
  z-index:999; box-shadow:0 8px 30px rgba(80,80,120,0.12);
}
#bb-page-overlay .mobile-nav.open{ display:flex; }
#bb-page-overlay .mobile-nav a{
  text-decoration:none; color:var(--text2);
  font-family:'Nunito',sans-serif; font-size:16px; font-weight:600;
  padding:12px 18px; border-radius:var(--radius2);
  background:rgba(255,255,255,0.4); border:1px solid rgba(255,255,255,0.6);
  transition:var(--transition);
}
#bb-page-overlay .mobile-nav a:hover{ background:rgba(91,63,160,0.1); color:var(--accent); }
#bb-page-overlay .mobile-nav a.active{ color:var(--accent); }

/* ═══════════════════════════════════════════
   HERO
═══════════════════════════════════════════ */
#bb-page-overlay .hero{
  position:relative; min-height:100vh;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  overflow:hidden; padding-top:70px;
}

/* Stars canvas */
#bb-page-overlay #bb-stars-canvas{
  position:absolute; inset:0; z-index:0;
  pointer-events:none; width:100%; height:100%;
}

/* Orbs — exact same setup as about page */
#bb-page-overlay .bb-orb{
  position:absolute; border-radius:50%;
  filter:blur(70px); will-change:transform, opacity;
  transform:translateZ(0); backface-visibility:hidden;
  pointer-events:none; z-index:1;
}
#bb-page-overlay .bb-orb-1{
  width:520px; height:520px;
  background: radial-gradient(circle, rgba(91,63,160,0.38), transparent 70%);
  top:-100px; left:-100px;
}
#bb-page-overlay .bb-orb-2{
  width:420px; height:420px;
  background: radial-gradient(circle, rgba(201,169,110,0.22), transparent 70%);
  top:200px; right:-80px;
}
#bb-page-overlay .bb-orb-3{
  width:360px; height:360px;
  background: radial-gradient(circle, rgba(139,92,246,0.18), transparent 70%);
  bottom:100px; left:38%;
}
#bb-page-overlay .bb-orb-4{
  width:280px; height:280px;
  background: radial-gradient(circle, rgba(201,169,110,0.12), transparent 70%);
  bottom:-40px; left:10%;
}

/* Grid texture overlay */
#bb-page-overlay .bb-grid-overlay{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background-image:
    linear-gradient(rgba(91,63,160,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(91,63,160,0.04) 1px, transparent 1px);
  background-size: 60px 60px;
}

#bb-page-overlay .hero-content{
  position:relative; z-index:5;
  max-width:820px; margin:0 auto;
  padding:80px 40px 60px;
  display:flex; flex-direction:column;
  align-items:center; gap:28px; text-align:center;
}

#bb-page-overlay .hero-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  background: rgba(91,63,160,0.12); border:1px solid rgba(91,63,160,0.25);
  padding:6px 18px; border-radius:20px;
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:600;
  letter-spacing:0.8px; text-transform:uppercase; color:var(--gold);
  opacity:0; transform:translateY(14px);
  animation: fadeUp 0.9s cubic-bezier(0.16,1,0.3,1) 0.2s forwards;
}
#bb-page-overlay .eyebrow-dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--gold); flex-shrink:0;
  animation: dotPulse 2s ease-in-out infinite;
}
@keyframes dotPulse {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:0.5; transform:scale(1.5); }
}

#bb-page-overlay .hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size: clamp(2.8rem,6vw,5rem);
  font-weight:600; line-height:1.08; letter-spacing:-0.5px;
  opacity:0; transform:translateY(20px);
  animation: fadeUp 1.1s cubic-bezier(0.16,1,0.3,1) 0.35s forwards;
}
#bb-page-overlay .hero-title em{ font-style:italic; color:var(--gold2); }

#bb-page-overlay .hero-subtitle{
  font-size:16px; color:rgba(255,255,255,0.55);
  line-height:1.75; max-width:560px;
  opacity:0; transform:translateY(16px);
  animation: fadeUp 1.1s cubic-bezier(0.16,1,0.3,1) 0.5s forwards;
}

/* Decorative arc divider */
#bb-page-overlay .hero-arc{
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  pointer-events:none;
}

@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }

/* ═══════════════════════════════════════════
   MAIN SECTION — category buttons + content
═══════════════════════════════════════════ */
.main-section {
  position:relative; z-index:5;
  background: var(--dark);
  padding: 0 0 120px;
}

#bb-page-overlay .section-inner{
  max-width:1200px; margin:0 auto; padding:0 40px;
}

/* ── Category nav pills (iOS liquid glass) ── */
#bb-page-overlay .cat-nav{
  display:flex; flex-wrap:wrap; gap:10px;
  justify-content:center;
  padding: 60px 0 52px;
  position:sticky; top:70px; z-index:100;
  /* subtle bg on scroll handled by JS */
}
#bb-page-overlay .cat-nav-bg{
  /* gradient fade to make sticky area blend into dark bg */
  background: linear-gradient(
    180deg,
    rgba(5,3,10,0) 0%,
    rgba(5,3,10,0.85) 20%,
    rgba(5,3,10,0.85) 80%,
    rgba(5,3,10,0) 100%
  );
}

/* ── iOS Liquid Glass pill ── */
#bb-page-overlay .cat-btn{
  position:relative; overflow:hidden;
  display:inline-flex; align-items:center; gap:9px;
  padding: 12px 22px;
  border-radius: 50px;
  cursor:pointer; border:none; outline:none;
  font-family:'Montserrat',sans-serif; font-size:12px; font-weight:500;
  letter-spacing:0.08em; text-transform:uppercase;
  color: rgba(255,255,255,0.7);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -1px 0 rgba(0,0,0,0.12),
    0 4px 16px rgba(0,0,0,0.25),
    0 1px 4px rgba(0,0,0,0.15);
  transition: var(--tr);
  white-space:nowrap;
}
#bb-page-overlay .cat-btn::before{
  content:'';
  position:absolute; top:0; left:-100%; width:60%; height:100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.07), transparent);
  transition: left 0.6s ease;
}
#bb-page-overlay .cat-btn:hover::before{ left:160%; }
#bb-page-overlay .cat-btn:hover{
  color: #fff;
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 -1px 0 rgba(0,0,0,0.1),
    0 8px 30px rgba(0,0,0,0.3),
    0 0 0 1px rgba(255,255,255,0.05);
  transform: translateY(-2px);
}

#bb-page-overlay .cat-btn.active{
  color: #fff;
  background: linear-gradient(
    135deg,
    rgba(91,63,160,0.55) 0%,
    rgba(139,92,246,0.4) 50%,
    rgba(91,63,160,0.55) 100%
  );
  border-color: rgba(139,92,246,0.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.22),
    inset 0 -1px 0 rgba(0,0,0,0.15),
    0 0 0 1px rgba(139,92,246,0.2),
    0 8px 32px rgba(91,63,160,0.35),
    0 0 20px rgba(139,92,246,0.15);
}
#bb-page-overlay .cat-btn.active .cat-icon{ opacity:1; }

#bb-page-overlay .cat-icon{
  font-size:15px; opacity:0.7; transition:opacity 0.3s;
  display:flex; align-items:center;
}

/* ── Content panels ── */
#bb-page-overlay .content-panels{
  position:relative;
}
#bb-page-overlay .content-panel{
  display:none; opacity:0;
  transition: opacity 0.4s ease;
}
#bb-page-overlay .content-panel.active{
  display:block; opacity:0;
  animation: panelIn 0.5s cubic-bezier(0.23,1,0.32,1) forwards;
}
@keyframes panelIn {
  from { opacity:0; transform:translateY(18px); }
  to { opacity:1; transform:translateY(0); }
}

/* ── Panel layout ── */
#bb-page-overlay .panel-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
  margin-bottom:24px;
}
#bb-page-overlay .panel-grid.single{ grid-template-columns:1fr; }
#bb-page-overlay .panel-grid.thirds{ grid-template-columns:1fr 1fr 1fr; }

/* ── Glass card ── */
#bb-page-overlay .glass-card{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-top: 1px solid rgba(255,255,255,0.14);
  border-radius: 24px;
  padding: 36px;
  position:relative; overflow:hidden;
  transition: transform 0.4s cubic-bezier(0.23,1,0.32,1), box-shadow 0.4s ease;
}
#bb-page-overlay .glass-card::before{
  content:'';
  position:absolute; inset:0; border-radius:24px;
  background: linear-gradient(135deg, rgba(201,169,110,0.04), rgba(139,92,246,0.03));
  opacity:0; transition:opacity 0.4s;
  pointer-events:none;
}
#bb-page-overlay .glass-card:hover{ transform:translateY(-4px); box-shadow:0 24px 60px rgba(0,0,0,0.4), 0 0 0 1px rgba(201,169,110,0.1); }
#bb-page-overlay .glass-card:hover::before{ opacity:1; }

#bb-page-overlay .glass-card-full{
  background: rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-top:1px solid rgba(255,255,255,0.14);
  border-radius:24px; padding:44px;
  position:relative; overflow:hidden;
}

#bb-page-overlay .card-icon-wrap{
  width:52px; height:52px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; font-size:24px;
  background: rgba(91,63,160,0.15); border:1px solid rgba(91,63,160,0.25);
  box-shadow: 0 0 20px rgba(91,63,160,0.15);
}

#bb-page-overlay .card-badge{
  display:inline-block; padding:4px 12px; border-radius:20px;
  font-family:'Montserrat',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:0.8px; text-transform:uppercase;
  background: rgba(201,169,110,0.12); border:1px solid rgba(201,169,110,0.22);
  color:var(--gold); margin-bottom:14px;
}

#bb-page-overlay .card-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.65rem; font-weight:600; color:#fff;
  line-height:1.2; margin-bottom:14px;
}
#bb-page-overlay .card-title em{ font-style:italic; color:var(--gold2); }

#bb-page-overlay .card-text{
  font-size:14.5px; color:rgba(255,255,255,0.58);
  line-height:1.78;
}
#bb-page-overlay .card-text strong{ color:rgba(255,255,255,0.82); font-weight:600; }

#bb-page-overlay .card-divider{
  width:40px; height:1.5px;
  background: linear-gradient(90deg, var(--gold), transparent);
  margin:18px 0;
}

/* ── Link button inside card ── */
#bb-page-overlay .card-link{
  display:inline-flex; align-items:center; gap:8px;
  margin-top:22px; padding:10px 20px; border-radius:50px;
  text-decoration:none;
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:600;
  letter-spacing:0.08em; text-transform:uppercase;
  color:var(--gold2);
  background: rgba(201,169,110,0.10); border:1px solid rgba(201,169,110,0.22);
transition: var(--tr);
  width: fit-content;
}
#bb-page-overlay .card-link:hover{
  background: rgba(201,169,110,0.18);
  border-color:rgba(201,169,110,0.4);
  transform:translateX(3px);
  box-shadow:0 4px 20px rgba(201,169,110,0.15);
}
#bb-page-overlay .card-link svg{ transition: transform 0.3s; }
#bb-page-overlay .card-link:hover svg{ transform:translateX(3px); }

/* ── Info tag list ── */
#bb-page-overlay .tag-list{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-top:18px;
}
#bb-page-overlay .tag{
  padding:6px 14px; border-radius:50px;
  font-size:12px; font-weight:500; color:rgba(255,255,255,0.6);
  background: rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08);
}

/* ── Section heading inside panel ── */
#bb-page-overlay .panel-section-hdr{
  text-align:center; margin-bottom:44px; padding-top:8px;
}
#bb-page-overlay .panel-section-hdr .sec-badge{
  display:inline-block; padding:5px 16px; border-radius:20px;
  background:rgba(201,169,110,0.10); border:1px solid rgba(201,169,110,0.22);
  font-family:'Montserrat',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; color:var(--gold); margin-bottom:14px;
}
#bb-page-overlay .panel-section-hdr h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.9rem,3.5vw,2.8rem); font-weight:600; color:#fff; line-height:1.2;
}
#bb-page-overlay .panel-section-hdr h2 em{ font-style:italic; color:var(--gold2); }
#bb-page-overlay .sec-line{
  width:50px; height:1.5px; margin:16px auto 0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

/* ── Monitoring item ── */
#bb-page-overlay .monitor-item{
  display:flex; align-items:flex-start; gap:20px;
  padding:24px 32px;
  border-bottom:1px solid rgba(255,255,255,0.04);
  cursor:pointer; transition: background 0.3s;
}
#bb-page-overlay .monitor-item:last-child{ border-bottom:none; }
#bb-page-overlay .monitor-item:hover{ background:rgba(255,255,255,0.03); }
#bb-page-overlay .monitor-num{
  width:40px; height:40px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(91,63,160,0.15); border:1px solid rgba(91,63,160,0.25);
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:700;
  color:var(--gold); flex-shrink:0;
}
#bb-page-overlay .monitor-body{ flex:1; min-width:0; }
#bb-page-overlay .monitor-date{
  font-family:'Montserrat',sans-serif; font-size:10px; font-weight:700;
  color:var(--gold); letter-spacing:0.5px; margin-bottom:6px;
}
#bb-page-overlay .monitor-title{
  font-family:'Cormorant Garamond',serif; font-size:1.15rem; font-weight:600;
  color:#fff; line-height:1.35; margin-bottom:6px;
}
#bb-page-overlay .monitor-desc{
  font-size:13.5px; color:rgba(255,255,255,0.45); line-height:1.6;
}
#bb-page-overlay .monitor-arrow{
  color:rgba(255,255,255,0.2); flex-shrink:0;
  transition:color 0.3s, transform 0.3s; align-self:center;
}
#bb-page-overlay .monitor-item:hover .monitor-arrow{ color:var(--gold); transform:translateX(4px); }

/* ── Documents list ── */
#bb-page-overlay .doc-item{
  display:flex; align-items:center; gap:16px;
  padding:18px 24px; border-radius:14px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06);
  text-decoration:none; color:#fff; transition:var(--tr);
  margin-bottom:10px;
}
#bb-page-overlay .doc-item:hover{
  background:rgba(255,255,255,0.06);
  border-color:rgba(201,169,110,0.2);
  transform:translateX(4px);
}
#bb-page-overlay .doc-icon{
  width:42px; height:42px; border-radius:11px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(91,63,160,0.18); border:1px solid rgba(91,63,160,0.25);
  flex-shrink:0; font-size:18px;
}
#bb-page-overlay .doc-info{ flex:1; min-width:0; }
#bb-page-overlay .doc-name{ font-size:14.5px; font-weight:600; color:#fff; margin-bottom:3px; }
#bb-page-overlay .doc-meta{ font-size:12px; color:rgba(255,255,255,0.4); }

/* ── Map embed card ── */
#bb-page-overlay .map-card{
  border-radius:20px; overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  height:320px; position:relative;
  background:rgba(255,255,255,0.03);
  display:flex; align-items:center; justify-content:center;
}
#bb-page-overlay .map-placeholder{
  text-align:center; color:rgba(255,255,255,0.3); padding:40px;
}
#bb-page-overlay .map-placeholder svg{ margin-bottom:12px; opacity:0.4; }
#bb-page-overlay .map-placeholder p{ font-size:13px; line-height:1.6; }

/* ── Decorative gold accent bar ── */
#bb-page-overlay .accent-bar{
  width:3px; height:100%;
  position:absolute; left:0; top:0;
  background:linear-gradient(180deg,transparent,var(--gold),transparent);
  border-radius:0 3px 3px 0;
}

/* ── Normative base accordion ── */
#bb-page-overlay .norm-acc-trigger{
  width:100%; display:flex; align-items:center; justify-content:space-between;
  padding:28px 36px; background:none; border:none; cursor:pointer;
  text-align:left; gap:16px;
  transition: background 0.3s;
}
#bb-page-overlay .norm-acc-trigger:hover{ background: rgba(255,255,255,0.025); }

#bb-page-overlay .norm-acc-arrow{
  width:38px; height:38px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.10);
  color:rgba(255,255,255,0.5);
  transition: transform 0.4s cubic-bezier(0.23,1,0.32,1), background 0.3s;
}
#bb-page-overlay .norm-acc-trigger:hover .norm-acc-arrow{ background:rgba(255,255,255,0.10); }
#bb-page-overlay .norm-acc-open .norm-acc-arrow{ transform:rotate(180deg); background:rgba(91,63,160,0.2); border-color:rgba(91,63,160,0.3); color:#fff; }

#bb-page-overlay .norm-acc-body{
  max-height:0; overflow:hidden;
  transition: max-height 0.55s cubic-bezier(0.23,1,0.32,1);
}

#bb-page-overlay .norm-group-label{
  display:inline-block; padding:4px 12px; border-radius:20px; margin-bottom:12px;
  font-family:'Montserrat',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:0.7px; text-transform:uppercase;
  border:1px solid;
}

#bb-page-overlay .norm-law-item{
  display:flex; align-items:flex-start; gap:14px;
  padding:16px 20px; border-radius:14px; margin-bottom:8px;
  text-decoration:none; color:#fff;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06);
  transition: var(--tr);
}
#bb-page-overlay .norm-law-item:hover{
  background:rgba(255,255,255,0.06);
  border-color:rgba(201,169,110,0.2);
  transform:translateX(4px);
}
#bb-page-overlay .norm-law-item:hover .norm-law-arr{ color:var(--gold); }
#bb-page-overlay .norm-law-icon{
  width:38px; height:38px; border-radius:10px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:17px;
  background:rgba(91,63,160,0.15); border:1px solid rgba(91,63,160,0.22);
}
#bb-page-overlay .norm-law-body{ flex:1; min-width:0; }
#bb-page-overlay .norm-law-num{
  font-family:'Montserrat',sans-serif; font-size:10px; font-weight:600;
  color:var(--gold); letter-spacing:0.3px; margin-bottom:5px;
}
#bb-page-overlay .norm-law-title{ font-size:13.5px; color:rgba(255,255,255,0.75); line-height:1.5; }
#bb-page-overlay .norm-law-arr{
  flex-shrink:0; align-self:center;
  color:rgba(255,255,255,0.2); transition:color 0.3s, transform 0.3s;
}
#bb-page-overlay .norm-law-item:hover .norm-law-arr{ transform:translateX(3px) translateY(-3px); }

/* ── Footer ── */
#bb-page-overlay footer{
  background: #060310;
  padding:60px; display:grid;
  grid-template-columns:1fr 1fr 1fr; gap:40px;
  border-top:1px solid rgba(255,255,255,0.05);
}
#bb-page-overlay .footer-brand .logo-text{
  font-family:'Cormorant Garamond',serif; font-size:20px;
  font-weight:600; color:#fff; margin-bottom:12px;
}
#bb-page-overlay .footer-brand p{ font-size:14px; color:rgba(255,255,255,0.35); line-height:1.6; }
#bb-page-overlay .footer-col h4{
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; color:var(--gold); margin-bottom:16px;
}
#bb-page-overlay .footer-col a{
  display:block; color:rgba(255,255,255,0.45); text-decoration:none;
  font-size:14px; margin-bottom:8px; transition:color 0.3s;
}
#bb-page-overlay .footer-col a:hover{ color:#fff; }
#bb-page-overlay .footer-bottom{
  background:#030108; padding:20px 60px;
  display:flex; justify-content:space-between; align-items:center;
  font-family:'Montserrat',sans-serif; font-size:12px;
  color:rgba(255,255,255,0.25);
  border-top:1px solid rgba(255,255,255,0.04);
}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:1023px) {
  #bb-page-overlay header{ padding:0 24px; }
  #bb-page-overlay .section-inner{ padding:0 24px; }
  #bb-page-overlay .panel-grid{ grid-template-columns:1fr; }
  #bb-page-overlay .panel-grid.thirds{ grid-template-columns:1fr 1fr; }
  #bb-page-overlay footer{ grid-template-columns:1fr 1fr; padding:50px 32px; gap:28px; }
  #bb-page-overlay .footer-bottom{ padding:18px 32px; }
}
@media(max-width:767px) {
  #bb-page-overlay header{ padding:0 18px; height:60px; }
  #bb-page-overlay nav{ display:none; }
  #bb-page-overlay .burger{ display:flex; }
  #bb-page-overlay .mobile-nav{ top:60px; }
  #bb-page-overlay .hero-content{ padding:60px 20px 50px; }
  #bb-page-overlay .cat-nav{ padding:40px 0 32px; gap:8px; }
  #bb-page-overlay .cat-btn{ padding:10px 16px; font-size:11px; }
  #bb-page-overlay .section-inner{ padding:0 16px; }
  #bb-page-overlay .glass-card{ padding:24px; }
  #bb-page-overlay .glass-card-full{ padding:28px; }
  #bb-page-overlay .panel-grid.thirds{ grid-template-columns:1fr; }
  #bb-page-overlay footer{ grid-template-columns:1fr; padding:40px 20px; gap:24px; }
  #bb-page-overlay .footer-bottom{ padding:16px 20px; flex-direction:column; gap:6px; text-align:center; }
  #bb-page-overlay .card-title{ font-size:1.4rem; }
  #bb-page-overlay .monitor-item{ padding:16px 20px; gap:14px; }
}
@media(max-width:480px) {
  #bb-page-overlay .cat-btn .cat-label-full{ display:none; }
  #bb-page-overlay .cat-btn .cat-label-short{ display:inline; }
}

/* ── Doc card buttons ── */
#bb-page-overlay .doc-card-actions{
  display:flex; gap:10px; margin-top:22px; flex-wrap:wrap;
}
#bb-page-overlay .doc-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 20px; border-radius:50px;
  font-family:'Montserrat',sans-serif; font-size:11px;
  font-weight:600; letter-spacing:0.07em; text-transform:uppercase;
  cursor:pointer; text-decoration:none; transition:all 0.35s cubic-bezier(0.23,1,0.32,1);
  white-space:nowrap;
}
#bb-page-overlay .doc-btn-view{
  background:rgba(201,169,110,0.12); border:1px solid rgba(201,169,110,0.28);
  color:var(--gold2);
}
#bb-page-overlay .doc-btn-view:hover{
  background:rgba(201,169,110,0.22); border-color:rgba(201,169,110,0.5);
  transform:translateY(-2px); box-shadow:0 6px 20px rgba(201,169,110,0.18);
}
#bb-page-overlay .doc-btn-dl{
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.55);
}
#bb-page-overlay .doc-btn-dl:hover{
  background:rgba(255,255,255,0.10); color:#fff;
  transform:translateY(-2px);
}
#bb-page-overlay .doc-btn svg{ flex-shrink:0; }

/* ── Monitor item clickable ── */
#bb-page-overlay .monitor-item.has-doc{ cursor:pointer; }
#bb-page-overlay .monitor-item.has-doc:hover{ background:rgba(255,255,255,0.04); }
#bb-page-overlay .monitor-badge{
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:20px; font-size:10px; font-weight:700;
  background:rgba(91,200,120,0.12); border:1px solid rgba(91,200,120,0.25);
  color:rgba(91,200,120,0.9); letter-spacing:0.3px; margin-top:6px;
}

/* ══ PDF MODAL ══ */
#pdf-modal-overlay{
  position:fixed; inset:0; z-index:99999;
  background:rgba(0,0,0,0.85);
  display:none; align-items:center; justify-content:center;
  visibility:hidden;
  padding:20px;
  opacity:0;
  transition:opacity 0.35s ease;
}
#pdf-modal-overlay.open{
  display:flex;
  visibility:visible;
  opacity:1;
}

#pdf-modal-box{
  position:relative;
  width:100%; max-width:900px;
  height:90vh; max-height:900px;
  background:linear-gradient(160deg,#1a0e35 0%,#0f0820 100%);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:24px;
  display:flex; flex-direction:column;
  overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.06);
  transform:translateY(24px) scale(0.97);
  transition:transform 0.4s cubic-bezier(0.23,1,0.32,1);
}
#pdf-modal-overlay.open #pdf-modal-box{
  transform:translateY(0) scale(1);
}

/* Header bar */
#pdf-modal-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,0.07);
  background:rgba(255,255,255,0.03);
  gap:12px;
}
#pdf-modal-title{
  font-family:'Cormorant Garamond',serif; font-size:1.15rem;
  font-weight:600; color:#fff; line-height:1.3;
  flex:1; min-width:0;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
#pdf-modal-actions{ display:flex; gap:8px; flex-shrink:0; align-items:center; }
#pdf-modal-dl{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:50px;
  background:rgba(201,169,110,0.12); border:1px solid rgba(201,169,110,0.28);
  color:var(--gold2); font-family:'Montserrat',sans-serif;
  font-size:10px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase;
  text-decoration:none; transition:all 0.3s ease; white-space:nowrap;
}
#pdf-modal-dl:hover{ background:rgba(201,169,110,0.22); transform:translateY(-1px); }
#pdf-modal-close{
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.14);
  color:rgba(255,255,255,0.7); cursor:pointer; display:flex;
  align-items:center; justify-content:center; font-size:18px; line-height:1;
  transition:all 0.25s; flex-shrink:0;
}
#pdf-modal-close:hover{ background:rgba(255,255,255,0.14); color:#fff; }

/* iFrame area */
#pdf-modal-frame-wrap{
  flex:1; min-height:0; position:relative;
  background:#111;
}
#pdf-modal-iframe{
  width:100%; height:100%; border:none; display:block;
}

/* Mobile fallback (no iframe) */
#pdf-modal-mobile{
  display:none; flex-direction:column; align-items:center;
  justify-content:center; gap:20px;
  padding:40px 24px; text-align:center; flex:1;
}
#pdf-modal-mobile p{
  color:rgba(255,255,255,0.55); font-size:14px; line-height:1.6;
  max-width:320px;
}
#pdf-modal-mobile-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 28px; border-radius:50px;
  background:linear-gradient(135deg,rgba(201,169,110,0.85),rgba(232,201,138,0.7));
  color:#1a0d20; font-family:'Montserrat',sans-serif;
  font-size:12px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase;
  text-decoration:none; transition:all 0.3s;
}
#pdf-modal-mobile-btn:hover{ transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,169,110,0.35); }

/* Responsive modal */
@media(max-width:767px){
  #pdf-modal-overlay{ padding:12px; align-items:flex-end; }
  #pdf-modal-box{ height:92vh; max-height:none; border-radius:20px 20px 16px 16px; }
  #pdf-modal-header{ padding:14px 16px; }
  #pdf-modal-title{ font-size:1rem; }
  #pdf-modal-dl span{ display:none; }
  #pdf-modal-dl{ padding:8px 12px; }
}
@media(max-width:480px){
  #pdf-modal-overlay{ padding:8px; }
  #pdf-modal-box{ height:95vh; border-radius:16px 16px 12px 12px; }
}
