/* =========================================================
   리본플러스 주간보호센터 — Design System
   Palette: Deep Navy + White (no extra accent)
   Type: Pretendard
   ========================================================= */

@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css");

:root{
  /* ---- Navy scale ---- */
  --navy-950:#0a162e;
  --navy-900:#0e1d3a;
  --navy-800:#13294f;
  --navy-700:#1b3563;   /* primary */
  --navy-600:#274a85;
  --navy-500:#3a5da0;
  --navy-300:#8a9cc0;
  --navy-200:#b9c4da;
  --navy-100:#e2e7f1;

  /* ---- Neutrals (warm white) ---- */
  --paper:#fafaf7;
  --paper-2:#f3f4f1;
  --white:#ffffff;
  --ink:#152038;
  --muted:#5d6679;
  --line:#e7e8e6;
  --line-soft:#eef0ee;

  /* ---- Tokens ---- */
  --radius:16px;
  --radius-sm:12px;
  --radius-lg:26px;
  --shadow-sm:0 1px 2px rgba(14,29,58,.05), 0 8px 24px rgba(14,29,58,.05);
  --shadow-md:0 2px 6px rgba(14,29,58,.06), 0 18px 50px rgba(14,29,58,.10);
  --shadow-lg:0 30px 80px rgba(14,29,58,.18);

  --max:1200px;
  --gutter:clamp(20px,5vw,56px);

  --header-h:84px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Pretendard Variable","Pretendard",system-ui,-apple-system,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.7;
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--navy-700);color:#fff}

/* ---------- Logo mark ---------- */
.brand svg .loop,.brand svg .knot{fill:var(--logo-loop,#1b3563)}
.brand svg .plus{stroke:var(--logo-plus,#fff)}
.header-light .brand svg,.site-footer .brand svg,.page-hero .brand svg{--logo-loop:#fff;--logo-plus:#0a162e}

/* ---------- Layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1360px;margin:0 auto;padding-inline:var(--gutter)}
section{position:relative}
.sec{padding-block:clamp(64px,9vw,128px)}
.sec-sm{padding-block:clamp(48px,6vw,84px)}

/* ---------- Typography ---------- */
h1,h2,h3,h4{line-height:1.18;letter-spacing:-.025em;font-weight:700;color:var(--navy-900)}
.display{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:800;line-height:1.08;letter-spacing:-.035em}
.h1{font-size:clamp(2.1rem,4.4vw,3.3rem);font-weight:800}
.h2{font-size:clamp(1.7rem,3.2vw,2.5rem);font-weight:700}
.h3{font-size:clamp(1.3rem,2vw,1.6rem);font-weight:700}
.lead{font-size:clamp(1.15rem,1.6vw,1.4rem);color:var(--muted);font-weight:400;line-height:1.7}
.muted{color:var(--muted)}
.balance{text-wrap:balance}
.pretty{text-wrap:pretty}

/* Eyebrow label */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.85rem;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;color:var(--navy-600);
  margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--navy-600);opacity:.7}
.eyebrow.on-dark{color:var(--navy-200)}
.eyebrow.on-dark::before{background:var(--navy-200)}
.eyebrow.center{justify-content:center}

.sec-head{max-width:760px}
.sec-head.center{margin-inline:auto;text-align:center}

/* index number */
.idx{font-size:.95rem;font-weight:700;color:var(--navy-300);letter-spacing:.1em}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-size:1.05rem;font-weight:700;letter-spacing:-.01em;
  padding:16px 30px;border-radius:999px;border:1.5px solid transparent;
  transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s,box-shadow .25s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn .ico{width:20px;height:20px;flex:none}
.btn-primary{background:var(--navy-700);color:#fff;box-shadow:0 12px 30px rgba(27,53,99,.28)}
.btn-primary:hover{background:var(--navy-800);box-shadow:0 18px 40px rgba(27,53,99,.34)}
.btn-ghost{background:transparent;color:var(--navy-800);border-color:var(--navy-200)}
.btn-ghost:hover{border-color:var(--navy-700);background:var(--white)}
.header-light .header-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.42)}
.header-light .header-cta .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.site-header.scrolled .header-cta .btn-ghost{color:var(--navy-800);border-color:var(--navy-200)}
.btn-white{background:#fff;color:var(--navy-900)}
.btn-white:hover{background:#fff;box-shadow:0 18px 40px rgba(0,0,0,.18)}
.btn-outline-light{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.34)}
.btn-outline-light:hover{background:rgba(255,255,255,.14);border-color:#fff}
.btn-lg{padding:19px 38px;font-size:1.12rem}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--header-h);
  display:flex;align-items:center;
  transition:background .35s var(--ease),box-shadow .35s var(--ease),height .35s var(--ease);
}
.site-header .wrap-wide{display:flex;align-items:center;justify-content:space-between;width:100%}
.site-header.scrolled{background:rgba(250,250,247,.86);backdrop-filter:saturate(180%) blur(16px);box-shadow:0 1px 0 var(--line),0 8px 30px rgba(14,29,58,.06);height:72px}
.site-header.solid{background:var(--paper);box-shadow:0 1px 0 var(--line)}

/* scrolled state always uses dark text on light bg (overrides header-light) */
.site-header.scrolled .brand .bn b{color:var(--navy-900)}
.site-header.scrolled .brand .bn span{color:var(--navy-500)}
.site-header.scrolled .brand svg{--logo-loop:var(--navy-700);--logo-plus:#fff}
.site-header.scrolled .nav>li>a{color:var(--navy-900)}
.site-header.scrolled .nav>li>a:hover,.site-header.scrolled .nav>li.active>a{color:var(--navy-700)}
.site-header.scrolled .burger span{background:var(--navy-900)}

.brand{display:flex;align-items:center;gap:13px;z-index:2;flex:none}
.brand svg{height:38px;width:auto;flex:none}
.brand .bn{display:flex;flex-direction:column;line-height:1.05}
.brand .bn b{font-size:1.32rem;font-weight:800;color:var(--navy-900);letter-spacing:-.03em;white-space:nowrap}
.brand .bn span{font-size:.72rem;font-weight:600;letter-spacing:.2em;color:var(--navy-500);text-transform:uppercase;white-space:nowrap}
.header-light .brand .bn b{color:#fff}
.header-light .brand .bn span{color:var(--navy-200)}

/* desktop nav */
.nav{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.nav>li{position:relative;list-style:none}
.nav>li>a{
  display:flex;align-items:center;white-space:nowrap;
  padding:11px 13px;font-size:.98rem;font-weight:600;color:var(--navy-900);border-radius:10px;
  transition:color .2s,background .2s;
}
.header-light .nav>li>a{color:rgba(255,255,255,.92)}
.nav>li>a:hover,.nav>li.active>a{color:var(--navy-700)}
.header-light .nav>li>a:hover,.header-light .nav>li.active>a{color:#fff}

/* dropdown */
.submenu{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:210px;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-md);padding:10px;
  opacity:0;visibility:hidden;transition:opacity .22s var(--ease),transform .22s var(--ease);
}
.nav>li:hover .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.submenu::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px}
.submenu a{display:block;padding:11px 15px;border-radius:9px;font-size:.97rem;font-weight:500;color:var(--ink);transition:background .18s,color .18s}
.submenu a:hover{background:var(--paper-2);color:var(--navy-700)}

.header-cta{display:flex;align-items:center;gap:8px;flex:none}
.header-cta .btn{padding:11px 18px;font-size:.96rem;white-space:nowrap}

/* hamburger */
.burger{display:none;width:46px;height:46px;border:none;background:transparent;position:relative;z-index:120}
.burger span{position:absolute;left:11px;right:11px;height:2.5px;background:var(--navy-900);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
.header-light .burger span{background:#fff}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:23px}
.burger span:nth-child(3){top:30px}
body.menu-open .burger span{background:var(--navy-900)}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.mobile-nav{
  position:fixed;inset:0;z-index:110;background:var(--paper);
  padding:26px var(--gutter) 40px;
  overflow-y:auto;transform:translateX(100%);transition:transform .42s var(--ease);
  display:flex;flex-direction:column;
}
body.menu-open .mobile-nav{transform:translateX(0)}
.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}
.mobile-nav-head b{display:block;font-size:1.25rem;font-weight:800;color:var(--navy-900);letter-spacing:-.03em}
.mobile-nav-head span{display:block;margin-top:3px;font-size:.75rem;font-weight:700;letter-spacing:.16em;color:var(--navy-500);text-transform:uppercase}
.mobile-close{width:48px;height:48px;border:1px solid var(--line);border-radius:50%;background:#fff;position:relative;flex:none;box-shadow:var(--shadow-sm)}
.mobile-close span{position:absolute;left:14px;right:14px;top:50%;height:2px;background:var(--navy-900);border-radius:2px}
.mobile-close span:first-child{transform:rotate(45deg)}
.mobile-close span:last-child{transform:rotate(-45deg)}
.mobile-nav .mgroup{border-bottom:1px solid var(--line)}
.mobile-nav .mtop{display:flex;align-items:center;justify-content:space-between;width:100%;padding:20px 4px;font-size:1.3rem;font-weight:700;color:var(--navy-900);background:none;border:none;text-align:left}
.mobile-nav .mtop .caret{width:10px;height:10px;border-right:2.5px solid var(--navy-300);border-bottom:2.5px solid var(--navy-300);transform:rotate(45deg);transition:transform .3s}
.mobile-nav .mgroup.open .mtop .caret{transform:rotate(-135deg)}
.mobile-nav .msub{overflow:hidden;max-height:0;transition:max-height .35s var(--ease)}
.mobile-nav .msub a{display:block;padding:11px 4px 11px 18px;font-size:1.08rem;color:var(--muted);font-weight:500}
.mobile-nav .msub a:active{color:var(--navy-700)}
.mobile-nav .m-cta{margin-top:28px;display:flex;flex-direction:column;gap:12px}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-950);color:var(--navy-200);padding-block:72px 36px}
.site-footer .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px}
.site-footer .brand .bn b{color:#fff}
.site-footer .fdesc{margin-top:20px;color:var(--navy-300);max-width:340px;line-height:1.8}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:18px;letter-spacing:0}
.site-footer ul{list-style:none}
.site-footer .flinks li{margin-bottom:11px}
.site-footer .flinks a{color:var(--navy-200);font-size:.98rem;transition:color .2s}
.site-footer .flinks a:hover{color:#fff}
.site-footer .finfo li{margin-bottom:12px;color:var(--navy-200);font-size:.98rem;display:flex;gap:10px}
.site-footer .finfo li b{color:#fff;font-weight:600;flex:none;min-width:58px}
.fbar{margin-top:54px;padding-top:26px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;color:var(--navy-300);font-size:.9rem}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{
  background:
    linear-gradient(90deg,rgba(5,14,31,.68) 0%,rgba(5,14,31,.42) 48%,rgba(5,14,31,.18) 100%),
    linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.2)),
    url("../images/index/hero/hero-1.png") center/cover no-repeat;
  color:#fff;padding-top:calc(var(--header-h) + 56px);padding-bottom:84px;
  position:relative;overflow:hidden;
}
.page-hero .wrap{position:relative;z-index:1}
.page-hero .eyebrow{color:var(--navy-200)}
.page-hero .eyebrow::before{background:var(--navy-200)}
.page-hero h1{color:#fff;font-size:clamp(2.3rem,4.6vw,3.6rem);font-weight:800;text-shadow:0 4px 22px rgba(0,0,0,.32)}
.page-hero p{color:rgba(255,255,255,.86);font-size:1.2rem;margin-top:18px;max-width:620px;text-shadow:0 3px 16px rgba(0,0,0,.28)}
.crumbs{display:flex;gap:8px;align-items:center;font-size:.92rem;color:var(--navy-300);margin-bottom:24px;flex-wrap:wrap}
.crumbs a,.crumbs span{white-space:nowrap}
.crumbs a:hover{color:#fff}
.crumbs span{opacity:.5}

/* ---------- Cards & components ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.card.hover:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.card-pad{padding:clamp(26px,3vw,40px)}

.grid{display:grid;gap:clamp(18px,2.2vw,28px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* feature item with number */
.feat{display:flex;flex-direction:column;gap:14px}
.feat .fnum{font-size:1rem;font-weight:800;color:var(--navy-300);letter-spacing:.05em}
.feat h3{font-size:1.3rem}

/* icon chip */
.chip{width:60px;height:60px;border-radius:16px;background:var(--navy-100);display:flex;align-items:center;justify-content:center;color:var(--navy-700);flex:none}
.chip svg{width:30px;height:30px}
.chip.dark{background:var(--navy-700);color:#fff}

/* ---------- Image placeholder ---------- */
.ph{
  position:relative;border-radius:var(--radius);overflow:hidden;background:var(--navy-900);
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.035) 0 12px,transparent 12px 24px);
  display:flex;align-items:center;justify-content:center;color:var(--navy-200);
}
.ph::after{content:attr(data-label);font-family:"SFMono-Regular",ui-monospace,Menlo,Consolas,monospace;font-size:.82rem;letter-spacing:.05em;color:rgba(255,255,255,.5);padding:8px 14px;border:1px dashed rgba(255,255,255,.25);border-radius:8px;text-align:center}
.ph.light{background:var(--paper-2);background-image:repeating-linear-gradient(135deg,rgba(27,53,99,.05) 0 12px,transparent 12px 24px)}
.ph.light::after{color:var(--navy-500);border-color:rgba(27,53,99,.25)}
.ph.photo{display:block;background:none;background-image:none}
.ph.photo::after{display:none}
.ph.photo img{width:100%;height:100%;object-fit:cover}
.ratio-4-3{aspect-ratio:4/3}
.ratio-1-1{aspect-ratio:1/1}
.ratio-3-2{aspect-ratio:3/2}
.ratio-16-9{aspect-ratio:16/9}
.ratio-3-4{aspect-ratio:3/4}

/* ---------- List with check ---------- */
.checklist{list-style:none;display:flex;flex-direction:column;gap:16px}
.checklist li{display:flex;gap:14px;align-items:flex-start;font-size:1.08rem;line-height:1.6}
.checklist li .ck{width:26px;height:26px;border-radius:50%;background:var(--navy-700);color:#fff;flex:none;display:flex;align-items:center;justify-content:center;margin-top:2px}
.checklist li .ck svg{width:14px;height:14px}

/* ---------- Steps ---------- */
.steps{display:grid;gap:20px;counter-reset:s}
.step{display:flex;gap:22px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 30px;box-shadow:var(--shadow-sm)}
.step .sn{counter-increment:s;flex:none;width:52px;height:52px;border-radius:50%;background:var(--navy-700);color:#fff;font-weight:800;font-size:1.25rem;display:flex;align-items:center;justify-content:center}
.step .sn::before{content:counter(s,decimal-leading-zero)}
.step h3{font-size:1.25rem;margin-bottom:6px}

/* ---------- Tables (cost, menu) ---------- */
.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.tbl th,.tbl td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--line-soft);font-size:1.05rem}
.tbl thead th{background:var(--navy-800);color:#fff;font-weight:700;letter-spacing:-.01em}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:nth-child(even){background:var(--paper)}
.tbl td b{color:var(--navy-800)}

/* menu calendar */
.menu-cal{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.menu-day{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.menu-day .md-head{background:var(--navy-800);color:#fff;padding:14px;text-align:center;font-weight:700}
.menu-day .md-body{padding:18px 16px;display:flex;flex-direction:column;gap:10px}
.menu-day .md-meal{font-size:.95rem;line-height:1.5}
.menu-day .md-meal b{display:block;font-size:.78rem;letter-spacing:.08em;color:var(--navy-500);margin-bottom:3px;font-weight:700}

/* ---------- Gallery ---------- */
.gallery{columns:3;column-gap:18px}
.gallery .gitem{break-inside:avoid;margin-bottom:18px;border-radius:var(--radius);overflow:hidden}
.gtabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px}
.gtab{padding:12px 24px;border-radius:999px;border:1.5px solid var(--line);background:#fff;font-weight:600;font-size:1rem;color:var(--muted);transition:all .2s}
.gtab.active,.gtab:hover{background:var(--navy-700);border-color:var(--navy-700);color:#fff}

/* ---------- Notice list ---------- */
.notice-list{border-top:2px solid var(--navy-800)}
.notice-row{display:flex;align-items:center;gap:24px;padding:24px 8px;border-bottom:1px solid var(--line);transition:background .2s}
.notice-row:hover{background:#fff}
.notice-tag{flex:none;font-size:.85rem;font-weight:700;padding:6px 14px;border-radius:999px;background:var(--navy-100);color:var(--navy-700)}
.notice-tag.notice{background:var(--navy-800);color:#fff}
.notice-row .nt{flex:1;font-size:1.15rem;font-weight:600;color:var(--navy-900)}
.notice-row .nd{color:var(--muted);font-size:.95rem;flex:none}

/* ---------- Form ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:clamp(28px,4vw,52px)}
.field{margin-bottom:24px}
.field label{display:block;font-weight:700;font-size:1.02rem;margin-bottom:10px;color:var(--navy-900)}
.field label .req{color:#c0392b;margin-left:4px}
.field input,.field textarea,.field select{
  width:100%;padding:16px 18px;font-size:1.05rem;font-family:inherit;
  border:1.5px solid var(--line);border-radius:12px;background:var(--paper);color:var(--ink);
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--navy-600);background:#fff;box-shadow:0 0 0 4px rgba(39,74,133,.1)}
.field textarea{min-height:160px;resize:vertical;line-height:1.6}
.checkbox{display:flex;gap:12px;align-items:flex-start;font-size:.98rem;color:var(--muted)}
.checkbox input{width:auto;margin-top:5px}

/* contact info side */
.cinfo{display:flex;flex-direction:column;gap:8px}
.cinfo .ci{display:flex;gap:18px;align-items:flex-start;padding:22px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.cinfo .ci:last-child{border-bottom:none}
.cinfo .ci .chip{background:rgba(255,255,255,.1);color:#fff}
.cinfo .ci h4{color:#fff;font-size:1.1rem;margin-bottom:4px}
.cinfo .ci p{color:var(--navy-200);font-size:1.02rem}

/* split panel */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,64px);align-items:center}
.split.rev .col-text{order:2}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.stat{text-align:center}
.stat .num{font-size:clamp(2.4rem,4vw,3.4rem);font-weight:800;color:var(--navy-800);line-height:1;letter-spacing:-.04em}
.stat .lbl{margin-top:10px;color:var(--muted);font-weight:500}

/* divider tag */
.tag{display:inline-block;font-size:.82rem;font-weight:700;letter-spacing:.04em;padding:6px 13px;border-radius:999px;background:var(--navy-100);color:var(--navy-700)}

/* map placeholder */
.map-box{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--line)}

/* floating quick contact (mobile) */
.quickbar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(14,29,58,.08)}
.quickbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:11px 4px;font-size:.78rem;font-weight:600;color:var(--navy-800)}
.quickbar a svg{width:22px;height:22px}
.quickbar a.kakao{background:var(--navy-800);color:#fff}

/* floating quick actions (desktop) */
.floating-actions{position:fixed;right:28px;bottom:28px;z-index:95;display:flex;flex-direction:column;gap:10px}
.fa-btn{
  width:58px;height:58px;border-radius:50%;border:1px solid rgba(255,255,255,.72);
  background:rgba(255,255,255,.94);color:var(--navy-800);box-shadow:0 14px 34px rgba(14,29,58,.18);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  font-size:.68rem;font-weight:800;letter-spacing:.02em;transition:transform .22s var(--ease),box-shadow .22s var(--ease),background .22s;
}
.fa-btn:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(14,29,58,.24)}
.fa-btn .ico{width:21px;height:21px;flex:none}
.fa-btn.kakao{background:var(--navy-800);color:#fff;border-color:rgba(255,255,255,.18)}
.fa-btn.phone{background:var(--navy-700);color:#fff;border-color:rgba(255,255,255,.18)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1 !important;transform:none !important}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Responsive ---------- */
@media(max-width:1240px){
  :root{--header-h:74px}
  .nav,.header-cta{display:none}
  .burger{display:block}
}
@media(max-width:1080px){
  .menu-cal{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  body{font-size:17px}
  h1,h2,h3,h4,p,li,a,button,span{word-break:keep-all;overflow-wrap:break-word}
  h1,h2,h3,h4,.lead,.pretty{text-wrap:balance}
  p,.muted,.checklist li{line-break:strict}
  .sec,.sec-sm,.page-hero,.site-footer{text-align:center}
  .eyebrow{justify-content:center}
  .sec-head{margin-left:auto;margin-right:auto;text-align:center}
  .lead,.pretty{margin-left:auto;margin-right:auto}
  .checklist li{justify-content:center;text-align:center}
  .prog-card,.feat,.card{text-align:center}
  .btn{justify-content:center}
  .g-3,.g-4{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:32px}
  .split.rev .col-text{order:0}
  .stats{grid-template-columns:repeat(3,1fr);gap:12px}
  .gallery{columns:2}
  .site-footer .fgrid{grid-template-columns:1fr 1fr;gap:34px}
  .site-footer .brand-col{grid-column:1/-1}
  .site-footer .brand{justify-content:center}
  .site-footer .fdesc{margin-left:auto;margin-right:auto}
  .site-footer .finfo{margin-left:auto;margin-right:auto}
  .site-footer .finfo li{justify-content:center}
  .fbar{justify-content:center;text-align:center}
  .floating-actions{display:none}
  .quickbar{display:flex}
  body{padding-bottom:0}
  .notice-row{flex-wrap:wrap;gap:10px}
  .notice-row .nt{flex-basis:100%;order:3;font-size:1.05rem}
}
@media(max-width:540px){
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .menu-cal{grid-template-columns:1fr}
  .gallery{columns:1}
  .stats{grid-template-columns:1fr;gap:18px}
  .stat{display:flex;align-items:baseline;justify-content:center;gap:14px}
  .stat .lbl{margin-top:0}
  .site-footer .fgrid{grid-template-columns:1fr}
  .btn{width:100%}
  .step{padding:22px}
}
