/* courses.css — page-specific styles. Shared chrome (colours, nav, footer,
   fonts, buttons, animations) lives in site.css. */

/* NAV */
  .nav{position:fixed;top:0;left:0;right:0;z-index:40;background:rgba(251,253,251,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
/* PAGE HERO */
  .phero{position:relative;padding:150px 0 60px;overflow:hidden;background:#ffffff}
.phero .b{position:absolute;border-radius:50%;filter:blur(8px);z-index:0}
.phero .b1{width:340px;height:340px;background:radial-gradient(circle,rgba(255,210,74,.5),transparent 65%);top:-80px;right:-40px}
.phero .b2{width:300px;height:300px;background:radial-gradient(circle,rgba(125,107,196,.3),transparent 65%);bottom:-120px;left:-60px}
.phero .wrap{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--yellow-deep);border-radius:2px}
.phero h1{font-size:clamp(2.3rem,5.4vw,3.7rem);line-height:1.08;color:var(--green-darker);font-weight:700;margin:16px 0 16px;max-width:17ch}
.phero p{color:var(--muted);font-size:1.08rem;line-height:1.7;max-width:60ch}
.phero-stats{display:flex;gap:38px;flex-wrap:wrap;margin-top:34px}
.phero-stats .st b{display:block;font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--green-darker);line-height:1}
.phero-stats .st span{font-size:.84rem;color:var(--muted);font-weight:500}
.phero-stats .st b .u{color:var(--yellow-deep)}
/* FILTER PILLS (decorative) */
  .pad{padding:54px 0 64px;position:relative;z-index:1}
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.filt{font-size:.84rem;font-weight:600;color:var(--green-darker);background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 16px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.ccard.hide{display:none}
.filt.on{background:var(--green);color:#fff;border-color:transparent}
.filt::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c,var(--leaf))}
.filt.on::before{background:var(--yellow)}
/* COURSE GRID */
  .course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.ccard{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;display:flex;flex-direction:column;
     box-shadow:0 30px 60px -48px rgba(18,46,35,.5);transition:transform .3s var(--ease),box-shadow .3s;opacity:0;transform:translateY(28px)}
.ccard.in{opacity:1;transform:none}
.ccard:hover{transform:translateY(-6px);box-shadow:0 50px 84px -44px rgba(18,46,35,.55)}
.cc-img{position:relative;height:172px;overflow:hidden}
.cc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.ccard:hover .cc-img img{transform:scale(1.06)}
.cc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,40,30,.05),rgba(20,40,30,.45))}
.cc-cat{position:absolute;top:14px;left:14px;z-index:2;background:var(--c,var(--green));color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:6px 12px;border-radius:999px;box-shadow:0 10px 22px -10px rgba(0,0,0,.5)}
.cc-level{position:absolute;top:14px;right:14px;z-index:2;background:rgba(255,255,255,.94);color:var(--green-darker);font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:6px 11px;border-radius:999px}
.cc-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.cc-meta{display:flex;align-items:center;gap:14px;font-size:.78rem;font-weight:600;color:var(--muted);margin-bottom:8px}
.cc-meta span{display:inline-flex;align-items:center;gap:6px}
.cc-meta svg{width:15px;height:15px;stroke:var(--c,var(--green));fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.cc-title{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--green-darker);line-height:1.22}
.cc-desc{color:var(--muted);font-size:.91rem;line-height:1.6;margin:10px 0 14px;flex:1}
.cc-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.cc-tag{font-size:.72rem;font-weight:600;color:var(--green-darker);background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:4px 10px}
.cc-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--c,var(--green));font-size:.92rem;margin-top:auto}
.cc-link svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s}
.cc-link:hover svg{transform:translateX(4px)}
/* CTA band */
  .ctaband{margin:50px 0 80px}
.ctaband .inner{position:relative;overflow:hidden;border-radius:30px;padding:54px 48px;text-align:center;
     background:linear-gradient(135deg,var(--green-deep),var(--green));box-shadow:0 50px 90px -50px rgba(18,46,35,.7)}
.ctaband .inner::before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,210,74,.4),transparent 65%);top:-100px;right:-40px}
.ctaband .inner::after{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(124,198,232,.35),transparent 65%);bottom:-120px;left:-30px}
.ctaband h2{position:relative;z-index:1;color:#fff;font-size:clamp(1.7rem,3.6vw,2.5rem);font-weight:700;margin-bottom:12px}
.ctaband h2 .serif{color:var(--yellow)}
.ctaband p{position:relative;z-index:1;color:rgba(255,255,255,.86);max-width:54ch;margin:0 auto 26px;line-height:1.6}
.ctaband .btn{position:relative;z-index:1;display:inline-flex;align-items:center;gap:10px;background:var(--btn-yellow);color:var(--green-darker);font-weight:700;padding:15px 30px;border-radius:999px;font-size:1rem;box-shadow:0 18px 36px -16px rgba(0,0,0,.4)}
.ctaband .btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* ENQUIRY FORM */
  .enquire{padding:20px 0 80px;scroll-margin-top:92px}
.enq-card{display:grid;grid-template-columns:.95fr 1.15fr;gap:0;border:1px solid var(--line);border-radius:28px;overflow:hidden;background:#fff;box-shadow:0 50px 90px -56px rgba(18,46,35,.55)}
.enq-info{position:relative;overflow:hidden;padding:46px 40px;background:linear-gradient(150deg,var(--green-deep),var(--green));color:#fff}
.enq-info::before{content:"";position:absolute;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(255,210,74,.4),transparent 65%);top:-110px;right:-60px}
.enq-info::after{content:"";position:absolute;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(124,198,232,.35),transparent 65%);bottom:-110px;left:-50px}
.enq-info .eyebrow{color:#ffe49a}
.enq-info .eyebrow::before{background:var(--yellow)}
.enq-info h2{position:relative;z-index:1;font-size:clamp(1.7rem,3.2vw,2.3rem);font-weight:700;margin:14px 0 14px;line-height:1.12}
.enq-info h2 .serif{color:var(--yellow)}
.enq-info>p{position:relative;z-index:1;color:rgba(255,255,255,.88);line-height:1.65;font-size:.96rem}
.enq-points{position:relative;z-index:1;list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:12px}
.enq-points li{display:flex;align-items:flex-start;gap:11px;font-size:.93rem;color:#eaf6f0}
.enq-points svg{width:20px;height:20px;flex:0 0 auto;stroke:var(--yellow);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;margin-top:1px}
.enq-form{padding:44px 40px;display:flex;flex-direction:column;gap:16px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.enq-form label{display:flex;flex-direction:column;gap:7px;font-size:.85rem;font-weight:600;color:var(--ink)}
.enq-form input,.enq-form select,.enq-form textarea{font-family:var(--font-body);font-size:.95rem;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-weight:400;transition:border-color .2s,box-shadow .2s}
.enq-form input:focus,.enq-form select:focus,.enq-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(44,128,103,.15)}
.enq-form textarea{resize:vertical;min-height:108px}
.btn-submit{margin-top:4px;align-self:flex-start;display:inline-flex;align-items:center;gap:10px;background:var(--green);color:#fff;font-family:var(--font-body);font-weight:700;font-size:1rem;border:0;cursor:pointer;padding:14px 28px;border-radius:999px;box-shadow:0 18px 36px -16px rgba(34,101,80,.9);transition:transform .25s,box-shadow .25s}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 26px 44px -18px rgba(34,101,80,.95)}
.btn-submit svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.enq-note{font-size:.78rem;color:var(--muted);line-height:1.5;margin-top:2px}
/* FOOTER */
  .foot{background:var(--green-darker);color:#cfe6da;padding:60px 0 28px}
@media(max-width:980px){
.course-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
.enq-card{grid-template-columns:1fr}
}
@media(max-width:560px){
.course-grid,.foot-grid{grid-template-columns:1fr}
.phero-stats{gap:24px}
.frow{grid-template-columns:1fr}
.enq-form,.enq-info{padding:34px 26px}
}
@media(prefers-reduced-motion:reduce){
.ccard{opacity:1;transform:none}
}
