/* StarduNord.net — Beste Casino NO — main.css */
/* font-display:swap — OBIGATORISK for alle @font-face (LCP optimalisering) */
@font-face{font-family:'Inter';font-display:swap}

:root {
  --bg:#FFFFFF;
  --bg-alt:#F8F9FA;
  --border:#E5E7EB;
  --text:#111827;
  --muted:#6B7280;
  --accent:#16A34A;
  --dark:#0f172a;
  --dark2:#1e293b;
  --radius:8px;
  --font:'Inter',system-ui,sans-serif;
}

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

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

body{
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  font-size:16px;
}

img{max-width:100%;height:auto}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* CONTAINER */
.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 16px;
}

/* HEADER */
.site-header{
  background:var(--dark);
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 2px 8px rgba(0,0,0,.3);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:64px;
  gap:16px;
}

.logo{
  display:flex;
  align-items:center;
  gap:8px;
  color:#fff;
  font-weight:700;
  font-size:1.2rem;
  text-decoration:none;
}

.logo-icon{font-size:1.4rem}
.logo-text{color:#fff}

.main-nav ul{
  display:flex;
  list-style:none;
  gap:24px;
}

.main-nav a{
  color:#cbd5e1;
  font-size:.9rem;
  font-weight:500;
  transition:color .2s;
}

.main-nav a:hover{color:#fff;text-decoration:none}

.nav-author{color:var(--accent)!important}

/* HAMBURGER */
.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:4px;
}

.hamburger span{
  display:block;
  width:24px;
  height:2px;
  background:#fff;
  transition:transform .3s;
}

/* MOBILE NAV */
.mobile-nav{display:none}

@media(max-width:768px){
  .main-nav{display:none}
  .hamburger{display:flex}
  .mobile-nav.open{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:64px;
    left:0;
    right:0;
    background:var(--dark);
    padding:16px;
    z-index:99;
  }
  .mobile-nav ul{
    list-style:none;
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  .mobile-nav a{
    color:#cbd5e1;
    font-size:1rem;
    font-weight:500;
    display:block;
    padding:8px 0;
    border-bottom:1px solid #1e293b;
  }
}

/* HERO */
.hero{
  background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%)!important;
  color:#fff;
  padding:64px 0 48px;
}

.hero h1,.hero-desc{color:#f1f5f9}

.hero-content{max-width:800px}

.hero-badge{
  display:inline-block;
  background:rgba(22,163,74,.2);
  color:#4ade80;
  border:1px solid rgba(22,163,74,.4);
  padding:6px 16px;
  border-radius:20px;
  font-size:.85rem;
  font-weight:600;
  margin-bottom:20px;
}

.hero h1{
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;
  line-height:1.2;
  margin-bottom:16px;
}

.hero-desc{
  font-size:1.1rem;
  color:#94a3b8;
  margin-bottom:32px;
  max-width:680px;
}

.hero-stats{
  display:flex;
  gap:32px;
  margin-bottom:32px;
  flex-wrap:wrap;
}

.stat-item{text-align:center}

.stat-number{
  font-size:2rem;
  font-weight:800;
  color:#4ade80;
}

.stat-label{
  font-size:.8rem;
  color:#94a3b8;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.hero-cta{margin-bottom:32px}

.btn-hero{
  font-size:1.1rem;
  padding:16px 36px;
  margin-bottom:16px;
  display:inline-flex;
}

.trust-stars{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:8px;
}

.trust-text{
  color:#94a3b8;
  font-size:.85rem;
}

.hero-author{
  display:flex;
  align-items:center;
  gap:12px;
  margin-top:24px;
  padding:16px;
  background:rgba(255,255,255,.05);
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.1);
  width:fit-content;
}

.hero-author img{
  border-radius:50%;
  object-fit:cover;
}

.author-name{color:#f1f5f9;font-weight:700}
.author-title{color:#94a3b8;font-size:.85rem}
.author-update{color:#64748b;font-size:.8rem;margin-top:4px}

/* BREADCRUMB */
.breadcrumb-nav{
  background:var(--bg-alt);
  padding:12px 0;
  border-bottom:1px solid var(--border);
}

.breadcrumb{
  display:flex;
  list-style:none;
  gap:8px;
  font-size:.85rem;
  color:var(--muted);
}

.breadcrumb li:not(:last-child)::after{content:" / "}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent)}

/* CONTENT SECTIONS */
.content-section{padding:64px 0}

.section-light{background:var(--bg)}
.section-alt{background:var(--bg-alt)}

.content-section h2{
  font-size:clamp(1.4rem,3vw,2rem);
  font-weight:700;
  color:var(--dark);
  margin-bottom:24px;
  display:block;
  width:100%;
  float:none;
  clear:both;
}

/* H2 BANNER */
.h2-banner-wrap{
  display:block;
  width:calc(100% + 32px);
  margin-left:-16px;
  margin-bottom:32px;
  overflow:hidden;
  line-height:0;
  clear:both;
}

.h2-banner-img{
  display:block;
  width:100%;
  aspect-ratio:3/1;
  object-fit:cover;
}

@media(max-width:767px){
  .h2-banner-img{
    aspect-ratio:1/1;
    object-position:center top;
  }
}

.h2-banner-wrap figcaption{
  font-size:11px;
  color:#6b7280;
  text-align:right;
  padding:4px 8px 0;
  font-style:italic;
  line-height:1.4;
}

/* SECTION BODY */
.section-body p{
  margin-bottom:16px;
  color:var(--text);
  line-height:1.7;
}

.section-body ul{
  list-style:none;
  margin:24px 0;
  display:grid;
  gap:8px;
}

.section-body ul li{
  padding:8px 16px;
  background:var(--bg);
  border-left:3px solid var(--accent);
  border-radius:0 var(--radius) var(--radius) 0;
  font-size:.95rem;
}

.section-alt .section-body ul li{background:#fff}

/* TABLE */
.table-wrap{
  overflow-x:auto;
  margin:24px 0;
  border-radius:var(--radius);
  border:1px solid var(--border);
}

table{
  width:100%;
  border-collapse:collapse;
  font-size:.9rem;
}

th{
  background:var(--dark);
  color:#fff;
  padding:12px 16px;
  text-align:left;
  font-weight:600;
  white-space:nowrap;
}

td{
  padding:10px 16px;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}

tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(22,163,74,.05)}

/* VITRINA */
.vitrina-section{
  background:var(--dark);
  padding:64px 0;
}

.vitrina-header{
  text-align:center;
  margin-bottom:40px;
}

.vitrina-title{
  font-size:clamp(1.4rem,3vw,2rem);
  font-weight:800;
  color:#fff;
  margin-bottom:12px;
}

.vitrina-desc{
  color:#94a3b8;
  font-size:1rem;
}

.vitrina-grid{
  display:grid;
  gap:16px;
}

.casino-card{
  background:var(--dark2);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  padding:24px;
  display:grid;
  grid-template-columns:48px 1fr auto;
  gap:20px;
  align-items:start;
  transition:border-color .2s,transform .2s;
}

.casino-card:hover{
  border-color:var(--accent);
  transform:translateY(-2px);
}

.casino-card.top-pick{
  border-color:rgba(22,163,74,.5);
  background:rgba(22,163,74,.08);
}

.casino-rank{
  width:48px;
  height:48px;
  background:rgba(22,163,74,.2);
  border:2px solid var(--accent);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:1.2rem;
  color:#4ade80;
  flex-shrink:0;
}

.casino-badge{
  display:inline-block;
  background:rgba(22,163,74,.2);
  color:#4ade80;
  border-radius:4px;
  padding:2px 10px;
  font-size:.8rem;
  font-weight:600;
  margin-bottom:8px;
}

.casino-name{
  font-size:1.2rem;
  font-weight:700;
  color:#fff;
  margin-bottom:6px;
}

.casino-license{
  color:#94a3b8;
  font-size:.85rem;
  margin-bottom:6px;
}

.casino-bonus{
  color:#fbbf24;
  font-size:.95rem;
  font-weight:600;
  margin-bottom:12px;
}

.casino-features{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.feature-tag{
  background:rgba(255,255,255,.07);
  color:#cbd5e1;
  padding:3px 10px;
  border-radius:4px;
  font-size:.8rem;
}

.casino-cta{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:12px;
  flex-shrink:0;
}

.casino-rating{
  color:#fbbf24;
  font-size:1rem;
  font-weight:700;
}

.vitrina-disclaimer{
  text-align:center;
  color:#64748b;
  font-size:.8rem;
  margin-top:24px;
}

@media(max-width:768px){
  .casino-card{
    grid-template-columns:1fr;
  }
  .casino-rank{
    width:36px;
    height:36px;
    font-size:1rem;
  }
  .casino-cta{
    align-items:stretch;
  }
  .casino-cta .btn-primary{
    text-align:center;
    justify-content:center;
  }
}

/* BTN PRIMARY */
.btn-primary{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:linear-gradient(135deg,#16A34A,#15803d);
  color:#fff;
  padding:14px 28px;
  border-radius:8px;
  font-weight:700;
  text-decoration:none;
  animation:pulse 2s infinite;
  font-size:.95rem;
  border:none;
  cursor:pointer;
  transition:background .2s;
  white-space:nowrap;
}

.btn-primary:hover{
  background:linear-gradient(135deg,#15803d,#166534);
  text-decoration:none;
  animation:none;
}

@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,.4)}
  50%{box-shadow:0 0 0 8px rgba(22,163,74,0)}
}

/* AUTHOR SECTION */
.author-section{padding:64px 0}

.author-box{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:40px;
  align-items:start;
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:40px;
}

.author-portrait img{
  width:160px;
  height:160px;
  object-fit:cover;
  border-radius:50%;
  border:3px solid var(--accent);
}

.author-badge{
  display:inline-block;
  background:rgba(22,163,74,.1);
  color:var(--accent);
  padding:4px 12px;
  border-radius:20px;
  font-size:.8rem;
  font-weight:600;
  margin-bottom:12px;
}

.author-box h3{
  font-size:1.5rem;
  font-weight:700;
  color:var(--dark);
  margin-bottom:4px;
}

.author-title-text{
  color:var(--muted);
  font-size:.9rem;
  margin-bottom:16px;
}

.author-bio{
  color:var(--text);
  line-height:1.7;
  margin-bottom:20px;
}

.expertise-title{
  font-weight:700;
  margin-bottom:8px;
  color:var(--dark);
}

.expertise-list{
  list-style:none;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-bottom:20px;
}

.expertise-list li{
  padding:6px 12px;
  background:var(--bg-alt);
  border-radius:var(--radius);
  font-size:.9rem;
  position:relative;
  padding-left:24px;
}

.expertise-list li::before{
  content:"✓";
  color:var(--accent);
  position:absolute;
  left:8px;
  font-weight:700;
}

.author-link{
  display:inline-block;
  color:var(--accent);
  font-weight:600;
  font-size:.9rem;
}

@media(max-width:768px){
  .author-box{
    grid-template-columns:1fr;
    padding:24px;
  }
  .author-portrait{text-align:center}
  .expertise-list{grid-template-columns:1fr}
}

/* REVIEWED BY */
.reviewed-by-section{padding:64px 0}

.section-title-sm{
  font-size:1.3rem;
  font-weight:700;
  color:var(--dark);
  margin-bottom:32px;
  text-align:center;
}

.reviewed-by-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}

@media(max-width:768px){
  .reviewed-by-cards{grid-template-columns:1fr}
}

.reviewer-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:24px;
}

.reviewer-header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}

.reviewer-header img{
  width:60px;
  height:60px;
  object-fit:cover;
  border-radius:50%;
  border:2px solid var(--border);
}

.reviewer-name{
  font-weight:700;
  color:var(--dark);
}

.reviewer-title{
  color:var(--muted);
  font-size:.85rem;
}

.reviewer-stars{
  color:#f59e0b;
  margin-bottom:12px;
  font-size:1.1rem;
}

.reviewer-quote{
  color:var(--text);
  font-size:.9rem;
  line-height:1.6;
  font-style:italic;
  border-left:3px solid var(--accent);
  padding-left:12px;
  margin-bottom:12px;
}

.reviewer-date{
  color:var(--muted);
  font-size:.8rem;
}

/* FAQ */
.faq-section{padding:64px 0}

.faq-section h2{
  font-size:clamp(1.4rem,3vw,2rem);
  font-weight:700;
  color:var(--dark);
  margin-bottom:40px;
  text-align:center;
}

.faq-list{display:grid;gap:8px}

.faq-item{
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
}

.faq-question{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px 24px;
  background:none;
  border:none;
  cursor:pointer;
  text-align:left;
  font-size:1rem;
  font-weight:600;
  color:var(--dark);
  gap:16px;
}

.faq-question:hover{background:var(--bg-alt)}

.faq-icon{
  font-size:1.4rem;
  color:var(--accent);
  flex-shrink:0;
  transition:transform .3s;
  font-weight:400;
}

.faq-question[aria-expanded="true"] .faq-icon{transform:rotate(45deg)}

.faq-answer{
  display:none;
  padding:0 24px 20px;
}

.faq-answer p{
  color:var(--text);
  line-height:1.7;
}

.faq-answer.open{display:block}

/* FOOTER */
.site-footer{
  background:var(--dark);
  color:#94a3b8;
  padding:48px 0 24px;
}

.footer-inner{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:40px;
  margin-bottom:32px;
}

@media(max-width:768px){
  .footer-inner{grid-template-columns:1fr}
}

.footer-logo{
  font-size:1.2rem;
  font-weight:700;
  color:#fff;
  margin-bottom:12px;
}

.footer-desc{
  font-size:.9rem;
  line-height:1.6;
}

.site-footer h4{
  color:#fff;
  font-size:.95rem;
  margin-bottom:16px;
}

.footer-links ul{
  list-style:none;
  display:grid;
  gap:8px;
}

.footer-links a{
  color:#94a3b8;
  font-size:.9rem;
  transition:color .2s;
}

.footer-links a:hover{color:#fff;text-decoration:none}

.footer-responsible p{
  font-size:.85rem;
  margin-bottom:8px;
}

.footer-responsible a{color:#94a3b8}
.footer-responsible a:hover{color:#fff}

.footer-disclaimer{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:24px;
  font-size:.8rem;
  color:#64748b;
  line-height:1.6;
}

.footer-disclaimer a{color:#64748b}
.footer-disclaimer a:hover{color:#94a3b8}

/* STICKY CTA */
.sticky-cta{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  background:var(--dark);
  padding:12px 16px;
  border-top:2px solid var(--accent);
  z-index:1000;
  display:none;
}

.sticky-cta:not([hidden]){display:block}

.sticky-btn{
  display:block;
  width:100%;
  text-align:center;
  padding:14px;
  background:linear-gradient(135deg,#16A34A,#15803d);
  color:#fff;
  font-weight:700;
  border-radius:var(--radius);
  font-size:1rem;
  text-decoration:none;
}

@media(min-width:769px){
  .sticky-cta{display:none!important}
}

/* POPUP */
.popup-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.7);
  z-index:2000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}

.popup-overlay[hidden]{display:none}

.popup-box{
  background:#fff;
  border-radius:16px;
  padding:40px 32px;
  max-width:480px;
  width:100%;
  position:relative;
  text-align:center;
  animation:slideUp .3s ease;
}

@keyframes slideUp{
  from{transform:translateY(20px);opacity:0}
  to{transform:translateY(0);opacity:1}
}

.popup-close{
  position:absolute;
  top:12px;
  right:16px;
  background:none;
  border:none;
  font-size:1.2rem;
  cursor:pointer;
  color:var(--muted);
  padding:4px;
}

.popup-icon{font-size:3rem;margin-bottom:16px}

.popup-box h3{
  font-size:1.4rem;
  font-weight:700;
  color:var(--dark);
  margin-bottom:12px;
}

.popup-box p{
  color:var(--muted);
  margin-bottom:20px;
}

.popup-btn{
  width:100%;
  justify-content:center;
  font-size:1rem;
  padding:16px;
  margin-bottom:12px;
}

.popup-disclaimer{
  font-size:.75rem!important;
  color:var(--muted)!important;
  margin:0!important;
}
