:root{--primary:#ff6b9d;--primary-dark:#e25b89;--secondary:#7e57c2;--bg:#f7f7fb;--surface:#fff;--text:#2d2b55;--muted:#6b6a82;--border:#e5e4f0;--success:#2eaf62;--danger:#e25555;--shadow:0 12px 30px #12122b14;--radius:16px;font-family:Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);width:260px;height:100vh;padding:24px 18px;position:sticky;top:0}.sidebar-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.sidebar-logo{color:var(--primary);font-size:20px;font-weight:700}.sidebar-close{color:var(--muted);cursor:pointer;background:0 0;border:none;display:none}.sidebar-nav{flex-direction:column;gap:8px;display:flex}.sidebar-link{color:var(--muted);border-radius:10px;padding:10px 12px;font-weight:500}.sidebar-link-active{color:var(--primary);background:#ff6b9d1f}.app-content{flex-direction:column;flex:1;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 28px;display:flex}.topbar-menu{color:var(--secondary);cursor:pointer;background:#7e57c21a;border:none;border-radius:10px;padding:8px 14px;font-weight:600;display:none}.topbar-info{align-items:center;gap:16px;display:flex}.topbar-label{margin:0;font-weight:600}.topbar-sub{color:var(--muted);margin:0;font-size:14px}.app-main{padding:28px}.page{flex-direction:column;gap:20px;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-title{margin:0;font-size:28px}.page-back{color:var(--muted);align-items:center;gap:6px;margin-bottom:6px;font-size:14px;display:inline-flex}.page-subtitle{color:var(--muted);margin:6px 0 0}.page-action{gap:8px;display:flex}.section-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.section-card-title{margin:0 0 16px;font-size:18px}.grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;display:grid}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;display:grid}.metric-card{background:#ff6b9d14;border-radius:14px;gap:6px;padding:16px;display:grid}.metric-card strong{font-size:20px}.list{color:var(--muted);gap:8px;margin:0;padding-left:16px;display:grid}.button{cursor:pointer;border:none;border-radius:12px;padding:10px 16px;font-weight:600;transition:all .2s}.link-button{justify-content:center;align-items:center;gap:6px;display:inline-flex}.inline-field{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.button-primary{background:var(--primary);color:#fff}.button-primary:hover{background:var(--primary-dark)}.button-secondary{color:var(--secondary);background:#7e57c21f}.button-ghost{color:var(--muted);background:0 0}.field{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.field-label{color:var(--muted);font-size:14px}.field-input{border:1px solid var(--border);background:#fff;border-radius:10px;padding:10px 12px;font-size:14px}.field-input-error{border-color:var(--danger)}.field-textarea{resize:vertical;min-height:110px}.field-helper{color:var(--muted);font-size:12px}.field-error{color:var(--danger);font-size:12px}.auth-layout{background:linear-gradient(135deg,#ff6b9d33,#7e57c233);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--surface);border-radius:var(--radius);width:min(480px,100%);box-shadow:var(--shadow);gap:20px;padding:32px;display:grid}.auth-brand{text-align:center}.auth-logo{color:var(--primary);font-size:24px;font-weight:700;display:inline-block}.auth-form h2{margin:0 0 8px}.auth-form p{color:var(--muted);margin:0 0 16px}.auth-links{color:var(--muted);justify-content:space-between;font-size:14px;display:flex}.form-error{color:var(--danger);background:#e255551a;border-radius:10px;margin-bottom:12px;padding:10px 12px}.form-success{color:var(--success);background:#2eaf621a;border-radius:10px;margin-bottom:12px;padding:10px 12px}.form{gap:12px;display:grid}.form-actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;display:flex}.quick-actions{flex-wrap:wrap;gap:10px;display:flex}.checkbox-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;display:grid}.checkbox-item{background:#7e57c214;border-radius:10px;align-items:center;gap:8px;padding:8px 10px;font-size:14px;display:flex}.pagination{justify-content:space-between;align-items:center;gap:12px;padding:12px 0 24px;display:flex}.pagination-info{color:var(--muted);font-size:14px}.empty-state{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.empty-state h3{margin:0 0 6px}.empty-state p{color:var(--muted);margin:0}.empty-state-action{gap:8px;display:flex}.centered{text-align:center;min-height:60vh;color:var(--muted);place-items:center;display:grid}.muted{color:var(--muted);margin-top:12px}.table-wrap{width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:14px}.table th,.table td{border-bottom:1px solid var(--border);text-align:left;padding:10px 12px}.badge{color:var(--secondary);background:#7e57c226;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.color-dot{border-radius:999px;width:10px;height:10px;margin-right:6px;display:inline-block}.report-grid{gap:12px;display:grid}.report-grid span{color:var(--muted);font-size:12px;display:block}.report-grid strong{margin-top:4px;display:block}.loyalty-balance{background:#ff6b9d14;border-radius:12px;margin-top:16px;padding:12px}@media (width<=900px){.sidebar{z-index:10;transition:left .2s;position:fixed;top:0;left:-100%}.sidebar.sidebar-open{left:0}.sidebar-close,.topbar-menu{display:inline-flex}.page-header{flex-direction:column}}@media (width<=720px){.app-main{padding:20px 16px}.table thead{display:none}.table,.table tbody,.table tr,.table td{width:100%;display:block}.table tr{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:12px;padding:10px}.table td{border-bottom:none;justify-content:space-between;gap:12px;padding:8px 0;display:flex}.table td:before{content:attr(data-label);color:var(--muted);font-weight:600}}.modal-overlay{z-index:50;background:#1a1a288c;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);width:min(640px,100%);box-shadow:var(--shadow);border-radius:18px;gap:12px;max-height:90vh;display:grid;overflow:hidden}.modal-sm{width:min(420px,100%)}.modal-lg{width:min(860px,100%)}.modal-header{justify-content:space-between;align-items:center;padding:16px 20px 0;display:flex}.modal-header h3{margin:0}.modal-close{cursor:pointer;background:0 0;border:none;font-size:18px}.modal-body{padding:0 20px 20px;overflow-y:auto}.modal-toolbar{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.modal-list{gap:10px;margin-top:12px;display:grid}.modal-list-item{border:1px solid var(--border);text-align:left;cursor:pointer;background:#fff;border-radius:12px;gap:4px;width:100%;padding:12px;display:grid}.modal-list-item input{margin-right:8px}.modal-list-item.active{border-color:var(--primary);box-shadow:0 0 0 2px #ff6b9d33}.modal-list-item small{color:var(--muted)}@media (width<=720px){.pagination{flex-direction:column;align-items:flex-start}.inline-field{flex-direction:column;align-items:stretch}}
