/* 빛가람 계단수리 — C03 Charcoal Mustard */
:root{
  --bg:#F7F6F3; --bg-alt:#E8E5DD; --surface:#F7F6F3;
  --text:#1A1A1A; --mute:#6B6B68; --line:#DDD9CF;
  --primary:#2D2D2A; --primary-deep:#1A1A1A; --accent:#C9962E;
  --shadow-sm:0 1px 2px rgba(26,26,26,.05);
  --shadow-md:0 8px 24px rgba(26,26,26,.08);
  --shadow-lg:0 24px 60px rgba(26,26,26,.14);
  --radius:1.5rem; --radius-pill:999px;
  --container:1180px;
  --nseo-primary:#100021;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Pretendard','Noto Sans KR','Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  background:var(--bg);color:var(--text);
  line-height:1.62;font-weight:400;
  word-break:keep-all;overflow-wrap:break-word;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit;color:inherit;background:none;border:0}
h1,h2,h3,h4{font-family:'Noto Serif KR','Pretendard',serif;font-weight:800;letter-spacing:-.01em;line-height:1.18;color:var(--text)}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.1rem,2vw,1.35rem)}
p{font-weight:300;color:var(--text)}
.container{max-width:var(--container);margin:0 auto;padding:0 1.25rem}
.eyebrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--accent)}
.lede{color:var(--mute);font-size:1.02rem;max-width:48rem;margin-top:.6rem;line-height:1.75}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ====== Header ====== */
.site-header{
  position:fixed;inset:0 0 auto 0;height:72px;z-index:50;
  background:rgba(247,246,243,.78);backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(221,217,207,.7);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:100%}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:700}
.brand img{width:auto;height:34px}
.brand-mark{display:flex;flex-direction:column;gap:.3rem;line-height:1.15}
.brand-mark b{font-family:'Noto Serif KR',serif;font-size:1.05rem;line-height:1.2}
.brand-mark span{font-size:.68rem;letter-spacing:.18em;color:var(--mute);text-transform:uppercase;line-height:1.2}
.footer-brand .brand-mark{gap:.45rem;line-height:1.25}
.footer-brand .brand-mark b{font-size:1.15rem;line-height:1.3}
.footer-brand .brand-mark span{font-size:.72rem;line-height:1.3}
.header-cta{display:flex;align-items:center;gap:.6rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--radius-pill);padding:.78rem 1.5rem;font-weight:600;font-size:.95rem;transition:transform .2s,box-shadow .2s,background .2s,color .2s,border-color .2s;border:1px solid transparent;cursor:pointer}
.btn-primary{background:var(--primary);color:#F7F6F3}
.btn-primary:hover{background:var(--primary-deep);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline{border-color:var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:var(--primary);color:#F7F6F3}
.btn-ghost{color:var(--text);background:rgba(45,45,42,.08)}
.btn-ghost:hover{background:rgba(45,45,42,.14)}
.btn-sm{padding:.6rem 1.1rem;font-size:.86rem}
/* Header keeps only brand + 상담 CTA — service navigation lives on the sitemap page (per spec) */

/* ====== Section spacing ====== */
section{padding:4.5rem 0}
@media(min-width:768px){section{padding:6rem 0}}
@media(max-width:520px){section{padding:3.2rem 0}}
section + section{border-top:1px solid var(--line)}

/* ====== Hero ====== */
.hero{position:relative;min-height:88vh;padding:140px 0 80px;overflow:hidden;background:var(--bg)}
@media(max-width:760px){.hero{min-height:auto;padding:118px 0 60px}}
@media(max-width:520px){.hero{padding:104px 0 48px}}
.hero .slides{position:absolute;inset:0}
.hero .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.hero .slide.is-active{opacity:1}
.hero .slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .slide::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(26,26,26,0) 0%,rgba(26,26,26,.55) 60%,rgba(26,26,26,.82) 100%)}
.hero-content{position:relative;z-index:2;color:#F7F6F3;max-width:740px}
.hero-content .eyebrow{color:#C9962E}
.hero-content .eyebrow::before{background:#C9962E}
.hero-content h1,.hero-content h2.hero-heading{color:#F7F6F3;margin:.7rem 0 1.1rem;font-size:clamp(1.9rem,4.6vw,3.1rem);font-family:'Noto Serif KR','Pretendard',serif;font-weight:800;letter-spacing:-.01em;line-height:1.18}
.hero-content p{color:rgba(247,246,243,.92);font-size:1.06rem;max-width:36rem;font-weight:300;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.hero-actions .btn-outline{color:#F7F6F3;border-color:rgba(247,246,243,.55)}
.hero-actions .btn-outline:hover{background:#F7F6F3;color:#1A1A1A;border-color:transparent}
.hero-note{position:relative;z-index:2;margin-top:3rem;display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem 1.4rem;background:rgba(26,26,26,.5);border:1px solid rgba(221,217,207,.18);border-radius:var(--radius);max-width:760px;color:#F7F6F3;font-size:.92rem;line-height:1.55}
.hero-note b{color:#C9962E;display:block;margin-bottom:.2rem;font-weight:600}
.hero-controls{position:absolute;inset:auto 0 28px 0;display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem;z-index:3}
.hero-dots{display:flex;gap:.5rem}
.hero-dots button{width:24px;height:4px;border-radius:4px;background:rgba(247,246,243,.4);transition:background .2s}
.hero-dots button.is-active{background:#C9962E}
.hero-arrows{display:flex;gap:.5rem}
.hero-arrows button{width:42px;height:42px;border-radius:50%;background:rgba(26,26,26,.35);color:#F7F6F3;display:flex;align-items:center;justify-content:center;border:1px solid rgba(247,246,243,.22)}
.hero-arrows button:hover{background:rgba(26,26,26,.6)}

/* Sub-page Hero (simpler) */
.sub-hero{position:relative;min-height:62vh;padding:140px 0 60px;overflow:hidden;background:var(--bg-alt)}
@media(max-width:760px){.sub-hero{min-height:auto;padding:108px 0 48px}}
@media(max-width:520px){.sub-hero{padding:96px 0 40px}}
.sub-hero .img-bg{position:absolute;inset:0}
.sub-hero .img-bg img{width:100%;height:100%;object-fit:cover}
.sub-hero .img-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(26,26,26,.1) 0%,rgba(26,26,26,.55) 60%,rgba(26,26,26,.82) 100%)}
.sub-hero .container{position:relative;z-index:2;color:#F7F6F3}
.sub-hero h1{color:#F7F6F3;margin:.8rem 0 1rem;font-size:clamp(2rem,4.8vw,3.4rem);font-family:'Noto Serif KR','Pretendard',serif;font-weight:800;line-height:1.15;letter-spacing:-.015em}
.sub-hero p{color:rgba(247,246,243,.92);max-width:36rem;font-weight:300}
.sub-hero .hero-actions{margin-top:1.6rem}

/* Breadcrumb */
.crumbs{position:relative;z-index:2;font-size:.84rem;color:rgba(247,246,243,.78);margin-bottom:.4rem}
.crumbs a{text-decoration:underline;text-underline-offset:3px;color:#C9962E}

/* ====== Cases (전후 비교) ====== */
.cases-section{background:var(--bg)}
.cases-section--top{padding-top:120px}
@media(min-width:768px){.cases-section--top{padding-top:140px}}
@media(max-width:520px){.cases-section--top{padding-top:96px}}
.cases-section--top .cases-head h1{font-size:clamp(2rem,4.8vw,3.4rem);line-height:1.15;letter-spacing:-.015em;margin:.6rem 0 .8rem}
.cases-head{max-width:48rem;margin-bottom:2.5rem}
.cases-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.6rem}
@media(max-width:760px){.cases-grid{grid-template-columns:1fr;gap:1.1rem}}
.case-card{background:var(--surface);border:1px solid var(--line);border-radius:0;overflow:hidden;transition:transform .3s,box-shadow .3s}
.case-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.case-pair{display:grid;grid-template-columns:1fr 1fr;gap:0}
.case-pair figure{position:relative;aspect-ratio:3/4;overflow:hidden;cursor:zoom-in}
@media(max-width:760px){.case-pair figure{aspect-ratio:4/5}}
.case-pair figure::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,26,0) 55%,rgba(26,26,26,.65) 100%);opacity:0;transition:opacity .25s ease;z-index:1;pointer-events:none}
.case-pair figure:hover::before{opacity:1}
.case-pair figure .cp-hint{position:absolute;right:.8rem;bottom:.8rem;z-index:2;display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;background:rgba(247,246,243,.94);color:#1A1A1A;font-size:.72rem;font-weight:700;letter-spacing:.05em;border-radius:var(--radius-pill);opacity:0;transform:translateY(6px);transition:opacity .25s ease,transform .25s ease}
.case-pair figure:hover .cp-hint,.case-pair figure:focus-visible .cp-hint{opacity:1;transform:translateY(0)}
.case-pair img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.case-card:hover .case-pair img{transform:scale(1.04)}

/* ====== Case lightbox (BEFORE + AFTER side by side) ====== */
.cp-modal{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;padding:1rem;background:rgba(26,26,26,.88);backdrop-filter:blur(6px);overflow-y:auto}
.cp-modal.is-open{display:flex;animation:cp-fade .25s ease}
@keyframes cp-fade{from{opacity:0}to{opacity:1}}
.cp-dialog{position:relative;width:min(1180px,100%);max-height:calc(100vh - 2rem);display:flex;flex-direction:column;background:var(--surface);border-radius:0;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,.5)}
.cp-pair{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:#1A1A1A}
.cp-figure{position:relative;background:#1A1A1A;aspect-ratio:3/4;overflow:hidden;margin:0}
.cp-figure img{width:100%;height:100%;object-fit:contain;background:#1A1A1A}
.cp-label{position:absolute;left:1rem;top:1rem;z-index:2;background:rgba(26,26,26,.82);color:#F7F6F3;font-size:.78rem;letter-spacing:.18em;font-weight:800;padding:.4rem .85rem;border-radius:var(--radius-pill)}
.cp-label--after{color:#1A1A1A;background:#C9962E}
.cp-close{position:absolute;right:.85rem;top:.85rem;z-index:5;width:40px;height:40px;border-radius:50%;background:rgba(247,246,243,.94);color:#1A1A1A;display:flex;align-items:center;justify-content:center;border:0;box-shadow:0 4px 14px rgba(0,0,0,.35);cursor:pointer;transition:background .2s,color .2s}
.cp-close:hover{background:#C9962E}
.cp-meta{padding:1.6rem 1.8rem 1.8rem;background:var(--surface);border-top:1px solid var(--line)}
.cp-meta .case-tag{margin-bottom:.5rem}
.cp-meta h3{margin:.3rem 0 .45rem;font-size:1.4rem;line-height:1.3}
.cp-meta p{font-size:.96rem;color:var(--mute);line-height:1.8}
@media(max-width:760px){
  .cp-modal{padding:0;align-items:flex-start}
  .cp-dialog{max-height:none;min-height:100vh}
  .cp-pair{grid-template-columns:1fr;gap:2px}
  .cp-figure{aspect-ratio:4/5}
  .cp-meta{padding:1.3rem 1.3rem 1.6rem}
  .cp-meta h3{font-size:1.2rem}
}
.case-pair figcaption{position:absolute;left:.8rem;top:.8rem;background:rgba(26,26,26,.78);color:#C9962E;font-size:.7rem;letter-spacing:.16em;padding:.3rem .65rem;border-radius:var(--radius-pill);font-weight:700}
.case-meta{padding:1.3rem 1.5rem 1.6rem}
.case-tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);background:rgba(45,45,42,.08);padding:.3rem .65rem;border-radius:var(--radius-pill)}
.case-meta h3{margin:.5rem 0 .4rem}
.case-meta p{font-size:.92rem;color:var(--mute)}

/* ====== Reusable two-col / numeric strip / steps ====== */
.numbers{background:var(--bg-alt)}
.numbers-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem;margin-top:2.2rem}
@media(max-width:860px){.numbers-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.num-card{padding:1.8rem 1.5rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.num-card .lbl{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.num-card .val{font-family:'Noto Serif KR',serif;font-size:2.1rem;font-weight:800;margin:.4rem 0;color:var(--primary-deep)}
.num-card p{font-size:.9rem;color:var(--mute)}

.services{background:var(--bg)}
.services-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.4rem;margin-top:2.4rem}
@media(max-width:860px){.services-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.services-grid{grid-template-columns:1fr}}
.svc-card{position:relative;padding:1.8rem 1.6rem 1.6rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:border-color .25s,transform .25s,box-shadow .25s}
.svc-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.svc-card .ic{width:46px;height:46px;border-radius:14px;background:rgba(201,150,46,.12);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.svc-card h3{margin:1rem 0 .3rem}
.svc-card p{font-size:.93rem;color:var(--mute)}

.process{background:var(--bg-alt)}
.steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.4rem;margin-top:2.4rem;counter-reset:step}
@media(max-width:860px){.steps{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step-card{position:relative;padding:1.8rem 1.5rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);counter-increment:step}
.step-card::before{content:counter(step,decimal-leading-zero);font-family:'Noto Serif KR',serif;font-size:1.6rem;font-weight:800;color:var(--accent)}
.step-card h3{margin:.4rem 0 .3rem;font-size:1.06rem}
.step-card p{font-size:.9rem;color:var(--mute)}

/* ====== NSEO card grid ====== */
.nseo-section{background:var(--bg)}
.nseo-head{max-width:48rem;margin-bottom:2.4rem}
.nseo-grid{list-style:none;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem}
@media(max-width:860px){.nseo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}}
@media(max-width:520px){.nseo-grid{gap:.7rem}}
@media(max-width:380px){.nseo-grid{gap:.55rem}}
.nseo-card{border-radius:0;overflow:hidden;background:var(--surface);border:1px solid var(--line);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative}
.nseo-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.nseo-card--main{border-color:var(--primary);box-shadow:0 0 0 2px rgba(45,45,42,.18) inset}
.nseo-card--current{opacity:.66;pointer-events:none}
.nseo-card-inner{display:grid;grid-template-rows:auto 1fr;height:100%}
a.nseo-card-inner{cursor:pointer}
.nseo-img{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--bg-alt)}
.nseo-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.nseo-card:hover .nseo-img img{transform:scale(1.06)}
.nseo-body{display:flex;flex-direction:column;gap:.55rem;padding:1.2rem 1.3rem 1.4rem}
@media(max-width:520px){.nseo-body{padding:.85rem .9rem 1rem;gap:.4rem}.nseo-title{font-size:.95rem}.nseo-desc{font-size:.78rem;-webkit-line-clamp:2}.nseo-badge{font-size:.62rem;padding:.25rem .55rem}.nseo-go{font-size:.78rem}}
.nseo-badge{align-self:flex-start;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#1A1A1A;background:var(--accent);padding:.32rem .7rem;border-radius:var(--radius-pill)}
.nseo-card--main .nseo-badge{background:var(--primary);color:#F7F6F3}
.nseo-title{font-family:'Noto Serif KR',serif;font-weight:800;font-size:1.05rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nseo-desc{font-size:.86rem;color:var(--mute);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.55}
.nseo-go{margin-top:auto;display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;color:var(--primary);padding-top:.3rem}
.nseo-card[hidden]{display:none!important}
.nseo-more-wrap{text-align:center;margin-top:2rem}

/* ====== Numeric / Process / FAQ ====== */
.faq-section{background:var(--bg)}
.faq-list{margin-top:2rem;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.3rem 0;font-weight:600;font-size:1.02rem;text-align:left}
.faq-q .icn{width:24px;height:24px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;transition:transform .25s,background .25s,color .25s}
.faq-item.is-open .faq-q .icn{transform:rotate(45deg);background:var(--primary);color:#F7F6F3;border-color:var(--primary)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--mute);font-size:.94rem;line-height:1.75}
.faq-item.is-open .faq-a{max-height:600px}
.faq-a-inner{padding:0 0 1.3rem}

/* ====== Related links (bottom) ====== */
.related{background:var(--bg-alt)}
.related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.2rem;margin-top:1.8rem}
@media(max-width:760px){.related-grid{grid-template-columns:1fr}}
.related-card{display:flex;flex-direction:column;gap:.4rem;padding:1.4rem 1.4rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:border-color .2s,transform .2s,box-shadow .2s}
.related-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.related-card span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700}
.related-card h3{margin:0;font-size:1rem}
.related-card p{font-size:.88rem;color:var(--mute)}

/* ====== Mid-banner (메인페이지 유도) ====== */
.midbanner{background:linear-gradient(120deg,#E8E5DD 0%,#DDD9CF 100%);border-radius:var(--radius);padding:2rem 2rem;display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:space-between;margin:0 1.25rem;border:1px solid var(--line)}
.midbanner h3{margin:0 0 .3rem;font-size:1.2rem}
.midbanner p{font-size:.92rem;color:var(--mute);max-width:34rem}

/* ====== CTA section ====== */
.cta-section{background:linear-gradient(140deg,#1A1A1A 0%,#2D2D2A 55%,#2D2D2A 100%);color:#F7F6F3;position:relative;overflow:hidden}
.cta-section::before{content:"";position:absolute;top:-160px;right:-160px;width:520px;height:520px;border-radius:50%;background:radial-gradient(closest-side,rgba(201,150,46,.18),transparent 70%)}
.cta-section h2,.cta-section p{color:#F7F6F3}
.cta-section p{color:rgba(247,246,243,.85)}
.cta-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.cta-section .btn-primary{background:#F7F6F3;color:#1A1A1A}
.cta-section .btn-primary:hover{background:#C9962E;color:#1A1A1A}
.cta-section .btn-outline{border-color:rgba(247,246,243,.4);color:#F7F6F3}
.cta-section .btn-outline:hover{background:#F7F6F3;color:#1A1A1A}
.cta-trust{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.8rem;color:rgba(247,246,243,.7);font-size:.82rem}
.cta-trust span{display:inline-flex;align-items:center;gap:.4rem}
.cta-trust span::before{content:"·";color:#C9962E;font-weight:800}

/* ====== Footer ====== */
.site-footer{background:#1A1A1A;color:#DDD9CF;padding:4.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1.2fr;gap:2rem}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-col h4{color:#C9962E;font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1rem;font-family:'Pretendard',sans-serif}
.footer-col p,.footer-col li{font-size:.9rem;color:#DDD9CF;font-weight:300;line-height:1.85}
.footer-col ul{list-style:none}
.footer-col a:hover{color:#C9962E}
.footer-brand .brand-mark b{color:#C9962E}
.footer-brand .brand-mark span{color:#DDD9CF}
.footer-brand p{margin-top:1rem;line-height:1.7;max-width:22rem;font-size:.9rem;color:rgba(221,217,207,.78)}
.footer-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(221,217,207,.15);display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.78rem;color:rgba(221,217,207,.6)}

/* ====== Floating button ====== */
.floating{position:fixed;right:1.2rem;bottom:1.2rem;z-index:40;display:flex;flex-direction:column;gap:.6rem;align-items:flex-end}
.floating .float-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem 1.3rem;border-radius:var(--radius-pill);background:var(--primary);color:#F7F6F3;font-weight:700;box-shadow:0 12px 32px rgba(45,45,42,.35)}
.floating .float-btn::after{content:"";position:absolute;inset:0;border-radius:var(--radius-pill);border:2px solid rgba(201,150,46,.5);animation:pulse-ring 3s infinite}
@keyframes pulse-ring{0%{transform:scale(1);opacity:1}100%{transform:scale(1.4);opacity:0}}
.floating .top-btn{width:44px;height:44px;border-radius:50%;background:var(--surface);color:var(--text);box-shadow:var(--shadow-md);display:none;align-items:center;justify-content:center;border:1px solid var(--line)}
.floating .top-btn.is-visible{display:inline-flex}

/* ====== Microdata 3 / 4 — visually hidden navigation ====== */
.md3-wrap,.md4-wrap{background:var(--md3-bg,#F9FAFB)}
.md3-hidden,.md4-hidden{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}
.md3-grid{display:grid;gap:.5rem;padding:.5rem}
.md3-card{padding:.6rem;background:transparent;color:var(--md3-title,#111);border:1px solid transparent;text-align:center;font-size:.85rem;border-radius:8px;transition:border-color .2s}
.md3-card:hover{border-color:var(--md3-hover,#111)}
.md4-list{display:grid;gap:.4rem;list-style:none;padding:.5rem;background:var(--md4-bg,#fff)}
.md4-list a{color:var(--md4-title,#202124);font-size:.85rem;padding:.4rem}
.md4-list a:hover{border-bottom:1px solid var(--md4-hover,#FFFFFF)}

/* ====== Sitemap page ====== */
.sm-wrap{padding-top:6rem}
.sm-search{display:flex;gap:.8rem;flex-wrap:wrap;margin:2rem 0 1rem}
.sm-search input{flex:1 1 240px;padding:.85rem 1.2rem;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--surface);font:inherit}
.sm-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.sm-filters button{padding:.55rem 1rem;border-radius:var(--radius-pill);border:1px solid var(--line);background:var(--surface);font-size:.86rem;color:var(--mute)}
.sm-filters button.is-active{background:var(--primary);color:#F7F6F3;border-color:var(--primary)}
.sm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1rem}
.sm-card{padding:1.2rem 1.3rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:transform .25s,box-shadow .25s,border-color .25s}
.sm-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.sm-card .lbl{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700}
.sm-card h3{margin:.3rem 0 .2rem;font-size:1rem}
.sm-card p{font-size:.84rem;color:var(--mute)}
.sm-count{font-size:.86rem;color:var(--mute)}
.sm-empty{margin-top:2rem;padding:1.4rem 1.5rem;text-align:center;color:var(--mute);background:var(--bg-alt);border:1px dashed var(--line);border-radius:var(--radius);font-size:.92rem}

/* ====== Consultation page (no form) ====== */
.consult-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:2rem 2.2rem;display:flex;flex-direction:column;gap:1rem}
.consult-row{display:flex;gap:.8rem;align-items:flex-start;padding:1rem 0;border-bottom:1px dashed var(--line)}
.consult-row:last-child{border-bottom:0}
.consult-step{flex:0 0 auto;width:36px;height:36px;border-radius:50%;background:var(--primary);color:#F7F6F3;display:flex;align-items:center;justify-content:center;font-weight:800;font-family:'Noto Serif KR',serif}
.consult-row h3{margin:.1rem 0 .3rem;font-size:1.05rem}
.consult-row p{font-size:.94rem;color:var(--mute);line-height:1.75}
.consult-actions{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-top:1.6rem}
@media(max-width:520px){.consult-actions{grid-template-columns:1fr}}
.consult-actions .btn{padding:1.1rem 1.4rem;font-size:1rem}

/* ====== 404 ====== */
.err-wrap{min-height:88vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 1.25rem 60px}
.err-wrap h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:.6rem}
.err-wrap p{max-width:32rem;color:var(--mute);margin-bottom:1.6rem}
.err-actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}

/* ====== fade in ====== */
.fade-in-up{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.fade-in-up.is-visible{opacity:1;transform:translateY(0)}

/* ====== utility ====== */
.text-mute{color:var(--mute)}
.eyebrow-dark{color:var(--primary)}
.divider{height:1px;background:var(--line);margin:2rem 0}
