.personal-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.5rem}@media(max-width:900px){.personal-fields{grid-template-columns:1fr}}.text-section{resize:vertical;min-height:80px}.list-section{display:flex;flex-direction:column;gap:.75rem}.list-item{padding:.75rem;background:var(--gruvbox-bg2);border-radius:4px;display:flex;flex-direction:column;gap:.5rem}.list-item-row{display:flex;gap:.5rem}.list-item-row input{flex:1}.list-item-row button{width:32px;border:1px solid var(--gruvbox-bg3);background:var(--gruvbox-bg1);cursor:pointer;border-radius:4px;color:var(--gruvbox-red)}.list-item-row button:hover{background:var(--gruvbox-red);color:var(--gruvbox-bg);border-color:var(--gruvbox-red)}.list-item-row.textarea-row{align-items:flex-start}.list-item-row.textarea-row textarea{flex:1}.list-item-row.textarea-row .field-font-size{margin-top:.25rem}.field-font-size{width:60px;padding:.25rem;border:1px solid var(--gruvbox-bg3);border-radius:4px;font-size:.75rem;background:var(--gruvbox-bg1);color:var(--gruvbox-fg);flex-shrink:0}.tags-section{display:flex;flex-direction:column;gap:.5rem}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:var(--gruvbox-blue);color:var(--gruvbox-bg);border-radius:4px;font-size:.875rem}.tag button{background:none;border:none;color:var(--gruvbox-bg);cursor:pointer;padding:0;font-size:1rem;line-height:1;opacity:.7}.tag button:hover{opacity:1}.tags-input{display:flex;gap:.5rem}.tags-input input{flex:1}.cv-section{background:var(--gruvbox-bg1);border-radius:8px;padding:1rem;border:1px solid var(--gruvbox-bg3)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--gruvbox-bg3)}.section-title-input{font-size:1rem;font-weight:600;border:none;background:transparent;flex:1;color:var(--gruvbox-fg0)}.section-title-input:focus{outline:none;border-bottom:2px solid var(--gruvbox-aqua)}.section-controls{display:flex;gap:.25rem}.section-controls button{width:28px;height:28px;border:1px solid var(--gruvbox-bg3);background:var(--gruvbox-bg2);cursor:pointer;border-radius:4px;font-size:1rem;color:var(--gruvbox-fg3)}.section-controls button:hover{background:var(--gruvbox-bg3);color:var(--gruvbox-fg)}.section-controls button.active{background:var(--gruvbox-aqua);color:var(--gruvbox-bg);border-color:var(--gruvbox-aqua)}.style-options{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem;background:var(--gruvbox-bg2);border-radius:4px;margin-bottom:.75rem}.style-option{display:flex;align-items:center;gap:.5rem}.style-option label{font-size:.8rem;color:var(--gruvbox-fg3)}.style-option input[type=color]{width:32px;height:28px;border:1px solid var(--gruvbox-bg3);border-radius:4px;cursor:pointer;padding:2px;background:var(--gruvbox-bg1)}.style-option select{padding:.25rem .5rem;border:1px solid var(--gruvbox-bg3);border-radius:4px;font-size:.8rem;background:var(--gruvbox-bg1);color:var(--gruvbox-fg)}.btn-reset{font-size:.7rem;padding:.2rem .4rem;background:var(--gruvbox-bg3);border:1px solid var(--gruvbox-bg3);border-radius:3px;cursor:pointer;color:var(--gruvbox-fg3)}.btn-reset:hover{background:var(--gruvbox-orange);color:var(--gruvbox-bg);border-color:var(--gruvbox-orange)}.style-option input[type=checkbox]{margin-right:.35rem;cursor:pointer;accent-color:var(--gruvbox-aqua)}.style-option label:has(input[type=checkbox]){display:flex;align-items:center;cursor:pointer;font-size:.8rem;color:var(--gruvbox-fg2)}.style-option .number-input{width:50px;padding:.25rem .4rem;border:1px solid var(--gruvbox-bg3);border-radius:4px;font-size:.8rem;background:var(--gruvbox-bg1);color:var(--gruvbox-fg);text-align:center}.style-option .unit{font-size:.75rem;color:var(--gruvbox-fg4)}.cv-form{display:flex;flex-direction:column;gap:1rem}.add-section{display:flex;gap:.5rem;align-items:center;padding:.75rem;background:var(--gruvbox-bg1);border-radius:8px;border:1px solid var(--gruvbox-bg3)}.add-section span{font-size:.875rem;color:var(--gruvbox-fg4)}.add-section button{padding:.5rem 1rem;border:1px solid var(--gruvbox-bg3);background:var(--gruvbox-bg2);cursor:pointer;border-radius:4px;font-size:.875rem;color:var(--gruvbox-fg3)}.add-section button:hover{background:var(--gruvbox-bg3);color:var(--gruvbox-fg)}.cv-preview{background:#fff;padding:40px;min-height:297mm;box-shadow:0 2px 8px #0000001a;border-radius:4px;line-height:1.6;color:#333;overflow-wrap:break-word;word-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;overflow:hidden}.cv-header{text-align:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #2c3e50}.cv-header h1{font-size:1.5rem;margin-bottom:8px;color:#2c3e50}.contact-info{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 16px;font-size:.8rem;color:#777}.header-summary{margin:12px 0 0;font-size:.85rem;color:#444;white-space:pre-wrap;line-height:1.5}.preview-section{margin-bottom:20px;page-break-inside:avoid}.preview-section h2{font-size:1rem;color:#2c3e50;border-bottom:1px solid #ddd;padding-bottom:4px;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.section-text{font-size:.85rem;color:#444;white-space:pre-wrap;margin:0}.section-list{display:flex;flex-direction:column;gap:12px}.list-entry{font-size:.85rem;page-break-inside:avoid}.entry-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2px}.entry-date{font-size:.75rem;color:#666;flex-shrink:0;margin-left:1rem}.entry-subtitle{color:#555;font-size:.8rem;margin-bottom:4px}.entry-desc{margin:6px 0 0;color:#444;white-space:pre-wrap;line-height:1.5}.section-tags{font-size:.85rem;color:#444;line-height:1.8}.markdown-content p{margin:0 0 .5em}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{margin:.25em 0;padding-left:1.5em}.markdown-content li{margin:.15em 0}.markdown-content strong{font-weight:600}.markdown-content em{font-style:italic}.markdown-content a{color:#2c3e50;text-decoration:underline}.markdown-content code{background:#f4f4f4;padding:.1em .3em;border-radius:3px;font-size:.9em}.markdown-content blockquote{margin:.5em 0;padding-left:.75em;border-left:2px solid #ddd;color:#666}@media(max-width:600px){.cv-preview{padding:1rem}.contact-info{flex-direction:column;gap:.2rem}}:root{--gruvbox-bg: #282828;--gruvbox-bg0: #282828;--gruvbox-bg1: #3c3836;--gruvbox-bg2: #504945;--gruvbox-bg3: #665c54;--gruvbox-fg: #ebdbb2;--gruvbox-fg0: #fbf1c7;--gruvbox-fg1: #ebdbb2;--gruvbox-fg2: #d5c4a1;--gruvbox-fg3: #bdae93;--gruvbox-fg4: #a89984;--gruvbox-red: #fb4934;--gruvbox-green: #b8bb26;--gruvbox-yellow: #fabd2f;--gruvbox-blue: #83a598;--gruvbox-purple: #d3869b;--gruvbox-aqua: #8ec07c;--gruvbox-orange: #fe8019;--gruvbox-gray: #928374}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;color:var(--gruvbox-fg);background:var(--gruvbox-bg)}#root{min-height:100vh}input,textarea{width:100%;padding:.5rem;border:1px solid var(--gruvbox-bg3);border-radius:4px;font-size:.875rem;font-family:inherit;background:var(--gruvbox-bg1);color:var(--gruvbox-fg)}input:focus,textarea:focus{outline:none;border-color:var(--gruvbox-aqua)}input::placeholder,textarea::placeholder{color:var(--gruvbox-fg4)}.btn-add{padding:.5rem 1rem;background:var(--gruvbox-bg2);border:1px dashed var(--gruvbox-bg3);border-radius:4px;cursor:pointer;font-size:.875rem;color:var(--gruvbox-fg3)}.btn-add:hover{background:var(--gruvbox-bg3);color:var(--gruvbox-fg)}.btn-remove{color:var(--gruvbox-red)!important}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--gruvbox-bg1);color:var(--gruvbox-fg);padding:.75rem 1rem;border-bottom:1px solid var(--gruvbox-bg3)}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.app-header h1{font-size:1.25rem;margin-bottom:.1rem;color:var(--gruvbox-fg0)}.app-header p{font-size:.75rem;color:var(--gruvbox-fg4)}.header-actions{display:flex;align-items:center;gap:.5rem}.btn-reset-all{padding:.4rem .75rem;border-radius:4px;border:1px solid var(--gruvbox-bg3);background:transparent;color:var(--gruvbox-fg4);font-size:.75rem;cursor:pointer;transition:all .2s}.btn-reset-all:hover{background:var(--gruvbox-bg2);border-color:var(--gruvbox-orange);color:var(--gruvbox-orange)}.btn-help{width:32px;height:32px;border-radius:50%;border:2px solid var(--gruvbox-bg3);background:transparent;color:var(--gruvbox-fg3);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-help:hover{background:var(--gruvbox-bg2);border-color:var(--gruvbox-aqua);color:var(--gruvbox-aqua)}.btn-export{padding:.5rem 1.25rem;background:var(--gruvbox-green);color:var(--gruvbox-bg);border:none;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500}.btn-export:hover{background:var(--gruvbox-aqua)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--gruvbox-bg1);border-radius:8px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0006;border:1px solid var(--gruvbox-bg3)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--gruvbox-bg3);position:sticky;top:0;background:var(--gruvbox-bg1)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--gruvbox-fg0)}.modal-close{width:32px;height:32px;border:none;background:var(--gruvbox-bg2);border-radius:4px;font-size:1.25rem;cursor:pointer;line-height:1;color:var(--gruvbox-fg3)}.modal-close:hover{background:var(--gruvbox-bg3);color:var(--gruvbox-red)}.modal-body{padding:1.25rem}.modal-body section{margin-bottom:1.5rem}.modal-body section:last-child{margin-bottom:0}.modal-body h3{font-size:1rem;margin:0 0 .75rem;color:var(--gruvbox-aqua)}.modal-body p{margin:0 0 .5rem;font-size:.9rem;color:var(--gruvbox-fg2)}.modal-body ol,.modal-body ul{margin:0;padding-left:1.25rem;font-size:.9rem;color:var(--gruvbox-fg2)}.modal-body li{margin:.35rem 0}.modal-body strong{color:var(--gruvbox-yellow)}.modal-body a{color:var(--gruvbox-blue)}.markdown-table{width:100%;border-collapse:collapse;font-size:.85rem;margin-top:.5rem}.markdown-table th,.markdown-table td{padding:.5rem;border:1px solid var(--gruvbox-bg3);text-align:left}.markdown-table th{background:var(--gruvbox-bg2);font-weight:600;color:var(--gruvbox-fg1)}.markdown-table td{color:var(--gruvbox-fg2)}.markdown-table code{background:var(--gruvbox-bg2);padding:.15rem .35rem;border-radius:3px;font-size:.85rem;color:var(--gruvbox-orange)}.main-content{flex:1;display:flex;gap:1rem;padding:1rem;max-width:1400px;margin:0 auto;width:100%}.preview-panel{flex:1;position:sticky;top:1rem;height:fit-content;max-height:calc(100vh - 6rem);overflow-y:auto}.form-panel{flex:1;max-height:calc(100vh - 6rem);overflow-y:auto}.app-footer{text-align:center;padding:.75rem;font-size:.75rem;color:var(--gruvbox-fg4);background:var(--gruvbox-bg1);border-top:1px solid var(--gruvbox-bg3)}.app-footer p{margin:0 0 .25rem}.footer-links{display:flex;justify-content:center;align-items:center;gap:.5rem}.footer-links a{color:var(--gruvbox-fg3);text-decoration:none}.footer-links a:hover{color:var(--gruvbox-aqua);text-decoration:underline}.footer-links span{color:var(--gruvbox-bg3)}@media(max-width:900px){.main-content{flex-direction:column}.preview-panel{position:static;max-height:none;order:2}.form-panel{max-height:none;order:1}}@media(max-width:600px){.header-content{flex-direction:column;gap:.5rem;text-align:center}}@media print{.app-header,.app-footer,.form-panel{display:none}.main-content{padding:0}.preview-panel{position:static;max-height:none}.cv-preview{box-shadow:none;padding:0}}
