/* Rising Himse Academy - main.css v4.0 */

/* ============================================================
   VARIABLES
============================================================ */
:root {
  --green:      #2D5A27;
  --green-dk:   #1e3d1a;
  --green-lt:   #3d7a34;
  --green-pale: #eaf3e9;
  --gold:       #F0B429;
  --gold-dk:    #b8860b;
  --gold-pale:  #fdf6e3;
  --white:      #ffffff;
  --off-white:  #f8f8f6;
  --gray-lt:    #f2f2ef;
  --gray:       #e0e0dc;
  --text:       #1a1a18;
  --text-m:     #6b6b67;
  --text-l:     #9b9b97;
  --r-sm:       6px;
  --r-md:       12px;
  --r-lg:       20px;
  --sh-sm:      0 2px 8px rgba(0,0,0,.07);
  --sh-md:      0 4px 20px rgba(0,0,0,.11);
  --sh-lg:      0 8px 40px rgba(0,0,0,.15);
  --fh:         'Merriweather', Georgia, serif;
  --fb:         'Nunito', system-ui, sans-serif;
  --tr:         .25s ease;
  --cw:         1240px;
}

/* ============================================================
   RESET
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fb);color:var(--text);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ============================================================
   TYPOGRAPHY
============================================================ */
h1,h2,h3,h4,h5,h6{font-family:var(--fh);line-height:1.3;color:var(--text);word-break:break-word}
h1{font-size:clamp(1.6rem,4vw,2.75rem)}
h2{font-size:clamp(1.3rem,3vw,2.1rem)}
h3{font-size:clamp(1rem,2.2vw,1.35rem)}
h4{font-size:clamp(.95rem,1.8vw,1.08rem)}
p{font-size:1rem;color:var(--text-m);line-height:1.75}

.eyebrow{display:inline-block;font-family:var(--fb);font-size:.7rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--green);background:var(--green-pale);padding:4px 14px;border-radius:20px;margin-bottom:10px;border-left:3px solid var(--gold)}

/* ============================================================
   LAYOUT
============================================================ */
.container{width:100%;max-width:var(--cw);margin:0 auto;padding:0 22px}
.section-pad{padding:68px 0}
.section-sm{padding:44px 0}
.text-center{text-align:center}
.flex-between{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}

/* ============================================================
   BUTTONS
============================================================ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 26px;border-radius:50px;font-family:var(--fb);font-size:.88rem;font-weight:700;cursor:pointer;border:2px solid transparent;transition:var(--tr);text-decoration:none;line-height:1}
.btn-gold{background:var(--gold);color:var(--green-dk);border-color:var(--gold)}
.btn-gold:hover{background:#d4a017}
.btn-green{background:var(--green);color:#fff;border-color:var(--green)}
.btn-green:hover{background:var(--green-dk)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn-outline:hover{background:rgba(255,255,255,.15);border-color:#fff}
.view-all{display:inline-flex;align-items:center;gap:6px;font-size:.86rem;font-weight:700;color:var(--green);border-bottom:1.5px solid var(--green);padding-bottom:2px;transition:var(--tr)}
.view-all:hover{gap:10px}

/* ============================================================
   HEADER
============================================================ */
#site-header{position:sticky;top:0;z-index:1000;background:var(--white);box-shadow:var(--sh-sm)}

/* Topbar */
.topbar{background:var(--green-dk);padding:5px 0;font-size:.78rem;color:rgba(255,255,255,.75)}
.topbar a{color:rgba(255,255,255,.85);transition:var(--tr)}
.topbar a:hover{color:var(--gold)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:14px}
.topbar-left{display:flex;gap:18px;flex-wrap:wrap}
.topbar-right{display:flex;gap:10px;align-items:center}
.topbar-social{display:flex;align-items:center;color:rgba(255,255,255,.8);transition:var(--tr)}
.topbar-social:hover{color:var(--gold)}

/* Main header */
.header-main-wrap{padding:10px 0}
.header-main{display:flex;align-items:center;justify-content:space-between;gap:18px}

/* Logo — auto-fit uploaded image */
.site-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo-img-wrap{
  width:56px;height:56px;
  border-radius:50%;
  overflow:hidden;
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--green);
  border:2px solid var(--gold);
}
/* custom_logo img auto-fits */
.logo-img-wrap img,.logo-img-wrap a{display:block;width:100%;height:100%}
.logo-img-wrap a img{width:100%;height:100%;object-fit:cover;object-position:center}
.logo-placeholder{font-family:var(--fh);font-size:1.3rem;font-weight:900;color:var(--gold)}
.logo-text .logo-name{font-family:var(--fh);font-size:1rem;font-weight:700;color:var(--green);display:block;line-height:1.2}
.logo-text .logo-sub{font-size:.67rem;color:var(--text-m);display:block}

/* Nav */
.primary-nav{display:flex;align-items:center;gap:4px}
.primary-nav>li{position:relative}
.primary-nav>li>a{display:block;padding:8px 12px;font-size:.86rem;font-weight:600;color:var(--text);border-radius:var(--r-sm);transition:var(--tr)}
.primary-nav>li>a:hover,.primary-nav>li.current-menu-item>a{color:var(--green);background:var(--green-pale)}
.nav-cta{background:var(--green)!important;color:#fff!important;border-radius:20px!important}
.nav-cta:hover{background:var(--green-dk)!important;color:#fff!important}
.primary-nav .sub-menu{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--gray);border-radius:var(--r-md);box-shadow:var(--sh-lg);min-width:190px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:var(--tr);z-index:100}
.primary-nav li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.primary-nav .sub-menu li a{display:block;padding:9px 14px;font-size:.83rem;color:var(--text-m);transition:var(--tr)}
.primary-nav .sub-menu li a:hover{color:var(--green);background:var(--green-pale)}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:var(--tr)}

/* ============================================================
   NOTICE TICKER — compact, dark green, white text, clickable
============================================================ */
.notice-ticker{
  background:var(--green-dk);
  padding:7px 0;
  overflow:hidden;
  border-top:2px solid var(--gold);
}
.ticker-wrap{display:flex;align-items:center;height:28px}
.ticker-tag{
  flex-shrink:0;
  background:var(--gold);
  color:var(--green-dk);
  font-size:.68rem;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;
  padding:3px 12px;border-radius:20px;margin-right:14px;white-space:nowrap;
}
.ticker-scroll-outer{flex:1;overflow:hidden;height:28px;display:flex;align-items:center}
.ticker-scroll{display:flex;align-items:center;gap:0;white-space:nowrap;width:max-content;animation:tick 30s linear infinite}
.ticker-scroll:hover{animation-play-state:paused}
.ticker-item{font-size:.82rem;color:#fff;font-weight:600;padding:0 16px;transition:var(--tr)}
.ticker-item:hover{color:var(--gold)}
.ticker-sep{color:rgba(255,255,255,.35);font-size:.7rem;flex-shrink:0}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================================
   HERO SLIDER — clear image with blurred bg fill
============================================================ */
.hero-wrap{position:relative;overflow:hidden;height:clamp(420px,62vh,660px)}
.hero-slides-track{display:flex;height:100%}
.hero-slide{flex-shrink:0;width:100%;height:100%;position:relative}

/* Blurred background — fills entire slide */
.hero-blur-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:blur(18px);transform:scale(1.12);
  transition:opacity .5s ease;
}

/* Sharp centred image on top of blur */
.hero-img-layer{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  z-index:1;
}
.hero-main-img{
  max-width:100%;max-height:100%;
  width:100%;height:100%;
  object-fit:cover;      /* fill the hero area cleanly */
  object-position:center;
  display:block;
  transition:transform 7s ease;
}
.hero-slide.active .hero-main-img{transform:scale(1.03)}

/* Dark overlay for text readability */
.hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(100deg,rgba(15,40,12,.80) 0%,rgba(15,40,12,.45) 55%,transparent 100%);
}
.hero-content{position:absolute;bottom:0;left:0;right:0;padding:44px 0 56px;z-index:3}
.hero-content h1{color:#fff;max-width:620px;opacity:0;transform:translateY(22px);transition:opacity .6s .3s ease,transform .6s .3s ease}
.hero-slide.active .hero-content h1{opacity:1;transform:translateY(0)}
.hero-sub{color:rgba(255,255,255,.82);max-width:500px;margin-top:12px;opacity:0;transform:translateY(18px);transition:opacity .6s .5s ease,transform .6s .5s ease;font-size:1rem}
.hero-slide.active .hero-sub{opacity:1;transform:translateY(0)}
.hero-btns{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap;opacity:0;transform:translateY(18px);transition:opacity .6s .65s ease,transform .6s .65s ease}
.hero-slide.active .hero-btns{opacity:1;transform:translateY(0)}

.hero-ctrl{position:absolute;bottom:18px;right:18px;display:flex;align-items:center;gap:9px;z-index:10}
.hero-dots{display:flex;gap:7px}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:var(--tr);border:none}
.hero-dot.active{background:var(--gold);width:22px;border-radius:4px}
.hero-arr{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.hero-arr:hover{background:rgba(255,255,255,.3)}

/* ============================================================
   STATS BAR
============================================================ */
.stats-bar{background:var(--green);padding:38px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{text-align:center;padding:14px 18px;border-right:1px solid rgba(255,255,255,.15)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--fh);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;color:var(--gold);display:block;line-height:1;margin-bottom:5px}
.stat-lbl{font-size:.76rem;color:rgba(255,255,255,.75);text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* ============================================================
   FACILITIES BENTO GRID
============================================================ */
.sec-head{margin-bottom:40px}
.sec-sub{max-width:520px;margin:9px auto 0}
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.bento-cell{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:220px;cursor:pointer;background:var(--green-pale);transition:transform var(--tr),box-shadow var(--tr)}
.bento-cell:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.bento-cell.wide{grid-column:span 2}
.bento-cell.tall{grid-row:span 2}
.bento-bg{position:absolute;inset:0;background-size:cover!important;background-position:center center!important;background-repeat:no-repeat!important;transition:transform .5s ease}
.bento-cell:hover .bento-bg{transform:scale(1.06)}
.bento-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,40,12,.85) 0%,transparent 60%)}
.bento-info{position:absolute;bottom:0;left:0;right:0;padding:16px 18px}
.bento-tag{display:inline-block;background:var(--gold);color:var(--green-dk);font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:20px;margin-bottom:6px}
.bento-info h3{color:#fff;font-size:1rem;margin-bottom:3px}
.bento-info p{color:rgba(255,255,255,.75);font-size:.79rem;line-height:1.4}

/* Lightbox */
.lb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;display:none;align-items:center;justify-content:center}
.lb-overlay.open{display:flex}
.lb-box{position:relative;max-width:90vw;max-height:90vh}
.lb-box img{max-width:100%;max-height:82vh;border-radius:var(--r-md);object-fit:contain}
.lb-close{position:absolute;top:-36px;right:0;background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;font-weight:700}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;width:44px;height:44px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lb-prev{left:16px}.lb-next{right:16px}

/* ============================================================
   ACADEMIC PROGRAMS - 3 cards in one row, no tabs
============================================================ */
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prog-card{background:var(--off-white);border:1px solid var(--gray);border-radius:var(--r-lg);overflow:hidden;transition:var(--tr);display:flex;flex-direction:column}
.prog-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.prog-img{height:185px;background:var(--green-pale);overflow:hidden;flex-shrink:0}
.prog-img img{width:100%;height:100%;object-fit:cover}
.prog-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.prog-img-ph span{font-size:3.5rem;font-weight:900;color:var(--green);opacity:.3;font-family:var(--fh)}
.prog-body{padding:18px;flex:1;display:flex;flex-direction:column}
.prog-stream-tag{display:inline-block;font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--green);background:var(--green-pale);padding:3px 10px;border-radius:20px;margin-bottom:8px}
.prog-body h3{font-size:1.05rem;margin-bottom:7px}
.prog-body>p{font-size:.875rem;margin-bottom:12px;flex:1}
.prog-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.prog-chip{background:var(--green-pale);color:var(--green);font-size:.71rem;font-weight:700;padding:3px 10px;border-radius:20px}
.prog-foot{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.prog-meta{background:var(--gray-lt);color:var(--text-m);font-size:.71rem;font-weight:600;padding:3px 10px;border-radius:20px}
.prog-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}
.prog-link{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:700;color:var(--green);border:1.5px solid var(--green);padding:6px 14px;border-radius:20px;transition:var(--tr)}
.prog-link:hover{background:var(--green);color:#fff}
.prog-link-gold{background:var(--gold);color:var(--green-dk);border-color:var(--gold)}
.prog-link-gold:hover{background:#d4a017;color:var(--green-dk)}

/* ============================================================
   NEWS CARDS - no date, no category shown
============================================================ */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.news-card{background:#fff;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--gray);transition:var(--tr)}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.news-card-img-link{display:block;height:195px;overflow:hidden;background:var(--green-pale)}
.news-card-img-link img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.news-card:hover .news-card-img-link img{transform:scale(1.05)}
.news-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.news-no-img span{font-size:3rem;font-weight:900;color:var(--green);opacity:.25;font-family:var(--fh)}
.news-body{padding:18px}
.news-body h3{font-size:.98rem;margin-bottom:7px;line-height:1.4}
.news-body h3 a{color:var(--text)}
.news-body h3 a:hover{color:var(--green)}
.news-body>p{font-size:.875rem;margin-bottom:11px}
.read-more{font-size:.8rem;font-weight:700;color:var(--green);display:inline-flex;align-items:center;gap:5px}

/* ============================================================
   GALLERY
============================================================ */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:185px;gap:10px}
.gallery-cell{border-radius:var(--r-md);overflow:hidden;position:relative;cursor:pointer;background:var(--green-pale)}
.gallery-cell.g-span2{grid-column:span 2}
.gallery-cell.g-row2{grid-row:span 2}
.gallery-cell img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .4s ease}
.gallery-cell:hover img{transform:scale(1.07)}
.gallery-ov{position:absolute;inset:0;background:rgba(15,40,12,0);transition:var(--tr);display:flex;align-items:center;justify-content:center}
.gallery-cell:hover .gallery-ov{background:rgba(15,40,12,.42)}
.gallery-zoom{color:#fff;font-size:2rem;font-weight:700;opacity:0;transform:scale(.7);transition:var(--tr)}
.gallery-cell:hover .gallery-zoom{opacity:1;transform:scale(1)}
.gallery-lbl{position:absolute;bottom:0;left:0;right:0;padding:11px 12px 8px;background:linear-gradient(to top,rgba(15,40,12,.8) 0%,transparent 100%);color:#fff;font-size:.76rem;font-weight:700;opacity:0;transform:translateY(5px);transition:var(--tr)}
.gallery-cell:hover .gallery-lbl{opacity:1;transform:translateY(0)}
.gallery-ph{background:var(--green-pale);display:flex;align-items:center;justify-content:center}
.gallery-ph span{font-size:.75rem;color:var(--text-m);font-weight:600;text-align:center;padding:0 10px}

/* ============================================================
   EVENTS
============================================================ */
.events-list{display:flex;flex-direction:column;gap:10px}
.event-row{background:#fff;border:1px solid var(--gray);border-radius:var(--r-md);padding:14px 16px;display:flex;gap:14px;align-items:flex-start;border-left:4px solid var(--green);transition:var(--tr)}
.event-row:hover{box-shadow:var(--sh-sm);transform:translateX(4px)}
.event-date-box{flex-shrink:0;text-align:center;background:var(--green);color:#fff;border-radius:var(--r-sm);padding:7px 11px;min-width:54px}
.ed-day{font-size:1.35rem;font-weight:900;line-height:1;display:block;font-family:var(--fh)}
.ed-mon{font-size:.63rem;text-transform:uppercase;letter-spacing:.06em;display:block;margin-top:2px}
.event-info h4{font-size:.93rem;margin-bottom:3px}
.event-info p{font-size:.82rem}
.event-cls{font-size:.74rem;color:var(--text-l);display:block;margin-top:3px}
.event-badge{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:20px;display:inline-block;margin-top:5px}
.b-exam{background:#fce8e6;color:#c0392b}
.b-holiday{background:var(--gold-pale);color:var(--gold-dk)}
.b-activity{background:var(--green-pale);color:var(--green)}
.b-meeting{background:#e8f0fe;color:#1a73e8}

/* ============================================================
   CTA
============================================================ */
.cta-strip{background:var(--green-dk);padding:64px 0;text-align:center}

/* ============================================================
   NOTICES PAGE
============================================================ */
.notices-list{display:flex;flex-direction:column;gap:10px}
.notice-item{background:#fff;border:1px solid var(--gray);border-radius:var(--r-md);padding:15px 20px;display:flex;align-items:flex-start;gap:14px;transition:var(--tr)}
.notice-item:hover{border-color:var(--green);box-shadow:var(--sh-sm)}
.notice-item.expired{opacity:.44}
.notice-icon{width:38px;height:38px;border-radius:9px;background:var(--green-pale);color:var(--green);font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:800}
.ni-urgent{background:#fce8e6;color:#c0392b}
.notice-body{flex:1}
.notice-title-link{color:var(--text);font-weight:700;transition:var(--tr)}
.notice-title-link:hover{color:var(--green)}
.notice-body h4{font-size:.96rem;margin-bottom:4px}
.notice-body p{font-size:.84rem}
.notice-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:7px}
.notice-date{font-size:.73rem;color:var(--text-l)}
.notice-status{font-size:.67rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 9px;border-radius:20px}
.status-active{background:#e6f4ea;color:#137333}
.status-expired{background:var(--gray-lt);color:var(--text-l)}
.status-urgent{background:#fce8e6;color:#c0392b}
.notice-read-btn{font-size:.78rem;font-weight:700;color:var(--green);border:1.5px solid var(--green);padding:4px 12px;border-radius:20px;transition:var(--tr)}
.notice-read-btn:hover{background:var(--green);color:#fff}

/* ============================================================
   STAFF PAGE — 5 cards per row
============================================================ */
.staff-filter{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:28px}
.staff-btn{padding:7px 17px;border-radius:20px;font-size:.81rem;font-weight:700;cursor:pointer;border:1.5px solid var(--gray);background:#fff;color:var(--text-m);transition:var(--tr);font-family:var(--fb)}
.staff-btn.active,.staff-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}

.staff-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}

.staff-card-5{background:#fff;border:1px solid var(--gray);border-radius:var(--r-md);overflow:hidden;transition:var(--tr);text-align:center}
.staff-card-5:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.sc5-photo{position:relative;height:0;padding-bottom:100%;background:var(--green-pale);overflow:hidden}
.sc5-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.sc5-initials{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.6rem;font-weight:900;color:var(--green);opacity:.4}
.sc5-dept{position:absolute;top:7px;right:7px;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:20px;z-index:2}
.dept-school{background:var(--green-pale);color:var(--green)}
.dept-plus-two{background:var(--gold-pale);color:var(--gold-dk)}
.dept-admin{background:var(--gray-lt);color:var(--text-m)}
.sc5-info{padding:12px 10px 14px}
.sc5-info h4{font-size:.88rem;margin-bottom:3px;line-height:1.3}
.sc5-desig{font-size:.76rem;color:var(--green);font-weight:700;margin-bottom:2px}
.sc5-qual{font-size:.71rem;color:var(--text-l);margin-bottom:8px}
.sc5-contacts{display:flex;justify-content:center;gap:7px}
.sc5-contact-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--green-pale);color:var(--green);transition:var(--tr);flex-shrink:0}
.sc5-contact-btn:hover{background:var(--green);color:#fff}

/* ============================================================
   CONTACT PAGE
============================================================ */
.contact-map-wrap{border-radius:var(--r-lg);overflow:hidden;height:380px;background:var(--gray-lt)}
.contact-map-wrap iframe{width:100%;height:100%;border:none}
.contact-info-row{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--gray)}
.contact-info-row:last-child{border-bottom:none}
.contact-icon-box{width:38px;height:38px;flex-shrink:0;background:var(--green-pale);border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--green);font-size:.8rem}
.contact-info-row strong{display:block;font-size:.77rem;color:var(--text-m);margin-bottom:2px}
.contact-info-row span{font-size:.93rem;font-weight:600;color:var(--text)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.81rem;font-weight:700;color:var(--text);margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1.5px solid var(--gray);border-radius:var(--r-sm);font-family:var(--fb);font-size:.89rem;color:var(--text);background:#fff;outline:none;transition:var(--tr)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(45,90,39,.1)}
.form-group textarea{resize:vertical;min-height:110px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form-box{background:#fff;border:1px solid var(--gray);border-radius:var(--r-lg);padding:32px;box-shadow:var(--sh-sm)}

/* ============================================================
   PAGE HERO (generic)
============================================================ */
.page-hero{background:var(--green);padding:48px 0}
.page-hero h1{color:#fff;margin-bottom:7px}
.breadcrumb{color:rgba(255,255,255,.6);font-size:.78rem;margin-bottom:10px;display:block}
.breadcrumb a{color:var(--gold)}
.sub-title{color:rgba(255,255,255,.75);font-size:.97rem}

/* ============================================================
   SINGLE POST
============================================================ */
.single-layout{display:grid;grid-template-columns:1fr 300px;gap:40px;padding:48px 0 70px;align-items:start}
.post-feat-img{border-radius:var(--r-md);overflow:hidden;margin-bottom:26px}
.post-feat-img img{width:100%;aspect-ratio:16/9;object-fit:cover}
.post-content{font-size:1.02rem;line-height:1.85}
.post-content h2,.post-content h3{color:var(--green);margin:24px 0 9px}
.post-content p{margin-bottom:15px;color:var(--text)}
.post-content ul{margin:11px 0 15px 20px;list-style:disc}
.post-content blockquote{border-left:4px solid var(--gold);padding:12px 16px;background:var(--gold-pale);border-radius:0 5px 5px 0;margin:18px 0;font-style:italic}
.sidebar-block{background:#fff;border:1px solid var(--gray);border-radius:var(--r-md);padding:18px;margin-bottom:18px}
.sidebar-block h4{font-size:.84rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--green);padding-bottom:9px;border-bottom:2px solid var(--gold);margin-bottom:12px}
.sidebar-sticky{position:sticky;top:105px}
.related-item{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--gray)}
.related-item:last-child{border-bottom:none}
.related-thumb{width:56px;height:56px;border-radius:var(--r-sm);background:var(--green-pale);flex-shrink:0;overflow:hidden}
.related-thumb img{width:100%;height:100%;object-fit:cover}
.related-info h5{font-size:.82rem;line-height:1.4;margin-bottom:3px}
.related-info h5 a:hover{color:var(--green)}
.related-info span{font-size:.71rem;color:var(--text-l)}
.snr-row{padding:8px 0;border-bottom:1px solid var(--gray);display:flex;gap:8px;align-items:flex-start}
.snr-row:last-child{border-bottom:none}
.snr-dot{width:7px;height:7px;background:var(--green);border-radius:50%;margin-top:7px;flex-shrink:0}
.snr-row p{font-size:.79rem;color:var(--text);line-height:1.5}

/* ============================================================
   FOOTER
============================================================ */
#site-footer{background:var(--green-dk);color:rgba(255,255,255,.8);padding:56px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-name{font-family:var(--fh);font-size:1.1rem;color:#fff;margin-bottom:9px}
.footer-desc{font-size:.85rem;line-height:1.7;margin-bottom:16px}
.footer-social{display:flex;gap:8px}
.social-btn{width:33px;height:33px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;transition:var(--tr);text-decoration:none}
.social-btn:hover{background:var(--gold);border-color:var(--gold);color:var(--green-dk)}
.footer-col h4{font-family:var(--fb);font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gold);margin-bottom:14px}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col ul li a{font-size:.84rem;color:rgba(255,255,255,.7);transition:var(--tr);display:flex;align-items:center;gap:5px}
.footer-col ul li a::before{content:'>';color:var(--gold);font-size:.75rem}
.footer-col ul li a:hover{color:#fff;padding-left:4px}
.fc-row{display:flex;gap:8px;margin-bottom:9px;font-size:.84rem}
.fc-icon{color:var(--gold);flex-shrink:0;margin-top:1px;font-weight:700;min-width:14px;font-size:.78rem}
.footer-bottom{padding:15px 0;text-align:center;font-size:.76rem;color:rgba(255,255,255,.42)}
.footer-bottom a{color:var(--gold)}

/* ============================================================
   WHATSAPP FLOAT
============================================================ */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;align-items:flex-end;gap:8px;opacity:0;transition:opacity .4s ease,transform .4s ease;transform:translateY(20px)}
.wa-float.visible{opacity:1;transform:translateY(0)}
.wa-btn{width:54px;height:54px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);text-decoration:none;color:#fff;animation:wapulse 3s ease-in-out infinite}
.wa-btn:hover{transform:scale(1.1)}
@keyframes wapulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.wa-tip{background:rgba(0,0,0,.72);color:#fff;font-size:.74rem;font-weight:600;padding:5px 12px;border-radius:20px;white-space:nowrap;opacity:0;transform:translateX(7px);transition:var(--tr);pointer-events:none}
.wa-float:hover .wa-tip{opacity:1;transform:translateX(0)}

/* ============================================================
   UTILITIES
============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* News meta hidden (date/category removed from frontend) */
.news-meta-hidden{display:none}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .bento-grid{grid-template-columns:1fr 1fr}
  .bento-cell.wide{grid-column:span 2}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .staff-grid-5{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:900px){
  .prog-grid{grid-template-columns:repeat(2,1fr)}
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .staff-grid-5{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .topbar{display:none}
  .primary-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;flex-direction:column;padding:72px 20px 28px;z-index:900;overflow-y:auto}
  .primary-nav.open{display:flex}
  .primary-nav>li>a{padding:12px 0;border-bottom:1px solid var(--gray);border-radius:0;font-size:1rem}
  .nav-toggle{display:flex;z-index:1000}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.15)}
  .stat-item:nth-child(odd){border-right:1px solid rgba(255,255,255,.15)}
  .bento-grid{grid-template-columns:1fr}
  .bento-cell.wide,.bento-cell.tall{grid-column:span 1;grid-row:span 1}
  .prog-grid{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .staff-grid-5{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-cell.g-span2,.gallery-cell.g-row2{grid-column:span 1;grid-row:span 1}
  .single-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .hero-wrap{height:68vh;min-height:370px}
  .hero-content{padding:24px 0 76px}
  .flex-between{flex-direction:column;align-items:flex-start;gap:10px}
}
@media(max-width:480px){
  .container{padding:0 14px}
  .section-pad{padding:44px 0}
  .staff-grid-5{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-auto-rows:140px}
  h1,h2,h3{word-break:break-word}
}
