.scanner-container{min-height:100vh;padding:20px;max-width:600px;margin:0 auto}.scanner-header{text-align:center;margin-bottom:32px}.scanner-header h1{font-size:32px;font-weight:700;margin-bottom:12px}.org-badge{display:inline-block;padding:6px 16px;border-radius:20px;color:#fff;font-weight:600;font-size:14px}.scanner-start{text-align:center}.scanner-start .btn-large{margin-bottom:48px}.manual-entry{background:var(--card-bg);border-radius:var(--border-radius);padding:24px;box-shadow:var(--box-shadow)}.manual-entry h3{font-size:18px;margin-bottom:16px}.manual-form{display:flex;gap:12px}.manual-form input{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:16px;font-family:monospace;text-transform:uppercase}.manual-form button{padding:12px 24px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.manual-form button:disabled{opacity:.5;cursor:not-allowed}.scanner-active{position:relative;margin-bottom:24px}.scanner-video{width:100%;max-width:500px;border-radius:var(--border-radius);display:block;margin:0 auto 16px}.scanner-overlay{position:absolute;top:0;left:50%;transform:translate(-50%);width:100%;max-width:500px;height:calc(100% - 60px);display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.scanner-frame{width:250px;height:250px;border:3px solid var(--primary-color);border-radius:16px;box-shadow:0 0 0 10000px #00000080}.scanner-overlay p{color:#fff;font-weight:600;margin-top:20px;text-shadow:0 2px 4px rgba(0,0,0,.5)}.scan-loading{text-align:center;padding:48px}.scan-result{background:var(--card-bg);border-radius:var(--border-radius);padding:32px;box-shadow:var(--box-shadow-lg);text-align:center;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.scan-result.success{border-top:4px solid var(--success-color)}.scan-result.error{border-top:4px solid var(--danger-color)}.result-icon{font-size:64px;margin-bottom:16px}.scan-result h2{font-size:24px;margin-bottom:8px}.result-message{font-size:16px;color:var(--secondary-color);margin-bottom:24px}.ticket-details{background:var(--light-color);border-radius:8px;padding:20px;margin-bottom:24px;text-align:left}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color)}.detail-row:last-child{border-bottom:none}.detail-row span{color:var(--secondary-color);font-size:14px}.detail-row strong{font-weight:600}.scan-history{background:var(--card-bg);border-radius:var(--border-radius);padding:24px;box-shadow:var(--box-shadow);margin-top:32px}.scan-history h3{font-size:18px;margin-bottom:16px}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--light-color);border-radius:8px}.history-info{display:flex;flex-direction:column;gap:4px}.history-info strong{font-weight:600;font-size:14px}.history-time{font-size:12px;color:var(--secondary-color)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:24px;margin-bottom:24px}.campaign-list,.scan-list{display:flex;flex-direction:column;gap:12px}.campaign-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--light-color);border-radius:8px;text-decoration:none;color:var(--dark-color);transition:all .2s}.campaign-item:hover{background:var(--border-color);transform:translate(4px)}.campaign-info{display:flex;flex-direction:column;gap:6px}.campaign-info strong{font-weight:600}.campaign-stats{text-align:right}.campaign-stats span{font-weight:600;font-size:18px}.campaign-stats small{display:block;font-size:12px;color:var(--secondary-color)}@media (max-width: 768px){.dashboard-grid{grid-template-columns:1fr}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--box-shadow-lg);max-width:450px;width:100%}.login-header{text-align:center;padding:40px 40px 32px}.login-header h1{font-size:36px;font-weight:700;margin-bottom:8px}.login-header p{color:var(--secondary-color);font-size:14px}.login-form{padding:0 40px 32px}.login-footer{background:var(--light-color);padding:24px 40px;border-radius:0 0 var(--border-radius) var(--border-radius);border-top:1px solid var(--border-color)}.login-footer p{font-weight:600;margin-bottom:12px;font-size:14px}.demo-creds{display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--secondary-color)}.demo-creds strong{color:var(--dark-color)}.campaigns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.campaign-card{background:var(--card-bg);border-radius:var(--border-radius);padding:24px;box-shadow:var(--box-shadow);transition:transform .2s,box-shadow .2s}.campaign-card:hover{transform:translateY(-2px);box-shadow:var(--box-shadow-lg)}.campaign-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:16px}.campaign-header h3{font-size:18px;font-weight:600;margin-bottom:6px}.campaign-description{font-size:14px;color:var(--secondary-color);margin:0}.campaign-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.campaign-stats .stat{text-align:center}.campaign-stats .stat strong{display:block;font-size:24px;font-weight:700;margin-bottom:4px}.campaign-stats .stat span{font-size:12px;color:var(--secondary-color)}.campaign-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;font-size:13px}.status-badge{padding:4px 12px;border-radius:12px;font-weight:600;text-transform:uppercase;font-size:11px}.status-active{background:#d4edda;color:#155724}.status-draft{background:#e2e3e5;color:#383d41}.status-paused{background:#fff3cd;color:#856404}.campaign-meta .date{color:var(--secondary-color)}.campaign-actions{display:flex;gap:8px}.campaign-actions button,.campaign-actions a{flex:1}@media (max-width: 768px){.campaigns-grid{grid-template-columns:1fr}}:root{--primary-color: #007BFF;--secondary-color: #6C757D;--success-color: #28A745;--danger-color: #DC3545;--warning-color: #FFC107;--info-color: #17A2B8;--light-color: #F8F9FA;--dark-color: #343A40;--bg-color: #F5F7FA;--card-bg: #FFFFFF;--border-color: #E1E8ED;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--border-radius: 12px;--box-shadow: 0 2px 8px rgba(0,0,0,.08);--box-shadow-lg: 0 4px 16px rgba(0,0,0,.12)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--dark-color);line-height:1.6;-webkit-font-smoothing:antialiased}.app{min-height:100vh}.loading-screen,.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background:var(--card-bg);border-bottom:1px solid var(--border-color);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--box-shadow)}.dashboard-header h1{font-size:24px;font-weight:700;margin:0;display:flex;align-items:center;gap:8px}.header-left{display:flex;align-items:center;gap:16px}.header-right{display:flex;align-items:center;gap:12px}.org-name{font-size:14px;color:var(--secondary-color);font-weight:500}.user-name{font-size:14px;font-weight:500}.back-btn{padding:8px 16px;background:var(--light-color);border-radius:var(--border-radius);text-decoration:none;color:var(--dark-color);font-weight:500;transition:background .2s}.back-btn:hover{background:var(--border-color)}.dashboard-nav{background:var(--card-bg);border-bottom:1px solid var(--border-color);padding:0 24px;display:flex;gap:8px;overflow-x:auto}.nav-item{padding:12px 16px;text-decoration:none;color:var(--secondary-color);font-weight:500;border-bottom:3px solid transparent;transition:all .2s;white-space:nowrap}.nav-item:hover{color:var(--primary-color)}.nav-item.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.dashboard-content{flex:1;padding:24px;max-width:1400px;width:100%;margin:0 auto}.card{background:var(--card-bg);border-radius:var(--border-radius);padding:24px;box-shadow:var(--box-shadow);margin-bottom:24px}.card h3{font-size:18px;font-weight:600;margin-bottom:16px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--card-bg);border-radius:var(--border-radius);padding:20px;box-shadow:var(--box-shadow);display:flex;align-items:center;gap:16px}.stat-icon{font-size:32px;opacity:.8}.stat-info{flex:1}.stat-value{font-size:28px;font-weight:700;line-height:1;margin-bottom:4px}.stat-label{font-size:14px;color:var(--secondary-color);font-weight:500}.btn-primary,.btn-secondary,.btn-warning{padding:10px 20px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:14px;text-decoration:none;display:inline-block;text-align:center}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:#0056b3;transform:translateY(-1px);box-shadow:var(--box-shadow)}.btn-secondary{background:var(--light-color);color:var(--dark-color)}.btn-secondary:hover{background:var(--border-color)}.btn-warning{background:var(--warning-color);color:var(--dark-color)}.btn-sm{padding:6px 12px;font-size:13px}.btn-large{padding:16px 32px;font-size:18px}.btn-block{width:100%;display:block}.btn-link{color:var(--primary-color);text-decoration:none;font-weight:600;font-size:14px}.badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase}.badge-success{background:#d4edda;color:#155724}.badge-error,.badge-invalid,.badge-expired{background:#f8d7da;color:#721c24}.badge-already_redeemed,.badge-redeemed{background:#fff3cd;color:#856404}.badge-event{background:#d1ecf1;color:#0c5460}.badge-redemption,.badge-freebie{background:#f8d7da;color:#721c24}.badge-active{background:#d4edda;color:#155724}.badge-draft{background:#e2e3e5;color:#383d41}.badge-paused{background:#fff3cd;color:#856404}table{width:100%;border-collapse:collapse}thead{background:var(--light-color)}th{padding:12px;text-align:left;font-weight:600;font-size:13px;color:var(--secondary-color);text-transform:uppercase;letter-spacing:.5px}td{padding:12px;border-top:1px solid var(--border-color)}tr:hover{background:var(--light-color)}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:600;margin-bottom:6px;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff1a}.form-group small{display:block;margin-top:4px;color:var(--secondary-color);font-size:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-weight:500}.alert-error{background:#f8d7da;color:#721c24}.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;padding:20px}.modal{background:var(--card-bg);border-radius:var(--border-radius);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--box-shadow-lg)}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:20px;font-weight:600;margin:0}.close-btn{background:none;border:none;font-size:32px;line-height:1;cursor:pointer;color:var(--secondary-color);padding:0;width:32px;height:32px}.modal form{padding:24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border-color)}.empty-state{text-align:center;padding:48px 24px;color:var(--secondary-color)}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-state h3{font-size:20px;margin-bottom:8px;color:var(--dark-color)}.empty-state p{margin-bottom:20px}@media (max-width: 768px){.dashboard-header{padding:12px 16px}.dashboard-header h1{font-size:20px}.dashboard-nav{padding:0 16px}.dashboard-content{padding:16px}.stats-grid,.form-row{grid-template-columns:1fr}}
