*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:62.5%;scroll-behavior:smooth;overflow-x:hidden}
body{font-family:"Source Sans 3",system-ui,sans-serif;font-size:1.7rem;line-height:1.75;color:#1C1917;background:#FAF7F2;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:#047857;text-decoration:none;transition:color .2s}
a:hover{color:#059669}
.container{width:100%;max-width:128rem;margin:0 auto;padding:0 2rem}
:root{--green:#047857;--green-dark:#064E3B;--gold:#D97706;--cream:#FFFBEB;--border:#E7E5E4;--widget-scale:.78;--header-h:6.4rem}

/* Top bar */
.top-bar{background:var(--green-dark);color:rgba(255,255,255,.85);font-size:1.3rem;text-align:center;padding:.7rem 1rem}
.top-bar strong{color:#FBBF24}

/* Header */
.site-header{position:sticky;top:0;z-index:200;background:#fff;border-bottom:3px solid var(--green);box-shadow:0 2px 12px rgba(6,78,59,.06)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.6rem;padding:1.2rem 0;min-height:var(--header-h)}
.site-logo{display:flex;align-items:center;flex-shrink:0}
.site-logo img{height:3.6rem;width:auto}
.site-nav ul{display:flex;flex-wrap:wrap;gap:.2rem;list-style:none;align-items:center}
.site-nav a{display:block;padding:.7rem 1.2rem;font-size:1.45rem;font-weight:600;color:#44403C;border-radius:.6rem;transition:background .2s,color .2s}
.site-nav a:hover,.site-nav a[aria-current="page"]{background:var(--cream);color:var(--green-dark)}
.site-nav .nav-divider{width:1px;height:1.8rem;background:var(--border);margin:0 .4rem}
.menu-toggle{display:none;flex-direction:column;gap:.45rem;padding:.8rem;background:none;border:2px solid var(--border);border-radius:.6rem;cursor:pointer}
.menu-toggle span{display:block;width:2.2rem;height:.2rem;background:var(--green-dark);border-radius:2px;transition:transform .2s,opacity .2s}
.menu-toggle--active span:nth-child(1){transform:translateY(.65rem) rotate(45deg)}
.menu-toggle--active span:nth-child(2){opacity:0}
.menu-toggle--active span:nth-child(3){transform:translateY(-.65rem) rotate(-45deg)}

/* Hero intro */
.hero-intro{background:linear-gradient(160deg,var(--green-dark) 0%,#065F46 55%,var(--green) 100%);color:#fff;padding:4rem 0 3.2rem;position:relative;overflow:hidden}
.hero-intro::after{content:"";position:absolute;right:-8%;top:-30%;width:45%;height:160%;background:radial-gradient(circle,rgba(251,191,36,.12) 0%,transparent 65%);pointer-events:none}
.hero-intro__inner{position:relative;max-width:84rem}
.hero-intro__label{display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1.4rem;padding:.45rem 1.2rem;font-size:1.25rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:10rem;color:#FDE68A}
.hero-intro h1{font-family:"Fraunces",Georgia,serif;font-size:clamp(2.6rem,4.8vw,4rem);font-weight:700;line-height:1.18;margin-bottom:1.4rem;max-width:72rem}
.hero-intro__lead{font-size:1.75rem;line-height:1.65;color:rgba(255,255,255,.9);max-width:72rem}

/* Layout with TOC */
.page-layout{display:grid;grid-template-columns:24rem 1fr;gap:3.2rem;align-items:start;padding:3.2rem 0 5rem}
.toc{position:sticky;top:calc(var(--header-h) + 1.6rem);max-height:calc(100vh - var(--header-h) - 3rem);overflow-y:auto;padding:2rem;background:#fff;border:1px solid var(--border);border-radius:1.2rem;box-shadow:0 4px 20px rgba(28,25,23,.04)}
.toc__title{font-family:"Fraunces",Georgia,serif;font-size:1.5rem;font-weight:700;color:var(--green-dark);margin-bottom:1.2rem;padding-bottom:1rem;border-bottom:2px solid var(--cream)}
.toc ol{list-style:none;counter-reset:toc}
.toc li{margin-bottom:.3rem}
.toc a{display:block;padding:.55rem .8rem;font-size:1.35rem;font-weight:500;color:#57534E;border-radius:.5rem;border-left:3px solid transparent;transition:all .2s;line-height:1.4}
.toc a:hover,.toc a.is-active{background:var(--cream);color:var(--green-dark);border-left-color:var(--gold)}
.toc ol ol{padding-left:1rem;margin-top:.2rem}
.toc ol ol a{font-size:1.25rem;font-weight:400}

/* Article */
.article{min-width:0}
.article p{margin-bottom:1.5rem}
.article h2{font-family:"Fraunces",Georgia,serif;font-size:2.6rem;font-weight:700;color:var(--green-dark);margin:4rem 0 1.2rem;line-height:1.25;scroll-margin-top:calc(var(--header-h) + 1.2rem)}
.article h2:first-of-type{margin-top:0}
.article h3{font-size:2rem;font-weight:700;color:#292524;margin:2.8rem 0 1rem;scroll-margin-top:calc(var(--header-h) + 1.2rem)}
.article h4{font-size:1.7rem;font-weight:600;color:#44403C;margin:2rem 0 .8rem}
.article ul,.article ol{margin:1.2rem 0 1.6rem 2.2rem}
.article li{margin-bottom:.55rem}
.article-img{display:inline-block;width:auto;max-width:18rem;margin:1.2rem 0;border-radius:.8rem}

/* Widget */
.widget-section{margin:2.4rem 0;padding:2rem;background:#fff;border:2px solid var(--border);border-radius:1.2rem;overflow:hidden;touch-action:pan-y}
.widget-section__label{font-family:"Fraunces",Georgia,serif;font-size:1.8rem;font-weight:700;color:var(--green-dark);margin-bottom:1.2rem}
.widget-wrap{width:100%;overflow:hidden;touch-action:pan-y}
.widget-wrap__scale{width:calc(100% / var(--widget-scale));transform:scale(var(--widget-scale));transform-origin:top left}
.widget-wrap iframe{width:100%;border:none;display:block;overflow:hidden;pointer-events:auto}

/* Author byline */
.author-byline{display:flex;align-items:center;gap:1.6rem;margin:2.4rem 0;padding:1.8rem 2rem;background:var(--cream);border-radius:1.2rem;border:1px solid #FDE68A}
.author-byline__avatar{width:6rem;height:6rem;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.08);flex-shrink:0}
.author-byline__name{font-size:1.8rem;font-weight:700;color:var(--green-dark)}
.author-byline__role{font-size:1.4rem;color:#78716C}
.author-byline__meta{font-size:1.3rem;color:#A8A29E;margin-top:.3rem}

/* Casino cards */
.casino-showcase{display:flex;flex-direction:column;gap:2.4rem;margin:2rem 0}
.casino-item{padding:2rem;background:#fff;border:1px solid var(--border);border-radius:1.2rem;border-left:5px solid var(--green);box-shadow:0 2px 12px rgba(28,25,23,.03)}
.casino-item__head{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.casino-item__rank{display:inline-flex;align-items:center;justify-content:center;min-width:3rem;height:3rem;font-size:1.4rem;font-weight:800;color:#fff;background:var(--gold);border-radius:.6rem;flex-shrink:0}
.casino-item__name{font-family:"Fraunces",Georgia,serif;font-size:2.2rem;color:var(--green-dark);margin:0}
.data-table{width:100%;border-collapse:collapse;margin:1.2rem 0 1.4rem;font-size:1.45rem;border:1px solid var(--border);table-layout:fixed}
.data-table th,.data-table td{padding:.85rem 1.1rem;text-align:left;border:1px solid var(--border);vertical-align:top}
.data-table th{width:30%;font-weight:700;color:#57534E;background:#FAFAF9}
.data-table td{color:#1C1917}
.score-pill{display:inline-block;padding:.25rem .9rem;font-size:1.35rem;font-weight:700;color:#047857;background:#D1FAE5;border-radius:10rem}

/* Info grid */
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin:2rem 0}
.info-card{padding:1.8rem;background:#fff;border:1px solid var(--border);border-radius:1rem;border-top:4px solid var(--green)}
.info-card h3{font-size:1.65rem;margin:0 0 .7rem;color:var(--green-dark)}
.info-card p{font-size:1.45rem;color:#57534E;margin:0;line-height:1.6}

/* Feature list */
.check-list{list-style:none;margin:1.6rem 0;padding:0}
.check-list li{position:relative;padding:1rem 1rem 1rem 3.2rem;margin-bottom:.8rem;background:#fff;border:1px solid var(--border);border-radius:.8rem;font-size:1.55rem}
.check-list li::before{content:"✓";position:absolute;left:1.1rem;top:1rem;font-weight:800;color:var(--green)}
.warn-list li{border-left:4px solid #DC2626}
.warn-list li::before{content:"!";color:#DC2626}

/* Payment row */
.pay-row{display:flex;flex-wrap:wrap;gap:1rem;margin:1.6rem 0}
.pay-chip{display:flex;align-items:center;gap:.8rem;padding:1rem 1.4rem;background:#fff;border:1px solid var(--border);border-radius:10rem;font-weight:600;font-size:1.45rem}
.pay-chip img{width:2.4rem;height:2.4rem;object-fit:contain}

/* FAQ */
.faq-block{margin:2rem 0}
.faq-entry{border:1px solid var(--border);border-radius:1rem;margin-bottom:.8rem;background:#fff;overflow:hidden}
.faq-entry summary{padding:1.4rem 1.8rem;font-weight:700;font-size:1.65rem;color:var(--green-dark);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-entry summary::-webkit-details-marker{display:none}
.faq-entry summary::after{content:"+";font-size:2.2rem;color:var(--gold);font-weight:400;line-height:1}
.faq-entry[open] summary::after{content:"−"}
.faq-entry__body{padding:0 1.8rem 1.4rem;font-size:1.55rem;color:#57534E;line-height:1.65}

/* Author card */
.author-spotlight{display:grid;grid-template-columns:auto 1fr;gap:2.4rem;padding:2.8rem;background:var(--green-dark);border-radius:1.4rem;color:#fff;margin:3rem 0}
.author-spotlight__photo{width:12rem;height:12rem;border-radius:1rem;object-fit:cover;border:3px solid rgba(255,255,255,.2)}
.author-spotlight h3{font-family:"Fraunces",Georgia,serif;font-size:2.8rem;margin-bottom:.4rem;color:#fff}
.author-spotlight__role{font-size:1.55rem;color:rgba(255,255,255,.7);margin-bottom:1.2rem}
.author-spotlight p{font-size:1.55rem;line-height:1.7;color:rgba(255,255,255,.92);margin-bottom:1.2rem}
.tag-row{display:flex;flex-wrap:wrap;gap:.6rem;list-style:none}
.tag-row li{padding:.45rem 1.1rem;font-size:1.25rem;font-weight:600;background:rgba(255,255,255,.12);border-radius:10rem}

/* Inner page hero */
.page-banner{background:var(--green-dark);color:#fff;padding:3.6rem 0 2.8rem;text-align:center}
.page-banner h1{font-family:"Fraunces",Georgia,serif;font-size:clamp(2.4rem,4vw,3.4rem);margin-bottom:.8rem}
.page-banner p{font-size:1.65rem;color:rgba(255,255,255,.85);max-width:64rem;margin:0 auto}
.page-content{padding:4rem 0;max-width:84rem;margin:0 auto}

/* Contact */
.contact-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:2.4rem 0}
.contact-box{padding:2.4rem;background:#fff;border:1px solid var(--border);border-radius:1.2rem}
.contact-box h2{font-family:"Fraunces",Georgia,serif;font-size:2rem;color:var(--green-dark);margin-bottom:1rem}
.contact-box p{margin-bottom:.6rem;font-size:1.55rem;color:#57534E}
.contact-box a.contact-link{font-size:1.8rem;font-weight:700}

/* Footer form */
.footer-form{display:flex;flex-direction:column;gap:1rem;margin-top:1.2rem}
.footer-form input,.footer-form textarea{padding:1rem 1.2rem;font-family:inherit;font-size:1.45rem;border:1px solid rgba(255,255,255,.2);border-radius:.6rem;background:rgba(255,255,255,.08);color:#fff;width:100%}
.footer-form input::placeholder,.footer-form textarea::placeholder{color:rgba(255,255,255,.45)}
.footer-form textarea{min-height:8rem;resize:vertical}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:1.1rem 2.2rem;font-family:inherit;font-size:1.45rem;font-weight:700;color:#fff;background:var(--green);border:none;border-radius:.8rem;cursor:pointer;text-decoration:none;transition:background .2s,transform .2s}
.btn:hover{background:#059669;color:#fff;transform:translateY(-1px)}
.btn--gold{background:var(--gold)}
.btn--gold:hover{background:#B45309;color:#fff}
.btn--outline{background:transparent;border:2px solid #fff;color:#fff}
.btn--outline:hover{background:rgba(255,255,255,.12);color:#fff}

/* Footer */
.site-footer{background:#1C1917;color:rgba(255,255,255,.75);padding:4rem 0 2rem;margin-top:auto}
.site-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:2.4rem;margin-bottom:2.4rem;padding-bottom:2.4rem;border-bottom:1px solid rgba(255,255,255,.1)}
.site-footer__brand img{height:3.6rem;width:auto;margin-bottom:1rem}
.site-footer__brand a{display:inline-block;margin-bottom:1rem}
.site-footer__brand a img{margin-bottom:0}
.site-footer__brand p{font-size:1.45rem;line-height:1.65;max-width:34rem}
.site-footer h3{font-size:1.3rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#FBBF24;margin-bottom:1rem}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:.6rem}
.site-footer a{color:rgba(255,255,255,.7);font-size:1.45rem}
.site-footer a:hover{color:#fff}
.footer-contact p{font-size:1.45rem;margin-bottom:.5rem}
.footer-contact a{color:#FDE68A;font-weight:600}
.site-footer__badges{display:flex;gap:1rem;margin:1.2rem 0}
.site-footer__badges img{height:3.6rem;border-radius:.4rem}
.site-footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:1.3rem;color:rgba(255,255,255,.45)}
.responsible-strip{text-align:center;padding:1rem;background:rgba(217,119,6,.15);border-radius:.8rem;margin-bottom:2rem;font-weight:700;color:#FBBF24;font-size:1.4rem}

/* Cookie banner */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:300;background:#1C1917;color:rgba(255,255,255,.9);padding:1.6rem 2rem;box-shadow:0 -4px 24px rgba(0,0,0,.2);transform:translateY(100%);transition:transform .35s ease}
.cookie-banner.is-visible{transform:translateY(0)}
.cookie-banner__inner{max-width:128rem;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.6rem}
.cookie-banner p{font-size:1.45rem;line-height:1.55;flex:1;min-width:24rem}
.cookie-banner__actions{display:flex;gap:1rem;flex-shrink:0}

/* Scroll top */
.scroll-top{position:fixed;bottom:2rem;right:2rem;width:4.4rem;height:4.4rem;display:none;align-items:center;justify-content:center;background:var(--green);color:#fff;border:none;border-radius:50%;cursor:pointer;box-shadow:0 4px 16px rgba(4,120,87,.35);font-size:2rem;z-index:50}
.scroll-top:hover{transform:scale(1.05)}

/* 404 */
.error-page{text-align:center;padding:8rem 2rem;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}
.error-page h1{font-family:"Fraunces",Georgia,serif;font-size:8rem;color:var(--green-dark);line-height:1}
.error-page p{font-size:1.8rem;color:#57534E;margin:1.6rem 0 2.4rem;max-width:48rem}

/* Responsive */
@media(max-width:1024px){
  .page-layout{grid-template-columns:1fr}
  .toc{position:static;max-height:none;margin-bottom:1.6rem}
  .info-grid{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .author-spotlight{grid-template-columns:1fr;text-align:center}
  .author-spotlight__photo{margin:0 auto}
  .tag-row{justify-content:center}
}
@media(max-width:768px){
  .menu-toggle{display:flex}
  .site-nav{position:fixed;top:var(--header-h);left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:1.2rem 2rem;transform:translateY(-120%);opacity:0;visibility:hidden;transition:transform .25s,opacity .25s,visibility .25s;box-shadow:0 8px 24px rgba(0,0,0,.08)}
  .site-nav.site-nav--open{transform:translateY(0);opacity:1;visibility:visible}
  .site-nav ul{flex-direction:column;align-items:stretch}
  .site-nav .nav-divider{display:none}
  .site-nav a{padding:1rem}
  .contact-row{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr}
  .cookie-banner__inner{flex-direction:column;align-items:stretch}
  .cookie-banner__actions{justify-content:stretch}
  .cookie-banner__actions .btn{flex:1;justify-content:center}
  :root{--widget-scale:.65}
}
@media(max-width:480px){
  html{font-size:58%}
  .container{padding:0 1.4rem}
  :root{--widget-scale:.58}
}
