.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 0;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{font-size:24px;font-weight:700;margin:0}.logo a{color:#3b82f6;text-decoration:none}.nav{display:flex;gap:24px}.nav a{color:#6b7280;text-decoration:none;font-weight:500;padding:8px 0;border-bottom:2px solid transparent;transition:all .2s}.nav a:hover{color:#3b82f6}.nav a.active{color:#3b82f6;border-bottom-color:#3b82f6}.btn-logout{background:#ef4444;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s;font-size:14px}.btn-logout:hover{background:#dc2626}.btn-logout:active{background:#b91c1c}.dashboard-main{flex:1;padding:32px 0}.dashboard-footer{background:#fff;border-top:1px solid #e5e7eb;padding:24px 0;margin-top:auto;text-align:center;color:#6b7280;font-size:14px}.dashboard-footer .version{margin-left:12px;padding:4px 8px;background:#f3f4f6;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;color:#4b5563;font-weight:500}@media (max-width: 768px){.dashboard-header{padding:12px 0}.header-content{flex-direction:column;align-items:flex-start;gap:12px}.logo{font-size:20px}.nav{width:100%;gap:16px;flex-wrap:wrap}.nav a{font-size:14px;padding:6px 0}.btn-logout{padding:10px 16px;font-size:14px;width:auto;min-width:80px}.dashboard-main{padding:16px 0}.dashboard-footer{padding:16px 0;font-size:12px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:2.5rem;width:100%;max-width:400px}.login-title{font-size:2rem;font-weight:700;color:#333;margin:0 0 .5rem;text-align:center}.login-subtitle{color:#666;text-align:center;margin:0 0 2rem;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s;font-family:Monaco,Menlo,Courier New,monospace}.form-group input:focus{outline:none;border-color:#667eea}.form-group input.error{border-color:#e74c3c}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:6px;font-size:.9rem;border:1px solid #fcc}.btn-block{width:100%;padding:.875rem;font-size:1rem;font-weight:600}.btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.login-card{padding:2rem 1.5rem}.login-title{font-size:1.75rem}.login-subtitle{font-size:.9rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:32px;max-width:500px;width:90%;position:relative;box-shadow:0 20px 25px -5px #0000001a}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:32px;color:#6b7280;cursor:pointer;line-height:1;padding:0;width:44px;height:44px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.modal-close:hover{background:#f3f4f6}.modal-content h2{margin:0 0 24px;font-size:20px;color:#111827}.qr-code-container{text-align:center;margin-bottom:24px;padding:20px;background:#f9fafb;border-radius:8px}.qr-code-image{max-width:100%;height:auto}.qr-code-url{display:flex;gap:8px;margin-bottom:24px}.qr-code-url input{flex:1}.qr-code-actions{display:flex;gap:12px;justify-content:center}@media (max-width: 768px){.modal-content{padding:24px;width:95%;max-width:100%;margin:20px}.modal-content h2{font-size:18px;margin-bottom:20px}.qr-code-url{flex-direction:column;gap:8px}.qr-code-url input{font-size:14px}.qr-code-url .btn{width:100%}.qr-code-actions{flex-direction:column;gap:8px}.qr-code-actions .btn{width:100%}}.redirect-list{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.list-header h2{margin:0;font-size:24px;font-weight:600;color:#111827}.header-actions{display:flex;gap:12px}.search-bar{margin-bottom:24px}.redirects-table-container{overflow-x:auto}.redirects-table{width:100%;border-collapse:collapse}.redirects-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.redirects-table th{padding:12px;text-align:left;font-weight:600;color:#374151;font-size:14px}.redirects-table td{padding:12px;border-bottom:1px solid #e5e7eb;font-size:14px}.redirects-table tbody tr:hover{background:#f9fafb}.short-code{background:#f3f4f6;padding:4px 8px;border-radius:4px;font-family:Courier New,monospace;font-size:13px;color:#1f2937}.target-url{color:#3b82f6;text-decoration:none;max-width:300px;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.target-url:hover{text-decoration:underline}.hit-count{font-weight:600;color:#059669}.actions{display:flex;gap:8px;align-items:center}.btn-icon{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px;transition:background .2s;min-width:32px;min-height:32px;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:#f3f4f6}.btn-icon-danger:hover{background:#fee2e2}.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.empty-state p{margin-bottom:16px;font-size:16px}.error-container{text-align:center;padding:40px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.type-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.type-redirect{background:#dbeafe;color:#1e40af}.type-linkpage{background:#fae8ff;color:#86198f}.links-count{display:inline-block;padding:2px 8px;background:#f3e8ff;color:#7c3aed;border-radius:10px;font-size:12px;font-weight:600}.redirect-card-badges{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}.disabled-row{opacity:.6;background:#f9fafb}.disabled-row:hover{background:#f3f4f6}@media (max-width: 768px){.redirect-list{padding:16px;border-radius:0}.list-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px}.list-header h2{font-size:20px}.header-actions{width:100%;flex-direction:column;gap:8px}.header-actions .btn{width:100%}.search-bar{margin-bottom:16px}.redirects-table-container{display:none}.redirects-table-mobile{display:block}.redirect-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:12px}.redirect-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.redirect-card-title{display:flex;flex-direction:column;gap:4px;flex:1}.redirect-card-status{margin-bottom:8px}.redirect-card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.redirect-card-actions .btn-icon{font-size:20px;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.redirect-card-info{display:flex;flex-direction:column;gap:8px;font-size:14px}.redirect-card-info-item{display:flex;justify-content:space-between;align-items:flex-start}.redirect-card-info-label{font-weight:600;color:#6b7280;min-width:80px}.redirect-card-info-value{flex:1;text-align:right;word-break:break-word}}@media (min-width: 769px){.redirects-table-mobile{display:none}}.redirect-form{background:#fff;border-radius:8px;padding:32px;box-shadow:0 1px 3px #0000001a;max-width:600px;margin:0 auto}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.form-header h2{margin:0;font-size:24px;font-weight:600;color:#111827}.form-hint{font-size:12px;color:#6b7280;margin-top:4px}.required{color:#ef4444}.form-input.error{border-color:#ef4444}.form-checkbox{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}@media (max-width: 768px){.redirect-form{padding:20px;border-radius:0;max-width:100%}.form-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:24px}.form-header h2{font-size:20px}.form-header .btn{width:100%}.form-actions{flex-direction:column;gap:8px}.form-actions .btn{width:100%}}.linkpage-form{max-width:800px;margin:0 auto}.linkpage-form .form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.linkpage-form .form-header h2{margin:0;color:var(--text-primary)}.form-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin-bottom:24px}.form-section h3{margin:0 0 20px;font-size:1.1rem;color:var(--text-primary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{margin:0}.theme-selector{display:flex;gap:12px;flex-wrap:wrap}.theme-option{width:80px;height:60px;border:3px solid transparent;border-radius:10px;cursor:pointer;display:flex;align-items:flex-end;justify-content:center;padding:8px;transition:all .2s ease;position:relative;overflow:hidden}.theme-option:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.theme-option.selected{border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f64d}.theme-name{font-size:.75rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);background:#0000004d;padding:2px 8px;border-radius:4px}.checkbox-label{display:flex!important;align-items:center;cursor:pointer;gap:8px}.checkbox-label span{margin-left:0}.links-editor{display:flex;flex-direction:column;gap:16px}.link-editor-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;padding:16px;transition:box-shadow .2s ease}.link-editor-item:hover{box-shadow:0 2px 8px #00000014}.link-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.link-number{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.link-item-actions{display:flex;gap:4px}.btn-icon-small{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.9rem;color:var(--text-secondary);transition:all .15s ease}.btn-icon-small:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-icon-small:disabled{opacity:.4;cursor:not-allowed}.btn-icon-small.btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#ef4444;color:#ef4444}.link-fields{display:grid;gap:12px}.link-fields .form-group{margin-bottom:0}.link-fields .form-label{font-size:.85rem;margin-bottom:4px}.link-fields .form-input{padding:10px 12px}.btn-small{padding:8px 16px;font-size:.85rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .15s ease}.btn-small:hover:not(:disabled){background:var(--primary-hover)}.btn-small:disabled{opacity:.5;cursor:not-allowed}.btn-add-link{padding:12px 24px;font-size:1rem;font-weight:600;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #3b82f633;display:inline-flex;align-items:center;gap:6px}.btn-add-link:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.btn-add-link:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #3b82f633}.btn-add-link:disabled{opacity:.5;cursor:not-allowed;transform:none}.add-link-footer{margin-top:24px;padding-top:24px;border-top:2px dashed var(--border-color);text-align:center}.btn-add-link-footer{padding:14px 28px;font-size:1rem;font-weight:600;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #3b82f640;display:inline-flex;align-items:center;gap:8px}.btn-add-link-footer:hover:not(:disabled){background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f659}.btn-add-link-footer:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #3b82f640}.btn-add-link-footer:disabled{opacity:.5;cursor:not-allowed;transform:none}.add-link-hint{margin-top:8px;font-size:.85rem;color:var(--text-secondary);font-style:italic}.linkpage-form .form-actions{margin-top:24px}@media (max-width: 600px){.form-section{padding:16px}.theme-selector{gap:8px}.theme-option{width:70px;height:50px}.link-item-header{flex-direction:column;align-items:flex-start;gap:8px}}.metrics-view{background:#fff;border-radius:8px;padding:32px;box-shadow:0 1px 3px #0000001a}.metrics-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.back-link{color:#6b7280;text-decoration:none;font-size:14px;margin-bottom:8px;display:inline-block}.back-link:hover{color:#3b82f6}.metrics-header h2{margin:0;font-size:24px;font-weight:600;color:#111827}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.metrics-card{background:#f9fafb;border-radius:8px;padding:24px}.metrics-card h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#111827}.details-list{display:flex;flex-direction:column;gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.redirect-url{font-family:Courier New,monospace;font-size:13px;background:#fff;padding:8px;border-radius:4px;flex:1}.url-with-copy{display:flex;gap:8px;align-items:center}.btn-sm{padding:6px 12px;font-size:12px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.stat-item{text-align:center;padding:16px;background:#fff;border-radius:6px}.stat-value{font-size:24px;font-weight:700;color:#3b82f6;margin-bottom:4px}.stat-label{font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.qr-code-preview{text-align:center;padding:20px;background:#fff;border-radius:6px}.qr-code-preview img{max-width:100%;height:auto}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.status-enabled{background:#d1fae5;color:#065f46}.status-disabled{background:#fee2e2;color:#991b1b}@media (max-width: 768px){.metrics-view{padding:16px;border-radius:0}.metrics-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:24px;padding-bottom:16px}.metrics-header h2{font-size:20px}.metrics-header .btn{width:100%}.metrics-grid{grid-template-columns:1fr;gap:16px}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-value{font-size:20px}.url-with-copy{flex-direction:column;align-items:stretch}.url-with-copy input{margin-bottom:8px}.url-with-copy .btn{width:100%}.qr-code-actions{flex-direction:column}.qr-code-actions .btn{width:100%}}.app{min-height:100vh;background:#f5f5f5}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.1rem;color:#666}.container{max-width:1200px;margin:0 auto;padding:0 20px}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:500;color:#374151}.form-input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea{min-height:100px;resize:vertical}.error-message{color:#ef4444;font-size:14px;margin-top:8px}.success-message{color:#10b981;font-size:14px;margin-top:8px}.loading{text-align:center;padding:40px;color:#6b7280}@media (max-width: 768px){.container{padding:0 16px}.btn{padding:12px 16px;font-size:14px;width:100%;text-align:center}.form-input{font-size:16px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#333;-webkit-tap-highlight-color:transparent}*{-webkit-tap-highlight-color:transparent}button,a{touch-action:manipulation}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
