 :root {

   --bg-dark-primary: #1a1d24;
   --bg-dark-secondary: #252a34;
   --text-light: #f0f4f8;
   --text-medium: #a9b4c2;
   --accent-teal: #14b8a6;
   --accent-purple: #a855f7;
   --accent-gold: #eab308;
   --accent-danger: #ef4444;
   --accent-success: #22c55e;


   --font-primary: 'Helvetica Neue', Arial, sans-serif;
   --font-secondary: 'Georgia', serif;


   --header-height: 70px;
   --border-radius: 8px;
   --container-width: 1100px;
   --shadow: 0 4px 15px rgba(0, 0, 0, 0.2);

   --age-cookie-bg: #252a34;
   --age-cookie-accent: #14b8a6;
   --age-cookie-text: #f9fafb;
   --age-cookie-subtext: #cbd5f5;
 }

 * {
   box-sizing: border-box;
   margin: 0;
   padding: 0;
 }

 html {
   scroll-behavior: smooth;
 }

 body {
   font-family: var(--font-primary);
   background-color: var(--bg-dark-primary);
   color: var(--text-light);
   line-height: 1.7;
   font-size: 16px;
 }

 img {
   max-width: 100%;
   height: auto;
 }

 a {
   color: var(--accent-teal);
   text-decoration: none;
   transition: color 0.3s ease;
 }

 a:hover {
   color: var(--text-light);
 }

 h1,
 h2,
 h3,
 h4 {
   font-family: var(--font-secondary);
   color: var(--text-light);
   line-height: 1.3;
   margin-bottom: 1.2rem;
 }

 h1 {
   font-size: 2.5rem;
 }

 h2 {
   font-size: 2rem;
 }

 h3 {
   font-size: 1.5rem;
 }

 p {
   margin-bottom: 1.2rem;
   color: var(--text-medium);
 }

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

 .btn {
   display: inline-block;
   padding: 0.8rem 1.8rem;
   border: none;
   border-radius: var(--border-radius);
   font-size: 1rem;
   font-weight: 600;
   cursor: pointer;
   text-align: center;
   transition: all 0.3s ease;
   text-decoration: none;
 }

 .btn-primary {
   background-color: var(--accent-teal);
   color: var(--bg-dark-primary);
 }

 .btn-primary:hover {
   background-color: #10a391;
   color: #fff;
   transform: translateY(-2px);
   box-shadow: 0 4px 10px rgba(20, 184, 166, 0.2);
 }

 .btn-secondary {
   background-color: var(--accent-purple);
   color: var(--text-light);
 }

 .btn-secondary:hover {
   background-color: #9333ea;
   color: var(--text-light);
   transform: translateY(-2px);
   box-shadow: 0 4px 10px rgba(168, 85, 247, 0.2);
 }

 .card {
   background-color: var(--bg-dark-secondary);
   border-radius: var(--border-radius);
   padding: 2rem;
   box-shadow: var(--shadow);
   border: 1px solid #333;
 }

 .section-padding {
   padding: 4rem 0;
 }

 .text-center {
   text-align: center;
 }

 .section-title {
   font-size: 2.2rem;
   text-align: center;
   margin-bottom: 3rem;
   color: var(--text-light);
 }

 .section-title::after {
   content: '';
   display: block;
   width: 60px;
   height: 4px;
   background-color: var(--accent-teal);
   margin: 0.5rem auto 0;
   border-radius: 2px;
 }

 .site-header {
   background-color: var(--bg-dark-secondary);
   padding: 0 1.5rem;
   height: var(--header-height);
   position: sticky;
   top: 0;
   z-index: 1000;
   box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
   border-bottom: 1px solid #333;
 }

 .site-header .container {
   display: flex;
   justify-content: space-between;
   align-items: center;
   height: 100%;
 }

 .logo {
   font-size: 1.5rem;
   font-weight: 700;
   color: var(--text-light);
   text-decoration: none;
 }

 .logo .fa-ticket-alt {
   color: var(--accent-teal);
   margin-right: 0.5rem;
   transform: rotate(-30deg);
 }

 .main-nav {
   list-style: none;
 }

 .main-nav li {
   display: inline-block;
   margin-left: 1rem;
 }

 .main-nav a {
   color: var(--text-medium);
   text-decoration: none;
   padding: 0.5rem 0.8rem;
   font-weight: 500;
   transition: all 0.3s ease;
   position: relative;
 }

 .main-nav a::after {
   content: '';
   display: block;
   width: 0;
   height: 2px;
   background: var(--accent-teal);
   transition: width 0.3s;
   position: absolute;
   bottom: 0;
   left: 50%;
   transform: translateX(-50%);
 }

 .main-nav a:hover,
 .main-nav a.active {
   color: var(--text-light);
 }

 .main-nav a:hover::after,
 .main-nav a.active::after {
   width: 100%;
 }


 .nav-toggle {
   display: none;
   background: none;
   border: none;
   color: var(--text-light);
   font-size: 1.8rem;
   cursor: pointer;
 }



 .footer-grid {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
   gap: 2rem;
   margin-bottom: 2rem;
 }

 .footer-section h4 {
   color: var(--text-light);
   font-size: 1.2rem;
   margin-bottom: 1rem;
 }

 .footer-section p {
   margin-bottom: 0.5rem;
   color: var(--text-medium);
 }

 .footer-links {
   list-style: none;
 }

 .footer-links li {
   margin-bottom: 0.5rem;
 }

 .footer-links a {
   color: var(--text-medium);
 }

 .footer-links a:hover {
   color: var(--accent-teal);
   padding-left: 5px;
 }

 .footer-bottom {
   text-align: center;
   border-top: 1px solid #444;
   padding-top: 1.5rem;
   font-size: 0.85rem;
 }

 .footer-bottom p {
   margin-bottom: 0.5rem;
 }

 .hero {
   display: flex;
   align-items: center;
   justify-content: center;
   text-align: center;
   min-height: 70vh;
   padding: 4rem 1.5rem;
   background: linear-gradient(rgba(26, 29, 36, 0.85), rgba(26, 29, 36, 0.85)),
     url('../img/hero.png') no-repeat center center/cover;
   color: var(--text-light);
 }

 .hero-content h1 {
   font-size: 3.5rem;
   margin-bottom: 1rem;
 }

 .hero-content p {
   font-size: 1.2rem;
   max-width: 600px;
   margin: 0 auto 2rem;
   color: var(--text-light);
 }

 .hero-content .btn {
   margin: 0.5rem;
 }


 .featured-games-grid {
   display: grid;
   grid-template-columns: repeat(3, 1fr);
   gap: 1.5rem;
 }

 .game-card {
   background: var(--bg-dark-secondary);
   border-radius: var(--border-radius);
   text-align: center;
   padding: 2rem;
   border: 1px solid #333;
   transition: all 0.3s ease;
 }

 .game-card:hover {
   transform: translateY(-5px);
   box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
   border-color: var(--accent-teal);
 }

 .game-logo-generic {
   width: 100px;
   height: 100px;
   border-radius: 50%;
   margin: 0 auto 1.5rem;
   display: flex;
   align-items: center;
   justify-content: center;
   font-size: 1.4rem;
   font-weight: 700;
   color: var(--text-light);
 }

 .logo-649 {
   background: linear-gradient(135deg, #c0392b, #8e44ad);
 }

 .logo-max {
   background: linear-gradient(135deg, #8e44ad, #16a085);
 }

 .logo-grand {
   background: linear-gradient(135deg, #d4af37, #27ae60);
 }

 .game-card h3 {
   color: var(--text-light);
   font-size: 1.6rem;
 }


 .how-it-works-steps {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
   gap: 2rem;
   text-align: center;
 }

 .step-card {
   padding: 1.5rem;
 }

 .step-card .icon {
   font-size: 3rem;
   color: var(--accent-purple);
   margin-bottom: 1rem;
 }

 .step-card h3 {
   font-size: 1.3rem;
   color: var(--text-light);
 }


 .why-us-grid {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
   gap: 1.5rem;
 }

 .feature-card {
   background: var(--bg-dark-secondary);
   padding: 2rem;
   border-radius: var(--border-radius);
   border-left: 5px solid var(--accent-gold);
 }

 .feature-card .icon {
   font-size: 2.5rem;
   color: var(--accent-gold);
   margin-bottom: 1rem;
 }

 .feature-card h3 {
   font-size: 1.3rem;
 }


 .responsible-play {
   background-color: var(--bg-dark-secondary);
   border: 1px solid #444;
   border-left: 5px solid var(--accent-danger);
 }

 .form-section {
   display: flex;
   justify-content: center;
   align-items: center;
   padding: 4rem 1.5rem;
   min-height: 70vh;
 }

 .form-container {
   width: 100%;
   max-width: 500px;
 }

 .form-container.card {
   padding: 2.5rem;
 }

 .form-title {
   text-align: center;
   font-size: 2rem;
   margin-bottom: 2rem;
 }

 .form-group {
   margin-bottom: 1.5rem;
   position: relative;
 }

 .form-group label {
   display: block;
   margin-bottom: 0.5rem;
   font-weight: 500;
   color: var(--text-medium);
 }

 .form-group input,
 .form-group select,
 .form-group textarea {
   width: 100%;
   padding: 0.8rem 1rem;
   border-radius: var(--border-radius);
   border: 1px solid #444;
   background-color: var(--bg-dark-primary);
   color: var(--text-light);
   font-size: 1rem;
 }

 .form-group textarea {
   min-height: 120px;
   resize: vertical;
 }

 .form-group input:focus,
 .form-group select:focus,
 .form-group textarea:focus {
   outline: none;
   border-color: var(--accent-teal);
   box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.3);
 }


 .form-group .error-message {
   color: var(--accent-danger);
   font-size: 0.85rem;
   margin-top: 0.3rem;
   display: none;
 }

 .form-group.error input,
 .form-group.error textarea {
   border-color: var(--accent-danger);
 }

 .form-group.error .error-message {
   display: block;
 }

 .form-group.success input {
   border-color: var(--accent-success);
 }

 .form-checkbox {
   display: flex;
   align-items: center;
   gap: 0.5rem;
 }

 .form-checkbox input {
   width: auto;
 }

 .form-link {
   display: block;
   text-align: right;
   font-size: 0.9rem;
   margin-top: 0.5rem;
 }

 .form-container .btn {
   width: 100%;
   margin-top: 1rem;
 }

 .form-switch {
   text-align: center;
   margin-top: 1.5rem;
   font-size: 0.95rem;
   color: var(--text-medium);
 }

 .alert-message {
   padding: 1rem;
   border-radius: var(--border-radius);
   margin-bottom: 1.5rem;
   font-weight: 500;
   display: none;
 }

 .alert-message.success {
   background-color: rgba(34, 197, 94, 0.2);
   border: 1px solid var(--accent-success);
   color: var(--accent-success);
   display: block;
 }

 .alert-message.error {
   background-color: rgba(239, 68, 68, 0.2);
   border: 1px solid var(--accent-danger);
   color: var(--accent-danger);
   display: block;
 }

 .about-header {
   text-align: center;
   padding: 3rem 1.5rem;
   background-color: var(--bg-dark-secondary);
 }

 .about-header p {
   font-size: 1.15rem;
   max-width: 800px;
   margin: 0 auto;
 }

 .values-grid {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
   gap: 1.5rem;
   text-align: center;
 }

 .value-card .icon {
   font-size: 2.5rem;
   color: var(--accent-purple);
   margin-bottom: 1rem;
 }

 .contact-grid {
   display: grid;
   grid-template-columns: 1fr;
   gap: 3rem;
 }

 .contact-info h3 {
   color: var(--text-light);
   margin-bottom: 1.5rem;
 }

 .contact-info p {
   display: flex;
   align-items: flex-start;
   gap: 1rem;
   margin-bottom: 1.2rem;
   font-size: 1.05rem;
 }

 .contact-info .icon {
   font-size: 1.2rem;
   color: var(--accent-teal);
   padding-top: 0.2rem;
   width: 20px;
   text-align: center;
 }

 .map-placeholder {
   height: 250px;
   background-color: #333;
   border-radius: var(--border-radius);
   display: flex;
   align-items: center;
   justify-content: center;
   color: var(--text-medium);
   font-style: italic;
   margin-top: 2rem;
   border: 1px solid #444;
 }

 .buy-grid {
   display: grid;
   grid-template-columns: 2fr 1fr;
   gap: 2rem;
 }

 .ticket-selection .card,
 .ticket-summary .card {
   height: 100%;
 }

 .ticket-summary .card {
   position: sticky;
   top: calc(var(--header-height) + 2rem);
 }

 .game-options .form-group {
   display: flex;
   flex-direction: column;
   gap: 0.5rem;
 }

 .game-options label {
   display: block;
   padding: 1rem;
   border: 1px solid #444;
   border-radius: var(--border-radius);
   cursor: pointer;
   transition: all 0.3s ease;
 }

 .game-options input[type="radio"] {
   display: none;
 }

 .game-options input[type="radio"]:checked+label {
   border-color: var(--accent-purple);
   background-color: rgba(168, 85, 247, 0.1);
   box-shadow: 0 0 0 2px var(--accent-purple);
 }

 .game-options label:hover {
   background-color: var(--bg-dark-primary);
 }

 .quick-pick-numbers {
   background-color: var(--bg-dark-primary);
   border: 1px solid #444;
   padding: 1rem;
   border-radius: var(--border-radius);
   margin-top: 1rem;
   font-size: 1.1rem;
   font-weight: 600;
   color: var(--text-medium);
   min-height: 50px;
 }

 .summary-line {
   display: flex;
   justify-content: space-between;
   padding: 1rem 0;
   border-bottom: 1px solid #444;
 }

 .summary-line:last-of-type {
   border-bottom: none;
 }

 .summary-line strong {
   color: var(--text-light);
 }

 .summary-total {
   font-size: 1.5rem;
   font-weight: 700;
   color: var(--accent-teal);
   margin-top: 1rem;
 }

 .summary-total span {
   font-size: 1rem;
   color: var(--text-medium);
 }

 .ticket-summary .btn {
   width: 100%;
   margin-top: 1.5rem;
 }


 .modal-overlay {
   position: fixed;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background: rgba(0, 0, 0, 0.7);
   display: flex;
   align-items: center;
   justify-content: center;
   z-index: 2000;
   opacity: 0;
   visibility: hidden;
   transition: opacity 0.3s ease, visibility 0.3s ease;
 }

 .modal-overlay.active {
   opacity: 1;
   visibility: visible;
 }

 .modal-content {
   background: var(--bg-dark-secondary);
   padding: 2.5rem;
   border-radius: var(--border-radius);
   width: 90%;
   max-width: 500px;
   text-align: center;
   box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
   transform: scale(0.9);
   transition: transform 0.3s ease;
 }

 .modal-overlay.active .modal-content {
   transform: scale(1);
 }

 .modal-content .icon {
   font-size: 3rem;
   color: var(--accent-success);
   margin-bottom: 1rem;
 }

 .modal-content h2 {
   color: var(--text-light);
 }

 .modal-content p {
   color: var(--text-medium);
   font-size: 0.95rem;
   margin-bottom: 2rem;
 }

 #closeModalBtn {
   background-color: var(--bg-dark-primary);
   color: var(--text-light);
   border: 1px solid #444;
 }

 #closeModalBtn:hover {
   background-color: #333;
 }



 @media (min-width: 768px) {
   h1 {
     font-size: 3rem;
   }

   .hero-content h1 {
     font-size: 4rem;
   }


   .main-nav {
     display: flex;
   }

   .nav-toggle {
     display: none;
   }


   .contact-grid {
     grid-template-columns: 1fr 1fr;
   }
 }


 @media (max-width: 767px) {
   .site-header {
     padding: 0 1rem;
   }

   .nav-toggle {
     display: block;
   }

   .main-nav {
     display: none;
     position: absolute;
     top: var(--header-height);
     left: 0;
     right: 0;
     background: var(--bg-dark-secondary);
     width: 100%;
     flex-direction: column;
     padding: 1rem;
     box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2);
     border-top: 1px solid #333;
   }

   .main-nav.active {
     display: flex;
   }

   .main-nav li {
     display: block;
     margin: 0;
   }

   .main-nav a {
     display: block;
     padding: 1rem;
     text-align: center;
   }

   .main-nav a:hover,
   .main-nav a.active {
     background-color: var(--bg-dark-primary);
   }

   .main-nav a::after {
     display: none;
   }


   .featured-games-grid,
   .buy-grid {
     grid-template-columns: 1fr;
   }

   .ticket-summary .card {
     position: static;
     margin-top: 2rem;
   }

   .hero {
     min-height: 50vh;
   }

   .hero-content h1 {
     font-size: 2.5rem;
   }
 }

 .footer-imgs {
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   align-items: center;
 }

 .footer-imgs img {
   padding: 12px;
   margin: 12px;
   height: 55px;
   background: white;
   border-radius: 10px;
 }

 .age-overlay {
   position: fixed;
   inset: 0;
   background: rgba(0, 0, 0, 0.7);
   display: none;
   align-items: center;
   justify-content: center;
   z-index: 9999;
 }

 .age-overlay.is-visible {
   display: flex;
 }

 .age-modal {
   max-width: 480px;
   width: 90%;
   background: var(--age-cookie-bg);
   color: var(--age-cookie-text);
   border-radius: 18px;
   padding: 24px 24px 20px;
   box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6);
   border: 1px solid rgba(255, 255, 255, 0.06);
 }

 .age-title {
   font-size: 1.5rem;
   margin-bottom: 12px;
 }

 .age-text {
   font-size: 0.95rem;
   line-height: 1.5;
   color: var(--age-cookie-subtext);
   margin-bottom: 20px;
 }

 .age-actions {
   display: flex;
   gap: 12px;
   margin-bottom: 12px;
   flex-wrap: wrap;
 }

 .age-note {
   font-size: 0.8rem;
   color: var(--age-cookie-subtext);
   opacity: 0.9;
 }

 /* COOKIE BANNER */

 .cookie-banner {
   position: fixed;
   left: 16px;
   right: 16px;
   bottom: 16px;
   background: var(--age-cookie-bg);
   color: var(--age-cookie-text);
   border-radius: 16px;
   padding: 16px 18px;
   box-shadow: 0 16px 40px rgba(0, 0, 0, 0.5);
   border-left: 4px solid var(--age-cookie-accent);
   display: none;
   z-index: 9998;
 }

 .cookie-banner.is-visible {
   display: block;
 }

 .cookie-inner {
   display: flex;
   gap: 16px;
   align-items: flex-start;
   justify-content: space-between;
 }

 .cookie-text h3 {
   margin: 0 0 6px;
   font-size: 1rem;
 }

 .cookie-text p {
   margin: 0 0 8px;
   font-size: 0.9rem;
   color: var(--age-cookie-subtext);
 }

 .cookie-actions {
   display: flex;
   flex-direction: column;
   gap: 8px;
   min-width: 160px;
 }

 .link-button {
   border: none;
   background: none;
   color: var(--age-cookie-accent);
   font-size: 0.85rem;
   padding: 0;
   cursor: pointer;
   text-decoration: underline;
   display: inline-flex;
   align-items: center;
   gap: 6px;
 }

 .link-button i {
   font-size: 0.85rem;
 }

 /* COOKIE SETTINGS OVERLAY */

 .cookie-settings-overlay {
   position: fixed;
   inset: 0;
   background: rgba(0, 0, 0, 0.7);
   display: none;
   align-items: center;
   justify-content: center;
   z-index: 10000;
 }

 .cookie-settings-overlay.is-visible {
   display: flex;
 }

 .cookie-settings-modal {
   max-width: 520px;
   width: 90%;
   background: var(--age-cookie-bg);
   color: var(--age-cookie-text);
   border-radius: 18px;
   padding: 20px 20px 18px;
   box-shadow: 0 24px 60px rgba(0, 0, 0, 0.7);
   border: 1px solid rgba(255, 255, 255, 0.08);
 }

 .cookie-settings-header {
   display: flex;
   align-items: center;
   justify-content: space-between;
   gap: 12px;
   margin-bottom: 10px;
 }

 .cookie-settings-header h3 {
   margin: 0;
   font-size: 1.1rem;
 }

 .cookie-settings-desc {
   font-size: 0.9rem;
   color: var(--age-cookie-subtext);
   margin-bottom: 14px;
 }

 .cookie-option {
   display: flex;
   align-items: flex-start;
   justify-content: space-between;
   gap: 12px;
   padding: 10px 0;
   border-top: 1px solid rgba(255, 255, 255, 0.06);
 }

 .cookie-option:last-of-type {
   border-bottom: 1px solid rgba(255, 255, 255, 0.06);
 }

 .cookie-option-main h4 {
   margin: 0 0 4px;
   font-size: 0.95rem;
 }

 .cookie-option-main p {
   margin: 0;
   font-size: 0.85rem;
   color: var(--age-cookie-subtext);
 }

 .cookie-option--locked {
   opacity: 0.9;
 }

 .cookie-toggle {
   display: flex;
   flex-direction: column;
   align-items: flex-end;
   gap: 4px;
   min-width: 90px;
 }

 .toggle-label {
   font-size: 0.8rem;
   color: var(--age-cookie-subtext);
 }

 /* Switch component */

 .switch {
   position: relative;
   display: inline-block;
   width: 44px;
   height: 24px;
 }

 .switch input {
   opacity: 0;
   width: 0;
   height: 0;
 }

 .slider {
   position: absolute;
   cursor: pointer;
   inset: 0;
   background-color: #4b4f5c;
   transition: 0.3s;
   border-radius: 24px;
 }

 .slider:before {
   position: absolute;
   content: "";
   height: 18px;
   width: 18px;
   left: 3px;
   bottom: 3px;
   background-color: #ffffff;
   transition: 0.3s;
   border-radius: 50%;
 }

 input:checked+.slider {
   background-color: var(--age-cookie-accent);
 }

 input:checked+.slider:before {
   transform: translateX(20px);
 }


 
 
 .icon-button {
   border: none;
   background: transparent;
   color: var(--age-cookie-subtext);
   cursor: pointer;
   display: inline-flex;
   align-items: center;
   justify-content: center;
   padding: 4px;
 }

 .icon-button:hover {
   color: var(--age-cookie-text);
 }


 .cookie-settings-footer {
   display: flex;
   justify-content: flex-end;
   gap: 10px;
   margin-top: 14px;
 }


 @media (max-width: 640px) {
   .cookie-inner {
     flex-direction: column;
   }

   .cookie-actions {
     flex-direction: row;
     justify-content: flex-end;
   }

   .cookie-settings-modal {
     padding: 18px 16px 16px;
   }
 }