/*
Theme Name: Europe 777 Casino Satellite
Theme URI: https://europe777.com
Description: Satellite theme for Europe 777 Casino with centralized CTA link management.
Version: 1.0.0
Author: Europe 777
Text Domain: europe777-satellite
*/

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=Outfit:wght@400;500;600;700&display=swap');

:root {
  --clr-bg: #0a0e1e;
  --clr-bg-card: #111734;
  --clr-bg-card-hover: #1a2248;
  --clr-primary: #d4a832;
  --clr-primary-bright: #f0c44a;
  --clr-accent: #1c2868;
  --clr-accent-light: #283a8e;
  --clr-text: #eae8f0;
  --clr-text-muted: #9498b4;
  --clr-gold-glow: rgba(212, 168, 50, 0.12);
  --clr-border: rgba(212, 168, 50, 0.10);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Outfit', sans-serif;
  --radius: 14px;
  --radius-sm: 8px;
  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--clr-bg);
  color: var(--clr-text);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--clr-primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--clr-primary-bright); }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

.gold {
  background: linear-gradient(135deg, var(--clr-primary-bright), var(--clr-primary), #c89a20);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* HEADER */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(10, 14, 30, 0.92); backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--clr-border); padding: 14px 0;
}
.site-header .container { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.site-logo img { height: 48px; width: auto; }
.site-nav { display: flex; align-items: center; gap: 6px; }
.site-nav a { font-size: 0.88rem; font-weight: 500; color: var(--clr-text-muted); padding: 8px 16px; border-radius: var(--radius-sm); transition: all var(--transition); }
.site-nav a:hover, .site-nav a.current { color: var(--clr-primary); background: var(--clr-gold-glow); }

.header-cta {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, var(--clr-primary), #b89020);
  color: #0a0e1e !important; font-weight: 700; font-size: 0.88rem;
  padding: 10px 26px; border-radius: 50px; text-transform: uppercase; letter-spacing: 0.06em;
  transition: all var(--transition); box-shadow: 0 4px 22px rgba(212, 168, 50, 0.3);
}
.header-cta:hover { transform: translateY(-2px); box-shadow: 0 6px 30px rgba(212, 168, 50, 0.45); color: #0a0e1e !important; }
.mobile-toggle { display: none; background: none; border: none; color: var(--clr-primary); font-size: 1.5rem; cursor: pointer; }

/* HERO */
.hero { position: relative; padding: 100px 0 80px; text-align: center; overflow: hidden; }
.hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(212, 168, 50, 0.06), transparent), radial-gradient(ellipse 40% 60% at 80% 100%, rgba(28, 40, 104, 0.12), transparent);
  pointer-events: none;
}
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: var(--clr-gold-glow); border: 1px solid var(--clr-border); color: var(--clr-primary); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; padding: 8px 22px; border-radius: 50px; margin-bottom: 28px; animation: fadeDown 0.8s ease forwards; }
.hero h1 { font-family: var(--font-display); font-size: clamp(2.8rem, 6vw, 5.2rem); font-weight: 700; line-height: 1.1; margin-bottom: 20px; animation: fadeDown 0.8s 0.15s ease both; }
.hero-sub { font-size: 1.12rem; color: var(--clr-text-muted); max-width: 600px; margin: 0 auto 36px; animation: fadeDown 0.8s 0.3s ease both; }
.hero-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; animation: fadeDown 0.8s 0.45s ease both; }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-weight: 700; font-size: 1rem; padding: 14px 34px; border-radius: 50px; border: none; cursor: pointer; transition: all var(--transition); text-transform: uppercase; letter-spacing: 0.05em; }
.btn-primary { background: linear-gradient(135deg, var(--clr-primary), #b89020); color: #0a0e1e; box-shadow: 0 4px 24px rgba(212, 168, 50, 0.35); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(212, 168, 50, 0.5); color: #0a0e1e; }
.btn-outline { background: transparent; color: var(--clr-primary); border: 2px solid var(--clr-primary); }
.btn-outline:hover { background: var(--clr-gold-glow); transform: translateY(-2px); }
.btn-sm { font-size: 0.85rem; padding: 10px 22px; }

/* SECTIONS */
.section { padding: 80px 0; position: relative; }
.section-label { display: inline-flex; align-items: center; gap: 6px; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--clr-primary); margin-bottom: 12px; }
.section-title { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 2.8rem); font-weight: 700; margin-bottom: 16px; line-height: 1.15; }
.section-desc { color: var(--clr-text-muted); font-size: 1.05rem; max-width: 560px; margin-bottom: 48px; }
.section-desc.center { margin-left: auto; margin-right: auto; text-align: center; }

/* FEATURES */
.features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; }
.feature-card { background: var(--clr-bg-card); border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 36px 28px; transition: all var(--transition); position: relative; overflow: hidden; }
.feature-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, transparent, var(--clr-primary), transparent); opacity: 0; transition: opacity var(--transition); }
.feature-card:hover { border-color: rgba(212, 168, 50, 0.25); transform: translateY(-4px); background: var(--clr-bg-card-hover); }
.feature-card:hover::before { opacity: 1; }
.feature-icon { font-size: 2.4rem; margin-bottom: 16px; display: block; }
.feature-card h3 { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; margin-bottom: 10px; }
.feature-card p { color: var(--clr-text-muted); font-size: 0.95rem; line-height: 1.6; }

/* BONUS BANNER */
.bonus-banner { background: linear-gradient(135deg, var(--clr-accent) 0%, #0c1232 100%); border: 1px solid rgba(212, 168, 50, 0.18); border-radius: var(--radius); padding: 60px 48px; display: flex; align-items: center; justify-content: space-between; gap: 40px; position: relative; overflow: hidden; }
.bonus-banner::before { content: ''; position: absolute; top: -50%; right: -10%; width: 400px; height: 400px; background: radial-gradient(circle, rgba(212, 168, 50, 0.08), transparent 70%); pointer-events: none; }
.bonus-content h2 { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.4rem); font-weight: 700; margin-bottom: 12px; }
.bonus-content p { color: var(--clr-text-muted); font-size: 1.05rem; max-width: 480px; }

/* ARTICLES */
.articles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 28px; }
.article-card { background: var(--clr-bg-card); border: 1px solid var(--clr-border); border-radius: var(--radius); overflow: hidden; transition: all var(--transition); }
.article-card:hover { border-color: rgba(212, 168, 50, 0.25); transform: translateY(-4px); }
.article-card-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.article-card-body { padding: 24px; }
.article-card-meta { font-size: 0.8rem; color: var(--clr-text-muted); margin-bottom: 10px; display: flex; gap: 16px; }
.article-card-body h3 { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; margin-bottom: 10px; line-height: 1.35; }
.article-card-body h3 a { color: var(--clr-text); }
.article-card-body h3 a:hover { color: var(--clr-primary); }
.article-card-body p { color: var(--clr-text-muted); font-size: 0.92rem; line-height: 1.6; margin-bottom: 16px; }
.read-more { font-size: 0.85rem; font-weight: 600; color: var(--clr-primary); display: inline-flex; align-items: center; gap: 6px; }
.read-more::after { content: '→'; transition: transform var(--transition); }
.read-more:hover::after { transform: translateX(4px); }

/* FOOTER */
.site-footer { border-top: 1px solid var(--clr-border); padding: 60px 0 32px; margin-top: 40px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 48px; }
.footer-brand p { color: var(--clr-text-muted); font-size: 0.9rem; margin-top: 16px; max-width: 300px; line-height: 1.7; }
.footer-col h4 { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; margin-bottom: 16px; color: var(--clr-primary); }
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { color: var(--clr-text-muted); font-size: 0.9rem; }
.footer-col a:hover { color: var(--clr-primary); }
.footer-bottom { border-top: 1px solid var(--clr-border); padding-top: 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.footer-bottom p { color: var(--clr-text-muted); font-size: 0.8rem; }
.footer-disclaimer { color: var(--clr-text-muted); font-size: 0.75rem; line-height: 1.6; max-width: 800px; margin: 24px auto 0; text-align: center; padding: 20px; border: 1px solid var(--clr-border); border-radius: var(--radius-sm); background: rgba(212, 168, 50, 0.03); }

/* PAGE / SINGLE */
.page-header { padding: 60px 0 40px; text-align: center; border-bottom: 1px solid var(--clr-border); margin-bottom: 48px; }
.page-header h1 { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); font-weight: 700; }
.content-area { max-width: 800px; margin: 0 auto; padding-bottom: 60px; }
.content-area h2, .content-area h3, .content-area h4 { font-family: var(--font-display); margin-top: 2em; margin-bottom: 0.8em; }
.content-area h2 { font-size: 1.8rem; }
.content-area h3 { font-size: 1.4rem; }
.content-area p { margin-bottom: 1.2em; color: var(--clr-text-muted); }
.content-area ul, .content-area ol { margin-bottom: 1.2em; padding-left: 1.5em; color: var(--clr-text-muted); }
.content-area li { margin-bottom: 0.5em; }
.content-area blockquote { border-left: 3px solid var(--clr-primary); padding: 16px 24px; margin: 1.5em 0; background: var(--clr-gold-glow); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-style: italic; }
.content-area img { border-radius: var(--radius); margin: 1.5em 0; }
.content-cta-box { background: linear-gradient(135deg, var(--clr-accent), #0c1232); border: 1px solid rgba(212, 168, 50, 0.18); border-radius: var(--radius); padding: 32px; text-align: center; margin: 2em 0; }
.content-cta-box h3 { font-family: var(--font-display); margin-top: 0; margin-bottom: 12px; color: var(--clr-text); }
.content-cta-box p { color: var(--clr-text-muted); margin-bottom: 20px; }

/* SIDEBAR */
.with-sidebar { display: grid; grid-template-columns: 1fr 320px; gap: 48px; max-width: 1200px; margin: 0 auto; }
.sidebar .widget { background: var(--clr-bg-card); border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 24px; margin-bottom: 24px; }
.sidebar .widget h4 { font-family: var(--font-display); font-size: 1.05rem; margin-bottom: 16px; color: var(--clr-primary); }
.sidebar .widget ul { list-style: none; }
.sidebar .widget li { margin-bottom: 10px; }
.sidebar .widget a { color: var(--clr-text-muted); font-size: 0.9rem; }
.sidebar .widget a:hover { color: var(--clr-primary); }

/* ANIMATIONS */
@keyframes fadeDown { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }
.fade-in { opacity: 0; transform: translateY(24px); transition: opacity 0.6s ease, transform 0.6s ease; }
.fade-in.visible { opacity: 1; transform: translateY(0); }

.age-badge { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--clr-primary); font-size: 0.7rem; font-weight: 700; color: var(--clr-primary); }

/* RESPONSIVE */
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } .with-sidebar { grid-template-columns: 1fr; } .bonus-banner { flex-direction: column; text-align: center; padding: 40px 28px; } }
@media (max-width: 768px) { .site-nav { display: none; } .site-nav.open { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: rgba(10, 14, 30, 0.97); backdrop-filter: blur(16px); padding: 20px; border-bottom: 1px solid var(--clr-border); } .mobile-toggle { display: block; } .hero { padding: 60px 0 50px; } .articles-grid { grid-template-columns: 1fr; } .footer-grid { grid-template-columns: 1fr; } }
@media (max-width: 480px) { .hero-actions { flex-direction: column; align-items: center; } }
