/* =============================================================
   Concept E — Warm Community
   미래소비자행동
   - 크림 베이스 + 사이프러스 그린 + 테라코타 (시민단체 따뜻한 톤)
   - 라운드 카드, 부드러운 곡선, 인간미 있는 인터랙션
   - "함께하는 시민단체" 톤 — 옥스팜·아름다운재단 계열
   ============================================================= */

:root{
  --color-bg:        #fbf6ef;        /* 따뜻한 크림 베이스 */
  --color-bg-alt:    #f3ebde;        /* 옅은 크림 */
  --color-bg-soft:   #fff8eb;
  --color-ink:       #1f2a23;        /* 깊은 그린 잉크 */
  --color-ink-sub:   #4a5751;
  --color-ink-soft:  #8a9089;

  --color-line:      #e8dfcb;
  --color-line-soft: #f0e9d8;

  --color-brand:     #2e5a3e;        /* 사이프러스 그린 (NGO 신뢰감) */
  --color-brand-dk:  #1f4029;
  --color-brand-lt:  #547a5e;

  --color-accent:    #d96f4a;        /* 테라코타 (따뜻한 행동) */
  --color-accent-lt: #f0a585;
  --color-accent-bg: #fde9de;

  --color-gold:      #c89c4d;        /* 빈티지 골드 보조 */

  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --radius-xl: 40px;
  --radius-pill: 999px;

  --shadow-card:  0 4px 14px rgba(31,42,35,.06);
  --shadow-soft:  0 12px 30px rgba(31,42,35,.08);
  --shadow-deep:  0 24px 56px rgba(31,42,35,.14);

  --font-sans: 'Noto Sans KR',system-ui,-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;

  --container: 1200px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font-sans);
  color:var(--color-ink);
  background:var(--color-bg);
  font-size:16px;line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none;}
a:focus-visible,button:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:6px;}
ul{list-style:none;margin:0;padding:0;}
img{display:block;max-width:100%;}
button{font:inherit;border:0;background:transparent;cursor:pointer;color:inherit;}
h1,h2,h3,h4,h5,p{margin:0;}

.container{
  width:100%;max-width:var(--container);
  margin:0 auto;padding:0 24px;
}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:54px;padding:0 32px;
  font-weight:600;font-size:15px;letter-spacing:.01em;
  border-radius:var(--radius-pill);
  transition:all .22s ease;
  white-space:nowrap;
  box-shadow:var(--shadow-card);
}
.btn--primary{background:var(--color-brand);color:#fff;}
.btn--primary:hover{background:var(--color-brand-dk);transform:translateY(-2px);box-shadow:var(--shadow-soft);}
.btn--accent{background:var(--color-accent);color:#fff;}
.btn--accent:hover{background:#c25a35;transform:translateY(-2px);box-shadow:var(--shadow-soft);}
.btn--ghost{
  background:#fff;color:var(--color-brand);
  border:1.5px solid var(--color-line);
  box-shadow:none;
}
.btn--ghost:hover{border-color:var(--color-brand);background:var(--color-bg-soft);}

/* ============ Util bar ============ */
.util-bar{
  background:var(--color-brand);
  color:#fff;
  font-size:12px;
}
.util-bar__inner{
  display:flex;justify-content:space-between;align-items:center;
  height:36px;
}
.util-bar__sns{display:flex;gap:10px;align-items:center;color:#fbf6ef;}
.util-bar__links{display:flex;gap:18px;align-items:center;}
.util-bar__links a{color:rgba(255,255,255,.85);transition:color .15s;}
.util-bar__links a:hover{color:#fff;}
.util-bar__sns a{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  color:inherit;
  opacity:.9;transition:opacity .15s,color .15s,transform .15s;
}
.util-bar__sns a:hover{opacity:1;color:#fff;transform:translateY(-1px);}
.util-bar__sns .sns-ico{width:14px;height:14px;display:block;fill:currentColor;}

/* ============ Header / GNB ============ */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,246,239,.94);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--color-line);
}
.header__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;gap:24px;
}
.brand{display:flex;align-items:center;}
.brand__img{height:46px;width:auto;display:block;}

.gnb__list{display:flex;gap:6px;}
.gnb__item{position:relative;}
.gnb__link{
  display:inline-block;padding:12px 22px;
  font-size:15px;font-weight:600;color:var(--color-ink);
  border-radius:var(--radius-pill);
  transition:all .18s ease;
}
.gnb__item:hover > .gnb__link,
.gnb__item:focus-within > .gnb__link{
  background:var(--color-bg-alt);color:var(--color-brand);
}

.gnb__panel{
  position:absolute;left:50%;top:100%;
  transform:translate(-50%,5px);
  min-width:240px;
  background:#fff;
  border:1px solid var(--color-line);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-deep);
  /* 상단 12px 은 시각적 여백(panel 내부) — 메뉴 아이템과의 hover bridge 역할 */
  padding:24px 12px 12px;
  margin-top:0;
  /* hover 잃기 직전 약간의 delay 로 마우스 이동 중 사라짐 방지 */
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .18s ease .12s,transform .18s ease .12s,visibility 0s linear .3s;
  z-index:60;
}
.gnb__panel::before{
  /* arrow 를 padding-top 영역 안(panel 상단 6px 위치)에 그려 panel hover area 와 분리되지 않도록 */
  content:"";position:absolute;left:50%;top:6px;transform:translateX(-50%) rotate(45deg);
  width:12px;height:12px;background:#fff;border:1px solid var(--color-line);
  border-right:0;border-bottom:0;border-radius:2px 0 0 0;
}
.gnb__item:hover > .gnb__panel,
.gnb__item:focus-within > .gnb__panel{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translate(-50%,0);
  transition:opacity .18s ease,transform .18s ease,visibility 0s linear 0s;
}
.gnb__panel ul{display:flex;flex-direction:column;gap:2px;}
.gnb__panel li a{
  display:block;
  padding:12px 16px;
  font-size:14px;font-weight:500;color:var(--color-ink-sub);
  border-radius:10px;
  white-space:nowrap;
  transition:all .15s;
}
.gnb__panel li a:hover{background:var(--color-accent-bg);color:var(--color-accent);}

.header__cta{height:44px;font-size:13px;padding:0 22px;}

/* ============ Hero — Warm split + 라운드 시각 ============ */
.hero{
  position:relative;
  padding:80px 0 64px;
  overflow:hidden;
}
.hero__shape{
  position:absolute;
  top:-180px;right:-220px;
  width:680px;height:680px;
  background:radial-gradient(circle at center,var(--color-accent-bg) 0%,transparent 65%);
  z-index:0;
  pointer-events:none;
}
.hero__container{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;
  align-items:center;
}
.hero__copy{}
.hero__chip{
  display:inline-flex;align-items:center;
  padding:8px 18px;
  font-size:13px;font-weight:600;
  color:var(--color-brand);
  background:#fff;border:1px solid var(--color-line);
  border-radius:var(--radius-pill);
  margin-bottom:24px;
  box-shadow:var(--shadow-card);
}
.hero__title{
  font-size:clamp(40px,4.6vw,64px);
  line-height:1.18;
  font-weight:700;
  letter-spacing:-.025em;
  color:var(--color-ink);
  margin-bottom:24px;
}
.hero__title-accent{
  color:var(--color-accent);
  position:relative;
  display:inline-block;
}
.hero__title-accent::after{
  content:"";
  position:absolute;left:-4px;right:-4px;bottom:4px;height:14px;
  background:rgba(217,111,74,.18);
  border-radius:8px;
  z-index:-1;
}
.hero__lead{
  font-size:17px;line-height:1.85;
  color:var(--color-ink-sub);
  margin-bottom:34px;
  max-width:520px;
}
.hero__actions{
  display:flex;gap:14px;flex-wrap:wrap;
  margin-bottom:44px;
}
.hero__stats{
  display:grid;grid-template-columns:repeat(3,auto);
  gap:36px;
  padding:24px 28px;
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  width:fit-content;
}
.hero__stats > div{}
.hero__stats-num{
  font-size:36px;font-weight:800;line-height:1;
  color:var(--color-brand);
  letter-spacing:-.03em;
}
.hero__stats-num span{
  color:var(--color-accent);font-size:24px;vertical-align:top;font-weight:700;
}
.hero__stats-label{
  font-size:12px;color:var(--color-ink-soft);
  margin-top:6px;
}

.hero__visual{
  position:relative;
  aspect-ratio:1/1.1;
}
.hero__visual-img{
  width:100%;height:100%;
  border-radius:100px;
  background:#1f4029 center/cover no-repeat;
  box-shadow:var(--shadow-deep);
  overflow:hidden;
}
.hero__badge{
  position:absolute;
  bottom:24px;left:-30px;
  width:140px;height:140px;
  background:var(--color-accent);
  color:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  box-shadow:var(--shadow-deep);
  transform:rotate(-8deg);
  border:6px solid #fff;
}
.hero__badge-text{
  font-size:14px;font-weight:600;line-height:1.4;
  letter-spacing:-.01em;
}

/* 퀵메뉴 — 라운드 카드 4개 (히어로 하단) */
.hero__quick{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  margin-top:64px;
  position:relative;z-index:1;
}
.hero__quick li{}
.hero__quick a{
  display:grid;grid-template-columns:56px 1fr;gap:16px;align-items:center;
  padding:22px 24px;
  background:#fff;border:1px solid var(--color-line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  transition:all .22s ease;
}
.hero__quick a:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-soft);
  border-color:var(--color-brand-lt);
}
.qk__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;
  border-radius:50%;
  background:var(--color-bg-alt);
  color:var(--color-brand);
  transition:all .22s ease;
}
.qk__icon--1{background:#dbe6d2;color:var(--color-brand);}
.qk__icon--2{background:#fde9de;color:var(--color-accent);}
.qk__icon--3{background:#e6e8d8;color:var(--color-gold);}
.qk__icon--4{background:#fde9de;color:var(--color-accent);}
.hero__quick a:hover .qk__icon{transform:scale(1.05);}
.qk__txt{display:flex;flex-direction:column;gap:2px;}
.qk__label{
  font-size:15px;font-weight:700;color:var(--color-ink);
  letter-spacing:-.01em;
}
.qk__sub{
  font-size:12px;color:var(--color-ink-soft);
}

/* ============ Section ============ */
.section{padding:96px 0;}
.section--soft{background:var(--color-bg-alt);}
.section__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:48px;gap:24px;flex-wrap:wrap;
}
.section__eyebrow{
  display:inline-block;
  padding:5px 14px;
  font-size:12px;font-weight:600;letter-spacing:.06em;
  color:var(--color-brand);
  background:#fff;border:1px solid var(--color-line);
  border-radius:var(--radius-pill);
  margin-bottom:14px;
}
.section--soft .section__eyebrow{background:var(--color-bg);}
.section__title{
  font-size:clamp(28px,3.2vw,40px);
  font-weight:700;letter-spacing:-.025em;
  line-height:1.25;
  color:var(--color-ink);
}
.section__sub{
  font-size:15px;color:var(--color-ink-sub);
  margin-top:10px;
}
.section__more{
  font-size:14px;font-weight:600;color:var(--color-brand);
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 22px;
  background:#fff;border:1px solid var(--color-line);
  border-radius:var(--radius-pill);
  transition:all .15s;
  box-shadow:var(--shadow-card);
}
.section--soft .section__more{background:var(--color-bg);}
.section__more i{font-style:normal;transition:transform .2s;}
.section__more:hover{background:var(--color-brand);color:#fff;border-color:var(--color-brand);}
.section__more:hover i{transform:translateX(4px);}

/* ============ Card grid ============ */
.card-grid{display:grid;gap:36px 24px;}
.card-grid--4{grid-template-columns:repeat(4,1fr);}
.card-grid--6{grid-template-columns:repeat(6,1fr);gap:24px 16px;}

.card{display:flex;flex-direction:column;}
.card a{display:flex;flex-direction:column;gap:16px;height:100%;}
.card__thumb{
  width:100%;aspect-ratio:4/3;
  background:#1f4029 center/cover no-repeat;
  border-radius:var(--radius-md);
  position:relative;overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;
  box-shadow:var(--shadow-card);
}
.card__thumb--portrait{aspect-ratio:3/4;border-radius:var(--radius-lg);}
.card__thumb--mini{aspect-ratio:1/1;border-radius:var(--radius-sm);}
.card a:hover .card__thumb{
  transform:translateY(-4px);
  box-shadow:var(--shadow-soft);
}

.card__cate{
  font-size:12px;font-weight:600;color:var(--color-accent);
  letter-spacing:.02em;
}
.card__tag{
  position:absolute;top:14px;left:14px;
  background:#fff;color:var(--color-ink);
  font-size:11px;font-weight:600;
  padding:5px 12px;border-radius:var(--radius-pill);
  box-shadow:var(--shadow-card);
}
.card__body{display:flex;flex-direction:column;gap:8px;padding:0 4px;}
.card__title{
  font-size:17px;font-weight:600;line-height:1.45;color:var(--color-ink);
  letter-spacing:-.015em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
  transition:color .15s;
}
.card a:hover .card__title{color:var(--color-brand);}
.card__date{font-size:13px;color:var(--color-ink-soft);font-variant-numeric:tabular-nums;}
.card__loca{
  position:absolute;left:10px;top:10px;
  background:rgba(31,64,41,.88);color:#fff;
  font-size:11px;font-weight:600;padding:5px 10px;border-radius:var(--radius-pill);
}
.card--mini .card__title{font-size:14px;font-weight:500;line-height:1.45;}

/* ============ Filter chips ============ */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:36px;
}
.filter-bar__chip{
  height:40px;padding:0 20px;
  font-size:13px;font-weight:500;color:var(--color-ink-sub);
  background:#fff;border:1px solid var(--color-line);
  border-radius:var(--radius-pill);
  transition:all .15s;
  box-shadow:var(--shadow-card);
}
.section--soft .filter-bar__chip{background:var(--color-bg);}
.filter-bar__chip:hover{color:var(--color-brand);border-color:var(--color-brand-lt);}
.filter-bar__chip.is-on{
  background:var(--color-brand);color:#fff;border-color:var(--color-brand);
  font-weight:600;
}

/* ============ Family / Banner row ============ */
.family{
  padding:56px 0;
  background:#ffffff;
  border-top:1px solid var(--color-line-soft);
  border-bottom:1px solid var(--color-line-soft);
}
.family__list{
  display:flex;flex-wrap:nowrap;align-items:center;justify-content:space-between;
  gap:20px;
}
.family__list li{display:flex;align-items:center;flex:0 1 auto;min-width:0;}
.family__list a{
  display:inline-flex;align-items:center;
  height:64px;
  padding:8px 16px;
  border-radius:var(--radius-md);
}
/* 사용자 요청 (2026-05-20): 패밀리 로고 hover 효과 제거 */
.family__list a:hover{background:transparent;box-shadow:none;transform:none;}
.family__list img{height:54px;width:auto;display:block;max-width:100%;object-fit:contain;}

/* ============ Footer ============ */
.footer{background:var(--color-brand-dk);color:#c4d2c8;font-size:14px;}
.footer__inner{
  display:grid;grid-template-columns:1fr 2.2fr;gap:64px;
  padding:80px 24px 56px;
}
.footer__logo-link{display:inline-block;margin-bottom:14px;}
.footer__logo-img{
  height:48px;width:auto;display:block;
  background:#fff;padding:8px 14px;border-radius:var(--radius-sm);
}
.footer__tag{
  font-size:13px;color:var(--color-accent-lt);letter-spacing:.02em;
  margin-bottom:28px;
}
.footer__sns{display:flex;flex-wrap:wrap;gap:10px;}
.footer__sns a{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.08);
  color:#fbf6ef;
  transition:background .15s,color .15s,transform .15s;
}
.footer__sns a:hover{background:var(--color-accent);color:#fff;transform:translateY(-2px);}
.footer__sns .sns-ico{width:16px;height:16px;display:block;fill:currentColor;}

.footer__cols{
  display:grid;grid-template-columns:repeat(5,1fr);gap:32px;
}
.footer__col-title{
  color:#fff;font-size:15px;font-weight:700;margin-bottom:16px;
}
.footer__col-title a:hover{color:var(--color-accent-lt);}
.footer__cols ul li{margin-bottom:10px;}
.footer__cols ul a{
  font-size:13px;color:#a8b9af;transition:color .15s;
}
.footer__cols ul a:hover{color:#fff;}

.footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:28px 0 36px;
}
.footer__bottom-inner{
  display:flex;flex-direction:column;gap:14px;
}
.footer__legal{display:flex;flex-wrap:wrap;gap:0;}
.footer__legal li{
  padding:0 14px;border-right:1px solid rgba(255,255,255,.12);
  font-size:13px;
}
.footer__legal li:first-child{padding-left:0;}
.footer__legal li:last-child{border-right:0;}
.footer__legal a{color:#a8b9af;transition:color .15s;}
.footer__legal a:hover{color:#fff;}
.footer__info{font-size:12px;color:#a8b9af;line-height:1.85;}
.footer__info strong{color:#fff;font-weight:600;}
.footer__info a{color:var(--color-accent-lt);}
.footer__copy{
  font-size:11px;color:rgba(255,255,255,.35);letter-spacing:.05em;
  padding-top:8px;
}

/* ============ Responsive ============ */
@media (max-width:1100px){
  .hero__container{grid-template-columns:1fr;gap:48px;}
  .hero__visual{aspect-ratio:16/12;max-width:560px;margin:0 auto;}
  .hero__badge{left:auto;right:-10px;bottom:-10px;}
  .card-grid--4{grid-template-columns:repeat(2,1fr);}
  .card-grid--6{grid-template-columns:repeat(3,1fr);}
  .footer__cols{grid-template-columns:repeat(2,1fr);}
  .footer__inner{grid-template-columns:1fr;gap:48px;}
  .hero__quick{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:768px){
  .container{padding:0 20px;}
  .util-bar__links{display:none;}
  .header__inner{height:68px;}
  .gnb{display:none;}
  .brand__img{height:36px;}
  .header__cta{padding:0 16px;height:40px;font-size:12px;}

  .hero{padding:48px 0 48px;}
  .hero__title{font-size:34px;}
  .hero__lead{font-size:15px;}
  .hero__stats{padding:18px 22px;gap:24px;}
  .hero__stats-num{font-size:28px;}

  .hero__visual{aspect-ratio:16/13;}
  .hero__visual-img{border-radius:60px;}
  .hero__badge{width:110px;height:110px;}
  .hero__badge-text{font-size:12px;}

  .section{padding:64px 0;}
  .section__title{font-size:26px;}

  .card-grid--4{grid-template-columns:repeat(2,1fr);gap:24px 14px;}
  .card-grid--6{grid-template-columns:repeat(2,1fr);}

  .hero__quick{grid-template-columns:1fr;gap:12px;}

  .family__list{flex-wrap:wrap;gap:18px 32px;justify-content:center;}
  .family__list img{height:46px;}

  .footer__cols{grid-template-columns:1fr 1fr;gap:24px;}
}
@media (max-width:480px){
  .hero__title{font-size:30px;}
  .section__head{flex-direction:column;align-items:flex-start;}
  .card-grid--4{grid-template-columns:1fr;}
  .hero__stats{grid-template-columns:repeat(3,1fr);width:100%;gap:14px;padding:18px;}
  .hero__stats-num{font-size:24px;}
}
