:root {
  --slotivo7-bg-dark: #1a1008;
  --slotivo7-bg-mid: #2a1a0e;
  --slotivo7-card: #2d1e12;
  --slotivo7-gold: #ffd700;
  --slotivo7-gold-deep: #ffcc00;
  --slotivo7-amber: #f59e0b;
  --slotivo7-leather: #8b4513;
  --slotivo7-text: #fdf0d5;
  --slotivo7-muted: #e8cfaa;
  --slotivo7-shadow: 0 12px 34px rgba(0, 0, 0, 0.35);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: linear-gradient(140deg, var(--slotivo7-bg-dark), var(--slotivo7-bg-mid));
  color: var(--slotivo7-text);
  font-family: "Nunito Sans", sans-serif;
  line-height: 1.6;
}

a {
  color: var(--slotivo7-gold);
  text-decoration: none;
}

a:hover {
  color: var(--slotivo7-gold-deep);
}

.slotivo7-container {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

.slotivo7-cookie-banner {
  position: sticky;
  top: 0;
  z-index: 1200;
  display: none;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: #3f240f;
  border-bottom: 1px solid rgba(255, 215, 0, 0.45);
}

.slotivo7-cookie-banner p {
  margin: 0;
  font-size: 0.92rem;
}

.slotivo7-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: linear-gradient(90deg, #593417 0%, var(--slotivo7-leather) 100%);
  border-bottom: 1px solid rgba(255, 204, 0, 0.5);
}

.slotivo7-header-row {
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.slotivo7-brand img {
  display: block;
}

.slotivo7-nav {
  display: flex;
  align-items: center;
  gap: 14px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.slotivo7-nav a {
  color: #ffe8ab;
  font-weight: 700;
  font-size: 0.95rem;
}

.slotivo7-nav a:hover {
  color: var(--slotivo7-amber);
}

.slotivo7-burger {
  display: none;
  background: transparent;
  border: 0;
  padding: 5px;
  cursor: pointer;
}

.slotivo7-burger span {
  display: block;
  width: 24px;
  height: 3px;
  margin: 4px 0;
  background: var(--slotivo7-gold);
}

.slotivo7-hero {
  position: relative;
  overflow: hidden;
  padding: 96px 0 22px;
  background:
    radial-gradient(circle at 15% 20%, rgba(245, 158, 11, 0.22), transparent 45%),
    radial-gradient(circle at 80% 35%, rgba(255, 215, 0, 0.14), transparent 40%),
    linear-gradient(160deg, rgba(18, 10, 6, 0.9), rgba(49, 30, 12, 0.82));
}

.slotivo7-kicker {
  margin: 0 0 8px;
  color: var(--slotivo7-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.78rem;
}

h1, h2, h3 {
  margin-top: 0;
  font-family: "Lora", serif;
}

h1 {
  max-width: 740px;
  margin-bottom: 10px;
  font-size: clamp(1.95rem, 4.2vw, 3rem);
  line-height: 1.2;
}

.slotivo7-lead {
  max-width: 760px;
  color: #f6dfbc;
  margin-bottom: 20px;
}

.slotivo7-chest-wrap {
  margin: 26px 0 24px;
}

.slotivo7-chest {
  position: relative;
  width: min(280px, 76vw);
  height: 170px;
  border-radius: 18px;
  background: linear-gradient(180deg, #693819, #3d220e);
  border: 3px solid #b7792f;
  box-shadow: var(--slotivo7-shadow);
}

.slotivo7-chest::before {
  content: "";
  position: absolute;
  top: -58px;
  left: 8px;
  width: calc(100% - 16px);
  height: 84px;
  border-radius: 88px 88px 24px 24px;
  background: linear-gradient(180deg, #8d4d20, #51270f);
  border: 3px solid #b7792f;
  transform: rotate(-9deg);
  transform-origin: bottom left;
}

.slotivo7-coin {
  position: absolute;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 30%, #fff1aa 0%, var(--slotivo7-gold) 58%, #d88a00 100%);
  border: 1px solid rgba(102, 62, 0, 0.45);
}

.slotivo7-coin-a { top: -22px; left: 56px; animation: slotivo7Drop 2.7s infinite; }
.slotivo7-coin-b { top: -10px; left: 104px; animation: slotivo7Drop 2.2s infinite 0.45s; }
.slotivo7-coin-c { top: -18px; left: 148px; animation: slotivo7Drop 2.5s infinite 0.22s; }
.slotivo7-coin-d { top: -14px; left: 192px; animation: slotivo7Drop 2.9s infinite 0.72s; }

@keyframes slotivo7Drop {
  0% { transform: translateY(0) rotate(0deg); opacity: 0.95; }
  60% { transform: translateY(44px) rotate(180deg); opacity: 1; }
  100% { transform: translateY(66px) rotate(360deg); opacity: 0; }
}

.slotivo7-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 20px;
  border-radius: 999px;
  border: 1px solid rgba(255, 207, 90, 0.65);
  background: linear-gradient(120deg, var(--slotivo7-gold), #ffc02f);
  color: #2b1607;
  font-weight: 800;
  cursor: pointer;
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.slotivo7-btn:hover {
  transform: translateY(-1px) rotateY(10deg);
  box-shadow: 0 8px 20px rgba(255, 206, 76, 0.25);
  color: #1f1207;
}

.slotivo7-btn-small {
  padding: 8px 14px;
}

.slotivo7-btn-outline {
  background: transparent;
  color: var(--slotivo7-text);
}

.slotivo7-marquee-shell {
  margin-top: 20px;
  border-top: 1px solid rgba(255, 212, 119, 0.3);
  border-bottom: 1px solid rgba(255, 212, 119, 0.3);
  background: rgba(28, 14, 6, 0.62);
}

.slotivo7-marquee {
  overflow: hidden;
  white-space: nowrap;
}

.slotivo7-marquee-track {
  display: inline-flex;
  gap: 18px;
  padding: 8px 0;
  min-width: 100%;
  animation: slotivo7Ticker 28s linear infinite;
}

.slotivo7-marquee-reverse .slotivo7-marquee-track {
  animation-direction: reverse;
  animation-duration: 33s;
}

@keyframes slotivo7Ticker {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.slotivo7-section {
  padding: 62px 0;
}

.slotivo7-alt {
  background: rgba(33, 18, 8, 0.55);
}

.slotivo7-casino-card {
  margin-bottom: 24px;
  border-radius: 18px;
  overflow: visible;
  background: var(--slotivo7-card);
  border: 1px solid rgba(255, 201, 99, 0.35);
  box-shadow: var(--slotivo7-shadow);
}

.slotivo7-card-banner {
  height: 136px;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  padding: 14px;
}

.slotivo7-banner-888 {
  background: linear-gradient(90deg, #3f230f, #8b4513, #f59e0b);
}

.slotivo7-banner-unibet {
  background: linear-gradient(90deg, #1f2e17, #2f6a28, #8bbf38);
}

.slotivo7-banner-betsson {
  background: linear-gradient(90deg, #1f253a, #203d69, #447cbf);
}

.slotivo7-badge {
  display: inline-block;
  background: rgba(23, 13, 5, 0.8);
  border: 1px solid rgba(255, 214, 112, 0.5);
  color: #ffdf90;
  border-radius: 999px;
  font-size: 0.8rem;
  padding: 6px 11px;
}

.slotivo7-card {
  display: grid;
  grid-template-columns: 145px minmax(0, 1fr) 220px;
  gap: 22px;
  align-items: center;
  padding: 0 18px 18px;
}

.slotivo7-logo-wrap {
  width: 80px;
  height: 80px;
  margin-top: -40px;
  border-radius: 50%;
  background: linear-gradient(140deg, #fff6dc, #e6c99d);
  border: 3px solid rgba(255, 215, 0, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
}

.slotivo7-logo-wrap img {
  max-width: 64px;
  max-height: 64px;
}

.slotivo7-main-col h3 {
  margin-bottom: 4px;
}

.slotivo7-rating {
  margin: 0 0 8px;
}

.slotivo7-bonus {
  margin: 0 0 10px;
  font-weight: 700;
  color: #ffdfab;
}

.slotivo7-pills {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.slotivo7-pills li {
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 212, 107, 0.45);
  background: rgba(95, 52, 22, 0.45);
  font-size: 0.84rem;
}

.slotivo7-cta-col {
  width: 220px;
}

.slotivo7-cta-col .slotivo7-btn {
  width: 100%;
}

.slotivo7-disclaimer {
  margin: 10px 0 0;
  font-size: 0.77rem;
  color: #e3bf8d;
}

.slotivo7-calculator {
  max-width: 560px;
  padding: 18px;
  border-radius: 14px;
  border: 1px solid rgba(255, 206, 94, 0.4);
  background: rgba(59, 31, 13, 0.75);
}

.slotivo7-calculator label {
  display: block;
  margin-bottom: 8px;
  font-weight: 700;
}

.slotivo7-calculator input {
  width: 100%;
  margin-bottom: 12px;
  padding: 10px;
  border-radius: 10px;
  border: 1px solid rgba(255, 214, 111, 0.4);
  background: #2a180d;
  color: var(--slotivo7-text);
}

.slotivo7-calc-result {
  margin-top: 14px;
  border-top: 1px dashed rgba(255, 203, 95, 0.5);
  padding-top: 10px;
}

.slotivo7-calc-result p {
  margin: 6px 0;
}

blockquote {
  margin: 0 0 16px;
  padding: 12px 16px;
  border-left: 4px solid var(--slotivo7-gold);
  background: rgba(47, 23, 8, 0.72);
  font-style: italic;
}

.slotivo7-readtime {
  margin-bottom: 8px;
  color: #f3c970;
  font-size: 0.9rem;
}

.slotivo7-rg {
  background: linear-gradient(180deg, rgba(35, 16, 7, 0.85), rgba(24, 10, 5, 0.88));
}

.slotivo7-rg-links {
  list-style: none;
  margin: 0;
  padding: 0;
}

.slotivo7-rg-links li {
  margin-bottom: 8px;
}

.slotivo7-criteria-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.slotivo7-criteria-grid article {
  border: 1px solid rgba(255, 209, 97, 0.35);
  border-radius: 12px;
  padding: 14px;
  background: rgba(54, 29, 11, 0.65);
}

.slotivo7-faq-list {
  display: grid;
  gap: 10px;
}

.slotivo7-faq-item {
  border: 1px solid rgba(255, 207, 100, 0.34);
  border-radius: 12px;
  background: rgba(48, 24, 10, 0.7);
}

.slotivo7-faq-question {
  width: 100%;
  text-align: left;
  background: transparent;
  border: 0;
  color: var(--slotivo7-text);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  padding: 14px;
}

.slotivo7-faq-answer {
  display: none;
  padding: 0 14px 14px;
  color: #f3d6ab;
}

.slotivo7-faq-item.is-open .slotivo7-faq-answer {
  display: block;
}

.slotivo7-footer {
  border-top: 1px solid rgba(255, 201, 91, 0.4);
  background: rgba(25, 12, 6, 0.95);
  padding: 14px 0;
}

.slotivo7-footer-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 18px;
}

.slotivo7-footer-row nav,
.slotivo7-footer-rg {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
}

.slotivo7-footer-row p {
  margin: 0;
  color: #e9c48d;
  font-size: 0.9rem;
}

.slotivo7-age-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 1300;
  background: rgba(0, 0, 0, 0.75);
}

.slotivo7-age-modal.is-open {
  display: flex;
}

.slotivo7-age-dialog {
  width: min(440px, calc(100% - 24px));
  border-radius: 14px;
  border: 1px solid rgba(255, 206, 91, 0.5);
  background: #311c0d;
  padding: 22px;
}

.slotivo7-age-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

@media (max-width: 980px) {
  .slotivo7-card {
    grid-template-columns: 110px minmax(0, 1fr);
  }

  .slotivo7-cta-col {
    width: 100%;
    grid-column: 1 / -1;
    padding-top: 6px;
  }
}

@media (max-width: 860px) {
  .slotivo7-burger {
    display: block;
  }

  .slotivo7-nav-backdrop {
    position: fixed;
    inset: 70px 0 0 0;
    display: none;
    background: rgba(0, 0, 0, 0.5);
  }

  .slotivo7-nav-backdrop.is-open {
    display: block;
  }

  .slotivo7-nav {
    max-width: min(340px, 90vw);
    height: 100%;
    margin-left: auto;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 18px;
    background: #4f2d14;
    border-left: 1px solid rgba(255, 206, 91, 0.45);
  }
}

@media (max-width: 700px) {
  .slotivo7-criteria-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .slotivo7-card {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .slotivo7-logo-wrap {
    margin-top: -32px;
  }
}

@media (max-width: 380px) {
  * { max-width: 100%; box-sizing: border-box; }
  .slotivo7-nav { max-width: min(320px, 85vw) !important; }
  .slotivo7-nav-backdrop { max-width: unset !important; width: 100vw !important; }
  img, svg { max-width: 100% !important; height: auto !important; }
  table { display: block; overflow-x: auto; }
}
