/* ============================================================
   복지콜 장애인활동지원기관 — 공통 스타일 (전 페이지 공유)
   컨셉: "돌봄의 울타리" · 따뜻한 신뢰
   컬러 규율(§10.14): 1 액센트(그린) + 1 포인트(살구) + 장식
============================================================ */
:root {
  --bg:           #FAF6EF;
  --bg-warm:      #F3EADB;
  --surface:      #FFFFFF;
  --ink:          #22302B;
  --ink-soft:     #515C56;
  --ink-faint:    #8A938C;
  --line:         #E6DECF;

  --green:        #2E6B5E;
  --green-deep:   #1E4A40;
  --green-soft:   #E4EFE9;
  --apricot:      #E8895A;
  --apricot-soft: #FBE6D7;

  --radius:       18px;
  --radius-lg:    28px;
  --shadow:       0 1px 2px rgba(30,74,64,.04), 0 12px 30px -12px rgba(30,74,64,.18);
  --shadow-lg:    0 24px 60px -24px rgba(30,74,64,.34);

  --fz-display:   clamp(2.2rem, 1.2rem + 4.4vw, 4rem);
  --fz-h2:        clamp(1.6rem, 1.1rem + 2vw, 2.5rem);
  --fz-h3:        clamp(1.2rem, 1rem + .8vw, 1.5rem);
  --fz-lead:      clamp(1.08rem, 1rem + .5vw, 1.3rem);

  --serif:  'Gowun Batang', 'Pretendard', serif;
  --sans:   'Pretendard', system-ui, -apple-system, 'Apple SD Gothic Neo', 'Malgun Gothic', sans-serif;

  --maxw: 1160px;
  --gut:  clamp(1.1rem, 4vw, 2.5rem);
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: 90px; }
body {
  margin: 0; font-family: var(--sans); font-size: 1.0625rem; line-height: 1.75;
  color: var(--ink); background: var(--bg);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  overflow-wrap: break-word; word-break: keep-all;
}
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 700; line-height: 1.3; letter-spacing: -.01em; margin: 0; }
p { margin: 0; }
a { color: var(--green-deep); text-decoration-thickness: 1px; text-underline-offset: 3px; }
img { max-width: 100%; display: block; }
ul { margin: 0; padding: 0; list-style: none; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* 접근성 */
.skip { position: fixed; left: 12px; top: -60px; z-index: 1000; background: var(--green-deep); color: #fff; padding: 12px 18px; border-radius: 0 0 12px 12px; font-weight: 700; transition: top .2s; }
.skip:focus { top: 0; }
:focus-visible { outline: 3px solid var(--apricot); outline-offset: 3px; border-radius: 6px; }

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.section { padding-block: clamp(3.5rem, 7vw, 6.5rem); }
.section--tight { padding-block: clamp(2.5rem, 5vw, 4rem); }

.eyebrow { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--sans); font-weight: 700; font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; color: var(--green); margin: 0 0 .9rem; }
.eyebrow::before { content: ""; width: 1.6rem; height: 2px; background: var(--apricot); border-radius: 2px; }
.section-head { max-width: 44ch; margin-bottom: clamp(1.8rem, 4vw, 3rem); }
.section-head h2 { font-size: var(--fz-h2); }
.section-head p { margin-top: .9rem; color: var(--ink-soft); font-size: var(--fz-lead); }

/* 버튼 */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; min-height: 52px; padding: 0 1.6rem; border-radius: 999px; font-family: var(--sans); font-weight: 700; font-size: 1.02rem; text-decoration: none; cursor: pointer; border: 2px solid transparent; transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease; }
.btn--primary { background: var(--green); color: #fff; box-shadow: 0 10px 24px -10px rgba(46,107,94,.7); }
.btn--primary:hover { background: var(--green-deep); transform: translateY(-2px); }
.btn--ghost { background: #fff; color: var(--green-deep); border-color: var(--line); }
.btn--ghost:hover { border-color: var(--green); transform: translateY(-2px); box-shadow: var(--shadow); }
.btn--lg { min-height: 60px; font-size: 1.1rem; padding: 0 2rem; }

/* ===== 헤더 / 내비 ===== */
.hdr { position: sticky; top: 0; z-index: 100; background: color-mix(in srgb, var(--bg) 86%, transparent); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.hdr__bar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 76px; }
.brand { display: inline-flex; align-items: center; gap: .7rem; text-decoration: none; color: var(--ink); }
.brand__mark { width: 42px; height: 42px; flex: none; }
.brand__txt { display: flex; flex-direction: column; line-height: 1.15; }
.brand__txt b { font-family: var(--serif); font-size: 1.18rem; letter-spacing: -.01em; }
.brand__txt span { font-size: .74rem; color: var(--ink-soft); letter-spacing: .02em; }

.nav { display: none; }
@media (min-width: 920px) { .nav { display: flex; align-items: center; gap: .4rem; } }
.nav__item { position: relative; }
.nav__top { display: inline-flex; align-items: center; gap: .35rem; background: none; border: 0; font: inherit; font-weight: 700; color: var(--ink); padding: .7rem 1rem; border-radius: 10px; cursor: pointer; text-decoration: none; }
.nav__top:hover { background: var(--green-soft); color: var(--green-deep); }
.nav__top svg { width: 12px; height: 12px; transition: transform .2s; }
.nav__item:hover .nav__top svg, .nav__item:focus-within .nav__top svg { transform: rotate(180deg); }
.nav__menu { position: absolute; top: calc(100% + 6px); left: 0; min-width: 210px; background: #fff; border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow-lg); padding: .5rem; opacity: 0; visibility: hidden; transform: translateY(6px); transition: all .18s ease; }
.nav__item:hover .nav__menu, .nav__item:focus-within .nav__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nav__menu a { display: block; padding: .6rem .8rem; border-radius: 9px; text-decoration: none; color: var(--ink); font-size: .96rem; font-weight: 500; }
.nav__menu a:hover { background: var(--green-soft); color: var(--green-deep); }
.hdr__cta { display: none; }
@media (min-width: 920px) { .hdr__cta { display: inline-flex; } }

.navtoggle { display: inline-flex; align-items: center; gap: .5rem; background: var(--green); color: #fff; border: 0; border-radius: 999px; min-height: 48px; padding: 0 1.1rem; font: inherit; font-weight: 700; cursor: pointer; }
@media (min-width: 920px) { .navtoggle { display: none; } }
.mnav { display: none; border-top: 1px solid var(--line); background: var(--bg); }
.mnav.open { display: block; }
.mnav__group { border-bottom: 1px solid var(--line); padding: .4rem 0; }
.mnav__group > b { display: block; font-family: var(--sans); padding: .8rem var(--gut) .3rem; color: var(--green); font-size: .82rem; letter-spacing: .1em; text-transform: uppercase; }
.mnav a { display: block; padding: .55rem var(--gut); text-decoration: none; color: var(--ink); font-weight: 500; }
.mnav a:hover, .mnav a:focus { background: var(--green-soft); }

/* ===== 히어로 (메인) ===== */
.hero { position: relative; overflow: hidden; background: var(--bg); }
.hero::before { content: ""; position: absolute; inset: 0; z-index: 0; background: radial-gradient(60% 70% at 88% 6%, var(--apricot-soft) 0%, transparent 55%), radial-gradient(70% 80% at 6% 100%, var(--green-soft) 0%, transparent 55%); }
.hero__arc { position: absolute; right: -6%; bottom: -30%; width: min(58%, 640px); aspect-ratio: 1; z-index: 0; opacity: .9; pointer-events: none; }
.hero .wrap { position: relative; z-index: 1; }
.hero__inner { display: grid; gap: clamp(2rem, 5vw, 4rem); align-items: center; padding-block: clamp(3rem, 8vw, 6rem); }
@media (min-width: 940px) { .hero__inner { grid-template-columns: 1.05fr .95fr; } }
.hero__tag { display: inline-flex; align-items: center; gap: .55rem; background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: .5rem 1rem; font-weight: 700; font-size: .9rem; color: var(--green-deep); box-shadow: var(--shadow); margin-bottom: 1.4rem; }
.hero__tag .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--apricot); }
.hero h1 { font-size: var(--fz-display); }
.hero h1 .accent { color: var(--green); }
.hero h1 .ap { color: var(--apricot); }
.hero__lead { margin-top: 1.4rem; font-size: var(--fz-lead); color: var(--ink-soft); max-width: 38ch; }
.hero__cta { margin-top: 2.2rem; display: flex; flex-wrap: wrap; gap: .8rem; }
.hero__note { margin-top: 1.2rem; font-size: .92rem; color: var(--ink-faint); }
.hero__card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(1.4rem, 3vw, 2rem); box-shadow: var(--shadow-lg); }
.hero__card h2 { font-size: 1.15rem; font-family: var(--sans); color: var(--ink); margin-bottom: 1rem; }
.quick { display: grid; gap: .7rem; }
.quick a { display: flex; align-items: center; gap: .9rem; padding: .9rem 1rem; border-radius: 14px; background: var(--bg-warm); text-decoration: none; color: var(--ink); font-weight: 600; transition: background .18s, transform .18s; }
.quick a:hover { background: var(--green-soft); transform: translateX(3px); }
.quick .ic { width: 42px; height: 42px; flex: none; border-radius: 12px; display: grid; place-items: center; background: #fff; color: var(--green); box-shadow: var(--shadow); }
.quick .ic svg { width: 22px; height: 22px; }
.quick small { display: block; font-weight: 500; color: var(--ink-faint); font-size: .82rem; }

/* ===== 서브페이지 헤더 배너 ===== */
.page-hero { position: relative; overflow: hidden; background: linear-gradient(160deg, var(--green) 0%, var(--green-deep) 100%); color: #fff; padding-block: clamp(2.6rem, 6vw, 4.5rem); }
.page-hero::after { content: ""; position: absolute; right: -4%; top: -40%; width: 360px; height: 360px; border-radius: 50%; border: 16px solid rgba(251,230,215,.16); }
.page-hero .wrap { position: relative; z-index: 1; }
.breadcrumb { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; font-size: .85rem; color: rgba(255,255,255,.7); margin-bottom: 1rem; }
.breadcrumb a { color: rgba(255,255,255,.7); text-decoration: none; }
.breadcrumb a:hover { color: #fff; }
.breadcrumb .sep { opacity: .5; }
.page-hero h1 { font-size: clamp(1.9rem, 1.2rem + 3vw, 3rem); }
.page-hero p { margin-top: .8rem; color: rgba(255,255,255,.85); font-size: var(--fz-lead); max-width: 50ch; }

/* 섹션 내 앵커 서브내비 (서브페이지 상단 sticky 탭) */
.subnav { position: sticky; top: 76px; z-index: 50; background: color-mix(in srgb, var(--bg) 92%, transparent); backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); }
.subnav__list { display: flex; gap: .3rem; overflow-x: auto; padding-block: .5rem; -ms-overflow-style: none; scrollbar-width: none; }
.subnav__list::-webkit-scrollbar { display: none; }
.subnav a { flex: none; padding: .55rem 1rem; border-radius: 999px; text-decoration: none; color: var(--ink-soft); font-weight: 600; font-size: .94rem; white-space: nowrap; }
.subnav a:hover { background: var(--green-soft); color: var(--green-deep); }

/* ===== 본문(프로즈) ===== */
.prose { max-width: 70ch; }
.prose > * + * { margin-top: 1.1rem; }
.prose p { color: var(--ink-soft); font-size: var(--fz-lead); }
.prose h3 { font-family: var(--sans); font-size: var(--fz-h3); color: var(--ink); margin-top: 2rem; }
.prose strong { color: var(--ink); }

/* 설립목적 그리드 (메인 재사용) */
.purpose { background: var(--surface); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.purpose__grid { display: grid; gap: clamp(1.6rem, 4vw, 3rem); align-items: center; }
@media (min-width: 860px) { .purpose__grid { grid-template-columns: 1.3fr 1fr; } }
.purpose p.body { font-size: var(--fz-lead); color: var(--ink-soft); }
.purpose .lead-line { font-family: var(--serif); font-size: var(--fz-h3); color: var(--ink); margin-bottom: 1.2rem; line-height: 1.5; }
.pillars { display: grid; gap: 1rem; }
.pillar { display: flex; gap: 1rem; align-items: flex-start; background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.1rem 1.2rem; }
.pillar .ic { width: 40px; height: 40px; flex: none; border-radius: 11px; display: grid; place-items: center; background: var(--green-soft); color: var(--green-deep); }
.pillar .ic svg { width: 22px; height: 22px; }
.pillar b { display: block; font-family: var(--sans); }
.pillar small { color: var(--ink-soft); font-size: .92rem; }

/* 인사말 */
.greet { background: var(--green-deep); color: #fff; position: relative; overflow: hidden; }
.greet::before { content: "\201C"; position: absolute; top: -.1em; left: var(--gut); font-family: var(--serif); font-size: 16rem; line-height: 1; color: rgba(255,255,255,.07); }
.greet .wrap { position: relative; }
.greet__grid { display: grid; gap: clamp(1.6rem,4vw,3rem); }
@media (min-width: 860px) { .greet__grid { grid-template-columns: .8fr 1.2fr; align-items: start; } }
.greet .eyebrow { color: var(--apricot); }
.greet h2 { font-size: var(--fz-h2); color: #fff; }
.greet h2 .ap { color: var(--apricot); }
.greet__body p { color: rgba(255,255,255,.86); margin-bottom: 1rem; }
.greet__body p:first-child { font-size: var(--fz-lead); color: #fff; }
.greet__sign { margin-top: 1.6rem; display: flex; align-items: center; gap: .8rem; font-weight: 700; }
.greet__sign span { width: 38px; height: 2px; background: var(--apricot); }

/* 사업소개 카드 */
.svc__grid { display: grid; gap: 1.2rem; grid-template-columns: 1fr; }
@media (min-width: 680px) { .svc__grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1000px) { .svc__grid { grid-template-columns: repeat(3,1fr); } }
.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 1.6rem; box-shadow: var(--shadow); position: relative; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; display: flex; flex-direction: column; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--green-soft); }
.card .ic { width: 56px; height: 56px; border-radius: 16px; display: grid; place-items: center; background: var(--green-soft); color: var(--green-deep); margin-bottom: 1.1rem; }
.card .ic svg { width: 28px; height: 28px; }
.card h3 { font-family: var(--sans); font-size: 1.2rem; margin-bottom: .5rem; }
.card p { color: var(--ink-soft); font-size: .98rem; flex: 1; }
.card .more { margin-top: 1rem; font-weight: 700; color: var(--green); font-size: .94rem; display: inline-flex; align-items: center; gap: .35rem; }
.card--feature { background: linear-gradient(155deg, var(--green) 0%, var(--green-deep) 100%); color: #fff; border-color: transparent; }
.card--feature .ic { background: rgba(255,255,255,.16); color: #fff; }
.card--feature h3 { color: #fff; }
.card--feature p { color: rgba(255,255,255,.85); }
.card--feature .more { color: var(--apricot); }
.card .badge { position: absolute; top: 1.2rem; right: 1.2rem; background: var(--apricot); color: #fff; font-size: .72rem; font-weight: 700; padding: .25rem .6rem; border-radius: 999px; letter-spacing: .03em; }

/* 신청 절차 */
.flow { background: var(--bg-warm); }
.steps { display: grid; gap: 1rem; counter-reset: step; grid-template-columns: 1fr; }
@media (min-width: 720px) { .steps { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1000px) { .steps { grid-template-columns: repeat(4,1fr); } }
.step { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; position: relative; }
.step::before { counter-increment: step; content: counter(step,decimal-leading-zero); font-family: var(--serif); font-size: 2rem; color: var(--green-soft); font-weight: 700; display: block; line-height: 1; margin-bottom: .6rem; }
.step b { display: block; font-family: var(--sans); margin-bottom: .3rem; }
.step small { color: var(--ink-soft); font-size: .92rem; }
.eligibility { margin-top: 1.4rem; display: grid; gap: 1rem; }
@media (min-width: 760px) { .eligibility { grid-template-columns: repeat(2,1fr); } }
.panel { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem 1.5rem; }
.panel h3 { font-family: var(--sans); font-size: 1.1rem; margin-bottom: .8rem; display: flex; align-items: center; gap: .5rem; }
.panel h3 .pin { width: 10px; height: 10px; border-radius: 50%; background: var(--apricot); }
.panel li { display: flex; gap: .6rem; padding: .35rem 0; color: var(--ink-soft); }
.panel li::before { content: ""; flex: none; width: 7px; height: 7px; margin-top: .65rem; border-radius: 2px; background: var(--green); }

/* 급여비용 표 */
.tbl { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.tbl caption { text-align: left; color: var(--ink-faint); font-size: .9rem; padding: .6rem .2rem; }
.tbl th, .tbl td { padding: .9rem 1rem; text-align: left; border-bottom: 1px solid var(--line); }
.tbl thead th { background: var(--green-soft); color: var(--green-deep); font-family: var(--sans); }
.tbl tbody tr:last-child td { border-bottom: 0; }
.tbl td .ph-flag { color: var(--apricot); font-weight: 700; }

/* 연혁 타임라인 */
.timeline { position: relative; padding-left: 1.6rem; }
.timeline::before { content: ""; position: absolute; left: 5px; top: .5rem; bottom: .5rem; width: 2px; background: var(--line); }
.timeline li { position: relative; padding: 0 0 1.6rem 1.2rem; }
.timeline li::before { content: ""; position: absolute; left: -1.6rem; top: .4rem; width: 12px; height: 12px; border-radius: 50%; background: var(--green); border: 3px solid var(--bg); }
.timeline b { font-family: var(--serif); color: var(--green-deep); font-size: 1.1rem; }
.timeline p { color: var(--ink-soft); }

/* 조직도 */
.org { display: grid; gap: 1rem; justify-items: center; text-align: center; }
.org__node { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: .9rem 1.4rem; font-weight: 700; box-shadow: var(--shadow); min-width: 180px; }
.org__node.is-top { background: var(--green); color: #fff; border-color: transparent; }
.org__row { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }
.org__line { width: 2px; height: 22px; background: var(--line); }

/* 오시는 길 */
.visit__grid { display: grid; gap: 1.4rem; }
@media (min-width: 860px) { .visit__grid { grid-template-columns: 1.3fr 1fr; } }
.map { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); aspect-ratio: 16/10; background: repeating-linear-gradient(45deg, var(--green-soft) 0 18px, #eaf2ee 18px 36px); display: grid; place-items: center; color: var(--green); }
.map .ph { text-align: center; }
.map .ph svg { width: 40px; height: 40px; margin-bottom: .4rem; }
.info { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 1.6rem; box-shadow: var(--shadow); }
.info dl { margin: 0; display: grid; gap: 1rem; }
.info dt { font-size: .8rem; font-weight: 700; color: var(--green); letter-spacing: .06em; text-transform: uppercase; }
.info dd { margin: .2rem 0 0; font-weight: 500; }
.info .ph-flag { color: var(--apricot); font-weight: 700; }

/* 커뮤니티 — 공지/앨범/고충 */
.comm__grid { display: grid; gap: 1.4rem; }
@media (min-width: 920px) { .comm__grid { grid-template-columns: 1.1fr 1fr; } }
.notice { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 1.6rem; box-shadow: var(--shadow); }
.notice__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: .6rem; }
.notice__top h3 { font-family: var(--sans); font-size: 1.2rem; }
.notice__top a { font-size: .9rem; font-weight: 700; color: var(--green); text-decoration: none; }
.notice li a { display: flex; align-items: center; gap: .8rem; padding: .85rem .2rem; border-top: 1px solid var(--line); text-decoration: none; color: var(--ink); }
.notice li:first-child a { border-top: 0; }
.notice li a:hover .nt-title { color: var(--green-deep); text-decoration: underline; }
.nt-tag { flex: none; font-size: .72rem; font-weight: 700; color: var(--green-deep); background: var(--green-soft); padding: .2rem .55rem; border-radius: 7px; }
.nt-title { flex: 1; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nt-date { flex: none; color: var(--ink-faint); font-size: .85rem; }
.album { display: grid; grid-template-columns: repeat(2,1fr); gap: .9rem; }
.album figure { margin: 0; border-radius: var(--radius); overflow: hidden; position: relative; aspect-ratio: 4/3; background: var(--green-soft); border: 1px solid var(--line); }
.album figure .ph { position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); opacity: .5; }
.album figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: .7rem .8rem; background: linear-gradient(transparent, rgba(30,74,64,.82)); color: #fff; font-size: .86rem; font-weight: 600; }
.grievance { margin-top: 1.4rem; background: var(--apricot-soft); border: 1px solid #f2cdb6; border-radius: var(--radius); padding: 1.4rem 1.5rem; display: flex; gap: 1rem; align-items: flex-start; }
.grievance .ic { width: 44px; height: 44px; flex: none; border-radius: 12px; background: #fff; color: var(--apricot); display: grid; place-items: center; }
.grievance b { font-family: var(--sans); display: block; margin-bottom: .25rem; }
.grievance small { color: #8a5a3e; }

/* 서식자료실 다운로드 리스트 */
.files { display: grid; gap: .7rem; }
.files a { display: flex; align-items: center; gap: 1rem; background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 1rem 1.2rem; text-decoration: none; color: var(--ink); font-weight: 600; transition: border-color .18s, transform .18s; }
.files a:hover { border-color: var(--green); transform: translateX(3px); }
.files .ic { width: 40px; height: 40px; flex: none; border-radius: 11px; background: var(--green-soft); color: var(--green-deep); display: grid; place-items: center; }
.files small { display: block; font-weight: 500; color: var(--ink-faint); font-size: .82rem; }
.files .dl { margin-left: auto; color: var(--green); font-size: .85rem; font-weight: 700; }

/* 문의 폼(정적 안내) */
.qna { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(1.5rem,3vw,2.2rem); box-shadow: var(--shadow); }
.field { display: grid; gap: .4rem; margin-bottom: 1rem; }
.field label { font-weight: 700; font-size: .94rem; }
.field input, .field textarea { font: inherit; padding: .8rem 1rem; border: 1px solid var(--line); border-radius: 12px; background: var(--bg); color: var(--ink); }
.field input:focus, .field textarea:focus { outline: 3px solid var(--apricot); outline-offset: 1px; border-color: var(--green); }

.callout { background: var(--green-soft); border-radius: var(--radius); padding: 1.2rem 1.4rem; color: var(--green-deep); font-weight: 500; }
.ph-flag { color: var(--apricot); font-weight: 700; }

/* ===== 푸터 ===== */
.ftr { background: var(--ink); color: rgba(255,255,255,.7); padding-block: clamp(2.5rem,5vw,4rem) 2rem; }
.ftr__top { display: grid; gap: 1.6rem; padding-bottom: 2rem; border-bottom: 1px solid rgba(255,255,255,.12); }
@media (min-width: 760px) { .ftr__top { grid-template-columns: 1.4fr 1fr 1fr; } }
.ftr .brand__txt b { color: #fff; }
.ftr h4 { color: #fff; font-family: var(--sans); font-size: .95rem; margin: 0 0 .8rem; }
.ftr a { color: rgba(255,255,255,.7); text-decoration: none; display: inline-block; padding: .25rem 0; }
.ftr a:hover { color: #fff; }
.ftr__desc { font-size: .95rem; max-width: 40ch; margin-top: 1rem; }
.ftr__bottom { padding-top: 1.5rem; font-size: .85rem; color: rgba(255,255,255,.45); display: flex; flex-wrap: wrap; gap: .5rem 1.5rem; justify-content: space-between; }

/* scroll-reveal */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: none; }
