:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;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;display:flex;place-items:center;min-width:320px;min-height:100vh}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}}#root{width:100%;margin:0;padding:0;text-align:left}html,body{margin:0;padding:0;background:#3e2c23}.site{min-height:100vh;background:#3e2c23;color:#f5ebdd}.panel{background:tan;color:#3e2c23;border-radius:12px;padding:24px;box-shadow:0 8px 24px #0003}.panel h1{margin:0 0 12px;font-size:26px}.panel p{margin:0;font-size:16px;line-height:1.6}.navbar{position:sticky;top:0;z-index:20;background:#5c4033;border-bottom:2px solid #6FAF8F}.navbarInner{max-width:1600px;margin:0 auto;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{font-weight:800;letter-spacing:.5px;font-size:20px;color:#f5ebdd}.brandClickable{cursor:pointer}.tabs{display:flex;gap:10px}.tabButton{border:1px solid #6FAF8F;background:transparent;color:#f5ebdd;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease}.tabButton:hover{background:#8fc9a8;color:#3e2c23}.tabButton.active{background:#6faf8f;color:#3e2c23;border-color:#6faf8f}.content{padding:40px 20px}.container{max-width:1600px;margin:0 auto}.analyzer-panel{display:flex;flex-direction:column;gap:24px}.analyzer-header h1{margin:0 0 6px;font-size:26px;color:#3e2c23}.analyzer-header p{margin:0;font-size:15px;color:#5c4033}.input-area{display:flex;flex-direction:column;gap:10px}.input-label{font-weight:700;font-size:14px;color:#3e2c23;text-transform:uppercase;letter-spacing:.5px}.food-textarea{width:100%;box-sizing:border-box;padding:14px 16px;border-radius:10px;border:2px solid #A0785A;background:#fdf6ee;color:#3e2c23;font-size:15px;font-family:inherit;resize:vertical;line-height:1.6;transition:border-color .2s}.food-textarea:focus{outline:none;border-color:#6faf8f}.food-textarea::placeholder{color:#a0785a}.analyze-btn{align-self:flex-start;background:#6faf8f;color:#3e2c23;border:none;padding:12px 28px;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s,transform .1s}.analyze-btn:hover:not(:disabled){background:#8fc9a8;transform:translateY(-1px)}.analyze-btn:disabled{opacity:.5;cursor:not-allowed}.btn-loading{display:flex;align-items:center;gap:8px}.spinner{width:14px;height:14px;border:2px solid #3E2C23;border-top-color:transparent;border-radius:50%;display:inline-block;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-area{background:#fdf6ee;border:2px solid #6FAF8F;border-radius:10px;padding:20px}.result-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.result-label{font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.5px;color:#5c4033}.result-rating{font-size:28px;font-weight:800;color:#6faf8f}.result-body{color:#3e2c23;font-size:15px;line-height:1.7;white-space:pre-wrap}.result-error{border-color:#c0392b;color:#c0392b}.homeSite{min-height:100vh;position:relative}.leftSidebar{position:fixed;top:0;left:0;width:96px;height:100vh;background:#4a342a;border-right:2px solid #6FAF8F;display:flex;flex-direction:column;align-items:center;padding:24px 12px;gap:28px;z-index:50;box-sizing:border-box}.sidebarTop{display:flex;flex-direction:column;align-items:center;gap:28px}.sidebarBottom{margin-top:auto;width:100%;display:flex;justify-content:center;padding-bottom:2px}.profileAvatar{width:62px;height:62px;border-radius:50%;background:#f5ebdd;color:#3e2c23;display:flex;align-items:center;justify-content:center;font-size:30px;box-shadow:0 4px 12px #00000040}.menuToggle{width:54px;height:54px;border:none;border-radius:14px;background:transparent;color:#f5ebdd;font-size:28px;cursor:pointer;transition:background .2s ease,transform .2s ease;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.menuToggle:hover{background:#ffffff1a;transform:translateY(-1px)}.menuIcon{display:block}.historyPanel{position:fixed;top:0;left:96px;width:280px;height:100vh;background:#5c4033;border-right:2px solid #6FAF8F;transform:translate(-100%);transition:transform .25s ease;z-index:40;padding:22px 18px;box-sizing:border-box;overflow-y:auto}.historyPanel.open{transform:translate(0)}.historyPanelHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;color:#f5ebdd}.historyPanelHeader h3{margin:0;font-size:18px}.closeHistoryBtn{border:none;background:transparent;color:#f5ebdd;font-size:20px;cursor:pointer}.historyList{display:flex;flex-direction:column;gap:10px}.historyItem{text-align:left;border:1px solid rgba(255,255,255,.12);background:#ffffff14;color:#f5ebdd;padding:12px 14px;border-radius:12px;cursor:pointer;transition:background .2s ease}.historyItem:hover{background:#ffffff24}.homeMain{margin-left:96px;min-height:100vh;transition:margin-left .25s ease}.homeMain.shifted{margin-left:376px}.homeNavbarInner{max-width:1500px}.navRight{display:flex;align-items:center;gap:18px}.compactTabs{gap:8px}.compactTabButton{padding:8px 14px;border-radius:999px;font-size:14px;font-weight:600}.logoBox{width:68px;height:68px;border:2px dashed #F5EBDD;color:#f5ebdd;display:flex;align-items:center;justify-content:center;font-weight:700;border-radius:10px;font-size:14px}.homeContent{padding:36px 28px 48px}.homeContainer{max-width:1450px;margin:0 auto}.homeHero{display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:center;min-height:520px;margin-top:24px}.homeVisual{display:flex;justify-content:center}.visualPlaceholder{width:100%;max-width:560px;min-height:370px;background:#e9ded2;border:2px solid #A0785A;border-radius:18px;padding:28px;box-sizing:border-box;color:#3e2c23;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:20px}.visualCircle{width:120px;height:120px;border-radius:50%;background:#fdf6ee;display:flex;align-items:center;justify-content:center;font-weight:700;color:#5c4033;border:2px solid #A0785A}.homeInstructions{color:#f5ebdd;max-width:520px}.homeInstructions h2{margin:0 0 18px;font-size:22px;color:#f5ebdd}.homeInstructions p{margin:0 0 16px;font-size:16px;line-height:1.55;color:#f5ebdd}.startButtonWrap{display:flex;justify-content:center;margin-top:24px}.startBtn{border:none;background:#3e2c23;color:#f5ebdd;padding:16px 54px;border-radius:14px;font-size:18px;font-weight:700;cursor:pointer;transition:transform .15s ease,background .2s ease;box-shadow:0 8px 24px #00000038}.startBtn:hover{background:#2f211a;transform:translateY(-1px)}.subPageContent{padding:36px 28px 48px}.subPageContainer{max-width:1450px;margin:0 auto}.subPagePanel{min-height:280px}.subPagePanel h1{margin:0 0 16px;font-size:34px;color:#3e2c23}.subPagePanel p{font-size:20px;line-height:1.7;color:#3e2c23}.loginBtn{width:100%;max-width:80px;padding:8px 5px;border-radius:10px;border:none;background:#6faf8f;color:#3e2c23;font-weight:700;cursor:pointer;font-size:12px;text-align:center}.loginBtn:hover{background:#8fc9a8}.pageBlurred{filter:blur(6px);pointer-events:none;-webkit-user-select:none;user-select:none}.loginModalOverlay{position:fixed;inset:0;background:#1e140f73;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;box-sizing:border-box;overflow:hidden}.loginModalCard{position:relative;width:100%;max-width:430px;max-height:90vh;overflow-y:auto;background:#fdf6ee;color:#3e2c23;border:2px solid #6FAF8F;border-radius:24px;padding:32px 28px 24px;box-shadow:0 20px 50px #00000047}.loginModalClose{position:absolute;top:14px;right:14px;width:36px;height:36px;border:none;border-radius:50%;background:#3e2c2314;color:#3e2c23;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.loginModalClose:hover{background:#3e2c2324}.loginModalHeader{margin-bottom:22px}.loginModalHeader h1{margin:0 0 8px;font-size:30px;color:#3e2c23}.loginModalHeader p{margin:0;font-size:15px;color:#6b5142}.loginForm{display:flex;flex-direction:column;gap:16px}.loginField{display:flex;flex-direction:column;gap:8px}.loginField label{font-size:14px;font-weight:700;color:#5c4033}.loginField input{width:100%;box-sizing:border-box;padding:14px 16px;border-radius:14px;border:2px solid #A0785A;background:#fffaf5;color:#3e2c23;font-size:15px;outline:none;transition:border-color .2s ease}.loginField input:focus{border-color:#6faf8f}.loginPrimaryBtn{margin-top:6px;width:100%;border:none;border-radius:14px;background:#6faf8f;color:#3e2c23;font-size:16px;font-weight:700;padding:14px 18px;cursor:pointer;transition:background .2s ease,transform .15s ease}.loginPrimaryBtn:hover{background:#8fc9a8;transform:translateY(-1px)}.loginSecondaryActions{margin-top:18px;display:flex;flex-direction:column;align-items:center;gap:10px}.loginTextBtn{border:none;background:none;color:#5c4033;cursor:pointer;font-size:14px;font-weight:600;text-decoration:underline}.loginTextBtn:hover{color:#3e2c23}.loginMessage{margin-top:16px;font-size:14px;color:#5c4033}.petModalOverlay{z-index:250}.petModalCard{max-width:900px;max-height:90vh;overflow-y:auto}.petChoiceRow{display:flex;gap:12px;margin-bottom:4px}.petChoiceBtn{flex:1;border:2px solid #A0785A;background:#fffaf5;color:#3e2c23;border-radius:14px;padding:12px 14px;font-weight:700;cursor:pointer;transition:all .2s ease}.petChoiceBtn.active{background:#6faf8f;border-color:#6faf8f;color:#3e2c23}.loginField select{width:100%;box-sizing:border-box;padding:14px 16px;border-radius:14px;border:2px solid #A0785A;background:#fffaf5;color:#3e2c23;font-size:15px;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;box-shadow:none;background-image:none}.petBlock{border:2px solid rgba(160,120,90,.35);border-radius:18px;padding:18px;margin-top:8px;background:#fffaf573}.petBlockTitle{margin:0 0 14px;font-size:20px;color:#5c4033}.petBlockHeader{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.petBlockTitle{margin:0;font-size:20px;color:#5c4033}.removePetBtn{border:none;background:#c0392b;color:#fff;padding:10px 14px;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s ease}.removePetBtn:hover{background:#a93226}.addPetBtn{width:100%;border:2px dashed #A0785A;background:transparent;color:#5c4033;border-radius:14px;padding:14px 18px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s ease}.addPetBtn:hover{background:#6faf8f1f;border-color:#6faf8f}.inputError{border-color:#c0392b!important;background:#fff0f0}@media(max-width:1100px){.homeHero{grid-template-columns:1fr;gap:28px}.homeInstructions{max-width:100%}.homeInstructions h2{font-size:28px}.homeInstructions p{font-size:18px}}@media(max-width:760px){.leftSidebar{width:78px;padding:20px 10px}.historyPanel{left:78px;width:240px}.homeMain{margin-left:78px}.homeMain.shifted{margin-left:318px}.navbarInner,.homeNavbarInner{flex-direction:column;align-items:flex-start}.navRight{width:100%;justify-content:space-between;flex-wrap:wrap}.compactTabs{flex-wrap:wrap}.content,.homeContent,.subPageContent{padding:24px 16px 32px}.visualPlaceholder{min-height:300px}.homeInstructions h2,.subPagePanel h1{font-size:24px}.homeInstructions p,.subPagePanel p{font-size:16px}.startBtn{width:100%;max-width:320px}}.mode-toggle-pill{margin-bottom:20px}.mode-toggle-track{position:relative;display:grid;grid-template-columns:1fr 1fr;background:#0000000f;border-radius:14px;padding:4px;gap:0}.mode-toggle-slider{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);background:#fff;border-radius:10px;box-shadow:0 1px 4px #0000001f;transition:transform .22s cubic-bezier(.4,0,.2,1);pointer-events:none}.mode-tab{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:none;background:transparent;border-radius:10px;font-size:.9rem;font-weight:500;color:#00000073;cursor:pointer;transition:color .18s ease;white-space:nowrap}.mode-tab.active{color:#000000d9;font-weight:600}.mode-tab-icon{font-size:1rem;line-height:1}.mode-hint{margin:8px 0 0;font-size:.8rem;color:#00000073;text-align:center}.drop-zone{border:2px dashed rgba(0,0,0,.18);border-radius:14px;background:#00000005;min-height:160px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .18s,background .18s;margin-bottom:14px;overflow:hidden}.drop-zone:hover:not(.has-image){border-color:#00000059;background:#0000000a}.drop-zone.drag-over{border-color:#4f8ef7;background:#4f8ef70f}.drop-zone.has-image{cursor:default;border-style:solid;border-color:#0000001a;min-height:unset}.drop-zone-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;text-align:center;pointer-events:none}.drop-zone-icon{font-size:2rem;line-height:1;opacity:.5}.drop-zone-text{font-size:.9rem;color:#00000080}.drop-zone-link{color:#4f8ef7;text-decoration:underline;text-underline-offset:2px}.drop-zone-sub{font-size:.75rem;color:#00000059}.drop-zone-preview{position:relative;width:100%}.drop-zone-preview img{display:block;width:100%;max-height:320px;object-fit:contain;border-radius:12px}.remove-image-btn{position:absolute;top:10px;right:10px;padding:5px 12px;background:#0000008c;color:#fff;border:none;border-radius:8px;font-size:.8rem;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s}.remove-image-btn:hover{background:#000000bf}
