@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css");:root{--color-primary:#504BEF;--color-primary-hover:#3D38C7;--color-primary-light:#EEF0FF;--color-accent:#F67ADF;--color-accent-light:#FEF0FA;--color-yellow:#D4C800;--color-yellow-light:#FEFCE8;--color-bg:#F8F9FC;--color-surface:#FFFFFF;--color-surface-2:#F3F4F6;--color-border:#E5E7EB;--color-line:#F1F1F3;--color-text-primary:#111827;--color-text-secondary:#6B7280;--color-text-hint:#9CA3AF;--color-text-inverse:#FFFFFF;--color-success:#10B981;--color-success-light:#ECFDF5;--color-error:#EF4444;--color-error-light:#FEF2F2;--color-warning:#F59E0B;--color-warning-light:#FFFBEB;--color-input-bg:#F9FAFB;--color-input-border:#D1D5DB;--color-input-focus:#504BEF;--color-placeholder:#9CA3AF;--btn-primary-bg:#504BEF;--btn-primary-text:#FFFFFF;--btn-primary-hover:#3D38C7;--btn-secondary-bg:#EEF0FF;--btn-secondary-text:#504BEF;--btn-secondary-hover:#DDE0FF;--btn-tertiary-bg:#F3F4F6;--btn-tertiary-text:#374151;--btn-tertiary-hover:#E5E7EB;--btn-danger-bg:#FEF2F2;--btn-danger-text:#EF4444;--btn-danger-hover:#FEE2E2;--btn-disabled-bg:#E5E7EB;--btn-disabled-text:#9CA3AF;--font-base:"Pretendard Variable",Pretendard,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-weight-regular:400;--font-weight-medium:600;--font-weight-super:800;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.75;--sp-1:0.1875rem;--sp-2:0.5rem;--sp-3:0.75rem;--sp-4:1rem;--sp-5:1.5rem;--sp-6:2rem;--sp-7:3rem;--sp-8:4.5rem;--sp-9:6rem;--radius-sm:0.5rem;--radius-md:1rem;--radius-lg:1.5rem;--radius-xl:2rem;--radius-pill:100px;--radius-full:9999px;--z-base:1;--z-dropdown:5;--z-tooltip:6;--z-navbar:10;--z-modal:100;--z-overlay:1000;--transition-fast:.15s ease;--transition-base:.3s ease-in-out;--transition-slow:.4s ease;--tabbar-height:56px;--header-height:56px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-base);font-weight:var(--font-weight-regular);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6,label,p,span{transition:color var(--transition-slow)}a{color:var(--color-primary);text-decoration:none}button{cursor:pointer;border:none;background:none}button,input,select,textarea{font-family:var(--font-base)}img,svg{display:block;max-width:100%}.app-container{max-width:430px;margin:0 auto;min-height:100dvh;background:var(--color-bg);position:relative}.page{padding:var(--sp-4);padding-bottom:calc(var(--tabbar-height) + env(safe-area-inset-bottom) + var(--sp-4))}.page-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 var(--sp-4);background:var(--color-surface);border-bottom:1px solid var(--color-line);position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-navbar)}.page-title{font-size:var(--text-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--sp-5);border:1px solid var(--color-border)}.card+.card{margin-top:var(--sp-3)}.card-title{font-size:var(--text-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--sp-3);display:flex;align-items:center;gap:var(--sp-2)}.card-footer{font-size:var(--text-xs);color:var(--color-text-hint);margin-top:var(--sp-3)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);border-radius:var(--radius-pill);font-family:var(--font-base);font-weight:var(--font-weight-medium);font-size:var(--text-base);padding:var(--sp-3) var(--sp-5);min-height:44px;border:none;cursor:pointer;transition:background-color var(--transition-base),transform var(--transition-fast);text-decoration:none}.btn:active{transform:scale(.97)}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text)}.btn-tertiary{background:var(--btn-tertiary-bg);color:var(--btn-tertiary-text)}.btn-danger{background:var(--btn-danger-bg);color:var(--btn-danger-text)}.btn-primary:hover{background:var(--btn-primary-hover)}.btn-secondary:hover{background:var(--btn-secondary-hover)}.btn-tertiary:hover{background:var(--btn-tertiary-hover)}.btn-danger:hover{background:var(--btn-danger-hover)}.btn:disabled,.btn[aria-disabled=true]{background:var(--btn-disabled-bg);color:var(--btn-disabled-text);cursor:not-allowed;transform:none}.btn-full{width:100%}.btn-sm{font-size:var(--text-sm);padding:var(--sp-2) var(--sp-3);min-height:32px}.input{width:100%;background:var(--color-input-bg);border:1.5px solid var(--color-input-border);border-radius:var(--radius-sm);padding:var(--sp-3) var(--sp-4);font-family:var(--font-base);font-size:var(--text-base);color:var(--color-text-primary);min-height:44px;transition:border-color var(--transition-base);outline:none}.input::placeholder{color:var(--color-placeholder)}.input:focus{border-color:var(--color-input-focus)}.badge{display:inline-flex;align-items:center;border-radius:var(--radius-pill);padding:2px var(--sp-2);font-size:var(--text-xs);font-weight:var(--font-weight-medium);line-height:1.4}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-accent{background:var(--color-accent-light);color:#C756B6}.badge-yellow{background:var(--color-yellow-light);color:#7A7200}.badge-error{background:var(--color-error-light);color:var(--color-error)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-neutral{background:var(--color-surface-2);color:var(--color-text-secondary)}.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;height:calc(var(--tabbar-height) + env(safe-area-inset-bottom));background:var(--color-surface);border-top:1px solid var(--color-border);align-items:flex-start;z-index:var(--z-navbar)}.tabbar,.tabbar-item{display:flex;padding-top:4px}.tabbar-item{flex:1 1;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--color-text-hint);font-size:10px;font-weight:var(--font-weight-medium);transition:color var(--transition-base);min-height:44px;text-decoration:none}.tabbar-item.active{color:var(--color-primary)}.tabbar-item svg{width:22px;height:22px}.section-label{display:inline-flex;align-items:center;gap:var(--sp-2);border-radius:var(--radius-pill);padding:var(--sp-1) var(--sp-3);font-size:var(--text-xs);font-weight:var(--font-weight-medium);margin-bottom:var(--sp-3)}.section-label--primary{background:var(--color-primary-light);color:var(--color-primary)}.section-label--accent{background:var(--color-accent-light);color:#C756B6}.section-label--yellow{background:var(--color-yellow-light);color:#7A7200}.section-label--error{background:var(--color-error-light);color:var(--color-error)}.nutrition-row{display:flex;gap:var(--sp-2);overflow-x:auto;padding-bottom:var(--sp-2);scrollbar-width:none}.nutrition-row::-webkit-scrollbar{display:none}.nutrition-chip{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--color-surface-2);border-radius:var(--radius-pill);padding:var(--sp-2) var(--sp-3);min-width:68px}.nutrition-chip__value{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.nutrition-chip__label{font-size:var(--text-xs);color:var(--color-text-hint)}.sync-banner{background:var(--color-warning-light);border-bottom:1px solid var(--color-warning);padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--sp-2)}.sync-banner--error{background:var(--color-error-light);border-bottom-color:var(--color-error)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-surface-2) 25%,#E9EAED 50%,var(--color-surface-2) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-text{height:1em;margin-bottom:var(--sp-2)}.skeleton-text--sm{width:40%}.skeleton-text--md{width:65%}.skeleton-text--full{width:100%}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);padding:var(--sp-7) var(--sp-5);text-align:center}.empty-state__icon{font-size:2.5rem}.empty-state__title{font-size:var(--text-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.empty-state__desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.tab-group{display:flex;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);background:var(--color-surface);border-bottom:1px solid var(--color-line);overflow-x:auto;scrollbar-width:none}.tab-group::-webkit-scrollbar{display:none}.tab-item{flex-shrink:0;padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;cursor:pointer;transition:all var(--transition-base);border:none}.tab-item.active{background:var(--color-primary-light);color:var(--color-primary)}.list-item{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4);background:var(--color-surface);border-bottom:1px solid var(--color-line);min-height:52px;cursor:pointer;transition:background-color var(--transition-fast)}.list-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.list-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-bottom:none}.list-item:only-child{border-radius:var(--radius-lg);border-bottom:none}.list-item:hover{background:var(--color-surface-2)}.list-item__label{display:flex;align-items:center;gap:var(--sp-3);font-size:var(--text-base);color:var(--color-text-primary)}.list-item__value{font-size:var(--text-sm);color:var(--color-text-secondary)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:var(--z-overlay);display:flex;align-items:flex-end;justify-content:center}.modal-sheet{width:100%;max-width:430px;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--sp-5);padding-bottom:calc(var(--sp-5) + env(safe-area-inset-bottom))}.modal-title{font-size:var(--text-xl);font-weight:var(--font-weight-medium);margin-bottom:var(--sp-5)}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:fade-in .3s ease-in-out}@keyframes spin{0%{transform:rotate(0deg) scale(.8)}50%{transform:rotate(180deg) scale(1)}to{transform:rotate(1turn) scale(.8)}}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-secondary{color:var(--color-text-secondary)}.text-hint{color:var(--color-text-hint)}.text-primary-c{color:var(--color-primary)}.text-error{color:var(--color-error)}.font-medium{font-weight:var(--font-weight-medium)}.font-bold{font-weight:var(--font-weight-super)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-5{margin-top:var(--sp-5)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}