:root{--c-peach-50:#fff5ee;--c-peach-100:#ffe5d4;--c-peach-200:#ffc8a3;--c-peach-400:#ff8b5d;--c-peach-500:#ff7a4a;--c-peach-600:#e66a3a;--c-cream-50:#fffbf5;--c-cream-100:#fff4e5;--c-lavender-100:#f0eaff;--c-lavender-200:#dcc9ff;--c-lavender-400:#b68fff;--c-lavender-600:#8b5fe6;--c-mint-100:#dffae8;--c-mint-400:#6bcfa1;--c-ink-900:#2a2438;--c-ink-700:#4a4357;--c-ink-500:#7a7280;--c-ink-300:#c7c2d0;--c-ink-100:#efebf5;--c-bg:#fffbf5;--c-surface:#fff;--c-surface-soft:#fff8f0;--c-danger:#e5484d;--gradient-bg:linear-gradient(180deg, #fff8f0 0%, #ffefe0 40%, #f8ebff 100%);--gradient-coral:linear-gradient(135deg, #ff8b5d 0%, #ff6a8b 100%);--gradient-soft:linear-gradient(135deg, #ffe5d4, #f0eaff);--gradient-warm:linear-gradient(135deg, #fff5ee, #ffe5d4);--font-sans:"Pretendard", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Segoe UI", Roboto, sans-serif;--text-xs:12px;--text-sm:13px;--text-base:15px;--text-md:16px;--text-lg:18px;--text-xl:22px;--text-2xl:26px;--text-3xl:32px;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--radius-pill:999px;--shadow-sm:0 1px 2px #2a24380a;--shadow-md:0 4px 16px #ff8b5d1a;--shadow-lg:0 12px 32px #ff8b5d29;--shadow-card:0 2px 8px #2a24380a, 0 1px 2px #2a243808;--ease:cubic-bezier(.16, 1, .3, 1);--transition:all .2s var(--ease)}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}html,body,#root{min-height:100dvh}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--c-ink-900);background:var(--gradient-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;overscroll-behavior-y:contain;touch-action:manipulation;background-attachment:fixed;margin:0;line-height:1.55}input,textarea,select{font-family:inherit;font-size:16px}button,a,label,input{-webkit-tap-highlight-color:transparent}button{-webkit-touch-callout:none}::selection{background:var(--c-peach-200);color:var(--c-ink-900)}h1,h2,h3,h4,p{margin:0}h1{font-size:var(--text-3xl);font-weight:var(--weight-bold);letter-spacing:-.5px}h2{font-size:var(--text-2xl);font-weight:var(--weight-bold);letter-spacing:-.3px}h3{font-size:var(--text-lg);font-weight:var(--weight-semibold);letter-spacing:-.2px}button{font-family:inherit}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.page{width:100%;max-width:480px;padding:calc(var(--space-5) + env(safe-area-inset-top)) calc(var(--space-4) + env(safe-area-inset-right)) calc(var(--space-8) + env(safe-area-inset-bottom)) calc(var(--space-4) + env(safe-area-inset-left));gap:var(--space-4);flex-direction:column;min-height:100dvh;margin:0 auto;display:flex}.page-center{width:100%;max-width:420px;padding:calc(var(--space-5) + env(safe-area-inset-top)) var(--space-5) calc(var(--space-5) + env(safe-area-inset-bottom));flex-direction:column;justify-content:center;min-height:100dvh;margin:0 auto;display:flex}.row{gap:var(--space-2);align-items:center;display:flex}.row-between{gap:var(--space-2);justify-content:space-between;align-items:center;display:flex}.col{gap:var(--space-2);flex-direction:column;display:flex}.grow{flex:1}.app-header{padding:var(--space-2) 0 var(--space-4);justify-content:space-between;align-items:center;display:flex}.app-header h1{font-size:var(--text-xl);align-items:center;gap:var(--space-2);display:flex}.user-chip{align-items:center;gap:var(--space-2);background:var(--c-surface);padding:var(--space-1) var(--space-2);border-radius:var(--radius-pill);box-shadow:var(--shadow-card);display:flex}.user-chip__avatar{background:var(--gradient-warm);object-fit:cover;border-radius:50%;width:28px;height:28px}.user-chip__name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--c-ink-700);white-space:nowrap;text-overflow:ellipsis;max-width:80px;overflow:hidden}.card{background:var(--c-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-card)}.card-soft{background:var(--gradient-warm);border-radius:var(--radius-lg);padding:var(--space-5)}.card-section+.card-section{margin-top:var(--space-5)}.btn{justify-content:center;align-items:center;gap:var(--space-2);height:52px;padding:0 var(--space-5);border-radius:var(--radius-md);font-size:var(--text-md);font-weight:var(--weight-semibold);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.98)}.btn-block{width:100%}.btn-primary{background:var(--gradient-coral);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-lg)}.btn-ghost{color:var(--c-ink-700);border:1px solid var(--c-ink-100);min-width:40px;height:40px;padding:0 var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm);background:0 0;text-decoration:none}.btn-ghost:hover{background:var(--c-surface-soft)}.header-actions{align-items:center;gap:var(--space-2);display:flex}.btn-link{color:var(--c-peach-600);height:auto;font-size:var(--text-sm);font-weight:var(--weight-medium);background:0 0;padding:0}.btn-oauth-google{color:#3c4043;background:#fff;border:1px solid #dadce0;box-shadow:0 1px 2px #0000000a}.btn-oauth-google:hover:not(:disabled){background:#f9fafb}.btn-oauth-kakao{color:#000000d9;background:#fee500;box-shadow:0 1px 2px #0000000a}.btn-oauth-kakao:hover:not(:disabled){filter:brightness(.97)}.pet-tabs{gap:var(--space-2);padding:var(--space-1);background:var(--c-cream-100);border-radius:var(--radius-md);grid-template-columns:1fr 1fr;display:grid}.pet-tab{appearance:none;padding:var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-md);font-weight:var(--weight-medium);color:var(--c-ink-500);cursor:pointer;transition:var(--transition);background:0 0;border:none}.pet-tab[aria-pressed=true]{background:var(--c-surface);color:var(--c-ink-900);font-weight:var(--weight-semibold);box-shadow:var(--shadow-sm)}.upload-zone{border:2px dashed var(--c-peach-200);background:var(--c-peach-50);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-4);text-align:center;cursor:pointer;transition:var(--transition);display:block}.upload-zone:hover{border-color:var(--c-peach-400);background:var(--c-peach-100)}.upload-zone__icon{margin-bottom:var(--space-2);font-size:36px}.upload-zone__label{font-size:var(--text-base);color:var(--c-ink-700);font-weight:var(--weight-medium);display:block}.upload-zone__hint{font-size:var(--text-xs);color:var(--c-ink-500);margin-top:var(--space-1);display:block}.upload-preview{object-fit:contain;border-radius:var(--radius-md);width:100%;max-height:280px;margin-top:var(--space-3)}.score-card{background:var(--gradient-soft);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center}.score-card__label{font-size:var(--text-sm);color:var(--c-ink-500);margin-bottom:var(--space-1)}.score-card__value{font-size:48px;font-weight:var(--weight-bold);color:var(--c-ink-900);letter-spacing:-1.2px;justify-content:center;align-items:baseline;gap:var(--space-1);display:flex}.score-card__value small{font-size:var(--text-lg);color:var(--c-ink-500);font-weight:var(--weight-medium)}.score-card__grade{margin-top:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--c-surface);color:var(--c-peach-600);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:var(--weight-semibold);display:inline-block}.kv{gap:var(--space-1);padding:var(--space-3) 0;border-top:1px solid var(--c-ink-100);flex-direction:column;display:flex}.kv__label{font-size:var(--text-xs);color:var(--c-ink-500);font-weight:var(--weight-semibold);letter-spacing:.4px;text-transform:uppercase}.kv__value{font-size:var(--text-base);color:var(--c-ink-900);line-height:1.5}.alert-warning{color:#b45309;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);text-align:center;background:#fff4e5}.disclaimer{font-size:var(--text-xs);color:var(--c-ink-500);margin-top:var(--space-3);line-height:1.5}.reco-section__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--c-ink-700);margin-bottom:var(--space-3);align-items:center;gap:var(--space-1);display:flex}.reco-grid{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.reco-card{text-align:center;background:var(--c-surface);border:1px solid var(--c-ink-100);border-radius:var(--radius-md);padding:var(--space-3);transition:var(--transition);flex-direction:column;align-items:center;text-decoration:none;display:flex}.reco-card:hover{box-shadow:var(--shadow-md);border-color:var(--c-peach-200);transform:translateY(-2px)}.reco-card__emoji{font-size:28px}.reco-card--compact .reco-card__emoji{font-size:20px}.reco-card__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--c-ink-900);margin:var(--space-1) 0}.reco-card--compact .reco-card__title{font-size:var(--text-xs)}.reco-card__subtitle{font-size:var(--text-xs);color:var(--c-ink-500)}.reco-card__cta{margin-top:var(--space-2);padding:var(--space-1) var(--space-3);color:#fff;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--weight-semibold);background:#03c75a;display:inline-block}.history-list{gap:var(--space-3);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.history-item{background:var(--c-surface);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-card)}.history-item__top{gap:var(--space-3);display:flex}.history-thumb{border-radius:var(--radius-md);background:var(--c-peach-50);flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:22px;display:flex;overflow:hidden}.history-thumb img{object-fit:cover;width:100%;height:100%}.history-meta{flex:1;min-width:0}.history-meta__row{margin-bottom:var(--space-1);justify-content:space-between;align-items:baseline;display:flex}.history-meta__date{font-size:var(--text-xs);color:var(--c-ink-500)}.history-meta__score{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--c-peach-600);white-space:nowrap}.history-meta__comment{font-size:var(--text-sm);color:var(--c-ink-700);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.45;display:-webkit-box;overflow:hidden}.history-item__reco{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px dashed var(--c-ink-100)}.empty-state{background:var(--c-surface);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-5);text-align:center;box-shadow:var(--shadow-card)}.empty-state__icon{margin-bottom:var(--space-3);font-size:48px}.empty-state__text{color:var(--c-ink-500);font-size:var(--text-base);margin-bottom:var(--space-4)}.login-card{text-align:center}.login-card__brand{margin-bottom:var(--space-3);font-size:56px}.login-card__title{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--c-ink-900);margin-bottom:var(--space-2);letter-spacing:-.4px}.login-card__subtitle{font-size:var(--text-base);color:var(--c-ink-500);margin-bottom:var(--space-8)}.login-card__divider{font-size:var(--text-xs);color:var(--c-ink-300);margin:var(--space-5) 0;align-items:center;gap:var(--space-3);display:flex}.login-card__divider:before,.login-card__divider:after{content:"";background:var(--c-ink-100);flex:1;height:1px}.center-screen{justify-content:center;align-items:center;gap:var(--space-3);min-height:100vh;color:var(--c-ink-500);font-size:var(--text-sm);flex-direction:column;display:flex}.spinner{border:3px solid var(--c-peach-100);border-top-color:var(--c-peach-400);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=380px){.page,.page-center{padding-left:var(--space-3);padding-right:var(--space-3)}}
