@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css";:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1c1c26;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-tertiary: #707080;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--season-spring-from: #ff9a9e;--season-spring-to: #fecfef;--season-summer-from: #a18cd1;--season-summer-to: #fbc2eb;--season-autumn-from: #fa709a;--season-autumn-to: #fee140;--season-winter-from: #30cfd0;--season-winter-to: #330867;--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .37);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--transition-fast: .2s ease;--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.text-gradient{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-spring{background:linear-gradient(135deg,var(--season-spring-from),var(--season-spring-to));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.text-summer{background:linear-gradient(135deg,var(--season-summer-from),var(--season-summer-to));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.text-autumn{background:linear-gradient(135deg,var(--season-autumn-from),var(--season-autumn-to));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.text-winter{background:linear-gradient(135deg,var(--season-winter-from),var(--season-winter-to));-webkit-background-clip:text;-webkit-text-fill-color:transparent}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}@keyframes pulse-soft{0%{box-shadow:0 0 #6366f166}70%{box-shadow:0 0 0 15px #6366f100}to{box-shadow:0 0 #6366f100}}.animate-fade-in{animation:fadeIn .6s cubic-bezier(.4,0,.2,1) forwards}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md);width:100%}.btn{border:none;outline:none;cursor:pointer;font-family:inherit;font-weight:600;transition:var(--transition-normal);display:inline-flex;align-items:center;justify-content:center;border-radius:12px}.card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:24px;box-shadow:0 8px 32px #0003}.app-header{height:80px;display:flex;align-items:center;position:sticky;top:0;z-index:100;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--glass-border);background:#0a0a0fcc}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.5rem;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none}.logo-icon{font-size:1.8rem;animation:float 3s ease-in-out infinite}.header-controls{display:flex;align-items:center;gap:var(--spacing-md)}.language-switcher{display:flex;align-items:center;gap:var(--spacing-xs);background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;padding:4px}.lang-btn{background:transparent;border:none;color:var(--text-muted);padding:6px 12px;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.lang-btn:hover{color:var(--text-primary)}.lang-btn.active{background:#ffffff1a;color:var(--text-primary)}.lang-divider{color:var(--glass-border);font-size:.8rem}.mode-badge{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.5px;transition:all .3s ease}.mode-badge.mock{background:#ffab001f;color:#ffb300;border:1px solid rgba(255,171,0,.25)}.mode-badge.live{background:#4caf501f;color:#4caf50;border:1px solid rgba(76,175,80,.25)}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s ease-in-out infinite}.status-dot.mock{background:#ffb300;box-shadow:0 0 8px #ffb30080}.status-dot.live{background:#4caf50;box-shadow:0 0 8px #4caf5080}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@media(max-width:600px){.header-controls{gap:var(--spacing-sm)}.language-switcher{padding:2px}.lang-btn{padding:4px 8px;font-size:.75rem}.mode-badge{padding:6px 10px;font-size:.7rem}}.uploader-container{width:100%;max-width:600px;margin:0 auto}.dropzone{border:2px dashed var(--glass-border);border-radius:24px;background:var(--glass-bg);min-height:300px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-normal);position:relative;overflow:hidden}.dropzone:hover,.dropzone.dragging{border-color:var(--accent-primary);background:#6366f10d;transform:translateY(-2px)}.dropzone-content{text-align:center;padding:var(--spacing-xl)}.upload-icon{font-size:3rem;margin-bottom:var(--spacing-md);display:block;animation:float 4s ease-in-out infinite}.dropzone h3{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.dropzone p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.upload-hint{display:inline-block;font-size:.8rem;color:var(--text-tertiary);background:#ffffff0d;padding:4px 12px;border-radius:12px}.preview-container{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.image-wrapper{position:relative;width:100%;height:300px;border-radius:16px;overflow:hidden;background:#000}.preview-image{width:100%;height:100%;object-fit:cover}.remove-btn{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.remove-btn:hover{background:#ef4444cc;transform:scale(1.1)}.action-area{display:flex;flex-direction:column;gap:var(--spacing-md)}.analyze-btn{width:100%;padding:16px;font-size:1.1rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 4px 15px #6366f166;position:relative;overflow:hidden}.analyze-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #6366f180}.analyze-btn:disabled{opacity:.7;cursor:not-allowed;background:var(--bg-tertiary);color:var(--text-tertiary);box-shadow:none}.reupload-btn{background:transparent;border:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;text-decoration:underline;text-decoration-color:transparent;transition:var(--transition-fast)}.reupload-btn:hover{color:var(--text-primary);text-decoration-color:var(--text-primary)}@media(min-width:768px){.preview-container{flex-direction:row;align-items:center}.image-wrapper{width:50%;height:350px}.action-area{width:50%}}.result-container{width:100%;max-width:900px;margin:0 auto;padding-bottom:var(--spacing-2xl)}.result-header{text-align:center;margin-bottom:var(--spacing-2xl)}.season-badge{display:inline-block;padding:8px 16px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:100px;font-size:.9rem;font-weight:700;letter-spacing:2px;margin-bottom:var(--spacing-md);text-transform:uppercase;color:var(--text-secondary)}.season-title{font-size:3.5rem;margin-bottom:var(--spacing-md);line-height:1.1;font-weight:800}.season-description{font-size:1.1rem;color:var(--text-secondary);max-width:600px;margin:0 auto var(--spacing-lg)}.characteristics-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-sm)}.tag{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:6px 14px;border-radius:20px;font-size:.9rem;color:var(--text-secondary)}.palettes-section{display:flex;flex-direction:column;gap:var(--spacing-2xl);margin-bottom:var(--spacing-2xl)}.palette-group h3{font-size:1.5rem;margin-bottom:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-sm)}.section-subtitle{color:var(--text-tertiary);margin-bottom:var(--spacing-lg)}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-md)}.color-card{background:var(--bg-secondary);border-radius:16px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;border:1px solid var(--glass-border)}.color-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0003;border-color:#fff3}.color-swatch{height:100px;width:100%}.color-info{padding:var(--spacing-sm)}.color-name{display:block;font-weight:600;font-size:.9rem;margin-bottom:2px}.color-hex{display:block;font-size:.75rem;color:var(--text-tertiary);font-family:monospace;margin-bottom:4px}.color-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.3}.avoid-palette .color-card{opacity:.85}.avoid-palette .color-card:hover{opacity:1}.tips-section{padding:var(--spacing-xl)}.tips-section h3{font-size:1.5rem;margin-bottom:var(--spacing-lg)}.tips-list{list-style:none;display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.tip-item{display:flex;align-items:flex-start;gap:var(--spacing-md);font-size:1.05rem;color:var(--text-secondary);line-height:1.6}.tip-icon{color:var(--accent-primary);font-size:1.2rem}@media(min-width:768px){.tips-list{grid-template-columns:1fr 1fr}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);animation:fadeIn .5s ease-out}.spinner-wrapper{position:relative;width:80px;height:80px;margin-bottom:var(--spacing-lg)}.spinner-ring{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;border:3px solid transparent;border-top-color:var(--accent-primary);border-right-color:var(--accent-secondary);animation:spin 1.5s linear infinite}.spinner-ring:before{content:"";position:absolute;inset:5px;border-radius:50%;border:3px solid transparent;border-top-color:var(--season-spring-from);border-left-color:var(--season-winter-to);animation:spin-reverse 2s linear infinite}.spinner-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background-color:var(--text-primary);border-radius:50%;box-shadow:0 0 20px var(--accent-primary);animation:pulse 1.5s ease-in-out infinite}.loading-text{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-xs);background:linear-gradient(to right,#fff,#a0a0b0);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.loading-subtext{font-size:.9rem;color:var(--text-tertiary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin-reverse{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}to{transform:translate(-50%,-50%) scale(.8);opacity:.5}}.home-page{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding-top:var(--spacing-2xl);padding-bottom:var(--spacing-2xl);display:flex;flex-direction:column;align-items:center}.hero-section{text-align:center;margin-bottom:var(--spacing-2xl);max-width:800px}.hero-title{font-size:3rem;font-weight:800;line-height:1.1;margin-bottom:var(--spacing-md);letter-spacing:-.02em}.hero-subtitle{font-size:1.2rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.content-wrapper{width:100%;display:flex;justify-content:center}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#ef4444;padding:12px 24px;border-radius:12px;margin-bottom:var(--spacing-lg);font-weight:500}.result-view{width:100%}.result-actions{max-width:900px;margin:0 auto var(--spacing-md)}.back-btn{background:transparent;border:1px solid var(--glass-border);color:var(--text-secondary);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;transition:var(--transition-fast)}.back-btn:hover{background:var(--glass-bg);color:var(--text-primary);border-color:var(--text-tertiary)}.app-footer{text-align:center;padding:var(--spacing-lg);color:var(--text-tertiary);font-size:.8rem;border-top:1px solid var(--glass-border);background:var(--bg-secondary)}@media(min-width:768px){.hero-title{font-size:4rem}}#root{width:100%}
