/*
Theme Name: NutriCare Pro
Theme URI: https://example.com/nutricare-pro
Author: LakOm International Technologies
Author URI: https://example.com
Description: A modern, lightweight, SEO-friendly WordPress theme built for Nutritionists, Dietitians, Health Coaches and Online Consultation professionals. Includes a Customizer-based header/footer builder, popup & announcement system, blog layouts, and pre-built nutrition business sections.
Version: 1.16.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: nutricare
Tags: blog, e-commerce, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, rtl-language-support, accessibility-ready
*/

/* ==========================================================================
   1. CSS Custom Properties (Design Tokens) — edited live by the Customizer
   ========================================================================== */
:root{
  --nc-color-primary:#4f9d69;      /* soft green */
  --nc-color-primary-dark:#3c7d52;
  --nc-color-secondary:#e7ddcb;    /* natural beige */
  --nc-color-accent:#bcd9c8;       /* light healthcare accent */
  --nc-color-bg:#ffffff;
  --nc-color-surface:#f8f7f3;
  --nc-color-text:#2b2f2a;
  --nc-color-text-muted:#6b7269;
  --nc-color-border:#e7e9e4;

  --nc-font-heading:'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
  --nc-font-body:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --nc-font-size-base:16px;
  --nc-line-height-base:1.65;

  --nc-container-width:1200px;
  --nc-radius:14px;
  --nc-radius-sm:8px;
  --nc-shadow:0 8px 24px rgba(43,47,42,.08);
  --nc-transition:.25s ease;

  --nc-header-height:84px;
}

/* ==========================================================================
   2. Reset / Base
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;max-width:100%}
body{
  margin:0;
  font-family:var(--nc-font-body);
  font-size:var(--nc-font-size-base);
  line-height:var(--nc-line-height-base);
  color:var(--nc-color-text);
  background:var(--nc-color-bg);
  max-width:100%;
}
/* Horizontal-scroll containment lives on the content wrapper (not html/body),
   because overflow-x:hidden on html/body breaks position:sticky — that was
   the reason the sticky header wasn't sticking when scrolling. */
.nc-site-content{overflow-x:hidden}
.nc-footer{overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--nc-color-primary-dark);text-decoration:none;transition:color var(--nc-transition)}
a:hover{color:var(--nc-color-primary)}
h1,h2,h3,h4,h5,h6{font-family:var(--nc-font-heading);line-height:1.25;margin:0 0 .6em;font-weight:600;color:var(--nc-color-text)}
p{margin:0 0 1.2em}
ul,ol{padding-left:1.2em}
button,input,select,textarea{font-family:inherit;font-size:1rem}
:focus-visible{outline:3px solid var(--nc-color-primary);outline-offset:2px}
.skip-link{position:absolute;left:-999px;top:0;background:#000;color:#fff;padding:10px 16px;z-index:100000}
.skip-link:focus{left:10px;top:10px}

/* ==========================================================================
   3. Layout helpers
   ========================================================================== */
.nc-container{max-width:var(--nc-container-width);margin-inline:auto;padding-inline:20px}
.nc-section{padding-block:clamp(48px,6vw,96px)}
.nc-section--no-pb{padding-bottom:0}
.nc-section--surface{background:var(--nc-color-surface)}
.nc-grid{display:grid;gap:28px}
.nc-grid--2{grid-template-columns:repeat(2,1fr)}
.nc-grid--3{grid-template-columns:repeat(3,1fr)}
.nc-grid--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.nc-grid--3,.nc-grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.nc-grid--2,.nc-grid--3,.nc-grid--4{grid-template-columns:1fr}}

.nc-eyebrow{display:inline-block;color:var(--nc-color-primary-dark);background:var(--nc-color-accent);padding:4px 14px;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.nc-section-head{max-width:680px;margin-bottom:40px}
.nc-section-head.nc-center{margin-inline:auto;text-align:center}

/* ==========================================================================
   4. Buttons
   ========================================================================== */
.nc-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--nc-radius-sm);font-weight:600;border:2px solid transparent;cursor:pointer;transition:all var(--nc-transition)}
.nc-btn--primary{background:var(--nc-color-primary);color:#fff}
.nc-btn--primary:hover{background:var(--nc-color-primary-dark);color:#fff}
.nc-btn--outline{border-color:var(--nc-color-primary);color:var(--nc-color-primary-dark)}
.nc-btn--outline:hover{background:var(--nc-color-primary);color:#fff}
.nc-btn--sm{padding:8px 18px;font-size:.9rem}

/* ==========================================================================
   5. Cards
   ========================================================================== */
.nc-card{background:#fff;border:1px solid var(--nc-color-border);border-radius:var(--nc-radius);padding:28px;box-shadow:var(--nc-shadow);transition:transform var(--nc-transition),box-shadow var(--nc-transition)}
.nc-card:hover{transform:translateY(-4px);box-shadow:0 16px 32px rgba(43,47,42,.12)}
.nc-card__icon{width:52px;height:52px;border-radius:12px;background:var(--nc-color-accent);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--nc-color-primary-dark)}

/* Pagination */
.nc-pagination,.pagination{display:flex;justify-content:center;gap:8px;margin-top:40px;flex-wrap:wrap}
.nc-pagination .page-numbers,.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border-radius:8px;border:1px solid var(--nc-color-border);color:var(--nc-color-text);text-decoration:none;font-weight:500}
.nc-pagination .page-numbers.current,.pagination .page-numbers.current{background:var(--nc-color-primary);border-color:var(--nc-color-primary);color:#fff}
.nc-pagination .page-numbers:hover,.pagination .page-numbers:hover{border-color:var(--nc-color-primary)}

/* Course cards */
.nc-course-card{display:flex;flex-direction:column;align-items:flex-start}
.nc-course-card .nc-card__icon{font-size:1.4rem}
.nc-course-card__meta{font-size:.85rem;color:var(--nc-color-text-muted);margin-bottom:18px}
.nc-course-card__footer{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:auto;padding-top:14px;border-top:1px solid var(--nc-color-border)}
.nc-course-card__price{color:var(--nc-color-primary-dark);font-family:var(--nc-font-heading)}

/* Course registration form */
.nc-course-registration{display:flex;flex-direction:column;gap:4px;margin-top:18px}
.nc-course-registration label{display:block;font-weight:600;font-size:.85rem;margin-top:8px}
.nc-course-registration input{display:block;padding:11px 14px;border:1px solid var(--nc-color-border);border-radius:8px;width:100%}

/* Curriculum list */
.nc-curriculum{margin:32px 0}
.nc-curriculum__list{list-style:none;padding:0;margin:16px 0 0}
.nc-curriculum__list li{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--nc-color-border);border-radius:10px;margin-bottom:10px}
.nc-curriculum__num{width:30px;height:30px;border-radius:50%;background:var(--nc-color-accent);color:var(--nc-color-primary-dark);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}

/* Instructor card */
.nc-instructor-card{display:flex;align-items:center;gap:18px;background:var(--nc-color-surface);border-radius:var(--nc-radius);padding:22px;margin:28px 0}
.nc-instructor-card__photo{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0}
.nc-instructor-card__photo--placeholder{display:flex;align-items:center;justify-content:center;background:var(--nc-color-accent);color:var(--nc-color-primary-dark);font-weight:700;font-size:1.6rem;font-family:var(--nc-font-heading)}

/* Certificate preview */
.nc-certificate-preview{display:flex;align-items:center;gap:18px;border:2px dashed var(--nc-color-accent);border-radius:var(--nc-radius);padding:22px;margin:28px 0}

/* ==========================================================================
   6. Header
   ========================================================================== */
.nc-header{background:var(--nc-color-bg);border-bottom:1px solid var(--nc-color-border);z-index:999}
.nc-header.nc-header--transparent{background:transparent;border-bottom-color:transparent;position:absolute;inset-inline:0;top:0}
.nc-header.nc-header--sticky{position:-webkit-sticky;position:sticky;top:0}
.nc-header.is-stuck{box-shadow:0 2px 16px rgba(0,0,0,.06);background:rgba(255,255,255,.96);backdrop-filter:blur(8px)}
.nc-header__row{display:flex;align-items:center;justify-content:space-between;min-height:var(--nc-header-height);gap:16px;flex-wrap:nowrap}
.nc-header__logo{font-family:var(--nc-font-heading);font-weight:700;font-size:1.4rem;color:var(--nc-color-text);min-width:0;flex:1 1 auto;overflow:hidden}
.nc-header__logo a,.nc-header__logo > a{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.nc-header__logo img{max-height:48px;width:auto}
.nc-nav{display:flex}
.nc-nav ul{list-style:none;display:flex;gap:6px;margin:0;padding:0}
.nc-nav li{position:relative}
.nc-nav a{display:block;padding:10px 14px;border-radius:8px;color:var(--nc-color-text);font-weight:500}
.nc-nav a:hover,.nc-nav .current-menu-item>a{color:var(--nc-color-primary-dark);background:var(--nc-color-accent)}
.nc-nav ul ul{position:absolute;top:100%;left:0;background:#fff;min-width:220px;border:1px solid var(--nc-color-border);border-radius:10px;box-shadow:var(--nc-shadow);padding:8px;display:none;flex-direction:column;z-index:50}
.nc-nav li:hover>ul{display:flex}
.nc-header__actions{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nc-header__search-toggle,.nc-mobile-toggle{background:none;border:none;cursor:pointer;padding:8px;color:var(--nc-color-text);display:flex}
.nc-mobile-toggle{display:none}
.nc-mobile-panel{display:none}

@media (max-width:980px){
  .nc-nav{display:none}
  .nc-mobile-toggle{display:flex}
  /* Header sticks on mobile too by default; only un-stick if the admin
     explicitly disabled "Sticky Header (Mobile)" in the Customizer. */
  .nc-header.nc-header--sticky.nc-no-sticky-mobile{position:static}
  /* The "Book Consultation" CTA already lives in the mobile slide-out menu,
     so don't duplicate it in the compact mobile header bar. */
  .nc-header__actions > a.nc-btn{display:none}
}

/* App-style slide-in mobile drawer */
.nc-drawer-backdrop{position:fixed;inset:0;background:rgba(20,24,20,.5);z-index:998;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}
.nc-drawer-backdrop.is-open{opacity:1;visibility:visible}

.nc-mobile-panel{
  position:fixed;top:0;right:0;bottom:0;
  width:min(86vw,360px);
  background:#fff;
  z-index:999;
  display:flex;flex-direction:column;
  padding:0;
  box-shadow:-12px 0 32px rgba(0,0,0,.18);
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
.nc-mobile-panel.is-open{transform:translateX(0)}

.nc-mobile-panel__header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--nc-color-border);position:sticky;top:0;background:#fff;z-index:2}
.nc-mobile-panel__logo{font-family:var(--nc-font-heading);font-weight:700;font-size:1.15rem}
.nc-mobile-panel__logo img{max-height:36px}
.nc-mobile-panel__close{background:var(--nc-color-surface);border:none;border-radius:50%;width:36px;height:36px;font-size:1.3rem;line-height:1;cursor:pointer;color:var(--nc-color-text)}

.nc-mobile-panel__nav{padding:8px 12px}
.nc-mobile-panel__nav ul{list-style:none;padding:0;margin:0}
.nc-mobile-panel__nav li{border-bottom:1px solid var(--nc-color-border)}
.nc-mobile-panel__nav a{display:flex;align-items:center;justify-content:space-between;padding:16px 10px;color:var(--nc-color-text);font-weight:600;font-size:1.02rem;border-radius:8px}
.nc-mobile-panel__nav a:after{content:"›";color:var(--nc-color-text-muted);font-size:1.2rem}
.nc-mobile-panel__nav a:hover,.nc-mobile-panel__nav .current-menu-item>a{background:var(--nc-color-surface);color:var(--nc-color-primary-dark)}
.nc-mobile-panel__nav ul ul{padding-left:14px}

.nc-mobile-panel__cta{margin:18px 20px 6px;text-align:center;justify-content:center}
.nc-mobile-panel__widget{padding:0 20px}
.nc-mobile-panel__contact{display:flex;flex-direction:column;gap:10px;padding:18px 20px;font-size:.92rem}
.nc-mobile-panel .nc-footer__social{padding:0 20px 24px}
.nc-mobile-panel .nc-footer__social a{background:var(--nc-color-surface);color:var(--nc-color-primary-dark);font-weight:700}

body.nc-mobile-open{overflow:hidden}

/* Header search */
.nc-search-box{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--nc-color-border);padding:20px;display:none;box-shadow:var(--nc-shadow);box-sizing:border-box;max-width:100vw}
.nc-search-box.is-open{display:block}
.nc-search-box form{display:flex;max-width:var(--nc-container-width);margin-inline:auto;gap:10px}
.nc-search-box input[type="search"]{flex:1 1 auto;min-width:0;padding:12px 16px;border:1px solid var(--nc-color-border);border-radius:8px}
.nc-search-box button{flex-shrink:0}
.nc-search-suggestions{max-width:var(--nc-container-width);margin:10px auto 0;}
.nc-search-suggestions ul{list-style:none;margin:0;padding:0}
.nc-search-suggestions li a{display:block;padding:10px 14px;border-radius:8px}
.nc-search-suggestions li a:hover{background:var(--nc-color-surface)}

/* ==========================================================================
   7. Announcement bar
   ========================================================================== */
.nc-announcement-bar{background:var(--nc-color-primary);color:#fff;padding:10px 0;font-size:.9rem;position:relative;overflow:hidden}
.nc-announcement-bar__track{display:flex;width:max-content;animation:nc-marquee 18s linear infinite}
.nc-announcement-bar__track:hover{animation-play-state:paused}
.nc-announcement-bar__text{padding-inline:40px;white-space:nowrap}
@keyframes nc-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.nc-announcement-bar a{color:#fff;text-decoration:underline}
.nc-announcement-bar__close{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;cursor:pointer;font-size:1.1rem;line-height:1;z-index:2}
@media (prefers-reduced-motion: reduce){.nc-announcement-bar__track{animation:none}.nc-announcement-bar__text:nth-child(2){display:none}}

/* ==========================================================================
   8. Hero
   ========================================================================== */
.nc-hero{padding-block:clamp(56px,8vw,120px);background:linear-gradient(160deg,var(--nc-color-surface) 0%,var(--nc-color-bg) 60%)}
.nc-hero__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.nc-hero h1{font-size:clamp(2rem,4vw,3.2rem)}
.nc-hero p.lead{font-size:1.15rem;color:var(--nc-color-text-muted);max-width:540px}
.nc-hero__actions{display:flex;gap:14px;margin-top:24px;flex-wrap:wrap}
.nc-hero__media img{border-radius:var(--nc-radius);box-shadow:var(--nc-shadow)}
.nc-hero__stats{display:flex;gap:32px;margin-top:36px}
.nc-hero__stats strong{display:block;font-size:1.6rem;font-family:var(--nc-font-heading);color:var(--nc-color-primary-dark)}
@media (max-width:900px){.nc-hero__grid{grid-template-columns:1fr}}

/* ==========================================================================
   9. Testimonials, FAQ, misc sections
   ========================================================================== */
.nc-testimonial{padding:28px}
.nc-testimonial__stars{color:#e0a83a;margin-bottom:10px}
.nc-testimonial__author{display:flex;align-items:center;gap:12px;margin-top:16px}
.nc-testimonial__author img{width:46px;height:46px;border-radius:50%}

/* Testimonial cards are rendered as <button> elements so they're clickable
   (opens the review in a modal) and keyboard-focusable; reset default
   button chrome so they still look exactly like the original card. */
.nc-testimonial--clickable{
  display:block;width:100%;text-align:left;
  font:inherit;color:inherit;
  border:none;cursor:pointer;
  appearance:none;-webkit-appearance:none;
}
.nc-testimonial--clickable:hover{box-shadow:0 20px 40px rgba(43,47,42,.16)}
.nc-testimonial--clickable p{
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}

/* Carousel — native horizontal scroll, driven continuously by JS (rAF),
   with manual prev/next arrows and touch/trackpad swipe support built in
   for free since it's a real scroll container. */
.nc-carousel{position:relative}
.nc-carousel__track{
  display:flex;
  overflow-x:auto;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.nc-carousel__track::-webkit-scrollbar{display:none}
.nc-carousel__slide{flex:0 0 33.3333%;padding:0 12px;box-sizing:border-box}
.nc-carousel__slide .nc-testimonial{height:100%}
@media (max-width:900px){.nc-carousel__slide{flex:0 0 50%}}
@media (max-width:600px){.nc-carousel__slide{flex:0 0 84%}}

.nc-carousel__controls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:28px}
.nc-carousel__arrow{background:#fff;border:1px solid var(--nc-color-border);border-radius:50%;width:42px;height:42px;font-size:1.4rem;cursor:pointer;color:var(--nc-color-text);line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s ease, transform .15s ease}
.nc-carousel__arrow:hover{background:var(--nc-color-accent);transform:translateY(-2px)}
.nc-carousel__arrow:focus-visible{outline:2px solid var(--nc-color-primary);outline-offset:2px}

/* Review detail modal — reuses the site's existing .nc-popup-overlay styling */
.nc-review-modal__box{max-width:520px;text-align:center}
.nc-review-modal__quote{font-size:1.05rem;line-height:1.6;margin:14px 0 4px}

.nc-faq{border-top:1px solid var(--nc-color-border)}
.nc-faq__item{border-bottom:1px solid var(--nc-color-border)}
.nc-faq__q{width:100%;text-align:left;background:none;border:none;padding:18px 4px;font-weight:600;font-size:1.05rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--nc-color-text)}
.nc-faq__a{display:none;padding:0 4px 18px;color:var(--nc-color-text-muted)}
.nc-faq__item.is-open .nc-faq__a{display:block}

/* ==========================================================================
   10. Blog
   ========================================================================== */
.nc-blog--grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.nc-blog--list .nc-post{display:grid;grid-template-columns:280px 1fr;gap:24px;margin-bottom:32px}
.nc-blog--magazine .nc-post--featured{grid-column:span 2}
.nc-post__thumb{border-radius:var(--nc-radius);overflow:hidden;margin-bottom:14px;aspect-ratio:16/10}
a.nc-post__thumb{display:block;border-radius:var(--nc-radius) var(--nc-radius) 0 0;margin:-28px -28px 14px}
.nc-post__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.nc-post:hover .nc-post__thumb img{transform:scale(1.05)}
.nc-post__meta{font-size:.85rem;color:var(--nc-color-text-muted);display:flex;gap:14px;margin-bottom:8px}
.nc-post__title a{color:var(--nc-color-text);font-size:1.15rem}
.nc-post__title a:hover{color:var(--nc-color-primary-dark)}
.nc-author-box{display:flex;gap:18px;background:var(--nc-color-surface);border-radius:var(--nc-radius);padding:24px;margin:40px 0}
.nc-author-box img{width:80px;height:80px;border-radius:50%}
.nc-share{display:flex;gap:10px;margin:24px 0}
.nc-share a{width:38px;height:38px;border-radius:50%;background:var(--nc-color-surface);display:flex;align-items:center;justify-content:center;color:var(--nc-color-text)}
@media (max-width:900px){.nc-blog--grid{grid-template-columns:repeat(2,1fr)}.nc-blog--list .nc-post{grid-template-columns:1fr}}
@media (max-width:600px){.nc-blog--grid{grid-template-columns:1fr}.nc-blog--magazine .nc-post--featured{grid-column:span 1}}

/* ==========================================================================
   11. Footer
   ========================================================================== */
.nc-footer{background:var(--nc-footer-bg,#12241a);color:var(--nc-footer-text,#e6e9e4);margin-top:60px}
.nc-footer__top{padding-block:56px}
.nc-footer__widgets{display:grid;grid-template-columns:repeat(var(--nc-footer-cols,4),1fr);gap:32px}
.nc-footer__widgets h4{font-size:1rem;text-transform:uppercase;letter-spacing:.03em;color:#fff}
.nc-footer__widgets ul{list-style:none;padding:0;margin:0}
.nc-footer__widgets li{margin-bottom:8px}
.nc-footer__widgets a{color:var(--nc-footer-text,#e6e9e4)}
.nc-footer__widgets a:hover{color:#fff}
.nc-footer p{color:var(--nc-footer-text,#e6e9e4)}
.nc-footer__social{display:flex;gap:10px;margin-top:14px}
.nc-footer__social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;display:flex;align-items:center;justify-content:center}
.nc-footer__social a:hover{background:var(--nc-color-primary)}
.nc-footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;font-size:.88rem;color:var(--nc-footer-text,#e6e9e4)}
.nc-footer__bottom .nc-container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.nc-footer__bottom nav ul{list-style:none;display:flex;gap:14px;margin:0;padding:0}
.nc-footer__bottom nav a{color:var(--nc-footer-text,#e6e9e4)}
.nc-footer__bottom nav a:hover{color:#fff}
@media (max-width:900px){.nc-footer__widgets{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.nc-footer__widgets{grid-template-columns:1fr}}

/* ==========================================================================
   12. Popups
   ========================================================================== */
.nc-popup-overlay{position:fixed;inset:0;background:rgba(20,24,20,.55);display:none;align-items:center;justify-content:center;z-index:9999;padding:20px}
.nc-popup-overlay.is-open{display:flex}
.nc-popup{background:#fff;border-radius:var(--nc-radius);max-width:480px;width:100%;padding:36px;position:relative;box-shadow:0 24px 60px rgba(0,0,0,.25)}
.nc-popup__close{position:absolute;top:14px;right:14px;background:var(--nc-color-surface);border:none;border-radius:50%;width:34px;height:34px;cursor:pointer}
.nc-popup form{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.nc-popup input{padding:12px 14px;border:1px solid var(--nc-color-border);border-radius:8px}

/* ==========================================================================
   13. Forms / booking
   ========================================================================== */
.nc-booking{background:#fff;border-radius:var(--nc-radius);box-shadow:var(--nc-shadow);padding:32px}
.nc-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.nc-form-row label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.nc-form-row input,.nc-form-row select,.nc-form-row textarea{width:100%;padding:12px 14px;border:1px solid var(--nc-color-border);border-radius:8px}
.nc-booking label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px;margin-top:14px}
.nc-booking textarea{display:block;width:100%;padding:12px 14px;border:1px solid var(--nc-color-border);border-radius:8px}
@media (max-width:600px){.nc-form-row{grid-template-columns:1fr}}

.nc-form-message{border-radius:10px;padding:12px 14px;font-size:.9rem;margin-bottom:16px}
.nc-form-message--success{background:#e3f5ea;border:1px solid #bcd9c8;color:#1e7e42}
.nc-form-message--error{background:#fdecec;border:1px solid #f3c3c3;color:#a12f2f}

/* RTL */
body.rtl .nc-nav a{text-align:right}
body.rtl .nc-blog--list .nc-post{direction:rtl}

/* Container width variants set from Customizer */
body.nc-container-boxed{--nc-container-width:1200px}
body.nc-container-fluid .nc-container{max-width:100%}

/* ==========================================================================
   14. Mobile fixes
   ========================================================================== */
/* Avoid header being hidden under the logged-in WP admin bar */
body.admin-bar .nc-header.nc-header--sticky{top:32px}
@media (max-width:782px){
  body.admin-bar .nc-header.nc-header--sticky{top:46px}
}
@media (max-width:600px){
  .nc-container{padding-inline:16px}
  .nc-section{padding-block:40px}
  .nc-header__row{gap:8px}
  .nc-header__logo{font-size:1.05rem}
  .nc-header__logo img{max-height:36px}
  .nc-header__actions{gap:4px}
  .nc-header__actions .nc-btn--sm{padding:7px 10px;font-size:.78rem}
  .nc-hero__stats{gap:18px;flex-wrap:wrap}
  .nc-footer__newsletter{padding:22px !important}
  .nc-footer__newsletter form{grid-template-columns:1fr !important}
  .nc-footer__newsletter form button{width:100%;justify-content:center}
  .nc-booking{padding:22px}
  .nc-course-card{padding:22px}
  .nc-search-box{padding:14px}
  .nc-search-box form{flex-direction:column;gap:10px}
  .nc-search-box button{width:100%;justify-content:center}
  table{display:block;overflow-x:auto}
}
@media (max-width:380px){
  .nc-header__logo{font-size:.92rem;max-width:120px}
  .nc-header__actions .nc-btn--sm span{display:none} /* show icon-only CTA if a label span is used */
}
@media (max-width:900px){
  .nc-course-registration,
  aside.nc-card{position:static !important}
}

/* ==========================================================
 * Floating WhatsApp Chat Widget
 * ========================================================== */
.nc-whatsapp-widget{
  position:fixed;
  bottom:calc(var(--nc-wa-offset, 90px) + env(safe-area-inset-bottom, 0px));
  z-index:9000;
}
.nc-whatsapp-widget--right{right:calc(20px + env(safe-area-inset-right, 0px));}
.nc-whatsapp-widget--left{left:calc(20px + env(safe-area-inset-left, 0px));}

/* --- Toggle button --- */
.nc-whatsapp-toggle{
  position:relative;
  width:58px;height:58px;
  background:#25D366;
  color:#fff;
  border:none;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,.4), 0 2px 6px rgba(0,0,0,.15);
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease;
}
.nc-whatsapp-toggle:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 10px 26px rgba(37,211,102,.5), 0 4px 10px rgba(0,0,0,.18);}
.nc-whatsapp-toggle:focus-visible{outline:3px solid #128C7E;outline-offset:3px;}
.nc-whatsapp-toggle__icon{width:28px;height:28px;position:absolute;transition:opacity .18s ease, transform .18s ease;}
.nc-whatsapp-toggle__icon--close{opacity:0;transform:scale(.5) rotate(-45deg);}
.nc-whatsapp-widget.is-open .nc-whatsapp-toggle__icon--chat{opacity:0;transform:scale(.5) rotate(45deg);}
.nc-whatsapp-widget.is-open .nc-whatsapp-toggle__icon--close{opacity:1;transform:scale(1) rotate(0);}

.nc-whatsapp-toggle__ping{
  position:absolute;inset:0;border-radius:50%;
  background:#25D366;
  opacity:.55;
  animation:nc-wa-ping 2.2s cubic-bezier(0,0,.2,1) infinite;
}
.nc-whatsapp-widget.is-open .nc-whatsapp-toggle__ping{display:none;}
@keyframes nc-wa-ping{
  0%{transform:scale(1);opacity:.55;}
  75%,100%{transform:scale(1.7);opacity:0;}
}
@media (prefers-reduced-motion: reduce){
  .nc-whatsapp-toggle__ping{animation:none;display:none;}
}

.nc-whatsapp-toggle__tooltip{
  position:absolute;top:50%;transform:translateY(-50%);
  background:#1d2327;color:#fff;
  font-size:.85rem;font-weight:500;white-space:nowrap;
  padding:7px 14px;border-radius:8px;
  opacity:0;pointer-events:none;
  transition:opacity .18s ease;
}
.nc-whatsapp-widget--right .nc-whatsapp-toggle__tooltip{right:calc(100% + 12px);}
.nc-whatsapp-widget--left .nc-whatsapp-toggle__tooltip{left:calc(100% + 12px);}
.nc-whatsapp-toggle:hover ~ .nc-whatsapp-toggle__tooltip{opacity:1;}
.nc-whatsapp-widget.is-open .nc-whatsapp-toggle__tooltip{display:none;}
@media (hover:none){.nc-whatsapp-toggle__tooltip{display:none;}}

/* --- Expandable chat-preview card --- */
.nc-whatsapp-card{
  position:absolute;
  bottom:calc(100% + 14px);
  width:min(320px, calc(100vw - 40px));
  background:#fff;
  border-radius:16px;
  box-shadow:0 14px 40px rgba(0,0,0,.18), 0 4px 12px rgba(0,0,0,.08);
  overflow:hidden;
  opacity:0;
  transform:translateY(14px) scale(.96);
  transform-origin:bottom;
  transition:opacity .2s ease, transform .2s ease;
  pointer-events:none;
}
.nc-whatsapp-widget--right .nc-whatsapp-card{right:0;}
.nc-whatsapp-widget--left .nc-whatsapp-card{left:0;}
.nc-whatsapp-widget.is-open .nc-whatsapp-card{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}

.nc-whatsapp-card__header{
  background:#075E54;
  color:#fff;
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;
}
.nc-whatsapp-card__avatar{
  width:36px;height:36px;flex:0 0 36px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.nc-whatsapp-card__avatar svg{width:20px;height:20px;color:#fff;}
.nc-whatsapp-card__name{font-weight:600;font-size:.95rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nc-whatsapp-card__close{
  background:none;border:none;color:#fff;
  font-size:1.5rem;line-height:1;cursor:pointer;
  opacity:.85;padding:0 2px;
}
.nc-whatsapp-card__close:hover{opacity:1;}

.nc-whatsapp-card__body{background:#e5ddd5;padding:16px;}
.nc-whatsapp-card__bubble{
  background:#fff;
  border-radius:10px 10px 10px 2px;
  padding:10px 14px;
  font-size:.88rem;line-height:1.5;
  color:#1d2327;
  box-shadow:0 1px 2px rgba(0,0,0,.08);
  margin:0;
}

.nc-whatsapp-card__cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:#25D366;color:#fff;
  font-weight:600;font-size:.92rem;
  padding:13px;text-decoration:none;
  transition:background .15s ease;
}
.nc-whatsapp-card__cta:hover{background:#128C7E;color:#fff;}
.nc-whatsapp-card__cta svg{width:18px;height:18px;}

@media (max-width:600px){
  .nc-whatsapp-toggle{width:52px;height:52px;}
  .nc-whatsapp-toggle__icon{width:24px;height:24px;}
  .nc-whatsapp-widget--right{right:calc(14px + env(safe-area-inset-right, 0px));}
  .nc-whatsapp-widget--left{left:calc(14px + env(safe-area-inset-left, 0px));}
}

