@import url("https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Manrope:wght@400;500;600;700&display=swap");

/* ==========================================================================
   Best Slots Bonuses — Design System (trm-)
   Clean, trustworthy, modern. Light-dominant, deep teal/indigo ink with a
   warm gold accent. Gradient headings, soft cards, generous depth.
   Scoped under .trm-page so the rest of the site is untouched.
   ========================================================================== */
.trm-page{
  --ink:#11202b; --ink-soft:#3a4a57; --muted:#67788a;
  --teal:#0f7b78; --teal-d:#0a5f5d;
  --indigo:#1f3b73; --indigo-d:#16284d;
  --gold:#e6a93c; --gold-d:#c98a1f;
  --green:#1f9d6b; --green-soft:#e8f7f0;
  --rose:#d65563; --rose-soft:#fbecee;
  --line:#e4e9ef; --line-2:#d2dae3;
  --wash:#f6f8fb; --wash-2:#eef3f8; --card:#ffffff;
  --grad:linear-gradient(100deg,#0f7b78 0%,#1f3b73 60%,#2a2f6e 100%);
  --shadow-sm:0 1px 2px rgba(16,32,43,.06),0 2px 6px rgba(16,32,43,.05);
  --shadow:0 4px 14px rgba(16,32,43,.08),0 12px 30px rgba(16,32,43,.07);
  --shadow-lg:0 10px 30px rgba(16,32,43,.12),0 30px 60px rgba(16,32,43,.10);
  --r:14px; --r-sm:10px; --r-lg:22px;
  --display:"Fraunces",Georgia,serif;
  --head:"Sora","Helvetica Neue",sans-serif;
  --body:"Manrope","Helvetica Neue",Arial,sans-serif;
  color:var(--ink); font-family:var(--body); font-size:17px; line-height:1.72;
  background:
    radial-gradient(1200px 600px at 85% -5%, rgba(15,123,120,.06), transparent 60%),
    radial-gradient(1000px 500px at -10% 8%, rgba(31,59,115,.05), transparent 55%),
    #fff;
  -webkit-font-smoothing:antialiased;
}
.trm-page *{ box-sizing:border-box; }
.trm-page img{ max-width:100%; height:auto; }
.trm-wrap{ max-width:1180px; margin:0 auto; padding:0 24px; }

.trm-page h1,.trm-page h2,.trm-page h3{ font-family:var(--head); font-weight:700; line-height:1.12; color:var(--ink); margin:0; letter-spacing:-.02em; }
.trm-page p{ margin:0 0 1.1rem; }
.trm-page a{ color:var(--teal-d); text-decoration:none; }
.trm-page a:hover{ color:var(--teal); }
.trm-page strong{ font-weight:700; color:var(--ink); }

.trm-grad{ background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }
.trm-topbar{ height:5px; background:var(--grad); border-radius:0 0 6px 6px; }

/* SECTION HEADER */
.trm-sh{ margin:64px 0 18px; }
.trm-sh .trm-kick{ display:inline-block; font-family:var(--head); font-weight:700; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--teal-d); background:var(--green-soft); border:1px solid rgba(15,123,120,.18); padding:5px 12px; border-radius:999px; margin-bottom:14px; }
.trm-sh h2{ font-size:2.05rem; line-height:1.08; }
.trm-sh h2 .trm-grad{ display:inline; }
.trm-sub{ color:var(--ink-soft); margin:14px 0 30px; max-width:780px; font-size:1.04rem; }

/* HERO */
.trm-hero{ position:relative; margin:34px 0 8px; display:grid; grid-template-columns:1.55fr 1fr; gap:26px; align-items:stretch; }
.trm-hero-l{ background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); padding:48px 46px; box-shadow:var(--shadow); position:relative; overflow:hidden; }
.trm-hero-l::before{ content:""; position:absolute; inset:0 0 auto 0; height:6px; background:var(--grad); }
.trm-eyebrow{ display:inline-flex; align-items:center; gap:8px; font-family:var(--head); font-weight:700; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-d); margin-bottom:18px; }
.trm-eyebrow::before{ content:""; width:22px; height:2px; background:var(--gold); display:inline-block; }
.trm-hero-l h1{ font-family:var(--display); font-weight:600; font-size:3.15rem; line-height:1.02; letter-spacing:-.025em; margin-bottom:20px; }
.trm-hero-l h1 .trm-grad{ display:inline; }
.trm-hero-l p{ font-size:1.06rem; color:var(--ink-soft); line-height:1.7; margin:0; max-width:60ch; }
.trm-hero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:26px; }
.trm-btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--head); font-weight:700; font-size:.92rem; letter-spacing:.01em; padding:13px 22px; border-radius:999px; transition:transform .15s ease, box-shadow .15s ease, background .15s ease; }
.trm-btn-primary{ background:var(--grad); color:#fff !important; box-shadow:0 6px 18px rgba(15,123,120,.32); }
.trm-btn-primary:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(15,123,120,.4); color:#fff !important; }
.trm-btn-ghost{ background:#fff; color:var(--indigo) !important; border:1.5px solid var(--line-2); }
.trm-btn-ghost:hover{ border-color:var(--teal); color:var(--teal-d) !important; transform:translateY(-2px); }
.trm-hero-r{ background:var(--grad); border-radius:var(--r-lg); padding:34px 32px; color:#fff; box-shadow:var(--shadow-lg); position:relative; overflow:hidden; display:flex; flex-direction:column; justify-content:center; }
.trm-hero-r::after{ content:""; position:absolute; right:-60px; top:-60px; width:220px; height:220px; border-radius:50%; background:radial-gradient(circle at center, rgba(230,169,60,.4), transparent 70%); }
.trm-hero-r .trm-panel-k{ font-family:var(--head); font-weight:700; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:#bfe9e6; margin-bottom:6px; position:relative; }
.trm-stat{ padding:16px 0; border-bottom:1px solid rgba(255,255,255,.16); position:relative; }
.trm-stat:last-child{ border-bottom:none; }
.trm-stat-num{ font-family:var(--display); font-weight:700; font-size:2.5rem; line-height:1; color:#fff; }
.trm-stat-num span{ color:var(--gold); }
.trm-stat-lbl{ font-size:.92rem; color:#cfe3f2; margin-top:4px; line-height:1.4; }

/* QUICK NAV */
.trm-navgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:18px; }
.trm-navcard{ display:block; background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:22px 22px 20px; color:inherit; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease; }
.trm-navcard::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--grad); transform:scaleY(0); transform-origin:top; transition:transform .2s ease; }
.trm-navcard:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--line-2); }
.trm-navcard:hover::before{ transform:scaleY(1); }
.trm-navnum{ font-family:var(--head); font-weight:700; font-size:.78rem; letter-spacing:.06em; color:var(--gold-d); }
.trm-navcard h3{ margin:8px 0 8px; font-size:1.12rem; }
.trm-navcard p{ margin:0; font-size:.92rem; color:var(--muted); line-height:1.5; }
.trm-navgo{ display:inline-block; margin-top:12px; font-family:var(--head); font-weight:700; font-size:.82rem; color:var(--teal-d); }
.trm-navgo::after{ content:" \2192"; }

/* TABLE */
.trm-table-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow-sm); background:var(--card); margin-top:6px; }
.trm-table{ width:100%; border-collapse:collapse; background:var(--card); font-size:.95rem; min-width:680px; }
.trm-table thead th{ background:var(--grad); color:#fff; font-family:var(--head); font-weight:600; letter-spacing:.04em; font-size:.82rem; padding:16px 18px; text-align:left; white-space:nowrap; }
.trm-table tbody td{ padding:15px 18px; border-bottom:1px solid var(--line); vertical-align:middle; }
.trm-table tbody tr:last-child td{ border-bottom:none; }
.trm-table tbody tr{ transition:background .12s ease; }
.trm-table tbody tr:nth-child(even){ background:var(--wash); }
.trm-table tbody tr:hover{ background:var(--wash-2); }
.trm-table tbody td:first-child{ font-family:var(--head); font-weight:700; color:var(--indigo); }
.trm-pill{ display:inline-block; font-family:var(--head); font-weight:700; font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; padding:4px 11px; border-radius:999px; }
.trm-pill-reg{ background:var(--green-soft); color:var(--teal-d); border:1px solid rgba(15,123,120,.25); }
.trm-pill-off{ background:#eef1fb; color:var(--indigo); border:1px solid rgba(31,59,115,.22); }
.trm-tbl-btn{ display:inline-block; background:var(--gold); color:#3a2a05 !important; font-family:var(--head); font-weight:700; font-size:.78rem; padding:9px 16px; border-radius:999px; white-space:nowrap; box-shadow:0 2px 8px rgba(230,169,60,.35); transition:transform .14s ease, box-shadow .14s ease, background .14s ease; }
.trm-tbl-btn:hover{ background:var(--gold-d); color:#fff !important; transform:translateY(-1px); box-shadow:0 5px 14px rgba(201,138,31,.45); }
.trm-note{ margin-top:14px; font-size:.92rem; color:var(--muted); padding:12px 16px; background:var(--wash); border-left:3px solid var(--gold); border-radius:0 var(--r-sm) var(--r-sm) 0; }

/* FLAGSHIP SPOTLIGHT */
.trm-spotlight{ position:relative; display:grid; grid-template-columns:1.7fr 1fr; gap:0; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-lg); margin-top:8px; background:var(--card); border:1px solid var(--line); }
.trm-spot-l{ padding:34px 38px; position:relative; }
.trm-spot-badge{ display:inline-flex; align-items:center; gap:8px; font-family:var(--head); font-weight:700; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:#3a2a05; background:linear-gradient(100deg,var(--gold),#f4c869); padding:6px 14px; border-radius:999px; box-shadow:0 3px 10px rgba(230,169,60,.4); margin-bottom:16px; }
.trm-spot-badge::before{ content:"\2605"; font-size:.85rem; }
.trm-spot-top{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:14px; }
.trm-spot-logo{ font-family:var(--head); font-weight:800; font-size:1.7rem; color:var(--indigo); letter-spacing:-.02em; }
.trm-rating{ display:inline-flex; align-items:center; gap:6px; font-family:var(--head); font-weight:700; font-size:.82rem; color:var(--teal-d); background:var(--green-soft); border:1px solid rgba(15,123,120,.22); padding:5px 12px; border-radius:999px; }
.trm-rating .trm-stars{ color:var(--gold-d); letter-spacing:1px; }
.trm-spot-l p{ font-size:1rem; color:var(--ink-soft); margin:0; line-height:1.72; }
.trm-spot-states{ margin-top:16px; font-family:var(--head); font-weight:600; font-size:.84rem; color:var(--muted); }
.trm-spot-states span{ color:var(--indigo); }
.trm-spot-r{ background:var(--grad); color:#fff; padding:34px 28px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:14px; position:relative; overflow:hidden; }
.trm-spot-r::after{ content:""; position:absolute; left:-40px; bottom:-40px; width:160px; height:160px; border-radius:50%; background:radial-gradient(circle, rgba(230,169,60,.35), transparent 70%); }
.trm-offer-k{ font-family:var(--head); font-weight:700; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:#bfe9e6; position:relative; }
.trm-offer{ font-family:var(--display); font-weight:700; font-size:1.55rem; line-height:1.12; position:relative; }
.trm-spot-cta{ display:block; width:100%; background:var(--gold); color:#3a2a05 !important; font-family:var(--head); font-weight:700; font-size:1rem; padding:15px; border-radius:999px; position:relative; box-shadow:0 5px 16px rgba(0,0,0,.2); transition:transform .15s ease, background .15s ease; }
.trm-spot-cta:hover{ background:#f4c869; transform:translateY(-2px); color:#3a2a05 !important; }

/* SECONDARY REVIEW BOXES */
.trm-srgrid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:22px; }
.trm-sr{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px 26px; box-shadow:var(--shadow-sm); position:relative; transition:transform .15s ease, box-shadow .15s ease; display:flex; flex-direction:column; }
.trm-sr:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.trm-sr-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:6px; }
.trm-sr h3{ font-size:1.18rem; color:var(--indigo); }
.trm-sr-rate{ font-family:var(--head); font-weight:700; font-size:.78rem; color:var(--gold-d); white-space:nowrap; }
.trm-sr-states{ font-family:var(--head); font-weight:600; font-size:.78rem; color:var(--muted); margin-bottom:10px; }
.trm-sr-states span{ color:var(--teal-d); }
.trm-sr p{ font-size:.95rem; color:var(--ink-soft); margin:0 0 18px; line-height:1.62; flex:1; }
.trm-sr-btn{ display:inline-block; align-self:flex-start; font-family:var(--head); font-weight:700; font-size:.82rem; color:var(--teal-d); border:1.5px solid var(--line-2); padding:10px 20px; border-radius:999px; transition:.14s ease; }
.trm-sr-btn:hover{ background:var(--grad); color:#fff !important; border-color:transparent; }

/* CONCEPT CARDS */
.trm-concepts{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:20px; }
.trm-concept{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px 26px; box-shadow:var(--shadow-sm); position:relative; transition:transform .15s ease, box-shadow .15s ease; }
.trm-concept:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.trm-concept h3{ font-size:1.14rem; color:var(--indigo); margin-bottom:10px; display:flex; align-items:center; gap:10px; }
.trm-concept h3::before{ content:""; width:32px; height:32px; flex:0 0 auto; border-radius:9px; background:var(--green-soft); border:1px solid rgba(15,123,120,.22); background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a5f5d' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; background-size:17px; }
.trm-concept p{ font-size:.95rem; color:var(--ink-soft); margin:0; line-height:1.62; }

/* PROSE + PANELS */
.trm-prose{ margin-top:8px; }
.trm-prose p{ font-size:1.05rem; color:var(--ink-soft); line-height:1.78; }
.trm-prose p strong{ color:var(--ink); }
.trm-prose a{ color:var(--teal-d); font-weight:600; border-bottom:1px solid rgba(15,123,120,.3); }
.trm-prose a:hover{ border-bottom-color:var(--teal); }
.trm-panel{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:30px 34px; box-shadow:var(--shadow-sm); margin-top:8px; }
.trm-panel p{ font-size:1.02rem; color:var(--ink-soft); line-height:1.75; }
.trm-panel p:last-child{ margin-bottom:0; }

/* RESPONSIBLE GAMBLING */
.trm-rg{ background:linear-gradient(120deg,var(--wash),var(--wash-2)); border:1px solid var(--line); border-left:5px solid var(--teal); border-radius:var(--r); padding:30px 34px; box-shadow:var(--shadow-sm); margin-top:8px; position:relative; }
.trm-rg h2{ font-size:1.5rem; color:var(--indigo); margin-bottom:12px; display:flex; align-items:center; gap:12px; }
.trm-rg h2::before{ content:""; width:34px; height:34px; flex:0 0 auto; border-radius:9px; background:var(--teal); -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z'/%3E%3C/svg%3E") center/20px no-repeat; mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z'/%3E%3C/svg%3E") center/20px no-repeat; }
.trm-rg p{ font-size:1.02rem; color:var(--ink-soft); margin:0; line-height:1.75; }
.trm-rg .trm-helpline{ display:inline-block; margin-top:16px; background:var(--grad); color:#fff !important; font-family:var(--head); font-weight:700; font-size:1.05rem; padding:12px 22px; border-radius:999px; box-shadow:0 5px 16px rgba(15,123,120,.3); }

/* DISCLOSURE */
.trm-disclosure{ margin-top:40px; padding:22px 26px; background:var(--wash); border:1px dashed var(--line-2); border-radius:var(--r); color:var(--muted); font-size:.88rem; line-height:1.6; }
.trm-disclosure em{ font-style:normal; }

/* RESPONSIVE */
@media (max-width:1000px){
  .trm-hero{ grid-template-columns:1fr; }
  .trm-spotlight{ grid-template-columns:1fr; }
  .trm-navgrid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .trm-page{ font-size:16px; }
  .trm-wrap{ padding:0 16px; }
  .trm-hero-l{ padding:34px 26px; }
  .trm-hero-l h1{ font-size:2.4rem; }
  .trm-sh h2{ font-size:1.7rem; }
  .trm-navgrid,.trm-srgrid,.trm-concepts{ grid-template-columns:1fr; }
  .trm-spot-l,.trm-panel,.trm-rg{ padding:24px 22px; }
}

/* helpers (moved off inline styles) */
.trm-sub-lead{ margin-top:26px; }
.trm-table-title{ font-size:1.35rem; color:var(--indigo); margin:34px 0 14px; }
