:root{--bg-main:#0f172a;--bg-card:#1e293bb3;--text-primary:#f8fafc;--text-secondary:#94a3b8;--border-color:#ffffff1a;--accent-color:#3b82f6;--color-kospi:#3b82f6;--color-kosdaq:#a855f7;--color-nasdaq:#22c55e;--color-sp500:#ef4444;--shadow-glow:0 0 15px #3b82f64d}body{background-color:var(--bg-main);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}*{box-sizing:border-box}.glass{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:16px}.app-container{max-width:1400px;margin:0 auto;padding:2rem}.app-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2.5rem;padding:1rem 2rem;display:flex}.app-header h1{background:linear-gradient(90deg,#fff,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:2rem;font-weight:700}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem;display:grid}@media (width<=768px){.dashboard-grid{grid-template-columns:1fr}}.chart-card{flex-direction:column;height:440px;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;position:relative}.chart-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #00000080}.chart-header{justify-content:space-between;align-items:flex-end;margin-bottom:1rem;display:flex}.chart-title{align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:600;display:flex}.chart-value{font-size:1.5rem;font-weight:700}.chart-change{font-size:1rem;font-weight:500}.change-positive{color:var(--color-nasdaq)}.change-negative{color:var(--color-sp500)}.chart-body{flex:1;width:100%;min-height:0}.custom-tooltip{border:1px solid var(--border-color);color:var(--text-primary);background:#0f172ae6;border-radius:8px;padding:10px}.custom-tooltip .label{color:var(--text-secondary);margin:0 0 .25rem;font-size:.875rem}.custom-tooltip .value{margin:0;font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}.search-bar-container{align-items:center;gap:1rem;margin-bottom:2rem;padding:.75rem 1.25rem;display:flex}.market-select{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:#0f172a66;border-radius:8px;outline:none;height:38px;padding:.5rem .75rem;font-size:.95rem;font-weight:500;transition:border-color .2s}.market-select:focus{border-color:var(--accent-color)}.market-select option{background:var(--bg-main);color:var(--text-primary)}.search-input-wrapper{border:1px solid var(--border-color);background:#0f172a66;border-radius:8px;flex:1;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.search-icon{color:var(--text-secondary)}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:1rem}.search-input::placeholder{color:var(--text-secondary)}.search-button{background:var(--accent-color);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.95rem;font-weight:600;transition:opacity .2s,transform .1s;display:flex}.search-button:hover{opacity:.9}.search-button:active{transform:scale(.98)}.remove-chart-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;z-index:10;background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:background-color .2s,color .2s,border-color .2s;display:flex;position:absolute;top:1.25rem;right:1.25rem}.remove-chart-btn:hover{color:var(--color-sp500);background:#ef444433;border-color:#ef44444d}.range-selector-row{scrollbar-width:none;gap:.35rem;margin-bottom:.5rem;display:flex;overflow-x:auto}.range-selector-row::-webkit-scrollbar{display:none}.range-btn{color:var(--text-secondary);cursor:pointer;text-align:center;background:#ffffff05;border:1px solid #ffffff0d;border-radius:6px;flex:1;min-width:32px;padding:.3rem .6rem;font-size:.7rem;font-weight:600;transition:all .2s}.range-btn:hover{color:var(--text-primary);background:#ffffff0d;border-color:#ffffff1a}.range-btn.active{background:#ffffff0d;font-weight:700}.chart-type-selector{border:1px solid var(--border-color);background:#0f172a66;border-radius:6px;padding:2px;display:flex}.type-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .5rem;font-size:.65rem;font-weight:600;transition:all .2s}.type-btn:hover{color:var(--text-primary)}.type-btn.active{color:var(--text-primary);background:#ffffff14}.portfolio-btn{color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;background:#ffffff0d;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:background-color .2s,border-color .2s,transform .1s;display:flex}.portfolio-btn:hover{background:#ffffff1a;border-color:#fff3}.portfolio-btn:active{transform:scale(.98)}.add-to-portfolio-btn{color:var(--accent-color);cursor:pointer;background:#3b82f626;border:1px solid #3b82f64d;border-radius:4px;padding:2px 8px;font-size:.75rem;font-weight:700;transition:all .2s}.add-to-portfolio-btn:hover{background:var(--accent-color);color:#fff;box-shadow:0 0 8px #3b82f666}.remove-from-portfolio-btn{color:#ef4444;cursor:pointer;background:#ef444426;border:1px solid #ef44444d;border-radius:4px;padding:2px 8px;font-size:.75rem;font-weight:700;transition:all .2s}.remove-from-portfolio-btn:hover{color:#fff;background:#ef4444;box-shadow:0 0 8px #ef444466}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#0f172a99;justify-content:center;align-items:center;width:100%;height:100%;animation:.2s fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{border:1px solid var(--border-color);background:#1e293b;border-radius:16px;flex-direction:column;width:90%;max-width:650px;max-height:85vh;padding:2rem;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;position:relative;overflow-y:auto;box-shadow:0 20px 40px #00000080}.modal-header{border-bottom:1px solid var(--border-color);align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem;display:flex}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700}.modal-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:background-color .2s,color .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.modal-close-btn:hover{color:var(--text-primary);background:#ffffff0d}.exchange-rate-banner{color:var(--text-secondary);border-radius:8px;justify-content:center;align-items:center;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.9rem;display:flex}.exchange-rate-banner strong{color:var(--text-primary);margin:0 4px}.portfolio-list{flex-direction:column;gap:1rem;max-height:40vh;margin-bottom:1.5rem;padding-right:4px;display:flex;overflow-y:auto}.portfolio-item{border-radius:12px;grid-template-columns:2fr 1.5fr 2fr 1.5fr auto;align-items:center;gap:1rem;padding:1rem;display:grid}.item-info{flex-direction:column;min-width:0;display:flex}.item-name{text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:600;overflow:hidden}.item-ticker{color:var(--text-secondary);font-size:.8rem}.item-price-wrapper,.item-total-wrapper,.item-qty-wrapper{flex-direction:column;display:flex}.item-label{color:var(--text-secondary);text-transform:uppercase;margin-bottom:2px;font-size:.7rem}.item-value{font-size:.9rem;font-weight:500}.item-value-krw{color:var(--text-primary);font-size:.95rem;font-weight:700}.item-qty-input{border:1px solid var(--border-color);color:var(--text-primary);text-align:center;background:#0f172a66;border-radius:6px;outline:none;width:100%;padding:4px 8px;font-size:.9rem;font-weight:600}.item-qty-input:focus{border-color:var(--accent-color)}.item-delete-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.item-delete-btn:hover{color:var(--color-sp500);background:#ef444426}.empty-portfolio{text-align:center;color:var(--text-secondary);padding:3rem 1rem}.modal-footer{border-top:1px solid var(--border-color);justify-content:center;margin-top:1.5rem;padding-top:1.5rem;display:flex}.analysis-trigger-btn{background:linear-gradient(135deg, var(--accent-color), #2563eb);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 2rem;font-size:1rem;font-weight:700;transition:opacity .2s,transform .1s;display:flex;box-shadow:0 4px 12px #3b82f64d}.analysis-trigger-btn:hover{opacity:.95}.analysis-trigger-btn:active{transform:scale(.99)}.portfolio-analysis-container{flex-direction:column;display:flex}.back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:6px;transition:background-color .2s,color .2s;display:flex}.back-btn:hover{color:var(--text-primary);background:#ffffff0d}.analysis-loading-wrapper{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:5rem 1rem;display:flex}.analysis-error-wrapper{text-align:center;padding:4rem 1rem}.analysis-metrics-row{border-radius:12px;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1.25rem;display:grid}.metric-card{flex-direction:column;align-items:center;display:flex}.metric-value{color:var(--text-primary);margin-top:4px;font-size:1.35rem;font-weight:800}.metric-value-secondary{color:var(--text-secondary);margin-top:6px;font-size:1.15rem;font-weight:700}.metric-change{align-items:center;margin-top:6px;font-size:1.1rem;font-weight:700;display:flex}.analysis-chart-wrapper{border:1px solid var(--border-color);background:#0f172a33;border-radius:12px;padding:1rem 1rem .5rem .5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=600px){.modal-content{width:94%;max-height:90vh;padding:1.25rem 1rem}.modal-close-btn{top:1rem;right:1rem}.exchange-rate-banner{margin-bottom:1rem;padding:.6rem .75rem;font-size:.82rem}.portfolio-list{gap:.75rem;margin-bottom:1.25rem}.portfolio-item{grid-template-columns:1fr 1fr 1.2fr .5fr;grid-template-areas:"info info info delete""price qty total total";gap:10px;padding:.85rem;display:grid}.item-info{grid-area:info}.item-price-wrapper{grid-area:price;display:flex!important}.item-qty-wrapper{grid-area:qty}.item-total-wrapper{grid-area:total;align-items:flex-end}.item-delete-btn{grid-area:delete;place-self:start end;padding:4px}.analysis-metrics-row{grid-template-columns:1fr;gap:.75rem;padding:1rem}}.user-profile-badge{border:1px solid var(--border-color);background:#ffffff08;border-radius:8px;align-items:center;gap:8px;padding:4px 10px;transition:all .2s;display:flex}.user-profile-badge:hover{background:#ffffff0f;border-color:#ffffff26}.sync-spin{animation:1.5s linear infinite spin}.login-modal{background:#141e32d9!important;border:1px solid #ffffff26!important}.instructions-body a{color:var(--accent-color);font-weight:600;text-decoration:none}.instructions-body a:hover{color:#60a5fa;text-decoration:underline}.error-banner{box-shadow:0 4px 15px #ef444433}.chart-header-left{flex-direction:column;flex:1;min-width:0;display:flex}.chart-header-right{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.chart-title-text{text-overflow:ellipsis;white-space:nowrap;max-width:220px;overflow:hidden}.header-title-container{align-items:center;gap:1rem;display:flex}.header-actions-container{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}@media (width<=768px){.app-container{padding:1.5rem}.dashboard-grid{gap:1.5rem}}@media (width<=576px){.app-container{padding:.75rem}.app-header{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:1rem}.header-title-container{justify-content:center;width:100%}.header-title-container h1{font-size:1.5rem}.header-actions-container{justify-content:center;gap:8px;width:100%}.search-bar-container{flex-direction:column;align-items:stretch;gap:10px;padding:1rem}.market-select,.search-input-wrapper,.search-button{width:100%;height:40px}.search-button{justify-content:center}.chart-card{height:460px;padding:1rem}.chart-header{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:.75rem}.chart-header-right{flex-direction:row;justify-content:space-between;align-items:center;width:100%;margin-top:4px}.chart-title-text{max-width:140px}}.exchange-rate-bar{justify-content:center;align-items:center;gap:2rem;margin-bottom:2rem;padding:.75rem 1.5rem;display:flex}.rate-item{cursor:pointer;border-radius:8px;align-items:center;gap:.75rem;padding:.35rem .75rem;font-size:.9rem;transition:background-color .2s,transform .1s;display:flex}.rate-item:hover{background:#ffffff0d;transform:translateY(-1px)}.rate-item:active{transform:translateY(0)}.rate-flag-icon{font-size:1.1rem}.rate-label{color:var(--text-secondary);font-weight:500}.rate-values{align-items:center;gap:.75rem;display:flex}.rate-price{color:var(--text-primary);font-weight:700}.rate-change{align-items:center;gap:2px;font-size:.85rem;font-weight:600;display:inline-flex}.rate-divider{background-color:var(--border-color);width:1px;height:16px}.rate-loading,.rate-error{color:var(--text-secondary);font-size:.85rem}@media (width<=768px){.exchange-rate-bar{gap:1.5rem;padding:.65rem 1rem}}@media (width<=576px){.exchange-rate-bar{flex-direction:column;align-items:stretch;gap:.5rem;padding:.75rem 1rem}.rate-item{justify-content:space-between;width:100%}.rate-divider{display:none}}.exchange-rate-modal .chart-card{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;background:0 0;border:none;height:100%;padding:0}.exchange-rate-modal .chart-card:hover{box-shadow:none;transform:none}
