/* ══════════════════════════════════════
   Woongilde HSG Home Plugin — Stylesheet
   ══════════════════════════════════════ */

.hsg-wrap *,
.hsg-wrap *::before,
.hsg-wrap *::after { box-sizing: border-box; }

.hsg-wrap { font-family: 'Segoe UI', Arial, sans-serif; font-size: 16px; line-height: 1.8; color: #333; }
.hsg-wrap a { color: #c8a96e; text-decoration: none; }
.hsg-wrap a:hover { color: #a8893e; }
.hsg-wrap img { max-width: 100%; height: auto; display: block; }

/* ── TAB NAV ── */
.hsg-nav { background: #1a1a1a; border-bottom: 3px solid #c8a96e; overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; margin: 0 -20px; }
.hsg-nav-inner { max-width: 1200px; margin: 0 auto; padding: 0 20px; display: flex; }
.hsg-tab { background: none; border: none; cursor: pointer; color: rgba(255,255,255,.55); font-size: .76rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 14px 16px; border-bottom: 3px solid transparent; margin-bottom: -3px; transition: all .2s; font-family: inherit; white-space: nowrap; }
.hsg-tab:hover { color: #fff; }
.hsg-tab.hsg-active { color: #c8a96e; border-bottom-color: #c8a96e; }

/* ── PAGES ── */
.hsg-page { display: none; }
.hsg-page.hsg-active { display: block; }

/* ── HERO ── */
.hsg-hero { background: #f6f4f1; padding: 52px 24px; }
.hsg-hero-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 360px; gap: 52px; align-items: center; }
.hsg-hero-label { font-size: .7rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: #c8a96e; margin-bottom: 8px; }
.hsg-hero-h1 { font-family: Georgia, 'Times New Roman', serif; font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 700; color: #1a1a1a; line-height: 1.15; margin-bottom: 14px; }
.hsg-hero-h1 em { font-style: italic; color: #c8a96e; }
.hsg-hero-sub { font-size: .97rem; color: #555; line-height: 1.75; margin-bottom: 24px; max-width: 480px; }
.hsg-btns { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; }
.hsg-btn-gold { background: #c8a96e; color: #1a1a1a !important; font-weight: 700; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; padding: 12px 24px; border-radius: 3px; text-decoration: none !important; border: none; cursor: pointer; font-family: inherit; transition: background .2s; display: inline-block; }
.hsg-btn-gold:hover { background: #daba80 !important; color: #1a1a1a !important; }
.hsg-btn-outline { border: 1px solid #bbb; color: #555 !important; font-size: .8rem; font-weight: 700; padding: 11px 20px; border-radius: 3px; text-decoration: none !important; display: inline-block; transition: all .2s; }
.hsg-btn-outline:hover { border-color: #333; color: #333 !important; }
.hsg-btn-wire { border: 1px solid rgba(255,255,255,.25); color: rgba(255,255,255,.75) !important; font-size: .8rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 11px 22px; border-radius: 3px; text-decoration: none !important; display: inline-block; transition: all .2s; }
.hsg-btn-wire:hover { background: rgba(255,255,255,.08); color: #fff !important; }
.hsg-checks { display: flex; flex-direction: column; gap: 7px; }
.hsg-check { display: flex; align-items: center; gap: 9px; font-size: .87rem; color: #444; }
.hsg-ci { color: #c8a96e; font-weight: 700; }
.hsg-hero-img { border-radius: 6px; overflow: hidden; box-shadow: 0 8px 32px rgba(0,0,0,.12); }
.hsg-hero-img img { width: 100%; height: 360px; object-fit: cover; }
.hsg-badge { background: #1a1a1a; color: #fff; border-radius: 4px; padding: 14px 18px; margin-top: 14px; text-align: center; }
.hsg-badge-top { font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: #c8a96e; margin-bottom: 3px; }
.hsg-badge-mid { font-family: Georgia, serif; font-size: 1.1rem; font-weight: 700; }
.hsg-badge-sub { font-size: .72rem; color: rgba(255,255,255,.5); margin-top: 3px; }

/* ── SPECS ── */
.hsg-specs { background: #1a1a1a; padding: 44px 24px; }
.hsg-specs-inner { max-width: 1200px; margin: 0 auto; }
.hsg-specs-label { font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: #c8a96e; margin-bottom: 18px; }
.hsg-specs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: #2c2c2c; border: 1px solid #2c2c2c; border-radius: 4px; overflow: hidden; }
.hsg-spec { background: #1a1a1a; padding: 18px 22px; }
.hsg-spec-lbl { font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: #666; margin-bottom: 5px; }
.hsg-spec-val { font-size: .95rem; font-weight: 700; color: #fff; margin-bottom: 1px; }
.hsg-spec-det { font-size: .77rem; color: rgba(255,255,255,.45); }

/* ── SECTIONS ── */
.hsg-section { padding: 60px 24px; }
.hsg-section-cream { background: #f6f4f1; }
.hsg-section-dark { background: #1a1a1a; }
.hsg-inner { max-width: 1200px; margin: 0 auto; }
.hsg-lbl { font-size: .7rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: #c8a96e; margin-bottom: 7px; }
.hsg-h2 { font-family: Georgia, serif; font-size: clamp(1.3rem, 2.5vw, 1.9rem); font-weight: 700; color: #1a1a1a; line-height: 1.2; margin-bottom: 10px; }
.hsg-h2 em { font-style: italic; color: #c8a96e; }
.hsg-h2-light { color: #fff; }
.hsg-sub { font-size: .93rem; color: #666; max-width: 600px; line-height: 1.7; margin-bottom: 36px; }

/* ── DETAIL ROW ── */
.hsg-detail-row { display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: center; margin-bottom: 52px; }
.hsg-detail-img { border-radius: 6px; overflow: hidden; box-shadow: 0 6px 24px rgba(0,0,0,.1); }
.hsg-detail-img img { width: 100%; height: 340px; object-fit: cover; }
.hsg-detail-lbl { font-size: .68rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: #c8a96e; margin-bottom: 8px; }
.hsg-detail-h3 { font-family: Georgia, serif; font-size: 1.35rem; font-weight: 700; color: #1a1a1a; margin-bottom: 12px; line-height: 1.25; }
.hsg-detail-h3 em { font-style: italic; color: #c8a96e; }
.hsg-detail-p { font-size: .93rem; color: #555; line-height: 1.8; margin-bottom: 18px; }

/* ── OVERVIEW GRID ── */
.hsg-ov-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.hsg-ov-card { border: 1px solid #e5ddd0; border-radius: 6px; overflow: hidden; cursor: pointer; transition: box-shadow .2s; background: #fff; }
.hsg-ov-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.1); }
.hsg-ov-img { height: 180px; overflow: hidden; background: #f6f4f1; position: relative; }
.hsg-ov-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.hsg-ov-card:hover .hsg-ov-img img { transform: scale(1.05); }
.hsg-ov-num { position: absolute; top: 10px; left: 10px; background: #c8a96e; color: #1a1a1a; font-weight: 700; font-size: .68rem; width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center; justify-content: center; z-index: 1; }
.hsg-ov-body { padding: 16px; }
.hsg-ov-title { font-size: .9rem; font-weight: 700; color: #1a1a1a; margin-bottom: 6px; }
.hsg-ov-desc { font-size: .78rem; color: #777; line-height: 1.55; margin-bottom: 12px; }
.hsg-ov-link { font-size: .75rem; font-weight: 700; color: #c8a96e; letter-spacing: .06em; text-transform: uppercase; }

/* ── VOORDELEN ── */
.hsg-vrd-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 8px; }
.hsg-vrd { background: #fff; border: 1px solid #e5ddd0; border-top: 3px solid #c8a96e; border-radius: 0 0 4px 4px; padding: 22px; }
.hsg-vrd-num { font-family: Georgia, serif; font-size: 1.5rem; font-weight: 700; color: #c8a96e; line-height: 1; margin-bottom: 10px; }
.hsg-vrd-title { font-size: .92rem; font-weight: 700; color: #1a1a1a; margin-bottom: 6px; }
.hsg-vrd-text { font-size: .84rem; color: #666; line-height: 1.65; }

/* ── WERKWIJZE ── */
.hsg-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 32px; }
.hsg-step { text-align: center; padding: 20px 14px; }
.hsg-step-num { width: 48px; height: 48px; border-radius: 50%; background: #c8a96e; color: #1a1a1a; font-weight: 700; font-size: 1rem; display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; font-family: Georgia, serif; }
.hsg-step-title { font-size: .9rem; font-weight: 700; color: #1a1a1a; margin-bottom: 6px; }
.hsg-step-text { font-size: .82rem; color: #666; line-height: 1.65; }

/* ── WHY ── */
.hsg-why-row { display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: start; }
.hsg-why-img { border-radius: 6px; overflow: hidden; box-shadow: 0 6px 24px rgba(0,0,0,.1); }
.hsg-why-img img { width: 100%; height: 400px; object-fit: cover; }
.hsg-why-badge { background: #1a1a1a; color: #c8a96e; padding: 10px 16px; border-radius: 3px; display: inline-flex; align-items: baseline; gap: 6px; margin-bottom: 18px; }
.hsg-why-badge-num { font-family: Georgia, serif; font-size: 1.5rem; font-weight: 700; }
.hsg-why-badge-lbl { font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.6); }
.hsg-why-points { display: flex; flex-direction: column; gap: 18px; margin-top: 6px; }
.hsg-why-pt { display: flex; gap: 14px; }
.hsg-why-pt-num { width: 30px; height: 30px; border-radius: 50%; background: #c8a96e; color: #1a1a1a; font-weight: 700; font-size: .82rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.hsg-why-pt-title { font-size: .92rem; font-weight: 700; color: #1a1a1a; margin-bottom: 3px; }
.hsg-why-pt-text { font-size: .84rem; color: #666; line-height: 1.65; }

/* ── REVIEWS ── */
.hsg-rev-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 32px; }
.hsg-rev { background: #f9f6f0; border: 1px solid #e5ddd0; border-radius: 6px; padding: 22px; }
.hsg-rev-stars { color: #c8a96e; font-size: .95rem; margin-bottom: 10px; }
.hsg-rev-text { font-size: .87rem; color: #555; font-style: italic; line-height: 1.7; margin-bottom: 14px; }
.hsg-rev-author { font-size: .8rem; font-weight: 700; color: #1a1a1a; }

/* ── CONTACT ── */
.hsg-contact-row { display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: center; }
.hsg-contact-info { display: flex; flex-direction: column; gap: 14px; margin-top: 20px; }
.hsg-ci-row { display: flex; gap: 12px; align-items: flex-start; }
.hsg-ci-icon { color: #c8a96e; font-size: 1rem; flex-shrink: 0; margin-top: 3px; }
.hsg-ci-lbl { font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: #888; margin-bottom: 1px; }
.hsg-ci-val { font-size: .92rem; color: #fff; }
.hsg-ci-val a { color: #c8a96e !important; }
.hsg-score-box { background: #c8a96e; border-radius: 4px; padding: 16px 20px; display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.hsg-score-big { font-family: Georgia, serif; font-size: 2.8rem; font-weight: 700; color: #1a1a1a; line-height: 1; }
.hsg-score-stars { color: #1a1a1a; font-size: 1rem; }
.hsg-score-src { font-size: .75rem; color: rgba(26,26,26,.7); margin-top: 2px; }
.hsg-info-box { background: #f6f4f1; border-radius: 4px; padding: 20px; font-size: .87rem; color: #555; line-height: 1.75; }
.hsg-info-box strong { color: #1a1a1a; display: block; margin-bottom: 6px; }

/* ── CTA ── */
.hsg-cta { background: #1a1a1a; padding: 56px 24px; text-align: center; }
.hsg-cta-h2 { font-family: Georgia, serif; font-size: clamp(1.3rem, 2.5vw, 2rem); font-weight: 700; color: #fff; margin-bottom: 26px; line-height: 1.2; }
.hsg-cta-h2 em { color: #c8a96e; font-style: italic; }
.hsg-cta-btns { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) { .hsg-ov-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 960px) {
  .hsg-hero-inner, .hsg-detail-row, .hsg-why-row, .hsg-contact-row { grid-template-columns: 1fr; gap: 28px; }
  .hsg-specs-grid { grid-template-columns: 1fr 1fr; }
  .hsg-vrd-grid { grid-template-columns: 1fr 1fr; }
  .hsg-steps { grid-template-columns: 1fr 1fr; }
  .hsg-rev-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .hsg-ov-grid, .hsg-vrd-grid, .hsg-steps, .hsg-specs-grid { grid-template-columns: 1fr; }
  .hsg-btns, .hsg-cta-btns { flex-direction: column; align-items: flex-start; }
  .hsg-cta-btns { align-items: center; }
  .hsg-hero-img img { height: 240px; }
}
