:root{
  --bg: #f5f7fb;
  --surface: rgba(255, 255, 255, 0.78);
  --surface-strong: #ffffff;
  --text: #11213b;
  --muted: #51607a;
  --primary: #1456d9;
  --primary-dark: #0f3fa0;
  --accent: #00b3a4;
  --accent-soft: rgba(0, 179, 164, 0.12);
  --border: rgba(17, 33, 59, 0.1);
  --shadow: 0 20px 60px rgba(17, 33, 59, 0.12);
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --danger:#b91c1c;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
}
a{color:inherit;text-decoration:none}

.containerok{
  width:min(1180px, calc(100% - 32px));
  margin:0 auto;
}

.hero-wrap{padding:24px 0 0}
.hero{
  position:relative;
  overflow:hidden;
  border-radius:34px;
  background:linear-gradient(135deg, rgba(30, 58, 138, 0.88), rgba(59, 130, 246, 0.82));
  box-shadow:var(--shadow);
  isolation:isolate;
}
.hero::before,
.hero::after{
  content:"";
  position:absolute;
  border-radius:50%;
  filter:blur(10px);
  z-index:-1;
}
.hero::before{
  width:280px;height:280px;background:rgba(255,255,255,0.12);top:-90px;right:-70px;
}
.hero::after{
  width:220px;height:220px;background:rgba(0,179,164,0.25);bottom:-70px;left:-50px;
}
.hero-banner img{
  width:100%;
  height:auto;
  object-fit:cover;
  display:block;
}
.hero-content{
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:32px;
  padding:38px;
  align-items:center;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,0.12);
  color:#ffffff;
  font-size:.86rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.12);
}
.hero h1{
  margin:18px 0 14px;
  color:#fff;
  font-size:clamp(2.2rem, 4vw, 4.3rem);
  line-height:1.03;
  letter-spacing:-0.04em;
}
.hero p{
  margin:0;
  color:rgba(255,255,255,0.86);
  font-size:1.08rem;
  max-width:62ch;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:28px;
}
.btn3{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 22px;
  border-radius:999px;
  font-weight:700;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.btn3:hover{transform:translateY(-2px)}
.btn-primary3{
  background:#ffffff;
  color:var(--primary-dark);
  box-shadow:0 14px 26px rgba(0,0,0,0.16);
}
.btn-secondary3{
  background:rgba(255,255,255,0.1);
  color:#fff;
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(10px);
}

.hero-card{
  background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:var(--radius-xl);
  padding:24px;
  color:#fff;
  backdrop-filter:blur(12px);
}
.hero-card h2{
  margin:0 0 12px;
  font-size:1.1rem;
  letter-spacing:-0.02em;
}
.hero-stats{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:14px;
  margin-top:18px;
}
.stat{
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.08);
}
.stat strong{
  display:block;
  font-size:1.2rem;
  line-height:1.1;
  margin-bottom:8px;
}

main{padding:10px 0 70px}
.gridsi{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.card{
  background:var(--surface);
  border:1px solid rgba(255,255,255,0.7);
  backdrop-filter:blur(14px);
  border-radius:var(--radius-xl);
  box-shadow:0 20px 50px rgba(17, 33, 59, 0.08);
  padding:30px;
}
.card h2{
  margin:0 0 14px;
  font-size:clamp(1.55rem, 2vw, 2.15rem);
  line-height:1.1;
  letter-spacing:-0.04em;
}
.card p{
  margin:0 0 16px;
  color:var(--muted);
  font-size:1rem;
}
.lead{
  font-size:1.08rem;
  color:var(--text) !important;
}
.badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:20px;
}
.badge{
  padding:10px 14px;
  border-radius:999px;
  background:var(--accent-soft);
  color:#1d3557;
  font-weight:700;
  font-size:.95rem;
}
.simple-list{
  list-style:none;
  padding:0;
  margin:20px 0 0;
  display:grid;
  gap:14px;
}
.simple-list li{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:16px 18px;
  border-radius:18px;
  background:#fff;
  border:1px solid var(--border);
}
.icon{
  flex:0 0 36px;
  width:36px;
  height:36px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--primary), var(--accent));
  color:#fff;
  font-weight:800;
  box-shadow:0 10px 20px rgba(20, 86, 217, 0.18);
}
.simple-list strong{
  display:block;
  margin-bottom:4px;
  font-size:1rem;
}
.simple-list span{
  color:var(--muted);
  font-size:.98rem;
}
.highlight{background:linear-gradient(180deg, #ffffff, #f9fbff)}
.faq-wrap{margin-top:24px}
.faq-item{
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  margin-bottom:14px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(17, 33, 59, 0.04);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:20px 24px;
  font-weight:700;
  color:var(--text);
  position:relative;
  padding-right:60px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";
  position:absolute;
  right:22px;
  top:50%;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  border-radius:10px;
  display:grid;
  place-items:center;
  background:var(--accent-soft);
  color:var(--primary-dark);
  font-size:1.2rem;
  font-weight:800;
}
.faq-item[open] summary::after{content:"−"}
.faq-content{
  padding:0 24px 22px;
  color:var(--muted);
  line-height:1.7;
}
.faq-content p{margin:0 0 14px}
.faq-content ul{margin:10px 0 0 18px;padding:0}
.faq-content li{margin-bottom:10px}

.cta{
  margin-top:24px;
  background:linear-gradient(135deg, #0f2b70, #1456d9 62%, #00b3a4);
  color:#fff;
  overflow:hidden;
  position:relative;
}
.cta::after{
  content:"";
  position:absolute;
  inset:auto -60px -60px auto;
  width:220px;
  height:220px;
  border-radius:50%;
  background:rgba(255,255,255,0.1);
  filter:blur(2px);
}
.cta h2,.cta p{color:#fff}
.cta-links{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:22px;
}

.calendar-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-top:22px;
}
.event-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:20px;
  box-shadow:0 10px 30px rgba(17, 33, 59, 0.04);
}
.event-card .num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:12px;
  background:linear-gradient(135deg, var(--primary), var(--accent));
  color:#fff;
  font-weight:800;
  margin-bottom:14px;
}
.event-card h3{
  margin:0 0 10px;
  font-size:1.08rem;
  line-height:1.3;
}
.event-card p{
  margin:0 0 14px;
  color:var(--muted);
  font-size:.97rem;
  line-height:1.65;
}
.event-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:auto;
}
.meta-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border-radius:999px;
  background:var(--accent-soft);
  color:#1d3557;
  font-size:.9rem;
  font-weight:700;
}
.meta-pill.alt{
  background:rgba(20, 86, 217, 0.08);
  color:var(--primary-dark);
}
a.meta-pill.alt{
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
a.meta-pill.alt:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 18px rgba(20,86,217,.12);
  background:rgba(20, 86, 217, 0.14);
}

form{display:grid;gap:16px;margin-top:8px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label{display:block;font-weight:700;margin:0 0 6px}
input[type="text"],input[type="email"],input[type="tel"]{
  width:100%;
  padding:14px 14px;
  border:1px solid #dbe2ea;
  border-radius:14px;
  font-size:16px;
  background:#fff;
  color:var(--text);
}
input:focus{
  outline:2px solid rgba(20,86,217,.14);
  border-color:#8cb0f5;
}
.error{color:var(--danger);font-size:13px;margin-top:6px}
.checkbox{
  display:flex;
  align-items:flex-start;
  gap:10px;
}
.checkbox input[type="checkbox"]{
  margin-top:4px;
}
.privacy{
  font-size:12px;
  line-height:1.45;
  color:var(--muted);
  font-weight:500;
}
.privacy a{
  color:var(--primary);
  text-decoration:underline;
}
.help{
  font-size:13px;
  color:var(--muted);
  margin-top:6px;
}
.actions{
  display:flex;
  justify-content:flex-start;
  margin-top:6px;
}
button{
  appearance:none;
  border:0;
  background:linear-gradient(135deg, var(--primary), var(--primary-dark));
  color:#fff;
  padding:14px 22px;
  border-radius:999px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 14px 30px rgba(20,86,217,.28);
}
button:hover{transform:translateY(-1px)}
.pill{
  display:inline-block;
  padding:8px 12px;
  background:#ecfeff;
  color:#0369a1;
  border:1px solid #bae6fd;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
}
.success-box{
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:22px;
  margin-top:16px;
}
.debugbox{
  margin-top:14px;
  padding:12px;
  background:#0b1020;
  color:#e5e7eb;
  border-radius:12px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:12px;
  overflow:auto;
  max-height:320px;
}
.debugbox b{color:#93c5fd}

@media (max-width: 980px){
  .hero-content,.gridsi,.calendar-grid{grid-template-columns:1fr}
  .hero-card{max-width:520px}
}
@media (max-width: 640px){
  .hero-wrap{padding-top:14px}
  .hero{border-radius:24px}
  .hero-content,.card{padding:22px}
  .hero h1{font-size:clamp(2rem,11vw,3rem)}
  .hero p{font-size:1rem}
  .hero-stats{grid-template-columns:1fr}
  .faq-item,.simple-list li,.event-card{border-radius:16px}
  .btn3{width:100%}
  .cta-links{flex-direction:column}
  .faq-item summary{padding:18px 18px;padding-right:54px}
  .faq-content{padding:0 18px 18px}
  .row{grid-template-columns:1fr}
}
