/*
Theme Name: Hello Elementor Child
Theme URI: https://gradinavisurilor.ro
Description: Child theme for Hello Elementor – Grădina Visurilor
Author: Grădina Visurilor SRL
Template: hello-elementor
Version: 1.0.0
Text Domain: hello-elementor-child
*/

/* ===== Reset ===== */
* { margin: 0; padding: 0; box-sizing: border-box; }
#site-header { display: none !important; }
#site-footer, footer.site-footer { display: none !important; }
body, body.page, body.home, #site-main, .site-main { background: #0f2b1a !important; font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; }
html, body { overflow-x: hidden !important; max-width: 100vw !important; }

/* ===== Header ===== */
.gv-header { position: sticky; top: 0; z-index: 9999; background: linear-gradient(135deg, #0a1f12 0%, #153d24 50%, #1b4a2e 100%); box-shadow: 0 2px 20px rgba(0,0,0,0.4); border-bottom: 3px solid #2d6a4f; width: 100%; }
.gv-header-inner { max-width: 1300px; margin: 0 auto; padding: 12px 30px; display: flex; align-items: center; justify-content: space-between; }
.gv-brand { display: flex; align-items: center; gap: 15px; }
.gv-brand .custom-logo-link { display: flex; align-items: center; }
.gv-brand .custom-logo { max-height: 55px; width: auto; border-radius: 8px; background: rgba(255,255,255,0.95); padding: 4px; box-shadow: 0 2px 8px rgba(0,0,0,0.2); transition: transform 0.3s ease; }
.gv-brand .custom-logo:hover { transform: scale(1.05); }
.gv-brand-text { display: flex; flex-direction: column; }
.gv-name { color: #fff; font-size: 1.3rem; letter-spacing: 2px; font-weight: 300; }
.gv-name strong { color: #52b788; font-weight: 700; }
.gv-tagline { color: rgba(255,255,255,0.55); font-size: 0.7rem; letter-spacing: 2px; text-transform: uppercase; margin-top: 2px; }

/* ===== Nav ===== */
.gv-nav { display: flex; align-items: center; gap: 25px; }
.gv-nav a { color: rgba(255,255,255,0.8); text-decoration: none; font-size: 0.9rem; letter-spacing: 1px; transition: color 0.3s; }
.gv-nav a:hover { color: #52b788; }
.gv-nav .gv-btn-nav { background: #2d6a4f; color: #fff !important; padding: 10px 22px; border-radius: 50px; font-weight: 600; transition: background 0.3s; }
.gv-nav .gv-btn-nav:hover { background: #40916c; }

/* ===== Linie ===== */
.gv-linie { width: 80px; height: 3px; background: #2d6a4f; margin: 0 auto 35px; }

/* ===== Hero ===== */
.gv-hero { position: relative; min-height: 85vh; display: flex; align-items: center; justify-content: center; text-align: center; background: linear-gradient(135deg, rgba(10,31,18,0.92), rgba(15,43,26,0.82)); padding: 80px 30px; }
.gv-hero-inner { max-width: 800px; }
.gv-hero h1 { font-size: 3.2rem; color: #fff; font-weight: 700; margin-bottom: 25px; line-height: 1.2; }
.gv-hero h1 span { color: #52b788; }
.gv-hero p { font-size: 1.25rem; color: rgba(255,255,255,0.8); line-height: 1.8; margin-bottom: 40px; }
.gv-hero-btns { display: flex; gap: 20px; justify-content: center; flex-wrap: wrap; }
.gv-btn-primary { display: inline-block; background: #2d6a4f; color: #fff; padding: 16px 35px; border-radius: 50px; text-decoration: none; font-weight: 600; font-size: 1rem; transition: all 0.3s; border: 2px solid #2d6a4f; }
.gv-btn-primary:hover { background: #40916c; border-color: #40916c; transform: translateY(-2px); }
.gv-btn-secondary { display: inline-block; color: #fff; padding: 16px 35px; border-radius: 50px; text-decoration: none; font-weight: 600; font-size: 1rem; border: 2px solid rgba(255,255,255,0.4); transition: all 0.3s; }
.gv-btn-secondary:hover { border-color: #52b788; color: #52b788; transform: translateY(-2px); }

/* ===== Servicii ===== */
.gv-servicii { padding: 100px 30px; text-align: center; border-top: 1px solid rgba(255,255,255,0.05); }
.gv-servicii h2 { font-size: 2.4rem; color: #fff; margin-bottom: 20px; }
.gv-servicii-subtitlu { font-size: 1.1rem; color: #a0b8a8; max-width: 700px; margin: 0 auto 60px; }

/* Blocuri servicii cu imagine */
.gv-serviciu-bloc { max-width: 1200px; margin: 0 auto 60px; display: flex; align-items: center; gap: 50px; }
.gv-serviciu-reverse { flex-direction: row-reverse; }
.gv-serviciu-img { flex: 0 0 500px; height: auto; aspect-ratio: 4/3; border-radius: 16px; overflow: hidden; border: 3px solid rgba(82,183,136,0.3); box-shadow: 0 10px 30px rgba(0,0,0,0.3); }
.gv-serviciu-img img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; display: block; }
.gv-serviciu-text { flex: 1; text-align: left; }
.gv-serviciu-label { display: inline-block; color: #52b788; font-size: 0.8rem; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 15px; background: rgba(82,183,136,0.1); padding: 5px 15px; border-radius: 20px; }
.gv-serviciu-text h3 { font-size: 1.8rem; color: #fff; font-weight: 600; margin-bottom: 20px; line-height: 1.3; }
.gv-serviciu-text p { font-size: 1.05rem; color: #a0b8a8; line-height: 1.9; margin-bottom: 15px; }

/* Carduri servicii */
.gv-servicii-grid { max-width: 1200px; margin: 60px auto 0; display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; }
.gv-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 35px 25px; text-align: left; transition: transform 0.3s ease, border-color 0.3s ease; }
.gv-card:hover { transform: translateY(-5px); border-color: rgba(82,183,136,0.4); }
.gv-card-icon { font-size: 2.5rem; display: block; margin-bottom: 18px; }
.gv-card h4 { font-size: 1.2rem; color: #fff; margin-bottom: 12px; }
.gv-card p { font-size: 0.95rem; color: #a0b8a8; line-height: 1.7; }
.gv-nota { max-width: 1200px; margin: 40px auto 0; text-align: center; color: #a0b8a8; font-size: 0.95rem; font-style: italic; }

/* ===== Despre Noi ===== */
.gv-despre { padding: 100px 30px; border-top: 1px solid rgba(255,255,255,0.05); background: rgba(0,0,0,0.15); }
.gv-despre-inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; gap: 60px; }
.gv-despre-text { flex: 1; }
.gv-despre-text h2 { font-size: 2.4rem; color: #fff; margin-bottom: 20px; }
.gv-despre-text p { font-size: 1.05rem; color: #a0b8a8; line-height: 1.9; margin-bottom: 18px; }
.gv-cifre { display: flex; gap: 40px; margin-top: 40px; flex-wrap: wrap; }
.gv-cifra { text-align: center; }
.gv-cifra strong { display: block; font-size: 2.5rem; color: #52b788; font-weight: 700; }
.gv-cifra span { font-size: 0.85rem; color: #a0b8a8; text-transform: uppercase; letter-spacing: 1px; }
.gv-despre-img { flex: 0 0 420px; height: auto; aspect-ratio: 3/4; border-radius: 16px; overflow: hidden; border: 3px solid rgba(82,183,136,0.3); box-shadow: 0 10px 30px rgba(0,0,0,0.3); }
.gv-despre-img img { width: 100%; height: 100%; object-fit: cover; object-position: center 40%; }

/* ===== De Ce Noi ===== */
.gv-dece { padding: 100px 30px; text-align: center; border-top: 1px solid rgba(255,255,255,0.05); }
.gv-dece h2 { font-size: 2.4rem; color: #fff; margin-bottom: 20px; }
.gv-dece-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(4,1fr); gap: 30px; }
.gv-dece-item { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 35px 25px; transition: transform 0.3s ease, border-color 0.3s ease; }
.gv-dece-item:hover { transform: translateY(-3px); border-color: rgba(82,183,136,0.4); }
.gv-dece-icon { font-size: 2.5rem; display: block; margin-bottom: 15px; }
.gv-dece-item h4 { font-size: 1.1rem; color: #fff; margin-bottom: 12px; }
.gv-dece-item p { font-size: 0.9rem; color: #a0b8a8; line-height: 1.7; }

/* ===== Contact ===== */
.gv-contact { padding: 100px 30px; border-top: 1px solid rgba(255,255,255,0.05); background: rgba(0,0,0,0.15); }
.gv-contact h2 { font-size: 2.4rem; color: #fff; margin-bottom: 20px; text-align: center; }
.gv-contact-inner { max-width: 1200px; margin: 0 auto; display: flex; gap: 60px; margin-top: 50px; }
.gv-contact-info { flex: 1; }
.gv-contact-info h3 { font-size: 1.5rem; color: #fff; margin-bottom: 25px; }
.gv-contact-item { display: flex; align-items: flex-start; gap: 15px; margin-bottom: 25px; }
.gv-contact-item-icon { font-size: 1.5rem; flex-shrink: 0; }
.gv-contact-item-text h4 { color: #fff; font-size: 1rem; margin-bottom: 5px; }
.gv-contact-item-text p { color: #a0b8a8; font-size: 0.95rem; line-height: 1.6; }
.gv-contact-item-text a { color: #52b788; text-decoration: none; font-weight: 600; }
.gv-contact-item-text a:hover { color: #40916c; }
.gv-contact-form { flex: 1; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 40px; }
.gv-contact-form h3 { font-size: 1.3rem; color: #fff; margin-bottom: 25px; }
.gv-contact-form input[type="text"], .gv-contact-form input[type="email"], .gv-contact-form input[type="tel"], .gv-contact-form textarea,
.gv-contact-form .wpcf7 input[type="text"], .gv-contact-form .wpcf7 input[type="email"], .gv-contact-form .wpcf7 input[type="tel"], .gv-contact-form .wpcf7 textarea {
    width: 100%; padding: 14px 18px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: 10px; color: #fff; font-size: 0.95rem; margin-bottom: 15px; outline: none; transition: border-color 0.3s;
}
.gv-contact-form input:focus, .gv-contact-form textarea:focus { border-color: #52b788; }
.gv-contact-form input[type="submit"], .gv-contact-form .wpcf7 input[type="submit"], .gv-contact-form button {
    background: #2d6a4f; color: #fff; border: none; padding: 16px 40px; border-radius: 50px; font-size: 1rem; font-weight: 600; cursor: pointer; transition: background 0.3s; width: 100%;
}
.gv-contact-form input[type="submit"]:hover, .gv-contact-form button:hover { background: #40916c; }

/* ===== Bandă Finanțare ===== */
.gv-finantare { background: #0a1f12; padding: 20px 30px; text-align: center; border-top: 1px solid rgba(82,183,136,0.2); border-bottom: 1px solid rgba(82,183,136,0.2); }
.gv-finantare-inner { max-width: 1200px; margin: 0 auto; }
.gv-finantare p { color: #a0b8a8; font-size: 0.8rem; line-height: 1.6; }
.gv-finantare strong { color: #52b788; }

/* ===== Footer ===== */
.gv-footer { background: #071a0e; border-top: 3px solid #2d6a4f; padding: 60px 30px 0; }
.gv-footer-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; padding-bottom: 50px; border-bottom: 1px solid rgba(255,255,255,0.08); }
.gv-footer-brand p { color: #fff; font-size: 1.1rem; font-weight: 600; margin-bottom: 8px; }
.gv-footer-brand span { color: #a0b8a8; font-size: 0.9rem; line-height: 1.7; display: block; margin-bottom: 5px; }
.gv-footer-links h4, .gv-footer-social h4 { color: #fff; font-size: 1rem; margin-bottom: 20px; letter-spacing: 1px; text-transform: uppercase; }
.gv-footer-links a { display: block; color: #a0b8a8; text-decoration: none; font-size: 0.95rem; margin-bottom: 10px; transition: color 0.3s; }
.gv-footer-links a:hover { color: #52b788; }
.gv-social-links { display: flex; flex-direction: column; gap: 10px; }
.gv-social-links a { color: #a0b8a8; text-decoration: none; font-size: 0.95rem; transition: color 0.3s; }
.gv-social-links a:hover { color: #52b788; }
.gv-footer-bottom { padding: 25px 0; text-align: center; }
.gv-footer-bottom p { color: rgba(255,255,255,0.3); font-size: 0.85rem; letter-spacing: 0.5px; }

/* ===== Page Content (legal pages) ===== */
.gv-page-content { padding: 100px 30px 80px; }
.gv-page-inner { max-width: 900px; margin: 0 auto; }
.gv-page-inner h1 { font-size: 2.4rem; color: #fff; margin-bottom: 20px; }
.gv-page-inner h2 { font-size: 1.6rem; color: #52b788; margin: 40px 0 15px; }
.gv-page-inner h3 { font-size: 1.3rem; color: #fff; margin: 30px 0 12px; }
.gv-page-inner p { font-size: 1rem; color: #a0b8a8; line-height: 1.9; margin-bottom: 15px; }
.gv-page-inner ul, .gv-page-inner ol { color: #a0b8a8; margin: 15px 0 15px 25px; line-height: 1.9; }
.gv-page-inner li { margin-bottom: 8px; }
.gv-page-inner a { color: #52b788; text-decoration: underline; }
.gv-page-inner a:hover { color: #40916c; }
.gv-page-inner strong { color: #e0e8e2; }

/* ===== RESPONSIVE TABLET ===== */
@media (max-width: 1024px) {
    .gv-nav { display: none; }
    .gv-dece-grid { grid-template-columns: repeat(2,1fr); }
    .gv-serviciu-img { flex: 0 0 350px; height: auto; aspect-ratio: 4/3; }
    .gv-footer-inner { display: flex; flex-wrap: wrap; gap: 30px; }
    .gv-footer-inner > div { flex: 1 1 45%; }
    .gv-servicii-grid { display: flex; flex-wrap: wrap; gap: 30px; }
    .gv-servicii-grid > div { flex: 1 1 45%; }
}

/* ===== RESPONSIVE MOBIL ===== */
@media (max-width: 768px) {
    .gv-header-inner { flex-direction: column; gap: 10px; padding: 12px 20px; }
    .gv-brand { flex-direction: column; text-align: center; }
    .gv-brand-text { align-items: center; }
    .gv-nav { display: none; }
    .gv-hero { min-height: 70vh; padding: 60px 20px; }
    .gv-hero h1 { font-size: 2rem; }
    .gv-hero p { font-size: 1rem; }
    .gv-hero-btns { flex-direction: column; align-items: center; }
    .gv-serviciu-bloc, .gv-serviciu-reverse { flex-direction: column !important; gap: 25px; }
    .gv-serviciu-img { flex: 0 0 auto !important; width: 100% !important; height: auto; aspect-ratio: 16/9; }
    .gv-despre-inner { flex-direction: column; gap: 30px; }
    .gv-despre-img { flex: 0 0 auto; width: 100%; height: auto; aspect-ratio: 4/3; }
    .gv-cifre { justify-content: center; }
    .gv-contact-inner { flex-direction: column; gap: 30px; }
    .gv-servicii-grid, .gv-dece-grid { display: flex !important; flex-direction: column !important; gap: 20px !important; }
    .gv-servicii-grid > div, .gv-dece-grid > div { flex: 1 1 100% !important; width: 100% !important; }
    .gv-servicii h2, .gv-despre-text h2, .gv-dece h2, .gv-contact h2 { font-size: 1.8rem; }
    .gv-footer-inner { display: flex !important; flex-direction: column !important; text-align: center; gap: 30px; }
    .gv-footer-inner > div { flex: 1 1 100% !important; width: 100% !important; }
    .gv-social-links { align-items: center; }
    .gv-contact-form { padding: 25px; }
}