*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1d6ff4;--primary-dark: #1558d6;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-primary: #f0f6ff;--bg-secondary: #ffffff;--bg-tertiary: #e8f0fe;--text-primary: #1a202c;--text-secondary: #6b7280;--border: #d1ddf5;--shadow: rgba(29, 111, 244, .1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column;padding-bottom:80px}.ad-banner{width:100%;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem;gap:.25rem}.ad-label{font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.ad-placeholder{width:100%;max-width:728px;height:90px;background:var(--bg-tertiary);border:1px dashed var(--border);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem}.ad-placeholder p{font-size:1rem;font-weight:600;color:var(--text-secondary)}.ad-placeholder span{font-size:.7rem;color:var(--text-secondary);opacity:.7;text-align:center;padding:0 1rem}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1rem}.dashboard,.alerts-page,.history-page{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header,.alerts-header,.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}h1{font-size:2rem;font-weight:700}.app-headline{color:#1d6ff4}h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.connection-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500}.connection-status.connected{background:#10b9811a;color:var(--success)}.connection-status.disconnected{background:#ef44441a;color:var(--danger)}.price-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.price-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:transform .2s,box-shadow .2s}.price-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow)}.price-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.price-card-symbol{font-size:1.25rem;font-weight:700}.price-card-time{font-size:.75rem;color:var(--text-secondary)}.price-card-price{font-size:2rem;font-weight:700;margin-bottom:.5rem}.price-card-change{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.price-card-change.positive{color:var(--success)}.price-card-change.negative{color:var(--danger)}.price-card-volume{font-size:.875rem;color:var(--text-secondary)}.notification-banner{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.notification-banner span{flex:1}.email-alert-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-top:2rem}.email-alert-header{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;margin-bottom:.4rem;color:var(--text-primary)}.email-alert-badge{margin-left:auto;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;background:var(--bg-tertiary);color:var(--primary);border:1px solid var(--border);border-radius:999px;padding:.15rem .55rem}.email-alert-desc{font-size:.82rem;color:var(--text-secondary);margin-bottom:1rem}.email-subscription-row{display:flex;align-items:center;gap:.75rem;background:var(--bg-tertiary);border-radius:8px;padding:.75rem 1rem}.email-subscription-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.email-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.email-status-dot.active{background:var(--success)}.email-status-dot.inactive{background:var(--text-secondary)}.email-address{font-size:.85rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.email-status-label{font-size:.72rem;color:var(--text-secondary);white-space:nowrap}.email-subscription-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.btn-email-toggle{font-size:.78rem;font-weight:600;padding:.3rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;gap:.3rem;transition:background .15s}.btn-email-toggle:hover:not(:disabled){background:var(--bg-primary)}.btn-email-toggle:disabled{opacity:.5;cursor:not-allowed}.btn-email-remove{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--danger);cursor:pointer;transition:background .15s}.btn-email-remove:hover:not(:disabled){background:#fee2e2}.btn-email-remove:disabled{opacity:.5;cursor:not-allowed}.email-form{display:flex;flex-direction:column;gap:.6rem}.email-input{width:100%;padding:.65rem .9rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);outline:none;transition:border-color .15s}.email-input:focus{border-color:var(--primary)}.email-form-actions{display:flex;gap:.5rem}.btn-email-save{display:flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:8px;border:none;background:var(--primary);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-email-save:hover:not(:disabled){background:var(--primary-dark)}.btn-email-save:disabled{opacity:.5;cursor:not-allowed}.btn-email-cancel{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:background .15s}.btn-email-cancel:hover{background:var(--bg-tertiary)}.email-error{font-size:.78rem;color:var(--danger)}.btn-add-email{display:flex;align-items:center;gap:.5rem;padding:.55rem 1rem;border-radius:8px;border:1px dashed var(--border);background:transparent;color:var(--primary);font-size:.85rem;font-weight:500;cursor:pointer;width:100%;justify-content:center;transition:background .15s,border-color .15s}.btn-add-email:hover{background:var(--bg-tertiary);border-color:var(--primary)}.spin{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.empty-state svg{margin-bottom:1.5rem;opacity:.5}.empty-state p{margin-bottom:2rem;max-width:400px}.alerts-list,.history-list{display:flex;flex-direction:column;gap:1rem}.alert-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.25rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .2s}.alert-item.inactive{opacity:.6}.alert-info{flex:1}.alert-symbol{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.alert-details{display:flex;gap:1rem;font-size:.875rem;color:var(--text-secondary)}.alert-actions{display:flex;gap:.5rem}.history-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.25rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.history-info{flex:1}.history-symbol{font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.history-time{font-size:.75rem;color:var(--text-secondary)}.history-price-info{text-align:right}.history-price{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.history-change{display:inline-flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:600}.history-change.positive{color:var(--success)}.history-change.negative{color:var(--danger)}.history-volume{font-size:.875rem;color:var(--text-secondary);text-align:right}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1a202c80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-in}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border)}.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s,color .2s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.alert-form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.875rem}.form-select,.form-input{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-select:focus,.form-input:focus{outline:none;border-color:var(--primary)}.form-select option{background:var(--bg-tertiary)}.error-message{background:#ef44441a;color:var(--danger);padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-primary,.btn-secondary,.btn-icon{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border)}.btn-icon{padding:.5rem;background:transparent;color:var(--text-secondary)}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon.active{color:var(--primary)}.btn-icon.danger:hover{background:#ef44441a;color:var(--danger)}.navigation{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:.5rem;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1.5rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s;font-size:.75rem;font-weight:500}.nav-item:hover{background:var(--bg-tertiary)}.nav-item.active{color:var(--primary);background:#3b82f61a}.install-prompt{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;box-shadow:0 4px 12px var(--shadow)}.install-prompt-content{display:flex;align-items:center;gap:1rem;flex:1}.install-prompt-text{display:flex;flex-direction:column}.install-prompt-text strong{font-weight:600}.install-prompt-text span{font-size:.875rem;color:var(--text-secondary)}.install-prompt-actions{display:flex;gap:.5rem}.loading{text-align:center;padding:2rem;color:var(--text-secondary)}.alerts-section{margin-bottom:2rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.periodic-badge{display:inline-flex;align-items:center;gap:.25rem}.mode-tabs{display:flex;gap:.5rem;background:var(--bg-tertiary);padding:.25rem;border-radius:10px}.mode-tab{flex:1;padding:.6rem 1rem;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.mode-tab.active{background:var(--primary);color:#fff}.mode-tab:hover:not(.active){background:var(--border);color:var(--text-primary)}.form-hint{margin-top:.5rem;font-size:.8rem;color:var(--text-secondary);line-height:1.4}.header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.alarm-toggle-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.alarm-toggle-btn.alarm-on{background:#1d6ff41f;color:var(--primary);border:1px solid rgba(29,111,244,.3)}.alarm-toggle-btn.alarm-on:hover{background:#1d6ff438}.alarm-toggle-btn.alarm-off{background:#6b72801a;color:var(--text-secondary);border:1px solid var(--border)}.alarm-toggle-btn.alarm-off:hover{background:#6b728033}.alarm-banner{display:flex;align-items:center;gap:.75rem;background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:.875rem 1rem;margin-bottom:1.5rem;color:#92660a;font-size:.9rem}.alarm-banner span{flex:1}.alarm-enable-btn{padding:.4rem .9rem!important;font-size:.875rem!important;white-space:nowrap;flex-shrink:0}.background-alarm-banner{display:flex;align-items:center;gap:.75rem;background:#6b72800f;border:1px solid var(--border);border-radius:10px;padding:.875rem 1rem;margin-bottom:1.5rem;color:var(--text-secondary);font-size:.9rem;transition:all .2s}.background-alarm-banner.subscribed{background:#10b98112;border-color:#10b9814d;color:#065f46}.background-alarm-text{flex:1;display:flex;flex-direction:column;gap:.15rem}.background-alarm-text strong{font-weight:600;font-size:.9rem;color:var(--text-primary)}.background-alarm-text span{font-size:.8rem;color:var(--text-secondary)}@media(max-width:768px){h1{font-size:1.5rem}.price-grid{grid-template-columns:1fr}.dashboard-header,.alerts-header,.history-header,.history-item{flex-direction:column;align-items:flex-start}.history-price-info,.history-volume{text-align:left}}
