/* ============================================================
   HOMEGA WIREFRAME – style.css
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Helvetica Neue', Arial, sans-serif; background: #fff; color: #111; font-size: 15px; line-height: 1.65; }
:where(a, a:visited) { color: inherit; text-decoration: none; }
:where(a:hover, a:focus-visible, a:active) { color: inherit; }
:where(a:focus-visible) { outline: 2px solid currentColor; outline-offset: 3px; }
img { display: block; max-width: 100%; }

/* ---- Layout ---- */
.wrap { max-width: 1140px; margin: 0 auto; padding: 0 24px; }
.section { padding: 72px 0; border-top: 1px solid #e4e4e4; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; align-items: center; }
.gap-lg { gap: 72px; }
.gap-md { gap: 48px; }
.flex-col-center { display: flex; flex-direction: column; justify-content: center; }
.mt-8  { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mb-8  { margin-bottom: 8px; display: inline-block; }

/* ---- Typography ---- */
h1 { font-size: 40px; line-height: 1.1; font-weight: 800; margin-bottom: 18px; }
h2 { font-size: 28px; font-weight: 700; line-height: 1.2; margin-bottom: 14px; }
h3 { font-size: 18px; font-weight: 700; margin-bottom: 10px; }
p  { color: #555; margin-bottom: 14px; }
p:last-child { margin-bottom: 0; }
.eyebrow { display: block; font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: #888; margin-bottom: 10px; }
.breadcrumb { font-size: 13px; color: #888; padding: 16px 0; }
.breadcrumb a { color: #555; }
.breadcrumb a:hover { color: #111; }

/* ---- Placeholder (grey image box) ---- */
.ph { background: #ddd; display: flex; align-items: center; justify-content: center; }

/* ---- Buttons ---- */
.btn { display: inline-block; padding: 13px 28px; font-size: 14px; font-weight: 700; border: 2px solid #111; cursor: pointer; white-space: nowrap; }
.btn-dark  { background: #111; color: #fff; }
.btn-light { background: #fff; color: #111; }
.btn-sm    { padding: 9px 18px; font-size: 13px; }
.btn-full  { display: block; width: 100%; text-align: center; }

/* ---- Badge ---- */
.badge { display: inline-block; background: #111; color: #fff; font-size: 10px; font-weight: 700; letter-spacing: 1.5px; padding: 3px 8px; text-transform: uppercase; }

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar { background: #111; color: #fff; font-size: 12px; padding: 8px 0; position: sticky; top: 0; z-index: 1000; }
.topbar .wrap { display: flex; justify-content: space-between; align-items: center; }
.topbar-left { display: flex; gap: 20px; }
.topbar-left span { opacity: .8; }
.topbar-left .topbar-login { display: flex; align-items: center; gap: 6px; color: #fff; font-size: 12px; cursor: default; opacity: 1; }
.topbar-login svg { width: 14px; height: 14px; stroke: currentColor; }
.topbar-right { display: flex; align-items: center; gap: 24px; font-size: 12px; }
.topbar-right > span:first-child { opacity: .65; }
.topbar-right .topbar-login { display: flex; align-items: center; gap: 6px; color: #fff; cursor: default; opacity: 1; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header { border-bottom: 2px solid #111; padding: 18px 0; background: #fff; position: sticky; top: 36px; z-index: 999; transition: padding .2s ease, box-shadow .2s ease; }
.site-header .wrap { display: flex; justify-content: space-between; align-items: center; }
.site-header .logo img { transition: height .2s ease; }
body.is-scrolled .site-header { padding: 10px 0; box-shadow: 0 8px 18px rgba(0,0,0,.08); }
body.is-scrolled .site-header .logo img { height: 34px !important; }
.logo { display: inline-flex; align-items: center; flex-shrink: 0; }
.logo span { font-size: 22px; font-weight: 900; letter-spacing: 3px; text-transform: uppercase; }
.nav { display: flex; gap: 32px; align-items: center; }
.nav a { font-size: 13px; font-weight: 500; color: #111; letter-spacing: .5px; text-transform: uppercase; }
.nav a.active { border-bottom: 2px solid #111; padding-bottom: 2px; }
.nav-cart { font-weight: 700 !important; }

/* ============================================================
   PAGE HERO BANNER (belső oldalak)
   ============================================================ */
.page-hero { background: #f5f5f5; border-bottom: 2px solid #111; padding: 48px 0; }
.page-hero h1 { font-size: 34px; max-width: 680px; }
.page-hero p { font-size: 17px; max-width: 600px; margin-top: 10px; }

/* ============================================================
   HERO (főoldal)
   ============================================================ */
.hero { display: grid; grid-template-columns: 1fr 440px; border-bottom: 2px solid #111; min-height: 480px; }
.hero-copy { padding: 64px 48px; display: flex; flex-direction: column; justify-content: center; border-right: 2px solid #111; }
.hero-copy h1 { max-width: 500px; }
.hero-copy > p { max-width: 460px; font-size: 16px; margin-bottom: 28px; }
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-visual { min-height: 480px; }

/* ============================================================
   STATS ROW
   ============================================================ */
.stats-row { display: flex; border: 2px solid #111; }
.stat { flex: 1; padding: 18px 12px; text-align: center; border-right: 2px solid #111; }
.stat:last-child { border-right: none; }
.stat-num { display: block; font-size: 26px; font-weight: 800; margin-bottom: 2px; }
.stat-lbl { font-size: 12px; color: #888; }

/* ============================================================
   SERVICES
   ============================================================ */
.section-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 32px; }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); border: 2px solid #111; }
.svc-card { padding: 36px 28px; border-right: 2px solid #111; }
.svc-card:last-child { border-right: none; }
.svc-icon { width: 44px; height: 44px; background: #ddd; border-radius: 50%; margin-bottom: 20px; }
.svc-link { font-size: 13px; font-weight: 700; border-bottom: 1px solid #111; padding-bottom: 2px; display: inline-block; margin-top: 16px; }

/* ============================================================
   PRODUCTS
   ============================================================ */
.row-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 28px; }
.row-header h2 { margin-bottom: 0; }
.products-grid { display: grid; gap: 20px; }
.products-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.products-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.product-card { border: 1px solid #ddd; }
.product-body { padding: 16px; }
.product-cat { font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: #999; margin-bottom: 6px; }
.product-name { font-size: 14px; font-weight: 700; margin-bottom: 10px; color: #111; }
.price-row { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; }
.price-old { font-size: 13px; color: #bbb; text-decoration: line-through; }
.price-new { font-size: 20px; font-weight: 800; color: #111; }
.btn-cart { display: block; width: 100%; text-align: center; background: #111; color: #fff; border: 2px solid #111; padding: 10px; font-size: 13px; font-weight: 700; cursor: pointer; }

/* ============================================================
   CREDENTIALS / TIMELINE
   ============================================================ */
.cred-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.cred-item { border-left: 3px solid #111; padding: 0 0 28px 20px; margin-bottom: 4px; }
.cred-year { font-size: 12px; color: #888; font-weight: 700; margin-bottom: 4px; }
.cred-title { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.cred-place { font-size: 13px; color: #666; }

.timeline { padding-left: 28px; position: relative; }
.timeline::before { content: ''; position: absolute; left: 6px; top: 4px; bottom: 0; width: 2px; background: #111; }
.tl-item { position: relative; margin-bottom: 32px; }
.tl-dot { position: absolute; left: -26px; top: 4px; width: 14px; height: 14px; background: #111; border-radius: 50%; }
.tl-year { font-size: 12px; color: #888; font-weight: 700; margin-bottom: 4px; }
.tl-title { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.tl-desc { font-size: 13px; color: #666; }

/* ============================================================
   PRESS
   ============================================================ */
.press-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 32px; }
.press-card { border: 1px solid #ddd; padding: 24px; }
.press-logo-ph { height: 56px; background: #e8e8e8; margin-bottom: 14px; display: flex; align-items: center; justify-content: center; }
.press-logo-ph span { font-size: 12px; color: #aaa; font-weight: 700; letter-spacing: 1px; }
.press-date { font-size: 12px; color: #aaa; margin-bottom: 10px; }
.press-quote { font-size: 13px; color: #555; font-style: italic; border-left: 3px solid #111; padding-left: 12px; }
.press-readmore { font-size: 12px; font-weight: 700; display: inline-block; margin-top: 12px; border-bottom: 1px solid #111; padding-bottom: 1px; }

/* ============================================================
   SERVICE DETAIL PAGE
   ============================================================ */
.trust-band { background: #f5f5f5; border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; padding: 32px 0; }
.trust-items { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.trust-item { text-align: center; padding: 8px 16px; }
.trust-icon { width: 44px; height: 44px; background: #ddd; border-radius: 50%; margin: 0 auto 12px; }
.trust-item h4 { font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.trust-item p  { font-size: 13px; }

.svc-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; padding: 64px 0; }
.svc-detail.reverse { direction: rtl; }
.svc-detail.reverse > * { direction: ltr; }
.svc-tag { display: inline-block; border: 2px solid #111; padding: 4px 12px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 16px; }
.price-box { background: #111; color: #fff; padding: 16px 24px; display: inline-block; margin: 24px 0; }
.price-box .price-lbl  { font-size: 11px; color: #aaa; text-transform: uppercase; letter-spacing: 1px; }
.price-box .price-amt  { font-size: 26px; font-weight: 800; }
.price-box .price-dur  { font-size: 12px; color: #aaa; margin-top: 4px; }
.checklist { list-style: none; padding: 0; margin: 16px 0 24px; }
.checklist li { padding: 8px 0 8px 24px; position: relative; border-bottom: 1px solid #f0f0f0; font-size: 14px; color: #333; }
.checklist li::before { content: '✓'; position: absolute; left: 0; font-weight: 800; }
.svc-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

.faq-list { max-width: 760px; }
.faq-item { border: 1px solid #ddd; margin-bottom: 8px; }
.faq-q { padding: 16px 20px; font-weight: 700; font-size: 15px; display: flex; justify-content: space-between; cursor: pointer; }
.faq-toggle { font-size: 20px; font-weight: 400; color: #aaa; }
.faq-a { padding: 0 20px 16px; font-size: 14px; color: #555; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band { background: #111; color: #fff; padding: 56px 0; text-align: center; }
.cta-band h2 { color: #fff; font-size: 28px; margin-bottom: 14px; }
.cta-band p  { color: #888; max-width: 500px; margin: 0 auto 28px; }
.cta-band-btns { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.btn-white { border: 2px solid #fff; background: #fff; color: #111; padding: 13px 28px; font-size: 14px; font-weight: 700; display: inline-block; }
.btn-outline-white { border: 2px solid #fff; background: transparent; color: #fff; padding: 13px 28px; font-size: 14px; font-weight: 700; display: inline-block; }

/* ============================================================
   SHOP
   ============================================================ */
.promo-bar { background: #111; color: #fff; padding: 14px 0; }
.promo-bar .wrap { display: flex; justify-content: space-between; align-items: center; }
.promo-bar p { color: #fff; margin: 0; font-size: 14px; }
.coupon-code { border: 2px dashed #fff; padding: 6px 16px; font-size: 13px; font-weight: 700; letter-spacing: 2px; }

.shop-layout { display: grid; grid-template-columns: 260px 1fr; gap: 40px; padding: 40px 0 72px; }

.sidebar-block { border: 1px solid #ddd; margin-bottom: 20px; }
.sidebar-block h4 { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; padding: 12px 16px; border-bottom: 1px solid #ddd; background: #f9f9f9; }
.sidebar-block ul { list-style: none; padding: 8px 0; }
.sidebar-block ul li a { display: flex; justify-content: space-between; padding: 8px 16px; font-size: 14px; color: #333; }
.sidebar-block ul li a.active { font-weight: 700; color: #111; }
.cat-count { color: #aaa; font-size: 13px; }
.coupon-hint { border: 2px dashed #111; padding: 16px; background: #fafafa; font-size: 13px; color: #333; }
.coupon-hint strong { display: block; margin-bottom: 4px; font-size: 14px; }

.shop-main-header { display: flex; justify-content: space-between; align-items: center; padding-bottom: 16px; border-bottom: 1px solid #ddd; margin-bottom: 24px; }
.results-count { font-size: 13px; color: #888; }
.sort-select { border: 1px solid #ddd; padding: 8px 12px; font-size: 14px; background: #fff; }

.cat-tabs { display: flex; gap: 8px; margin-bottom: 28px; flex-wrap: wrap; }
.cat-tab { border: 2px solid #111; padding: 8px 18px; font-size: 13px; font-weight: 700; cursor: pointer; }
.cat-tab.active { background: #111; color: #fff; }

.pagination { display: flex; gap: 8px; margin-top: 40px; }
.page-btn { border: 1px solid #ddd; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; font-size: 14px; cursor: pointer; }
.page-btn.active { background: #111; color: #fff; border-color: #111; }
.page-btn.wide { width: auto; padding: 0 14px; }

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.product-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; padding: 48px 0 64px; }

.gallery-main { height: 440px; }
.thumb-row { display: flex; gap: 8px; margin-top: 10px; }
.thumb-item { width: 80px; height: 80px; background: #e8e8e8; border: 1px solid #ddd; }
.thumb-item.active { border: 2px solid #111; }

.product-tag { font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: #888; margin-bottom: 6px; }
.product-badge-sale { display: inline-block; background: #111; color: #fff; font-size: 11px; font-weight: 700; padding: 3px 10px; letter-spacing: 1px; margin-bottom: 14px; }
.price-section { border-top: 1px solid #eee; border-bottom: 1px solid #eee; padding: 18px 0; margin: 18px 0; }
.price-section .price-old { font-size: 14px; color: #bbb; text-decoration: line-through; }
.price-section .price-new { font-size: 36px; font-weight: 800; }
.price-saving { font-size: 13px; color: #666; margin-top: 4px; }

.qty-row { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.qty-ctrl { display: flex; align-items: center; border: 2px solid #111; }
.qty-btn { width: 38px; height: 40px; background: #fff; border: none; font-size: 20px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.qty-input { width: 48px; height: 40px; text-align: center; border: none; border-left: 1px solid #ddd; border-right: 1px solid #ddd; font-size: 15px; font-weight: 700; }
.stock-info { font-size: 13px; color: #888; }

.coupon-hint-box { border: 2px dashed #111; padding: 16px; background: #fafafa; font-size: 13px; margin-top: 20px; }
.coupon-hint-box strong { display: block; margin-bottom: 4px; }

.product-meta-row { margin-top: 20px; font-size: 13px; color: #666; }
.product-meta-row span { display: block; margin-bottom: 4px; }

.product-tabs { border-top: 2px solid #111; padding-top: 48px; margin-top: 0; }
.tab-nav { display: flex; border-bottom: 2px solid #111; margin-bottom: 32px; }
.tab-btn { padding: 12px 24px; font-size: 14px; font-weight: 700; cursor: pointer; border-bottom: 4px solid transparent; margin-bottom: -2px; }
.tab-btn.active { border-bottom-color: #111; }
.tab-content { max-width: 760px; }
.tab-content h3 { margin-bottom: 12px; margin-top: 24px; }
.tab-content h3:first-child { margin-top: 0; }

.related { padding: 48px 0; border-top: 1px solid #e4e4e4; }
.related-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 24px; }
.rel-card { border: 1px solid #ddd; }
.rel-body { padding: 14px; }
.rel-body h4 { font-size: 14px; font-weight: 700; margin-bottom: 8px; }
.rel-price { font-size: 16px; font-weight: 800; }
.rel-price .price-old { font-size: 12px; color: #bbb; text-decoration: line-through; font-weight: 400; margin-left: 4px; }

/* ============================================================
   CART
   ============================================================ */
.checkout-steps { display: flex; align-items: center; padding: 24px 0; border-bottom: 1px solid #ddd; margin-bottom: 40px; }
.step { display: flex; align-items: center; gap: 10px; font-size: 14px; color: #aaa; }
.step.active { color: #111; font-weight: 700; }
.step.done { color: #111; }
.step-num { width: 28px; height: 28px; border: 2px solid #ddd; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; flex-shrink: 0; }
.step.active .step-num { border-color: #111; background: #111; color: #fff; }
.step.done .step-num { border-color: #111; background: #111; color: #fff; }
.step-line { flex: 1; height: 2px; background: #ddd; margin: 0 20px; }
.step-line.done { background: #111; }

.cart-layout { display: grid; grid-template-columns: 1fr 340px; gap: 40px; align-items: start; }
.cart-table { width: 100%; border-collapse: collapse; }
.cart-table th { font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px; color: #aaa; border-bottom: 2px solid #111; padding: 0 0 12px; text-align: left; }
.cart-table td { padding: 20px 0; border-bottom: 1px solid #eee; vertical-align: middle; }
.cart-thumb { width: 80px; height: 80px; background: #e8e8e8; border: 1px solid #ddd; }
.cart-prod-name { font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.cart-prod-meta { font-size: 12px; color: #aaa; }
.cart-remove { font-size: 12px; color: #aaa; cursor: pointer; border-bottom: 1px solid #ddd; }

.coupon-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid #eee; }
.coupon-section h3 { font-size: 16px; margin-bottom: 16px; }
.coupon-row { display: flex; gap: 12px; }
.coupon-field { flex: 1; border: 2px solid #111; padding: 12px 14px; font-size: 14px; }
.coupon-field::placeholder { color: #bbb; }
.coupon-applied { background: #f5f5f5; border-left: 4px solid #111; padding: 12px 16px; margin-top: 12px; font-size: 14px; }
.coupon-tip { font-size: 13px; color: #888; margin-top: 8px; }

.order-summary-box { border: 2px solid #111; padding: 24px; }
.order-summary-box h3 { margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid #eee; }
.sum-row { display: flex; justify-content: space-between; font-size: 15px; margin-bottom: 10px; }
.sum-row.discount { font-weight: 700; }
.sum-row.total { font-size: 20px; font-weight: 800; margin-top: 14px; padding-top: 14px; border-top: 2px solid #111; }
.shipping-tip { font-size: 12px; color: #aaa; margin-bottom: 14px; }
.btn-checkout-main { display: block; width: 100%; text-align: center; background: #111; color: #fff; border: 2px solid #111; padding: 15px; font-size: 15px; font-weight: 700; margin-top: 14px; cursor: pointer; }
.btn-continue-shop { display: block; width: 100%; text-align: center; border: 2px solid #111; background: #fff; color: #111; padding: 11px; font-size: 14px; font-weight: 700; margin-top: 8px; cursor: pointer; }
.secure-note { text-align: center; font-size: 12px; color: #aaa; margin-top: 10px; }

/* ============================================================
   CHECKOUT FORM
   ============================================================ */
.checkout-layout { display: grid; grid-template-columns: 1fr 340px; gap: 40px; align-items: start; }
.checkout-options { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 32px; }
.checkout-opt { border: 2px solid #ddd; padding: 18px; cursor: pointer; }
.checkout-opt.active { border-color: #111; }
.checkout-opt-tag { font-size: 10px; font-weight: 700; background: #111; color: #fff; padding: 2px 8px; letter-spacing: 1px; display: inline-block; margin-bottom: 8px; }
.checkout-opt h4 { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.checkout-opt p  { font-size: 13px; }

.form-section { margin-bottom: 36px; }
.form-section h3 { font-size: 16px; font-weight: 700; padding-bottom: 12px; border-bottom: 2px solid #111; margin-bottom: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-group { margin-bottom: 14px; }
.form-group label { display: block; font-size: 13px; font-weight: 700; margin-bottom: 6px; }
.form-input { width: 100%; border: 2px solid #ddd; padding: 12px 14px; font-size: 14px; }
.form-input:focus { border-color: #111; outline: none; }
.form-input::placeholder { color: #bbb; }
.form-select { width: 100%; border: 2px solid #ddd; padding: 12px 14px; font-size: 14px; background: #fff; }

.payment-opt { display: flex; align-items: center; gap: 14px; border: 2px solid #ddd; padding: 16px; margin-bottom: 8px; cursor: pointer; }
.payment-opt.active { border-color: #111; }
.radio-ring { width: 20px; height: 20px; border: 2px solid #ddd; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.radio-ring.on::after { content: ''; width: 10px; height: 10px; background: #111; border-radius: 50%; display: block; }
.payment-opt.active .radio-ring { border-color: #111; }
.pay-logo { width: 56px; height: 26px; background: #eee; display: flex; align-items: center; justify-content: center; font-size: 10px; color: #aaa; }
.pay-lbl { font-size: 14px; font-weight: 700; }
.pay-desc { font-size: 13px; color: #888; }

.checkout-note textarea { width: 100%; border: 2px solid #ddd; padding: 12px; font-size: 14px; height: 80px; resize: vertical; font-family: inherit; }

.mini-product { display: flex; gap: 12px; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid #eee; }
.mini-product:last-of-type { border-bottom: none; }
.mini-thumb { width: 52px; height: 52px; background: #e8e8e8; flex-shrink: 0; }
.mini-name { font-size: 13px; font-weight: 700; margin-bottom: 2px; }
.mini-qty { font-size: 12px; color: #888; }
.mini-price { font-size: 13px; font-weight: 700; }

.btn-place-order { display: block; width: 100%; text-align: center; background: #111; color: #fff; border: 2px solid #111; padding: 16px; font-size: 15px; font-weight: 700; margin-top: 14px; cursor: pointer; }
.order-tos { font-size: 12px; color: #888; margin-top: 10px; text-align: center; }
.order-tos a { color: #555; text-decoration: underline; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background: #111; color: #fff; padding: 56px 0 0; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 48px; }
.footer-grid p,
.footer-grid span,
.footer-grid a { display: block; font-size: 13px; color: #aaa; text-decoration: none; margin-bottom: 6px; line-height: 1.6; }
.footer-grid h4 { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #fff; margin-bottom: 16px; }
.footer-bottom { border-top: 1px solid #333; padding: 20px 0; display: flex; justify-content: space-between; align-items: center; }
.footer-bottom p { font-size: 12px; color: #666; }
.footer-legal { display: flex; gap: 20px; }
.footer-legal a { font-size: 12px; color: #666; text-decoration: none; }
