:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#333;background-color:#f8f9fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{color:#667eea;text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:inherit}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 6px #0000001a;position:sticky;top:0;z-index:100}.navbar-top,.navbar-brand-mobile{display:none}.navbar-brand-desktop{display:block}.navbar-brand a{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.navbar-menu{display:flex;align-items:center;gap:1.5rem}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:8px;transition:background-color .2s}.nav-link:hover{background-color:#fff3}.admin-link{background-color:#ffd7004d}.admin-link:hover{background-color:#ffd70080}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background-color:#ffffff1a;border-radius:8px}.user-name{font-weight:500}.user-role{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;background-color:#fff3}.user-role.admin{background-color:#ffd70066}.btn{padding:.5rem 1rem;border-radius:8px;border:none;cursor:pointer;font-weight:500;transition:all .2s}.btn-primary{background-color:#fff;color:#667eea}.btn-primary:hover{background-color:#f0f0f0}.btn-logout{background-color:#fff3;color:#fff}.btn-logout:hover{background-color:#ffffff4d}.btn-logout-mobile{display:none}@media(max-width:650px){.navbar{flex-direction:column;padding:.75rem 1rem;gap:.5rem}.navbar-top{display:flex;justify-content:space-between;align-items:center;width:100%}.navbar-brand-desktop{display:none}.navbar-brand-mobile{display:block}.navbar-brand a{font-size:1.25rem}.btn.btn-logout-mobile{display:flex;align-items:center;justify-content:center;padding:0;font-size:1rem;background-color:#fff3;color:#fff;border:none;border-radius:50%;cursor:pointer;width:28px!important;height:28px!important;min-width:28px!important;max-width:28px!important;flex-shrink:0}.btn.btn-logout-mobile:hover{background-color:#ffffff4d}.btn-logout-desktop{display:none}.navbar-menu{gap:.5rem;flex-wrap:wrap;justify-content:center}.nav-link{padding:.4rem .6rem;font-size:.75rem}.user-info{padding:.35rem .5rem;gap:.4rem}.user-name{font-size:.8rem}.user-role{font-size:.65rem;padding:.15rem .35rem}.btn{padding:.4rem .6rem;font-size:.75rem}}@media(max-width:380px){.navbar{padding:.5rem .75rem;gap:.4rem}.navbar-brand a{font-size:1.1rem}.btn-logout-mobile{padding:.3rem .5rem;font-size:.65rem}.navbar-menu{gap:.35rem}.nav-link{padding:.3rem .45rem;font-size:.65rem}.user-info{padding:.25rem .4rem;gap:.25rem}.user-name{font-size:.7rem}.user-role{font-size:.55rem;padding:.1rem .25rem}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:#fff;border-radius:24px;padding:3rem;width:100%;max-width:420px;box-shadow:0 20px 60px #0003}.auth-header{text-align:center;margin-bottom:2rem}.auth-icon{font-size:3rem;display:block;margin-bottom:1rem}.auth-header h1{font-size:1.75rem;color:#333;margin:0 0 .5rem}.auth-header p{color:#666;margin:0}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.auth-error{background-color:#fee;color:#c00;padding:1rem;border-radius:12px;text-align:center;font-size:.875rem;border:1px solid #fcc}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password]{padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea}.checkbox-group{flex-direction:row}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:400}.checkbox-label input{width:18px;height:18px;accent-color:#667eea}.btn-submit{padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s;margin-top:.5rem}.btn-submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.auth-footer{margin-top:2rem;text-align:center}.auth-footer p{color:#666;margin:0}.auth-footer a{color:#667eea;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.sweet-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000001a;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.sweet-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.sweet-card.out-of-stock{opacity:.7}.sweet-image{position:relative;height:180px;background:linear-gradient(135deg,#ffecd2,#fcb69f);display:flex;align-items:center;justify-content:center;overflow:hidden}.sweet-image img{width:100%;height:100%;object-fit:cover}.sweet-placeholder{display:flex;align-items:center;justify-content:center}.category-emoji{font-size:4rem}.stock-badge{position:absolute;top:10px;right:10px;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.stock-badge.out{background-color:#f44;color:#fff}.stock-badge.low{background-color:#fa0;color:#fff}.sweet-content{padding:1.25rem;flex:1;display:flex;flex-direction:column}.sweet-header{margin-bottom:.75rem}.sweet-name{font-size:1.25rem;font-weight:600;color:#333;margin:0 0 .25rem}.sweet-category{font-size:.875rem;color:#667eea;font-weight:500}.sweet-description{color:#666;font-size:.875rem;margin-bottom:1rem;line-height:1.5;flex:1}.sweet-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem;background-color:#f8f9fa;border-radius:8px}.sweet-price{font-size:1.5rem;font-weight:700;color:#333}.sweet-price .currency{font-size:1rem;color:#667eea}.sweet-quantity{text-align:right}.qty-label{font-size:.75rem;color:#666;display:block}.qty-value{font-size:1.25rem;font-weight:600;color:#28a745}.qty-value.low{color:#fa0}.sweet-actions{margin-top:auto}.purchase-section{display:flex;gap:.75rem;align-items:center}.quantity-selector{display:flex;align-items:center;background-color:#f0f0f0;border-radius:8px;overflow:hidden}.quantity-selector button{width:36px;height:36px;border:none;background-color:transparent;cursor:pointer;font-size:1.25rem;color:#667eea;transition:background-color .2s}.quantity-selector button:hover:not(:disabled){background-color:#e0e0e0}.quantity-selector button:disabled{color:#ccc;cursor:not-allowed}.quantity-selector span{padding:0 1rem;font-weight:600}.btn-purchase{flex:1;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s}.btn-purchase:hover:not(:disabled){opacity:.9;transform:scale(1.02)}.btn-purchase:disabled{background:#ccc;cursor:not-allowed}.out-of-stock-message{text-align:center;color:#f44;font-style:italic;padding:.75rem;background-color:#fff0f0;border-radius:8px}.admin-actions{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.btn-edit,.btn-delete,.btn-restock{padding:.5rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:opacity .2s}.btn-restock{background-color:#28a745;color:#fff}.btn-edit:hover,.btn-delete:hover,.btn-restock:hover{opacity:.9}.restock-form{display:flex;gap:.5rem;align-items:center}.restock-form input{width:60px;padding:.5rem;border:2px solid #28a745;border-radius:6px;text-align:center;font-weight:600}.btn-confirm{padding:.5rem .75rem;background-color:#28a745;color:#fff;border:none;border-radius:6px;cursor:pointer}.btn-cancel{padding:.5rem .75rem;background-color:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer}@media(max-width:650px){.sweet-card{border-radius:12px}.sweet-image{height:150px}.category-emoji{font-size:3rem}.stock-badge{font-size:.65rem;padding:.2rem .5rem}.sweet-content{padding:1rem}.sweet-name{font-size:1.1rem}.sweet-category{font-size:.8rem}.sweet-description{font-size:.8rem;margin-bottom:.75rem}.sweet-details{padding:.5rem;margin-bottom:.75rem}.sweet-price{font-size:1.25rem}.sweet-price .currency{font-size:.875rem}.qty-label{font-size:.65rem}.qty-value{font-size:1rem}.purchase-section{flex-direction:column;gap:.5rem}.quantity-selector{width:100%;justify-content:center}.quantity-selector button{width:40px;height:40px}.quantity-selector span{padding:0 1.5rem}.btn-purchase{width:100%;padding:.7rem;font-size:.9rem}.out-of-stock-message{font-size:.8rem;padding:.5rem}.admin-actions{gap:.35rem;margin-top:.5rem}.btn-edit,.btn-delete,.btn-restock{flex:1;padding:.45rem .5rem;font-size:.75rem}.restock-form{flex-wrap:wrap}.restock-form input{width:50px;padding:.4rem}.btn-confirm,.btn-cancel{padding:.4rem .6rem;font-size:.75rem}}.search-filter{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem}.search-main{display:flex;gap:1rem;align-items:center}.search-input-wrapper{flex:1;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.25rem}.search-input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:#667eea}.btn-search{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-search:hover{opacity:.9}.btn-filter-toggle{padding:.875rem 1rem;background-color:#f0f0f0;color:#333;border:none;border-radius:12px;cursor:pointer;font-weight:500;transition:background-color .2s}.btn-filter-toggle:hover{background-color:#e0e0e0}.filter-options{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end}.filter-group{flex:1;min-width:150px;max-width:250px}.filter-group label{font-weight:600;color:#333;font-size:.875rem;display:block;margin-bottom:.5rem}.filter-group select{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;cursor:pointer}.filter-group select:focus{outline:none;border-color:#667eea}.price-range{display:flex;align-items:center;gap:.5rem}.price-range input{width:70px;min-width:60px;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;box-sizing:border-box}.price-range input:focus{outline:none;border-color:#667eea}.price-range span{color:#666;font-weight:500}.filter-actions{display:flex;gap:.75rem;align-items:flex-end;flex-shrink:0}.btn-apply{padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;white-space:nowrap}.btn-clear{padding:.75rem 1rem;background-color:#f0f0f0;color:#666;border:none;border-radius:8px;font-weight:500;cursor:pointer;white-space:nowrap}.btn-clear:hover{background-color:#e0e0e0}@media(max-width:900px){.filter-options{flex-direction:column;align-items:stretch}.filter-group{max-width:100%}.price-range input{flex:1;width:auto}.filter-actions{justify-content:flex-start;margin-top:.5rem}}@media(max-width:768px){.search-main{flex-direction:column}.search-input-wrapper,.btn-search,.btn-filter-toggle{width:100%}}@media(max-width:650px){.search-filter{padding:1rem;border-radius:12px;margin-bottom:1rem}.search-main{gap:.75rem}.search-input{padding:.75rem .75rem .75rem 2.5rem;font-size:.875rem;border-radius:8px}.search-icon{left:.75rem;font-size:1rem}.btn-search{padding:.75rem 1rem;font-size:.875rem;border-radius:8px}.btn-filter-toggle{padding:.75rem;font-size:.875rem;border-radius:8px}.filter-options{margin-top:1rem;padding-top:1rem;gap:1rem}.filter-group{min-width:100%}.filter-group label{font-size:.8rem;margin-bottom:.35rem}.filter-group select{padding:.6rem;font-size:.875rem}.price-range{gap:.35rem}.price-range input{padding:.6rem;font-size:.875rem;min-width:50px}.price-range span{font-size:.875rem}.filter-actions{width:100%;justify-content:stretch}.btn-apply,.btn-clear{flex:1;padding:.65rem .75rem;font-size:.875rem}}.dashboard{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-header h1{font-size:2.5rem;color:#333;margin:0 0 .5rem}.dashboard-header p{color:#666;font-size:1.125rem;margin:0}.notification{padding:1rem 1.5rem;border-radius:12px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.notification.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.notification button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit;line-height:1}.loading{text-align:center;padding:4rem 2rem}.spinner{width:50px;height:50px;border:4px solid #f0f0f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading p{color:#666;font-size:1.125rem}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a}.empty-icon{font-size:4rem;display:block;margin-bottom:1rem}.empty-state h2{color:#333;margin:0 0 .5rem}.empty-state p{color:#666;margin:0}.results-count{color:#666;margin-bottom:1rem;font-size:.875rem}.sweets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}@media(max-width:768px){.dashboard{padding:1rem}.dashboard-header h1{font-size:2rem}.sweets-grid{grid-template-columns:1fr}}@media(max-width:650px){.dashboard{padding:.75rem}.dashboard-header{margin-bottom:1rem}.dashboard-header h1{font-size:1.5rem}.dashboard-header p{font-size:.875rem}.sweets-grid{gap:1rem}.results-count{font-size:.8rem;margin-bottom:.75rem}.notification{padding:.75rem 1rem;font-size:.875rem}}.admin-page{max-width:1400px;margin:0 auto;padding:2rem}.admin-page h1{font-size:2rem;color:#333;margin:0 0 .5rem}.admin-page .subtitle{color:#666;margin-bottom:2rem}.alert{padding:1rem 1.5rem;border-radius:12px;margin-bottom:1.5rem}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.admin-content{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:1024px){.admin-content{grid-template-columns:400px 1fr}}.form-section,.inventory-section{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 6px #0000001a}.form-section h2,.inventory-section h2{font-size:1.25rem;color:#333;margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:1px solid #eee}.sweet-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:flex;flex-wrap:wrap;gap:1rem}.form-row .form-group{flex:1;min-width:140px}@media(max-width:500px){.form-row{flex-direction:column}.form-row .form-group{min-width:100%}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:1rem;margin-top:.5rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-secondary{background-color:#f0f0f0;color:#666}.btn:hover{opacity:.9}.inventory-table-wrapper{overflow-x:auto}.inventory-table{width:100%;border-collapse:collapse;font-size:.875rem}.inventory-table th,.inventory-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #eee}.inventory-table th{background-color:#f8f9fa;font-weight:600;color:#333}.inventory-table tr:hover{background-color:#f8f9fa}.inventory-table tr.out-of-stock{background-color:#fff5f5}.name-cell{font-weight:500}.low-stock{color:#f60;font-weight:600}.actions-cell{white-space:nowrap}.btn-sm{padding:.4rem .75rem;font-size:.75rem;margin-right:.5rem}.btn-edit{background-color:#17a2b8;color:#fff}.btn-delete{background-color:#dc3545;color:#fff}.loading{text-align:center;padding:4rem;color:#666}@media(max-width:650px){.admin-page{padding:.75rem}.admin-page h1{font-size:1.5rem}.admin-page .subtitle{font-size:.875rem;margin-bottom:1rem}.form-section,.inventory-section{padding:1rem;border-radius:12px}.form-section h2,.inventory-section h2{font-size:1.1rem;margin-bottom:1rem;padding-bottom:.75rem}.sweet-form{gap:1rem}.form-row{gap:.75rem}.form-group label{font-size:.8rem}.form-group input,.form-group select,.form-group textarea{padding:.6rem;font-size:.875rem;border-radius:6px}.form-group textarea{min-height:60px}.form-actions{flex-direction:column;gap:.5rem}.btn{width:100%;padding:.65rem 1rem;font-size:.875rem}.inventory-table th,.inventory-table td{padding:.5rem;font-size:.75rem}.btn-sm{padding:.3rem .5rem;font-size:.65rem;margin-right:.25rem}.alert{padding:.75rem 1rem;font-size:.875rem;border-radius:8px}.loading{padding:2rem}}*{box-sizing:border-box}.app{min-height:100vh;background-color:#f8f9fa}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-screen .spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{font-size:1.125rem;margin:0}
