* { margin: 0; padding: 0; box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body { font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, sans-serif; color: #111827; background: #fff; overflow-x: hidden; }
    p { font-size: 18px; }
    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; display: block; }
    ul, li { list-style: none; }

    /* ============================================== */
    /* 그누보드 default.css 충돌 차단 (메인 페이지 전용) */
    /* ============================================== */
    /* default.css의 #contents{max-width:1600px}, #container{width:930px;float:left}, 
       #wrapper{min-width:1200px} 등이 메인 페이지를 가둠 → 모두 강제 해제 */
    .dw-main #wrapper,
    .dw-main #container_wr,
    .dw-main #container,
    .dw-main #contents {
      max-width: none !important;
      width: 100% !important;
      min-width: 0 !important;
      float: none !important;
      margin: 0 !important;
      padding: 0 !important;
      min-height: 0 !important;
    }
    /* default.css의 img { width:100%; height:100%; } 가 swiper 이미지 비율을 망침 → 카드 외 슬라이드 이미지 보호 */
    .dw-hero img, .dw-work-card img, .dw-service-thumb img, .dw-story-slide img, .dw-process-image img { width: 100%; height: 100%; object-fit: cover; }
    /* swiper 컨테이너의 너비/높이 강제 */
    .dw-work-swiper, .dw-story-swiper, .dw-hero-swiper { width: 100% !important; }
    .dw-work-swiper .swiper-slide { width: auto; height: auto; }
    .dw-work-swiper .swiper-slide .dw-work-card { height: 620px !important; width: 100%; }
    /* ============================================== */



    .dw-container { width: min(1600px, calc(100% - 48px)); margin: 0 auto; }
    .dw-section { padding: 150px 0; position: relative; }
    .dw-eyebrow { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 18px; color: #2563eb; font-size: 14px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
    .dw-eyebrow:before { content: ""; width: 34px; height: 2px; background: #2563eb; }
    .dw-section-title { font-size: clamp(36px, 5vw, 80px); line-height: 1.2; letter-spacing: -.06em; font-weight: 900; color: #08111f; }
    .dw-section-desc { max-width: 680px; margin-top: 24px; color: #6b7280; font-size: clamp(16px, 1.45vw, 20px); line-height: 1.65; font-weight: 400;  word-break: keep-all;}

    .dw-site-header { position: fixed; top: 0; left: 0; z-index: 100; width: 100%; height: 86px; backdrop-filter: blur(18px); background: rgba(255,255,255,.72); border-bottom: 1px solid rgba(17,24,39,.08); }
    .dw-header-inner { height: 100%; display: flex; align-items: center; justify-content: space-between; }
    .dw-logo { display: flex; align-items: center; gap: 12px; font-size: 22px; font-weight: 900; letter-spacing: -.04em; }
    .dw-logo-mark { width: 38px; height: 38px; border-radius: 14px; background: linear-gradient(135deg, #111827, #2563eb); box-shadow: 0 12px 30px rgba(37,99,235,.28); }
    .dw-nav { display: flex; align-items: center; gap: 38px; color: #374151; font-size: 15px; font-weight: 700; }
    .dw-nav a { position: relative; }
    .dw-nav a:after { content: ""; position: absolute; left: 0; bottom: -8px; width: 0; height: 2px; background: #2563eb; transition: .35s; }
    .dw-nav a:hover:after { width: 100%; }
    .dw-header-cta { display: inline-flex; align-items: center; justify-content: center; height: 46px; padding: 0 22px; border-radius: 999px; background: #111827; color: #fff; font-size: 14px; font-weight: 800; box-shadow: 0 16px 35px rgba(17,24,39,.18); }
    .dw-menu-btn { display: none; width: 44px; height: 44px; border: 0; background: #111827; border-radius: 14px; cursor: pointer; }
    .dw-menu-btn span { display: block; width: 18px; height: 2px; margin: 4px auto; background: #fff; }

    .dw-mobile-menu { position: fixed; top: 86px; right: 24px; left: 24px; z-index: 90; display: none; padding: 24px; border-radius: 26px; background: rgba(255,255,255,.96); box-shadow: 0 26px 70px rgba(17,24,39,.18); border: 1px solid rgba(17,24,39,.08); }
    .dw-mobile-menu.active { display: block; }
    .dw-mobile-menu a { display: block; padding: 16px 4px; font-weight: 800; color: #111827; border-bottom: 1px solid #eef2f7; }

    /* dw-hero: padding-top을 제거하여 hero 이미지가 화면 맨 위(투명한 header 뒤)까지 올라가도록 함 */
    .dw-hero { min-height: 100vh; padding-top: 0; position: relative; background: #08111f; color: #fff; overflow: hidden; }
    .dw-hero-swiper, .dw-hero .swiper-wrapper, .dw-hero .swiper-slide { min-height: 100vh; }
    .dw-hero-slide { position: relative; display: flex; align-items: center; min-height: 100vh; }
    .dw-hero-bg { position: absolute; inset: 0; z-index: 0; }
    .dw-hero-bg img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.02) contrast(1.02); transform: scale(1.08); transition: transform 7s ease; }
    .swiper-slide-active .dw-hero-bg img { transform: scale(1); }
    .dw-hero-bg:after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(8,17,31,.86) 0%, rgba(8,17,31,.58) 44%, rgba(8,17,31,.14) 100%); }
    .dw-hero-content { position: relative; z-index: 2; width: min(1600px, calc(100% - 48px)); margin: 0 auto; padding: 160px 0 90px; }
    .dw-hero-label { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 26px; padding: 10px 15px; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; background: rgba(255,255,255,.08); color: rgba(255,255,255,.86); font-size: 13px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
    .dw-hero-label:before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: #60a5fa; box-shadow: 0 0 0 8px rgba(96,165,250,.14); }
    .dw-hero-title { max-width: 980px; font-size: clamp(48px, 8vw, 100px); line-height: 1.1; letter-spacing: -.075em; font-weight: 900; word-break: keep-all; }
    .dw-hero-title span { color: #93c5fd; }
    .dw-hero-text { max-width: 660px; margin-top: 32px; color: rgba(255,255,255,.76); font-size: clamp(17px, 1.5vw, 22px); line-height: 1.35; word-break: keep-all; }
    .dw-hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; margin-top: 42px; }
    .dw-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 56px; padding: 0 26px; border-radius: 999px; font-size: 15px; font-weight: 900; transition: .35s; }
    .dw-btn-primary { background: #fff; color: #08111f; }
    .dw-btn-primary:hover { transform: translateY(-3px); box-shadow: 0 22px 46px rgba(255,255,255,.2); }
    .dw-btn-ghost { border: 1px solid rgba(255,255,255,.28); color: #fff; background: rgba(255,255,255,.06); }
    .dw-btn-ghost:hover { background: rgba(255,255,255,.14); transform: translateY(-3px); }
    .dw-hero-control { position: absolute; z-index: 5; right: max(24px, calc((100% - 1600px) / 2)); bottom: 54px; display: flex; align-items: center; gap: 16px; }
    .dw-hero-button { width: 54px; height: 54px; display: grid; place-items: center; border-radius: 50%; border: 1px solid rgba(255,255,255,.25); color: #fff; background: rgba(255,255,255,.08); cursor: pointer; transition: .3s; }
    .dw-hero-button:hover { background: #fff; color: #111827; }
    .dw-hero-pagination { position: static !important; display: flex; align-items: center; gap: 10px; width: auto !important; }
    .dw-hero-pagination .swiper-pagination-bullet { width: 8px; height: 8px; opacity: .45; background: #fff; transition: .3s; }
    .dw-hero-pagination .swiper-pagination-bullet-active { width: 34px; border-radius: 999px; opacity: 1; }

    .dw-intro { background: #fff; }
    .dw-intro-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 80px; align-items: end; }
    .dw-intro-card-wrap { display: grid; grid-template-columns: repeat(2, 1fr); column-gap: 18px; row-gap: 22px; align-items: start; }
    .dw-intro-card { min-height: 240px; padding: 30px; border-radius: 34px; background: #f3f6fb; border: 1px solid #e8edf5; transition: .35s; }
    .dw-intro-card:nth-child(2) { transform: translateY(44px); background: #111827; color: #fff; }
    .dw-intro-card:nth-child(4) { transform: translateY(44px); }
    .dw-intro-card:nth-child(3) { background: #2563eb; color: #fff; }
    .dw-intro-card:hover { transform: translateY(-8px); box-shadow: 0 28px 70px rgba(17,24,39,.12); }
    .dw-intro-card:nth-child(2):hover { transform: translateY(34px); }
    .dw-intro-card:nth-child(4):hover { transform: translateY(34px); }
    .dw-card-num { font-size: 13px; font-weight: 900; color: #2563eb; }
    .dw-intro-card:nth-child(2) .dw-card-num, .dw-intro-card:nth-child(3) .dw-card-num { color: rgba(255,255,255,.72); }
    .dw-intro-card h3 { margin-top: 54px; font-size: 24px; letter-spacing: -.04em; }
    .dw-intro-card p { margin-top: 16px; color: #6b7280; line-height: 1.7; font-size: 15px; }
    .dw-intro-card:nth-child(2) p, .dw-intro-card:nth-child(3) p { color: rgba(255,255,255,.72); }

    .dw-services { background: #f4f6f9; overflow: hidden; }
    .dw-services:before { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(90deg, rgba(15,23,42,.045) 1px, transparent 1px), linear-gradient(180deg, rgba(15,23,42,.035) 1px, transparent 1px); background-size: calc(1600px / 12) 118px; background-position: center top; mask-image: linear-gradient(180deg, rgba(0,0,0,.9), rgba(0,0,0,.18)); }
    .dw-service-top { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(360px, .48fr); gap: 72px; align-items: end; width: min(1600px, 100%); margin: 0 auto 70px; }
    .dw-service-grid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: 20px; width: min(1600px, 100%); margin: 0 auto; }
    .dw-service-item { position: relative; min-height: 560px; padding: 0; border-radius: 0; background: rgba(255,255,255,.78); border: 1px solid rgba(15,23,42,.12); overflow: hidden; transition: transform .45s ease, background .45s ease, border-color .45s ease, box-shadow .45s ease; }
    .dw-service-item:nth-child(1) { grid-column: span 3; }
    .dw-service-item:nth-child(2) { grid-column: span 3; transform: translateY(46px); }
    .dw-service-item:nth-child(3) { grid-column: span 3; }
    .dw-service-item:nth-child(4) { grid-column: span 3; transform: translateY(46px); }
    .dw-service-item:before { content: ""; position: absolute; left: 34px; right: 34px; top: 292px; height: 1px; background: rgba(15,23,42,.14); transform-origin: left center; transform: scaleX(.34); transition: transform .45s ease, background .45s ease; }
    .dw-service-item:after { content: ""; position: absolute; right: -1px; bottom: -1px; width: 46%; height: 38%; background: linear-gradient(135deg, transparent 0%, rgba(37,99,235,.08) 100%); clip-path: polygon(100% 0, 100% 100%, 0 100%); opacity: 0; transition: opacity .45s ease; }
    .dw-service-item:hover { background: #fff; border-color: rgba(15,23,42,.28); box-shadow: 0 28px 70px rgba(15,23,42,.12); }
    .dw-service-item:nth-child(odd):hover { transform: translateY(-12px); }
    .dw-service-item:nth-child(even):hover { transform: translateY(34px); }
    .dw-service-item:hover:before { transform: scaleX(1); background: rgba(37,99,235,.7); }
    .dw-service-item:hover:after { opacity: 1; }
    .dw-service-thumb { position: relative; height: 238px; overflow: hidden; background: #dbe3ef; }
    .dw-service-thumb img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.04); filter: saturate(.92) contrast(1.03); transition: transform .7s ease, filter .7s ease; }
    .dw-service-thumb:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,23,42,0) 45%, rgba(15,23,42,.18) 100%); }
    .dw-service-body { position: relative; min-height: 320px; padding: 34px 34px 78px; }
    .dw-service-icon { width: auto; height: auto; display: block; border-radius: 0; background: transparent; color: rgba(15,23,42,.24); font-weight: 900; font-size: clamp(42px, 4vw, 68px); line-height: .82; letter-spacing: -.09em; }
    .dw-service-item h3 { position: relative; z-index: 1; margin-top: 58px; max-width: 280px; font-size: clamp(25px, 2vw, 34px); line-height: 1.04; letter-spacing: -.065em; font-weight: 900; color: #0f172a; }
    .dw-service-item p { position: relative; z-index: 1; margin-top: 22px; color: #64748b; line-height: 1.78; font-size: 18px; word-break: keep-all; }
    .dw-service-item:hover .dw-service-thumb img { transform: scale(1.12); filter: saturate(1.02) contrast(1.06); }
    .dw-service-link { position: absolute; left: 34px; bottom: 34px; display: inline-flex; align-items: center; gap: 10px; color: #0f172a; font-weight: 900; font-size: 13px; letter-spacing: .03em; text-transform: uppercase; }
    .dw-service-link:before { content: ""; width: 30px; height: 1px; background: currentColor; transition: width .35s ease; }
    .dw-service-item:hover .dw-service-link:before { width: 52px; }

    .dw-works { background: #08111f; color: #fff; overflow: hidden; }
    .dw-works .dw-section-title { color: #fff; }
    .dw-works .dw-section-desc { color: rgba(255,255,255,.66); }
    /* works 섹션: 컨테이너 너비 제약을 제거해 화면 전체 사용 (HTML 샘플과 동일한 그리드) */

    .dw-works-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; margin-bottom: 58px; width: min(1600px, 100%); margin-left: auto; margin-right: auto; }
    .dw-work-control { display: flex; gap: 12px; }
    .dw-work-prev, .dw-work-next { width: 54px; height: 54px; border-radius: 50%; border: 1px solid rgba(255,255,255,.24); display: grid; place-items: center; cursor: pointer; color: #fff; background: rgba(255,255,255,.07); transition: .3s; }
    .dw-work-prev:hover, .dw-work-next:hover { background: #fff; color: #08111f; }
    /* Swiper 동작 보장: 그누보드 default.css의 간섭을 차단 */
    .dw-works .dw-work-swiper { overflow: visible; width: 100%; padding: 0; }
    .dw-works .dw-work-swiper .swiper-wrapper { display: flex; align-items: stretch; box-sizing: content-box; }
    .dw-works .dw-work-swiper .swiper-slide { height: auto; flex-shrink: 0; }
    .dw-works .dw-work-card { position: relative; display: block; height: 620px; border-radius: 42px; overflow: hidden; background: #111827; }
    .dw-works .dw-work-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; display: block; max-width: none; }
    .dw-works .dw-work-card:hover img { transform: scale(1.07); }
    .dw-works .dw-work-card:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,17,31,0) 30%, rgba(8,17,31,.9) 100%); }
    .dw-works .dw-work-info { position: absolute; left: 32px; right: 32px; bottom: 32px; z-index: 2; }
    .dw-works .dw-work-category { display: inline-flex; margin-bottom: 16px; padding: 9px 13px; border-radius: 999px; background: rgba(255,255,255,.13); backdrop-filter: blur(10px); color: rgba(255,255,255,.86); font-size: 12px; font-weight: 900; letter-spacing: .08em; }
    .dw-works .dw-work-info h3 { font-size: clamp(28px, 3vw, 44px); letter-spacing: -.055em; line-height: 1; color: #fff; }
    .dw-works .dw-work-info p { margin-top: 16px; max-width: 440px; color: rgba(255,255,255,.72); line-height: 1.65; }

    .dw-process { background: #fff; overflow: hidden; }
    .dw-process:before { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(15,23,42,.16), transparent); }
    .dw-process:after { content: ""; position: absolute; left: -18vw; bottom: -24vw; width: 56vw; height: 56vw; border-radius: 50%; background: radial-gradient(circle, rgba(37,99,235,.075), transparent 62%); pointer-events: none; }
    .dw-process-wrap { position: relative; z-index: 1; width: min(1600px, calc(100% - 48px)); margin: 0 auto; }
    .dw-process-head { display: grid; grid-template-columns: minmax(0, .72fr) minmax(360px, .46fr); gap: 80px; align-items: end; margin-bottom: 72px; }
    .dw-process-head .dw-section-title { max-width: 880px; }
    .dw-process-head .dw-section-desc { justify-self: end; max-width: 560px; margin-top: 0; }
    .dw-process-ux { display: grid; grid-template-columns: minmax(0, .92fr) minmax(440px, .58fr); gap: 22px; min-height: 720px; }
    .dw-process-display { position: relative; display: grid; grid-template-rows: minmax(0, 1fr) 360px; border: 1px solid rgba(15,23,42,.12); background: #f8fafc; overflow: hidden; }
    .dw-process-display:before { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(90deg, rgba(15,23,42,.045) 1px, transparent 1px), linear-gradient(180deg, rgba(15,23,42,.035) 1px, transparent 1px); background-size: 80px 80px; opacity: .72; }
    .dw-process-copy { position: relative; z-index: 1; padding: clamp(34px, 5vw, 74px); display: flex; flex-direction: column; justify-content: center; }
    .dw-process-label { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 28px; color: #2563eb; font-size: 13px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
    .dw-process-label:before { content: ""; width: 42px; height: 1px; background: #2563eb; }
    .dw-process-title { max-width: 860px; color: #0f172a; font-size: clamp(42px, 6vw, 60px); line-height: 1.1; letter-spacing: -.075em; font-weight: 900; word-break: keep-all; }
    .dw-process-desc { max-width: 680px; margin-top: 30px; color: #64748b; font-size: 18px; line-height: 1.82; word-break: keep-all; }
    .dw-process-meta-line { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 34px; }
    .dw-process-meta-line span { display: inline-flex; align-items: center; min-height: 36px; padding: 0 13px; background: #fff; border: 1px solid rgba(15,23,42,.08); color: #334155; font-size: 13px; font-weight: 900; }
    .dw-process-image { position: relative; z-index: 1; overflow: hidden; border-top: 1px solid rgba(15,23,42,.1); }
    .dw-process-image img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.04); filter: saturate(.96) contrast(1.04); transition: opacity .35s ease, transform .7s ease; }
    .dw-process-image:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,23,42,0), rgba(15,23,42,.18)); }
    .dw-process-nav { display: grid; grid-template-rows: repeat(4, 1fr); gap: 14px; }
    .dw-process-tab { position: relative; display: grid; grid-template-columns: 76px 1fr; gap: 22px; align-items: center; padding: 28px; border: 1px solid rgba(15,23,42,.12); background: #fff; text-align: left; cursor: pointer; transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease, background .35s ease; overflow: hidden; }
    .dw-process-tab:before { content: ""; position: absolute; left: 0; top: 0; width: 4px; height: 100%; background: #2563eb; transform: scaleY(0); transform-origin: top; transition: transform .35s ease; }
    .dw-process-tab:hover { transform: translateX(-8px); border-color: rgba(37,99,235,.34); box-shadow: 0 22px 64px rgba(15,23,42,.09); }
    .dw-process-tab.dw-is-active { background: #0f172a; border-color: #0f172a; color: #fff; box-shadow: 0 26px 70px rgba(15,23,42,.18); }
    .dw-process-tab.dw-is-active:before { transform: scaleY(1); }
    .dw-process-tab-num { position: relative; z-index: 1; color: rgba(15,23,42,.25); font-size: clamp(42px, 4vw, 66px); line-height: .82; font-weight: 900; letter-spacing: -.08em; transition: color .35s ease; }
    .dw-process-tab.dw-is-active .dw-process-tab-num { color: rgba(255,255,255,.26); }
    .dw-process-tab-body { position: relative; z-index: 1; }
    .dw-process-tab-kicker { display: block; color: #2563eb; font-size: 12px; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; transition: color .35s ease; }
    .dw-process-tab.dw-is-active .dw-process-tab-kicker { color: #93c5fd; }
    .dw-process-tab-title { display: block; margin-top: 13px; color: #0f172a; font-size: clamp(22px, 1.7vw, 30px); line-height: 1.02; letter-spacing: -.06em; font-weight: 900; word-break: keep-all; transition: color .35s ease; }
    .dw-process-tab.dw-is-active .dw-process-tab-title { color: #fff; }
    .dw-process-tab-text { display: block; margin-top: 12px; color: #64748b; font-size: 15px; line-height: 1.6; word-break: keep-all; transition: color .35s ease; }
    .dw-process-tab.dw-is-active .dw-process-tab-text { color: rgba(255,255,255,.66); }
    .dw-stats { padding: 150px 0; background: #fff; }
    .dw-stats-box { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; overflow: hidden; border-radius: 42px; background: #dbe3ef; border: 1px solid #dbe3ef; }
    .dw-stat-item { padding: 48px 32px; background: #f8fafc; }
    .dw-stat-item strong { display: block; font-size: clamp(42px, 5vw, 74px); letter-spacing: -.07em; color: #111827; }
    .dw-stat-item span { display: block; margin-top: 12px; color: #6b7280; font-weight: 700; }

    .dw-story { background: #f8fafc; overflow: hidden; }
    .dw-story-layout { display: grid; grid-template-columns: .85fr 1.15fr; gap: 60px; align-items: center; }
    .dw-story-copy { position: relative; z-index: 2; }
    .dw-story-swiper { width: 100%; border-radius: 42px; overflow: hidden; box-shadow: 0 36px 90px rgba(17,24,39,.16); }
    .dw-story-slide { height: 680px; position: relative; }
    .dw-story-slide img { width: 100%; height: 100%; object-fit: cover; }
    .dw-story-caption { position: absolute; left: 30px; right: 30px; bottom: 30px; padding: 26px; border-radius: 26px; background: rgba(255,255,255,.82); backdrop-filter: blur(18px); }
    .dw-story-caption h3 { font-size: 28px; letter-spacing: -.05em; }
    .dw-story-caption p { margin-top: 10px; color: #6b7280; line-height: 1.6; }
    .dw-story-pagination { position: static !important; margin-top: 32px; text-align: left !important; }
    .dw-story-pagination .swiper-pagination-bullet { width: 10px; height: 10px; background: #9ca3af; opacity: .45; }
    .dw-story-pagination .swiper-pagination-bullet-active { width: 34px; border-radius: 999px; background: #2563eb; opacity: 1; }

    .dw-contact { background: #08111f; color: #fff; padding: 150px 0; }
    .dw-contact-box { position: relative; overflow: hidden; padding: clamp(42px, 7vw, 90px); border-radius: 48px; background: linear-gradient(135deg, #172033, #0f172a 50%, #1d4ed8); }
    .dw-contact-box:before { content: ""; position: absolute; right: -140px; top: -140px; width: 420px; height: 420px; border-radius: 50%; background: rgba(255,255,255,.1); }
    .dw-contact-box h2 { position: relative; z-index: 1; max-width: 980px; font-size: clamp(32px, 6.4vw, 80px); line-height: 1.1; letter-spacing: -.075em; }
    .dw-contact-box p { position: relative; z-index: 1; max-width: 670px; margin-top: 28px; color: rgba(255,255,255,.72); line-height: 1.8; font-size: 18px; }
    .dw-contact-box .dw-btn { position: relative; z-index: 1; margin-top: 42px; }

    .dw-reveal { opacity: 0; transform: translateY(36px); transition: opacity .8s ease, transform .8s ease; }
    .dw-reveal.active { opacity: 1; transform: translateY(0); }

    @media (max-width: 1200px) {
      .dw-service-grid { grid-template-columns: repeat(2, 1fr); }
      .dw-service-item:nth-child(n) { grid-column: auto; transform: none; }
      .dw-service-item:nth-child(even):hover, .dw-service-item:nth-child(odd):hover { transform: translateY(-8px); }
      .dw-intro-grid, .dw-story-layout { grid-template-columns: 1fr; }
      .dw-process-head { grid-template-columns: 1fr; gap: 24px; }
      .dw-process-head .dw-section-desc { justify-self: start; margin-top: 0; }
      .dw-process-ux { grid-template-columns: 1fr; min-height: auto; }
      .dw-process-display { min-height: 780px; }
      .dw-process-nav { grid-template-columns: repeat(2, 1fr); grid-template-rows: auto; }
      .dw-intro-card:nth-child(2), .dw-intro-card:nth-child(4) { transform: translateY(0); }
      .dw-intro-card:nth-child(2):hover, .dw-intro-card:nth-child(4):hover { transform: translateY(-8px); }
      .dw-stats-box { grid-template-columns: repeat(2, 1fr); }
    }

    @media (max-width: 900px) {
      .dw-container, .dw-hero-content { width: min(100% - 32px, 1600px); }
      .dw-site-header { height: 74px; }
      .dw-hero { padding-top: 0; }
      .dw-hero-swiper, .dw-hero .swiper-wrapper, .dw-hero .swiper-slide, .dw-hero-slide { min-height: 100vh; }
      .dw-nav, .dw-header-cta { display: none; }
      .dw-menu-btn { display: block; }
      .dw-mobile-menu { top: 82px; }
      .dw-section { padding: 86px 0; }
      .dw-service-top, .dw-works-head { display: block; }
      .dw-service-top { width: 100%; margin-bottom: 42px; }
      .dw-works > .dw-container { padding: 0 16px; }
      .dw-work-control { margin-top: 28px; }
      .dw-hero-control { left: 16px; right: auto; bottom: 28px; }
      .dw-hero-content { padding-bottom: 120px; }
      .dw-work-card { height: 520px; border-radius: 32px; }
      .dw-story-slide { height: 520px; }
    }

    @media (max-width: 640px) {
      .dw-section { padding: 72px 0; }
      .dw-hero-title { font-size: clamp(32px, 7vw, 72px);}
      .dw-hero-text { font-size: 16px; }
      .dw-btn { width: 100%; }
      .dw-intro-card-wrap, .dw-service-grid, .dw-stats-box { grid-template-columns: 1fr; }
      .dw-intro-card-wrap { row-gap: 18px; }
      .dw-intro-card { min-height: auto; padding: 26px; }
      .dw-intro-card h3 { margin-top: 46px; }
      .dw-service-item { min-height: auto; padding: 0; }
      .dw-service-thumb { height: 210px; }
      .dw-service-body { min-height: 300px; padding: 28px 28px 76px; }
      .dw-service-item:before { left: 28px; right: 28px; top: 276px; }
      .dw-service-item h3 { margin-top: 54px; }
      .dw-service-link { left: 28px; bottom: 28px; }
      .dw-process-wrap { width: min(100% - 32px, 1600px); }
      .dw-process-head { margin-bottom: 42px; }
      .dw-process-display { grid-template-rows: auto 300px; min-height: auto; }
      .dw-process-copy { padding: 34px 24px; }
      .dw-process-title { font-size: clamp(30px, 6vw, 58px);}
      .dw-process-nav { grid-template-columns: 1fr; gap: 10px; }
      .dw-process-tab { grid-template-columns: 54px 1fr; gap: 16px; padding: 22px; }
      .dw-process-tab-num { font-size: 42px; }
      .dw-process-tab:hover { transform: translateY(-4px); }
      .dw-work-card { height: 460px; }
      .dw-work-info { left: 24px; right: 24px; bottom: 24px; }
      .dw-story-slide { height: 440px; }
      .dw-story-caption { left: 18px; right: 18px; bottom: 18px; padding: 20px; }
    }