:root{
  --bg:#ffffff;
  --text:#111111;
  --muted:#5b5b5b;
  --line:#ececec;
  --card:#ffffff;
  --shadow: 0 12px 30px rgba(0,0,0,.06);
  --radius: 16px;
  --radius2: 22px;
  --container: 1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; height:auto; display:block}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}

.site-header{
  position:sticky;
  top:0;
  background:rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
  z-index:50;
}

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

.logo{
  font-weight:800;
  letter-spacing:.6px;
  font-size:18px;
}

.nav{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}

.nav a{
  color:#222;
  font-weight:600;
  font-size:14px;
  opacity:.85;
  padding:10px 10px;
  border-radius:12px;
}

.nav a:hover{background:#f6f6f6; opacity:1}
.nav a.is-active{background:#f2f2f2; opacity:1}

.header-cta{
  display:flex;
  gap:10px;
  align-items:center;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:11px 16px;
  border-radius:999px;
  font-weight:700;
  font-size:14px;
  background:#111;
  color:#fff;
  border:1px solid #111;
  cursor:pointer;
  transition: transform .05s ease, opacity .2s ease, background .2s ease;
}

.btn:hover{opacity:.92}
.btn:active{transform:translateY(1px)}
.btn-ghost{
  background:transparent;
  color:#111;
  border:1px solid var(--line);
}

.site-main{min-height:60vh}

.hero{
  padding:64px 0 10px;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:34px;
  align-items:center;
}

.kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  font-weight:700;
  font-size:12px;
  color:#222;
  background:#fff;
}

.h1{
  font-size:56px;
  line-height:1.02;
  letter-spacing:-1px;
  margin:18px 0 14px;
}

.lead{
  color:var(--muted);
  font-size:18px;
  margin:0 0 22px;
  max-width:52ch;
}

.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}

.badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
}
.badge{
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:700;
  color:#222;
  background:#fff;
}

.hero-media{
  border-radius: var(--radius2);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  background:#fafafa;
}

.section{
  padding:64px 0;
}

.section-title{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:18px;
  margin-bottom:22px;
}

.h2{
  font-size:28px;
  margin:0;
  letter-spacing:-.4px;
}

.sub{
  margin:0;
  color:var(--muted);
  max-width:60ch;
}

.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:18px;
}

.card{
  grid-column: span 4;
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding:20px;
  background: var(--card);
  box-shadow: 0 1px 0 rgba(0,0,0,.02);
}

.card h3{
  margin:0 0 8px;
  font-size:18px;
  letter-spacing:-.2px;
}

.card p{
  margin:0;
  color:var(--muted);
}

.card .card-link{
  display:inline-flex;
  margin-top:14px;
  font-weight:800;
  font-size:13px;
  opacity:.9;
}

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:20px;
  align-items:stretch;
}

.panel{
  border:1px solid var(--line);
  border-radius: var(--radius2);
  overflow:hidden;
  background:#fff;
  box-shadow: var(--shadow);
}

.panel .panel-body{
  padding:22px;
}

.panel img{width:100%; height:260px; object-fit:cover}

.cta-band{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background: #0f0f10;
  color:#fff;
  padding:60px 0;
}

.cta-band .h2{color:#fff}
.cta-band .sub{color:rgba(255,255,255,.72)}

.footer-grid{
  display:grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap:18px;
  padding:46px 0 20px;
}

.site-footer{
  border-top:1px solid var(--line);
  padding-top:0;
}

.footer-brand{
  font-weight:900;
  letter-spacing:.6px;
  margin-bottom:10px;
}

.footer-title{
  font-weight:900;
  margin-bottom:10px;
}

.footer-col a{
  display:block;
  padding:7px 0;
  color:#222;
  opacity:.9;
}
.footer-col a:hover{opacity:1}

.footer-bottom{
  padding:16px 0 30px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  border-top:1px solid var(--line);
}

.muted{color:var(--muted)}
.site-footer .muted{color:#6b6b6b}

.floating-cta{
  position:fixed;
  bottom:14px;
  left:50%;
  transform:translateX(-50%);
  display:none;
  gap:10px;
  z-index:60;
}

.floating-cta a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:999px;
  font-weight:900;
  border:1px solid var(--line);
  background:#fff;
  box-shadow: var(--shadow);
}

.cookie-banner{
  position:fixed;
  left:12px;
  right:12px;
  bottom:12px;
  z-index:80;
  display:none;
}

.cookie-inner{
  max-width:var(--container);
  margin:0 auto;
  background:#fff;
  border:1px solid var(--line);
  border-radius: var(--radius2);
  padding:14px;
  box-shadow: var(--shadow);
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}

.cookie-text{
  color:#333;
  font-size:13px;
  max-width:70ch;
}
.cookie-text a{font-weight:900; text-decoration:underline}

.cookie-actions{
  display:flex;
  gap:10px;
  align-items:center;
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .h1{font-size:44px}
  .card{grid-column:span 6}
  .footer-grid{grid-template-columns:1fr 1fr}
}

@media (max-width: 640px){
  .nav{display:none}
  .h1{font-size:38px}
  .lead{font-size:16px}
  .card{grid-column:span 12}
  .split{grid-template-columns:1fr}
  .floating-cta{display:flex}
}
