/*
Theme Name: Bitcoin Casino Deutsch
Theme URI: https://bitcoincasino-deutsch.de
Description: Premium German Bitcoin Casino affiliate theme
Version: 1.0.0
Author: bitcoincasino-deutsch.de
Text Domain: nokyc
*/
:root {
    --bg-primary: #080B1A;
    --bg-alt: #0E1225;
    --bg-card: #131836;
    --bg-card-hover: #1A2044;
    --bg-input: #0F1328;
    --accent: #F59E0B;
    --accent-hover: #D97706;
    --accent-glow: rgba(245,158,11,0.15);
    --secondary: #10B981;
    --secondary-hover: #059669;
    --red: #EF4444;
    --text: #E2E8F0;
    --text-muted: #94A3B8;
    --text-dim: #64748B;
    --border: rgba(148,163,184,0.1);
    --border-accent: rgba(245,158,11,0.3);
    --radius: 8px;
    --max-width: 1280px;
    --font-heading: 'Space Grotesk', sans-serif;
    --font-body: 'Inter', sans-serif;
    --gradient-hero: linear-gradient(170deg,#080B1A 0%,#0E1225 50%,#131836 100%);
    --gradient-card: linear-gradient(135deg,rgba(19,24,54,0.8) 0%,rgba(14,18,37,0.9) 100%);
    --shadow-card: 0 4px 24px rgba(0,0,0,0.3);
    --shadow-glow: 0 0 30px rgba(245,158,11,0.1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text);line-height:1.7;font-size:16px;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-hover)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text);line-height:1.3;font-weight:700}
h1{font-size:2.5rem;margin-bottom:1rem}h2{font-size:1.8rem;margin-bottom:.8rem;margin-top:2rem}
h3{font-size:1.3rem;margin-bottom:.6rem;margin-top:1.5rem}p{margin-bottom:1rem}
.container{max-width:var(--max-width);margin:0 auto;padding:0 20px;width:100%}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(8,11,26,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 20px}
.header-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}
.site-logo{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--text)}
.site-logo span{color:var(--accent)}
.nav-menu{display:flex;gap:28px;list-style:none}
.nav-menu a{color:var(--text-muted);font-size:.9rem;font-weight:500;transition:color .2s}
.nav-menu a:hover,.nav-menu a.active{color:var(--accent)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);margin:5px 0;transition:.3s;border-radius:2px}
.mobile-nav{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:rgba(8,11,26,.98);z-index:999;padding:40px 20px}
.mobile-nav.active{display:flex;flex-direction:column;gap:24px}
.mobile-nav a{color:var(--text);font-size:1.2rem;font-weight:600}
.hero{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--gradient-hero);padding:80px 20px 60px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(245,158,11,.04) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(16,185,129,.03) 0%,transparent 50%);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:900px}
.hero h1{font-size:2.8rem;margin-bottom:1.2rem;background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero .subtitle{font-size:1.15rem;color:var(--text-muted);margin-bottom:1.5rem;line-height:1.6}
.hero .meta-line{font-size:.85rem;color:var(--text-dim);margin-bottom:.5rem}
.hero .author-line{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-dim)}
.hero .author-line img{width:28px;height:28px;border-radius:50%;object-fit:cover}
.hero-cta{display:inline-block;margin-top:24px;padding:14px 36px;background:var(--accent);color:#000;font-weight:700;font-size:1rem;border-radius:var(--radius);transition:all .3s;font-family:var(--font-heading)}
.hero-cta:hover{background:var(--accent-hover);color:#000;transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.inner-hero{min-height:40vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--gradient-hero);padding:80px 20px 50px;position:relative;overflow:hidden}
.inner-hero.tall{min-height:45vh}
.inner-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 80%,rgba(245,158,11,.05) 0%,transparent 60%);pointer-events:none}
.inner-hero-content{position:relative;z-index:1;max-width:800px}
.inner-hero h1{font-size:2.4rem;margin-bottom:1rem}
.inner-hero .subtitle{color:var(--text-muted);font-size:1.05rem}
.badge-row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:20px}
.badge{display:inline-flex;align-items:center;gap:6px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:var(--secondary);font-size:.8rem;font-weight:600;padding:6px 14px;border-radius:20px;font-family:var(--font-heading)}
.toc-wrapper{max-width:480px;margin:0 auto 48px;padding:0 20px}
.toc-box{background:rgba(19,24,54,0.6);border:1px solid rgba(245,158,11,0.25);border-radius:var(--radius);overflow:hidden}
.toc-toggle{width:100%;padding:12px 16px;background:transparent;border:none;color:var(--text-muted);font-size:.84rem;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-body);transition:color .2s}
.toc-toggle:hover{color:var(--accent)}
.toc-toggle .arrow{font-size:.65rem;color:var(--accent);transition:transform .3s ease}
.toc-toggle.active .arrow{transform:rotate(180deg)}
.toc-list{display:none;padding:0 16px 12px;list-style:none;margin:0}
.toc-list.active{display:block}
.toc-list li{padding:0}
.toc-list li a{display:block;padding:5px 8px;color:var(--text-dim);font-size:.8rem;border-radius:4px;transition:all .15s}
.toc-list li a:hover{color:var(--accent);background:rgba(245,158,11,0.06)}
.section-spacing{padding:60px 0}
.section-alt{background:var(--bg-alt)}
.section-primary{background:var(--bg-primary)}
.section-divider{display:flex;justify-content:center;align-items:center;padding:40px 0;gap:12px}
.section-divider span{width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:.4}
.grid-heading{text-align:left;margin-bottom:32px}
.casino-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.casino-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .3s;position:relative;overflow:hidden}
.casino-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}
.casino-card .rank-badge{position:absolute;top:12px;right:12px;background:var(--accent);color:#000;font-weight:800;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-family:var(--font-heading)}
.casino-card .card-logo{width:100%;height:60px;object-fit:contain;margin-bottom:12px;background:rgba(255,255,255,.03);border-radius:6px;padding:8px}
.casino-card .card-name{font-size:1.1rem;font-weight:700;margin-bottom:4px;font-family:var(--font-heading)}
.casino-card .card-rating{color:var(--accent);font-size:.9rem;margin-bottom:10px}
.casino-card .card-bonus{font-size:.95rem;color:var(--secondary);font-weight:600;margin-bottom:10px;line-height:1.4}
.casino-card .card-details{font-size:.8rem;color:var(--text-muted);margin-bottom:4px}
.casino-card .card-details strong{color:var(--text);font-weight:600}
.card-badge{display:inline-block;font-size:.7rem;padding:3px 8px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:var(--secondary);border-radius:12px;margin:8px 0;font-weight:600}
.payment-icons{display:flex;gap:6px;margin:10px 0;flex-wrap:wrap;align-items:center}
.payment-icons .pay-icon{width:32px;height:20px;background:rgba(255,255,255,.06);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.55rem;color:var(--text-dim);font-weight:700;font-family:var(--font-heading)}
.bonus-details-toggle{background:none;border:none;color:var(--text-dim);font-size:.75rem;cursor:pointer;padding:4px 0;display:flex;align-items:center;gap:4px;transition:color .2s;font-family:var(--font-body)}
.bonus-details-toggle:hover{color:var(--accent)}
.bonus-details-toggle .bd-arrow{transition:transform .3s;font-size:.65rem}
.bonus-details-toggle.active .bd-arrow{transform:rotate(180deg)}
.bonus-details-content{display:none;font-size:.78rem;color:var(--text-dim);padding:8px 0 4px;line-height:1.5;border-top:1px solid var(--border);margin-top:6px}
.bonus-details-content.active{display:block}
.card-cta{display:block;text-align:center;padding:12px;margin-top:14px;background:var(--accent);color:#000;font-weight:700;font-size:.9rem;border-radius:var(--radius);transition:all .3s;font-family:var(--font-heading);letter-spacing:.5px}
.card-cta:hover{background:var(--accent-hover);color:#000;transform:translateY(-1px)}
.card-terms{font-size:.65rem;color:var(--text-dim);margin-top:8px;line-height:1.4;text-align:center}
.reviews-heading{margin-bottom:40px}
.review-block{margin-bottom:48px}
.review-topbar{display:flex;align-items:center;gap:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:20px;flex-wrap:wrap}
.review-topbar .review-logo{width:48px;height:48px;object-fit:contain;border-radius:6px}
.review-topbar h3{font-size:1.2rem;flex:1;margin:0}
.review-topbar .review-stars{color:var(--accent);font-size:.95rem}
.review-topbar .review-cta{padding:8px 20px;background:var(--accent);color:#000;font-weight:700;border-radius:var(--radius);font-size:.85rem;transition:all .2s;font-family:var(--font-heading)}
.review-topbar .review-cta:hover{background:var(--accent-hover);color:#000}
.review-screenshots{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.review-screenshots img{width:100%;height:200px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;transition:opacity .2s}
.review-screenshots img:hover{opacity:.85}
.review-body{line-height:1.7}
.review-body h3{color:var(--accent);font-size:1.1rem}
.pros-cons-table{width:100%;border-collapse:collapse;margin:20px 0;border-radius:var(--radius);overflow:hidden}
.pros-cons-table th{padding:12px 16px;font-weight:700;font-size:.9rem;font-family:var(--font-heading)}
.pros-cons-table th.pros-header{background:rgba(16,185,129,.15);color:var(--secondary);text-align:left}
.pros-cons-table th.cons-header{background:rgba(239,68,68,.15);color:var(--red);text-align:left}
.pros-cons-table td{padding:10px 16px;font-size:.88rem;vertical-align:top;border-bottom:1px solid var(--border)}
.pros-cons-table td.pros-cell{color:var(--text)}
.pros-cons-table td.cons-cell{color:var(--text-muted)}
.pros-cons-table tr:last-child td{border-bottom:none}
.two-col-section{display:flex;gap:40px;align-items:flex-start}
.two-col-section.img-left .col-image{order:1;flex:0 0 40%}
.two-col-section.img-left .col-text{order:2;flex:0 0 60%;max-width:60%}
.two-col-section.img-right .col-text{order:1;flex:0 0 60%;max-width:60%}
.two-col-section.img-right .col-image{order:2;flex:0 0 40%}
.col-image img{width:100%;height:auto;border-radius:var(--radius)}
.image-placeholder{width:100%;min-height:200px;border:2px dashed var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:.8rem;text-align:center;padding:20px}
.content-section{line-height:1.75}
.content-section h2{color:var(--accent);margin-top:0}
.content-section h3{color:var(--text)}
.content-section strong{color:var(--text)}
.content-section table{width:100%;border-collapse:collapse;margin:16px 0}
.content-section table th{background:var(--bg-card);color:var(--accent);padding:10px 12px;text-align:left;font-size:.85rem;font-weight:600;font-family:var(--font-heading);position:sticky;top:0}
.content-section table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:.88rem;color:var(--text-muted)}
.content-section table tr:hover td{background:rgba(245,158,11,.03)}
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border);margin:16px 0}
.table-responsive table{margin:0;border:none}
.table-responsive table td,.table-responsive table th{min-width:120px;white-space:nowrap}
.faq-section{max-width:900px}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}
.faq-question{width:100%;padding:16px 20px;background:var(--bg-card);border:none;color:var(--text);font-size:.95rem;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;transition:background .2s;font-family:var(--font-heading);min-height:48px;line-height:1.4}
.faq-question:hover{background:var(--bg-card-hover)}
.faq-question .faq-icon{color:var(--accent);font-size:1.2rem;font-weight:300;transition:transform .3s;flex-shrink:0;margin-left:12px;width:24px;text-align:center}
.faq-question.active .faq-icon{transform:rotate(45deg)}
.faq-answer{display:none;padding:16px 20px;font-size:.9rem;color:var(--text-muted);line-height:1.7;background:var(--bg-primary)}
.faq-answer.active{display:block}
.author-box{display:flex;gap:20px;align-items:flex-start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-top:40px}
.author-box img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-box .author-info h4{font-size:1rem;margin-bottom:4px;color:var(--accent)}
.author-box .author-info p{font-size:.85rem;color:var(--text-muted);margin:0;line-height:1.6}
.page-content{padding:60px 0}
.page-content .container{max-width:900px}
.page-content h2{color:var(--accent);margin-top:2rem}
.page-content h3{margin-top:1.5rem}
.page-content p{line-height:1.75;color:var(--text-muted)}
.page-content strong{color:var(--text)}
.page-content table{width:100%;border-collapse:collapse;margin:16px 0}
.page-content table th{background:var(--bg-card);color:var(--accent);padding:10px 12px;text-align:left;font-size:.85rem;font-weight:600}
.page-content table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:.88rem;color:var(--text-muted)}
.contact-form-wrap{max-width:600px;margin:0 auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:6px;font-weight:600}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;font-family:var(--font-body);transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.form-group textarea{min-height:120px;resize:vertical}
.form-submit{width:100%;padding:14px;background:var(--accent);color:#000;border:none;border-radius:var(--radius);font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s;font-family:var(--font-heading)}
.form-submit:hover{background:var(--accent-hover)}
.contact-info-box{max-width:600px;margin:24px auto 0;padding:20px;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);text-align:center;font-size:.9rem;color:var(--text-muted)}
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);background:var(--secondary);color:#000;padding:12px 24px;border-radius:var(--radius);font-weight:600;font-size:.9rem;z-index:9999;display:none;box-shadow:0 4px 12px rgba(0,0,0,.3)}
.toast.active{display:block;animation:fadeInUp .3s ease}
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:10000;display:none;align-items:center;justify-content:center;cursor:zoom-out;padding:20px}
.lightbox-overlay.active{display:flex}
.lightbox-overlay img{max-width:95%;max-height:90vh;object-fit:contain;border-radius:var(--radius)}
.lightbox-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;z-index:10001}
.site-footer{background:var(--bg-alt);border-top:1px solid var(--border);padding:40px 20px;text-align:center}
.site-footer p{font-size:.8rem;color:var(--text-dim);margin-bottom:8px;line-height:1.6}
.site-footer a{color:var(--accent)}
.site-footer a:hover{color:var(--accent-hover);text-decoration:underline}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin:32px 0}
.team-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center}
.team-card img{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto 12px}
.team-card h4{font-size:1rem;color:var(--accent);margin-bottom:4px}
.team-card p{font-size:.85rem;color:var(--text-muted)}
@keyframes fadeInUp{from{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%,0)}}
@media(max-width:1024px){.casino-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.nav-menu{display:none}.hamburger{display:block}.hero h1{font-size:1.8rem}.hero{min-height:50vh;padding:60px 20px 40px}.inner-hero h1{font-size:1.6rem}.casino-grid{grid-template-columns:repeat(2,1fr);gap:12px}.casino-card{padding:16px}.review-topbar{flex-direction:column;text-align:center;gap:10px}.review-screenshots{grid-template-columns:1fr}.two-col-section{flex-direction:column}.two-col-section.img-left .col-image,.two-col-section.img-left .col-text,.two-col-section.img-right .col-image,.two-col-section.img-right .col-text{flex:1 1 100%;max-width:100%;order:initial}.two-col-section .col-image{order:-1!important}.author-box{flex-direction:column;align-items:center;text-align:center}.team-grid{grid-template-columns:1fr}.badge-row{gap:8px}.badge{font-size:.7rem;padding:4px 10px}.table-responsive table td,.table-responsive table th{font-size:13px;min-width:100px}h1{font-size:1.6rem}h2{font-size:1.4rem}.section-spacing{padding:40px 0}.content-section table td,.content-section table th,.page-content table td,.page-content table th{font-size:13px;min-width:100px}}
@media(max-width:480px){.casino-grid{grid-template-columns:1fr 1fr;gap:10px}.casino-card{padding:12px}.casino-card .card-logo{height:40px}.casino-card .card-name{font-size:.85rem}.casino-card .card-bonus{font-size:.82rem}.casino-card .card-details{font-size:.72rem}.card-cta{font-size:.8rem;padding:10px}}
