/* =========================================================
   True Fortune Casino — stylesheet
   Theme: chocolate + cream + gold
   ========================================================= */

:root{
  --c-choc:        #2b1810;   /* dark chocolate */
  --c-choc-2:      #3d241a;   /* lighter brown panel */
  --c-choc-3:      #4a2c1a;   /* hover brown */
  --c-cream:       #f5ebe0;   /* cream background */
  --c-cream-2:     #ffffff;   /* card surface */
  --c-gold:        #c9a24b;
  --c-gold-light:  #e8c874;
  --c-gold-dark:   #9c7a2e;
  --c-text:        #2b1d14;   /* body text on cream */
  --c-text-soft:   #6a584a;
  --c-text-light:  #f5ebe0;   /* text on dark */
  --c-line:        #e4d3bf;

  --radius:   16px;
  --radius-sm:10px;
  --shadow:   0 14px 40px rgba(43,24,16,.12);
  --shadow-sm:0 6px 18px rgba(43,24,16,.10);
  --container: 1120px;

  --ff-head: "Playfair Display", Georgia, serif;
  --ff-body: "Poppins", "Trebuchet MS", system-ui, sans-serif;
}

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

html{ scroll-behavior:smooth; }

body{
  font-family:var(--ff-body);
  color:var(--c-text);
  background:
    radial-gradient(1200px 600px at 50% -200px, rgba(201,162,75,.18), transparent 60%),
    var(--c-cream);
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:20px;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

/* ---------- Typography ---------- */
h1,h2,h3{ font-family:var(--ff-head); line-height:1.2; color:var(--c-choc); }
h1{ font-size:clamp(2.2rem,6vw,3.6rem); font-weight:800; }
h2{ font-size:clamp(1.6rem,4vw,2.4rem); font-weight:700; }
h3{ font-size:1.25rem; font-weight:700; }

h2{ position:relative; padding-bottom:14px; margin-bottom:18px; }
h2::after{
  content:""; position:absolute; left:0; bottom:0;
  width:64px; height:4px; border-radius:4px;
  background:linear-gradient(90deg,var(--c-gold),var(--c-gold-light));
}

p{ margin-bottom:14px; color:var(--c-text-soft); }
.content p{ font-size:1.02rem; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px; font-family:var(--ff-body); font-weight:600;
  font-size:.95rem; letter-spacing:.3px;
  padding:11px 22px; border-radius:999px; cursor:pointer;
  border:2px solid transparent; transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }

.btn-gold{
  background:linear-gradient(135deg,var(--c-gold-light),var(--c-gold));
  color:var(--c-choc);
  box-shadow:0 8px 20px rgba(201,162,75,.4);
}
.btn-gold:hover{ box-shadow:0 12px 28px rgba(201,162,75,.55); transform:translateY(-2px); }

.btn-ghost{
  background:transparent; color:var(--c-text-light);
  border-color:rgba(245,235,224,.4);
}
.btn-ghost:hover{ border-color:var(--c-gold-light); color:var(--c-gold-light); }

.btn-outline{
  background:transparent; color:var(--c-choc);
  border-color:var(--c-gold);
}
.btn-outline:hover{ background:var(--c-gold); color:var(--c-choc); }

.btn-lg{ padding:15px 34px; font-size:1.05rem; }

/* ---------- Header ---------- */
.site-header{
  background:linear-gradient(180deg,var(--c-choc),var(--c-choc-2));
  position:sticky; top:0; z-index:50;
  box-shadow:0 4px 20px rgba(0,0,0,.25);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding-block:14px; gap:16px;
}
.logo img{ height:48px; width:auto; }
.header-actions{ display:flex; gap:10px; }

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(800px 400px at 80% 0%, rgba(201,162,75,.22), transparent 55%),
    linear-gradient(160deg,var(--c-choc),var(--c-choc-2) 60%,var(--c-choc-3));
  color:var(--c-text-light);
  padding-block:clamp(40px,7vw,84px);
  border-bottom:3px solid var(--c-gold);
}
.hero-grid{
  display:grid; grid-template-columns:1fr; gap:36px; align-items:center;
}
.hero-copy h1{ color:var(--c-cream); margin-bottom:18px; }
.hero-copy h1::after{ display:none; }
.hero-copy p{ color:rgba(245,235,224,.85); font-size:1.08rem; max-width:60ch; margin-bottom:26px; }
.hero-media img{
  width:100%; border-radius:var(--radius);
  border:3px solid var(--c-gold);
  box-shadow:0 24px 60px rgba(0,0,0,.45);
}

/* ---------- Content layout ---------- */
.content{ padding-block:clamp(36px,6vw,72px); }
.block{ margin-bottom:clamp(44px,7vw,80px); }
.block:last-child{ margin-bottom:0; }

/* ---------- Tables ---------- */
.table-wrap{ overflow-x:auto; margin:22px 0; border-radius:var(--radius); box-shadow:var(--shadow-sm); }
table{
  width:100%; border-collapse:collapse; background:var(--c-cream-2);
  min-width:480px; overflow:hidden; border-radius:var(--radius);
}
thead th{
  background:linear-gradient(135deg,var(--c-choc),var(--c-choc-3));
  color:var(--c-gold-light); font-family:var(--ff-body); font-weight:600;
  text-align:left; padding:14px 18px; font-size:.95rem;
}
tbody th{
  text-align:left; padding:13px 18px; background:var(--c-choc);
  color:var(--c-cream); font-weight:600; width:42%; font-family:var(--ff-body);
}
tbody td{ padding:13px 18px; color:var(--c-text); border-bottom:1px solid var(--c-line); }
tbody tr:nth-child(even) td{ background:#fbf5ec; }
tbody tr:last-child td{ border-bottom:none; }

/* ---------- Steps ---------- */
.steps{ list-style:none; display:grid; gap:14px; margin-top:20px; }
.steps li{
  display:flex; gap:16px; align-items:flex-start;
  background:var(--c-cream-2); border:1px solid var(--c-line);
  border-radius:var(--radius-sm); padding:16px 18px; box-shadow:var(--shadow-sm);
}
.steps-compact{ grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.step-no{
  flex:0 0 auto; width:38px; height:38px; border-radius:50%;
  display:grid; place-items:center; font-family:var(--ff-head); font-weight:700;
  background:linear-gradient(135deg,var(--c-gold-light),var(--c-gold));
  color:var(--c-choc); font-size:1.1rem;
}
.steps li strong{ display:block; color:var(--c-choc); margin-bottom:2px; font-size:1.02rem; }
.steps li p{ margin:0; font-size:.95rem; }

/* ---------- Card grids ---------- */
.cards-2,.cards-3,.cards-4{ display:grid; gap:22px; margin-top:24px; }
.cards-2{ grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.cards-3{ grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.cards-4{ grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }

.game-card,.app-card,.bonus-card,.support-card{
  background:var(--c-cream-2); border:1px solid var(--c-line);
  border-radius:var(--radius); padding:26px 22px;
  box-shadow:var(--shadow-sm); text-align:center;
  display:flex; flex-direction:column; align-items:center;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.game-card:hover,.app-card:hover,.bonus-card:hover,.support-card:hover{
  transform:translateY(-5px); box-shadow:var(--shadow); border-color:var(--c-gold);
}
.game-card img,.app-card img,.bonus-card img,.support-card img{
  width:300px; height:100px; object-fit:contain; margin-bottom:16px;
  border-radius:14px;
}
.game-card img{ width:300px; height:190px; }
.game-card h3,.app-card h3,.bonus-card h3,.support-card h3{ margin-bottom:10px; }
.game-card p,.app-card p,.bonus-card p,.support-card p{ font-size:.94rem; margin-bottom:18px; }
.game-card .btn,.app-card .btn,.bonus-card .btn{ margin-top:auto; }

/* ---------- Pros & Cons ---------- */
.proscons{ display:grid; gap:22px; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); margin-top:24px; }
.pros,.cons{ border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); }
.pros{ background:#f3f8f0; border:1px solid #cfe3c5; }
.cons{ background:#fbf1ee; border:1px solid #ecc9bf; }
.pros h3{ color:#2f6b32; } .cons h3{ color:#a23a2a; }
.pros ul,.cons ul{ list-style:none; margin-top:14px; display:grid; gap:10px; }
.pros li,.cons li{ position:relative; padding-left:30px; font-size:.95rem; color:var(--c-text); }
.pros li::before{ content:"✓"; position:absolute; left:0; top:0; color:#2f6b32; font-weight:700; }
.cons li::before{ content:"✕"; position:absolute; left:0; top:0; color:#a23a2a; font-weight:700; }

/* ---------- FAQ ---------- */
.faq{ display:grid; gap:12px; margin-top:20px; }
.faq details{
  background:var(--c-cream-2); border:1px solid var(--c-line);
  border-radius:var(--radius-sm); box-shadow:var(--shadow-sm); overflow:hidden;
}
.faq summary{
  cursor:pointer; padding:16px 50px 16px 18px; position:relative;
  font-weight:600; color:var(--c-choc); list-style:none; font-size:1rem;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"+"; position:absolute; right:18px; top:50%; transform:translateY(-50%);
  width:26px; height:26px; border-radius:50%;
  background:linear-gradient(135deg,var(--c-gold-light),var(--c-gold));
  color:var(--c-choc); display:grid; place-items:center; font-size:1.2rem; font-weight:700;
  transition:transform .2s ease;
}
.faq details[open] summary::after{ content:"–"; transform:translateY(-50%) rotate(180deg); }
.faq details p{ padding:0 18px 18px; margin:0; font-size:.95rem; }

/* ---------- Footer ---------- */
.site-footer{
  background:linear-gradient(0deg,var(--c-choc),var(--c-choc-2));
  color:rgba(245,235,224,.75); padding-block:40px; margin-top:60px;
  border-top:3px solid var(--c-gold);
}
.footer-inner{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:16px; }
.footer-logo{ height:46px; width:auto; }
.footer-disclaimer{ max-width:70ch; font-size:.85rem; color:rgba(245,235,224,.6); margin:0; }
.footer-copy{ font-size:.85rem; margin:0; color:var(--c-gold-light); }

/* ---------- Responsive ---------- */
@media (min-width:860px){
  .hero-grid{ grid-template-columns:1.15fr .85fr; gap:48px; }
}
@media (max-width:520px){
  .logo img{ height:40px; }
  .btn{ padding:10px 16px; font-size:.88rem; }
  .header-actions{ gap:8px; }
}
