/*
Theme Name: MMES Custom Theme
Author: FA Studio
Description: Complete custom theme for MMES Public School
Version: 1.0
*/

/* ================= GLOBAL & HEADER ================= */
:root {
    --fa-dark-green: #1C4533; --fa-cream: #F6F3EB; --fa-sage: #6CA37D; 
    --fa-mint: #E6F0E9; --fa-white: #FFFFFF; 
    --shadow-main: 0 15px 35px -5px rgba(28, 69, 51, 0.15); --border-soft: #E6F0E9; 
}
* { margin:0; padding:0; box-sizing:border-box; font-family:'Outfit', sans-serif; }
body { background: var(--fa-cream); overflow-x: hidden; color: var(--fa-dark-green); -webkit-font-smoothing: antialiased; }
a { text-decoration: none; }
.fx-w { position:fixed; top:0; width:100%; z-index:999; left: 0; }
.spcr { width:100%; height:140px; display:block; }
.tb { background: var(--fa-dark-green); color: var(--fa-white); height: 48px; display:flex; justify-content:space-between; align-items:center; font-size: 13.5px; font-weight: 500; width: 100%; }
.mq { flex:1; overflow:hidden; white-space:nowrap; padding-left:20px; min-width:0; }
.mq-hl { background: var(--fa-mint); color: var(--fa-dark-green); padding: 4px 14px; border-radius: 20px; font-weight: 700; margin-left: 10px; }
.ta { display:flex; align-items:center; padding:0 25px; gap:20px; height:100%; background: rgba(0,0,0,0.15); flex-shrink:0; }
.sl { color: var(--fa-mint); transition:.3s; font-size: 15px; } .sl:hover { color: var(--fa-white); transform:translateY(-2px); }
.bp { background: var(--fa-mint); color: var(--fa-dark-green); padding: 8px 24px; border-radius: 50px; font-weight: 700; font-size: 13px; text-transform: capitalize; transition: all .3s cubic-bezier(0.16, 1, 0.3, 1); }
.bp:hover { background: var(--fa-white); transform: translateY(-2px); box-shadow: 0 6px 15px rgba(230, 240, 233, 0.2); }
.gh { background: rgba(255,255,255,0.9); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--border-soft); height: 90px; width: 100%; box-shadow: var(--shadow-main); }
.nc { max-width:1400px; margin:0 auto; padding:0 25px; display:flex; justify-content:space-between; align-items:center; height:100%; }
.lg img { height: 60px; transition:.3s; filter: drop-shadow(0 4px 6px rgba(28, 69, 51, 0.05)); } .lg:hover img { transform:scale(1.03); }
.nm { display:flex; gap: 4px; list-style:none; height:100%; } .ni { position:relative; display:flex; align-items:center; height:100%; }
.nl { color: var(--fa-dark-green); font-weight: 600; font-size: 15px; padding: 10px 16px; transition:.3s; display:flex; align-items:center; gap:6px; position:relative; border-radius: 50px; }
.nl i { font-size: 11px; color: var(--fa-sage); transition:.3s; }
.ni:hover .nl { color: var(--fa-dark-green); background: var(--fa-mint); } .ni:hover .nl i { color: var(--fa-dark-green); transform:rotate(180deg); } 
.drp { position:absolute; top:85%; left:50%; transform:translateX(-50%) translateY(15px); width:260px; background: var(--fa-white); border-radius: 20px; box-shadow: var(--shadow-main); border: 1px solid var(--border-soft); opacity:0; visibility:hidden; transition:all .3s cubic-bezier(0.16, 1, 0.3, 1); padding: 12px; list-style:none; }
.ni::before { content:''; position:absolute; top:100%; width:100%; height:30px; }
.ni:hover .drp { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); top:100%; }
.ni:nth-last-child(1) .drp, .ni:nth-last-child(2) .drp, .ni:nth-last-child(3) .drp { left: auto; right: 0; transform: translateY(15px); }
.ni:nth-last-child(1):hover .drp, .ni:nth-last-child(2):hover .drp, .ni:nth-last-child(3):hover .drp { transform: translateY(0); }
.drp li { margin-bottom: 4px; } .drp li:last-child { margin-bottom: 0; }
.drp a { display:flex; align-items:center; padding: 12px 16px; color: var(--fa-sage); font-size: 14px; font-weight: 500; border-radius: 12px; transition:.2s; position:relative; }
.drp a::after { content:'\f061'; font-family:'Font Awesome 6 Free'; font-weight:900; position:absolute; right:16px; opacity:0; transition:.3s; color: var(--fa-dark-green); font-size:12px; transform: translateX(-10px); }
.drp a:hover { background: var(--fa-mint); color: var(--fa-dark-green); padding-left: 20px; font-weight: 600; } .drp a:hover::after { opacity:1; transform: translateX(0); }
.mtr { display:none; font-size:20px; color: var(--fa-dark-green); background:var(--fa-mint); border:none; cursor:pointer; width: 45px; height: 45px; border-radius: 12px; transition: .2s; }
.mtr:hover { background: var(--fa-sage); color: var(--fa-white); }
.mdr { position:fixed; top:0; right:-100%; width:340px; max-width: 85vw; height:100vh; background: var(--fa-cream); z-index:9999; box-shadow:-20px 0 50px rgba(28, 69, 51, 0.15); transition: right .4s cubic-bezier(0.16, 1, 0.3, 1); overflow-y:auto; }
.mdr.act { right:0; }
.bgp { position:fixed; inset:0; background:rgba(28, 69, 51, 0.4); z-index:9998; display:none; backdrop-filter:blur(4px); } .bgp.act { display:block; }
.mh { display:flex; justify-content:space-between; align-items:center; padding:25px; background: var(--fa-white); border-bottom:1px solid var(--border-soft); border-radius: 0 0 20px 20px; } .mh img { height:40px; }
.cbt { background: var(--fa-mint); border: none; width:38px; height:38px; border-radius:50%; color: var(--fa-dark-green); font-size:16px; cursor:pointer; transition:.3s; display:flex; align-items:center; justify-content:center; }
.cbt:hover { background: var(--fa-dark-green); color:var(--fa-white); transform: rotate(90deg); }
.mbd { padding:20px 25px; }
.mlk { display:flex; justify-content:space-between; align-items:center; padding:16px 0; color: var(--fa-dark-green); font-weight:600; border-bottom:1px solid rgba(28, 69, 51, 0.05); font-size:16px; transition:.2s; }
.mlk i { font-size:12px; color: var(--fa-sage); transition:.3s; padding: 6px; background: var(--fa-mint); border-radius: 50%; }
.mlk.act { color: var(--fa-sage); border-bottom-color: transparent;} .mlk.act i { transform:rotate(180deg); color: var(--fa-white); background: var(--fa-sage); }
.msb { max-height:0; overflow:hidden; transition: max-height .4s ease; background: var(--fa-white); border-radius:16px; box-shadow: 0 4px 15px rgba(28, 69, 51, 0.05); }
.msb.shw { max-height:800px; padding:10px 0; margin:5px 0 15px 0; border: 1px solid var(--fa-mint); }
.msb a { font-size:14px; color: var(--fa-sage); padding:12px 20px; display:block; font-weight:500; transition:.2s; position:relative; }
.msb a::before { content:''; position:absolute; left:12px; top:50%; transform:translateY(-50%); width:6px; height:6px; border-radius:50%; background: var(--fa-sage); opacity:0; transition:.3s; }
.msb a:hover { color: var(--fa-dark-green); background: var(--fa-mint); padding-left:28px; font-weight: 600; } .msb a:hover::before { opacity:1; }
@media(max-width:1150px) { .nm{display:none;} .mtr{display:flex; align-items:center; justify-content:center;} .spcr{height:135px;} }
@media(max-width:768px) { .ta{display:none;} .mq{padding-right:20px;} .tb{justify-content: center;} }

/* ================= SLIDER ================= */
.fa-ed-sec { --d: #1C4533; --s: #6CA37D; --m: #E6F0E9; --w: #FFFFFF; --cv: cubic-bezier(0.16, 1, 0.3, 1); position: relative; width: 100%; padding: clamp(60px, 8vw, 120px) 0; display: flex; align-items: center; justify-content: center; background: var(--w); overflow: hidden; }
.fa-ed-glo { position: absolute; width: 600px; height: 600px; background: radial-gradient(circle, rgba(230, 240, 233, 0.8) 0%, rgba(255,255,255,0) 70%); top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 0; pointer-events: none; }
.fa-ed-wrp { width: 100%; max-width: 1350px; margin: 0 auto; padding: 0 clamp(25px, 5vw, 50px); position: relative; z-index: 10; display: grid; grid-template-columns: 100%; }
.fa-ed-sl { grid-area: 1/1; display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(40px, 6vw, 80px); align-items: center; opacity: 0; pointer-events: none; visibility: hidden; transition: opacity 0.8s var(--cv), visibility 0s 0.8s; }
.fa-ed-sl.act { opacity: 1; pointer-events: all; visibility: visible; z-index: 2; transition: opacity 0.8s var(--cv), visibility 0s; }
.fa-ed-txt { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; z-index: 5; }
.fa-ed-anm { opacity: 0; transform: translateY(30px); }
.fa-ed-sl.act .fa-ed-anm { animation: faEdUp 0.8s var(--cv) forwards; }
.fa-ed-sl.act .d1{animation-delay: 0.1s} .fa-ed-sl.act .d2{animation-delay: 0.2s} .fa-ed-sl.act .d3{animation-delay: 0.3s}
@keyframes faEdUp { to { opacity: 1; transform: translateY(0); } }
.fa-ed-tit { font-size: clamp(2.8rem, 4.5vw, 4.5rem); line-height: 1.1; color: var(--d); font-weight: 800; margin-bottom: 20px; letter-spacing: -0.5px; }
.fa-ed-des { font-size: clamp(1.1rem, 1.2vw, 1.2rem); line-height: 1.6; color: #475569; font-weight: 300; margin-bottom: 35px; max-width: 90%; }
.fa-ed-btn { padding: 16px 36px; border-radius: 12px; font-weight: 600; font-size: 1.05rem; display: inline-flex; align-items: center; justify-content: center; gap: 10px; background: var(--s); color: var(--w); transition: 0.4s var(--cv); cursor: pointer; border: none; box-shadow: 0 10px 25px rgba(108, 163, 125, 0.2); }
.fa-ed-btn:hover { background: var(--d); transform: translateY(-4px); box-shadow: 0 15px 35px rgba(28, 69, 51, 0.25); }
.fa-ed-img-w { position: relative; width: 100%; display: flex; justify-content: center; padding: 20px 40px 30px 0; }
@keyframes faMorphWv { 0% { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; } 50% { border-radius: 30% 60% 70% 40% / 50% 60% 30% 60%; } 100% { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; } }
.fa-ed-wv { position: absolute; top: -10px; right: 0; bottom: 10px; left: 30px; background: linear-gradient(135deg, var(--s), var(--m)); z-index: 0; opacity: 0.6; animation: faMorphWv 8s ease-in-out infinite reverse; }
.fa-ed-pic { position: relative; z-index: 1; width: 100%; aspect-ratio: 1/1; max-width: 500px; overflow: hidden; box-shadow: 0 20px 50px -10px rgba(28, 69, 51, 0.25); border: 6px solid var(--w); animation: faMorphWv 8s ease-in-out infinite; transform: translateX(40px); opacity: 0; transition: 1s var(--cv); }
.fa-ed-sl.act .fa-ed-pic { transform: translateX(0); opacity: 1; transition-delay: 0.2s; }
.fa-ed-pic img { width: 100%; height: 100%; object-fit: cover; display: block; transform: scale(1.1); transition: transform 3s ease-out; }
.fa-ed-sl.act .fa-ed-pic img { transform: scale(1); }
.fa-ed-flt { position: absolute; bottom: 10px; left: -10px; background: rgba(255, 255, 255, 0.85); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); padding: 15px 25px; border-radius: 16px; display: flex; align-items: center; gap: 15px; box-shadow: 0 15px 30px rgba(28, 69, 51, 0.1); border: 1px solid rgba(255,255,255,0.8); z-index: 3; animation: faEdBnc 4s infinite alternate ease-in-out; }
.fa-ed-flt i { width: 40px; height: 40px; background: var(--m); color: var(--d); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; }
.fa-ed-f-tx { display: flex; flex-direction: column; } .fa-ed-f-n { font-weight: 800; color: var(--d); font-size: 1.1rem; line-height: 1; } .fa-ed-f-m { font-weight: 600; color: var(--s); font-size: 0.75rem; text-transform: uppercase; margin-top: 2px;}
@keyframes faEdBnc { 100% { transform: translateY(-15px); } }
.fa-ed-ctrl { position: absolute; bottom: -40px; left: 50px; display: flex; gap: 12px; z-index: 20; }
.fa-ed-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--m); cursor: pointer; transition: 0.4s var(--cv); }
.fa-ed-dot:hover { background: var(--s); } .fa-ed-dot.act { background: var(--d); width: 35px; border-radius: 10px; }
@media(max-width: 950px) { .fa-ed-sec { padding: 60px 0 100px 0; } .fa-ed-sl { grid-template-columns: 1fr; gap: 50px; text-align: center; } .fa-ed-txt { align-items: center; } .fa-ed-des { max-width: 100%; margin-bottom: 25px; } .fa-ed-img-w { padding: 15px; max-width: 500px; margin: 0 auto; } .fa-ed-wv { top: 0; right: 0; bottom: 0; left: 0; } .fa-ed-flt { left: 0px; bottom: 0px; padding: 12px 20px; } .fa-ed-ctrl { left: 50%; transform: translateX(-50%); bottom: -60px; } }
@media(max-width: 480px) { .fa-ed-flt { display: none; } }

/* ================= WIDGETS ================= */
.fa-wgt-sec { max-width: 1350px; margin: 80px auto; padding: 0 clamp(25px, 5vw, 50px); display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 40px; align-items: start; }
.fa-sx-box, .fa-dl-box { --d: #1C4533; --c: #F6F3EB; --s: #6CA37D; --m: #E6F0E9; --w: #FFFFFF; --cv: cubic-bezier(0.16, 1, 0.3, 1); width: 100%; background: var(--w); border-radius: 24px; box-shadow: 0 20px 40px -10px rgba(28, 69, 51, 0.08); border: 1px solid var(--m); display: flex; flex-direction: column; overflow: hidden; }
.fa-sx-hd, .fa-dl-hd { padding: 25px 25px 15px 25px; border-bottom: 1px solid var(--m); position: relative; }
.fa-sx-tg, .fa-dl-tg { display: inline-block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--d); background: var(--m); padding: 5px 12px; border-radius: 50px; margin-bottom: 10px; }
.fa-sx-tt, .fa-dl-tt { font-size: 1.4rem; color: var(--d); font-weight: 800; display: flex; align-items: center; justify-content: space-between; }
.fa-sx-tt i, .fa-dl-tt i { color: var(--s); font-size: 1.2rem; }
.fa-sx-ls, .fa-dl-ls { padding: 15px 20px; display: flex; flex-direction: column; gap: 8px; }
.fa-sx-it, .fa-dl-it { display: flex; align-items: center; gap: 15px; padding: 12px; border-radius: 16px; transition: 0.3s var(--cv); border: 1px solid transparent; }
.fa-sx-it:hover, .fa-dl-it:hover { background: var(--w); border-color: var(--s); box-shadow: 0 10px 20px rgba(28, 69, 51, 0.06); transform: translateY(-2px); }
.fa-sx-dt { width: 45px; height: 45px; background: var(--m); color: var(--d); border-radius: 12px; display: flex; flex-direction: column; align-items: center; justify-content: center; flex-shrink: 0; transition: 0.3s var(--cv); }
.fa-dl-ic { width: 45px; height: 45px; background: var(--m); color: var(--d); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; transition: 0.3s var(--cv); }
.fa-sx-dn { font-size: 1.05rem; font-weight: 800; line-height: 1; margin-bottom: 1px; }
.fa-sx-dm { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;}
.fa-sx-it:hover .fa-sx-dt, .fa-dl-it:hover .fa-dl-ic { background: var(--s); color: var(--w); }
.fa-sx-tx, .fa-dl-tx { flex: 1; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
.fa-sx-n, .fa-dl-n { font-size: 0.95rem; font-weight: 700; color: var(--d); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 2px; transition: 0.3s; }
.fa-sx-m, .fa-dl-m { font-size: 0.7rem; font-weight: 600; color: var(--s); text-transform: uppercase; letter-spacing: 0.5px; }
.fa-sx-ar, .fa-dl-ar { color: var(--s); font-size: 1rem; opacity: 0; transform: translateX(-10px); transition: 0.3s var(--cv); }
.fa-dl-ar { font-size: 1.1rem; }
.fa-sx-it:hover .fa-sx-ar, .fa-dl-it:hover .fa-dl-ar { opacity: 1; transform: translateX(0); }
.fa-sx-ft, .fa-dl-ft { padding: 15px 20px 20px 20px; }
.fa-sx-bt, .fa-dl-bt { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 14px; background: var(--d); color: var(--w); border-radius: 14px; font-size: 0.95rem; font-weight: 700; transition: 0.3s var(--cv); }
.fa-sx-bt:hover, .fa-dl-bt:hover { background: var(--s); box-shadow: 0 8px 20px rgba(108, 163, 125, 0.3); transform: translateY(-2px); }

/* ================= ABOUT US ================= */
.fa-mn-sec { font-family: 'Outfit', sans-serif !important; width: 100% !important; max-width: 100% !important; background: #FFFFFF !important; box-sizing: border-box !important; display: flex !important; flex-direction: column !important; overflow: hidden !important; }
.fa-mn-sec *, .fa-mn-sec *::before, .fa-mn-sec *::after { box-sizing: border-box !important; margin: 0; padding: 0; }
.fa-mn-hero { width: 100% !important; height: clamp(250px, 35vh, 400px) !important; position: relative !important; overflow: hidden !important; }
.fa-mn-hero img { width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; transform: scale(1.02) !important; transition: transform 1.5s ease-out !important; }
.fa-mn-hero:hover img { transform: scale(1.05) !important; }
.fa-mn-hero::after { content: ''; position: absolute !important; inset: 0 !important; background: linear-gradient(to top, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 25%) !important; }
.fa-mn-cnt { width: 100% !important; max-width: 1350px !important; margin: 0 auto !important; padding: 50px 40px 80px 40px !important; display: flex !important; flex-direction: column !important; }
.fa-mn-intro { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 50px !important; align-items: flex-start !important; margin-bottom: 40px !important; }
.fa-mn-hdg { display: flex !important; flex-direction: column !important; align-items: flex-start !important; }
.fa-mn-bdg { font-size: 13px !important; font-weight: 700 !important; color: #1C4533 !important; background: #E6F0E9 !important; padding: 6px 16px !important; border-radius: 50px !important; text-transform: uppercase !important; letter-spacing: 1px !important; margin-bottom: 15px !important; display: inline-flex !important; align-items: center !important; gap: 8px !important; }
.fa-mn-bdg i { color: #6CA37D !important; font-size: 14px !important; }
.fa-mn-tit { font-size: clamp(2.5rem, 4vw, 3.8rem) !important; line-height: 1.1 !important; color: #1C4533 !important; font-weight: 800 !important; margin: 0 !important; letter-spacing: -0.5px !important; }
.fa-mn-tit span { color: #6CA37D !important; }
.fa-mn-txt { padding-top: 10px !important; }
.fa-mn-des { font-size: 1.1rem !important; line-height: 1.65 !important; color: #475569 !important; font-weight: 400 !important; margin-bottom: 15px !important; }
.fa-mn-des:last-child { margin-bottom: 0 !important; }
.fa-mn-des strong { color: #1C4533 !important; font-weight: 700 !important; }
.fa-mn-fts { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 15px 20px !important; list-style: none !important; margin-bottom: 40px !important; }
.fa-mn-ft-i { display: flex !important; align-items: center !important; gap: 10px !important; font-size: 1rem !important; font-weight: 600 !important; color: #1C4533 !important; }
.fa-mn-ft-i i { color: #1C4533 !important; background: #E6F0E9 !important; width: 28px !important; height: 28px !important; border-radius: 6px !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 11px !important; flex-shrink: 0 !important; }
.fa-mn-act { display: flex !important; justify-content: flex-start !important; width: 100% !important; }
.fa-mn-btn { display: inline-flex !important; align-items: center !important; gap: 10px !important; background: #1C4533 !important; color: #FFFFFF !important; padding: 14px 36px !important; border-radius: 50px !important; font-size: 1.05rem !important; font-weight: 700 !important; transition: 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important; }
.fa-mn-btn:hover { background: #6CA37D !important; transform: translateY(-3px) !important; box-shadow: 0 10px 20px rgba(108, 163, 125, 0.3) !important; }
@media(max-width: 1024px) { .fa-mn-fts { grid-template-columns: repeat(3, 1fr) !important; } }
@media(max-width: 850px) { .fa-mn-cnt { padding: 40px 30px 60px 30px !important; } .fa-mn-intro { grid-template-columns: 1fr !important; gap: 20px !important; margin-bottom: 30px !important; } .fa-mn-txt { padding-top: 0 !important; } .fa-mn-fts { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; margin-bottom: 35px !important; } }
@media(max-width: 550px) { .fa-mn-hero { height: 220px !important; } .fa-mn-cnt { padding: 30px 20px 50px 20px !important; } .fa-mn-tit { font-size: 2.2rem !important; } .fa-mn-fts { grid-template-columns: 1fr !important; } .fa-mn-btn { width: 100% !important; justify-content: center !important; } }

/* ================= COUNTERS ================= */
.fa-ct-sec { --d: #1C4533; --s: #6CA37D; --m: #E6F0E9; --w: #FFFFFF; --cv: cubic-bezier(0.16, 1, 0.3, 1); padding: 80px 20px; background: #F8FAFC; }
.fa-ct-wrp { max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(15px, 2vw, 30px); }
.fa-ct-crd { background: var(--w); border: 1px solid var(--m); border-radius: 24px; padding: clamp(20px, 3vw, 35px) clamp(15px, 2vw, 30px); position: relative; overflow: hidden; box-shadow: 0 15px 35px -5px rgba(28, 69, 51, 0.04); transition: 0.4s var(--cv); display: flex; flex-direction: column; justify-content: center; cursor: default; }
.fa-ct-crd:hover { transform: translateY(-8px); border-color: var(--s); box-shadow: 0 25px 50px -10px rgba(28, 69, 51, 0.12); }
.fa-ct-wtm { position: absolute; top: -10px; right: -10px; font-size: clamp(80px, 8vw, 110px); color: var(--m); opacity: 0.4; transform: rotate(15deg); transition: 0.6s var(--cv); z-index: 0; }
.fa-ct-crd:hover .fa-ct-wtm { transform: rotate(0deg) scale(1.1); color: var(--s); opacity: 0.15; }
.fa-ct-icn { width: clamp(45px, 5vw, 60px); height: clamp(45px, 5vw, 60px); background: var(--m); color: var(--d); border-radius: 16px; display: flex; align-items: center; justify-content: center; font-size: clamp(18px, 2vw, 24px); margin-bottom: 20px; z-index: 1; transition: 0.4s var(--cv); }
.fa-ct-crd:hover .fa-ct-icn { background: var(--s); color: var(--w); transform: scale(1.1) rotate(-5deg); border-radius: 12px; }
.fa-ct-num { font-size: clamp(2rem, 3.5vw, 3.5rem); font-weight: 800; color: var(--d); line-height: 1; margin-bottom: 5px; z-index: 1; letter-spacing: -1px; }
.fa-ct-lbl { font-size: clamp(0.65rem, 1vw, 0.85rem); font-weight: 700; color: var(--s); text-transform: uppercase; letter-spacing: 0.5px; z-index: 1; white-space: nowrap; }
@media(max-width: 768px) { .fa-ct-wrp { grid-template-columns: repeat(2, 1fr); gap: 15px; } }
@media(max-width: 480px) { .fa-ct-sec { padding: 60px 20px; } .fa-ct-wrp { grid-template-columns: 1fr; } .fa-ct-crd { align-items: center; text-align: center; } }

/* ================= LEADERSHIP ================= */
.f-ld-sec { --d: #1C4533; --c: #F8FAFC; --s: #6CA37D; --m: #E6F0E9; --w: #FFFFFF; --cv: cubic-bezier(0.16, 1, 0.3, 1); width: 100%; background: var(--c); padding: clamp(40px, 5vw, 50px) 0; overflow: hidden; }
.f-ld-wrp { max-width: 1200px; margin: 0 auto; padding: 0 25px; }
.f-ld-hdr { text-align: center; margin-bottom: 30px; }
.f-ld-bdg { display: inline-flex; align-items: center; gap: 8px; background: var(--w); color: var(--d); border: 1px solid var(--m); padding: 6px 14px; border-radius: 50px; font-size: 12px; font-weight: 700; text-transform: uppercase; margin-bottom: 12px; box-shadow: 0 4px 10px rgba(28, 69, 51, 0.05); letter-spacing: 0.5px; }
.f-ld-bdg i { color: var(--s); }
.f-ld-tit { font-size: clamp(2.2rem, 4vw, 3.2rem); line-height: 1.1; color: var(--d); font-weight: 800; margin: 0; }
.f-ld-tit span { color: var(--s); }
.f-ld-grd { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; }
.f-ld-crd { background: var(--w); border: 1px solid var(--m); border-radius: 24px; padding: 30px 25px; text-align: center; position: relative; box-shadow: 0 10px 30px -5px rgba(28, 69, 51, 0.04); transition: 0.4s var(--cv); display: flex; flex-direction: column; align-items: center; }
.f-ld-crd:hover { transform: translateY(-5px); border-color: var(--s); box-shadow: 0 20px 40px rgba(28, 69, 51, 0.1); }
.f-ld-shp { width: 140px; height: 140px; margin: 0 auto 15px; position: relative; }
.f-ld-lqd { position: absolute; top: -5px; left: -5px; right: -5px; bottom: -5px; background: linear-gradient(135deg, var(--d), var(--s)); z-index: 0; animation: faMorph 8s ease-in-out infinite; transition: 0.4s var(--cv); }
.f-ld-crd:hover .f-ld-lqd { opacity: 0.8; transform: scale(1.05); }
.f-ld-crd.alt .f-ld-lqd { background: linear-gradient(135deg, var(--s), var(--m)); }
.f-ld-pic { width: 100%; height: 100%; position: relative; z-index: 1; border: 4px solid var(--w); overflow: hidden; animation: faMorph 8s ease-in-out infinite; }
.f-ld-pic img { width: 100%; height: 100%; object-fit: cover; display: block; }
.f-ld-qt { color: var(--m); font-size: 24px; margin-bottom: 10px; transition: 0.4s; }
.f-ld-crd:hover .f-ld-qt { color: var(--s); transform: scale(1.1); }
.f-ld-msg { font-size: 1.05rem; line-height: 1.55; color: #475569; font-weight: 400; margin-bottom: 15px; font-style: italic; }
.f-ld-div { width: 40px; height: 3px; background: var(--m); margin: 0 auto 15px; border-radius: 50px; transition: 0.4s; }
.f-ld-crd:hover .f-ld-div { background: var(--s); width: 60px; }
.f-ld-nme { font-size: 1.4rem; font-weight: 800; color: var(--d); line-height: 1; margin-bottom: 4px; }
.f-ld-rle { font-size: 0.75rem; font-weight: 700; color: var(--s); text-transform: uppercase; letter-spacing: 1px; }
@media(max-width: 900px) { .f-ld-grd { grid-template-columns: 1fr; max-width: 550px; margin: 0 auto; } }
@media(max-width: 480px) { .f-ld-sec { padding: 40px 0; } .f-ld-crd { padding: 25px 20px; } .f-ld-shp { width: 120px; height: 120px; } .f-ld-tit { font-size: 2rem; } }

/* ================= PARTNERS ================= */
.f-pt-sec { --d: #1C4533; --c: #F6F3EB; --s: #6CA37D; --m: #E6F0E9; --w: #FFFFFF; --cv: cubic-bezier(0.16, 1, 0.3, 1); width: 100%; background: #F8FAFC; padding: 60px 0; }
.f-pt-wrp { max-width: 1250px; margin: 0 auto; padding: 0 25px; }
.f-pt-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 30px; padding-bottom: 15px; border-bottom: 1px solid var(--m); }
.f-pt-tit { font-size: clamp(1.5rem, 2.5vw, 2rem); color: var(--d); font-weight: 800; display: flex; align-items: center; gap: 12px; }
.f-pt-tit i { color: var(--s); font-size: 1.6rem; }
.f-pt-bdg { font-size: 0.75rem; font-weight: 700; color: var(--d); background: var(--m); padding: 6px 14px; border-radius: 50px; text-transform: uppercase; letter-spacing: 1px; }
.f-pt-grd { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 15px; }
.f-pt-crd { background: var(--w); border: 1px solid var(--m); border-radius: 16px; padding: 16px 20px; display: flex; align-items: center; gap: 18px; transition: 0.3s var(--cv); cursor: pointer; box-shadow: 0 5px 15px rgba(28, 69, 51, 0.02); }
.f-pt-crd:hover { transform: translateY(-3px); border-color: var(--s); background: var(--w); box-shadow: 0 15px 30px rgba(28, 69, 51, 0.08); }
.f-pt-lg { width: 55px; height: 55px; background: var(--m); border-radius: 12px; padding: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: 0.4s var(--cv); }
.f-pt-lg img { width: 100%; height: 100%; object-fit: contain; filter: grayscale(100%) opacity(0.7); transition: 0.4s var(--cv); }
.f-pt-crd:hover .f-pt-lg { background: var(--w); box-shadow: 0 5px 15px rgba(28, 69, 51, 0.1); }
.f-pt-crd:hover .f-pt-lg img { filter: grayscale(0%) opacity(1); transform: scale(1.1); }
.f-pt-tx { flex: 1; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
.f-pt-nme { font-size: 1rem; font-weight: 700; color: var(--d); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 2px; transition: color 0.3s; }
.f-pt-crd:hover .f-pt-nme { color: var(--s); }
.f-pt-mta { font-size: 0.7rem; font-weight: 600; color: #64748B; text-transform: uppercase; letter-spacing: 0.5px; display: flex; align-items: center; gap: 6px; }
.f-pt-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--s); box-shadow: 0 0 0 2px rgba(108, 163, 125, 0.2); }
.f-pt-ar { color: var(--s); font-size: 1rem; opacity: 0; transform: translateX(-10px); transition: 0.3s var(--cv); }
.f-pt-crd:hover .f-pt-ar { opacity: 1; transform: translateX(0); }
@media(max-width: 768px) { .f-pt-hdr { flex-direction: column; align-items: flex-start; gap: 15px; } .f-pt-grd { grid-template-columns: 1fr; } }
@media(max-width: 480px) { .f-pt-sec { padding: 40px 0; } .f-pt-crd { padding: 15px; } .f-pt-lg { width: 45px; height: 45px; } }

/* ================= GALLERY ================= */
.fa-gal-sec { background: #F8FAFC; padding: 40px 0 80px 0; overflow: hidden; display: flex; flex-direction: column; align-items: center; }
.fa-gal-tit { font-family: 'Outfit', sans-serif; font-size: 2rem; color: #1C4533; font-weight: 800; margin-bottom: 30px; }
.fa-gal-tit span { color: #6CA37D; }
.fa-gal-trk { display: flex; width: max-content; animation: faScroll 30s linear infinite; }
.fa-gal-trk:hover { animation-play-state: paused; }
.fa-gal-trk img { height: 250px; width: 350px; object-fit: cover; border-radius: 20px; margin: 0 15px; box-shadow: 0 15px 35px rgba(28, 69, 51, 0.1); transition: 0.4s; }
.fa-gal-trk img:hover { transform: translateY(-10px) scale(1.02); box-shadow: 0 25px 45px rgba(28, 69, 51, 0.2); }
@keyframes faScroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ================= FOOTER ================= */
.f-ft { --d:#1C4533; --s:#6CA37D; --m:#E6F0E9; --w:#FFFFFF; --cv:cubic-bezier(0.16,1,0.3,1); font-family:'Outfit',sans-serif !important; position: relative !important; display: block !important; margin-top: 150px !important; width: 100vw !important; max-width: 100vw !important; left: 50% !important; right: 50% !important; margin-left: -50vw !important; margin-right: -50vw !important; padding: 0 !important; border-radius: 0 !important; background: transparent !important; }
.f-ft *, .f-ft *::before, .f-ft *::after { box-sizing:border-box; margin:0; padding:0; list-style:none; text-decoration:none; }
.f-wv{position:absolute;top:-84px;left:0;width:100%;height:85px;overflow:hidden;line-height:0;z-index:2; margin:0 !important; padding:0 !important; border-radius:0 !important;}
.f-wv svg{position:relative;display:block;width:calc(200% + 1.3px);height:100%;transform:scaleY(-1)}
.f-wv .w1{animation:fWv 15s linear infinite;fill:var(--d);opacity:0.3}
.f-wv .w2{animation:fWv 20s linear infinite;fill:var(--d);opacity:0.5;animation-delay:-5s}
.f-wv .w3{animation:fWv 10s linear infinite;fill:var(--d);animation-delay:-2s}
@keyframes fWv{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.f-bg{ width: 100% !important; background: var(--d) !important; padding: 80px 0 0 0 !important; position: relative !important; overflow: hidden !important; z-index: 1 !important; border-radius: 0 !important; margin: 0 !important; }
.f-glo{position:absolute;width:600px;height:600px;border-radius:50%;background:var(--s);filter:blur(150px);opacity:.15;top:-50px;left:15%;z-index:0;pointer-events:none}
.f-wtm{position:absolute;bottom:-30px;right:-20px;font-family:'Calistoga',serif;font-size:clamp(120px,15vw,250px);font-weight:900;line-height:1;color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.03);z-index:0;pointer-events:none;user-select:none;letter-spacing:-2px}
.f-wrp{max-width:1400px;margin:0 auto;padding:0 40px 70px;position:relative;z-index:2;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:50px}
.f-rv{opacity:0;transform:translateY(40px);transition:.8s var(--cv)} .f-rv.v{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}
.f-brd{display:flex;flex-direction:column;align-items:flex-start}
.f-log{background:var(--w);padding:15px 25px;border-radius:20px;display:inline-flex;margin-bottom:25px;box-shadow:0 15px 40px rgba(0,0,0,.2);transition:.4s var(--cv)}
.f-log:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(108,163,125,.3)}
.f-log img{height:45px;display:block}
.f-des{font-size:1.05rem;line-height:1.6;color:var(--m);opacity:.85;margin-bottom:30px;max-width:90%;font-weight:300}
.f-soc{display:flex;gap:12px}
.f-slk{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.05);color:var(--m);display:flex;align-items:center;justify-content:center;font-size:18px;transition:.4s var(--cv);border:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}
.f-slk::before{content:'';position:absolute;inset:0;background:var(--s);border-radius:12px;transform:scale(0);transition:.4s var(--cv);z-index:-1}
.f-slk:hover{color:var(--w);border-color:var(--s);transform:translateY(-5px);box-shadow:0 10px 20px rgba(108,163,125,.4)}
.f-slk:hover::before{transform:scale(1)}
.f-tit{font-size:1.3rem;color:var(--w);font-weight:700;margin-bottom:25px;position:relative;display:inline-block;letter-spacing:0.5px}
.f-tit::after{content:'';position:absolute;bottom:-6px;left:0;width:30px;height:3px;background:var(--s);border-radius:5px}
.f-ul{display:flex;flex-direction:column;gap:16px}
.f-ul a{color:var(--m);opacity:.8;font-size:1.05rem;font-weight:400;transition:.3s;display:inline-flex;width:max-content;position:relative}
.f-ul a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--s);transition:.4s var(--cv)}
.f-ul a:hover{opacity:1;color:var(--w);transform:translateX(5px)} .f-ul a:hover::after{width:100%}
.f-nl{position:relative;margin-bottom:30px}
.f-nl input{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);padding:16px 20px;border-radius:50px;color:var(--w);font-family:inherit;font-size:1rem;font-weight:400;outline:none;transition:.3s}
.f-nl input:focus{border-color:var(--s);background:rgba(255,255,255,.1)}
.f-nl button{position:absolute;right:6px;top:6px;bottom:6px;background:var(--s);border:none;border-radius:50px;padding:0 25px;color:var(--w);font-weight:700;font-family:inherit;cursor:pointer;transition:.3s var(--cv)}
.f-nl button:hover{background:var(--m);color:var(--d);box-shadow:0 5px 15px rgba(108,163,125,.4);transform:scale(0.95)}
.f-app{display:flex;gap:12px}
.f-abn{display:flex;align-items:center;gap:10px;background:rgba(0,0,0,.2);padding:10px 18px;border-radius:14px;color:var(--w);border:1px solid rgba(255,255,255,.1);transition:.4s var(--cv);position:relative;overflow:hidden}
.f-abn::before{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:skewX(-20deg);transition:0s}
.f-abn:hover::before{left:200%;transition:.6s}
.f-abn:hover{border-color:var(--s);transform:translateY(-3px);box-shadow:0 10px 25px rgba(0,0,0,.3)}
.f-abn i{font-size:24px}
.f-atx{display:flex;flex-direction:column;line-height:1.1}
.f-atx span{font-size:9px;color:var(--m);opacity:.8;text-transform:uppercase;font-weight:500}
.f-atx b{font-size:14px;font-weight:600}
.f-btm{border-top:1px solid rgba(255,255,255,.08);width:100%;position:relative;z-index:2;border-radius:0 !important;}
.f-bin{max-width:1400px;margin:0 auto;padding:25px 40px;display:flex;justify-content:space-between;align-items:center}
.f-cpy,.f-dev{font-size:.95rem;color:var(--m);opacity:.7;font-weight:300}
.f-dev a{color:var(--s);font-weight:600;transition:.3s}
.f-dev a:hover{color:var(--w)}
.f-up{background:rgba(255,255,255,.05);color:var(--w);width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:.4s var(--cv);cursor:pointer;border:1px solid rgba(255,255,255,.05)}
.f-up:hover{background:var(--s);transform:translateY(-5px);box-shadow:0 10px 20px rgba(108,163,125,.4)}
@media(max-width:1150px){.f-wrp{grid-template-columns:repeat(2,1fr);gap:60px}}
@media(max-width:768px){.f-wrp{grid-template-columns:1fr;gap:45px;text-align:center;padding:50px 30px}.f-brd{align-items:center}.f-des{max-width:100%}.f-soc{justify-content:center}.f-tit::after{left:50%;transform:translateX(-50%)}.f-ul a{margin:0 auto;justify-content:center}.f-app{justify-content:center}.f-bin{flex-direction:column;gap:20px;text-align:center;padding:25px 30px}}
@media(max-width:480px){.f-app{flex-direction:column;width:100%}.f-abn{justify-content:center}}