*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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}#root{width:100%;min-height:100vh}.home-screen{min-height:100vh;background:linear-gradient(135deg,#312e81,#4338ca,#6d28d9);display:flex;flex-direction:column}.nav-bar{display:flex;align-items:center;justify-content:space-between;padding:24px 48px}.nav-brand{display:flex;align-items:center;gap:12px}.nav-brand-icon{width:32px;height:32px;color:#fff}.nav-brand-text{font-size:24px;font-weight:800;color:#fff;letter-spacing:-.5px;margin:0}.nav-avatar{width:44px;height:44px;border-radius:22px;border:2px solid rgba(255,255,255,.2);background:linear-gradient(135deg,#4f46e5,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:700;text-transform:uppercase}.nav-right{display:flex;align-items:center;gap:12px}.nav-logout{width:44px;height:44px;border-radius:22px;border:2px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .1s;padding:0}.nav-logout:hover{background:#ffffff2e}.nav-logout:active{transform:scale(.95)}.welcome-header{background:#ffffff14;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:33px 41px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 4px 30px #0000001a;width:100%}.welcome-info{display:flex;flex-direction:column;gap:6px}.greeting{font-size:28px;font-weight:700;color:#fff;margin:0;letter-spacing:-.5px}.subtitle{font-size:16px;color:#fffc;margin:0;font-weight:400}.btn-push-toggle{display:inline-flex;align-items:center;gap:8px;background:#fff;border:none;color:#4b3bff;padding:12px 24px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0;box-shadow:0 4px 15px #0000001a;font-family:inherit}.btn-push-toggle:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #00000026}.btn-push-toggle:disabled{opacity:.5;cursor:not-allowed}.push-active-badge{display:inline-flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:50%;width:36px;height:36px;color:#fffc;flex-shrink:0}.home-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:40px 20px 80px;gap:48px;max-width:640px;width:100%;margin:0 auto}.card-tabs{display:flex;gap:.5rem;overflow-x:auto;padding:0 .25rem 1.5rem;-webkit-overflow-scrolling:touch;scrollbar-width:none;width:100%}.card-tabs::-webkit-scrollbar{display:none}.card-tab{flex-shrink:0;padding:.5rem 1.25rem;border-radius:2rem;border:2px solid rgba(255,255,255,.4);background:#ffffff26;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:inherit}.card-tab:hover{background:#ffffff40}.card-tab.active{background:#fff;color:#4b3bff;border-color:#fff;font-weight:600;box-shadow:0 4px 12px #00000026}.card-container{width:100%;display:flex;justify-content:center}.loyalty-card{background:#fff;border-radius:32px;padding:0;box-shadow:0 25px 50px -12px #00000040;width:100%;overflow:hidden;position:relative}.card-gradient-bar{height:8px;background:linear-gradient(135deg,#4f46e5,#8b5cf6);width:100%}.card-inner{padding:56px 56px 48px}.card-header{text-align:center;margin-bottom:0}.card-header h2{font-size:32px;color:#222224;margin:0 0 8px;font-weight:800;letter-spacing:-.5px}.merchant-name{font-size:18px;color:#9aa0ab;margin:0;font-weight:400}.reward-badge{display:inline-flex;align-items:center;gap:10px;background:#efe9ff;color:#4b3bff;padding:12px 24px;border-radius:12px;font-size:16px;font-weight:700;margin-top:24px}.reward-badge-icon{width:20px;height:20px}.stamps-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:48px;margin-bottom:48px}.stamp{aspect-ratio:1;border-radius:20px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:28px;color:#94a3b8;background:#f8fafc;border:3px dashed #cbd5e1;transition:all .3s ease;position:relative}.stamp.filled{background:linear-gradient(135deg,#4f46e5,#8b5cf6);border:none;color:#fff;font-size:0;box-shadow:0 10px 20px -5px #6366f166}.stamp.filled:before{content:"";position:absolute;inset:0;border-radius:20px;box-shadow:inset 0 2px 4px #fff3;pointer-events:none}.stamp-check{width:40px;height:40px}.progress-info{display:flex;flex-direction:column;gap:16px}.stamps-count{text-align:center;font-size:16px;color:#222224;margin:0;font-weight:700}.progress-bar{height:12px;background:#f3f4f6;border-radius:12px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000000d}.progress-fill{height:100%;background:linear-gradient(135deg,#4f46e5,#8b5cf6);transition:width .5s ease;border-radius:12px}.reward-available{margin-top:1.5rem;padding:1rem;background:linear-gradient(135deg,#4f46e5,#8b5cf6);border-radius:1rem;text-align:center;color:#fff}.reward-available-icon{font-size:2rem;display:block;margin-bottom:.5rem}.reward-available p{margin:0;font-weight:600;font-size:.95rem}.actions{padding:40px 0 0;display:flex;justify-content:center}.btn-primary{background:#fff;color:#4b3bff;border:none;padding:20px 48px;font-size:18px;font-weight:700;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:12px;box-shadow:0 20px 25px -5px #00000026,0 8px 10px -6px #0000001a;transition:all .3s ease;position:relative;font-family:inherit}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 25px 30px -5px #0003,0 10px 15px -6px #00000026}.btn-primary:active{transform:translateY(0)}.btn-icon{width:24px;height:24px;color:#4b3bff}.loading,.error{display:flex;align-items:center;justify-content:center;min-height:100vh;color:#fff;font-size:1.25rem;font-weight:500}.error{color:#fcc}.empty-cards-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;color:#fff;flex:1}.empty-cards-state h2{font-size:1.5rem;font-weight:600;margin:0 0 .75rem}.empty-cards-state p{font-size:1rem;opacity:.85;margin:0;max-width:320px;line-height:1.5}.id-qr-wrapper{background:#fff;padding:1.25rem;border-radius:1rem;margin:1.5rem 0 1rem;box-shadow:0 10px 30px #0003;display:inline-flex;align-items:center;justify-content:center}.id-qr-hint{font-size:.875rem;opacity:.7;margin-top:.5rem}@media(max-width:768px){.nav-bar{padding:16px 20px}.nav-brand-text{font-size:20px}.nav-avatar{width:36px;height:36px;font-size:14px}.welcome-header{padding:24px 20px;flex-direction:column;gap:16px;align-items:flex-start}.greeting{font-size:24px}.home-content{padding:24px 16px 60px}.card-inner{padding:32px 20px 28px}.card-header h2{font-size:24px}.merchant-name{font-size:15px}.stamps-grid{gap:10px;margin-top:32px;margin-bottom:32px}.stamp-check{width:28px;height:28px}.btn-primary{padding:16px 32px;font-size:16px}.reward-badge{font-size:14px;padding:10px 18px}}.qr-modal-overlay{position:fixed;inset:0;background:#0f172ae6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.qr-modal-content{background:#fff;border-radius:12px;padding:40px 32px;max-width:400px;width:100%;position:relative;animation:slideUp .3s ease;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;align-items:center}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.qr-modal-close{position:absolute;top:16px;right:16px;background:#f3f4f6;border:none;width:32px;height:32px;border-radius:16px;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s ease;line-height:1;padding:0}.qr-modal-close:hover{background:#e5e7eb;transform:scale(1.1)}.qr-modal-header{text-align:center;margin-bottom:24px}.qr-modal-header h2{font-size:20px;color:#22212a;margin:0 0 8px;font-weight:600}.qr-subtitle{font-size:14px;color:#9fa3b2;margin:0}.qr-code-container{display:flex;justify-content:center;margin-bottom:24px}.qr-code-wrapper{padding:16px;background:#fff;border-radius:8px;box-shadow:0 4px 24px #0000000f;display:inline-block}.qr-info{text-align:center;margin-bottom:24px}.qr-timer{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(to right,#6366f1,#9333ea);color:#fff;padding:10px 20px;border-radius:9999px;font-size:14px;font-weight:600;margin-bottom:24px}.timer-icon{font-size:1rem;display:flex;align-items:center}.timer-text{line-height:1}.qr-hint{font-size:13px;color:#9fa3b2;margin:0;line-height:1.5;max-width:280px}.btn-close-modal{width:100%;background:linear-gradient(to right,#6366f1,#8b5cf6);color:#fff;border:none;padding:16px 24px;font-size:16px;font-weight:700;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.btn-close-modal:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.btn-close-modal:active{transform:translateY(0)}.qr-modal-success{animation:scaleIn .4s ease}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.success-animation{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 0}.success-check-icon{width:72px;height:72px}.success-circle{stroke-dasharray:151;stroke-dashoffset:151;animation:drawCircle .5s ease forwards}.success-tick{stroke-dasharray:40;stroke-dashoffset:40;animation:drawTick .3s .4s ease forwards}@keyframes drawCircle{to{stroke-dashoffset:0}}@keyframes drawTick{to{stroke-dashoffset:0}}.success-title{font-size:22px;font-weight:700;color:#22c55e;margin:0;text-align:center}.success-subtitle{font-size:14px;color:#6b7280;margin:0;text-align:center}@media(max-width:480px){.qr-modal-content{padding:32px 24px}.qr-modal-header h2{font-size:18px}.qr-code-wrapper{padding:12px}}.staff-layout{display:flex;min-height:100vh;background:#f5f7fb;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.nav-item{width:48px;height:48px;border:none;background:transparent;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.main-content{flex:1;padding:32px 40px;overflow-y:auto;min-width:0}.top-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.header-left h1{margin:0;font-size:26px;font-weight:700;color:#0f172a}.header-subtitle{display:block;margin-top:6px;font-size:14px;color:#9ca3af}.header-right{display:flex;align-items:center;gap:16px}.location-select{display:flex;align-items:center;gap:8px;background:#fff;padding:9px 17px;border-radius:6px;border:1px solid rgba(0,0,0,.08)}.location-select label{font-size:14px;color:#9ca3af;font-weight:500;white-space:nowrap}.location-select input,.location-select select{border:none;outline:none;font-size:14px;color:#0f172a;background:transparent;width:60px}.location-select select{width:auto;cursor:pointer}.btn-logout{background:#f87171;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-weight:700;font-size:14px;cursor:pointer;transition:background .2s}.btn-logout:hover{background:#ef4444}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:24px}.stat-card{background:#fff;border-radius:14px;padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 1px 3px #0000000a,0 1px 2px #0000000f}.stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:28px;height:28px}.stat-icon.blue{background:#eff6ff;color:#3b82f6}.stat-icon.orange{background:#fff7ed;color:#f97316}.stat-icon.green{background:#f0fdf4;color:#22c55e}.stat-info{display:flex;flex-direction:column;gap:2px}.stat-value{font-size:28px;font-weight:700;color:#0f172a;line-height:1.2}.stat-label{font-size:14px;color:#9ca3af}.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.scanner-card,.activity-card{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 3px #0000000a,0 1px 2px #0000000f}.scanner-card h2,.activity-card h2,.enroll-section h2{margin:0 0 4px;font-size:18px;font-weight:600;color:#0f172a}.scanner-desc{margin:0 0 20px;font-size:14px;color:#9ca3af}.scanner-placeholder{background:#fafbfc;border:2px dashed #d0d5dd;border-radius:12px;padding:50px;display:flex;flex-direction:column;align-items:center;gap:16px;cursor:pointer;transition:all .2s}.scanner-placeholder:hover{border-color:#667eea;background:#f5f7ff}.qr-icon{width:48px;height:48px;color:#667eea}.qr-icon svg{width:100%;height:100%}.scanner-placeholder span{font-size:15px;color:#667eea;font-weight:500}.scanner-active{display:flex;flex-direction:column;gap:12px}#qr-reader{border-radius:12px;overflow:hidden}.btn-cancel{background:#f87171;color:#fff;border:none;padding:12px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.btn-cancel:hover{background:#ef4444}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.result-card{margin-top:20px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:12px;padding:21px}.result-card.with-reward{background:#fef3c7;border-color:#fcd34d}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.result-status{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px;color:#059669}.result-status.redeem{color:#d97706}.result-status-icon{width:20px;height:20px}.result-time{font-size:13px;color:#9ca3af}.result-body{display:flex;flex-direction:column;gap:8px}.result-row{display:flex;justify-content:space-between;font-size:14px}.result-row span{color:#6b7280}.result-row strong{color:#0f172a}.progress-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s}.reward-alert{background:#fff;padding:10px;border-radius:8px;text-align:center;font-weight:600;color:#d97706}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.activity-count{font-size:13px;color:#9ca3af}.activity-list{display:flex;flex-direction:column;gap:24px;max-height:400px;overflow-y:auto}.empty-state{text-align:center;padding:40px;color:#9ca3af}.empty-state-icon{width:48px;height:48px;margin:0 auto 12px;display:block}.empty-state p{margin:0;font-size:14px}.activity-item{display:flex;align-items:center;gap:16px;padding:16px;background:#f8fafc;border-radius:12px}.activity-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon svg{width:20px;height:20px}.activity-icon.stamp{background:#eff6ff;color:#3b82f6}.activity-icon.reward{background:#fff7ed;color:#f97316}.activity-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.activity-title{font-weight:600;font-size:14px;color:#0f172a}.activity-meta{font-size:13px;color:#9ca3af}.activity-time{font-size:13px;color:#9ca3af;white-space:nowrap;flex-shrink:0}.activity-list::-webkit-scrollbar{width:6px}.activity-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.activity-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.enroll-section{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 3px #0000000a,0 1px 2px #0000000f}.enroll-desc{margin:0 0 20px;font-size:14px;color:#9ca3af}.enroll-scan-area{margin-bottom:24px}.enroll-scan-area .scanner-active{max-width:500px}#enroll-qr-reader{border-radius:12px;overflow:hidden}.enroll-divider{display:flex;align-items:center;gap:16px;margin-bottom:16px;color:#9ca3af;font-size:14px}.enroll-divider:before,.enroll-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.enroll-form{margin-bottom:24px}.enroll-input-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.enroll-input-group label{font-size:14px;font-weight:500;color:#374151}.enroll-input-group input{width:140px;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-size:14px;transition:border-color .2s,box-shadow .2s;color:#0f172a}.enroll-input-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1f}.btn-search{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .2s,transform .1s}.btn-search:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-search:disabled{opacity:.5;cursor:not-allowed}.enroll-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;font-weight:500}.enroll-programs-title{margin:0 0 12px;font-size:15px;font-weight:600;color:#0f172a}.enroll-programs-list{display:flex;flex-direction:column;gap:12px}.enroll-program-card{display:flex;align-items:center;justify-content:space-between;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:21px 25px;transition:border-color .2s,box-shadow .2s}.enroll-program-card:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.enroll-program-info{flex:1;min-width:0}.enroll-program-info h3{margin:0 0 8px;font-size:16px;font-weight:600;color:#0f172a}.enroll-program-desc{margin:0 0 8px;font-size:13px;color:#6b7280;line-height:1.5}.enroll-program-meta{display:flex;gap:12px;flex-wrap:wrap}.enroll-program-meta span{font-size:13px;color:#6b7280;background:#fff;padding:5px 13px;border-radius:20px;border:1px solid #e2e8f0}.btn-enroll{background:#059669;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;flex-shrink:0;margin-left:20px;transition:background .2s,transform .1s}.btn-enroll:hover:not(:disabled){background:#047857;transform:translateY(-1px)}.btn-enroll:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1100px){.content-grid{grid-template-columns:1fr}}@media(max-width:900px){.stats-row{grid-template-columns:1fr}.enroll-program-card{flex-direction:column;align-items:stretch;gap:12px}.btn-enroll{margin-left:0}}@media(max-width:768px){.sidebar{width:64px;padding:16px 0}.sidebar-nav{gap:16px}.nav-item{width:40px;height:40px}.nav-item svg{width:20px;height:20px}.logo-icon-wrap{width:36px;height:36px}.logo-icon-wrap svg{width:20px;height:20px}.main-content{padding:20px}.top-header{flex-direction:column;gap:16px;align-items:flex-start}.header-right{width:100%;flex-wrap:wrap}}.sidebar{width:80px;background:linear-gradient(180deg,#667eea,#764ba2);display:flex;flex-direction:column;align-items:center;padding:24px 0;flex-shrink:0}.sidebar-logo{margin-bottom:24px}.logo-icon-wrap{width:44px;height:44px;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center}.logo-icon-wrap svg{width:24px;height:24px;color:#fff}.sidebar-nav{display:flex;flex-direction:column;gap:24px;flex:1}.nav-item{width:48px;height:48px;border:none;background:transparent;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;text-decoration:none;color:inherit}.nav-item svg{width:24px;height:24px;color:#ffffffb3;transition:color .2s}.nav-item:hover{background:#ffffff26}.nav-item:hover svg{color:#fff}.nav-item.active{background:#ffffff40}.nav-item.active svg{color:#fff}.sidebar-bottom{margin-top:auto}@media(max-width:720px){.sidebar{width:64px;padding:16px 0}.sidebar-nav{gap:16px}.nav-item{width:40px;height:40px}.nav-item svg{width:20px;height:20px}.logo-icon-wrap{width:36px;height:36px}.logo-icon-wrap svg{width:20px;height:20px}}.app-container{min-height:100vh}.mode-selector{position:fixed;top:20px;right:20px;display:flex;gap:10px;z-index:1000;background:#fffffff2;padding:10px;border-radius:12px;box-shadow:0 4px 6px #0000001a}.mode-btn{padding:8px 16px;border:2px solid transparent;border-radius:6px;background:#f0f0f0;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;color:#666}.mode-btn:hover{background:#e0e0e0}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}@media(max-width:768px){.mode-selector{top:10px;right:10px;padding:8px;gap:8px}.mode-btn{padding:6px 12px;font-size:12px}}.admin-layout{display:flex;min-height:100vh;background:#f5f7fb;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.admin-main{flex:1;padding:32px 40px;overflow-y:auto;min-width:0}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.admin-header-info{display:flex;flex-direction:column;gap:4px}.admin-title{font-size:28px;font-weight:800;color:#1f2937;margin:0;letter-spacing:-.5px}.admin-subtitle{font-size:14px;color:#6b7280;margin:0}.admin-header-extra{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.admin-content{display:flex;flex-direction:column;gap:12px}.admin-btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .05s,box-shadow .15s;font-family:inherit}.admin-btn:disabled{opacity:.55;cursor:not-allowed}.admin-btn-primary{background:linear-gradient(90deg,#7c3aed,#3b82f6);color:#fff;box-shadow:0 2px 6px #7c3aed4d}.admin-btn-primary:not(:disabled):hover{box-shadow:0 4px 10px #7c3aed66}.admin-btn-secondary{background:#f1f5f9;color:#1f2937}.admin-btn-secondary:not(:disabled):hover{background:#e2e8f0}.admin-btn-ghost{background:transparent;color:#475569;padding:6px 12px}.admin-btn-ghost:not(:disabled):hover{background:#f1f5f9}.admin-btn-danger{background:#fee2e2;color:#b91c1c}.admin-btn-danger:not(:disabled):hover{background:#fecaca}.admin-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.admin-field label{font-size:13px;font-weight:600;color:#374151}.admin-field input,.admin-field textarea,.admin-field select{border:1px solid #d1d5db;border-radius:8px;padding:10px 12px;font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;background:#fff;color:#1f2937}.admin-field input:focus,.admin-field textarea:focus,.admin-field select:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed26}.admin-field textarea{resize:vertical;min-height:80px}.admin-field .field-error{color:#dc2626;font-size:12px}.admin-form-row{display:flex;gap:12px}.admin-form-row>*{flex:1}.admin-empty{text-align:center;padding:48px 24px;color:#6b7280;background:#fff;border:1px dashed #cbd5e1;border-radius:12px}.admin-error-banner{background:#fee2e2;color:#b91c1c;padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:16px}.admin-loading{padding:24px;text-align:center;color:#6b7280}.admin-filter-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:#475569;cursor:pointer;-webkit-user-select:none;user-select:none}@media(max-width:720px){.admin-main{padding:20px 16px}.admin-title{font-size:22px}.admin-form-row{flex-direction:column}}.admin-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;transition:box-shadow .15s,border-color .15s}.admin-card:hover{border-color:#c7d2fe;box-shadow:0 4px 12px #6366f114}.admin-card.is-dimmed{opacity:.55;background:#fafafa}.admin-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.admin-card-headline{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-card-title{font-size:16px;font-weight:700;color:#1f2937;margin:0}.admin-card-badges{display:flex;align-items:center;gap:6px}.admin-card-subtitle{font-size:13px;color:#6b7280;margin:0}.admin-card-meta{font-size:13px;color:#4b5563;margin-top:4px;display:flex;flex-wrap:wrap;gap:12px}.admin-card-meta span{display:inline-flex;align-items:center;gap:4px}.admin-card-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-card-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;border-radius:12px}.admin-card-badge.is-active{background:#dcfce7;color:#16a34a}.admin-card-badge.is-inactive{background:#fee2e2;color:#dc2626}.admin-card-badge.is-info{background:#e0e7ff;color:#4338ca}@media(max-width:720px){.admin-card{flex-direction:column;align-items:stretch}.admin-card-actions{justify-content:flex-end}}.modal-backdrop{position:fixed;inset:0;background:#0f0f1e8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.modal-box{background:#fff;border-radius:16px;max-width:560px;width:100%;max-height:calc(100vh - 32px);display:flex;flex-direction:column;box-shadow:0 20px 60px #00000059;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #f1f5f9}.modal-title{font-size:20px;font-weight:700;color:#1f2937;margin:0}.modal-close{width:32px;height:32px;border:none;background:#f1f5f9;border-radius:16px;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;padding:0}.modal-close:hover{background:#e2e8f0}.modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid #f1f5f9;background:#fafafa}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-row.is-disabled{opacity:.5;cursor:not-allowed}.toggle-text{display:flex;flex-direction:column;gap:2px;flex:1}.toggle-label{font-size:14px;color:#1f2937;font-weight:600}.toggle-description{font-size:12px;color:#6b7280}.toggle-switch{position:relative;width:44px;height:24px;background:#cbd5e1;border-radius:12px;transition:background .2s;flex-shrink:0}.toggle-switch.is-on{background:#7c3aed}.toggle-switch input{position:absolute;opacity:0;inset:0;width:100%;height:100%;margin:0;cursor:inherit}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:10px;box-shadow:0 1px 3px #0003;transition:transform .2s}.toggle-switch.is-on .toggle-knob{transform:translate(20px)}
