@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-border-style:solid;--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}}}@layer theme{:root,:host{--font-sans:"DM Sans", sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-xl:.75rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary-50:#022c22;--color-primary-100:#064e3b;--color-primary-200:#065f46;--color-primary-300:#047857;--color-primary-400:#059669;--color-primary-500:#10b981;--color-primary-600:#34d399;--color-primary-700:#6ee7b7;--color-surface-50:#09090b;--color-surface-100:#111114;--color-surface-200:#1a1a1f;--color-surface-300:#27272a;--color-surface-400:#3f3f46;--color-surface-500:#52525b;--color-surface-600:#71717a;--color-surface-700:#a1a1aa;--color-surface-800:#d4d4d8;--color-surface-900:#fafafa;--color-warning:#f59e0b;--color-danger:#ef4444;--color-card:#111114;--color-card-hover:#16161a;--font-display:"Outfit", sans-serif;--font-body:"DM Sans", sans-serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.start{inset-inline-start:var(--spacing)}.block{display:block}.grid{display:grid}.inline{display:inline}.table{display:table}.border{border-style:var(--tw-border-style);border-width:1px}.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)}}html{font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--color-surface-50);color:var(--color-surface-700);min-height:100vh}.font-display{font-family:var(--font-display)}.slide-left-enter-active,.slide-left-leave-active,.slide-right-enter-active,.slide-right-leave-active{transition:all .3s cubic-bezier(.4,0,.2,1)}.slide-left-enter-from{opacity:0;transform:translate(40px)}.slide-left-leave-to,.slide-right-enter-from{opacity:0;transform:translate(-40px)}.slide-right-leave-to{opacity:0;transform:translate(40px)}.fade-enter-active,.fade-leave-active{transition:opacity .2s}.fade-enter-from,.fade-leave-to{opacity:0}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background-color:var(--color-surface-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background-color:var(--color-surface-400)}.grain:after{content:"";pointer-events:none;opacity:.03;z-index:9999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-main{flex:1}.app-container{padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 8);max-width:72rem;margin-inline:auto}@media(min-width:640px){.app-container{padding-inline:calc(var(--spacing) * 6)}}@media(min-width:1024px){.app-container{padding-inline:calc(var(--spacing) * 8)}}.app-header{top:calc(var(--spacing) * 0);z-index:40;border-bottom:1px solid var(--color-surface-300);-webkit-backdrop-filter:blur(16px);background-color:#09090bcc;position:sticky}.header-inner{padding-inline:calc(var(--spacing) * 4);max-width:72rem;margin-inline:auto}@media(min-width:640px){.header-inner{padding-inline:calc(var(--spacing) * 6)}}@media(min-width:1024px){.header-inner{padding-inline:calc(var(--spacing) * 8)}}.header-content{justify-content:space-between;align-items:center;height:4rem;display:flex}.logo-link{cursor:pointer;align-items:center;gap:.625rem;text-decoration:none;display:flex}.logo-icon-wrap{border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-300));justify-content:center;align-items:center;width:2.25rem;height:2.25rem;transition:box-shadow .2s;display:flex;box-shadow:0 0 12px #10b98133}.logo-link:hover .logo-icon-wrap{box-shadow:0 0 20px #10b98159}.logo-icon{color:#fff}.logo-text{font-family:var(--font-display);letter-spacing:-.025em;color:var(--color-surface-800);font-size:1.125rem;font-weight:600}.logo-accent{color:var(--color-primary-600)}.stage-nav{align-items:center;gap:.5rem;display:flex}@media(min-width:640px){.stage-nav{gap:.75rem}}.stage-connector{background-color:var(--color-surface-300);border-radius:3.40282e38px;width:1.5rem;height:2px;transition:background-color .3s}@media(min-width:640px){.stage-connector{width:2.5rem}}.stage-connector.is-reached{background-color:var(--color-primary-500)}.stage-btn{cursor:default;background:0 0;border:none;align-items:center;gap:.5rem;padding:0;display:flex}.stage-btn.is-clickable{cursor:pointer}.stage-circle{background-color:var(--color-surface-200);width:2rem;height:2rem;color:var(--color-surface-500);border-radius:3.40282e38px;justify-content:center;align-items:center;font-size:.875rem;font-weight:600;transition:all .3s;display:flex;position:relative}.stage-circle.is-completed{background-color:var(--color-primary-500);color:#fff;box-shadow:0 0 10px #10b98133}.stage-circle.is-active{background-color:var(--color-primary-50);color:var(--color-primary-600);outline:2px solid var(--color-primary-500);outline-offset:2px}.stage-btn.is-clickable:hover .stage-circle{transform:scale(1.05);box-shadow:0 0 16px #10b9814d}.stage-label{color:var(--color-surface-500);font-size:.875rem;font-weight:500;transition:color .3s;display:none}@media(min-width:640px){.stage-label{display:block}}.stage-label.is-active{color:var(--color-primary-600)}.stage-label.is-completed{color:var(--color-primary-500)}.stage-btn.is-clickable:hover .stage-label{color:var(--color-primary-600)}.view-stack{flex-direction:column;gap:1.5rem;display:flex}.view-title{font-family:var(--font-display);letter-spacing:-.025em;color:var(--color-surface-800);font-size:1.5rem;font-weight:600}.view-subtitle{color:var(--color-surface-600);margin-top:.25rem;font-size:.875rem}.page-heading-row{align-items:center;gap:.75rem;display:flex}.back-btn{border:1px solid var(--color-surface-300);width:2.25rem;height:2.25rem;color:var(--color-surface-600);cursor:pointer;background:0 0;border-radius:.5rem;justify-content:center;align-items:center;transition:all .15s;display:flex}.back-btn:hover{color:var(--color-surface-800);border-color:var(--color-surface-400);background-color:var(--color-surface-200)}.file-info-bar{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:.75rem;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.file-info-bar.is-valid{border-color:var(--color-primary-200)}.file-info-bar.is-invalid{border-color:#f59e0b40}.file-info-left{align-items:center;gap:.75rem;min-width:0;display:flex}.file-icon-wrap{border-radius:.5rem;flex-shrink:0;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;display:flex}.file-icon-wrap.is-valid{background-color:var(--color-primary-50)}.file-icon-wrap.is-invalid{background-color:#f59e0b1a}.file-icon.is-valid{color:var(--color-primary-600)}.file-icon.is-invalid{color:#fbbf24}.file-info-details{min-width:0}.file-name{color:var(--color-surface-800);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:500;overflow:hidden}.file-status-valid{color:var(--color-primary-600);font-size:.75rem}.file-status-warning{color:#fbbf24;font-size:.75rem}.file-status-error{color:var(--color-danger);font-size:.75rem}.replace-btn{color:var(--color-surface-600);border:1px solid var(--color-surface-300);cursor:pointer;background:0 0;border-radius:.5rem;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;transition:all .15s;display:flex}.replace-btn:hover{color:var(--color-surface-800);border-color:var(--color-surface-400);background-color:var(--color-surface-200)}.drop-zone{cursor:pointer;border:2px dashed var(--color-surface-300);background-color:var(--color-card);border-radius:1rem;transition:all .3s;position:relative}.drop-zone:hover{border-color:var(--color-primary-400);background-color:var(--color-card-hover)}.drop-zone.is-dragging{border-color:var(--color-primary-500);background-color:#10b9810d;transform:scale(1.005);box-shadow:0 0 30px #10b98114}.drop-zone-content{flex-direction:column;justify-content:center;align-items:center;padding:4rem 1.5rem;display:flex}.drop-zone-icon-wrap{background-color:var(--color-surface-200);border-radius:1rem;justify-content:center;align-items:center;width:4rem;height:4rem;margin-bottom:1.25rem;transition:all .3s;display:flex}.drop-zone:hover .drop-zone-icon-wrap{background-color:var(--color-primary-50)}.drop-zone-icon-wrap.is-dragging{background-color:var(--color-primary-100);transform:scale(1.1)}.drop-zone-icon{color:var(--color-surface-500);transition:color .3s}.drop-zone:hover .drop-zone-icon{color:var(--color-primary-500)}.drop-zone-icon.is-dragging{color:var(--color-primary-600)}.drop-zone-title{color:var(--color-surface-800);margin-bottom:.25rem;font-size:1rem;font-weight:500}.drop-zone-hint{color:var(--color-surface-500);margin-bottom:1.25rem;font-size:.875rem}.drop-zone-browse{color:var(--color-primary-600);font-weight:500}.download-sample-btn{color:var(--color-surface-600);border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);border-radius:.5rem;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.download-sample-btn:hover{color:var(--color-primary-600);border-color:var(--color-primary-200)}.file-input-hidden{display:none}.error-alert{background-color:#ef44440f;border:1px solid #ef444433;border-radius:.75rem;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;display:flex}.error-alert-icon{color:var(--color-danger);flex-shrink:0;margin-top:.125rem}.error-alert-title{color:#fca5a5;font-size:.875rem;font-weight:500}.error-alert-message{color:#f87171;margin-top:.125rem;font-size:.875rem}.validation-panel{background-color:#f59e0b0a;border:1px solid #f59e0b33;border-radius:.75rem;overflow:hidden}.validation-header{border-bottom:1px solid #f59e0b1f;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.validation-header-icon{color:#fbbf24}.validation-header-text{color:#fbbf24;font-size:.875rem;font-weight:500}.validation-list{margin:0;padding:0;list-style:none}.validation-item{border-bottom:1px solid #f59e0b0f;align-items:flex-start;gap:.75rem;padding:.625rem 1rem;display:flex}.validation-item:last-child{border-bottom:none}.validation-badge{color:#fbbf24;background-color:#f59e0b26;border-radius:.375rem;flex-shrink:0;align-items:center;margin-top:.125rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:500;display:inline-flex}.validation-message{color:#fcd34d;font-size:.875rem}.preview-card{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:1rem;overflow:hidden}.preview-header{border-bottom:1px solid var(--color-surface-200);background-color:var(--color-surface-100);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.preview-header-left{align-items:center;gap:.625rem;display:flex}.preview-header-icon{color:var(--color-primary-600)}.preview-header-title{font-family:var(--font-display);color:var(--color-surface-800);font-size:1rem;font-weight:600}.preview-valid-badge{color:var(--color-primary-600);align-items:center;gap:.375rem;font-size:.75rem;display:flex}.preview-valid-text{font-weight:500}.preview-table-wrap{overflow-x:auto}.preview-table{border-collapse:collapse;width:100%;font-size:.875rem}.preview-thead-row{text-align:left;border-bottom:1px solid var(--color-surface-200)}.preview-th{color:var(--color-surface-600);text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1.25rem;font-size:.75rem;font-weight:600}.preview-th-right{color:var(--color-surface-600);text-transform:uppercase;letter-spacing:.05em;text-align:right;padding:.75rem 1.25rem;font-size:.75rem;font-weight:600}.preview-tbody tr{border-bottom:1px solid var(--color-surface-200);transition:background-color .15s}.preview-tbody tr:last-child{border-bottom:none}.preview-tbody tr:hover{background-color:var(--color-surface-200)}.preview-row-error{background-color:#f59e0b0a}.preview-row-error:hover{background-color:#f59e0b14}.preview-row-meal-error{background-color:#f59e0b05}.preview-cell{padding:.75rem 1.25rem}.preview-cell-top{vertical-align:top;padding:.75rem 1.25rem}.meal-name-wrap{align-items:center;gap:.5rem;display:flex}.meal-name-icon{color:var(--color-primary-500);flex-shrink:0}.meal-name-text{color:var(--color-surface-800);font-weight:500}.meal-time-wrap{color:var(--color-surface-600);align-items:center;gap:.375rem;display:flex}.meal-time-icon{flex-shrink:0}.food-text{color:var(--color-surface-700)}.food-text-error{color:#fbbf24}.qty-cell{text-align:right;font-variant-numeric:tabular-nums;color:var(--color-surface-700);padding:.75rem 1.25rem}.unit-badge{background-color:var(--color-surface-200);color:var(--color-surface-700);border-radius:.375rem;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.unit-badge-missing{color:#fca5a5;background-color:#ef44441a;border-radius:.375rem;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.preview-footer{border-top:1px solid var(--color-surface-200);background-color:var(--color-surface-100);justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.preview-footer-stats{color:var(--color-surface-600);font-size:.75rem}.preview-footer-count{color:var(--color-surface-700);font-weight:500}.download-link{color:var(--color-surface-500);align-items:center;gap:.25rem;font-size:.75rem;text-decoration:none;transition:color .15s;display:inline-flex}.download-link:hover{color:var(--color-primary-600)}.continue-wrap{justify-content:flex-end;display:flex}.continue-btn{cursor:pointer;background-color:var(--color-primary-500);color:#fff;border:none;border-radius:.75rem;align-items:center;gap:.5rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 0 12px #10b98133}.continue-btn:hover{background-color:var(--color-primary-400);box-shadow:0 0 20px #10b9814d}.continue-btn:active{transform:scale(.98)}.continue-btn.is-disabled{opacity:.4;cursor:not-allowed;background-color:var(--color-surface-300);color:var(--color-surface-500);box-shadow:none}.continue-btn.is-disabled:hover{background-color:var(--color-surface-300);box-shadow:none}.placeholder-card{border:1px solid var(--color-surface-300);background-color:var(--color-card);text-align:center;border-radius:1rem;padding:3rem}.placeholder-icon-wrap{background-color:var(--color-primary-50);margin-inline:auto;border-radius:1rem;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;margin-bottom:1rem;display:flex}.placeholder-icon{color:var(--color-primary-500)}.placeholder-title{font-family:var(--font-display);color:var(--color-surface-800);margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.placeholder-desc{color:var(--color-surface-600);font-size:.875rem}.placeholder-phase{color:var(--color-surface-500);margin-top:1rem;font-size:.75rem}.goals-section{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:1rem;padding:1.25rem}@media(min-width:640px){.goals-section{padding:1.5rem}}.goals-section-header{align-items:center;gap:.625rem;margin-bottom:1.25rem;display:flex}.goals-section-icon-wrap{border-radius:.625rem;flex-shrink:0;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;display:flex}.goals-section-icon-wrap.is-calories{background-color:#fb923c1a}.goals-section-icon-wrap.is-macros{background-color:var(--color-primary-50)}.goals-section-icon-wrap.is-thresholds{background-color:#60a5fa1a}.goals-section-icon{color:var(--color-surface-800)}.goals-section-icon-wrap.is-calories .goals-section-icon{color:#fb923c}.goals-section-icon-wrap.is-macros .goals-section-icon{color:var(--color-primary-600)}.goals-section-icon-wrap.is-thresholds .goals-section-icon{color:#60a5fa}.goals-section-title{font-family:var(--font-display);color:var(--color-surface-800);font-size:1rem;font-weight:600}.calorie-input-wrap{align-items:center;gap:.5rem;display:flex}.calorie-input{border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);width:10rem;color:var(--color-surface-800);font-variant-numeric:tabular-nums;border-radius:.625rem;outline:none;padding:.5rem .75rem;font-size:1rem;font-weight:500;transition:border-color .15s,box-shadow .15s}.calorie-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #10b98126}.calorie-input.is-invalid{border-color:var(--color-danger)}.calorie-input.is-invalid:focus{box-shadow:0 0 0 3px #ef444426}.calorie-unit{color:var(--color-surface-500);font-size:.875rem;font-weight:500}.goals-field-error{color:var(--color-danger);margin-top:.5rem;font-size:.8125rem}.macro-total-bar{border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);border-radius:.625rem;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.5rem .875rem;transition:background-color .2s,border-color .2s;display:flex}.macro-total-bar.is-valid{background-color:#10b9810f;border-color:#10b98140}.macro-total-bar.is-invalid{background-color:#ef44440f;border-color:#ef444440}.macro-total-label{color:var(--color-surface-600);font-size:.8125rem;font-weight:500}.macro-total-value{font-variant-numeric:tabular-nums;color:var(--color-surface-700);font-size:.875rem;font-weight:600;transition:color .2s}.macro-total-bar.is-valid .macro-total-value{color:var(--color-primary-600)}.macro-total-bar.is-invalid .macro-total-value{color:var(--color-danger)}.macro-slider-group{border-bottom:1px solid var(--color-surface-200);padding:.75rem 0}.macro-slider-group:last-child{border-bottom:none;padding-bottom:0}.macro-slider-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.macro-slider-label{color:var(--color-surface-700);margin-right:auto;font-size:.875rem;font-weight:500}.macro-slider-label.is-protein{color:#60a5fa}.macro-slider-label.is-carbs{color:var(--color-primary-600)}.macro-slider-label.is-fat{color:#fb923c}.macro-slider-pct{font-variant-numeric:tabular-nums;text-align:right;min-width:2.5rem;font-size:.9375rem;font-weight:600}.macro-slider-pct.is-protein{color:#60a5fa}.macro-slider-pct.is-carbs{color:var(--color-primary-600)}.macro-slider-pct.is-fat{color:#fb923c}.macro-grams{font-variant-numeric:tabular-nums;text-align:center;border-radius:9999px;justify-content:center;align-items:center;min-width:3rem;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.macro-grams.is-protein{color:#93bbfd;background-color:#60a5fa1a}.macro-grams.is-carbs{color:var(--color-primary-700);background-color:#10b9811a}.macro-grams.is-fat{color:#fdb78b;background-color:#fb923c1a}.macro-slider{appearance:none;cursor:pointer;background:var(--color-surface-300);border-radius:3px;outline:none;width:100%;height:6px;transition:background .15s}.macro-slider::-webkit-slider-thumb{appearance:none;border:2px solid var(--color-surface-100);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:box-shadow .15s,transform .15s}.macro-slider::-moz-range-thumb{border:2px solid var(--color-surface-100);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:box-shadow .15s,transform .15s}.macro-slider:active::-webkit-slider-thumb{transform:scale(1.15)}.macro-slider:active::-moz-range-thumb{transform:scale(1.15)}.macro-slider.is-protein::-webkit-slider-thumb{background-color:#60a5fa;box-shadow:0 0 8px #60a5fa4d}.macro-slider.is-protein::-moz-range-thumb{background-color:#60a5fa;box-shadow:0 0 8px #60a5fa4d}.macro-slider.is-protein:hover::-webkit-slider-thumb{box-shadow:0 0 14px #60a5fa73}.macro-slider.is-protein:hover::-moz-range-thumb{box-shadow:0 0 14px #60a5fa73}.macro-slider.is-carbs::-webkit-slider-thumb{background-color:var(--color-primary-500);box-shadow:0 0 8px #10b9814d}.macro-slider.is-carbs::-moz-range-thumb{background-color:var(--color-primary-500);box-shadow:0 0 8px #10b9814d}.macro-slider.is-carbs:hover::-webkit-slider-thumb{box-shadow:0 0 14px #10b98173}.macro-slider.is-carbs:hover::-moz-range-thumb{box-shadow:0 0 14px #10b98173}.macro-slider.is-fat::-webkit-slider-thumb{background-color:#fb923c;box-shadow:0 0 8px #fb923c4d}.macro-slider.is-fat::-moz-range-thumb{background-color:#fb923c;box-shadow:0 0 8px #fb923c4d}.macro-slider.is-fat:hover::-webkit-slider-thumb{box-shadow:0 0 14px #fb923c73}.macro-slider.is-fat:hover::-moz-range-thumb{box-shadow:0 0 14px #fb923c73}.threshold-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media(min-width:640px){.threshold-grid{grid-template-columns:repeat(3,1fr)}}.threshold-item{flex-direction:column;gap:.375rem;display:flex}.threshold-label{color:var(--color-surface-600);font-size:.8125rem;font-weight:500}.threshold-input-wrap{align-items:center;gap:.5rem;display:flex}.threshold-input{border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);width:100%;color:var(--color-surface-800);font-variant-numeric:tabular-nums;border-radius:.625rem;outline:none;padding:.5rem .75rem;font-size:.9375rem;font-weight:500;transition:border-color .15s,box-shadow .15s}.threshold-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #10b98126}.threshold-unit{color:var(--color-surface-500);flex-shrink:0;font-size:.8125rem;font-weight:500}.calorie-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.calorie-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.threshold-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.threshold-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.calorie-input[type=number],.threshold-input[type=number]{-moz-appearance:textfield}.dashboard-loading{border:1px solid var(--color-surface-300);background-color:var(--color-card);text-align:center;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;padding:4rem 1.5rem;display:flex}.dashboard-loading-icon-wrap{background-color:var(--color-primary-50);border-radius:1rem;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;margin-bottom:1.25rem;animation:2s ease-in-out infinite pulse-glow;display:flex}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #10b98126}50%{box-shadow:0 0 25px #10b9814d}}.dashboard-loading-icon{color:var(--color-primary-500)}.dashboard-loading-title{font-family:var(--font-display);color:var(--color-surface-800);margin-bottom:.375rem;font-size:1.125rem;font-weight:600}.dashboard-loading-desc{color:var(--color-surface-600);margin-bottom:1.5rem;font-size:.875rem}.loading-progress-bar{background-color:var(--color-surface-300);border-radius:3px;width:100%;max-width:20rem;height:6px;overflow:hidden}.loading-progress-fill{background:linear-gradient(90deg,var(--color-primary-400),var(--color-primary-600));border-radius:3px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1);position:relative}.loading-progress-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff26,#0000);animation:1.5s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.dashboard-error{text-align:center;background-color:#ef44440a;border:1px solid #ef444433;border-radius:1rem;flex-direction:column;align-items:center;padding:3rem 1.5rem;display:flex}.dashboard-error-icon-wrap{background-color:#ef44441a;border-radius:1rem;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;margin-bottom:1.25rem;display:flex}.dashboard-error-icon{color:var(--color-danger)}.dashboard-error-title{font-family:var(--font-display);color:#fca5a5;margin-bottom:.375rem;font-size:1.125rem;font-weight:600}.dashboard-error-desc{color:#f87171;max-width:32rem;margin-bottom:1.5rem;font-size:.875rem}.dashboard-error-steps{text-align:left;background-color:#ef44440f;border:1px solid #ef44441f;border-radius:.75rem;width:100%;max-width:28rem;padding:1rem 1.25rem}.dashboard-error-steps-title{color:#fca5a5;margin-bottom:.5rem;font-size:.8125rem;font-weight:600}.dashboard-error-list{color:var(--color-surface-600);flex-direction:column;gap:.375rem;padding-left:1.25rem;font-size:.8125rem;list-style:decimal;display:flex}.dashboard-error-list code{background-color:var(--color-surface-200);color:var(--color-surface-800);border-radius:.25rem;padding:.125rem .375rem;font-size:.75rem}.dashboard-header-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.dashboard-header-left{align-items:center;gap:.75rem;min-width:0;display:flex}.dashboard-body{flex-direction:column;gap:1.5rem;display:flex}.export-btn{border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);color:var(--color-surface-700);cursor:pointer;border-radius:.625rem;flex-shrink:0;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;transition:all .15s;display:inline-flex}.export-btn:hover{color:var(--color-primary-600);border-color:var(--color-primary-200);background-color:var(--color-primary-50)}.export-btn:disabled{opacity:.5;cursor:not-allowed}.failed-banner{color:#fbbf24;background-color:#f59e0b0f;border:1px solid #f59e0b40;border-radius:.75rem;align-items:center;gap:.625rem;padding:.75rem 1rem;font-size:.8125rem;display:flex}.failed-banner svg{flex-shrink:0}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}@media(min-width:768px){.kpi-grid{grid-template-columns:repeat(4,1fr)}}.kpi-card{border:1px solid var(--color-surface-300);background-color:var(--color-card);text-align:center;border-radius:1rem;flex-direction:column;align-items:center;padding:1.25rem 1rem;transition:border-color .2s,box-shadow .2s;display:flex}.kpi-card:hover{border-color:var(--color-surface-400);box-shadow:0 4px 20px #0003}.kpi-ring-wrap{width:5.5rem;height:5.5rem;margin-bottom:.75rem;position:relative}.kpi-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.kpi-ring-bg{fill:none;stroke:var(--color-surface-300);stroke-width:6px}.kpi-ring-progress{fill:none;stroke-width:6px;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}.kpi-ring-progress.is-green{stroke:#10b981;filter:drop-shadow(0 0 4px #10b9814d)}.kpi-ring-progress.is-yellow{stroke:#f59e0b;filter:drop-shadow(0 0 4px #f59e0b4d)}.kpi-ring-progress.is-red{stroke:#ef4444;filter:drop-shadow(0 0 4px #ef44444d)}.kpi-ring-inner{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.kpi-ring-icon.is-green{color:#10b981}.kpi-ring-icon.is-yellow{color:#f59e0b}.kpi-ring-icon.is-red{color:#ef4444}.kpi-info{flex-direction:column;align-items:center;gap:.125rem;display:flex}.kpi-label{color:var(--color-surface-600);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.kpi-actual{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:1.375rem;font-weight:700}.kpi-actual.is-green{color:#10b981}.kpi-actual.is-yellow{color:#f59e0b}.kpi-actual.is-red{color:#ef4444}.kpi-goal{color:var(--color-surface-500);font-variant-numeric:tabular-nums;font-size:.75rem}.charts-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media(min-width:768px){.charts-grid{grid-template-columns:repeat(2,1fr)}}.chart-card{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:1rem;overflow:hidden}.chart-card-header{border-bottom:1px solid var(--color-surface-200);padding:1rem 1.25rem}.chart-card-title{font-family:var(--font-display);color:var(--color-surface-800);font-size:.9375rem;font-weight:600}.chart-card-body{padding:1.25rem}.doughnut-wrap{max-width:14rem;margin:0 auto 1rem;position:relative}.doughnut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.doughnut-center-value{font-family:var(--font-display);color:var(--color-surface-800);font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:700}.doughnut-center-label{color:var(--color-surface-500);margin-top:-.125rem;font-size:.75rem}.doughnut-legend{justify-content:center;align-items:center;gap:1.25rem;display:flex}.doughnut-legend-item{align-items:center;gap:.375rem;display:flex}.doughnut-legend-dot{border-radius:50%;width:8px;height:8px}.doughnut-legend-dot.is-protein{background-color:#60a5fa}.doughnut-legend-dot.is-carbs{background-color:#10b981}.doughnut-legend-dot.is-fat{background-color:#fb923c}.doughnut-legend-label{color:var(--color-surface-600);font-size:.75rem}.doughnut-legend-value{font-variant-numeric:tabular-nums;color:var(--color-surface-700);font-size:.75rem;font-weight:600}.stacked-bar-wrap{height:16rem}.section-heading{font-family:var(--font-display);color:var(--color-surface-800);margin-bottom:.75rem;font-size:1rem;font-weight:600}.meal-details-section{flex-direction:column;gap:.75rem;display:flex}.meal-detail-card{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:.75rem;transition:border-color .15s;overflow:hidden}.meal-detail-card:hover{border-color:var(--color-surface-400)}.meal-detail-header{cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:.875rem 1.25rem;transition:background-color .15s;display:flex}.meal-detail-header:hover{background-color:var(--color-surface-200)}.meal-detail-header-left{align-items:center;gap:.5rem;display:flex}.meal-detail-time-icon{color:var(--color-surface-500);flex-shrink:0}.meal-detail-time{font-variant-numeric:tabular-nums;color:var(--color-surface-500);font-size:.8125rem}.meal-detail-name{color:var(--color-surface-800);font-size:.9375rem;font-weight:500}.meal-detail-header-right{align-items:center;gap:.75rem;display:flex}.meal-detail-cals{font-variant-numeric:tabular-nums;color:var(--color-primary-600);font-size:.875rem;font-weight:600}.meal-detail-chevron{color:var(--color-surface-500)}.meal-detail-body{border-top:1px solid var(--color-surface-200)}.detail-table-wrap{overflow-x:auto}.detail-table{border-collapse:collapse;width:100%;font-size:.8125rem}.detail-th{color:var(--color-surface-500);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--color-surface-200);white-space:nowrap;padding:.625rem 1rem;font-size:.6875rem;font-weight:600}.detail-th-right{text-align:right}.detail-td{color:var(--color-surface-700);border-bottom:1px solid var(--color-surface-200);white-space:nowrap;padding:.625rem 1rem}.detail-td-right{text-align:right}.detail-td-num{font-variant-numeric:tabular-nums}.detail-td-subtotal{color:var(--color-surface-800);font-weight:600}.detail-food-cell{align-items:center;gap:.5rem;display:flex}.detail-food-name{color:var(--color-surface-800);font-weight:500}.detail-food-matched{color:var(--color-surface-500);margin-top:.0625rem;font-size:.6875rem}.detail-food-matched.is-failed{color:#fbbf24}.detail-failed-icon{color:#fbbf24;flex-shrink:0}.detail-row-failed{background-color:#f59e0b0a}.detail-row-failed:hover{background-color:#f59e0b14}.detail-subtotal-row{background-color:var(--color-surface-100)}.detail-subtotal-row .detail-td{border-bottom:none}.threshold-alerts-card{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:1rem;padding:1.25rem}.threshold-alert-list{flex-direction:column;gap:.625rem;display:flex}.threshold-alert-item{background-color:#f59e0b0a;border:1px solid #f59e0b33;border-radius:.625rem;align-items:flex-start;gap:.625rem;padding:.625rem .875rem;display:flex}.threshold-alert-icon{color:#fbbf24;flex-shrink:0;margin-top:.125rem}.threshold-alert-text{color:var(--color-surface-600);font-size:.8125rem;line-height:1.4}.threshold-alert-label{color:#fbbf24;font-weight:600}.threshold-alert-text strong{color:#fcd34d;font-weight:600}.threshold-success{color:var(--color-primary-600);background-color:#10b9810a;border:1px solid #10b98133;border-radius:.625rem;align-items:center;gap:.625rem;padding:.875rem;font-size:.8125rem;display:flex}.threshold-success-icon{color:var(--color-primary-500);flex-shrink:0}.timeline-wrap{height:12rem}.portfolio-page{flex-direction:column;align-items:center;min-height:100vh;padding:1rem;display:flex}.portfolio-hero{text-align:center;max-width:40rem;padding:4rem 1rem 2.5rem}@media(min-width:640px){.portfolio-hero{padding:6rem 1.5rem 3rem}}.portfolio-hero-title{font-family:var(--font-display);color:var(--color-surface-900);letter-spacing:-.025em;font-size:2.5rem;font-weight:700;line-height:1.1}@media(min-width:640px){.portfolio-hero-title{font-size:3.25rem}}.portfolio-hero-accent{color:var(--color-primary-500)}.portfolio-hero-tagline{color:var(--color-surface-600);margin-top:.75rem;font-size:1.0625rem;line-height:1.5}.portfolio-grid-section{width:100%;max-width:72rem;padding:0 .5rem 4rem}@media(min-width:640px){.portfolio-grid-section{padding:0 1.5rem 4rem}}.portfolio-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media(min-width:640px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}.project-card{text-align:left;border:1px solid var(--color-surface-300);background-color:var(--color-card);cursor:pointer;border-radius:1rem;flex-direction:column;align-items:flex-start;padding:1.5rem;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.project-card:hover{border-color:var(--color-surface-400);transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.project-card-icon-wrap{background:linear-gradient(135deg,var(--color-primary-50),var(--color-primary-100));width:2.75rem;height:2.75rem;color:var(--color-primary-500);border-radius:.75rem;justify-content:center;align-items:center;margin-bottom:1rem;display:flex}.project-card-title{font-family:var(--font-display);color:var(--color-surface-800);margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.project-card-desc{color:var(--color-surface-600);flex-grow:1;margin-bottom:1rem;font-size:.875rem;line-height:1.55}.project-card-tags{flex-wrap:wrap;gap:.375rem;margin-bottom:1.25rem;display:flex}.project-card-tag{background-color:var(--color-surface-200);color:var(--color-surface-600);letter-spacing:.01em;border-radius:9999px;padding:.1875rem .5rem;font-size:.6875rem;font-weight:500;display:inline-flex}.project-card-cta{color:var(--color-primary-500);align-items:center;gap:.375rem;font-size:.8125rem;font-weight:600;transition:gap .2s;display:inline-flex}.project-card:hover .project-card-cta{gap:.625rem}.header-left{align-items:center;gap:.75rem;display:flex}.back-to-portfolio{color:var(--color-surface-500);border-right:1px solid var(--color-surface-300);align-items:center;gap:.25rem;padding-right:.75rem;font-size:.75rem;font-weight:500;text-decoration:none;transition:color .15s;display:inline-flex}.back-to-portfolio:hover{color:var(--color-primary-500)}.not-found-page{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.not-found-card{text-align:center;flex-direction:column;align-items:center;max-width:24rem;display:flex}.not-found-code{font-family:var(--font-display);color:var(--color-surface-300);letter-spacing:-.03em;font-size:5rem;font-weight:700;line-height:1}.not-found-title{font-family:var(--font-display);color:var(--color-surface-800);margin-top:.75rem;font-size:1.5rem;font-weight:600}.not-found-desc{color:var(--color-surface-600);margin-top:.5rem;font-size:.9375rem;line-height:1.5}.not-found-link{border:1px solid var(--color-primary-200);color:var(--color-primary-500);border-radius:.625rem;align-items:center;gap:.375rem;margin-top:1.5rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.not-found-link:hover{background-color:var(--color-primary-50);border-color:var(--color-primary-300)}.tb-header{top:calc(var(--spacing) * 0);z-index:40;border-bottom:1px solid var(--color-surface-300);-webkit-backdrop-filter:blur(16px);background-color:#09090bcc;position:sticky}.tb-logo-link{cursor:pointer;align-items:center;gap:.625rem;text-decoration:none;display:flex}.tb-logo-icon-wrap{border-radius:var(--radius-xl);background:linear-gradient(135deg,#7c3aed,#5b21b6);justify-content:center;align-items:center;width:2.25rem;height:2.25rem;transition:box-shadow .2s;display:flex;box-shadow:0 0 12px #7c3aed33}.tb-logo-link:hover .tb-logo-icon-wrap{box-shadow:0 0 20px #7c3aed59}.tb-logo-accent{color:#a78bfa}.tb-page-intro{text-align:center;padding:1rem 0 .5rem}.tb-intro-icon-wrap{margin-inline:auto;background:#7c3aed1a;border-radius:1rem;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;margin-bottom:1rem;display:flex}.tb-intro-icon{color:#a78bfa}.tb-input-form{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:1rem;flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}@media(min-width:640px){.tb-input-form{padding:2rem}}.tb-form-section{flex-direction:column;gap:.5rem;display:flex}.tb-label{color:var(--color-surface-700);font-size:.875rem;font-weight:500}.tb-label-optional{color:var(--color-surface-500);font-weight:400}.tb-textarea-wrap{position:relative}.tb-textarea{border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);width:100%;color:var(--color-surface-800);font-family:var(--font-body);resize:vertical;border-radius:.75rem;outline:none;padding:.75rem 1rem;font-size:.9375rem;line-height:1.6;transition:border-color .15s,box-shadow .15s}.tb-textarea:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed26}.tb-textarea.is-invalid{border-color:var(--color-danger)}.tb-textarea.is-invalid:focus{box-shadow:0 0 0 3px #ef444426}.tb-textarea::placeholder{color:var(--color-surface-500)}.tb-textarea-footer{justify-content:flex-end;margin-top:.375rem;display:flex}.tb-char-count{font-variant-numeric:tabular-nums;color:var(--color-surface-500);font-size:.75rem;transition:color .15s}.tb-char-count.is-near{color:var(--color-warning)}.tb-char-count.is-over{color:var(--color-danger)}.tb-field-error{color:var(--color-danger);font-size:.8125rem}.tb-md-drop-zone{cursor:pointer;border:2px dashed var(--color-surface-300);background-color:var(--color-surface-100);border-radius:.75rem;flex-direction:column;align-items:center;gap:.375rem;padding:1.5rem;transition:all .2s;display:flex;position:relative}.tb-md-drop-zone:hover{background-color:#7c3aed0a;border-color:#7c3aed}.tb-md-drop-zone.is-dragging{background-color:#7c3aed14;border-color:#a78bfa}.tb-md-drop-icon{color:var(--color-surface-500);transition:color .2s}.tb-md-drop-zone:hover .tb-md-drop-icon{color:#a78bfa}.tb-md-drop-text{color:var(--color-surface-700);font-size:.875rem}.tb-md-browse{color:#a78bfa;font-weight:500}.tb-md-drop-hint{color:var(--color-surface-500);font-size:.75rem}.tb-md-file-bar{background-color:#7c3aed0f;border:1px solid #7c3aed40;border-radius:.75rem;justify-content:space-between;align-items:center;padding:.625rem .875rem;display:flex}.tb-md-file-info{align-items:center;gap:.5rem;min-width:0;display:flex}.tb-md-file-icon{color:#a78bfa;flex-shrink:0}.tb-md-file-name{color:var(--color-surface-800);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:500;overflow:hidden}.tb-md-remove-btn{width:1.75rem;height:1.75rem;color:var(--color-surface-500);cursor:pointer;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;transition:all .15s;display:flex}.tb-md-remove-btn:hover{color:var(--color-danger);background-color:#ef44441a}.tb-form-actions{border-top:1px solid var(--color-surface-200);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding-top:.5rem;display:flex}.tb-toggle-btn{color:var(--color-surface-500);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.375rem 0;font-size:.875rem;font-weight:500;transition:color .15s;display:inline-flex}.tb-toggle-btn:hover{color:var(--color-surface-700)}.tb-toggle-btn.is-active{color:#a78bfa}.tb-toggle-track{background-color:var(--color-surface-300);border-radius:9999px;width:2.25rem;height:1.25rem;transition:background-color .2s;position:relative}.tb-toggle-btn.is-active .tb-toggle-track{background-color:#7c3aed}.tb-toggle-thumb{background-color:#fff;border-radius:9999px;width:1rem;height:1rem;transition:transform .2s;position:absolute;top:2px;left:2px}.tb-toggle-btn.is-active .tb-toggle-thumb{transform:translate(1rem)}.tb-generate-btn{cursor:pointer;color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:.75rem;align-items:center;gap:.5rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 0 12px #7c3aed40}.tb-generate-btn:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 0 20px #7c3aed59}.tb-generate-btn:active{transform:scale(.98)}.tb-generate-btn.is-disabled{opacity:.4;cursor:not-allowed;background:var(--color-surface-300);color:var(--color-surface-500);box-shadow:none}.tb-generate-btn.is-disabled:hover{background:var(--color-surface-300);box-shadow:none}.tb-results-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.tb-results-left{align-items:center;gap:.75rem;display:flex}.tb-results-actions{align-items:center;gap:.5rem;display:flex}.tb-btn-primary{cursor:pointer;color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:.625rem;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;transition:all .15s;display:inline-flex;box-shadow:0 0 8px #7c3aed33}.tb-btn-primary:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 0 14px #7c3aed4d}.tb-btn-secondary{border:1px solid var(--color-surface-300);color:var(--color-surface-700);cursor:pointer;background:0 0;border-radius:.625rem;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:500;transition:all .15s;display:inline-flex}.tb-btn-secondary:hover{color:var(--color-surface-800);border-color:var(--color-surface-400);background-color:var(--color-surface-200)}.tb-btn-danger{cursor:pointer;background-color:var(--color-danger);color:#fff;border:none;border-radius:.625rem;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;transition:all .15s;display:inline-flex}.tb-btn-danger:hover{background-color:#dc2626}.tb-task-list{flex-direction:column;gap:.5rem;display:flex}.tb-task-group{flex-direction:column;display:flex}.tb-subtask-list{flex-direction:column;gap:.375rem;margin-top:.375rem;padding-left:1.5rem;display:flex}.tb-card{border:1px solid var(--color-surface-300);background-color:var(--color-card);border-radius:.75rem;transition:all .15s;display:flex;overflow:hidden}.tb-card:hover{border-color:var(--color-surface-400);background-color:var(--color-card-hover)}.tb-card.is-subtask{border-color:var(--color-surface-200);background-color:var(--color-surface-100)}.tb-card.is-subtask:hover{border-color:var(--color-surface-300)}.tb-card-drag-handle{width:2.5rem;color:var(--color-surface-400);cursor:grab;border-right:1px solid var(--color-surface-200);flex-shrink:0;justify-content:center;align-items:center;transition:color .15s;display:flex}.tb-card-drag-handle:hover{color:var(--color-surface-600)}.tb-card-drag-handle:active{cursor:grabbing}.tb-card-body{flex:1;min-width:0;padding:.875rem 1rem}.tb-card-header{align-items:center;gap:.5rem;margin-bottom:.375rem;display:flex}.tb-card-subtask-icon{color:var(--color-surface-500);flex-shrink:0}.tb-card-title{color:var(--color-surface-800);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.9375rem;font-weight:600;overflow:hidden}.tb-card-desc{color:var(--color-surface-600);margin-bottom:.625rem;font-size:.8125rem;line-height:1.5}.tb-card-footer{justify-content:space-between;align-items:center;display:flex}.tb-card-meta{align-items:center;gap:.5rem;display:flex}.tb-card-actions{align-items:center;gap:.25rem;display:flex}.tb-card-action-btn{width:1.75rem;height:1.75rem;color:var(--color-surface-500);cursor:pointer;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;transition:all .15s;display:flex}.tb-card-action-btn:hover{color:#a78bfa;background-color:#7c3aed1a}.tb-card-action-btn.is-danger:hover{color:var(--color-danger);background-color:#ef44441a}.tb-priority-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:9999px;flex-shrink:0;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;display:inline-flex}.tb-priority-badge.is-low{color:#93bbfd;background-color:#60a5fa1a}.tb-priority-badge.is-medium{color:#fbbf24;background-color:#fbbf241a}.tb-priority-badge.is-high{color:#f87171;background-color:#ef44441a}.tb-time-badge{background-color:var(--color-surface-200);color:var(--color-surface-600);border-radius:9999px;align-items:center;gap:.25rem;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.tb-drag-ghost{opacity:.4}.tb-loading-state{border:1px solid var(--color-surface-300);background-color:var(--color-card);text-align:center;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;padding:4rem 1.5rem;display:flex}.tb-loading-icon-wrap{background:#7c3aed1a;border-radius:1rem;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;margin-bottom:1.25rem;animation:2s ease-in-out infinite tb-pulse-glow;display:flex}@keyframes tb-pulse-glow{0%,to{box-shadow:0 0 10px #7c3aed26}50%{box-shadow:0 0 25px #7c3aed4d}}.tb-loading-icon{color:#a78bfa}.tb-loading-title{font-family:var(--font-display);color:var(--color-surface-800);margin-bottom:.375rem;font-size:1.125rem;font-weight:600}.tb-loading-desc{color:var(--color-surface-600);margin-bottom:1.5rem;font-size:.875rem}.tb-loading-dots{justify-content:center;align-items:center;gap:.5rem;display:flex}.tb-loading-dot{background-color:#7c3aed;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite tb-dot-bounce}.tb-loading-dot:nth-child(2){animation-delay:.2s}.tb-loading-dot:nth-child(3){animation-delay:.4s}@keyframes tb-dot-bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.tb-error-state{text-align:center;background-color:#ef44440a;border:1px solid #ef444433;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;padding:4rem 1.5rem;display:flex}.tb-error-icon-wrap{background-color:#ef44441a;border-radius:.75rem;justify-content:center;align-items:center;width:3rem;height:3rem;margin-bottom:1rem;display:flex}.tb-error-icon{color:#f87171}.tb-error-title{font-family:var(--font-display);color:var(--color-surface-800);margin-bottom:.375rem;font-size:1.125rem;font-weight:600}.tb-error-message{color:var(--color-surface-600);max-width:28rem;margin-bottom:1.5rem;font-size:.875rem}.tb-modal-overlay{z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.tb-modal{border:1px solid var(--color-surface-300);background-color:var(--color-surface-100);border-radius:1rem;width:100%;max-width:32rem;overflow:hidden}.tb-modal-header{border-bottom:1px solid var(--color-surface-200);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.tb-modal-title{font-family:var(--font-display);color:var(--color-surface-800);font-size:1.0625rem;font-weight:600}.tb-modal-close{width:2rem;height:2rem;color:var(--color-surface-500);cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;transition:all .15s;display:flex}.tb-modal-close:hover{color:var(--color-surface-800);background-color:var(--color-surface-200)}.tb-modal-body{flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.tb-modal-field{flex-direction:column;flex:1;gap:.375rem;display:flex}.tb-modal-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.tb-modal-textarea{min-height:unset}.tb-modal-footer{border-top:1px solid var(--color-surface-200);justify-content:flex-end;align-items:center;gap:.5rem;padding:1rem 1.25rem;display:flex}.tb-input{border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);width:100%;color:var(--color-surface-800);border-radius:.625rem;outline:none;padding:.5rem .75rem;font-size:.9375rem;transition:border-color .15s,box-shadow .15s}.tb-input:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed26}.tb-select{border:1px solid var(--color-surface-300);background-color:var(--color-surface-200);width:100%;color:var(--color-surface-800);cursor:pointer;border-radius:.625rem;outline:none;padding:.5rem .75rem;font-size:.9375rem;transition:border-color .15s,box-shadow .15s}.tb-select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed26}.tb-confirm-dialog{border:1px solid var(--color-surface-300);background-color:var(--color-surface-100);text-align:center;border-radius:1rem;flex-direction:column;align-items:center;width:100%;max-width:24rem;padding:2rem 1.5rem 1.5rem;display:flex}.tb-confirm-icon-wrap{background-color:#ef44441a;border-radius:.75rem;justify-content:center;align-items:center;width:3rem;height:3rem;margin-bottom:1rem;display:flex}.tb-confirm-icon{color:#f87171}.tb-confirm-title{font-family:var(--font-display);color:var(--color-surface-800);margin-bottom:.375rem;font-size:1.0625rem;font-weight:600}.tb-confirm-desc{color:var(--color-surface-600);margin-bottom:1.5rem;font-size:.875rem}.tb-confirm-actions{justify-content:center;align-items:center;gap:.5rem;width:100%;display:flex}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@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}
