@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Lora:ital,wght@0,400;0,600;1,400&display=swap);:root{--green-950:#250c07;--green-900:#3d140c;--green-800:#5f1e12;--green-700:#872b1a;--green-600:#a93820;--green-500:#c34931;--green-400:#e3674e;--green-100:#fdebe8;--green-50:#fffaf9;--earth-800:#8c500e;--earth-600:#b36914;--earth-400:#e18821;--earth-100:#fef5e9;--ink:#241816;--muted:#6e5a57;--border:#ebdcd9;--surface:#fff;--bg:#fcf9f8;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--shadow-sm:0 1px 3px #3c1e1e14;--shadow-md:0 4px 16px #3c1e1e1a;--shadow-lg:0 8px 32px #3c1e1e21;--font-display:"Lora",Georgia,serif;--font-body:"Plus Jakarta Sans",system-ui,sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#fcf9f8;background:var(--bg);color:#241816;color:var(--ink);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body);line-height:1.6}.app-shell{display:flex;min-height:100vh}.sidebar{background:#3d140c;background:var(--green-900);bottom:0;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;width:240px;z-index:100}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:24px 20px 20px}.sidebar-logo{align-items:center;display:flex;gap:10px;text-decoration:none}.sidebar-logo-mark{align-items:center;background:#c34931;background:var(--green-500);border-radius:10px;display:flex;font-size:18px;height:36px;justify-content:center;width:36px}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-name{color:#fff;font-family:Lora,Georgia,serif;font-family:var(--font-display);font-size:13px;font-weight:600;line-height:1.2}.sidebar-logo-sub{color:#e3674e;color:var(--green-400);font-size:10px;letter-spacing:.05em;text-transform:uppercase}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:16px 12px}.nav-section-label{color:#ffffff4d;font-size:10px;font-weight:700;letter-spacing:.1em;padding:12px 8px 6px;text-transform:uppercase}.nav-link{align-items:center;border-radius:8px;border-radius:var(--radius-sm);color:#ffffffa6;display:flex;font-size:14px;font-weight:500;gap:10px;padding:10px 12px;text-decoration:none;transition:all .15s ease}.nav-link:hover{background:#ffffff14;color:#fff}.nav-link.active{background:#872b1a;background:var(--green-700);color:#fff}.nav-link svg{flex-shrink:0}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.sidebar-rule{color:#fff6;font-size:11px;line-height:1.5}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:240px;min-height:100vh}.topbar{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #ebdcd9;border-bottom:1px solid var(--border);display:flex;height:60px;justify-content:space-between;padding:0 32px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar-title{color:#241816;color:var(--ink);font-size:16px;font-weight:600}.topbar-actions{align-items:center;display:flex;gap:10px}.page{flex:1 1;padding:32px}.card{background:#fff;background:var(--surface);border:1px solid #ebdcd9;border:1px solid var(--border);border-radius:18px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #3c1e1e14;box-shadow:var(--shadow-sm)}.card-header{align-items:center;border-bottom:1px solid #ebdcd9;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px 16px}.card-title{color:#241816;color:var(--ink);font-size:15px;font-weight:600}.card-body{padding:24px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:28px}.stat-card{background:#fff;background:var(--surface);border:1px solid #ebdcd9;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 3px #3c1e1e14;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px;padding:20px}.stat-card.accent-green{border-left:3px solid #c34931;border-left:3px solid var(--green-500)}.stat-card.accent-earth{border-left:3px solid #e18821;border-left:3px solid var(--earth-400)}.stat-card.accent-teal{border-left:3px solid #26c6a8}.stat-card.accent-blue{border-left:3px solid #5c9cf5}.stat-icon{align-items:center;border-radius:8px;display:flex;height:36px;justify-content:center;margin-bottom:4px;width:36px}.stat-label{color:#6e5a57;color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.stat-value{color:#241816;color:var(--ink);font-size:26px;font-weight:700;line-height:1.1}.stat-sub{color:#6e5a57;color:var(--muted);font-size:12px}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:14px;font-weight:600;gap:6px;padding:9px 18px;text-decoration:none;transition:all .15s ease;white-space:nowrap}.btn-primary{background:#872b1a;background:var(--green-700);color:#fff}.btn-primary:hover{background:#5f1e12;background:var(--green-800)}.btn-secondary{background:#fdebe8;background:var(--green-100);border:1px solid #ebdcd9;border:1px solid var(--border);color:#5f1e12;color:var(--green-800)}.btn-secondary:hover{background:#fffaf9;background:var(--green-50)}.btn-danger{background:#fdecea;color:#c62828}.btn-danger:hover{background:#fccecb}.btn-ghost{background:#0000;border:1px solid #ebdcd9;border:1px solid var(--border);color:#6e5a57;color:var(--muted)}.btn-ghost:hover{background:#fcf9f8;background:var(--bg)}.btn-sm{font-size:13px;padding:6px 12px}.btn-lg{font-size:15px;padding:12px 24px}.btn:disabled{cursor:not-allowed;opacity:.5}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid.single{grid-template-columns:1fr}.field{display:flex;flex-direction:column;gap:6px}.field.full{grid-column:1/-1}label{color:#6e5a57;color:var(--muted);font-size:13px;font-weight:600}input,select,textarea{background:#fff;background:var(--surface);border:1.5px solid #ebdcd9;border:1.5px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#241816;color:var(--ink);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:14px;outline:none;padding:10px 14px;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:#c34931;border-color:var(--green-500);box-shadow:0 0 0 3px #4caf501f}textarea{min-height:80px;resize:vertical}.field-hint{color:#6e5a57;color:var(--muted);font-size:12px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;font-size:14px;width:100%}thead tr{background:#fffaf9;background:var(--green-50);border-bottom:1px solid #ebdcd9;border-bottom:1px solid var(--border)}th{color:#6e5a57;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.05em;padding:11px 16px;text-align:left;text-transform:uppercase}td{border-bottom:1px solid #fcf9f8;border-bottom:1px solid var(--bg);padding:13px 16px;vertical-align:middle}tbody tr:hover{background:#fffaf9;background:var(--green-50)}tbody tr:last-child td{border-bottom:none}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:3px 9px}.badge-green{background:#e7f7e8;color:#0f7207}.badge-earth{background:#fef5e9;color:#b36a14}.badge-red{background:#ffebeb;color:#df0f09}.badge-blue{background:#ebeaff;color:#1e14b8}.badge-gray{background:#f5f5f5;color:#6e5a57}.points-pill{align-items:center;background:#fdebe8;background:var(--green-100);border-radius:20px;color:#5f1e12;color:var(--green-800);display:inline-flex;font-size:13px;font-weight:700;gap:5px;padding:4px 12px}.search-bar{max-width:320px;position:relative}.search-bar input{padding-left:38px;width:100%}.search-bar .search-icon{color:#6e5a57;color:var(--muted);left:11px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h1{color:#241816;color:var(--ink);font-family:Lora,Georgia,serif;font-family:var(--font-display);font-size:22px;font-weight:600}.page-header p{color:#6e5a57;color:var(--muted);font-size:13px;margin-top:2px}.grid-2{grid-gap:24px;grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:24px}.grid-3{grid-gap:24px;grid-template-columns:1fr 1fr 1fr}.flex{display:flex}.flex-col{flex-direction:column}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.items-center{align-items:center}.justify-between{justify-content:space-between}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.text-sm{font-size:13px}.text-muted{color:#6e5a57;color:var(--muted)}.text-right{text-align:right}.font-bold{font-weight:700}.w-full{width:100%}.empty-state{color:#6e5a57;color:var(--muted);padding:60px 20px;text-align:center}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state p{font-size:14px}.error-msg{background:#fdecea;color:#c62828}.error-msg,.success-msg{border-radius:8px;border-radius:var(--radius-sm);font-size:14px;padding:10px 14px}.success-msg{background:#e8f5e9;color:#2e7a35}.tier-badge{border:1.5px solid;border-radius:20px;display:inline-flex;font-size:12px;gap:5px;padding:3px 10px}.avatar,.tier-badge{align-items:center;font-weight:700}.avatar{background:#872b1a;background:var(--green-700);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;height:36px;justify-content:center;width:36px}.customer-row{align-items:center;display:flex;gap:10px}.loyalty-card-container{background:linear-gradient(135deg,#250c07,#3d140c);background:linear-gradient(135deg,var(--green-950) 0,var(--green-900) 100%);color:#fff;overflow:hidden;position:relative}.loyalty-card-container .card-body{padding:32px 28px}.loyalty-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:28px}.loyalty-card-title{color:#fff;font-family:Lora,Georgia,serif;font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:.05em}.loyalty-card-tier{align-items:center;background:#0003;border:1.5px solid;border-radius:20px;display:inline-flex;font-size:12px;font-weight:700;gap:5px;padding:3px 10px}.loyalty-card-center{align-items:center;display:flex;gap:24px}.loyalty-card-qr-wrap{align-items:center;background:#fff;border-radius:12px;box-shadow:0 8px 20px #0003;display:flex;justify-content:center;padding:8px}.loyalty-card-qr-img{display:block;height:100px;width:100px}.loyalty-card-info{display:flex;flex-direction:column}.loyalty-card-balance-label{color:#fff6;font-size:11px;letter-spacing:.05em;text-transform:uppercase}.loyalty-card-balance-val{color:#fff;font-size:36px;font-weight:800;line-height:1.1;margin:4px 0}.loyalty-card-balance-worth{color:#e3674e;color:var(--green-400);font-size:13px}.loyalty-card-footer{border-top:1px solid #ffffff14;color:#ffffff80;display:flex;font-size:12px;justify-content:space-between;margin-top:32px;padding-top:16px}.loyalty-card-footer-item{display:flex;flex-direction:column}.loyalty-card-footer-label{color:#fff6;font-size:9px;letter-spacing:.05em;text-transform:uppercase}.loyalty-card-footer-val{color:#fff;font-size:13px;font-weight:600}.mobile-customer-header{align-items:center;background:#250c07;background:var(--green-950);border-bottom:1px solid #ffffff0d;display:none;height:60px;justify-content:space-between;padding:0 20px}.mobile-header-brand{align-items:center;display:flex;gap:10px}.mobile-customer-userbar{align-items:center;background:#250c07;background:var(--green-950);display:none;gap:12px;padding:16px 20px 24px}.bottom-nav{align-items:center;background:#0d2010;border-top:1px solid #ffffff14;bottom:0;display:none;height:65px;justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;z-index:100}.bottom-nav-link{align-items:center;display:flex;flex:1 1;flex-direction:column;font-size:10px;font-weight:500;gap:4px;text-align:center;text-decoration:none}.bottom-nav-link,.bottom-nav-link svg{color:#728476;transition:all .15s ease}.bottom-nav-link svg{stroke-width:2}.bottom-nav-link.active,.bottom-nav-link.active svg{color:#4caf50}.sidebar-backdrop{background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}@media (max-width:768px){.sidebar{box-shadow:none;transform:translateX(-100%);transition:transform .3s ease;z-index:100}.sidebar.mobile-open{box-shadow:0 8px 32px #3c1e1e21;box-shadow:var(--shadow-lg);transform:translateX(0)}.main-content{margin-left:0!important}.topbar{height:56px;padding:0 16px}.hamburger-btn{background:none;border:none;color:#241816;color:var(--ink);cursor:pointer;display:flex!important}.page{padding:16px}.role-customer .sidebar,.role-customer .topbar{display:none!important}.role-customer .bottom-nav,.role-customer .mobile-customer-header,.role-customer .mobile-customer-userbar{display:flex}.role-customer .main-content,.role-customer .page{background:#250c07;background:var(--green-950)}.role-customer .page{padding:0!important}.role-customer .page>div{background:#fff;border-top-left-radius:24px;border-top-right-radius:24px;box-shadow:0 -8px 24px #00000026;min-height:calc(100vh - 124px);padding:28px 16px 85px}.form-grid,.grid-2,.grid-3{grid-template-columns:1fr!important}.stats-grid{grid-template-columns:1fr 1fr!important}h1{font-size:20px!important}.card-body{padding:16px!important}.page-header{align-items:flex-start;flex-direction:column;gap:8px;margin-bottom:20px}.loyalty-card-container{aspect-ratio:16/9;height:auto!important;margin:0 auto;max-width:400px;width:100%}.loyalty-card-container .card-body{display:flex;flex-direction:column;height:100%;justify-content:space-between;padding:12px 14px!important}.loyalty-card-container .card-body>div,.loyalty-card-header{margin-bottom:0!important}.loyalty-card-title{font-size:11px!important;white-space:nowrap!important}.loyalty-card-tier{border-width:1px!important;font-size:9px!important;padding:1px 6px!important}.loyalty-card-center{gap:12px!important}.loyalty-card-qr-wrap{border-radius:8px!important;padding:4px!important}.loyalty-card-qr-img{height:60px!important;width:60px!important}.loyalty-card-balance-label{font-size:9px!important}.loyalty-card-balance-val{font-size:22px!important;margin:2px 0!important}.loyalty-card-balance-worth,.loyalty-card-footer{font-size:10px!important}.loyalty-card-footer{margin-top:0!important;padding-top:6px!important}.loyalty-card-footer-label{font-size:7px!important}.loyalty-card-footer-val{font-size:11px!important}}#reader{border:none!important}#reader video{border-radius:12px;height:100%!important;object-fit:cover!important;width:100%!important}