/* ==========================================================
   김장호 · 2026 구미시장 — 미니멀 프리미엄 디자인
   국민의힘 Red 단색 강조 + 화이트 + 블랙
   ========================================================== */
:root{
  --red:        #EA0029;    /* 메인 레드 — 세련된 진한 크림슨 */
  --red-dark:   #C50020;    /* 진한 레드 (호버/프레스) */
  --red-soft:   #FFF1F3;    /* 연한 레드 배경 */
  --red-line:   #FFC9CF;    /* 레드 라인/보더 */

  --black:      #111111;
  --gray-900:   #1A1A1A;
  --gray-700:   #3D3D3D;
  --gray-500:   #6B6B6B;
  --gray-300:   #BFBFBF;
  --gray-200:   #E5E5E5;
  --gray-100:   #F2F2F2;
  --gray-50:    #F8F8F8;
  --white:      #FFFFFF;

  --max-w: 1200px;
  --header-h: 80px;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:'Pretendard','Noto Sans KR',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--black);
  background:var(--white);
  line-height:1.6;
  font-feature-settings:"ss03","ss04";
  overflow-x:hidden;
  width:100%;
  min-height:100vh;
  min-height:100dvh;
  -webkit-tap-highlight-color:transparent;
}
/* iOS safe-area 대응 */
@supports (padding:max(0px)){
  .container{
    padding-left:max(24px, env(safe-area-inset-left));
    padding-right:max(24px, env(safe-area-inset-right));
  }
  .site-footer{padding-bottom:max(24px, env(safe-area-inset-bottom))}
  .toast{bottom:max(32px, calc(env(safe-area-inset-bottom) + 20px))}
  .mobile-menu{padding-bottom:max(32px, env(safe-area-inset-bottom))}
}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
input,textarea,select{font-family:inherit;-webkit-appearance:none;appearance:none;border-radius:0}
img{max-width:100%;display:block;height:auto}

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

/* ==========================================================
   🎬 100억짜리 프리미엄 애니메이션 시스템
   ========================================================== */

/* 스크롤 등장 애니메이션 */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.34,1.56,.64,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* 순차 딜레이 */
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}
.reveal[data-delay="4"]{transition-delay:.4s}
.reveal[data-delay="5"]{transition-delay:.5s}

/* 히어로 입장 애니메이션 */
@keyframes heroFadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes heroSlideIn{
  from{opacity:0;transform:translateX(-30px)}
  to{opacity:1;transform:translateX(0)}
}
.hero-tag{animation:heroFadeUp .8s cubic-bezier(.22,1,.36,1) both}
.hero-slogan{animation:heroSlideIn 1s cubic-bezier(.22,1,.36,1) .15s both}
.hero-title{animation:heroFadeUp 1s cubic-bezier(.22,1,.36,1) .3s both}
.hero-sub{animation:heroFadeUp 1s cubic-bezier(.22,1,.36,1) .5s both}
.hero-actions{animation:heroFadeUp 1s cubic-bezier(.22,1,.36,1) .7s both}
.hero-meta{animation:heroFadeUp 1s cubic-bezier(.22,1,.36,1) .9s both}

/* Red Text 글로우 효과 */
@keyframes redGlow{
  0%,100%{text-shadow:0 0 0 rgba(234,0,41,0)}
  50%{text-shadow:0 0 30px rgba(234,0,41,.4),0 0 60px rgba(234,0,41,.2)}
}
.hero-title .red-text{animation:redGlow 3s ease-in-out infinite}

/* 버튼 프리미엄 효과 */
.btn-primary,.btn-line{
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  transition:left .6s ease;
}
.btn-primary:hover::before{left:100%}
.btn-primary{transition:all .3s cubic-bezier(.34,1.56,.64,1)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(234,0,41,.35)}

.btn-line{transition:all .3s cubic-bezier(.34,1.56,.64,1)}
.btn-line:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(234,0,41,.25)}

/* 이름 블록 광채 효과 */
.name-block{
  position:relative;overflow:hidden;
}
.name-block::after{
  content:"";position:absolute;top:-50%;left:-100%;
  width:60%;height:200%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  transform:skewX(-20deg);
  animation:nameShine 4s ease-in-out infinite;
}
@keyframes nameShine{
  0%,100%{left:-100%}
  50%{left:150%}
}

/* 숫자 카운트업 반짝임 */
.hero-meta-value{position:relative}
.hero-meta-value::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transform:translateX(-100%);
  animation:statShine 5s ease-in-out infinite;
  pointer-events:none;
}
@keyframes statShine{
  0%,85%{transform:translateX(-100%)}
  95%{transform:translateX(100%)}
  100%{transform:translateX(100%)}
}

/* 섹션 헤더 언더라인 애니메이션 */
.section-eyebrow::before{
  transition:width .6s cubic-bezier(.22,1,.36,1);
}
.section-eyebrow.visible::before{animation:eyebrowGrow .8s cubic-bezier(.22,1,.36,1)}
@keyframes eyebrowGrow{
  from{width:0}
  to{width:24px}
}

/* 공약 카드 3D 틸트 */
.pledge-row{
  transition:all .4s cubic-bezier(.22,1,.36,1) !important;
  will-change:transform;
}

/* 슬로건 박스 둥둥 */
@keyframes sloganFloat{
  0%,100%{transform:rotate(-1.5deg) translateY(0)}
  50%{transform:rotate(-1.5deg) translateY(-4px)}
}
.hero-slogan{animation:heroSlideIn 1s cubic-bezier(.22,1,.36,1) .15s both, sloganFloat 4s ease-in-out 1s infinite}

/* 프로젝트 배지 부드러운 등장 */
.project-badge{
  transition:all .4s cubic-bezier(.34,1.56,.64,1);
}
.project-badge:hover{
  transform:translateY(-4px) scale(1.02);
  box-shadow:0 16px 40px rgba(0,0,0,.08);
}

/* Follow 카드 3D 호버 */
.follow-card{will-change:transform}
.follow-card .follow-icon{will-change:transform}

/* Chat 메시지 smooth slide */
.msg{animation:msgSlide .4s cubic-bezier(.22,1,.36,1)}
@keyframes msgSlide{
  from{opacity:0;transform:translateY(12px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* Share 버튼 파티클 효과 */
.share-btn{position:relative;overflow:hidden}
.share-btn::after{
  content:"";position:absolute;top:50%;left:50%;
  width:0;height:0;border-radius:50%;
  background:rgba(234,0,41,.1);
  transform:translate(-50%,-50%);
  transition:width .5s ease,height .5s ease;
  pointer-events:none;
}
.share-btn:hover::after{width:200%;height:200%}

/* Vision 섹션 풍성한 효과 */
.vision-section::before{
  animation:visionBarGrow 1.5s cubic-bezier(.22,1,.36,1) .3s both;
}
@keyframes visionBarGrow{
  from{width:0}
  to{width:50%}
}

/* 스무스한 전체 스크롤 */
html{scroll-padding-top:100px}

/* Reduced motion 접근성 */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none}
}

/* ==========================================================
   Header — 김철민.com 스타일 (얇고 깔끔)
   ========================================================== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(20px) saturate(1.8);
  -webkit-backdrop-filter:blur(20px) saturate(1.8);
  border-bottom:1px solid transparent;
  transition:all .4s cubic-bezier(.22,1,.36,1);
}
.site-header.scrolled{
  background:rgba(255,255,255,.95);
  border-bottom-color:var(--gray-200);
  box-shadow:0 4px 30px rgba(0,0,0,.06);
}
.site-header.hide{transform:translateY(-100%)}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
}
/* ===== Premium Brand Logo (기호 2번) ===== */
.brand{
  display:flex;align-items:center;gap:14px;
  position:relative;transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.brand:hover{transform:translateY(-1px)}

.brand-mark{
  position:relative;width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  flex:none;
}
.brand-mark-num{
  position:relative;z-index:3;
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#EA0029 0%,#C50020 100%);
  color:#fff;font-size:19px;font-weight:900;letter-spacing:-.05em;
  display:flex;align-items:center;justify-content:center;
  box-shadow:
    0 4px 12px rgba(234,0,41,.35),
    inset 0 1px 0 rgba(255,255,255,.25),
    inset 0 -2px 4px rgba(0,0,0,.12);
  animation:brandPulse 3s ease-in-out infinite;
}
.brand-mark-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid var(--red);opacity:.4;
  animation:brandRing 2s ease-out infinite;
}
.brand-mark-shine{
  position:absolute;top:3px;left:8px;
  width:14px;height:8px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(255,255,255,.55) 0%,transparent 70%);
  z-index:4;pointer-events:none;
}
@keyframes brandPulse{
  0%,100%{box-shadow:0 4px 12px rgba(234,0,41,.35),inset 0 1px 0 rgba(255,255,255,.25),inset 0 -2px 4px rgba(0,0,0,.12)}
  50%{box-shadow:0 6px 20px rgba(234,0,41,.55),inset 0 1px 0 rgba(255,255,255,.3),inset 0 -2px 4px rgba(0,0,0,.12)}
}
@keyframes brandRing{
  0%{transform:scale(.9);opacity:.6}
  100%{transform:scale(1.35);opacity:0}
}
.brand:hover .brand-mark-num{transform:rotate(-8deg) scale(1.05)}
.brand-mark-num{transition:transform .4s cubic-bezier(.34,1.56,.64,1)}

.brand-text{line-height:1.2;position:relative}
.brand-text strong{
  display:flex;align-items:center;gap:6px;
  font-size:17px;font-weight:900;
  letter-spacing:-.04em;color:var(--black);
  white-space:nowrap;
}
.brand-check{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;
  background:linear-gradient(135deg,#EA0029,#C50020);
  color:#fff;font-size:8px;
  box-shadow:0 2px 6px rgba(234,0,41,.4);
  animation:checkBob 2.5s ease-in-out infinite;
}
@keyframes checkBob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-2px)}
}
.brand-text small{
  font-size:11px;color:var(--gray-500);font-weight:600;letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:6px;
}
/* 🎯 국민의힘 pill (헤더) — 세련된 미니 배지 */
.party-pill{
  display:inline-flex;align-items:center;
  background:var(--red);color:#fff;
  padding:2px 9px;border-radius:10px;
  font-size:10px;font-weight:800;letter-spacing:.02em;
  box-shadow:0 2px 6px rgba(234,0,41,.25);
}
.brand-sep{color:var(--gray-300);margin:0 2px}

.main-nav{display:flex;gap:36px}
.main-nav a{
  font-size:15px;font-weight:600;color:var(--gray-700);
  letter-spacing:-.01em;transition:color .2s;position:relative;
}
.main-nav a:hover{color:var(--red)}

.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 22px;
  background:var(--red);color:#fff;
  font-size:14px;font-weight:700;letter-spacing:-.01em;
  transition:background .2s;
  border-radius:0;
}
.btn-primary:hover{background:var(--red-dark)}

/* ==========================================================
   Hero — 큰 타이포 중심 미니멀
   ========================================================== */
.hero{
  padding:120px 0 100px;
  border-bottom:1px solid var(--gray-200);
  position:relative;
  overflow:hidden;
}
/* ===== Hero Grid — 데스크탑: 좌(태그+텍스트) / 우(사진) 2-column ===== */
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  grid-template-areas:
    "tag  visual"
    "text visual";
  gap:20px 48px;
  align-items:center;
}
.hero-grid > .hero-tag{grid-area:tag;align-self:end}
.hero-text{grid-area:text;min-width:0}
.hero-visual{
  grid-area:visual;min-width:0;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  background:transparent;
}

/* ===== Hero Visual — 인물사진 크게, 테두리/배경 완전 없음 ===== */
.hero-photo-wrap{
  position:relative;
  width:100%;
  max-width:640px;
  margin:0 auto;
  display:flex;align-items:flex-end;justify-content:center;
  background:transparent !important;
  border:0 !important;
}

/* 사진 자체 — 테두리/박스/배경 완전 제거, 순수 투명 PNG + 💓 심장박동 애니메이션 */
.hero-photo{
  position:relative;z-index:2;
  width:100%;height:auto;
  max-height:640px;
  background:transparent !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  object-fit:contain;object-position:bottom center;
  filter:drop-shadow(0 24px 40px rgba(0,0,0,.14))
         drop-shadow(0 8px 16px rgba(0,0,0,.06));
  transform-origin:bottom center;
  /* 등장 후 지속적인 심장박동 */
  animation:
    photoEntrance 1.2s cubic-bezier(.22,1,.36,1) .2s both,
    photoHeartbeat 1.4s ease-in-out 1.4s infinite;
  transition:filter .4s;
}

/* 1. 초기 등장 */
@keyframes photoEntrance{
  0%{opacity:0;transform:translateY(30px) scale(.96)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

/* 2. 💓 심장박동 — 실제 심전도 리듬(두번 박동 → 쉼) */
@keyframes photoHeartbeat{
  0%   {transform:scale(1)}
  14%  {transform:scale(1.025)}   /* 첫 번째 수축 (큰 박동) */
  28%  {transform:scale(1)}
  42%  {transform:scale(1.018)}   /* 두 번째 수축 (작은 박동) */
  70%  {transform:scale(1)}
  100% {transform:scale(1)}        /* 휴식 구간 */
}

/* 호버 시 심장박동 잠시 멈추고 살짝 들어올림 */
.hero-photo-wrap:hover .hero-photo{
  animation:
    photoEntrance 1.2s cubic-bezier(.22,1,.36,1) both,
    photoLift .6s cubic-bezier(.22,1,.36,1) 1.4s forwards;
  filter:drop-shadow(0 30px 50px rgba(234,0,41,.18))
         drop-shadow(0 10px 20px rgba(0,0,0,.08));
}
@keyframes photoLift{
  to{transform:translateY(-8px) scale(1.02)}
}

/* 접근성: 모션 민감 사용자에게는 심장박동 애니메이션 비활성 */
@media (prefers-reduced-motion: reduce){
  .hero-photo{
    animation:photoEntrance 1s ease both !important;
  }
}

/* ===== 네비게이션 외부 링크 (지난 4년 구미 이야기) ===== */
.main-nav .nav-ext{
  display:inline-flex;align-items:center;gap:5px;
  position:relative;
  color:var(--red) !important;
  font-weight:800;
}
.main-nav .nav-ext::before{
  content:"NEW";
  position:absolute;top:-10px;right:-14px;
  background:var(--red);color:#fff;
  font-size:8px;font-weight:900;letter-spacing:.06em;
  padding:2px 5px;line-height:1;
  transform:scale(.92);
  box-shadow:0 2px 6px rgba(234,0,41,.4);
}
.main-nav .nav-ext .nav-ext-ico{
  font-size:10px;opacity:.7;transition:transform .2s;
}
.main-nav .nav-ext:hover .nav-ext-ico{
  transform:translate(2px,-2px);opacity:1;
}

.mobile-ext{
  background:var(--red-soft) !important;
  color:var(--red) !important;
  font-weight:800 !important;
  display:flex !important;align-items:center;gap:10px;
  padding-left:16px !important;
  border-left:3px solid var(--red) !important;
}
.mobile-ext .ext-ico{
  margin-left:auto;font-size:12px;opacity:.7;
}

.hero-tag{
  display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:13px;font-weight:700;color:var(--red);
  letter-spacing:.02em;max-width:100%;
}
/* ===== 🎯 기호 2번 · 국민의힘 · 현.구미시장 — 3단 강조 태그 ===== */
.hero-tag-no{
  display:inline-flex;align-items:center;gap:4px;
  color:var(--black);font-weight:800;
  padding:4px 10px;border:1.5px solid var(--black);border-radius:4px;
}
.hero-tag-no b{color:var(--red);font-size:15px;font-weight:900;}
.hero-tag-party{
  display:inline-flex;align-items:center;
  background:var(--red);color:#fff;
  padding:5px 14px;border-radius:4px;
  font-weight:800;letter-spacing:.02em;
  box-shadow:0 2px 10px rgba(234,0,41,.28);
  position:relative;
}
.hero-tag-pos{
  display:inline-flex;align-items:center;
  color:var(--gray-700);font-weight:700;
  padding:4px 10px;background:var(--gray-100);border-radius:4px;
}

/* ===== Hero Slogan — "맡겨보니 시켜보니 역시!" ===== */
.hero-slogan{
  display:inline-flex;gap:6px;flex-wrap:wrap;
  background:var(--red);padding:14px 20px;
  margin-bottom:28px;
  transform:rotate(-1.5deg);
  box-shadow:6px 6px 0 rgba(0,0,0,.08);
}
.hero-slogan span{
  font-size:22px;font-weight:900;color:#fff;
  letter-spacing:-.03em;line-height:1;
}
.hero-slogan .accent{
  color:#FFEB3B;font-size:26px;
  text-shadow:1px 1px 0 rgba(0,0,0,.15);
}
@media (max-width:640px){
  .hero-slogan{padding:10px 14px;margin-bottom:20px;gap:4px}
  .hero-slogan span{font-size:17px}
  .hero-slogan .accent{font-size:20px}
}

/* ===== 3대 프로젝트 배지 ===== */
.projects-intro{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin:32px 0 40px;
}
.project-badge{
  display:flex;align-items:center;gap:14px;
  padding:20px 22px;background:#fff;
  border:2px solid var(--gray-200);
  transition:all .25s;cursor:default;
  position:relative;overflow:hidden;
}
.project-badge::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:6px;
  transition:width .25s;
}
.project-badge:hover::before{width:100%;opacity:.05}
.project-badge-red::before{background:var(--red)}
.project-badge-navy::before{background:#003A7E}
.project-badge-green::before{background:#2E7D32}
.project-badge-red:hover{border-color:var(--red)}
.project-badge-navy:hover{border-color:#003A7E}
.project-badge-green:hover{border-color:#2E7D32}
.project-badge .p-num{
  font-size:32px;font-weight:900;letter-spacing:-.05em;
  line-height:1;position:relative;z-index:2;
}
.project-badge-red .p-num{color:var(--red)}
.project-badge-navy .p-num{color:#003A7E}
.project-badge-green .p-num{color:#2E7D32}
.project-badge strong{
  display:block;font-size:15px;font-weight:900;color:var(--black);
  letter-spacing:-.02em;line-height:1.3;margin-bottom:3px;
  position:relative;z-index:2;
}
.project-badge em{
  font-style:normal;font-size:12px;color:var(--gray-500);
  font-weight:600;position:relative;z-index:2;
}
@media (max-width:760px){
  .projects-intro{grid-template-columns:1fr;gap:10px;margin:24px 0 32px}
  .project-badge{padding:16px 18px}
  .project-badge .p-num{font-size:26px}
  .project-badge strong{font-size:14px}
}
.hero-tag::before{
  content:"";width:32px;height:2px;background:var(--red);
}
.hero-title{
  font-size:clamp(40px,5.2vw,76px);
  font-weight:900;line-height:1.15;letter-spacing:-.04em;
  color:var(--black);margin-bottom:32px;
  word-break:keep-all;     /* 한글 단어 중간에서 줄바꿈 방지 */
  overflow-wrap:break-word;
}
.hero-title .red-text{color:var(--red)}
.hero-title .name-block{
  display:inline-block;
  background:var(--red);color:#fff;
  padding:0 14px 3px;
}
/* 🎨 "김장호" — 검정 배경 + 흰 글씨 (사용자 요청) */
.hero-title .name-block-black{
  display:inline-block;
  background:var(--black);color:#fff;
  padding:0 14px 3px;
  position:relative;
  box-shadow:5px 5px 0 rgba(234,0,41,.2);
}
.hero-sub{
  font-size:20px;line-height:1.7;color:var(--gray-700);
  max-width:640px;margin-bottom:48px;font-weight:500;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:64px}
.btn-line{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 22px;
  background:transparent;color:var(--red);
  border:1.5px solid var(--red);
  font-size:14px;font-weight:700;letter-spacing:-.01em;
  transition:all .2s;
}
.btn-line:hover{background:var(--red);color:#fff}

/* Hero meta strip (빨간 배경 강조) */
.hero-meta{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:var(--red);color:#fff;
  padding:36px 32px;margin-top:16px;
  position:relative;overflow:hidden;
}
.hero-meta::before{
  content:"";position:absolute;top:-50%;right:-10%;width:400px;height:400px;
  background:radial-gradient(circle, rgba(255,255,255,.08) 0%, transparent 70%);
  pointer-events:none;
}
.hero-meta-item{
  border-right:1px solid rgba(255,255,255,.2);padding:0 24px;
  position:relative;z-index:2;
}
.hero-meta-item:first-child{padding-left:0}
.hero-meta-item:last-child{border-right:none;padding-right:0}
.hero-meta-label{
  font-size:11px;font-weight:700;color:rgba(255,255,255,.8);
  letter-spacing:.12em;margin-bottom:10px;text-transform:uppercase;
}
.hero-meta-value{
  font-size:28px;font-weight:900;color:#fff;
  letter-spacing:-.02em;
}
.hero-meta-value .unit{font-size:14px;color:rgba(255,255,255,.75);font-weight:700;margin-left:4px}

/* ==========================================================
   Section Heading 공통
   ========================================================== */
.section{padding:120px 0;border-bottom:1px solid var(--gray-200)}
.section-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:800;letter-spacing:.2em;
  color:var(--red);text-transform:uppercase;margin-bottom:20px;
}
.section-eyebrow::before{
  content:"";width:24px;height:2px;background:var(--red);
}
.section-title{
  font-size:clamp(32px,4.5vw,52px);
  font-weight:900;letter-spacing:-.035em;line-height:1.15;
  color:var(--black);margin-bottom:18px;
}
.section-desc{
  font-size:17px;color:var(--gray-500);max-width:600px;line-height:1.7;
}
.section-head-row{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:60px;flex-wrap:wrap;gap:20px;
}

/* ==========================================================
   🎯 국민의힘 공식 후보 배너 (Hero 아래, AI Chat 위)
   ========================================================== */
.party-banner{
  background:linear-gradient(120deg,#B8001E 0%,var(--red) 50%,var(--red-dark) 100%);
  color:#fff;
  padding:32px 0;
  position:relative;
  overflow:hidden;
  border-top:1px solid rgba(0,0,0,.15);
  border-bottom:1px solid rgba(0,0,0,.15);
}
/* 좌상단 → 우하단 세로 라인 무늬 (아주 섬세하게) */
.party-banner::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(0,0,0,.12) 0%,transparent 40%,transparent 60%,rgba(0,0,0,.15) 100%),
    repeating-linear-gradient(90deg,
      transparent 0,transparent 60px,
      rgba(255,255,255,.025) 60px,rgba(255,255,255,.025) 61px);
  pointer-events:none;
}
/* 우측 빛 번짐 */
.party-banner::after{
  content:"";position:absolute;top:-40%;right:-5%;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 65%);
  pointer-events:none;
  animation:partyGlow 5s ease-in-out infinite;
}
@keyframes partyGlow{
  0%,100%{opacity:.5;transform:scale(1)}
  50%{opacity:.9;transform:scale(1.08)}
}
.party-banner-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:28px;flex-wrap:wrap;position:relative;z-index:1;
}
.party-banner-left{
  display:flex;align-items:center;flex-shrink:0;
}
.party-banner-right{
  display:flex;align-items:center;flex-shrink:0;
}
/* 🔷 국민의힘 공식 로고 — 흰 배경 카드 안에 배치 */
.party-banner-logo{
  height:48px;width:auto;display:block;
  background:#fff;padding:12px 18px;border-radius:10px;
  box-shadow:
    0 10px 24px rgba(0,0,0,.2),
    0 2px 4px rgba(0,0,0,.12),
    inset 0 -2px 0 rgba(0,0,0,.06);
  transition:transform .3s cubic-bezier(.22,1,.36,1);
}
.party-banner-logo:hover{transform:translateY(-2px) scale(1.02)}
.party-banner-center{
  flex:1;min-width:0;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
}
.party-banner-caption{
  font-size:clamp(20px,2.4vw,30px);
  font-weight:900;color:#fff;
  letter-spacing:-.025em;line-height:1.2;
  text-shadow:0 2px 8px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.15);
  word-break:keep-all;
}
.party-num-big{
  display:inline-flex;align-items:baseline;
  padding:10px 22px;
  background:#fff;color:#222;
  border-radius:10px;font-weight:900;
  font-size:18px;letter-spacing:-.02em;
  box-shadow:
    0 8px 20px rgba(0,0,0,.18),
    0 2px 4px rgba(0,0,0,.12),
    inset 0 -3px 0 rgba(0,0,0,.08);
  transition:transform .3s cubic-bezier(.22,1,.36,1);
  flex-shrink:0;
}
.party-num-big:hover{transform:translateY(-2px) scale(1.03)}
.party-num-big b{font-size:30px;color:var(--red);margin:0 3px;letter-spacing:-.03em}
/* party-banner-right, check 요소 제거됨 */

/* 배너 모바일 대응 — 한 줄 유지 */
@media (max-width:760px){
  .party-banner{padding:18px 0}
  .party-banner-inner{
    gap:10px;flex-direction:row;flex-wrap:nowrap;
    justify-content:space-between;align-items:center;
  }
  .party-banner-left,.party-banner-right{justify-content:center;flex-shrink:0}
  .party-banner-logo{height:32px;padding:7px 10px;border-radius:7px}
  .party-banner-center{flex:1;min-width:0}
  .party-banner-caption{
    font-size:14px;line-height:1.25;
    display:block;white-space:nowrap;
    overflow:hidden;text-overflow:ellipsis;
  }
  .party-num-big{font-size:13px;padding:6px 12px;border-radius:7px}
  .party-num-big b{font-size:20px;margin:0 2px}
}
@media (max-width:480px){
  .party-banner{padding:14px 0}
  .party-banner-inner{gap:8px}
  .party-banner-logo{height:28px;padding:6px 8px}
  .party-banner-caption{font-size:12px;letter-spacing:-.03em}
  .party-num-big{font-size:11px;padding:5px 10px}
  .party-num-big b{font-size:17px}
}
@media (max-width:380px){
  .party-banner-inner{gap:6px}
  .party-banner-logo{height:26px;padding:5px 7px;border-radius:6px}
  .party-banner-caption{font-size:11px}
  .party-num-big{font-size:10px;padding:4px 8px;border-radius:6px}
  .party-num-big b{font-size:15px;margin:0 1px}
}

/* ==========================================================
   AI 채팅 섹션
   ========================================================== */
.chat-section{background:var(--gray-50)}
.chat-box{
  background:#fff;border:1px solid var(--gray-200);
  max-width:900px;margin:0 auto;
}
.chat-header{
  display:flex;align-items:center;gap:14px;
  padding:22px 28px;border-bottom:1px solid var(--gray-200);
}
.chat-header-mark{
  width:42px;height:42px;background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:16px;
  box-shadow:0 6px 16px rgba(234,0,41,.25);
}
.chat-header-text strong{
  display:block;font-size:16px;font-weight:800;letter-spacing:-.02em;
}
.chat-header-text span{font-size:13px;color:var(--gray-500)}
.chat-status{
  margin-left:auto;display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;background:var(--red-soft);color:var(--red);
  font-size:11px;font-weight:800;letter-spacing:.05em;
}
.chat-status::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--red);
  animation:pulse 1.5s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(234,0,41,.5)}
  50%{box-shadow:0 0 0 6px rgba(234,0,41,0)}
}

.chat-messages{
  padding:28px;max-height:420px;overflow-y:auto;
  display:flex;flex-direction:column;gap:18px;
}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--gray-300)}
.msg{display:flex;gap:12px;align-items:flex-start;animation:fadeUp .3s}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg-avatar{
  flex:none;width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;font-size:13px;
}
.msg-bot .msg-avatar{background:var(--red);color:#fff}
.msg-user .msg-avatar{background:var(--red-dark);color:#fff}
.msg-bubble{
  padding:14px 18px;font-size:15px;line-height:1.7;
  background:var(--gray-100);max-width:85%;color:var(--gray-900);
}
.msg-user{flex-direction:row-reverse}
.msg-user .msg-bubble{background:var(--red);color:#fff}
.msg-bubble strong{color:var(--red);font-weight:800}
.msg-user .msg-bubble strong{color:#fff;border-bottom:1px solid rgba(255,255,255,.5)}
.msg-bubble ul{margin:8px 0 0 20px}
.msg-bubble li{margin-bottom:5px}

.chat-suggestions{
  display:flex;flex-wrap:wrap;gap:8px;
  padding:0 28px 22px;
}
.suggestion-chip{
  padding:9px 16px;border:1px solid var(--gray-200);
  background:#fff;font-size:13px;font-weight:600;color:var(--gray-700);
  transition:all .2s;
}
.suggestion-chip i{color:var(--red);margin-right:7px;transition:color .2s}
.suggestion-chip:hover{
  border-color:var(--red);color:var(--red);background:var(--red-soft);
}

.chat-input-wrap{
  display:flex;align-items:center;gap:0;
  border-top:1px solid var(--gray-200);
}
#chat-input{
  flex:1;border:none;outline:none;
  font-size:15px;padding:18px 28px;background:transparent;
  font-family:inherit;
}
#chat-send{
  width:60px;align-self:stretch;
  background:var(--red);color:#fff;font-size:16px;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
#chat-send:hover{background:var(--red-dark)}

.chat-hint{
  padding:14px 28px;font-size:12px;color:var(--gray-500);
  border-top:1px solid var(--gray-200);background:var(--gray-50);
  display:flex;align-items:center;gap:6px;
}
.chat-hint i{color:var(--red)}

/* ==========================================================
   공약 — 김철민.com 스타일 리스트형 카드
   ========================================================== */
.category-tabs{
  display:flex;flex-wrap:wrap;gap:0;
  border-bottom:2px solid var(--gray-200);margin-bottom:0;
}
.cat-tab{
  padding:16px 22px;
  font-size:15px;font-weight:700;color:var(--gray-500);
  letter-spacing:-.01em;transition:all .2s;
  position:relative;border:none;background:transparent;
  display:inline-flex;align-items:center;gap:8px;
}
.cat-tab i{font-size:13px}
.cat-tab::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--red);transform:scaleX(0);transition:transform .25s;
}
.cat-tab:hover{color:var(--black)}
.cat-tab.active{color:var(--red)}
.cat-tab.active::after{transform:scaleX(1)}

.pledge-list{
  border-top:none;
  max-height: 650px; /* Show about 5 items */
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 5%, black 95%, transparent);
  mask-image: linear-gradient(to bottom, transparent, black 5%, black 95%, transparent);
}

.pledge-scroll-inner {
  display: flex;
  flex-direction: column;
  animation: scroll-up 45s linear infinite;
}

.pledge-scroll-inner:hover {
  animation-play-state: paused;
}

@keyframes scroll-up {
  0% { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

.pledge-row{
  display:grid;grid-template-columns:80px 1fr auto;gap:32px;
  align-items:center;padding:36px 8px;
  border-bottom:1px solid var(--gray-200);
  cursor:pointer;transition:all .2s;
  position:relative;
}
.pledge-row::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--red);transition:width .25s;
}
.pledge-row:hover{padding-left:24px;background:var(--gray-50)}
.pledge-row:hover::before{width:4px}
.pledge-num-big{
  font-size:46px;font-weight:900;color:var(--red);
  letter-spacing:-.05em;font-family:'Pretendard';line-height:1;
}
.pledge-row-content h3{
  font-size:24px;font-weight:800;letter-spacing:-.025em;
  color:var(--black);margin-bottom:8px;line-height:1.3;
}
.pledge-row-content p{
  font-size:15px;color:var(--gray-500);line-height:1.6;margin-bottom:10px;
}
.pledge-row-meta{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-size:12px;color:var(--gray-500);
}
.pledge-row-cat{
  display:inline-block;padding:3px 10px;
  background:var(--red-soft);color:var(--red);
  font-size:11px;font-weight:800;letter-spacing:.03em;
}
.pledge-row-keywords{display:flex;gap:6px;flex-wrap:wrap}
.pledge-row-keywords span{color:var(--gray-500);font-weight:600}
.pledge-row-arrow{
  width:48px;height:48px;border:1.5px solid var(--gray-200);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--gray-700);transition:all .25s;
}
.pledge-row:hover .pledge-row-arrow{
  background:var(--red);border-color:var(--red);color:#fff;
  transform:rotate(-45deg);
}

/* Pledge detail (인라인 확장형) */
.pledge-detail{
  border-bottom:1px solid var(--gray-200);
  background:var(--gray-50);padding:60px 8px;
  animation:fadeUp .3s ease;position:relative;
}
.pledge-detail-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:20px;margin-bottom:32px;
}
.pledge-detail-cat{
  display:inline-block;padding:5px 14px;
  background:var(--red);color:#fff;
  font-size:11px;font-weight:800;letter-spacing:.05em;margin-bottom:14px;
}
.pledge-detail h3{
  font-size:36px;font-weight:900;letter-spacing:-.03em;
  line-height:1.15;color:var(--black);max-width:800px;
}
.pledge-detail-close{
  width:42px;height:42px;flex:none;
  background:#fff;border:1.5px solid var(--gray-200);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--gray-700);transition:all .2s;
}
.pledge-detail-close:hover{background:var(--red);color:#fff;border-color:var(--red);transform:rotate(90deg)}
.pledge-detail-summary{
  font-size:18px;line-height:1.7;color:#fff;
  padding:24px 28px;background:var(--red);border-left:4px solid #fff;
  margin-bottom:32px;font-weight:600;
  box-shadow:0 10px 30px rgba(234,0,41,.2);
}
.pledge-detail-body{
  font-size:16px;line-height:1.9;color:var(--gray-900);
  background:#fff;padding:32px;
}
.pledge-detail-body strong{color:var(--red);font-weight:800}
.pledge-detail-body ul{margin:14px 0 14px 22px}
.pledge-detail-body li{margin-bottom:8px}
.pledge-detail-keys{display:flex;gap:8px;flex-wrap:wrap;margin-top:24px}
.pledge-detail-keys span{
  font-size:12px;font-weight:700;color:var(--gray-700);
  padding:5px 12px;background:#fff;border:1px solid var(--gray-200);
}
.pledge-detail-actions{
  display:flex;gap:10px;flex-wrap:wrap;margin-top:32px;
}

/* ==========================================================
   비전 섹션 (빨간 배경 + 흰 글씨)
   ========================================================== */
.vision-section{
  background:var(--red);color:#fff;padding:140px 0;
  border-bottom:none;position:relative;overflow:hidden;
}
.vision-section::before{
  content:"";position:absolute;top:0;left:0;width:50%;height:6px;
  background:#fff;
}
.vision-section::after{
  content:"";position:absolute;top:-40%;right:-10%;width:600px;height:600px;
  background:radial-gradient(circle, rgba(255,255,255,.08) 0%, transparent 70%);
  pointer-events:none;
}
.vision-section .container{position:relative;z-index:2}
.vision-section .section-eyebrow{color:#fff}
.vision-section .section-eyebrow::before{background:#fff}
.vision-content{max-width:820px}
.vision-content h2{
  font-size:clamp(36px,5vw,64px);
  font-weight:900;letter-spacing:-.035em;line-height:1.1;
  color:#fff;margin-bottom:32px;
}
.vision-content h2 .red-text{
  color:#fff;display:inline-block;position:relative;
}
.vision-content h2 .red-text::after{
  content:"";position:absolute;left:0;right:0;bottom:2px;height:8px;
  background:rgba(255,255,255,.25);z-index:-1;
}
.vision-content > p{
  font-size:19px;line-height:1.8;color:rgba(255,255,255,.92);
  font-weight:500;margin-bottom:40px;
}
.vision-content > p strong{color:#fff;font-weight:800}
.vision-quote{
  border-left:4px solid #fff;padding:20px 0 20px 28px;
  font-size:17px;line-height:1.75;color:#fff;
  font-style:italic;background:rgba(255,255,255,.08);
  border-radius:0 6px 6px 0;
}
.vision-quote cite{
  display:block;margin-top:14px;font-style:normal;
  font-size:13px;font-weight:800;color:#fff;letter-spacing:.05em;
  opacity:.85;
}

/* ==========================================================
   시민 목소리
   ========================================================== */
.voices-section{background:var(--gray-50)}
.voices-layout{display:grid;grid-template-columns:380px 1fr;gap:48px}
.voice-form{
  background:#fff;border:1px solid var(--gray-200);
  padding:32px;position:sticky;top:calc(var(--header-h) + 20px);
  height:fit-content;
}
.voice-form h3{
  font-size:16px;font-weight:900;letter-spacing:-.01em;
  margin-bottom:24px;color:#fff;
  padding:10px 18px;background:var(--red);display:inline-block;
}
.voice-form label{display:block;margin-bottom:18px}
.voice-form label span{
  display:block;font-size:12px;font-weight:800;
  color:var(--gray-700);margin-bottom:8px;letter-spacing:.02em;
  text-transform:uppercase;
}
.voice-form input,.voice-form select,.voice-form textarea{
  width:100%;padding:12px 14px;
  border:1px solid var(--gray-200);
  font-size:14px;font-family:inherit;
  background:var(--gray-50);transition:all .2s;outline:none;
  border-radius:0;
}
.voice-form input:focus,.voice-form select:focus,.voice-form textarea:focus{
  border-color:var(--red);background:#fff;
}
.voice-form textarea{resize:vertical}
.voice-form .btn-primary{width:100%;justify-content:center;padding:14px;margin-top:6px}
.form-hint{font-size:11px;color:var(--gray-500);margin-top:10px;text-align:center;line-height:1.6}

/* 개인정보 미수집 안내 */
.privacy-notice{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;margin-bottom:18px;
  background:var(--gray-50);border-left:3px solid var(--red);
  font-size:12.5px;color:var(--gray-700);line-height:1.5;
}
.privacy-notice i{
  color:var(--red);font-size:16px;flex:none;
}
.privacy-notice strong{color:var(--red);font-weight:800}

/* ============================================================
   🔴 LIVE 배지 — 방송 스타일 미니멀 (LIVE만 표시)
   ============================================================ */
.sheets-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px 7px 10px;margin-bottom:18px;
  background:#0f0f0f;
  color:#fff;
  position:relative;overflow:hidden;
  box-shadow:
    0 4px 16px rgba(255,23,68,.25),
    inset 0 1px 0 rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  cursor:help;
}
.sheets-badge::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(45deg,
    transparent 0,transparent 12px,
    rgba(255,255,255,.02) 12px,rgba(255,255,255,.02) 24px);
}

/* 🔴 빨간 점 (LIVE 인디케이터) */
.live-dot{
  position:relative;
  width:10px;height:10px;flex:none;
  display:inline-flex;align-items:center;justify-content:center;
  margin-left:2px;
}
.live-dot-core{
  position:relative;z-index:2;
  width:10px;height:10px;border-radius:50%;
  background:#FF1744;
  box-shadow:0 0 8px #FF1744,0 0 2px #fff inset;
  animation:liveCore 1.2s ease-in-out infinite;
}
@keyframes liveCore{
  0%,100%{transform:scale(1);box-shadow:0 0 8px #FF1744,0 0 2px #fff inset}
  50%{transform:scale(1.15);box-shadow:0 0 14px #FF1744,0 0 4px #fff inset}
}
.live-dot-ring{
  position:absolute;inset:-4px;border-radius:50%;
  border:2px solid #FF1744;opacity:.6;
  animation:liveRing 1.6s ease-out infinite;
}
@keyframes liveRing{
  0%{transform:scale(.6);opacity:.8}
  100%{transform:scale(1.8);opacity:0}
}

/* "LIVE" 텍스트 */
.live-label{
  font-size:12px;font-weight:900;letter-spacing:.22em;
  color:#FF1744;
  text-shadow:0 0 6px rgba(255,23,68,.5);
  font-family:'Pretendard',sans-serif;
  padding-right:2px;
}

.voice-form label span em.required{
  color:var(--red);font-style:normal;margin-left:2px;
}

.sheets-link{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin-top:14px;padding:10px;
  background:transparent;border:1px solid var(--gray-200);
  font-size:11px;font-weight:700;color:var(--gray-500);
  letter-spacing:.02em;transition:all .2s;
}
.sheets-link:hover{
  border-color:var(--red);color:var(--red);background:var(--red-soft);
}
.sheets-link i{font-size:10px}

.voice-list{display:flex;flex-direction:column;gap:0}
.voice-item{
  background:#fff;border:1px solid var(--gray-200);border-bottom:none;
  padding:24px 28px;transition:all .2s;
  position:relative;
}
.voice-item:last-child{border-bottom:1px solid var(--gray-200)}
.voice-item::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--red);transition:width .25s;
}
.voice-item:hover::before{width:3px}
.voice-meta{
  display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px;
}
.voice-name{font-weight:800;color:var(--black)}
.voice-cat{
  font-size:11px;padding:3px 10px;background:var(--red-soft);color:var(--red);
  font-weight:800;letter-spacing:.02em;
}
.voice-time{color:var(--gray-500);margin-left:auto;font-size:12px;font-weight:600}
.voice-msg{font-size:15px;color:var(--gray-900);line-height:1.7}
.voice-actions{
  margin-top:14px;display:flex;align-items:center;gap:14px;
  font-size:13px;color:var(--gray-500);
}
.voice-like{
  display:inline-flex;align-items:center;gap:6px;padding:5px 12px;
  border:1px solid var(--gray-200);font-weight:700;
  transition:all .2s;cursor:pointer;
}
.voice-like:hover,.voice-like.liked{
  border-color:var(--red);color:var(--red);background:var(--red-soft);
}

/* ==========================================================
   Follow — 공식 SNS 채널 (5종)
   ========================================================== */
.follow-section{background:var(--gray-50)}
.follow-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  max-width:1100px;margin:0 auto;
}
.follow-card{
  position:relative;display:flex;flex-direction:column;
  padding:28px 22px 22px;
  background:#fff;border:1px solid var(--gray-200);
  transition:all .3s cubic-bezier(.4,0,.2,1);
  overflow:hidden;min-height:220px;
}
.follow-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;
}
.follow-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 40px rgba(0,0,0,.08);
  border-color:transparent;
}
.follow-card:hover::before{transform:scaleX(1)}

/* 브랜드별 컬러 */
.follow-blog::before{background:#03C75A}
.follow-blog .follow-icon{background:#03C75A}
.follow-blog:hover .follow-icon{background:#03C75A;color:#fff}

.follow-insta::before{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4)}
.follow-insta .follow-icon{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4)}

.follow-fb::before{background:#1877F2}
.follow-fb .follow-icon{background:#1877F2}

.follow-kakao::before{background:#FEE500}
.follow-kakao .follow-icon{background:#FEE500;color:#3C1E1E}
.follow-kakao:hover .follow-icon{color:#3C1E1E}

.follow-yt::before{background:#FF0000}
.follow-yt .follow-icon{background:#FF0000}

.follow-threads::before{background:#000}
.follow-threads .follow-icon{background:#000}

.follow-icon{
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:22px;margin-bottom:18px;
  transition:transform .3s ease;
}
.follow-card:hover .follow-icon{transform:scale(1.08) rotate(-4deg)}

.follow-text{flex:1;display:flex;flex-direction:column;gap:3px}
.follow-text strong{
  font-size:16px;font-weight:900;color:var(--black);
  letter-spacing:-.02em;line-height:1.2;
}
.follow-text small{
  font-size:12px;color:var(--red);font-weight:700;
  letter-spacing:.02em;font-family:'Pretendard',monospace;
}
.follow-text span{
  font-size:12.5px;color:var(--gray-500);line-height:1.5;
  margin-top:6px;font-weight:500;
}

.follow-arrow{
  position:absolute;top:22px;right:22px;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-300);font-size:12px;
  transition:all .25s ease;
}
.follow-card:hover .follow-arrow{
  color:var(--red);transform:translate(2px,-2px);
}

@media (max-width:980px){
  .follow-grid{grid-template-columns:repeat(3,1fr)}
  .follow-card{min-height:200px;padding:24px 20px 20px}
}
@media (max-width:640px){
  .follow-grid{grid-template-columns:1fr 1fr;gap:10px}
  .follow-card{
    min-height:auto;padding:18px 16px 18px 16px;
    flex-direction:row;align-items:center;gap:14px;
  }
  .follow-icon{
    width:42px;height:42px;font-size:18px;margin-bottom:0;flex:none;
  }
  .follow-text strong{font-size:14px}
  .follow-text small{font-size:11px}
  .follow-text span{display:none}
  .follow-arrow{top:50%;right:14px;transform:translateY(-50%);width:24px;height:24px;font-size:10px}
  .follow-card:hover .follow-arrow{transform:translate(2px,-50%)}
}
@media (max-width:380px){
  .follow-grid{grid-template-columns:1fr}
}

/* Mobile menu social row */
.mobile-menu-social{
  display:flex;justify-content:center;gap:14px;
  padding:28px 0 20px;margin-top:12px;
  border-top:1px solid rgba(255,255,255,.15);
}
.mobile-menu-social a{
  width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.12);color:#fff;
  font-size:16px;border:none;padding:0;
  border-radius:50%;
  transition:all .2s;
}
.mobile-menu-social a::after{content:"";display:none}
.mobile-menu-social a:active{
  background:#fff;color:var(--red);transform:scale(.95);
}

/* ==========================================================
   SNS 공유
   ========================================================== */
.share-section{background:var(--white);text-align:center}
.share-buttons{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  max-width:900px;margin:0 auto 48px;
  border:1px solid var(--gray-200);
}
.share-btn{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:32px 16px;
  border-right:1px solid var(--gray-200);
  background:#fff;color:var(--black);
  transition:all .25s;
}
.share-btn:last-child{border-right:none}
.share-btn i{font-size:24px;color:var(--gray-700);transition:color .2s}
.share-btn span{font-size:13px;font-weight:800;letter-spacing:-.01em}
.share-btn small{font-size:10px;font-weight:600;color:var(--gray-500)}
.share-btn:hover{background:var(--red);color:#fff}
.share-btn:hover i,.share-btn:hover small{color:#fff}

.share-cta{
  font-size:18px;font-weight:600;color:var(--black);
  max-width:680px;margin:0 auto;line-height:1.7;
}
.share-cta strong{color:var(--red);font-weight:900}

/* ==========================================================
   Footer (빨간 배경 + 흰 글씨)
   ========================================================== */
.site-footer{
  background:var(--red);color:rgba(255,255,255,.8);padding:64px 0 24px;
  border-top:6px solid #fff;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:24px;
}
.footer-brand strong{
  display:block;font-size:20px;font-weight:900;color:#fff;
  margin-bottom:8px;letter-spacing:-.02em;
}
.footer-brand p{font-size:13px;color:rgba(255,255,255,.75);line-height:1.7;max-width:280px}
.footer-col h4{
  color:#fff;font-size:13px;font-weight:800;margin-bottom:16px;
  letter-spacing:.05em;text-transform:uppercase;
}
.footer-col a{
  display:block;font-size:13px;color:rgba(255,255,255,.8);
  margin-bottom:10px;transition:all .2s;font-weight:500;
}
.footer-col a:hover{color:#fff;padding-left:4px}
.footer-col a i{margin-right:6px;width:14px}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:rgba(255,255,255,.65);flex-wrap:wrap;gap:12px;
}
.footer-highlight{
  color:#fff;font-size:14px;font-weight:900;margin:0 2px;
}
.footer-party{
  display:inline-flex;align-items:center;
  color:#fff;font-weight:800;letter-spacing:.02em;
  padding:2px 9px;background:rgba(234,0,41,.28);
  border:1px solid rgba(234,0,41,.55);border-radius:4px;margin:0 2px;
}

/* ==========================================================
   Toast (빨간 배경 + 흰 글씨)
   ========================================================== */
.toast{
  position:fixed;bottom:32px;left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--red);color:#fff;
  padding:14px 24px;font-size:14px;font-weight:700;
  opacity:0;pointer-events:none;
  transition:all .3s ease;z-index:200;
  border-left:4px solid #fff;
  box-shadow:0 10px 30px rgba(234,0,41,.35);
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}

/* ==========================================================
   Mobile Menu Button (햄버거)
   ========================================================== */
.menu-toggle{
  display:none;
  width:44px;height:44px;
  align-items:center;justify-content:center;
  background:transparent;border:none;
  position:relative;z-index:101;
}
.menu-toggle span{
  position:absolute;left:10px;right:10px;height:2.5px;
  background:var(--black);transition:all .3s ease;
  border-radius:2px;
}
.menu-toggle span:nth-child(1){top:14px}
.menu-toggle span:nth-child(2){top:21px}
.menu-toggle span:nth-child(3){top:28px}
.menu-toggle.active span:nth-child(1){top:21px;transform:rotate(45deg);background:#fff}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){top:21px;transform:rotate(-45deg);background:#fff}

/* Mobile menu overlay */
.mobile-menu{
  display:none;
  position:fixed;inset:0;z-index:99;
  background:var(--red);
  flex-direction:column;
  padding:calc(var(--header-h) + 20px) 24px 32px;
  overflow-y:auto;
  animation:slideDown .3s ease;
}
@keyframes slideDown{
  from{opacity:0;transform:translateY(-10px)}
  to{opacity:1;transform:translateY(0)}
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-size:26px;font-weight:900;color:#fff;
  padding:18px 0;border-bottom:1px solid rgba(255,255,255,.15);
  letter-spacing:-.02em;
  display:flex;align-items:center;justify-content:space-between;
}
.mobile-menu a::after{
  content:"→";font-size:22px;font-weight:700;opacity:.6;
}
.mobile-menu a:active{opacity:.7}
.mobile-menu .mobile-cta{
  margin-top:28px;padding:18px;background:#fff;color:var(--red);
  text-align:center;font-size:16px;font-weight:900;
  display:flex;align-items:center;justify-content:center;gap:10px;
  border-bottom:none;
}
.mobile-menu .mobile-cta::after{content:""}

body.menu-open{overflow:hidden}

/* ==========================================================
   Tablet (max 980px)
   ========================================================== */
@media (max-width:980px){
  .container{padding:0 20px}
  .section{padding:80px 0}
  .vision-section{padding:80px 0}

  /* Header */
  .main-nav{display:none}
  .nav-cta{display:none}
  .menu-toggle{display:inline-flex}

  /* Hero — 모바일: 태그 → 사진 → 텍스트 순서 */
  .hero{padding:28px 0 50px}
  .hero-grid{
    grid-template-columns:1fr;
    grid-template-areas:
      "tag"
      "visual"
      "text";
    gap:16px;
  }
  .hero-grid > .hero-tag{align-self:start;justify-self:start}
  .hero-photo-wrap{max-width:340px;margin:0 auto}
  .hero-photo-num{font-size:clamp(200px, 55vw, 320px);top:-4%}

  .hero-meta{
    grid-template-columns:repeat(2,1fr);
    gap:24px 20px;padding:28px 24px;
  }
  .hero-meta-item{padding:0}
  .hero-meta-item{border-right:none}
  .hero-meta-item:nth-child(1),
  .hero-meta-item:nth-child(3){border-right:1px solid rgba(255,255,255,.2)}
  .hero-meta-item:nth-child(1),
  .hero-meta-item:nth-child(2){padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.2)}
  .hero-meta-item:nth-child(1),
  .hero-meta-item:nth-child(3){padding-right:20px}
  .hero-meta-item:nth-child(2),
  .hero-meta-item:nth-child(4){padding-left:20px}

  /* Voices */
  .voices-layout{grid-template-columns:1fr;gap:28px}
  .voice-form{position:static}

  /* Share */
  .share-buttons{grid-template-columns:repeat(3,1fr)}
  .share-btn:nth-child(3){border-right:none}
  .share-btn:nth-child(n+4){border-top:1px solid var(--gray-200)}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}

  /* Pledges */
  .pledge-row{grid-template-columns:60px 1fr 40px;gap:20px;padding:28px 8px}
  .pledge-num-big{font-size:40px}
  .pledge-row-content h3{font-size:20px}
  .pledge-row-arrow{width:40px;height:40px}
}

/* ==========================================================
   Tablet-Mobile Transition (max 760px) — 접히는폰/큰폰 대응
   ========================================================== */
@media (max-width:760px) and (min-width:641px){
  .hero-title{font-size:44px;line-height:1.2;word-break:keep-all}
  .hero-sub{font-size:17px}
  .hero-photo-wrap{max-width:400px}
  .hero-meta{grid-template-columns:repeat(2,1fr);gap:20px 0}
  .share-buttons{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
}

/* ==========================================================
   Mobile (max 640px)
   ========================================================== */
@media (max-width:640px){
  .container{padding:0 16px}
  :root{--header-h:64px}

  /* Header */
  .site-header{border-bottom:1px solid var(--gray-200)}
  .brand-mark{width:32px;height:32px;font-size:15px}
  .brand-text strong{font-size:14px;letter-spacing:-.045em;gap:4px}
  .brand-check{width:14px;height:14px;font-size:8px}
  .brand-text small{display:none}

  /* Section 공통 */
  .section{padding:60px 0}
  .vision-section{padding:64px 0}
  .section-title{font-size:28px;line-height:1.2}
  .section-desc{font-size:15px}
  .section-eyebrow{font-size:11px;margin-bottom:16px}
  .section-head-row{margin-bottom:32px}

  /* Hero — 모바일: 사진 먼저, 슬로건/타이틀 아래 */
  .hero{padding:24px 0 44px}
  .hero-photo-wrap{max-width:280px;margin:0 auto 4px}
  .hero-tag{font-size:11px;letter-spacing:.02em;gap:6px}
  .hero-tag::before{display:none}
  .hero-tag-no,.hero-tag-party,.hero-tag-pos{padding:3px 8px;font-size:11px}
  .hero-tag-no b{font-size:13px}
  .hero-title{
    font-size:32px;line-height:1.25;margin-bottom:24px;letter-spacing:-.03em;
    word-break:keep-all;
  }
  .hero-title .name-block,
  .hero-title .name-block-black{padding:0 10px 2px;box-shadow:3px 3px 0 rgba(234,0,41,.15)}
  .hero-sub{font-size:15px;margin-bottom:32px;line-height:1.65}
  .hero-actions{gap:10px;margin-bottom:36px;flex-direction:column;align-items:stretch}
  .hero-actions .btn-primary,
  .hero-actions .btn-line{
    width:100%;justify-content:center;padding:14px 20px;font-size:14px;
  }
  .hero-meta{
    grid-template-columns:1fr 1fr;
    padding:24px 20px;gap:0;
  }
  .hero-meta-item{
    padding:14px 16px !important;
    border:none !important;
  }
  .hero-meta-item:nth-child(1),
  .hero-meta-item:nth-child(3){border-right:1px solid rgba(255,255,255,.2) !important}
  .hero-meta-item:nth-child(1),
  .hero-meta-item:nth-child(2){border-bottom:1px solid rgba(255,255,255,.2) !important}
  .hero-meta-label{font-size:10px;margin-bottom:6px;letter-spacing:.08em}
  .hero-meta-value{font-size:22px}
  .hero-meta-value .unit{font-size:12px}

  /* Chat — iOS 자동 줌 방지 (16px 이상 필수) */
  .chat-box{margin:0 -4px}
  .chat-header{padding:16px 20px;gap:10px}
  .chat-header-mark{width:36px;height:36px;font-size:14px}
  .chat-header-text strong{font-size:14px}
  .chat-header-text span{font-size:12px}
  .chat-status{padding:4px 10px;font-size:10px}
  .chat-messages{padding:20px;gap:14px;max-height:360px}
  .msg-bubble{font-size:14px;padding:12px 14px;max-width:88%}
  .msg-avatar{width:28px;height:28px;font-size:11px}
  .chat-suggestions{padding:0 20px 16px;gap:6px}
  .suggestion-chip{padding:8px 12px;font-size:12px}
  .suggestion-chip i{margin-right:5px;font-size:11px}
  #chat-input{padding:14px 18px;font-size:16px}
  #chat-send{width:54px;font-size:15px}
  .chat-hint{padding:12px 18px;font-size:11px}

  /* Pledges */
  .category-tabs{
    overflow-x:auto;flex-wrap:nowrap;
    -webkit-overflow-scrolling:touch;
    margin:0 -16px 0;padding:0 16px;
    scrollbar-width:none;
  }
  .category-tabs::-webkit-scrollbar{display:none}
  .cat-tab{flex:none;padding:14px 14px;font-size:13px;gap:6px}
  .cat-tab i{font-size:12px}
  .pledge-row{
    grid-template-columns:44px 1fr;
    gap:16px;padding:22px 4px;
    position:relative;
  }
  .pledge-row-arrow{
    position:absolute;top:22px;right:4px;
    width:32px;height:32px;font-size:12px;
  }
  .pledge-row:hover{padding-left:4px}
  .pledge-num-big{font-size:30px}
  .pledge-row-content{padding-right:40px}
  .pledge-row-content h3{font-size:17px;margin-bottom:6px;letter-spacing:-.02em}
  .pledge-row-content p{font-size:13.5px;line-height:1.55;margin-bottom:8px}
  .pledge-row-meta{gap:8px;font-size:11px}
  .pledge-row-cat{padding:2px 8px;font-size:10px}
  .pledge-row-keywords span{font-size:11px}

  /* Pledge detail */
  .pledge-detail{padding:28px 4px}
  .pledge-detail-head{flex-direction:column;gap:14px;margin-bottom:20px}
  .pledge-detail-close{align-self:flex-end;width:36px;height:36px;font-size:12px}
  .pledge-detail h3{font-size:22px;line-height:1.25}
  .pledge-detail-cat{font-size:10px;padding:4px 12px}
  .pledge-detail-summary{font-size:15px;padding:18px 20px;margin-bottom:24px;line-height:1.6}
  .pledge-detail-body{padding:22px 18px;font-size:14.5px;line-height:1.75}
  .pledge-detail-body ul{margin-left:18px}
  .pledge-detail-keys{gap:6px;margin-top:18px}
  .pledge-detail-keys span{font-size:11px;padding:4px 10px}
  .pledge-detail-actions{flex-direction:column;gap:8px;margin-top:24px}
  .pledge-detail-actions .btn-primary,
  .pledge-detail-actions .btn-line{
    width:100%;justify-content:center;padding:13px;
  }

  /* Vision */
  .vision-content h2{font-size:34px;line-height:1.15;margin-bottom:22px}
  .vision-content > p{font-size:15.5px;margin-bottom:28px;line-height:1.75}
  .vision-quote{padding:16px 0 16px 20px;font-size:15px;line-height:1.7}
  .vision-quote cite{font-size:12px;margin-top:10px}

  /* Voices */
  .voice-form{padding:24px 20px}
  .voice-form h3{font-size:14px;padding:8px 14px;margin-bottom:20px}
  .voice-form label span{font-size:11px}
  .voice-form input,.voice-form select,.voice-form textarea{font-size:16px;padding:12px 12px}
  .voice-item{padding:18px 20px}
  .voice-meta{font-size:12px;gap:8px;flex-wrap:wrap}
  .voice-name{font-size:13px}
  .voice-cat{font-size:10px;padding:2px 8px}
  .voice-time{font-size:11px;margin-left:auto}
  .voice-msg{font-size:14px;line-height:1.65}
  .voice-like{font-size:12px;padding:4px 10px}

  /* Share */
  .share-buttons{grid-template-columns:repeat(2,1fr)}
  .share-btn{padding:22px 12px;gap:8px}
  .share-btn i{font-size:20px}
  .share-btn span{font-size:12px}
  .share-btn small{font-size:10px}
  .share-btn:nth-child(3){border-right:1px solid var(--gray-200)}
  .share-btn:nth-child(2n){border-right:none}
  .share-btn:nth-child(n+3){border-top:1px solid var(--gray-200)}
  .share-cta{font-size:15px;padding:0 4px;line-height:1.65}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:32px;padding-bottom:28px}
  .footer-brand strong{font-size:18px}
  .footer-brand p{font-size:13px}
  .footer-bottom{
    flex-direction:column;text-align:center;gap:8px;
    font-size:11px;padding-top:8px;
  }

  /* Toast */
  .toast{
    left:16px;right:16px;bottom:20px;
    transform:translateY(20px);
    text-align:center;font-size:13px;padding:13px 18px;
  }
  .toast.show{transform:translateY(0)}
}

/* ==========================================================
   Small Mobile (max 380px)
   ========================================================== */
@media (max-width:380px){
  .hero-title{font-size:32px}
  .hero-meta-value{font-size:19px}
  .section-title{font-size:24px}
  .vision-content h2{font-size:28px}
  .hero-photo-wrap{max-width:320px}
  .hero-photo-num{font-size:220px;top:-2%}
  .share-buttons{grid-template-columns:1fr}
  .share-btn{
    flex-direction:row;justify-content:flex-start;gap:14px;
    padding:16px 20px;text-align:left;
    border-right:none !important;border-top:1px solid var(--gray-200) !important;
  }
  .share-btn:first-child{border-top:none !important}
  .share-btn i{font-size:18px}
  .share-btn span{flex:1}
}

/* ==========================================================
   Touch Target 최소 44×44 보장 (애플 접근성 가이드)
   ========================================================== */
@media (max-width:640px){
  .menu-toggle{min-width:44px;min-height:44px}
  .suggestion-chip{min-height:38px;display:inline-flex;align-items:center}
  .cat-tab{min-height:44px}
  .voice-like{min-height:32px}
  #chat-send{min-width:54px;min-height:48px}
  .pledge-row-arrow{min-width:32px;min-height:32px}
  .share-btn{min-height:90px}
  .footer-col a{padding:4px 0;min-height:28px}
  .main-nav a{padding:8px 0}
}

/* ==========================================================
   Landscape 모드 (낮은 높이)
   ========================================================== */
@media (max-height:500px) and (orientation:landscape){
  .hero{padding:40px 0 32px}
  .hero-title{font-size:36px;margin-bottom:16px}
  .hero-sub{font-size:14px;margin-bottom:20px}
  .hero-actions{margin-bottom:24px}
  .chat-messages{max-height:260px}
  .mobile-menu{padding-top:80px}
  .mobile-menu a{padding:12px 0;font-size:20px}
}

/* ==========================================================
   Touch Device Optimization
   ========================================================== */
@media (hover:none) and (pointer:coarse){
  .pledge-row:hover{padding-left:4px;background:transparent}
  .pledge-row:hover::before{width:0}
  .pledge-row:active{background:var(--gray-50)}
  .pledge-row:active::before{width:4px}

  .voice-item:hover::before{width:0}
  .voice-item:active::before{width:3px}

  .cat-tab:hover{color:var(--gray-500)}
  .cat-tab.active{color:var(--red)}

  .suggestion-chip:hover{
    border-color:var(--gray-200);color:var(--gray-700);background:#fff;
  }
  .suggestion-chip:active{
    border-color:var(--red);color:var(--red);background:var(--red-soft);
  }

  .btn-primary:hover{background:var(--red)}
  .btn-primary:active{background:var(--red-dark)}

  .share-btn:hover{background:#fff;color:var(--black)}
  .share-btn:hover i,.share-btn:hover small{color:inherit}
  .share-btn:active{background:var(--red);color:#fff}
  .share-btn:active i,.share-btn:active small{color:#fff}
}

/* ==========================================================
   BGM Control
   ========================================================== */
.bgm-control {
  position: fixed;
  bottom: 24px;
  left: 24px;
  z-index: 999;
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid var(--gray-200);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  transition: all 0.3s;
  color: var(--gray-500);
}
.bgm-control:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.12);
  color: var(--red);
}
.bgm-control.playing {
  color: var(--red);
  background: #fff;
  border-color: rgba(234, 0, 41, 0.3);
}
.bgm-control i {
  font-size: 16px;
  position: absolute;
  transition: opacity 0.3s;
}
.bgm-wave {
  display: flex;
  gap: 2px;
  height: 12px;
  align-items: flex-end;
  opacity: 0;
  transition: opacity 0.3s;
}
/* .bgm-control.playing i { opacity: 0; } 를 주석처리/삭제하여 아이콘이 보이게 함 */
.bgm-control.playing .bgm-wave { opacity: 0; } /* 웨이브 대신 아이콘 보이게 변경 또는 같이 보이게 */
.bgm-bar {
  width: 3px;
  background: var(--red);
  border-radius: 2px;
  animation: bgm-bounce 0.5s infinite alternate;
}
.bgm-bar:nth-child(2) { animation-delay: 0.15s; }
.bgm-bar:nth-child(3) { animation-delay: 0.3s; }
@keyframes bgm-bounce {
  0% { height: 3px; }
  100% { height: 12px; }
}
@media (max-width: 980px) {
  .bgm-control {
    bottom: 20px;
    left: 20px;
    width: 44px;
    height: 44px;
  }
}


