#hg-age-gate {
  position: fixed; inset: 0; z-index: 99999;
  background: #0D0D0D; display: flex; align-items: center;
  justify-content: center; padding: 20px;
  opacity: 1; transition: opacity 0.4s ease;
}
#hg-age-gate.hg-hiding { opacity: 0; pointer-events: none; }
#hg-age-gate.hg-hidden { display: none; }
.hg-age-inner {
  background: #161616; border: 1px solid #2a2a2a; border-radius: 22px;
  padding: 48px 44px; max-width: 520px; width: 100%; text-align: center;
  color: #f0f0f0; font-family: 'Helvetica Neue', Arial, sans-serif;
  position: relative; overflow: hidden;
}
.hg-age-inner::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #FF0066, #FF6600, #FFCC00, #00CC44, #0099FF, #9933FF);
}
.hg-age-logo { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 20px; }
.hg-age-logo-text { font-size: 30px; font-weight: 900; letter-spacing: -1px; line-height: 1; }
.hg-homo { background: linear-gradient(90deg,#FF0080,#FF44AA); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hg-guru { background: linear-gradient(90deg,#FF9900,#FFCC00); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hg-rainbow-bar { height: 2px; background: linear-gradient(90deg,#FF0066,#FF6600,#FFCC00,#00CC44,#0099FF,#9933FF); border-radius: 2px; opacity: .6; margin: 0 auto 24px; max-width: 160px; }
.hg-age-badge { display: inline-block; background: linear-gradient(135deg,#1a0010,#220022); border: 1px solid #FF004440; color: #FF44AA; font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 6px 16px; border-radius: 99px; margin-bottom: 20px; }
.hg-age-heading { font-size: 24px; font-weight: 900; letter-spacing: -.5px; margin-bottom: 16px; color: #fff; line-height: 1.2; }
.hg-age-body { font-size: 14px; color: #aaa; line-height: 1.65; margin-bottom: 14px; }
.hg-age-body strong { color: #f0f0f0; }
.hg-age-small { font-size: 12px; color: #666; }
.hg-age-small a { color: #FF44AA; text-decoration: none; }
.hg-age-buttons { display: flex; flex-direction: column; gap: 12px; margin-top: 28px; }
.hg-btn-enter { display: block; width: 100%; background: linear-gradient(90deg,#FF0080,#FF44AA); color: #fff; font-family: 'Helvetica Neue',Arial,sans-serif; font-size: 15px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; padding: 16px 24px; border: none; border-radius: 12px; cursor: pointer; transition: opacity .2s, transform .1s; }
.hg-btn-enter:hover { opacity: .88; transform: translateY(-1px); }
.hg-btn-leave { display: block; width: 100%; background: transparent; border: 1px solid #2a2a2a; color: #555; font-family: 'Helvetica Neue',Arial,sans-serif; font-size: 13px; font-weight: 600; letter-spacing: .5px; padding: 13px 24px; border-radius: 12px; text-decoration: none; transition: border-color .2s,color .2s; box-sizing: border-box; }
.hg-btn-leave:hover { border-color: #444; color: #888; }
body.hg-gate-active { overflow: hidden; }
@media(max-width:560px){ .hg-age-inner{padding:36px 24px;} .hg-age-heading{font-size:20px;} }
