/*! tailwindcss v4.1.12 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-duration:initial}}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.z-10{z-index:10}.z-50{z-index:50}.mx-auto{margin-inline:auto}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.w-full{width:100%}.flex-1{flex:1}.-skew-x-12{--tw-skew-x:skewX( -12deg );transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.overflow-hidden{overflow:hidden}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-transparent{--tw-gradient-from:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.text-center{text-align:center}.leading-none{--tw-leading:1;line-height:1}.opacity-10{opacity:.1}.opacity-30{opacity:.3}.opacity-100{opacity:1}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-300{--tw-duration:.3s;transition-duration:.3s}@media (hover:hover){.group-hover\:opacity-90:is(:where(.group):hover *){opacity:.9}}.focus\:border-transparent:focus{border-color:#0000}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}:root{color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;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}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-duration{syntax:"*";inherits:false}:root{--safe-area-inset-top: env(safe-area-inset-top, 0px);--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--safe-area-inset-left: env(safe-area-inset-left, 0px);--safe-area-inset-right: env(safe-area-inset-right, 0px);--tg-header-height: 0px;--tg-bottom-safe-area: 0px;--tg-viewport-height: 100vh}body.tg-webapp{--tg-header-height: 60px;--tg-bottom-safe-area: 44px}#root{--bg: #0a0e13;--bg-alt: rgba(255, 255, 255, .06);--card: rgba(255, 255, 255, .08);--card-border: rgba(255, 255, 255, .12);--accent: #10b981;--accent-grad: linear-gradient(135deg, #10b981 0%, #06d6a0 30%, #118ab2 70%, #073ac7 100%);--accent-secondary: linear-gradient(135deg, #f093fb 0%, #f5576c 50%, #4facfe 100%);--text: #f1f5f9;--text-dim: #94a3b8;--danger: #f87171;--warn: #fbbf24;--radius: 20px;--trans: .2s cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6);--glow-accent: 0 0 20px rgba(16, 185, 129, .3);--glow-secondary: 0 0 25px rgba(240, 147, 251, .4);width:100vw;height:100vh;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}html{background:linear-gradient(135deg,#0a0f1c,#151b2d,#1a1f35,#0f1419,#050a0f);background-attachment:fixed;min-height:100%;height:100%}body{background:transparent;min-height:100vh;height:100%;margin:0;padding:0;overflow-x:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;background:#ffffff0d;-webkit-backdrop-filter:blur(32px) saturate(200%);backdrop-filter:blur(32px) saturate(200%);border:1px solid rgba(255,255,255,.1);padding:1.2rem 1.5rem;border-radius:24px;box-shadow:0 16px 32px #0000004d,0 8px 16px #0003,inset 0 1px #ffffff1a;margin-bottom:2rem;position:sticky;top:0;z-index:40;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.topbar:hover{box-shadow:0 20px 40px #0006,0 12px 24px #10b98133,inset 0 1px #ffffff26;border-color:#10b9814d}.topbar .logo{font-weight:800;letter-spacing:.5px;cursor:pointer;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:1.3rem;text-shadow:0 0 30px rgba(16,185,129,.5);position:relative}.topbar .logo:after{content:"";position:absolute;inset:0;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;filter:blur(8px);z-index:-1;opacity:.6}.topbar nav{display:flex;gap:.8rem}.topbar nav a{position:relative;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:.55rem .85rem;border-radius:12px;color:var(--text-dim);text-decoration:none;transition:background var(--trans),color var(--trans)}.topbar nav a.active,.topbar nav a:hover{background:#ffffff14;color:var(--text)}.topbar .actions{display:flex;align-items:center;gap:.55rem}.status-chip{font-size:.6rem;padding:.35rem .55rem .4rem;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:10px;letter-spacing:.6px;text-transform:uppercase;color:var(--text-dim)}.meal-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem;max-height:340px;overflow:auto;scrollbar-width:thin}.meal-item{position:relative;padding:1rem 1.2rem;border:1px solid rgba(255,255,255,.12);background:#ffffff14;border-radius:18px;display:flex;flex-direction:column;gap:.5rem;transition:all var(--trans);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden}.meal-item:before{content:"";position:absolute;inset:0;background:var(--accent-secondary);opacity:0;transition:opacity var(--trans);z-index:-1}.meal-item:hover{border-color:#10b98166;background:#ffffff1f;box-shadow:var(--shadow-md),var(--glow-accent);transform:translateY(-2px)}.meal-item:hover:before{opacity:.1}.mi-head{display:flex;justify-content:space-between;font-size:.85rem}.mi-cal{font-weight:600;color:#fbbf24}.mi-macros{font-size:.65rem;letter-spacing:.5px;text-transform:uppercase;color:#94a3b8;display:flex;gap:.6rem}.mi-actions{display:flex;gap:.4rem}.btn.small{padding:.45rem .7rem;font-size:.7rem}.btn.xsmall{padding:.35rem .55rem;font-size:.65rem}.meal-item .btn.xsmall{box-shadow:none;background:#ffffff14;color:var(--text)}.meal-item .btn.xsmall:hover{background:#ffffff26}.meal-list .empty{text-align:center;padding:.9rem .4rem;font-size:.7rem;color:#64748b;background:#ffffff0a;border:1px dashed rgba(255,255,255,.12);border-radius:14px}.spark-wrap{padding:.4rem .2rem .8rem}.history-list{display:flex;flex-direction:column;gap:.4rem;max-height:340px;overflow:auto;scrollbar-width:thin}.history-row{display:grid;grid-template-columns:1fr auto auto;gap:.6rem;align-items:center;font-size:.7rem;background:#ffffff0d;padding:.5rem .7rem;border-radius:10px}.history-row span:nth-child(2){font-weight:600}.history-row .good{color:#34d399}.history-row .bad{color:#ef4444}.history-meta{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.4rem}.history-meta .filters{display:flex;gap:.4rem;flex-wrap:wrap}.history-meta .filters .btn.xsmall{background:#ffffff14;box-shadow:none}.history-meta .filters .btn.xsmall.active{background:var(--accent-grad);color:#0f1115}.history-meta .stats{display:flex;gap:1.1rem;font-size:.65rem;letter-spacing:.5px;text-transform:uppercase;color:#94a3b8}.history-meta .stats strong{font-size:.8rem;margin-left:.25rem}.sparkline{width:100%;height:40px;overflow:visible}.skeleton{position:relative;overflow:hidden;background:#ffffff14;border-radius:10px}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#fff0,#ffffff2e,#fff0);transform:translate(-100%);animation:shimmer 1.3s infinite}@keyframes shimmer{to{transform:translate(100%)}}.sk-line{height:14px}.sk-ring{width:130px;height:130px;border-radius:50%}.profile-block{display:flex;flex-direction:column;gap:.5rem;font-size:.8rem}.edit-form{margin-top:.6rem}.ef-grid{display:grid;gap:.7rem .8rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.ef-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.6rem;text-transform:uppercase;letter-spacing:.5px;color:#8da3b7;font-weight:600}.ef-grid input,.ef-grid select{background:#ffffff12;border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:.5rem .6rem;font-size:.72rem;color:var(--text);font-family:inherit;outline:none}.ef-grid input:focus,.ef-grid select:focus{border-color:#2dd4bf}.ef-actions{margin-top:1rem;display:flex;gap:.6rem;justify-content:flex-end}.row-btns{display:flex;gap:.6rem}.toasts{position:fixed;bottom:18px;right:18px;display:flex;flex-direction:column;gap:.6rem;z-index:100}.toast{padding:.65rem .9rem .7rem;background:#1e293be6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:14px;font-size:.7rem;letter-spacing:.5px;font-weight:500;box-shadow:0 4px 18px -6px #0009;animation:fadeIn .4s ease}.toast.success{border-color:#047857;background:#065f46e6;color:#d1fae5}.toast.error{border-color:#b91c1c;background:#7f1d1deb;color:#fee2e2}.toast.info{border-color:#1e3a8a;background:#1e40afe6;color:#dbeafe}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.light .topbar{background:#ffffffbf;border:1px solid rgba(0,0,0,.08)}.light .meal-item{background:#0000000a;border-color:#00000014}.light .meal-item:hover{background:#00000012}.light .status-chip{background:#0000000f;border-color:#00000014;color:#475569}.light .history-row{background:#0000000d}.light .meal-list .empty{background:#00000008;border-color:#0000001a}.app{display:flex;flex-direction:column;gap:2.5rem;min-height:calc(var(--tg-viewport-height, 100vh));padding-top:calc(var(--safe-area-inset-top, 0px) + var(--tg-header-height, 0px));padding-bottom:calc(var(--safe-area-inset-bottom, 0px) + var(--tg-bottom-safe-area, 0px));padding-left:var(--safe-area-inset-left, 0px);padding-right:var(--safe-area-inset-right, 0px);box-sizing:border-box}.hero{text-align:left;position:relative}.hero .logo-icon{font-size:3.2rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}.hero h1{margin:.2rem 0 .4rem;font-size:3.4rem;letter-spacing:.5px;background:var(--accent-grad);background-clip:text;-webkit-background-clip:text;color:transparent}.hero .tagline{margin:0;font-size:1.2rem;color:var(--text-dim)}.grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.card{position:relative;border-radius:28px;padding:2rem 1.8rem 2.2rem;background:#ffffff0f;-webkit-backdrop-filter:blur(32px) saturate(200%);backdrop-filter:blur(32px) saturate(200%);border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 40px #0006,0 8px 16px #0003,inset 0 1px #ffffff14,0 0 0 1px #ffffff0a;transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden}.card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#10b98105,#3b82f605,#9333ea05);opacity:0;transition:opacity .4s cubic-bezier(.4,0,.2,1);border-radius:28px}.card:hover{transform:translateY(-6px) scale(1.02);border-color:#10b98166;box-shadow:var(--shadow-xl),var(--glow-accent),inset 0 1px #fff3}.card:hover:before{opacity:.08}.card h2{margin:0 0 1.5rem;font-size:1.4rem;font-weight:800;letter-spacing:-.01em;background:linear-gradient(135deg,#10b981,#06d6a0,#118ab2 50%,#6366f1);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;position:relative;z-index:1}.status-line{display:flex;align-items:center;gap:.6rem;margin:.55rem 0;font-size:.95rem}.status-line .label{color:var(--text-dim);width:95px;text-align:right;font-variant:all-small-caps;letter-spacing:.5px}.status-line .value{font-weight:500}.btn{border:0;background:linear-gradient(135deg,#10b981,#06d6a0,#118ab2);color:#fff;font-weight:700;padding:.9rem 1.6rem;border-radius:20px;cursor:pointer;font-size:.95rem;display:inline-flex;align-items:center;gap:.6rem;box-shadow:0 8px 16px #10b98140,0 4px 8px #0003,inset 0 1px #ffffff26;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.3) 0%,transparent 50%);opacity:0;transition:opacity var(--trans)}.btn:hover:before{opacity:1}.btn:hover:not(:disabled){box-shadow:var(--shadow-lg),var(--glow-accent),0 0 30px #10b98166;transform:translateY(-3px) scale(1.02)}.btn:disabled{opacity:.55;cursor:default;filter:grayscale(.4)}.chip{padding:.2rem .65rem .28rem;border-radius:10px;font-size:.75rem;letter-spacing:.5px;font-weight:600;text-transform:uppercase;background:#374151;color:#d1d5db}.chip-ok{background:#065f46;color:#a7f3d0}.chip-warn{background:#92400e;color:#fcd34d}.chip-bad{background:#7f1d1d;color:#fecaca}.features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.85rem}.features li{display:flex;align-items:center;gap:.6rem;font-size:.95rem;background:linear-gradient(90deg,#ffffff0d,#fff0);padding:.65rem .85rem;border-radius:12px;position:relative;overflow:hidden}.features li.ready{border-left:3px solid #2dd4bf}.features li:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;background:linear-gradient(120deg,#ffffff26,#fff0);transition:opacity var(--trans)}.features li:hover:after{opacity:1}.badge{font-size:.6rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;background:#1e293b;padding:.25rem .5rem .3rem;border-radius:7px;margin-left:auto;color:#94a3b8;border:1px solid #334155}.badge.soon{background:#172554;color:#60a5fa;border-color:#1e3a8a}.badge.lock{background:#3f1f4b;color:#f0abfc;border-color:#6d28d9}.roadmap{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.55rem;counter-reset:step}.roadmap li{position:relative;padding:.45rem .65rem .55rem .9rem;background:linear-gradient(90deg,#ffffff0d,#fff0);border-radius:12px;font-size:.9rem;line-height:1.25rem}.roadmap li::marker{color:#3b82f6;font-weight:600}.users-list{margin-top:1.2rem;background:#04785726;border:1px solid rgba(16,185,129,.35);border-radius:14px;padding:1rem .9rem 1.1rem}.users-list h3{margin:.1rem 0 .8rem;font-size:.95rem;letter-spacing:.5px;text-transform:uppercase;color:#34d399}.users-list ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem;max-height:220px;overflow-y:auto;scrollbar-width:thin}.users-list li{display:flex;justify-content:space-between;font-size:.82rem;background:#ffffff0d;padding:.45rem .6rem;border-radius:8px}.mono{font-family:JetBrains Mono,IBM Plex Mono,monospace;opacity:.6}footer{text-align:center;margin-top:1rem;font-size:.7rem;letter-spacing:.6px;text-transform:uppercase;color:#64748b}.hint{background:#ffffff0d;padding:.4rem .7rem .45rem;border-radius:10px;border:1px solid rgba(255,255,255,.08)}.fade-in{animation:fade .6s ease}@keyframes fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.progress-ring{filter:drop-shadow(0 4px 10px rgba(0,0,0,.5))}.progress-ring .track{fill:none;stroke:#ffffff14;stroke-width:10}.progress-ring .progress{fill:none;stroke:url(#grad) var(--accent, #4ade80);stroke:linear-gradient(90deg,#4ade80,#2dd4bf);stroke-width:10;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;transition:stroke-dashoffset .6s ease}.progress-text{font-size:.95rem;font-weight:600;fill:#e2e8f0}.daily-grid{display:flex;gap:1.2rem;align-items:center}.ring-wrap{position:relative}.kpi{flex:1;display:flex;flex-direction:column;gap:.35rem}.k-row{display:flex;justify-content:space-between;font-size:.85rem;background:#ffffff14;padding:.6rem .8rem;border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all var(--trans);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden}.k-row:before{content:"";position:absolute;inset:0;background:var(--accent-secondary);opacity:0;transition:opacity var(--trans)}.k-row:hover{background:#ffffff1f;border-color:#10b9814d;box-shadow:var(--shadow-sm),var(--glow-accent);transform:translate(4px)}.k-row:hover:before{opacity:.05}.macro-bar{display:flex;height:10px;border-radius:6px;overflow:hidden;margin:.4rem .1rem .2rem;background:#ffffff14}.macro{height:100%;transition:width .6s cubic-bezier(.4,.4,.2,1)}.macro.p{background:#34d399}.macro.c{background:#60a5fa}.macro.f{background:#fbbf24}.mini-msg{font-size:.7rem;letter-spacing:.5px;text-transform:uppercase;color:#94a3b8;margin-top:.2rem}.macro-goals,.forecast-block{display:flex;flex-direction:column;gap:.4rem;font-size:.75rem}.macro-goals .mg-row,.forecast-block .mg-row{display:flex;justify-content:space-between;background:#ffffff0d;padding:.4rem .6rem;border-radius:8px}.macro-goals .mg-row span,.forecast-block .mg-row span{color:#94a3b8;letter-spacing:.5px;text-transform:uppercase;font-size:.6rem}.macro-goals strong,.forecast-block strong{font-weight:600}.placeholder{font-size:.8rem;color:#64748b;padding:.6rem .4rem}.controls-row{display:flex;gap:.5rem;margin:.9rem 0 1rem}.select{flex:1;background:#ffffff12;border:1px solid rgba(255,255,255,.15);color:var(--text);padding:.55rem .7rem;border-radius:12px;font-size:.8rem;font-family:inherit;outline:none;transition:border-color var(--trans),background var(--trans)}.select:focus{border-color:#2dd4bf;background:#ffffff1a}.btn.ghost{background:#ffffff14;color:var(--text);box-shadow:none}.btn.ghost:hover{background:#ffffff26;box-shadow:0 4px 12px -4px #0006}.users-list.compact ul{max-height:150px}.users-list.compact li.sel{outline:2px solid #2dd4bf}.more{margin-top:.4rem;font-size:.65rem;text-align:center;opacity:.6}.summary-card{min-height:260px}.modal-backdrop{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:flex-start;padding:max(5vh,calc(var(--safe-area-inset-top, 0px) + var(--tg-header-height, 60px) + 40px)) 1rem max(5vh,calc(var(--safe-area-inset-bottom, 0px) + var(--tg-bottom-safe-area, 44px) + 40px));z-index:50;box-sizing:border-box}.modal{background:#141820e6;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:1.8rem 1.6rem 2.1rem;width:min(880px,calc(100% - 2rem));max-height:calc(var(--tg-viewport-height, 100vh) - max(10vh,calc(var(--safe-area-inset-top, 0px) + var(--tg-header-height, 60px) + var(--safe-area-inset-bottom, 0px) + var(--tg-bottom-safe-area, 44px) + 80px)));overflow-y:auto;box-shadow:0 10px 40px -10px #0009;box-sizing:border-box}.modal h2{margin:0 0 .6rem;font-size:1.4rem;background:var(--accent-grad);background-clip:text;-webkit-background-clip:text;color:transparent}.onboarding-subtitle{margin:0 0 1.8rem;font-size:1rem;color:var(--text-dim);line-height:1.5;text-align:center}.form-grid{display:grid;gap:.9rem .9rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.form-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.7rem;letter-spacing:.5px;text-transform:uppercase;color:#97a6b5;font-weight:600}.form-grid input,.form-grid select{background:#ffffff0d;border:1px solid rgba(255,255,255,.12);color:var(--text);padding:.55rem .7rem;border-radius:12px;font-size:.8rem;font-family:inherit;outline:none;transition:border-color var(--trans),background var(--trans)}.form-grid input:focus,.form-grid select:focus{border-color:#2dd4bf;background:#ffffff17}.modal-actions{margin-top:1.4rem;display:flex;justify-content:flex-end;gap:.7rem}.theme-toggle{position:fixed;top:12px;right:14px;z-index:60}.light body{background:#f5f7fa}.light #root{color:#1e293b}.light .card{background:#ffffffa6;border:1px solid rgba(0,0,0,.08)}.light .modal{background:#ffffffea}.light .btn.ghost{background:#0000000f}.light .select{background:#0000000a;color:#1e293b}@media (max-width: 640px){#root{padding:1.3rem 1rem 2.5rem;max-width:100%}.hero h1{font-size:2.1rem}.hero .logo-icon{font-size:2.6rem}.grid{display:flex;flex-direction:column;gap:1rem}.card{padding:1.05rem .95rem 1.25rem;border-radius:20px}.status-line{font-size:.78rem}.controls-row{flex-wrap:wrap}.select{min-width:140px;flex:1 1 140px}.btn{flex:1 1 auto;justify-content:center}.daily-grid{flex-direction:column;align-items:stretch}.ring-wrap{display:flex;justify-content:center}.kpi{gap:.25rem}.k-row{font-size:.72rem;padding:.35rem .55rem}.features li{font-size:.78rem}.roadmap li{font-size:.72rem}.modal{padding:1.3rem 1.1rem 1.6rem;border-radius:20px}.form-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.65rem}.form-grid input,.form-grid select{padding:.45rem .55rem;font-size:.72rem}.modal-actions{flex-direction:column-reverse}.modal-actions .btn,.modal-actions .btn.ghost{width:100%}.users-list ul{max-height:120px}.progress-ring{width:110px;height:110px}.progress-text{font-size:.8rem}}@media (max-width: 380px){.hero h1{font-size:1.8rem}.controls-row{gap:.4rem}.btn{padding:.55rem .6rem;font-size:.7rem}.select{font-size:.7rem}}@media (max-height: 520px) and (orientation: landscape){#root{padding:.8rem .9rem 1.2rem}.hero{display:flex;align-items:center;gap:.9rem}.hero .tagline{font-size:.85rem}.grid{gap:.6rem}.card{padding:.75rem .8rem 1rem}.modal{max-height:90vh;overflow:auto}}.modern-welcome{background:radial-gradient(circle at 20% 20%,rgba(16,185,129,.15) 0%,transparent 60%),radial-gradient(circle at 80% 80%,rgba(59,130,246,.15) 0%,transparent 60%),radial-gradient(circle at 40% 60%,rgba(147,51,234,.1) 0%,transparent 70%),transparent;position:fixed;top:0;left:0;width:100vw;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:2rem;box-sizing:border-box}.modern-title{background:linear-gradient(135deg,#10b981,#06d6a0 15%,#38bdf8,#3b82f6,#6366f1 75%,#8b5cf6 90%,#a855f7);background-size:400% 400%;-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 8px 16px rgba(16,185,129,.3)) drop-shadow(0 4px 8px rgba(59,130,246,.2));text-shadow:none}.modern-features-card{position:relative;-webkit-backdrop-filter:blur(40px) saturate(200%);backdrop-filter:blur(40px) saturate(200%);background:linear-gradient(135deg,#ffffff1f,#ffffff0f,#ffffff14);border:1px solid rgba(255,255,255,.2);border-radius:32px;box-shadow:0 32px 64px #0006,0 16px 32px #0000004d,inset 0 1px #ffffff26,inset 0 -1px #ffffff0d,0 0 0 1px #ffffff0d;overflow:hidden}.modern-features-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#10b9810d,#3b82f60d,#9333ea0d);border-radius:32px}.feature-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem;border-radius:20px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;text-align:center}.feature-item:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff14,#ffffff05);border-radius:20px;opacity:0;transition:opacity .4s ease}.feature-item:hover:before{opacity:1}.feature-icon{flex-shrink:0;margin-bottom:0}.feature-content{flex:1;text-align:center}.feature-title{background:linear-gradient(135deg,#fff,#e2e8f0);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700;margin-bottom:.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.feature-desc{color:#cbd5e1e6;line-height:1.6;font-weight:400;letter-spacing:.01em}.modern-cta-button{position:relative;display:inline-block;background:linear-gradient(135deg,#10b981,#06d6a0,#3b82f6);border:none;border-radius:28px;padding:1.5rem 4rem;font-size:1.1rem;font-weight:700;color:#fff;cursor:pointer;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 16px 32px #10b9814d,0 8px 16px #0003,inset 0 1px #fff3,0 0 0 1px #ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-shadow:0 2px 4px rgba(0,0,0,.2);margin:2rem auto;min-width:300px}.modern-cta-button:hover{box-shadow:0 24px 48px #10b98166,0 12px 24px #3b82f64d,0 8px 16px #0003,inset 0 1px #ffffff4d,0 0 0 1px #ffffff26;transform:translateY(-2px)}.modern-cta-button:active{transform:translateY(0) scale(.98)}.emoji-large{font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji","Android Emoji",EmojiSymbols,EmojiOne Color,Twemoji Mozilla,sans-serif!important;font-style:normal!important;font-variant:normal!important;text-rendering:auto!important;color:initial!important;background:none!important;-webkit-background-clip:initial!important;background-clip:initial!important;-webkit-text-fill-color:initial!important}.emoji-medium{font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji","Android Emoji",EmojiSymbols,EmojiOne Color,Twemoji Mozilla,sans-serif!important;font-style:normal!important;font-variant:normal!important;text-rendering:auto!important;color:initial!important}.welcome-button-container{margin-top:4rem!important}.welcome-button{background:linear-gradient(135deg,#10b981,#06d6a0,#3b82f6)}@media (min-width: 1024px){.modern-features-card{max-width:800px;margin:0 auto}}@media (min-width: 1280px){.modern-features-card{max-width:900px}}@media (min-width: 1536px){.modern-features-card{max-width:1000px}}@media (max-width: 768px){.modern-features-card{margin:0 1rem;padding:1.5rem}.feature-item{padding:.75rem;gap:.5rem}.modern-welcome{padding:1rem}.modern-cta-button{min-width:250px;margin:1rem auto}}@media (max-width: 480px){.modern-features-card{margin:0 .5rem;padding:1rem}.feature-item{padding:.5rem;gap:.5rem}.modern-welcome{padding:.5rem}.modern-cta-button{min-width:200px;margin:.5rem auto}}@media (max-height: 700px){.modern-welcome{overflow-y:auto}.feature-item{padding:.5rem}.modern-features-card{padding:1rem}}body.tg-webapp{overflow-x:hidden;--tg-header-height: 60px;--tg-bottom-safe-area: 44px}body.tg-webapp .app{padding-top:calc(var(--safe-area-inset-top, 0px) + var(--tg-header-height, 60px) + 20px);padding-bottom:calc(var(--safe-area-inset-bottom, 0px) + var(--tg-bottom-safe-area, 44px) + 20px)}body.tg-webapp .modal-backdrop{padding-top:calc(var(--safe-area-inset-top, 0px) + var(--tg-header-height, 60px) + 30px);padding-bottom:calc(var(--safe-area-inset-bottom, 0px) + var(--tg-bottom-safe-area, 44px) + 30px)}body.tg-webapp .modal{max-height:calc(var(--tg-viewport-height, 100vh) - var(--safe-area-inset-top, 0px) - var(--tg-header-height, 60px) - var(--safe-area-inset-bottom, 0px) - var(--tg-bottom-safe-area, 44px) - 60px)}@media (max-width: 768px){body.tg-webapp .app{gap:1.5rem;padding-left:max(var(--safe-area-inset-left, 0px),1rem);padding-right:max(var(--safe-area-inset-right, 0px),1rem);padding-top:calc(var(--safe-area-inset-top, 0px) + var(--tg-header-height, 60px) + 30px);padding-bottom:calc(var(--safe-area-inset-bottom, 0px) + var(--tg-bottom-safe-area, 44px) + 30px)}body.tg-webapp .modal-backdrop{padding-top:calc(var(--safe-area-inset-top, 0px) + var(--tg-header-height, 60px) + 50px);padding-bottom:calc(var(--safe-area-inset-bottom, 0px) + var(--tg-bottom-safe-area, 44px) + 50px)}body.tg-webapp .modal{width:calc(100% - 2rem);margin:0 1rem;border-radius:16px;max-height:calc(var(--tg-viewport-height, 100vh) - var(--safe-area-inset-top, 0px) - var(--tg-header-height, 60px) - var(--safe-area-inset-bottom, 0px) - var(--tg-bottom-safe-area, 44px) - 100px)}body.tg-webapp .form-grid{grid-template-columns:1fr;gap:1rem}}.onboarding-intro-modal{max-width:480px;text-align:center}.intro-header{margin-bottom:.7rem}.intro-emoji{font-size:2.8rem;margin-bottom:.3rem;display:inline-block}.intro-header h2{font-size:1.8rem;margin:0 0 .8rem;background:var(--accent-grad);background-clip:text;-webkit-background-clip:text;color:transparent}.intro-subtitle{font-size:1.1rem;color:var(--text-dim);line-height:1.5;margin:0}.intro-benefits{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:1rem;text-align:left}.benefit-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--card);border:1px solid var(--card-border);border-radius:16px;transition:var(--trans)}.benefit-item:hover{background:var(--bg-alt);transform:translateY(-2px)}.benefit-icon{font-size:1.8rem;flex-shrink:0;margin-top:.2rem}.benefit-item h4{margin:0 0 .4rem;font-size:1rem;font-weight:600;color:var(--text)}.benefit-item p{margin:0;font-size:.9rem;color:var(--text-dim);line-height:1.4}.intro-actions{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.5rem}.primary-btn{background:var(--accent-grad);color:#fff;border:none;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.primary-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.ghost-btn{background:transparent;color:var(--text-dim);border:1px solid var(--card-border)}.ghost-btn:hover{color:var(--text);border-color:var(--accent)}.btn-emoji{font-size:1.1rem}.intro-footer{text-align:center}.intro-footer p{margin:0;font-size:.85rem;color:var(--text-dim);opacity:.8}@media (max-width: 480px){.onboarding-intro-modal{margin:1rem}.intro-actions{gap:.6rem}.benefit-item{padding:.8rem}}
