/* MASTERJI LIBRARY — COMPONENT STYLES — Premium Off-White Theme */

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 28px;border-radius:var(--radius-md);font-weight:600;font-size:0.9rem;transition:all var(--transition-base);position:relative;overflow:hidden;letter-spacing:0.02em}
.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.2),transparent);opacity:0;transition:opacity var(--transition-fast)}
.btn:hover::before{opacity:1}

.btn-primary{background:linear-gradient(135deg,var(--primary-gold),var(--deep-gold));color:#FFFFFF;font-weight:700;box-shadow:var(--shadow-gold)}
.btn-primary:hover{box-shadow:var(--shadow-gold-lg), var(--glow-gold);transform:translateY(-2px)}
.btn-primary:active{transform:translateY(0)}

.btn-secondary{background:rgba(201,169,110,0.08);color:var(--deep-gold);border:1px solid var(--border-gold)}
.btn-secondary:hover{background:rgba(201,169,110,0.15);box-shadow:var(--glow-gold-subtle)}

.btn-ghost{color:var(--text-secondary);background:transparent}
.btn-ghost:hover{color:var(--deep-gold);background:rgba(201,169,110,0.06)}

.btn-danger{background:rgba(198,40,40,0.08);color:var(--danger);border:1px solid rgba(198,40,40,0.2)}
.btn-danger:hover{background:rgba(198,40,40,0.15)}

.btn-success{background:rgba(46,125,50,0.08);color:var(--success);border:1px solid rgba(46,125,50,0.2)}
.btn-success:hover{background:rgba(46,125,50,0.15)}

.btn-sm{padding:8px 16px;font-size:0.8rem}
.btn-lg{padding:16px 36px;font-size:1rem}
.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md)}
.btn-icon.sm{width:32px;height:32px}
.btn-block{width:100%}

/* --- Inputs --- */
.form-group{margin-bottom:var(--space-lg)}
.form-label{display:block;font-size:0.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-sm);letter-spacing:0.02em}
.form-input{width:100%;padding:12px 16px;background:var(--bg-card-solid);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);font-size:0.9rem;transition:all var(--transition-base);box-shadow:inset 0 1px 2px rgba(0,0,0,0.04)}
.form-input:focus{border-color:var(--primary-gold);box-shadow:0 0 0 3px rgba(201,169,110,0.1), inset 0 1px 2px rgba(0,0,0,0.02)}
.form-input::placeholder{color:var(--text-muted)}
.form-input.error{border-color:var(--danger);box-shadow:0 0 0 3px rgba(198,40,40,0.08)}
.form-error{font-size:0.75rem;color:var(--danger);margin-top:var(--space-xs)}

textarea.form-input{min-height:100px;resize:vertical}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8A8A' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}

/* --- Toggle Switch --- */
.toggle{position:relative;width:48px;height:26px;cursor:pointer;display:inline-block}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-full);transition:all var(--transition-base)}
.toggle-slider::before{content:'';position:absolute;width:20px;height:20px;border-radius:50%;background:white;box-shadow:var(--shadow-sm);top:2px;left:2px;transition:all var(--transition-base)}
.toggle input:checked+.toggle-slider{background:linear-gradient(135deg,var(--primary-gold),var(--deep-gold));border-color:var(--primary-gold)}
.toggle input:checked+.toggle-slider::before{transform:translateX(22px)}

/* --- Badges --- */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:0.7rem;font-weight:600;letter-spacing:0.03em;text-transform:uppercase}
.badge-gold{background:rgba(201,169,110,0.12);color:var(--deep-gold);border:1px solid rgba(201,169,110,0.2)}
.badge-success{background:var(--success-bg);color:var(--success)}
.badge-danger{background:var(--danger-bg);color:var(--danger)}
.badge-warning{background:var(--warning-bg);color:var(--warning)}
.badge-info{background:var(--info-bg);color:var(--info)}

/* --- Cards --- */
.card{background:var(--bg-card-solid);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}
.card:hover{border-color:var(--border-color);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card-body{padding:var(--space-lg)}
.card-img{width:100%;aspect-ratio:3/4;object-fit:cover}

/* --- Tables --- */
.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-light);background:var(--bg-card-solid);box-shadow:var(--shadow-sm)}
.table{width:100%;border-collapse:collapse}
.table th{background:rgba(201,169,110,0.06);padding:14px 16px;text-align:left;font-size:0.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.05em;border-bottom:1px solid var(--border-light)}
.table td{padding:14px 16px;font-size:0.88rem;border-bottom:1px solid var(--border-light);color:var(--text-secondary)}
.table tbody tr{transition:background var(--transition-fast)}
.table tbody tr:hover{background:rgba(201,169,110,0.03)}
.table tbody tr:last-child td{border-bottom:none}

/* --- Tabs --- */
.tabs{display:flex;gap:4px;background:var(--bg-secondary);border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-light);overflow-x:auto}
.tab{padding:10px 20px;border-radius:var(--radius-sm);font-size:0.85rem;font-weight:500;color:var(--text-muted);transition:all var(--transition-base);white-space:nowrap;cursor:pointer}
.tab:hover{color:var(--text-secondary);background:rgba(255,255,255,0.6)}
.tab.active{color:var(--deep-gold);background:var(--bg-card-solid);font-weight:600;box-shadow:var(--shadow-sm)}

/* --- Search --- */
.search-box{position:relative;display:flex;align-items:center}
.search-box input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-card-solid);border:1px solid var(--border-light);border-radius:var(--radius-full);color:var(--text-primary);font-size:0.9rem;transition:all var(--transition-base)}
.search-box input:focus{border-color:var(--primary-gold);box-shadow:var(--glow-gold-subtle)}
.search-box .search-icon{position:absolute;left:16px;color:var(--text-muted);pointer-events:none}

/* --- Pagination --- */
.pagination{display:flex;gap:var(--space-sm);justify-content:center;margin-top:var(--space-xl)}
.page-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-card-solid);color:var(--text-secondary);font-size:0.85rem;transition:all var(--transition-base);border:1px solid var(--border-light)}
.page-btn:hover{background:rgba(201,169,110,0.08);color:var(--deep-gold);border-color:var(--border-gold)}
.page-btn.active{background:linear-gradient(135deg,var(--primary-gold),var(--deep-gold));color:white;font-weight:700;border-color:transparent;box-shadow:var(--shadow-gold)}

/* --- Dropdown --- */
.dropdown{position:relative;display:inline-block}
.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:var(--bg-card-solid);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-base);padding:var(--space-sm)}
.dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-item{padding:10px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:0.85rem;transition:all var(--transition-fast);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm)}
.dropdown-item:hover{background:rgba(201,169,110,0.06);color:var(--deep-gold)}

/* --- Chip / Tag --- */
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-full);background:rgba(201,169,110,0.06);color:var(--text-secondary);font-size:0.8rem;border:1px solid var(--border-light);transition:all var(--transition-fast);cursor:pointer}
.chip:hover{border-color:var(--primary-gold);color:var(--deep-gold)}
.chip.active{background:rgba(201,169,110,0.12);color:var(--deep-gold);border-color:var(--border-gold)}

/* --- Star Rating --- */
.stars{display:flex;gap:2px;color:var(--primary-gold)}
.stars .star{font-size:0.9rem}
.stars .star.empty{color:var(--text-muted)}

/* --- Quantity Selector --- */
.qty-selector{display:flex;align-items:center;border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden;width:fit-content;background:var(--bg-card-solid)}
.qty-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--text-secondary);font-size:1.1rem;transition:all var(--transition-fast)}
.qty-btn:hover{background:rgba(201,169,110,0.08);color:var(--deep-gold)}
.qty-value{width:44px;height:36px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:0.9rem;border-left:1px solid var(--border-light);border-right:1px solid var(--border-light)}

/* --- Price --- */
.price{font-family:var(--font-heading);font-weight:700;color:var(--deep-gold)}
.price-original{text-decoration:line-through;color:var(--text-muted);font-weight:400;font-size:0.85em;margin-left:8px}
.price-discount{background:var(--danger);color:white;font-size:0.7rem;padding:2px 8px;border-radius:var(--radius-full);font-weight:600;font-family:var(--font-body)}

/* --- Empty State --- */
.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl)}
.empty-state-icon{font-size:4rem;margin-bottom:var(--space-lg);opacity:0.3}
.empty-state h3{margin-bottom:var(--space-sm);color:var(--text-secondary)}
.empty-state p{color:var(--text-muted);margin-bottom:var(--space-lg)}

/* --- Stat Card --- */
.stat-card{background:var(--bg-card-solid);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}
.stat-card:hover{border-color:var(--border-gold);box-shadow:var(--shadow-md), var(--glow-gold-subtle);transform:translateY(-2px)}
.stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:var(--space-md);background:rgba(201,169,110,0.08)}
.stat-card .stat-value{font-size:1.8rem;font-weight:800;font-family:var(--font-heading);margin-bottom:4px}
.stat-card .stat-label{font-size:0.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em}
.stat-card .stat-change{font-size:0.75rem;margin-top:var(--space-sm);display:flex;align-items:center;gap:4px}

/* --- File Upload --- */
.file-upload{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;transition:all var(--transition-base);cursor:pointer;background:rgba(201,169,110,0.02)}
.file-upload:hover{border-color:var(--primary-gold);background:rgba(201,169,110,0.04)}
.file-upload.dragover{border-color:var(--deep-gold);background:rgba(201,169,110,0.08)}
.file-upload input[type="file"]{display:none}
.file-upload-icon{font-size:2.5rem;color:var(--text-muted);margin-bottom:var(--space-md)}
.file-upload-text{color:var(--text-secondary);font-size:0.9rem}
.file-upload-hint{color:var(--text-muted);font-size:0.8rem;margin-top:var(--space-sm)}

/* --- Status dots --- */
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}
.status-dot.active{background:var(--success);box-shadow:0 0 6px var(--success)}
.status-dot.inactive{background:var(--danger)}
.status-dot.pending{background:var(--warning);animation:glow-pulse 2s ease-in-out infinite}

/* Loading spinner */
.spinner{width:24px;height:24px;border:3px solid rgba(201,169,110,0.2);border-top-color:var(--primary-gold);border-radius:50%;animation:rotate 0.8s linear infinite}
@keyframes rotate{to{transform:rotate(360deg)}}
.spinner-overlay{position:absolute;inset:0;background:rgba(250,248,245,0.85);display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:10}
