.home-page{scroll-snap-type:y mandatory;overflow-y:scroll;height:100vh}.hero-section{height:100vh;scroll-snap-align:start;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:20px;position:relative}.hero-content h1{font-size:3rem;margin-bottom:16px}.hero-subtitle{font-size:1.3rem;opacity:.9;margin-bottom:40px;line-height:1.6}.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.hero-buttons .btn-large{padding:14px 32px;font-size:1.1rem}.hero-buttons .btn-outline{border-color:#fff;color:#fff}.hero-buttons .btn-outline:hover{background:#fff;color:#2563eb}.scroll-hint{position:absolute;bottom:30px;display:flex;flex-direction:column;align-items:center;opacity:.7;animation:bounce 2s infinite}.scroll-hint span{font-size:.9rem;margin-bottom:8px}.scroll-arrow{font-size:1.5rem}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.info-section{min-height:100vh;scroll-snap-align:start;background:#f8fafc;display:flex;flex-direction:column;padding:60px 40px 40px;box-sizing:border-box}.info-content{flex:1;display:flex;flex-direction:column;gap:50px;max-width:1200px;margin:0 auto;width:100%}.features-section h2,.how-it-works h2{font-size:1.6rem;color:#1e293b;text-align:center;margin-bottom:32px}.features-grid,.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.feature-card,.step-card{background:#fff;border-radius:16px;padding:28px 24px;box-shadow:0 2px 12px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover,.step-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #2563eb1f}.feature-icon,.step-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:20px}.feature-icon{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.step-icon{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;font-size:1.4rem;font-weight:700}.feature-card h3,.step-card h3{font-size:1.1rem;margin-bottom:12px;color:#1e293b}.feature-card p,.step-card p{color:#64748b;font-size:.95rem;margin:0;line-height:1.6}.home-footer{text-align:center;padding:24px 20px;color:#94a3b8;font-size:.85rem}@media (max-width: 1024px){.features-grid,.steps-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.hero-content h1{font-size:2rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{flex-direction:column;align-items:center}.hero-buttons .btn{width:100%;max-width:280px}.info-section{padding:40px 20px 24px}.features-grid,.steps-grid{grid-template-columns:1fr;gap:16px}.features-section h2,.how-it-works h2{font-size:1.3rem;margin-bottom:20px}.feature-card,.step-card{padding:20px}}.create-room-page{min-height:100vh;padding-bottom:40px}.create-form{margin-top:-20px}.error-message{padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin-bottom:20px}.candidates-section{margin-top:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{margin:0}.candidate-input{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;margin-bottom:12px}.candidate-number{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#4f46e5;color:#fff;font-weight:700;border-radius:8px;flex-shrink:0}.candidate-fields{flex:1;display:flex;flex-direction:column;gap:8px}.candidate-fields .input-small{font-size:.9rem;padding:8px 12px}.remove-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#94a3b8;cursor:pointer;border-radius:6px;transition:all .2s}.remove-btn:hover{background:#fee2e2;color:#ef4444}.image-upload-section{margin-top:8px}.image-upload-label{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f1f5f9;border:2px dashed #cbd5e1;border-radius:8px;cursor:pointer;transition:all .2s;color:#64748b;font-size:.9rem}.image-upload-label:hover{background:#e2e8f0;border-color:#94a3b8}.upload-icon{font-size:1.2rem}.image-preview{position:relative;display:inline-block}.image-preview img{max-width:120px;max-height:80px;object-fit:cover;border-radius:8px;border:2px solid #e2e8f0}.remove-image-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:.8rem;font-weight:700;transition:all .2s}.remove-image-btn:hover{background:#dc2626;transform:scale(1.1)}@media (max-width: 480px){.section-header{flex-direction:column;gap:12px;align-items:flex-start}.candidate-input{flex-wrap:wrap}.candidate-number{width:32px;height:32px;font-size:.9rem}}.results-visualization{max-width:800px;margin:0 auto}.winner-banner{text-align:center;padding:32px;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:20px;margin-bottom:32px;border:2px solid #10b981}.winner-icon{font-size:3rem;margin-bottom:8px}.winner-banner h2{color:#065f46;margin-bottom:8px;font-size:1.2rem}.winner-name{font-size:2.5rem;font-weight:800;color:#047857;margin-bottom:8px}.winner-stats{color:#059669;font-size:.95rem}.round-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.round-indicator{display:flex;align-items:baseline;gap:8px;padding:12px 24px;background:#f1f5f9;border-radius:12px}.round-label{font-size:.9rem;color:#64748b}.round-number{font-size:2rem;font-weight:700;color:#4f46e5}.round-total{font-size:1rem;color:#94a3b8}.play-btn{display:block;margin:0 auto 24px}.round-info{display:flex;justify-content:center;gap:32px;margin-bottom:24px}.info-item{text-align:center}.info-label{display:block;font-size:.85rem;color:#64748b;margin-bottom:4px}.info-value{font-size:1.5rem;font-weight:700;color:#1e293b}.chart-container{position:relative;background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 12px #00000014;margin-bottom:24px}.threshold-line{position:absolute;top:24px;bottom:24px;width:2px;background:#f59e0b;opacity:.7}.threshold-line span{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.75rem;color:#f59e0b;white-space:nowrap}.round-event{display:flex;align-items:center;gap:16px;padding:20px;border-radius:12px;margin-bottom:24px}.round-event.elimination{background:#fef2f2;border:1px solid #fecaca}.round-event.winner{background:#ecfdf5;border:1px solid #a7f3d0}.event-icon{font-size:2rem}.event-content{flex:1}.event-content strong{font-size:1.1rem}.vote-transfers{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.transfer-item{display:inline-block;padding:4px 10px;background:#fff;border-radius:6px;font-size:.85rem;color:#64748b}.all-votes-section{margin-top:32px}.all-votes-list{overflow:hidden}.votes-header{text-align:center;padding:20px;color:#64748b}.votes-header small{color:#94a3b8}.votes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;padding:20px;background:#f8fafc;border-radius:16px;max-height:700px;overflow-y:auto}.ballot-card{background:#fff;border-radius:14px;padding:16px;box-shadow:0 2px 8px #00000014}.ballot-nickname{font-weight:700;font-size:1.1rem;color:#4f46e5;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid #e2e8f0}.ballot-rankings{display:flex;flex-direction:column;gap:10px}.ranking-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#f1f5f9;border-radius:10px;font-size:1rem;color:#475569}.ranking-number{font-weight:700;font-size:1.1rem;color:#4f46e5;min-width:28px}.ranking-image{width:50px;height:50px;object-fit:cover;border-radius:8px;border:2px solid #e2e8f0;flex-shrink:0}.ranking-name{color:#1e293b;font-weight:500;font-size:1rem}@media (max-width: 640px){.round-controls{flex-wrap:wrap}.round-info{flex-direction:column;gap:16px}.winner-name{font-size:1.8rem}.votes-grid{grid-template-columns:1fr}}.admin-dashboard{min-height:100vh;padding-bottom:40px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:20px}.error-container h2{margin-bottom:8px}.error-container p{color:#64748b;margin-bottom:24px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:-20px}.status-card{text-align:center}.status-badge-container{margin-bottom:20px}.status-badge-container .badge{font-size:1rem;padding:8px 20px}.stats-row{display:flex;justify-content:space-around;margin-bottom:24px}.stat-item{text-align:center}.stat-item .stat-value{font-size:2.5rem;font-weight:700;color:#1e293b}.stat-item .stat-label{font-size:.9rem;color:#64748b}.control-buttons{margin-top:16px}.qr-card{text-align:center}.qr-card h3{margin-bottom:16px}.qr-container{cursor:pointer;transition:transform .2s}.qr-container:hover{transform:scale(1.02)}.qr-image{max-width:200px;border-radius:8px}.room-code{margin-top:16px;font-size:1.1rem;color:#64748b}.room-code strong{color:#4f46e5;font-size:1.3rem}.candidates-card h3{margin-bottom:16px}.candidates-list{list-style:none}.candidate-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:8px;margin-bottom:8px}.candidate-order{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#4f46e5;color:#fff;font-weight:600;border-radius:6px;font-size:.9rem}.candidate-item .candidate-info{display:flex;flex-direction:column}.candidate-item .candidate-info strong{color:#1e293b}.candidate-item .candidate-info small{color:#64748b;font-size:.85rem}.results-section{margin-top:40px}.results-section h2{text-align:center;margin-bottom:24px}.fullscreen-qr{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#1e293b,#0f172a);display:flex;align-items:center;justify-content:center;z-index:9999;cursor:pointer}.fullscreen-content{text-align:center;color:#fff}.fullscreen-content h1{font-size:3rem;margin-bottom:32px}.fullscreen-content .qr-code{background:#fff;padding:24px;border-radius:16px;display:inline-block;margin-bottom:24px}.fullscreen-content .qr-code img{width:300px;height:300px}.fullscreen-content .room-code-display{font-size:2rem;font-weight:700;color:#fbbf24;margin-bottom:8px}.fullscreen-content .join-url{font-size:1.2rem;color:#94a3b8;margin-bottom:32px}.fullscreen-content .live-stats{display:flex;justify-content:center;gap:64px;margin-bottom:32px}.fullscreen-content .stat{text-align:center}.fullscreen-content .stat-value{display:block;font-size:4rem;font-weight:700;color:#10b981}.fullscreen-content .stat-label{font-size:1.2rem;color:#94a3b8}.fullscreen-content .click-hint{color:#64748b;font-size:.9rem}@media (max-width: 768px){.dashboard-grid{grid-template-columns:1fr}.fullscreen-content h1{font-size:1.8rem}.fullscreen-content .qr-code img{width:200px;height:200px}.fullscreen-content .live-stats{gap:32px}.fullscreen-content .stat-value{font-size:2.5rem}}.join-room-page{min-height:100vh}.join-form{margin-top:-20px;text-align:center}.code-input{text-align:center;font-size:2rem;font-weight:700;letter-spacing:8px;text-transform:uppercase}.code-input::placeholder{letter-spacing:4px;font-size:1.5rem;font-weight:400}.qr-hint{margin-top:32px;text-align:center;padding:24px;background:#f0f9ff;border-radius:16px;border:1px dashed #38bdf8}.qr-icon{font-size:2.5rem;margin-bottom:12px}.qr-hint p{color:#0369a1;font-size:.95rem;line-height:1.6}.draggable-vote-container{max-width:500px;margin:0 auto}.vote-instructions{text-align:center;margin-bottom:24px;padding:20px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:16px}.instruction-icon{font-size:2.5rem;margin-bottom:8px}.vote-instructions h3{margin-bottom:8px;color:#1e40af}.vote-instructions p{color:#3b82f6;font-size:.95rem;line-height:1.5}.vote-instructions strong{color:#1e40af}.progress-indicator{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f1f5f9;border-radius:12px;margin-bottom:16px}.progress-text{font-weight:600;color:#475569}.reset-btn{padding:6px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.85rem;color:#64748b;cursor:pointer;transition:all .2s ease}.reset-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.clickable-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.clickable-item{display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.clickable-item:hover{border-color:#4f46e5;box-shadow:0 4px 12px #4f46e526}.clickable-item.selected{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.clickable-item.selected:hover{border-color:#059669;box-shadow:0 4px 12px #10b98133}.rank-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;width:50px;height:50px;border-radius:12px;flex-shrink:0;transition:all .2s ease}.rank-badge.active{background:linear-gradient(135deg,#10b981,#059669)}.rank-badge.inactive{background:#e2e8f0}.rank-number{font-size:1.5rem;font-weight:700;color:#fff;line-height:1}.rank-label{font-size:.65rem;color:#ffffffe6;margin-top:2px}.rank-placeholder{font-size:1.5rem;font-weight:700;color:#94a3b8}.candidate-image{flex-shrink:0}.candidate-image img{width:60px;height:60px;object-fit:cover;border-radius:8px;border:2px solid #e2e8f0}.clickable-item.selected .candidate-image img{border-color:#10b981}.candidate-info{flex:1;min-width:0}.candidate-name{font-size:1.1rem;font-weight:600;color:#1e293b;margin-bottom:4px}.candidate-description{font-size:.85rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-check{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#10b981;color:#fff;border-radius:50%;font-size:1.2rem;font-weight:700;flex-shrink:0}.vote-summary{background:#f8fafc;border-radius:12px;padding:16px;margin-bottom:24px}.vote-summary h4{font-size:.9rem;color:#64748b;margin-bottom:12px;text-align:center}.summary-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.summary-item{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border-radius:20px;font-size:.85rem;box-shadow:0 1px 3px #0000001a}.summary-rank{color:#10b981;font-weight:600}.summary-name{color:#1e293b}.submit-vote-btn{margin-top:16px}.submit-vote-btn:disabled{background:#94a3b8;cursor:not-allowed}@media (max-width: 480px){.clickable-item{padding:12px;gap:12px}.rank-badge{width:44px;height:44px}.rank-number{font-size:1.3rem}.candidate-name{font-size:1rem}.selected-check{width:28px;height:28px;font-size:1rem}}.voting-page{min-height:100vh;padding:20px;background:#f8fafc}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.nickname-header{text-align:center;padding:20px;margin-bottom:20px}.nickname-header p{color:#64748b;font-size:.9rem;margin-top:8px}.state-container{max-width:600px;margin:0 auto}.waiting-state{max-width:800px}.waiting-header{text-align:center;margin-bottom:32px}.waiting-badge{display:inline-block;padding:8px 20px;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-radius:24px;font-weight:600;font-size:.9rem;margin-bottom:16px;animation:pulse-badge 2s ease-in-out infinite}@keyframes pulse-badge{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.waiting-header h2{color:#1e293b;font-size:1.8rem;margin-bottom:8px}.waiting-description{color:#64748b;font-size:1rem;margin-bottom:12px}.waiting-notice{color:#94a3b8;font-size:.9rem;padding:12px 20px;background:#f1f5f9;border-radius:12px;display:inline-block}.candidates-preview-grid{background:#fff;border-radius:20px;padding:24px;box-shadow:0 4px 20px #00000014}.candidates-preview-grid h3{text-align:center;color:#64748b;font-size:1rem;font-weight:500;margin-bottom:20px}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.preview-card{background:#f8fafc;border-radius:16px;overflow:hidden;border:2px solid #e2e8f0;transition:all .2s ease}.preview-card:hover{border-color:#4f46e5;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e526}.preview-image{width:100%;aspect-ratio:1;overflow:hidden}.preview-image img{width:100%;height:100%;object-fit:cover}.preview-image-placeholder{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.preview-image-placeholder span{font-size:2.5rem;font-weight:700;color:#4f46e5}.preview-info{padding:12px;text-align:center}.preview-info h4{font-size:.95rem;font-weight:600;color:#1e293b;margin-bottom:4px}.preview-info p{font-size:.8rem;color:#64748b;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.voting-content{padding:20px 0}.room-title{text-align:center;margin-bottom:8px}.room-description{text-align:center;color:#64748b;margin-bottom:24px}.error-message{padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin-bottom:20px;text-align:center}.receipt-content{text-align:center}.receipt-icon{font-size:4rem;margin-bottom:16px}.receipt-content h2{color:#059669;margin-bottom:8px}.receipt-content>p{color:#64748b;margin-bottom:24px}.receipt-details{background:#f8fafc;border-radius:12px;padding:20px;margin-bottom:20px;text-align:left}.receipt-details .label{display:block;font-size:.85rem;color:#64748b;margin-bottom:8px}.receipt-nickname{margin-bottom:20px;text-align:center}.receipt-rankings{margin-bottom:20px}.receipt-rankings ul{list-style:none}.receipt-rankings li{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #e2e8f0}.receipt-rankings li:last-child{border-bottom:none}.receipt-rankings .rank{display:inline-block;padding:4px 10px;background:#4f46e5;color:#fff;border-radius:6px;font-size:.8rem;font-weight:600}.receipt-rankings .name{font-weight:600;color:#1e293b}.receipt-candidate-image{width:40px;height:40px;object-fit:cover;border-radius:6px;border:2px solid #e2e8f0}.receipt-time{text-align:center}.receipt-time .time{display:block;color:#64748b;font-size:.9rem}.receipt-notice{padding:16px;background:#ecfdf5;border-radius:12px;border:1px solid #a7f3d0}.receipt-notice p{color:#047857;font-size:.9rem;line-height:1.6;margin:0}.closed-content{text-align:center}.closed-icon{font-size:4rem;margin-bottom:16px}.closed-content h2{margin-bottom:8px}.closed-content p{color:#64748b}.voted-notice{margin-top:24px;padding:16px;background:#ecfdf5;border-radius:12px;color:#047857}.results-page{min-height:100vh;padding-bottom:40px}.results-page .loading-container,.results-page .error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:20px}.results-page .error-container h2{margin-bottom:8px}.results-page .error-container p{color:#64748b;margin-bottom:24px}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #60a5fa;--secondary: #10b981;--secondary-dark: #059669;--accent: #f59e0b;--danger: #ef4444;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-radius: 12px;--border-radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .25s ease}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:0 20px}.container-sm{max-width:600px;margin:0 auto;padding:0 20px}.card{background:var(--bg-card);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:24px;margin-bottom:20px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:none;border-radius:var(--border-radius);font-size:16px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);gap:8px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:var(--secondary-dark)}.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-large{padding:16px 32px;font-size:18px}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.input-group{margin-bottom:20px}.input-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary)}.input{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:16px;transition:border-color var(--transition-fast)}.input:focus{outline:none;border-color:var(--primary)}.textarea{min-height:100px;resize:vertical}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;margin-bottom:16px}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-primary{color:var(--primary)}.text-success{color:var(--secondary)}.text-danger{color:var(--danger)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}.page-header{position:relative;text-align:center;padding:40px 20px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;margin-bottom:32px}.page-header h1{margin-bottom:8px}.page-header p{opacity:.9;font-size:1.1rem}.back-button{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:#fff;text-decoration:none;font-weight:600;font-size:1rem;padding:8px 16px;border-radius:var(--border-radius);background:#ffffff26;transition:all var(--transition-fast)}.back-button:hover{background:#ffffff40}.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:14px;font-weight:600}.badge-primary{background:var(--primary-light);color:var(--primary-dark)}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.nickname-tag{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:20px;font-weight:600;color:#92400e;font-size:1.1rem}.nickname-tag:before{content:"🐾"}.qr-container{display:flex;flex-direction:column;align-items:center;padding:32px;background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg)}.qr-container img{max-width:300px;border-radius:8px}.qr-code{padding:16px;background:#fff;border-radius:12px}@media (max-width: 768px){h1{font-size:1.75rem}h2{font-size:1.5rem}.card{padding:16px}.btn-large{padding:14px 24px;font-size:16px}}
