.navbar{color:var(--text-primary);padding:0}.navbar-container{max-width:1280px;margin:0 auto;padding:0 1rem;height:64px;display:flex;align-items:center;gap:12px}.navbar-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text-primary);font-weight:700;white-space:nowrap;flex-shrink:0}.navbar-brand:hover{opacity:.8}.logo{font-size:1.6rem}.title{font-size:1.1rem}.kitchen-selector{flex:1;max-width:300px}.kitchen-dropdown{width:100%;padding:7px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease;outline:none}.kitchen-dropdown:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--glow)}.nav-menu{display:flex;gap:2px;align-items:center;flex:1}.nav-link{display:flex;align-items:center;gap:6px;padding:8px 12px;text-decoration:none;color:var(--text-secondary);font-size:14px;font-weight:500;border-radius:var(--radius-md);transition:background .15s ease,color .15s ease;white-space:nowrap}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{background:var(--bg-tertiary);color:var(--accent)}.navbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}.menu-toggle{display:none;background:none;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;padding:6px;margin-left:auto}.user-menu-wrapper{position:relative}.user-menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background .18s ease,color .18s ease}.user-menu-btn:hover{background:var(--bg-secondary);color:var(--accent)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:210px;z-index:200;overflow:hidden}.user-dropdown-header{padding:12px 16px;display:flex;flex-direction:column;gap:2px}.user-dropdown-header strong{font-size:14px;color:var(--text-primary)}.user-dropdown-header span{font-size:12px;color:var(--text-muted)}.user-dropdown hr{border:none;border-top:1px solid var(--border)}.user-dropdown button{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-secondary);transition:background .15s;text-align:left}.user-dropdown button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.user-dropdown .logout-item{color:var(--danger)}.user-dropdown .logout-item:hover{background:#ef444414;color:var(--danger)}@media (max-width: 768px){.menu-toggle{display:flex;align-items:center;justify-content:center}.nav-menu{display:none;position:absolute;top:64px;left:0;right:0;flex-direction:column;background:var(--nav-bg);border-bottom:1px solid var(--nav-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:8px;gap:2px;z-index:99}.nav-menu.active{display:flex}.nav-link{width:100%}.title{display:none}.kitchen-selector{flex:unset;max-width:180px}.navbar-container{flex-wrap:nowrap}}.home{padding:2rem 1rem;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#667eea,#764ba2)}.container{max-width:1000px;margin:0 auto}.welcome-section{text-align:center;color:#fff;margin-bottom:2rem}.welcome-section h1{font-size:2.2rem;font-weight:700;margin-bottom:.5rem}.welcome-section p{font-size:1.1rem;opacity:.9}.home-error{background:#f56565e6;color:#fff;padding:.75rem 1rem;border-radius:.75rem;margin-bottom:1rem}.home-success{background:#48bb78e6;color:#fff;padding:.75rem 1rem;border-radius:.75rem;margin-bottom:1rem}.invites-section{margin-bottom:2rem}.invites-section h2{color:#fff;font-size:1.2rem;display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.invites-list{display:flex;flex-direction:column;gap:.5rem}.invite-card{background:#fff;border-radius:.75rem;padding:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.invite-info{display:flex;flex-direction:column;gap:.25rem}.invite-info strong{color:#2d3748}.invite-info span{font-size:.85rem;color:#718096}.invite-actions{display:flex;gap:.5rem}.btn-accept{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#48bb78;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:13px}.btn-decline{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#fc8181;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:13px}.kitchens-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-bottom:2rem}.kitchen-card{background:#fff;border:2px solid transparent;border-radius:1rem;padding:1.25rem;cursor:pointer;transition:all .3s ease;color:#333}.kitchen-card:hover{border-color:#fff9;transform:translateY(-4px);box-shadow:0 8px 24px #0003}.kitchen-card.selected{border-color:#48bb78;box-shadow:0 0 0 3px #48bb784d,0 8px 24px #00000026}.kitchen-icon{font-size:2.5rem;margin-bottom:.5rem}.kitchen-card h3{font-size:1.15rem;margin:.5rem 0 .25rem;color:#2d3748}.kitchen-card p{font-size:.85rem;color:#999;margin:0 0 .75rem}.kitchen-info{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:.75rem;border-top:1px solid #f0f0f0;flex-wrap:wrap}.info-item{display:flex;align-items:center;gap:4px;font-size:.8rem;color:#666}.admin-badge{display:inline-block;background:#667eea;color:#fff;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.btn-invite{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#667eea1a;color:#667eea;border:1px solid #667eea;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.invite-form{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f0f0f0}.invite-form input{width:100%;padding:8px 10px;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;box-sizing:border-box;margin-bottom:.5rem}.invite-form-actions{display:flex;gap:.5rem}.add-kitchen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#ffffff26;border:2px dashed rgba(255,255,255,.4);color:#fff;font-size:1rem;font-weight:600}.add-kitchen:hover{background:#ffffff40;border-color:#ffffffb3}.create-form{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 20px #00000026;margin-bottom:2rem}.create-form h3{font-size:1.15rem;margin:0 0 1rem;color:#2d3748}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:4px;color:#333;font-weight:500;font-size:.9rem}.create-form input{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;box-sizing:border-box}.create-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-actions{display:flex;gap:.75rem;margin-top:1rem}.home .btn-primary,.home .btn-secondary{flex:1;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.home .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.home .btn-secondary{background:#f0f0f0;color:#333}.kitchen-dashboard{margin-top:1rem}.kitchen-dashboard h2{color:#fff;font-size:1.4rem;margin-bottom:1rem}.stats-loading{color:#fffc;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:1rem;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #0000001a}.stat-card svg{color:var(--primary, #667eea);flex-shrink:0}.stat-card.warning svg{color:var(--warning, #ecc94b)}.stat-card.danger svg{color:var(--danger, #f56565)}.stat-content h3{margin:0;color:#2d3748;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.stat-value{margin:.3rem 0 0;font-size:1.75rem;font-weight:700;color:var(--primary, #667eea)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.action-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;border-radius:.75rem;text-decoration:none;font-weight:600;transition:all .3s ease;border:none;cursor:pointer;font-size:1rem}.action-btn.primary{background:#fff;color:var(--primary, #667eea)}.action-btn.primary:hover{transform:translateY(-3px);box-shadow:0 15px 30px #0003}.action-btn.secondary{background:#fff3;color:#fff;border:2px solid white}.action-btn.secondary:hover{background:#ffffff4d;transform:translateY(-3px)}.action-btn.warning{background:var(--warning, #ecc94b);color:#fff}.action-btn.warning:hover{transform:translateY(-3px)}@media (max-width: 768px){.welcome-section h1{font-size:1.6rem}.kitchens-grid,.stats-grid,.quick-actions{grid-template-columns:1fr}}.pantry{padding:2rem 1rem;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#667eea,#764ba2)}.pantry .container{max-width:1000px;margin:0 auto}.pantry h1{color:#fff;margin-bottom:2rem;font-size:2rem}.empty-state{background:#fff;border-radius:1rem;padding:3rem;text-align:center;color:var(--dark)}.pantry-group{margin-bottom:2rem}.pantry-category-heading{color:#ffffffe6;font-size:1rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .75rem .25rem;display:flex;align-items:center;gap:.5rem}.pantry-category-heading:after{content:"";flex:1;height:1px;background:#ffffff4d}.products-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.product-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:var(--shadow);animation:slideIn .3s ease;border-left:4px solid var(--success)}.product-card.expired{border-left-color:var(--danger);opacity:.7}.product-card.low-stock{border-left-color:var(--warning)}.product-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:.75rem}.product-thumb{width:56px;height:56px;object-fit:contain;border-radius:.5rem;flex-shrink:0;background:#f7fafc}.product-title{flex:1;min-width:0}.product-header h3{margin:0 0 .25rem;color:var(--dark)}.brand{margin:0;font-size:.9rem;color:#718096}.nutriscore{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:.5rem;font-weight:700;color:#fff;font-size:.9rem;flex-shrink:0}.nutriscore-a{background:var(--success)}.nutriscore-b{background:#9ae6b4}.nutriscore-c{background:var(--warning)}.nutriscore-d{background:#fc8181}.nutriscore-e{background:var(--danger)}.product-details{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;font-size:.9rem;color:var(--dark)}.stock{display:inline-flex;align-items:center;gap:.3rem;background:#4c51bf;color:#fff;padding:.25rem .6rem;border-radius:.25rem;font-weight:700;font-size:.85rem;line-height:1}.expiry{background:var(--border);padding:.25rem .75rem;border-radius:.25rem}.expiry.expired-text{background:#f5656533;color:var(--danger);font-weight:700}.quantity{background:#0000000d;color:var(--dark);padding:.25rem .75rem;border-radius:.25rem;font-size:.85rem}.product-actions{display:flex;gap:.5rem;align-items:center}.consume-row{display:flex;align-items:center;gap:.4rem;flex:1}.consume-qty{display:flex;align-items:center;gap:.25rem}.qty-mini-btn{width:28px;height:28px;border:1px solid #cbd5e0;background:#fff;border-radius:.375rem;font-size:1rem;font-weight:700;color:var(--primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.qty-mini-btn:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.qty-mini-btn:disabled{opacity:.35;cursor:not-allowed}.qty-mini-val{min-width:1.5rem;text-align:center;font-weight:700;font-size:.9rem;color:var(--dark)}.modal-qty{display:flex;align-items:center;justify-content:center;gap:.75rem;margin:.75rem 0 1.25rem}.modal-qty .qty-mini-btn{width:36px;height:36px;font-size:1.2rem}.modal-qty .qty-mini-val{font-size:1.3rem;min-width:2rem}.btn-consume,.btn-delete{flex:1;padding:.5rem 1rem;border:none;border-radius:.5rem;cursor:pointer;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s ease}.btn-consume{background:var(--success);color:#fff}.btn-consume:hover{transform:translateY(-2px);box-shadow:0 5px 15px #48bb784d}.btn-delete{background:var(--danger);color:#fff}.btn-delete:hover{transform:translateY(-2px);box-shadow:0 5px 15px #f565654d}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal-content{background:#fff;border-radius:1rem;padding:2rem;max-width:380px;width:100%;text-align:center;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideIn .25s ease}.modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;cursor:pointer;color:#718096;padding:4px}.modal-icon{color:#667eea;margin-bottom:.5rem}.modal-content h3{margin:.5rem 0;color:#2d3748;font-size:1.2rem}.modal-content p{color:#718096;font-size:.95rem;margin:.5rem 0 1.25rem;line-height:1.5}.modal-actions{display:flex;flex-direction:column;gap:.5rem}.btn-modal-primary{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;font-size:.95rem;transition:opacity .2s}.btn-modal-primary:hover{opacity:.9}.btn-modal-secondary{padding:.6rem 1rem;background:none;color:#718096;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;font-size:.9rem}.btn-modal-secondary:hover{background:#f7fafc}@media (max-width: 768px){.products-list{grid-template-columns:1fr}}.scan{padding:2rem 1rem;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#667eea,#764ba2)}.scan-container{max-width:640px;margin:0 auto}.scan-title{color:#fff;font-size:1.8rem;text-align:center;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.scan-mode-selector{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}.scan-mode-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1.25rem 2rem;background:#ffffff26;border:2px solid rgba(255,255,255,.3);border-radius:1rem;color:#fff;cursor:pointer;transition:all .2s;min-width:140px}.scan-mode-btn:hover{background:#ffffff40;border-color:#fff9;transform:translateY(-2px);box-shadow:0 8px 24px #0003}.mode-label{font-weight:700;font-size:1rem}.mode-desc{font-size:.7rem;opacity:.75}.error-dismiss{margin-left:auto;background:none;border:none;color:#fff;cursor:pointer;padding:2px;opacity:.8}.error-dismiss:hover{opacity:1}.scan-notice{background:#ffc832e6;color:#333;border-radius:.75rem;padding:.75rem 1rem;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem}.scan-viewport{position:relative;width:100%;aspect-ratio:4 / 3;background:#111;border-radius:1rem;overflow:hidden;box-shadow:0 20px 50px #00000080;margin-bottom:1rem}.scan-video{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1)}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.scan-zone{position:relative;width:70%;aspect-ratio:2 / 1;border:none}.corner{position:absolute;width:20px;height:20px;border-color:#fff;border-style:solid}.corner.tl{top:0;left:0;border-width:3px 0 0 3px}.corner.tr{top:0;right:0;border-width:3px 3px 0 0}.corner.bl{bottom:0;left:0;border-width:0 0 3px 3px}.corner.br{bottom:0;right:0;border-width:0 3px 3px 0}@keyframes scan-line{0%{top:4px;opacity:1}49%{top:calc(100% - 4px);opacity:1}50%{top:calc(100% - 4px);opacity:0}51%{top:4px;opacity:0}52%{top:4px;opacity:1}to{top:4px;opacity:1}}.scan-line{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#f00,transparent);box-shadow:0 0 6px 2px #f009;animation:scan-line 2s linear infinite}.scan-hint{margin-top:1rem;color:#fff;font-size:.85rem;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.8);padding:0 1rem}.scan-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#555;gap:.75rem;font-size:1rem}.scan-controls{display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.btn-scan{padding:.5rem 1rem;border:none;border-radius:.75rem;font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:transform .2s,box-shadow .2s}.btn-scan:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #00000040}.btn-scan:disabled{opacity:.5;cursor:not-allowed}.btn-scan.primary{background:#fff;color:#764ba2}.btn-scan.danger{background:#fc8181;color:#fff}.btn-scan.secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4)}.btn-scan.cart{background:#f6d365;color:#764ba2}.btn-scan.use{background:#ed8936;color:#fff}.scan-error{background:#f56565e6;color:#fff;padding:.75rem 1rem;border-radius:.75rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.result-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 20px 40px #0000004d;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.result-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.result-header h2{margin:0;font-size:1.2rem;color:#2d3748}.result-icon{color:#48bb78;flex-shrink:0}.result-image{width:100%;max-height:160px;object-fit:contain;border-radius:.5rem;margin-bottom:1rem;background:#f7f7f7}.result-grid{display:grid;grid-template-columns:1fr 2fr;gap:.4rem .75rem;margin-bottom:1rem}.result-label{font-weight:600;color:#718096;font-size:.85rem;display:flex;align-items:center}.result-value{color:#2d3748;font-size:.9rem;display:flex;align-items:center}.nutriscore{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:#fff;font-weight:700;font-size:.85rem}.nutriscore.grade-a{background:#2f855a}.nutriscore.grade-b{background:#68d391;color:#333}.nutriscore.grade-c{background:#f6e05e;color:#333}.nutriscore.grade-d{background:#ed8936}.nutriscore.grade-e{background:#e53e3e}.result-message{text-align:center;color:#48bb78;font-weight:600;margin:0}.quantity-selector{margin:1.5rem 0;padding:1rem;background:#f7f7f7;border-radius:.75rem}.quantity-selector label{display:block;font-weight:600;color:#2d3748;margin-bottom:.75rem;font-size:.95rem}.qty-controls{display:flex;align-items:center;gap:.5rem}.qty-btn{width:40px;height:40px;border:1px solid #cbd5e0;background:#fff;border-radius:.5rem;font-size:1.2rem;font-weight:700;color:#667eea;cursor:pointer;transition:all .2s;flex-shrink:0}.qty-btn:hover:not(:disabled){background:#667eea;color:#fff;border-color:#667eea}.qty-btn:disabled{opacity:.5;cursor:not-allowed}.qty-input{flex:1;padding:.75rem;border:1px solid #cbd5e0;border-radius:.5rem;font-size:1.1rem;text-align:center;font-weight:600;color:#2d3748}.qty-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.qty-input:disabled{background:#e2e8f0;cursor:not-allowed}.result-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.scan-popup-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10;padding:1rem}.scan-popup{background:#fff;border-radius:1rem;padding:.875rem;width:90%;max-width:270px;position:relative;box-shadow:0 20px 50px #0006;animation:slideIn .25s ease}.popup-close{position:absolute;top:.6rem;right:.6rem;background:none;border:none;cursor:pointer;color:#718096;padding:2px}.popup-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.75rem}.popup-check{color:#48bb78;flex-shrink:0}.popup-header h3{margin:0;font-size:1rem;color:#2d3748;line-height:1.3}.popup-image{width:100%;max-height:64px;object-fit:contain;border-radius:.5rem;margin-bottom:.5rem;background:#f7f7f7}.popup-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;font-size:.85rem;color:#718096}.popup-qty{background:#f7f7f7;border-radius:.5rem;padding:.75rem;margin-bottom:.75rem}.popup-qty label{display:block;font-weight:600;color:#2d3748;margin-bottom:.5rem;font-size:.85rem}.popup-qty .qty-controls{display:flex;align-items:center;gap:.4rem}.popup-qty .qty-btn{width:34px;height:34px;font-size:1rem}.popup-qty .qty-input{padding:.5rem;font-size:1rem}.popup-actions{display:flex;flex-direction:column;gap:.4rem}.popup-actions .btn-scan{justify-content:center;padding:.4rem .75rem;font-size:.8rem;width:100%}.popup-actions .btn-scan.cart{background:#f6d365;color:#764ba2}.popup-use-msg{font-size:.85rem;font-weight:600;color:#48bb78;margin-bottom:.5rem;text-align:center}.popup-use-confirm-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.popup-use-qty{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.popup-use-qty .qty-mini-btn{width:26px;height:26px;border:1px solid #cbd5e0;background:#fff;border-radius:.325rem;font-size:.95rem;font-weight:700;color:#667eea;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.popup-use-qty .qty-mini-btn:hover:not(:disabled){background:#667eea;color:#fff;border-color:#667eea}.popup-use-qty .qty-mini-btn:disabled{opacity:.35;cursor:not-allowed}.popup-use-qty .qty-mini-val{min-width:1.4rem;text-align:center;font-weight:700;font-size:.9rem;color:#2d3748}.btn-scan.compact{padding:.35rem .6rem;font-size:.78rem;flex:1}.result-use-msg{font-size:1rem;font-weight:600;color:#48bb78;text-align:center;padding:.75rem 0 .5rem}.search{padding:2rem 1rem;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#667eea,#764ba2)}.search .container{max-width:700px;margin:0 auto}.search h1{color:#fff;margin-bottom:2rem;font-size:2rem;text-align:center}.search-form{margin-bottom:2rem}.search-input-group{display:flex;background:#fff;border-radius:.75rem;padding:.75rem;gap:.75rem;align-items:center;box-shadow:var(--shadow)}.search-input-group svg{color:var(--primary);flex-shrink:0}.search-input-group input{flex:1;border:none;outline:none;font-size:1rem;padding:.5rem 0}.search-input-group button{background:var(--primary);color:#fff;border:none;padding:.5rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .3s ease}.search-input-group button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px)}.search-input-group button:disabled{opacity:.7;cursor:not-allowed}.no-results{background:#ffffffe6;padding:2rem;border-radius:.75rem;text-align:center;color:var(--dark)}.results{animation:slideIn .3s ease}.result-count{color:#fff;margin-bottom:1rem;font-weight:600}.results-list{display:flex;flex-direction:column;gap:1rem}.result-item{background:#fff;padding:1rem;border-radius:.75rem;box-shadow:var(--shadow);transition:all .3s ease}.result-item:hover{transform:translateY(-2px);box-shadow:0 15px 30px #0003}.result-item h3{margin:0 0 .25rem;color:var(--dark)}.brand{margin:0 0 .75rem;color:#718096;font-size:.9rem}.stock{margin:0;color:var(--primary);font-weight:600}.alerts{padding:2rem 1rem;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#667eea,#764ba2)}.alerts .container{max-width:1000px;margin:0 auto}.alerts h1{color:#fff;margin-bottom:2rem;font-size:2rem}.alerts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.alert-section{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:var(--shadow);animation:slideIn .3s ease}.alert-section h2{margin:0 0 1rem;color:var(--dark);display:flex;align-items:center;gap:.5rem}.alert-section.expired{border-left:4px solid var(--danger)}.alert-section.low-stock{border-left:4px solid var(--warning)}.no-items{color:#a0aec0;text-align:center;padding:1rem}.items-list{display:flex;flex-direction:column;gap:.75rem}.alert-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--light);border-radius:.5rem;animation:slideIn .3s ease}.alert-item h4{margin:0 0 .25rem;color:var(--dark)}.alert-item .expiry{margin:0;font-size:.8rem;color:var(--danger);font-weight:700}.alert-item .stock{margin:0;font-size:.9rem;color:var(--warning);font-weight:700}.btn-delete{background:var(--danger);color:#fff;border:none;padding:.5rem;border-radius:.25rem;cursor:pointer;transition:all .3s ease}.btn-delete:hover{transform:scale(1.1);background:#e53e3e}.badge{background:var(--warning);color:#fff;padding:.25rem .75rem;border-radius:.25rem;font-size:.8rem;font-weight:700}@media (max-width: 768px){.alerts-grid{grid-template-columns:1fr}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--auth-bg, linear-gradient(135deg, #667eea 0%, #764ba2 100%));padding:20px}.auth-box{background:var(--bg-secondary);border-radius:12px;box-shadow:0 10px 40px #0000004d;padding:40px;max-width:400px;width:100%;animation:slideIn .3s ease-out;border:1px solid var(--border)}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.auth-box h1{font-size:32px;margin:0 0 10px;text-align:center;color:var(--text-primary)}.auth-box h2{font-size:24px;margin:0 0 30px;text-align:center;color:var(--text-secondary);font-weight:500}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text-primary);font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:all .3s ease;box-sizing:border-box;background:var(--bg-input, var(--bg-primary));color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--glow, rgba(102, 126, 234, .1))}.form-group input:disabled{background-color:var(--bg-tertiary, #f5f5f5);cursor:not-allowed}.btn-primary{width:100%;padding:12px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover, #764ba2) 100%);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px var(--glow, rgba(102, 126, 234, .4))}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:var(--danger-bg, #fee);color:var(--danger, #c33);padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid var(--danger-border, #fcc)}.success-message{background-color:var(--success-bg, #eef8ee);color:var(--success, #2d7a2d);padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid var(--success-border, #b7e4b7);text-align:center}.success-message p{margin:6px 0}.btn-secondary{padding:10px 16px;background:var(--bg-tertiary, #f0f0f0);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:var(--border)}.auth-link{text-align:center;margin-top:20px;color:var(--text-secondary);font-size:14px}.auth-link a{color:var(--accent);text-decoration:none;font-weight:600;transition:color .3s ease}.auth-link a:hover{color:var(--accent-hover, var(--accent));text-decoration:underline}@media (max-width: 480px){.auth-box{padding:30px 20px}.auth-box h1{font-size:28px}.auth-box h2{font-size:20px}}.wiki-container{max-width:900px;margin:0 auto;padding:20px}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.access-denied svg{color:#ff6b6b;margin-bottom:20px}.access-denied h2{font-size:24px;color:#333;margin:0 0 10px}.access-denied p{color:#666;font-size:14px;margin:5px 0}.access-denied p.secondary{color:#999;font-size:12px}.wiki-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;gap:20px;flex-wrap:wrap}.wiki-header h1{font-size:32px;margin:0;color:#333}.wiki-header p{margin:5px 0 0;color:#999;font-size:14px}.header-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.font-size-control{display:flex;align-items:center;gap:8px}.font-size-control label{font-size:14px;color:#666;font-weight:500}.font-size-control select{padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-size:13px;cursor:pointer;background:#fff}.btn-action{display:flex;align-items:center;gap:8px;padding:10px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease}.btn-action:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.btn-download{background:linear-gradient(135deg,#4facfe,#00f2fe)}.wiki-content{background:#fff;border-radius:12px;padding:40px;box-shadow:0 2px 8px #0000001a;line-height:1.8;color:#333}.wiki-content h1{font-size:28px;margin:30px 0 20px;padding-bottom:10px;border-bottom:3px solid #667eea;color:#333}.wiki-content h1:first-child{margin-top:0}.wiki-content h2{font-size:22px;margin:25px 0 15px;color:#333}.wiki-content h3{font-size:18px;margin:20px 0 12px;color:#555}.wiki-content h4{font-size:16px;margin:15px 0 10px;color:#666;font-weight:600}.wiki-content p{margin:10px 0;text-align:justify}.wiki-content p.emphasis{font-weight:600;color:#667eea;margin:8px 0}.wiki-content p.table-row{font-family:Courier New,monospace;background:#f5f5f5;padding:8px 12px;border-radius:4px;margin:5px 0;font-size:13px;overflow-x:auto}.wiki-content li{margin:8px 0 8px 24px;list-style:disc}.wiki-content ul{margin:12px 0}.wiki-content code{background:#f5f5f5;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;color:#c33}.wiki-content strong{font-weight:700;color:#667eea}.spacer{height:12px}.toast{position:fixed;bottom:20px;right:20px;background:#4caf50;color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.wiki-header{flex-direction:column}.header-actions{width:100%}.wiki-content{padding:20px}.wiki-content h1{font-size:24px}.wiki-content h2{font-size:20px}}.cart{padding:2rem 1rem;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#f6d365,#fda085)}.cart-loading{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 70px);font-size:1.1rem;color:#764ba2}.cart-container{max-width:640px;margin:0 auto}.cart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.cart-header h1{color:#fff;font-size:1.8rem;margin:0;display:flex;align-items:center;gap:.5rem}.cart-actions{display:flex;gap:.5rem}.btn-icon{background:#ffffff40;border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:.5rem;padding:.5rem .75rem;cursor:pointer;display:flex;align-items:center;transition:background .2s}.btn-icon:hover{background:#fff6}.btn-icon.danger{background:#f5656566;border-color:#f5656580}.btn-icon.danger:hover{background:#f56565a6}.cart-search{background:#fff;border-radius:.75rem;padding:.5rem .75rem;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#718096}.cart-search input{border:none;outline:none;flex:1;font-size:.9rem;color:#2d3748}.clear-search{background:none;border:none;cursor:pointer;color:#718096;display:flex;padding:0}.add-form{background:#fff;border-radius:1rem;padding:1.25rem;margin-bottom:1rem;box-shadow:0 4px 20px #00000026}.add-form h3{margin:0 0 1rem;color:#2d3748;font-size:1rem}.add-fields{display:grid;grid-template-columns:1fr 80px;gap:.5rem;margin-bottom:.75rem}.add-fields .form-input:nth-child(3),.add-fields .form-input:nth-child(4){grid-column:1 / -1}.form-input{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.9rem;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}.form-input:focus{border-color:#fda085}.add-form-buttons{display:flex;gap:.5rem}.btn-primary{background:linear-gradient(135deg,#f6d365,#fda085);color:#fff;border:none;border-radius:.5rem;padding:.5rem 1.25rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:opacity .2s}.btn-primary:hover{opacity:.9}.btn-ghost{background:none;border:1px solid #e2e8f0;border-radius:.5rem;padding:.5rem 1rem;cursor:pointer;color:#718096;font-size:.9rem}.cart-error{background:#f56565e6;color:#fff;padding:.75rem 1rem;border-radius:.75rem;margin-bottom:1rem;font-size:.9rem}.cart-empty{background:#fff;border-radius:1rem;padding:3rem 1rem;text-align:center;color:#718096}.cart-empty svg{color:#fda085;margin-bottom:.75rem}.cart-empty p{font-size:1.1rem;margin-bottom:1.25rem}.cart-group{margin-bottom:1rem}.category-heading{color:#ffffffd9;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .4rem .25rem}.cart-item{background:#fff;border-radius:.75rem;padding:.75rem 1rem;display:flex;align-items:center;gap:.6rem;justify-content:space-between;margin-bottom:.4rem;box-shadow:0 2px 8px #00000014;transition:transform .15s}.cart-item-img{width:44px;height:44px;object-fit:contain;border-radius:.4rem;flex-shrink:0;background:#f7fafc}.cart-item-placeholder{display:flex;align-items:center;justify-content:center;color:#cbd5e0}.cart-item:hover{transform:translate(2px)}.item-info{flex:1;min-width:0}.item-name{display:block;font-weight:600;color:#2d3748;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-notes{display:block;font-size:.78rem;color:#a0aec0;margin-top:.1rem}.item-controls{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.qty-btn{background:#f7fafc;border:1px solid #e2e8f0;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#4a5568;transition:background .15s}.qty-btn:hover{background:#edf2f7}.item-qty{min-width:24px;text-align:center;font-weight:700;color:#2d3748;font-size:.95rem}.remove-btn{background:none;border:none;cursor:pointer;color:#cbd5e0;display:flex;align-items:center;margin-left:.25rem;transition:color .15s;padding:0}.remove-btn:hover{color:#fc8181}.cart-count{text-align:center;color:#ffffffbf;font-size:.85rem;margin-top:.5rem}.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.admin-sidebar{width:220px;background:var(--bg-secondary);border-right:1px solid var(--border);padding:24px 0;display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh}.admin-sidebar-brand{padding:0 20px 24px;font-size:15px;font-weight:700;color:var(--text-primary);border-bottom:1px solid var(--border);margin-bottom:8px}.admin-nav-link{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s}.admin-nav-link:hover,.admin-nav-link.active{background:var(--bg-tertiary);color:var(--accent)}.admin-sidebar-footer{margin-top:auto;padding:16px 20px;border-top:1px solid var(--border)}.admin-main{flex:1;padding:32px;overflow-y:auto}.admin-page-title{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:center}.stat-value{font-size:36px;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{font-size:13px;color:var(--text-muted);margin-top:6px;text-transform:uppercase;letter-spacing:.05em}.stat-card.pending .stat-value{color:var(--warning)}.stat-card.active .stat-value{color:var(--success)}.stat-card.rejected .stat-value{color:var(--danger)}.table-actions{display:flex;gap:6px}.admin-logo{padding:0 20px 24px;font-size:16px;font-weight:700;color:var(--text-primary);border-bottom:1px solid var(--border);margin-bottom:8px}.admin-logout{background:none;border:none;cursor:pointer;text-align:left;margin-top:auto;padding:10px 20px;border-top:1px solid var(--border);color:var(--danger);font-size:14px;font-weight:500;width:100%;transition:background .15s}.admin-logout:hover{background:var(--bg-tertiary)}.admin-loading{color:var(--text-muted);font-size:14px}.admin-empty{text-align:center;color:var(--text-muted);padding:32px 0;font-size:14px}.admin-alert{background:var(--warning-bg, #fef9e7);border:1px solid var(--warning);color:var(--text-primary);border-radius:var(--radius-md);padding:12px 16px;font-size:14px;margin-top:8px}.admin-alert a{color:var(--accent);text-decoration:none;font-weight:600}.admin-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.admin-card-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.admin-inline-form{display:flex;gap:12px;align-items:center}.admin-create-btn{white-space:nowrap;padding:10px 18px;border-radius:8px;background:var(--accent);color:#fff;border:none;font-weight:600;cursor:pointer;font-size:14px;transition:opacity .2s}.admin-create-btn:disabled{opacity:.6;cursor:not-allowed}.admin-hint{font-size:12px;color:var(--text-muted);margin-top:10px}.admin-filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.admin-filter-btn{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s,color .15s}.admin-filter-btn:hover,.admin-filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-filter-count{background:#ffffff40;border-radius:10px;padding:1px 7px;font-size:11px}.admin-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}.admin-row-dim td{opacity:.5}.admin-actions{display:flex;gap:6px;flex-wrap:wrap}.btn-action{padding:4px 10px;border-radius:6px;border:none;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-approve{background:var(--success-bg, #f0fdf4);color:var(--success)}.btn-reject{background:var(--danger-bg, #fef2f2);color:var(--danger)}.btn-delete{background:var(--bg-tertiary);color:var(--danger)}.btn-copy{background:var(--bg-tertiary);color:var(--text-secondary)}.admin-token{font-family:monospace;font-size:13px;color:var(--text-muted)}.badge-status{display:inline-flex;align-items:center;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600}.badge-active{background:var(--success-bg, #f0fdf4);color:var(--success)}.badge-rejected{background:var(--danger-bg, #fef2f2);color:var(--danger)}.badge-invited{background:var(--bg-tertiary);color:var(--accent)}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;overflow-y:auto}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:2rem;color:#fff}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.main-content{padding-bottom:80px}}:root,[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #f1f3f5;--text-primary: #0f1117;--text-secondary: #4a5568;--text-muted: #9ca3af;--accent: #3b82f6;--accent-hover: #2563eb;--border: #e5e7eb;--danger: #ef4444;--success: #10b981;--warning: #f59e0b;--danger-bg: #fef2f2;--danger-border: #fecaca;--success-bg: #f0fdf4;--success-border: #bbf7d0;--auth-bg: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--bg-input: #ffffff;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 10px 30px rgba(0,0,0,.12);--glow: rgba(59,130,246,.12);--nav-bg: rgba(255,255,255,.85);--nav-border: rgba(229,231,235,.8);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px}[data-theme=dark]{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--text-primary: #f0f6fc;--text-secondary: #8b949e;--text-muted: #484f58;--accent: #58a6ff;--accent-hover: #79c0ff;--border: #30363d;--danger: #ff6b6b;--success: #3fb950;--warning: #d29922;--danger-bg: #2d1515;--danger-border: #6b2c2c;--success-bg: #122d20;--success-border: #1a5c35;--auth-bg: linear-gradient(135deg, #1a1f2e 0%, #2d1b4e 100%);--bg-input: #21262d;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 10px 30px rgba(0,0,0,.6);--glow: rgba(88,166,255,.15);--nav-bg: rgba(13,17,23,.9);--nav-border: rgba(48,54,61,.8);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:background .18s ease,box-shadow .18s ease,transform .12s ease,opacity .18s ease;text-decoration:none;white-space:nowrap;line-height:1}.btn:active{transform:translateY(0)!important}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 0 3px var(--glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.btn-secondary .btn-spinner,.btn-ghost .btn-spinner{border-color:#0003;border-top-color:var(--text-primary)}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,border-color .2s ease}.card:hover{box-shadow:var(--shadow-md)}[data-theme=dark] .card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow-md)}.card-sm{padding:16px;border-radius:var(--radius-md)}.card-lg{padding:32px;border-radius:var(--radius-xl)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.02em}.badge-pending{background:#f59e0b26;color:var(--warning)}.badge-active{background:#10b98126;color:var(--success)}.badge-rejected{background:#ef444426;color:var(--danger)}.badge-invited{background:#3b82f626;color:var(--accent)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--bg-primary);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:border-color .18s ease,box-shadow .18s ease;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--glow)}.form-input.error{border-color:var(--danger)}.form-input.success{border-color:var(--success)}.form-error{font-size:12px;color:var(--danger);display:flex;align-items:center;gap:4px}.table-container{width:100%;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table thead tr{background:var(--bg-tertiary);position:sticky;top:0;z-index:1}.data-table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border)}.data-table td{padding:12px 16px;color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr:hover{background:var(--bg-secondary)}.data-table tbody tr:last-child td{border-bottom:none}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:280px;max-width:380px;pointer-events:all;animation:slideInRight .25s ease}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-info{border-left:3px solid var(--accent)}.toast-warning{border-left:3px solid var(--warning)}.toast-icon{font-size:16px;flex-shrink:0;margin-top:1px}.toast-body{flex:1}.toast-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.toast-message{font-size:13px;color:var(--text-secondary)}.toast-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:0;font-size:16px;line-height:1;flex-shrink:0}.toast-close:hover{color:var(--text-primary)}.navbar-glass{background:var(--nav-bg);border-bottom:1px solid var(--nav-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .25s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background .2s ease,color .2s ease}#root{min-height:100vh}:root{--primary: #667eea;--primary-dark: #764ba2;--shadow: 0 10px 30px rgba(0, 0, 0, .1);--shadow-md: 0 20px 40px rgba(0, 0, 0, .15)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease;flex-shrink:0}.theme-toggle:hover{background:var(--bg-secondary);color:var(--accent);box-shadow:0 0 0 2px var(--glow)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px;background:var(--bg-primary)}.spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.main-content{min-height:calc(100vh - 64px);background:var(--bg-primary)}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-slide-in{animation:slideIn .3s ease}.animate-fade-in{animation:fadeIn .3s ease}
