:root {
  --lw-prm: #4CC9F0;
  --lw-sec: #3A86FF;
  --lw-acc: #80FFDB;
  --lw-bg: #08101A;
  --lw-surf: #152231;
  --lw-txt: #EDF8FF;
  --lw-txt-mut: #A9C0D4;
  --lw-font-head: 'Playfair Display', serif;
  --lw-font-body: 'Inter', sans-serif;
  --lw-rad-sm: 4px;
  --lw-rad-md: 8px;
  --lw-rad-lg: 16px;
  --lw-trans: 0.3s ease;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body.lottowiner_body {
  font-family: var(--lw-font-body);
  background-color: var(--lw-bg);
  color: var(--lw-txt);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  padding-bottom: 60px;
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--lw-font-head);
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 0.5em;
}
a { color: var(--lw-prm); text-decoration: none; transition: color var(--lw-trans); }
a:hover { color: var(--lw-acc); }
img { max-width: 100%; height: auto; display: block; }

.lottowiner_container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.lottowiner_container-sm { max-width: 800px; }
.lottowiner_text-center { text-align: center; }
.lottowiner_mt-2 { margin-top: 1rem; }
.lottowiner_mt-4 { margin-top: 2rem; }

.lottowiner_btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 12px 24px; font-family: var(--lw-font-body); font-weight: 600;
  border-radius: var(--lw-rad-sm); border: none; cursor: pointer;
  transition: all var(--lw-trans); text-align: center;
}
.lottowiner_btn-primary {
  background: linear-gradient(135deg, var(--lw-prm), var(--lw-sec));
  color: #fff;
}
.lottowiner_btn-primary:hover { transform: translateY(-2px); box-shadow: 0 4px 15px rgba(76, 201, 240, 0.4); }
.lottowiner_btn-outline {
  background: transparent; border: 2px solid var(--lw-prm); color: var(--lw-prm);
}
.lottowiner_btn-outline:hover { background: rgba(76, 201, 240, 0.1); }
.lottowiner_btn-text { background: none; color: var(--lw-txt-mut); text-decoration: underline; padding: 0; }
.lottowiner_btn-text:hover { color: var(--lw-txt); }
.lottowiner_btn-block { width: 100%; }

.lottowiner_header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(21, 34, 49, 0.95); backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.lottowiner_header-inner {
  display: flex; justify-content: space-between; align-items: center; height: 70px;
}
.lottowiner_logo-link {
  font-family: var(--lw-font-head); font-size: 1.5rem; color: #fff; letter-spacing: 1px;
}
.lottowiner_nav-list {
  display: flex; gap: 30px; list-style: none;
}
.lottowiner_nav-link { color: var(--lw-txt-mut); font-weight: 600; }
.lottowiner_nav-link:hover, .lottowiner_nav-link[aria-current="page"] { color: var(--lw-prm); }
.lottowiner_header-actions { display: flex; align-items: center; gap: 15px; }
.lottowiner_age-badge {
  width: 32px; height: 32px; border: 2px solid var(--lw-txt-mut); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.8rem; font-weight: 700; color: var(--lw-txt-mut);
}
.lottowiner_burger { display: none; background: none; border: none; cursor: pointer; flex-direction: column; gap: 5px; }
.lottowiner_burger-line { width: 25px; height: 3px; background: #fff; transition: var(--lw-trans); }

@media (max-width: 768px) {
  .lottowiner_nav {
    position: absolute; top: 70px; left: 0; right: 0;
    background: var(--lw-surf); padding: 20px; border-bottom: 1px solid rgba(255,255,255,0.1);
    display: none; flex-direction: column;
  }
  .lottowiner_nav.is-open { display: flex; }
  .lottowiner_nav-list { flex-direction: column; gap: 15px; }
  .lottowiner_header-actions .lottowiner_btn { display: none; }
  .lottowiner_burger { display: flex; }
}

.lottowiner_hero {
  padding: 60px 0; min-height: 80vh; display: flex; align-items: center;
  background: radial-gradient(circle at right, rgba(58, 134, 255, 0.15) 0%, var(--lw-bg) 60%);
}
.lottowiner_hero-inner { display: flex; gap: 40px; align-items: center; }
.lottowiner_hero-content { flex: 1; }
.lottowiner_hero-tagline { color: var(--lw-acc); font-weight: 600; text-transform: uppercase; letter-spacing: 2px; display: block; margin-bottom: 10px; }
.lottowiner_hero-title { font-size: 3.5rem; margin-bottom: 20px; }
.lottowiner_hero-desc { font-size: 1.2rem; color: var(--lw-txt-mut); margin-bottom: 30px; max-width: 500px; }
.lottowiner_hero-ctas { display: flex; gap: 15px; margin-bottom: 40px; }
.lottowiner_hero-proof { display: flex; gap: 20px; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 20px; }
.lottowiner_proof-card { display: flex; flex-direction: column; }
.lottowiner_proof-val { font-size: 1.5rem; font-weight: 700; color: var(--lw-prm); }
.lottowiner_proof-label { font-size: 0.9rem; color: var(--lw-txt-mut); }
.lottowiner_hero-visual { flex: 1; }
.lottowiner_hero-media-wrapper { border-radius: var(--lw-rad-lg); overflow: hidden; border: 1px solid rgba(76, 201, 240, 0.2); box-shadow: 0 20px 40px rgba(0,0,0,0.5); }

@media (max-width: 992px) {
  .lottowiner_hero-inner { flex-direction: column; text-align: center; }
  .lottowiner_hero-desc { margin: 0 auto 30px; }
  .lottowiner_hero-ctas { justify-content: center; }
  .lottowiner_hero-proof { justify-content: center; }
  .lottowiner_hero-title { font-size: 2.5rem; }
}

.lottowiner_home-block { padding: 80px 0; }
.lottowiner_home-block:nth-child(even) { background-color: rgba(21, 34, 49, 0.5); }
.lottowiner_section-header { text-align: center; margin-bottom: 50px; }
.lottowiner_section-title { font-size: 2.5rem; }
.lottowiner_section-subtitle { color: var(--lw-txt-mut); font-size: 1.1rem; }

.lottowiner_grid { display: grid; gap: 30px; }
.lottowiner_grid-3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

.lottowiner_card { background: var(--lw-surf); padding: 30px; border-radius: var(--lw-rad-md); border: 1px solid rgba(255,255,255,0.05); }
.lottowiner_card-title { color: var(--lw-prm); margin-bottom: 15px; }

.lottowiner_split { display: flex; gap: 50px; align-items: center; }
.lottowiner_split-reverse { flex-direction: row-reverse; }
.lottowiner_split-text, .lottowiner_split-visual { flex: 1; }
.lottowiner_text-lead { font-size: 1.2rem; color: var(--lw-txt-mut); margin-bottom: 20px; }

@media (max-width: 768px) {
  .lottowiner_split, .lottowiner_split-reverse { flex-direction: column; }
}

.lottowiner_myth-list { margin-top: 20px; }
.lottowiner_myth-term { font-weight: 600; color: #fff; margin-bottom: 5px; padding-left: 20px; position: relative; }
.lottowiner_myth-term::before { content: '×'; position: absolute; left: 0; color: #ff4b4b; }
.lottowiner_myth-desc { color: var(--lw-txt-mut); margin-bottom: 20px; padding-left: 20px; position: relative; }
.lottowiner_myth-desc::before { content: '✓'; position: absolute; left: 0; color: var(--lw-acc); }
.lottowiner_myth-panel { height: 300px; background: linear-gradient(45deg, var(--lw-surf), rgba(76, 201, 240, 0.1)); border-radius: var(--lw-rad-lg); border: 1px solid rgba(76,201,240,0.3); }

.lottowiner_list { list-style: none; margin: 20px 0; }
.lottowiner_list-check li { padding-left: 30px; position: relative; margin-bottom: 10px; }
.lottowiner_list-check li::before { content: ''; position: absolute; left: 0; top: 5px; width: 8px; height: 14px; border: solid var(--lw-acc); border-width: 0 2px 2px 0; transform: rotate(45deg); }

.lottowiner_feature-card { background: var(--lw-surf); padding: 40px; border-radius: var(--lw-rad-lg); text-align: center; border: 1px solid rgba(128, 255, 219, 0.2); }
.lottowiner_thermal-bar { height: 20px; background: rgba(0,0,0,0.5); border-radius: 10px; overflow: hidden; margin-bottom: 15px; }
.lottowiner_thermal-fill { height: 100%; background: linear-gradient(90deg, var(--lw-prm), #ff7b00); transition: width 0.5s; }
.lottowiner_thermal-label { font-family: var(--lw-font-head); color: #ff7b00; }

.lottowiner_live-game-wrapper { max-width: 800px; margin: 0 auto; background: var(--lw-surf); border-radius: var(--lw-rad-lg); padding: 30px; border: 1px solid rgba(76, 201, 240, 0.3); }
.lottowiner_game-board-area { position: relative; width: 300px; height: 300px; margin: 0 auto 30px; }
.lottowiner_wheel-img { width: 100%; height: 100%; object-fit: contain; transition: transform 2.5s cubic-bezier(0.25, 0.1, 0.25, 1); }
.lottowiner_wheel-pointer { position: absolute; top: -10px; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-left: 15px solid transparent; border-right: 15px solid transparent; border-top: 25px solid #fff; z-index: 2; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.5)); }
.lottowiner_game-controls { display: flex; justify-content: center; gap: 20px; align-items: flex-end; margin-bottom: 20px; }
.lottowiner_select { background: rgba(0,0,0,0.5); color: #fff; border: 1px solid rgba(255,255,255,0.2); padding: 10px; border-radius: var(--lw-rad-sm); outline: none; }
.lottowiner_game-status { background: rgba(0,0,0,0.3); padding: 15px; border-radius: var(--lw-rad-sm); display: flex; justify-content: space-between; font-family: monospace; font-size: 1.1rem; }
.lottowiner_status-message { color: var(--lw-acc); }
@media (max-width: 600px) {
  .lottowiner_game-status { flex-direction: column; gap: 10px; align-items: center; }
  .lottowiner_game-board-area { width: 250px; height: 250px; }
}

.lottowiner_lore-banner { position: relative; border-radius: var(--lw-rad-lg); overflow: hidden; min-height: 400px; display: flex; align-items: center; }
.lottowiner_lore-bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.lottowiner_lore-img { width: 100%; height: 100%; object-fit: cover; opacity: 0.4; }
.lottowiner_lore-content { position: relative; z-index: 2; padding: 40px; max-width: 600px; background: linear-gradient(90deg, rgba(8, 16, 26, 0.9), transparent); height: 100%; display: flex; flex-direction: column; justify-content: center; }
.lottowiner_lore-title { font-size: 2.5rem; color: var(--lw-prm); }
.lottowiner_lore-text { margin-bottom: 20px; font-size: 1.1rem; }

.lottowiner_accordion-item { border-bottom: 1px solid rgba(255,255,255,0.1); }
.lottowiner_accordion-trigger { width: 100%; text-align: left; background: none; border: none; padding: 20px 0; color: #fff; font-size: 1.2rem; font-family: var(--lw-font-head); cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
.lottowiner_accordion-trigger::after { content: '+'; color: var(--lw-prm); font-size: 1.5rem; transition: transform 0.3s; }
.lottowiner_accordion-trigger[aria-expanded="true"]::after { transform: rotate(45deg); }
.lottowiner_accordion-panel { max-height: 0; overflow: hidden; transition: max-height 0.3s ease-out; }
.lottowiner_accordion-content { padding-bottom: 20px; color: var(--lw-txt-mut); }

.lottowiner_lobby-main { padding-top: 40px; }
.lottowiner_page-title { font-size: 3rem; text-align: center; margin-bottom: 10px; }
.lottowiner_page-subtitle { text-align: center; color: var(--lw-txt-mut); margin-bottom: 50px; font-size: 1.2rem; }
.lottowiner_stack-layout { display: flex; flex-direction: column; gap: 40px; }
.lottowiner_game-card { background: var(--lw-surf); border-radius: var(--lw-rad-lg); border: 1px solid rgba(255,255,255,0.05); overflow: hidden; }
.lottowiner_game-card-header { padding: 20px 30px; border-bottom: 1px solid rgba(255,255,255,0.05); display: flex; justify-content: space-between; align-items: center; background: rgba(0,0,0,0.2); }
.lottowiner_game-title { margin: 0; color: var(--lw-prm); }
.lottowiner_game-badge { background: rgba(128, 255, 219, 0.1); color: var(--lw-acc); padding: 4px 12px; border-radius: 20px; font-size: 0.9rem; }
.lottowiner_game-card-body { padding: 40px; display: flex; justify-content: center; background: radial-gradient(circle, rgba(76, 201, 240, 0.05) 0%, transparent 70%); }

.lottowiner_slot-board { display: flex; gap: 10px; position: relative; background: rgba(0,0,0,0.5); padding: 15px; border-radius: var(--lw-rad-md); border: 2px solid #2a3b4c; }
.lottowiner_slot-payline { position: absolute; top: 50%; left: 0; right: 0; height: 4px; background: rgba(128, 255, 219, 0.6); transform: translateY(-50%); z-index: 10; box-shadow: 0 0 10px var(--lw-acc); pointer-events: none; }
.lottowiner_reel { width: 100px; height: 300px; display: flex; flex-direction: column; overflow: hidden; background: #0c1622; border-radius: 4px; }
.lottowiner_sym { width: 100px; height: 100px; object-fit: contain; padding: 10px; }
.is-spinning .lottowiner_reel { animation: blurReel 0.1s infinite alternate; }
@keyframes blurReel { 0% { filter: blur(0px); transform: translateY(0); } 100% { filter: blur(4px); transform: translateY(-10px); } }

.lottowiner_wheel-board { position: relative; width: 350px; height: 350px; }
@media (max-width: 500px) {
  .lottowiner_wheel-board { width: 260px; height: 260px; }
  .lottowiner_reel { width: 80px; height: 240px; }
  .lottowiner_sym { width: 80px; height: 80px; }
}

.lottowiner_game-card-footer { padding: 30px; border-top: 1px solid rgba(255,255,255,0.05); display: flex; justify-content: space-between; align-items: center; background: rgba(0,0,0,0.2); }
@media (max-width: 768px) {
  .lottowiner_game-card-footer { flex-direction: column; gap: 20px; }
}
.lottowiner_game-status-panel { text-align: right; font-family: monospace; }
@media (max-width: 768px) { .lottowiner_game-status-panel { text-align: center; } }

.lottowiner_mission-block { background: linear-gradient(0deg, var(--lw-surf), transparent); padding: 40px 0 80px; text-align: center; }
.lottowiner_mission-tracker { max-width: 600px; margin: 0 auto; background: rgba(0,0,0,0.4); padding: 30px; border-radius: var(--lw-rad-lg); border: 1px solid rgba(128, 255, 219, 0.3); }
.lottowiner_mission-title { color: var(--lw-acc); }
.lottowiner_mission-progress { display: flex; align-items: center; gap: 15px; margin-top: 20px; }
.lottowiner_mission-bar { flex: 1; height: 10px; background: #000; border-radius: 5px; overflow: hidden; }
.lottowiner_mission-fill { height: 100%; background: var(--lw-acc); transition: width 0.3s; }

.lottowiner_bottom-status-bar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 90;
  background: rgba(8, 16, 26, 0.95); border-top: 2px solid var(--lw-prm);
  padding: 10px 0; backdrop-filter: blur(5px);
}
.lottowiner_status-bar-inner { display: flex; justify-content: space-between; align-items: center; }
.lottowiner_status-brand { font-family: var(--lw-font-head); color: var(--lw-txt-mut); font-size: 0.9rem; }
.lottowiner_status-wallet { font-weight: 700; font-size: 1.2rem; color: #fff; display: flex; gap: 8px; align-items: center; }
.lottowiner_wallet-val { color: var(--lw-acc); }

.lottowiner_page-main { padding: 60px 0; }
.lottowiner_article-header { text-align: center; margin-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 30px; }
.lottowiner_longform h2 { color: var(--lw-prm); margin-top: 40px; }
.lottowiner_longform p { margin-bottom: 20px; color: var(--lw-txt-mut); }
.lottowiner_content-img { border-radius: var(--lw-rad-md); margin: 30px 0 10px; }
.lottowiner_img-caption { display: block; text-align: center; color: var(--lw-txt-mut); font-size: 0.9rem; font-style: italic; }

.lottowiner_table-wrapper { overflow-x: auto; margin: 30px 0; }
.lottowiner_table { width: 100%; border-collapse: collapse; text-align: left; }
.lottowiner_table th, .lottowiner_table td { padding: 15px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.lottowiner_table th { background: rgba(255,255,255,0.05); color: var(--lw-prm); }

.lottowiner_callout { padding: 20px; border-left: 4px solid var(--lw-acc); background: rgba(128, 255, 219, 0.05); margin: 30px 0; }
.lottowiner_callout-warning { border-color: #ff4b4b; background: rgba(255, 75, 75, 0.05); }

.lottowiner_questionnaire { background: var(--lw-surf); padding: 30px; border-radius: var(--lw-rad-md); margin: 30px 0; }
.lottowiner_list-bullet { padding-left: 20px; margin-bottom: 20px; }
.lottowiner_list-bullet li { margin-bottom: 10px; color: var(--lw-txt-mut); }
.lottowiner_help-links { display: flex; gap: 15px; margin-top: 20px; flex-wrap: wrap; }

.lottowiner_contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-top: 40px; }
@media (max-width: 768px) { .lottowiner_contact-layout { grid-template-columns: 1fr; } }
.lottowiner_form-group { margin-bottom: 20px; }
.lottowiner_label { display: block; margin-bottom: 8px; color: var(--lw-txt-mut); }
.lottowiner_input { width: 100%; padding: 12px; background: rgba(0,0,0,0.5); border: 1px solid rgba(255,255,255,0.2); border-radius: var(--lw-rad-sm); color: #fff; font-family: var(--lw-font-body); }
.lottowiner_input:focus { outline: none; border-color: var(--lw-prm); }
.lottowiner_textarea { resize: vertical; }

.lottowiner_footer { background: #050a10; padding: 60px 0 80px; border-top: 1px solid rgba(255,255,255,0.05); font-size: 0.9rem; }
.lottowiner_footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
@media (max-width: 768px) { .lottowiner_footer-top { grid-template-columns: 1fr; } }
.lottowiner_logo-footer { font-family: var(--lw-font-head); font-size: 1.5rem; margin-bottom: 15px; color: #fff; }
.lottowiner_footer-nrm { color: var(--lw-txt-mut); margin-bottom: 20px; }
.lottowiner_footer-title { color: var(--lw-prm); margin-bottom: 15px; }
.lottowiner_footer-links { list-style: none; }
.lottowiner_footer-links li { margin-bottom: 10px; }
.lottowiner_footer-contact p { color: var(--lw-txt-mut); margin-bottom: 5px; }
.lottowiner_footer-rg { text-align: center; padding: 30px; border-top: 1px solid rgba(255,255,255,0.05); border-bottom: 1px solid rgba(255,255,255,0.05); margin-bottom: 30px; }
.lottowiner_footer-rg-text { color: var(--lw-txt-mut); margin: 10px 0; }
.lottowiner_footer-partners { display: flex; justify-content: center; gap: 20px; margin-top: 20px; flex-wrap: wrap; }
.lottowiner_partner-link { display: inline-flex; align-items: center; justify-content: center; padding: 10px; border-radius: var(--lw-rad-sm); }
.lottowiner_partner-gamcare { background: #fff; }
.lottowiner_partner-gamcare img { height: 30px; }
.lottowiner_partner-begambleaware { background: #000; border: 1px solid rgba(255,255,255,0.2); }
.lottowiner_partner-begambleaware img { height: 30px; }
.lottowiner_footer-bottom { text-align: center; color: rgba(255,255,255,0.3); }

.lottowiner_modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 1000; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: all 0.3s; }
.lottowiner_modal:not([aria-hidden="true"]) { opacity: 1; visibility: visible; }
.lottowiner_modal-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.8); backdrop-filter: blur(5px); }
.lottowiner_modal-content { position: relative; background: var(--lw-surf); width: 100%; max-width: 400px; padding: 40px; border-radius: var(--lw-rad-md); border: 1px solid rgba(76, 201, 240, 0.3); z-index: 1001; transform: translateY(20px); transition: transform 0.3s; }
.lottowiner_modal:not([aria-hidden="true"]) .lottowiner_modal-content { transform: translateY(0); }
.lottowiner_modal-close { position: absolute; top: 15px; right: 15px; background: none; border: none; color: #fff; font-size: 1.5rem; cursor: pointer; }
.lottowiner_modal-title { margin-bottom: 10px; color: var(--lw-prm); }
.lottowiner_modal-desc { color: var(--lw-txt-mut); margin-bottom: 20px; }
.lottowiner_modal-text p { margin-bottom: 15px; color: var(--lw-txt-mut); }

.lottowiner_toast { position: fixed; top: 20px; right: 20px; background: var(--lw-surf); border-left: 4px solid var(--lw-acc); padding: 15px 20px; border-radius: var(--lw-rad-sm); box-shadow: 0 10px 30px rgba(0,0,0,0.5); z-index: 2000; transform: translateX(120%); transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
.lottowiner_toast.show { transform: translateX(0); }

/* footer-logo-contrast-guard */
a[href*="begambleaware.org"] img,
a[href*="begambleaware.org"] picture,
a[href*="begambleaware.org"] .partner-logo,
img[src*="gambleaware"],
img[alt*="BeGambleAware" i],
img[alt*="GambleAware" i] {
  background: #111111 !important;
  padding: 0.45rem 0.7rem !important;
  border-radius: 0.7rem !important;
  box-sizing: border-box !important;
}

a[href*="gamcare.org"] img,
a[href*="gamcare.org"] picture,
a[href*="gamcare.org"] .partner-logo,
img[src*="gamcare"],
img[alt*="GamCare" i] {
  background: #ffffff !important;
  padding: 0.45rem 0.7rem !important;
  border-radius: 0.7rem !important;
  box-sizing: border-box !important;
}

a[href*="begambleaware.org"],
a[href*="gamcare.org"] {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
