/* ============================================================
   video-recovery.html — page-specific CSS
   분리: 2026-06-07
   ============================================================ */

/* ─────────────────────────────────────────────────────
   forensic-headers-center
   (페이지 섹션 헤더 중앙 정렬 — PC 전용)
   ───────────────────────────────────────────────────── */
@media (min-width: 769px) {
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head {
    text-align: center !important;
  }
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head .st-section-badge,
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head .st-section-eyebrow,
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head .st-h2,
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head h2,
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head .st-section-desc,
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head .st-section-subdesc,
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head p {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head .st-section-badge,
  section:not(.st-hero-v2):not([class*="hero"]) .st-section-head .st-section-eyebrow {
    display: inline-flex !important;
  }
}

/* ─────────────────────────────────────────────────────
   st-hero-v2 (히어로 영역 — 다크 네이비 + 민트 #00897b)
   ───────────────────────────────────────────────────── */
.st-hero-v2 { background: linear-gradient(135deg, #142e48 0%, #173a52 50%, #0f2233 100%); color: #fff; padding: 56px 0 64px; position: relative; overflow: hidden; }
.st-hero-v2 .lg-container { max-width: 1280px; margin: 0 auto; padding: 0 24px; position: relative; z-index: 2; }
.st-hero-v2 .st-hero-card { background: rgba(22, 50, 75, .85); border: 2px solid rgba(0,201,180,.7); border-radius: 22px; padding: 44px 44px 40px; box-shadow: 0 0 0 1px rgba(255,255,255,.04) inset, 0 10px 36px rgba(0,0,0,.35), 0 0 32px rgba(0,201,180,.7); backdrop-filter: blur(10px); }
.st-hero-v2 .st-hero-stage { display: grid; grid-template-columns: 1.4fr .6fr; gap: 36px; align-items: center; min-height: 380px; }
.st-hero-v2 .st-hero-content { min-width: 0; }
.st-hero-v2 .st-hero-tag { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px; background: rgba(0,201,180,.22); color: #5cf0dd; border: 1px solid rgba(0,201,180,.7); border-radius: 999px; font-size: 12.5px; font-weight: 700; letter-spacing: .02em; }
.st-hero-v2 .st-hero-h1 { font-family: "Montserrat","Pretendard",sans-serif; font-size: 52px; font-weight: 800; letter-spacing: -.02em; line-height: 1.05; color: #fff; margin: 16px 0 14px; display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.st-hero-v2 .st-hero-h1 .brand { font-size: .55em; color: rgba(255,255,255,.7); font-weight: 700; letter-spacing: -.005em; }
.st-hero-v2 .st-hero-h1 .tier { color: #00897b; font-size: 1em; font-weight: 800; letter-spacing: -.01em; }
.st-hero-v2 .st-hero-h1 .tier .hl { color: #00897b; }
.st-hero-v2 .st-hero-h1 .tier .rest { color: #fff; margin-left: .15em; }
.st-hero-v2 .st-hero-tagline { font-size: 25px; font-weight: 800; line-height: 1.4; color: #fff; margin: 0 0 18px; letter-spacing: -.01em; }
.st-hero-v2 .st-hero-sub { font-size: 17px; color: rgba(230,238,244,.9); line-height: 1.7; margin: 0 0 18px; font-weight: 500; max-width: 600px; }
.st-hero-v2 .st-hero-trust { display: flex; gap: 12px; align-items: flex-start; padding: 14px 16px; background: rgba(0,0,0,.25); border-left: 3px solid #00897b; border-radius: 8px; margin: 0 0 18px; font-size: 13.5px; line-height: 1.6; color: rgba(255,255,255,.85); max-width: 620px; }
.st-hero-v2 .st-hero-trust > i { color: #00897b; font-size: 18px; flex: none; margin-top: 2px; }
.st-hero-v2 .st-hero-trust strong { color: #fff; font-weight: 700; }
.st-hero-v2 .st-hero-warn { display: flex; flex-direction: column; gap: 8px; margin: 0 0 22px; font-size: 12.5px; color: rgba(255,255,255,.78); line-height: 1.55; max-width: 620px; }
.st-hero-v2 .st-hero-warn p { display: flex; align-items: flex-start; gap: 8px; margin: 0; }
.st-hero-v2 .st-hero-warn p i { color: #00897b; font-size: 13px; flex: none; margin-top: 3px; }
.st-hero-v2 .st-hero-warn p strong { color: #fff; font-weight: 700; }
.st-hero-v2 .st-hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.st-hero-v2 .st-cta-primary { display: inline-flex; align-items: center; gap: 8px; padding: 14px 24px; background: #00897b; color: #fff; text-decoration: none; border-radius: 10px; font-weight: 700; font-size: 15px; box-shadow: 0 4px 18px rgba(0,0,0,.3); transition: transform .15s, box-shadow .15s; }
.st-hero-v2 .st-cta-primary:hover { transform: translateY(-1px); }
.st-hero-v2 .st-cta-secondary { display: inline-flex; align-items: center; gap: 8px; padding: 14px 22px; background: transparent; color: #fff; text-decoration: none; border: 1.5px solid rgba(255,255,255,.4); border-radius: 10px; font-weight: 600; font-size: 15px; }
.st-hero-v2 .st-hero-meta { display: flex; gap: 18px; flex-wrap: wrap; font-size: 13px; color: rgba(255,255,255,.85); }
.st-hero-v2 .st-hero-meta i { color: #00897b; }
.st-hero-v2 .st-hero-visual { position: relative; min-height: 340px; display: flex; align-items: center; justify-content: center; }
.st-hero-v2 .st-hero-package { position: relative; width: 100%; max-width: 220px; filter: drop-shadow(0 18px 36px rgba(0,0,0,.5)); }
.st-hero-v2 .st-hero-package img { width: 100%; height: auto; display: block; }

@media (max-width: 960px) {
  .st-hero-v2 { padding: 36px 0 44px; }
  .st-hero-v2 .st-hero-card { padding: 32px 28px; border-radius: 18px; }
  .st-hero-v2 .st-hero-stage { grid-template-columns: 1fr; gap: 20px; text-align: center; min-height: auto; }
  .st-hero-v2 .st-hero-h1 { font-size: 44px; justify-content: center; }
  .st-hero-v2 .st-hero-h1 .brand { display: block; width: 100%; font-size: 16px; margin-bottom: 4px; }
  .st-hero-v2 .st-hero-tagline { font-size: 21px; }
  .st-hero-v2 .st-hero-sub { font-size: 16px; margin-left: auto; margin-right: auto; }
  .st-hero-v2 .st-hero-meta { justify-content: center; }
  .st-hero-v2 .st-hero-cta { justify-content: center; }
  .st-hero-v2 .st-hero-visual { min-height: auto; padding-top: 12px; }
  .st-hero-v2 .st-hero-package { max-width: 180px; }
}

@media (max-width: 540px) {
  .st-hero-v2 { padding: 24px 0 32px; }
  .st-hero-v2 .lg-container { padding: 0 12px; }
  .st-hero-v2 .st-hero-card { padding: 24px 18px; border-radius: 14px; }
  .st-hero-v2 .st-hero-h1 { font-size: 36px; flex-direction: column; gap: 4px; }
  .st-hero-v2 .st-hero-h1 .brand { font-size: 14px; }
  .st-hero-v2 .st-hero-tagline { font-size: 18px; }
  .st-hero-v2 .st-hero-sub { font-size: 14.5px; line-height: 1.65; }
  .st-hero-v2 .st-hero-meta { font-size: 12px; gap: 10px; }
  .st-hero-v2 .st-cta-primary, .st-hero-v2 .st-cta-secondary { padding: 12px 18px; font-size: 14px; }
  .st-hero-v2 .st-hero-package { max-width: 150px; }
}
