:root{
    --bg:#0a0b10;
    --bg-soft:#12141c;
    --bg-card:#171a24;
    --bg-card-2:#1d2230;
    --text:#f5f7fb;
    --text-soft:#afb7c9;
    --text-muted:#7d8597;
    --line:rgba(255,255,255,.08);
    --gold:#f3c969;
    --gold-2:#ffdd8a;
    --red:#ff4d6d;
    --green:#3fe08f;
    --blue:#67b7ff;
    --shadow:0 20px 50px rgba(0,0,0,.35);
    --radius:22px;
    --radius-sm:14px;
    --container:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Inter,Segoe UI,Arial,sans-serif;
    background:
        radial-gradient(circle at top left, rgba(255,77,109,.12), transparent 28%),
        radial-gradient(circle at top right, rgba(243,201,105,.10), transparent 30%),
        linear-gradient(180deg, #08090d 0%, #0e1118 100%);
    color:var(--text);
    line-height:1.6;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}

.container{
    width:min(var(--container), calc(100% - 32px));
    margin:0 auto;
}

.site-shell{min-height:100vh;display:flex;flex-direction:column}
.site-main{flex:1;padding-bottom:50px}

.site-header{
    position:sticky;
    top:0;
    z-index:40;
    backdrop-filter:blur(16px);
    background:rgba(8,10,14,.72);
    border-bottom:1px solid var(--line);
}

.header-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    min-height:80px;
}

.brand{
    display:flex;
    align-items:center;
    gap:14px;
    min-width:0;
}

.brand-mark{
    width:50px;
    height:50px;
    border-radius:16px;
    display:grid;
    place-items:center;
    font-weight:900;
    letter-spacing:.06em;
    background:
        linear-gradient(135deg, rgba(243,201,105,.25), rgba(255,77,109,.22));
    border:1px solid rgba(243,201,105,.35);
    box-shadow:0 12px 26px rgba(243,201,105,.12);
    color:var(--gold-2);
}

.brand-text-wrap{display:flex;flex-direction:column;line-height:1.05}
.brand-text{
    font-size:1.25rem;
    font-weight:900;
    letter-spacing:.02em;
}
.brand-subtext{
    font-size:.8rem;
    color:var(--text-muted);
}

.main-nav{
    display:flex;
    align-items:center;
    gap:22px;
}

.main-nav > a{
    color:var(--text-soft);
    font-weight:700;
    transition:.2s ease;
}

.main-nav > a:hover,
.main-nav > a.active{
    color:var(--text);
}

.nav-actions{
    display:flex;
    align-items:center;
    gap:10px;
    margin-left:10px;
}

.mobile-toggle{
    display:none;
    width:48px;
    height:48px;
    border-radius:14px;
    border:1px solid var(--line);
    background:var(--bg-card);
    color:var(--text);
    cursor:pointer;
}
.mobile-toggle span{
    display:block;
    width:20px;
    height:2px;
    margin:4px auto;
    background:var(--text);
    border-radius:999px;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:46px;
    padding:0 18px;
    border-radius:14px;
    border:1px solid transparent;
    font-weight:800;
    cursor:pointer;
    transition:.2s ease;
}

.btn-sm{
    min-height:40px;
    padding:0 14px;
    font-size:.92rem;
}

.btn-primary{
    color:#121212;
    background:linear-gradient(135deg, var(--gold), var(--gold-2));
    box-shadow:0 12px 24px rgba(243,201,105,.18);
}

.btn-primary:hover{transform:translateY(-1px)}

.btn-secondary{
    color:var(--text);
    background:rgba(255,255,255,.03);
    border-color:var(--line);
}

.btn-secondary:hover{
    background:rgba(255,255,255,.06);
}

.flash-wrap{padding-top:18px}
.flash{
    border-radius:18px;
    padding:14px 16px;
    font-weight:700;
    margin-bottom:12px;
}
.flash-success{
    background:rgba(63,224,143,.12);
    border:1px solid rgba(63,224,143,.28);
    color:#d7ffe8;
}
.flash-error{
    background:rgba(255,77,109,.12);
    border:1px solid rgba(255,77,109,.26);
    color:#ffd3db;
}

.hero{
    padding:54px 0 30px;
}

.hero-grid{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:26px;
    align-items:stretch;
}

.hero-card,
.panel,
.offer-card,
.info-card,
.casino-card{
    background:linear-gradient(180deg, rgba(23,26,36,.94), rgba(16,18,25,.96));
    border:1px solid var(--line);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}

.hero-card{
    padding:34px;
    position:relative;
    overflow:hidden;
}

.hero-card::before{
    content:"";
    position:absolute;
    inset:auto -60px -90px auto;
    width:220px;
    height:220px;
    background:radial-gradient(circle, rgba(243,201,105,.18), transparent 65%);
    pointer-events:none;
}

.eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:34px;
    padding:0 12px;
    border-radius:999px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--line);
    color:var(--gold-2);
    font-weight:800;
    font-size:.86rem;
    letter-spacing:.02em;
}

.hero h1{
    margin:18px 0 12px;
    font-size:clamp(2rem, 4vw, 4.2rem);
    line-height:.98;
    letter-spacing:-.03em;
}

.hero p{
    margin:0 0 22px;
    font-size:1.05rem;
    color:var(--text-soft);
    max-width:760px;
}

.hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
}

.hero-stats{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:14px;
    margin-top:28px;
}

.stat{
    padding:18px;
    border-radius:18px;
    background:rgba(255,255,255,.03);
    border:1px solid var(--line);
}
.stat strong{
    display:block;
    font-size:1.4rem;
    line-height:1;
    margin-bottom:6px;
}
.stat span{
    color:var(--text-muted);
    font-size:.92rem;
}

.hero-side{
    display:grid;
    gap:18px;
}

.panel{
    padding:22px;
}

.panel h3{
    margin:0 0 10px;
    font-size:1.1rem;
}

.panel p{
    margin:0;
    color:var(--text-soft);
}

.badge-row{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:16px;
}

.badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:32px;
    padding:0 11px;
    border-radius:999px;
    font-size:.82rem;
    font-weight:800;
    border:1px solid var(--line);
    background:rgba(255,255,255,.04);
    color:var(--text-soft);
}

.badge-gold{color:#1b1405;background:linear-gradient(135deg,var(--gold),var(--gold-2));border:none}
.badge-green{color:#032a15;background:linear-gradient(135deg,#50f0a0,#8ff5c3);border:none}
.badge-red{color:#3d0813;background:linear-gradient(135deg,#ff6a86,#ff9cae);border:none}

.section{
    padding:24px 0;
}

.section-head{
    display:flex;
    align-items:end;
    justify-content:space-between;
    gap:18px;
    margin-bottom:18px;
}

.section-head h2{
    margin:0;
    font-size:clamp(1.4rem, 2.4vw, 2.2rem);
    line-height:1.05;
}

.section-head p{
    margin:6px 0 0;
    color:var(--text-soft);
}

.grid{
    display:grid;
    gap:18px;
}

.grid-3{grid-template-columns:repeat(3, 1fr)}
.grid-4{grid-template-columns:repeat(4, 1fr)}
.grid-2{grid-template-columns:repeat(2, 1fr)}

.offer-card,
.info-card,
.casino-card{
    padding:20px;
    position:relative;
    overflow:hidden;
}

.offer-card:hover,
.info-card:hover,
.casino-card:hover{
    transform:translateY(-2px);
    transition:.2s ease;
}

.card-top{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:start;
    margin-bottom:14px;
}

.card-title{
    margin:0 0 8px;
    font-size:1.15rem;
    line-height:1.15;
}

.card-text{
    margin:0;
    color:var(--text-soft);
    font-size:.96rem;
}

.code-box{
    margin:18px 0 14px;
    padding:16px 18px;
    border-radius:16px;
    border:1px dashed rgba(243,201,105,.45);
    background:rgba(243,201,105,.07);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
}

.code-box strong{
    font-size:1.02rem;
    letter-spacing:.06em;
    color:var(--gold-2);
}

.meta-row{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-bottom:16px;
}

.meta-pill{
    display:inline-flex;
    align-items:center;
    min-height:30px;
    padding:0 10px;
    border-radius:999px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--line);
    color:var(--text-muted);
    font-size:.8rem;
    font-weight:700;
}

.card-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.info-icon{
    width:52px;
    height:52px;
    border-radius:18px;
    display:grid;
    place-items:center;
    font-weight:900;
    font-size:1.05rem;
    background:rgba(255,255,255,.04);
    border:1px solid var(--line);
    color:var(--gold-2);
    margin-bottom:16px;
}

.newsletter-box{
    padding:26px;
    display:grid;
    grid-template-columns:1.15fr .85fr;
    gap:22px;
    align-items:center;
}

.newsletter-form{
    display:grid;
    grid-template-columns:1fr auto;
    gap:12px;
}

.input,
.textarea{
    width:100%;
    border:1px solid var(--line);
    background:rgba(255,255,255,.03);
    color:var(--text);
    border-radius:14px;
    padding:0 16px;
    outline:none;
}

.input{min-height:50px}
.textarea{padding:14px 16px;min-height:140px;resize:vertical}

.input:focus,
.textarea:focus{
    border-color:rgba(243,201,105,.45);
    box-shadow:0 0 0 4px rgba(243,201,105,.08);
}

.site-footer{
    border-top:1px solid var(--line);
    background:rgba(10,12,18,.78);
    padding-top:34px;
}

.footer-grid{
    display:grid;
    grid-template-columns:1.2fr .8fr .8fr .8fr;
    gap:24px;
}

.footer-col h3{
    margin:0 0 10px;
    font-size:1rem;
}

.footer-brand{
    font-size:1.3rem;
    font-weight:900;
    margin-bottom:12px;
}

.footer-text,
.footer-note{
    color:var(--text-soft);
}

.footer-links{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    gap:8px;
}

.footer-links a{
    color:var(--text-soft);
}
.footer-links a:hover{color:var(--text)}

.footer-bottom{
    padding:18px 0 24px;
    margin-top:18px;
    border-top:1px solid var(--line);
    color:var(--text-muted);
    font-size:.92rem;
}

.cookie-banner{
    position:fixed;
    left:16px;
    right:16px;
    bottom:16px;
    z-index:60;
}

.cookie-banner-inner{
    width:min(960px, 100%);
    margin:0 auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    padding:18px;
    border-radius:20px;
    background:rgba(16,18,25,.96);
    border:1px solid var(--line);
    box-shadow:var(--shadow);
}

.cookie-banner-text{
    display:flex;
    flex-direction:column;
    gap:6px;
}
.cookie-banner-text span{color:var(--text-soft)}

.cookie-banner-actions{
    display:flex;
    gap:10px;
    flex-shrink:0;
}

@media (max-width: 1080px){
    .hero-grid,
    .newsletter-box,
    .footer-grid,
    .grid-4{
        grid-template-columns:1fr 1fr;
    }

    .grid-3{
        grid-template-columns:1fr 1fr;
    }
}

@media (max-width: 820px){
    .mobile-toggle{display:block}

    .main-nav{
        position:absolute;
        left:16px;
        right:16px;
        top:86px;
        display:none;
        flex-direction:column;
        align-items:stretch;
        gap:14px;
        padding:18px;
        border-radius:20px;
        background:rgba(16,18,25,.98);
        border:1px solid var(--line);
        box-shadow:var(--shadow);
    }

    .main-nav.is-open{display:flex}
    .nav-actions{
        margin-left:0;
        flex-direction:column;
    }

    .nav-actions .btn{width:100%}

    .hero-grid,
    .grid-3,
    .grid-2,
    .newsletter-box,
    .footer-grid{
        grid-template-columns:1fr;
    }

    .hero-card{padding:26px}
    .hero-stats{grid-template-columns:1fr}
    .newsletter-form{grid-template-columns:1fr}
    .cookie-banner-inner{
        flex-direction:column;
        align-items:stretch;
    }
    .cookie-banner-actions{
        width:100%;
        flex-direction:column;
    }
}

@media (max-width: 560px){
    .container{
        width:min(var(--container), calc(100% - 22px));
    }

    .header-inner{
        min-height:72px;
    }

    .brand-subtext{display:none}

    .hero{
        padding-top:24px;
    }

    .hero h1{
        font-size:2.1rem;
    }

    .btn,
    .input{
        min-height:48px;
    }

    .code-box{
        flex-direction:column;
        align-items:flex-start;
    }
}