/*
Theme Name: Naprawa Okien Koszalin
Theme URI: https://naprawakoszalin.pl
Author: Maciej Czajkowski
Author URI: https://github.com/mebahiahh
Description: Professional, high-performance one-page theme for window & door repair services. Ported from the Joomla tpl_naprawakoszalin template. Dark/light modes, PL/EN, hero slider, services, references, blog, gallery and contact section with Google Maps.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: GNU General Public License v3 or later
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Text Domain: naprawakoszalin
Tags: business, one-page, dark-mode, translation-ready
*/

/* The full design system lives in assets/css/template.css, enqueued via functions.php. */

/* ---- Blog cards (the blog was a separate Joomla module; styled here to match) ---- */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-xl, 2rem);
    margin-top: var(--space-2xl, 3rem);
}
.blog-card {
    background: var(--clr-bg-card);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg, 1rem);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.blog-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
}
.blog-card-link { display: block; color: inherit; text-decoration: none; height: 100%; }
.blog-card-image img { width: 100%; height: 200px; object-fit: cover; display: block; }
.blog-card-body { padding: var(--space-lg, 1.5rem); }
.blog-card-date { font-size: 0.85rem; color: var(--clr-text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.blog-card-title { margin: 0.5rem 0 0.75rem; font-size: 1.25rem; color: var(--clr-text); }
.blog-card-excerpt { color: var(--clr-text-muted); line-height: 1.6; margin-bottom: 1rem; }
.blog-card-more { color: var(--clr-primary); font-weight: 600; }
.blog-pagination { margin-top: var(--space-2xl, 3rem); display: flex; justify-content: center; }
.blog-pagination .page-numbers { padding: 0.5rem 0.9rem; margin: 0 0.2rem; border-radius: var(--radius-sm, 0.5rem); border: 1px solid var(--clr-border); color: var(--clr-text); text-decoration: none; }
.blog-pagination .page-numbers.current { background: var(--clr-primary); color: #fff; border-color: var(--clr-primary); }
.single-content { line-height: 1.8; color: var(--clr-text); }
.single-content h2, .single-content h3 { color: var(--clr-text); margin: 2rem 0 1rem; }
.single-content img { max-width: 100%; height: auto; border-radius: var(--radius-md, 0.75rem); }
.single-content a { color: var(--clr-primary); }

/* ---- Contact Form 7 — match the theme's dark form styling ---- */
.contact-form-wrap .wpcf7-form { display: flex; flex-direction: column; gap: var(--space-lg, 1.5rem); }
.contact-form-wrap .wpcf7-form .form-group { margin: 0; }
.contact-form-wrap .wpcf7-form .wpcf7-form-control-wrap { display: block; }
.contact-form-wrap .wpcf7-form .form-input { width: 100%; box-sizing: border-box; }
.contact-form-wrap .wpcf7-form input[type="submit"],
.contact-form-wrap .wpcf7-form .btn {
    width: 100%;
    justify-content: center;
    cursor: pointer;
    border: none;
}
.wpcf7 .wpcf7-response-output { margin: 1rem 0 0; padding: 0.7rem 1rem; border-radius: var(--radius-sm, 0.5rem); font-size: 0.9rem; }
.wpcf7-not-valid-tip { color: var(--clr-error, #ef4444); font-size: 0.8rem; margin-top: 0.25rem; }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output { border: 1px solid var(--clr-error, #ef4444); color: var(--clr-error, #ef4444); }
.wpcf7 form.sent .wpcf7-response-output { border: 1px solid var(--clr-success, #10b981); color: var(--clr-success, #10b981); }
.wpcf7-spinner { margin: 0 0.5rem; }
