:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh}#root{min-height:100vh}.App{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.error-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.error-content{background:#fff;border-radius:20px;padding:2.5rem;text-align:center;box-shadow:0 20px 60px #0000001a;max-width:500px;width:100%}.error-content h2{color:#e74c3c;font-size:1.5rem;margin-bottom:1rem}.error-content p{color:#666;font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.retry-button,.home-button{background:linear-gradient(45deg,#667eea,#764ba2);border:none;color:#fff;font-size:1rem;font-weight:600;padding:.8rem 2rem;border-radius:25px;cursor:pointer;transition:all .3s ease;margin:0 .5rem}.retry-button:hover,.home-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #764ba24d}*{margin:0;padding:0;box-sizing:border-box}.fortune-calendar-container{min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;color:#fff}.calendar-header h1{font-size:2rem;margin:0}.back-button{padding:10px 20px;background:#fff;color:#667eea;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.back-button:hover{background:#f0f0f0;transform:translateY(-2px)}.error-message{background:#f44;color:#fff;padding:15px;border-radius:8px;margin-bottom:20px;text-align:center}.calendar{background:#fff;border-radius:16px;padding:30px;box-shadow:0 10px 40px #0000001a;max-width:800px;margin:0 auto}.calendar-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.calendar-controls button{background:#667eea;color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.2rem;cursor:pointer;transition:all .3s ease}.calendar-controls button:hover:not(:disabled){background:#5568d3;transform:scale(1.1)}.calendar-controls button:disabled{opacity:.5;cursor:not-allowed}.calendar-controls h2{margin:0;color:#333;font-size:1.5rem}.year-month-selector{cursor:pointer;transition:all .3s ease;padding:8px 16px;border-radius:8px;-webkit-user-select:none;user-select:none}.year-month-selector:hover{background:#f0f0f0;transform:scale(1.02)}.date-picker-container{display:flex;justify-content:center;margin:15px 0;padding:15px;background:#f9f9f9;border-radius:8px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.date-picker-input{padding:10px 15px;font-size:1rem;border:2px solid #667eea;border-radius:8px;background:#fff;color:#333;cursor:pointer;transition:all .3s ease}.date-picker-input:hover{border-color:#5568d3;box-shadow:0 2px 8px #667eea33}.date-picker-input:focus{outline:none;border-color:#5568d3;box-shadow:0 2px 12px #667eea4d}.today-button{display:block;margin:0 auto 20px;padding:8px 20px;background:#667eea;color:#fff;border:none;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.today-button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px)}.today-button:disabled{opacity:.5;cursor:not-allowed}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:10px}.weekday{text-align:center;font-weight:600;color:#666;padding:10px;font-size:.9rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.calendar-day{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#f5f5f5;transition:all .3s ease;font-weight:500;color:#333}.calendar-day.empty{background:transparent}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{background:#e8e8e8;transform:scale(1.05)}.calendar-day.today{background:#fff3cd;border:2px solid #ffc107;font-weight:700}.calendar-day.has-chat{background:#d1e7ff;border:2px solid #667eea}.calendar-day.has-chat.clickable:hover{background:#b8d9ff}.day-number{font-size:1.1rem;z-index:1}.chat-indicator{position:absolute;top:8px;right:8px;width:8px;height:8px;background:#667eea;border-radius:50%}.loading{grid-column:1 / -1;text-align:center;padding:40px;color:#666;font-size:1.1rem}.calendar-legend{display:flex;justify-content:center;gap:30px;margin-top:30px;padding:20px;background:#fff;border-radius:12px;max-width:800px;margin-left:auto;margin-right:auto}.legend-item{display:flex;align-items:center;gap:10px;color:#333;font-size:.9rem}.legend-indicator{width:30px;height:30px;border-radius:8px;display:inline-block}.legend-indicator.has-chat{background:#d1e7ff;border:2px solid #667eea}.legend-indicator.today{background:#fff3cd;border:2px solid #ffc107}@media (max-width: 768px){.fortune-calendar-container{padding:15px}.calendar-header h1{font-size:1.5rem}.calendar{padding:20px 15px}.calendar-controls h2{font-size:1.2rem}.year-month-selector{padding:6px 12px}.date-picker-input{width:100%;max-width:250px}.day-number{font-size:.9rem}.calendar-legend{flex-direction:column;gap:15px}}.chat-room-container{display:flex;flex-direction:column;height:100vh;background:#f5f5f5}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 10px #0000001a}.chat-header h1{margin:0;font-size:1.3rem;font-weight:600}.chat-header .back-button{background:#fff3;color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.chat-header .back-button:hover{background:#ffffff4d;transform:scale(1.1)}.header-spacer{width:40px}.error-banner{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f44;color:#fff;font-size:.9rem}.error-banner button{background:transparent;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;width:24px;height:24px}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:15px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:1.1rem;text-align:center}.message{display:flex;margin-bottom:10px}.message.user-message{justify-content:flex-end}.message.ai-message{justify-content:flex-start}.message-bubble{max-width:70%;padding:12px 16px;border-radius:18px;position:relative;animation:fadeIn .3s ease}.user-message .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.ai-message .message-bubble{background:#fff;color:#333;border-bottom-left-radius:4px;box-shadow:0 2px 5px #0000001a}.message-text{margin:0 0 8px;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.message-time{font-size:.75rem;opacity:.7;display:block;text-align:right}.ai-message .message-time{color:#666}.typing-indicator{display:flex;gap:4px;padding:8px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#999;animation:typing 1.4s infinite}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.chat-input-container{display:flex;gap:10px;padding:15px 20px;background:#fff;border-top:1px solid #e0e0e0;box-shadow:0 -2px 10px #0000000d}.chat-input-container textarea{flex:1;padding:12px 15px;border:2px solid #e0e0e0;border-radius:24px;font-size:1rem;font-family:inherit;resize:none;max-height:120px;transition:all .3s ease}.chat-input-container textarea:focus{outline:none;border-color:#667eea}.chat-input-container textarea:disabled{background:#f5f5f5;cursor:not-allowed}.chat-input-container button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.chat-input-container button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.chat-input-container button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:20px;color:#666}.chat-error button{padding:12px 24px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease}.chat-error button:hover{background:#5568d3;transform:translateY(-2px)}@media (max-width: 768px){.chat-header h1{font-size:1.1rem}.message-bubble{max-width:85%}.chat-input-container{padding:10px 15px}.chat-input-container button{padding:10px 20px;font-size:.9rem}}.landing-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden}.auth-header{position:absolute;top:0;right:0;left:0;padding:1rem 2rem;z-index:3}.user-info,.login-option{display:flex;justify-content:flex-end;align-items:center;gap:1rem}.welcome-text{color:#fff;font-size:1rem;opacity:.9}.sign-out-button,.login-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sign-out-button:hover,.login-button:hover{background:#ffffff4d;transform:translateY(-1px)}.landing-content{text-align:center;color:#fff;z-index:2;position:relative}.landing-title{font-size:4rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);letter-spacing:.1em}.landing-subtitle{font-size:1.5rem;margin-bottom:3rem;opacity:.9;font-weight:300}.button-group{display:flex;flex-direction:column;gap:1rem;align-items:center}.start-button,.view-result-button,.calendar-button{border:none;color:#fff;font-size:1.5rem;font-weight:600;padding:1rem 3rem;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #0003;text-transform:uppercase;letter-spacing:.1em;min-width:200px}.start-button{background:linear-gradient(45deg,#ff6b6b,#ee5a24)}.start-button:hover{transform:translateY(-3px);box-shadow:0 12px 35px #0000004d;background:linear-gradient(45deg,#ee5a24,#ff6b6b)}.view-result-button{background:linear-gradient(45deg,#667eea,#764ba2)}.view-result-button:hover{transform:translateY(-3px);box-shadow:0 12px 35px #0000004d;background:linear-gradient(45deg,#764ba2,#667eea)}.calendar-button{background:linear-gradient(45deg,#4ecdc4,#44a08d)}.calendar-button:hover{transform:translateY(-3px);box-shadow:0 12px 35px #0000004d;background:linear-gradient(45deg,#44a08d,#4ecdc4)}.start-button:active,.view-result-button:active,.calendar-button:active{transform:translateY(-1px)}.background-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 1px,transparent 1px),radial-gradient(circle at 80% 50%,rgba(255,255,255,.1) 1px,transparent 1px),radial-gradient(circle at 40% 20%,rgba(255,255,255,.1) 1px,transparent 1px),radial-gradient(circle at 60% 80%,rgba(255,255,255,.1) 1px,transparent 1px);background-size:100px 100px,120px 120px,80px 80px,90px 90px;animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@media (max-width: 768px){.landing-title{font-size:2.5rem}.landing-subtitle{font-size:1.2rem}.start-button{font-size:1.2rem;padding:.8rem 2rem}}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.loading-content{text-align:center;color:#fff}.spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}.loading-text{font-size:1.2rem;font-weight:500;opacity:.9}.result-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.result-wrapper{max-width:900px;margin:0 auto;background:#fff;border-radius:20px;padding:2rem;box-shadow:0 20px 60px #0000001a}.header-buttons{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.back-button{background:none;border:none;color:#666;font-size:1rem;cursor:pointer;padding:.5rem;transition:color .3s ease}.back-button:hover{color:#764ba2}.pdf-export-button{background:linear-gradient(45deg,#667eea,#764ba2);border:none;color:#fff;font-size:1rem;font-weight:600;padding:.6rem 1.2rem;border-radius:25px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #764ba24d;display:flex;align-items:center;gap:.5rem}.pdf-export-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #764ba266}.pdf-export-button:active{transform:translateY(0);box-shadow:0 2px 10px #764ba24d}.result-header{text-align:center;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #f0f0f0}.result-title{font-size:2.5rem;font-weight:700;background:linear-gradient(45deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}.person-info h2{color:#333;font-size:1.5rem;margin-bottom:.5rem}.person-info p{color:#666;font-size:1.1rem}.result-content{display:flex;flex-direction:column;gap:2rem}.birth-info-section h3,.saju-section h3,.elements-section h3,.interpretation-section h3{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:1rem;padding-left:1rem;border-left:4px solid #667eea}.birth-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.birth-card{background:linear-gradient(135deg,#f8f9ff,#e8ebff);padding:1.5rem;border-radius:15px;text-align:center;border:2px solid #e0e6ff}.birth-card h4{color:#667eea;font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.birth-card p{color:#333;font-size:1.1rem;font-weight:500}.saju-pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.pillar-card{background:#fff;border:2px solid #e0e0e0;border-radius:15px;padding:1.5rem;text-align:center;transition:transform .3s ease}.pillar-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a}.pillar-card h4{color:#764ba2;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.stem-branch{display:flex;flex-direction:column;gap:.5rem}.stem,.branch{font-size:1.5rem;font-weight:700;padding:.5rem;border-radius:8px}.stem,.stem-sipseong{background:linear-gradient(45deg,#ff9a9e,#fecfef);color:#333}.branch,.branch-sipseong{background:linear-gradient(45deg,#a8edea,#fed6e3);color:#333}.elements-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.element-card{background:#fff;border:3px solid #e0e0e0;border-radius:15px;padding:1.5rem;text-align:center;transition:all .3s ease}.element-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a}.element-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;font-weight:700;margin:0 auto 1rem}.element-icon.화{background-color:#f44336!important}.element-icon.수{background-color:#2196f3!important}.element-icon.목{background-color:#4caf50!important}.element-icon.금{background-color:#9e9e9e!important}.element-icon.토{background-color:#ffeb3b!important;color:#333!important}.element-info h4{color:#333;font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.element-count{color:#666;font-size:1.2rem;font-weight:700}.interpretation-section{background:linear-gradient(135deg,#ffeef8,#f0e6ff);border-radius:15px;padding:2rem}.interpretation-card p{color:#333;font-size:1.1rem;line-height:1.6;margin-bottom:1rem}.interpretation-card ul{list-style:none;padding:0}.interpretation-card li{background:#fff;padding:1rem;margin-bottom:.5rem;border-radius:10px;box-shadow:0 2px 10px #0000000d;color:#333}.gemini-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.loading-spinner{margin-bottom:1rem}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gemini-loading p{color:#667eea;font-size:1.1rem;font-weight:500;margin:0}.gemini-interpretation{animation:fadeIn .5s ease-in}.pdf-generating .gemini-interpretation{animation:none!important}.pdf-generating *{animation:none!important;transition:none!important}.gemini-content p{margin-bottom:1rem;line-height:1.7;color:#333}.gemini-category-section{margin-bottom:2rem}.gemini-category{color:#5e35b1;font-size:1.3rem;font-weight:700;margin:2rem 0 1rem;padding:.8rem 1.2rem;background:linear-gradient(135deg,#f3e5f5,#e8eaf6);border-left:4px solid #5e35b1;border-radius:8px;box-shadow:0 2px 8px #5e35b11a}.gemini-paragraph{margin-bottom:1.2rem;line-height:1.8;color:#444;text-indent:1rem;text-align:justify}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.analysis-request-section{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-radius:12px;text-align:center;border:2px solid #e1bee7}.analysis-request-text{color:#5e35b1;font-size:1.1rem;font-weight:500;margin-bottom:1rem}.analysis-request-button{background:linear-gradient(45deg,#667eea,#764ba2);border:none;color:#fff;font-size:1.1rem;font-weight:600;padding:.8rem 2rem;border-radius:25px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #764ba24d}.analysis-request-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #764ba266}.new-reading-button{background:linear-gradient(45deg,#667eea,#764ba2);border:none;color:#fff;font-size:1.2rem;font-weight:600;padding:1rem 2rem;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #764ba24d;margin:2rem auto 0;display:block}.new-reading-button:hover{transform:translateY(-2px);box-shadow:0 12px 35px #764ba266}@media (max-width: 768px){.result-wrapper{padding:1rem;margin:1rem}.result-title{font-size:2rem}.header-buttons{flex-direction:column;align-items:stretch}.back-button,.pdf-export-button{width:100%;justify-content:center}.birth-info-grid{grid-template-columns:1fr}.saju-pillars{grid-template-columns:repeat(2,1fr)}.elements-grid{grid-template-columns:1fr}}.saju-form-container{min-height:100vh;background:linear-gradient(135deg,#f093fb,#f5576c);display:flex;align-items:center;justify-content:center;padding:2rem}.form-wrapper{background:#fff;border-radius:20px;padding:2.5rem;box-shadow:0 20px 60px #0000001a;max-width:500px;width:100%;position:relative}.back-button{background:none;border:none;color:#666;font-size:1rem;cursor:pointer;padding:.5rem;margin-bottom:1rem;transition:color .3s ease}.back-button:hover{color:#f5576c}.form-title{text-align:center;color:#333;font-size:2rem;font-weight:700;margin-bottom:2rem;background:linear-gradient(45deg,#f093fb,#f5576c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.saju-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;color:#333;margin-bottom:.5rem;font-size:1.1rem}.form-group input,.form-group select{padding:1rem;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;transition:all .3s ease;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#f5576c;box-shadow:0 0 0 3px #f5576c1a}.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.date-inputs,.time-inputs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}.time-inputs{grid-template-columns:1fr 1fr}.checkbox-group{flex-direction:row;align-items:center}.checkbox-label{display:flex;align-items:center;cursor:pointer;font-weight:500;color:#555}.checkbox-label input[type=checkbox]{display:none}.checkmark{width:20px;height:20px;border:2px solid #e0e0e0;border-radius:4px;margin-right:.5rem;position:relative;transition:all .3s ease}.checkbox-label input[type=checkbox]:checked+.checkmark{background:linear-gradient(45deg,#f093fb,#f5576c);border-color:#f5576c}.checkbox-label input[type=checkbox]:checked+.checkmark:after{content:"✓";position:absolute;color:#fff;font-weight:700;left:50%;top:50%;transform:translate(-50%,-50%);font-size:12px}.submit-button{background:linear-gradient(45deg,#f093fb,#f5576c);border:none;color:#fff;font-size:1.2rem;font-weight:600;padding:1rem 2rem;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #f5576c4d;margin-top:1rem}.submit-button:hover{transform:translateY(-2px);box-shadow:0 12px 35px #f5576c66}.submit-button:active{transform:translateY(0)}@media (max-width: 768px){.form-wrapper{padding:1.5rem;margin:1rem}.form-title{font-size:1.5rem}.date-inputs,.time-inputs{gap:.3rem}}
