@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background:#f0f4f8;color:#1e293b;min-height:100vh;font-size:14px}.app{max-width:1200px;margin:0 auto;padding:24px 20px 60px}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px}.header-left{display:flex;align-items:center;gap:14px}.header-icon{width:48px;height:48px;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 12px #2563eb4d}h1{font-size:22px;font-weight:700;color:#0f172a}.header-sub{font-size:13px;color:#64748b;margin-top:2px}.header-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.btn-add,.btn-export,.btn-import{display:flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s}.btn-add{background:#2563eb;color:#fff;box-shadow:0 2px 8px #2563eb40}.btn-add:hover{background:#1d4ed8;transform:translateY(-1px)}.btn-export{background:#16a34a;color:#fff;box-shadow:0 2px 8px #16a34a40}.btn-export:hover{background:#15803d;transform:translateY(-1px)}.btn-import{background:#fff;color:#475569;border:1.5px solid #e2e8f0}.btn-import:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.btn-erase{background:#fff;color:#dc2626;border:1.5px solid #fecaca}.btn-erase:hover{background:#fef2f2;border-color:#f87171;transform:translateY(-1px)}.btn-danger{background:#dc2626;color:#fff;padding:9px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:inherit}.btn-danger:hover{background:#b91c1c}.export-wrap{position:relative}.export-menu{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f;overflow:hidden;z-index:50;min-width:210px}.export-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:11px 16px;background:none;border:none;cursor:pointer;font-size:13.5px;font-weight:500;color:#334155;text-align:left;transition:background .1s}.export-menu button:hover{background:#f8fafc}.export-menu button+button{border-top:1px solid #f1f5f9}.tab-bar{display:flex;gap:4px;margin-bottom:18px;border-bottom:2px solid #e2e8f0;padding-bottom:0}.tab-btn{padding:10px 20px;font-size:13.5px;font-weight:600;border:none;background:none;cursor:pointer;color:#64748b;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;border-radius:6px 6px 0 0}.tab-btn:hover{color:#334155;background:#f8fafc}.tab-active{color:#2563eb!important;border-bottom-color:#2563eb!important;background:none!important}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.search-input{width:100%;padding:9px 12px 9px 36px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:13px;background:#fff;color:#1e293b;outline:none;transition:border-color .15s;font-family:inherit}.search-input:focus{border-color:#2563eb}.filter-tabs{display:flex;gap:6px}.filter-tab{padding:8px 16px;border-radius:7px;border:1.5px solid #e2e8f0;background:#fff;font-size:13px;font-weight:500;cursor:pointer;color:#64748b;transition:all .15s;font-family:inherit}.filter-tab:hover{border-color:#cbd5e1;background:#f8fafc}.filter-tab.active{border-color:#2563eb;background:#eff6ff;color:#2563eb;font-weight:600}.filter-tab.tab-enter.active{border-color:#16a34a;background:#f0fdf4;color:#16a34a}.filter-tab.tab-exit.active{border-color:#dc2626;background:#fef2f2;color:#dc2626}.filter-notice{background:#fef9c3;border:1px solid #fde047;border-radius:8px;padding:10px 14px;font-size:12.5px;color:#713f12;margin-bottom:12px;display:flex;align-items:center;gap:12px}.filter-notice button{margin-left:auto;background:none;border:1px solid #ca8a04;border-radius:5px;padding:3px 10px;font-size:12px;cursor:pointer;color:#713f12;font-family:inherit}.filter-notice button:hover{background:#fde047}.table-wrap{background:#fff;border-radius:12px;border:1.5px solid #e2e8f0;overflow:hidden;box-shadow:0 1px 6px #0000000d;overflow-x:auto}.records-table{width:100%;border-collapse:collapse;min-width:700px}.records-table thead tr{background:#1e293b}.records-table thead th{padding:11px 12px;text-align:left;font-size:12px;font-weight:600;color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}.table-row{border-bottom:1px solid #f1f5f9;transition:background .1s;cursor:default}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f8fafc!important}.enter-row{background:#f0fdf4}.exit-row{background:#fff}.records-table td{padding:9px 12px;font-size:13px;color:#334155;white-space:nowrap}.td-drag{width:32px;padding:0 4px!important}.drag-handle{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:none;cursor:grab;color:#cbd5e1;border-radius:4px;transition:color .15s,background .15s}.drag-handle:hover{color:#64748b;background:#f1f5f9}.drag-handle:active{cursor:grabbing}.td-index{color:#94a3b8;font-size:12px;width:40px}.td-num{color:#64748b;font-weight:500}.td-date{font-weight:600;color:#0f172a}.td-month{color:#334155}.td-year{color:#64748b}.td-country{font-weight:600;color:#0f172a}.td-notes{color:#94a3b8;font-style:italic;max-width:140px;overflow:hidden;text-overflow:ellipsis}.td-actions{width:72px;display:flex;gap:6px;align-items:center}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:700;letter-spacing:.03em}.badge-enter{background:#dcfce7;color:#15803d}.badge-exit{background:#fee2e2;color:#b91c1c}.btn-icon{width:28px;height:28px;border-radius:6px;border:1px solid transparent;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-edit{color:#3b82f6}.btn-edit:hover{background:#eff6ff;border-color:#bfdbfe}.btn-delete{color:#ef4444}.btn-delete:hover{background:#fef2f2;border-color:#fecaca}.empty-state{text-align:center;padding:48px;color:#94a3b8;font-size:14px}.stats-wrap{animation:fadeIn .2s ease}.stats-header{margin-bottom:20px}.stats-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media(max-width:640px){.stats-kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:#fff;border-radius:12px;padding:18px 20px;border:1.5px solid #e2e8f0;text-align:center;box-shadow:0 1px 4px #0000000a}.kpi-value{font-size:28px;font-weight:700;color:#0f172a}.kpi-label{font-size:12px;color:#64748b;font-weight:500;margin-top:4px;text-transform:uppercase;letter-spacing:.05em}.stats-table-wrap{background:#fff;border-radius:12px;border:1.5px solid #e2e8f0;overflow:hidden;box-shadow:0 1px 6px #0000000d}.stats-table{width:100%;border-collapse:collapse}.stats-table thead tr{background:#1e293b}.stats-table thead th{padding:11px 16px;text-align:left;font-size:12px;font-weight:600;color:#94a3b8;letter-spacing:.05em;text-transform:uppercase}.stats-row{border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s}.stats-row:hover{background:#f8fafc}.stats-row td{padding:13px 16px;font-size:13.5px;color:#334155}.stats-country{display:flex;align-items:center;gap:10px;font-weight:600;color:#0f172a}.country-flag{font-size:20px}.stats-visits{color:#64748b;font-size:13px}.stats-days strong{color:#0f172a;font-size:15px}.stats-chevron{color:#94a3b8}.bar-track{background:#f1f5f9;border-radius:100px;height:8px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#2563eb,#60a5fa);border-radius:100px;transition:width .6s ease}.stats-detail-row td{padding:0 16px 12px}.periods-grid{display:flex;flex-wrap:wrap;gap:8px;padding:8px 0}.period-chip{display:flex;align-items:center;gap:8px;background:#f1f5f9;border-radius:20px;padding:5px 12px;font-size:12px;color:#475569}.period-dates{color:#64748b}.period-days{font-weight:700;color:#2563eb;background:#eff6ff;padding:2px 7px;border-radius:10px}.modal-backdrop{position:fixed;inset:0;background:#00000073;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:14px;width:100%;max-width:520px;box-shadow:0 20px 60px #0003;overflow:hidden;animation:slideUp .2s ease}.modal-wide{max-width:680px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #f1f5f9;background:#f8fafc}.modal-header h2{font-size:16px;font-weight:700;color:#0f172a}.btn-close{width:28px;height:28px;border-radius:6px;border:none;background:#f1f5f9;cursor:pointer;color:#64748b;font-size:13px;display:flex;align-items:center;justify-content:center}.btn-close:hover{background:#e2e8f0;color:#0f172a}.modal-body{padding:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid label{display:flex;flex-direction:column;gap:5px}.form-grid label.full-width{grid-column:1 / -1}.form-grid span{font-size:12px;font-weight:600;color:#475569;letter-spacing:.03em;text-transform:uppercase}.form-grid input,.form-grid select{padding:9px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:13px;color:#1e293b;background:#fff;outline:none;transition:border-color .15s;font-family:inherit;width:100%}.form-grid input:focus,.form-grid select:focus{border-color:#2563eb}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid #f1f5f9;background:#f8fafc}.btn-primary,.btn-secondary{padding:9px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:inherit}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-secondary{background:#fff;color:#475569;border:1.5px solid #e2e8f0}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.import-zone{display:flex;flex-direction:column;align-items:center;padding:32px 20px;text-align:center;border:2px dashed #e2e8f0;border-radius:12px;background:#f8fafc}.import-icon{font-size:40px;margin-bottom:12px}.import-title{font-size:16px;font-weight:600;color:#0f172a;margin-bottom:6px}.import-sub{font-size:13px;color:#64748b;margin-bottom:4px;line-height:1.5}.import-error{color:#b91c1c;font-size:13px;margin-top:12px;background:#fef2f2;padding:8px 14px;border-radius:8px}.import-preview-msg{font-size:14px;color:#334155;margin-bottom:12px}.import-preview-msg strong{color:#0f172a}.import-mode-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}.import-mode-btns .btn-primary{background:#2563eb;color:#fff;border:none}.import-mode-btns .btn-secondary{border:1.5px solid #e2e8f0}.import-restart{background:none;border:none;cursor:pointer;font-size:13px;color:#64748b;text-decoration:underline;font-family:inherit}.import-restart:hover{color:#2563eb}
