/* ═══ 디자인 클론 출처 ═══
   참조: https://remodeling.kjibsuri.com/
   배경1~3: #ffffff / #faf7f6 / #f5efed
   폰트: Pretendard Variable / 200·400·600·700·800·900
   카드: radius 2px / 1px solid #e8ddda / grid gap:0 + 내부 라인
   버튼: radius 999px (pill) / primary 그라디언트
   레이아웃: max-width 1280px / section padding 112px/80px/56px
   헤더: 흰색 / height 68px / border-bottom
   배경패턴: .section.alt 만 #faf7f6 교차
   ═══════════════════════ */

/* Primary: 파스텔 스틸블루 #A0C4D8 (랜덤 선정) */
:root {
  --primary: #A0C4D8;
  --primary-dark: #6A9DB8;
  --primary-soft: #E8F4FA;
  --surf: #faf7f6;
  --surf-2: #f5efed;
  --line: #e8ddda;
  --text: #2d3748;
  --text-muted: #718096;
  --text-light: #a0aec0;
  --ff: 'Pretendard Variable','Pretendard',-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  --r-xs: 2px;
  --r-pill: 999px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.08);
  --shadow-md: 0 4px 14px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.06);
  --shadow-lg: 0 20px 40px -12px rgba(0,0,0,.18),0 8px 16px rgba(0,0,0,.08);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff);color:var(--text);background:#fff;word-break:keep-all;overflow-wrap:break-word;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4{margin:0 0 12px;line-height:1.25;letter-spacing:-.02em}

/* ── Layout ── */
.wrap{width:100%;max-width:1280px;margin:0 auto;padding:0 24px}
.section{padding:112px 0}
.section.alt{background:var(--surf)}
@media(max-width:880px){.section{padding:80px 0}}
@media(max-width:560px){.section{padding:56px 0}}

.section-head{text-align:center;max-width:760px;margin:0 auto 56px}
.section-title{margin-bottom:32px}
.eyebrow{display:inline-block;color:var(--primary-dark);font-weight:800;letter-spacing:.14em;font-size:11px;margin-bottom:12px;text-transform:uppercase}
.section-head p{color:var(--text-muted);font-size:16px;line-height:1.7;margin:0}
@media(max-width:880px){.section-head{margin-bottom:40px}}
@media(max-width:560px){.section-head{margin-bottom:32px}.section-head h2{font-size:24px}}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 26px;border-radius:var(--r-pill);font-weight:700;font-size:15px;line-height:1;border:1.5px solid transparent;transition:transform .15s,box-shadow .2s,background .2s,color .2s,border-color .2s;cursor:pointer;font-family:var(--ff)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#1a365d;box-shadow:0 10px 24px -8px rgba(160,196,216,.45)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px -10px rgba(160,196,216,.55)}
.btn-ghost{background:#fff;color:var(--primary-dark);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary-dark)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-dark{background:#1e293b;color:#fff}
.btn-dark:hover{background:#0f172a}
@media(max-width:560px){.btn{padding:13px 20px;font-size:14px}}

/* ── Header ── */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;height:68px}
.brand{display:inline-flex;align-items:center;gap:8px;line-height:1.15;letter-spacing:-.02em;text-decoration:none}
.brand-name{font-size:18px;font-weight:800;color:var(--primary-dark)}
.brand-kw{font-size:15px;font-weight:500;color:var(--text-muted)}
.nav-menu{display:flex;gap:28px;align-items:center}
.nav-menu a{font-size:14px;color:var(--text);font-weight:600;transition:color .2s}
.nav-menu a:hover{color:var(--primary-dark)}
.nav-cta{padding:10px 20px;border-radius:var(--r-pill);background:var(--primary);color:#1a365d!important;font-weight:700;font-size:14px;transition:background .2s,transform .15s}
.nav-cta:hover{background:var(--primary-dark);transform:translateY(-1px)}
.hamburger{display:none;color:var(--text);padding:6px;background:none;border:none}
.hamburger svg{width:24px;height:24px}

.mobile-drawer{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:60}
.mobile-drawer .panel{position:absolute;top:0;right:0;bottom:0;width:min(300px,85%);background:#fff;padding:24px 20px;display:flex;flex-direction:column;gap:10px;overflow-y:auto}
.mobile-drawer .panel a{padding:14px 4px;border-bottom:1px solid var(--line);font-weight:600;font-size:15px;display:block}
.mobile-drawer .close-btn{align-self:flex-end;color:var(--text-muted);padding:4px;background:none;border:none;font-size:20px;cursor:pointer}
.mobile-drawer.open{display:block}

@media(max-width:768px){
  .nav-menu,.nav-cta-wrap{display:none}
  .hamburger{display:flex;align-items:center;justify-content:center}
}

/* ── Portfolio Grid ── */
.portfolio-section{max-width:1280px;margin:0 auto;padding:0 24px}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:880px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.portfolio-grid{grid-template-columns:1fr}}

.portfolio-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:block;color:inherit;transition:background .3s;overflow:hidden;text-decoration:none}
.portfolio-card:hover{background:var(--surf)}
.card-thumb{aspect-ratio:4/3;overflow:hidden;background:var(--surf)}
.card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.portfolio-card:hover .card-thumb img{transform:scale(1.05)}
.card-body{padding:28px 24px;display:flex;flex-direction:column;gap:8px}
.card-badge{font-size:10px;font-weight:800;letter-spacing:.1em;background:var(--primary);color:#1a365d;display:inline-block;padding:.2rem .6rem;border-radius:.25rem;align-self:flex-start;text-transform:uppercase}
.card-title{font-weight:800;font-size:1rem;line-height:1.4;color:var(--text)}
.card-sub{font-weight:400;font-size:.875rem;color:var(--text-muted)}
.card-more{font-size:.875rem;font-weight:600;color:var(--text-muted);margin-top:.25rem;transition:color .3s}
.portfolio-card:hover .card-more{color:var(--primary-dark)}

/* ── Service Grid ── */
.service-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:1024px){.service-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.service-grid{grid-template-columns:repeat(2,1fr)}}

.service-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:block;color:inherit;transition:background .3s;overflow:hidden;text-decoration:none}
.service-card:hover{background:var(--surf)}
.service-thumb{aspect-ratio:3/4;overflow:hidden;background:var(--surf)}
.service-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.service-card:hover .service-thumb img{transform:scale(1.04)}
.service-body{padding:20px 18px 24px;display:flex;flex-direction:column;gap:6px}
.service-label{font-size:10px;font-weight:800;letter-spacing:.14em;color:var(--primary-dark);text-transform:uppercase}
.service-body h3{font-weight:800;font-size:.95rem;line-height:1.35;color:var(--text)}
.service-body p{font-size:.8rem;color:var(--text-muted);line-height:1.6;margin:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.service-more{font-size:.8rem;font-weight:700;color:var(--text-muted);transition:color .3s}
.service-card:hover .service-more{color:var(--primary-dark)}

/* ── Hero Overlay ── */
.hero-overlay{position:relative;overflow:hidden;min-height:560px;display:flex;align-items:center;justify-content:center;text-align:center}
.hero-overlay .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay .hero-dim{position:absolute;inset:0;background:rgba(0,0,0,.42);z-index:1}
.hero-overlay .hero-inner{position:relative;z-index:2;padding:80px 24px;max-width:820px;margin:0 auto}
.hero-overlay h2{color:#fff;font-size:clamp(26px,4vw,46px);font-weight:800;line-height:1.2;margin:0 0 16px;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.hero-overlay .hero-sub{color:rgba(255,255,255,.88);font-size:clamp(15px,2vw,18px);line-height:1.7;margin:0 0 32px;text-shadow:0 1px 6px rgba(0,0,0,.3)}
.hero-badges{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:13px;font-weight:600;padding:8px 16px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── Process ── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:768px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.process-grid{grid-template-columns:1fr}}
.process-step{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 32px}
.step-num{font-size:clamp(56px,7vw,96px);font-weight:200;color:var(--line);letter-spacing:-.04em;line-height:1;margin-bottom:24px}
.step-title{font-weight:800;font-size:18px;color:var(--text);margin-bottom:10px}
.step-desc{font-size:14px;color:var(--text-muted);line-height:1.7}
@media(max-width:560px){.process-step{padding:28px 20px}.step-title{font-size:16px}}

/* ── About ── */
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center}
@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:40px}}
.about-text h2{font-size:clamp(24px,3vw,36px);font-weight:800;color:var(--text);margin-bottom:20px}
.about-text p{color:var(--text-muted);line-height:1.8;margin-bottom:16px;font-size:15px}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.stat-item{background:#fff;padding:28px 24px;text-align:center}
.stat-num{font-size:clamp(28px,4vw,42px);font-weight:800;color:var(--primary-dark);line-height:1;display:block}
.stat-label{font-size:13px;color:var(--text-muted);margin-top:6px;display:block}

/* ── Areas ── */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:768px){.areas-grid{grid-template-columns:1fr}}
.area-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:36px 32px}
.area-name{font-weight:800;font-size:18px;color:var(--text);margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--primary)}
.area-list{display:flex;flex-wrap:wrap;gap:6px;list-style:none;margin:0;padding:0}
.area-list li{font-size:13px;color:var(--text-muted);background:var(--surf);padding:4px 10px;border-radius:var(--r-pill)}

/* ── FAQ ── */
.faq-list{max-width:800px;margin:0 auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;padding:20px 0;font-weight:700;font-size:15px;color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:16px;background:none;border:none;cursor:pointer;font-family:var(--ff);line-height:1.5}
.faq-q .faq-icon{flex-shrink:0;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s}
.faq-q.open .faq-icon{background:var(--primary);border-color:var(--primary)}
.faq-icon svg{width:10px;height:10px;transition:transform .3s;color:var(--text-muted)}
.faq-q.open .faq-icon svg{transform:rotate(45deg);color:#1a365d}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a.open{max-height:400px}
.faq-a-inner{padding:0 0 20px;color:var(--text-muted);line-height:1.8;font-size:14px}
.faq-num{font-size:11px;font-weight:800;color:var(--primary-dark);letter-spacing:.08em;margin-right:12px}

/* ── CTA Band ── */
.cta-band{background:linear-gradient(135deg,var(--primary-dark),#4a7a94);color:#fff;padding:80px 0;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 85% -10%,rgba(255,255,255,.12),transparent 60%);pointer-events:none}
.cta-inner{position:relative;z-index:1}
.cta-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:center}
@media(max-width:768px){.cta-grid{grid-template-columns:1fr;text-align:center}.cta-btns{justify-content:center}}
.cta-copy h2{color:#fff;font-size:clamp(22px,3vw,34px);font-weight:800;margin-bottom:8px;line-height:1.25}
.cta-copy p{color:rgba(255,255,255,.85);margin:0;line-height:1.7;font-size:15px}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap}
.cta-trust{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px}
.trust-badge{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:rgba(255,255,255,.9)}
.trust-badge svg{color:var(--primary);width:16px;height:16px;flex-shrink:0}
.cta-band .btn-primary{background:#fff;color:var(--primary-dark);box-shadow:0 10px 24px -8px rgba(0,0,0,.2)}
.cta-band .btn-primary:hover{background:var(--primary-soft);transform:translateY(-2px)}
.cta-band .btn-outline:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* ── Footer ── */
.site-footer{background:#1e293b;color:#fff;padding:72px 0 32px;font-size:13px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:56px;margin-bottom:40px}
@media(max-width:880px){.footer-grid{grid-template-columns:repeat(2,1fr);gap:32px}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr;gap:28px}}
.footer-brand h3{font-size:18px;font-weight:800;color:#fff;margin-bottom:8px}
.footer-brand p{color:rgba(255,255,255,.55);line-height:1.7;font-size:13px;margin:0}
.footer-col h4{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin:0 0 14px}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer-col ul li a{color:rgba(255,255,255,.7);font-size:13px;transition:color .2s}
.footer-col ul li a:hover{color:#fff}
.footer-col p{color:rgba(255,255,255,.6);font-size:13px;line-height:1.8;margin:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.biz-info{color:rgba(255,255,255,.45);font-size:12px;line-height:1.8}
.footer-copy{color:rgba(255,255,255,.35);font-size:12px}

/* ── Floating Button ── */
.fab-wrap{position:fixed;right:20px;bottom:24px;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.fab-main{width:52px;height:52px;border-radius:var(--r-pill);display:grid;place-items:center;color:#1a365d;background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:var(--shadow-lg),0 0 0 4px rgba(160,196,216,.18);transition:transform .2s,box-shadow .2s;cursor:pointer;border:none}
.fab-main:hover{transform:scale(1.06)}
.fab-main svg{width:22px;height:22px}
.fab-items{display:flex;flex-direction:column;align-items:flex-end;gap:8px;transition:opacity .25s,transform .25s}
.fab-items.hidden{opacity:0;transform:translateY(8px);pointer-events:none}
.fab-item{display:inline-flex;align-items:center;gap:8px;padding:9px 16px 9px 12px;border-radius:var(--r-pill);font-size:13px;font-weight:700;color:#fff;box-shadow:var(--shadow-md);transition:transform .2s;white-space:nowrap}
.fab-item:hover{transform:translateY(-2px)}
.fab-item.tel{background:#1e293b}
.fab-item.sms{background:var(--primary-dark);color:#fff}
.fab-item svg{width:16px;height:16px;flex-shrink:0}

/* ── Animations ── */
.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)}

/* ── Detail page ── */
.info-bar{background:var(--surf);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:28px 0}
.info-bar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-left:1px solid var(--line)}
@media(max-width:768px){.info-bar-grid{grid-template-columns:repeat(2,1fr)}}
.info-cell{border-right:1px solid var(--line);padding:20px 24px}
.info-cell-label{font-size:11px;font-weight:800;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:6px}
.info-cell-val{font-weight:700;font-size:15px;color:var(--text)}

.detail-hero{position:relative;min-height:400px;display:flex;align-items:flex-end;background-size:cover;background-position:center}
.detail-hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.detail-hero .hero-dim{position:absolute;inset:0;background:rgba(0,0,0,.52);z-index:1}
.detail-hero .hero-inner{position:relative;z-index:2;padding:40px 24px 48px;max-width:1280px;margin:0 auto;width:100%}
.detail-hero .back-link{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.8);font-size:13px;font-weight:600;margin-bottom:20px;transition:color .2s}
.detail-hero .back-link:hover{color:#fff}
.detail-hero h1{color:#fff;font-size:clamp(24px,4vw,40px);font-weight:800;text-shadow:0 2px 12px rgba(0,0,0,.35);margin:0 0 8px}
.detail-hero .detail-sub{color:rgba(255,255,255,.75);font-size:15px;font-weight:400}

.summary-box{background:var(--surf);border-left:4px solid var(--primary);padding:24px 28px;border-radius:var(--r-xs)}
.summary-box h3{font-size:15px;font-weight:800;color:var(--text);margin:0 0 14px}
.summary-box ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.summary-box ul li{font-size:14px;color:var(--text-muted);display:flex;align-items:flex-start;gap:8px}
.summary-box ul li::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--primary);margin-top:6px;flex-shrink:0}

.before-after-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:640px){.before-after-grid{grid-template-columns:1fr}}
.ba-img{border-radius:var(--r-xs);overflow:hidden;border:1px solid var(--line)}
.ba-img img{width:100%;height:auto;display:block}
.ba-label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--primary-dark);margin-top:10px;text-align:center}

.process-list{display:flex;flex-direction:column;gap:40px}
.process-row{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:flex-start}
@media(max-width:640px){.process-row{grid-template-columns:1fr}}
.process-badge{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--primary);color:#1a365d;font-weight:800;font-size:15px;flex-shrink:0}
.process-content h3{font-weight:800;font-size:17px;color:var(--text);margin:0 0 8px;padding-top:8px}
.process-content p{font-size:14px;color:var(--text-muted);line-height:1.8;margin:0}

.article-body p{color:var(--text-muted);line-height:1.9;font-size:15px;margin:0 0 16px}
.article-body h2{font-size:clamp(20px,2.5vw,28px);font-weight:800;color:var(--text);margin:40px 0 16px}

/* ── Consultation page ── */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:640px){.steps-grid{grid-template-columns:1fr}}
.step-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:36px 28px}
.step-card .step-num{font-size:clamp(48px,7vw,80px);font-weight:200;color:var(--line);line-height:1;margin-bottom:20px}
.step-card h3{font-weight:800;font-size:17px;color:var(--text);margin:0 0 10px}
.step-card p{font-size:14px;color:var(--text-muted);line-height:1.7;margin:0}

.photo-guide-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:640px){.photo-guide-grid{grid-template-columns:1fr}}
.photo-card{border:1px solid var(--line);border-radius:var(--r-xs);overflow:hidden}
.photo-card img{width:100%;height:220px;object-fit:cover}
.photo-card-body{padding:20px}
.photo-card-body h3{font-weight:800;font-size:15px;color:var(--text);margin:0 0 8px}
.photo-card-body p{font-size:13px;color:var(--text-muted);line-height:1.7;margin:0}

.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:640px){.benefits-grid{grid-template-columns:1fr}}
.benefit-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 28px;display:flex;flex-direction:column;gap:14px}
.benefit-card svg{color:var(--primary-dark);width:28px;height:28px}
.benefit-card h3{font-weight:800;font-size:15px;color:var(--text);margin:0}
.benefit-card p{font-size:13px;color:var(--text-muted);line-height:1.7;margin:0}

/* ── NSEO page ── */
.nseo-hero{position:relative;min-height:420px;display:flex;align-items:center;justify-content:center;text-align:center}
.nseo-hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.nseo-hero .hero-dim{position:absolute;inset:0;background:rgba(0,0,0,.42)}
.nseo-hero .hero-inner{position:relative;z-index:2;padding:80px 24px;max-width:720px;margin:0 auto}
.nseo-hero h1{color:#fff;font-size:clamp(26px,4vw,44px);font-weight:800;text-shadow:0 2px 12px rgba(0,0,0,.35);margin:0 0 14px;line-height:1.2}
.nseo-hero p{color:rgba(255,255,255,.85);font-size:clamp(15px,2vw,17px);line-height:1.7;margin:0 0 28px;text-shadow:0 1px 6px rgba(0,0,0,.3)}

.related-nav{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.related-link{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border:1px solid var(--line);border-radius:var(--r-pill);font-size:13px;font-weight:600;color:var(--text-muted);transition:border-color .2s,color .2s}
.related-link:hover{border-color:var(--primary);color:var(--primary-dark)}

/* ── NSEO template missing classes ── */
.section--gray{background:var(--surf)}
.section-more{text-align:center;margin-top:40px}

.card-grid{display:grid;gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.card-grid--3{grid-template-columns:repeat(3,1fr)}
.card-grid--5{grid-template-columns:repeat(5,1fr)}
@media(max-width:880px){.card-grid--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.card-grid--3{grid-template-columns:1fr}}
@media(max-width:1024px){.card-grid--5{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.card-grid--5{grid-template-columns:repeat(2,1fr)}}

.portfolio-card__thumb{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--surf)}
.portfolio-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.portfolio-card:hover .portfolio-card__thumb img{transform:scale(1.05)}
.portfolio-card__body{padding:28px 24px;display:flex;flex-direction:column;gap:8px}
.portfolio-card__title{font-weight:800;font-size:1rem;line-height:1.4;color:var(--text);display:block}
.portfolio-card__sub{font-weight:400;font-size:.875rem;color:var(--text-muted);margin:0}

.badge{font-size:10px;font-weight:800;letter-spacing:.1em;background:var(--primary);color:#1a365d;display:inline-block;padding:.2rem .6rem;border-radius:.25rem;text-transform:uppercase;position:absolute;top:12px;left:12px}

.service-card__img{aspect-ratio:3/4;overflow:hidden;background:var(--surf)}
.service-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.service-card:hover .service-card__img img{transform:scale(1.04)}
.service-card__body{padding:20px 18px 24px;display:flex;flex-direction:column;gap:6px}
.service-card__label{font-size:10px;font-weight:800;letter-spacing:.14em;color:var(--primary-dark);text-transform:uppercase}
.service-card__title{font-weight:800;font-size:.95rem;line-height:1.35;color:var(--text);display:block}
.service-card__desc{font-size:.8rem;color:var(--text-muted);line-height:1.6;margin:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.service-card--active{background:var(--primary-soft)}

.promo-banner{display:flex;align-items:center;justify-content:space-between;gap:24px;background:var(--surf);border:1px solid var(--line);border-radius:var(--r-xs);padding:32px 40px;flex-wrap:wrap}
.promo-banner__text{display:flex;flex-direction:column;gap:6px}
.promo-banner__text strong{font-weight:800;font-size:18px;color:var(--text)}
.promo-banner__text p{font-size:14px;color:var(--text-muted);margin:0}
@media(max-width:640px){.promo-banner{padding:24px 20px;flex-direction:column;align-items:flex-start}}

.article-intro{font-size:17px;color:var(--text-muted);line-height:1.9;margin:0 0 24px;border-left:3px solid var(--primary);padding-left:16px}

.related-pages{list-style:none;margin:0 auto;padding:0;display:flex;flex-direction:column;gap:12px;max-width:800px}
.related-page-link{display:flex;flex-direction:column;gap:4px;padding:20px 24px;border:1px solid var(--line);border-radius:var(--r-xs);transition:border-color .2s,background .2s;color:inherit}
.related-page-link:hover{border-color:var(--primary);background:var(--primary-soft)}
.related-page-link strong{font-weight:800;font-size:15px;color:var(--text)}
.related-page-link span{font-size:13px;color:var(--text-muted)}

.cta-band__title{color:#fff;font-size:clamp(22px,3vw,34px);font-weight:800;margin:0 0 12px;line-height:1.25;text-align:center}
.cta-band__desc{color:rgba(255,255,255,.85);font-size:15px;line-height:1.7;margin:0 0 28px;text-align:center}
.cta-band__btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── Portfolio detail page missing classes ── */
.detail-hero-dim{position:absolute;inset:0;background:rgba(0,0,0,.52);z-index:1}
.detail-hero-inner{position:relative;z-index:2;padding:40px 24px 48px;max-width:1280px;margin:0 auto;width:100%}
.process-imgs{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:16px}
.process-imgs img{border-radius:var(--r-xs);width:100%;height:200px;object-fit:cover}
