@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@600&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2d7a5f;--primary-dark:#236349;--primary-light:#e8f5ef;--accent:#3a9e8a;--background:#f8faf9;--foreground:#1a1f1c;--muted:#6b7280;--border:#e5e7eb;--card:#fff;--danger:#dc2626;--danger-light:#fef2f2;--success:#16a34a;--warning:#d97706;--sidebar-width:260px;--radius:10px;--shadow:0 1px 3px #00000014;--shadow-lg:0 10px 40px #0000001f}body{-webkit-font-smoothing:antialiased;background:#f8faf9;background:var(--background);color:#1a1f1c;color:var(--foreground);font-family:Inter,system-ui,sans-serif;line-height:1.5}.admin-layout{display:flex;min-height:100vh}.sidebar{background:#fff;background:var(--card);border-right:1px solid #e5e7eb;border-right:1px solid var(--border);bottom:0;display:flex;flex-direction:column;left:0;position:fixed;top:0;width:260px;width:var(--sidebar-width);z-index:40}.sidebar-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);gap:12px;padding:20px}.sidebar-header,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{border-radius:8px;color:#fff;font-size:18px;height:36px;justify-content:center;width:36px}.sidebar-brand{font-family:Playfair Display,serif;font-size:15px;font-weight:600}.sidebar-sub{color:#6b7280;color:var(--muted);font-size:11px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:16px 12px}.sidebar-label{color:#6b7280;color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.05em;padding:0 8px 8px;text-transform:uppercase}.sidebar-nav ul{list-style:none}.sidebar-link{align-items:center;border-radius:8px;color:#1a1f1c;color:var(--foreground);display:flex;font-size:14px;font-weight:500;gap:10px;padding:9px 12px;text-decoration:none;transition:background .15s}.sidebar-link.active,.sidebar-link:hover{background:#e8f5ef;background:var(--primary-light)}.sidebar-link.active{color:#2d7a5f;color:var(--primary)}.sidebar-link-icon{font-size:16px;text-align:center;width:20px}.sidebar-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border);color:#6b7280;color:var(--muted);font-size:11px;padding:16px 20px}.admin-main{display:flex;flex:1 1;flex-direction:column;margin-left:260px;margin-left:var(--sidebar-width);min-height:100vh}.admin-header{align-items:center;background:#fff;background:var(--card);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);display:flex;gap:12px;height:56px;padding:0 16px;position:-webkit-sticky;position:sticky;top:0;z-index:30}.sidebar-toggle{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:8px;color:#1a1f1c;color:var(--foreground);cursor:pointer;display:none;flex-shrink:0;font-size:18px;height:40px;justify-content:center;width:40px}.sidebar-backdrop{background:#0f172a73;border:none;cursor:pointer;display:none;inset:0;position:fixed;z-index:35}.header-brand-mobile{display:none;font-family:Playfair Display,serif;font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-actions{align-items:center;display:flex;gap:8px;margin-left:auto;min-width:0}.header-store-link{white-space:nowrap}.header-store-icon{display:none}.header-user{align-items:center;gap:10px}.header-user,.user-info{display:flex;min-width:0}.user-info{flex-direction:column}.user-name{font-size:13px;font-weight:600}.user-email,.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{color:#6b7280;color:var(--muted);font-size:11px;max-width:160px}.user-avatar{align-items:center;background:#2d7a5f;background:var(--primary);border-radius:50%;color:#fff;display:flex;font-size:13px;font-weight:600;height:36px;justify-content:center;width:36px}.user-avatar.sm{font-size:12px;height:32px;width:32px}.admin-content{flex:1 1;padding:24px}.page-header{align-items:flex-start;gap:16px;justify-content:space-between;margin-bottom:24px}.page-action,.page-header{display:flex;flex-wrap:wrap}.page-action{gap:8px}.page-title{font-size:24px;font-weight:700}.page-description{color:#6b7280;color:var(--muted);font-size:14px;margin-top:4px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:24px}.stat-card{background:#fff;background:var(--card);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow);padding:20px}.stat-card-top{align-items:center;display:flex;justify-content:space-between}.stat-card-label{color:#6b7280;color:var(--muted);font-size:13px;font-weight:500}.stat-card-icon{font-size:20px}.stat-card-value{font-size:28px;font-weight:700;margin-top:8px}.stat-card-footer{display:flex;font-size:12px;gap:8px;margin-top:8px}.stat-card-desc{color:#6b7280;color:var(--muted)}.trend-up{color:#16a34a;color:var(--success)}.trend-down{color:#dc2626;color:var(--danger)}.card{background:#fff;background:var(--card);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow);padding:20px}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;text-decoration:none;transition:all .15s}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#2d7a5f;background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:#236349;background:var(--primary-dark)}.btn-outline{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border);color:#1a1f1c;color:var(--foreground)}.btn-outline:hover:not(:disabled){background:#f8faf9;background:var(--background)}.btn-ghost{background:#0000;color:#1a1f1c;color:var(--foreground)}.btn-ghost:hover:not(:disabled){background:#f8faf9;background:var(--background)}.btn-danger{background:#dc2626;background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{font-size:13px;padding:5px 10px}.btn-full{width:100%}.text-danger{color:#dc2626!important;color:var(--danger)!important}.input{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:8px;color:#1a1f1c;color:var(--foreground);font-family:inherit;font-size:14px;padding:9px 12px;transition:border-color .15s;width:100%}.input:focus{border-color:#2d7a5f;border-color:var(--primary);box-shadow:0 0 0 3px #2d7a5f26;outline:none}.textarea{min-height:80px;resize:vertical}select.input{cursor:pointer}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid .full{grid-column:1/-1}.checkbox-group label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:8px}.form-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.combo-product-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 100px 36px;margin-bottom:8px}.search-filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.search-input-wrap{flex:1 1;min-width:200px;position:relative}.search-icon{font-size:14px;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{padding-left:36px}.filter-select{min-width:160px;width:auto}.table-wrap{-webkit-overflow-scrolling:touch;margin:0 -4px;overflow-x:auto;scrollbar-width:thin}.data-table{border-collapse:collapse;font-size:14px;min-width:640px;width:100%}.data-table th{color:#6b7280;color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.03em;padding:10px 12px;text-align:left;text-transform:uppercase}.data-table td,.data-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border)}.data-table td{padding:12px;vertical-align:middle}.data-table tbody tr:hover{background:#fafafa}.data-table.compact td,.data-table.compact th{padding:8px 12px}.cell-product{align-items:center;display:flex;gap:12px}.cell-thumb{background:#f8faf9;background:var(--background);border-radius:6px;height:40px;object-fit:cover;width:40px}.cell-thumb.round{border-radius:50%}.cell-title{font-weight:500}.cell-sub{color:#6b7280;color:var(--muted);font-size:12px}.cell-truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-mono{font-family:monospace;font-size:13px}.line-through{margin-left:6px;text-decoration:line-through}.action-btns{display:flex;gap:4px}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:500;padding:2px 10px}.badge-primary{background:#e8f5ef;background:var(--primary-light);color:#2d7a5f;color:var(--primary)}.badge-secondary{background:#f3f4f6;color:#374151}.badge-success{background:#dcfce7;color:#16a34a;color:var(--success)}.badge-danger{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.badge-outline{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border);color:#6b7280;color:var(--muted)}.pagination-wrap{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-top:20px;padding-top:16px}.pagination-info{color:#6b7280;color:var(--muted);font-size:13px}.pagination{display:flex;gap:4px}.pagination-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-family:inherit;font-size:13px;padding:6px 12px}.pagination-btn:hover:not(:disabled){background:#f8faf9;background:var(--background)}.pagination-btn.active{background:#2d7a5f;background:var(--primary);border-color:#2d7a5f;border-color:var(--primary);color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-ellipsis{color:#6b7280;color:var(--muted);padding:6px 8px}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:50}.modal-content{background:#fff;border-radius:10px;border-radius:var(--radius);box-shadow:0 10px 40px #0000001f;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;width:100%}.modal-sm{max-width:420px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-header{align-items:flex-start;display:flex;justify-content:space-between;padding:20px 24px 0}.modal-title{font-size:18px;font-weight:600}.modal-description{font-size:13px;margin-top:4px}.modal-close,.modal-description{color:#6b7280;color:var(--muted)}.modal-close{background:none;border:none;cursor:pointer;font-size:24px;line-height:1;padding:0 4px}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;margin-top:8px;padding-top:16px}.delete-message{color:#6b7280;color:var(--muted);font-size:14px;margin-bottom:8px}.order-detail{display:flex;flex-direction:column;gap:20px}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.detail-label{color:#6b7280;color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}.detail-value{font-size:18px;font-weight:700}.detail-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border);padding-top:16px}.empty-state{padding:48px 24px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:18px;margin-bottom:8px}.empty-state p{font-size:14px;margin-bottom:16px}.empty-state p,.loading-state{color:#6b7280;color:var(--muted)}.loading-state{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:64px}.spinner{animation:spin .7s linear infinite;border:3px solid #e5e7eb;border-top-color:#2d7a5f;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.table-skeleton{padding:8px 0}.skeleton-row{display:flex;gap:12px;margin-bottom:12px}.skeleton-cell{animation:pulse 1.5s ease-in-out infinite;background:#f3f4f6;border-radius:6px;flex:1 1;height:40px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.login-page{align-items:center;background:linear-gradient(135deg,#e8f5ef,#f8faf9 50%);background:linear-gradient(135deg,var(--primary-light) 0,var(--background) 50%);display:flex;justify-content:center;min-height:100vh;padding:24px}.login-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001f;box-shadow:var(--shadow-lg);max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:32px;text-align:center}.login-logo{font-size:40px;margin-bottom:12px}.login-header h1{font-family:Playfair Display,serif;font-size:24px}.login-header p{color:#6b7280;color:var(--muted);font-size:14px;margin-top:4px}.login-form{display:flex;flex-direction:column;gap:16px}.alert{border-radius:8px;font-size:14px;margin-bottom:16px;padding:12px 16px}.alert-error{background:#fef2f2;background:var(--danger-light);border:1px solid #fecaca;color:#dc2626;color:var(--danger)}.toast-container{display:flex;flex-direction:column;gap:8px;position:fixed;right:20px;top:20px;z-index:100}.toast{animation:slideIn .3s ease;border-radius:8px;box-shadow:0 10px 40px #0000001f;box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;max-width:360px;padding:12px 20px}.toast-success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.toast-error{background:#fef2f2;background:var(--danger-light);border:1px solid #fecaca;color:#dc2626;color:var(--danger)}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.image-upload-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));margin-bottom:12px}.image-upload-preview{aspect-ratio:1;background:#f3f4f6;border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:10px;overflow:hidden;position:relative}.image-upload-preview img{height:100%;object-fit:cover;width:100%}.image-upload-remove{background:#000000a6;border:none;border-radius:999px;color:#fff;cursor:pointer;height:24px;line-height:1;position:absolute;right:6px;top:6px;width:24px}.field-hint{color:#6b7280;color:var(--muted);font-size:12px;margin-top:6px}@media (max-width:1023px){.sidebar{box-shadow:0 10px 40px #0000001f;box-shadow:var(--shadow-lg);transform:translateX(-100%);transition:transform .25s ease}.sidebar.open{transform:translateX(0)}.sidebar-backdrop{display:block}.admin-main{margin-left:0}.sidebar-toggle{display:inline-flex}.header-brand-mobile{display:block;flex:1 1;min-width:0}body.sidebar-open{overflow:hidden}}@media (max-width:768px){.admin-content{padding:16px}.admin-header{gap:8px;padding:0 12px}.page-header{align-items:stretch;flex-direction:column}.page-action,.page-action .btn{width:100%}.page-title{font-size:20px}.stats-grid{grid-template-columns:1fr}.card{padding:16px}.form-grid{grid-template-columns:1fr}.search-filter-bar{align-items:stretch;flex-direction:column}.filter-select,.search-input-wrap{min-width:0;width:100%}.combo-product-row{grid-template-columns:1fr}.header-logout,.header-store-text,.header-user .user-info{display:none}.header-store-icon{display:inline}.header-actions{gap:6px}.action-btns{flex-wrap:wrap}.data-table td,.data-table th{padding:10px 8px}.modal-overlay{align-items:flex-end;padding:12px}.modal-content{border-bottom-left-radius:0;border-bottom-right-radius:0;max-height:92vh}.modal-lg,.modal-md,.modal-sm{max-width:100%}.modal-body,.modal-header{padding-left:16px;padding-right:16px}.modal-footer{align-items:stretch;flex-direction:column-reverse}.modal-footer .btn{width:100%}.pagination-wrap{align-items:stretch;flex-direction:column}.pagination{flex-wrap:wrap;justify-content:center}.detail-grid{grid-template-columns:1fr 1fr}.login-card{padding:28px 20px}.toast-container{left:12px;right:12px;top:12px}.toast{max-width:none}.image-upload-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}@media (max-width:480px){.admin-header{flex-wrap:wrap;height:auto;min-height:56px;padding:10px 12px}.header-brand-mobile{flex-basis:calc(100% - 52px);flex-grow:1;flex-shrink:1;order:2;padding-left:4px}.header-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border);justify-content:space-between;margin-left:0;order:3;padding-top:4px;width:100%}.detail-grid{grid-template-columns:1fr}.stat-card-value{font-size:24px}}
/*# sourceMappingURL=main.cf111439.css.map*/