/* RCIPMS below-the-fold styles v1
   ~4 KB — loaded non-blocking via media=print swap.
   Uses the CSS custom properties declared in the inlined critical CSS. */

.hero .grid>.hero-copy{order:1}
.hero .grid>.enquiry-card{order:2}
@media(min-width:820px){.hero .grid>.hero-copy{order:0}.hero .grid>.enquiry-card{order:0}}

.section-pad{padding:28px 0}
.alt-bg{background:var(--bg-alt)}
.section-head{text-align:center;max-width:720px;margin:0 auto 20px}
.section-head h2{font-size:22px;margin:0 0 8px;color:var(--primary-dark)}
.section-head .lead{font-size:15px;color:var(--muted);margin:0}

.fact-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 16px;max-width:760px;margin:0 auto;box-shadow:var(--shadow);
}
.fact-card h3{font-size:17px;color:var(--primary-dark);margin:0 0 10px;text-align:center}
.check-list{list-style:none;padding:0;margin:0;display:grid;gap:6px}
.check-list li{
  position:relative;padding:6px 0 6px 26px;font-size:14px;line-height:1.5;
}
.check-list li::before{
  content:"";position:absolute;left:0;top:10px;width:16px;height:16px;
  background:var(--primary);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat;
}

.card-grid{
  display:grid;gap:16px;grid-template-columns:1fr;
}
@media(min-width:620px){.card-grid{grid-template-columns:1fr 1fr}}
@media(min-width:920px){.card-grid{grid-template-columns:1fr 1fr 1fr}}

/* ===== Affiliation / Info cards ===== */
.info-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease;
  will-change:transform;
}
.info-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(15,44,38,.12)}
.info-card-img{aspect-ratio:3/2;background:var(--primary-tint)}
.info-card-img img{width:100%;height:100%;object-fit:contain;padding:14px}
.info-card-body{padding:14px 16px 18px}
.info-card-body h3{font-size:17px;margin:0 0 8px;color:var(--primary-dark)}
.info-card-body p{font-size:14px;color:var(--muted);margin:0 0 12px;min-height:60px}

.btn-link{
  display:inline-flex;align-items:center;gap:4px;
  font-size:14px;font-weight:600;color:var(--primary);
}
.btn-link:hover,.btn-link:focus{text-decoration:none;color:var(--primary-dark)}

/* ===== Testimonials ===== */
.testi-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 16px;text-align:center;box-shadow:var(--shadow);
}
.testi-avatar{width:84px;height:84px;margin:0 auto 10px;border-radius:50%;overflow:hidden;background:var(--primary-tint)}
.testi-avatar img{width:100%;height:100%;object-fit:cover}
.testi-quote{font-size:14px;color:var(--text);font-style:italic;margin:0 0 10px;line-height:1.5}
.testi-name{font-size:15px;font-weight:700;margin:0 0 2px;color:var(--primary-dark)}
.testi-role{font-size:13px;color:var(--muted);margin:0 0 6px}
.testi-stars{margin:0;line-height:0}

/* ===== Office cards ===== */
.office-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 16px;box-shadow:var(--shadow);
}
.office-card h3{font-size:17px;color:var(--primary-dark);margin:0 0 10px;padding-bottom:8px;border-bottom:2px solid var(--primary-tint)}
.office-row{
  display:flex;align-items:flex-start;gap:8px;
  font-size:14px;color:var(--text);margin:0 0 10px;line-height:1.5;
}
.office-row svg{flex-shrink:0;margin-top:3px;color:var(--primary)}
.office-row a{color:var(--text)}
.office-row a:hover{color:var(--primary)}

/* ===== Footer ===== */
.site-footer{background:#0b3a32;color:#cde8e2;margin-top:20px}
.footer-top{padding:28px 0 16px}
.footer-grid{display:grid;gap:24px;grid-template-columns:1fr}
@media(min-width:620px){.footer-grid{grid-template-columns:1.2fr 1fr 1fr}}
.footer-brand{display:inline-block;margin:0 0 10px;background:#fff;padding:6px 10px;border-radius:6px}
.footer-brand img{width:140px;height:42px;object-fit:contain}
.footer-col address{font-style:normal;font-size:14px;line-height:1.6;margin:0 0 10px;color:#cde8e2}
.footer-contact{margin:0 0 6px;font-size:14px}
.footer-contact a{display:inline-flex;align-items:center;gap:6px;color:#fff}
.footer-contact a:hover{color:var(--accent);text-decoration:none}
.footer-title{font-size:15px;font-weight:700;color:#fff;margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin:0 0 6px}
.footer-links a{color:#cde8e2;font-size:14px}
.footer-links a:hover,.footer-links a:focus{color:#fff;text-decoration:none}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding:12px 0;text-align:center;font-size:13px;color:#8fb4ac;
}
.footer-bottom p{margin:0}

/* ===== Form validation states ===== */
.form-field.is-invalid input,
.form-field.is-invalid select{
  border-color:var(--danger);
  box-shadow:0 0 0 3px rgba(220,38,38,.12);
}
.form-field .err{
  display:none;color:var(--danger);font-size:12px;margin-top:4px;
}
.form-field.is-invalid .err{display:block}

/* ===================================================================
   INNER PAGES (About / Courses / Affiliation / Gallery / Contact /
   Registration / Thank-you / CMS)
   =================================================================== */

.container-narrow{max-width:860px;margin:0 auto;padding:0 16px}

/* ===== Inner-page hero ===== */
.inner-hero{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
  color:#fff;padding:26px 0 20px;text-align:center;
  min-height:120px;contain:layout;
}
.inner-hero h1{
  font-size:26px;margin:0 0 8px;color:#fff;line-height:1.25;
}
.breadcrumbs{font-size:13px;color:#cde8e2}
.breadcrumbs ol{list-style:none;padding:0;margin:0;display:flex;justify-content:center;flex-wrap:wrap;gap:4px}
.breadcrumbs li{display:flex;align-items:center}
.breadcrumbs li+li::before{content:"›";margin:0 6px;opacity:.7}
.breadcrumbs a{color:#fff;text-decoration:underline}
.breadcrumbs a:hover{text-decoration:none}
.breadcrumbs [aria-current]{color:#cde8e2}

/* ===== Prose (CMS / about / course text) ===== */
.prose{
  font-size:15px;line-height:1.65;color:var(--text);
}
.prose.prose-wide{max-width:760px;margin:0 auto}
.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{
  color:var(--primary-dark);margin:18px 0 8px;line-height:1.3;
}
.prose h2{font-size:20px}
.prose h3{font-size:18px}
.prose h4{font-size:16px}
.prose p{margin:0 0 12px}
.prose ul,.prose ol{padding-left:22px;margin:0 0 12px}
.prose li{margin-bottom:4px}
.prose a{color:var(--primary);text-decoration:underline}
.prose a:hover{color:var(--primary-dark)}
.prose img{max-width:100%;height:auto;border-radius:6px}
.prose blockquote{
  margin:12px 0;padding:10px 14px;border-left:3px solid var(--primary);
  background:var(--primary-tint);color:var(--text);
}

/* ===== About-us message grid ===== */
.msg-grid{
  display:grid;gap:20px;grid-template-columns:1fr;max-width:960px;margin:0 auto;
}
@media(min-width:720px){.msg-grid{grid-template-columns:1fr 1.4fr;align-items:start}}
.msg-photo{background:var(--primary-tint);border-radius:var(--radius);overflow:hidden;aspect-ratio:12/13}
.msg-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* ===== Affiliation row of thumbs (about page) ===== */
.aff-row{max-width:760px;margin:0 auto 20px}
.aff-thumb{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;align-items:center;justify-content:center;aspect-ratio:3/2}
.aff-thumb img{max-width:100%;max-height:100%;object-fit:contain}

/* ===== Affiliation detail (affiliation page) ===== */
.aff-detail{
  display:grid;gap:16px;grid-template-columns:1fr;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;margin:0 auto 16px;max-width:960px;box-shadow:var(--shadow);
}
@media(min-width:720px){.aff-detail{grid-template-columns:220px 1fr;align-items:start}}
.aff-detail-img{background:var(--primary-tint);border-radius:8px;display:flex;align-items:center;justify-content:center;padding:14px;aspect-ratio:3/2}
.aff-detail-img img{max-width:100%;max-height:100%;object-fit:contain}
.aff-detail-body{font-size:14.5px}
.aff-detail-body h1,.aff-detail-body h2,.aff-detail-body h3{margin-top:0}

/* ===== Course accordion (native <details>) ===== */
.accordion{max-width:820px;margin:0 auto;display:grid;gap:10px}
.acc-item{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.acc-item>summary{
  list-style:none;cursor:pointer;padding:14px 16px;
  font-size:15px;font-weight:600;color:var(--primary-dark);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.acc-item>summary::-webkit-details-marker{display:none}
.acc-item>summary:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}
.acc-icon{flex-shrink:0;transition:transform .2s ease;color:var(--primary)}
.acc-item[open] .acc-icon{transform:rotate(180deg)}
.acc-item>.prose{padding:0 16px 16px;font-size:14.5px}

/* ===== Gallery ===== */
.gallery-grid{
  display:grid;gap:8px;
  grid-template-columns:repeat(2,1fr);
}
@media(min-width:620px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:10px}}
@media(min-width:920px){.gallery-grid{grid-template-columns:repeat(4,1fr)}}
.gallery-item{
  display:block;aspect-ratio:4/3;background:var(--primary-tint);
  border-radius:8px;overflow:hidden;
  transition:transform .2s ease;will-change:transform;
}
.gallery-item:hover{transform:scale(1.03)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block}

/* ===== Contact page (cards + maps) ===== */
.contact-grid{
  display:grid;gap:16px;grid-template-columns:1fr;
}
@media(min-width:820px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 16px;box-shadow:var(--shadow);
}
.contact-card h3{
  font-size:17px;color:var(--primary-dark);margin:0 0 12px;
  padding-bottom:8px;border-bottom:2px solid var(--primary-tint);
}
.map-wrap{
  margin-top:12px;border-radius:8px;overflow:hidden;
  aspect-ratio:16/10;background:var(--primary-tint);
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

/* ===== Registration form (wider) ===== */
.enquiry-card-wide{max-width:760px;margin:0 auto}
.enquiry-card-wide .form-title{font-size:17px;margin:0 0 4px;color:var(--primary-dark)}

/* ===== Thank-you / success panel ===== */
.success-panel{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 20px;text-align:center;box-shadow:var(--shadow);
  max-width:560px;margin:0 auto;
}
.success-icon{color:var(--primary);margin:0 0 10px;line-height:0}
.success-panel h2{font-size:20px;color:var(--primary-dark);margin:0 0 12px}
.success-panel p{font-size:15px;color:var(--text);margin:0 0 10px;line-height:1.6}
.reg-id{font-size:16px}
.reg-id strong{
  display:inline-block;background:var(--primary-tint);color:var(--primary-dark);
  padding:2px 10px;border-radius:6px;font-weight:700;margin:0 4px;
}
.reg-id-note{display:block;font-size:12px;color:var(--muted);margin-top:2px}
.success-actions{
  margin-top:18px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center;
}
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 18px;border-radius:8px;
  background:transparent;color:var(--primary);
  border:2px solid var(--primary);font-weight:600;font-size:14px;
  text-decoration:none;transition:background .15s ease;
}
.btn-ghost:hover,.btn-ghost:focus{background:var(--primary-tint);text-decoration:none}

/* ===== Utility ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
