/*
Theme Name: HESDA Website Theme
Theme URI: https://github.com/google/gemini
Author: Antigravity
Author URI: https://github.com/google/gemini
Description: A premium, fast, responsive WordPress theme for Hiran Education Students Development Association (HESDA).
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hesda-theme
*/

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --g900: #1B5E20; --g800: #2E7D32; --g700: #388E3C;
      --g400: #66BB6A; --lime: #7CB342; --limeL: #9CCC65;
      --sky: #0288D1; --sand: #F5F0E8; --wbg: #F8F9F2;
      --dark: #1C1C1C; --g600: #4B5563; --g400c: #9CA3AF;
      --white: #FFFFFF;
      --fh: 'Oswald', sans-serif; --fb: 'Inter', sans-serif;
      --sh: 0 2px 8px rgba(0,0,0,0.08);
      --sm: 0 8px 24px rgba(0,0,0,0.12);
      --sl: 0 16px 48px rgba(0,0,0,0.16);
      --r: 4px; --rl: 12px; --tr: 0.25s ease;
    }
    html { scroll-behavior: smooth; }
    body { font-family: var(--fb); background: var(--wbg); color: var(--dark); line-height: 1.6; overflow-x: hidden; }
    img { max-width: 100%; display: block; }
    a { text-decoration: none; color: inherit; }
    ul { list-style: none; }
    .container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
    .sp { padding: 80px 0; }
    .tc { text-align: center; }
    .tc .ssub { margin: 0 auto; }
    .ey {
      display: inline-flex; align-items: center; gap: 8px;
      font-size: 11px; letter-spacing: 3px; text-transform: uppercase;
      font-weight: 600; margin-bottom: 16px;
    }
    .ey::before { content: ''; display: block; width: 24px; height: 2px; background: currentColor; }
    .ey-g { color: var(--lime); } .ey-w { color: var(--limeL); } .ey-d { color: var(--g800); }
    .stit {
      font-family: var(--fh); font-size: clamp(28px, 4vw, 42px);
      font-weight: 700; line-height: 1.1; margin-bottom: 16px;
    }
    .stit-w { color: var(--white); } .stit-g { color: var(--g900); }
    .ssub { font-size: 16px; color: var(--g600); max-width: 600px; line-height: 1.7; }
    .ssub-w { color: rgba(255,255,255,0.75); }

    /* BUTTONS */
    .btn {
      display: inline-flex; align-items: center; gap: 8px;
      font-family: var(--fh); font-size: 13px; font-weight: 600;
      letter-spacing: 1.5px; text-transform: uppercase;
      padding: 13px 28px; border: none; cursor: pointer;
      transition: all var(--tr); border-radius: var(--r);
    }
    .bp { background: var(--lime); color: var(--white); }
    .bp:hover { background: var(--g700); transform: translateY(-2px); box-shadow: 0 8px 20px rgba(124,179,66,0.4); }
    .bo { background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,0.5); }
    .bo:hover { border-color: var(--limeL); color: var(--limeL); }
    .bod { background: transparent; color: var(--g900); border: 2px solid var(--g900); }
    .bod:hover { background: var(--g900); color: var(--white); }

    /* NAV */
    #nav {
      position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;
      background: rgba(27,94,32,0.97); backdrop-filter: blur(12px);
      border-bottom: 1px solid rgba(255,255,255,0.08); transition: all var(--tr);
    }
    #nav.sc { background: var(--g900); box-shadow: var(--sm); }
    .ni { display: flex; align-items: center; justify-content: space-between; height: 72px; padding: 0 32px; }
    .nb { display: flex; align-items: center; gap: 12px; }
    .nl-img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255,255,255,0.3); }
    .nl-fb {
      width: 48px; height: 48px; border-radius: 50%; background: var(--lime);
      display: flex; align-items: center; justify-content: center;
      font-family: var(--fh); font-weight: 700; font-size: 13px;
      color: var(--white); border: 2px solid rgba(255,255,255,0.3); flex-shrink: 0;
    }
    .nn { font-family: var(--fh); font-weight: 600; font-size: 16px; color: var(--white); line-height: 1.2; }
    .nn small { display: block; font-size: 10px; font-weight: 400; opacity: 0.65; letter-spacing: 1.5px; text-transform: uppercase; }
    .nls { display: flex; gap: 28px; align-items: center; }
    .nls > li > a { color: rgba(255,255,255,0.82); font-size: 14px; font-weight: 500; transition: color var(--tr); position: relative; padding: 4px 0; }
    .nls > li > a::after { content: ''; position: absolute; bottom: -2px; left: 0; width: 0; height: 2px; background: var(--limeL); transition: width var(--tr); }
    .nls > li > a:hover { color: var(--limeL); }
    .nls > li > a:hover::after { width: 100%; }
    .nc { background: var(--lime); color: var(--white); padding: 9px 20px; border-radius: var(--r); font-family: var(--fh); font-size: 13px; font-weight: 600; }
    .nc:hover { background: var(--limeL); }
    .nc::after { display: none !important; }
    .nt { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; background: none; border: none; }
    .nt span { display: block; width: 26px; height: 2px; background: var(--white); border-radius: 2px; transition: all var(--tr); }
    .nt.op span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
    .nt.op span:nth-child(2) { opacity: 0; }
    .nt.op span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }
    .mm {
      display: none; position: fixed; top: 72px; left: 0; width: 100%; z-index: 999;
      background: var(--g900); flex-direction: column;
      border-top: 1px solid rgba(255,255,255,0.1); max-height: 0; overflow: hidden;
      transition: max-height 0.4s ease;
    }
    .mm.op { display: flex; max-height: 100vh; }
    .mm a { display: block; padding: 16px 32px; color: rgba(255,255,255,0.85); font-size: 16px; font-weight: 500; border-bottom: 1px solid rgba(255,255,255,0.07); transition: all var(--tr); }
    .mm a:hover { color: var(--limeL); background: rgba(255,255,255,0.04); padding-left: 40px; }
    .mm .mc { margin: 16px 32px 24px; background: var(--lime); color: var(--white); text-align: center; border-radius: var(--r); padding: 14px 20px; font-family: var(--fh); font-weight: 600; letter-spacing: 1px; border-bottom: none; }
    .mm .mc:hover { background: var(--limeL); padding-left: 32px; }

    /* HERO */
    #home { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; background: var(--g900); }

    /* Hero Image Slider */
    .hslider { position: absolute; inset: 0; z-index: 0; }
    .hslide {
      position: absolute; inset: 0;
      background-size: cover; background-position: center;
      opacity: 0; transition: opacity 1.2s ease;
      transform: scale(1.05);
      animation: none;
    }
    .hslide.active { opacity: 1; animation: zoomSlow 8s ease-out forwards; }
    @keyframes zoomSlow { from { transform: scale(1.05); } to { transform: scale(1.0); } }

    /* Slider dots */
    .hdots { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); z-index: 10; display: flex; gap: 8px; }
    .hdot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.4); cursor: pointer; transition: all 0.3s; border: none; }
    .hdot.active { background: var(--lime); transform: scale(1.4); }

    /* Full overlay gradient */
    .hov {
      position: absolute; inset: 0; z-index: 2;
      background: linear-gradient(105deg, rgba(27,94,32,0.70) 0%, rgba(27,94,32,0.60) 38%, rgba(27,94,32,0.40) 58%, rgba(0,0,0,0.25) 100%);
    }
    .hdt { position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: 3; background-image: radial-gradient(circle, rgba(255,255,255,0.04) 1px, transparent 1px); background-size: 22px 22px; pointer-events: none; }

    /* Hero logo centre-right */
    .hlogo-wrap {
      position: absolute; right: 6%; top: 50%; transform: translateY(-50%);
      z-index: 5; text-align: center;
      animation: floatLogo 4s ease-in-out infinite;
    }
    @keyframes floatLogo { 0%,100% { transform: translateY(-50%) translateY(0); } 50% { transform: translateY(-50%) translateY(-14px); } }
    .hlogo-wrap img {
      width: 220px; height: 220px; border-radius: 50%;
      object-fit: cover;
      border: 5px solid rgba(255,255,255,0.25);
      box-shadow: 0 0 0 12px rgba(124,179,66,0.15), 0 24px 64px rgba(0,0,0,0.5);
      display: block;
    }
    .hlogo-wrap .hlogo-txt {
      margin-top: 14px;
      font-family: var(--fh); font-weight: 700; font-size: 15px;
      color: var(--white); letter-spacing: 3px; text-transform: uppercase;
      text-shadow: 0 2px 8px rgba(0,0,0,0.5);
    }
    .hlogo-wrap .hlogo-sub {
      font-size: 10px; color: rgba(255,255,255,0.6);
      letter-spacing: 1.5px; text-transform: uppercase; margin-top: 4px;
    }

    .hc { position: relative; z-index: 4; padding: 140px 0 80px; max-width: 580px; }
    .hes {
      display: inline-flex; align-items: center; gap: 8px;
      background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15);
      border-radius: 100px; padding: 6px 16px;
      font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase;
      color: var(--limeL); font-weight: 600; margin-bottom: 28px;
    }
    .hes::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--lime); flex-shrink: 0; animation: bl 2s ease-in-out infinite; }
    @keyframes bl { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }
    .ht { font-family: var(--fh); font-weight: 700; font-size: clamp(40px, 6.5vw, 82px); color: var(--white); line-height: 0.95; letter-spacing: -1px; margin-bottom: 10px; }
    .ht .hl { color: var(--limeL); }
    .ha { font-family: var(--fh); font-weight: 300; font-size: clamp(15px, 2vw, 22px); color: rgba(255,255,255,0.45); letter-spacing: 10px; margin-bottom: 28px; display: block; }
    .htg { font-size: clamp(14px, 1.6vw, 17px); font-weight: 400; color: rgba(255,255,255,0.78); line-height: 1.75; max-width: 500px; margin-bottom: 40px; border-left: 3px solid var(--lime); padding-left: 20px; }
    .hbs { display: flex; gap: 14px; flex-wrap: wrap; }
    .hbg { position: absolute; bottom: 40px; left: 0; z-index: 6; }
    .hbg .num { font-size: 28px; font-weight: 700; line-height: 1; }
    .hbg .lbl { font-size: 9px; font-weight: 400; letter-spacing: 1.5px; opacity: 0.85; }
    @keyframes rng { 0%,100% { box-shadow: var(--sl), 0 0 0 0 rgba(124,179,66,0.5); } 50% { box-shadow: var(--sl), 0 0 0 18px rgba(124,179,66,0); } }
    .hbar { position: absolute; bottom: 0; left: 0; right: 0; z-index: 5; height: 4px; background: linear-gradient(90deg, var(--lime), var(--limeL) 60%, transparent); }

    /* NEWS / POSTS SECTION */
    #news { background: var(--wbg); }
    .news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
    .news-card {
      background: var(--white); border-radius: var(--rl);
      overflow: hidden; box-shadow: var(--sh);
      transition: all var(--tr); position: relative;
    }
    .news-card:hover { box-shadow: var(--sl); transform: translateY(-6px); }
    .news-card-img {
      position: relative; overflow: hidden;
      height: 220px;
    }
    .news-card-img img {
      width: 100%; height: 100%; object-fit: cover;
      transition: transform 0.5s ease;
    }
    .news-card:hover .news-card-img img { transform: scale(1.07); }
    .news-card-badge {
      position: absolute; top: 14px; left: 14px;
      background: var(--lime); color: var(--white);
      font-family: var(--fh); font-size: 11px; font-weight: 600;
      letter-spacing: 1px; text-transform: uppercase;
      padding: 5px 12px; border-radius: 100px;
    }
    .news-card-date {
      position: absolute; bottom: 0; right: 0;
      background: rgba(27,94,32,0.9);
      color: var(--white); padding: 6px 14px;
      font-size: 11px; letter-spacing: 1px;
      border-top-left-radius: var(--r);
      display: flex; align-items: center; gap: 5px;
    }
    .news-card-body { padding: 24px; }
    .news-card-cat {
      font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
      color: var(--lime); font-weight: 700; margin-bottom: 8px;
      display: flex; align-items: center; gap: 6px;
    }
    .news-card-title {
      font-family: var(--fh); font-size: 18px; font-weight: 600;
      color: var(--g900); line-height: 1.25; margin-bottom: 10px;
    }
    .news-card-text {
      font-size: 13px; color: var(--g600); line-height: 1.7;
      margin-bottom: 16px;
    }
    .news-card-meta {
      display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
      padding-top: 14px; border-top: 1px solid var(--sand);
    }
    .news-meta-item {
      display: flex; align-items: center; gap: 5px;
      font-size: 11px; color: var(--g400c);
    }
    .news-meta-item i { color: var(--lime); font-size: 12px; }
    .news-card-link {
      display: inline-flex; align-items: center; gap: 6px;
      font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
      color: var(--lime); margin-left: auto;
      transition: gap var(--tr);
    }
    .news-card-link:hover { gap: 10px; }

    /* Post Gallery sub-images */
    .news-sub-imgs {
      display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px;
      padding: 0 24px 20px;
    }
    .news-sub-imgs img {
      width: 100%; aspect-ratio: 1; object-fit: cover;
      border-radius: 6px; cursor: pointer;
      transition: transform 0.3s; filter: brightness(0.9);
    }
    .news-sub-imgs img:hover { transform: scale(1.06); filter: brightness(1); }

    /* Featured post (wide) */
    .news-card--featured {
      grid-column: 1 / -1;
      display: grid; grid-template-columns: 1.4fr 1fr;
    }
    .news-card--featured .news-card-img { height: 100%; min-height: 320px; }
    .news-card--featured .news-card-right { display: flex; flex-direction: column; justify-content: space-between; }
    .news-card--featured .news-sub-imgs { padding: 0; padding-top: 16px; grid-template-columns: repeat(4,1fr); }

    @media (max-width: 900px) {
      .news-grid { grid-template-columns: 1fr; }
      .news-card--featured { grid-template-columns: 1fr; }
      .news-card--featured .news-card-img { min-height: 260px; }
      .hlogo-wrap { right: 3%; }
      .hlogo-wrap img { width: 150px; height: 150px; }
    }
    @media (max-width: 600px) {
      .hlogo-wrap { display: none; }
      .news-sub-imgs { grid-template-columns: repeat(3,1fr); }
      .news-card--featured .news-sub-imgs { grid-template-columns: repeat(3,1fr); }
    }

    /* STATS */
    .ss { background: var(--dark); }
    .ssg { display: grid; grid-template-columns: repeat(4, 1fr); }
    .si { padding: 36px 24px; text-align: center; border-right: 1px solid rgba(255,255,255,0.07); transition: background var(--tr); }
    .si:last-child { border-right: none; }
    .si:hover { background: var(--g900); }
    .sn { font-family: var(--fh); font-size: 44px; font-weight: 700; color: var(--limeL); line-height: 1; }
    .sn sup { font-size: 20px; }
    .sl2 { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-top: 6px; }

    /* ABOUT */
    #about { background: var(--wbg); }
    .ag { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
    .ais { position: relative; }
    .aim { width: 100%; border-radius: var(--rl); overflow: hidden; box-shadow: var(--sl); aspect-ratio: 4/3; object-fit: cover; }
    .aio { position: absolute; bottom: -24px; right: -24px; width: 48%; border-radius: var(--rl); overflow: hidden; box-shadow: var(--sl); border: 4px solid var(--white); aspect-ratio: 1; object-fit: cover; }
    .afd { position: absolute; top: 24px; left: -16px; background: var(--g900); padding: 16px 20px; border-radius: var(--rl); text-align: center; box-shadow: var(--sm); }
    .afd .yr { font-family: var(--fh); font-size: 32px; font-weight: 700; color: var(--limeL); line-height: 1; }
    .afd .lb { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.6); margin-top: 4px; }
    .at p { color: var(--g600); font-size: 15px; line-height: 1.8; margin-bottom: 16px; }
    .atgs { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 24px; margin-bottom: 28px; }
    .tg { background: rgba(124,179,66,0.12); border: 1px solid rgba(124,179,66,0.3); color: var(--g800); font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; padding: 6px 14px; border-radius: var(--r); }

    /* MISSION */
    #mission { background: var(--g900); }
    .mvg { display: grid; grid-template-columns: 1fr 1fr; }
    .mvc { padding: 72px 56px; position: relative; }
    .mvc--v { background: var(--g800); }
    .mvc--v::before { content: ''; position: absolute; left: 0; top: 10%; bottom: 10%; width: 1px; background: rgba(255,255,255,0.15); }
    .mvp { display: flex; gap: 16px; margin-bottom: 24px; padding: 18px; background: rgba(255,255,255,0.05); border-radius: var(--rl); border-left: 3px solid var(--lime); transition: background var(--tr); }
    .mvp:hover { background: rgba(255,255,255,0.09); }
    .mvpi { width: 38px; height: 38px; border-radius: 50%; background: rgba(124,179,66,0.2); display: flex; align-items: center; justify-content: center; font-size: 17px; flex-shrink: 0; }
    .mvpt { font-size: 14px; color: rgba(255,255,255,0.75); line-height: 1.65; }

    /* VALUES */
    #values { background: var(--sand); }
    .valg { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; }
    .vc { background: var(--white); padding: 28px 22px; border-bottom: 3px solid transparent; transition: all var(--tr); position: relative; overflow: hidden; }
    .vc::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--lime); transform: scaleX(0); transition: transform var(--tr); }
    .vc:hover { border-color: var(--lime); transform: translateY(-5px); box-shadow: var(--sm); }
    .vc:hover::before { transform: scaleX(1); }
    .vn { font-family: var(--fh); font-size: 40px; font-weight: 700; color: rgba(124,179,66,0.15); line-height: 1; margin-bottom: 6px; }
    .vi { font-size: 26px; margin-bottom: 12px; }
    .vt { font-family: var(--fh); font-size: 14px; font-weight: 600; color: var(--g900); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; }
    .vd { font-size: 12px; color: var(--g600); line-height: 1.6; }

    /* PROGRAMS */
    #programs { background: var(--wbg); }
    .pgg { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
    .pgc { background: var(--white); border-radius: var(--rl); overflow: hidden; box-shadow: var(--sh); transition: all var(--tr); }
    .pgc:hover { box-shadow: var(--sl); transform: translateY(-6px); }
    .pgct { height: 8px; }
    .pgcb { padding: 28px 24px; }
    .pgi { width: 52px; height: 52px; border-radius: var(--rl); display: flex; align-items: center; justify-content: center; font-size: 24px; margin-bottom: 16px; }
    .pgt { font-family: var(--fh); font-size: 17px; font-weight: 600; color: var(--g900); margin-bottom: 10px; }
    .pgd { font-size: 13px; color: var(--g600); line-height: 1.7; }
    .pgcf { padding: 14px 24px; border-top: 1px solid var(--sand); }
    .pgl { font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--lime); display: flex; align-items: center; gap: 6px; transition: gap var(--tr); }
    .pgl:hover { gap: 10px; }

    /* PROJECTS */
    #projects { background: var(--dark); }
    .prw { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
    .prt { font-family: var(--fh); font-size: 20px; font-weight: 600; color: var(--white); margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
    .prt .bdg { background: var(--lime); color: var(--white); font-size: 10px; padding: 3px 10px; border-radius: 100px; letter-spacing: 1px; font-weight: 500; }
    .pri { display: flex; gap: 16px; padding: 18px; background: rgba(255,255,255,0.05); border-radius: var(--rl); margin-bottom: 12px; border: 1px solid rgba(255,255,255,0.08); transition: all var(--tr); }
    .pri:hover { background: rgba(255,255,255,0.09); border-color: rgba(124,179,66,0.3); }
    .prd { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
    .prd-d { background: var(--g400); }
    .prd-o { background: var(--sky); animation: bl 2s infinite; }
    .prtxt { font-size: 14px; color: rgba(255,255,255,0.75); line-height: 1.5; }

    /* MODALITIES */
    #modalities { background: var(--g800); }
    .mods { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
    .modc { background: rgba(255,255,255,0.06); border-radius: var(--rl); padding: 28px 20px; text-align: center; border: 1px solid rgba(255,255,255,0.1); transition: all var(--tr); }
    .modc:hover { background: rgba(255,255,255,0.12); transform: translateY(-4px); }
    .modn { width: 40px; height: 40px; border-radius: 50%; background: var(--lime); color: var(--white); font-family: var(--fh); font-size: 18px; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; }
    .modt { font-family: var(--fh); font-size: 13px; font-weight: 600; color: var(--white); text-transform: uppercase; letter-spacing: 0.5px; line-height: 1.3; }

    /* GALLERY */
    #gallery { background: var(--sand); padding: 56px 0; }
    .galg { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: auto auto; gap: 8px; }
    .gali { overflow: hidden; border-radius: var(--rl); position: relative; cursor: pointer; }
    .gali img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
    .gali:hover img { transform: scale(1.05); }
    .gali:first-child { grid-row: 1 / 3; height: 420px; }
    .gali:not(:first-child) { height: 204px; }
    .galo { position: absolute; inset: 0; background: rgba(27,94,32,0); display: flex; align-items: center; justify-content: center; transition: background 0.3s; }
    .galo i { color: var(--white); font-size: 24px; opacity: 0; transition: opacity 0.3s; }
    .gali:hover .galo { background: rgba(27,94,32,0.4); }
    .gali:hover .galo i { opacity: 1; }

    /* GEO */
    #geography { background: var(--wbg); }
    .geog { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
    .geor { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 24px; }
    .georc { padding: 18px 16px; background: var(--white); border-radius: var(--rl); border-left: 3px solid var(--lime); box-shadow: var(--sh); display: flex; align-items: center; gap: 10px; transition: all var(--tr); }
    .georc:hover { transform: translateX(4px); box-shadow: var(--sm); }
    .georc i { color: var(--lime); font-size: 16px; flex-shrink: 0; }
    .georn { font-family: var(--fh); font-size: 14px; font-weight: 600; color: var(--g900); text-transform: uppercase; letter-spacing: 0.5px; }
    .geov { background: var(--g900); border-radius: var(--rl); padding: 48px 32px; text-align: center; color: var(--white); }
    .geov .bi { font-size: 80px; margin-bottom: 24px; }
    .geov h3 { font-family: var(--fh); font-size: 22px; font-weight: 600; margin-bottom: 12px; }
    .geov p { font-size: 14px; color: rgba(255,255,255,0.65); line-height: 1.7; }
    .geobs { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-top: 20px; }
    .geob { background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2); color: var(--white); font-size: 11px; letter-spacing: 1px; padding: 6px 14px; border-radius: 100px; font-family: var(--fh); }

    /* BOARD */
    #board { background: var(--g900); }
    .bog { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
    .boc { background: rgba(255,255,255,0.06); border-radius: var(--rl); padding: 28px 16px; text-align: center; border: 1px solid rgba(255,255,255,0.1); transition: all var(--tr); }
    .boc:hover { background: rgba(255,255,255,0.12); transform: translateY(-5px); border-color: rgba(124,179,66,0.4); }
    .boa { width: 72px; height: 72px; border-radius: 50%; background: rgba(124,179,66,0.2); border: 3px solid var(--lime); display: flex; align-items: center; justify-content: center; font-family: var(--fh); font-size: 22px; font-weight: 700; color: var(--limeL); margin: 0 auto 14px; }
    .bon { font-family: var(--fh); font-size: 14px; font-weight: 600; color: var(--white); margin-bottom: 6px; line-height: 1.3; }
    .bor { font-size: 11px; letter-spacing: 1px; text-transform: uppercase; color: var(--limeL); font-weight: 500; }

    /* ORG CHART */
    #orgchart { background: var(--sand); }
    .cw { background: var(--white); border-radius: var(--rl); padding: 40px; box-shadow: var(--sm); overflow-x: auto; }
    .cl { display: flex; justify-content: center; gap: 16px; }
    .cc { width: 2px; height: 32px; background: rgba(124,179,66,0.4); margin: 0 auto; }
    .cn { background: var(--g900); color: var(--white); border-radius: var(--rl); padding: 12px 20px; font-family: var(--fh); font-size: 13px; font-weight: 600; text-align: center; white-space: nowrap; border: 2px solid transparent; transition: all var(--tr); min-width: 140px; }
    .cn:hover { border-color: var(--lime); transform: scale(1.03); }
    .cn-t { background: var(--lime); font-size: 15px; padding: 14px 28px; }
    .cn-m { background: var(--g800); }
    .cn-d { background: var(--g700); font-size: 11px; padding: 10px 14px; min-width: 110px; }
    .cn-s { background: rgba(27,94,32,0.1); color: var(--g900); border: 1px solid rgba(124,179,66,0.4); font-size: 11px; padding: 8px 12px; min-width: 90px; }

    /* FUTURE */
    #future { background: var(--wbg); }
    .fug { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
    .fuc { background: var(--white); border-radius: var(--rl); padding: 28px 20px; text-align: center; box-shadow: var(--sh); border-top: 3px solid var(--lime); transition: all var(--tr); }
    .fuc:hover { box-shadow: var(--sm); transform: translateY(-5px); }
    .fui { font-size: 32px; margin-bottom: 14px; }
    .fut { font-family: var(--fh); font-size: 14px; font-weight: 600; color: var(--g900); text-transform: uppercase; letter-spacing: 0.5px; }

    /* IMPACT */
    #impact { background: var(--dark); }
    .impg { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
    .impt p { color: rgba(255,255,255,0.7); font-size: 14px; line-height: 1.8; margin-bottom: 16px; }
    .imps { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
    .impst { background: rgba(255,255,255,0.06); border-radius: var(--rl); padding: 24px; border-left: 3px solid var(--lime); }
    .impst .num { font-family: var(--fh); font-size: 36px; font-weight: 700; color: var(--limeL); line-height: 1; }
    .impst .desc { font-size: 12px; color: rgba(255,255,255,0.55); margin-top: 6px; }

    /* CTA */
    #cta { background: linear-gradient(135deg, var(--g900) 0%, var(--g700) 100%); padding: 80px 0; text-align: center; position: relative; overflow: hidden; }
    #cta::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(255,255,255,0.04) 1px, transparent 1px); background-size: 24px 24px; }
    #cta .container { position: relative; z-index: 1; }
    #cta h2 { font-family: var(--fh); font-size: clamp(28px, 4vw, 44px); font-weight: 700; color: var(--white); margin-bottom: 16px; }
    #cta h2 em { color: var(--limeL); font-style: normal; }
    #cta p { color: rgba(255,255,255,0.7); font-size: 16px; margin-bottom: 36px; }
    #cta .cbs { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

    /* CONTACT */
    #contact { background: var(--wbg); }
    .cog { display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px; align-items: start; }
    .coi { display: flex; gap: 16px; margin-bottom: 24px; padding: 18px; background: var(--white); border-radius: var(--rl); box-shadow: var(--sh); align-items: flex-start; }
    .coic { width: 44px; height: 44px; border-radius: var(--rl); background: rgba(124,179,66,0.12); color: var(--lime); display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
    .coil { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--g400c); font-weight: 600; margin-bottom: 4px; }
    .coiv { font-size: 14px; color: var(--dark); font-weight: 500; line-height: 1.5; }
    .coiv a { color: var(--g800); }
    .coiv a:hover { color: var(--lime); }
    .cf { background: var(--white); border-radius: var(--rl); padding: 40px; box-shadow: var(--sm); }
    .cft { font-family: var(--fh); font-size: 22px; font-weight: 600; color: var(--g900); margin-bottom: 8px; }
    .cfs { font-size: 14px; color: var(--g600); margin-bottom: 28px; }
    .fr { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
    .fg { margin-bottom: 16px; }
    .fg label { display: block; font-size: 12px; font-weight: 600; letter-spacing: 0.5px; color: var(--g600); margin-bottom: 6px; text-transform: uppercase; }
    .fg input, .fg select, .fg textarea { width: 100%; padding: 12px 16px; border: 2px solid var(--sand); border-radius: var(--r); font-family: var(--fb); font-size: 14px; color: var(--dark); background: var(--wbg); transition: border-color var(--tr); outline: none; resize: vertical; }
    .fg input:focus, .fg select:focus, .fg textarea:focus { border-color: var(--lime); background: var(--white); }
    .fg textarea { min-height: 120px; }
    .csub { width: 100%; padding: 15px; background: var(--lime); color: var(--white); border: none; border-radius: var(--r); font-family: var(--fh); font-size: 14px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer; transition: all var(--tr); display: flex; align-items: center; justify-content: center; gap: 8px; }
    .csub:hover { background: var(--g700); transform: translateY(-2px); }

    /* FOOTER */
    footer { background: var(--g900); padding: 56px 0 28px; }
    .fg2 { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
    .fbli { width: 60px; height: 60px; border-radius: 50%; object-fit: cover; margin-bottom: 16px; border: 2px solid rgba(255,255,255,0.2); }
    .fbn { font-family: var(--fh); font-size: 18px; font-weight: 600; color: var(--white); margin-bottom: 4px; }
    .fbs { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.4); margin-bottom: 14px; }
    .fbd { font-size: 13px; color: rgba(255,255,255,0.5); line-height: 1.7; max-width: 280px; }
    .fso { display: flex; gap: 10px; margin-top: 16px; }
    .fsob { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); color: rgba(255,255,255,0.6); font-size: 14px; display: flex; align-items: center; justify-content: center; transition: all var(--tr); }
    .fsob:hover { background: var(--lime); color: var(--white); border-color: var(--lime); }
    .fct { font-family: var(--fh); font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--limeL); margin-bottom: 18px; }
    .fls { display: flex; flex-direction: column; gap: 8px; }
    .fls a { font-size: 13px; color: rgba(255,255,255,0.55); transition: color var(--tr); }
    .fls a:hover { color: var(--limeL); }
    .fdiv { border: none; border-top: 1px solid rgba(255,255,255,0.08); margin-bottom: 24px; }
    .fbot { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
    .fcp { font-size: 12px; color: rgba(255,255,255,0.35); }
    .fet { font-size: 11px; color: rgba(255,255,255,0.25); letter-spacing: 1px; }

    /* SCROLL TOP */
    #st { position: fixed; bottom: 28px; right: 28px; z-index: 500; width: 44px; height: 44px; border-radius: 50%; background: var(--lime); color: var(--white); border: none; font-size: 18px; cursor: pointer; box-shadow: var(--sm); display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: all var(--tr); }
    #st.sh { opacity: 1; pointer-events: auto; }
    #st:hover { background: var(--g700); transform: translateY(-3px); }

    /* ANIMATIONS */
    .fu { opacity: 0; transform: translateY(28px); transition: opacity 0.6s ease, transform 0.6s ease; }
    .fu.vis { opacity: 1; transform: translateY(0); }
    .d1 { transition-delay: 0.1s; } .d2 { transition-delay: 0.2s; }
    .d3 { transition-delay: 0.3s; } .d4 { transition-delay: 0.4s; }

    /* RESPONSIVE */
    @media (max-width: 1100px) {
      .bog { grid-template-columns: repeat(3, 1fr); }
      .fug { grid-template-columns: repeat(3, 1fr); }
      .fg2 { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 900px) {
      .nls { display: none; }
      .nt { display: flex; }
      .hpw { width: 100%; opacity: 0.3; }
      .hov { background: linear-gradient(105deg, rgba(27,94,32,0.70) 0%, rgba(27,94,32,0.55) 100%); }
      .hdt { width: 100%; }
      .hbg { display: none; }
      .ssg { grid-template-columns: repeat(2, 1fr); }
      .ag { grid-template-columns: 1fr; }
      .aio { width: 36%; }
      .mvg { grid-template-columns: 1fr; }
      .mvc--v::before { display: none; }
      .valg { grid-template-columns: repeat(3, 1fr); }
      .pgg { grid-template-columns: repeat(2, 1fr); }
      .prw { grid-template-columns: 1fr; gap: 32px; }
      .mods { grid-template-columns: repeat(2, 1fr); }
      .galg { grid-template-columns: 1fr 1fr; }
      .gali:first-child { grid-row: auto; height: 260px; }
      .gali:not(:first-child) { height: 200px; }
      .geog { grid-template-columns: 1fr; }
      .bog { grid-template-columns: repeat(3, 1fr); }
      .cog { grid-template-columns: 1fr; }
      .impg { grid-template-columns: 1fr; }
      .fug { grid-template-columns: repeat(3, 1fr); }
      .fg2 { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 600px) {
      .sp { padding: 56px 0; }
      .ni { padding: 0 20px; }
      .hc { padding: 120px 0 72px; }
      .ssg { grid-template-columns: 1fr 1fr; }
      .aio { display: none; }
      .valg { grid-template-columns: repeat(2, 1fr); }
      .pgg { grid-template-columns: 1fr; }
      .mods { grid-template-columns: repeat(2, 1fr); }
      .galg { grid-template-columns: 1fr; }
      .gali { height: 240px !important; }
      .gali:first-child { height: 280px !important; }
      .bog { grid-template-columns: repeat(2, 1fr); }
      .geor { grid-template-columns: 1fr; }
      .fug { grid-template-columns: repeat(2, 1fr); }
      .fr { grid-template-columns: 1fr; }
      .fg2 { grid-template-columns: 1fr; }
      .fbot { flex-direction: column; text-align: center; }
      .imps { grid-template-columns: repeat(2,1fr); }
      .mvc { padding: 48px 24px; }
      .cn { min-width: 90px; font-size: 11px; padding: 8px 10px; }
    }

    /* PARTNERS */
    #partners { background: var(--white); padding: 70px 0; border-top: 1px solid var(--sand); border-bottom: 1px solid var(--sand); }
    .partg { display: flex; justify-content: center; align-items: center; gap: 96px; flex-wrap: wrap; margin-top: 36px; }
    .partl { max-width: 312px; height: 120px; display: flex; align-items: center; justify-content: center; opacity: 0.9; transition: all var(--tr); }
    .partl:hover { opacity: 1; transform: scale(1.06); }
    .partl img { max-height: 100%; max-width: 100%; object-fit: contain; }
    .partl svg { max-height: 100%; max-width: 100%; }
  