/*
 Theme Name: eLearning Child (Full Style, compact)
 Description: Polished UI for header, nav, buttons, Masteriyo cards, sections, and utilities. Buy Now has gradient border; current price 25px.
 Version: 2025-09-02
*/

/* ========== DESIGN TOKENS ========== */
:root{
  --pri:#1837B4; --pri-2:#2156DA;
  --btn-bg:#1837B4; --btn-bg-hover:#04155a; --btn-text:#fff;
  --card-bg:rgba(255,255,255,.75);
  --shadow:0 8px 24px rgba(8,25,77,.08);
  --radius:18px;

  /* nav/drawer */
  --nav-active-bg:#1837B4; --nav-active-text:#fff;
  --nav-drawer-w:360px; --nav-radius:18px;
}

/* ========== GLOBAL ========== */
.hero-card,.mini-card,.stat-card,.course-card{background:var(--card-bg);backdrop-filter:blur(8px);border-radius:var(--radius);box-shadow:var(--shadow)}
.scroll-snap{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px}
.scroll-snap>*{scroll-snap-align:start;min-width:280px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#eef3ff;color:#1a3bb6;font-size:.85rem}
.counter-xl{font-size:2.2rem;font-weight:700;color:#0f1c5a}
.elementor-heading-title{color:var(--pri)!important}

/* Background blobs (subtle fixed scene) */
body{
  --blob1:rgba(43,14,146,1); --blob2:rgba(146,192,252,.4);
  --blob3:rgba(216,248,151,.3); --blob4:rgba(218,62,106,1);
  --fade:rgba(255,255,255,.10);
  background:
    radial-gradient(220px 220px at 12% 18%, var(--blob1), transparent 60%),
    radial-gradient(260px 260px at 78% 22%, var(--blob2), transparent 62%),
    radial-gradient(200px 200px at 22% 72%, var(--blob3), transparent 62%),
    radial-gradient(250px 250px at 88% 78%, var(--blob4), transparent 60%),
    radial-gradient(1200px 1200px at 50% 20%, var(--fade), transparent 70%),
    linear-gradient(135deg,#eef2ff 0%,#fff 60%);
  background-attachment:fixed;background-repeat:no-repeat;background-size:cover;min-height:100vh
}
.site,#page,#content,.wrapper,.container{background:transparent!important}

/* ========== HEADER (glass capsule) ========== */
.tg-header-builder .tg-header-main-row{padding:1rem!important}
#tg-masthead,#tg-masthead .tg-main-header,#tg-masthead .tg-header-main-row,
#tg-masthead .tg-header-transparent-wrapper,#tg-masthead .tg-header-wrapper,#tg-masthead .tg-header-inner,
#tg-masthead.tg-site-header,.site-header,.tg-site-header::after{background:transparent!important;border:0!important;box-shadow:none!important}
#tg-masthead{position:sticky;top:20px;z-index:9999}
#tg-masthead .tg-header-main-row>.tg-container{position:relative;max-width:900px;margin:0 auto;padding:1rem 3rem;z-index:1}
#tg-masthead .tg-header-main-row>.tg-container::before{
  content:"";position:absolute;inset:0;border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.30),rgba(255,255,255,.15));
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.55);box-shadow:0 10px 30px rgba(0,0,0,.10);z-index:-1;pointer-events:none
}
#tg-masthead .tg-header-main-row>.tg-container,
#tg-masthead .tg-header-main-row>.tg-container::before{transition:padding .22s cubic-bezier(.2,.7,.2,1),background .22s ease,box-shadow .22s ease,transform .22s cubic-bezier(.2,.7,.2,1)}
body.scrolled #tg-masthead .tg-header-main-row>.tg-container{padding:1rem 3.5rem;transform:translateY(0) scale(.985)}
body.scrolled #tg-masthead .tg-header-main-row>.tg-container::before{background:rgba(255,255,255,.30);box-shadow:0 12px 32px rgba(0,0,0,.14)}
@media (prefers-reduced-motion:reduce){
  #tg-masthead .tg-header-main-row>.tg-container,
  #tg-masthead .tg-header-main-row>.tg-container::before{transition:none!important}
}

/* Primary menu (desktop) */
#tg-masthead .tg-header-main-row nav ul{display:flex;align-items:center;gap:14px;margin:0;padding:0;list-style:none}
#tg-masthead .tg-header-main-row nav ul li{margin:0;padding:0}
#tg-masthead .tg-header-main-row nav ul li>a,
#tg-masthead .tg-header-main-row nav ul li>a:visited{
  display:inline-flex;align-items:center;padding:10px 18px;border-radius:999px;
  font-weight:400;font-size:15px;color:#757c88!important;text-decoration:none!important;border:0!important;box-shadow:none!important
}
#tg-masthead .tg-header-main-row nav ul li>a::before,
#tg-masthead .tg-header-main-row nav ul li>a::after{content:none!important}
#tg-masthead .tg-header-main-row nav ul li>a:hover{background:rgba(37,99,235,.15);color:var(--pri)!important}
.tg-site-header nav li.current-menu-item>a,
.tg-site-header nav li.current_page_item>a,
.tg-site-header nav li.current-menu-ancestor>a,
.tg-site-header nav li.current_page_parent>a,
#tg-masthead .tg-header-main-row nav ul li>a[aria-current="page"]{background:var(--nav-active-bg);color:var(--nav-active-text);border-radius:10px}
.tg-site-header nav li.current-menu-item>a *{color:inherit}
@media (max-width:768px){
  #tg-masthead{top:10px}
  #tg-masthead .tg-header-main-row>.tg-container{margin:0 8px;padding:8px 14px}
}

/* ========== THEMEGRILL/ZAKRA MOBILE NAV (drawer) ========== */
/* Structure */
.tg-mobile-navigation{
  position:fixed!important;top:0;left:0;height:100dvh;width:min(88vw,var(--nav-drawer-w));
  background:#fff;box-shadow:0 10px 32px rgba(4,21,90,.16);overflow-y:auto;
  -webkit-overflow-scrolling:touch;transform:translateX(-105%);transition:transform .24s ease;z-index:10050
}
.tg-mobile-navigation.tg-mobile-navigation--opened{transform:translateX(0)}
.tg-mobile-navigation.tg-mobile-navigation--opened::after{
  content:"";position:fixed;inset:0;left:min(88vw,var(--nav-drawer-w));
  background:rgba(3,10,30,.45);backdrop-filter:blur(1.5px);z-index:-1
}
@media (max-width:360px){
  .tg-mobile-navigation{width:100vw}
  .tg-mobile-navigation.tg-mobile-navigation--opened::after{left:100vw}
}
/* List + items */
.tg-mobile-navigation .tg-mobile-nav>ul,
.tg-mobile-navigation .menu>ul,
.tg-mobile-navigation ul#mobile-menu,
.tg-mobile-navigation .tg-mobile-nav .menu,
.tg-mobile-navigation .tg-mobile-nav ul{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:8px!important;margin:20px 12px 28px!important;padding:0!important;list-style:none!important}
.tg-mobile-navigation li{width:100%!important}
.tg-mobile-navigation a{
  display:block!important;width:100%!important;padding:14px 16px!important;border-radius:12px!important;
  white-space:nowrap!important;overflow-wrap:normal!important;word-break:keep-all!important;
  text-decoration:none!important;color:#111827!important;background:transparent!important;
  transition:background .18s ease,color .18s ease,transform .18s ease
}
.tg-mobile-navigation a:hover{background:rgba(24,55,180,.08)!important}
.tg-mobile-navigation li.current-menu-item>a,
.tg-mobile-navigation li.current_page_item>a,
.tg-mobile-navigation li.current-menu-ancestor>a,
.tg-mobile-navigation li.current_page_parent>a,
.tg-mobile-navigation a[aria-current="page"]{background:var(--nav-active-bg)!important;color:var(--nav-active-text)!important;font-weight:600}
.tg-mobile-navigation .tg-mobile-navigation-close{position:sticky;top:10px;margin:10px 10px 6px auto;z-index:2}
.nav-vertical-pill,.menu-vertical-label{display:none!important}
body.nav-open{overflow:hidden;touch-action:none}

/* ========== ELEMENTOR NAV (dropdown on mobile) ========== */
.elementor-nav-menu .elementor-item,
.elementor-nav-menu--dropdown .elementor-item{white-space:nowrap;overflow-wrap:normal;word-break:keep-all;letter-spacing:0}
.elementor-nav-menu .elementor-item{font-weight:500;line-height:1.25;padding:12px 16px;border-radius:var(--nav-radius)}
.elementor-nav-menu--dropdown{
  position:fixed!important;top:0;left:0;height:100dvh;width:min(88vw,340px);
  padding:18px 12px 28px;background:#fff;box-shadow:0 8px 28px rgba(4,21,90,.12);
  border-top-right-radius:22px;border-bottom-right-radius:22px;overflow-y:auto;z-index:9999
}
.elementor-nav-menu--dropdown .elementor-nav-menu{display:flex!important;flex-direction:column;gap:6px}
.elementor-nav-menu--dropdown .elementor-item{display:flex;align-items:center;gap:10px;padding:14px;border-radius:12px;transition:background-color .18s,transform .18s}
.elementor-nav-menu--dropdown .elementor-item:hover,
.elementor-nav-menu--dropdown .elementor-item:focus-visible{background:rgba(24,55,180,.08);transform:translateX(2px);outline:none}
.elementor-menu-toggle{margin:0 8px 0 0}
.elementor-nav-menu--dropdown .elementor-menu-toggle{position:absolute;top:12px;right:12px}
.elementor-menu-toggle[aria-expanded="true"]::after{
  content:"";position:fixed;inset:0;left:min(88vw,340px);background:rgba(3,10,30,.45);backdrop-filter:blur(1.5px);z-index:9990
}
@media (max-width:360px){
  .elementor-nav-menu--dropdown{width:100vw;border-radius:0 0 18px 0}
  .elementor-menu-toggle[aria-expanded="true"]::after{left:100vw}
}
@media (min-width:768px){
  .elementor-nav-menu--main .elementor-item{padding:10px 14px}
  .elementor-nav-menu--main{gap:8px}
}
@media (min-width:1024px){
  .elementor-nav-menu--main .elementor-item{border-radius:10px;transition:background-color .18s,color .18s,transform .18s}
  .elementor-nav-menu--main .elementor-item:hover,
  .elementor-nav-menu--main .elementor-item:focus-visible{background:rgba(24,55,180,.08);outline:none}
}

/* ========== BUTTONS (frontend only) ========== */
/* Force real buttons look consistent; avoid styling every <a> as a button */
body:not(.elementor-editor-active)
:is(button,input[type="submit"],input[type="button"],.wp-block-button__link,.wp-element-button,.elementor-button,.elementor-button-link.elementor-button,.woocommerce button.button,.woocommerce input.button,.woocommerce .button,.woocommerce .button.alt,.woocommerce button.single_add_to_cart_button,.masteriyo-btn,.masteriyo-enroll-btn){
  background:var(--btn-bg)!important;color:var(--btn-text)!important;border:none!important;border-radius:999px!important;
  font-family:'Kanit',sans-serif!important;font-size:16px!important;font-weight:400!important;line-height:1!important;
  text-decoration:none!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;
  cursor:pointer!important;transition:background .25s ease,transform .2s ease!important;box-shadow:none!important
}
body:not(.elementor-editor-active)
:is(button:hover,input[type="submit"]:hover,input[type="button"]:hover,.wp-block-button__link:hover,.wp-element-button:hover,.elementor-button:hover,.elementor-button-link.elementor-button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce .button:hover,.woocommerce .button.alt:hover,.masteriyo-btn:hover,.masteriyo-enroll-btn:hover,
button:focus,input[type="submit"]:focus,input[type="button"]:focus,.wp-block-button__link:focus,.wp-element-button:focus,.elementor-button:focus,.elementor-button-link.elementor-button:focus,.woocommerce button.button:focus,.woocommerce input.button:focus,.woocommerce .button:focus,.woocommerce .button.alt:focus,.woocommerce button.single_add_to_cart_button:focus,.masteriyo-btn:focus,.masteriyo-enroll-btn:focus){
  background:var(--btn-bg-hover)!important;transform:translateY(-1px)!important;outline:none!important
}
/* Reset Woo links that look like buttons back to plain links */
body:not(.elementor-editor-active)
:is(a.button,.woocommerce a.button,.woocommerce a.checkout-button,.woocommerce a.add_to_cart_button){
  appearance:none!important;background:none!important;border:0!important;border-radius:0!important;padding:0!important;box-shadow:none!important;transform:none!important;display:inline!important;color:#6b7280!important;text-decoration:none!important;cursor:pointer!important;transition:color .15s ease!important
}
body:not(.elementor-editor-active)
:is(a.button:hover,.woocommerce a.button:hover,.woocommerce a.checkout-button:hover,.woocommerce a.add_to_cart_button:hover,
a.button:focus,.woocommerce a.button:focus,.woocommerce a.checkout-button:focus,.woocommerce a.add_to_cart_button:focus){
  background:none!important;border:0!important;box-shadow:none!important;transform:none!important;text-decoration:none!important;color:#374151!important
}
/* Plain <a> hover (exclude menus/buttons) */
body:not(.elementor-editor-active)
a:not(.elementor-button):not(.wp-block-button__link):not(.wp-element-button):not(.button):not([role="button"])
:not(.tg-site-header a):not(.elementor-nav-menu a):not(.tg-mobile-navigation a){
  text-decoration:none!important;transition:color .15s ease!important
}
body:not(.elementor-editor-active)
a:not(.elementor-button):not(.wp-block-button__link):not(.wp-element-button):not(.button):not([role="button"])
:not(.tg-site-header a):not(.elementor-nav-menu a):not(.tg-mobile-navigation a):hover{color:#374151!important;background:none!important}

/* Woo cart tiny fix */
.wc-block-cart-item__remove-link:hover{background:none!important}

/* ========== MASTERIYO – COURSE CARD ========== */
.masteriyo-course--card,
.masteriyo-course-item--wrapper.masteriyo-course--card,
.masteriyo-course--card .masteriyo-course--content,
.masteriyo-course--card .masteriyo-course-card-footer,
.masteriyo-course--card .masteriyo-course--content__wrapper{background:none!important;border:0!important;box-shadow:none!important;padding:0!important}
.masteriyo-course-item--wrapper.masteriyo-course--card{position:relative!important;overflow:hidden!important;border-radius:26px!important;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s cubic-bezier(.2,.8,.2,1)!important;will-change:transform,box-shadow!important}
.masteriyo-course-item--wrapper.masteriyo-course--card:hover,
.masteriyo-course-item--wrapper.masteriyo-course--card:focus-within{transform:translateY(-8px) scale(1.015)!important}

/* Media */
.masteriyo-course--card .masteriyo-course--img-wrap{margin:16px 0 0!important;border-radius:22px!important;overflow:hidden!important}
.masteriyo-course--card .masteriyo-feature-img img{width:100%!important;height:220px!important;object-fit:cover!important;display:block!important;border-radius:18px!important;transition:transform .45s cubic-bezier(.2,.8,.2,1)!important;will-change:transform!important;backface-visibility:hidden!important}
.masteriyo-course-item--wrapper.masteriyo-course--card:hover .masteriyo-feature-img img{transform:scale(1.06)!important}

/* Content */
.masteriyo-course--card .masteriyo-course--content{padding:18px 20px 0!important}
.masteriyo-course--card .masteriyo-course--content__title a{display:block!important;font-size:20px!important;line-height:1.25!important;font-weight:300!important;color:#0f172a!important;text-decoration:none!important;margin:12px 0 8px!important}
.masteriyo-course--card .masteriyo-course-author{display:flex!important;align-items:center!important;gap:10px!important;color:#64748b!important;font-weight:600!important;font-size:15px!important;margin:6px 0 12px!important}
.masteriyo-course--card .masteriyo-course-author img{width:30px!important;height:30px!important;border-radius:50%!important}
.masteriyo-course--card .masteriyo-course--content__description{color:#475569!important;font-size:15.5px!important;line-height:1.65!important;margin:0 0 14px!important}
.masteriyo-course--card .masteriyo-course--content__description ul{margin:6px 0 0!important;padding:0!important;list-style:none!important}
.masteriyo-course--card .masteriyo-course--content__description li{display:flex!important;gap:10px!important;margin:8px 0!important;align-items:flex-start!important}

/* Stats row */
.masteriyo-course--card .masteriyo-course--content__stats{
  display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:12px!important;font-size:14px!important;color:#64748b!important;margin:8px 0 0!important;padding:14px 0 0!important;border-top:1px solid rgba(148,163,184,.25)!important
}
.masteriyo-course--card .masteriyo-course--content__stats>div{display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;white-space:nowrap!important}

/* Price row */
.masteriyo-course--card .masteriyo-course-card-footer{padding:20px 20px 18px!important;background:transparent!important;border:0!important}
.masteriyo-course--card .masteriyo-course-price{display:flex!important;align-items:baseline!important;gap:12px!important;flex-wrap:nowrap!important;line-height:1!important}
.masteriyo-course--card .masteriyo-course-price del.old-amount .masteriyo-price-amount,
.masteriyo-course--card .masteriyo-course-price del.old-amount .masteriyo-price-amount .masteriyo-price-currencySymbol{font-size:20px!important;color:#94a3b8!important;font-weight:500!important;opacity:.85!important;vertical-align:baseline!important}
.masteriyo-course--card .masteriyo-course-price del.old-amount{ text-decoration:line-through!important;text-decoration-color:#cbd5e1!important;margin-right:2px!important}
/* Current price = 25px */
.masteriyo-course--card .masteriyo-course-price .current-amount .masteriyo-price-amount,
.masteriyo-course--card .masteriyo-course-price .current-amount .masteriyo-price-amount .masteriyo-price-currencySymbol{font-size:25px!important;color:var(--pri)!important;font-weight:500!important;vertical-align:baseline!important;line-height:1!important;display:inline-block!important}
.masteriyo-course--card .masteriyo-course-price .masteriyo-price-amount,
.masteriyo-course--card .masteriyo-course-price .masteriyo-price-amount .masteriyo-price-currencySymbol{display:inline-block!important}

/* Buy Now: gradient border (stays visible on hover) */
.masteriyo-course--card .masteriyo-enroll-btn{
  display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:56px!important;margin-top:2rem!important;
  border-radius:999px!important;border:2px solid transparent!important;
  background:linear-gradient(#1837B4,#1837B4) padding-box,linear-gradient(90deg,#1837B4,#2156DA) border-box!important;
  color:#fff!important;font-weight:500!important;font-size:16.5px!important;text-decoration:none!important;transition:background .25s ease,transform .2s ease,box-shadow .25s ease!important
}
.masteriyo-course--card .masteriyo-enroll-btn:hover{background:linear-gradient(#04155a,#04155a) padding-box,linear-gradient(90deg,#1837B4,#2156DA) border-box!important;transform:translateY(-1px)!important}

/* ========== PAGE-SPECIFIC CLEANUP (example id 708) ========== */
.elementor-708 .elementor-element.elementor-element-8cd3370:not(.elementor-motion-effects-element-type-background),
.elementor-708 .elementor-element.elementor-element-8cd3370>.elementor-motion-effects-container>.elementor-motion-effects-layer{background:none!important}
.elementor-708 .elementor-element.elementor-element-50241dc:not(.elementor-motion-effects-element-type-background),
.elementor-708 .elementor-element.elementor-element-50241dc>.elementor-motion-effects-container>.elementor-motion-effects-layer{background:#eaeaec!important}

/* ========== CART / LAYOUT UTILITIES ========== */
.editor-styles-wrapper table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__quantity .wc-block-cart-item__remove-link,
table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__quantity .wc-block-cart-item__remove-link{background-color:transparent!important;color:#757c88!important;font-weight:300!important;font-size:12px!important}
.wp-block-woocommerce-cart{padding-top:10rem!important}

/* ========== STICKY FOOTER ========== */
html,body{height:100%}
body>#page,body>.site,.tg-site,.site-container,.site-wrap{min-height:100vh;display:flex;flex-direction:column}
main,#primary,#content,.site-content,.content-area,.tg-site .site-content,.tg-content,.elementor-location-header+*{flex:1 0 auto}
footer,#colophon,.site-footer,.elementor-location-footer{margin-top:auto}

/* ========== OPTIONAL: Stats cards ========== */
.imai-stats-title{font:700 44px/1.2 "Kanit",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;text-align:center;color:#0f172a;margin:24px 0 8px}
.imai-stats-sub{text-align:center;color:#6b7280;margin-bottom:28px}
.imai-stats-grid.two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;max-width:960px;margin:0 auto 36px;padding:0 16px}
@media (max-width:768px){.imai-stats-grid.two{grid-template-columns:1fr}}
.imai-stat-card{border-radius:22px;background:rgba(255,255,255,.70);backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.8);box-shadow:0 18px 40px rgba(15,23,42,.08);padding:28px 26px;text-align:center;transition:transform .25s,box-shadow .25s}
.imai-stat-card:hover{transform:translateY(-4px);box-shadow:0 22px 56px rgba(15,23,42,.12)}
.imai-stat-card .stat-icon{width:56px;height:56px;margin:0 auto 14px;display:grid;place-items:center;color:#fff;background:#1837B4;border-radius:14px;font-size:24px}
.imai-stat-card .stat-number{font:700 36px/1 "Kanit",system-ui,sans-serif;color:#0f172a;margin-bottom:8px}
.imai-stat-card .stat-label{font-weight:600;color:#1f2937;margin-bottom:4px}
.imai-stat-card .stat-sub{color:#6b7280;font-size:14px}

/* ========== WHY CHOOSE (3 cards) ========== */
.why-cards .elementor-widget-icon-box{
  position:relative;padding:28px 26px;border-radius:22px;text-align:center;
  background:
    radial-gradient(160px 160px at 50% 10%,rgba(24,55,180,.10),transparent 60%),
    radial-gradient(220px 220px at 20% 80%,rgba(168,255,120,.10),transparent 60%),
    rgba(255,255,255,.78);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(226,232,240,.85);box-shadow:0 18px 40px rgba(15,23,42,.08);
  transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s
}
.why-cards .elementor-widget-icon-box:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}
.why-cards .elementor-widget-icon-box .elementor-icon-box-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;margin:0 0 14px!important;width:auto!important}
.why-cards .elementor-widget-icon-box .elementor-icon{
  position:relative;display:inline-flex!important;width:64px;height:64px;align-items:center;justify-content:center;border-radius:16px!important;
  background:linear-gradient(180deg,#2156DA 0%,#1837B4 100%)!important;color:#fff!important;box-shadow:0 16px 36px rgba(24,55,180,.30);font-size:0;overflow:visible
}
.why-cards .elementor-widget-icon-box .elementor-icon i,
.why-cards .elementor-widget-icon-box .elementor-icon svg{width:28px;height:28px;flex:0 0 28px;display:block;margin:0;line-height:1;color:inherit;fill:currentColor;stroke:currentColor}
.why-cards .elementor-widget-icon-box .elementor-icon::after{
  content:"";position:absolute;left:50%;top:50%;width:110px;height:110px;border-radius:999px;transform:translate(-50%,-50%) translateY(-6px);
  background:radial-gradient(60px 60px at 50% 50%,rgba(33,86,218,.18),transparent 65%);filter:blur(2px);z-index:-1
}
.why-cards .elementor-icon-box-title{margin:6px 0 8px!important}
.why-cards .elementor-icon-box-title,.why-cards .elementor-icon-box-title a{font-weight:600!important;color:#0f172a!important}
.why-cards .elementor-icon-box-description{color:#4b5563;line-height:1.65}
@media (max-width:768px){.why-cards .elementor-widget-icon-box{margin-bottom:14px}}

/* ========== COURSE CARDS ROW (small icons) ========== */
.course-cards-row .elementor-widget-icon-box{position:relative;padding:18px 16px;border-radius:22px;background:none!important;backdrop-filter:none!important;transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s;text-align:center}
.course-cards-row .elementor-widget-icon-box:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}
.course-cards-row .elementor-widget-icon-box .elementor-icon-box-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;margin:0 0 14px!important;width:auto!important}
.course-cards-row .elementor-widget-icon-box .elementor-icon{position:relative;display:inline-flex!important;width:40px;height:40px;align-items:center;justify-content:center;border-radius:16px!important;background:linear-gradient(180deg,#2156DA 0%,#1837B4 100%)!important;color:#fff!important;box-shadow:0 16px 36px rgba(24,55,180,.30);font-size:0;overflow:visible}
.course-cards-row .elementor-widget-icon-box .elementor-icon i,
.course-cards-row .elementor-widget-icon-box .elementor-icon svg{width:18px;height:18px;display:block;margin:0;line-height:1;color:inherit;fill:currentColor;stroke:currentColor}
.course-cards-row .elementor-widget-icon-box .elementor-icon::after{content:"";position:absolute;left:50%;top:50%;width:110px;height:110px;border-radius:999px;transform:translate(-50%,-50%) translateY(-6px);background:radial-gradient(60px 60px at 50% 50%,rgba(33,86,218,.18),transparent 65%);filter:blur(2px);z-index:-1}
.course-cards-row .elementor-icon-box-title{margin:6px 0 8px!important}
.course-cards-row .elementor-icon-box-title,.course-cards-row .elementor-icon-box-title a{font-weight:600!important;color:#0f172a!important}
.course-cards-row .elementor-icon-box-description{color:#4b5563;line-height:1.65}
@media (max-width:768px){.course-cards-row .elementor-widget-icon-box{margin-bottom:14px}}

/* ========== Curriculum + Learn (2-col timeline) ========== */
.curriculum-col,.learn-col{position:relative}
.curriculum-col::before{content:"";position:absolute;left:6px;top:56px;bottom:0;width:3px;background:linear-gradient(180deg,rgba(24,55,180,.35),rgba(24,55,180,.12));border-radius:3px}
.curr-item{position:relative;padding:12px 12px 14px 28px;border-radius:14px;background:rgba(255,255,255,.65);backdrop-filter:blur(6px);box-shadow:0 6px 24px rgba(15,23,42,.06);margin:18px 0}
.curr-item::before{content:"";position:absolute;left:0;top:22px;width:12px;height:12px;border-radius:6px;background:#1837B4;box-shadow:0 0 0 4px rgba(24,55,180,.18)}
.week-badge{display:inline-block;font-size:.78rem;font-weight:600;padding:6px 10px;border-radius:999px;color:#fff;background:#1837B4;box-shadow:0 6px 18px rgba(24,55,180,.25);margin-bottom:10px}
.curr-item h4,.curr-item .elementor-heading-title{margin:6px 0 2px;font-size:1.05rem;color:#0f172a}
.curr-item p,.curr-item .elementor-text-editor{color:#6b7280;line-height:1.6;margin:0}
.learn-list .elementor-icon-list-items{gap:10px}
.learn-list .elementor-icon-list-item{align-items:flex-start}
.learn-list .elementor-icon{color:#22c55e;font-size:18px}
.learn-list .elementor-icon-list-text{color:#374151}
.bonus-box{display:flex;align-items:flex-start;gap:12px;margin-top:18px;padding:14px 16px;border-radius:14px;background:rgba(33,86,218,.10);border:1px solid rgba(33,86,218,.18);box-shadow:0 10px 30px rgba(33,86,218,.10)}
.bonus-box .elementor-icon{color:#f59e0b;font-size:20px}
.bonus-box h5,.bonus-box .elementor-heading-title{margin:0;font-size:1rem;color:#0f172a}
.bonus-box p,.bonus-box .elementor-text-editor{margin:2px 0 0;color:#4b5563}
@media (max-width:991px){.curriculum-col::before{left:5px}.curr-item{padding-left:26px}}

/* ========== Success Stories (shortcode) ========== */
.success-cards .elementor-shortcode{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.success-cards .elementor-shortcode>div,
.success-cards .elementor-shortcode>article,
.success-cards .elementor-shortcode>section,
.success-cards .elementor-shortcode>a{
  position:relative;padding:28px 26px;border-radius:22px;text-align:center;
  background:
    radial-gradient(160px 160px at 50% 10%,rgba(24,55,180,.10),transparent 60%),
    radial-gradient(220px 220px at 20% 80%,rgba(168,255,120,.10),transparent 60%),
    rgba(255,255,255,.78);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(226,232,240,.85);box-shadow:0 18px 40px rgba(15,23,42,.08);
  transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s
}
.success-cards .elementor-shortcode>div:hover,
.success-cards .elementor-shortcode>article:hover,
.success-cards .elementor-shortcode>section:hover,
.success-cards .elementor-shortcode>a:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}
.success-cards .elementor-shortcode .stat-icon,
.success-cards .elementor-shortcode .icon,
.success-cards .elementor-shortcode>* > svg:first-of-type,
.success-cards .elementor-shortcode>* i:first-of-type{
  width:64px;height:64px;margin:0 auto 14px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#2156DA 0%,#1837B4 100%);color:#fff;box-shadow:0 16px 36px rgba(24,55,180,.30);position:relative;line-height:1
}
.success-cards .elementor-shortcode>* > svg:first-of-type,
.success-cards .elementor-shortcode>* i:first-of-type{width:28px;height:28px;color:#fff}
.success-cards .elementor-shortcode .stat-icon::after,
.success-cards .elementor-shortcode .icon::after{content:"";position:absolute;left:50%;top:50%;width:110px;height:110px;border-radius:999px;transform:translate(-50%,-50%) translateY(-6px);background:radial-gradient(60px 60px at 50% 50%,rgba(33,86,218,.18),transparent 65%);z-index:-1;filter:blur(2px)}
.success-cards .elementor-shortcode h3,
.success-cards .elementor-shortcode h4,
.success-cards .elementor-shortcode .title{margin:6px 0 8px;font-weight:600;color:#0f172a}
.success-cards .elementor-shortcode p,
.success-cards .elementor-shortcode .desc{color:#4b5563;line-height:1.65;margin:0}
@media (max-width:768px){.success-cards .elementor-shortcode{gap:14px}}

/* ========== SLIDER EXCERPT (force single column) ========== */
/* Use .slider-excerpt inside Prime Slider caption to stack lines vertically */
.slider-excerpt{display:block;margin:0;padding:0}
.slider-excerpt span{display:block;margin-bottom:6px;font-size:17px;font-family:'Kanit',sans-serif;line-height:1.5}
.bdt-slider-excerpt,.bdt-slider-excerpt p,.bdt-ps-slide-content .bdt-slider-excerpt,.bdt-ps-slide-content .bdt-slider-excerpt p{
  -webkit-column-count:1!important;-moz-column-count:1!important;column-count:1!important;column-gap:normal!important
}
.bdt-slider-excerpt .slider-excerpt{display:block!important;margin:0!important;padding:0!important}
.bdt-slider-excerpt .slider-excerpt span{display:block!important;width:100%!important;margin-bottom:6px;font-size:17px;font-family:'Kanit',sans-serif;line-height:1.5}

/* === NAV: Light active pill (like screenshot #2) === */
:root{
  --nav-active-pill-bg: rgba(24,55,180,.16);   /* soft blue fill */
  --nav-active-pill-text: #1837B4;             /* blue text */
}

/* Desktop (Zakra header) */
#tg-masthead .tg-header-main-row nav ul li.current-menu-item > a,
#tg-masthead .tg-header-main-row nav ul li.current_page_item > a,
#tg-masthead .tg-header-main-row nav ul li.current-menu-ancestor > a,
#tg-masthead .tg-header-main-row nav ul li.current_page_parent > a,
#tg-masthead .tg-header-main-row nav ul li > a[aria-current="page"],
.tg-site-header nav li.current-menu-item > a,
.tg-site-header nav li.current_page_item > a,
.tg-site-header nav li.current-menu-ancestor > a,
.tg-site-header nav li.current_page_parent > a{
  background: var(--nav-active-pill-bg) !important;
  color: var(--nav-active-pill-text) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 22px rgba(24,55,180,.12) !important; /* soft drop */
}

/* Hover polish (active) */
#tg-masthead .tg-header-main-row nav ul li.current-menu-item > a:hover,
.tg-site-header nav li.current-menu-item > a:hover{
  filter: brightness(1.02);
}

/* Elementor Nav (ถ้าบางหน้าที่ใช้วิดเจ็ตเมนูของ Elementor) */
.elementor-nav-menu--main > .menu-item.current-menu-item > a,
.elementor-nav-menu--main > .menu-item.current-menu-ancestor > a,
.elementor-nav-menu--main > .menu-item.current_page_parent > a{
  background: var(--nav-active-pill-bg) !important;
  color: var(--nav-active-pill-text) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 22px rgba(24,55,180,.12) !important;
}

/* (ตัวเลือก) Mobile drawer ให้ยังเป็นพิลล์อ่อนเหมือนกัน */
.tg-mobile-navigation .tg-mobile-nav li.current-menu-item > a,
.tg-mobile-navigation .tg-mobile-nav li.current_page_item > a,
.tg-mobile-navigation .tg-mobile-nav li.current-menu-ancestor > a,
.tg-mobile-navigation .tg-mobile-nav li.current_page_parent > a{
  background: var(--nav-active-pill-bg) !important;
  color: var(--nav-active-pill-text) !important;
}

/* === MOBILE MENU • Centered Dropdown (Design #2) === */
:root{
  --nav-panel-w: 440px;        /* ความกว้างการ์ด สูงสุด */
  --nav-offset-top: 74px;      /* ระยะจากขอบบน (เผื่อแถบโลโก้/ปุ่ม X) */
  --nav2-card-bg: rgba(255,255,255,.68);
  --nav2-card-brd: rgba(255,255,255,.55);
  --nav2-card-shadow: 0 18px 46px rgba(15,23,42,.18);
  --nav2-pill: #1837B4;
  --nav2-pill-2:#2156DA;
}

/* ตัว overlay เต็มจอ + จัดวางให้อยู่กลาง */
.tg-mobile-navigation{
  position: fixed !important;
  inset: 0 !important;
  display: grid !important;
  justify-items: center !important;
  align-content: start !important;
  padding: var(--nav-offset-top) 12px 20px !important;
  background: radial-gradient(800px 420px at 50% -120px, rgba(33,86,218,.18), transparent 60%),
              rgba(10,15,30,.25) !important;
  backdrop-filter: blur(2px) !important;
  -webkit-backdrop-filter: blur(2px) !important;
  transform: translateY(-10px);
  opacity: 0; pointer-events: none;
  transition: transform .22s ease, opacity .22s ease;
  z-index: 10050;
}
/* เปิดเมนู */
.tg-mobile-navigation.tg-mobile-navigation--opened{
  transform: translateY(0);
  opacity: 1; pointer-events: auto;
}
/* ยกเลิกสไตล์ drawer เดิม */
.tg-mobile-navigation::after{ content:none !important; }

/* การ์ดเมนูตรงกลาง */
.tg-mobile-navigation .tg-site-navigation,
.tg-mobile-navigation nav{
  width: min(100%, var(--nav-panel-w)) !important;
  max-height: calc(100dvh - var(--nav-offset-top) - 24px) !important;
  overflow-y: auto !important;
  border-radius: 22px !important;
  background: var(--nav2-card-bg) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  backdrop-filter: blur(16px) !important;
  border: 1px solid var(--nav2-card-brd) !important;
  box-shadow: var(--nav2-card-shadow) !important;
  padding: 18px 14px !important;
}

/* ปุ่มปิด “ติดขอบขวาของการ์ด” ไม่ลอยชิดขอบจอ */
.tg-mobile-navigation .tg-mobile-navigation-close{
  position: fixed !important;
  top: 12px;
  right: calc(max(12px, 50vw - var(--nav-panel-w)/2 + 12px));
  width: 44px; height: 44px;
  border-radius: 999px !important;
  display: grid !important; place-items: center !important;
  background: var(--nav2-pill) !important; color:#fff !important; border:0 !important;
  box-shadow: 0 12px 28px rgba(24,55,180,.35) !important;
  z-index: 10100;
}

/* รายการเมนูในรูปแบบคอลัมน์ + ไม่แตกอักษร */
.tg-mobile-navigation .tg-mobile-nav > ul,
.tg-mobile-navigation ul#mobile-menu{
  display:flex !important; flex-direction:column !important;
  gap: 10px !important; margin: 6px 6px 12px !important; padding:0 !important; list-style:none !important;
}
.tg-mobile-navigation li{ width:100% !important; }
.tg-mobile-navigation a{
  position: relative !important; display:block !important; width:100% !important;
  padding: 14px 16px 14px 46px !important; border-radius: 14px !important;
  white-space: nowrap !important; overflow-wrap: normal !important; word-break: keep-all !important;
  text-decoration:none !important; color:#0f172a !important; background:transparent !important;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
/* จุด/ไอคอนซ้ายแบบดีไซน์ #2 */
.tg-mobile-navigation a::before{
  content:""; position:absolute; left:14px; top:50%; transform:translateY(-50%);
  width: 26px; height: 26px; border-radius:10px;
  background: linear-gradient(180deg,var(--nav2-pill-2),var(--nav2-pill));
  box-shadow: 0 10px 24px rgba(24,55,180,.35);
}
.tg-mobile-navigation a:hover{ background: rgba(24,55,180,.10) !important; transform: translateX(2px); }

/* Active item */
.tg-mobile-navigation li.current-menu-item > a,
.tg-mobile-navigation li.current_page_item > a,
.tg-mobile-navigation li.current-menu-ancestor > a,
.tg-mobile-navigation li.current_page_parent > a,/*
 Theme Name: eLearning Child (Full Style, compact)
 Description: Polished UI for header, nav, buttons, Masteriyo cards, sections, and utilities. Buy Now has gradient border; current price 25px.
 Version: 2025-09-02
*/

/* ========== DESIGN TOKENS ========== */
:root{
  --pri:#1837B4; --pri-2:#2156DA;
  --btn-bg:#1837B4; --btn-bg-hover:#04155a; --btn-text:#fff;
  --card-bg:rgba(255,255,255,.75);
  --shadow:0 8px 24px rgba(8,25,77,.08);
  --radius:18px;

  /* nav/drawer */
  --nav-active-bg:#1837B4; --nav-active-text:#fff;
  --nav-drawer-w:360px; --nav-radius:18px;
}

/* ========== GLOBAL ========== */
.hero-card,.mini-card,.stat-card,.course-card{background:var(--card-bg);backdrop-filter:blur(8px);border-radius:var(--radius);box-shadow:var(--shadow)}
.scroll-snap{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px}
.scroll-snap>*{scroll-snap-align:start;min-width:280px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#eef3ff;color:#1a3bb6;font-size:.85rem}
.counter-xl{font-size:2.2rem;font-weight:700;color:#0f1c5a}
.elementor-heading-title{color:var(--pri)!important}

/* Background blobs (subtle fixed scene) */
body{
  --blob1:rgba(43,14,146,1); --blob2:rgba(146,192,252,.4);
  --blob3:rgba(216,248,151,.3); --blob4:rgba(218,62,106,1);
  --fade:rgba(255,255,255,.10);
  background:
    radial-gradient(220px 220px at 12% 18%, var(--blob1), transparent 60%),
    radial-gradient(260px 260px at 78% 22%, var(--blob2), transparent 62%),
    radial-gradient(200px 200px at 22% 72%, var(--blob3), transparent 62%),
    radial-gradient(250px 250px at 88% 78%, var(--blob4), transparent 60%),
    radial-gradient(1200px 1200px at 50% 20%, var(--fade), transparent 70%),
    linear-gradient(135deg,#eef2ff 0%,#fff 60%);
  background-attachment:fixed;background-repeat:no-repeat;background-size:cover;min-height:100vh
}
.site,#page,#content,.wrapper,.container{background:transparent!important}

/* ========== HEADER (glass capsule) ========== */
.tg-header-builder .tg-header-main-row{padding:1rem!important}
#tg-masthead,#tg-masthead .tg-main-header,#tg-masthead .tg-header-main-row,
#tg-masthead .tg-header-transparent-wrapper,#tg-masthead .tg-header-wrapper,#tg-masthead .tg-header-inner,
#tg-masthead.tg-site-header,.site-header,.tg-site-header::after{background:transparent!important;border:0!important;box-shadow:none!important}
#tg-masthead{position:sticky;top:20px;z-index:9999}
#tg-masthead .tg-header-main-row>.tg-container{position:relative;max-width:900px;margin:0 auto;padding:1rem 3rem;z-index:1}
#tg-masthead .tg-header-main-row>.tg-container::before{
  content:"";position:absolute;inset:0;border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.30),rgba(255,255,255,.15));
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.55);box-shadow:0 10px 30px rgba(0,0,0,.10);z-index:-1;pointer-events:none
}
#tg-masthead .tg-header-main-row>.tg-container,
#tg-masthead .tg-header-main-row>.tg-container::before{transition:padding .22s cubic-bezier(.2,.7,.2,1),background .22s ease,box-shadow .22s ease,transform .22s cubic-bezier(.2,.7,.2,1)}
body.scrolled #tg-masthead .tg-header-main-row>.tg-container{padding:1rem 3.5rem;transform:translateY(0) scale(.985)}
body.scrolled #tg-masthead .tg-header-main-row>.tg-container::before{background:rgba(255,255,255,.30);box-shadow:0 12px 32px rgba(0,0,0,.14)}
@media (prefers-reduced-motion:reduce){
  #tg-masthead .tg-header-main-row>.tg-container,
  #tg-masthead .tg-header-main-row>.tg-container::before{transition:none!important}
}

/* Primary menu (desktop) */
#tg-masthead .tg-header-main-row nav ul{display:flex;align-items:center;gap:14px;margin:0;padding:0;list-style:none}
#tg-masthead .tg-header-main-row nav ul li{margin:0;padding:0}
#tg-masthead .tg-header-main-row nav ul li>a,
#tg-masthead .tg-header-main-row nav ul li>a:visited{
  display:inline-flex;align-items:center;padding:10px 18px;border-radius:999px;
  font-weight:400;font-size:15px;color:#757c88!important;text-decoration:none!important;border:0!important;box-shadow:none!important
}
#tg-masthead .tg-header-main-row nav ul li>a::before,
#tg-masthead .tg-header-main-row nav ul li>a::after{content:none!important}
#tg-masthead .tg-header-main-row nav ul li>a:hover{background:rgba(37,99,235,.15);color:var(--pri)!important}
.tg-site-header nav li.current-menu-item>a,
.tg-site-header nav li.current_page_item>a,
.tg-site-header nav li.current-menu-ancestor>a,
.tg-site-header nav li.current_page_parent>a,
#tg-masthead .tg-header-main-row nav ul li>a[aria-current="page"]{background:var(--nav-active-bg);color:var(--nav-active-text);border-radius:10px}
.tg-site-header nav li.current-menu-item>a *{color:inherit}
@media (max-width:768px){
  #tg-masthead{top:10px}
  #tg-masthead .tg-header-main-row>.tg-container{margin:0 8px;padding:8px 14px}
}

/* ========== THEMEGRILL/ZAKRA MOBILE NAV (drawer) ========== */
/* Structure */
.tg-mobile-navigation{
  position:fixed!important;top:0;left:0;height:100dvh;width:min(88vw,var(--nav-drawer-w));
  background:#fff;box-shadow:0 10px 32px rgba(4,21,90,.16);overflow-y:auto;
  -webkit-overflow-scrolling:touch;transform:translateX(-105%);transition:transform .24s ease;z-index:10050
}
.tg-mobile-navigation.tg-mobile-navigation--opened{transform:translateX(0)}
.tg-mobile-navigation.tg-mobile-navigation--opened::after{
  content:"";position:fixed;inset:0;left:min(88vw,var(--nav-drawer-w));
  background:rgba(3,10,30,.45);backdrop-filter:blur(1.5px);z-index:-1
}
@media (max-width:360px){
  .tg-mobile-navigation{width:100vw}
  .tg-mobile-navigation.tg-mobile-navigation--opened::after{left:100vw}
}
/* List + items */
.tg-mobile-navigation .tg-mobile-nav>ul,
.tg-mobile-navigation .menu>ul,
.tg-mobile-navigation ul#mobile-menu,
.tg-mobile-navigation .tg-mobile-nav .menu,
.tg-mobile-navigation .tg-mobile-nav ul{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:8px!important;margin:20px 12px 28px!important;padding:0!important;list-style:none!important}
.tg-mobile-navigation li{width:100%!important}
.tg-mobile-navigation a{
  display:block!important;width:100%!important;padding:14px 16px!important;border-radius:12px!important;
  white-space:nowrap!important;overflow-wrap:normal!important;word-break:keep-all!important;
  text-decoration:none!important;color:#111827!important;background:transparent!important;
  transition:background .18s ease,color .18s ease,transform .18s ease
}
.tg-mobile-navigation a:hover{background:rgba(24,55,180,.08)!important}
.tg-mobile-navigation li.current-menu-item>a,
.tg-mobile-navigation li.current_page_item>a,
.tg-mobile-navigation li.current-menu-ancestor>a,
.tg-mobile-navigation li.current_page_parent>a,
.tg-mobile-navigation a[aria-current="page"]{background:var(--nav-active-bg)!important;color:var(--nav-active-text)!important;font-weight:600}
.tg-mobile-navigation .tg-mobile-navigation-close{position:sticky;top:10px;margin:10px 10px 6px auto;z-index:2}
.nav-vertical-pill,.menu-vertical-label{display:none!important}
body.nav-open{overflow:hidden;touch-action:none}

/* ========== ELEMENTOR NAV (dropdown on mobile) ========== */
.elementor-nav-menu .elementor-item,
.elementor-nav-menu--dropdown .elementor-item{white-space:nowrap;overflow-wrap:normal;word-break:keep-all;letter-spacing:0}
.elementor-nav-menu .elementor-item{font-weight:500;line-height:1.25;padding:12px 16px;border-radius:var(--nav-radius)}
.elementor-nav-menu--dropdown{
  position:fixed!important;top:0;left:0;height:100dvh;width:min(88vw,340px);
  padding:18px 12px 28px;background:#fff;box-shadow:0 8px 28px rgba(4,21,90,.12);
  border-top-right-radius:22px;border-bottom-right-radius:22px;overflow-y:auto;z-index:9999
}
.elementor-nav-menu--dropdown .elementor-nav-menu{display:flex!important;flex-direction:column;gap:6px}
.elementor-nav-menu--dropdown .elementor-item{display:flex;align-items:center;gap:10px;padding:14px;border-radius:12px;transition:background-color .18s,transform .18s}
.elementor-nav-menu--dropdown .elementor-item:hover,
.elementor-nav-menu--dropdown .elementor-item:focus-visible{background:rgba(24,55,180,.08);transform:translateX(2px);outline:none}
.elementor-menu-toggle{margin:0 8px 0 0}
.elementor-nav-menu--dropdown .elementor-menu-toggle{position:absolute;top:12px;right:12px}
.elementor-menu-toggle[aria-expanded="true"]::after{
  content:"";position:fixed;inset:0;left:min(88vw,340px);background:rgba(3,10,30,.45);backdrop-filter:blur(1.5px);z-index:9990
}
@media (max-width:360px){
  .elementor-nav-menu--dropdown{width:100vw;border-radius:0 0 18px 0}
  .elementor-menu-toggle[aria-expanded="true"]::after{left:100vw}
}
@media (min-width:768px){
  .elementor-nav-menu--main .elementor-item{padding:10px 14px}
  .elementor-nav-menu--main{gap:8px}
}
@media (min-width:1024px){
  .elementor-nav-menu--main .elementor-item{border-radius:10px;transition:background-color .18s,color .18s,transform .18s}
  .elementor-nav-menu--main .elementor-item:hover,
  .elementor-nav-menu--main .elementor-item:focus-visible{background:rgba(24,55,180,.08);outline:none}
}

/* ========== BUTTONS (frontend only) ========== */
/* Force real buttons look consistent; avoid styling every <a> as a button */
body:not(.elementor-editor-active)
:is(button,input[type="submit"],input[type="button"],.wp-block-button__link,.wp-element-button,.elementor-button,.elementor-button-link.elementor-button,.woocommerce button.button,.woocommerce input.button,.woocommerce .button,.woocommerce .button.alt,.woocommerce button.single_add_to_cart_button,.masteriyo-btn,.masteriyo-enroll-btn){
  background:var(--btn-bg)!important;color:var(--btn-text)!important;border:none!important;border-radius:999px!important;
  font-family:'Kanit',sans-serif!important;font-size:16px!important;font-weight:400!important;line-height:1!important;
  text-decoration:none!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;
  cursor:pointer!important;transition:background .25s ease,transform .2s ease!important;box-shadow:none!important
}
body:not(.elementor-editor-active)
:is(button:hover,input[type="submit"]:hover,input[type="button"]:hover,.wp-block-button__link:hover,.wp-element-button:hover,.elementor-button:hover,.elementor-button-link.elementor-button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce .button:hover,.woocommerce .button.alt:hover,.masteriyo-btn:hover,.masteriyo-enroll-btn:hover,
button:focus,input[type="submit"]:focus,input[type="button"]:focus,.wp-block-button__link:focus,.wp-element-button:focus,.elementor-button:focus,.elementor-button-link.elementor-button:focus,.woocommerce button.button:focus,.woocommerce input.button:focus,.woocommerce .button:focus,.woocommerce .button.alt:focus,.woocommerce button.single_add_to_cart_button:focus,.masteriyo-btn:focus,.masteriyo-enroll-btn:focus){
  background:var(--btn-bg-hover)!important;transform:translateY(-1px)!important;outline:none!important
}
/* Reset Woo links that look like buttons back to plain links */
body:not(.elementor-editor-active)
:is(a.button,.woocommerce a.button,.woocommerce a.checkout-button,.woocommerce a.add_to_cart_button){
  appearance:none!important;background:none!important;border:0!important;border-radius:0!important;padding:0!important;box-shadow:none!important;transform:none!important;display:inline!important;color:#6b7280!important;text-decoration:none!important;cursor:pointer!important;transition:color .15s ease!important
}
body:not(.elementor-editor-active)
:is(a.button:hover,.woocommerce a.button:hover,.woocommerce a.checkout-button:hover,.woocommerce a.add_to_cart_button:hover,
a.button:focus,.woocommerce a.button:focus,.woocommerce a.checkout-button:focus,.woocommerce a.add_to_cart_button:focus){
  background:none!important;border:0!important;box-shadow:none!important;transform:none!important;text-decoration:none!important;color:#374151!important
}
/* Plain <a> hover (exclude menus/buttons) */
body:not(.elementor-editor-active)
a:not(.elementor-button):not(.wp-block-button__link):not(.wp-element-button):not(.button):not([role="button"])
:not(.tg-site-header a):not(.elementor-nav-menu a):not(.tg-mobile-navigation a){
  text-decoration:none!important;transition:color .15s ease!important
}
body:not(.elementor-editor-active)
a:not(.elementor-button):not(.wp-block-button__link):not(.wp-element-button):not(.button):not([role="button"])
:not(.tg-site-header a):not(.elementor-nav-menu a):not(.tg-mobile-navigation a):hover{color:#374151!important;background:none!important}

/* Woo cart tiny fix */
.wc-block-cart-item__remove-link:hover{background:none!important}

/* ========== MASTERIYO – COURSE CARD ========== */
.masteriyo-course--card,
.masteriyo-course-item--wrapper.masteriyo-course--card,
.masteriyo-course--card .masteriyo-course--content,
.masteriyo-course--card .masteriyo-course-card-footer,
.masteriyo-course--card .masteriyo-course--content__wrapper{background:none!important;border:0!important;box-shadow:none!important;padding:0!important}
.masteriyo-course-item--wrapper.masteriyo-course--card{position:relative!important;overflow:hidden!important;border-radius:26px!important;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s cubic-bezier(.2,.8,.2,1)!important;will-change:transform,box-shadow!important}
.masteriyo-course-item--wrapper.masteriyo-course--card:hover,
.masteriyo-course-item--wrapper.masteriyo-course--card:focus-within{transform:translateY(-8px) scale(1.015)!important}

/* Media */
.masteriyo-course--card .masteriyo-course--img-wrap{margin:16px 0 0!important;border-radius:22px!important;overflow:hidden!important}
.masteriyo-course--card .masteriyo-feature-img img{width:100%!important;height:220px!important;object-fit:cover!important;display:block!important;border-radius:18px!important;transition:transform .45s cubic-bezier(.2,.8,.2,1)!important;will-change:transform!important;backface-visibility:hidden!important}
.masteriyo-course-item--wrapper.masteriyo-course--card:hover .masteriyo-feature-img img{transform:scale(1.06)!important}

/* Content */
.masteriyo-course--card .masteriyo-course--content{padding:18px 20px 0!important}
.masteriyo-course--card .masteriyo-course--content__title a{display:block!important;font-size:20px!important;line-height:1.25!important;font-weight:300!important;color:#0f172a!important;text-decoration:none!important;margin:12px 0 8px!important}
.masteriyo-course--card .masteriyo-course-author{display:flex!important;align-items:center!important;gap:10px!important;color:#64748b!important;font-weight:600!important;font-size:15px!important;margin:6px 0 12px!important}
.masteriyo-course--card .masteriyo-course-author img{width:30px!important;height:30px!important;border-radius:50%!important}
.masteriyo-course--card .masteriyo-course--content__description{color:#475569!important;font-size:15.5px!important;line-height:1.65!important;margin:0 0 14px!important}
.masteriyo-course--card .masteriyo-course--content__description ul{margin:6px 0 0!important;padding:0!important;list-style:none!important}
.masteriyo-course--card .masteriyo-course--content__description li{display:flex!important;gap:10px!important;margin:8px 0!important;align-items:flex-start!important}

/* Stats row */
.masteriyo-course--card .masteriyo-course--content__stats{
  display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:12px!important;font-size:14px!important;color:#64748b!important;margin:8px 0 0!important;padding:14px 0 0!important;border-top:1px solid rgba(148,163,184,.25)!important
}
.masteriyo-course--card .masteriyo-course--content__stats>div{display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;white-space:nowrap!important}

/* Price row */
.masteriyo-course--card .masteriyo-course-card-footer{padding:20px 20px 18px!important;background:transparent!important;border:0!important}
.masteriyo-course--card .masteriyo-course-price{display:flex!important;align-items:baseline!important;gap:12px!important;flex-wrap:nowrap!important;line-height:1!important}
.masteriyo-course--card .masteriyo-course-price del.old-amount .masteriyo-price-amount,
.masteriyo-course--card .masteriyo-course-price del.old-amount .masteriyo-price-amount .masteriyo-price-currencySymbol{font-size:20px!important;color:#94a3b8!important;font-weight:500!important;opacity:.85!important;vertical-align:baseline!important}
.masteriyo-course--card .masteriyo-course-price del.old-amount{ text-decoration:line-through!important;text-decoration-color:#cbd5e1!important;margin-right:2px!important}
/* Current price = 25px */
.masteriyo-course--card .masteriyo-course-price .current-amount .masteriyo-price-amount,
.masteriyo-course--card .masteriyo-course-price .current-amount .masteriyo-price-amount .masteriyo-price-currencySymbol{font-size:22px!important;color:var(--pri)!important;font-weight:500!important;vertical-align:baseline!important;line-height:1!important;display:inline-block!important}
.masteriyo-course--card .masteriyo-course-price .masteriyo-price-amount,
.masteriyo-course--card .masteriyo-course-price .masteriyo-price-amount .masteriyo-price-currencySymbol{display:inline-block!important}

/* Buy Now: gradient border (stays visible on hover) */
.masteriyo-course--card .masteriyo-enroll-btn{
  display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:56px!important;margin-top:2rem!important;
  border-radius:999px!important;border:2px solid transparent!important;
  background:linear-gradient(#1837B4,#1837B4) padding-box,linear-gradient(90deg,#1837B4,#2156DA) border-box!important;
  color:#fff!important;font-weight:500!important;font-size:16.5px!important;text-decoration:none!important;transition:background .25s ease,transform .2s ease,box-shadow .25s ease!important
}
.masteriyo-course--card .masteriyo-enroll-btn:hover{background:linear-gradient(#04155a,#04155a) padding-box,linear-gradient(90deg,#1837B4,#2156DA) border-box!important;transform:translateY(-1px)!important}

/* ========== PAGE-SPECIFIC CLEANUP (example id 708) ========== */
.elementor-708 .elementor-element.elementor-element-8cd3370:not(.elementor-motion-effects-element-type-background),
.elementor-708 .elementor-element.elementor-element-8cd3370>.elementor-motion-effects-container>.elementor-motion-effects-layer{background:none!important}
.elementor-708 .elementor-element.elementor-element-50241dc:not(.elementor-motion-effects-element-type-background),
.elementor-708 .elementor-element.elementor-element-50241dc>.elementor-motion-effects-container>.elementor-motion-effects-layer{background:#eaeaec!important}

/* ========== CART / LAYOUT UTILITIES ========== */
.editor-styles-wrapper table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__quantity .wc-block-cart-item__remove-link,
table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__quantity .wc-block-cart-item__remove-link{background-color:transparent!important;color:#757c88!important;font-weight:300!important;font-size:12px!important}
.wp-block-woocommerce-cart{padding-top:10rem!important}

/* ========== STICKY FOOTER ========== */
html,body{height:100%}
body>#page,body>.site,.tg-site,.site-container,.site-wrap{min-height:100vh;display:flex;flex-direction:column}
main,#primary,#content,.site-content,.content-area,.tg-site .site-content,.tg-content,.elementor-location-header+*{flex:1 0 auto}
footer,#colophon,.site-footer,.elementor-location-footer{margin-top:auto}

/* ========== OPTIONAL: Stats cards ========== */
.imai-stats-title{font:700 44px/1.2 "Kanit",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;text-align:center;color:#0f172a;margin:24px 0 8px}
.imai-stats-sub{text-align:center;color:#6b7280;margin-bottom:28px}
.imai-stats-grid.two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;max-width:960px;margin:0 auto 36px;padding:0 16px}
@media (max-width:768px){.imai-stats-grid.two{grid-template-columns:1fr}}
.imai-stat-card{border-radius:22px;background:rgba(255,255,255,.70);backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.8);box-shadow:0 18px 40px rgba(15,23,42,.08);padding:28px 26px;text-align:center;transition:transform .25s,box-shadow .25s}
.imai-stat-card:hover{transform:translateY(-4px);box-shadow:0 22px 56px rgba(15,23,42,.12)}
.imai-stat-card .stat-icon{width:56px;height:56px;margin:0 auto 14px;display:grid;place-items:center;color:#fff;background:#1837B4;border-radius:14px;font-size:24px}
.imai-stat-card .stat-number{font:700 36px/1 "Kanit",system-ui,sans-serif;color:#0f172a;margin-bottom:8px}
.imai-stat-card .stat-label{font-weight:600;color:#1f2937;margin-bottom:4px}
.imai-stat-card .stat-sub{color:#6b7280;font-size:14px}

/* ========== WHY CHOOSE (3 cards) ========== */
.why-cards .elementor-widget-icon-box{
  position:relative;padding:28px 26px;border-radius:22px;text-align:center;
  background:
    radial-gradient(160px 160px at 50% 10%,rgba(24,55,180,.10),transparent 60%),
    radial-gradient(220px 220px at 20% 80%,rgba(168,255,120,.10),transparent 60%),
    rgba(255,255,255,.78);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(226,232,240,.85);box-shadow:0 18px 40px rgba(15,23,42,.08);
  transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s
}
.why-cards .elementor-widget-icon-box:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}
.why-cards .elementor-widget-icon-box .elementor-icon-box-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;margin:0 0 14px!important;width:auto!important}
.why-cards .elementor-widget-icon-box .elementor-icon{
  position:relative;display:inline-flex!important;width:64px;height:64px;align-items:center;justify-content:center;border-radius:16px!important;
  background:linear-gradient(180deg,#2156DA 0%,#1837B4 100%)!important;color:#fff!important;box-shadow:0 16px 36px rgba(24,55,180,.30);font-size:0;overflow:visible
}
.why-cards .elementor-widget-icon-box .elementor-icon i,
.why-cards .elementor-widget-icon-box .elementor-icon svg{width:28px;height:28px;flex:0 0 28px;display:block;margin:0;line-height:1;color:inherit;fill:currentColor;stroke:currentColor}
.why-cards .elementor-widget-icon-box .elementor-icon::after{
  content:"";position:absolute;left:50%;top:50%;width:110px;height:110px;border-radius:999px;transform:translate(-50%,-50%) translateY(-6px);
  background:radial-gradient(60px 60px at 50% 50%,rgba(33,86,218,.18),transparent 65%);filter:blur(2px);z-index:-1
}
.why-cards .elementor-icon-box-title{margin:6px 0 8px!important}
.why-cards .elementor-icon-box-title,.why-cards .elementor-icon-box-title a{font-weight:600!important;color:#0f172a!important}
.why-cards .elementor-icon-box-description{color:#4b5563;line-height:1.65}
@media (max-width:768px){.why-cards .elementor-widget-icon-box{margin-bottom:14px}}

/* ========== COURSE CARDS ROW (small icons) ========== */
.course-cards-row .elementor-widget-icon-box{position:relative;padding:18px 16px;border-radius:22px;background:none!important;backdrop-filter:none!important;transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s;text-align:center}
.course-cards-row .elementor-widget-icon-box:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}
.course-cards-row .elementor-widget-icon-box .elementor-icon-box-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;margin:0 0 14px!important;width:auto!important}
.course-cards-row .elementor-widget-icon-box .elementor-icon{position:relative;display:inline-flex!important;width:40px;height:40px;align-items:center;justify-content:center;border-radius:16px!important;background:linear-gradient(180deg,#2156DA 0%,#1837B4 100%)!important;color:#fff!important;box-shadow:0 16px 36px rgba(24,55,180,.30);font-size:0;overflow:visible}
.course-cards-row .elementor-widget-icon-box .elementor-icon i,
.course-cards-row .elementor-widget-icon-box .elementor-icon svg{width:18px;height:18px;display:block;margin:0;line-height:1;color:inherit;fill:currentColor;stroke:currentColor}
.course-cards-row .elementor-widget-icon-box .elementor-icon::after{content:"";position:absolute;left:50%;top:50%;width:110px;height:110px;border-radius:999px;transform:translate(-50%,-50%) translateY(-6px);background:radial-gradient(60px 60px at 50% 50%,rgba(33,86,218,.18),transparent 65%);filter:blur(2px);z-index:-1}
.course-cards-row .elementor-icon-box-title{margin:6px 0 8px!important}
.course-cards-row .elementor-icon-box-title,.course-cards-row .elementor-icon-box-title a{font-weight:600!important;color:#0f172a!important}
.course-cards-row .elementor-icon-box-description{color:#4b5563;line-height:1.65}
@media (max-width:768px){.course-cards-row .elementor-widget-icon-box{margin-bottom:14px}}

/* ========== Curriculum + Learn (2-col timeline) ========== */
.curriculum-col,.learn-col{position:relative}
.curriculum-col::before{content:"";position:absolute;left:6px;top:56px;bottom:0;width:3px;background:linear-gradient(180deg,rgba(24,55,180,.35),rgba(24,55,180,.12));border-radius:3px}
.curr-item{position:relative;padding:12px 12px 14px 28px;border-radius:14px;background:rgba(255,255,255,.65);backdrop-filter:blur(6px);box-shadow:0 6px 24px rgba(15,23,42,.06);margin:18px 0}
.curr-item::before{content:"";position:absolute;left:0;top:22px;width:12px;height:12px;border-radius:6px;background:#1837B4;box-shadow:0 0 0 4px rgba(24,55,180,.18)}
.week-badge{display:inline-block;font-size:.78rem;font-weight:600;padding:6px 10px;border-radius:999px;color:#fff;background:#1837B4;box-shadow:0 6px 18px rgba(24,55,180,.25);margin-bottom:10px}
.curr-item h4,.curr-item .elementor-heading-title{margin:6px 0 2px;font-size:1.05rem;color:#0f172a}
.curr-item p,.curr-item .elementor-text-editor{color:#6b7280;line-height:1.6;margin:0}
.learn-list .elementor-icon-list-items{gap:10px}
.learn-list .elementor-icon-list-item{align-items:flex-start}
.learn-list .elementor-icon{color:#22c55e;font-size:18px}
.learn-list .elementor-icon-list-text{color:#374151}
.bonus-box{display:flex;align-items:flex-start;gap:12px;margin-top:18px;padding:14px 16px;border-radius:14px;background:rgba(33,86,218,.10);border:1px solid rgba(33,86,218,.18);box-shadow:0 10px 30px rgba(33,86,218,.10)}
.bonus-box .elementor-icon{color:#f59e0b;font-size:20px}
.bonus-box h5,.bonus-box .elementor-heading-title{margin:0;font-size:1rem;color:#0f172a}
.bonus-box p,.bonus-box .elementor-text-editor{margin:2px 0 0;color:#4b5563}
@media (max-width:991px){.curriculum-col::before{left:5px}.curr-item{padding-left:26px}}

/* ========== Success Stories (shortcode) ========== */
.success-cards .elementor-shortcode{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.success-cards .elementor-shortcode>div,
.success-cards .elementor-shortcode>article,
.success-cards .elementor-shortcode>section,
.success-cards .elementor-shortcode>a{
  position:relative;padding:28px 26px;border-radius:22px;text-align:center;
  background:
    radial-gradient(160px 160px at 50% 10%,rgba(24,55,180,.10),transparent 60%),
    radial-gradient(220px 220px at 20% 80%,rgba(168,255,120,.10),transparent 60%),
    rgba(255,255,255,.78);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(226,232,240,.85);box-shadow:0 18px 40px rgba(15,23,42,.08);
  transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s
}
.success-cards .elementor-shortcode>div:hover,
.success-cards .elementor-shortcode>article:hover,
.success-cards .elementor-shortcode>section:hover,
.success-cards .elementor-shortcode>a:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}
.success-cards .elementor-shortcode .stat-icon,
.success-cards .elementor-shortcode .icon,
.success-cards .elementor-shortcode>* > svg:first-of-type,
.success-cards .elementor-shortcode>* i:first-of-type{
  width:64px;height:64px;margin:0 auto 14px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#2156DA 0%,#1837B4 100%);color:#fff;box-shadow:0 16px 36px rgba(24,55,180,.30);position:relative;line-height:1
}
.success-cards .elementor-shortcode>* > svg:first-of-type,
.success-cards .elementor-shortcode>* i:first-of-type{width:28px;height:28px;color:#fff}
.success-cards .elementor-shortcode .stat-icon::after,
.success-cards .elementor-shortcode .icon::after{content:"";position:absolute;left:50%;top:50%;width:110px;height:110px;border-radius:999px;transform:translate(-50%,-50%) translateY(-6px);background:radial-gradient(60px 60px at 50% 50%,rgba(33,86,218,.18),transparent 65%);z-index:-1;filter:blur(2px)}
.success-cards .elementor-shortcode h3,
.success-cards .elementor-shortcode h4,
.success-cards .elementor-shortcode .title{margin:6px 0 8px;font-weight:600;color:#0f172a}
.success-cards .elementor-shortcode p,
.success-cards .elementor-shortcode .desc{color:#4b5563;line-height:1.65;margin:0}
@media (max-width:768px){.success-cards .elementor-shortcode{gap:14px}}

/* ========== SLIDER EXCERPT (force single column) ========== */
/* Use .slider-excerpt inside Prime Slider caption to stack lines vertically */
.slider-excerpt{display:block;margin:0;padding:0}
.slider-excerpt span{display:block;margin-bottom:6px;font-size:17px;font-family:'Kanit',sans-serif;line-height:1.5}
.bdt-slider-excerpt,.bdt-slider-excerpt p,.bdt-ps-slide-content .bdt-slider-excerpt,.bdt-ps-slide-content .bdt-slider-excerpt p{
  -webkit-column-count:1!important;-moz-column-count:1!important;column-count:1!important;column-gap:normal!important
}
.bdt-slider-excerpt .slider-excerpt{display:block!important;margin:0!important;padding:0!important}
.bdt-slider-excerpt .slider-excerpt span{display:block!important;width:100%!important;margin-bottom:6px;font-size:17px;font-family:'Kanit',sans-serif;line-height:1.5}

/* === NAV: Light active pill (like screenshot #2) === */
:root{
  --nav-active-pill-bg: rgba(24,55,180,.16);   /* soft blue fill */
  --nav-active-pill-text: #1837B4;             /* blue text */
}

/* Desktop (Zakra header) */
#tg-masthead .tg-header-main-row nav ul li.current-menu-item > a,
#tg-masthead .tg-header-main-row nav ul li.current_page_item > a,
#tg-masthead .tg-header-main-row nav ul li.current-menu-ancestor > a,
#tg-masthead .tg-header-main-row nav ul li.current_page_parent > a,
#tg-masthead .tg-header-main-row nav ul li > a[aria-current="page"],
.tg-site-header nav li.current-menu-item > a,
.tg-site-header nav li.current_page_item > a,
.tg-site-header nav li.current-menu-ancestor > a,
.tg-site-header nav li.current_page_parent > a{
  background: var(--nav-active-pill-bg) !important;
  color: var(--nav-active-pill-text) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 22px rgba(24,55,180,.12) !important; /* soft drop */
}

/* Hover polish (active) */
#tg-masthead .tg-header-main-row nav ul li.current-menu-item > a:hover,
.tg-site-header nav li.current-menu-item > a:hover{
  filter: brightness(1.02);
}

/* Elementor Nav (ถ้าบางหน้าที่ใช้วิดเจ็ตเมนูของ Elementor) */
.elementor-nav-menu--main > .menu-item.current-menu-item > a,
.elementor-nav-menu--main > .menu-item.current-menu-ancestor > a,
.elementor-nav-menu--main > .menu-item.current_page_parent > a{
  background: var(--nav-active-pill-bg) !important;
  color: var(--nav-active-pill-text) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 22px rgba(24,55,180,.12) !important;
}

/* (ตัวเลือก) Mobile drawer ให้ยังเป็นพิลล์อ่อนเหมือนกัน */
.tg-mobile-navigation .tg-mobile-nav li.current-menu-item > a,
.tg-mobile-navigation .tg-mobile-nav li.current_page_item > a,
.tg-mobile-navigation .tg-mobile-nav li.current-menu-ancestor > a,
.tg-mobile-navigation .tg-mobile-nav li.current_page_parent > a{
  background: var(--nav-active-pill-bg) !important;
  color: var(--nav-active-pill-text) !important;
}

/* === MOBILE MENU • Centered Dropdown (Design #2) === */
:root{
  --nav-panel-w: 440px;        /* ความกว้างการ์ด สูงสุด */
  --nav-offset-top: 74px;      /* ระยะจากขอบบน (เผื่อแถบโลโก้/ปุ่ม X) */
  --nav2-card-bg: rgba(255,255,255,.68);
  --nav2-card-brd: rgba(255,255,255,.55);
  --nav2-card-shadow: 0 18px 46px rgba(15,23,42,.18);
  --nav2-pill: #1837B4;
  --nav2-pill-2:#2156DA;
}

/* ตัว overlay เต็มจอ + จัดวางให้อยู่กลาง */
.tg-mobile-navigation{
  position: fixed !important;
  inset: 0 !important;
  display: grid !important;
  justify-items: center !important;
  align-content: start !important;
  padding: var(--nav-offset-top) 12px 20px !important;
  background: radial-gradient(800px 420px at 50% -120px, rgba(33,86,218,.18), transparent 60%),
              rgba(10,15,30,.25) !important;
  backdrop-filter: blur(2px) !important;
  -webkit-backdrop-filter: blur(2px) !important;
  transform: translateY(-10px);
  opacity: 0; pointer-events: none;
  transition: transform .22s ease, opacity .22s ease;
  z-index: 10050;
}
/* เปิดเมนู */
.tg-mobile-navigation.tg-mobile-navigation--opened{
  transform: translateY(0);
  opacity: 1; pointer-events: auto;
}
/* ยกเลิกสไตล์ drawer เดิม */
.tg-mobile-navigation::after{ content:none !important; }

/* การ์ดเมนูตรงกลาง */
.tg-mobile-navigation .tg-site-navigation,
.tg-mobile-navigation nav{
  width: min(100%, var(--nav-panel-w)) !important;
  max-height: calc(100dvh - var(--nav-offset-top) - 24px) !important;
  overflow-y: auto !important;
  border-radius: 22px !important;
  background: var(--nav2-card-bg) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  backdrop-filter: blur(16px) !important;
  border: 1px solid var(--nav2-card-brd) !important;
  box-shadow: var(--nav2-card-shadow) !important;
  padding: 18px 14px !important;
}

/* ปุ่มปิด “ติดขอบขวาของการ์ด” ไม่ลอยชิดขอบจอ */
.tg-mobile-navigation .tg-mobile-navigation-close{
  position: fixed !important;
  top: 12px;
  right: calc(max(12px, 50vw - var(--nav-panel-w)/2 + 12px));
  width: 44px; height: 44px;
  border-radius: 999px !important;
  display: grid !important; place-items: center !important;
  background: var(--nav2-pill) !important; color:#fff !important; border:0 !important;
  box-shadow: 0 12px 28px rgba(24,55,180,.35) !important;
  z-index: 10100;
}

/* รายการเมนูในรูปแบบคอลัมน์ + ไม่แตกอักษร */
.tg-mobile-navigation .tg-mobile-nav > ul,
.tg-mobile-navigation ul#mobile-menu{
  display:flex !important; flex-direction:column !important;
  gap: 10px !important; margin: 6px 6px 12px !important; padding:0 !important; list-style:none !important;
}
.tg-mobile-navigation li{ width:100% !important; }
.tg-mobile-navigation a{
  position: relative !important; display:block !important; width:100% !important;
  padding: 14px 16px 14px 46px !important; border-radius: 14px !important;
  white-space: nowrap !important; overflow-wrap: normal !important; word-break: keep-all !important;
  text-decoration:none !important; color:#0f172a !important; background:transparent !important;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
/* จุด/ไอคอนซ้ายแบบดีไซน์ #2 */
.tg-mobile-navigation a::before{
  content:""; position:absolute; left:14px; top:50%; transform:translateY(-50%);
  width: 26px; height: 26px; border-radius:10px;
  background: linear-gradient(180deg,var(--nav2-pill-2),var(--nav2-pill));
  box-shadow: 0 10px 24px rgba(24,55,180,.35);
}
.tg-mobile-navigation a:hover{ background: rgba(24,55,180,.10) !important; transform: translateX(2px); }

/* Active item */
.tg-mobile-navigation li.current-menu-item > a,
.tg-mobile-navigation li.current_page_item > a,
.tg-mobile-navigation li.current-menu-ancestor > a,
.tg-mobile-navigation li.current_page_parent > a,
.tg-mobile-navigation a[aria-current="page"]{
  background: linear-gradient(180deg, rgba(24,55,180,.16), rgba(24,55,180,.12)) !important;
  color: #1837B4 !important; font-weight: 600 !important;
}

/* ปุ่ม Log in เป็นปุ่มกรอบไล่สี (ใส่ CSS Class: menu-btn ให้รายการนั้น) */
.tg-mobile-navigation li.menu-btn > a{
  margin-top: 8px !important; padding-left:16px !important; text-align:center !important;
  border: 2px solid transparent !important;
  background:
    linear-gradient(#1837B4,#1837B4) padding-box,
    linear-gradient(90deg,#1837B4,#2156DA) border-box !important;
  color:#fff !important;
}
.tg-mobile-navigation li.menu-btn > a::before{ content:none !important; }

/* จอเล็กมาก */
@media (max-width:360px){
  :root{ --nav-panel-w: 96vw; }
  .tg-mobile-navigation{ padding: 66px 8px 14px !important; }
}

/* === MOBILE MENU • CENTERED DROPDOWN (Design #2) === */
:root{
  --nav-panel-w: 440px;         /* กว้างสูงสุดของการ์ด */
  --nav-drop-gap: 8px;          /* ระยะห่างจากขอบล่างของ Navbar */
  --nav-top: 72px;              /* fallback – JS จะคำนวณให้ใหม่ */
  --nav2-card-bg: rgba(255,255,255,.68);
  --nav2-card-brd: rgba(255,255,255,.55);
  --nav2-card-shadow: 0 18px 46px rgba(15,23,42,.18);
  --nav2-pill:#1837B4; --nav2-pill-2:#2156DA;
}

/* ตัวครอบเมนู: ให้เป็นกล่องวาง “ใต้ Navbar” ตรงกลางจอ */
.tg-mobile-navigation{
  position: fixed !important;
  top: calc(var(--nav-top) + var(--nav-drop-gap)) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(-8px);
  width: min(94vw, var(--nav-panel-w));
  padding: 0 !important;
  background: transparent !important;      /* กำจัดฉากมืด/ไล่สีเดิม */
  box-shadow: none !important;
  opacity: 0; pointer-events: none;
  transition: transform .22s ease, opacity .22s ease;
  z-index: 10050;
}
.tg-mobile-navigation.tg-mobile-navigation--opened{
  transform: translateX(-50%) translateY(0);
  opacity: 1; pointer-events: auto;
}
/* ยกเลิก overlay/::after ของเวอร์ชันก่อนๆ */
.tg-mobile-navigation::after{ content:none !important; }

/* การ์ดเมนู (ตัว <nav>) */
.tg-mobile-navigation .tg-site-navigation,
.tg-mobile-navigation nav{
  width: 100% !important;
  max-height: calc(100dvh - var(--nav-top) - 24px) !important;
  overflow-y: auto !important;
  border-radius: 22px !important;
  background: var(--nav2-card-bg) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  backdrop-filter: blur(16px) !important;
  border: 1px solid var(--nav2-card-brd) !important;
  box-shadow: var(--nav2-card-shadow) !important;
  padding: 18px 14px !important;
}

/* ปุ่มปิด: ยึดชิดขวาของการ์ด (ไม่ชิดขอบจอ) */
.tg-mobile-navigation .tg-mobile-navigation-close{
  position: absolute !important;
  top: -52px;                  /* โผล่ขึ้นไปเหนือการ์ดให้ทับแถบ navbar พอดี */
  right: 0;
  width: 44px; height: 44px;
  border-radius: 999px !important;
  display: grid !important; place-items: center !important;
  background: var(--nav2-pill) !important; color:#fff !important; border:0 !important;
  box-shadow: 0 12px 28px rgba(24,55,180,.35) !important;
}

/* รายการเมนู */
.tg-mobile-navigation .tg-mobile-nav > ul,
.tg-mobile-navigation ul#mobile-menu{
  display:flex !important; flex-direction:column !important;
  gap: 10px !important; margin: 6px 6px 12px !important; padding:0 !important; list-style:none !important;
}
.tg-mobile-navigation li{ width:100% !important; }
.tg-mobile-navigation a{
  position: relative !important; display:block !important; width:100% !important;
  padding: 14px 16px 14px 46px !important; border-radius: 14px !important;
  white-space: nowrap !important; word-break: keep-all !important; overflow-wrap: normal !important;
  text-decoration:none !important; color:#0f172a !important; background:transparent !important;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
.tg-mobile-navigation a::before{
  content:""; position:absolute; left:14px; top:50%; transform:translateY(-50%);
  width: 26px; height: 26px; border-radius:10px;
  background: linear-gradient(180deg,var(--nav2-pill-2),var(--nav2-pill));
  box-shadow: 0 10px 24px rgba(24,55,180,.35);
}
.tg-mobile-navigation a:hover{ background: rgba(24,55,180,.10) !important; transform: translateX(2px); }

/* Active item */
.tg-mobile-navigation li.current-menu-item > a,
.tg-mobile-navigation li.current_page_item > a,
.tg-mobile-navigation li.current-menu-ancestor > a,
.tg-mobile-navigation li.current_page_parent > a,
.tg-mobile-navigation a[aria-current="page"]{
  background: linear-gradient(180deg, rgba(24,55,180,.16), rgba(24,55,180,.12)) !important;
  color: #1837B4 !important; font-weight: 600 !important;
}

/* ปุ่ม Log in (ให้เพิ่ม CSS Class: menu-btn ที่เมนูนั้น) */
.tg-mobile-navigation li.menu-btn > a{
  margin-top: 6px !important; padding-left:16px !important; text-align:center !important;
  border: 2px solid transparent !important;
  background:
    linear-gradient(#1837B4,#1837B4) padding-box,
    linear-gradient(90deg,#1837B4,#2156DA) border-box !important;
  color:#fff !important;
}
.tg-mobile-navigation li.menu-btn > a::before{ content:none !important; }

/* จอเล็กมาก */
@media (max-width:360px){
  :root{ --nav-panel-w: 96vw; }
}



/* =====================
   SUCCESS STORIES – SHORTCODE CARDS (แก้ใหม่)
===================== */
.success-cards .elementor-shortcode{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;
}
.success-cards .elementor-shortcode > .imai-stat-card{
  position:relative;
  padding:28px 26px;
  border-radius:22px;
  text-align:center;
  background:
    radial-gradient(160px 160px at 50% 10%, rgba(24,55,180,.10), transparent 60%),
    radial-gradient(220px 220px at 20% 80%, rgba(168,255,120,.10), transparent 60%),
    rgba(255,255,255,.78);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border:1px solid rgba(226,232,240,.85);
  box-shadow:0 18px 40px rgba(15,23,42,.08);
  transition:transform .28s cubic-bezier(.2,.7,.2,1), box-shadow .28s ease;
}
.success-cards .elementor-shortcode > .imai-stat-card:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 64px rgba(15,23,42,.14);
}
.success-cards .elementor-shortcode .stat-icon{
  width:64px; height:64px; margin:0 auto 14px;
  border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg,#2156DA 0%, #1837B4 100%);
  color:#fff; box-shadow:0 16px 36px rgba(24,55,180,.30);
  position:relative; line-height:1;
}
.success-cards .elementor-shortcode .stat-icon svg{
  width:28px; height:28px; z-index:1;
}
.success-cards .elementor-shortcode .stat-icon::after{
  content:""; position:absolute; left:50%; top:50%;
  width:110px; height:110px; border-radius:999px;
  transform:translate(-50%,-50%) translateY(-6px);
  background:radial-gradient(60px 60px at 50% 50%, rgba(33,86,218,.18), transparent 65%);
  z-index:-1; filter:blur(2px);
}
.success-cards .elementor-shortcode .stat-value{
  font-size:28px; font-weight:800; color:#0f172a; line-height:1;
}
.success-cards .elementor-shortcode .stat-label{
  font-weight:600; color:#0f172a; margin-top:6px;
}
.success-cards .elementor-shortcode .stat-sub{
  color:#4b5563; margin:6px 0 0; line-height:1.65;
}
@media(max-width:768px){
  .success-cards .elementor-shortcode{ gap:14px; }
}

.tg-mobile-navigation a[aria-current="page"]{
  background: linear-gradient(180deg, rgba(24,55,180,.16), rgba(24,55,180,.12)) !important;
  color: #1837B4 !important; font-weight: 600 !important;
}

/* ปุ่ม Log in เป็นปุ่มกรอบไล่สี (ใส่ CSS Class: menu-btn ให้รายการนั้น) */
.tg-mobile-navigation li.menu-btn > a{
  margin-top: 8px !important; padding-left:16px !important; text-align:center !important;
  border: 2px solid transparent !important;
  background:
    linear-gradient(#1837B4,#1837B4) padding-box,
    linear-gradient(90deg,#1837B4,#2156DA) border-box !important;
  color:#fff !important;
}
.tg-mobile-navigation li.menu-btn > a::before{ content:none !important; }

/* จอเล็กมาก */
@media (max-width:360px){
  :root{ --nav-panel-w: 96vw; }
  .tg-mobile-navigation{ padding: 66px 8px 14px !important; }
}

/* === MOBILE MENU • CENTERED DROPDOWN (Design #2) === */
:root{
  --nav-panel-w: 440px;         /* กว้างสูงสุดของการ์ด */
  --nav-drop-gap: 8px;          /* ระยะห่างจากขอบล่างของ Navbar */
  --nav-top: 72px;              /* fallback – JS จะคำนวณให้ใหม่ */
  --nav2-card-bg: rgba(255,255,255,.68);
  --nav2-card-brd: rgba(255,255,255,.55);
  --nav2-card-shadow: 0 18px 46px rgba(15,23,42,.18);
  --nav2-pill:#1837B4; --nav2-pill-2:#2156DA;
}

/* ตัวครอบเมนู: ให้เป็นกล่องวาง “ใต้ Navbar” ตรงกลางจอ */
.tg-mobile-navigation{
  position: fixed !important;
  top: calc(var(--nav-top) + var(--nav-drop-gap)) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(-8px);
  width: min(94vw, var(--nav-panel-w));
  padding: 0 !important;
  background: transparent !important;      /* กำจัดฉากมืด/ไล่สีเดิม */
  box-shadow: none !important;
  opacity: 0; pointer-events: none;
  transition: transform .22s ease, opacity .22s ease;
  z-index: 10050;
}
.tg-mobile-navigation.tg-mobile-navigation--opened{
  transform: translateX(-50%) translateY(0);
  opacity: 1; pointer-events: auto;
}
/* ยกเลิก overlay/::after ของเวอร์ชันก่อนๆ */
.tg-mobile-navigation::after{ content:none !important; }

/* การ์ดเมนู (ตัว <nav>) */
.tg-mobile-navigation .tg-site-navigation,
.tg-mobile-navigation nav{
  width: 100% !important;
  max-height: calc(100dvh - var(--nav-top) - 24px) !important;
  overflow-y: auto !important;
  border-radius: 22px !important;
  background: var(--nav2-card-bg) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  backdrop-filter: blur(16px) !important;
  border: 1px solid var(--nav2-card-brd) !important;
  box-shadow: var(--nav2-card-shadow) !important;
  padding: 18px 14px !important;
}

/* ปุ่มปิด: ยึดชิดขวาของการ์ด (ไม่ชิดขอบจอ) */
.tg-mobile-navigation .tg-mobile-navigation-close{
  position: absolute !important;
  top: -52px;                  /* โผล่ขึ้นไปเหนือการ์ดให้ทับแถบ navbar พอดี */
  right: 0;
  width: 44px; height: 44px;
  border-radius: 999px !important;
  display: grid !important; place-items: center !important;
  background: var(--nav2-pill) !important; color:#fff !important; border:0 !important;
  box-shadow: 0 12px 28px rgba(24,55,180,.35) !important;
}

/* รายการเมนู */
.tg-mobile-navigation .tg-mobile-nav > ul,
.tg-mobile-navigation ul#mobile-menu{
  display:flex !important; flex-direction:column !important;
  gap: 10px !important; margin: 6px 6px 12px !important; padding:0 !important; list-style:none !important;
}
.tg-mobile-navigation li{ width:100% !important; }
.tg-mobile-navigation a{
  position: relative !important; display:block !important; width:100% !important;
  padding: 14px 16px 14px 46px !important; border-radius: 14px !important;
  white-space: nowrap !important; word-break: keep-all !important; overflow-wrap: normal !important;
  text-decoration:none !important; color:#0f172a !important; background:transparent !important;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
.tg-mobile-navigation a::before{
  content:""; position:absolute; left:14px; top:50%; transform:translateY(-50%);
  width: 26px; height: 26px; border-radius:10px;
  background: linear-gradient(180deg,var(--nav2-pill-2),var(--nav2-pill));
  box-shadow: 0 10px 24px rgba(24,55,180,.35);
}
.tg-mobile-navigation a:hover{ background: rgba(24,55,180,.10) !important; transform: translateX(2px); }

/* Active item */
.tg-mobile-navigation li.current-menu-item > a,
.tg-mobile-navigation li.current_page_item > a,
.tg-mobile-navigation li.current-menu-ancestor > a,
.tg-mobile-navigation li.current_page_parent > a,
.tg-mobile-navigation a[aria-current="page"]{
  background: linear-gradient(180deg, rgba(24,55,180,.16), rgba(24,55,180,.12)) !important;
  color: #1837B4 !important; font-weight: 600 !important;
}

/* ปุ่ม Log in (ให้เพิ่ม CSS Class: menu-btn ที่เมนูนั้น) */
.tg-mobile-navigation li.menu-btn > a{
  margin-top: 6px !important; padding-left:16px !important; text-align:center !important;
  border: 2px solid transparent !important;
  background:
    linear-gradient(#1837B4,#1837B4) padding-box,
    linear-gradient(90deg,#1837B4,#2156DA) border-box !important;
  color:#fff !important;
}
.tg-mobile-navigation li.menu-btn > a::before{ content:none !important; }

/* จอเล็กมาก */
@media (max-width:360px){
  :root{ --nav-panel-w: 96vw; }
}

.skip-link {
  display: none !important;
}


/* === PATCH: allow page scroll while menu is open & let card scroll === */

/* 1) ปลดล็อกสกรอลของ body ที่เคยล็อกไว้ */
body.nav-open{
  overflow: auto !important;
  touch-action: auto !important;
}

/* 2) ไม่ให้ overlay บังการสกรอลของหน้า — เปิด event เฉพาะที่การ์ดกับปุ่มปิด */
.tg-mobile-navigation{
  pointer-events: none !important; /* คลิก/สกรอลทะลุได้ */
}
.tg-mobile-navigation.tg-mobile-navigation--opened{
  pointer-events: none !important; /* คงไว้แม้ตอนเปิด */
}
.tg-mobile-navigation nav,
.tg-mobile-navigation .tg-site-navigation,
.tg-mobile-navigation .tg-mobile-navigation-close{
  pointer-events: auto !important; /* การ์ดและปุ่มปิดคลิกได้ */
}

/* 3) ให้การ์ดเมนูสกรอลภายในได้ลื่นบนมือถือ */
.tg-mobile-navigation .tg-site-navigation,
.tg-mobile-navigation nav{
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  max-height: calc(100dvh - var(--nav-top) - 24px) !important;
}
@supports (height: 100svh){
  .tg-mobile-navigation .tg-site-navigation,
  .tg-mobile-navigation nav{
    max-height: calc(100svh - var(--nav-top) - 24px) !important;
  }
}


/* ============================================
   BEGIN: MASTERIYO • LOGIN & REGISTER (compact)
   ============================================ */

/* 2-คอลัมน์: กล่องรวม Login/Register */
.masteriyo-login-form-wrapper{
  display:flex !important;
  flex-direction:row !important;
  align-items:stretch !important;
  gap:0 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  border-radius:22px;
  overflow:hidden;
  max-width:1100px;
  margin:24px auto;
  position:relative;
}

/* เส้นแบ่งกลางนุ่ม ๆ */
.masteriyo-login-form-wrapper::before{
  content:"";
  position:absolute; left:50%; top:10%; bottom:10%;
  width:1px; transform:translateX(-.5px);
  background:linear-gradient(180deg,transparent,rgba(12,29,78,.18),transparent);
}

/* กล่องซ้าย/ขวา (Login / Register) */
.masteriyo-login-form-wrapper > section{
  flex:0 0 50% !important;
  max-width:50% !important;
  min-width:340px;
  padding:28px 32px !important;

  background:rgba(255,255,255,.78) !important;
  -webkit-backdrop-filter:blur(12px) !important;
  backdrop-filter:blur(12px) !important;
  border:1px solid rgba(226,232,240,.85) !important;
  border-radius:22px;
  box-shadow:0 10px 28px rgba(15,23,42,.08) !important;
  transition:transform .25s ease, box-shadow .25s ease !important;
}
.masteriyo-login-form-wrapper > section:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 36px rgba(15,23,42,.12) !important;
}

/* ล้างพื้นหลังเหลี่ยมของปลั๊กอิน */
.masteriyo-login,
.masteriyo-signup{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
}

/* ไทโปแบบ minimal */
.masteriyo-login-form-wrapper h3,
.masteriyo-login-form-wrapper .masteriyo-title{
  font-weight:500; color:#0f172a; margin-bottom:1rem;
}
.masteriyo-login-form-wrapper p,
.masteriyo-login-form-wrapper label{
  font-weight:400; color:#374151;
}

/* ช่องกรอก (Compact) */
.masteriyo-login-form-wrapper input[type="text"],
.masteriyo-login-form-wrapper input[type="email"],
.masteriyo-login-form-wrapper input[type="password"]{
  width:100%; height:42px; border-radius:14px;
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.95);
  padding:0 12px;
  transition:border-color .2s ease, box-shadow .2s ease;
  font-weight:400;
}
.masteriyo-login-form-wrapper input:focus{
  outline:none;
  border-color:var(--pri,#1837B4);
  box-shadow:0 0 0 4px rgba(24,55,180,.12);
  background:#fff;
}

/* ปุ่มหลัก (Sign in / Register) — Compact */
.masteriyo-login-form-wrapper input[type="submit"],
.masteriyo-login-form-wrapper .masteriyo-btn,
.masteriyo-login-form-wrapper .button{
  display:inline-flex; align-items:center; justify-content:center;
  width:100%; height:46px; margin-top:10px;
  border-radius:999px; border:none;
  background:linear-gradient(180deg,var(--pri,#1837B4),var(--pri-2,#2156DA));
  color:#fff; font-weight:500; letter-spacing:.2px;
  box-shadow:0 8px 18px rgba(24,55,180,.18);
  transition:transform .18s, box-shadow .18s;
}
.masteriyo-login-form-wrapper input[type="submit"]:hover,
.masteriyo-login-form-wrapper .masteriyo-btn:hover,
.masteriyo-login-form-wrapper .button:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 26px rgba(24,55,180,.22);
}

/* ปุ่ม Social (เช่น Google) */
.masteriyo-login-form-wrapper .nsl-container .nsl-button{
  height:46px !important;
  border-radius:12px !important;
  background:rgba(255,255,255,.95) !important;
  border:1px solid rgba(148,163,184,.35) !important;
  font-weight:400 !important;
  transition:transform .18s, box-shadow .18s !important;
}
.masteriyo-login-form-wrapper .nsl-container .nsl-button:hover{
  transform:translateY(-2px); box-shadow:0 10px 22px rgba(8,25,77,.12);
}

/* Register ฝั่งขวาให้อยู่กึ่งกลาง */
.masteriyo-signup{
  display:flex !important; flex-direction:column !important;
  align-items:center !important; justify-content:center !important;
  text-align:center;
}
.masteriyo-signup > *{ width:100%; max-width:520px; margin-inline:auto; }

/* -------- Standalone Register Page (หลังคลิกปุ่ม) -------- */
section.masteriyo-signup,
section.masteriyo-signup .masteriyo-signup--wrapper,
section.masteriyo-signup .masteriyo-form-container{
  background:transparent !important; border:0 !important; box-shadow:none !important; padding:0 !important;
}
section.masteriyo-signup .masteriyo-signup--wrapper{
  max-width:640px !important;          /* กว้างการ์ด */
  margin:32px auto !important;
  padding:24px 28px !important;
  background:rgba(255,255,255,.78) !important;
  -webkit-backdrop-filter:blur(12px) !important; backdrop-filter:blur(12px) !important;
  border:1px solid rgba(226,232,240,.85) !important; border-radius:22px !important;
  box-shadow:0 16px 40px rgba(15,23,42,.10) !important;
}
section.masteriyo-signup .masteriyo-signup--title,
section.masteriyo-signup h3{
  margin:0 0 14px !important; font-weight:500 !important; color:#0f172a !important; text-align:center !important;
}
section.masteriyo-signup form.masteriyo-signup-form{
  width:100% !important; max-width:560px !important; margin:0 auto !important;
}
section.masteriyo-signup input[type="text"],
section.masteriyo-signup input[type="email"],
section.masteriyo-signup input[type="password"]{
  height:42px !important; border-radius:14px !important;
  border:1px solid rgba(148,163,184,.35) !important;
  background:rgba(255,255,255,.95) !important; padding:0 12px !important; font-size:15px !important;
}
section.masteriyo-signup input:focus{
  outline:none !important; border-color:var(--pri,#1837B4) !important;
  box-shadow:0 0 0 4px rgba(24,55,180,.12) !important; background:#fff !important;
}
section.masteriyo-signup input[type="submit"],
section.masteriyo-signup .masteriyo-btn,
section.masteriyo-signup .button{
  height:46px !important; font-size:15px !important; border-radius:999px !important; margin-top:12px !important;
  background:linear-gradient(180deg,var(--pri,#1837B4),var(--pri-2,#2156DA)) !important;
  color:#fff !important; box-shadow:0 8px 18px rgba(24,55,180,.18) !important;
  transition:transform .18s, box-shadow .18s !important;
}
section.masteriyo-signup input[type="submit"]:hover,
section.masteriyo-signup .masteriyo-btn:hover,
section.masteriyo-signup .button:hover{
  transform:translateY(-2px) !important; box-shadow:0 12px 26px rgba(24,55,180,.22) !important;
}
section.masteriyo-signup .nsl-container .nsl-button{
  height:46px !important; border-radius:12px !important;
  background:rgba(255,255,255,.95) !important; border:1px solid rgba(148,163,184,.35) !important; font-weight:400 !important;
}

/* ข้อความอธิบาย/ข้อกำหนด */
section.masteriyo-signup label,
section.masteriyo-signup p,
section.masteriyo-signup .description{ color:#374151 !important; font-weight:400 !important; }
section.masteriyo-signup .masteriyo-signup-form ul,
section.masteriyo-signup .masteriyo-signup-form li{
  list-style:none !important; margin:0 0 6px !important; padding:0 !important; color:#6b7280 !important; text-align:left;
}

/* -------- Responsive -------- */
@media (max-width: 991px){
  .masteriyo-login-form-wrapper{
    flex-direction:column !important; gap:16px !important;
  }
  .masteriyo-login-form-wrapper::before{ display:none; }
  .masteriyo-login-form-wrapper > section{
    flex:1 1 auto !important; max-width:100% !important; min-width:0;
  }
}
@media (max-width: 600px){
  .masteriyo-login-form-wrapper > section{
    padding:18px 16px !important; border-radius:18px;
  }
  section.masteriyo-signup .masteriyo-signup--wrapper{
    max-width:92% !important; padding:18px 16px !important; border-radius:18px !important;
  }
}

/* ================================
   Fix Register Form Size (smaller)
   ================================ */

/* การ์ด Register: ย่อให้เล็กลง */
section.masteriyo-signup .masteriyo-signup--wrapper{
  max-width: 540px !important;   /* เดิม 640px */
  padding: 20px 24px !important;
}

/* เนื้อฟอร์มด้านใน: ย่อความกว้างลง */
section.masteriyo-signup form.masteriyo-signup-form{
  max-width: 460px !important;  /* เดิม 560px */
}

/* อินพุต: ลดความสูง + font */
section.masteriyo-signup input[type="text"],
section.masteriyo-signup input[type="email"],
section.masteriyo-signup input[type="password"]{
  height: 38px !important;
  font-size: 14px !important;
  padding: 0 10px !important;
}

/* ปุ่ม Register: ลดลงให้สมดุล */
section.masteriyo-signup input[type="submit"],
section.masteriyo-signup .masteriyo-btn,
section.masteriyo-signup .button{
  height: 42px !important;
  font-size: 14.5px !important;
  margin-top: 10px !important;
}

/* ปุ่ม Social (Google) */
section.masteriyo-signup .nsl-container .nsl-button{
  height: 42px !important;
  font-size: 14px !important;
  border-radius: 10px !important;
}

/* Responsive: มือถือจอเล็กลงไปอีก */
@media (max-width: 600px){
  section.masteriyo-signup .masteriyo-signup--wrapper{
    max-width: 92% !important;
    padding: 16px !important;
  }
  section.masteriyo-signup form.masteriyo-signup-form{
    max-width: 100% !important;
  }
}

/* Fix Elementor wrapper margin for Masteriyo Register */
.elementor-1022 .elementor-element.elementor-element-9f27b89 {
  margin-top: 1.5rem !important;    /* reset บน/ล่างเหลือ 0 และจัดกึ่งกลาง */
  padding: 0 !important;        /* กัน padding แปลก ๆ */
  max-width: 100% !important;   /* ป้องกันไม่ให้กินพื้นที่เกิน */
}

/* unify login/register input fields */
.masteriyo-login-form-wrapper input[type="text"],
.masteriyo-login-form-wrapper input[type="email"],
.masteriyo-login-form-wrapper input[type="password"],
section.masteriyo-signup input[type="text"],
section.masteriyo-signup input[type="email"],
section.masteriyo-signup input[type="password"] {
  width: 100% !important;
  height: 42px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(148,163,184,.35) !important;
  background: rgba(255,255,255,.95) !important;
  padding: 0 12px !important;
  font-size: 14.5px !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  box-shadow: none !important;
  transition: border-color .2s ease, box-shadow .2s ease !important;
}

/* focus effect */
.masteriyo-login-form-wrapper input[type="text"]:focus,
.masteriyo-login-form-wrapper input[type="email"]:focus,
.masteriyo-login-form-wrapper input[type="password"]:focus,
section.masteriyo-signup input[type="text"]:focus,
section.masteriyo-signup input[type="email"]:focus,
section.masteriyo-signup input[type="password"]:focus {
  outline: none !important;
  border-color: var(--pri,#1837B4) !important;
  box-shadow: 0 0 0 3px rgba(24,55,180,.15) !important;
  background: #fff !important;
}

/* ===== Register/Login form text alignment fix ===== */

/* ตั้งให้ title และข้อความในฟอร์มชิดซ้าย */
section.masteriyo-signup .masteriyo-signup--title,
section.masteriyo-signup h3,
section.masteriyo-signup form label,
section.masteriyo-signup form p,
section.masteriyo-signup form .description,
.masteriyo-login-form-wrapper h3,
.masteriyo-login-form-wrapper p,
.masteriyo-login-form-wrapper label {
  text-align: left !important;
}

/* ปุ่มให้กลับไปกึ่งกลาง */
section.masteriyo-signup input[type="submit"],
section.masteriyo-signup .masteriyo-btn,
section.masteriyo-signup .button,
.masteriyo-login-form-wrapper input[type="submit"],
.masteriyo-login-form-wrapper .masteriyo-btn,
.masteriyo-login-form-wrapper .button {
  display: block !important;
  margin: 12px auto !important;   /* auto ซ้ายขวา → center */
  text-align: center !important;
}

/* ===== Account page (2-column): force REGISTER column centered ===== */
.masteriyo-login-form-wrapper section.masteriyo-signup{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;      /* จัดกึ่งกลางแนวนอน */
  justify-content:center !important;  /* ถ้าต้องการกลางแนวตั้งด้วย */
  text-align:center !important;
}

.masteriyo-login-form-wrapper section.masteriyo-signup .masteriyo-title,
.masteriyo-login-form-wrapper section.masteriyo-signup h3{
  text-align:center !important;
  margin-left:auto !important;
  margin-right:auto !important;       /* กัน margin ฝั่งซ้ายค้าง */
}

/* ปุ่มด้านขวาให้กึ่งกลางแน่นอน */
.masteriyo-login-form-wrapper section.masteriyo-signup .masteriyo-btn,
.masteriyo-login-form-wrapper section.masteriyo-signup .button{
  display:block !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

/* ==========================================
   END: MASTERIYO • LOGIN & REGISTER (compact)
   ========================================== */

.woocommerce-order{
  padding-top: 2rem;
}

/* Hide color-mode toggle in Masteriyo Learn header */
.masteriyo-learn-page button[aria-label*="olor mode"],
.masteriyo-learn-page button[aria-label*="Dark"],
.masteriyo-learn-page button[aria-label*="Light"],
.masteriyo-learn-page .masteriyo-color-mode-toggle,
.masteriyo-learn-page .masteriyo-dark-mode-toggle,
.masteriyo-learn-page [data-theme-toggle] {
  display: none !important;
}

/* ===== Hide Masteriyo color-mode toggle (Learn header) ===== */

/* จงใจยิงกว้างและไม่ผูกกับ class ที่สุ่ม (css-xxxxx) ของ Chakra */
.masteriyo-learn__header button[aria-label*="mode" i],
.masteriyo-learn__header button[aria-label*="theme" i],
.masteriyo-learn__header button[aria-label*="dark" i],
.masteriyo-learn__header button[aria-label*="light" i],
.masteriyo-learn__header [data-theme-toggle],
.masteriyo-learn__header .masteriyo-color-mode-toggle,
.masteriyo-learn__header .masteriyo-dark-mode-toggle {
  display: none !important;
}

/* กันเคสปุ่มถูกห่อด้วย container เฉพาะของ Masteriyo */
.masteriyo-learn__header .chakra-stack > [data-theme-toggle],
.masteriyo-learn__header .chakra-stack > .masteriyo-color-mode-toggle,
.masteriyo-learn__header .chakra-stack > .masteriyo-dark-mode-toggle {
  display: none !important;
}

/* ถ้าปุ่มนั้นเป็น Chakra Button ทั่วไป ให้ซ่อน "ไอคอนพระอาทิตย์/พระจันทร์" ด้วย (เผื่อ aria-label เปลี่ยน) */
.masteriyo-learn__header button svg[viewBox="0 0 24 24"][focusable="false"][aria-hidden="true"] + * {
  display: none !important;
}

/* === IMAI Video Review Cards === */
.review-cards{display:grid;gap:22px}
.review-cards.grid-1{grid-template-columns:1fr}
.review-cards.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.review-cards.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.review-cards.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:991px){.review-cards.grid-4,.review-cards.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:600px){.review-cards{grid-template-columns:1fr}}

.review-card{
  padding:18px;border-radius:22px;
  background:
    radial-gradient(160px 160px at 50% 10%,rgba(24,55,180,.10),transparent 60%),
    rgba(255,255,255,.78);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(226,232,240,.85);
  box-shadow:0 18px 40px rgba(15,23,42,.08);
  transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s;
}
.review-card:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}
.imai-video-embed iframe,.review-card video{width:100%;height:auto;border-radius:14px;aspect-ratio:16/9;background:#000}
.review-title{margin:12px 4px 6px;font-weight:600;color:#0f172a}
.review-excerpt{color:#4b5563;line-height:1.65;margin:0 4px 4px}
.review-empty{color:#6b7280}

/* === Reviews: force 1 column on mobile === */
@media (max-width: 768px){
  /* ครอบให้หมดทั้งกรณีมีคลาส grid-2/3/4 */
  .review-cards,
  .elementor-shortcode .review-cards,
  .elementor-widget-shortcode .review-cards {
    display: grid;
    grid-template-columns: 1fr !important;
    gap: 14px;
  }
  .review-cards.grid-2,
  .review-cards.grid-3,
  .review-cards.grid-4 {
    grid-template-columns: 1fr !important;
  }
  .review-card { width: 100%; }
  /* วิดีโอให้เต็มการ์ด */
  .review-card iframe,
  .review-card video { width:100%; height:auto; }
}
/* === Home Reviews – Cards only (3 cols) === */
.hr-grid{display:grid;gap:24px}
.hr-grid.hr-grid-1{grid-template-columns:1fr}
.hr-grid.hr-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.hr-grid.hr-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.hr-grid.hr-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1024px){.hr-grid.hr-grid-3,.hr-grid.hr-grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.hr-grid{grid-template-columns:1fr}}

.hr-card{
  display:flex;flex-direction:column;overflow:hidden;border-radius:22px;
  background:radial-gradient(160px 160px at 50% 10%,rgba(24,55,180,.10),transparent 60%),rgba(255,255,255,.78);
  backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.85);
  box-shadow:0 18px 40px rgba(15,23,42,.08);text-decoration:none;transition:.28s cubic-bezier(.2,.7,.2,1);
}
.hr-card:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}

.hr-thumb{
  aspect-ratio:16/9;background-size:cover;background-position:center;
  position:relative;border-radius:18px;margin:14px 14px 0;overflow:hidden;
}
.hr-play{position:absolute;inset:auto auto 12px 12px;width:38px;height:38px;border-radius:50%;background:rgba(15,23,42,.75);display:inline-block}
.hr-play:after{content:"";position:absolute;left:14px;top:10px;border-left:12px solid #fff;border-top:8px solid transparent;border-bottom:8px solid transparent}

.hr-body{padding:14px 16px 16px}
.hr-title{margin:6px 0 6px;color:#0f172a;font-weight:700;font-size:18px}
.hr-excerpt{margin:0;color:#4b5563;line-height:1.65}
.hr-empty{color:#6b7280;text-align:center}
/* ============= 1) Mobile: บังคับ 1 คอลัมน์ ============= */
@media (max-width: 768px){
  /* Home reviews ที่ทำด้วย shortcode */
  .home-reviews .hr-grid,
  .elementor .hr-grid,
  .hr-grid{
    grid-template-columns: 1fr !important;
  }
  /* เผื่อกริดของส่วนรีวิวหลักด้วย */
  .review-cards,
  .div.review-cards.grid-2,
  .div.review-cards.grid-3,
  .div.review-cards.grid-4{
    grid-template-columns: 1fr !important;
  }
}

/* ============= 2) Hover แล้ววิดีโอหาย: บังคับให้เห็นเสมอ ============= */
/* ธีม/ปลั๊กอินบางตัวลด opacity ของสื่อในลิงก์ตอน hover → กันไว้ */
.hr-card:hover img,
.hr-card:hover video,
.review-card:hover img,
.review-card:hover video {
  opacity: 1 !important;
  visibility: visible !important;
}

/* กันอาการ flicker/hardware-accel เมื่อพาเรนต์มี transform + วิดีโออยู่ข้างใน */
.hr-card,
.hr-thumb,
.hr-thumb::before,
.hr-thumb video,
.review-card,
.review-card video,
.imai-video--mp4 {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);        /* สร้าง layer แยก ลดกระพริบ */
}

/* ถ้าบางเครื่องยังมีอาการ ให้ลด motion ตอน hover */
@media (prefers-reduced-motion: reduce){
  .hr-card:hover{ transform: none; }
}

/* ให้สื่อเต็มกรอบเสมอ */
.hr-thumb video,
.hr-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* โซนรีวิวกันโดนทับ + เว้นช่องเล็กน้อย */
.home-reviews{isolation:isolate;margin-bottom:24px}

/* กริดและการ์ด (เหมือนเดิม) */
.hr-grid{display:grid;gap:24px}
.hr-grid.hr-grid-1{grid-template-columns:1fr}
.hr-grid.hr-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.hr-grid.hr-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.hr-grid.hr-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:768px){ .hr-grid{grid-template-columns:1fr !important} }

.hr-card{
  display:flex;flex-direction:column;border-radius:22px;overflow:hidden;cursor:pointer;
  background:radial-gradient(160px 160px at 50% 10%,rgba(24,55,180,.10),transparent 60%),rgba(255,255,255,.78);
  backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.85);
  box-shadow:0 18px 40px rgba(15,23,42,.08);transition:.28s cubic-bezier(.2,.7,.2,1);
}
.hr-card:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(15,23,42,.14)}

.hr-thumb{
  aspect-ratio:16/9;background-size:cover;background-position:center;
  border-radius:18px;margin:14px 14px 0;overflow:hidden;position:relative;
}
.hr-play{position:absolute;left:12px;bottom:12px;width:38px;height:38px;border-radius:50%;background:rgba(15,23,42,.75)}
.hr-play:after{content:"";position:absolute;left:14px;top:10px;border-left:12px solid #fff;border-top:8px solid transparent;border-bottom:8px solid transparent}

.hr-body{padding:14px 16px 16px}
.hr-title{margin:6px 0 6px;color:#0f172a;font-weight:700;font-size:18px}
.hr-excerpt{margin:0;color:#4b5563;line-height:1.65}
.hr-empty{color:#6b7280;text-align:center}

/* กันอาการ hover แล้ววิดีโอ/รูปหาย (บางธีมลด opacity ของสื่อในลิงก์/การ์ด) */
.hr-card:hover img, .hr-card:hover video {opacity:1 !important;visibility:visible !important}
.hr-card, .hr-thumb, .hr-thumb video {backface-visibility:hidden;transform:translateZ(0)}

/* Lightbox */
.hr-lock{overflow:hidden}
.hr-lightbox{position:fixed;inset:0;z-index:9999;display:block;opacity:0;pointer-events:none;transition:.2s}
.hr-lightbox.is-open{opacity:1;pointer-events:auto}
.hr-lightbox__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.75)}
.hr-lightbox__dialog{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(92vw,960px);max-height:86vh;display:flex;flex-direction:column;gap:8px
}
.hr-lightbox__content{background:#000;border-radius:14px;overflow:hidden}
.hr-lightbox__content iframe{width:100%;height:min(54vw,540px);display:block}
.hr-lightbox__close{
  align-self:flex-end;background:#fff;border:0;border-radius:999px;width:38px;height:38px;
  font-size:22px;line-height:38px;cursor:pointer;box-shadow:0 6px 16px rgba(0,0,0,.25)
}

/* Grid 2 คอลัมน์ (ให้หน้าตาเข้ากับ layout เดิม) */
.review-cards--home{ display:grid; gap:24px; }
.review-cards--home.grid-1{ grid-template-columns: 1fr; }
.review-cards--home.grid-2{ grid-template-columns: repeat(2, minmax(0,1fr)); }
.review-cards--home.grid-3{ grid-template-columns: repeat(3, minmax(0,1fr)); }
.review-cards--home.grid-4{ grid-template-columns: repeat(4, minmax(0,1fr)); }

/* มือถือ: บังคับ 1 คอลัมน์ */
@media (max-width:768px){
  .review-cards--home{ grid-template-columns: 1fr !important; }
}

/* กันเอฟเฟกต์ hover จากธีมหายวิดีโอ (ปลอดภัยไว้ก่อน) */
.review-card:hover img,
.review-card:hover video{ opacity:1 !important; visibility:visible !important; }

/* ซ่อน meta ทั้งหมดใต้หัวข้อโพสต์ */
.entry-meta,
.post-meta,
.meta,
.single-post .entry-footer {
    display: none !important;
}

/* ========== HERO (EA Post Grid ที่ตั้ง Posts Per Page = 1) ========== */
.articles-hero-grid.elementor-widget-eael-post-grid .eael-grid-post{
  border-radius: var(--radius) !important;
  background: var(--card-bg) !important;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(226,232,240,.85) !important;
  box-shadow: var(--shadow) !important;
  overflow: hidden;
}
.articles-hero-grid.elementor-widget-eael-post-grid .eael-entry-title a{
  color:#0f172a !important; font-weight:700 !important; font-size:24px !important;
}
.articles-hero-grid.elementor-widget-eael-post-grid .eael-entry-title a:hover{ color:var(--pri) !important; }
.articles-hero-grid.elementor-widget-eael-post-grid .eael-read-more{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px; border-radius:12px;
  color:#fff !important;
  background: linear-gradient(135deg,var(--pri),var(--pri-2)) !important;
  box-shadow: 0 8px 18px rgba(24,55,180,.22);
}

/* ========== GRID ปกติ (EA Post Grid อันล่าง) ========== */
.articles-grid.elementor-widget-eael-post-grid .eael-grid-post{
  border-radius: var(--radius) !important;
  background: var(--card-bg) !important;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(226,232,240,.85) !important;
  box-shadow: var(--shadow) !important;
  transition: transform .25s, box-shadow .25s;
  overflow: hidden;
}
.articles-grid.elementor-widget-eael-post-grid .eael-grid-post:hover{ transform: translateY(-6px); }
.articles-grid.elementor-widget-eael-post-grid .eael-entry-title a{
  color:#0f172a !important; font-weight:600 !important; font-size:18px !important;
}
.articles-grid.elementor-widget-eael-post-grid .eael-entry-title a:hover{ color:var(--pri) !important; }
.articles-grid.elementor-widget-eael-post-grid .eael-read-more{
  border-radius:12px; padding:8px 12px; color:#fff !important;
  background: linear-gradient(135deg,var(--pri),var(--pri-2)) !important;
}

/* ป้ายหมวดมุมรูป (ถ้ามี) */
.elementor-widget-eael-post-grid .eael-entry-thumbnail{ position: relative; }
.elementor-widget-eael-post-grid .eael-entry-meta .eael-categories a{
  position:absolute; left:12px; top:12px;
  background: linear-gradient(135deg,var(--pri),var(--pri-2)) !important;
  color:#fff !important; font-size:12px; font-weight:700;
  padding:6px 10px; border-radius:999px; box-shadow:0 6px 16px rgba(24,55,180,.25);
}

/* ===== EA Post Grid • ทำให้เป็นการ์ดสไตล์ IMAI ===== */

/* ตัวการ์ด */
body .elementor .elementor-widget-eael-post-grid .eael-post-grid-container .eael-grid-post{
  border-radius: var(--radius, 18px) !important;
  background: var(--card-bg, rgba(255,255,255,.78)) !important;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(226,232,240,.85) !important;
  box-shadow: var(--shadow, 0 8px 24px rgba(8,25,77,.08)) !important;
  overflow: hidden;
  transition: transform .25s, box-shadow .25s;
}
body .elementor .elementor-widget-eael-post-grid .eael-post-grid-container .eael-grid-post:hover{
  transform: translateY(-6px);
}

/* รูปภาพ + มุมโค้ง */
body .elementor .elementor-widget-eael-post-grid .eael-entry-thumbnail{
  overflow: hidden; border-radius: calc(var(--radius,18px) - 2px) !important;
}
body .elementor .elementor-widget-eael-post-grid .eael-entry-thumbnail img{
  width:100%; height:auto; display:block; object-fit:cover;
}

/* ปิดฟิล์ม/โอเวอร์เลย์สีน้ำเงินที่ EA ใส่มา */
body .elementor .elementor-widget-eael-post-grid .eael-entry-overlay,
body .elementor .elementor-widget-eael-post-grid .eael-entry-overlay:before{
  display:none !important;
}

/* เนื้อหาในการ์ด */
body .elementor .elementor-widget-eael-post-grid .eael-entry-wrapper{
  background: transparent !important;
}
body .elementor .elementor-widget-eael-post-grid .eael-entry-title a{
  color:#0f172a !important; font-weight:600 !important; font-size:18px !important;
  text-decoration:none !important;
}
body .elementor .elementor-widget-eael-post-grid .eael-entry-title a:hover{ color: var(--pri,#1837B4) !important; }
body .elementor .elementor-widget-eael-post-grid .eael-post-grid-excerpt{ color:#475569 !important; line-height:1.6; }

/* ปุ่ม Read More */
body .elementor .elementor-widget-eael-post-grid .eael-post-elements-readmore-btn,
body .elementor .elementor-widget-eael-post-grid .eael-read-more{
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px; border-radius:12px;
  color:#fff !important; text-decoration:none !important;
  background: linear-gradient(135deg,var(--pri,#1837B4),var(--pri-2,#2156DA)) !important;
  box-shadow: 0 8px 18px rgba(24,55,180,.22) !important;
}

/* meta ใต้หัวข้อในการ์ด (วันที่, ผู้เขียน ฯลฯ) – ซ่อนได้ถ้าไม่อยากให้โชว์ */
body .elementor .elementor-widget-eael-post-grid .eael-entry-meta{
  color:#6b7280 !important; font-size:12.5px !important;
}

.eael-post-grid-container .eael-post-grid .eael-grid-post{
  padding: 0 !important;
}

/* ปลดล็อกความสูงรูปบทความ EA Post Grid เฉพาะมือถือ */
@media (max-width: 767px){
  .elementor-widget-eael-post-grid .eael-entry-thumbnail{
    height: auto !important;     /* ยกเลิกค่าที่ถูกล็อก */
    aspect-ratio: 16/9;          /* กำหนดสัดส่วน 16:9 หรือจะใช้ 4/3 ก็ได้ */
    overflow: hidden !important; /* กันรูปเกิน */
  }
  .elementor-widget-eael-post-grid .eael-entry-thumbnail img{
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: var(--radius, 18px) var(--radius, 18px) 0 0;
  }
}/* =========================
   IMAI Footer — Elementor Free
   ใช้กับ Section ที่มี class: imai-footer
   ========================= */
:root{
  --pri:#1837B4; --pri-2:#2156DA;
  --footer-bg:#0f172a;
  --footer-text:#9ca3af;
  --footer-head:#fff;
  --footer-link:#9ca3af;
  --footer-link-hover:#2156DA;
}

/* Section */
.imai-footer{
  position:relative;
  background:var(--footer-bg);
  color:var(--footer-text);
  padding:64px 0;
}
.imai-footer::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:rgba(255,255,255,.06);
}

/* แปลง .elementor-container ให้เป็น Grid 5 คอลัมน์ */
.imai-footer .elementor-container{
  display:grid !important;
  grid-template-columns: 1.5fr repeat(4,1fr);
  column-gap:56px; row-gap:28px;
  align-items:start;
}

/* เคลียร์สไตล์ margin จากวิดเจ็ตเริ่มต้นที่อาจทำให้ซ้อน */
.imai-footer .elementor-widget{margin:0 !important}
.imai-footer .elementor-widget:not(:last-child){margin-bottom:10px !important}
.imai-footer .elementor-widget-wrap{align-content:start}

/* ===== คอลัมน์ 1: แบรนด์ ===== */
.imai-footer .elementor-column:nth-child(1) .elementor-widget-wrap{
  display:grid; grid-template-columns:auto 1fr; gap:14px 14px;
}
.imai-footer .brand-icon img{
  width:40px;height:40px;border-radius:999px;display:block;object-fit:cover;
  box-shadow:0 10px 24px rgba(24,55,180,.35);
}
.imai-footer .brand-title{
  margin:0; color:var(--footer-head); font-weight:700; line-height:1.1; letter-spacing:.2px;
}
.imai-footer .brand-desc{
  grid-column:1 / -1; margin:8px 0 0; color:var(--footer-text); line-height:1.7;
}

/* ===== คอลัมน์เมนู (2–5) ===== */
.imai-footer .footer-title{
  margin:0 0 14px !important;
  color:var(--footer-head); font-weight:700; font-size:20px;
}
.imai-footer .footer-list{list-style:none;margin:0;padding:0}
.imai-footer .footer-list li{margin:10px 0;line-height:1.6}

/* ลิงก์ */
.imai-footer a{
  color:var(--footer-link); text-decoration:none; transition:color .18s ease, opacity .18s ease;
}
.imai-footer a:hover,
.imai-footer a:focus{ color:var(--footer-link-hover); outline:none }
.imai-footer a:focus-visible{ outline:2px solid var(--pri-2); outline-offset:2px; border-radius:6px }

/* ===== Responsive ===== */
@media (max-width:1024px){
  .imai-footer .elementor-container{
    grid-template-columns:1fr 1fr; column-gap:36px;
  }
  .imai-footer .elementor-column:nth-child(1){grid-column:1 / -1}
}
@media (max-width:640px){
  .imai-footer{padding:48px 0}
  .imai-footer .elementor-container{grid-template-columns:1fr; row-gap:18px}
}

/* แถบลิขสิทธิ์ (ถ้ามีวิดเจ็ต Text ด้านล่างสุด ให้ใส่ class: footer-bottom) */
.imai-footer .footer-bottom{
  margin-top:28px; padding-top:16px;
  border-top:1px solid rgba(255,255,255,.06);
  font-size:14px; color:#a3aab6;
}
/* ===== Footer heading override (แรงกว่าทุกที่) ===== */
.imai-footer .elementor-widget-heading .elementor-heading-title,
.imai-footer .footer-title,
.imai-footer h2, .imai-footer h3, .imai-footer h4, .imai-footer h5 {
  color: var(--footer-head, #fff) !important;
  font-weight: 500 !important;
  margin: 0 0 14px !important;
  letter-spacing: .1px;
  font-size: 22px !important;
}

/* ลิงก์ที่อยู่ในหัวข้อ (กันโดนธีม/Elementor เปลี่ยนสี) */
.imai-footer .elementor-widget-heading .elementor-heading-title a {
  color: inherit !important;
  text-decoration: none !important;
}

/* กัน heading ของคอลัมน์แรก (IMAI ACADEMY) โดนกฎ global */
.imai-footer .brand-title {
  color: var(--footer-head, #fff) !important;
  font-weight: 500 !important;
}
/* ——— ตัดช่องว่างใต้คอนเทนต์ก่อนฟุตเตอร์ ——— */
#content.site-content,
.site-content,
.tg-site .site-content,
.tg-content {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* ——— ล้าง margin/padding ของ Section สุดท้าย (Elementor) ——— */
.elementor-section-wrap > .elementor-section:last-child,
.elementor > .elementor-section:last-child,
.elementor .elementor-top-section:last-child {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* ——— ฟุตเตอร์ (รวม HFE/Elementor Footer) ไม่ให้ดันลง ——— */
footer, #colophon, .site-footer, .hfe-footer, .elementor-location-footer {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
.hfe-footer .elementor-section { margin-bottom: 0 !important; }

/* ——— Sticky footer layout (กันหน้าสั้นแล้วเหลือช่องว่าง) ——— */
html, body { height: 100%; }
body > #page, body > .site, .tg-site, .site-container, .site-wrap {
  min-height: 100vh; display: flex; flex-direction: column;
}
main, #primary, #content, .site-content, .content-area, .tg-site .site-content, .tg-content,
.elementor-location-header + * {
  flex: 1 0 auto;
}
footer, #colophon, .site-footer, .elementor-location-footer { margin-top: auto; }
/* ========== 1) ล้าง margin/padding ด้านล่างของโครงหลักทั้งหมด ========== */
html, body { margin-bottom:0 !important; padding-bottom:0 !important; }
#page, .site, .site-container, .site-wrap,
.site-main, .content-area, #primary,
#content, .site-content, .tg-site, .tg-content {
  margin-bottom:0 !important;
  padding-bottom:0 !important;
}

/* ========== 2) Sticky footer layout ให้ฟุตเตอร์กดลงก้นจอ ========== */
body > #page, body > .site, .tg-site {
  min-height:100vh; display:flex; flex-direction:column;
}
main, #primary, #content, .site-content, .content-area { flex:1 0 auto; }
footer, #colophon, .site-footer, .elementor-location-footer { margin-top:auto; }

/* ========== 3) ฆ่าพื้น/กล่อง/ pseudo-element ที่ธีม/ปลั๊กอินบางตัวเติมไว้ด้านล่าง ========== */
#page::after, .site::after, .site-main::after,
#content::after, .site-content::after,
.content-area::after, #primary::after,
.hfe-footer::after, .elementor-location-footer::after {
  content:none !important; display:none !important; height:0 !important;
}

/* ========== 4) กัน Section สุดท้ายของ Elementor ทิ้งช่องว่าง ========== */
.elementor-section-wrap > .elementor-section:last-child,
.elementor > .elementor-section:last-child,
.elementor .elementor-top-section:last-child {
  margin-bottom:0 !important; padding-bottom:0 !important;
}

/* ========== 5) ฟุตเตอร์ HFE และวิดเจ็ตล่างสุด ========== */
.hfe-footer, .hfe-footer .elementor-section,
footer, #colophon, .site-footer {
  margin-bottom:0 !important; padding-bottom:0 !important;
}

/* ========== 6) บางปลั๊กอินปุ่ม Back-to-Top จะใส่ padding-bottom ให้ body ========== */
body[class*="back-to-top"], body.has-back-to-top { padding-bottom:0 !important; }
/* ฆ่าช่องว่างท้ายบทความ/เพจ ก่อนฟุตเตอร์ */
.site-main > article,
.content-area > article,
#primary > article,
.site-main > .page,
.site-main > .post,
#post-708 {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* เนื้อหาภายในบทความก็ไม่ให้มีช่องว่างทิ้งท้าย */
.site-main > article:last-of-type .entry-content,
.content-area > article:last-of-type .entry-content,
#post-708 .entry-content {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Elementor container ในเพจ ให้ไม่มี padding ล่าง */
#post-708 .elementor,
.site-main > article:last-of-type .elementor {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* คอนเทนเนอร์ของธีมในส่วนเนื้อหา ให้ชิดล่าง */
.site-content .tg-container {
  padding-bottom: 0 !important;
}

/* กันเคสที่ธีมใส่เส้น/กล่อง pseudo-element ท้ายคอนเทนต์ */
#primary::after,
.site-content::after,
.content-area::after,
#post-708::after {
  content: none !important;
  display: none !important;
  height: 0 !important;
}
