/* === V28 FOOTER — T-Shirt Planet === */

.v28-footer {
    --footer-bg: rgb(37, 32, 32);
    --footer-text: rgba(255, 255, 255, 0.85);
    --footer-muted: rgba(255, 255, 255, 0.5);
    --footer-dim: rgba(255, 255, 255, 0.3);
    --footer-subtle: rgba(255, 255, 255, 0.08);
    --footer-glass: rgba(255, 255, 255, 0.06);
    --v28-lime: #C1E53E;
    --v28-coral: rgb(211, 47, 63);
}

.v28-footer, .v28-footer *, .v28-footer *::before, .v28-footer *::after { box-sizing: border-box; }
.v28-footer p, .v28-footer h4 { margin: 0; padding: 0; }

.v28-footer { background: var(--footer-bg); color: var(--footer-text); padding: 28px 0 20px; font-size: 16px; line-height: 1.6; width: 100%; }
.v28-footer .container { max-width: 1280px; margin: 0 auto; padding: 0 32px; }

.v28-footer .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 36px; }

.v28-footer .footer-brand { display: flex; flex-direction: column; align-items: flex-start; }
.v28-footer .footer-brand .logo { display: block; height: auto; margin-bottom: 8px; line-height: 0; font-size: 0; }
.v28-footer .footer-brand .logo img { height: 36px; width: auto; display: block; }
.v28-footer .footer-brand > p { color: var(--footer-muted) !important; font-size: 14px !important; line-height: 1.65 !important; margin: 0 0 16px 0 !important; padding: 0 !important; max-width: 380px; }

.v28-footer .footer-social { display: flex; gap: 8px; margin-bottom: 16px; }
.v28-footer .footer-social a { display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; background: var(--footer-glass); border-radius: 10px; color: var(--footer-text); text-decoration: none; transition: background 0.2s, color 0.2s; }
.v28-footer .footer-social a:hover { background: rgba(255,255,255,0.12); color: #fff; }
.v28-footer .footer-social a svg { width: 16px; height: 16px; }

.v28-footer .footer-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(230,57,70,0.1); color: var(--v28-coral); border-radius: 8px; padding: 6px 12px; font-size: 12px; font-weight: 600; }

.v28-footer .footer-col h4 { color: var(--v28-lime); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 2.5px; margin: 0 0 14px 0 !important; }
.v28-footer .footer-col a { display: block; color: var(--footer-muted); font-size: 14px; font-weight: 400; text-decoration: none; padding: 4px 0; line-height: 1.5; transition: color 0.2s; }
.v28-footer .footer-col a:hover { color: #fff; }
.v28-footer .footer-col a.text-coral { color: var(--v28-coral); }
.v28-footer .footer-col a.text-coral:hover { color: rgb(240,70,85); }

.v28-footer .footer-bottom { display: flex; justify-content: space-between; align-items: center; border-top: 0.7px solid var(--footer-subtle); padding-top: 36px; margin-top: 0; }
.v28-footer .footer-bottom .footer-copy { color: var(--footer-dim); font-size: 13px; font-weight: 400; }
.v28-footer .footer-bottom .footer-copy .flag-img { width: 15px; height: auto; vertical-align: middle; margin: 0 2px; }

.v28-footer .payment-icons { display: flex; gap: 8px; flex-wrap: wrap; }
.v28-footer .payment-icon { display: inline-flex; align-items: center; background: var(--footer-glass); color: rgba(255,255,255,0.4); border-radius: 6px; padding: 5px 11px; font-size: 12px; font-weight: 500; }

footer.site-footer, .site-footer { display: none !important; }
.wpml-ls-statics-footer { display: none !important; }

@media (max-width: 1024px) {
    .v28-footer .container { padding: 0 24px; }
    .v28-footer .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px 40px; }
    .v28-footer .footer-brand { grid-column: 1 / -1; }
    .v28-footer .footer-brand .logo img { height: 32px; }
    .v28-footer .footer-brand > p { max-width: none; }
}

@media (max-width: 600px) {
.v28-footer { padding: 24px 0 16px; }
.v28-footer .container { padding: 0 16px; }
.v28-footer .footer-grid { grid-template-columns: 1fr !important; gap: 20px !important; padding-bottom: 24px; }
.v28-footer .footer-brand { grid-column: 1 !important; display: flex !important; flex-direction: column !important; align-items: flex-start !important; overflow: hidden; }
/* FIX: collapse logo anchor height on mobile */
.v28-footer .footer-brand .logo { height: auto !important; min-height: 0 !important; line-height: 0 !important; margin-bottom: 4px !important; }
.v28-footer .footer-brand .logo img { height: 28px !important; width: auto !important; display: block !important; }
    .v28-footer .footer-brand > p { line-height: 1.5 !important; margin: 0 0 10px 0 !important; max-width: 100% !important; }
.v28-footer .footer-social { margin-bottom: 10px !important; }
.v28-footer .footer-social a { width: 36px; height: 36px; }
    .v28-footer .footer-badge { padding: 5px 10px; }
.v28-footer .footer-col { padding-top: 4px; }
.v28-footer .footer-col h4 { margin: 0 0 8px 0 !important; }
    .v28-footer .footer-col a { padding: 5px 0; }
.v28-footer .footer-bottom { flex-direction: column; gap: 16px; text-align: center; padding-top: 20px; }
.v28-footer .payment-icons { justify-content: center; }
    .v28-footer .payment-icon { padding: 4px 9px; }
}

@media (max-width: 400px) {
.v28-footer .footer-brand .logo img { height: 24px !important; }
    .v28-footer .payment-icon { padding: 4px 7px; }
}
