/* ============================================
   KOŁO ŁOWIECKIE – REGION RYBNIK
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500&family=Source+Sans+3:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&display=swap');

:root {
  --green-deepest: #0e1f0e;
  --green-dark: #1c341c;
  --green-mid: #2a4d2a;
  --green-accent: #3d6b3d;
  --green-light: #4a7f4a;
  --brown-dark: #5a4c1f;
  --brown: #725f27;
  --brown-light: #8a7533;
  --brown-bright: #a08a3c;
  --brown-pale: #c4b06a;
  --brown-cream: #ddd0a0;
  --cream: #f5f0e6;
  --cream-light: #faf7f0;
  --cream-white: #fdfcf8;
  --text-dark: #1a1a1a;
  --text-body: #3a3a3a;
  --text-muted: #6b6b6b;
  --text-on-dark: #e8e2d6;
  --text-on-dark-muted: #b0a890;
  --shadow-sm: 0 2px 8px rgba(14,31,14,.08);
  --shadow-md: 0 4px 20px rgba(14,31,14,.12);
  --shadow-lg: 0 8px 40px rgba(14,31,14,.18);
  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 12px;
  --t-fast: .2s cubic-bezier(.4,0,.2,1);
  --t-med: .4s cubic-bezier(.4,0,.2,1);
  --t-slow: .6s cubic-bezier(.4,0,.2,1);
  --f-display: 'Playfair Display', Georgia, serif;
  --f-body: 'Source Sans 3', 'Segoe UI', sans-serif;
  --f-accent: 'Cormorant Garamond', Georgia, serif;
}

/* Reset */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--f-body);color:var(--text-body);background:var(--cream-white);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--t-fast)}
ul{list-style:none}
.container{width:100%;max-width:1240px;margin:0 auto;padding:0 24px}

/* Utility */
.section-label{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-body);font-size:.72rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--brown);margin-bottom:14px}
.section-label::before{content:'';width:36px;height:2px;background:var(--brown)}
.section-title{font-family:var(--f-display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;line-height:1.2;margin-bottom:18px}
.section-title--light{color:var(--cream)}
.section-title--dark{color:var(--green-dark)}
.section-desc{font-size:1.05rem;line-height:1.8;color:var(--text-muted);max-width:600px}
.section-desc--light{color:var(--text-on-dark-muted)}

/* ============================================
   HEADER — top strip (scrolls away) + sticky nav
   ============================================ */

/* Top strip — scrolls away naturally */
.header__top{
  background:var(--green-deepest);
  padding:7px 0;
  border-bottom:1px solid rgba(114,95,39,.2);
}
.header__top-inner{display:flex;align-items:center;justify-content:space-between}
.header__top-text{font-size:.75rem;color:var(--text-on-dark-muted);letter-spacing:.2px}
.header__top-social{display:flex;gap:14px;align-items:center}
.header__top-social a{color:var(--text-on-dark-muted);display:flex;transition:color var(--t-fast)}
.header__top-social a:hover{color:var(--brown-pale)}

/* Sticky nav — stays at top */
.sticknav{
  background:var(--green-dark);
  padding:12px 0;
  position:sticky;
  top:0;
  z-index:1000;
  box-shadow:0 2px 16px rgba(0,0,0,.2);
}
.sticknav__inner{display:flex;align-items:center;justify-content:space-between}

.sticknav__logo{display:flex;align-items:center;gap:14px}
.sticknav__logo-img{
  width:50px;height:auto;object-fit:contain;
  filter:brightness(0) invert(1) sepia(1) saturate(.5) hue-rotate(15deg) brightness(1.5);
}
.sticknav__logo-text{display:flex;flex-direction:column}
.sticknav__logo-small{font-family:var(--f-body);font-size:.7rem;font-weight:500;color:var(--brown-pale);letter-spacing:1.5px;text-transform:uppercase;line-height:1.3}
.sticknav__logo-big{font-family:var(--f-display);font-size:1.3rem;font-weight:700;color:#fff;line-height:1.2}

.sticknav__links{display:flex;align-items:center;gap:2px}
.sticknav__link{
  font-family:var(--f-body);font-size:.87rem;font-weight:500;color:var(--text-on-dark);
  padding:10px 18px;transition:all var(--t-fast);position:relative;letter-spacing:.3px;
  border-bottom:3px solid transparent;
}
.sticknav__link:hover,.sticknav__link.active{color:#fff;background:rgba(255,255,255,.06)}
.sticknav__link.active{border-bottom-color:var(--brown)}

/* Burger */
.sticknav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}
.sticknav__burger span{width:26px;height:2px;background:var(--cream);transition:all var(--t-fast);border-radius:2px}
.sticknav__burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.sticknav__burger.open span:nth-child(2){opacity:0}
.sticknav__burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ============================================
   HERO — BRIGHT IMAGE, left gradient only
   ============================================ */
.hero{
  position:relative;
  height:clamp(420px, 65vh, 660px);
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--green-deepest);
}

.hero__bg{position:absolute;inset:0;z-index:1}
.hero__bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:70% 30%;
  /* Original colors — no darkening, just a touch of vibrancy */
  filter:saturate(1.1);
  transform:scale(1.02);
  transition:transform 5s ease-out;
}
.hero.loaded .hero__bg img{transform:scale(1)}

/* Gentle gradient: just enough on left for text, rest is bright open image */
.hero__gradient{
  position:absolute;
  inset:0;
  z-index:2;
  background:
    linear-gradient(105deg,
      rgba(14,31,14,.78) 0%,
      rgba(14,31,14,.55) 22%,
      rgba(14,31,14,.22) 42%,
      rgba(14,31,14,.05) 58%,
      transparent 72%
    ),
    linear-gradient(180deg,
      rgba(14,31,14,.08) 0%,
      transparent 20%,
      transparent 85%,
      rgba(14,31,14,.15) 100%
    );
}

.hero__inner{position:relative;z-index:3;width:100%}

.hero__content{max-width:520px}

.hero__org{
  font-family:var(--f-body);
  font-size:1rem;
  font-weight:600;
  color:var(--brown-pale);
  letter-spacing:1.5px;
  text-transform:uppercase;
  margin-bottom:8px;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
}

.hero__title{
  font-family:var(--f-display);
  font-size:clamp(2.6rem,5.5vw,4.2rem);
  font-weight:700;
  color:#fff;
  line-height:1.15;
  text-shadow:0 2px 20px rgba(0,0,0,.7), 0 1px 4px rgba(0,0,0,.5);
}

.hero__subtitle{
  font-family:var(--f-display);
  font-size:clamp(2.2rem,4.5vw,3.4rem);
  font-weight:700;
  color:#fff;
  line-height:1.15;
  margin-top:2px;
  text-shadow:0 2px 20px rgba(0,0,0,.7), 0 1px 4px rgba(0,0,0,.5);
}

.hero__line{
  width:70px;
  height:3px;
  background:var(--brown);
  margin:22px 0 18px;
  border-radius:2px;
  box-shadow:0 0 10px rgba(114,95,39,.4);
}

.hero__motto{
  font-family:var(--f-accent);
  font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:600;
  font-style:italic;
  color:var(--brown-cream);
  margin-bottom:26px;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}

.hero__actions{display:flex;gap:14px;flex-wrap:wrap}

.hero__btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-body);font-weight:600;font-size:.88rem;
  padding:12px 28px;border-radius:var(--r-sm);cursor:pointer;
  transition:all var(--t-fast);letter-spacing:.3px;border:2px solid transparent;
}

.hero__btn--fill{
  background:var(--green-dark);
  color:var(--cream);
  border-color:var(--green-dark);
  box-shadow:0 4px 16px rgba(0,0,0,.25);
}
.hero__btn--fill:hover{
  background:var(--green-mid);
  border-color:var(--green-mid);
  transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(0,0,0,.35);
}

.hero__btn--ghost{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.4);
  text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.hero__btn--ghost:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.6);
  transform:translateY(-2px);
}

/* ============================================
   HIGHLIGHTS — 3 info cards under hero
   ============================================ */
.highlights{
  position:relative;z-index:5;
  margin-top:-10px;
  padding:0 0 40px;
  pointer-events:none;
}
.highlights__row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  pointer-events:auto;
}
.hl-card{
  background:var(--green-dark);
  border-radius:var(--r-lg);
  padding:28px 24px;
  display:flex;
  align-items:flex-start;
  gap:18px;
  box-shadow:0 8px 32px rgba(14,31,14,.25);
  border:1px solid rgba(114,95,39,.15);
  transition:all var(--t-med);
  text-decoration:none;
  color:inherit;
}
.hl-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(14,31,14,.35);
  border-color:rgba(114,95,39,.35);
}
.hl-card__icon{
  width:50px;
  height:50px;
  border-radius:var(--r-md);
  background:rgba(114,95,39,.15);
  border:1px solid rgba(114,95,39,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--brown-pale);
}
.hl-card__icon svg{width:24px;height:24px}
.hl-card__body{flex:1;min-width:0}
.hl-card__tag{
  font-size:.68rem;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--brown-pale);margin-bottom:5px;
}
.hl-card__title{
  font-family:var(--f-display);font-size:1.1rem;font-weight:600;
  color:var(--cream);line-height:1.3;margin-bottom:4px;
  transition:color var(--t-fast);
}
.hl-card:hover .hl-card__title{color:var(--brown-cream)}
.hl-card__desc{font-size:.83rem;color:var(--text-on-dark-muted);line-height:1.5}

/* ============================================
   OBWODY SECTION — 2-column expandable cards
   ============================================ */
.obwody{padding:90px 0;background:var(--cream);border-top:1px solid rgba(28,52,28,.08);border-bottom:1px solid rgba(28,52,28,.08)}
.obwody__head{text-align:center;margin-bottom:44px}

.obwody__grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:14px;
}

.ok{
  background:var(--cream-white);
  border:1px solid rgba(28,52,28,.1);
  border-radius:var(--r-md);
  overflow:hidden;
  transition:all var(--t-fast);
  cursor:pointer;
}
.ok:hover{border-color:rgba(114,95,39,.3);box-shadow:var(--shadow-sm)}
.ok.open{border-color:var(--brown);box-shadow:var(--shadow-md)}

.ok__head{
  padding:18px 20px;
  display:flex;align-items:center;
  gap:14px;
}
.ok__nr{
  font-family:'Inter','Segoe UI',system-ui,sans-serif;
  font-size:.88rem;font-weight:700;
  color:var(--green-dark);background:rgba(28,52,28,.06);
  padding:6px 12px;border-radius:var(--r-sm);
  white-space:nowrap;flex-shrink:0;
  letter-spacing:.3px;
  border:1px solid rgba(28,52,28,.1);
  text-align:center;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum" 1, "tnum" 1;
}
.ok__info{flex:1;min-width:0}
.ok__name{
  font-family:var(--f-display);font-size:.95rem;font-weight:600;
  color:var(--green-dark);line-height:1.3;
}
.ok__loc-preview{
  font-size:.78rem;color:var(--text-muted);margin-top:2px;line-height:1.3;
}
.ok__chevron{
  flex-shrink:0;width:20px;height:20px;
  color:var(--text-muted);transition:transform var(--t-fast);
}
.ok.open .ok__chevron{transform:rotate(180deg)}

.ok__details{
  max-height:0;overflow:hidden;
  transition:max-height .35s ease,padding .3s ease;
  padding:0 20px;
  border-top:1px solid transparent;
}
.ok.open .ok__details{
  max-height:200px;
  padding:14px 20px 18px;
  border-top-color:rgba(28,52,28,.08);
}
.ok__detail-row{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:12px}
.ok__tel{font-size:.88rem}
.ok__tel a{color:var(--green-dark);font-weight:600;transition:color var(--t-fast)}
.ok__tel a:hover{color:var(--brown)}
.ok__mail{font-size:.82rem}
.ok__mail a{color:var(--text-muted);transition:color var(--t-fast)}
.ok__mail a:hover{color:var(--brown)}
.ok__pdf{
  display:inline-block;font-size:.78rem;font-weight:600;
  color:var(--brown);padding:8px 16px;
  border:1px solid rgba(114,95,39,.25);border-radius:var(--r-sm);
  transition:all var(--t-fast);
}
.ok__pdf:hover{background:var(--green-dark);color:var(--cream);border-color:var(--green-dark)}

@media(max-width:768px){.obwody__grid{grid-template-columns:1fr}}

/* ============================================
   PRZYDATNE LINKI
   ============================================ */
.links-section{
  padding:80px 0;
  background:var(--cream);
}
.links-section__head{text-align:center;margin-bottom:44px}
.links-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.link-tile{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:12px;
  padding:30px 20px;
  background:var(--cream-white);
  border:1px solid rgba(28,52,28,.08);
  border-radius:var(--r-lg);
  transition:all var(--t-med);
}
.link-tile:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:rgba(114,95,39,.2);
}
.link-tile__icon{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:var(--green-dark);
  border-radius:50%;
  color:var(--brown-pale);
}
.link-tile__icon svg{width:22px;height:22px}
.link-tile__name{
  font-family:var(--f-display);font-size:1.05rem;font-weight:600;
  color:var(--green-dark);line-height:1.3;
}
.link-tile__url{font-size:.78rem;color:var(--text-muted)}
.link-tile--placeholder{opacity:.55;border-style:dashed}
.link-tile--placeholder:hover{transform:none;box-shadow:none}
.about{padding:90px 0;background:var(--cream-white)}
.about__inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about__content{opacity:0;transform:translateX(-30px);transition:all .7s ease}
.about__content.visible{opacity:1;transform:translateX(0)}
.about__text{font-size:1.02rem;color:var(--text-body);line-height:1.85;margin-bottom:14px}
.about__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.about__stat{text-align:center;padding:16px 8px;border-radius:var(--r-md);background:var(--cream);border:1px solid rgba(28,52,28,.08)}
.about__stat-num{font-family:var(--f-display);font-size:2rem;font-weight:700;color:var(--green-dark);line-height:1}
.about__stat-lbl{font-size:.73rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}
.about__visual{position:relative;opacity:0;transform:translateX(30px);transition:all .7s .15s ease}
.about__visual.visible{opacity:1;transform:translateX(0)}
.about__img-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.about__img-wrap.about__img-wrap--map{border-radius:0;overflow:visible;box-shadow:none;background:none}
.about__visual:has(.about__img-wrap--map){overflow:hidden}
.about__img-wrap img{width:100%;height:400px;object-fit:cover;transition:transform var(--t-slow)}
.about__img-wrap:hover img{transform:scale(1.04)}
.about__img-wrap--map{
  display:flex;
  align-items:center;
  justify-content:center;
}
.about__img-wrap--map img{
  width:220%;
  max-width:220%;
  height:auto !important;
  object-fit:contain;
  transition:transform var(--t-slow);
  margin-left:0;
}
.about__img-wrap--map:hover img{transform:scale(1.03)}
.about__img-wrap--map ~ .about__accent{display:none}
.about__img-wrap--map ~ .about__badge{display:none}
.about__accent{position:absolute;top:-14px;right:-14px;width:100px;height:100px;border:3px solid var(--brown);border-radius:var(--r-lg);z-index:-1}
.about__badge{position:absolute;bottom:-16px;left:28px;background:var(--green-dark);color:var(--brown-pale);font-family:var(--f-accent);font-size:1.1rem;font-style:italic;font-weight:600;padding:12px 26px;border-radius:var(--r-md);box-shadow:var(--shadow-md)}

/* ============================================
   NEWS
   ============================================ */
.news{padding:90px 0;background:var(--green-dark);position:relative;overflow:hidden}
.news::before{content:'';position:absolute;inset:0;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23725f27'%3E%3Cpath d='M0 38.59l2.83-2.83 1.41 1.41L1.41 40H0v-1.41zM0 1.4l2.83 2.83 1.41-1.41L1.41 0H0v1.41zM38.59 40l-2.83-2.83 1.41-1.41L40 38.59V40h-1.41zM40 1.41l-2.83 2.83-1.41-1.41L38.59 0H40v1.41zM20 18.6l2.83-2.83 1.41 1.41L21.41 20l2.83 2.83-1.41 1.41L20 21.41l-2.83 2.83-1.41-1.41L18.59 20l-2.83-2.83 1.41-1.41L20 18.59z'/%3E%3C/g%3E%3C/svg%3E")}
.news__head{text-align:center;margin-bottom:48px;position:relative;z-index:1}
.news__head .section-desc{margin:0 auto}
.news__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:1}
.news__card{background:rgba(255,255,255,.04);border:1px solid rgba(114,95,39,.15);border-radius:var(--r-lg);overflow:hidden;transition:all var(--t-med);opacity:0;transform:translateY(25px)}
.news__card.visible{opacity:1;transform:translateY(0)}
.news__card:hover{transform:translateY(-5px);border-color:rgba(114,95,39,.35);box-shadow:0 10px 36px rgba(0,0,0,.3);background:rgba(255,255,255,.07)}
.news__card-img{height:180px;overflow:hidden;position:relative}
.news__card-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.news__card:hover .news__card-img img{transform:scale(1.07)}
.news__card-date{position:absolute;top:12px;left:12px;background:var(--green-dark);color:var(--brown-pale);font-size:.7rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:var(--r-sm);border:1px solid rgba(114,95,39,.3)}
.news__card-body{padding:22px}
.news__card-title{font-family:var(--f-display);font-size:1.12rem;font-weight:600;color:var(--cream);line-height:1.35;margin-bottom:10px;transition:color var(--t-fast)}
.news__card:hover .news__card-title{color:var(--brown-pale)}
.news__card-text{font-size:.88rem;color:var(--text-on-dark-muted);line-height:1.6;margin-bottom:14px}
.news__card-link{font-size:.83rem;font-weight:600;color:var(--brown-pale);transition:all var(--t-fast)}
.news__card-link:hover{color:var(--brown-cream)}
.news__more{text-align:center;margin-top:42px;position:relative;z-index:1}

/* ============================================
   MEMBERS
   ============================================ */
.members{padding:90px 0;background:var(--cream-white)}
.members__head{text-align:center;margin-bottom:48px}
.members__sub{font-family:var(--f-display);font-size:1.35rem;font-weight:600;color:var(--green-dark);text-align:center;margin-bottom:34px}
.members__sub::after{content:'';display:block;width:44px;height:2px;background:var(--brown);margin:10px auto 0}
.members__board{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-bottom:64px}
.member-card{text-align:center;opacity:0;transform:translateY(25px);transition:all .5s ease}
.member-card.visible{opacity:1;transform:translateY(0)}
.member-card__photo{width:140px;height:140px;margin:0 auto 14px;border-radius:50%;overflow:hidden;border:3px solid var(--cream);box-shadow:var(--shadow-md);transition:all var(--t-med);position:relative}
.member-card__photo::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--brown);opacity:0;transition:opacity var(--t-med)}
.member-card:hover .member-card__photo::after{opacity:1}
.member-card__photo img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-med)}
.member-card:hover .member-card__photo img{transform:scale(1.07)}
.member-card__name{font-family:var(--f-display);font-size:1.02rem;font-weight:600;color:var(--green-dark);margin-bottom:2px}
.member-card__role{font-size:.78rem;font-weight:500;color:var(--brown);text-transform:uppercase;letter-spacing:1px}
.members__roster{background:var(--cream);border-radius:var(--r-lg);padding:32px;border:1px solid rgba(28,52,28,.08)}
.members__roster-title{font-family:var(--f-display);font-size:1.15rem;font-weight:600;color:var(--green-dark);margin-bottom:20px}
.members__list{display:grid;grid-template-columns:repeat(3,1fr);gap:6px 20px}
.ml-i{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-sm);font-size:.92rem;color:var(--text-body);transition:background var(--t-fast)}
.ml-i:hover{background:rgba(28,52,28,.04)}
.ml-i::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green-accent);flex-shrink:0}

/* ============================================
   CONTACT
   ============================================ */
.contact{padding:90px 0;background:var(--green-dark);position:relative}
.contact::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--brown),transparent)}
.contact__inner{display:grid;grid-template-columns:1fr;max-width:600px;margin:0 auto}
.contact__info{opacity:0;transform:translateX(-30px);transition:all .7s ease}
.contact__info.visible{opacity:1;transform:translateX(0)}
.contact__detail{display:flex;gap:14px;margin-bottom:24px}
.contact__detail-icon{width:44px;height:44px;border-radius:var(--r-md);background:rgba(114,95,39,.12);border:1px solid rgba(114,95,39,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--brown-pale)}
.contact__detail-icon svg{width:20px;height:20px}
.contact__detail-label{font-size:.72rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--brown-pale);margin-bottom:2px}
.contact__detail-value{font-size:.95rem;color:var(--text-on-dark);line-height:1.5}
.contact__detail-value a:hover{color:var(--brown-pale)}
.contact__map{margin-top:24px;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(114,95,39,.2);height:170px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;color:var(--text-on-dark-muted);font-size:.85rem}
.contact__form-wrap{opacity:0;transform:translateX(30px);transition:all .7s .15s ease}
.contact__form-wrap.visible{opacity:1;transform:translateX(0)}
.contact__form{background:rgba(255,255,255,.04);border:1px solid rgba(114,95,39,.18);border-radius:var(--r-lg);padding:34px}
.contact__form-title{font-family:var(--f-display);font-size:1.3rem;font-weight:600;color:var(--cream);margin-bottom:24px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text-on-dark-muted);margin-bottom:6px}
.form-group input,.form-group textarea{width:100%;padding:12px 14px;background:rgba(255,255,255,.06);border:1px solid rgba(114,95,39,.25);border-radius:var(--r-md);color:var(--cream);font-family:var(--f-body);font-size:.92rem;transition:all var(--t-fast);outline:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(176,168,144,.4)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--brown);background:rgba(255,255,255,.08);box-shadow:0 0 0 3px rgba(114,95,39,.12)}
.form-group textarea{min-height:110px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.btn-submit{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--f-body);font-weight:600;font-size:.9rem;padding:14px;border-radius:var(--r-sm);cursor:pointer;border:none;background:var(--brown);color:var(--cream);transition:all var(--t-fast);margin-top:6px}
.btn-submit:hover{background:var(--brown-light);transform:translateY(-2px);box-shadow:0 4px 16px rgba(114,95,39,.3)}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--green-deepest);padding:28px 0;border-top:1px solid rgba(114,95,39,.15)}
.footer__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.footer__brand{display:flex;align-items:center;gap:10px;font-size:.83rem;color:var(--text-on-dark-muted)}
.footer__logo{width:32px;height:auto;filter:brightness(0) invert(1) sepia(1) saturate(.3) hue-rotate(15deg) brightness(1.4);opacity:.5}
.footer__copy{font-size:.78rem;color:rgba(176,168,144,.4)}
.footer__motto{font-family:var(--f-accent);font-style:italic;font-size:.92rem;color:var(--brown-dark)}

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

.anim-up{opacity:0;transform:translateY(22px);animation:fadeUp .7s ease forwards}
.anim-d1{animation-delay:.15s}
.anim-d2{animation-delay:.3s}
.anim-d3{animation-delay:.42s}
.anim-d4{animation-delay:.55s}
.anim-d5{animation-delay:.65s}
.anim-d6{animation-delay:.8s}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .about__inner{grid-template-columns:1fr;gap:36px}
  .about__visual{order:-1}
  .about__img-wrap img{height:300px}
  .members__board{grid-template-columns:repeat(2,1fr)}
  .news__grid{grid-template-columns:repeat(2,1fr)}
  .contact__inner{grid-template-columns:1fr}
  .members__list{grid-template-columns:repeat(2,1fr)}
  .links-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .header__top-text{font-size:.68rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70vw}
  .header__top-social{display:none}
  .sticknav__logo-img{width:40px}
  .sticknav__logo-big{font-size:1.1rem}

  .sticknav__links{
    position:fixed;top:0;right:-100%;width:280px;height:100vh;
    background:var(--green-deepest);flex-direction:column;
    padding:90px 28px 40px;gap:0;transition:right var(--t-med);
    box-shadow:-8px 0 30px rgba(0,0,0,.4);z-index:9999;
  }
  .sticknav__links.open{right:0}
  .sticknav__link{width:100%;padding:14px 16px;font-size:1rem;border-bottom:none !important}
  .sticknav__burger{display:flex;z-index:10000}

  .hero{height:50vh;min-height:340px}
  .hero__gradient{
    background:
      linear-gradient(100deg,
        rgba(14,31,14,.82) 0%,
        rgba(14,31,14,.5) 35%,
        rgba(14,31,14,.15) 60%,
        transparent 80%
      ),
      linear-gradient(0deg,
        rgba(14,31,14,.2) 0%,
        transparent 30%
      ) !important;
  }
  .hero__title{font-size:2rem}
  .hero__subtitle{font-size:1.7rem}

  .highlights{margin-top:0}
  .highlights__row{grid-template-columns:1fr;max-width:440px;margin:0 auto;gap:14px}
  .hl-card{padding:20px 18px}

  .news__grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .members__board{grid-template-columns:repeat(2,1fr);gap:16px}
  .member-card__photo{width:110px;height:110px}
  .members__list{grid-template-columns:1fr}
  .members__roster{padding:20px}
  .contact__form{padding:22px}
  .form-row{grid-template-columns:1fr}
  .about__stats{grid-template-columns:repeat(3,1fr);gap:8px}
  .footer__inner{flex-direction:column;text-align:center}
  .links-grid{grid-template-columns:repeat(2,1fr);gap:14px}
}

@media(max-width:480px){
  .about__stats{grid-template-columns:1fr}
  .members__board{grid-template-columns:1fr;max-width:240px;margin:0 auto 60px}
  .hero__actions{flex-direction:column;align-items:flex-start}
  .hero__btn{width:auto}
  .links-grid{grid-template-columns:1fr}
}

/* ============================================
   ADMIN BUTTON (FAB - bottom right corner)
   ============================================ */
.admin-btn-fab{
  position:fixed;
  bottom:20px;right:20px;
  padding:10px 18px;
  border-radius:24px;
  background:var(--green-dark);
  color:var(--brown-pale);
  border:1px solid rgba(114,95,39,.3);
  box-shadow:0 4px 16px rgba(0,0,0,.2);
  cursor:pointer;
  z-index:900;
  font-family:var(--f-body);
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.5px;
  opacity:0;
  pointer-events:none;
  transform:translateY(10px);
  transition:opacity .4s ease, transform .4s ease, background .2s ease;
}
.admin-btn-fab.visible{
  opacity:.45;
  pointer-events:auto;
  transform:translateY(0);
}
.admin-btn-fab.visible:hover{opacity:1;background:var(--green-mid)}

/* ============================================
   MODAL SYSTEM (login, admin panel, news detail)
   ============================================ */
.modal-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(14,31,14,.7);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
  padding:20px;
}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{
  background:var(--cream-white);
  border-radius:var(--r-lg);
  width:100%;max-height:90vh;
  display:flex;flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
  transform:translateY(20px) scale(.97);
  transition:transform .3s ease;
}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal--small{max-width:420px}
.modal--large{max-width:880px}
.modal__header{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:22px 26px;
  border-bottom:1px solid rgba(28,52,28,.1);
}
.modal__title{font-family:var(--f-display);font-size:1.3rem;font-weight:700;color:var(--green-dark);margin:0}
.modal__close{
  background:none;border:none;cursor:pointer;padding:6px;
  color:var(--text-muted);transition:color var(--t-fast);
  display:flex;align-items:center;
}
.modal__close:hover{color:var(--green-dark)}
.modal__body{overflow-y:auto;padding:24px 26px}

/* ============================================
   FORM ELEMENTS (admin)
   ============================================ */
.form-field{margin-bottom:16px}
.form-field label{
  display:block;font-size:.82rem;font-weight:600;
  color:var(--green-dark);margin-bottom:6px;
}
.form-field input[type="text"],
.form-field input[type="password"],
.form-field input[type="datetime-local"],
.form-field textarea{
  width:100%;padding:10px 14px;
  border:1px solid rgba(28,52,28,.15);
  border-radius:var(--r-sm);
  font-family:var(--f-body);font-size:.95rem;
  color:var(--text-dark);background:#fff;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.form-field input:focus,.form-field textarea:focus{
  outline:none;
  border-color:var(--brown);
  box-shadow:0 0 0 3px rgba(114,95,39,.12);
}
.form-field input[type="file"]{
  font-family:var(--f-body);font-size:.88rem;color:var(--text-muted);
  padding:6px 0;
}
.form-field textarea{resize:vertical;min-height:100px;font-family:var(--f-body)}
.form-field small{display:block;font-size:.72rem;color:var(--text-muted);margin-top:4px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.form-row-2{grid-template-columns:1fr}}

.form-error{color:#a83838;font-size:.85rem;min-height:1.2em;margin-bottom:10px}

.form-btn{
  font-family:var(--f-body);font-weight:600;font-size:.88rem;
  padding:11px 22px;border-radius:var(--r-sm);
  cursor:pointer;border:1px solid transparent;
  transition:all var(--t-fast);
}
.form-btn--primary{background:var(--green-dark);color:var(--cream)}
.form-btn--primary:hover{background:var(--green-mid)}
.form-btn--ghost{background:transparent;color:var(--green-dark);border-color:rgba(28,52,28,.2)}
.form-btn--ghost:hover{background:rgba(28,52,28,.05)}

.image-preview{
  max-width:100%;max-height:240px;
  margin-top:10px;border-radius:var(--r-sm);
  border:1px solid rgba(28,52,28,.1);
  object-fit:contain;
}

/* ============================================
   ADMIN PANEL — news list
   ============================================ */
.admin-form{
  background:var(--cream);
  border-radius:var(--r-md);
  padding:20px;
  margin-bottom:24px;
}
.admin-form__title{
  font-family:var(--f-display);font-size:1.05rem;font-weight:700;
  color:var(--green-dark);margin:0 0 14px;
}
.admin-list{margin-top:8px}
.admin-loading{font-size:.88rem;color:var(--text-muted);text-align:center;padding:20px}
.admin-news-item{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:12px 14px;
  background:var(--cream-white);
  border:1px solid rgba(28,52,28,.08);
  border-radius:var(--r-sm);
  margin-bottom:8px;
}
.admin-news-item__info{flex:1;min-width:0}
.admin-news-item__title{
  font-family:var(--f-display);font-weight:600;font-size:.95rem;
  color:var(--green-dark);
}
.admin-news-item__meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}
.admin-event-tag{
  display:inline-block;font-size:.7rem;font-weight:600;
  background:rgba(114,95,39,.12);color:var(--brown);
  padding:2px 8px;border-radius:var(--r-sm);margin-left:8px;
}
.admin-actions{display:flex;gap:8px;flex-shrink:0}
.admin-btn-sm{
  font-size:.78rem;font-weight:600;
  padding:6px 12px;border-radius:var(--r-sm);
  border:1px solid;cursor:pointer;background:transparent;
  transition:all var(--t-fast);
}
.admin-btn-sm--edit{color:var(--brown);border-color:rgba(114,95,39,.3)}
.admin-btn-sm--edit:hover{background:var(--brown);color:var(--cream)}
.admin-btn-sm--del{color:#a83838;border-color:rgba(168,56,56,.3)}
.admin-btn-sm--del:hover{background:#a83838;color:#fff}

/* ============================================
   NEWS DETAIL MODAL (public)
   ============================================ */
.news-modal-body{padding:0}
.news-modal__img{
  width:100%;max-height:380px;object-fit:cover;
  border-radius:0;display:block;
}
.news-modal-body > *:not(.news-modal__img){padding-left:30px;padding-right:30px}
.news-modal__date{
  font-size:.75rem;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--brown);
  padding-top:24px;
}
.news-modal__title{
  font-family:var(--f-display);font-size:1.7rem;font-weight:700;
  color:var(--green-dark);line-height:1.2;
  margin:8px 0 12px;
}
.news-modal__event{
  display:flex;flex-wrap:wrap;gap:20px;
  background:var(--cream);
  padding:14px 18px;border-radius:var(--r-sm);
  margin-bottom:18px;font-size:.88rem;color:var(--text-body);
}
.news-modal__desc{
  font-size:1rem;line-height:1.75;color:var(--text-body);
  padding-bottom:30px;
  white-space:pre-wrap;
}
@media(max-width:600px){
  .news-modal-body > *:not(.news-modal__img){padding-left:20px;padding-right:20px}
  .news-modal__title{font-size:1.3rem}
}

/* News card placeholder image (when no image) */
.news__card-img--placeholder{
  background:linear-gradient(135deg, var(--green-dark), var(--green-mid));
  display:flex;align-items:center;justify-content:center;
}
.news__card-img--placeholder::before{
  content:'';
  width:60px;height:60px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23725f27' stroke-width='1.5'%3E%3Crect x='3' y='3' width='18' height='18' rx='2'/%3E%3Cpath d='M3 9h18M9 21V9'/%3E%3C/svg%3E") center/contain no-repeat;
  opacity:.4;
}
.news__card{cursor:pointer}
