
.smg-ofl-wrap{max-width:1200px;margin:40px auto;padding:0 20px;color:#183b67}
.smg-ofl-hero{display:grid;grid-template-columns:2fr 1fr;gap:36px;align-items:center;background:linear-gradient(180deg,#eef5ff 0%,#e8f0fb 100%);border:1px solid #d6e2f2;border-radius:24px;padding:28px 28px 24px;box-shadow:0 12px 26px rgba(15,39,74,.06)}
.smg-ofl-eyebrow{font-size:13px;font-weight:700;letter-spacing:.02em;margin-bottom:12px}
.smg-ofl-hero-title{font-size:clamp(38px,4vw,64px);line-height:1.05;font-weight:800;margin:0 0 18px;color:#123f79}
.smg-ofl-hero-text p{font-size:20px;line-height:1.6;margin:0 0 16px;color:#355a87}
.smg-ofl-badges{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 22px}
.smg-ofl-badge{display:inline-flex;align-items:center;background:#fff;border:1px solid #d5e0ef;border-radius:999px;padding:10px 14px;font-size:14px;font-weight:700;color:#214d84;min-height:42px}
.smg-ofl-hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.smg-ofl-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:12px;font-weight:800;transition:.2s ease}
.smg-ofl-btn-primary{background:#0e73be;color:#fff;padding:16px 26px;min-height:54px;box-shadow:0 10px 20px rgba(14,115,190,.2)}
.smg-ofl-btn-primary:hover{background:#0b5d98;color:#fff}
.smg-ofl-btn-secondary{background:transparent;color:#123f79;padding:16px 8px;min-height:54px}
.smg-ofl-btn-secondary:hover{color:#0e73be}
.smg-ofl-hero-image-wrap{display:flex;justify-content:center}
.smg-ofl-hero-image{width:100%;max-width:340px;height:auto;border-radius:22px;display:block}
.smg-ofl-intro{font-size:20px;line-height:1.6;margin:18px 10px 34px;color:#58769b}
.smg-ofl-why,.smg-ofl-course,.smg-ofl-faq,.smg-ofl-closing{background:#f9fbff;border:1px solid #dce6f3;border-radius:22px;padding:26px;margin:0 0 24px;box-shadow:0 8px 20px rgba(15,39,74,.03)}
.smg-ofl-why h2,.smg-ofl-faq h2,.smg-ofl-closing h2{font-size:22px;color:#123f79;margin:0 0 14px}
.smg-ofl-why p,.smg-ofl-closing p{font-size:18px;line-height:1.6;color:#355a87}
.smg-ofl-course-title{font-size:22px;color:#123f79;margin:0 0 8px}
.smg-ofl-location{font-weight:700;color:#6c84a0;margin-bottom:16px}
.smg-ofl-highlight{background:#edf5ff;border:1px solid #dce6f2;border-radius:18px;padding:18px;margin-bottom:16px}
.smg-ofl-highlight-title{font-size:16px;font-weight:800;color:#123f79;margin-bottom:8px}
.smg-ofl-highlight-text{font-size:15px;color:#59769a}
.smg-ofl-tiles{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:16px}
.smg-ofl-tile{background:#fff;border:1px solid #dce6f3;border-radius:16px;padding:18px;display:flex;flex-direction:column;justify-content:center;min-height:106px;box-sizing:border-box}
.smg-ofl-tile-title{font-size:15px;font-weight:800;color:#123f79;margin-bottom:6px}
.smg-ofl-tile-text{font-size:15px;line-height:1.45;color:#5b7699}
.smg-ofl-points{margin:0 0 14px 18px;color:#173f6d}
.smg-ofl-points li{margin:8px 0;font-size:17px;line-height:1.5}
.smg-ofl-terms{display:flex;flex-direction:column;gap:12px;margin-top:14px}
.smg-ofl-term{display:grid;grid-template-columns:1.5fr .9fr .9fr;gap:12px;align-items:stretch}
.smg-ofl-term-date,.smg-ofl-term-price,.smg-ofl-term-action{background:#edf5ff;border:1px solid #dce6f3;border-radius:14px;padding:16px;display:flex;flex-direction:column;justify-content:center}
.smg-ofl-term-date{font-size:17px;font-weight:800;color:#123f79}
.smg-ofl-price-main{font-size:18px;font-weight:800;color:#123f79;margin-bottom:4px}
.smg-ofl-price-sub{font-size:12px;line-height:1.35;color:#5b7699}
.smg-ofl-term-action{padding:10px}
.smg-ofl-btn-course{background:#0e73be!important;color:#fff!important;width:100%;min-height:54px;border:none;box-shadow:0 8px 18px rgba(14,115,190,.18)}
.smg-ofl-btn-course:hover{background:#0b5d98!important;color:#fff!important}
.smg-ofl-faq-item{border:1px solid #dce6f3;border-radius:14px;background:#fff;margin:0 0 12px;padding:0}
.smg-ofl-faq-item summary{cursor:pointer;list-style:none;padding:16px 18px;font-size:17px;font-weight:800;color:#123f79}
.smg-ofl-faq-answer{padding:0 18px 18px;color:#355a87;font-size:16px;line-height:1.6}
.smg-ofl-whatsapp{position:fixed;right:20px;bottom:20px;background:#25D366;color:#fff!important;border-radius:999px;padding:14px 18px;display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-weight:800;box-shadow:0 14px 28px rgba(37,211,102,.28);z-index:9999}
.smg-ofl-whatsapp:hover{background:#1fb75a;color:#fff!important}
@media(max-width:1024px){.smg-ofl-wrap{max-width:1000px}.smg-ofl-hero{grid-template-columns:1fr}.smg-ofl-hero-image{max-width:280px}.smg-ofl-term{grid-template-columns:1fr}}
@media(max-width:700px){.smg-ofl-wrap{padding:0 14px}.smg-ofl-hero-title{font-size:38px}.smg-ofl-hero-text p,.smg-ofl-intro,.smg-ofl-why p,.smg-ofl-closing p,.smg-ofl-points li{font-size:16px}.smg-ofl-tiles{grid-template-columns:1fr}.smg-ofl-term{grid-template-columns:1fr}.smg-ofl-whatsapp-label{display:none}}

/* v3.5.1 stronger booking buttons */
.smg-book-btn,.smg-ofl-btn-course{background:#0e73be !important;color:#fff !important;}
.smg-book-btn:hover,.smg-ofl-btn-course:hover{background:#0b5d98 !important;color:#fff !important;}
