:root {
    --primary: #4361ee;
    --primary-dark: #3a56d4;
    --secondary: #6c63ff;
    --success: #4cc9f0;
    --danger: #e63946;
    --warning: #fca311;
    --info: #4361ee;
    --light: #f8f9fa;
    --dark: #212529;
    --gray: #6c757d;
    --gray-light: #ced4da;
    --background: #f5f7fb;
    --card-bg: #ffffff;
    --text-primary: #2d3436;
    --text-secondary: #636e72;
    --border-radius: 10px;
    --shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
    --transition: all 0.3s ease;
    --header-height: 70px;
    --cv-margin-top: 20mm;
    --cv-margin-right: 20mm;
    --cv-margin-bottom: 20mm;
    --cv-margin-left: 20mm;
}

* { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Poppins', sans-serif; }
body { background-color: var(--background); color: var(--text-primary); line-height: 1.6; min-height: 100vh; display: flex; flex-direction: column; }
body.printing .form-column, body.printing .preview-column { overflow-y: hidden !important; }

.app-container { display: flex; flex-direction: column; min-height: 100vh; padding-top: var(--header-height); }
.container { max-width: 1400px; margin: 0 auto; padding: 20px; flex: 1; width: 100%; }
.two-columns { display: flex; gap: 25px; align-items: flex-start; }
.form-column { flex: 1 1 550px; max-width: 650px; min-width: 450px; max-height: calc(100vh - var(--header-height) - 40px); overflow-y: auto; padding-right: 15px; }
.preview-column { flex: 2 1 0; max-height: calc(100vh - var(--header-height) - 40px); overflow-y: auto; padding: 0 10px 20px 0; }

header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background-color: var(--card-bg);
    height: var(--header-height);
    box-shadow: none;
    border-bottom: 1px solid #e0e0e0;
}

.header-content {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 100%;
}

.menu-toggle {
    display: none;
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--text-primary);
    cursor: pointer;
    z-index: 1001;
}

.logo { display: flex; align-items: center; gap: 15px; min-width: 0; }
.logo i { font-size: 2.5rem; color: var(--primary); }
.logo h1 { font-weight: 700; font-size: 1.8rem; background: linear-gradient(45deg, var(--primary), var(--secondary)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.controls { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.btn { padding: 10px 15px; border-radius: var(--border-radius); border: none; cursor: pointer; font-weight: 600; transition: var(--transition); display: flex; align-items: center; gap: 6px; font-size: 0.85rem; white-space: nowrap; }
.btn-primary { background-color: var(--primary); color: white; }
.btn-primary:hover { background-color: var(--primary-dark); }
.btn-success { background-color: var(--success); color: white; }
.btn-success:hover { opacity: 0.9; }
.btn-outline { background-color: transparent; border: 2px solid var(--primary); color: var(--primary); }
.btn-outline:hover { background-color: var(--primary); color: white; }
.btn-info { background-color: var(--info); color: white; }
.btn-info:hover { opacity: 0.9; }

.card { background-color: var(--card-bg); border-radius: var(--border-radius); box-shadow: var(--shadow); padding: 20px; margin-bottom: 20px; transition: var(--transition); overflow: hidden; }
.card:hover { box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12); }
.card-title { font-size: 1.3rem; margin-bottom: 15px; color: var(--primary); display: flex; align-items: center; gap: 8px; border-bottom: 1px solid var(--gray-light); padding-bottom: 8px; overflow: hidden; }

.form-row { display: flex; gap: 15px; margin-bottom: 12px; flex-wrap: wrap; }
.form-control { flex: 1; display: flex; flex-direction: column; min-width: 0; }
label { margin-bottom: 6px; font-weight: 600; color: var(--text-secondary); font-size: 0.85rem; }
input, select, textarea { padding: 10px 12px; border: 1px solid var(--gray-light); border-radius: 6px; font-size: 0.9rem; transition: var(--transition); background-color: var(--light); width: 100%; box-sizing: border-box; }
input:focus, select, textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.2); }

.items-table { width: 100%; border-collapse: collapse; margin: 15px 0; box-shadow: 0 0 10px rgba(0, 0, 0, 0.05); border-radius: var(--border-radius); overflow: hidden; table-layout: fixed; }
.items-table th, .items-table td { padding: 12px; text-align: left; border-bottom: 1px solid var(--gray-light); word-wrap: break-word; }
.items-table th { background-color: #f8f9fa; font-weight: 600; color: var(--text-secondary); font-size: 0.9rem; }
.action-btn { background: none; border: none; cursor: pointer; color: var(--gray); transition: var(--transition); padding: 5px; }
.action-btn:hover { color: var(--primary); }

.empty-state { text-align: center; padding: 30px 0; color: var(--text-secondary); }
.empty-state i { font-size: 2.5rem; margin-bottom: 10px; color: var(--gray-light); }

.template-selection { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 20px; }
.template-item { border: 2px solid var(--gray-light); border-radius: var(--border-radius); cursor: pointer; transition: all 0.2s ease-in-out; background-color: #fff; overflow: hidden; }
.template-item:hover { transform: translateY(-4px); box-shadow: 0 6px 12px rgba(0, 0, 0, 0.1); border-color: var(--primary); }
.template-item.selected { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.3); }
.template-name { font-size: 0.85rem; font-weight: 500; color: var(--text-secondary); text-align: center; padding: 12px 10px; margin: 0; background-color: #f8f9fa; border-top: 1px solid #e9ecef; }
.template-card-preview { height: 100px; background-color: #fdfdfd; padding: 10px; box-sizing: border-box; }
.template-card-preview .preview-header-bar { height: 8px; width: 50%; margin-bottom: 12px; border-radius: 4px; }
.template-card-preview .preview-line { height: 6px; width: 100%; margin-bottom: 8px; background-color: #e0e0e0; border-radius: 3px; }
.template-card-preview .preview-line.short { width: 60%; }
.template-card-preview .preview-sidebar { width: 30%; height: 100%; }
.template-card-preview .preview-main-content { width: 70%; padding: 10px; }

.preview-container { background-color: white; border-radius: var(--border-radius); box-shadow: var(--shadow); padding: 20px; display: none; overflow: hidden; }
#cvPreview { font-family: var(--cv-font-family, 'Poppins', sans-serif); overflow-wrap: break-word; word-wrap: break-word; hyphens: auto; background-color: #ffffff; margin: 0 auto; box-shadow: 0 0 14px rgba(0,0,0,0.08); transition: all 0.25s ease; overflow: hidden; box-sizing: border-box; }
#cvPreview.a4 { width: 210mm; min-height: 297mm; }
#cvPreview.a3 { width: 297mm; min-height: 420mm; }
#cvPreview.with-margins { padding: var(--cv-margin-top, 20mm) var(--cv-margin-right, 20mm) var(--cv-margin-bottom, 20mm) var(--cv-margin-left, 20mm); }
.preview-header h1 { font-size: 1.8rem; color: var(--primary); margin-bottom: 5px; word-wrap: break-word; }
.preview-header h3 { font-size: 1.1rem; margin-bottom: 10px; color: var(--text-secondary); }
.preview-header .contact-info { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px 20px; margin-top: 10px; font-size: 0.9rem; }
.preview-header .contact-info div { display: flex; align-items: center; gap: 5px; }
.preview-section { margin-bottom: 20px; }
.preview-section h2 { font-size: 1.2rem; color: var(--primary); border-bottom: 2px solid var(--primary); padding-bottom: 6px; margin-bottom: 12px; }
.experience-item, .education-item { margin-bottom: 12px; }
.experience-item h3, .education-item h3 { font-size: 1rem; margin-bottom: 4px; }
.experience-date, .education-date { color: var(--text-secondary); font-style: italic; margin-bottom: 5px; font-size: 0.9rem; }
#cvPreview ul { padding-left: 20px; }
#cvPreview li { margin-bottom: 5px; }

footer { text-align: center; margin-top: 30px; padding: 15px; color: var(--text-secondary); background-color: var(--light); font-size: 0.9rem; }
.toast { position: fixed; bottom: 20px; right: 20px; background-color: var(--success); color: white; padding: 12px 20px; border-radius: var(--border-radius); box-shadow: var(--shadow); display: flex; align-items: center; gap: 8px; transform: translateY(100px); opacity: 0; transition: var(--transition); z-index: 1000; max-width: calc(100% - 40px); }
.toast.show { transform: translateY(0); opacity: 1; }
.toast.error { background-color: var(--danger); }
.modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.5); display: flex; align-items: center; justify-content: center; z-index: 1000; opacity: 0; visibility: hidden; transition: var(--transition); }
.modal-overlay.active { opacity: 1; visibility: visible; }
.modal { background-color: var(--card-bg); border-radius: var(--border-radius); box-shadow: var(--shadow); width: 90%; max-width: 500px; max-height: 90vh; overflow-y: auto; transform: translateY(-50px); transition: var(--transition); }
.modal-overlay.active .modal { transform: translateY(0); }
.modal-header { padding: 15px; border-bottom: 1px solid var(--gray-light); display: flex; justify-content: space-between; align-items: center; }
.modal-header h2 { color: var(--primary); font-size: 1.3rem; }
.modal-close { background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--gray); }
.modal-body { padding: 15px; }
.modal-footer { padding: 15px; border-top: 1px solid var(--gray-light); display: flex; justify-content: flex-end; gap: 10px; }

#cvPreview:not(.template-colorido):not(.template-tokyo) .preview-header { display: flex; flex-direction: column; }
.preview-header { text-align: center; margin-bottom: 20px; }
.photo-layout-lateral { flex-direction: row !important; align-items: center; gap: 20px; }
.photo-layout-lateral .photo-wrapper { flex: 0 0 120px; margin: 0; }
.photo-layout-lateral .header-text-content { flex: 1; text-align: left; }
.photo-align-esquerda .photo-wrapper { align-self: flex-start; }
.photo-align-centro .photo-wrapper { align-self: center; }
.photo-align-direita .photo-wrapper { align-self: flex-end; }
.photo-layout-lateral.photo-align-esquerda .header-text-content { text-align: left; }
.photo-layout-lateral.photo-align-centro .header-text-content { text-align: center; }
.photo-layout-lateral.photo-align-direita { flex-direction: row-reverse !important; }
.photo-layout-lateral.photo-align-direita .header-text-content { text-align: right; }
.photo-shape-circulo .photo-wrapper img { border-radius: 50%; }
.photo-shape-quadrado .photo-wrapper img { border-radius: 12px; }

#cvPreview .photo-wrapper { display: flex; justify-content: center; margin-bottom: 15px; }
#cvPreview:not(.with-photo) .photo-wrapper { display: none; }
#cvPreview .photo-wrapper img { width: 120px; height: 120px; object-fit: cover; border: 3px solid var(--primary); }

/* --- TEMAS --- */
.template-moderno { --primary: #4361ee; --cv-font-family: 'Poppins', sans-serif; }
.template-moderno h1 { color: var(--primary); text-transform: uppercase; letter-spacing: 1px; }
.template-moderno h2 { color: var(--primary); border-bottom: 2px solid var(--primary); }
.template-classico { --primary: #2d3436; --cv-font-family: 'Times New Roman', serif; }
.template-classico h1 { font-size: 2rem; color: var(--primary); border-bottom: 2px solid var(--primary); }
.template-classico h2 { color: var(--primary); font-style: italic; }
.template-criativo { --primary: #fca311; --secondary: #e63946; --cv-font-family: 'Montserrat', sans-serif; }
.template-criativo h1 { background: linear-gradient(90deg, var(--primary), var(--secondary)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; font-weight: 800; }
.template-criativo h2 { color: var(--secondary); text-transform: uppercase; }
.template-executivo { --primary: #212529; --secondary: #6c757d; --cv-font-family: 'Helvetica Neue', sans-serif; }
.template-executivo h1 { color: var(--primary); font-size: 2.2rem; letter-spacing: -1px; }
.template-executivo h2 { color: var(--secondary); border-bottom: 1px solid var(--secondary); }
.template-minimalista { --primary: #000000; --secondary: #555555; --cv-font-family: 'Inter', sans-serif; color: #000; }
.template-minimalista h1 { font-size: 2.4rem; font-weight: 700; text-transform: uppercase; color: var(--primary); }
.template-minimalista h3 { font-weight: 400; color: var(--secondary); }
.template-minimalista h2 { font-size: 1.2rem; text-transform: uppercase; border-bottom: 1px solid #e0e0e0; color: var(--primary); }
.template-minimalista .skill-tag { background: #f5f5f5; border: 1px solid #ddd; color: var(--secondary); }
.template-colorido { --primary: #3a86ff; --secondary: #8338ec; --cv-font-family: 'Montserrat', sans-serif; display: grid; grid-template-columns: 35% 1fr; padding: 0; }
.template-colorido .preview-header { background: var(--primary); color: white; padding: 25px 15px; flex-direction: column; align-items: center; }
.template-colorido .main-content { padding: 20px 30px; background: #f8f9fa; color: #212529; }
.template-colorido h2 { color: var(--secondary); }
.template-dark { --primary: #00b4d8; --secondary: #90e0ef; --cv-font-family: 'Montserrat', sans-serif; background: #121212; color: #f1f1f1; }
.template-dark .preview-header { border-bottom: 2px solid var(--primary); }
.template-dark h2 { color: var(--secondary); border-left: 4px solid var(--primary); border-bottom: none; padding-left: 8px; }
.template-dark .skill-tag { background: var(--primary); color: #121212; font-weight: 600; }
.template-manhattan { --primary: #2c3e50; --secondary: #34495e; --cv-font-family: 'Lato', sans-serif; color: #333; }
.template-manhattan .preview-header { text-align: left; padding-bottom: 15px; border-bottom: 2px solid var(--primary); }
.template-manhattan h1 { font-family: 'Playfair Display', serif; font-size: 2.5rem; color: var(--primary); }
.template-manhattan h2 { font-family: 'Lato', sans-serif; text-transform: uppercase; color: var(--primary); border-bottom: 1px solid #e0e0e0; font-weight: 600; }
.template-manhattan .photo-wrapper { display: none; }
.template-tokyo { --primary: #33a1ff; --cv-font-family: 'DM Sans', sans-serif; background: #1a1a1a; color: #f0f0f0; display: grid; grid-template-columns: 220px 1fr; padding: 0; }
.template-tokyo .preview-header { background-color: #2a2a2a; color: #fff; padding: 30px 15px; text-align: left; flex-direction: column; align-items: flex-start; }
.template-tokyo .main-content { padding: 30px; }
.template-tokyo h2 { font-family: 'Source Code Pro', monospace; color: var(--primary); font-size: 1.1rem; border-bottom: 1px solid #444; }
.template-tokyo .skill-tag { background: #333; border: 1px solid #555; }
.template-zurique { --primary: #d90429; --cv-font-family: 'Inter', sans-serif; background: #fff; color: #111; }
.template-zurique > .preview-header { padding: 20px 0; border-bottom: 1.5px solid #111; text-align: left; }
.template-zurique h1 { font-size: 3rem; font-weight: 800; text-transform: uppercase; color: var(--primary); margin: 0; }
.template-zurique > .preview-section { display: grid; grid-template-columns: 140px 1fr; gap: 20px; align-items: start; border-bottom: 1px solid #eee; padding-bottom: 15px; margin-bottom: 15px; }
.template-zurique > .preview-section > h2 { font-size: 0.9rem; font-weight: 700; text-transform: uppercase; color: #111; border: none; text-align: right; margin: 0; padding: 0; }
.template-zurique .photo-wrapper { display: none; }

.file-upload-wrapper { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.file-upload-input { width: 0.1px; height: 0.1px; opacity: 0; overflow: hidden; position: absolute; z-index: -1; }
.file-upload-label { margin: 0; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; }
.file-upload-label:hover { background-color: var(--primary); color: white; }
.file-name { flex-grow: 1; color: var(--text-secondary); font-size: 0.85rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; padding: 8px; background-color: #f8f9fa; border: 1px solid #e9ecef; border-radius: 6px; }

#photoPreviewContainer { position: relative; width: 100px; height: 100px; margin-top: 10px; display: none; }
#photoPreview { width: 100%; height: 100%; object-fit: cover; border-radius: 5px; }
.remove-photo-btn { position: absolute; top: -8px; right: -8px; width: 24px; height: 24px; background-color: var(--danger); color: white; border: 2px solid white; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 16px; font-weight: bold; line-height: 1; padding: 0; box-shadow: 0 2px 5px rgba(0,0,0,0.2); transition: transform 0.2s ease; }
.remove-photo-btn:hover { transform: scale(1.1); }

.items-table .action-btn-group { display: flex; gap: 10px; }
.action-btn.edit:hover { color: var(--success); }
.action-btn.delete:hover { color: var(--danger); }
.items-table tr.editing-row { background-color: #e7f0ff; box-shadow: inset 4px 0 0 var(--primary); }

.btn.btn-sm { padding: 5px 8px; font-size: 0.7rem; }

.skills-list { display: flex; flex-direction: column; gap: 12px; }
.skill-item { display: grid; grid-template-columns: 150px 1fr; align-items: center; gap: 10px; }
.skill-name { font-weight: 500; text-align: right; font-size: 0.9rem; }
.skill-bar-container { width: 100%; height: 10px; background-color: #e9ecef; border-radius: 5px; overflow: hidden; }
.skill-bar-progress { height: 100%; background-color: var(--primary); border-radius: 5px; transition: width 0.5s ease-in-out; }

/* --- Menu Hamburguer e Navegação --- */
.nav-links {
    display: flex;
    transition: var(--transition);
}

/* --- Media Queries --- */
@media (max-width: 1024px) {
    .two-columns { flex-direction: column; }
    .form-column, .preview-column { width: 100%; max-width: 100%; max-height: none; overflow-y: visible; padding-right: 0; }
    .preview-column { order: 2; }
    .form-column { order: 1; }
    #cvPreview.a4, #cvPreview.a3 { width: 100%; min-height: auto; padding: 20px; }
}

@media (max-width: 768px) {
    .btn { padding: 8px 12px; font-size: 0.8rem; }
    .card, .container { padding: 15px; }
    .card-title { font-size: 1.2rem; }
    .form-row { flex-direction: column; gap: 12px; }
    .items-table { font-size: 0.85rem; }
    .template-selection { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 15px; }
    .preview-header .contact-info { flex-direction: column; align-items: center; }
    .logo h1 { font-size: 1.7rem; }

    header {
        position: fixed;
        height: 60px;
    }

    .app-container {
        padding-top: 60px;
    }

    /* Menu Hamburguer */
    .menu-toggle {
        display: block;
        position: relative;
        z-index: 1001;
    }

    .nav-links {
        display: none;
        position: fixed;
        top: 60px;
        left: 0;
        width: 100%;
        background-color: var(--card-bg);
        box-shadow: 0 4px 10px rgba(0,0,0,0.1);
        padding: 10px 0;
        border-bottom: 1px solid #e0e0e0;
        flex-direction: column;
        z-index: 1000;
    }

    .nav-links.active {
        display: flex;
        animation: slideDown 0.3s ease;
    }

    .nav-links .controls {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        width: 100%;
    }

    .nav-links .controls .btn {
        margin: 5px 15px;
        justify-content: flex-start;
        padding: 12px 15px;
        border-radius: 6px;
        width: calc(100% - 30px);
    }
    
    @keyframes slideDown {
        from {
            opacity: 0;
            transform: translateY(-10px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
}

@media (max-width: 640px) {
    .items-table { display: block; overflow-x: auto; white-space: nowrap; }
}

@media (max-width: 480px) {
    .skill-item {
        grid-template-columns: 1fr;
        gap: 5px;
    }
    .skill-name {
        text-align: left;
    }
}