
:root{
  --bg:#f4fbf7;
  --bg-deep:#e4f5ea;
  --paper:#ffffff;
  --paper-soft:#f7fcf8;
  --text:#1e2a22;
  --text-soft:#52645a;
  --line:#d8e9dd;
  --line-strong:#bdd9c6;
  --brand:#177245;
  --brand-dark:#0f5532;
  --brand-soft:#e8f7ee;
  --mint:#8ed0a7;
  --mint-soft:#eefaf2;
  --accent:#0d8b63;
  --accent-soft:#e8f8f3;
  --ink:#152019;
  --shadow:0 18px 42px rgba(22,78,48,.08);
  --shadow-lg:0 26px 60px rgba(22,78,48,.14);
  --radius-xl:30px;
  --radius-lg:22px;
  --radius-md:16px;
  --radius-sm:12px;
  --container:1200px;
}

*,
*::before,
*::after{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family: Arial, "Apple SD Gothic Neo", "Noto Sans KR", sans-serif;
  color:var(--text);
  line-height:1.76;
  word-break:keep-all;
  background:
    radial-gradient(circle at top left, rgba(23,114,69,.10), transparent 24%),
    radial-gradient(circle at 100% 0, rgba(13,139,99,.08), transparent 26%),
    linear-gradient(180deg, #fbfffc 0%, var(--bg) 100%);
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{
  width:min(100%, var(--container));
  margin:0 auto;
  padding:0 22px;
}

.skip-link{
  position:absolute;
  left:12px;
  top:-48px;
  z-index:999;
  padding:11px 15px;
  border-radius:10px;
  background:var(--brand);
  color:#fff;
  font-weight:700;
}
.skip-link:focus{top:12px}

.top-note{
  background:#ffffffd9;
  border-bottom:1px solid rgba(23,114,69,.10);
}
.top-note-inner{
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-size:14px;
  color:var(--text-soft);
}
.top-note strong{color:var(--brand-dark)}

.top-phone{
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:10px 18px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--brand-dark), var(--brand));
  color:#fff;
  box-shadow:var(--shadow);
}
.top-phone span{
  font-size:13px;
  font-weight:800;
  opacity:.92;
}
.top-phone strong{
  font-size:24px;
  line-height:1;
  letter-spacing:-.03em;
  color:#fff;
}

.site-header{
  position:sticky;
  top:0;
  z-index:998;
  background:rgba(244,251,247,.88);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(23,114,69,.09);
}
.header-inner{
  min-height:82px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.brand-wrap{display:flex;flex-direction:column;gap:4px}
.brand{
  font-size:28px;
  font-weight:900;
  letter-spacing:-.04em;
  color:var(--ink);
}
.brand-sub{
  font-size:12px;
  color:var(--text-soft);
}
.main-nav{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:18px;
}
.main-nav a{
  font-size:14px;
  font-weight:800;
  color:#2b3c31;
}
.main-nav a:hover{color:var(--brand-dark)}
.header-call{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-width:220px;
  min-height:66px;
  padding:8px 22px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--brand), var(--accent));
  color:#fff;
  box-shadow:var(--shadow-lg);
}
.header-call span{
  font-size:12px;
  font-weight:800;
  opacity:.9;
}
.header-call strong{
  font-size:28px;
  line-height:1.05;
  letter-spacing:-.04em;
}

.hero{
  padding:44px 0 24px;
}
.hero-shell{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) 360px;
  gap:24px;
  align-items:stretch;
}
.hero-main,
.hero-aside,
.panel,
.story-card,
.highlight-card,
.local-card,
.article-card,
.faq-card,
.notice-card,
.sidebar-card,
.cta-band{
  background:var(--paper);
  border:1px solid rgba(23,114,69,.10);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
}
.hero-main{
  padding:42px;
  background:
    linear-gradient(140deg, rgba(232,247,238,.96), rgba(255,255,255,.92)),
    linear-gradient(180deg, #fff 0%, #f7fcf8 100%);
  overflow:hidden;
  position:relative;
}
.hero-main::after{
  content:"";
  position:absolute;
  inset:auto -60px -70px auto;
  width:240px;
  height:240px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(23,114,69,.16), rgba(23,114,69,0));
}
.kicker,
.badge,
.post-label{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
}
.kicker{
  margin-bottom:18px;
  background:var(--brand-soft);
  color:var(--brand-dark);
  border:1px solid rgba(23,114,69,.12);
}
.badge{
  margin-bottom:12px;
  background:var(--accent-soft);
  color:var(--accent);
  border:1px solid rgba(13,139,99,.12);
}
.hero h1,
.article-hero h1,
.section-title h2,
.story-card h3,
.sidebar-card h3,
.faq-card h2,
.cta-band h2{
  margin:0;
  color:var(--ink);
  line-height:1.24;
  letter-spacing:-.03em;
}
.hero h1{
  font-size:52px;
  margin-bottom:18px;
  font-family: Georgia, "Times New Roman", serif;
}
.lead{
  margin:0;
  font-size:17px;
  color:var(--text-soft);
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 22px;
  border-radius:15px;
  font-weight:900;
  font-size:15px;
}
.btn-primary{
  background:linear-gradient(135deg, var(--brand), var(--accent));
  color:#fff;
}
.btn-secondary{
  background:#fff;
  border:1px solid var(--line-strong);
  color:var(--ink);
}
.hero-points{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-top:26px;
}
.hero-points div{
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(23,114,69,.08);
}
.hero-points strong{
  display:block;
  margin-bottom:6px;
  color:var(--ink);
  font-size:14px;
}
.hero-points span{
  display:block;
  color:var(--text-soft);
  font-size:13px;
}

.quick-nav{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.quick-nav a{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  padding:0 16px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  font-size:13px;
  font-weight:800;
  color:#33463a;
}

.hero-aside{
  padding:28px;
  display:flex;
  flex-direction:column;
  gap:18px;
  justify-content:space-between;
  background:
    linear-gradient(180deg, rgba(232,247,238,.88), rgba(255,255,255,.96));
}
.hero-aside h2{
  margin:0;
  font-size:28px;
  line-height:1.32;
}
.check-list{
  margin:0;
  padding-left:18px;
  color:var(--text-soft);
}
.check-list li+li{margin-top:8px}
.call-big{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:84px;
  border-radius:22px;
  background:linear-gradient(135deg, var(--brand-dark), var(--brand));
  color:#fff;
  font-size:34px;
  font-weight:900;
  letter-spacing:-.04em;
  box-shadow:var(--shadow-lg);
}
.hero-mini{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.hero-mini div{
  padding:14px;
  border-radius:16px;
  background:var(--paper-soft);
  border:1px solid var(--line);
}
.hero-mini strong{
  display:block;
  margin-bottom:6px;
  font-size:13px;
}
.hero-mini p{
  margin:0;
  font-size:12px;
  color:var(--text-soft);
}

main{padding:6px 0 84px}
.section{margin-top:30px}
.section-title{margin-bottom:18px}
.section-title h2{
  font-size:38px;
  margin-bottom:10px;
}
.section-title p,
.story-card p,
.highlight-card p,
.notice-card p,
.faq-card p{
  margin:0;
  color:var(--text-soft);
  font-size:15px;
}

.feature-grid,
.symptom-grid,
.local-grid,
.article-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.story-card,
.highlight-card,
.local-card,
.article-card{
  padding:24px;
}
.story-card h3{
  font-size:25px;
  margin-bottom:12px;
}
.story-card ul,
.notice-card ul,
.local-card ul{
  margin:14px 0 0;
  padding-left:18px;
  color:var(--text-soft);
}
.story-card li+li,
.notice-card li+li,
.local-card li+li{margin-top:8px}

.timeline{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.panel{
  padding:24px;
}
.step-no{
  width:46px;
  height:46px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:14px;
  background:var(--brand-soft);
  color:var(--brand-dark);
  font-weight:900;
}
.panel strong{
  display:block;
  margin-bottom:8px;
  font-size:20px;
  color:var(--ink);
}
.panel p{margin:0;color:var(--text-soft);font-size:15px}

.highlight-card strong,
.local-card strong,
.article-card strong{
  display:block;
  margin-bottom:10px;
  font-size:23px;
  color:var(--ink);
}
.highlight-card a,
.article-card a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  margin-top:16px;
  padding:0 16px;
  border-radius:12px;
  background:var(--paper-soft);
  border:1px solid var(--line);
  color:#2f4136;
  font-weight:800;
}
.local-card{
  background:linear-gradient(180deg, #fff 0%, #f8fcf9 100%);
}

.notice-card{padding:26px}
.notice-card + .notice-card{margin-top:18px}
.notice-card h2,
.notice-card h3{
  margin:0 0 10px;
  font-size:29px;
  line-height:1.3;
}
.info-stack{display:grid;gap:14px}
.info-row{
  padding:16px 18px;
  border-radius:16px;
  background:var(--paper-soft);
  border:1px solid var(--line);
}
.info-row strong{
  display:block;
  margin-bottom:6px;
  color:var(--ink);
}
.info-row p{margin:0}
.bullet-list{
  margin:14px 0 0;
  padding-left:20px;
  color:var(--text-soft);
}
.bullet-list li+li{margin-top:8px}

.article-hero{
  padding:34px;
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg, rgba(232,247,238,.9), rgba(255,255,255,.95));
  border:1px solid rgba(23,114,69,.10);
  box-shadow:var(--shadow);
}
.article-hero h1{
  font-size:44px;
  margin-bottom:16px;
}
.tag-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:20px;
}
.tag-row span{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:0 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  font-size:13px;
  font-weight:800;
  color:#365041;
}
.content-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:22px;
  align-items:start;
  margin-top:20px;
}
.sidebar-stack{display:flex;flex-direction:column;gap:18px}
.sidebar-card{
  padding:22px;
  position:sticky;
  top:98px;
}
.sidebar-card h3{
  font-size:22px;
  margin-bottom:12px;
}
.sidebar-links{
  display:grid;
  gap:10px;
}
.sidebar-links a{
  display:block;
  padding:14px 15px;
  border-radius:14px;
  background:var(--paper-soft);
  border:1px solid var(--line);
  font-weight:700;
  color:#365041;
}
.call-panel{
  padding:20px;
  border-radius:22px;
  background:linear-gradient(180deg, #fff 0%, #eefaf2 100%);
  border:1px solid rgba(23,114,69,.10);
  box-shadow:var(--shadow);
}
.call-panel strong{
  display:block;
  font-size:18px;
  margin-bottom:10px;
}
.call-panel a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:72px;
  border-radius:18px;
  background:linear-gradient(135deg, var(--brand), var(--accent));
  color:#fff;
  font-weight:900;
  font-size:30px;
  letter-spacing:-.04em;
}

.faq-card{
  padding:26px;
}
.faq-list{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.faq-item{
  padding:18px 20px;
  border-radius:18px;
  background:var(--paper-soft);
  border:1px solid var(--line);
}
.faq-item strong{
  display:block;
  margin-bottom:8px;
  color:var(--ink);
}

.cta-band{
  margin-top:32px;
  padding:32px;
  background:
    linear-gradient(135deg, rgba(23,114,69,.96), rgba(13,139,99,.94));
  color:#fff;
}
.cta-band h2{color:#fff;font-size:34px;margin-bottom:12px}
.cta-band p{margin:0;color:rgba(255,255,255,.88)}
.cta-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:20px;
}
.cta-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 20px;
  border-radius:14px;
  font-weight:900;
}
.cta-actions .solid{background:#fff;color:var(--brand-dark)}
.cta-actions .ghost{
  border:1px solid rgba(255,255,255,.35);
  color:#fff;
}

.site-footer{
  padding:28px 0 42px;
  border-top:1px solid rgba(23,114,69,.10);
  background:#fbfffc;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
}
.footer-brand{
  font-weight:900;
  color:var(--ink);
  margin-bottom:6px;
}
.footer-text{
  font-size:13px;
  color:var(--text-soft);
}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.footer-links a{
  display:inline-flex;
  min-height:38px;
  align-items:center;
  padding:0 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  font-size:13px;
  font-weight:800;
  color:#33513d;
}


.cta-actions .solid{
  min-height:58px;
  padding:0 24px;
  font-size:24px;
  font-weight:900;
  letter-spacing:-.03em;
}

.floating-call{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:1200;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:66px;
  padding:0 24px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--brand-dark), var(--accent));
  color:#fff;
  font-size:26px;
  font-weight:900;
  letter-spacing:-.04em;
  box-shadow:0 18px 38px rgba(15,85,50,.28);
}

@media (max-width: 1080px){
  .hero-shell,
  .content-layout{
    grid-template-columns:1fr;
  }
  .hero-points,
  .feature-grid,
  .symptom-grid,
  .local-grid,
  .article-grid,
  .timeline{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .sidebar-card{position:static}
}

@media (max-width: 720px){
  body{padding-bottom:92px}
  .header-inner,
  .top-note-inner,
  .footer-inner{
    flex-direction:column;
    align-items:flex-start;
  }
  .top-phone{
    width:100%;
    justify-content:space-between;
    padding:12px 18px;
  }
  .top-phone strong{font-size:28px}
  .hero h1{font-size:38px}
  .article-hero h1,
  .section-title h2{font-size:30px}
  .hero-main,
  .hero-aside,
  .article-hero,
  .notice-card,
  .story-card,
  .highlight-card,
  .local-card,
  .article-card,
  .faq-card,
  .cta-band{padding:22px}
  .hero-points,
  .feature-grid,
  .symptom-grid,
  .local-grid,
  .article-grid,
  .timeline,
  .hero-mini{
    grid-template-columns:1fr;
  }
  .main-nav{gap:12px}
  .header-call{
    width:100%;
    min-height:74px;
  }
  .header-call strong{font-size:32px}
  .call-big{font-size:32px; min-height:78px}
  .call-panel a{font-size:28px}
  .cta-actions .solid{
    width:100%;
    font-size:26px;
  }
  .floating-call{
    left:12px;
    right:12px;
    bottom:12px;
    width:auto;
    min-height:64px;
    font-size:28px;
  }
}
