*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{color:#333;background-color:#f5f5f5;height:100%;font-family:Roboto,sans-serif;overflow:hidden}#app{flex-direction:column;height:100%;display:flex}.main-menu{color:#333;background-color:#fdfdfd;background-image:radial-gradient(at 0 0,#4eb1514d 0,#0000 50%),radial-gradient(at 100% 0,#ffd90026 0,#0000 50%),radial-gradient(at 100% 100%,#876c5e40 0,#0000 50%),radial-gradient(at 0 100%,#00bfff26 0,#0000 50%);background-size:200% 200%;flex-direction:column;flex:1;justify-content:center;align-items:center;animation:8s ease-in-out infinite alternate mesh-movement;display:flex}@keyframes mesh-movement{0%{background-position:0 0}25%{background-position:100% 0}50%{background-position:100% 100%}75%{background-position:0 100%}to{background-position:0 0}}.main-menu .title-container{text-align:center;margin-bottom:3rem}.main-menu h1{letter-spacing:-1px;color:#2e7d32;text-shadow:0 4px 12px #0000000d;margin-bottom:.2rem;font-size:3.5rem;font-weight:800}.main-menu .subtitle{color:#4caf50;letter-spacing:4px;text-shadow:0 2px 8px #0000000d;margin:0;font-size:2rem;font-weight:600}.main-menu button{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:99px;padding:1rem 2.5rem;font-size:1.25rem;font-weight:700;transition:transform .2s,box-shadow .2s;box-shadow:0 8px 16px #4caf504d}.main-menu #start-btn{line-height:1;animation:2.5s ease-in-out infinite float-button}.main-menu #start-btn:active{animation:none}@keyframes float-button{0%,to{transform:translateY(0);box-shadow:0 8px 16px #4caf504d}50%{transform:translateY(-6px);box-shadow:0 12px 24px #4caf5059}}.main-menu button:active{transform:scale(.96);box-shadow:0 4px 8px #4caf5033}.language-switcher{background:#ffffff80;border-radius:99px;padding:.25rem;display:flex;position:absolute;bottom:1rem;right:1rem}.language-switcher button{cursor:pointer;color:#666;background:0 0;border:none;padding:.5rem 1rem;font-weight:700}.language-switcher button.active{color:#4caf50;background:#fff;border-radius:99px;box-shadow:0 2px 4px #0000001a}.hud{background:#fff;border-bottom:1px solid #ddd;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.hud-header{cursor:pointer;align-items:center;gap:.75rem;display:flex}.diner-avatar{background:#eee;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;display:flex}.diner-info{flex:1}.diner-name{font-weight:700}.diner-target{color:#666;font-size:.8rem}.tooltip-drawer{background:#f8f9fa;border-radius:4px;max-height:0;padding:0 .5rem;font-size:.8rem;transition:max-height .3s ease-out,padding .3s ease-out;overflow:hidden}.macro-bars,.eco-bars{gap:.5rem;display:flex}.tooltip-drawer.show{max-height:5rem;padding:.5rem}.bar-container{flex:1}.bar{background:#eee;border-radius:10px;height:20px;position:relative;overflow:hidden}.bar .fill{background:#4caf50;height:100%;transition:width .3s;position:absolute}.bar.carbs .fill{background:gold}.bar.protein .fill{background:tomato}.bar.fats .fill{background:#00f}.bar.water .fill,.bar.water{background:#00bfff}.bar.water .fill{background:#eee}.bar.land .fill,.bar.land{background:#8b4513}.bar.land .fill{background:#eee}.bar.carbs.over .fill{animation:1.5s infinite pulse-carbs}.bar.protein.over .fill{animation:1.5s infinite pulse-protein}.bar.fats.over .fill{animation:1.5s infinite pulse-fats}.bar.water.over .fill,.bar.land.over .fill{animation:1.5s infinite pulse-red}.bar .ghost-fill{opacity:.5;height:100%;position:absolute;top:0}.bar.carbs .ghost-fill{background:gold}.bar.protein .ghost-fill{background:tomato}.bar.fats .ghost-fill{background:#00f}.bar.water .ghost-fill,.bar.land .ghost-fill{background:#ddd}.sweet-spot{background:#ffffff80;border-left:1px solid #000;border-right:1px solid #000;height:100%;position:absolute;top:0}.bar-caption{color:#666;text-transform:uppercase;text-align:left;margin-top:.25rem;font-size:.6rem}@keyframes pulse-red{0%{background-color:#f44336}50%{background-color:#eee}to{background-color:#f44336}}@keyframes pulse-carbs{0%{background-color:gold}50%{background-color:#eee}to{background-color:gold}}@keyframes pulse-protein{0%{background-color:tomato}50%{background-color:#eee}to{background-color:tomato}}@keyframes pulse-fats{0%{background-color:#00f}50%{background-color:#eee}to{background-color:#00f}}.card-deck{background-color:#fdfdfd;background-image:radial-gradient(at 0 0,#4eb1514d 0,#0000 50%),radial-gradient(at 100% 0,#ffd90026 0,#0000 50%),radial-gradient(at 100% 100%,#876c5e40 0,#0000 50%),radial-gradient(at 0 100%,#00bfff26 0,#0000 50%);background-size:200% 200%;flex:1;justify-content:center;align-items:center;animation:8s ease-in-out infinite alternate mesh-movement;display:flex;position:relative}.card-stack{width:80%;position:relative}.card{background:#fff;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:.5rem;transition:transform .3s,opacity .3s;display:flex;position:absolute;box-shadow:0 4px 8px #0000001a}.card.current-card{z-index:20;opacity:1;transform:translateY(0)scale(1)}.card.next-card{z-index:10;opacity:.8;transform:translateY(12px)scale(.95)}.tutorial-overlay{z-index:100;pointer-events:none;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:absolute;inset:0}.tutorial-arrow{opacity:.8;color:#000c;text-align:center;flex-direction:column;align-items:center;gap:.25rem;animation:1.8s ease-in-out infinite float;display:flex}.tutorial-arrow.left,.tutorial-arrow.right{align-items:center}.tutorial-arrow .arrow{font-size:2rem}.tutorial-arrow .caption{background:#ffffffe6;border-radius:999px;padding:.25rem .5rem;font-size:.9rem;box-shadow:0 1px 4px #00000026}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.screen-transition-overlay{opacity:0;pointer-events:none;z-index:9999;background-color:#fdfdfd;width:100vw;height:100vh;transition:opacity .4s ease-in-out;position:fixed;top:0;left:0}.card-info{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;width:100%;padding:0 1rem;display:flex}.name-serving-group{flex-direction:column;display:flex}.card .emoji{margin-bottom:0;font-size:4em}.card .name{margin-bottom:.25rem;font-size:1.5em;font-weight:700}.card .serving{color:#666;font-size:1.2em}.special-remark{text-align:center;color:#2e7d32;flex-basis:100%;width:100%;margin-top:.5rem;font-size:1.1em;font-weight:500}.special-remark.warning{color:#d32f2f}.radar-chart-container{justify-content:center;align-items:center;width:100%;height:60%;margin-bottom:.5rem;display:flex}.radar-chart{width:100%;height:100%}.bowl{--emoji-size:1.5rem;--grid-gap:.5rem;background:#fff;border-top:1px solid #ddd;min-height:9.5rem;max-height:9.5rem;padding:1rem;display:flex}.bowl-hint{color:#666;white-space:nowrap;opacity:.8;pointer-events:none;grid-column:span 2;align-items:center;margin-left:.25rem;font-size:.85rem;font-weight:500;animation:2.5s ease-in-out infinite gentle-pulse;display:flex}.bowl-hint.fade-out{animation:.6s ease-out forwards hint-fade-out}@keyframes gentle-pulse{0%,to{opacity:.5;transform:translate(0)}50%{opacity:1;transform:translate(4px)}}@keyframes hint-fade-out{0%{opacity:.8;transform:translate(0)}to{opacity:0;transform:translate(-10px)}}.ingredients{gap:var(--grid-gap);grid-template-columns:repeat(6,2.5rem);align-content:start;width:100%;display:grid}.ingredient{font-size:var(--emoji-size);background:#4caf5014;border-radius:.75rem;justify-content:center;align-items:center;width:2.2rem;height:2.2rem;transition:transform .2s,box-shadow .2s;display:inline-flex}.ingredient.dragging{z-index:1000;pointer-events:none;position:fixed;transform:scale(1.15);box-shadow:0 10px 20px #0003}.bowl-actions{flex-direction:column;height:100%;margin-left:.5rem;display:flex}.bowl button,.results-card #next-btn{color:#fff;cursor:pointer;text-align:center;background:#4caf50;border:none;border-radius:.5rem}.bowl button{flex-grow:1;justify-content:center;align-items:center;width:4rem;max-width:4rem;display:inline-flex}.bowl button.disabled,.bowl button:disabled{color:#666;cursor:not-allowed;background:#ccc}.results-card #next-btn{width:100%;margin-top:1rem;padding:1rem;font-size:1.2rem}.bowl-action-btn{color:#fff;cursor:pointer;border:none;flex:1;width:4rem;transition:background-color .2s,transform .2s}.bowl-action-btn.drop{background:#f44336;border-radius:.5rem .5rem 0 0}.bowl-action-btn.double{background:#9c27b0;border-radius:0 0 .5rem .5rem}.bowl-action-btn.double:disabled{background:#ccc}.bowl-action-btn.trash-hover{background:#d32f2f;transform:scale(1.04)}.bowl-action-btn.double.trash-hover{background:#7b1fa2;transform:scale(1.04)}.bowl-action-btn:disabled.trash-hover{cursor:not-allowed;background:#ccc;transform:none}@keyframes trash-pulse{0%,to{box-shadow:0 0 #f4433640}50%{box-shadow:0 0 0 8px #f4433600}}.shine{animation:1.5s ease-in-out infinite shine-animation}@keyframes shine-animation{0%,to{background-color:#fff}50%{background-color:#4caf50}}.results-screen{background-color:#fdfdfd;background-image:radial-gradient(at 0 0,#4eb1514d 0,#0000 50%),radial-gradient(at 100% 0,#ffd90026 0,#0000 50%),radial-gradient(at 100% 100%,#876c5e40 0,#0000 50%),radial-gradient(at 0 100%,#00bfff26 0,#0000 50%);background-size:200% 200%;flex-direction:column;flex:1;align-items:center;padding:1rem;animation:8s ease-in-out infinite alternate mesh-movement;display:flex}.results-card{background:#fff;border:1px solid #0000000a;border-radius:16px;flex-direction:column;align-items:center;width:100%;max-width:400px;max-height:90vh;padding:1.5rem;display:flex;overflow-y:auto;box-shadow:0 12px 32px #00000014,0 2px 8px #00000008}.stars{color:gold;margin-bottom:1rem;font-size:2rem}.stars-container{justify-content:center;gap:.5rem;margin-bottom:1rem;display:flex}.star-outline{color:#eee;font-size:2rem;position:relative}.star-fill{transition:transform .3s cubic-bezier(.18,.89,.32,1.28);position:absolute;top:0;left:0;transform:scale(0)}.star-fill.met{transform:scale(1)}.visual-plate-container{margin:1rem 0}.plate-svg{width:200px;height:200px}.plate-svg .data-circle{transition:stroke-dasharray 1s cubic-bezier(.25,1,.5,1)}.plate-svg .overflow-circle{transition:stroke-dasharray .5s ease-out}.reviewer-block{text-align:center;border-bottom:1px solid #eee;width:100%;margin-bottom:1rem;padding-bottom:1rem}.reviewer-avatar{margin-bottom:.5rem;font-size:3rem}.reviewer-name{font-size:1.2rem;font-weight:700}.reviewer-bio{color:#666;font-size:.9rem;font-style:italic}.speech-bubble{text-align:center;background:#f8f9fa;border:1px solid #eee;border-radius:.4em;margin-bottom:1rem;padding:1rem;font-style:italic;position:relative}.documentary-recommendation{text-align:center;background-color:#eee;border-radius:10px;margin:1rem 0;padding:1rem;box-shadow:0 2px 4px #0000001a}.documentary-recommendation h3{margin-bottom:.5rem}.documentary-recommendation a{color:inherit;text-decoration:none;display:block}.documentary-recommendation img{border-radius:5px;width:100%;height:auto}.stats{margin-bottom:1rem}.card{box-sizing:border-box;background:linear-gradient(135deg,#fff 0%,#f5f5f5 100%);border:6px solid #e0e0e0}.card.type-vegetables,.card.type-fruits,.card.type-fruits-vitamin-c,.card.type-fruits-antioxidant-rich{border-color:#d1eed3}.card.type-animal-based,.card.type-meat{border-color:#f4d1d1}.card.type-legumes{border-color:#ecddc1}
