/* ============================================================
   Bihar Bowling Association — Design System
   Palette derived from the BBA emblem: green + gold + deep red
   ============================================================ */
:root{
    --green:#0a7d3c;
    --green-dark:#06502a;
    --green-darker:#04331b;
    --gold:#f5a623;
    --gold-deep:#e0901a;
    --red:#9e1b1b;
    --ink:#16241d;
    --muted:#5d6f64;
    --line:#e6ece7;
    --bg:#ffffff;
    --bg-alt:#f4f8f4;
    --radius:14px;
    --shadow:0 16px 40px rgba(6,80,42,.10);
    --shadow-sm:0 6px 18px rgba(6,80,42,.08);
    --maxw:1160px;
    --font:"Segoe UI","Nirmala UI",system-ui,-apple-system,Roboto,"Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.65;font-size:16px}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4{line-height:1.18;letter-spacing:-.4px;font-weight:800}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* Buttons */
.btn{display:inline-block;padding:13px 26px;border-radius:10px;font-weight:700;font-size:15px;
    border:2px solid transparent;cursor:pointer;transition:.2s;line-height:1}
.btn--gold{background:var(--gold);color:#3a2700}
.btn--gold:hover{background:var(--gold-deep);transform:translateY(-2px);box-shadow:0 12px 24px rgba(245,166,35,.35)}
.btn--outline{border-color:var(--green);color:var(--green);background:transparent}
.btn--outline:hover{background:var(--green);color:#fff}

/* Top bar */
.topbar{background:var(--green-darker);color:#cfe8d8;font-size:13px}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:10px;flex-wrap:wrap}
.langswitch{display:flex;align-items:center;gap:6px}
.langswitch__label{opacity:.85}
.langswitch__item{padding:3px 11px;border-radius:20px;border:1px solid rgba(255,255,255,.22);font-size:12px;transition:.2s}
.langswitch__item:hover{background:rgba(255,255,255,.12)}
.langswitch__item.is-active{background:var(--gold);color:#3a2700;border-color:var(--gold);font-weight:700}

/* Header */
.header{background:#fff;position:sticky;top:0;z-index:50;box-shadow:0 1px 0 rgba(0,0,0,.06);transition:box-shadow .2s}
.header.is-stuck{box-shadow:0 6px 20px rgba(0,0,0,.08)}
.header__inner{display:flex;align-items:center;gap:16px;min-height:76px}
.brand{display:flex;align-items:center;gap:12px}
.brand__logo{width:52px;height:52px;border-radius:50%}
.brand__text strong{display:block;font-size:16.5px;color:var(--green-dark);line-height:1.1}
.brand__text small{color:var(--muted);font-size:11.5px}
.nav{margin-left:auto;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.nav a{padding:10px 14px;border-radius:9px;font-weight:600;font-size:14.5px;color:#22332b;transition:.18s}
.nav a:hover{background:var(--bg-alt);color:var(--green)}
.nav a.active{color:var(--green)}
.nav .nav__cta{background:var(--green);color:#fff;margin-left:6px}
.nav .nav__cta:hover{background:var(--green-dark);color:#fff}
.navtoggle{display:none;margin-left:auto;background:none;border:0;width:42px;height:42px;cursor:pointer}
.navtoggle span{display:block;height:3px;background:var(--green-dark);border-radius:3px;margin:5px 6px;transition:.25s}

/* Hero */
.hero{position:relative;background:var(--green-dark)}
.hero__slides{position:relative}
.hero__slide{display:none;position:relative;overflow:hidden;min-height:clamp(540px,78vh,760px);align-items:center;color:#fff}
.hero__slide.is-active{display:flex;animation:fade .8s ease}
.hero__slide--fallback{background:radial-gradient(1200px 500px at 80% -10%,rgba(245,166,35,.4),transparent 60%),linear-gradient(135deg,var(--green),var(--green-darker))}
.hero__content{padding:40px 22px;position:relative;z-index:2}
.hero__pill{display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);
    padding:6px 16px;border-radius:30px;font-size:13px;margin-bottom:18px;backdrop-filter:blur(4px)}
.hero h1{font-size:clamp(30px,5vw,54px);max-width:16ch}
.hero p{margin-top:16px;font-size:clamp(16px,2vw,20px);max-width:54ch;color:#eafff1}
.hero .btn{margin-top:28px}
.hero__dots{position:absolute;bottom:20px;left:0;right:0;display:flex;justify-content:center;gap:10px;z-index:3}
.hero__dot{width:11px;height:11px;border-radius:50%;border:2px solid #fff;background:transparent;cursor:pointer;padding:0}
.hero__dot.is-active{background:var(--gold);border-color:var(--gold)}
@keyframes fade{from{opacity:.3}to{opacity:1}}

/* Stats */
.stats{background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:28px;margin-top:-44px;position:relative;z-index:5;
    display:grid;grid-template-columns:repeat(4,1fr)}
.stat{text-align:center;padding:8px 6px}
.stat+.stat{border-left:1px solid var(--line)}
.stat b{display:block;font-size:34px;font-weight:800;color:var(--green);line-height:1}
.stat span{display:block;margin-top:6px;color:var(--muted);font-size:14px}

/* Sections */
.section{padding:74px 0}
.section--alt{background:var(--bg-alt)}
.eyebrow{display:inline-block;color:var(--gold-deep);font-weight:800;text-transform:uppercase;letter-spacing:1.6px;font-size:12.5px;margin-bottom:6px}
h2{font-size:clamp(24px,3.4vw,36px)}
.sectionhead{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:34px;flex-wrap:wrap}
.link-arrow{color:var(--green);font-weight:700;font-size:14.5px;white-space:nowrap}
.link-arrow:hover{color:var(--gold-deep)}

/* About */
.about__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.about__text p{color:var(--muted);font-size:17px;margin:14px 0 24px}
.about__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:4/3;object-fit:cover}
.about__media--empty{aspect-ratio:4/3;border-radius:var(--radius);
    background:linear-gradient(135deg,var(--green),var(--green-darker))}
.about__media--empty img{display:none}

/* Cards */
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.22s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#d3e4d7}
.card__media{display:block;position:relative;aspect-ratio:16/10;background:var(--bg-alt)}
.card__media img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.card__media--empty{background:linear-gradient(135deg,var(--green),var(--green-darker))}
.card__media--empty img{display:none}
.card__body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card__date{color:var(--gold-deep);font-size:13px;font-weight:700}
.card h3{font-size:18px}
.card h3 a:hover{color:var(--green)}
.card__body p{color:var(--muted);font-size:14.5px}
.card__meta{color:var(--muted);font-size:14px}
.card .link-arrow{margin-top:auto}
.badge{position:absolute;top:12px;left:12px;background:var(--gold);color:#3a2700;font-size:11.5px;font-weight:800;
    padding:5px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.badge--ongoing{background:#1f9d57;color:#fff}
.badge--completed{background:#6b7d72;color:#fff}

/* Gallery */
.gallerygrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallerygrid--full{grid-template-columns:repeat(4,1fr)}
.gallerygrid__item{display:block;border-radius:12px;overflow:hidden;aspect-ratio:1;background:var(--bg-alt)}
.gallerygrid__item img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.gallerygrid__item--empty{background:linear-gradient(135deg,var(--green),var(--green-darker))}
.gallerygrid__item--empty img{display:none}
.gallerygrid__item figcaption{display:none}

/* Page hero / prose */
.pagehero{background:radial-gradient(900px 400px at 85% -20%,rgba(245,166,35,.25),transparent 60%),linear-gradient(135deg,var(--green),var(--green-darker));
    color:#fff;padding:60px 0}
.pagehero h1{font-size:clamp(28px,4vw,44px)}
.pagehero .eyebrow{color:#ffe2ad}
.prose{max-width:780px;font-size:17px;color:#26342c}
.prose__hero{display:block;max-width:100%;width:auto;max-height:520px;margin:0 auto 26px;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--bg-alt)}
.prose p{margin-bottom:1.1em}
.prose h2,.prose h3{margin:1.4em 0 .5em}
.eventmeta{display:flex;gap:30px;flex-wrap:wrap;background:var(--bg-alt);border-radius:12px;padding:18px 22px;margin-bottom:24px}

/* Contact */
.contact__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px}
.contact__info h3{color:var(--green-dark);margin-bottom:14px}
.contact__info p{color:var(--muted);margin-bottom:10px}
.contact__form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.field input,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font:inherit;background-color:#fcfdfc;transition:.15s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green);background-color:#fff;box-shadow:0 0 0 3px rgba(10,125,60,.12)}
.field .err{color:var(--red);font-size:13px}
.alert{padding:13px 16px;border-radius:9px;margin-bottom:18px;font-size:14.5px}
.alert--success{background:#e6f6ec;color:#13683a;border:1px solid #b9e2c8}
.alert--error{background:#fbeaea;color:#9e1b1b;border:1px solid #f1c6c6}

/* Pagination */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:40px}
.pagination a{min-width:40px;text-align:center;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-weight:700;color:var(--green-dark)}
.pagination a:hover{background:var(--bg-alt)}
.pagination a.is-active{background:var(--green);color:#fff;border-color:var(--green)}

/* CTA */
.cta{background:linear-gradient(135deg,var(--gold),var(--gold-deep))}
.cta__inner{text-align:center;padding:60px 22px}
.cta h2{color:#3a2700;max-width:24ch;margin:0 auto 24px}

/* Footer */
.footer{background:var(--green-darker);color:#a9c9b6;font-size:14.5px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:40px;padding:56px 22px}
.brand--footer{margin-bottom:14px}
.brand--footer strong{color:#fff;font-size:17px}
.footer__about{line-height:1.7}
.footer__col h4{color:#fff;margin-bottom:14px;font-size:15px}
.footer__col ul{list-style:none}
.footer__col li{margin-bottom:8px}
.footer__col a:hover{color:var(--gold)}
.footer__contact{line-height:1.9}
.social{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.social a{padding:6px 13px;border:1px solid rgba(255,255,255,.2);border-radius:20px;font-size:13px}
.social a:hover{background:var(--gold);color:#3a2700;border-color:var(--gold)}
.footer__bar{border-top:1px solid rgba(255,255,255,.1);padding:18px 0;text-align:center;font-size:13px;color:#86a896}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}

/* Error pages */
.errorbody{min-height:100vh;display:flex;align-items:center;justify-content:center;
    background:radial-gradient(900px 500px at 50% -10%,rgba(245,166,35,.18),transparent 60%),linear-gradient(135deg,var(--green-dark),var(--green-darker))}
.errorbox{text-align:center;color:#fff;padding:40px}
.errorbox__logo{width:84px;height:84px;border-radius:50%;margin:0 auto 18px}
.errorbox__code{font-size:90px;font-weight:800;color:var(--gold);line-height:1}
.errorbox h1{margin:6px 0 10px}
.errorbox p{color:#d6eadf;margin-bottom:24px}
.empty{color:var(--muted);text-align:center;padding:40px}

/* Responsive */
@media(max-width:960px){
    .about__grid,.contact__grid{grid-template-columns:1fr;gap:30px}
    .cardgrid{grid-template-columns:repeat(2,1fr)}
    .gallerygrid--full{grid-template-columns:repeat(3,1fr)}
    .footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
    .navtoggle{display:block}
    .nav{position:fixed;inset:0 0 0 auto;width:min(80%,320px);background:#fff;flex-direction:column;align-items:stretch;
        padding:90px 20px 30px;transform:translateX(100%);transition:transform .3s;box-shadow:-10px 0 40px rgba(0,0,0,.15);gap:4px}
    .nav.is-open{transform:none}
    .nav a{padding:14px 16px;border-radius:10px}
    .nav .nav__cta{margin-left:0;text-align:center}
    .navtoggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
    .navtoggle.is-open span:nth-child(2){opacity:0}
    .navtoggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
    .stats{grid-template-columns:repeat(2,1fr);gap:10px}
    .stat:nth-child(3){border-left:0}
    .stat+.stat{border-top:1px solid var(--line)}
    .cardgrid{grid-template-columns:1fr}
    .field-row{grid-template-columns:1fr}
    .footer__grid{grid-template-columns:1fr}
}
@media(max-width:480px){
    .gallerygrid,.gallerygrid--full{grid-template-columns:repeat(2,1fr)}
    .stats{grid-template-columns:1fr}
    .stat+.stat{border-left:0}
}

/* ============================================================
   Notice ticker
   ============================================================ */
.ticker{background:var(--gold);color:#3a2700;overflow:hidden;border-bottom:1px solid rgba(0,0,0,.08)}
.ticker__inner{display:flex;align-items:center;gap:14px;height:44px}
.ticker__label{background:var(--green-dark);color:#fff;font-weight:800;font-size:12px;padding:6px 14px;border-radius:6px;
    white-space:nowrap;text-transform:uppercase;letter-spacing:.6px;flex:none}
.ticker__viewport{overflow:hidden;flex:1;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.ticker__track{display:inline-flex;align-items:center;white-space:nowrap;animation:tickerScroll 34s linear infinite;will-change:transform}
.ticker:hover .ticker__track{animation-play-state:paused}
.ticker__item{font-weight:600;font-size:14px;color:#3a2700}
a.ticker__item:hover{text-decoration:underline}
.ticker__sep{opacity:.45;padding:0 16px}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   Bowling preloader
   ============================================================ */
#preloader{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
    background:radial-gradient(800px 400px at 50% 30%,rgba(245,166,35,.18),transparent 60%),linear-gradient(135deg,var(--green-dark),var(--green-darker));
    transition:opacity .6s ease,visibility .6s ease}
#preloader.is-hidden{opacity:0;visibility:hidden}
.loader{text-align:center}
.loader__logo{width:74px;height:74px;border-radius:50%;margin:0 auto 22px;animation:loaderPulse 1.6s ease-in-out infinite}
.loader__lane{position:relative;width:230px;height:44px;margin:0 auto}
.loader__green{position:absolute;left:0;right:0;bottom:12px;height:5px;border-radius:5px;
    background:linear-gradient(90deg,rgba(255,255,255,.05),rgba(255,255,255,.25),rgba(255,255,255,.05))}
.loader__bowl{position:absolute;bottom:9px;left:0;width:24px;height:24px;border-radius:50%;
    background:#16181d;border:2px solid var(--gold);box-shadow:inset -3px -3px 0 rgba(255,255,255,.08);
    animation:loaderRoll 1.8s cubic-bezier(.45,.05,.4,1) infinite}
.loader__jack{position:absolute;bottom:14px;right:8px;width:11px;height:11px;border-radius:50%;background:#fff;
    animation:loaderJack 1.8s ease-in-out infinite}
.loader__text{color:#cfe8d8;margin-top:20px;font-weight:700;letter-spacing:3px;font-size:12px;text-transform:uppercase}
@keyframes loaderRoll{0%{left:0;transform:rotate(0)}80%{left:188px;transform:rotate(900deg)}100%{left:188px;transform:rotate(900deg)}}
@keyframes loaderJack{0%,75%{transform:translateX(0)}85%{transform:translateX(6px)}100%{transform:translateX(6px)}}
@keyframes loaderPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.09)}}

/* ============================================================
   Hero background (fills cleanly, gentle Ken Burns via transform)
   ============================================================ */
.hero__bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 22%}
.hero__overlay{position:absolute;inset:0;z-index:1;
    background:linear-gradient(120deg,rgba(6,80,42,.84) 0%,rgba(6,80,42,.5) 45%,rgba(4,51,27,.22) 100%)}
.hero__slide.is-active{animation:fade .8s ease}

/* ============================================================
   Animated image scroller (marquee)
   ============================================================ */
.scroller{overflow:hidden;padding:26px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.scroller__track{display:flex;gap:20px;width:max-content;animation:scrollX 45s linear infinite;will-change:transform}
.scroller:hover .scroller__track{animation-play-state:paused}
.scroller__item{position:relative;width:clamp(220px,28vw,320px);height:225px;border-radius:18px;overflow:hidden;flex:none;
    border:0;padding:0;margin:0;cursor:pointer;background:var(--bg-alt);box-shadow:var(--shadow-sm);
    transition:transform .45s cubic-bezier(.2,.8,.3,1),box-shadow .45s ease}
.scroller__item img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block}
.scroller__item::before{content:"";position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg,transparent 45%,rgba(4,51,27,.82));opacity:.12;transition:opacity .35s}
.scroller__item:hover{transform:translateY(-12px);box-shadow:0 26px 48px rgba(6,80,42,.32),0 0 0 3px var(--gold);z-index:3}
.scroller__item:hover::before{opacity:1}
.scroller__cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px 16px;color:#fff;font-weight:700;font-size:14px;text-align:left;
    transform:translateY(115%);transition:transform .4s cubic-bezier(.2,.8,.3,1)}
.scroller__item:hover .scroller__cap{transform:none}
.scroller__cap::before{content:"";display:inline-block;width:18px;height:2px;background:var(--gold);vertical-align:middle;margin-right:8px}
.scroller__shine{position:absolute;top:0;left:-60%;width:55%;height:100%;z-index:2;pointer-events:none;transform:skewX(-18deg);
    background:linear-gradient(100deg,transparent,rgba(255,255,255,.38),transparent)}
.scroller__item:hover .scroller__shine{animation:shine .9s ease}
@keyframes shine{from{left:-60%}to{left:135%}}
@keyframes scrollX{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 10px))}}

@media (prefers-reduced-motion: reduce){
    .ticker__track,.scroller__track{animation:none}
    .hero__slide.is-active{animation:fade .8s ease}
    .hero__slide.is-active .hero__bg{animation:none}
    .loader__bowl,.loader__jack,.loader__logo{animation:none}
}

/* ============================================================
   Stunning gallery mosaic
   ============================================================ */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:165px;gap:14px;grid-auto-flow:dense}
.mosaic__item{position:relative;border:0;padding:0;margin:0;cursor:pointer;border-radius:16px;overflow:hidden;background:var(--bg-alt);box-shadow:var(--shadow-sm)}
.mosaic__item:nth-child(1){grid-column:span 2;grid-row:span 2}
.mosaic__item:nth-child(4){grid-row:span 2}
.mosaic__item{transition:transform .4s cubic-bezier(.2,.8,.3,1),box-shadow .4s ease}
.mosaic__item img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block}
.mosaic__item:hover{transform:translateY(-5px);box-shadow:var(--shadow);z-index:2}
.mosaic__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:14px;
    background:linear-gradient(180deg,rgba(6,80,42,0) 35%,rgba(4,51,27,.82));opacity:0;transition:opacity .35s}
.mosaic__item:hover .mosaic__overlay{opacity:1}
.mosaic__plus{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:var(--gold);color:#3a2700;
    font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;transform:scale(.5);transition:transform .35s}
.mosaic__item:hover .mosaic__plus{transform:scale(1)}
.mosaic__cap{color:#fff;font-weight:700;font-size:14px;transform:translateY(10px);transition:transform .35s}
.mosaic__item:hover .mosaic__cap{transform:none}
@media(max-width:760px){
    .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
    .mosaic__item:nth-child(1){grid-column:span 2;grid-row:span 1}
    .mosaic__item:nth-child(4){grid-row:span 1}
}

/* ============================================================
   Lightbox
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:9998;display:none;align-items:center;justify-content:center;padding:30px;
    background:rgba(4,20,12,.92);backdrop-filter:blur(4px)}
.lightbox.is-open{display:flex;animation:fade .3s ease}
.lightbox__figure{margin:0;text-align:center}
.lightbox__figure img{max-width:90vw;max-height:80vh;border-radius:12px;box-shadow:0 24px 70px rgba(0,0,0,.55);animation:lbpop .35s cubic-bezier(.2,.8,.3,1)}
.lightbox__figure figcaption{color:#cfe8d8;margin-top:12px;font-weight:600}
.lightbox__close{position:absolute;top:20px;right:26px;width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;
    background:rgba(255,255,255,.14);color:#fff;font-size:28px;line-height:1;transition:.2s}
.lightbox__close:hover{background:var(--gold);color:#3a2700}
@keyframes lbpop{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:none}}

/* ============================================================
   Members / Office bearers
   ============================================================ */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.member{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 18px;text-align:center;transition:transform .25s,box-shadow .25s,border-color .25s}
.member:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#d3e4d7}
.member__photo{width:124px;height:124px;margin:0 auto 16px;border-radius:50%;overflow:hidden;border:4px solid #eef5ef;box-shadow:var(--shadow-sm)}
.team--featured .member__photo{width:142px;height:142px;border-color:var(--gold)}
.member__photo img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.member__name{font-size:17px;color:var(--green-dark);line-height:1.2}
.member__role{color:var(--gold-deep);font-weight:700;font-size:14px;margin-top:5px}
.member__bio{color:var(--muted);font-size:13.5px;margin-top:8px}
.member__contact{display:flex;gap:10px;justify-content:center;margin-top:14px}
.member__contact a{width:38px;height:38px;border-radius:50%;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;transition:.2s;font-size:15px}
.member__contact a:hover{background:var(--gold);transform:translateY(-2px)}
@media(max-width:960px){.team{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.team{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.team{grid-template-columns:1fr}}

/* Public form sections & checkbox */
.formsec{margin:0 0 16px;color:var(--green-dark);font-size:18px}
.check{display:inline-flex;align-items:flex-start;gap:10px;font-weight:600;cursor:pointer;line-height:1.4}
.check input{width:18px;height:18px;margin-top:2px;accent-color:var(--green);flex:none}

/* ============================================================
   Multi-step form wizard
   ============================================================ */
.wizard{position:relative}
.wizard__progress{margin-bottom:26px}
.wizard__bar{height:6px;background:var(--line);border-radius:6px;overflow:hidden;margin-bottom:18px}
.wizard__bar span{display:block;height:100%;width:0;border-radius:6px;background:linear-gradient(90deg,var(--green),var(--gold));transition:width .45s cubic-bezier(.4,.8,.3,1)}
.wizard__steps{list-style:none;display:flex;gap:6px;padding:0;margin:0}
.wizard__steps li{flex:1;min-width:0;text-align:center;font-size:12px;color:var(--muted);position:relative;padding-top:38px;line-height:1.25}
.wizard__steps li::before{content:attr(data-n);position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:32px;height:32px;border-radius:50%;background:#fff;border:2px solid var(--line);color:var(--muted);
    display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;transition:.25s;z-index:2}
.wizard__steps li::after{content:"";position:absolute;top:15px;left:-50%;width:100%;height:2px;background:var(--line);z-index:1}
.wizard__steps li:first-child::after{display:none}
.wizard__steps li.is-active{color:var(--green-dark);font-weight:700}
.wizard__steps li.is-active::before{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 0 0 4px rgba(10,125,60,.15)}
.wizard__steps li.is-done::before{content:"\2713";background:var(--gold);border-color:var(--gold);color:#3a2700}
.wizard__steps li.is-done::after,.wizard__steps li.is-active::after{background:var(--green)}
.wizard__step{display:none}
.wizard__step.is-active{display:block;animation:fade .35s ease}
.wizard__nav{display:flex;justify-content:space-between;gap:10px;margin-top:22px;border-top:1px solid var(--line);padding-top:20px}
.wizard__nav .btn{min-width:120px}
.field input,.field textarea,.field select{border-radius:10px;padding:12px 14px}
@media(max-width:620px){
    .wizard__steps li{font-size:0;padding-top:34px}
    .wizard__steps li.is-active{font-size:0}
    .wizard__nav .btn{min-width:96px}
}

/* Inline field icons */
.has-ico{background-repeat:no-repeat;background-position:14px center;background-size:18px 18px;padding-left:44px !important}
.i-user{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 20c0-4 4-6 8-6s8 2 8 6'/%3E%3C/svg%3E")}
.i-mail{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Cpath d='m3 7 9 6 9-6'/%3E%3C/svg%3E")}
.i-phone{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 4h4l2 5-3 2a14 14 0 0 0 6 6l2-3 5 2v4a2 2 0 0 1-2 2A18 18 0 0 1 3 6a2 2 0 0 1 2-2z'/%3E%3C/svg%3E")}
.i-cal{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='2'/%3E%3Cpath d='M3 9h18M8 3v4M16 3v4'/%3E%3C/svg%3E")}
.i-id{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Ccircle cx='8' cy='12' r='2'/%3E%3Cpath d='M13 10h5M13 14h5'/%3E%3C/svg%3E")}
.i-pin{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-6 7-11a7 7 0 1 0-14 0c0 5 7 11 7 11z'/%3E%3Ccircle cx='12' cy='10' r='2.5'/%3E%3C/svg%3E")}
.i-flag{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 21V4M5 4h12l-2 4 2 4H5'/%3E%3C/svg%3E")}
.i-drop{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3s6 7 6 11a6 6 0 1 1-12 0c0-4 6-11 6-11z'/%3E%3C/svg%3E")}
.i-ruler{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='8' width='18' height='8' rx='1'/%3E%3Cpath d='M7 8v3M11 8v4M15 8v3M19 8v4'/%3E%3C/svg%3E")}
.i-book{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 5a2 2 0 0 1 2-2h12v16H6a2 2 0 0 0-2 2z'/%3E%3C/svg%3E")}
.i-trophy{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235d6f64' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 4h10v4a5 5 0 0 1-10 0z'/%3E%3Cpath d='M9 14h6M10 18h4M12 14v4'/%3E%3C/svg%3E")}

/* Review step */
.review{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.review__row{display:flex;gap:14px;padding:11px 16px;border-bottom:1px solid var(--line);font-size:14.5px}
.review__row:last-child{border-bottom:0}
.review__row:nth-child(even){background:var(--bg-alt)}
.review__k{flex:0 0 38%;color:var(--muted);font-weight:600}
.review__v{flex:1;font-weight:600;color:var(--ink);word-break:break-word}
.review__edit{flex:none;background:none;border:0;color:var(--green);font-weight:700;font-size:13px;cursor:pointer;padding:0 2px;text-decoration:underline}
.review__edit:hover{color:var(--gold-deep)}

/* Live inline validation */
.field input.is-valid,.field select.is-valid,.field textarea.is-valid{border-color:#1f9d57}
.field input.is-valid:focus,.field select.is-valid:focus,.field textarea.is-valid:focus{box-shadow:0 0 0 3px rgba(31,157,87,.16)}
.field input.is-invalid,.field select.is-invalid,.field textarea.is-invalid{border-color:#c0392b}
.field input.is-invalid:focus,.field select.is-invalid:focus,.field textarea.is-invalid:focus{box-shadow:0 0 0 3px rgba(192,57,43,.16)}
