/* ═══════════════════════════════════════════════════════════════
 * hwaon_landings_common.css — 랜딩 페이지 공통 CSS
 * 세션 61 Pack B-2 · 법무법인 화온 (2026.04.18) · 수정됨
 * ───────────────────────────────────────────────────────────────
 * 참고: Sticky CTA는 tail.php의 #premium-quick-menu + #mobile-sticky-cta
 *       가 전역 제공하므로 여기서는 중복 정의하지 않음
 * ═══════════════════════════════════════════════════════════════ */

/* ─── [1] 기본 변수 ─── */
:root {
    --hw-navy: #1B2A4A;
    --hw-navy-deep: #0F1B30;
    --hw-orange: #EA5514;
    --hw-gold: #C9A96E;
    --hw-gold-dim: rgba(201,169,110,.12);
    --hw-gold-line: rgba(201,169,110,.35);
    --hw-cream: #F5F0EB;
    --hw-bg: #FAFAF7;
    --hw-text: #2C2C2C;
    --hw-text-sub: #6B6B6B;
    --hw-border: #E8E2DA;
    --hw-red: #C62828;
}

/* ═══════════════════════════════════════════════════════
   [2] hw-firm-eyebrow — 법인 브랜드 Eyebrow
═══════════════════════════════════════════════════════ */
.hw-firm-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 8px 16px;
    margin: 0 auto 24px;
    background: linear-gradient(135deg, rgba(201,169,110,0.12), rgba(201,169,110,0.05));
    border: 1px solid rgba(201,169,110,0.35);
    border-radius: 999px;
    font-family: 'Pretendard', -apple-system, sans-serif;
    font-size: 13px;
    letter-spacing: 0.02em;
    color: #1B2A4A;
    position: relative;
    z-index: 2;
}
.hw-firm-eyebrow-logo {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 700;
    font-size: 15px;
    letter-spacing: 0.15em;
    color: #C9A96E;
}
.hw-firm-eyebrow-sep {
    width: 1px;
    height: 12px;
    background: rgba(27,42,74,0.3);
}
.hw-firm-eyebrow-text {
    font-weight: 500;
}
@media (max-width: 768px) {
    .hw-firm-eyebrow {
        font-size: 12px;
        padding: 6px 14px;
        gap: 10px;
        margin-bottom: 18px;
    }
    .hw-firm-eyebrow-logo {
        font-size: 14px;
    }
}

/* ═══════════════════════════════════════════════════════
   [3] hw-related-hub — 관련 전담센터 허브 섹션
═══════════════════════════════════════════════════════ */
.hw-related-hub {
    max-width: 1100px;
    margin: 0 auto;
    padding: 72px 40px;
    background: #FAFAF7;
    border-top: 1px solid rgba(201,169,110,0.2);
}
.hw-related-header {
    text-align: center;
    margin-bottom: 44px;
}
.hw-related-eyebrow {
    font-family: 'Cormorant Garamond', serif;
    font-size: 11px;
    letter-spacing: 5px;
    color: #C9A96E;
    text-transform: uppercase;
    font-weight: 700;
    display: block;
    margin-bottom: 12px;
}
.hw-related-title {
    font-family: 'Noto Serif KR', serif;
    font-size: clamp(22px, 2.8vw, 30px);
    font-weight: 700;
    color: #1B2A4A;
    letter-spacing: -.02em;
    margin-bottom: 12px;
}
.hw-related-sub {
    font-size: 14px;
    color: #6B6B6B;
    line-height: 1.7;
}
.hw-related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-bottom: 32px;
}
.hw-related-link {
    background: #fff;
    border: 1px solid #E8E2DA;
    border-radius: 2px;
    padding: 18px 22px;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: all .4s cubic-bezier(0.19,1,0.22,1);
    position: relative;
    overflow: hidden;
}
.hw-related-link::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: #C9A96E;
    transform: scaleY(0);
    transform-origin: bottom;
    transition: transform .4s cubic-bezier(0.19,1,0.22,1);
}
.hw-related-link:hover {
    border-color: rgba(201,169,110,0.4);
    transform: translateX(4px);
    box-shadow: 0 8px 24px rgba(27,42,74,0.08);
}
.hw-related-link:hover::before {
    transform: scaleY(1);
}
.hw-related-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(201,169,110,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #C9A96E;
    font-size: 13px;
    flex-shrink: 0;
    transition: all .35s;
}
.hw-related-link:hover .hw-related-icon {
    background: #1B2A4A;
    color: #C9A96E;
}
.hw-related-name {
    font-family: 'Pretendard', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #1B2A4A;
    letter-spacing: -.01em;
    flex: 1;
    transition: color 0.3s;
}
.hw-related-link:hover .hw-related-name {
    color: #EA5514;
}
.hw-related-arrow {
    color: #C9A96E;
    font-size: 10px;
    opacity: 0;
    transform: translateX(-6px);
    transition: all .35s;
}
.hw-related-link:hover .hw-related-arrow {
    opacity: 1;
    transform: translateX(0);
}
.hw-related-hub-link {
    text-align: center;
    padding-top: 24px;
    border-top: 1px solid rgba(201,169,110,0.2);
}
.hw-hub-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 32px;
    background: #1B2A4A;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 2px;
    transition: all .35s;
}
.hw-hub-btn:hover {
    background: #C9A96E;
    color: #1B2A4A;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(201,169,110,0.3);
}
@media (max-width: 1024px) {
    .hw-related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .hw-related-hub { padding: 48px 20px; }
    .hw-related-grid { grid-template-columns: 1fr; gap: 10px; }
    .hw-related-link { padding: 14px 18px; }
}

/* ═══════════════════════════════════════════════════════
   [4] A11y — 접근성·가독성 공통 (Pack A-4)
═══════════════════════════════════════════════════════ */

:focus-visible {
    outline: 2px solid #C9A96E;
    outline-offset: 3px;
    border-radius: 2px;
}
a:focus-visible,
button:focus-visible {
    outline: 2px solid #C9A96E;
    outline-offset: 3px;
    box-shadow: 0 0 0 4px rgba(201,169,110,0.2);
}
.faq-q:focus-visible {
    outline: 2px solid #C9A96E;
    outline-offset: 2px;
    border-radius: 4px;
}

@media (max-width: 768px) {
    [class*="-eyebrow"],
    [class*="-en"],
    [class*="-phase"],
    [class*="-tag"]:not(.sc-hero-tag-dot),
    [class*="-label"]:not(.sc-hero-tag-dot),
    [class*="-badge"],
    [class*="-cred"],
    [class*="-mistake-num"],
    [class*="-tl-num"],
    [class*="-tl-timing"] {
        font-size: max(11px, 0.6875em) !important;
    }
    [class*="-body"]:not(.sc-hero-body),
    [class*="-desc"]:not([class*="-mini"]) {
        font-size: max(13px, 0.8125em);
    }
    .hw-firm-eyebrow-text,
    .hw-firm-eyebrow-logo {
        font-size: max(11px, inherit);
    }
}

@media (max-width: 768px) and (hover: none) {
    button,
    a[class*="btn"],
    a[class*="cta"],
    .faq-q {
        min-height: 44px;
    }
}

@media (prefers-reduced-motion: reduce) {
    *[class*="animation"],
    *[class*="-anim-"] {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}

/* ═══════════════════════════════════════════════════════
   [5] hw-quick-form — 간이 상담 폼 (Pack C-1)
═══════════════════════════════════════════════════════ */
.hw-quick-form-section {
    max-width: 800px;
    margin: 60px auto 0;
    padding: 56px 48px;
    background: linear-gradient(135deg, #0F1B30 0%, #1B2A4A 100%);
    border-radius: 4px;
    position: relative;
    overflow: hidden;
}
.hw-quick-form-section::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, #C9A96E, transparent);
}
.hw-quick-form-header {
    text-align: center;
    margin-bottom: 36px;
}
.hw-quick-form-eyebrow {
    font-family: 'Cormorant Garamond', serif;
    font-size: 11px;
    letter-spacing: 5px;
    color: #C9A96E;
    text-transform: uppercase;
    font-weight: 700;
    display: block;
    margin-bottom: 14px;
}
.hw-quick-form-title {
    font-family: 'Noto Serif KR', serif;
    font-size: clamp(22px, 2.8vw, 30px);
    font-weight: 700;
    color: #fff;
    line-height: 1.4;
    letter-spacing: -.02em;
    margin-bottom: 12px;
}
.hw-quick-form-title em {
    font-style: normal;
    color: #C9A96E;
}
.hw-quick-form-sub {
    font-size: 14px;
    color: rgba(255,255,255,0.55);
    line-height: 1.7;
}
.hw-quick-form {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.hw-quick-form-field.full { grid-column: 1 / -1; }
.hw-quick-form-input,
.hw-quick-form-textarea {
    width: 100%;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(201,169,110,0.22);
    border-radius: 2px;
    padding: 14px 18px;
    font-family: 'Pretendard', sans-serif;
    font-size: 14px;
    color: #fff;
    transition: all 0.3s;
}
.hw-quick-form-input::placeholder,
.hw-quick-form-textarea::placeholder {
    color: rgba(255,255,255,0.35);
}
.hw-quick-form-input:focus,
.hw-quick-form-textarea:focus {
    outline: none;
    border-color: #C9A96E;
    background: rgba(255,255,255,0.07);
    box-shadow: 0 0 0 3px rgba(201,169,110,0.15);
}
.hw-quick-form-textarea {
    resize: vertical;
    min-height: 100px;
}
.hw-quick-form-submit {
    grid-column: 1 / -1;
    background: #EA5514;
    color: #fff;
    padding: 16px 32px;
    border: none;
    border-radius: 2px;
    font-family: 'Pretendard', sans-serif;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
.hw-quick-form-submit:hover {
    background: #d14a10;
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(234,85,20,0.35);
}
.hw-quick-form-note {
    grid-column: 1 / -1;
    text-align: center;
    font-size: 12px;
    color: rgba(255,255,255,0.35);
    margin-top: 6px;
    line-height: 1.6;
}
.hw-quick-form-note a {
    color: rgba(201,169,110,0.8);
    text-decoration: underline;
}
.sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}
@media (max-width: 768px) {
    .hw-quick-form-section {
        padding: 40px 24px;
        margin-top: 40px;
    }
    .hw-quick-form { grid-template-columns: 1fr; }
}
