/*
Theme Name: Mars Films Casino
Theme URI: https://www.marsfilms.com
Author: Mars Films
Author URI: https://www.marsfilms.com
Description: Custom theme for Mars Films - Casino en ligne reviews and comparisons.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: marsfilms
*/

/* ============================================
       CSS VARIABLES
       ============================================ */
    :root {
      --color-bg: #f5f5f0;
      --color-bg-white: #ffffff;
      --color-bg-alt: #eeeee8;
      --color-text: #1a1a2e;
      --color-text-secondary: #4a4a5a;
      --color-text-muted: #7a7a8a;
      --color-accent: #c8102e;
      --color-accent-hover: #a00d24;
      --color-cta: #2ecc71;
      --color-cta-hover: #27ae60;
      --color-cta-border: #1fa855;
      --color-gold: #d4a44a;
      --color-gold-light: #f0d78c;
      --color-dark: #10102a;
      --color-dark-card: #161638;
      --color-dark-card-border: #2a2a5a;
      --color-border: #e0dfd8;
      --color-border-dark: #c8c7c0;
      --color-table-header: #1a1a2e;
      --color-table-stripe: #fafaf7;
      --color-pro: #2ecc71;
      --color-con: #e74c3c;
      --color-warning: #f39c12;
      --font-body: 'Plus Jakarta Sans', sans-serif;
      --font-heading: 'Plus Jakarta Sans', sans-serif;
      --max-width: 1200px;
      --radius: 8px;
      --radius-lg: 16px;
      --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
      --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
      --shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
    }

    /* ============================================
       RESET & BASE
       ============================================ */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { font-size: 17px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
    body {
      font-family: var(--font-body);
      background-color: var(--color-bg);
      color: var(--color-text);
      line-height: 1.7;
      font-weight: 400;
    }
    img { max-width: 100%; height: auto; display: block; }
    a { color: var(--color-accent); text-decoration: none; transition: color 0.2s ease; }
    a:hover { color: var(--color-accent-hover); }
    strong { font-weight: 700; }
    p { margin-bottom: 1.4em; }
    ul, ol { margin: 0 0 1.4em 1.2em; }
    li { margin-bottom: 0.5em; }
    table { border-collapse: collapse; width: 100%; }
    figure { margin: 0 0 1.5em; }

    h1, h2, h3, h4 {
      font-family: var(--font-heading);
      color: var(--color-text);
      line-height: 1.25;
      font-weight: 800;
    }
    h1 { font-size: 2.4rem; margin-bottom: 0.6em; }
    h2 { font-size: 1.85rem; margin: 2em 0 0.7em; }
    h3 { font-size: 1.35rem; margin: 1.6em 0 0.5em; }
    h4 { font-size: 1.1rem; margin: 1.4em 0 0.4em; }

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

    /* ============================================
       HEADER
       ============================================ */
    .site-header {
      background: var(--color-bg-white);
      border-bottom: 3px solid var(--color-accent);
      position: sticky;
      top: 0;
      z-index: 1000;
      box-shadow: var(--shadow-sm);
    }
    .header-inner {
      max-width: var(--max-width);
      margin: 0 auto;
      padding: 16px 24px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 32px;
    }
    .logo {
      font-family: var(--font-heading);
      font-size: 1.6rem;
      font-weight: 900;
      color: var(--color-text);
      text-decoration: none;
      display: flex;
      align-items: center;
      gap: 8px;
      letter-spacing: -0.02em;
    }
    .logo span { color: var(--color-accent); }
    .logo:hover { color: var(--color-text); }

    .nav-list {
      display: flex;
      gap: 32px;
      list-style: none;
      margin: 0;
      padding: 0;
      align-items: center;
    }
    .nav-list a {
      color: var(--color-text);
      font-weight: 500;
      font-size: 0.95rem;
      text-decoration: none;
      position: relative;
      padding: 6px 0;
    }
    .nav-list a::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      width: 0;
      height: 2px;
      background: var(--color-accent);
      transition: width 0.3s ease;
    }
    .nav-list a:hover::after { width: 100%; }
    .nav-list a:hover { color: var(--color-accent); }

    .mobile-toggle {
      display: none;
      flex-direction: column;
      gap: 5px;
      background: none;
      border: none;
      cursor: pointer;
      padding: 8px;
    }
    .mobile-toggle span {
      width: 24px;
      height: 2.5px;
      background: var(--color-text);
      border-radius: 2px;
      transition: all 0.3s ease;
    }

    /* ============================================
       HERO / INTRO SECTION
       ============================================ */
    .article-wrapper {
      max-width: 880px;
      margin: 0 auto;
      padding: 0 24px;
    }
    .intro-section {
      padding: 48px 0 24px;
    }
    .intro-grid {
      display: flex;
      gap: 40px;
      align-items: flex-start;
    }
    .intro-content { flex: 1; }
    .intro-icon {
      flex-shrink: 0;
      width: 140px;
      height: 140px;
      background: var(--color-bg-alt);
      border-radius: var(--radius-lg);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 64px;
    }
    .intro-content p {
      font-size: 1.05rem;
      color: var(--color-text-secondary);
    }
    .read-more-toggle {
      background: none;
      border: none;
      color: var(--color-accent);
      cursor: pointer;
      font-size: 0.95rem;
      font-weight: 500;
      text-decoration: underline;
      padding: 0;
      font-family: var(--font-body);
    }
    .read-more-content { display: none; }
    .read-more-content.active { display: block; }

    /* ============================================
       AUTHOR BOX (SLIM)
       ============================================ */
    .author-box-slim {
      display: flex;
      justify-content: space-between;
      align-items: center;
      background: var(--color-bg-white);
      border: 2px solid var(--color-border);
      border-radius: var(--radius);
      padding: 12px 20px;
      margin: 24px 0 32px;
      gap: 16px;
    }
    .author-box-left {
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .author-avatar {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--color-accent), #e8455a);
      display: flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      font-weight: 700;
      font-size: 1rem;
      border: 2px solid var(--color-border-dark);
      flex-shrink: 0;
    }
    .author-info { display: flex; flex-direction: column; gap: 1px; }
    .author-label { font-size: 0.78rem; color: var(--color-text-muted); }
    .author-name { font-size: 0.95rem; font-weight: 600; color: var(--color-text); }
    .author-name a { color: inherit; text-decoration: none; }
    .author-name a:hover { color: var(--color-accent); }
    .author-box-right {
      display: flex;
      align-items: center;
      gap: 16px;
      font-size: 0.85rem;
      color: var(--color-text-secondary);
    }
    .update-info { display: flex; align-items: center; gap: 6px; }
    .update-info svg { width: 15px; height: 15px; }
    .tooltip-triggers { display: flex; gap: 8px; }
    .tooltip-wrapper { position: relative; }
    .tooltip-btn {
      background: var(--color-bg-alt);
      border: 1px solid var(--color-border);
      border-radius: 50%;
      width: 32px;
      height: 32px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--color-text-secondary);
      transition: all 0.2s ease;
    }
    .tooltip-btn:hover { background: var(--color-border); }
    .tooltip-content {
      position: absolute;
      bottom: calc(100% + 12px);
      right: 0;
      width: 300px;
      background: var(--color-bg-white);
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow-lg);
      opacity: 0;
      visibility: hidden;
      transform: translateY(8px);
      transition: all 0.25s ease;
      z-index: 100;
    }
    .tooltip-wrapper:hover .tooltip-content {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }
    .tooltip-content h4 {
      font-family: var(--font-body);
      font-size: 0.9rem;
      font-weight: 700;
      margin: 0 0 8px;
    }
    .tooltip-content p {
      font-size: 0.82rem;
      line-height: 1.6;
      color: var(--color-text-secondary);
      margin: 0;
    }

    /* ============================================
       CASINO CARDS SECTION (DARK THEME)
       ============================================ */
    .casino-section {
      background: var(--color-dark);
      margin: 0 -9999px;
      padding: 48px 9999px;
    }
    .casino-section h2 {
      color: #ffffff;
      text-align: center;
      margin-top: 0;
      margin-bottom: 32px;
    }

    .casino-card {
      background: var(--color-dark-card);
      border: 2px solid var(--color-dark-card-border);
      border-radius: var(--radius-lg);
      padding: 24px 28px;
      margin-bottom: 20px;
      display: grid;
      grid-template-columns: 140px 1.2fr 1fr auto;
      gap: 20px;
      align-items: center;
      position: relative;
      transition: border-color 0.3s ease;
    }
    .casino-card:hover { border-color: var(--color-gold); }

    .casino-rank {
      position: absolute;
      top: -10px;
      left: -10px;
      background: var(--color-gold);
      color: var(--color-dark);
      width: 32px;
      height: 32px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 800;
      font-size: 0.85rem;
    }

    .casino-logo-area {
      background: rgba(255,255,255,0.06);
      border-radius: var(--radius);
      padding: 16px;
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 100px;
    }
    .casino-logo-text {
      color: #ffffff;
      font-family: var(--font-heading);
      font-size: 1.3rem;
      font-weight: 800;
      text-align: center;
      line-height: 1.2;
    }

    .casino-info h3 {
      color: #ffffff;
      font-family: var(--font-body);
      font-size: 1.15rem;
      font-weight: 700;
      margin: 0 0 4px;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .casino-stars { color: var(--color-gold); font-size: 0.85rem; letter-spacing: 1px; }
    .casino-rating { color: var(--color-text-muted); font-size: 0.85rem; font-weight: 400; }
    .casino-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 10px;
    }
    .casino-tag {
      background: rgba(255,255,255,0.08);
      border: 1px solid rgba(255,255,255,0.12);
      color: #ccccdd;
      font-size: 0.78rem;
      padding: 4px 12px;
      border-radius: 20px;
    }

    .casino-bonus {
      text-align: center;
    }
    .casino-bonus-label {
      color: #aaaabb;
      font-size: 0.82rem;
      margin-bottom: 4px;
    }
    .casino-bonus-value {
      color: var(--color-gold);
      font-family: var(--font-heading);
      font-size: 1.5rem;
      font-weight: 800;
      line-height: 1.2;
    }
    .casino-bonus-extra {
      color: #ccccdd;
      font-size: 0.85rem;
      margin-top: 2px;
    }

    .casino-cta-area {
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .btn-cta {
      display: inline-block;
      background: var(--color-cta);
      color: #000000;
      font-weight: 800;
      font-size: 0.9rem;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      padding: 16px 32px;
      border-radius: 30px;
      border: 2px solid var(--color-cta-border);
      text-decoration: none;
      transition: all 0.25s ease;
      text-align: center;
      white-space: nowrap;
    }
    .btn-cta:hover {
      background: var(--color-cta-hover);
      color: #000;
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(46,204,113,0.35);
    }

    /* ============================================
       TABLE OF CONTENTS
       ============================================ */
    .toc-container {
      background: var(--color-bg-white);
      border: 2px solid var(--color-border);
      border-radius: var(--radius);
      padding: 20px 24px;
      margin: 36px 0;
    }
    .toc-title {
      font-family: var(--font-body);
      font-size: 1rem;
      font-weight: 700;
      margin: 0 0 12px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .toc-toggle {
      background: var(--color-bg-alt);
      border: 1px solid var(--color-border);
      border-radius: 4px;
      padding: 4px 12px;
      cursor: pointer;
      font-size: 0.78rem;
      color: var(--color-text-secondary);
      font-family: var(--font-body);
    }
    .toc-list {
      list-style: none;
      margin: 0;
      padding: 0;
      columns: 2;
      column-gap: 32px;
    }
    .toc-list li {
      margin-bottom: 8px;
      break-inside: avoid;
    }
    .toc-list a {
      color: var(--color-accent);
      font-size: 0.9rem;
      text-decoration: none;
      display: block;
      padding: 3px 0;
      line-height: 1.4;
    }
    .toc-list a:hover { text-decoration: underline; }

    /* ============================================
       CONTENT AREA
       ============================================ */
    .content-area {
      background: var(--color-bg-white);
      border: 2px solid var(--color-border);
      border-radius: var(--radius);
      padding: 48px;
      margin-bottom: 32px;
    }
    .content-area h2:first-child { margin-top: 0; }

    .content-area ul { list-style: none; margin-left: 0; }
    .content-area > ul > li,
    .content-area .styled-list > li {
      position: relative;
      padding-left: 24px;
      margin-bottom: 0.7em;
    }
    .content-area > ul > li::before,
    .content-area .styled-list > li::before {
      content: "";
      position: absolute;
      left: 0;
      top: 0.55em;
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--color-cta);
    }
    .content-area ol { margin-left: 1.4em; }
    .content-area ol li { padding-left: 0.4em; }

    /* ============================================
       CRITERIA BLOCKS (ICON + TEXT)
       ============================================ */
    .criteria-block {
      display: flex;
      gap: 24px;
      align-items: flex-start;
      margin: 24px 0;
      padding: 20px;
      background: var(--color-bg);
      border-radius: var(--radius);
      border: 1px solid var(--color-border);
    }
    .criteria-icon {
      width: 72px;
      height: 72px;
      flex-shrink: 0;
      background: var(--color-bg-white);
      border-radius: var(--radius);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 32px;
      border: 1px solid var(--color-border);
    }
    .criteria-text h3 {
      margin: 0 0 6px;
      font-family: var(--font-body);
      font-size: 1.05rem;
      font-weight: 700;
    }
    .criteria-text p {
      margin: 0;
      font-size: 0.92rem;
      color: var(--color-text-secondary);
      line-height: 1.6;
    }

    /* ============================================
       OVERVIEW TABLE
       ============================================ */
    .table-wrapper {
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      margin: 20px 0;
      border-radius: var(--radius);
      border: 2px solid var(--color-border-dark);
    }
    .table-wrapper table {
      min-width: 600px;
    }
    .table-wrapper thead {
      background: var(--color-table-header);
    }
    .table-wrapper th {
      color: #ffffff;
      font-weight: 600;
      font-size: 0.88rem;
      text-align: left;
      padding: 12px 16px;
      border: none;
    }
    .table-wrapper td {
      padding: 12px 16px;
      border-bottom: 1px solid var(--color-border);
      font-size: 0.92rem;
    }
    .table-wrapper tbody tr:nth-child(even) {
      background: var(--color-table-stripe);
    }
    .table-wrapper tbody tr:hover {
      background: rgba(200,16,46,0.04);
    }

    /* ============================================
       TOP CASINO DETAILED LIST
       ============================================ */
    .top-casinos-list {
      list-style: none;
      padding: 0;
      margin: 32px 0 0;
    }
    .casino-item {
      background: var(--color-bg-white);
      border: 2px solid var(--color-border);
      border-radius: var(--radius-lg);
      padding: 32px;
      margin-bottom: 24px;
    }
    .casino-item-header {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-bottom: 12px;
    }
    .casino-item-number {
      width: 34px;
      height: 34px;
      min-width: 34px;
      background: var(--color-cta);
      border: 2px solid var(--color-cta-border);
      color: #000;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 800;
      font-size: 0.85rem;
    }
    .casino-item-name {
      font-family: var(--font-heading);
      font-size: 1.6rem;
      font-weight: 800;
      color: var(--color-text);
      margin: 0;
    }
    .casino-item-bonus {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 20px;
    }
    .casino-item-bonus span {
      padding: 6px 14px;
      background: var(--color-bg);
      border: 2px solid var(--color-border);
      border-radius: 6px;
      font-size: 0.92rem;
      font-weight: 600;
    }
    .casino-details-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 28px;
      margin-bottom: 20px;
    }
    .detail-section h4 {
      font-family: var(--font-body);
      font-size: 1rem;
      font-weight: 700;
      margin: 0 0 10px;
    }

    /* Pros / Cons lists - flexbox, no absolute positioning */
    .pros-list, .cons-list {
      list-style: none;
      padding: 0;
      margin: 0;
    }
    .pros-list li, .cons-list li {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      margin-bottom: 10px;
      font-size: 0.92rem;
      line-height: 1.55;
    }
    .icon-pro, .icon-con {
      width: 20px;
      height: 20px;
      min-width: 20px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: 2px;
    }
    .icon-pro {
      background: var(--color-pro);
    }
    .icon-con {
      background: var(--color-con);
    }
    .icon-pro svg, .icon-con svg {
      width: 12px;
      height: 12px;
      stroke: #fff;
      stroke-width: 3;
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .why-section {
      background: rgba(212,164,74,0.08);
      border: 2px solid rgba(212,164,74,0.25);
      border-radius: var(--radius);
      padding: 20px;
      margin-bottom: 16px;
    }
    .why-section h4 {
      font-family: var(--font-body);
      font-weight: 700;
      font-size: 0.95rem;
      margin: 0 0 8px;
      color: var(--color-text);
    }
    .why-section p {
      font-size: 0.9rem;
      line-height: 1.6;
      margin: 0;
      color: var(--color-text-secondary);
    }
    .casino-meta {
      display: flex;
      gap: 24px;
      font-size: 0.85rem;
      color: var(--color-text-muted);
      padding-top: 16px;
      border-top: 1px solid var(--color-border);
    }
    .meta-item strong { color: var(--color-text); }

    /* ============================================
       PROS / CONS SECTION (standalone block)
       ============================================ */
    .pros-cons-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 28px;
      margin: 20px 0;
    }
    .pros-block, .cons-block {
      padding: 24px;
      border-radius: var(--radius);
    }
    .pros-block {
      background: rgba(46,204,113,0.06);
      border: 2px solid rgba(46,204,113,0.2);
    }
    .cons-block {
      background: rgba(231,76,60,0.05);
      border: 2px solid rgba(231,76,60,0.15);
    }
    .pros-block h3, .cons-block h3 {
      font-family: var(--font-body);
      font-size: 1.1rem;
      margin: 0 0 14px;
    }

    /* ============================================
       STEP-BY-STEP - flexbox, no absolute positioning
       ============================================ */
    .steps-list {
      list-style: none;
      margin: 20px 0;
      padding: 0;
    }
    .steps-list li {
      display: flex;
      align-items: flex-start;
      gap: 16px;
      margin-bottom: 1.2em;
      line-height: 1.6;
    }
    .step-number {
      width: 36px;
      height: 36px;
      min-width: 36px;
      background: var(--color-accent);
      color: #fff;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 700;
      font-size: 0.85rem;
      margin-top: 1px;
    }

    /* ============================================
       FAQ SECTION
       ============================================ */
    .faq-item {
      border-bottom: 1px solid var(--color-border);
      padding: 20px 0;
    }
    .faq-item:last-child { border-bottom: none; }
    .faq-question {
      font-family: var(--font-body);
      font-weight: 700;
      font-size: 1.05rem;
      margin: 0 0 8px;
      color: var(--color-text);
    }
    .faq-answer {
      font-size: 0.95rem;
      color: var(--color-text-secondary);
      line-height: 1.6;
    }
    .faq-answer p { margin: 0; }

    /* ============================================
       AUTHOR BOX (FULL)
       ============================================ */
    .author-box-full {
      display: flex;
      gap: 24px;
      padding: 24px;
      background: var(--color-bg-white);
      border: 2px solid var(--color-border);
      border-radius: var(--radius);
      margin-top: 36px;
    }
    .author-photo-full {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--color-accent), #e8455a);
      display: flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      font-weight: 800;
      font-size: 1.5rem;
      flex-shrink: 0;
      border: 3px solid var(--color-border-dark);
    }
    .author-details-full { flex: 1; }
    .author-details-full .author-name-full {
      font-size: 1.15rem;
      font-weight: 700;
      margin: 0 0 2px;
    }
    .author-details-full .author-title-full {
      font-style: italic;
      color: var(--color-text-secondary);
      font-size: 0.9rem;
      margin: 0 0 10px;
    }
    .author-details-full .author-bio-full {
      font-size: 0.9rem;
      line-height: 1.6;
      color: var(--color-text-secondary);
      margin: 0 0 8px;
    }
    .author-links-full a {
      font-size: 0.85rem;
      color: var(--color-accent);
    }
    .author-date-full {
      font-size: 0.82rem;
      color: var(--color-text-muted);
      margin-top: 6px;
    }

    /* ============================================
       FOOTER
       ============================================ */
    .site-footer {
      background: var(--color-bg-white);
      color: var(--color-text);
      padding: 48px 0 24px;
      border-top: 3px solid var(--color-accent);
      margin-top: 48px;
    }
    .footer-top {
      display: grid;
      grid-template-columns: 1fr 2fr;
      gap: 48px;
      padding-bottom: 32px;
      border-bottom: 1px solid var(--color-border);
    }
    .footer-brand .footer-logo {
      font-family: var(--font-heading);
      font-size: 1.4rem;
      font-weight: 900;
      color: var(--color-text);
      margin-bottom: 8px;
    }
    .footer-brand .footer-logo span { color: var(--color-accent); }
    .footer-tagline { font-size: 0.9rem; color: var(--color-text-secondary); margin: 0; }

    .footer-nav {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 32px;
    }
    .footer-col-title {
      color: var(--color-accent);
      font-weight: 700;
      text-transform: uppercase;
      font-size: 0.78rem;
      letter-spacing: 0.08em;
      margin-bottom: 12px;
    }
    .footer-col ul { list-style: none; margin: 0; padding: 0; }
    .footer-col li { margin-bottom: 8px; }
    .footer-col a { color: var(--color-text); font-size: 0.9rem; text-decoration: none; }
    .footer-col a:hover { color: var(--color-accent); }

    .footer-responsible {
      display: flex;
      align-items: center;
      gap: 16px;
      padding: 20px 0;
      border-bottom: 1px solid var(--color-border);
    }
    .badge-18 {
      background: var(--color-accent);
      color: #fff;
      font-weight: 800;
      padding: 6px 10px;
      border-radius: 4px;
      font-size: 0.85rem;
      flex-shrink: 0;
    }
    .footer-responsible p {
      font-size: 0.85rem;
      margin: 0;
      color: var(--color-text-secondary);
    }
    .footer-responsible a { text-decoration: underline; }

    .footer-disclaimer {
      padding: 20px 0;
      border-bottom: 1px solid var(--color-border);
    }
    .footer-disclaimer p {
      font-size: 0.82rem;
      line-height: 1.7;
      color: var(--color-text-muted);
      margin: 0;
    }
    .footer-bottom {
      padding-top: 16px;
      text-align: center;
      font-size: 0.82rem;
      color: var(--color-text-muted);
    }

    /* ============================================
       RESPONSIVE
       ============================================ */
    @media (max-width: 1100px) {
      .casino-card {
        grid-template-columns: 120px 1fr 1fr;
        grid-template-rows: auto auto;
        gap: 16px 20px;
      }
      .casino-logo-area {
        grid-row: 1 / 3;
      }
      .casino-bonus {
        text-align: left;
      }
      .casino-cta-area {
        justify-content: flex-start;
      }
    }
    @media (max-width: 968px) {
      .nav-list { display: none; }
      .mobile-toggle { display: flex; }
      .casino-card {
        grid-template-columns: 1fr 1fr;
        gap: 16px;
        padding: 24px;
      }
      .casino-logo-area {
        grid-row: auto;
        max-width: 100%;
      }
      .casino-info {
        grid-column: 1 / -1;
      }
      .casino-bonus {
        text-align: left;
      }
      .casino-cta-area {
        justify-content: flex-end;
        align-items: flex-end;
      }
    }
    @media (max-width: 768px) {
      html { font-size: 16px; }
      h1 { font-size: 1.8rem; }
      h2 { font-size: 1.5rem; }
      .content-area { padding: 28px 20px; }
      .intro-icon { display: none; }
      .author-box-slim { flex-direction: column; align-items: flex-start; }
      .author-box-right { width: 100%; justify-content: space-between; }
      .tooltip-triggers { display: none; }
      .toc-list { columns: 1; }
      .casino-card {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 28px 20px;
      }
      .casino-logo-area { max-width: 180px; margin: 0 auto; }
      .casino-info { grid-column: auto; }
      .casino-info h3 { justify-content: center; flex-wrap: wrap; }
      .casino-tags { justify-content: center; }
      .casino-bonus { text-align: center; margin: 4px 0; }
      .casino-cta-area { justify-content: center; }
      .btn-cta { width: 100%; max-width: 280px; }
      .casino-details-grid { grid-template-columns: 1fr; gap: 20px; }
      .pros-cons-grid { grid-template-columns: 1fr; }
      .casino-item { padding: 24px 20px; margin-left: 0; }
      .casino-item::before { left: -16px; top: 24px; width: 28px; height: 28px; font-size: 0.8rem; }
      .footer-top { grid-template-columns: 1fr; gap: 32px; }
      .footer-nav { grid-template-columns: repeat(2, 1fr); }
      .footer-responsible { flex-direction: column; align-items: flex-start; }
      .criteria-block { flex-direction: column; text-align: center; align-items: center; }
      .author-box-full { flex-direction: column; text-align: center; align-items: center; }
    }
    @media (max-width: 480px) {
      .header-inner { padding: 12px 16px; }
      .logo { font-size: 1.3rem; }
      .content-area { padding: 24px 16px; }
      .footer-nav { grid-template-columns: 1fr; }
      .casino-item-bonus { flex-direction: column; }
      .casino-meta { flex-direction: column; gap: 8px; }
    }
/* Prevent horizontal scroll from full-width casino section */
body { overflow-x: hidden; }

/* ============================================
   SHARED: PAGE WRAPPER (Author + Contact pages)
   ============================================ */
.page-wrapper {
  max-width: 880px;
  margin: 0 auto;
  padding: 48px 24px;
}
.page-intro { margin-bottom: 32px; }
.page-intro p { font-size: 1.05rem; color: var(--color-text-secondary); }
.page-intro p:last-child { margin-bottom: 0; }

/* ============================================
   AUTHOR PAGE
   ============================================ */
.author-hero {
  background: var(--color-bg-white);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 48px;
  display: flex;
  gap: 40px;
  align-items: flex-start;
  margin-bottom: 32px;
}
.author-avatar-large {
  width: 140px; height: 140px; min-width: 140px;
  border-radius: 50%; object-fit: cover;
  border: 4px solid var(--color-border-dark);
}
.author-avatar-large-placeholder {
  width: 140px; height: 140px; min-width: 140px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-accent), #e8455a);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 3rem;
  border: 4px solid var(--color-border-dark);
}
.author-hero-info h1 { margin-bottom: 4px; }
.author-role { font-size: 1.1rem; color: var(--color-accent); font-weight: 600; margin-bottom: 16px; }
.author-hero-bio { font-size: 1rem; color: var(--color-text-secondary); line-height: 1.7; }
.author-hero-bio p:last-child { margin-bottom: 0; }
.author-contact-row { display: flex; gap: 24px; margin-top: 20px; flex-wrap: wrap; }
.author-contact-item { display: flex; align-items: center; gap: 8px; font-size: 0.9rem; color: var(--color-text-secondary); }
.author-contact-item a { color: var(--color-accent); }
.author-contact-item svg { width: 18px; height: 18px; stroke: var(--color-text-muted); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.author-content {
  background: var(--color-bg-white);
  border: 2px solid var(--color-border);
  border-radius: var(--radius);
  padding: 48px;
}
.author-content h2:first-child { margin-top: 0; }

.expertise-tags { display: flex; flex-wrap: wrap; gap: 10px; margin: 16px 0 24px; }
.expertise-tag {
  padding: 8px 16px; background: var(--color-bg);
  border: 2px solid var(--color-border); border-radius: 6px;
  font-size: 0.88rem; font-weight: 600; color: var(--color-text);
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin: 24px 0; }
.stat-card {
  background: var(--color-bg); border: 2px solid var(--color-border);
  border-radius: var(--radius); padding: 20px; text-align: center;
}
.stat-number { font-size: 1.8rem; font-weight: 800; color: var(--color-accent); line-height: 1.2; }
.stat-label { font-size: 0.82rem; color: var(--color-text-muted); margin-top: 4px; }

.timeline { margin: 24px 0; padding: 0; list-style: none; }
.timeline li { display: flex; gap: 20px; margin-bottom: 24px; align-items: flex-start; }
.timeline-year {
  min-width: 64px; padding: 6px 12px;
  background: var(--color-accent); color: #fff;
  font-weight: 700; font-size: 0.82rem; border-radius: 4px; text-align: center; margin-top: 2px;
}
.timeline-content h3 { margin: 0 0 4px; font-size: 1rem; }
.timeline-content p { margin: 0; font-size: 0.9rem; color: var(--color-text-secondary); }

.methodology-list { list-style: none; margin: 16px 0; padding: 0; }
.methodology-list li { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; font-size: 0.95rem; line-height: 1.5; }
.method-icon {
  width: 28px; height: 28px; min-width: 28px;
  background: var(--color-cta); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; margin-top: 1px;
}
.method-icon svg { width: 14px; height: 14px; stroke: #fff; fill: none; stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }

.cert-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 16px 0; }
.cert-card {
  background: var(--color-bg); border: 2px solid var(--color-border);
  border-radius: var(--radius); padding: 20px;
}
.cert-card h3 { margin: 0 0 6px; font-size: 0.95rem; }
.cert-card p { margin: 0; font-size: 0.85rem; color: var(--color-text-secondary); }

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 32px; }
.contact-card {
  background: var(--color-bg-white); border: 2px solid var(--color-border);
  border-radius: var(--radius); padding: 32px;
}
.contact-card-icon {
  width: 48px; height: 48px; background: var(--color-bg);
  border: 2px solid var(--color-border); border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; margin-bottom: 16px;
}
.contact-card h2 { font-size: 1.1rem; margin-bottom: 8px; }
.contact-card p { font-size: 0.92rem; color: var(--color-text-secondary); margin-bottom: 12px; }
.contact-card a.contact-link { font-weight: 600; font-size: 0.95rem; }

.form-section {
  background: var(--color-bg-white); border: 2px solid var(--color-border);
  border-radius: var(--radius-lg); padding: 48px;
}
.form-section h2 { margin-bottom: 8px; }
.form-section > p { color: var(--color-text-secondary); font-size: 0.95rem; margin-bottom: 28px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group.full-width { grid-column: 1 / -1; }
.form-group label { font-weight: 600; font-size: 0.88rem; color: var(--color-text); }
.form-group input,
.form-group select,
.form-group textarea {
  font-family: var(--font-body); font-size: 0.95rem; padding: 12px 16px;
  border: 2px solid var(--color-border); border-radius: var(--radius);
  background: var(--color-bg); color: var(--color-text);
  transition: border-color 0.2s ease; outline: none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--color-accent); }
.form-group textarea { resize: vertical; min-height: 140px; }
.form-group select {
  cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237a7a8a' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px;
}
.btn-submit {
  display: inline-block; background: var(--color-accent); color: #fff;
  font-family: var(--font-body); font-weight: 700; font-size: 0.95rem;
  padding: 14px 36px; border: none; border-radius: var(--radius);
  cursor: pointer; transition: background 0.2s ease; margin-top: 8px;
}
.btn-submit:hover { background: var(--color-accent-hover); }
.response-note {
  display: flex; align-items: flex-start; gap: 12px; margin-top: 28px;
  padding: 16px 20px; background: var(--color-bg);
  border: 1px solid var(--color-border); border-radius: var(--radius);
}
.response-note-icon { font-size: 1.2rem; margin-top: 1px; }
.response-note p { margin: 0; font-size: 0.88rem; color: var(--color-text-secondary); line-height: 1.5; }

/* ============================================
   RESPONSIVE - AUTHOR & CONTACT
   ============================================ */
@media (max-width: 768px) {
  .page-wrapper { padding: 32px 16px; }
  .author-hero { flex-direction: column; align-items: center; text-align: center; padding: 32px 24px; gap: 24px; }
  .author-contact-row { justify-content: center; }
  .author-content { padding: 28px 20px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .cert-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .form-section { padding: 28px 20px; }
  .form-row { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .author-hero { padding: 24px 16px; }
  .author-content { padding: 24px 16px; }
  .form-section { padding: 24px 16px; }
}
