@import"https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Roboto:wght@300;400;500;700&display=swap";.pagination-controls[data-v-25e6cee8]{display:flex;justify-content:center;align-items:center;gap:20px;padding:15px;background:linear-gradient(135deg,#f5edd8,#e8dfc8);border-radius:10px;margin-bottom:20px}.pagination-controls.bottom[data-v-25e6cee8]{margin-top:20px;margin-bottom:0}.btn-page[data-v-25e6cee8]{padding:10px 20px;border:none;border-radius:6px;background:linear-gradient(135deg,#8b6b4a,#6b4f35);color:#fff;cursor:pointer;font-weight:500;transition:all .3s ease}.btn-page[data-v-25e6cee8]:hover:not(:disabled){background:linear-gradient(135deg,#a68b5b,#8b6b4a);transform:translateY(-2px)}.btn-page[data-v-25e6cee8]:disabled{opacity:.5;cursor:not-allowed}.page-info[data-v-25e6cee8]{font-size:1.1em;color:#5a4a3a}.page-jump[data-v-25e6cee8]{display:flex;align-items:center;gap:8px;color:#5a4a3a}.page-jump input[data-v-25e6cee8]{width:60px;padding:8px;border:1px solid #d4c4b0;border-radius:5px;text-align:center;font-size:1em}.btn-go[data-v-25e6cee8]{padding:8px 15px;border:none;border-radius:5px;background:#4a90a4;color:#fff;cursor:pointer;font-weight:500}.btn-go[data-v-25e6cee8]:hover{background:#5aa0b4}.a4-page[data-v-25e6cee8]{position:relative;width:297mm;height:210mm;margin:0 auto 20px;border:1px solid #ddd;box-shadow:0 4px 20px #00000026;overflow:hidden;background-color:#fff}.background-image[data-v-25e6cee8]{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:fill;object-position:center;z-index:0}.overlay-content[data-v-25e6cee8]{position:absolute;z-index:1;width:100%;height:100%;top:0;left:0}.bai-vi-box[data-v-25e6cee8]{position:absolute;display:flex;flex-direction:column;justify-content:flex-start}.box-1[data-v-25e6cee8]{top:30.5%;left:4.2%;width:17.8%;height:45%}.box-2[data-v-25e6cee8]{top:30.5%;left:28.9%;width:17.8%;height:45%}.box-3[data-v-25e6cee8]{top:30.5%;left:53.5%;width:17.8%;height:45%}.box-4[data-v-25e6cee8]{top:30.5%;left:78.7%;width:17.8%;height:45%}.huong-linh-list[data-v-25e6cee8]{display:flex;flex-direction:column;justify-content:center;height:100%;padding:1mm 1.5mm}.huong-linh-row[data-v-25e6cee8]{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;padding:.8mm 1mm;font-family:Saira Extra Condensed,sans-serif;font-weight:500;font-size:var(--font-size, 9pt);color:#3b2a1a;min-height:4.5mm;line-height:1.2;text-transform:uppercase}.name-text[data-v-25e6cee8]{flex:1;text-align:left;font-weight:500;word-wrap:break-word;overflow-wrap:break-word}.date-text[data-v-25e6cee8]{text-align:right;font-style:italic;color:#5a4a3a;font-weight:400;white-space:nowrap}*{box-sizing:border-box}body{font-family:Roboto,sans-serif;margin:0;padding:0;background:linear-gradient(135deg,#f5f0e8,#e8dfd4);color:#333;line-height:1.6;min-height:100vh}.container{display:flex;max-width:1600px;margin:20px auto;background-color:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;overflow:hidden;min-height:calc(100vh - 40px)}.input-panel{flex:0 0 420px;padding:25px;border-right:1px solid #e8dfd4;background:linear-gradient(180deg,#fffdf9,#f9f5ef);max-height:100vh;overflow-y:auto}.input-panel h2{color:#5a4a3a;margin-bottom:20px;font-size:1.5em;border-bottom:2px solid #d4c4b0;padding-bottom:12px;font-weight:600}.upload-section{background:#fff;border-radius:10px;padding:20px;margin-bottom:20px;border:1px solid #e8dfd4;box-shadow:0 2px 8px #00000008}.upload-section h3{color:#5a4a3a;margin:0 0 15px;font-size:1.1em}.upload-info{background:linear-gradient(135deg,#fff8e8,#f5edd8);border:1px solid #d4c4a0;border-radius:8px;padding:12px 15px;margin-bottom:15px;font-size:.85em}.upload-info p{margin:0 0 8px;color:#6b5a4a}.upload-info ul{margin:8px 0 0;padding-left:18px;color:#7a6a5a}.upload-info li{margin-bottom:4px}.csv-format{background:#fff;padding:8px 12px;border-radius:5px;font-family:monospace;font-size:.9em;color:#5a4a3a;border:1px dashed #c4b4a0}.upload-actions{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.download-link{color:#667eea;text-decoration:none;font-size:.9em;font-weight:500;transition:all .3s ease;padding:8px 0}.download-link:hover{color:#5a67d8;text-decoration:underline}.btn{padding:12px 20px;border:none;border-radius:8px;cursor:pointer;font-size:.95em;font-weight:500;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-upload{width:100%;background:linear-gradient(135deg,#4a90a4,#357a8a);color:#fff}.btn-upload:hover:not(:disabled){background:linear-gradient(135deg,#5aa0b4,#458a9a);transform:translateY(-2px);box-shadow:0 4px 12px #4a90a44d}.message{margin-top:12px;padding:10px 15px;border-radius:6px;font-size:.9em}.success-message{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:1px solid #a5d6a7;color:#2e7d32}.error-message{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:1px solid #ef9a9a;color:#c62828}.summary-section{background:#fff;border-radius:10px;padding:20px;margin-bottom:20px;border:1px solid #e8dfd4}.summary-section h3{color:#5a4a3a;margin:0 0 15px;font-size:1.1em}.summary-stats{display:flex;gap:15px;margin-bottom:20px}.stat-item{flex:1;text-align:center;background:linear-gradient(135deg,#f5edd8,#e8dfc8);padding:12px 8px;border-radius:8px;border:1px solid #d4c4a0}.stat-number{display:block;font-size:1.8em;font-weight:700;color:#6b5a4a}.stat-label{font-size:.8em;color:#8a7a6a}.family-list{max-height:300px;overflow-y:auto}.family-item{margin-bottom:12px;border:1px solid #e8dfd4;border-radius:8px;overflow:hidden}.family-header{background:linear-gradient(135deg,#8b6b4a,#6b4f35);color:#fff;padding:10px 15px;display:flex;justify-content:space-between;align-items:center}.family-name{font-weight:600}.family-count{font-size:.85em;opacity:.9}.family-members{padding:10px 15px;background:#faf8f5}.member-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dotted #e0d8d0;font-size:.9em}.member-row:last-child{border-bottom:none}.member-name{color:#5a4a3a}.member-date{color:#8a7a6a;font-style:italic}.action-buttons-container{margin-top:20px;padding-top:20px;border-top:2px solid #e8dfd4}.action-buttons-row{display:flex;flex-direction:column;gap:10px}.btn-settings{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-settings:hover:not(:disabled){background:linear-gradient(135deg,#7b8eef,#8a5fb5);transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-export{background:linear-gradient(135deg,#4a90a4,#357a8a);color:#fff}.btn-export:hover:not(:disabled){background:linear-gradient(135deg,#5aa0b4,#458a9a);transform:translateY(-2px);box-shadow:0 4px 12px #4a90a44d}.btn-export:disabled{background:linear-gradient(135deg,#aaa,#888);cursor:not-allowed}.btn-clear{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.btn-clear:hover:not(:disabled){background:linear-gradient(135deg,#ec7063,#d63031);transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.clear-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #eb334966}.preview-panel{flex:1;padding:25px;background:linear-gradient(180deg,#f5f0e8,#e8dfd4);overflow-y:auto;max-height:100vh}.preview-panel h2{color:#5a4a3a;margin-bottom:20px;font-size:1.5em;border-bottom:2px solid #d4c4b0;padding-bottom:12px}.preview-wrapper{background:#fff;padding:20px;border-radius:12px;box-shadow:0 4px 20px #00000014}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f5f0e8;border-radius:4px}::-webkit-scrollbar-thumb{background:#c4b4a4;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a4948a}@media print{.a4-page{page-break-after:always}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:15px;padding:30px;width:90%;max-width:450px;box-shadow:0 10px 40px #0000004d}.modal-content h3{color:#5a4a3a;margin:0 0 25px;font-size:1.4em;text-align:center}.setting-group{margin-bottom:20px}.setting-group label{display:block;color:#5a4a3a;font-weight:500;margin-bottom:8px}.setting-group input{width:100%;padding:12px 15px;border:2px solid #d4c4b0;border-radius:8px;font-size:1em;transition:border-color .3s}.setting-group input:focus{outline:none;border-color:#8b6b4a}.setting-hint{display:block;font-size:.8em;color:#8a7a6a;margin-top:5px;font-style:italic}.modal-buttons{display:flex;gap:10px;margin-top:25px}.btn-settings{flex:1;background:linear-gradient(135deg,#6a5acd,#483d8b);color:#fff}.btn-settings:hover{background:linear-gradient(135deg,#7b68ee,#5a4fcf)}.btn-reset{flex:1;background:linear-gradient(135deg,#8a8a8a,#6a6a6a);color:#fff}.btn-cancel{flex:1;background:linear-gradient(135deg,#c75a50,#a54840);color:#fff}.btn-save{flex:2;background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.btn-save:hover{background:linear-gradient(135deg,#66bb6a,#43a047)}
