*{margin:0;padding:0;box-sizing:border-box}body{background:#e4f0f5;background:linear-gradient(90deg,#e4f0f5,#edf5f0,#f7f5f0);margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}:root{--bg-color: #ffffff;--text-color: #111827}[data-theme=dark]{--bg-color: #111827;--text-color: #f9fafb}body{background-color:var(--bg-color);color:var(--text-color);transition:background-color .3s ease,color .3s ease}.navbar{display:flex;align-items:center;justify-content:space-between;background:#444;padding:.7rem 2rem;color:#fff}.navbar-left{display:flex;align-items:center}.navbar-logo{width:38px;height:38px;margin-right:10px;border-radius:50%;object-fit:cover}.navbar-title{font-size:1.5rem;font-weight:700;color:#19d4fe;margin-right:2rem}.theme-toggle-btn{font-size:1.5rem;background:transparent;border:none;cursor:pointer;margin-left:auto;padding:.5rem;transition:transform .2s ease}.theme-toggle-btn:hover{transform:rotate(20deg)}.navbar-search{flex:1;display:flex;justify-content:center}.navbar-search input{width:260px;padding:.5rem 1rem;border-radius:20px 0 0 20px;border:none;outline:none;font-size:1rem}.navbar-search button{padding:.5rem 1.2rem;border-radius:0 20px 20px 0;border:none;background:#2563eb;color:#fff;font-weight:600;font-size:1rem;cursor:pointer}.navbar-links{display:flex;align-items:center;gap:1.5rem}.navbar-links a{color:#fff;text-decoration:none;font-weight:500;font-size:1.1rem;transition:color .2s}.navbar-links a:hover{color:#19d4fe}.navbar-profile{position:relative;display:inline-block;cursor:pointer}.profile-dropdown{position:absolute;top:100%;left:0;background:#fff;border:1px solid #ddd;padding:8px 16px;z-index:100;min-width:100px;box-shadow:0 2px 8px #0000001a}.profile-dropdown button{background:#3c3edf;color:#fff;border:none;padding:6px 12px;cursor:pointer;width:100%;border-radius:4px}.profile-dropdown button:hover{background:#d32f2f}.user-name{font-size:1rem;color:#fff;font-weight:500}@media (max-width: 600px){.navbar{flex-direction:column;padding:1rem}.navbar-links{flex-direction:column;gap:10px}}.dashboard-container{background:#f7fafd;min-height:100vh;padding:2.5rem 1rem 2rem}.dashboard-container h1{font-size:2.2rem;font-weight:700;color:#2563eb;text-align:center;margin-bottom:1.5rem}.dashboard-top-section{display:flex;justify-content:center;align-items:stretch;gap:2.5rem;margin:2.5rem auto;max-width:1100px;width:100%}.dashboard-top-section>*{flex:1 1 0;min-width:340px;max-width:520px;background:#fff;border-radius:18px;box-shadow:0 4px 24px #00000012;padding:2.5rem 2rem 2rem;display:flex;flex-direction:column;justify-content:center}.metrics-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;padding:1rem}.dashboard-container{background-color:var(--bg-color);color:var(--text-color);min-height:100vh;padding:2rem}.datacard{background:var(--card-bg);color:var(--text-color);padding:1rem;border-radius:10px;box-shadow:0 2px 8px #0000000f}.chart-wrapper{background-color:var(--accent);padding:1rem;border-radius:10px;color:var(--text-color)}.datacard{background:#f8fafc;border-radius:12px;box-shadow:0 2px 12px #2563eb12;padding:1.2rem 1rem;text-align:center;font-size:1.1rem;font-weight:500;color:#222;transition:box-shadow .2s,transform .2s}.datacard:hover{box-shadow:0 8px 32px #2563eb21;transform:translateY(-4px) scale(1.03)}.datacard .datacard-value{color:#2563eb;font-size:1.4rem;font-weight:700;margin-top:.3rem}.charts-section{display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:center;margin:2.5rem auto 0;max-width:1200px}.chart-wrapper{background:#fff;border-radius:18px;box-shadow:0 4px 24px #00000012;padding:2rem 1.5rem 1.5rem;min-width:340px;flex:1 1 380px;max-width:540px}.chart-wrapper h2{font-size:1.3rem;font-weight:700;margin-bottom:1.2rem;color:#2563eb}.market-status-bar{display:flex;justify-content:center;gap:2rem;font-weight:600;margin-top:1rem;font-size:1.1rem}.market-indicator.open{color:green}.market-indicator.closed{color:red}@media (max-width: 900px){.dashboard-top-section{flex-direction:column;align-items:stretch;gap:1.5rem}.dashboard-top-section>*{max-width:98vw;min-width:0;padding:1.2rem .5rem}.charts-section{flex-direction:column;align-items:center}.chart-wrapper{min-width:90vw;max-width:98vw}}.top-gainer-loser-section{display:flex;gap:32px;margin-top:40px;justify-content:center}.gainers{background:#e6f9f0;border-radius:12px;padding:1.5rem 2rem;min-width:220px}.losers{background:#fbeaea;border-radius:12px;padding:1.5rem 2rem;min-width:220px}.gainers h3{color:#16a34a;margin-bottom:16px}.losers h3{color:#dc2626;margin-bottom:16px}@media (max-width: 900px){.top-gainer-loser-section{flex-direction:column;align-items:center}.gainers,.losers{min-width:100%;max-width:100%;margin-bottom:16px}}.stock-details-section{background:#fff;border-radius:18px;box-shadow:0 4px 24px #00000012;padding:2.5rem 2rem 2rem;margin:2rem auto 2.5rem;max-width:700px;min-height:180px;display:flex;flex-direction:column;align-items:center}.stock-details-section h2{font-size:2rem;font-weight:700;margin-bottom:.7rem;color:#222;letter-spacing:1px}.stock-details-list{font-size:1.15rem;color:#333;margin-top:.5rem;line-height:2.1;text-align:center}.stock-details-list span{font-weight:600;color:#2563eb;margin-right:.5rem}@media (max-width: 600px){.stock-details-section{padding:1.2rem .5rem;max-width:98vw}.stock-details-section h2{font-size:1.3rem}.stock-details-list{font-size:1rem}}.top-movers-wrapper{display:flex;justify-content:space-around;gap:2rem;margin:2rem auto;max-width:800px}.mover-column{flex:1;background-color:#f8fafc;padding:1rem;border-radius:1rem;box-shadow:0 0 10px #e2e8f0}.mover-column h3{text-align:center;margin-bottom:1rem;font-size:1.1rem;color:#2563eb}.mover-item{display:flex;justify-content:space-between;margin:.5rem 0;font-weight:500;font-size:.95rem}.mover-item.up{color:green}.mover-item.down{color:red}.form-container{display:flex;flex-direction:column;margin:40px auto;gap:18px;max-width:400px;padding:30px;background:#fff;box-shadow:0 2px 8px #0000001a;background-color:#f0f0f0}.sign-up{font-size:24px;font-weight:600;color:#000;text-align:center;margin:0 0 8px}.welcome-message{font-size:16px;color:#555;text-align:center;margin-bottom:20px}.username,.email,.password{width:100%;margin-bottom:8px;padding:10px;border:1px solid #ccc;border-radius:4px;font-size:16px;outline:none;transition:border .2s ease}.submit-btn{width:100%;padding:10px;background-color:#007bff;color:#fff;border:none;border-radius:4px;font-size:16px;cursor:pointer;margin:4px 0;transition:background-color .2s ease}.login-prompt,.reset-password{text-align:center;margin:8px 0 0;font-size:15px}.sign-in-btn,.sign-up-btn{background-color:#fff;color:#2563eb;border:1.5px solid #c1d3f9;border-radius:4px;font-size:16px;cursor:pointer;padding:8px 18px;font-weight:500;margin-left:6px;transition:background .2s,color .2s}.sign-in-btn:hover,.sign-up-btn:hover{background-color:#2563eb;color:#fff}.stock-ticker{position:relative;width:100%;height:50px;overflow:hidden;background-color:#424242;padding:.5rem 0;border-bottom:2px solid #2563eb;white-space:nowrap;font-family:Montserrat,Arial,sans-serif}.stock-ticker__list{display:flex;flex-direction:row;animation:ticker 20s linear infinite}.stock-ticker__item{padding:0 20px;font-size:16px;color:#333;white-space:nowrap}.stock-ticker-item{display:inline-block;padding:0 32px;font-size:1.2rem;color:#fff;font-weight:600;letter-spacing:1px;border-right:1px solid #2563eb;background:transparent;animation:ticker-scroll 30s linear infinite;transition:background .3s}.stock-ticker-item:last-child{border-right:none}.stock-ticker-item:hover{background:#2563eb;color:#fff}@keyframes ticker-scroll{0%{transform:translate(100%)}to{transform:translate(-100%)}}.stocks-main-wrapper{display:flex;align-items:stretch;justify-content:center;gap:2rem;margin:2rem 0;height:500px;padding:2rem;background-color:#f0f4ff;width:100%;box-sizing:border-box}.stock-container{flex:0 0 35%;max-width:35%;min-width:280px;background:#fff;border-radius:14px;box-shadow:0 4px 24px #2563eb14,0 1.5px 6px #0000000a;padding:2.5rem 2rem 2rem;display:flex;flex-direction:column;justify-content:flex-start;height:100%;box-sizing:border-box}.stock-container:hover{box-shadow:0 8px 32px #2563eb21,0 3px 12px #00000012}.stock-container h2{color:#2563eb;font-size:1.7rem;font-weight:700;margin-bottom:1.2rem;text-align:center;letter-spacing:1px}.details{display:flex;flex-direction:column;gap:.7rem;align-items:flex-start;font-size:1.1rem;padding:.5rem 0}.details p{margin:0;color:#333;font-weight:500;background:#f7fafc;border-radius:6px;padding:.4rem .8rem;width:100%}.error-message{color:#e53e3e;font-weight:600;margin-top:1rem;text-align:center}.first{font-weight:600;color:#2563eb;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;height:auto;padding:.5rem 1rem;background:#f0f4ff;border-radius:8px;box-shadow:0 2px 12px #2563eb1a;transition:background .3s,box-shadow .3s}.stock-news{flex:1 1 0;min-width:320px;background:#fff;border-radius:14px;box-shadow:0 4px 24px #2563eb14,0 1.5px 6px #0000000a;padding:2rem 1.5rem;height:100%;overflow-y:auto;box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#2563eb #f0f4ff}.stock-news::-webkit-scrollbar{width:8px}.stock-news::-webkit-scrollbar-thumb{background:#2563eb;border-radius:6px}.stock-news::-webkit-scrollbar-track{background:#f0f4ff}@media (max-width: 600px){.stocks-container{padding:.5rem}.stock-container{padding:1.2rem .5rem;max-width:98vw}}.stock-chart-wrapper{width:80vw;max-width:900px;margin:2rem auto;display:flex;flex-direction:column;align-items:center}.stock-chart-wrapper .chart-title{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:1rem;text-align:center}.stock-chart-wrapper .button-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;justify-content:center}.stock-chart-wrapper .button-bar button{background:#e0f2fe;color:#0369a1;border:1px solid #bae6fd;border-radius:6px;padding:.5rem 1rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s,border-color .2s}.stock-chart-wrapper .button-bar button:hover{background:#bae6fd}.stock-chart-wrapper .button-bar button.btn-active{background:#0369a1;color:#fff;border-color:#0369a1}.stock-chart-wrapper .chart-card{width:100%;position:relative;padding-top:50%;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014}.stock-chart-wrapper .chart-card canvas{position:absolute!important;top:0;left:0;width:100%!important;height:100%!important}.stock-chart-wrapper .loading,.stock-chart-wrapper .no-data{width:100%;text-align:center;color:#64748b;padding:1rem 0}@media (max-width: 640px){.stock-chart-wrapper{width:95vw;margin:1.5rem auto}.stock-chart-wrapper .chart-title{font-size:1.25rem}.stock-chart-wrapper .button-bar{gap:.5rem;margin-bottom:1rem}.stock-chart-wrapper .chart-card{padding-top:60%}}.crypto-ticker{overflow:hidden;background:#f8fafc;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:.5rem 0}.ticker-track{display:flex;animation:scroll 20s linear infinite}.ticker-item{display:flex;align-items:center;min-width:150px;margin-right:2rem;font-size:.875rem;color:#334155}.ticker-item img{width:20px;height:20px;margin-right:.5rem}.ticker-item .symbol{font-weight:600;margin-right:.5rem}.ticker-item .price{display:flex;align-items:baseline}.ticker-item .price small{font-size:.7rem;margin-left:.25rem}.ticker-item .price.up{color:#16a34a}.ticker-item .price.down{color:#dc2626}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(-100%)}}.crypto-ticker:hover .ticker-track{animation-play-state:paused}.crypto-news-wrapper{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-top:2rem}.crypto-news-item{display:flex;flex-direction:column;background:#fff;border-radius:10px;overflow:hidden;text-decoration:none;color:inherit;box-shadow:0 2px 8px #0000000d;transition:transform .2s,box-shadow .2s}.crypto-news-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.crypto-news-thumb{width:100%;height:140px;object-fit:cover}.crypto-news-content{padding:.75rem 1rem;display:flex;flex-direction:column;flex:1}.crypto-news-title{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:#1e293b}.crypto-news-desc{flex:1;font-size:.875rem;color:#475569;margin-bottom:.75rem}.crypto-news-footer{display:flex;justify-content:space-between;font-size:.75rem;color:#94a3b8}.crypto-news-loading,.crypto-news-error,.crypto-news-empty{text-align:center;width:100%;margin:2rem 0;color:#64748b}.chart-title{font-size:1.5rem;font-weight:600;color:#1e293b;text-align:center;margin-bottom:1rem}.button-bar{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.btn{flex:1 1 100px;max-width:120px;height:2.5rem;line-height:2.5rem;font-size:.875rem;font-weight:600;border-radius:6px;border:none;cursor:pointer;transition:background .2s,transform .1s;box-shadow:0 2px 4px #0000001a}.btn-inactive{background:#e0e7ff;color:#334155}.btn-inactive:hover{background:#c7d2fe;transform:translateY(-1px)}.btn-active{background:#2563eb;color:#fff}.chart-card{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 4px 12px #0000000d;width:100%;max-width:700px;height:400px;margin-bottom:1.5rem;position:relative}.chart-card canvas{position:absolute!important;top:0;left:0;width:234px}.loading,.no-data{text-align:center;color:#64748b;margin-top:1rem}@media (max-width: 768px){.chart-card{height:300px}}.crypto-main-content{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;align-items:flex-start;padding:2rem;background:#f9fafb;min-height:calc(100vh - 4rem);box-sizing:border-box}.crypto-details-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000000d;max-width:350px;flex:1 1 300px;min-width:300px;display:flex;flex-direction:column;align-items:center;transition:transform .2s,box-shadow .2s;margin-right:2rem}.crypto-heading{font-size:1.25rem;margin-bottom:1rem;font-weight:600;color:#111827}.crypto-stats p{margin:.5rem 0;font-size:1rem;color:#374151}.pos-change{color:#16a34a}.neg-change{color:#dc2626}.watchlist-btn{margin-top:1rem;background:#2563eb;color:#fff;padding:.6rem 1.2rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;width:100%;text-decoration:none;font-size:.875rem;box-shadow:0 2px 4px #0000001a;text-align:center;height:2.5rem}.crypto-chart-container{flex:2 1 500px;min-width:300px;max-width:600px;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;align-items:center;transition:transform .2s,box-shadow .2s;width:100%}.watchlist-btn.btn-added{background:#4ade80;cursor:default}.login-note{color:#888;margin-top:1rem}.news-page-wrapper{max-width:1200px;margin:2rem auto;padding:0 1rem;background:#f8fafc;border-radius:12px;box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column;align-items:center;justify-content:center}.news-page-wrapper h1{font-size:2rem;text-align:center;margin-bottom:1.5rem;color:#1e293b}.news-loading,.news-empty{text-align:center;color:#64748b;margin:2rem 0}.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;width:100%;padding:0 1rem;background:#f8fafc;border-radius:12px;box-shadow:0 4px 12px #0000000d}.news-card{display:block;overflow:hidden;box-shadow:0 4px 12px #0000000d;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s;height:100%;display:flex;flex-direction:column;align-items:stretch;justify-content:space-between;padding:1rem;margin:0 auto;max-width:100%;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000001a;border-radius:8px}.news-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.news-thumb{width:100%;height:160px;object-fit:cover;border-radius:8px;margin-bottom:1rem;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);display:flex;align-items:center}.news-content{padding:1rem;display:flex;flex-direction:column;height:100%}.news-title{font-size:1rem;font-weight:600;margin-bottom:.5rem}.news-desc{flex:1;font-size:.875rem;color:#475569;margin-bottom:1rem}.news-footer{display:flex;justify-content:space-between;font-size:.75rem;color:#94a3b8}
