/* Final Version */
/* --- GLOBAL SETUP & TYPOGRAPHY --- */
:root {
    --theme-color: #333333;
    --text-dark: #2c2c2c;
    --text-light: #6b6b6b;
    --line-color: #e0e0e0;
    --bg-color: #f4f4f4;
    --green-color: #4CAF50;
    --blue-color: #2196F3;
    --preview-width: 800px;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: 'Lato', sans-serif;
    background-color: #fff;
    margin: 0;
    color: var(--text-light);
    line-height: 1.6;
}

body.cv-generator {
    background-color: var(--bg-color);
}

/* --- AD BANNERS & SITE HEADER --- */
.top-ad-container, .bottom-ad-container{ 
    display: flex; 
    justify-content: center; 
    padding: 20px 0; 
    background-color: #fff; 
    border-bottom: 1px solid var(--line-color); 
}
.bottom-ad-container { 
    border-top: 1px solid var(--line-color); 
    border-bottom: none; 
    margin-top: 30px; 
}
.ad-banner-top, .ad-banner-bottom { 
    width: 970px; 
    height: 250px; 
    background-color: #e0e0e0; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    color: var(--text-light); 
    font-weight: 700; 
}
.ad-container { 
    display: flex; 
    justify-content: center; 
    padding: 20px 0; 
    background-color: #fff; 
    border-bottom: 1px solid var(--line-color); 
    margin-bottom: 25px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}
.ad-banner { 
    width: 300px; 
    height: 250px; 
    background-color: #e0e0e0; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    color: var(--text-light); 
    font-weight: 700; 
}


/* --- HEADER --- */
.site-header {
    background: #fff;
    padding: 10px 30px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    position: sticky;
    top: 0;
    z-index: 100;
}

.progress-bar {
    position: absolute;
    top: 0;
    left: 0;
    height: 4px;
    background-color: var(--green-color);
    width: 0;
    transition: width 0.1s ease-out;
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
}

.site-logo-link {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
}

.logo-icon {
    display: flex;
    align-items: center;
}

.site-logo-link .site-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--theme-color);
    margin: 0;
}

.controls-bar {
    display: flex;
    align-items: center;
    gap: 10px;
}

#language-select {
    padding: 8px 12px;
    border: 1px solid var(--line-color);
    border-radius: 4px;
    font-family: 'Lato', sans-serif;
    font-size: 14px;
}


/* --- HERO SECTION --- */
.hero-section {
    background-color: var(--bg-color);
    padding: 80px 30px;
    text-align: center;
}

.hero-content {
    max-width: 800px;
    margin: 0 auto;
}

.hero-content h1 {
    font-size: xx-large;
    ont-weight: 900;
    color: #000;
}

.hero-content h2 {
    font-size: 3rem;
    font-weight: 900;
    color: var(--text-dark);
    margin-bottom: 20px;
}

.hero-content p {
    font-size: 1.2rem;
    margin-bottom: 30px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.cta-button {
    display: inline-block;
    padding: 15px 35px;
    border: none;
    border-radius: 4px;
    color: #fff;
    background-color: var(--green-color);
    font-weight: 700;
    font-size: 1.1rem;
    cursor: pointer;
    text-decoration: none;
    transition: background-color 0.2s;
}

.cta-button:hover {
    background-color: #45a049;
}

.cta-button.secondary {
    background-color: var(--blue-color);
}
.cta-button.secondary:hover {
    background-color: #1e88e5;
}


/* --- FEATURES SECTION --- */
.features-section {
    display: flex;
    justify-content: center;
    gap: 40px;
    padding: 60px 30px;
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
}

.feature {
    flex: 1;
    max-width: 300px;
}

.feature .material-symbols-outlined {
    font-size: 48px;
    color: var(--theme-color);
    background-color: var(--bg-color);
    padding: 20px;
    border-radius: 50%;
    margin-bottom: 20px;
}

.feature h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-dark);
    margin-bottom: 10px;
}

/* --- RESUME EXAMPLE SECTION --- */
.resume-example-section {
    background-color: var(--bg-color);
    padding: 80px 30px;
    text-align: center;
}

.section-title {
    font-size: 2.5rem;
    font-weight: 900;
    color: var(--text-dark);
    margin-bottom: 40px;
}

.resume-image-container {
    max-width: var(--preview-width);
    margin: 0 auto 40px auto;
}

.resume-image-container img {
    max-width: 100%;
    display: block;
}


/* --- CONTENT SECTION (ACCORDION) --- */
.content-section {
    max-width: 900px;
    margin: 60px auto;
    padding: 0 30px;
}

.accordion-item {
    background-color: #fff;
    border: 1px solid var(--line-color);
    border-radius: 8px;
    margin-bottom: 15px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    overflow: hidden;
}

.accordion-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    cursor: pointer;
    background-color: #f9f9f9;
    border-bottom: 1px solid var(--line-color);
    transition: background-color 0.3s ease;
}

.accordion-item[open] .accordion-header {
    background-color: var(--bg-color);
    border-bottom: none;
}

.accordion-header h3 {
    margin: 0;
    font-size: 1.2rem;
    color: var(--text-dark);
}

.accordion-icon {
    transition: transform 0.3s ease;
}

.accordion-item[open] .accordion-icon {
    transform: rotate(180deg);
}

.accordion-content {
    padding: 20px 20px 20px 20px;
    color: var(--text-light);
    line-height: 1.6;
}

.content-section .cta-button {
    margin: 50px auto 20px;
    display: table;
}

/* --- DISCLAIMER SECTION --- */
.disclaimer-section {
    padding: 60px 30px;
    text-align: center;
    background: var(--bg-color);
}

.disclaimer-content {
    max-width: 600px;
    margin: 0 auto;
    padding: 30px;
    border: 1px solid var(--line-color);
    border-radius: 8px;
    background-color: #fafafa;
}

.disclaimer-content .material-symbols-outlined {
    font-size: 36px;
    color: var(--blue-color);
    margin-bottom: 15px;
}

.disclaimer-content h3 {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--text-dark);
    margin-bottom: 10px;
}

.disclaimer-content p {
    font-size: 1rem;
    color: var(--text-light);
}

/* --- RESPONSIVE DESIGN LANDING PAGE--- */
@media (max-width: 768px) {
    .hero-content h2 {
        font-size: 2.5rem;
    }
    .features-section {
        flex-direction: column;
        align-items: center;
        gap: 50px;
    }
    .ad-banner-top, .ad-banner-bottom { 
        width: 300px; 
        height: 250px; 
    } 
}


/* --- PAGE GENEARTOR & FORM LAYOUT --- */
.page-container { 
    display: grid; 
    grid-template-columns: 400px 1fr; 
    gap: 30px; 
    padding: 30px; 
    max-width: 1300px; 
    margin: auto; 
    background-color:  var(--bg-color);
}
.form-container { 
    background: none; 
    box-shadow: none; 
    padding: 0; 
}
.preview-container { 
    position: sticky; 
    top: 90px; 
    align-self: flex-start;
}
.form-section-card { 
    background: #fff; 
    border-radius: 8px; 
    padding: 20px; 
    box-shadow: 0 2px 8px rgba(0,0,0,0.08); 
    margin-bottom: 25px; 
}
.form-section-title { 
    font-weight: 700; 
    color: var(--theme-color); 
    margin-top: 0; 
    margin-bottom: 20px; 
    padding-bottom: 10px; 
    border-bottom: 1px solid var(--line-color); 
    font-size: 1.1rem; 
}
#resume-form input, #resume-form textarea, #resume-form select { 
    width: 100%; 
    padding: 12px; 
    box-sizing: border-box; 
    border: 1px solid var(--line-color); 
    border-radius: 4px; 
    margin-bottom: 10px; 
    font-family: 'Lato', sans-serif; 
    font-size: 16px;
}
#resume-form textarea { 
    resize: vertical; 
    min-height: 80px; 
    margin-bottom: 5px;
}
.char-counter {
    text-align: right;
    font-size: 0.8rem;
    color: #999;
    margin-bottom: 10px;
}
button { 
    width: 100%; 
    padding: 12px; 
    border: none; 
    border-radius: 4px; 
    color: #fff; 
    background-color: var(--theme-color); 
    font-weight: 700; 
    font-size: 1rem; 
    cursor: pointer; 
    transition: background-color 0.2s, opacity 0.2s; 
    min-height: 44px;
}
button:hover { 
    background-color: #555; 
}
button:disabled {
    background-color: #999;
    cursor: not-allowed;
    opacity: 0.7;
}
button:disabled:hover {
    background-color: #999;
}
#download-pdf-btn { 
    background-color: var(--green-color); 
}
#download-pdf-btn:hover { 
    background-color: #45a049; 
}
.dynamic-entry { 
    padding: 15px; 
    border: 1px solid #f0f0f0; 
    border-radius: 4px; 
    margin-bottom: 10px; 
}
.dynamic-entry.skill-entry {
    display: flex;
    gap: 10px;
    flex-direction: row;
    align-items: baseline;
}
.dynamic-entry.skill-entry input { 
    margin-bottom: 0; 
    flex: 1;
}
.dynamic-entry.language-entry { 
    display: grid; 
    grid-template-columns: 1fr 1fr auto; 
    gap: 10px; 
    align-items: baseline; 
}
.dynamic-entry.language-entry input, .dynamic-entry.language-entry select { 
    margin-bottom: 0; 
}
.dynamic-entry button.remove-btn { 
    background-color: #d32f2f; 
    font-size: 0.8rem; 
    padding: 8px 12px; 
    width: auto; 
    min-height: 36px;
}
.dynamic-entry button.remove-btn:hover {
    background-color: #b71c1c;
}

/* --- SECTION HEADER & TOGGLE SWITCH --- */
.form-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--line-color);
    padding-bottom: 10px;
    margin-bottom: 20px;
}
.form-section-header .form-section-title {
    border: none;
    padding: 0;
    margin: 0;
}
.toggle-switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 28px;
}
.toggle-switch .section-toggle-checkbox {
    opacity: 0;
    width: 0;
    height: 0;
}
.toggle-label {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #ccc;
    transition: .4s;
    border-radius: 28px;
}
.toggle-label:before {
    position: absolute;
    content: "";
    height: 20px;
    width: 20px;
    left: 4px;
    bottom: 4px;
    background-color: white;
    transition: .4s;
    border-radius: 50%;
}
/* MODIFIED: Changed color to green */
.section-toggle-checkbox:checked + .toggle-label {
    background-color: var(--green-color);
}
.section-toggle-checkbox:checked + .toggle-label:before {
    transform: translateX(22px);
}


/* --- RESUME PREVIEW STYLING --- */
#resume-preview { 
    background: #fff; 
    box-shadow: 0 4px 15px rgba(0,0,0,0.15); 
    padding: 40px 50px; 
}
.resume-header-new { 
    display: flex; 
    justify-content: space-between; 
    align-items: flex-end; 
    padding-bottom: 15px; 
    border-bottom: 2px solid var(--text-dark); 
    gap: 20px;
}
.name-section h1 { 
    font-size: 2.4rem; 
    font-weight: 300; 
    letter-spacing: 2px; 
    margin: 0; 
    color: var(--text-light); 
}
.name-section h2 { 
    font-size: 2.4rem; 
    font-weight: 900; 
    letter-spacing: 2px; 
    margin: -10px 0 0 0; 
    color: var(--text-dark); 
}
.contact-info { 
    text-align: right; 
    flex-shrink: 0;
}
.contact-info p { 
    margin: 0 0 5px 0; 
    font-size: 0.9rem; 
    display: flex; 
    justify-content: flex-end; 
    align-items: center; 
    gap: 8px; 
}
.contact-info .material-symbols-outlined { 
    color: var(--theme-color); 
}
.resume-body-new { 
    margin-top: 30px; 
}
.timeline { 
    position: relative; 
    padding-left: 50px; 
}
.timeline::before { 
    content: ''; 
    position: absolute; 
    left: 14px; 
    top: 5px; 
    bottom: 5px; 
    width: 2px; 
    background-color: var(--line-color); 
}
.section-new { 
    position: relative; 
    margin-bottom: 25px; 
}
.section-icon { 
    position: absolute; 
    left: -50px; 
    top: 0; 
    width: 30px; 
    height: 30px; 
    background-color: var(--theme-color); 
    border-radius: 50%; 
    display: flex; 
    justify-content: center; 
    align-items: center; 
    color: #fff; 
}
.section-content h3 { 
    font-size: 1.1rem; 
    font-weight: 900; 
    text-transform: uppercase; 
    letter-spacing: 1px; 
    color: var(--text-dark); 
    margin: 5px 0 10px 0; 
}
.section-content p { 
    line-height: 1.5; 
    margin: 0 0 10px 0; 
}
.entry-new { 
    margin-bottom: 20px;
    flex: 1 1 30%;
    display: grid;
}
.entry-new h4 { 
    font-size: 1rem; 
    font-weight: 700; 
    color: var(--text-dark); 
    margin: 0; 
}
.entry-new .date { 
    font-size: 0.8rem; 
    font-weight: 700; 
    color: var(--text-light); 
    text-transform: uppercase; 
    margin: 2px 0 5px 0; 
}
#resume-education-entries,
#resume-experience-entries { 
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}
#resume-skills-list { 
    list-style: none; 
    padding: 0; 
    margin: 0; 
    column-count: 3; 
}
#resume-skills-list li { 
    padding-left: 20px; 
    position: relative; 
    margin-bottom: 5px; 
}
#resume-skills-list li::before { 
    content: '•'; 
    position: absolute; 
    left: 0; 
    color: var(--theme-color); 
    font-weight: 900; 
    font-size: 1.2rem; 
}
#resume-language-entries {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}
#resume-language-entries .entry-new.language-entry {
    flex: 1 1 30%;
    display: grid;
}
#resume-language-entries .entry-new.language-entry span:first-child { 
    font-weight: 700; 
    color: var(--text-dark); 
}
#resume-reference-entries { 
    display: flex; 
    flex-wrap: wrap; 
    gap: 15px; 
}
.entry-new.reference-entry { 
    flex: 1 1 30%;
}

/* --- RESPONSIVE DESIGN GENERADOR--- */
@media (max-width: 992px) { 
    .ad-banner-top, .ad-banner-bottom { 
        width: 728px; 
        height: 90px; 
    }
    .page-container {
        grid-template-columns: 400px 1fr;
    }
}

@media (max-width: 768px) { 
    .page-container { 
        grid-template-columns: 1fr; 
        padding: 15px;
    } 
    .preview-container {
        display: none;
    }
    .ad-banner-top, .ad-banner-bottom { 
        width: 300px; 
        height: 250px; 
    } 
    .header-content { 
        flex-direction: row; 
        gap: 10px; 
    }
    .form-section-card {
        padding: 15px;
    }
    .dynamic-entry.language-entry {
        grid-template-columns: 1fr;
    }
    .dynamic-entry.skill-entry {
        flex-direction: column;
    }
    .dynamic-entry.skill-entry input {
        margin-bottom: 10px;
    }
}

/* --- PDF & PRINT STYLES --- */
.pdf-generation-mode .preview-container {
    display: block !important;
    position: absolute !important;
    top: 0;
    left: 0;
    z-index: -1;
    opacity: 0;
}
.pdf-generation-mode #resume-preview {
    width: var(--preview-width) !important;
    box-shadow: none !important;
    margin: 0 !important;
}

/* --- FOOTER --- */
.site-footer {
    background-color: var(--theme-color);
    color: #fff;
    text-align: center;
    padding: 20px 30px;
    margin-top: 0;
}