@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@400;500;600;700&display=swap";:root{--color-primary: hsl(340, 82%, 52%);--color-primary-light: hsl(340, 82%, 62%);--color-primary-dark: hsl(340, 82%, 42%);--color-secondary: hsl(280, 40%, 50%);--color-secondary-light: hsl(280, 40%, 60%);--color-accent: hsl(45, 100%, 60%);--color-accent-light: hsl(45, 100%, 70%);--color-background: hsl(0, 0%, 98%);--color-surface: hsl(0, 0%, 100%);--color-surface-hover: hsl(0, 0%, 97%);--color-text-primary: hsl(0, 0%, 10%);--color-text-secondary: hsl(0, 0%, 40%);--color-text-muted: hsl(0, 0%, 60%);--color-border: hsl(0, 0%, 90%);--color-border-light: hsl(0, 0%, 95%);--color-success: hsl(142, 71%, 45%);--color-error: hsl(0, 84%, 60%);--color-warning: hsl(38, 92%, 50%);--color-info: hsl(199, 89%, 48%);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--font-family-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-heading: "Playfair Display", Georgia, serif;--font-size-xs: .6rem;--font-size-sm: .7rem;--font-size-base: .8rem;--font-size-lg: .9rem;--font-size-xl: 1rem;--font-size-2xl: 1.2rem;--font-size-3xl: 1.6rem;--font-size-4xl: 2rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-background);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;border:none;outline:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.btn-second.variant-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary);transform:translateY(-2px)}.variant-btn.disabled{background:var(--color-background);border-color:var(--color-border);color:var(--color-text-muted);cursor:not-allowed;opacity:.5}.variant-btn.disabled:hover{transform:none;background:var(--color-background)}.out-of-stock-badge{display:block;font-size:.75rem;color:var(--color-error);margin-top:.25rem;font-weight:var(--font-weight-medium)}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:#fff}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-base) ease-out}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.navbar{background:var(--color-surface);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:var(--z-sticky);padding:var(--spacing-md) 0}.navbar-content{display:flex;align-items:center;justify-content:space-between}.navbar-logo h2{margin:0;font-size:var(--font-size-2xl)}.navbar-links{display:flex;gap:var(--spacing-lg);align-items:center}.nav-link{color:var(--color-text-primary);font-weight:var(--font-weight-medium);transition:color var(--transition-fast);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md)}.nav-link:hover{color:var(--color-primary);background:var(--color-surface-hover)}.nav-link.admin-link{color:var(--color-secondary)}.navbar-auth{display:flex;gap:var(--spacing-sm);align-items:center}.navbar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.navbar-actions{display:flex;align-items:center;gap:.75rem}.cart-icon{display:flex;align-items:center;justify-content:center;position:relative;height:40px;top:5px}.cart-icon svg{display:block}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;height:40px;padding:0}.user-menu{display:flex;gap:var(--spacing-md);align-items:center}.user-name{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.btn-block{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.mobile-menu-btn{display:none;font-size:var(--font-size-2xl);padding:var(--spacing-sm);background:none;border:none;cursor:pointer;color:var(--color-text-primary)}.mobile-menu{display:none;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) 0;margin-top:var(--spacing-md);border-top:1px solid var(--color-border)}.mobile-nav-link{padding:var(--spacing-md);color:var(--color-text-primary);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:background var(--transition-fast)}.mobile-nav-link:hover{background:var(--color-surface-hover)}.mobile-auth{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}@media(max-width:768px){.desktop-only{display:none!important}.mobile-only{display:block!important}.mobile-menu{display:flex}.mobile-menu-btn{display:block}}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;transition:border-color var(--transition-fast);background:var(--color-surface)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary)}.form-textarea{min-height:120px;resize:vertical}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl) 0}.auth-container{width:100%;max-width:450px}.auth-card{background:var(--color-surface);padding:var(--spacing-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.auth-title{text-align:center;margin-bottom:var(--spacing-sm)}.auth-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.auth-form{margin-bottom:var(--spacing-lg)}.auth-footer{text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.auth-link{color:var(--color-primary);font-weight:var(--font-weight-medium)}.auth-link:hover{text-decoration:underline}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.alert-error{background:#fde8e8;color:var(--color-error);border:1px solid var(--color-error)}.alert-success{background:#e9fbf0;color:var(--color-success);border:1px solid var(--color-success)}.alert-info{background:#e7f6fe;color:var(--color-info);border:1px solid var(--color-info)}.product-card{background:var(--color-surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-base);display:block;height:100%}.product-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.product-image-wrapper{position:relative;width:100%;padding-top:120%;overflow:hidden;background:var(--color-background)}.product-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.product-card:hover .product-image{transform:scale(1.05)}.product-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);padding:4px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px}.badge-new{background:var(--color-primary);color:#fff}.badge-featured{background:var(--color-accent);color:var(--color-text-primary)}.badge-out-of-stock{background:var(--color-text-secondary);color:#fff}.product-info{padding:var(--spacing-md)}.product-name{font-size:var(--font-size-base);margin-bottom:var(--spacing-xs);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);line-height:1.3;display:-webkit-box;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-category{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.product-footer{display:flex;justify-content:space-between;align-items:center}.product-price{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.product-sales{font-size:var(--font-size-sm);color:var(--color-text-muted)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(224px,1fr));gap:var(--spacing-xl);margin-top:var(--spacing-xl)}@media(max-width:640px){.products-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.product-info{padding:var(--spacing-sm)}.product-name{font-size:var(--font-size-sm);margin-bottom:2px}.product-category{font-size:10px;margin-bottom:var(--spacing-xs)}.product-price{font-size:var(--font-size-base)}.product-price-original,.product-price-discount{font-size:var(--font-size-sm)}}.section{padding:var(--spacing-3xl) 0}.section-header{text-align:center;margin-bottom:var(--spacing-2xl)}.section-title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm)}.section-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-lg)}.spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.container{padding:0 var(--spacing-md)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}.section{padding:var(--spacing-2xl) 0}}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:260px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.admin-sidebar-header{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border)}.admin-sidebar-header h2{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-xl);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.admin-user{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.admin-nav{flex:1;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-nav-link{padding:var(--spacing-md);color:var(--color-text-primary);border-radius:var(--radius-md);transition:all var(--transition-fast);display:block;font-weight:var(--font-weight-medium)}.admin-nav-link:hover{background:var(--color-surface-hover);color:var(--color-primary)}.admin-nav-link.active{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff}.admin-sidebar-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-main{flex:1;margin-left:260px;padding:var(--spacing-2xl);background:var(--color-background);min-height:100vh}.admin-page{max-width:1200px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl)}.admin-header h1{margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:var(--spacing-lg);transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-highlight{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff}.stat-card-highlight .stat-info h3,.stat-card-highlight .stat-info p{color:#fff}.stat-icon{font-size:2.5rem}.stat-info h3{font-size:var(--font-size-3xl);margin:0 0 var(--spacing-xs) 0;font-weight:var(--font-weight-bold)}.stat-info p{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.admin-quick-actions{margin-top:var(--spacing-2xl)}.admin-quick-actions h2{margin-bottom:var(--spacing-lg)}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg)}.quick-action-card{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);text-align:center;transition:all var(--transition-base);color:var(--color-text-primary)}.quick-action-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);color:var(--color-primary)}.quick-action-icon{font-size:2rem}.admin-table-container{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background:var(--color-background)}.admin-table th{padding:var(--spacing-lg);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);border-bottom:2px solid var(--color-border)}.admin-table td{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.admin-table tbody tr:hover{background:var(--color-surface-hover)}.admin-table tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:var(--spacing-sm)}.btn-icon{background:none;border:none;cursor:pointer;font-size:var(--font-size-lg);padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--color-surface-hover);transform:scale(1.1)}.btn-icon.btn-danger:hover{background:#fde8e8}.badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px}.badge-success{background:#e9fbf0;color:var(--color-success)}.badge-inactive{background:var(--color-background);color:var(--color-text-muted)}.empty-state{text-align:center;padding:var(--spacing-3xl);color:var(--color-text-muted)}.empty-state p{margin-bottom:var(--spacing-lg)}.admin-mobile-header{display:none;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:var(--z-sticky)}.admin-mobile-menu-btn,.admin-mobile-close-btn{background:none;border:none;color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:var(--spacing-xs)}.admin-mobile-close-btn{display:none}.admin-mobile-title{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary)}.admin-sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:1040;opacity:0;transition:opacity var(--transition-base);pointer-events:none}@media(max-width:768px){.admin-mobile-header{display:flex}.admin-sidebar-overlay{display:block}.admin-sidebar-overlay.active{opacity:1;pointer-events:auto}.admin-sidebar{width:270px;position:fixed;top:0;left:0;height:100vh;transform:translate(-100%);transition:transform var(--transition-base);z-index:1050;box-shadow:none}.admin-sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.admin-mobile-close-btn{display:block}.admin-main{margin-left:0;padding:var(--spacing-lg)}.admin-layout{flex-direction:column}.stats-grid{grid-template-columns:1fr}.admin-table-container{overflow-x:auto}}.product-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.variant-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-md)}.variant-item-compact{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);position:relative}.variant-item-compact .form-group{margin-bottom:var(--spacing-sm)}.variant-item-compact .form-group:last-of-type{margin-bottom:0}.variant-item-remove{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--color-error);color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:all var(--transition-base)}.variant-item-remove:hover{background:#eb1414;transform:scale(1.1)}.form-actions{display:flex;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.image-preview{position:relative;aspect-ratio:3/4;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--color-border)}.image-preview img{width:100%;height:100%;object-fit:cover}.image-remove-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--color-error);color:#fff;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:var(--font-size-lg);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.image-remove-btn:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.option-item{padding:var(--spacing-lg);background:var(--color-background);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#eb1414}.product-detail-page{background:var(--color-background);min-height:calc(100vh - 70px)}@media(max-width:768px){.product-detail-grid{grid-template-columns:1fr;gap:2rem}}.product-gallery{position:sticky;top:2rem}.main-image{width:100%;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface);margin-bottom:1rem}.main-image img{width:100%;height:100%;object-fit:cover}.thumbnail{aspect-ratio:3/4;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all var(--transition-base)}.thumbnail:hover{border-color:var(--color-primary)}.thumbnail.active{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.thumbnail img{width:100%;height:100%;object-fit:cover}.product-info-section{background:var(--color-surface);padding:2rem;border-radius:var(--radius-lg)}.product-title{font-size:2rem;margin-bottom:.5rem;color:var(--color-text-primary)}.product-category{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:1rem}.product-sku{color:var(--color-text-muted);font-size:var(--font-size-xs);margin-bottom:.5rem;font-family:monospace}.product-price{font-size:2rem;font-weight:var(--font-weight-bold);color:var(--color-primary);margin:1.5rem 0}.product-description{color:var(--color-text-secondary);line-height:1.6;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border)}.variant-section{margin-bottom:1.5rem}.variant-label{display:block;font-weight:var(--font-weight-semibold);margin-bottom:.75rem;color:var(--color-text-primary)}.variant-options{display:flex;flex-wrap:wrap;gap:.5rem}.variant-btn{padding:.75rem 1.5rem;border:2px solid var(--color-border);background:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);font-weight:var(--font-weight-medium);position:relative}.variant-btn:hover:not(.disabled){border-color:var(--color-primary);background:#fef1f5}.variant-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.variant-btn.active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.variant-btn.disabled{opacity:.5;cursor:not-allowed;text-decoration:line-through}.price-badge{display:inline-block;margin-left:.5rem;font-size:.875rem;color:var(--color-success)}.variant-btn.active .price-badge{color:#fff}.out-of-stock-badge{display:block;font-size:.75rem;color:var(--color-error);margin-top:.25rem}.stock-info{margin-top:.5rem;font-size:.875rem;color:var(--color-text-secondary)}.quantity-section{margin-bottom:1.5rem}.quantity-controls{display:flex;align-items:center;gap:1rem}.quantity-btn{width:40px;height:40px;border:2px solid var(--color-border);background:#fff;border-radius:var(--radius-md);cursor:pointer;font-size:1.25rem;font-weight:var(--font-weight-bold);transition:all var(--transition-base)}.quantity-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.quantity-display{font-size:1.25rem;font-weight:var(--font-weight-semibold);min-width:40px;text-align:center}.search-bar-wrapper{max-width:600px;margin:0 auto}.search-bar{position:relative;display:flex;align-items:center;background:#fff;border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:.75rem 1rem;transition:all var(--transition-base)}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.search-icon{color:var(--color-text-secondary);margin-right:.75rem;flex-shrink:0}.search-input{flex:1;border:none;outline:none;font-size:1rem;background:transparent}.search-input::placeholder{color:var(--color-text-muted)}.search-clear{background:none;border:none;color:var(--color-text-secondary);font-size:1.5rem;cursor:pointer;padding:0 .5rem;line-height:1;transition:color var(--transition-base)}.search-clear:hover{color:var(--color-error)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:500px;width:90%;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:all var(--transition-base)}.modal-close:hover{background:var(--color-background);color:var(--color-text)}.modal-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--color-border)}.modal-title{margin:0;font-size:1.25rem;font-weight:var(--font-weight-semibold);color:var(--color-text)}.modal-body{padding:1.5rem;color:var(--color-text-secondary);line-height:1.6}.modal-footer{padding:1rem 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.modal-footer .btn{min-width:100px}.toast-container{position:fixed;top:80px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{background:#fff;padding:1rem 1.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:.75rem;min-width:300px;max-width:400px;pointer-events:all;animation:slideIn .3s ease-out;border-left:4px solid var(--color-success)}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:var(--color-success);color:var(--color-success)}.toast-error{border-left-color:var(--color-error);color:var(--color-error)}.toast span{flex:1;color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.toast-close{background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;color:var(--color-text-secondary);transition:color var(--transition-base)}.toast-close:hover{color:var(--color-text-primary)}@media(max-width:768px){.toast-container{right:10px;left:10px}.toast{min-width:auto}}.product-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.product-gallery{position:sticky;top:1rem}.main-image{width:100%;min-height:400px;max-height:700px;overflow:hidden;border-radius:var(--radius-lg);background:var(--color-surface);margin-bottom:1rem;display:flex;align-items:center;justify-content:center}.main-image img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.image-thumbnails{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}.thumbnail{min-height:80px;max-height:120px;overflow:hidden;border-radius:var(--radius-md);cursor:pointer;border:2px solid transparent;transition:border-color var(--transition-base);display:flex;align-items:center;justify-content:center;background:var(--color-surface)}.thumbnail:hover,.thumbnail.active{border-color:var(--color-primary)}.thumbnail img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}@media(max-width:768px){.product-detail-grid{grid-template-columns:1fr;gap:1.5rem}.product-gallery{position:relative;top:0}.main-image{max-height:400px;margin-bottom:.75rem}.image-thumbnails{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.375rem}}.cart-layout{display:grid;grid-template-columns:1fr 350px;gap:2rem;align-items:start}@media(max-width:768px){.cart-layout{grid-template-columns:1fr;gap:1.5rem}}.discount-layout{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}.discount-form-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-sm)}.discount-detail-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);position:sticky;top:1rem}.discount-section-title{font-size:.7rem;font-weight:var(--font-weight-bold);color:var(--color-text-secondary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border-light)}.discount-field-label{display:block;font-size:.65rem;font-weight:var(--font-weight-semibold);color:var(--color-text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.35rem}.discount-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.discount-toggle-row{display:flex;align-items:center;gap:.75rem}.discount-toggle-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:40px}.discount-toggle{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer}.discount-toggle input{opacity:0;width:0;height:0}.discount-toggle-slider{position:absolute;inset:0;background:var(--color-border);border-radius:24px;transition:background var(--transition-base)}.discount-toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform var(--transition-base);box-shadow:var(--shadow-sm)}.discount-toggle input:checked+.discount-toggle-slider{background:var(--color-success)}.discount-toggle input:checked+.discount-toggle-slider:before{transform:translate(20px)}.discount-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.discount-submit-btn{background:#13ae85;color:#fff;font-weight:var(--font-weight-bold);font-size:.75rem;letter-spacing:.06em;padding:.6rem 1.5rem;border-radius:var(--radius-md);transition:all var(--transition-base);box-shadow:var(--shadow-md)}.discount-submit-btn:hover{background:#0f8a69;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.discount-detail-title{font-size:.7rem;font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border-light)}.discount-detail-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.discount-detail-list li{display:flex;gap:.4rem;align-items:flex-start;font-size:var(--font-size-sm)}.detail-key{color:var(--color-text-secondary);flex-shrink:0}.detail-value{color:var(--color-text-primary)}.detail-bold{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.discount-note{margin-top:1.25rem;font-size:.7rem;color:#12a17b;font-style:italic;line-height:1.4}.discount-status-badge{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:.68rem;font-weight:var(--font-weight-semibold)}.badge-active{background:#d3f8e1;color:#16833e}.badge-passive{background:#e6e6e6;color:#737373}.badge-success{background:#d3f8e1;color:#16833e;padding:2px 10px;border-radius:var(--radius-full);font-size:.68rem;font-weight:var(--font-weight-semibold)}.badge-inactive{background:#e6e6e6;color:#737373;padding:2px 10px;border-radius:var(--radius-full);font-size:.68rem;font-weight:var(--font-weight-semibold)}@media(max-width:900px){.discount-layout{grid-template-columns:1fr}.discount-detail-card{position:static}.discount-row{grid-template-columns:1fr}}.discount-checklist{display:flex;flex-direction:column;gap:.4rem;max-height:220px;overflow-y:auto;padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background)}.discount-check-item{display:flex;align-items:center;gap:.6rem;font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;padding:.2rem 0;transition:color var(--transition-fast)}.discount-check-item:hover{color:var(--color-primary)}.discount-check-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.product-badge.badge-discount{background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff;font-weight:var(--font-weight-semibold);font-size:.75rem;letter-spacing:.02em;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.product-price-group{display:flex;align-items:baseline;gap:.4rem;flex-wrap:wrap}.product-price-original{font-size:.85rem;color:var(--color-text-muted);text-decoration:line-through}.product-price-discount{font-size:1.05rem;font-weight:var(--font-weight-bold);color:#e53e3e}.product-price-section{margin:1rem 0;display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem}.product-price-original-lg{font-size:1.1rem;color:var(--color-text-muted);text-decoration:line-through}.product-price-discount-lg{font-size:1.75rem;font-weight:var(--font-weight-bold);color:#e53e3e}.product-discount-info{display:inline-block;width:100%;font-size:.85rem;color:#e53e3e;font-weight:var(--font-weight-medium);background:#e53e3e14;padding:.3rem .6rem;border-radius:var(--radius-sm);margin-top:.25rem}.variation-tags{display:flex;flex-wrap:wrap;gap:.5rem}.variation-tag{display:inline-flex;align-items:center;gap:.35rem;background:var(--color-primary);color:#fff;padding:.4rem .75rem;border-radius:50px;font-size:.875rem;font-weight:var(--font-weight-medium)}.variation-tag-remove{background:none;border:none;color:#fffc;cursor:pointer;padding:0;display:flex;align-items:center;transition:color .15s}.variation-tag-remove:hover{color:#fff}.variation-tags-sm{display:flex;flex-wrap:wrap;gap:.3rem}.variation-tag-sm{display:inline-block;background:var(--color-bg-secondary);color:var(--color-text-primary);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.8rem;border:1px solid var(--color-border)}.variation-stock-section{margin-top:1rem}.variation-stock-table{width:100%;border-collapse:collapse}.variation-stock-table th{text-align:left;padding:.6rem .75rem;font-size:.8rem;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--color-border)}.variation-stock-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border);vertical-align:middle}.variation-stock-table tr:last-child td{border-bottom:none}.variation-stock-table .form-input{margin:0;padding:.4rem .6rem;font-size:.9rem}.variation-option-name{font-weight:var(--font-weight-medium);font-size:.95rem}.variation-stock-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.variation-group-header{cursor:pointer;background:var(--color-bg-secondary);transition:background .15s}.variation-group-header:hover{background:var(--color-bg-tertiary, rgba(0, 0, 0, .04))}.variation-group-header td{padding:.75rem;border-bottom:2px solid var(--color-border)}.variation-group-name{font-weight:var(--font-weight-semibold);font-size:1rem;color:var(--color-text-primary)}.variation-group-count{font-size:.8rem;color:var(--color-text-secondary);background:var(--color-bg-primary);padding:.15rem .5rem;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.variation-group-chevron{font-size:1.1rem;color:var(--color-text-secondary);transition:transform .2s ease;display:inline-block;margin-left:auto}.variation-sub-row td{border-bottom:1px solid var(--color-border)}.variation-sub-row td:first-child{border-left:3px solid var(--color-primary)}.password-input-wrapper{position:relative}.password-input-wrapper .form-input{padding-right:2.75rem}.password-toggle-btn{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .15s}.password-toggle-btn:hover{color:var(--color-text-primary)}.shipping-checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.95rem;color:var(--color-text-primary)}.shipping-radio-label{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:1rem;color:var(--color-text-primary)}.shipping-radio-label input[type=radio]{width:18px;height:18px;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--color-surface);border-radius:12px;padding:1.5rem;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.pagination-bar{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.5rem;flex-wrap:wrap}.pagination-pages{display:flex;align-items:center;gap:.25rem}.pagination-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text-primary);font-size:.9rem;cursor:pointer;transition:all .15s}.pagination-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-dots{padding:0 .25rem;color:var(--color-text-secondary)}.customer-detail-grid{display:flex;flex-direction:column}.customer-detail-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary)}.customer-detail-item>div{display:flex;flex-direction:column;gap:.15rem}.customer-detail-label{font-size:.8rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.customer-detail-value{font-size:.95rem;color:var(--color-text-primary);font-weight:500}.report-page{max-width:1400px}.report-filters{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-md)}.report-preset-group{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.report-preset-btn{padding:.5rem 1rem;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);background:var(--color-background);color:var(--color-text-secondary);border:1.5px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:.35rem}.report-preset-btn:hover{border-color:var(--color-primary-light);color:var(--color-primary);background:#fef1f5}.report-preset-btn.active{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;border-color:transparent;box-shadow:0 2px 8px #e920634d}.report-filter-row{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--spacing-md)}.report-flatpickr-wrapper{position:relative;display:flex;align-items:center;width:100%;max-width:260px}.report-flatpickr-icon{position:absolute;left:10px;color:var(--color-text-muted);pointer-events:none}.report-flatpickr-input{width:100%;padding:.5rem .75rem .5rem 2rem!important;font-size:var(--font-size-sm)!important;background:var(--color-background);cursor:pointer;border-radius:var(--radius-md)}.flatpickr-calendar{border:1px solid var(--color-border);box-shadow:var(--shadow-lg);font-family:inherit;border-radius:var(--radius-lg);padding:.5rem}.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange,.flatpickr-day.selected.inRange,.flatpickr-day.startRange.inRange,.flatpickr-day.endRange.inRange,.flatpickr-day.selected:focus,.flatpickr-day.startRange:focus,.flatpickr-day.endRange:focus,.flatpickr-day.selected:hover,.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover,.flatpickr-day.selected.prevMonthDay,.flatpickr-day.startRange.prevMonthDay,.flatpickr-day.endRange.prevMonthDay,.flatpickr-day.selected.nextMonthDay,.flatpickr-day.startRange.nextMonthDay,.flatpickr-day.endRange.nextMonthDay{background:var(--color-primary);border-color:var(--color-primary)}.flatpickr-day.inRange,.flatpickr-day.prevMonthDay.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.today.inRange,.flatpickr-day.prevMonthDay.today.inRange,.flatpickr-day.nextMonthDay.today.inRange,.flatpickr-day:hover,.flatpickr-day.prevMonthDay:hover,.flatpickr-day.nextMonthDay:hover,.flatpickr-day:focus,.flatpickr-day.prevMonthDay:focus,.flatpickr-day.nextMonthDay:focus{background:#e920631a;border-color:transparent}.report-date-display{display:flex;align-items:center;gap:.4rem;font-size:var(--font-size-sm);color:var(--color-text-muted)}.report-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.report-metric-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl) var(--spacing-lg);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:var(--spacing-lg);transition:all var(--transition-base);position:relative;overflow:hidden;animation:reportCardIn .4s ease-out both}.report-metric-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.metric-revenue:before{background:linear-gradient(to bottom,#21c45d,#3bde77)}.metric-orders:before{background:linear-gradient(to bottom,#0da2e7,#3ebaf4)}.metric-avg:before{background:linear-gradient(to bottom,#914db3,#b282c9)}.metric-cancelled:before{background:linear-gradient(to bottom,#ef4343,#f37272)}.metric-returns:before{background:linear-gradient(to bottom,#f59f0a,#f7b23b)}.report-metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.report-metric-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.metric-revenue .report-metric-icon{background:#21c45d1a;color:#1eae53}.metric-orders .report-metric-icon{background:#0da2e71a;color:#0c8eca}.metric-avg .report-metric-icon{background:#914db31a;color:#8245a1}.metric-cancelled .report-metric-icon{background:#ef43431a;color:#ed2c2c}.metric-returns .report-metric-icon{background:#f59f0a1a;color:#dc8f09}.report-metric-info{display:flex;flex-direction:column;gap:.15rem}.report-metric-value{font-size:1.35rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.02em}.report-metric-label{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}@keyframes reportCardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.report-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.report-chart-section{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);animation:reportCardIn .5s ease-out both}.report-chart-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.report-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-sm)}.report-granularity-group{display:flex;gap:2px;background:var(--color-background);border-radius:var(--radius-md);padding:2px;border:1px solid var(--color-border)}.report-gran-btn{padding:.3rem .7rem;border-radius:calc(var(--radius-md) - 2px);font-size:.7rem;font-weight:var(--font-weight-medium);background:transparent;color:var(--color-text-secondary);border:none;cursor:pointer;transition:all var(--transition-fast)}.report-gran-btn:hover{color:var(--color-primary)}.report-gran-btn.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm);font-weight:var(--font-weight-semibold)}.report-recharts-tooltip{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.6rem .85rem;box-shadow:var(--shadow-md);font-size:.75rem}.report-recharts-tooltip-label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 .25rem;font-size:.75rem}.report-recharts-tooltip-value{margin:0;font-weight:var(--font-weight-medium);font-size:.75rem}.report-bar-chart{width:100%;overflow-x:auto}.report-bars-wrapper{display:flex;gap:4px;align-items:flex-end;height:220px;min-width:fit-content;padding:0 .25rem}.report-bar-column{display:flex;flex-direction:column;align-items:center;flex:1;min-width:28px;max-width:56px;position:relative}.report-bar-column:hover .report-bar-tooltip{opacity:1;transform:translate(-50%) translateY(-4px);pointer-events:auto}.report-bar-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(0);background:var(--color-text-primary);color:#fff;font-size:.65rem;padding:3px 7px;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:all var(--transition-fast);z-index:10;margin-bottom:4px}.report-bar-track{width:100%;height:190px;display:flex;align-items:flex-end;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.report-bar-fill{width:100%;border-radius:var(--radius-sm) var(--radius-sm) 0 0;min-height:2px;transition:height .6s cubic-bezier(.4,0,.2,1);animation:barGrow .6s ease-out both}@keyframes barGrow{0%{height:0!important}}.report-bar-label{font-size:.6rem;color:var(--color-text-muted);margin-top:6px;white-space:nowrap;text-align:center}.report-h-bar-chart{display:flex;flex-direction:column;gap:.75rem}.report-h-bar-row{display:grid;grid-template-columns:120px 1fr 100px;align-items:center;gap:.75rem}.report-h-bar-name{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-h-bar-track{height:26px;background:var(--color-background);border-radius:var(--radius-full);overflow:hidden}.report-h-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .8s cubic-bezier(.4,0,.2,1);animation:hBarGrow .8s ease-out both;min-width:4px}@keyframes hBarGrow{0%{width:0!important}}.report-h-bar-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-align:right}.report-export-dropdown{position:relative}.report-export-btn{display:inline-flex;align-items:center;gap:.4rem;font-size:var(--font-size-sm)}.report-export-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);overflow:hidden;z-index:var(--z-dropdown);min-width:170px;animation:dropIn .15s ease-out}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.report-export-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.65rem 1rem;font-size:var(--font-size-sm);color:var(--color-text-primary);background:none;border:none;cursor:pointer;transition:background var(--transition-fast)}.report-export-item:hover{background:var(--color-surface-hover);color:var(--color-primary)}.report-export-item+.report-export-item{border-top:1px solid var(--color-border-light)}.skeleton-card{position:relative;overflow:hidden}.skeleton-card:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.4),transparent);animation:skeletonShimmer 1.5s infinite}@keyframes skeletonShimmer{to{left:100%}}.skeleton-circle{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--color-background)}.skeleton-text-group{flex:1;display:flex;flex-direction:column;gap:.5rem}.skeleton-line{height:14px;border-radius:var(--radius-sm);background:var(--color-background)}.skeleton-line.wide{width:70%}.skeleton-line.narrow{width:40%}.report-skeleton-bars{display:flex;gap:8px;align-items:flex-end;height:200px;padding-top:1rem}.skeleton-bar{flex:1;background:var(--color-background);border-radius:var(--radius-sm) var(--radius-sm) 0 0}@media print{.navbar,.admin-sidebar,.admin-mobile-header,.admin-sidebar-overlay,.no-print{display:none!important}.admin-main{margin-left:0!important;padding:0!important}.report-page{max-width:100%!important}.report-metrics-grid{grid-template-columns:repeat(3,1fr)}.report-charts-grid{grid-template-columns:1fr}.report-chart-section,.report-metric-card{box-shadow:none;border:1px solid var(--color-border);break-inside:avoid}.report-bar-fill,.report-h-bar-fill{animation:none!important;transition:none!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.report-export-dropdown{display:none!important}}@media(max-width:1024px){.report-charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.report-metrics-grid,.report-charts-grid{grid-template-columns:1fr}.report-preset-group{gap:.35rem}.report-preset-btn{padding:.4rem .75rem;font-size:.7rem}.report-filter-row{flex-direction:column;align-items:stretch}.report-flatpickr-wrapper{max-width:100%}.report-h-bar-row{grid-template-columns:80px 1fr 70px;gap:.5rem}.report-h-bar-name{font-size:.7rem}.report-bars-wrapper{height:180px}.report-metric-value{font-size:1.15rem}.admin-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}}.flatpickr-calendar{background:transparent;opacity:0;display:none;text-align:center;visibility:hidden;padding:0;-webkit-animation:none;animation:none;direction:ltr;border:0;font-size:14px;line-height:24px;border-radius:5px;position:absolute;width:307.875px;-webkit-box-sizing:border-box;box-sizing:border-box;-ms-touch-action:manipulation;touch-action:manipulation;background:#fff;-webkit-box-shadow:1px 0 0 #e6e6e6,-1px 0 0 #e6e6e6,0 1px 0 #e6e6e6,0 -1px 0 #e6e6e6,0 3px 13px rgba(0,0,0,.08);box-shadow:1px 0 #e6e6e6,-1px 0 #e6e6e6,0 1px #e6e6e6,0 -1px #e6e6e6,0 3px 13px #00000014}.flatpickr-calendar.open,.flatpickr-calendar.inline{opacity:1;max-height:640px;visibility:visible}.flatpickr-calendar.open{display:inline-block;z-index:99999}.flatpickr-calendar.animate.open{-webkit-animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1);animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1)}.flatpickr-calendar.inline{display:block;position:relative;top:2px}.flatpickr-calendar.static{position:absolute;top:calc(100% + 2px)}.flatpickr-calendar.static.open{z-index:999;display:block}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7){-webkit-box-shadow:none!important;box-shadow:none!important}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1){-webkit-box-shadow:-2px 0 0 #e6e6e6,5px 0 0 #e6e6e6;box-shadow:-2px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-calendar .hasWeeks .dayContainer,.flatpickr-calendar .hasTime .dayContainer{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.flatpickr-calendar .hasWeeks .dayContainer{border-left:0}.flatpickr-calendar.hasTime .flatpickr-time{height:40px;border-top:1px solid #e6e6e6}.flatpickr-calendar.noCalendar.hasTime .flatpickr-time{height:auto}.flatpickr-calendar:before,.flatpickr-calendar:after{position:absolute;display:block;pointer-events:none;border:solid transparent;content:"";height:0;width:0;left:22px}.flatpickr-calendar.rightMost:before,.flatpickr-calendar.arrowRight:before,.flatpickr-calendar.rightMost:after,.flatpickr-calendar.arrowRight:after{left:auto;right:22px}.flatpickr-calendar.arrowCenter:before,.flatpickr-calendar.arrowCenter:after{left:50%;right:50%}.flatpickr-calendar:before{border-width:5px;margin:0 -5px}.flatpickr-calendar:after{border-width:4px;margin:0 -4px}.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{bottom:100%}.flatpickr-calendar.arrowTop:before{border-bottom-color:#e6e6e6}.flatpickr-calendar.arrowTop:after{border-bottom-color:#fff}.flatpickr-calendar.arrowBottom:before,.flatpickr-calendar.arrowBottom:after{top:100%}.flatpickr-calendar.arrowBottom:before{border-top-color:#e6e6e6}.flatpickr-calendar.arrowBottom:after{border-top-color:#fff}.flatpickr-calendar:focus{outline:0}.flatpickr-wrapper{position:relative;display:inline-block}.flatpickr-months{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flatpickr-months .flatpickr-month{background:transparent;color:#000000e6;fill:#000000e6;height:34px;line-height:1;text-align:center;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1}.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;text-decoration:none;cursor:pointer;position:absolute;top:0;height:34px;padding:10px;z-index:3;color:#000000e6;fill:#000000e6}.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,.flatpickr-months .flatpickr-next-month.flatpickr-disabled{display:none}.flatpickr-months .flatpickr-prev-month i,.flatpickr-months .flatpickr-next-month i{position:relative}.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,.flatpickr-months .flatpickr-next-month.flatpickr-prev-month{left:0}.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,.flatpickr-months .flatpickr-next-month.flatpickr-next-month{right:0}.flatpickr-months .flatpickr-prev-month:hover,.flatpickr-months .flatpickr-next-month:hover{color:#959ea9}.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:#f64747}.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{width:14px;height:14px}.flatpickr-months .flatpickr-prev-month svg path,.flatpickr-months .flatpickr-next-month svg path{-webkit-transition:fill .1s;transition:fill .1s;fill:inherit}.numInputWrapper{position:relative;height:auto}.numInputWrapper input,.numInputWrapper span{display:inline-block}.numInputWrapper input{width:100%}.numInputWrapper input::-ms-clear{display:none}.numInputWrapper input::-webkit-outer-spin-button,.numInputWrapper input::-webkit-inner-spin-button{margin:0;-webkit-appearance:none}.numInputWrapper span{position:absolute;right:0;width:14px;padding:0 4px 0 2px;height:50%;line-height:50%;opacity:0;cursor:pointer;border:1px solid rgba(57,57,57,.15);-webkit-box-sizing:border-box;box-sizing:border-box}.numInputWrapper span:hover{background:#0000001a}.numInputWrapper span:active{background:#0003}.numInputWrapper span:after{display:block;content:"";position:absolute}.numInputWrapper span.arrowUp{top:0;border-bottom:0}.numInputWrapper span.arrowUp:after{border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:4px solid rgba(57,57,57,.6);top:26%}.numInputWrapper span.arrowDown{top:50%}.numInputWrapper span.arrowDown:after{border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid rgba(57,57,57,.6);top:40%}.numInputWrapper span svg{width:inherit;height:auto}.numInputWrapper span svg path{fill:#00000080}.numInputWrapper:hover{background:#0000000d}.numInputWrapper:hover span{opacity:1}.flatpickr-current-month{font-size:135%;line-height:inherit;font-weight:300;color:inherit;position:absolute;width:75%;left:12.5%;padding:7.48px 0 0;line-height:1;height:34px;display:inline-block;text-align:center;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}.flatpickr-current-month span.cur-month{font-family:inherit;font-weight:700;color:inherit;display:inline-block;margin-left:.5ch;padding:0}.flatpickr-current-month span.cur-month:hover{background:#0000000d}.flatpickr-current-month .numInputWrapper{width:6ch;width:7ch�;display:inline-block}.flatpickr-current-month .numInputWrapper span.arrowUp:after{border-bottom-color:#000000e6}.flatpickr-current-month .numInputWrapper span.arrowDown:after{border-top-color:#000000e6}.flatpickr-current-month input.cur-year{background:transparent;-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;cursor:text;padding:0 0 0 .5ch;margin:0;display:inline-block;font-size:inherit;font-family:inherit;font-weight:300;line-height:inherit;height:auto;border:0;border-radius:0;vertical-align:initial;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.flatpickr-current-month input.cur-year:focus{outline:0}.flatpickr-current-month input.cur-year[disabled],.flatpickr-current-month input.cur-year[disabled]:hover{font-size:100%;color:#00000080;background:transparent;pointer-events:none}.flatpickr-current-month .flatpickr-monthDropdown-months{appearance:menulist;background:transparent;border:none;border-radius:0;box-sizing:border-box;color:inherit;cursor:pointer;font-size:inherit;font-family:inherit;font-weight:300;height:auto;line-height:inherit;margin:-1px 0 0;outline:none;padding:0 0 0 .5ch;position:relative;vertical-align:initial;-webkit-box-sizing:border-box;-webkit-appearance:menulist;-moz-appearance:menulist;width:auto}.flatpickr-current-month .flatpickr-monthDropdown-months:focus,.flatpickr-current-month .flatpickr-monthDropdown-months:active{outline:none}.flatpickr-current-month .flatpickr-monthDropdown-months:hover{background:#0000000d}.flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month{background-color:transparent;outline:none;padding:0}.flatpickr-weekdays{background:transparent;text-align:center;overflow:hidden;width:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;height:28px}.flatpickr-weekdays .flatpickr-weekdaycontainer{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1}span.flatpickr-weekday{cursor:default;font-size:90%;background:transparent;color:#0000008a;line-height:1;margin:0;text-align:center;display:block;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;font-weight:bolder}.dayContainer,.flatpickr-weeks{padding:1px 0 0}.flatpickr-days{position:relative;overflow:hidden;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start;width:307.875px}.flatpickr-days:focus{outline:0}.dayContainer{padding:0;outline:0;text-align:left;width:307.875px;min-width:307.875px;max-width:307.875px;-webkit-box-sizing:border-box;box-sizing:border-box;display:inline-block;display:-ms-flexbox;display:-webkit-box;display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-wrap:wrap;-ms-flex-pack:justify;-webkit-justify-content:space-around;justify-content:space-around;-webkit-transform:translate3d(0,0,0);transform:translateZ(0);opacity:1}.dayContainer+.dayContainer{-webkit-box-shadow:-1px 0 0 #e6e6e6;box-shadow:-1px 0 #e6e6e6}.flatpickr-day{background:none;border:1px solid transparent;border-radius:150px;-webkit-box-sizing:border-box;box-sizing:border-box;color:#393939;cursor:pointer;font-weight:400;width:14.2857143%;-webkit-flex-basis:14.2857143%;-ms-flex-preferred-size:14.2857143%;flex-basis:14.2857143%;max-width:39px;height:39px;line-height:39px;margin:0;display:inline-block;position:relative;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;text-align:center}.flatpickr-day.inRange,.flatpickr-day.prevMonthDay.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.today.inRange,.flatpickr-day.prevMonthDay.today.inRange,.flatpickr-day.nextMonthDay.today.inRange,.flatpickr-day:hover,.flatpickr-day.prevMonthDay:hover,.flatpickr-day.nextMonthDay:hover,.flatpickr-day:focus,.flatpickr-day.prevMonthDay:focus,.flatpickr-day.nextMonthDay:focus{cursor:pointer;outline:0;background:#e6e6e6;border-color:#e6e6e6}.flatpickr-day.today{border-color:#959ea9}.flatpickr-day.today:hover,.flatpickr-day.today:focus{border-color:#959ea9;background:#959ea9;color:#fff}.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange,.flatpickr-day.selected.inRange,.flatpickr-day.startRange.inRange,.flatpickr-day.endRange.inRange,.flatpickr-day.selected:focus,.flatpickr-day.startRange:focus,.flatpickr-day.endRange:focus,.flatpickr-day.selected:hover,.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover,.flatpickr-day.selected.prevMonthDay,.flatpickr-day.startRange.prevMonthDay,.flatpickr-day.endRange.prevMonthDay,.flatpickr-day.selected.nextMonthDay,.flatpickr-day.startRange.nextMonthDay,.flatpickr-day.endRange.nextMonthDay{background:#569ff7;-webkit-box-shadow:none;box-shadow:none;color:#fff;border-color:#569ff7}.flatpickr-day.selected.startRange,.flatpickr-day.startRange.startRange,.flatpickr-day.endRange.startRange{border-radius:50px 0 0 50px}.flatpickr-day.selected.endRange,.flatpickr-day.startRange.endRange,.flatpickr-day.endRange.endRange{border-radius:0 50px 50px 0}.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)){-webkit-box-shadow:-10px 0 0 #569ff7;box-shadow:-10px 0 #569ff7}.flatpickr-day.selected.startRange.endRange,.flatpickr-day.startRange.startRange.endRange,.flatpickr-day.endRange.startRange.endRange{border-radius:50px}.flatpickr-day.inRange{border-radius:0;-webkit-box-shadow:-5px 0 0 #e6e6e6,5px 0 0 #e6e6e6;box-shadow:-5px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay,.flatpickr-day.notAllowed,.flatpickr-day.notAllowed.prevMonthDay,.flatpickr-day.notAllowed.nextMonthDay{color:#3939394d;background:transparent;border-color:transparent;cursor:default}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover{cursor:not-allowed;color:#3939391a}.flatpickr-day.week.selected{border-radius:0;-webkit-box-shadow:-5px 0 0 #569ff7,5px 0 0 #569ff7;box-shadow:-5px 0 #569ff7,5px 0 #569ff7}.flatpickr-day.hidden{visibility:hidden}.rangeMode .flatpickr-day{margin-top:1px}.flatpickr-weekwrapper{float:left}.flatpickr-weekwrapper .flatpickr-weeks{padding:0 12px;-webkit-box-shadow:1px 0 0 #e6e6e6;box-shadow:1px 0 #e6e6e6}.flatpickr-weekwrapper .flatpickr-weekday{float:none;width:100%;line-height:28px}.flatpickr-weekwrapper span.flatpickr-day,.flatpickr-weekwrapper span.flatpickr-day:hover{display:block;width:100%;max-width:none;color:#3939394d;background:transparent;cursor:default;border:none}.flatpickr-innerContainer{display:block;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.flatpickr-rContainer{display:inline-block;padding:0;-webkit-box-sizing:border-box;box-sizing:border-box}.flatpickr-time{text-align:center;outline:0;display:block;height:0;line-height:40px;max-height:40px;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flatpickr-time:after{content:"";display:table;clear:both}.flatpickr-time .numInputWrapper{-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;width:40%;height:40px;float:left}.flatpickr-time .numInputWrapper span.arrowUp:after{border-bottom-color:#393939}.flatpickr-time .numInputWrapper span.arrowDown:after{border-top-color:#393939}.flatpickr-time.hasSeconds .numInputWrapper{width:26%}.flatpickr-time.time24hr .numInputWrapper{width:49%}.flatpickr-time input{background:transparent;-webkit-box-shadow:none;box-shadow:none;border:0;border-radius:0;text-align:center;margin:0;padding:0;height:inherit;line-height:inherit;color:#393939;font-size:14px;position:relative;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.flatpickr-time input.flatpickr-hour{font-weight:700}.flatpickr-time input.flatpickr-minute,.flatpickr-time input.flatpickr-second{font-weight:400}.flatpickr-time input:focus{outline:0;border:0}.flatpickr-time .flatpickr-time-separator,.flatpickr-time .flatpickr-am-pm{height:inherit;float:left;line-height:inherit;color:#393939;font-weight:700;width:2%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-align-self:center;-ms-flex-item-align:center;align-self:center}.flatpickr-time .flatpickr-am-pm{outline:0;width:18%;cursor:pointer;text-align:center;font-weight:400}.flatpickr-time input:hover,.flatpickr-time .flatpickr-am-pm:hover,.flatpickr-time input:focus,.flatpickr-time .flatpickr-am-pm:focus{background:#eee}.flatpickr-input[readonly]{cursor:pointer}@-webkit-keyframes fpFadeInDown{0%{opacity:0;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:1;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}}@keyframes fpFadeInDown{0%{opacity:0;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:1;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}}
