@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&display=swap";body{margin:0;min-width:320px}#root{min-height:100vh}:root{--primary-color: #4FC3F7;--primary-hover: #29B6F6;--secondary-color: #FF6B9D;--secondary-hover: #FF4081;--danger-color: #FF6B9D;--danger-hover: #FF4081;--success-color: #66BB6A;--bg-color: #FFFFFF;--card-bg: #FFFFFF;--card-hover-bg: #F5F9FF;--text-primary: #2C3E50;--text-secondary: #7B8794;--border-color: #E1E8ED;--input-bg: #F8FAFB;--gradient-primary: linear-gradient(135deg, #4FC3F7 0%, #FF6B9D 100%);--gradient-light: linear-gradient(135deg, rgba(79, 195, 247, .1) 0%, rgba(255, 107, 157, .1) 100%);--shadow-sm: 0 2px 8px rgba(79, 195, 247, .1);--shadow-md: 0 4px 16px rgba(79, 195, 247, .15);--shadow-lg: 0 8px 24px rgba(79, 195, 247, .2)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(180deg,#fff,#f8fbff,#fff5f8);background-attachment:fixed;color:var(--text-primary)}.container{max-width:100%;margin:0 auto;padding:20px;min-height:100vh}@media(min-width:768px){.container{max-width:600px}}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.header h1{font-size:24px;font-weight:700;color:var(--text-primary)}.header h2{font-size:20px;font-weight:600;color:var(--text-primary)}.nav-button,.back-button{background:none;border:1px solid var(--border-color);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;color:var(--text-primary);transition:all .2s;font-family:Noto Sans KR,sans-serif}.nav-button:hover,.back-button:hover{background-color:var(--card-hover-bg);border-color:var(--primary-color)}.mode-selector{display:flex;gap:12px;justify-content:center;margin:20px 0 8px}.mode-button{flex:1;max-width:180px;padding:12px 24px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);cursor:pointer;font-size:15px;font-weight:600;color:var(--text-secondary);transition:all .2s;font-family:Noto Sans KR,sans-serif}.mode-button:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--card-hover-bg)}.mode-button.active{border-color:var(--primary-color);background-color:var(--primary-color);color:#fff}.mode-description{text-align:center;margin-bottom:20px}.mode-description p{font-size:14px;color:var(--text-secondary)}.input-mode-selector{display:flex;gap:12px;justify-content:center;margin:20px 0 24px}.input-mode-button{flex:1;max-width:180px;padding:12px 24px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);cursor:pointer;font-size:15px;font-weight:600;color:var(--text-secondary);transition:all .2s;font-family:Noto Sans KR,sans-serif}.input-mode-button:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--card-hover-bg)}.input-mode-button.active{border-color:var(--primary-color);background-color:var(--primary-color);color:#fff}.text-input-section{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px}.text-input-area{width:100%;max-width:600px;min-height:140px;padding:16px;border:1px solid var(--border-color);border-radius:6px;font-size:15px;font-family:Noto Sans KR,sans-serif;resize:vertical;line-height:1.6;transition:border-color .2s;background:var(--input-bg);color:var(--text-primary)}.text-input-area:focus{outline:none;border-color:var(--primary-color)}.text-input-area::placeholder{color:var(--text-secondary);opacity:.7}.add-button{background:var(--gradient-primary);border:none;color:#fff;padding:10px 20px;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s;font-family:Noto Sans KR,sans-serif;box-shadow:var(--shadow-sm)}.add-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.recording-section{display:flex;flex-direction:column;align-items:center;gap:24px;padding:40px 20px}.status-text{font-size:20px;font-weight:600;color:var(--text-primary)}.status-text.listening{color:var(--danger-color)}.mic-button{width:140px;height:140px;border-radius:50%;border:none;background:var(--gradient-primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:var(--shadow-lg)}.mic-button:hover{transform:scale(1.08);box-shadow:0 8px 32px #4fc3f74d}.mic-button.active{background:linear-gradient(135deg,#ff6b9d,#ff4081);animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 20px #f4877166}50%{box-shadow:0 0 40px #f48771cc}}.date-selector-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;padding:20px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.date-selector-section h3{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.date-mode-buttons{display:flex;gap:12px;margin-bottom:12px}.date-mode-button{flex:1;padding:10px 20px;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);cursor:pointer;font-size:14px;font-weight:600;color:var(--text-secondary);transition:all .2s;font-family:Noto Sans KR,sans-serif}.date-mode-button:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--card-hover-bg)}.date-mode-button.active{border-color:var(--primary-color);background-color:var(--primary-color);color:#fff}.date-picker{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-family:Noto Sans KR,sans-serif;margin-bottom:12px;cursor:pointer;transition:border-color .2s;background:var(--input-bg);color:var(--text-primary);color-scheme:dark}.date-picker:focus{outline:none;border-color:var(--primary-color)}.selected-date-display{text-align:center;padding:8px;background:var(--input-bg);border-radius:6px;font-size:14px;color:var(--text-secondary)}.selected-date-display strong{color:var(--primary-color);font-weight:600}.input-guide{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;max-width:600px;margin:16px auto 8px;padding:12px 16px;background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color)}.guide-item{font-size:13px;font-weight:500;color:var(--text-primary);padding:4px 8px;background:var(--input-bg);border-radius:4px;white-space:nowrap}.guide-separator{font-size:12px;color:var(--text-secondary);font-weight:300}.guide-note{font-size:12px;color:var(--text-secondary);text-align:center;margin-top:8px;font-style:italic}.guide-example{font-size:13px;color:var(--primary-color);text-align:center;margin-top:4px;margin-bottom:16px;font-weight:500}.hint-text{font-size:14px;color:var(--text-secondary)}.transcript-box{width:100%;max-width:600px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:20px;min-height:120px;max-height:300px;overflow-y:auto}.ai-preview-label{font-size:12px;color:var(--primary-color);font-weight:600;margin-bottom:12px;padding:6px 12px;background:#007acc26;border-radius:6px;text-align:center}.transcript-final{font-size:16px;line-height:1.6;margin-bottom:8px;color:var(--text-primary)}.transcript-interim{font-size:16px;line-height:1.6;color:var(--text-secondary);font-style:italic}.ai-recording-info{text-align:center;margin-top:20px;padding:20px;background:var(--card-bg);border:2px dashed var(--primary-color);border-radius:8px;max-width:400px}.ai-recording-info p{font-size:16px;color:var(--text-primary);margin-bottom:8px}.ai-recording-note{font-size:14px!important;color:var(--text-secondary)!important;font-style:italic}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.review-section{display:flex;flex-direction:column;gap:24px}.section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm)}.section h3{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.edit-textarea{width:100%;min-height:120px;padding:12px;border:1px solid var(--border-color);border-radius:6px;font-size:15px;font-family:Noto Sans KR,sans-serif;resize:vertical;margin-bottom:12px;background:var(--input-bg);color:var(--text-primary)}.edit-textarea:focus{outline:none;border-color:var(--primary-color)}.secondary-button{background:none;border:1px solid var(--primary-color);color:var(--primary-color);padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;font-family:Noto Sans KR,sans-serif}.secondary-button:hover{background-color:var(--primary-color);color:#fff}.workout-cards{display:flex;flex-direction:column;gap:12px}.workout-card{background:var(--input-bg);border:1px solid var(--border-color);border-radius:16px;padding:20px;position:relative;border-left-width:4px;box-shadow:var(--shadow-sm);transition:all .3s}.workout-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.workout-card.strength{border-left-color:#3b82f6}.workout-card.cardio{border-left-color:#ef4444}.workout-card.core{border-left-color:#f59e0b}.workout-card.mobility{border-left-color:#10b981}.workout-card.snowboard{border-left-color:#8b5cf6}.workout-card.unknown{border-left-color:var(--text-secondary)}.workout-name{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.workout-details{display:flex;gap:12px;flex-wrap:wrap;font-size:14px;color:var(--text-secondary)}.workout-details span{background:var(--card-bg);padding:4px 10px;border-radius:4px;border:1px solid var(--border-color)}.workout-details span.weight{background:var(--primary-color);color:#fff;border-color:var(--primary-color);font-weight:600}.no-details{font-style:italic}.workout-note{margin-top:8px;font-size:13px;color:var(--text-secondary);font-style:italic}.workout-type-badge{position:absolute;top:12px;right:12px;font-size:11px;text-transform:uppercase;color:var(--text-secondary);background:var(--card-bg);padding:4px 8px;border-radius:4px;border:1px solid var(--border-color)}.empty-message{text-align:center;color:var(--text-secondary);padding:20px}.action-buttons{display:flex;gap:12px;margin-top:8px}.primary-button{flex:1;background:var(--gradient-primary);color:#fff;border:none;padding:16px 28px;border-radius:16px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s;font-family:Noto Sans KR,sans-serif;box-shadow:var(--shadow-sm)}.primary-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.cancel-button{flex:1;background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:14px 24px;border-radius:12px;cursor:pointer;font-size:16px;font-weight:500;transition:all .3s;font-family:Noto Sans KR,sans-serif}.cancel-button:hover{background-color:var(--card-hover-bg);border-color:var(--primary-color);color:var(--primary-color)}.complete-button{background:linear-gradient(135deg,#66bb6a,#4caf50);color:#fff;border:none;padding:12px 24px;border-radius:14px;cursor:pointer;font-size:15px;font-weight:600;transition:all .3s;font-family:Noto Sans KR,sans-serif;box-shadow:var(--shadow-sm)}.complete-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.error-message{text-align:center;padding:40px 20px}.error-message h2{margin-bottom:16px;color:var(--danger-color)}.error-message p{margin-bottom:12px;color:var(--text-secondary)}.error-message button{margin-top:20px;background-color:var(--primary-color);color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;font-family:Noto Sans KR,sans-serif}.history-list{display:flex;flex-direction:column;gap:24px}.date-group{display:flex;flex-direction:column;gap:12px}.date-header{font-size:18px;font-weight:600;color:var(--text-primary);padding-bottom:8px;border-bottom:1px solid var(--border-color)}.log-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;padding:20px;cursor:pointer;transition:all .3s;box-shadow:var(--shadow-sm)}.log-item:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--primary-color)}.log-preview{font-size:15px;line-height:1.5;margin-bottom:8px;color:var(--text-primary)}.log-meta{display:flex;gap:12px;font-size:13px;color:var(--text-secondary)}.log-count{font-weight:500}.empty-state{text-align:center;padding:60px 20px}.empty-state p{font-size:16px;color:var(--text-secondary);margin-bottom:24px}.detail-section{display:flex;flex-direction:column;gap:20px}.detail-date{font-size:20px;font-weight:600;color:var(--primary-color);margin-bottom:8px}.detail-text{font-size:15px;line-height:1.6;white-space:pre-wrap;color:var(--text-primary)}.delete-button{background-color:var(--danger-color);color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;margin-top:12px;font-family:Noto Sans KR,sans-serif}.delete-button:hover{background-color:var(--danger-hover)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border-color);display:flex;justify-content:space-around;align-items:center;padding:0 8px;z-index:1000;box-shadow:0 -2px 16px #4fc3f71a}.bottom-nav .nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px;background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:all .2s;border-radius:8px;min-width:60px;font-family:Noto Sans KR,sans-serif}.bottom-nav .nav-item:hover{background-color:var(--card-hover-bg)}.bottom-nav .nav-item.active{background:var(--gradient-light);color:var(--primary-color)}.bottom-nav .nav-item.active svg{transform:scale(1.1)}.bottom-nav .nav-item span{font-size:12px;font-weight:500}.bottom-nav-3 .nav-item{max-width:140px}.app-container{display:flex;flex-direction:column;min-height:100vh;padding-top:60px;padding-bottom:70px}.app-header{position:fixed;top:0;left:0;right:0;height:60px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:1000;box-shadow:var(--shadow-sm)}.header-content{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 20px}.header-logo h1{font-size:20px;font-weight:700;margin:0;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-profile{position:relative}.profile-button{display:flex;align-items:center;gap:10px;background:none;border:1px solid var(--border-color);border-radius:6px;padding:6px 12px;cursor:pointer;transition:all .2s;font-family:Noto Sans KR,sans-serif}.profile-button:hover{background-color:var(--card-hover-bg);border-color:var(--primary-color)}.profile-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.profile-name{font-size:14px;font-weight:500;color:var(--text-primary)}.dropdown-arrow{transition:transform .2s;color:var(--text-secondary)}.dropdown-arrow.open{transform:rotate(180deg)}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:250px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 20px #00000080;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:16px;background:var(--input-bg)}.dropdown-user-info{display:flex;align-items:center;gap:12px}.dropdown-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600}.dropdown-user-details{flex:1}.dropdown-name{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.dropdown-email{font-size:12px;color:var(--text-secondary)}.dropdown-divider{height:1px;background:var(--border-color)}.dropdown-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-primary);transition:all .2s;text-align:left;font-family:Noto Sans KR,sans-serif}.dropdown-item:hover{background:var(--card-hover-bg)}.dropdown-item svg{color:var(--text-secondary)}.recommend-header{text-align:center;margin-bottom:32px}.recommend-header h1{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.recommend-header .subtitle{font-size:14px;color:var(--text-secondary)}.recommend-empty{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.recommend-empty p{color:var(--text-secondary);margin:0}.recommend-empty svg{margin-bottom:20px;color:var(--primary-color)}.recommend-loading{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:20px}.recommend-loading p{color:var(--text-secondary)}.recommend-result{display:flex;flex-direction:column;gap:24px}.recommend-content{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:24px;line-height:1.8}.recommend-content p{margin-bottom:12px;white-space:pre-wrap;color:var(--text-primary)}.recommend-content p:last-child{margin-bottom:0}.error-box{background:#f487711a;border:1px solid var(--danger-color);border-radius:8px;padding:20px;text-align:center}.error-box p{color:var(--danger-color);margin-bottom:16px}.profile-setup{display:flex;flex-direction:column;gap:20px}.setup-instruction{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:20px}.setup-instruction h3{font-size:17px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.instruction-text{font-size:14px;color:var(--text-secondary);line-height:1.6}.profile-input{width:100%;min-height:180px;padding:16px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;font-family:Noto Sans KR,sans-serif;resize:vertical;line-height:1.6;background:var(--input-bg);color:var(--text-primary)}.profile-input:focus{outline:none;border-color:var(--primary-color)}.setup-buttons{display:flex;gap:12px}.setup-buttons .primary-button:disabled{background-color:var(--text-secondary);cursor:not-allowed;opacity:.5}.setup-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px}.setup-loading p{color:var(--text-secondary);font-size:14px}.profile-display{background:var(--gradient-light);border:2px solid transparent;background-clip:padding-box;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:var(--shadow-sm);position:relative}.profile-display:before{content:"";position:absolute;inset:0;border-radius:16px;padding:2px;background:var(--gradient-primary);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.profile-header h3{font-size:16px;font-weight:600;color:var(--primary-color);margin:0}.profile-actions{display:flex;gap:8px}.edit-button{background:none;border:1px solid var(--primary-color);color:var(--primary-color);padding:6px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;font-family:Noto Sans KR,sans-serif}.edit-button:hover{background-color:var(--primary-color);color:#fff}.delete-icon-button{background:none;border:1px solid var(--danger-color);color:var(--danger-color);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;font-family:Noto Sans KR,sans-serif}.delete-icon-button:hover{background-color:var(--danger-color);color:#fff}.profile-content{font-size:15px;line-height:1.8;color:var(--text-primary);white-space:pre-wrap}.recommend-cta{text-align:center;padding:40px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.recommend-cta svg{margin-bottom:16px;color:var(--primary-color)}.recommend-cta p{color:var(--text-secondary);margin:0;font-size:15px}.large-button{margin-top:16px;padding:16px 40px;font-size:17px}.result-actions{display:flex;gap:12px;margin-top:8px}.today-feeling-section{background:var(--gradient-light);border:2px solid transparent;background-clip:padding-box;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:var(--shadow-sm);position:relative}.today-feeling-section:before{content:"";position:absolute;inset:0;border-radius:16px;padding:2px;background:var(--gradient-primary);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.today-feeling-section h3{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--primary-color)}.feeling-input{width:100%;min-height:100px;padding:14px;border:1px solid var(--border-color);border-radius:6px;font-size:15px;font-family:Noto Sans KR,sans-serif;resize:vertical;line-height:1.6;transition:border-color .2s;margin-bottom:12px;background:var(--input-bg);color:var(--text-primary)}.feeling-input:focus{outline:none;border-color:var(--primary-color)}.feeling-input::placeholder{color:var(--text-secondary);opacity:.7}.feeling-hint{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0}.history-workout-view{display:flex;flex-direction:column;gap:28px}.history-date-section{display:flex;flex-direction:column;gap:16px}.history-date-header{display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:600;padding-bottom:8px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.session-count{font-size:14px;font-weight:500;color:var(--text-secondary)}.history-session{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px}.session-time{font-size:13px;font-weight:500;color:var(--primary-color)}.session-workouts{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.history-workout-card{background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;padding:12px;border-left-width:4px}.history-workout-card.strength{border-left-color:#3b82f6}.history-workout-card.cardio{border-left-color:#ef4444}.history-workout-card.core{border-left-color:#f59e0b}.history-workout-card.mobility{border-left-color:#10b981}.history-workout-card.snowboard{border-left-color:#8b5cf6}.history-workout-card.unknown{border-left-color:var(--text-secondary)}.hw-name{font-size:14px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.hw-details{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary)}.hw-weight{font-weight:600;color:var(--primary-color)}.session-detail-button{align-self:flex-start;background:none;border:1px solid var(--primary-color);color:var(--primary-color);padding:6px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;font-family:Noto Sans KR,sans-serif}.session-detail-button:hover{background:var(--primary-color);color:#fff}.todo-header-card{background:var(--gradient-light);border:2px solid transparent;background-clip:padding-box;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:var(--shadow-sm);position:relative}.todo-header-card:before{content:"";position:absolute;inset:0;border-radius:16px;padding:2px;background:var(--gradient-primary);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.todo-date{font-size:20px;font-weight:700;color:var(--primary-color);margin-bottom:16px}.todo-progress-section{display:flex;flex-direction:column;gap:8px}.progress-bar-container{width:100%;height:10px;background:var(--border-color);border-radius:5px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,var(--success-color) 100%);transition:width .3s ease}.progress-text{font-size:14px;font-weight:600;color:var(--text-secondary)}.todo-source-badge{display:inline-block;background:var(--primary-color);color:#fff;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;margin-top:8px}.ai-recommendation-preview{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:20px}.recommendation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.recommendation-header h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.expand-button{background:none;border:none;color:var(--primary-color);font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s;font-family:Noto Sans KR,sans-serif}.expand-button:hover{background:#007acc26}.ai-recommendation-text{font-size:14px;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;transition:max-height .3s ease;overflow:hidden}.ai-recommendation-text.collapsed{max-height:80px}.ai-recommendation-text.expanded{max-height:none}.add-todo-button{background:none;border:1px solid var(--primary-color);color:var(--primary-color);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s;font-family:Noto Sans KR,sans-serif}.add-todo-button:hover{background-color:var(--primary-color);color:#fff}.todo-workout-list{display:flex;flex-direction:column;gap:12px}.todo-workout-list h3{font-size:16px;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.todo-workout-item{display:flex;gap:14px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;align-items:flex-start}.todo-workout-item:hover{box-shadow:0 0 15px #007acc33}.todo-workout-item.completed{background:var(--input-bg);border-color:var(--success-color);opacity:.7}.todo-workout-item.completed .todo-workout-name{text-decoration:line-through;color:var(--text-secondary)}.todo-checkbox{width:24px;height:24px;border:2px solid var(--border-color);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--input-bg);transition:all .2s}.todo-workout-item.completed .todo-checkbox{background:var(--success-color);border-color:var(--success-color)}.todo-checkbox svg{color:#fff}.todo-workout-info{flex:1;display:flex;flex-direction:column;gap:6px}.todo-workout-name{font-size:16px;font-weight:600;color:var(--text-primary)}.todo-workout-specs{display:flex;gap:10px;flex-wrap:wrap;font-size:14px;color:var(--text-secondary)}.spec-weight{font-weight:600;color:var(--primary-color)}.todo-workout-note{font-size:13px;color:var(--text-secondary);font-style:italic}.todo-completion-message{background:#89d1851a;border:2px solid var(--success-color);border-radius:8px;padding:24px;margin-top:20px;display:flex;align-items:center;gap:16px}.completion-icon{font-size:48px}.completion-text h3{font-size:18px;font-weight:700;color:var(--success-color);margin-bottom:4px}.completion-text p{font-size:14px;color:var(--text-secondary)}.login-container,.signup-container{max-width:500px;margin:80px auto;text-align:center;padding:40px 20px}.login-container h1{font-size:32px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.login-subtitle,.signup-subtitle{font-size:16px;color:var(--text-secondary);margin-bottom:40px}.kakao-login-button{width:100%;max-width:400px;padding:14px 20px;background-color:#fee500;border:none;border-radius:8px;font-size:16px;font-weight:600;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s;margin:0 auto 24px}.kakao-login-button:hover{background-color:#fdd835}.kakao-icon{font-size:20px}.divider{display:flex;align-items:center;text-align:center;margin:24px 0;color:var(--text-secondary)}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.divider span{padding:0 16px;font-size:14px}.login-form,.signup-form{display:flex;flex-direction:column;gap:20px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:var(--shadow-sm);text-align:left}.form-group{display:flex;flex-direction:column;align-items:flex-start;gap:8px;text-align:left}.form-group label{font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:6px;font-size:15px;font-family:Noto Sans KR,sans-serif;transition:border-color .2s;background:var(--input-bg);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--primary-color)}.form-group input:disabled{background-color:var(--card-hover-bg);cursor:not-allowed}.login-hint{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:20px}.login-hint p{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.login-hint p:last-child{margin-bottom:0}.field-hint{font-size:12px;color:var(--text-secondary);margin-top:4px;font-style:italic}.agreements-section{display:flex;flex-direction:column;gap:12px;padding:20px;background:var(--input-bg);border-radius:12px;margin-top:8px}.agreement-item{display:flex;align-items:flex-start}.checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:var(--primary-color)}.link-text{color:var(--primary-color);text-decoration:none;font-weight:600;transition:all .2s}.link-text:hover{color:var(--primary-hover);text-decoration:underline}.signup-footer,.login-footer{text-align:center;padding-top:16px;border-top:1px solid var(--border-color)}.signup-footer p,.login-footer p{font-size:14px;color:var(--text-secondary)}.policy-container{max-width:800px;margin:40px auto;padding:40px 20px;background:var(--card-bg);border-radius:16px;box-shadow:var(--shadow-sm)}.policy-container h1{font-size:28px;font-weight:700;margin-bottom:12px;color:var(--text-primary);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.policy-date{font-size:14px;color:var(--text-secondary);margin-bottom:32px;font-style:italic}.policy-section{margin-bottom:40px}.policy-section h2{font-size:20px;font-weight:600;margin-bottom:16px;color:var(--text-primary);padding-bottom:8px;border-bottom:2px solid var(--border-color)}.policy-section h3{font-size:16px;font-weight:600;margin-top:20px;margin-bottom:12px;color:var(--primary-color)}.policy-section p{font-size:15px;line-height:1.8;color:var(--text-primary);margin-bottom:16px}.policy-section ul,.policy-section ol{margin-left:24px;margin-bottom:16px}.policy-section li{font-size:15px;line-height:1.8;color:var(--text-primary);margin-bottom:8px}.policy-section ul li{list-style-type:disc}.policy-section ol li{list-style-type:decimal}.contact-info{background:var(--gradient-light);padding:20px;border-radius:12px;margin-top:12px}.contact-info p{margin-bottom:8px;font-size:14px}.contact-info p:last-child{margin-bottom:0}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:var(--text-secondary)}.month-selector{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:32px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px}.month-nav-button{background:none;border:1px solid var(--border-color);width:40px;height:40px;border-radius:6px;cursor:pointer;font-size:20px;color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:Noto Sans KR,sans-serif}.month-nav-button:hover{background-color:var(--card-hover-bg);border-color:var(--primary-color);color:var(--primary-color)}.month-display{font-size:20px;font-weight:700;color:var(--text-primary);min-width:150px;text-align:center}.stats-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:24px;margin-bottom:24px}.stats-section h2{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;padding:20px;text-align:center;transition:all .2s}.stat-card:hover{border-color:var(--primary-color);transform:translateY(-2px)}.stat-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:500}.stat-value{font-size:28px;font-weight:700;color:var(--primary-color)}.stat-note{font-size:11px;color:var(--text-secondary);margin-top:4px;font-style:italic}.type-stats{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.type-stat-item{display:flex;align-items:center;gap:8px;background:var(--input-bg);padding:10px 16px;border-radius:6px;border:1px solid var(--border-color)}.type-badge{padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;color:#fff}.type-badge.strength{background-color:#3b82f6}.type-badge.cardio{background-color:#ef4444}.type-badge.core{background-color:#f59e0b}.type-badge.snowboard{background-color:#8b5cf6}.calendar-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:24px;margin-bottom:24px}.calendar-section h2{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:20px}.calendar-weekday{text-align:center;font-size:13px;font-weight:600;color:var(--text-secondary);padding:8px}.calendar-day{aspect-ratio:1;background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;padding:8px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;position:relative;transition:all .2s}.calendar-day.empty{background:transparent;border:none}.calendar-day.has-workout{background:#007acc1a;border-color:var(--primary-color);cursor:pointer}.calendar-day.has-workout:hover{transform:scale(1.05);box-shadow:0 0 15px #007acc4d}.day-number{font-size:14px;font-weight:600;color:var(--text-primary)}.workout-indicators{display:flex;gap:4px;flex-wrap:wrap;justify-content:center}.indicator{width:6px;height:6px;border-radius:50%}.indicator.strength{background-color:#3b82f6}.indicator.cardio{background-color:#ef4444}.indicator.core{background-color:#f59e0b}.indicator.snowboard{background-color:#8b5cf6}.calendar-legend{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;padding:16px;background:var(--input-bg);border-radius:6px}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.strength{background-color:#3b82f6}.legend-dot.cardio{background-color:#ef4444}.legend-dot.core{background-color:#f59e0b}.legend-dot.snowboard{background-color:#8b5cf6}.legend-item span{font-size:13px;color:var(--text-secondary)}.bottom-nav-4 .nav-item{max-width:100px;font-size:11px}.bottom-nav-4 .nav-item svg{width:22px;height:22px}.history-day-cards{display:flex;flex-direction:column;gap:12px}.day-card-compact{background:var(--card-bg);border:1px solid var(--border-color);border-radius:18px;padding:20px;cursor:pointer;transition:all .3s;border-left:5px solid transparent;background-image:linear-gradient(var(--card-bg),var(--card-bg)),var(--gradient-primary);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:var(--shadow-sm)}.day-card-compact:hover{box-shadow:var(--shadow-lg);transform:translate(6px) translateY(-2px)}.day-card-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}.day-info{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:60px;padding:12px;background:var(--gradient-primary);border-radius:14px;box-shadow:var(--shadow-sm)}.day-date-short{font-size:24px;font-weight:700;color:#fff;line-height:1}.day-month-year{font-size:11px;font-weight:500;color:#ffffffe6;margin-top:2px}.day-summary{flex:1;display:flex;flex-direction:column;gap:6px}.day-title{font-size:15px;font-weight:600;color:var(--text-primary)}.day-stats-inline{display:flex;gap:6px;flex-wrap:wrap}.stat-chip{font-size:12px;padding:3px 8px;background:var(--input-bg);border-radius:4px;color:var(--text-secondary);font-weight:500}.day-arrow{font-size:24px;color:var(--text-secondary);font-weight:300}.day-workouts-preview{display:flex;gap:6px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--border-color)}.workout-chip{font-size:12px;padding:4px 10px;background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-weight:500}.workout-chip-more{font-size:12px;padding:4px 10px;background:var(--primary-color);border-radius:6px;color:#fff;font-weight:600}.detail-stats-summary{display:flex;gap:8px;flex-wrap:wrap;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:20px}.detail-stat{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--input-bg);border-radius:6px;flex:1;min-width:100px}.detail-stat-label{font-size:13px;color:var(--text-secondary);font-weight:500}.detail-stat-value{font-size:18px;font-weight:700;color:var(--primary-color);margin-left:auto}.session-raw-text{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:12px}.session-raw-text:last-child{margin-bottom:0}.session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.session-time{font-size:13px;font-weight:600;color:var(--primary-color)}.delete-session-button{background:none;border:1px solid var(--danger-color);color:var(--danger-color);padding:4px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s;font-family:Noto Sans KR,sans-serif}.delete-session-button:hover{background:var(--danger-color);color:#fff}@media(max-width:640px){.container{padding:12px 12px 90px}.header{margin-bottom:20px}.header h1{font-size:20px}.header h2{font-size:18px}.mic-button{width:130px;height:130px}.workout-cards{gap:14px}.workout-card{padding:18px}.workout-name{font-size:17px;margin-bottom:10px}.primary-button,.cancel-button,.complete-button{padding:18px 24px;font-size:16px;min-height:56px;border-radius:16px}.add-button{padding:12px 24px;font-size:15px;min-height:48px}.bottom-nav{height:75px;padding:0 4px}.bottom-nav .nav-item{min-height:60px;padding:10px 8px;gap:6px}.bottom-nav .nav-item span{font-size:11px}.history-day-cards{gap:10px}.day-card-compact{padding:12px;border-radius:10px}.day-info{min-width:50px;padding:6px}.day-date-short{font-size:20px}.day-month-year{font-size:10px}.day-title{font-size:14px}.stat-chip{font-size:11px;padding:2px 6px}.workout-chip,.workout-chip-more{font-size:11px;padding:3px 8px}.detail-stats-summary{padding:12px;gap:6px}.detail-stat{padding:6px 10px;min-width:80px}.detail-stat-label{font-size:12px}.detail-stat-value{font-size:16px}}@media(max-width:375px){.container{padding:12px}.mic-button{width:110px;height:110px}.bottom-nav .nav-item span{font-size:10px}}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 200px);max-height:600px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-md)}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-message{display:flex;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{justify-content:flex-end}.chat-message.assistant{justify-content:flex-start}.message-content{max-width:80%;padding:14px 18px;border-radius:18px;line-height:1.7;box-shadow:var(--shadow-sm)}.chat-message.user .message-content{background:var(--gradient-primary);color:#fff;border-bottom-right-radius:6px}.chat-message.assistant .message-content{background:var(--input-bg);color:var(--text-primary);border-bottom-left-radius:6px;border:1px solid var(--border-color)}.message-content p{margin:0 0 8px}.message-content p:last-child{margin-bottom:0}.typing-indicator{display:flex;gap:6px;padding:8px 0}.typing-indicator span{width:8px;height:8px;background:var(--text-secondary);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-8px)}}.chat-input-container{border-top:1px solid var(--border-color);padding:16px;background:var(--card-bg)}.chat-input{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:6px;font-size:15px;font-family:Noto Sans KR,sans-serif;resize:none;background:var(--input-bg);color:var(--text-primary);margin-bottom:12px}.chat-input:focus{outline:none;border-color:var(--primary-color)}.chat-input:disabled{opacity:.6;cursor:not-allowed}.chat-buttons{display:flex;gap:12px}.chat-send-button{background:var(--gradient-primary);color:#fff;border:none;padding:12px 28px;border-radius:14px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s;font-family:Noto Sans KR,sans-serif;box-shadow:var(--shadow-sm)}.chat-send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-finalize-button{flex:1;background:linear-gradient(135deg,#66bb6a,#4caf50);color:#fff;border:none;padding:14px 28px;border-radius:16px;cursor:pointer;font-size:15px;font-weight:600;transition:all .3s;font-family:Noto Sans KR,sans-serif;box-shadow:var(--shadow-sm)}.chat-finalize-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.chat-finalize-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-generating{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;border-top:1px solid var(--border-color)}.chat-generating p{font-size:14px;color:var(--text-secondary)}@media(max-width:640px){.chat-container{height:calc(100vh - 180px)}.chat-messages{padding:12px;gap:12px}.message-content{max-width:85%;padding:10px 14px;font-size:14px}.chat-input-container{padding:12px}.chat-input{font-size:14px}.chat-buttons{flex-direction:column}.chat-send-button,.chat-finalize-button{width:100%}}
