@charset "utf-8";
/* Pretendard Variable Font */
@font-face {
  font-family: 'Pretendard Variable';
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
  src: url('/fonts/PretendardVariable.woff2') format('woff2-variations');
}
/* Variables & Reset */
:root{
  --color-primary:#143a7b;
  --color-primary-dark:#0f2f6e;
  --color-dark:#111827;
  --color-gold:#c79d2e;
  --color-text:#111827;
  --color-text-sub:#667085;
  --color-border:#e4e7ec;
  --color-border-light:#d0d5dd;
  --color-bg:#ffffff;
  --color-bg-soft:#f8fafc;
  --color-white:#ffffff;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
/* SVG Icon System */
.icon{display:inline-block;width:1em;height:1em;vertical-align:-0.125em;fill:currentColor;stroke:none;overflow:visible;}
html{scrollbar-gutter:stable;}
body{font-family:"Pretendard Variable","Pretendard","Noto Sans KR",sans-serif;font-size:16px;line-height:1.6;color:var(--color-text);background:var(--color-bg);word-break:keep-all;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1;}
h1,h2,h3,h4,h5,h6,p,ul,ol,dl{margin:0;padding:0;}
ul,ol,li{list-style:none;}
a{text-decoration:none;color:inherit;}
button{font:inherit;cursor:pointer;}
img{display:block;max-width:100%;}
/* =====================================================
   Layout Wrapper
   - #wrap: 전체 페이지 래퍼
   - .inner: 최대 너비 1280px 중앙 정렬 컨테이너
   ===================================================== */
#wrap{overflow:hidden;background:#fff;}
.inner{max-width:1280px;margin:0 auto;padding:0 24px;}

/* =====================================================
   Section Common
   - .section: 섹션 기본 상하 패딩 (모든 섹션에서 공통 사용)
   ===================================================== */
.section{padding:110px 0;}

/* =====================================================
   Common Section Title (공통 섹션 타이틀)
   전체 페이지에서 동일하게 사용하는 섹션 헤더 구조:
     <div class="section-head">
       <p class="section-label">LABEL</p>
       <h2>타이틀</h2>
       <div class="about-divider"></div>
       <p class="section-desc">설명</p>
     </div>
   ===================================================== */
.section-label{font-size:13px;font-weight:800;letter-spacing:0.24em;color:#9ca3af;text-transform:uppercase;}
.section-label.dark-mode{color:rgba(255,255,255,0.45);}
.section-head{margin-bottom:60px;}
.section-head .section-label{display:block;margin-bottom:16px;}
.section-head h2{margin:0;font-size:48px;line-height:1.2;font-weight:800;color:#111;letter-spacing:-0.03em;}
.section-desc{font-size:16px;line-height:1.8;color:#666;max-width:680px;}
/* 섹션 구분선 - section-head 내 h2 아래 강조 라인 */
.about-divider,.section-divider{width:64px;height:4px;border-radius:2px;background:linear-gradient(90deg,var(--color-primary),#5b8cff);margin:28px 0 24px;}
/* =====================================================
   Buttons (공통 버튼)
   - .btn: 기본 버튼 베이스
   - .btn-dark: 주색 채워진 버튼
   - .btn-outline / .btn-light: 아웃라인 버튼
   - .btn-white: 흰색 버튼 (다크 배경용)
   - .btn-ghost: 투명 배경 버튼 (다크 배경용)
   - .btn-small: 작은 사이즈
   ===================================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;min-width:140px;padding:0 28px;height:50px;border-radius:999px;font-size:15px;font-weight:700;transition:all .25s ease;}
/* 목록으로 공통 */
.btn-back-wrap{display:flex;justify-content:center;margin-top:48px;}
.btn-back{display:inline-flex;align-items:center;gap:8px;height:50px;padding:0 32px;border-radius:999px;background:var(--color-primary);color:#fff;font-size:15px;font-weight:700;text-decoration:none;transition:opacity .2s;}
.btn-back:hover{opacity:.88;}
.btn-back svg{width:18px;height:18px;fill:currentColor;flex-shrink:0;}
.btn-back-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#1e293b;text-decoration:none;transition:color .2s;}
.btn-back-link:hover{color:var(--color-primary);}
.btn-dark{background:var(--color-primary);color:#fff;border:1px solid var(--color-primary);}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(20,58,123,0.25);background:var(--color-primary-dark);border-color:var(--color-primary-dark);}
.btn-outline{background:var(--color-white);color:var(--color-text-sub);border:1px solid var(--color-border-light);}
.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary);}
.btn-light{background:var(--color-white);color:var(--color-text-sub);border:1px solid var(--color-border-light);}
.btn-light:hover{border-color:var(--color-primary);color:var(--color-primary);}
.btn-white{background:var(--color-white);color:var(--color-text);border:1px solid var(--color-white);transition:transform .25s ease,box-shadow .25s ease,background .25s ease;}
.btn-white:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,255,255,0.18);}
.btn-ghost{background:transparent;color:var(--color-white);border:1px solid rgba(255,255,255,0.3);transition:transform .25s ease,background .25s ease,border-color .25s ease;}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--color-white);background:rgba(255,255,255,0.08);}
.btn-small{height:44px;padding:0 22px;font-size:14px;}
/* CTA Button (그라디언트/다크 배경 섹션용 버튼) */
.btn-cta-primary{display:inline-flex;align-items:center;justify-content:center;min-width:152px;height:56px;padding:0 28px;border-radius:999px;font-size:16px;font-weight:700;background:#fff;color:#123782;transition:all .25s ease;}
.btn-cta-primary:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(255,255,255,.14);}
.btn-cta-outline{display:inline-flex;align-items:center;justify-content:center;min-width:152px;height:56px;padding:0 28px;border-radius:999px;font-size:16px;font-weight:700;border:1px solid rgba(255,255,255,.42);color:#fff;background:rgba(255,255,255,.04);transition:all .25s ease;}
.btn-cta-outline:hover{background:rgba(255,255,255,.1);}
.btn-cta-primary,.btn-cta-outline{width:100%;}
/* =====================================================
   Header & GNB (공통 헤더 / 글로벌 네비게이션)
   ===================================================== */
.site-header{position:sticky;top:0;left:0;z-index:200;background:rgba(255,255,255,0.97);backdrop-filter:blur(14px);border-bottom:1px solid #e8eaf0;overflow:visible;}
.header-inner{display:flex;align-items:center;height:88px;}
.logo-box{width:220px;flex-shrink:0;display:flex;align-items:center;}
.logo-link{display:block;}
.logo-img{display:block;height:40px;width:auto;}
.header-nav-wrap{flex:1;display:flex;justify-content:center;align-items:center;}
.header-side{width:220px;flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;gap:6px;}
.gnb{display:flex;align-items:center;}
.menu-item{position:relative;}
.menu-item>a{display:block;font-size:16px;font-weight:700;color:#374151;padding:0 28px;line-height:88px;white-space:nowrap;transition:color .2s;letter-spacing:-0.01em;position:relative;}
.menu-item>a::after{content:"";position:absolute;bottom:0;left:26px;right:26px;height:2px;background:var(--color-primary);border-radius:2px;transform:scaleX(0);transition:transform .22s ease;}
.menu-item>a:hover,.menu-item>a.active{color:var(--color-primary);}
.menu-item>a.active::after{transform:scaleX(1);}
.gnb-sub-wrap{position:absolute;top:100%;left:0;width:100%;background:rgba(10,18,40,0.97);backdrop-filter:blur(8px);box-shadow:0 24px 56px rgba(10,18,40,0.32);z-index:100;opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease;pointer-events:none;}
.site-header:hover .gnb-sub-wrap{opacity:1;visibility:visible;pointer-events:auto;}
.gnb-sub-inner{max-width:1280px;margin:0 auto;padding:36px 24px 48px;display:flex;align-items:flex-start;}
.gnb-sub-logo-gap{width:220px;flex-shrink:0;}
.gnb-sub-menu{flex:1;display:flex;align-items:flex-start;}
.gnb-sub-col{flex:1;padding:0 26px;border-left:1px solid rgba(255,255,255,0.08);display:flex;flex-direction:column;}
.gnb-sub-col:first-child{border-left:none;}
.gnb-sub-col a{display:block;font-size:16px;font-weight:600;line-height:1.4;color:rgba(255,255,255,0.78);white-space:nowrap;padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.06);transition:color .18s ease,padding-left .18s;}
.gnb-sub-col a:last-child{border-bottom:none;}
.gnb-sub-col a:hover{color:#fff;padding-left:5px;}
.gnb-sub-col a.active{color:#fff;font-weight:700;}
.header-utils{display:flex;align-items:center;gap:2px;}
.header-utils a{display:inline-flex;align-items:center;height:32px;padding:0 10px;font-size:12px;font-weight:600;color:#6b7280;border-radius:6px;transition:color .18s;text-decoration:none;}
.header-utils a:hover{color:var(--color-primary);}
.header-btns{display:flex;align-items:center;margin-left:4px;}
.header-btns .btn-dark{height:34px !important;padding:0 18px !important;min-width:0 !important;font-size:13px !important;font-weight:700 !important;border-radius:999px !important;line-height:1 !important;}
.header-btns .btn-dark:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(20,58,123,0.22);}
.header-menu-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:none;border-radius:8px;background:transparent;cursor:pointer;color:#374151;transition:all .18s ease;flex-shrink:0;margin-left:4px;}
.header-menu-btn:hover{color:var(--color-primary);background:#f0f4ff;}
.header-menu-btn svg{width:24px;height:24px;}
.pc-nav-overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(10,18,40,0.96);backdrop-filter:blur(8px);opacity:0;transition:opacity .25s ease;}
.pc-nav-overlay.open{opacity:1;}
@media(min-width:1025px){
  .pc-nav-overlay{display:block;pointer-events:none;}
  .pc-nav-overlay.open{pointer-events:auto;}
}
.pc-nav-inner{max-width:1280px;margin:0 auto;padding:0 48px;height:100%;display:flex;flex-direction:column;}
.pc-nav-head{display:flex;align-items:center;justify-content:space-between;height:88px;flex-shrink:0;}
.pc-nav-logo{display:block;}
.pc-nav-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:rgba(255,255,255,0.1);border-radius:50%;cursor:pointer;color:#fff;transition:background .2s;}
.pc-nav-close:hover{background:rgba(255,255,255,0.2);}
.pc-nav-close svg{width:20px;height:20px;stroke:#fff;}
.pc-nav-body{display:flex;gap:0;flex:1;align-items:flex-start;padding:60px 0;}
.pc-nav-col{flex:1;padding:0 32px;border-left:1px solid rgba(255,255,255,0.08);}
.pc-nav-col:first-child{border-left:none;padding-left:0;}
.pc-nav-cat{font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:24px;}
.pc-nav-col a{display:block;font-size:18px;font-weight:600;color:rgba(255,255,255,0.8);padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.06);transition:color .18s,padding-left .18s;}
.pc-nav-col a:last-child{border-bottom:none;}
.pc-nav-col a:hover{color:#fff;padding-left:6px;}
.site-header-mo{display:none;position:sticky;top:0;left:0;z-index:200;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);}
.mo-header-inner{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 10px 0 20px;}
.mo-logo-link{display:block;}
.mo-logo-img{display:block;height:32px;width:auto;}
.mo-menu-btn{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:44px;height:44px;background:none;border:none;cursor:pointer;padding:4px;}
.mo-menu-btn span{display:block;width:24px;height:2px;background:#111;border-radius:2px;transition:all .3s ease;}
.mo-nav-panel{position:fixed;inset:0;background:#fff;z-index:300;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;display:flex;flex-direction:column;overflow-y:auto;}
.mo-nav-panel.open{opacity:1;visibility:visible;}
.mo-nav-head{display:flex;align-items:center;justify-content:space-between;padding:0 10px 0 24px;height:64px;flex-shrink:0;}
.mo-nav-head .mo-logo-img{height:32px;}
.mo-nav-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#111;transition:opacity .2s;}
.mo-nav-close:hover{opacity:.6;}
.mo-nav-close svg{display:block;width:22px;height:22px;stroke:#111;stroke-width:1.8;stroke-linecap:round;}
.mo-nav-body{flex:1;padding:8px 0 24px;}
.mo-nav-group{border-bottom:1px solid #f0f2f6;}
.mo-nav-parent{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:68px;font-size:20px;font-weight:700;color:#111;letter-spacing:-0.02em;cursor:pointer;transition:color .2s;user-select:none;}
.mo-nav-parent:hover{color:var(--color-primary);}
.mo-nav-parent .mo-chev{width:20px;height:20px;stroke:#aaa;stroke-width:2;stroke-linecap:round;fill:none;transition:transform .28s ease;}
.mo-nav-group.open .mo-nav-parent .mo-chev{transform:rotate(180deg);}
.mo-nav-group.open .mo-nav-parent{color:var(--color-primary);}
.mo-nav-children{display:none;background:#fafbfc;border-top:1px solid #f0f2f6;}
.mo-nav-group.open .mo-nav-children{display:block;}
.mo-nav-children a{display:block;padding:14px 24px 14px 36px;font-size:16px;font-weight:600;color:#555;border-bottom:1px solid #f4f5f7;transition:color .2s,background .2s;}
.mo-nav-children a:last-child{border-bottom:none;}
.mo-nav-children a:hover{color:var(--color-primary);background:#f0f4ff;}
.mo-nav-children a.active{color:var(--color-primary);font-weight:700;}
.mo-nav-foot{padding:24px;border-top:1px solid #f0f2f6;display:flex;flex-direction:column;gap:12px;flex-shrink:0;}
.mo-nav-foot .btn{width:100%;justify-content:center;height:52px;font-size:15px;border-radius:14px;}
.mo-nav-foot-utils{display:flex;gap:20px;}
.mo-nav-foot-utils a{font-size:14px;font-weight:600;color:#9ca3af;transition:color .2s;}
.mo-nav-foot-utils a:hover{color:var(--color-primary);}
/* =====================================================
   Hero Section (메인 히어로 - index.jsp 전용)
   ===================================================== */
.hero-section{position:relative;padding:90px 0 70px;background:#fff;overflow:hidden;}
.hero-bg{position:absolute;top:-80px;right:-120px;width:540px;height:540px;background:radial-gradient(circle, rgba(0,0,0,0.06) 0%, rgba(0,0,0,0.02) 32%, rgba(255,255,255,0) 68%);pointer-events:none;}
.hero-inner{position:relative;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(420px,0.9fr);gap:48px;align-items:center;}
.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(17,24,39,0.8),rgba(20,58,123,0.7));}
.hero-media{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.page-home .site-header.pc{position:absolute;width:100%;background:transparent;border-bottom-color:transparent;backdrop-filter:none;}
.page-home .site-header.pc .menu-item>a{color:rgba(255,255,255,0.88);}
.page-home .site-header.pc .menu-item>a:hover,.page-home .site-header.pc .menu-item>a.active{color:#fff;}
.page-home .site-header.pc .menu-item>a.active::after{background:rgba(255,255,255,0.7);}
.page-home .site-header.pc .header-utils a{color:rgba(255,255,255,0.82);}
.page-home .site-header.pc .header-utils a:hover{color:#fff;}
.page-home .site-header.pc .header-btns .btn-dark{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.4);color:#fff;}
.page-home .site-header.pc .header-btns .btn-dark:hover{background:rgba(255,255,255,0.28);border-color:rgba(255,255,255,0.7);}
.page-home .site-header.pc .logo-img{filter:brightness(0) invert(1);}
.page-home .site-header.pc .header-menu-btn{color:rgba(255,255,255,0.88);}
.page-home .site-header.pc .header-menu-btn:hover{color:#fff;background:rgba(255,255,255,0.12);}
.page-home .site-header.pc .gnb-sub-wrap{background:rgba(10,18,40,0.97);}
.page-home .hero-section{margin-top:-88px;padding-top:calc(88px + 160px);padding-bottom:140px;min-height:680px;}
.page-home .site-header-mo{position:absolute;width:100%;background:transparent;border-bottom-color:transparent;backdrop-filter:none;}
.page-home .site-header-mo .mo-logo-img{filter:brightness(0) invert(1);}
.page-home .site-header-mo .mo-menu-btn span{background:#fff;}
.hero-copy{padding:30px 0;}
.hero-label{display:inline-flex;align-items:center;height:40px;padding:0 18px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;font-size:13px;font-weight:700;color:#666;box-shadow:0 8px 24px rgba(0,0,0,0.04);}
.hero-copy h1{margin-top:0;font-size:52px;line-height:1.25;font-weight:400;letter-spacing:-0.03em;color:#fff;animation:fadeUp 0.8s ease;}
.hero-copy h1 .h1-sub{font-size:30px;font-weight:400;color:rgba(255,255,255,0.72);letter-spacing:-0.02em;display:block;margin-bottom:4px;}
.hero-copy h1 .h1-main{font-size:56px;font-weight:800;color:#fff;letter-spacing:-0.04em;display:block;line-height:1.15;}
.hero-desc{margin-top:36px;margin-bottom:36px;max-width:560px;font-size:16px;line-height:1.85;color:rgba(255,255,255,0.78);animation:fadeUp 1s ease;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;animation:fadeUp 1.2s ease;}
/* =====================================================
   Main Page Sections & Cards (메인 페이지 섹션/카드)
   ===================================================== */
.core-list{display:flex;flex-direction:column;gap:14px;}
.core-list li{padding:20px 22px;border:1px solid #e5e7eb;border-radius:24px;background:#f9fafb;}
.core-list .num{display:block;font-size:12px;font-weight:800;letter-spacing:0.24em;color:#b0b8c4;}
.core-list strong{display:block;margin-top:6px;font-size:20px;font-weight:800;color:#111;}
.core-list p{margin-top:8px;font-size:14px;line-height:1.8;color:#666;}
.business-section{background:#f7f7f8;}
.business-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.business-card{overflow:hidden;border:1px solid #e5e7eb;border-radius:32px;background:#fff;box-shadow:0 18px 50px rgba(0,0,0,0.05);transition:transform .3s ease,box-shadow .3s ease;display:block;text-decoration:none;color:inherit;cursor:pointer;}
.business-card:hover{transform:translateY(-6px);box-shadow:0 26px 70px rgba(0,0,0,0.08);}
.card-more{display:inline-block;margin-top:20px;font-size:15px;font-weight:800;color:#111;}
.card-thumb{position:relative;height:250px;padding:22px;background-size:cover;background-position:center;}
.card-thumb::before{content:"";position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(to top, rgba(0,0,0,0.66), rgba(0,0,0,0.12));}
.thumb-num{position:relative;z-index:1;display:inline-flex;align-items:center;height:32px;padding:0 14px;border-radius:999px;background:rgba(255,255,255,0.92);font-size:12px;font-weight:800;color:#111;}
.card-thumb h3{position:absolute;left:22px;bottom:24px;right:22px;z-index:1;font-size:29px;line-height:1.25;font-weight:800;color:#fff;letter-spacing:-0.03em;}
.thumb-01{background-image:url("https://images.unsplash.com/photo-1516321318423-f06f85e504b3?auto=format&fit=crop&w=900&q=80");}
.thumb-02{background-image:url("https://images.unsplash.com/photo-1563986768494-4dee2763ff3f?auto=format&fit=crop&w=900&q=80");}
.thumb-03{background-image:url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=900&q=80");}
.thumb-04{background-image:url("https://images.unsplash.com/photo-1551288049-bebda4e38f71?auto=format&fit=crop&w=900&q=80");}
.card-body{padding:28px 24px 26px;}
.card-body p{font-size:15px;line-height:1.9;color:#666;}
.card-body a{display:inline-block;margin-top:20px;font-size:15px;font-weight:800;color:#111;}
.card{transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;cursor:pointer;}
.card:hover{transform:translateY(-6px);border-color:#c7d7fe;box-shadow:0 16px 30px rgba(20,58,123,0.15);}
.capability-section{background:#fff;padding:120px 0 80px;}
.capability-inner{display:grid;grid-template-columns:minmax(0,0.9fr) minmax(0,1.1fr);gap:60px;align-items:start;}
.capability-copy h2{margin-top:14px;font-size:48px;line-height:1.18;font-weight:800;letter-spacing:-0.04em;color:var(--color-text);}
.capability-desc{margin-top:24px;max-width:520px;font-size:18px;line-height:1.9;color:var(--color-text-sub);}
.capability-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.capability-item{min-height:220px;padding:30px 28px;border:1px solid var(--color-border);border-radius:28px;background:var(--color-white);box-shadow:0 18px 50px rgba(16,24,40,0.04);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;}
.capability-item:hover{transform:translateY(-6px);border-color:#c7d7fe;box-shadow:0 26px 70px rgba(20,58,123,0.12);}
.capability-item strong{display:block;font-size:24px;line-height:1.45;font-weight:800;letter-spacing:-0.03em;color:var(--color-text);}
.capability-item p{margin-top:16px;font-size:15px;line-height:1.9;color:var(--color-text-sub);}
/* =====================================================
   Portfolio & News (메인 포트폴리오/뉴스 섹션)
   ===================================================== */
.portfolio-section{background:#fff;}
.portfolio-inner{display:grid;grid-template-columns:minmax(0,0.85fr) minmax(0,1.15fr);gap:46px;align-items:start;}
.portfolio-copy{opacity:0;transform:translateY(40px);transition:all .8s ease;}
.portfolio-copy.active{opacity:1;transform:translateY(0);}
.portfolio-copy h2{margin-top:14px;font-size:50px;line-height:1.2;font-weight:800;color:#111;letter-spacing:-0.035em;position:relative;display:inline-block;}
.portfolio-copy h2::after{content:"";position:absolute;left:0;bottom:-10px;width:80px;height:4px;border-radius:2px;background:linear-gradient(90deg,var(--color-primary),#5b8cff);}
.portfolio-copy p{margin-top:24px;font-size:17px;line-height:1.9;color:#666;}
.strength-list{margin-top:34px;display:flex;flex-direction:column;gap:14px;}
.strength-list li{position:relative;padding:18px 20px 18px 46px;border:1px solid #e5e7eb;border-radius:22px;background:#f8f9fa;font-size:15px;font-weight:600;color:#555;transition:all .3s ease;}
.strength-list li::before{content:"";position:absolute;left:20px;top:50%;width:12px;height:12px;margin-top:-6px;border-radius:50%;background:#111;}
.strength-list li:hover{transform:translateX(6px);background:#eef4ff;border-color:#c7d7fe;}
.strength-list li:hover::before{background:var(--color-primary);}
.portfolio-showcase-section{background:var(--color-bg-soft);padding:90px 0 120px;}
.portfolio-showcase-head{margin-bottom:34px;}
.portfolio-showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch;}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.portfolio-card{display:flex;flex-direction:column;justify-content:space-between;min-height:360px;padding:34px 30px;border:1px solid var(--color-border);border-radius:32px;background:var(--color-white);box-shadow:0 18px 50px rgba(16,24,40,0.05);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;}
.portfolio-card:hover{transform:translateY(-6px);border-color:#c7d7fe;box-shadow:0 26px 70px rgba(20,58,123,0.15);}
.portfolio-card.highlight{background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-primary) 100%);border-color:var(--color-primary);color:var(--color-white);transform:translateY(-10px);box-shadow:0 24px 70px rgba(20,58,123,0.22);}
.portfolio-card.highlight:hover{transform:translateY(-16px);box-shadow:0 32px 86px rgba(20,58,123,0.28);}
.portfolio-cate{display:block;font-size:13px;font-weight:800;letter-spacing:0.18em;color:#9ca3af;text-transform:uppercase;}
.portfolio-card.highlight .portfolio-cate{color:rgba(255,255,255,0.55);}
.portfolio-card h3{margin-top:24px;font-size:34px;line-height:1.2;font-weight:800;letter-spacing:-0.04em;color:var(--color-text);}
.portfolio-card.highlight h3{color:var(--color-white);}
.portfolio-card p{margin-top:18px;font-size:16px;line-height:1.9;color:var(--color-text-sub);}
.portfolio-card.highlight p{color:rgba(255,255,255,0.82);}
.portfolio-card a{display:inline-block;margin-top:30px;font-size:15px;font-weight:800;color:var(--color-text);}
.portfolio-card.highlight a{color:var(--color-white);}
.news-section{background:#f7f7f8;}
.news-section-head{margin-bottom:40px;}
.news-section-head h2{margin-bottom:0;}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.news-empty{grid-column:1/-1;padding:60px 0;text-align:center;color:#b0b8c6;font-size:15px;}
.news-card{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e7eb;border-radius:24px;box-shadow:0 4px 24px rgba(0,0,0,0.05);transition:transform .2s ease,box-shadow .2s ease;overflow:hidden;}
.news-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(20,58,123,0.12);}
.news-thumb{display:block;overflow:hidden;aspect-ratio:16/9;background:#e5e7eb;}
.news-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.news-card:hover .news-thumb img{transform:scale(1.05);}
.news-body{display:flex;flex-direction:column;flex:1;padding:24px 26px 26px;}
.news-date{display:block;font-size:12px;font-weight:700;letter-spacing:0.18em;color:#9ca3af;text-transform:uppercase;}
.news-body h3{margin-top:12px;font-size:18px;line-height:1.5;font-weight:800;letter-spacing:-0.02em;color:#111;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.news-body h3 a{color:inherit;text-decoration:none;transition:color .2s;}
.news-body h3 a:hover{color:var(--color-primary);}
.news-body p{margin-top:10px;font-size:14px;line-height:1.8;color:#667085;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.news-more{display:inline-flex;align-items:center;gap:6px;margin-top:auto;padding-top:20px;font-size:13px;font-weight:700;color:var(--color-primary);text-decoration:none;transition:color .2s,gap .2s;}
.news-more:hover{color:#0f2a55;gap:10px;}
.news-footer{margin-top:40px;text-align:center;}
/* =====================================================
   CTA Section (공통 CTA 박스 - 하단 문의 유도)
   ===================================================== */
.cta-section{padding-top:0;background:#fff;}
.cta-box{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:56px 60px;border-radius:40px;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-primary) 100%);color:var(--color-white);box-shadow:0 24px 60px rgba(20,58,123,0.22);position:relative;overflow:hidden;transition:transform .35s ease,box-shadow .35s ease;}
.cta-box:hover{transform:translateY(-6px);box-shadow:0 34px 80px rgba(20,58,123,0.28);}
.cta-box::before{content:"";position:absolute;top:-120px;right:-80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,0.16) 0%,rgba(255,255,255,0.04) 38%,rgba(255,255,255,0) 72%);pointer-events:none;transition:transform .5s ease;}
.cta-box::after{content:"";position:absolute;left:-120px;bottom:-160px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(199,157,46,0.20) 0%,rgba(199,157,46,0.06) 40%,rgba(199,157,46,0) 75%);pointer-events:none;transition:transform .5s ease;}
.cta-box:hover::before{transform:scale(1.08);}
.cta-box:hover::after{transform:scale(1.12);}
.cta-copy,.cta-btns{position:relative;z-index:1;}
.cta-copy h2,.cta-copy p,.cta-btns .btn{transition:transform .35s ease,box-shadow .35s ease,background .35s ease;}
.cta-box:hover .cta-copy h2{transform:translateY(-2px);}
.cta-box:hover .cta-copy p{transform:translateY(-2px);}
.cta-box:hover .cta-btns .btn-white{box-shadow:0 12px 28px rgba(255,255,255,0.16);}
.cta-box:hover .cta-btns .btn-ghost{background:rgba(255,255,255,0.08);}
.cta-copy h2{margin-top:14px;font-size:48px;line-height:1.2;font-weight:800;letter-spacing:-0.03em;}
.cta-copy p{margin-top:18px;font-size:16px;line-height:1.85;color:rgba(255,255,255,0.76);}
.cta-btns{display:flex;flex-wrap:wrap;gap:14px;}
/* Page CTA Box (서브 비즈니스 페이지 하단 공통 문의 유도 박스) */
.page-cta-box{position:relative;overflow:hidden;padding:56px 60px;border-radius:36px;background:radial-gradient(circle at 10% 85%,rgba(255,198,75,.18),transparent 18%),radial-gradient(circle at 92% 18%,rgba(255,255,255,.22),transparent 16%),linear-gradient(120deg,#07152f 0%,#0b2f74 52%,#1d4daa 100%);box-shadow:0 24px 60px rgba(7,21,47,.18);color:#fff;}
.page-cta-box::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.06),transparent 38%);pointer-events:none;}
.page-cta-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:30px;}
.cta-kicker{margin:0 0 12px;font-size:13px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.7);}
.page-cta-box h2{margin:0;font-size:48px;line-height:1.22;font-weight:800;letter-spacing:-.04em;word-break:keep-all;}
.cta-desc{margin:18px 0 0;font-size:17px;line-height:1.9;color:rgba(255,255,255,.82);word-break:keep-all;}
.page-cta-actions{display:flex;align-items:center;gap:14px;flex-shrink:0;}
/* =====================================================
   Sub Hero (공통 서브페이지 히어로)
   서브 페이지 상단에 공통 사용하는 히어로 배너 구조:
     <section class="sub-hero">
       <div class="inner sub-hero-inner">
         <p class="section-label">LABEL</p>
         <h1>페이지명 <strong>강조</strong></h1>
         <p class="sub-hero-desc">설명</p>
         <div class="breadcrumb">...</div>
       </div>
     </section>
   ===================================================== */
.sub-hero{ position:relative;padding:88px 0 96px;min-height:340px;display:flex;align-items:center;overflow:hidden; background:linear-gradient(90deg,#0f2a55,#2d5fb8); }
.sub-hero::before{ content:"";position:absolute;inset:0;z-index:0;pointer-events:none; background:url('/images/bg-tech.jpg') center/cover no-repeat; opacity:0.22;filter:blur(3px);transform:scale(1.05); animation:subHeroBgMove 20s linear infinite; }
.sub-hero>.inner,.sub-hero>.inner.sub-hero-inner{width:100%;}
.sub-hero-inner{position:relative;z-index:1;}
.sub-hero .section-label{color:rgba(255,255,255,0.75);font-size:13px;font-weight:700;letter-spacing:0.28em;text-transform:uppercase;margin:0 0 18px;}
.sub-hero h1{margin:0;font-size:34px;line-height:1.3;font-weight:600;letter-spacing:-0.02em;color:rgba(255,255,255,0.72);word-break:keep-all;animation:fadeUp 0.7s ease;}
.sub-hero h1 strong{display:block;color:#fff;font-size:1.6em;font-weight:800;letter-spacing:-0.04em;margin-top:8px;opacity:1;}
.sub-hero-desc{margin:36px 0 0;font-size:17px;line-height:1.9;color:rgba(255,255,255,0.82);max-width:720px;word-break:keep-all;animation:fadeUp 0.9s ease;}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-top:20px;font-size:12px;color:rgba(255,255,255,0.4);}
.breadcrumb a{color:rgba(255,255,255,0.4);transition:color .2s ease;}
.breadcrumb a:hover{color:rgba(255,255,255,0.75);}
.breadcrumb .icon{font-size:13px;}
.breadcrumb .sep{opacity:0.3;font-size:11px;}
.breadcrumb .current{color:rgba(255,255,255,0.8);font-weight:600;}
.sub-divider{width:64px;height:4px;border-radius:2px;background:linear-gradient(90deg,var(--color-primary),#5b8cff);margin:28px 0 36px;}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;}
.feature-card{padding:34px 28px 30px;border:1px solid var(--color-border);border-radius:28px;background:#fff;box-shadow:0 18px 50px rgba(16,24,40,0.04);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;}
.feature-card:hover{transform:translateY(-6px);border-color:#c7d7fe;box-shadow:0 26px 70px rgba(20,58,123,0.12);}
.feature-icon{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,var(--color-primary),#4a7bff);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:#fff;}
.feature-icon .icon{width:24px;height:24px;}
/* ── Business Page Common Section Head ── */
.biz-section-head{margin-bottom:64px;}
.biz-kicker{display:block;font-size:12px;font-weight:800;letter-spacing:0.28em;text-transform:uppercase;color:#98a2b3;margin-bottom:18px;}
.biz-section-head h2{margin:0;font-size:48px;line-height:1.18;font-weight:800;letter-spacing:-0.04em;color:#101828;word-break:keep-all;}
.biz-section-head h2 strong{color:var(--color-primary);}
.biz-section-desc{margin:0;font-size:18px;line-height:1.9;color:#667085;word-break:keep-all;max-width:680px;}
.feature-card h3{font-size:22px;font-weight:800;letter-spacing:-0.02em;color:#111;}
.feature-card p{margin-top:12px;font-size:15px;line-height:1.85;color:#666;}
.feature-num{display:inline-flex;align-items:center;height:30px;padding:0 14px;border-radius:999px;background:#f3f4f6;font-size:12px;font-weight:800;letter-spacing:0.18em;color:#9ca3af;margin-bottom:16px;}
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:52px;position:relative;}
.process-steps::before{content:"";position:absolute;top:36px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,var(--color-primary),#5b8cff);z-index:0;}
.process-step{position:relative;z-index:1;text-align:center;padding:0 12px;}
.step-circle{width:72px;height:72px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 8px 24px rgba(20,58,123,0.25);}
.step-circle span{font-size:11px;letter-spacing:0.08em;}
.process-step h3{font-size:16px;font-weight:800;color:#111;margin-bottom:8px;}
.process-step p{font-size:13px;line-height:1.7;color:#888;}
/* ── 공통 프로세스 박스 (비즈니스 서브 페이지) ── */
.proc-box{padding:64px 52px;border:1px solid var(--color-border);border-radius:34px;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);box-shadow:0 18px 42px rgba(16,24,40,.06);}
.proc-list{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:32px;}
.proc-list.col-4{grid-template-columns:repeat(4,minmax(0,1fr));}
.proc-item{position:relative;text-align:center;padding:4px 8px 0;}
.proc-item:not(:last-child)::after{content:'';position:absolute;top:38px;right:-12px;width:24px;height:1px;background:linear-gradient(90deg,rgba(20,58,123,.42),rgba(20,58,123,.08));}
.proc-num{display:flex;align-items:center;justify-content:center;width:76px;height:76px;margin:0 auto 20px;border-radius:50%;background:linear-gradient(135deg,#163a86 0%,#2153bb 100%);color:#fff;font-size:19px;font-weight:800;box-shadow:0 14px 30px rgba(33,83,187,.26);}
.proc-item h3{margin:0 0 10px;font-size:22px;line-height:1.35;font-weight:800;color:#101828;word-break:keep-all;}
.proc-item p{margin:0;font-size:14px;line-height:1.9;color:#667085;word-break:keep-all;}
/* ── 공통 비즈니스 오버뷰 (피처 이미지 + 사이드카드) ── */
.biz-overview{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:stretch;margin-bottom:56px;}
.biz-feature{position:relative;overflow:hidden;min-height:380px;border-radius:32px;box-shadow:0 20px 50px rgba(16,24,40,.14);transition:all .4s ease;}
.biz-feature:hover{transform:scale(1.02);}
.biz-feature-copy{position:absolute;left:34px;right:34px;bottom:34px;color:#fff;}
.biz-feature-copy .kicker{margin:0 0 10px;font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.76);}
.biz-feature-copy h3{margin:0 0 14px;font-size:34px;line-height:1.3;font-weight:800;word-break:keep-all;text-shadow:0 6px 24px rgba(0,0,0,.35);}
.biz-feature-copy .desc{margin:0;font-size:16px;line-height:1.85;color:rgba(255,255,255,.9);word-break:keep-all;}
.biz-side{display:grid;grid-template-columns:1fr;gap:24px;}
.biz-side-card{padding:38px 34px 34px;border:1px solid var(--color-border);border-radius:26px;background:linear-gradient(180deg,#fff 0%,#f9fbff 100%);box-shadow:0 14px 34px rgba(16,24,40,.05);}
.biz-side-card h3{margin:0 0 12px;font-size:24px;font-weight:800;line-height:1.35;color:#101828;}
.biz-side-card p{margin:0;font-size:15px;line-height:1.85;color:#667085;word-break:keep-all;}
/* ── 공통 비즈니스 카드 (offer/service/product/biz/app) ── */
.biz-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:32px;}
.biz-card-grid.col-4{grid-template-columns:repeat(4,minmax(0,1fr));}
.biz-offer-card{position:relative;overflow:hidden;padding:46px 38px 38px;border-radius:30px;border:1px solid var(--color-border);background:#fff;box-shadow:0 12px 34px rgba(16,24,40,.05);transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease;}
.biz-offer-card:hover{transform:translateY(-8px);box-shadow:0 22px 50px rgba(14,64,154,.12);border-color:#cfd9ea;}
.biz-offer-card::before{content:'';position:absolute;left:0;top:0;width:100%;height:5px;background:linear-gradient(90deg,#17459d 0%,#3d76e6 100%);opacity:.9;}
.biz-offer-icon{display:flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,#2458c6 0%,#174199 100%);box-shadow:0 12px 24px rgba(36,88,198,.22);margin-bottom:22px;}
.biz-offer-icon svg{width:28px;height:28px;fill:#fff;}
.biz-offer-card h3{margin:0 0 14px;font-size:28px;font-weight:800;line-height:1.3;color:#101828;}
.biz-offer-card p{margin:0 0 22px;font-size:16px;line-height:1.85;color:#667085;word-break:keep-all;}
.biz-offer-card ul{display:flex;flex-direction:column;gap:10px;}
.biz-offer-card li{position:relative;padding-left:18px;font-size:16px;font-weight:600;color:#1d2939;}
.biz-offer-card li::before{content:'';position:absolute;left:0;top:10px;width:7px;height:7px;border-radius:50%;background:#2a5ecb;}
/* ── 공통 비즈니스 밴드 (strength/operation/solution) ── */
.biz-band{margin-top:44px;padding:44px 40px;border-radius:28px;background:linear-gradient(135deg,#eff5ff 0%,#f7faff 100%);border:1px solid #dce6f5;}
.biz-band-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:28px;}
.biz-band-item strong{display:block;margin-bottom:8px;font-size:17px;font-weight:800;color:var(--color-primary);}
.biz-band-item span{display:block;font-size:14px;line-height:1.75;color:#475467;word-break:keep-all;}
/* ── 공통 CTA 액션 ── */
.cta-actions{display:flex;align-items:center;gap:14px;flex-shrink:0;}
.sub-section-dark{background:var(--color-bg-soft);}
.board-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px;}
.board-tab{display:inline-flex;align-items:center;height:38px;padding:0 18px;border-radius:999px;font-size:13px;font-weight:700;letter-spacing:0.02em;text-decoration:none;border:1.5px solid var(--color-border);color:#888;background:#fff;transition:all .2s ease;cursor:pointer;}
.board-tab:hover{border-color:var(--color-primary);color:var(--color-primary);}
.board-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;}
.board-search{display:flex;align-items:center;gap:10px;margin-bottom:32px;background:#f9fafb;border:1px solid var(--color-border);border-radius:16px;padding:12px 16px;}
.board-search select{height:40px;padding:0 12px;border:1px solid var(--color-border);border-radius:10px;font-size:14px;color:#555;background:#fff;outline:none;cursor:pointer;transition:border-color .2s;}
.board-search select:focus{border-color:var(--color-primary);}
.board-search input{flex:1;height:40px;padding:0 14px;border:1px solid var(--color-border);border-radius:10px;font-size:14px;color:#333;background:#fff;outline:none;transition:border-color .2s;}
.board-search input:focus{border-color:var(--color-primary);}
.board-search .btn{height:40px;padding:0 20px;font-size:14px;border-radius:10px;white-space:nowrap;}
.sub-board{width:100%;border-collapse:collapse;}
.sub-board thead th{padding:22px 16px;font-size:15px;font-weight:700;color:#9ca3af;letter-spacing:0.08em;text-transform:uppercase;border-bottom:2px solid #e5e7eb;text-align:left;}
.sub-board tbody td{padding:22px 16px;font-size:16px;color:#555;border-bottom:1px solid #f3f4f6;vertical-align:middle;}
.sub-board tbody tr{transition:background .15s ease;}
.sub-board tbody tr:last-child td{border-bottom:none;}
.sub-board tbody tr:hover{background:#f5f8ff;}
.sub-board .td-num{width:60px;text-align:center;color:#9ca3af;font-size:14px;}
.sub-board .td-title{padding-left:20px;}
.sub-board .td-title a{font-size:17px;font-weight:700;color:#111;text-decoration:none;transition:color .2s;}
.sub-board .td-title a:hover{color:var(--color-primary);}
.sub-board .td-author{width:100px;color:#888;font-size:15px;}
.sub-board .td-date{width:120px;color:#9ca3af;font-size:15px;white-space:nowrap;}
.sub-board .td-state{width:80px;text-align:center;}
.sub-board .no-data{text-align:center;padding:60px 0;color:#b0b8c6;font-size:16px;}
.sub-board-wrap{border-top:2px solid #e5e7eb;margin-bottom:4px;}
.board-total{font-size:16px;font-weight:500;color:#888;}
.board-total strong{color:#111;font-weight:700;}
.badge{display:inline-flex;align-items:center;height:18px;padding:0 7px;border-radius:3px;font-size:10px;font-weight:800;letter-spacing:0.1em;white-space:nowrap;vertical-align:middle;line-height:1;}
.badge-kind{background:#eef4ff;color:var(--color-primary);}
.badge-new{background:none;color:#e03131;padding:0;height:auto;font-size:11px;font-weight:800;letter-spacing:0.08em;}
.badge-done{background:#d1fae5;color:#059669;}
.badge-ing{background:#f3f4f6;color:#9ca3af;}
/* Status Badge (점 인디케이터 + 라벨 — 채용·문의 목록 공통) */
.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;white-space:nowrap;}
.status-badge::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.status-open{color:#16a34a;}
.status-open::before{background:#16a34a;box-shadow:0 0 0 3px #dcfce7;}
.status-closed{color:#9ca3af;}
.status-closed::before{background:#9ca3af;box-shadow:0 0 0 3px #f3f4f6;}
.status-done{color:#16a34a;}
.status-done::before{background:#16a34a;box-shadow:0 0 0 3px #dcfce7;}
.status-received{color:#1d6fd6;}
.status-received::before{background:#1d6fd6;box-shadow:0 0 0 3px #dbeafe;}
.status-ing{color:#6b7280;}
.status-ing::before{background:#9ca3af;box-shadow:0 0 0 3px #f3f4f6;}
/* ── 공통 이메일행 ── */
.email-row{display:flex!important;align-items:center;gap:6px;flex-wrap:nowrap;max-width:480px;}
.email-row input{flex:1!important;width:auto!important;min-width:50px;max-width:160px;}
.email-row select{flex-shrink:1;min-width:0;width:120px;max-width:130px;}
.email-at{font-size:16px;font-weight:600;color:#9ca3af;flex-shrink:0;}

/* ── 공통 핸드폰행 ── */
.phone-row{display:flex!important;align-items:center;gap:6px;flex-wrap:nowrap;max-width:400px;}
.phone-row input{width:70px!important;flex:none!important;text-align:center;}
.phone-row select{width:82px!important;flex-shrink:0;}
.phone-dash{font-weight:700;color:#c0c4ce;flex-shrink:0;}

/* ── 공통 파일슬롯 ── */
.file-slots{display:flex;flex-direction:column;gap:10px;}
.file-slot{position:relative;border-radius:12px;overflow:hidden;}
.file-slot input[type="file"]{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2;font-size:0;}
.file-slot-box{display:flex;align-items:center;gap:14px;border:1.5px dashed #e4e7ec;border-radius:12px;padding:14px 18px;background:#fafbfc;transition:border-color .2s,background .2s;position:relative;z-index:1;}
.file-slot:hover .file-slot-box{border-color:var(--color-primary);background:#f0f4ff;}
.file-slot.has-file .file-slot-box{border-style:solid;border-color:var(--color-primary);background:#f0f4ff;}
.file-slot-icon{width:36px;height:36px;border-radius:8px;background:#e8edf8;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.file-slot-icon svg{width:18px;height:18px;stroke:var(--color-primary);stroke-width:1.5;fill:none;}
.file-slot-text{flex:1;min-width:0;}
.file-slot-name{font-size:13px;font-weight:600;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.file-slot-hint{font-size:11px;color:#9ca3af;margin-top:2px;}
.file-slot-badge{flex-shrink:0;font-size:11px;font-weight:700;color:var(--color-primary);background:#e8edf8;border-radius:6px;padding:3px 10px;}

.board-action{display:flex;justify-content:flex-end;margin-top:24px;}
.board-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.paging{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:40px;}
.paging .num{display:flex;align-items:center;gap:4px;}
.paging a,.paging strong,.paging .paginate>span{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;font-size:14px;font-weight:600;color:#9ca3af;background:#f3f4f6;border:none;text-decoration:none;transition:all .2s ease;}
.paging a:hover{background:#e5e7eb;color:var(--color-primary);}
.paging strong,.paging .active,.paging .paginate>span.on{background:var(--color-primary)!important;color:#fff!important;box-shadow:0 6px 18px rgba(36,88,198,.28);}
/* prev/next 화살표 */
.paging a.pre::before{content:'‹';font-size:20px;line-height:1;}
.paging a.next::before{content:'›';font-size:20px;line-height:1;}
.paging a.pre_end::before{content:'«';font-size:16px;line-height:1;}
.paging a.next_end::before{content:'»';font-size:16px;line-height:1;}
/* =====================================================
   Footer (공통 푸터)
   - .site-footer: PC 푸터
   - #footer_m / .footer-mobile: 모바일 푸터
   ===================================================== */
.site-footer{margin-top:20px;border-top:none;background:#111827;}
.footer-top{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr);gap:60px;padding-top:70px;padding-bottom:50px;}
.footer-summary{margin-top:24px;max-width:520px;font-size:15px;line-height:1.9;color:rgba(255,255,255,0.5);}
.footer-info{margin-top:22px;display:flex;flex-direction:column;gap:8px;}
.footer-info li{font-size:14px;color:rgba(255,255,255,0.45);}
.footer-info li a{color:rgba(255,255,255,0.45);transition:color .2s ease;}
.footer-info li a:hover{color:#fff;}
.footer-nav-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.footer-nav strong{display:block;font-size:15px;font-weight:800;color:#fff;}
.footer-nav a{display:block;margin-top:14px;font-size:14px;color:rgba(255,255,255,0.5);transition:color .2s ease;}
.footer-nav a:hover{color:#fff;}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:24px;padding-bottom:32px;border-top:1px solid rgba(255,255,255,0.1);}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,0.35);}
.footer-tags{display:flex;flex-wrap:wrap;gap:8px;}
.footer-tags span{display:inline-flex;align-items:center;height:34px;padding:0 14px;border-radius:999px;background:rgba(255,255,255,0.08);font-size:12px;font-weight:700;color:rgba(255,255,255,0.5);}
.footer-logo .logo-img{height:56px;opacity:0.9;filter:brightness(0) invert(1);}
.footer-family .f_site{position:relative;margin-top:14px;}
.footer-family .f_site_toggle{display:inline-flex;align-items:center;height:42px;padding:0 18px;border:1px solid var(--color-border);border-radius:999px;font-size:14px;font-weight:700;color:var(--color-text-sub);background:#fff;transition:all .25s ease;}
.footer-family .f_site_toggle:hover{border-color:var(--color-primary);color:var(--color-primary);}
.footer-family .f_site_list{position:absolute;left:0;bottom:52px;min-width:160px;padding:10px 0;border:1px solid var(--color-border);border-radius:16px;background:#fff;box-shadow:0 12px 30px rgba(16,24,40,0.08);}
.footer-family .f_site_list li a{display:block;padding:10px 16px;font-size:14px;color:var(--color-text-sub);}
.footer-family .f_site_list li a:hover{color:var(--color-primary);background:#f8fafc;}
#footer_m{display:none;}
.footer-mobile{padding:44px 24px 32px;background:#111827;color:#fff;box-sizing:border-box;overflow-x:hidden;width:100%;}
.footer-mobile-inner{width:100%;max-width:100%;box-sizing:border-box;}
.footer-mobile-logo{text-align:center;}
.footer-mobile-logo .logo-img{height:52px;width:auto;}
.footer-mobile-summary{margin-top:20px;font-size:13px;line-height:1.8;color:rgba(255,255,255,0.55);text-align:left;}
.footer-mobile-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:32px;padding-top:28px;border-top:1px solid rgba(255,255,255,0.1);text-align:left;}
.footer-mobile-nav-col strong{display:block;font-size:11px;font-weight:800;letter-spacing:.12em;color:rgba(255,255,255,0.4);text-transform:uppercase;margin-bottom:14px;}
.footer-mobile-nav-col a{display:block;font-size:13px;color:rgba(255,255,255,0.7);text-decoration:none;line-height:1;margin-bottom:12px;transition:color .2s;}
.footer-mobile-nav-col a:hover{color:#fff;}
.footer-mobile-info{margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.1);font-size:13px;line-height:2;color:rgba(255,255,255,0.5);text-align:left;}
.footer-mobile-copy{margin-top:16px;font-size:12px;color:rgba(255,255,255,0.35);text-align:center;}
/* =====================================================
   Form Components (공통 폼 컴포넌트)
   - .email-row / .email-at: 이메일 입력 (ID @ 도메인)
   - .file-slots / .file-slot*: 파일 첨부 슬롯 (application, request_form 공통)
   ===================================================== */
.email-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.email-at{font-weight:700;color:#9ca3af;flex-shrink:0;}
.file-slots{display:flex;flex-direction:column;gap:10px;}
.file-slot{position:relative;}
.file-slot-box{display:flex;align-items:center;gap:12px;padding:14px 18px;border:1.5px dashed #d1d5db;border-radius:12px;background:#fafbfc;transition:border-color .2s,background .2s;cursor:pointer;}
.file-slot:hover .file-slot-box{border-color:var(--color-primary);background:#f0f4ff;}
.file-slot.has-file .file-slot-box{border-color:var(--color-primary);border-style:solid;}
.file-slot-icon{width:36px;height:36px;border-radius:10px;background:#eef3ff;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.file-slot-icon svg{width:20px;height:20px;stroke:var(--color-primary);fill:none;}
.file-slot-text{flex:1;min-width:0;}
.file-slot-name{font-size:14px;color:#374151;font-weight:600;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;}
.file-slot-hint{font-size:12px;color:#9ca3af;margin-top:2px;}
.file-slot-badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;background:#e0e7ff;color:var(--color-primary);flex-shrink:0;}
/* =====================================================
   Animations
   ===================================================== */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:translateY(0);}
}
@keyframes subHeroBgMove{
  0%{transform:scale(1.05) translateX(0);}
  50%{transform:scale(1.1) translateX(-20px);}
  100%{transform:scale(1.05) translateX(0);}
}
/* =====================================================
   Responsive (미디어 쿼리)
   ===================================================== */
@media(max-width:1400px){
  .menu-item>a{padding:0 20px;}
  .menu-item>a::after{left:20px;right:20px;}
  .gnb-sub-logo-gap{width:180px;}
}
@media(max-width:1280px){
  .gnb-sub-logo-gap{width:140px;}
  .gnb-sub-col a{font-size:15px;}
  .menu-item>a{padding:0 16px;font-size:15px;}
  .menu-item>a::after{left:16px;right:16px;}
}
@media(max-width:1200px){
  .header-utils{display:none;}
  .menu-item>a{padding:0 14px;font-size:14px;}
  .menu-item>a::after{left:14px;right:14px;}
  .gnb-sub-logo-gap{width:100px;}
  .hero-inner{grid-template-columns:1fr;}
  .business-grid{grid-template-columns:repeat(2,1fr);}
  .portfolio-inner{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:repeat(3,1fr);}
  .footer-top{grid-template-columns:1fr;}
  .capability-inner{grid-template-columns:1fr;}
  .capability-list{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:1024px){
  .site-header.pc{display:none;}
  .site-header-mo{display:block;}
  .gnb{display:none;}
  .header-btns{display:none;}
  .mobile-menu-btn{display:block;}
  .hero-copy h1{font-size:52px;}
  .section-head h2,.capability-copy h2,.portfolio-copy h2,.cta-copy h2,.biz-section-head h2{font-size:36px;}
  .biz-overview{grid-template-columns:1fr;}
  .biz-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .biz-card-grid.col-4{grid-template-columns:repeat(2,minmax(0,1fr));}
  .biz-band-list{grid-template-columns:repeat(2,minmax(0,1fr));}
  .proc-list{grid-template-columns:repeat(3,minmax(0,1fr));}
  .proc-list.col-4{grid-template-columns:repeat(2,minmax(0,1fr));}
  .proc-item:nth-child(3)::after{display:none;}
  .portfolio-grid{grid-template-columns:1fr;}
  .portfolio-showcase-grid{grid-template-columns:1fr;}
  .portfolio-card.highlight{transform:none;}
  .portfolio-card.highlight:hover{transform:translateY(-6px);}
  .news-grid{grid-template-columns:repeat(2,1fr);}
  .cta-box{flex-direction:column;align-items:flex-start;}
  .page-cta-inner{flex-direction:column;align-items:flex-start;}
  .page-cta-actions{width:100%;flex-direction:column;}
  .footer-nav-wrap{grid-template-columns:repeat(2,1fr);}
  .sub-hero h1{font-size:42px;}
  .feature-grid{grid-template-columns:repeat(2,1fr);}
  .process-steps{grid-template-columns:repeat(3,1fr);}
  .page-home .hero-section{margin-top:-64px;padding-top:calc(64px + 100px);padding-bottom:100px;min-height:540px;}
}
.process-steps::before{display:none;}
@media (max-width:768px){
  /* ── 공통 여백 ── */
  .inner{padding:0 18px;}
  .section{padding:50px 0;}
  .section-head,.biz-section-head,.news-section-head,.capability-copy,.portfolio-copy{margin-bottom:24px;}
  .about-divider,.section-divider{margin:14px 0 12px;}
  /* ── 공통 제목 (h2) ── */
  .section-head h2,.capability-copy h2,.portfolio-copy h2,.cta-copy h2,.biz-section-head h2,.page-cta-box h2{font-size:26px;line-height:1.3;word-break:keep-all;}
  .section-head h2 br,.capability-copy h2 br,.portfolio-copy h2 br,.cta-copy h2 br,.biz-section-head h2 br,.page-cta-box h2 br{display:none;}
  /* ── 공통 라벨 (section-label, biz-kicker, portfolio-cate) ── */
  .section-label,.biz-kicker,.portfolio-cate{font-size:11px;margin-bottom:10px;}
  /* ── 공통 본문 (desc / p) ── */
  .section-desc,.capability-desc,.portfolio-copy p,.biz-section-desc,.cta-copy p{font-size:14px;line-height:1.75;margin-top:14px;}
  /* ── 공통 카드 h3 ── */
  .card-thumb h3,.portfolio-card h3,.capability-item strong,.news-body h3{font-size:18px;}
  /* ── 공통 카드 본문 ── */
  .portfolio-card p,.capability-item p,.news-body p{font-size:14px;line-height:1.7;margin-top:10px;}
  /* ── 공통 카드 링크 ── */
  .portfolio-card a,.card-body a{margin-top:16px;font-size:13px;}
  /* ── 공통 카드 패딩 ── */
  .portfolio-card,.capability-item{min-height:auto;padding:24px 20px;}
  .portfolio-card h3 br{display:none;}
  .portfolio-card h3{margin-top:14px;}
  /* ── 공통 그리드 1열 ── */
  .business-grid,.news-grid,.feature-grid,.process-steps,.capability-list,.proc-list,.proc-list.col-4,.biz-card-grid,.biz-card-grid.col-4,.biz-band-list{grid-template-columns:1fr;}
  .proc-list,.proc-list.col-4{gap:0;}
  /* ── 공통 비즈니스 카드/밴드 모바일 ── */
  .biz-feature{min-height:280px;border-radius:24px;}
  .biz-feature-copy{left:22px;right:22px;bottom:22px;}
  .biz-feature-copy h3{font-size:24px;}
  .biz-offer-card{padding:28px 22px 24px;border-radius:22px;}
  .biz-offer-card h3{font-size:20px;}
  .biz-side-card{padding:28px 22px;border-radius:20px;}
  .biz-side-card h3{font-size:20px;}
  .biz-band{padding:28px 22px;border-radius:20px;}
  .cta-actions{width:100%;flex-direction:column;}
  .proc-box{padding:28px 20px;border-radius:22px;}
  .proc-item{display:flex;align-items:center;gap:14px;text-align:left;padding:12px 0;}
  .proc-item:not(:last-child){border-bottom:1px solid #eef0f4;}
  .proc-item:not(:last-child)::after{display:none;}
  .proc-item:nth-child(3)::after{display:none;}
  .proc-num{width:40px;height:40px;min-width:40px;margin:0;font-size:13px;box-shadow:0 6px 14px rgba(33,83,187,.18);}
  .proc-item-txt{min-width:0;flex:1;}
  .proc-item h3{margin:0 0 2px;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .proc-item p{font-size:13px;line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  /* ── 헤더 ── */
  .site-header .header-inner{height:88px;}
  .logo-mark{width:40px;height:40px;border-radius:14px;font-size:18px;}
  .logo-text strong{font-size:18px;}
  .logo-text span{font-size:10px;}
  /* ── 히어로 ── */
  .hero-section{padding:60px 0 50px;}
  .hero-copy h1{font-size:38px;}
  .hero-desc{font-size:15px;}
  .hero-card{padding:20px;border-radius:24px;}
  .hero-card-head{flex-direction:column;align-items:flex-start;}
  .hero-card-head h2{font-size:22px;}
  .core-list li{padding:16px;}
  .core-list strong{font-size:17px;}
  /* ── 개별 섹션 패딩 ── */
  .capability-section{padding:50px 0 40px;}
  .portfolio-showcase-section{padding:50px 0 60px;}
  .card-thumb{height:220px;}
  /* ── CTA ── */
  .cta-box{padding:32px 22px;border-radius:24px;}
  .page-cta-box{padding:28px 20px;border-radius:24px;}
  /* ── 서브 히어로 ── */
  .sub-hero{padding:44px 0 48px;min-height:auto;}
  .sub-hero h1{font-size:18px;line-height:1.28;}
  .sub-hero h1 strong{font-size:1.35em;}
  .sub-hero-desc{display:none;}
  /* ── 푸터 ── */
  .footer-top{padding-top:40px;padding-bottom:28px;}
  .footer-nav-wrap{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  #footer_new{display:none;}
  #footer_m{display:block;}
}
@media (max-width:480px){
  .hero-actions{flex-direction:row;}
  .hero-actions .btn{flex:1;min-width:0;padding-left:0;padding-right:0;text-align:center;font-size:14px;}
  .btn{width:100%;}
  .cta-btns{flex-wrap:nowrap;gap:10px;}
  .cta-btns .btn{flex:1;min-width:0;padding-left:0;padding-right:0;text-align:center;font-size:14px;white-space:nowrap;}
  .news-head-row .btn{width:auto;min-width:0;}
}