/* CSS Reset & Variables */
:root {
  --14hs-primary: #8b5cf6;
  --14hs-primary-glow: rgba(139, 92, 246, 0.5);
  --14hs-secondary: #7c3aed;
  --14hs-accent: #c4b5fd;
  --14hs-accent-glow: rgba(196, 181, 253, 0.3);
  --14hs-bg-start: #0d0221;
  --14hs-bg-mid: #1e0a3a;
  --14hs-bg-end: #080114;
  --14hs-card-bg: rgba(30, 10, 58, 0.7);
  --14hs-card-border: rgba(139, 92, 246, 0.25);
  --14hs-white: #ffffff;
  --14hs-gray-100: #f3f4f6;
  --14hs-gray-300: #d1d5db;
  --14hs-gray-700: #374151;
  --14hs-gray-900: #111827;
  --14hs-radius: 8px;
  --14hs-transition: 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { 
  font-family: 'IBM Plex Sans', system-ui, sans-serif; 
  font-weight: 400; 
  line-height: 1.6; 
  background: linear-gradient(to bottom, var(--14hs-bg-start), var(--14hs-bg-mid), var(--14hs-bg-end)); 
  color: var(--14hs-white); 
  overflow-x: hidden;
  min-height: 100vh;
}
h1, h2, h3, h4, h5, h6 { font-family: 'Space Grotesk', system-ui, sans-serif; font-weight: 700; line-height: 1.2; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* Container */
.c14hs-container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* Age Verification Modal */
.c14hs-age-modal { 
  display: none; 
  position: fixed; 
  top: 0; 
  left: 0; 
  width: 100%; 
  height: 100%; 
  background: rgba(0, 0, 0, 0.95); 
  z-index: 9999; 
  align-items: center; 
  justify-content: center;
}
.c14hs-age-modal.c14hs-active { display: flex; }
.c14hs-age-modal-content { 
  background: var(--14hs-card-bg); 
  backdrop-filter: blur(20px);
  border: 2px solid var(--14hs-card-border); 
  border-radius: var(--14hs-radius); 
  padding: 40px; 
  max-width: 500px; 
  text-align: center;
  box-shadow: 0 0 40px var(--14hs-primary-glow);
}
.c14hs-age-badge-large { 
  width: 80px; 
  height: 80px; 
  background: var(--14hs-primary); 
  border-radius: 50%; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-size: 24px; 
  font-weight: 700; 
  margin: 0 auto 20px; 
  box-shadow: 0 0 30px var(--14hs-primary-glow);
  border: 3px solid var(--14hs-accent);
}
.c14hs-age-modal h2 { font-size: 28px; margin-bottom: 15px; color: var(--14hs-accent); }
.c14hs-age-modal p { font-size: 16px; margin-bottom: 30px; color: var(--14hs-gray-300); }
.c14hs-age-modal-buttons { display: flex; gap: 15px; justify-content: center; flex-wrap: wrap; }
.c14hs-btn-age-confirm { 
  padding: 15px 35px; 
  background: var(--14hs-primary); 
  color: var(--14hs-white); 
  border-radius: var(--14hs-radius); 
  font-weight: 600; 
  transition: all var(--14hs-transition);
  border: 2px solid var(--14hs-primary);
}
.c14hs-btn-age-confirm:hover { 
  transform: scale(1.05); 
  box-shadow: 0 0 25px var(--14hs-primary-glow);
}
.c14hs-btn-age-exit { 
  padding: 15px 35px; 
  background: transparent; 
  color: var(--14hs-gray-300); 
  border: 2px solid var(--14hs-gray-700); 
  border-radius: var(--14hs-radius); 
  font-weight: 600; 
  transition: all var(--14hs-transition);
}
.c14hs-btn-age-exit:hover { transform: scale(1.05); border-color: var(--14hs-gray-300); }

/* Header */
.c14hs-header { 
  position: sticky; 
  top: 0; 
  z-index: 1000; 
  background: rgba(13, 2, 33, 0.8); 
  backdrop-filter: blur(20px); 
  border-bottom: 1px solid var(--14hs-card-border);
}
.c14hs-header-inner { 
  display: flex; 
  justify-content: space-between; 
  align-items: center; 
  padding: 15px 20px; 
  max-width: 1200px; 
  margin: 0 auto;
}
.c14hs-logo { 
  font-size: 24px; 
  font-weight: 700; 
  color: var(--14hs-primary); 
  display: flex; 
  align-items: center; 
  gap: 10px;
}
.c14hs-logo-icon { 
  width: 40px; 
  height: 40px; 
  background: linear-gradient(135deg, var(--14hs-primary), var(--14hs-secondary)); 
  border-radius: 6px; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-size: 20px;
}
.c14hs-nav { display: flex; align-items: center; gap: 30px; }
.c14hs-nav-menu { display: flex; gap: 25px; list-style: none; align-items: center; }
.c14hs-nav-menu a { 
  font-size: 15px; 
  font-weight: 500; 
  transition: color var(--14hs-transition); 
  position: relative;
}
.c14hs-nav-menu a:hover { color: var(--14hs-accent); }
.c14hs-nav-menu a::after { 
  content: ''; 
  position: absolute; 
  bottom: -5px; 
  left: 0; 
  width: 0; 
  height: 2px; 
  background: var(--14hs-primary); 
  transition: width var(--14hs-transition);
}
.c14hs-nav-menu a:hover::after { width: 100%; }
.c14hs-age-badge { 
  background: var(--14hs-primary); 
  padding: 5px 12px; 
  border-radius: 20px; 
  font-size: 14px; 
  font-weight: 700; 
  box-shadow: 0 0 15px var(--14hs-primary-glow);
  border: 2px solid var(--14hs-accent);
}
.c14hs-mobile-toggle { 
  display: none; 
  flex-direction: column; 
  gap: 5px; 
  cursor: pointer;
}
.c14hs-mobile-toggle span { 
  width: 25px; 
  height: 3px; 
  background: var(--14hs-white); 
  border-radius: 2px; 
  transition: all var(--14hs-transition);
}

/* Hero */
.c14hs-hero { 
  min-height: 85vh; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  text-align: center; 
  position: relative; 
  padding: 60px 20px;
  background: linear-gradient(135deg, var(--14hs-bg-start) 0%, var(--14hs-bg-mid) 50%, var(--14hs-bg-end) 100%);
  overflow: hidden;
}
.c14hs-hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: 
    linear-gradient(rgba(139, 92, 246, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(139, 92, 246, 0.03) 1px, transparent 1px);
  background-size: 50px 50px;
  animation: c14hs-grid-move 20s linear infinite;
}
@keyframes c14hs-grid-move {
  0% { transform: translate(0, 0); }
  100% { transform: translate(50px, 50px); }
}
.c14hs-hero-content { position: relative; z-index: 10; max-width: 800px; }
.c14hs-hero-badge { 
  position: absolute; 
  top: 20px; 
  right: 20px; 
  width: 60px; 
  height: 60px; 
  background: var(--14hs-primary); 
  border-radius: 50%; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-weight: 700; 
  font-size: 16px;
  box-shadow: 0 0 30px var(--14hs-primary-glow);
  border: 3px solid var(--14hs-accent);
  animation: c14hs-pulse 2s ease-in-out infinite;
}
@keyframes c14hs-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 30px var(--14hs-primary-glow); }
  50% { transform: scale(1.05); box-shadow: 0 0 40px var(--14hs-primary-glow); }
}
.c14hs-hero h1 { 
  font-size: clamp(36px, 6vw, 64px); 
  margin-bottom: 20px; 
  background: linear-gradient(135deg, var(--14hs-white), var(--14hs-accent)); 
  -webkit-background-clip: text; 
  -webkit-text-fill-color: transparent; 
  background-clip: text;
  animation: c14hs-float 3s ease-in-out infinite;
}
@keyframes c14hs-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
.c14hs-hero p { 
  font-size: 18px; 
  margin-bottom: 35px; 
  color: var(--14hs-gray-300); 
  max-width: 600px; 
  margin-left: auto; 
  margin-right: auto;
}
.c14hs-hero-cta { display: flex; gap: 15px; justify-content: center; flex-wrap: wrap; margin-bottom: 20px; }
.c14hs-btn-primary { 
  padding: 16px 40px; 
  background: var(--14hs-primary); 
  color: var(--14hs-white); 
  border: 2px solid var(--14hs-primary); 
  border-radius: var(--14hs-radius); 
  font-weight: 600; 
  font-size: 16px; 
  transition: all var(--14hs-transition);
  box-shadow: 0 0 20px var(--14hs-primary-glow);
  animation: c14hs-pulse-btn 2s ease-in-out infinite;
}
@keyframes c14hs-pulse-btn {
  0%, 100% { box-shadow: 0 0 20px var(--14hs-primary-glow); }
  50% { box-shadow: 0 0 30px var(--14hs-primary-glow); }
}
.c14hs-btn-primary:hover { 
  transform: scale(1.05); 
  background: var(--14hs-secondary); 
  border-color: var(--14hs-secondary);
}
.c14hs-btn-secondary { 
  padding: 16px 40px; 
  background: transparent; 
  color: var(--14hs-white); 
  border: 2px solid var(--14hs-primary); 
  border-radius: var(--14hs-radius); 
  font-weight: 600; 
  font-size: 16px; 
  transition: all var(--14hs-transition);
}
.c14hs-btn-secondary:hover { 
  transform: scale(1.05); 
  background: var(--14hs-primary); 
  box-shadow: 0 0 20px var(--14hs-primary-glow);
}
.c14hs-hero-disclaimer { font-size: 14px; color: var(--14hs-gray-300); font-style: italic; }

/* Featured Games */
.c14hs-featured-games { padding: 60px 20px; position: relative; }
.c14hs-section-header { text-align: center; margin-bottom: 50px; }
.c14hs-section-header h2 { 
  font-size: clamp(32px, 5vw, 48px); 
  margin-bottom: 10px; 
  display: inline-flex; 
  align-items: center; 
  gap: 15px;
}
.c14hs-section-badge { 
  background: var(--14hs-primary); 
  padding: 8px 16px; 
  border-radius: 20px; 
  font-size: 14px; 
  box-shadow: 0 0 15px var(--14hs-primary-glow);
}
.c14hs-games-grid { 
  display: grid; 
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); 
  gap: 30px; 
  max-width: 1200px; 
  margin: 0 auto;
}
.c14hs-game-card { 
  background: var(--14hs-card-bg); 
  border: 2px solid var(--14hs-card-border); 
  border-radius: var(--14hs-radius); 
  padding: 20px; 
  transition: all var(--14hs-transition); 
  backdrop-filter: blur(10px);
}
.c14hs-game-card:hover { 
  transform: translateY(-8px) scale(1.02); 
  border-color: var(--14hs-primary); 
  box-shadow: 0 10px 40px var(--14hs-primary-glow);
}
.c14hs-game-image-wrap { 
  position: relative; 
  width: 100%; 
  height: 200px; 
  border-radius: var(--14hs-radius); 
  overflow: hidden; 
  margin-bottom: 15px;
}
.c14hs-game-image-wrap img { 
  width: 100%; 
  height: 100%; 
  object-fit: cover; 
  transition: transform var(--14hs-transition);
}
.c14hs-game-card:hover .c14hs-game-image-wrap img { transform: scale(1.1); }
.c14hs-game-image-fallback { 
  width: 100%; 
  height: 100%; 
  background: linear-gradient(135deg, var(--14hs-primary), var(--14hs-secondary)); 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  color: var(--14hs-white); 
  font-weight: 600; 
  font-size: 18px; 
  text-align: center; 
  padding: 20px;
}
.c14hs-game-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.c14hs-game-category { 
  font-size: 13px; 
  color: var(--14hs-accent); 
  font-weight: 600; 
  text-transform: uppercase; 
  letter-spacing: 0.5px;
}
.c14hs-game-card .c14hs-age-badge { 
  padding: 4px 10px; 
  font-size: 12px;
}
.c14hs-game-title { font-size: 20px; margin-bottom: 15px; color: var(--14hs-white); }
.c14hs-btn-play { 
  width: 100%; 
  padding: 12px; 
  background: transparent; 
  border: 2px solid var(--14hs-primary); 
  color: var(--14hs-white); 
  border-radius: var(--14hs-radius); 
  font-weight: 600; 
  transition: all var(--14hs-transition);
}
.c14hs-btn-play:hover { 
  background: var(--14hs-primary); 
  box-shadow: 0 0 20px var(--14hs-primary-glow);
}

/* Game Modal */
.c14hs-game-modal { 
  display: none; 
  position: fixed; 
  top: 0; 
  left: 0; 
  width: 100%; 
  height: 100%; 
  background: rgba(0, 0, 0, 0.95); 
  z-index: 9998; 
  align-items: center; 
  justify-content: center; 
  padding: 20px;
}
.c14hs-game-modal.c14hs-active { display: flex; }
.c14hs-modal-content { 
  background: var(--14hs-card-bg); 
  border: 2px solid var(--14hs-card-border); 
  border-radius: var(--14hs-radius); 
  width: 100%; 
  max-width: 1200px; 
  height: 90vh; 
  display: flex; 
  flex-direction: column;
  backdrop-filter: blur(20px);
}
.c14hs-modal-header { 
  display: flex; 
  justify-content: space-between; 
  align-items: center; 
  padding: 20px; 
  border-bottom: 1px solid var(--14hs-card-border);
}
.c14hs-modal-header h2 { font-size: 24px; flex: 1; }
.c14hs-close-btn { 
  width: 40px; 
  height: 40px; 
  background: transparent; 
  border: 2px solid var(--14hs-primary); 
  border-radius: 50%; 
  color: var(--14hs-white); 
  font-size: 24px; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  transition: all var(--14hs-transition);
  margin-left: 15px;
}
.c14hs-close-btn:hover { 
  background: var(--14hs-primary); 
  transform: rotate(90deg);
}
.c14hs-game-iframe { 
  flex: 1; 
  width: 100%; 
  border: none; 
  border-radius: 0 0 var(--14hs-radius) var(--14hs-radius);
}
.c14hs-demo-unavailable { 
  flex: 1; 
  display: none; 
  align-items: center; 
  justify-content: center; 
  font-size: 18px; 
  color: var(--14hs-gray-300);
}

/* CTA Band */
.c14hs-cta-band { 
  padding: 60px 20px; 
  background: linear-gradient(135deg, var(--14hs-primary), var(--14hs-secondary)); 
  text-align: center; 
  position: relative;
  overflow: hidden;
}
.c14hs-cta-band::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(255,255,255,0.1) 1px, transparent 1px);
  background-size: 30px 30px;
  animation: c14hs-rotate 30s linear infinite;
}
@keyframes c14hs-rotate {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
.c14hs-cta-band-content { position: relative; z-index: 10; }
.c14hs-cta-band h2 { font-size: clamp(28px, 4vw, 42px); margin-bottom: 15px; }
.c14hs-cta-band p { font-size: 18px; margin-bottom: 25px; opacity: 0.9; }
.c14hs-btn-cta { 
  padding: 18px 50px; 
  background: var(--14hs-white); 
  color: var(--14hs-primary); 
  border: 2px solid var(--14hs-white); 
  border-radius: var(--14hs-radius); 
  font-weight: 700; 
  font-size: 18px; 
  transition: all var(--14hs-transition);
}
.c14hs-btn-cta:hover { 
  transform: scale(1.08); 
  box-shadow: 0 10px 40px rgba(255, 255, 255, 0.3);
}

/* Trust Block */
.c14hs-trust-block { padding: 50px 20px; background: var(--14hs-card-bg); border-top: 1px solid var(--14hs-card-border); border-bottom: 1px solid var(--14hs-card-border); }
.c14hs-trust-content { max-width: 800px; margin: 0 auto; text-align: center; }
.c14hs-trust-content h3 { font-size: 28px; margin-bottom: 20px; color: var(--14hs-accent); }
.c14hs-trust-items { display: flex; flex-direction: column; gap: 15px; margin-bottom: 20px; }
.c14hs-trust-item { 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  gap: 10px; 
  font-size: 16px;
}
.c14hs-trust-item::before { 
  content: '✓'; 
  color: var(--14hs-primary); 
  font-weight: 700; 
  font-size: 20px;
}
.c14hs-trust-note { font-size: 14px; color: var(--14hs-gray-300); font-style: italic; }

/* How It Works */
.c14hs-how-it-works { padding: 60px 20px; }
.c14hs-steps-grid { 
  display: grid; 
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); 
  gap: 30px; 
  max-width: 1200px; 
  margin: 0 auto;
}
.c14hs-step-card { 
  background: var(--14hs-card-bg); 
  border: 2px solid var(--14hs-card-border); 
  border-radius: var(--14hs-radius); 
  padding: 30px; 
  text-align: center; 
  transition: all var(--14hs-transition);
  backdrop-filter: blur(10px);
}
.c14hs-step-card:hover { 
  transform: translateY(-5px); 
  border-color: var(--14hs-primary); 
  box-shadow: 0 10px 30px var(--14hs-primary-glow);
}
.c14hs-step-icon { 
  font-size: 40px; 
  margin-bottom: 15px; 
  display: block;
}
.c14hs-step-card h3 { font-size: 20px; margin-bottom: 10px; color: var(--14hs-accent); }
.c14hs-step-card p { font-size: 15px; color: var(--14hs-gray-300); }

/* Why Choose Us */
.c14hs-why-choose { padding: 60px 20px; background: rgba(0, 0, 0, 0.3); }
.c14hs-features-bento { 
  display: grid; 
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); 
  gap: 25px; 
  max-width: 1200px; 
  margin: 0 auto;
}
.c14hs-feature-card { 
  background: var(--14hs-card-bg); 
  border: 2px solid var(--14hs-card-border); 
  border-radius: var(--14hs-radius); 
  padding: 30px; 
  transition: all var(--14hs-transition);
  backdrop-filter: blur(10px);
}
.c14hs-feature-card:hover { 
  border-color: var(--14hs-primary); 
  box-shadow: 0 10px 40px var(--14hs-primary-glow); 
  transform: scale(1.02);
}
.c14hs-feature-icon { font-size: 36px; margin-bottom: 15px; display: block; }
.c14hs-feature-card h3 { font-size: 22px; margin-bottom: 10px; color: var(--14hs-accent); }
.c14hs-feature-card p { font-size: 15px; color: var(--14hs-gray-300); }

/* Responsible Gaming */
.c14hs-responsible { 
  padding: 60px 20px; 
  text-align: center; 
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.1), rgba(124, 58, 237, 0.1));
}
.c14hs-responsible-content { max-width: 800px; margin: 0 auto; }
.c14hs-responsible-icon { 
  width: 100px; 
  height: 100px; 
  background: var(--14hs-primary); 
  border-radius: 50%; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-size: 48px; 
  margin: 0 auto 25px;
  box-shadow: 0 0 40px var(--14hs-primary-glow);
  border: 4px solid var(--14hs-accent);
}
.c14hs-responsible h2 { font-size: clamp(32px, 5vw, 48px); margin-bottom: 20px; color: var(--14hs-accent); }
.c14hs-responsible p { font-size: 18px; margin-bottom: 25px; color: var(--14hs-gray-300); }
.c14hs-responsible-links { display: flex; gap: 20px; justify-content: center; flex-wrap: wrap; margin-top: 30px; }
.c14hs-responsible-links a { 
  padding: 12px 25px; 
  border: 2px solid var(--14hs-primary); 
  border-radius: var(--14hs-radius); 
  transition: all var(--14hs-transition); 
  font-weight: 600;
}
.c14hs-responsible-links a:hover { 
  background: var(--14hs-primary); 
  box-shadow: 0 0 20px var(--14hs-primary-glow); 
  transform: scale(1.05);
}

/* FAQ */
.c14hs-faq { padding: 60px 20px; }
.c14hs-faq-container { max-width: 800px; margin: 0 auto; }
.c14hs-faq-item { 
  background: var(--14hs-card-bg); 
  border: 2px solid var(--14hs-card-border); 
  border-radius: var(--14hs-radius); 
  margin-bottom: 15px; 
  overflow: hidden;
  backdrop-filter: blur(10px);
}
.c14hs-faq-question { 
  width: 100%; 
  padding: 20px; 
  text-align: left; 
  font-size: 18px; 
  font-weight: 600; 
  color: var(--14hs-white); 
  display: flex; 
  justify-content: space-between; 
  align-items: center; 
  cursor: pointer; 
  transition: all var(--14hs-transition);
}
.c14hs-faq-question:hover { color: var(--14hs-accent); }
.c14hs-faq-toggle { 
  font-size: 24px; 
  transition: transform var(--14hs-transition);
}
.c14hs-faq-item.c14hs-active .c14hs-faq-toggle { transform: rotate(45deg); }
.c14hs-faq-answer { 
  max-height: 0; 
  overflow: hidden; 
  transition: max-height var(--14hs-transition); 
  padding: 0 20px;
}
.c14hs-faq-item.c14hs-active .c14hs-faq-answer { max-height: 500px; padding: 0 20px 20px; }
.c14hs-faq-answer p { font-size: 16px; color: var(--14hs-gray-300); line-height: 1.6; }

/* Footer */
.c14hs-footer { 
  padding: 60px 20px 30px; 
  border-top: 2px solid var(--14hs-card-border); 
  background: rgba(0, 0, 0, 0.5);
}
.c14hs-footer-content { max-width: 1200px; margin: 0 auto; text-align: center; }
.c14hs-footer-logo { 
  font-size: 28px; 
  font-weight: 700; 
  color: var(--14hs-primary); 
  margin-bottom: 20px; 
  display: inline-block;
}
.c14hs-footer-age-badge { 
  width: 80px; 
  height: 80px; 
  background: var(--14hs-primary); 
  border-radius: 50%; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-size: 24px; 
  font-weight: 700; 
  margin: 20px auto; 
  box-shadow: 0 0 40px var(--14hs-primary-glow);
  border: 4px solid var(--14hs-accent);
}
.c14hs-footer-disclaimer { 
  font-size: 15px; 
  color: var(--14hs-gray-300); 
  margin-bottom: 25px; 
  max-width: 800px; 
  margin-left: auto; 
  margin-right: auto; 
  line-height: 1.6;
}
.c14hs-footer-links { 
  display: flex; 
  gap: 20px; 
  justify-content: center; 
  flex-wrap: wrap; 
  margin-bottom: 25px;
}
.c14hs-footer-links a { 
  color: var(--14hs-accent); 
  font-weight: 500; 
  transition: color var(--14hs-transition);
}
.c14hs-footer-links a:hover { color: var(--14hs-primary); }
.c14hs-footer-copyright { 
  font-size: 14px; 
  color: var(--14hs-gray-300); 
  padding-top: 20px; 
  border-top: 1px solid var(--14hs-card-border);
}

/* Games Page Specific */
.c14hs-page-header { padding: 100px 20px 40px; text-align: center; }
.c14hs-page-header h1 { font-size: clamp(36px, 6vw, 56px); margin-bottom: 15px; color: var(--14hs-accent); }
.c14hs-age-reminder { 
  background: rgba(139, 92, 246, 0.2); 
  border: 2px solid var(--14hs-primary); 
  border-radius: var(--14hs-radius); 
  padding: 15px; 
  margin: 20px auto; 
  max-width: 600px; 
  text-align: center; 
  font-weight: 600;
}
.c14hs-category-filters { 
  display: flex; 
  gap: 15px; 
  justify-content: center; 
  flex-wrap: wrap; 
  margin-bottom: 40px;
}
.c14hs-filter-btn { 
  padding: 10px 20px; 
  background: transparent; 
  border: 2px solid var(--14hs-primary); 
  border-radius: var(--14hs-radius); 
  color: var(--14hs-white); 
  font-weight: 600; 
  transition: all var(--14hs-transition);
}
.c14hs-filter-btn:hover, .c14hs-filter-btn.c14hs-active { 
  background: var(--14hs-primary); 
  box-shadow: 0 0 20px var(--14hs-primary-glow);
}

/* Legal Pages */
.c14hs-legal-page { padding: 100px 20px 60px; }
.c14hs-legal-content { max-width: 900px; margin: 0 auto; }
.c14hs-legal-content h1 { font-size: clamp(32px, 5vw, 48px); margin-bottom: 20px; color: var(--14hs-accent); }
.c14hs-legal-content h2 { font-size: 28px; margin-top: 40px; margin-bottom: 15px; color: var(--14hs-accent); }
.c14hs-legal-content h3 { font-size: 22px; margin-top: 30px; margin-bottom: 10px; color: var(--14hs-gray-300); }
.c14hs-legal-content p, .c14hs-legal-content li { font-size: 16px; color: var(--14hs-gray-300); line-height: 1.8; margin-bottom: 15px; }
.c14hs-legal-content ul { margin-left: 20px; margin-bottom: 20px; }
.c14hs-legal-notice { 
  background: rgba(139, 92, 246, 0.2); 
  border: 2px solid var(--14hs-primary); 
  border-radius: var(--14hs-radius); 
  padding: 20px; 
  margin: 30px 0; 
  font-weight: 600;
}

/* Decorative Elements */
.c14hs-glow-divider { 
  height: 2px; 
  background: linear-gradient(90deg, transparent, var(--14hs-primary), transparent); 
  margin: 40px 0; 
  box-shadow: 0 0 20px var(--14hs-primary-glow);
}
.c14hs-corner-badge { 
  position: absolute; 
  top: 10px; 
  right: 10px; 
  width: 30px; 
  height: 30px; 
  background: var(--14hs-primary); 
  border-radius: 50%; 
  opacity: 0.3;
}
.c14hs-floating-orb { 
  position: absolute; 
  width: 200px; 
  height: 200px; 
  background: radial-gradient(circle, var(--14hs-primary-glow), transparent); 
  border-radius: 50%; 
  filter: blur(60px); 
  pointer-events: none; 
  animation: c14hs-orb-float 10s ease-in-out infinite;
}
@keyframes c14hs-orb-float {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(50px, -50px); }
}
.c14hs-floating-orb-1 { top: 10%; left: 5%; }
.c14hs-floating-orb-2 { bottom: 20%; right: 10%; animation-delay: 5s; }

/* Wave Divider */
.c14hs-wave-divider { 
  position: relative; 
  width: 100%; 
  height: 80px; 
  overflow: hidden;
}
.c14hs-wave-divider svg { 
  position: absolute; 
  bottom: 0; 
  width: 100%; 
  height: 100%;
}

/* Responsive */
@media (max-width: 768px) {
  .c14hs-nav-menu { 
    position: fixed; 
    top: 70px; 
    left: 0; 
    width: 100%; 
    background: rgba(13, 2, 33, 0.98); 
    backdrop-filter: blur(20px); 
    flex-direction: column; 
    padding: 20px; 
    gap: 15px; 
    transform: translateX(-100%); 
    transition: transform var(--14hs-transition);
    border-bottom: 2px solid var(--14hs-card-border);
  }
  .c14hs-nav-menu.c14hs-active { transform: translateX(0); }
  .c14hs-mobile-toggle { display: flex; }
  .c14hs-hero { min-height: 70vh; padding: 40px 20px; }
  .c14hs-hero-badge { width: 50px; height: 50px; font-size: 14px; top: 10px; right: 10px; }
  .c14hs-games-grid { grid-template-columns: 1fr; gap: 20px; }
  .c14hs-steps-grid { grid-template-columns: 1fr; }
  .c14hs-features-bento { grid-template-columns: 1fr; }
  .c14hs-hero-cta { flex-direction: column; gap: 10px; }
  .c14hs-btn-primary, .c14hs-btn-secondary { width: 100%; }
  .c14hs-modal-content { height: 85vh; }
  .c14hs-age-modal-content { padding: 30px 20px; }
  .c14hs-age-modal-buttons { flex-direction: column; width: 100%; }
  .c14hs-btn-age-confirm, .c14hs-btn-age-exit { width: 100%; }
}

@media (max-width: 480px) {
  .c14hs-hero h1 { font-size: 32px; }
  .c14hs-hero p { font-size: 16px; }
  .c14hs-section-header h2 { font-size: 28px; }
  .c14hs-game-card { padding: 15px; }
  .c14hs-game-image-wrap { height: 180px; }
}