*,*:before,*:after{box-sizing:border-box}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1f2937;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background-color:#f8fafc}#root{width:100%;min-height:100vh;background-color:#f8fafc}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app-root{min-height:100vh;width:100%;margin:0;padding:2rem 1.5rem 3rem;background:#f8fafc;color:#1e293b;display:flex;flex-direction:column;align-items:center;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-header{width:100%;max-width:960px;margin-bottom:2rem;text-align:left}.app-header h1.app-header-title{font-size:2.2rem;margin:0 0 .5rem;letter-spacing:.02em;cursor:default;-webkit-user-select:none;user-select:none;color:#0f172a;font-weight:700}.intro-text{color:#334155;line-height:1.6;font-size:1rem;margin-top:1.5rem;margin-bottom:2.5rem}.intro-text p{margin:0 0 1rem}.intro-text h3{color:#0f172a;margin:1.5rem 0 1rem;font-size:1.25rem}.intro-important{font-weight:500;color:#0f172a;margin:1.5rem 0}.scoring-rules{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.75rem}.scoring-rules li{padding-left:1.5rem;position:relative}.scoring-rules li:before{content:"•";position:absolute;left:.5rem;color:#3b82f6;font-weight:700}.scoring-rules li strong{color:#0f172a}.intro-conclusion{font-weight:500;color:#0f172a;margin-top:2rem;font-style:italic;margin-bottom:0!important}.app-main{width:100%;max-width:960px}.file-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.recalculate-section{margin-bottom:1.5rem;display:flex;justify-content:center}.recalculate-button{padding:.75rem 1.5rem;background:#3b82f6e6;color:#fff;border:none;border-radius:.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .1s ease,box-shadow .2s ease;box-shadow:0 4px 12px #3b82f64d}.recalculate-button:hover:not(:disabled){background:#3b82f6;transform:translateY(-1px);box-shadow:0 6px 16px #3b82f666}.recalculate-button:active:not(:disabled){transform:translateY(0)}.recalculate-button:disabled{background:#3b82f680;cursor:not-allowed;opacity:.7}.status{padding:1rem 1.25rem;border-radius:.75rem;background:#fff;border:1px solid #e2e8f0;color:#1e293b}.status-loading{border-color:#3b82f6;background:#eff6ff}.status-error{border-color:#ef4444;color:#991b1b;background:#fef2f2}.toothpaste-list{list-style:none;margin:0;margin-top:1rem;padding:0;display:grid;grid-template-columns:1fr;gap:1rem}.toothpaste-card{background:#fff;border-radius:1rem;padding:1.5rem;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0f172a0f,0 2px 6px #0f172a0a;display:flex;flex-direction:column;gap:1.5rem;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.toothpaste-card-body{display:flex;flex-direction:row;align-items:center;gap:2rem}.toothpaste-image-wrapper{flex:0 0 160px}.toothpaste-image-container{width:160px;height:160px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;background:#fff}.toothpaste-image{width:100%;height:100%;object-fit:contain;object-position:center}.toothpaste-image-placeholder{width:160px;height:160px;border-radius:.5rem;background:#f1f5f9;border:2px dashed #cbd5e1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,border-color .2s ease}.toothpaste-image-placeholder:hover{background:#e2e8f0;border-color:#94a3b8}.upload-placeholder-text{color:#64748b;font-size:.95rem;font-weight:500}.toothpaste-card:hover{transform:translateY(-3px);border-color:#2dd4bf;box-shadow:0 10px 25px #0f766e1f,0 4px 10px #0f172a0f}.toothpaste-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.toothpaste-category{font-size:.85rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.toothpaste-name{font-weight:700;font-size:1.25rem;color:#0369a1;line-height:1.4;margin-bottom:.5rem}.toothpaste-score-section{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:0 0 120px;text-align:center}.score-value{font-size:1.8rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.2rem}.score-value.score-high{color:#10b981}.score-value.score-medium{color:#334155}.score-value.score-low{color:#ef4444}.score-label{font-size:.85rem;color:#94a3b8}.toothpaste-ingredients{margin-top:.5rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.ingredients-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;padding:.5rem 0;cursor:pointer;color:#64748b;transition:color .2s ease;outline:none;-webkit-tap-highlight-color:transparent}.ingredients-toggle:focus,.ingredients-toggle:focus-visible{outline:none;border:none}.ingredients-toggle:hover{color:#0f172a}.ingredients-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#475569;margin-bottom:.5rem}.ingredients-arrow{font-size:.75rem;transition:transform .2s ease;color:#94a3b8}.ingredients-list{margin-top:.5rem}.ingredients-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.ingredient-item{padding:.5rem .6rem;background:#f8fafc;border-radius:.5rem;font-size:.9rem;border:1px solid #e2e8f0}.ingredient-main{display:flex;flex-direction:column;gap:.3rem}.ingredient-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.ingredient-name{color:#1e293b;flex:1}.ingredient-non-essential{font-size:.8rem;color:#64748b;margin-top:.2rem;line-height:1.4}.ingredient-note{font-size:.8rem;color:#64748b;font-style:italic;margin-top:.2rem;line-height:1.4}.ingredient-score{font-weight:600;font-size:.875rem;padding:.2rem .5rem;border-radius:.375rem;min-width:2.5rem;text-align:right;flex-shrink:0}.ingredient-score.positive{color:#047857;background:#ccfbf1}.ingredient-score.neutral{color:#475569;background:#f1f5f9}.ingredient-score.negative{color:#b91c1c;background:#fee2e2}@media(max-width:640px){.app-root{padding:1.5rem 1rem 2.5rem}.app-header h1.app-header-title{font-size:1.7rem}.toothpaste-card-body{flex-direction:column;align-items:flex-start;gap:1.5rem}.toothpaste-image-wrapper{flex:0 0 auto;width:100%;display:flex;justify-content:center}.toothpaste-score-section{flex:0 0 auto;flex-direction:row;align-items:baseline;justify-content:space-between;width:100%;text-align:left;gap:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.score-value{margin-bottom:0}}.admin-root{min-height:100vh;width:100%;padding:2rem 1.5rem 3rem;background:#f8fafc;color:#1e293b;display:flex;flex-direction:column;align-items:center;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.admin-login-card{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;width:100%;max-width:400px;margin-top:10vh}.admin-login-card h2{margin-top:0;margin-bottom:1.5rem;text-align:center;color:#0f172a}.admin-login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:#475569}.form-group input{padding:.75rem;border:1px solid #cbd5e1;border-radius:.5rem;font-size:1rem}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.admin-header{width:100%;max-width:960px;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{font-size:2rem;margin:0;color:#0f172a}.logout-button{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer}.logout-button:hover{background:#dc2626}.admin-message{width:100%;max-width:960px;margin-bottom:1rem;background:#dcfce7;color:#166534;border-color:#22c55e}.admin-list{width:100%;max-width:960px;background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.admin-list-header{display:flex;background:#f1f5f9;padding:1rem;font-weight:600;border-bottom:1px solid #e2e8f0;color:#475569}.admin-list-item{display:flex;padding:1rem;border-bottom:1px solid #e2e8f0;align-items:center;gap:1rem;transition:background-color .2s}.admin-list-item:hover{background-color:#f8fafc}.col-name{flex:2;font-weight:500;color:#0f172a}.col-points{flex:1}.col-note{flex:3}.col-actions{flex:1;display:flex;justify-content:flex-end}.admin-input,.admin-input-small{width:100%;padding:.5rem;border:1px solid #cbd5e1;border-radius:.375rem;font-size:.9rem}.admin-input-small{max-width:80px}.admin-input:focus,.admin-input-small:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}.save-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem}.save-button:hover:not(:disabled){background:#2563eb}.save-button:disabled{opacity:.5;cursor:not-allowed}.scoring-root{max-width:800px;margin:0 auto;padding:2rem 1rem}.scoring-main{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000000d}.back-link{display:inline-block;padding:.75rem 1.5rem;background-color:var(--primary-color, #4CAF50);color:#fff;text-decoration:none;border-radius:8px;font-weight:500;transition:background-color .2s}.back-link:hover{background-color:var(--primary-color-dark, #45a049)}.navbar{background-color:#fff;box-shadow:0 2px 8px #0000000f;position:sticky;top:0;z-index:1000;font-family:inherit}.navbar-container{max-width:800px;margin:0 auto;padding:1rem;display:flex;justify-content:space-between;align-items:center}.navbar-logo a{font-size:1.25rem;font-weight:700;color:var(--primary-color, #4CAF50);text-decoration:none;letter-spacing:-.5px}.navbar-links{list-style:none;display:flex;gap:1.5rem;margin:0;padding:0}.navbar-links li{margin:0}.navbar-links a{text-decoration:none;color:var(--text-color, #333);font-weight:500;font-size:1rem;transition:all .2s ease;padding-bottom:.25rem;border-bottom:2px solid transparent}.navbar-links a:hover{color:var(--primary-color, #4CAF50)}.navbar-links a.active{color:var(--primary-color, #4CAF50);border-bottom:2px solid var(--primary-color, #4CAF50)}.hamburger-menu{display:none;flex-direction:column;justify-content:space-around;width:2rem;height:1.5rem;background:transparent;border:none;cursor:pointer;padding:0;z-index:10}.hamburger-line{width:100%;height:.2rem;background:var(--text-color, #333);border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.hamburger-line.open:nth-child(1){transform:rotate(45deg) translate(.4rem,-.5rem);width:1.6rem}.hamburger-line.open:nth-child(2){opacity:0;transform:translate(20px)}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(.4rem,.5rem);width:1.6rem}@media(max-width:768px){.hamburger-menu{display:flex}.navbar-container{position:relative}.navbar-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background-color:#fff;padding:1rem;box-shadow:0 4px 6px #0000000d;gap:1rem;align-items:center;border-top:1px solid #eee}.navbar-links.open{display:flex}}.layout-content{min-height:calc(100vh - 60px)}
