/* Big Bass Surge — hiddenwaters.info */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --ink:   #0d1f2d;
  --bg:    #e8f4f8;
  --tile:  #f0f9fc;
  --water: #1a6b8a;
  --gold:  #e8a020;
  --soft:  #2c4a5a;
}
html { font-family: Arial, Helvetica, sans-serif; font-size: 16px; background: var(--bg); color: var(--ink); }
body { min-height: 100vh; display: flex; flex-direction: column; }
a { color: inherit; text-decoration: none; }
h1, h2, h3 { font-weight: 950; line-height: 1.1; }
.label { display: inline-block; padding: 4px 12px; background: var(--gold); border: 2px solid var(--ink); font-size: 11px; font-weight: 950; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 12px; }
.topbar { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px; padding: 14px clamp(16px,4vw,54px); background: var(--ink); color: var(--bg); position: sticky; top: 0; z-index: 30; }
.brand { display: flex; align-items: center; gap: 10px; font-weight: 950; font-size: 18px; letter-spacing: 1px; }
.brand img { width: 32px; height: 32px; }
nav { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; }
nav a { padding: 6px 14px; font-weight: 850; font-size: 13px; border: 2px solid transparent; transition: border-color .15s; }
nav a:hover, nav a.active { border-color: var(--gold); color: var(--gold); }
.language { display: flex; gap: 6px; }
.language button { padding: 5px 10px; background: transparent; border: 2px solid var(--bg); color: var(--bg); font-weight: 850; font-size: 12px; cursor: pointer; transition: background .15s, color .15s; }
.language button:hover, .language button.active { background: var(--gold); border-color: var(--gold); color: var(--ink); }
.hero { display: grid; grid-template-columns: 1fr 1fr; min-height: 480px; }
.hero-copy { padding: clamp(32px,6vw,80px); display: flex; flex-direction: column; justify-content: center; gap: 18px; }
.hero-copy h1 { font-family: Georgia,"Times New Roman",serif; font-size: clamp(48px,7vw,96px); line-height: .92; }
.hero-copy p { font-size: 18px; font-weight: 780; color: var(--soft); max-width: 480px; line-height: 1.55; }
.actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 8px; }
.btn { display: inline-block; padding: 14px 28px; background: var(--gold); border: 3px solid var(--ink); box-shadow: 5px 5px 0 var(--ink); font-weight: 950; font-size: 15px; cursor: pointer; transition: box-shadow .12s, transform .12s; color: var(--ink); }
.btn:hover { box-shadow: 7px 7px 0 var(--ink); transform: translate(-2px,-2px); }
.btn.secondary { background: var(--tile); }
.btn:active { transform: translate(3px,3px); box-shadow: 2px 2px 0 var(--ink); }
.hero-map { position: relative; overflow: hidden; display: grid; place-items: center; background: linear-gradient(135deg, #1a6b8a40, #2a9bc028), var(--bg); }
.hero-map::before { content: ""; position: absolute; inset: auto -8% 20% -8%; height: 110px; background: var(--water); border-top: 3px solid var(--ink); border-bottom: 3px solid var(--ink); transform: rotate(-6deg); }
.hero-img { position: relative; z-index: 2; width: min(70%,500px); border: 5px solid var(--ink); box-shadow: 15px 15px 0 var(--ink); }
.hero-badge { position: absolute; z-index: 3; right: 8%; bottom: 16%; width: min(28%,180px); }
.play-section { display: grid; grid-template-columns: minmax(320px,1fr) 340px; gap: 28px; padding: clamp(22px,4vw,54px); background: linear-gradient(180deg,var(--tile),var(--bg)); }
.game-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 18px; margin-bottom: 14px; }
.game-head h2, .page-head h1 { font-family: Georgia,"Times New Roman",serif; font-size: clamp(36px,5vw,70px); line-height: .95; }
.scorebar { display: grid; grid-template-columns: repeat(4,minmax(78px,1fr)); gap: 8px; margin-bottom: 14px; }
.scorebar div, .board-panel, .info-block, .page-card, .contact-card { background: var(--tile); border: 3px solid var(--ink); }
.scorebar div { padding: 10px; }
.scorebar span { display: block; color: var(--soft); font-size: 11px; font-weight: 950; text-transform: uppercase; }
.scorebar strong { display: block; font-size: 28px; line-height: 1; }
.board-panel { padding: clamp(10px,2vw,20px); }
.game-canvas { display: block; max-width: 100%; border: 3px solid var(--ink); }
.side { display: grid; align-content: start; gap: 14px; }
.info-block { padding: 18px; }
.info-block h3, .page-card h2, .contact-card h2 { margin-bottom: 8px; font-family: Georgia,"Times New Roman",serif; font-size: 28px; line-height: 1; }
.info-block p, .info-block li, .page-card p, .contact-card p { color: var(--soft); font-weight: 780; line-height: 1.55; }
.info-block ul { margin: 0; padding-left: 20px; }
.status { min-height: 48px; padding: 12px; background: var(--ink); color: var(--bg); font-weight: 900; }
.page { padding: clamp(24px,6vw,78px); }
.page-head { max-width: 980px; margin-bottom: 24px; }
.page-head p { margin-top: 14px; }
.page-grid, .contact-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 18px; }
.page-card, .contact-card { padding: 24px; }
.page-card.wide { grid-column: 1 / -1; }
.footer { padding: 24px clamp(20px,4vw,54px); color: var(--bg); background: var(--ink); font-weight: 850; }
.hidden { display: none !important; }
@media (max-width: 980px) {
  .topbar { grid-template-columns: 1fr auto; }
  .brand { grid-column: 1; }
  .topbar nav { grid-column: 1 / -1; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; }
  .language { grid-column: 2; grid-row: 1; }
  .hero, .play-section { grid-template-columns: 1fr; }
  .side { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 640px) {
  .topbar { grid-template-columns: auto 1fr; padding: 10px 12px; gap: 10px; }
  .language { position: fixed; top: 10px; left: 72px; z-index: 40; }
  .brand span { display: none; }
  h1 { font-size: 48px; }
  .hero-copy, .page { padding: 24px 16px; }
  .hero-map { min-height: 320px; }
  .scorebar, .side, .page-grid, .contact-grid { grid-template-columns: 1fr; }
}
.cookie-popup { position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999; transform: translateY(110%); transition: transform .38s cubic-bezier(.22,.61,.36,1); pointer-events: none; }
.cookie-popup.visible { transform: translateY(0); pointer-events: auto; }
.cookie-inner { max-width: 900px; margin: 0 auto; background: var(--tile); border-top: 4px solid var(--ink); padding: 18px clamp(16px,4vw,48px) 22px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; box-shadow: 0 -6px 24px rgba(0,0,0,.18); }
.cookie-text { flex: 1; min-width: 220px; font-size: 14px; font-weight: 800; color: var(--soft); line-height: 1.5; }
.cookie-text a { color: var(--ink); font-weight: 950; }
.cookie-btns { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-btn-accept { padding: 12px 22px; background: var(--gold); border: 3px solid var(--ink); box-shadow: 4px 4px 0 var(--ink); font-weight: 950; font-size: 14px; cursor: pointer; color: var(--ink); }
.cookie-btn-decline { padding: 12px 22px; background: var(--tile); border: 3px solid var(--ink); box-shadow: 4px 4px 0 var(--ink); font-weight: 950; font-size: 14px; cursor: pointer; color: var(--ink); }
.cookie-btn-accept:active, .cookie-btn-decline:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }
@media (max-width: 640px) {
  .cookie-inner { flex-direction: column; align-items: flex-start; gap: 12px; }
  .cookie-btns { width: 100%; }
  .cookie-btn-accept, .cookie-btn-decline { flex: 1; text-align: center; }
}
