@layer tokens,base,components,theme,enhancements;@layer tokens{:root{--brand-primary:#3498db;--brand-primary-dark:#2980b9;--brand-primary-darker:#1f618d;--brand-secondary:#2ecc71;--brand-secondary-dark:#27ae60;--brand-accent:#9b59b6;--brand-accent-dark:#8e44ad;--color-success:#2ecc71;--color-warning:#f59e0b;--color-danger:#e74c3c;--color-info:#3498db;--color-positive:#ef4444;--color-negative:#2ecc71;--gray-50:#f8f9fa;--gray-100:#f1f3f4;--gray-200:#e8eaed;--gray-300:#dadce0;--gray-800:#3c4043;--color-primary:var(--brand-primary);--color-primary-hover:var(--brand-primary-dark);--color-primary-active:var(--brand-primary-darker);--color-secondary:var(--brand-secondary);--color-secondary-hover:var(--brand-secondary-dark);--color-secondary-active:#219653;--color-accent:var(--brand-accent);--color-background:var(--gray-50);--color-surface:#fff;--color-surface-alt:var(--gray-100);--color-surface-muted:#f8fafc;--color-bg-1:var(--gray-50);--color-bg-3:var(--gray-200);--color-bg-4:var(--gray-300);--color-white:#fff;--color-text:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-border:rgba(0,0,0,.08);--color-divider:var(--gray-200);--color-card-border:var(--color-border);--color-card-border-inner:rgba(0,0,0,.05);--color-primary-rgb:52,152,219;--color-secondary-rgb:46,204,113;--color-success-rgb:46,204,113;--color-warning-rgb:245,158,11;--color-error-rgb:239,68,68;--color-info-rgb:52,152,219;--color-positive-rgb:239,68,68;--color-negative-rgb:16,185,129;--color-green-500-rgb:34,197,94;--color-green-500:#22c55e;--color-red-500:#ef4444;--gradient-primary:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-dark));--gradient-secondary:linear-gradient(135deg,var(--brand-secondary),var(--brand-secondary-dark));--gradient-accent:linear-gradient(135deg,var(--brand-accent),var(--brand-accent-dark));--font-family-base:"Segoe UI","Helvetica Neue",Arial,sans-serif;--font-family-mono:"Berkeley Mono",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--font-size-xs:11px;--font-size-sm:12px;--font-size-base:15px;--font-size-md:16px;--font-size-lg:18px;--font-size-xl:20px;--font-size-2xl:22px;--font-size-3xl:24px;--font-size-4xl:28px;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-none:1;--line-height-tight:1.2;--line-height-normal:1.4;--line-height-relaxed:1.6;--letter-spacing-tight:-.01em;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:28px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--space-24:96px;--radius-sm:4px;--radius-base:6px;--radius-md:8px;--radius-lg:10px;--radius-xl:16px;--radius-full:9999px;--shadow-xs:0 1px 2px rgba(0,0,0,.05);--shadow-sm:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--duration-fast:.1s;--duration-normal:.2s;--transition-default:all .2s ease;--transition-fast:all .15s ease;--ease-standard:cubic-bezier(.4,0,.2,1);--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1280px;--btn-focus-shadow:0 0 0 3px rgba(52,152,219,.35);--btn-disabled-opacity:.55;--color-btn-primary-text:#fcfcf9;--focus-ring-color:rgba(52,152,219,.4);--focus-ring:0 0 0 3px var(--focus-ring-color);--modal-padding:var(--space-5);--tablist-gap:var(--space-4);--tab-padding-x:var(--space-5);--tab-padding-y:var(--space-2);--glass-border:var(--color-card-border);--select-caret-light:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23134252' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.text-muted{color:var(--color-text-secondary)}}@layer base{html{background-color:var(--color-background);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;box-sizing:border-box}body{margin:0;padding:0}*,:after,:before{box-sizing:inherit}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight);margin:0}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-md)}p{margin:0 0 var(--space-4) 0}a{color:var(--color-primary);text-decoration:none;transition:color var(--duration-fast) var(--ease-standard)}a:hover{color:var(--color-primary-hover)}code,pre{background-color:var(--color-surface-alt);border-radius:var(--radius-sm);font-family:var(--font-family-mono);font-size:calc(var(--font-size-base)*.95)}code{padding:var(--space-1) var(--space-2)}pre{border:1px solid var(--color-border);margin:var(--space-4) 0;overflow:auto;padding:var(--space-4)}pre code{background:none;padding:0}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.gap-8{gap:var(--space-8)}.gap-12{gap:var(--space-12)}.mt-8{margin-top:var(--space-8)}.mb-8{margin-bottom:var(--space-8)}.mx-auto{margin-left:auto;margin-right:auto}.text-xs{font-size:var(--font-size-xs)}.fw-600{font-weight:600}.bg-positive{background:var(--color-positive)}.bg-warning{background:var(--color-warning)}.bg-info{background:var(--color-info)}.block{display:block}.inline-block{display:inline-block}.invisible{visibility:hidden}.container{margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4);width:100%}}@layer base{@media(min-width:640px){.container{max-width:var(--container-sm)}}@media(min-width:768px){.container{max-width:var(--container-md)}}@media(min-width:1024px){.container{max-width:var(--container-lg)}}@media(min-width:1280px){.container{max-width:var(--container-xl)}}.container-fluid{margin:0 auto;max-width:100%;padding:0}.progress-slim{background:var(--color-surface-alt);border-radius:var(--radius-full);height:8px;overflow:hidden}.progress-bar{background:var(--color-primary);height:100%}.main-content{background:var(--color-background);min-height:calc(100vh - 100px);padding:var(--space-3) 5px}.dashboard-frame{display:grid;gap:var(--space-3);grid-template-columns:1fr;grid-template-rows:auto;margin:0 auto;padding:var(--space-2);width:min(1600px,100%)}.dashboard-frame>.map-panel{grid-column:1/2;grid-row:1/2}.dashboard-frame>.markets-panel{grid-column:1/2;grid-row:2/3}.dashboard-frame>.rankings-panel{grid-column:1/2;grid-row:3/4}.dashboard-frame>.news-panel{grid-column:1/2;grid-row:4/5}.dashboard-frame>.watchlist-stack{grid-column:1/2;grid-row:5/6}.dashboard-frame>#gamifyPanel{grid-column:1/2;grid-row:6/7}.dashboard-frame>.activities-panel{grid-column:1/2;grid-row:7/8}}@layer base{@media(min-width:1200px){.dashboard-frame{grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto auto auto;max-width:100%;width:100%}.dashboard-frame>.map-panel{grid-column:1/3;grid-row:1/2}.dashboard-frame>.watchlist-stack{grid-column:1/2;grid-row:2/3}.dashboard-frame>.markets-panel{grid-column:2/3;grid-row:2/3}.dashboard-frame>.rankings-panel{grid-column:1/3;grid-row:3/4}.dashboard-frame>.news-panel{grid-column:1/3;grid-row:4/5}.dashboard-frame>.activities-panel{grid-column:1/2;grid-row:5/6}.dashboard-frame>.gamify-panel{grid-column:2/3;grid-row:5/6}}@media(min-width:1100px)and (max-width:1199px){.dashboard-frame{grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto auto auto}}@media(max-width:1024px){.dashboard-frame{grid-template-columns:1fr;grid-template-rows:repeat(7,minmax(0,auto));max-width:100%}.dashboard-frame>*{grid-column:1/-1;grid-row:auto}}@media(max-width:768px){.dashboard-frame{gap:var(--space-3);padding:5px}}.panel{display:flex;flex-direction:column;gap:var(--space-3);height:100%}.panel-actions{align-items:center;display:flex;gap:var(--space-2)}.panel-actions .btn{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3)}@media(max-width:768px){.panel,.panel-header{gap:var(--space-2)}.panel-header{align-items:flex-start;flex-direction:column}.panel-actions{justify-content:flex-start;width:100%}}.feature-grid{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}#activitiesBoard,#activitiesBoard.feature-grid,.activities-panel .feature-grid{grid-template-columns:1fr 1fr}.ranking-list{display:flex;flex-direction:column;gap:var(--space-2)}}@layer base{@media(max-width:640px){.btn-auth-group--fluid{flex-direction:column;width:100%}.btn-auth-group--fluid .btn-auth{min-height:44px;width:100%}}}@layer base{.card,.panel,.trading-panel{border-radius:var(--radius-lg);margin:0;padding:var(--space-3)}.panel-header{align-items:flex-start;border-bottom:1px solid var(--color-divider);display:flex;gap:var(--space-2);justify-content:space-between;margin:0 0 var(--space-2) 0;padding:0 0 var(--space-2) 0}.panel-body{margin:0;padding:0}.panel-title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin:0}.panel-subtitle{color:#64748b;font-size:13px;font-weight:500;line-height:var(--line-height-normal);margin:var(--space-1) 0 0 0}.card,.market-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2)}.card+.card{margin-top:var(--space-2)}#majorMarkets .market-card+.market-card,#rankingsBoard .card+.card,#rankingsBoard .rankings-card+.rankings-card{margin-top:0}.feature-grid,.panel-grid,.stats-grid{display:grid;gap:var(--space-2);margin:0;padding:0}.news-feed,.ranking-list,.watchlist{display:flex;flex-direction:column;gap:var(--space-1);margin:0;padding:0}.ranking-item,.watch-item{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin:0;padding:var(--space-2)}.form-group{margin:0 0 var(--space-4) 0}.form-group:last-child{margin-bottom:0}.form-label{color:var(--color-text);display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin:0 0 var(--space-2) 0}.form-control{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3)}.btn{border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-4)}.btn-sm{font-size:var(--font-size-xs);padding:var(--space-1) var(--space-3)}.btn-lg{font-size:var(--font-size-md);padding:var(--space-3) var(--space-6)}.btn+.btn{margin-left:var(--space-2)}.modal-content{border-radius:var(--radius-lg);padding:var(--space-5)}.modal-header{border-bottom:1px solid var(--color-divider);margin:0 0 var(--space-4) 0;padding:0 0 var(--space-4) 0}.modal-body{margin:0;padding:0}.modal-footer{border-top:1px solid var(--color-divider);margin:var(--space-4) 0 0 0;padding:var(--space-4) 0 0 0}.container,.container-fluid{padding-left:5px;padding-right:5px}.main-content{padding:var(--space-3) 5px}.dashboard-frame{gap:var(--space-3);padding:0 5px}@media(max-width:768px){.card,.panel,.trading-panel{padding:var(--space-3)}.panel-header{margin:0 0 var(--space-2) 0;padding:0 0 var(--space-2) 0}.container,.container-fluid{padding-left:5px;padding-right:5px}.main-content{padding:var(--space-3) 5px}.dashboard-frame{gap:var(--space-3);padding:5px}.modal-content{padding:var(--space-4)}}@media(max-width:480px){.card,.panel,.trading-panel{border-radius:var(--radius-md);padding:var(--space-3)}.btn{padding:var(--space-2) var(--space-3)}}}@layer components{.btn--buy{--btn-bg:var(--color-positive);--btn-color:#fff;--btn-border:var(--color-positive)}.btn--sell{--btn-bg:var(--color-negative);--btn-color:#fff;--btn-border:var(--color-negative)}.btn--link{--btn-bg:transparent;--btn-color:var(--color-primary);--btn-border:transparent;--btn-shadow:none;text-decoration:underline;text-underline-offset:2px}.btn--link:hover{text-decoration-thickness:2px}.alert{align-items:flex-start;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;font-size:var(--font-size-sm);gap:var(--space-3);line-height:var(--line-height-normal);padding:var(--space-4)}.alert--success{background:rgba(var(--color-success-rgb),.1);border-color:rgba(var(--color-success-rgb),.3);color:var(--color-success)}.alert--warning{background:rgba(var(--color-warning-rgb),.1);border-color:rgba(var(--color-warning-rgb),.3);color:#92400e}.alert--danger,.alert--error{background:rgba(var(--color-error-rgb),.1);border-color:rgba(var(--color-error-rgb),.3);color:var(--color-danger)}.alert--info{background:rgba(var(--color-info-rgb),.1);border-color:rgba(var(--color-info-rgb),.3);color:var(--color-info)}.divider{align-items:center;color:var(--color-text-tertiary);display:flex;font-size:var(--font-size-sm);gap:var(--space-4);margin:var(--space-4) 0}.divider:after,.divider:before{background:var(--color-divider);content:"";flex:1;height:1px}.divider-text{white-space:nowrap}.link-primary{color:var(--color-primary);text-decoration:none;transition:var(--transition-fast)}.link-primary:hover{color:var(--color-primary-hover);text-decoration:underline}.link-secondary{color:var(--color-text-secondary);text-decoration:none;transition:var(--transition-fast)}.link-secondary:hover{color:var(--color-text)}.spinner{animation:spin .8s linear infinite;border:2px solid rgba(var(--color-primary-rgb),.2);border-radius:50%;border-top-color:var(--color-primary);display:inline-block;height:20px;width:20px}.spinner--sm{height:14px;width:14px}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--color-surface-alt) 0,var(--color-surface) 50%,var(--color-surface-alt) 100%);background-size:200% 100%;border-radius:var(--radius-sm)}.empty-state{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;justify-content:center;padding:var(--space-8);text-align:center}[data-tooltip]{position:relative}[data-tooltip]:after{background:var(--gray-800);border-radius:var(--radius-sm);bottom:100%;color:#fff;content:attr(data-tooltip);font-size:var(--font-size-xs);left:50%;opacity:0;padding:var(--space-2) var(--space-3);pointer-events:none;position:absolute;transform:translate(-50%) translateY(-4px);transition:opacity .2s,visibility .2s;visibility:hidden;white-space:nowrap;z-index:1000}[data-tooltip]:hover:after{opacity:1;visibility:visible}.progress{background:var(--color-surface-alt);height:8px;overflow:hidden}.progress,.progress__bar{border-radius:var(--radius-full)}.progress__bar{background:var(--gradient-primary);height:100%;transition:width .3s ease}.progress--sm{height:4px}.progress--lg{height:12px}.avatar{align-items:center;background:var(--gradient-primary);border-radius:50%;color:#fff;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:40px;justify-content:center;overflow:hidden;width:40px}.avatar img{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.status-dot{background:var(--color-text-tertiary);border-radius:50%;display:inline-block;height:8px;width:8px}.status-dot--success,.status-dot.active{background:var(--color-success);box-shadow:0 0 0 2px rgba(var(--color-success-rgb),.3)}.status-dot--warning{background:var(--color-warning);box-shadow:0 0 0 2px rgba(var(--color-warning-rgb),.3)}.hidden{display:none!important}.invisible{visibility:hidden}.hd-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;height:100%}.hd-panel,.hd-panel__header{display:flex;gap:var(--space-3)}.hd-panel__header{align-items:flex-start;border-bottom:1px solid var(--color-border);justify-content:space-between;padding:var(--space-3) var(--space-4)}.hd-panel__title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin:0}.hd-panel__subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:var(--space-1) 0 0}.hd-panel__eyebrow{color:var(--color-text-secondary);font-size:var(--font-size-xs);letter-spacing:.05em;margin:0 0 var(--space-1);text-transform:uppercase}.hd-panel__body{flex:1;padding:var(--space-4)}.hd-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);color:var(--color-text);display:block;font-size:var(--font-size-sm);line-height:var(--line-height-normal);padding:var(--space-2) var(--space-3);transition:border-color var(--duration-fast),box-shadow var(--duration-fast);width:100%}.hd-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.15);outline:none}.hd-input::-moz-placeholder{color:var(--color-text-tertiary)}.hd-input::placeholder{color:var(--color-text-tertiary)}.hd-form-group{display:flex;flex-direction:column;gap:var(--space-2)}.hd-form-group label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.hd-form-row{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.hd-badge{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:var(--space-1);line-height:1;padding:var(--space-1) var(--space-2)}.btn,.hd-badge{align-items:center;display:inline-flex}.btn{--btn-bg:var(--color-surface);--btn-color:var(--color-text);--btn-border:var(--color-border);--btn-shadow:var(--shadow-xs);--btn-radius:var(--radius-base);--btn-pad-y:var(--space-3);--btn-pad-x:var(--space-5);--btn-gap:var(--space-2);background:var(--btn-bg);border:1px solid var(--btn-border);border-radius:var(--btn-radius);box-shadow:var(--btn-shadow);color:var(--btn-color);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--btn-gap);isolation:isolate;justify-content:center;line-height:1.2;min-height:36px;padding:var(--btn-pad-y) var(--btn-pad-x);position:relative;text-decoration:none;transition:var(--transition-default)}.btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}}@layer components{.btn:focus-visible{box-shadow:var(--btn-focus-shadow);outline:none}.btn:active{transform:translateY(0)}.btn:disabled{box-shadow:none;cursor:not-allowed;opacity:var(--btn-disabled-opacity);transform:none}.btn--primary,.btn.btn-primary{--btn-bg:var(--color-primary);--btn-color:var(--color-btn-primary-text);--btn-border:var(--color-primary);--btn-shadow:var(--shadow-sm)}.btn--secondary,.btn.btn-secondary{--btn-bg:var(--color-secondary);--btn-color:var(--color-btn-primary-text);--btn-border:var(--color-secondary);--btn-shadow:var(--shadow-sm)}.btn--ghost,.btn.btn-ghost{--btn-bg:transparent;--btn-color:var(--color-text);--btn-border:transparent;--btn-shadow:none}.btn--ghost:hover{background:rgba(var(--color-primary-rgb),.08);border-color:rgba(var(--color-primary-rgb),.25)}.btn--outline,.btn.btn-outline{--btn-bg:transparent;--btn-color:var(--color-primary);--btn-border:var(--color-border);--btn-shadow:none}.btn--outline:hover{--btn-border:var(--color-primary);background:rgba(var(--color-primary-rgb),.08)}.btn--gradient-primary{--btn-bg:var(--gradient-primary);--btn-color:var(--color-btn-primary-text);--btn-border:transparent;--btn-shadow:var(--shadow-md)}.btn--gradient-secondary{--btn-bg:var(--gradient-secondary);--btn-color:var(--color-btn-primary-text);--btn-border:transparent;--btn-shadow:var(--shadow-md)}.btn--gradient-accent{--btn-bg:var(--gradient-accent);--btn-color:var(--color-btn-primary-text);--btn-border:transparent;--btn-shadow:var(--shadow-md)}.btn--glass{backdrop-filter:blur(12px);--btn-bg:hsla(0,0%,100%,.18);--btn-color:var(--color-text);--btn-border:hsla(0,0%,100%,.35)}.btn--danger{--btn-bg:var(--color-danger);--btn-color:#fff;--btn-border:var(--color-danger)}.btn--support{--btn-bg:var(--color-primary);--btn-color:var(--color-btn-primary-text);--btn-border:var(--color-primary)}.btn--withdraw{--btn-bg:var(--color-secondary);--btn-color:var(--color-btn-primary-text);--btn-border:var(--color-secondary)}.btn--sm{--btn-pad-y:var(--space-2);--btn-pad-x:var(--space-4);border-radius:var(--radius-sm);font-size:var(--font-size-xs);min-height:30px}.btn--lg{--btn-pad-y:var(--space-4);--btn-pad-x:var(--space-6);border-radius:var(--radius-lg);font-size:var(--font-size-md);min-height:44px}.btn--xl{--btn-pad-y:var(--space-5);--btn-pad-x:var(--space-7);border-radius:var(--radius-xl);font-size:var(--font-size-lg);min-height:52px}.btn--pill{border-radius:var(--radius-full)}.btn--full,.btn--full-width{width:100%}.btn--icon{--btn-pad-x:var(--space-3);min-height:40px;min-width:40px}.btn .btn-icon{align-items:center;display:inline-flex;gap:var(--space-1);justify-content:center}.btn .btn-icon+span,.btn span+.btn-icon{margin-inline-start:var(--space-1)}.btn.is-loading{color:transparent;pointer-events:none}.btn.is-loading>*{opacity:0}.btn.is-loading:after{animation:btn-spin .8s linear infinite;border:2px solid hsla(0,0%,100%,.35);border-radius:999px;border-top:2px solid var(--btn-spinner-color);content:"";height:1rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:1rem}@keyframes btn-spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4);position:relative}.form-group>label,.form-label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-1)}.form-group>label .required,.form-label .required,.required{color:var(--color-danger);font-weight:var(--font-weight-semibold);margin-left:var(--space-1)}.form-control{background:var(--color-surface);background-clip:padding-box;border:1px solid var(--color-border);border-radius:var(--radius-base);box-sizing:border-box;caret-color:var(--color-primary);color:var(--color-text);font-size:var(--font-size-base);line-height:1.4;min-height:40px;padding:var(--space-3) var(--space-5);transition:var(--transition-default);width:100%}.form-control:focus,.form-control:focus-visible{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.2);outline:none}.form-control:disabled{background:var(--color-surface-alt);cursor:not-allowed;opacity:.7}.form-control::-moz-placeholder{color:var(--color-text-secondary);opacity:.8}.form-control::placeholder{color:var(--color-text-secondary);opacity:.8}textarea.form-control{min-height:120px;resize:vertical}select.form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:var(--select-caret-light);background-position:right var(--space-4) center;background-repeat:no-repeat;background-size:16px;padding-right:var(--space-8)}.form-control.is-valid,.form-control.valid,.form-control[data-state=valid]{border-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(var(--color-secondary-rgb),.2)}.form-control.invalid,.form-control.is-invalid,.form-control[data-state=invalid]{border-color:var(--color-danger);box-shadow:0 0 0 3px rgba(var(--color-positive-rgb),.2)}.helper-text{color:var(--color-text-secondary)}.helper-text,.invalid-feedback,.valid-feedback{font-size:var(--font-size-sm);line-height:1.4;margin-top:var(--space-2)}.invalid-feedback{color:var(--color-danger)}.valid-feedback{color:var(--color-secondary)}.card,.market-card,.panel,.rankings-card,.watchlist-card{--atlas-card-bg:var(--color-surface);--atlas-card-border:var(--color-card-border);--atlas-card-shadow:var(--shadow-sm);--atlas-card-radius:var(--radius-lg);--atlas-card-accent-height:0px;--atlas-card-accent-color:transparent}:where(.card,.panel,.market-card,.rankings-card,.watchlist-card){background:var(--atlas-card-bg);border:1px solid var(--atlas-card-border);border-radius:var(--atlas-card-radius);box-shadow:var(--atlas-card-shadow);overflow:hidden;position:relative;transition:var(--transition-default)}:where(.card,.panel,.market-card,.rankings-card,.watchlist-card):before{background:var(--atlas-card-accent-color);content:"";height:var(--atlas-card-accent-height);left:0;opacity:1;pointer-events:none;position:absolute;right:0;top:0}.card{--atlas-card-radius:var(--radius-md);--atlas-card-accent-height:3px;--atlas-card-accent-color:var(--gradient-primary)}.panel{--atlas-card-radius:var(--radius-md)}.market-card{--atlas-card-border:rgba(var(--color-primary-rgb),.15);--atlas-card-shadow:var(--shadow-md)}.watchlist-card{--atlas-card-border:rgba(var(--color-secondary-rgb),.2);--atlas-card-shadow:var(--shadow-md)}.rankings-card{--atlas-card-border:rgba(155,89,182,.3);--atlas-card-accent-height:3px;--atlas-card-accent-color:var(--gradient-accent)}.badge,.meta-chip{align-items:center;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:var(--space-1);letter-spacing:.08em;padding:var(--space-1) var(--space-3);text-transform:uppercase}.badge--primary{background:rgba(var(--color-primary-rgb),.12);border-color:rgba(var(--color-primary-rgb),.3);color:var(--color-primary)}.badge--success{background:rgba(var(--color-secondary-rgb),.12);border-color:rgba(var(--color-secondary-rgb),.3);color:var(--color-secondary)}.chip{align-items:center;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);display:inline-flex;font-size:var(--font-size-sm);gap:var(--space-1);padding:var(--space-2) var(--space-4)}.chip.active,.chip.is-active{background:rgba(var(--color-primary-rgb),.08);border-color:var(--color-primary);color:var(--color-primary)}.chart-tab,.info-tab,.tab{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);justify-content:center;padding:var(--tab-padding-y) var(--tab-padding-x);transition:var(--transition-default)}.chart-tab:hover,.info-tab:hover,.tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.chart-tab.active,.info-tab.active,.tab.active,.tab.is-active{background:var(--color-primary);border-color:var(--color-primary);box-shadow:var(--shadow-sm);color:var(--color-btn-primary-text)}.modal-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-4)}.modal-actions .btn{justify-content:center;min-width:120px}@media(max-width:768px){.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}@keyframes value-flash{0%{background-color:transparent}25%{background-color:var(--color-primary-alpha,rgba(52,152,219,.3))}to{background-color:transparent}}.value-updated{border-radius:var(--radius-sm,4px)}.market-card__change.value-updated,.market-card__value.value-updated,.ranking-item__change.value-updated,.ranking-item__value.value-updated,.ticker-change.value-updated,.ticker-price.value-updated,.value-updated{animation:value-flash 1s ease-out}#mainMap.echarts-map{height:62vh;min-height:420px;touch-action:manipulation;width:100%}}@layer components{@media(pointer:coarse){#mainMap.echarts-map{touch-action:none}}.map-content{align-items:stretch;display:grid;grid-template-areas:"map";height:auto;isolation:isolate;position:relative}.map-content>#mainMap,.map-content>.map-init-overlay,.map-content>.map-loading-overlay{grid-area:map}@media(max-width:768px){#mainMap.echarts-map{height:56vh;min-height:360px}}.map-loading-overlay{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:rgba(255,255,255,.65);display:grid;height:100%;top:0;right:0;bottom:0;left:0;opacity:1;place-items:center;pointer-events:none;position:absolute;transition:opacity .3s ease-out;width:100%;z-index:1200}.map-loading-overlay.hidden{opacity:0;pointer-events:none}.map-init-overlay{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:linear-gradient(135deg,rgba(248,250,252,.95),rgba(241,245,249,.95));display:flex;height:100%;top:0;right:0;bottom:0;left:0;justify-content:center;pointer-events:none;position:absolute;transition:opacity .4s ease-out,visibility .4s ease-out;width:100%;z-index:10}.map-init-overlay.hidden{opacity:0;pointer-events:none;visibility:hidden}.map-init-content{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:0 8px 32px rgba(0,0,0,.12),0 0 0 1px var(--color-border);color:var(--color-text);max-width:320px;padding:32px 40px;text-align:center}.map-init-spinner{animation:map-spin .9s cubic-bezier(.4,0,.2,1) infinite;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:44px;margin:0 auto 16px;width:44px}.map-init-title{color:var(--color-text);font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0 0 8px}.map-init-subtitle{color:var(--color-text-secondary);font-size:12px;line-height:1.5;margin:0}.map-loading-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:24px 36px;text-align:center}.map-loading-spinner{animation:map-spin .8s linear infinite;border:3px solid var(--color-bg-1);border-radius:50%;border-top-color:var(--color-primary);height:40px;margin:0 auto 16px;width:40px}.map-loading-text{color:var(--color-text-secondary);font-size:14px;font-weight:500;margin:0}@keyframes map-spin{to{transform:rotate(1turn)}}}@layer components{:root{--map3d-bg-light:var(--gray-50,#f8f9fa);--map3d-bg-surface:var(--color-surface,#fff);--map3d-accent-primary:var(--brand-primary,#3498db);--map3d-accent-secondary:var(--brand-secondary,#2ecc71);--map3d-text-primary:var(--color-text,#111827);--map3d-text-secondary:var(--color-text-secondary,#6b7280);--map3d-text-muted:var(--color-text-tertiary,#9ca3af);--map3d-border-color:var(--color-border,rgba(0,0,0,.08));--map3d-glass-bg:hsla(0,0%,100%,.92);--map3d-glass-border:rgba(0,0,0,.08)}.china-map-3d-container{background:radial-gradient(ellipse 120% 100% at 50% 120%,rgba(52,152,219,.08) 0,transparent 50%),radial-gradient(ellipse 80% 60% at 50% -10%,rgba(52,152,219,.05) 0,transparent 45%),radial-gradient(circle at 20% 80%,rgba(52,152,219,.03) 0,transparent 30%),radial-gradient(circle at 80% 20%,rgba(155,89,182,.02) 0,transparent 30%),linear-gradient(180deg,var(--map3d-bg-light) 0,var(--map3d-bg-surface) 100%);border-radius:20px;box-shadow:0 4px 24px rgba(0,0,0,.08),0 0 0 1px var(--map3d-border-color),inset 0 1px rgba(255,255,255,.8);height:clamp(600px,75vh,950px);min-height:600px;overflow:hidden;position:relative;width:100%}.china-map-3d-container:before{background-image:linear-gradient(rgba(52,152,219,.04) 1px,transparent 0),linear-gradient(90deg,rgba(52,152,219,.04) 1px,transparent 0),linear-gradient(rgba(52,152,219,.02) 1px,transparent 0),linear-gradient(90deg,rgba(52,152,219,.02) 1px,transparent 0);background-size:80px 80px,80px 80px,20px 20px,20px 20px;content:"";top:0;right:0;bottom:0;left:0;mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,#000 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,#000 30%,transparent 70%);pointer-events:none;position:absolute;z-index:0}.china-map-3d-container:after{background:radial-gradient(ellipse 50% 30% at 50% 100%,rgba(52,152,219,.06) 0,transparent 70%);bottom:-50%;content:"";height:100%;left:50%;pointer-events:none;position:absolute;transform:translate(-50%);width:120%;z-index:0}.china-map-3d-main{top:0;right:0;bottom:0;left:0;position:absolute;z-index:1}.map-3d-glass{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-glass-border)}.map-3d-controls-left{display:flex;flex-direction:column;gap:10px;left:20px;position:absolute;top:24px;z-index:100}.map-3d-layer-toggle{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-glass-border);border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;display:flex;gap:12px;padding:10px 16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.map-3d-layer-toggle:hover{background:rgba(52,152,219,.08);border-color:var(--map3d-accent-primary);box-shadow:0 4px 12px rgba(52,152,219,.15);transform:translate(4px)}.map-3d-layer-toggle.active{background:rgba(52,152,219,.1);border-color:var(--map3d-accent-primary);box-shadow:0 4px 12px rgba(52,152,219,.2)}@keyframes pulse-ring{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}.map-3d-controls-right{display:flex;flex-direction:column;gap:8px;position:absolute;right:20px;top:24px;z-index:100}.map-3d-view-btn{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-glass-border);border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.08);color:var(--map3d-text-secondary);cursor:pointer;display:flex;font-size:12px;font-weight:600;height:36px;justify-content:center;letter-spacing:.5px;transition:all .25s cubic-bezier(.4,0,.2,1);width:60px}.map-3d-view-btn:hover{background:rgba(52,152,219,.08);border-color:var(--map3d-accent-primary);box-shadow:0 4px 12px rgba(52,152,219,.15);color:var(--map3d-text-primary);transform:translate(-4px)}.map-3d-view-btn:active{transform:translate(-4px) scale(.96)}.map-3d-back-btn{align-items:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-accent-primary);border-radius:24px;bottom:90px;box-shadow:0 4px 16px rgba(52,152,219,.2);color:var(--map3d-accent-primary);cursor:pointer;display:none;font-size:13px;font-weight:600;gap:10px;left:50%;letter-spacing:.5px;padding:12px 24px;position:absolute;transform:translate(-50%);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:100}.map-3d-back-btn:hover{background:var(--map3d-accent-primary);border-color:var(--map3d-accent-primary);box-shadow:0 6px 20px rgba(52,152,219,.3);color:#fff;transform:translate(-50%) translateY(-3px)}.map-3d-back-btn .back-icon{font-size:18px;transition:transform .25s ease}.map-3d-back-btn:hover .back-icon{transform:translate(-4px)}.map-3d-title{bottom:20px;left:50%;pointer-events:none;position:absolute;text-align:center;transform:translate(-50%);z-index:50}.map-3d-title-main{color:var(--map3d-text-primary);font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:24px;font-weight:700;letter-spacing:8px;position:relative;text-shadow:0 2px 8px hsla(0,0%,100%,.8)}.map-3d-title-main:after{background:linear-gradient(90deg,transparent 0,var(--map3d-accent-primary) 50%,transparent 100%);bottom:-6px;content:"";height:2px;left:50%;opacity:.5;position:absolute;transform:translate(-50%);width:50%}.map-3d-title-sub{color:var(--map3d-text-muted);font-size:10px;font-weight:500;letter-spacing:6px;margin-top:10px;text-transform:uppercase}.map-3d-breadcrumb{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-glass-border);border-radius:24px;box-shadow:0 2px 8px rgba(0,0,0,.08);display:flex;gap:10px;left:50%;padding:10px 20px;position:absolute;top:24px;transform:translate(-50%);z-index:100}.map-3d-breadcrumb-item{border-radius:6px;color:var(--map3d-text-secondary);cursor:pointer;font-size:13px;padding:4px 8px;transition:all .2s ease}.map-3d-breadcrumb-item:hover{background:rgba(52,152,219,.1);color:var(--map3d-accent-primary)}.map-3d-breadcrumb-item.active{color:var(--map3d-text-primary);font-weight:600}.map-3d-breadcrumb-separator{color:var(--map3d-text-muted);font-size:12px}.map-3d-loading{align-items:center;background:linear-gradient(180deg,var(--map3d-bg-light) 0,var(--map3d-bg-surface) 100%);display:flex;flex-direction:column;top:0;right:0;bottom:0;left:0;justify-content:center;position:absolute;transition:opacity .4s ease;z-index:200}.map-3d-loading-spinner{animation:spin .8s linear infinite;border:2px solid rgba(52,152,219,.1);border-radius:50%;border-top:2px solid var(--map3d-accent-primary);height:56px;position:relative;width:56px}.map-3d-loading-spinner:before{animation:spin 1.2s linear infinite reverse;border:2px solid rgba(46,204,113,.1);border-bottom:2px solid var(--map3d-accent-secondary);border-radius:50%;content:"";top:6px;right:6px;bottom:6px;left:6px;position:absolute}.map-3d-loading-text{color:var(--map3d-text-secondary);font-size:14px;font-weight:500;letter-spacing:2px;margin-top:20px}.china-map-3d-container .corner-decoration{height:40px;pointer-events:none;position:absolute;width:40px;z-index:10}.china-map-3d-container .corner-decoration:after,.china-map-3d-container .corner-decoration:before{background:linear-gradient(90deg,var(--map3d-accent-primary),transparent);content:"";opacity:.3;position:absolute}.china-map-3d-container .corner-decoration.top-left{left:0;top:0}.china-map-3d-container .corner-decoration.top-left:before{height:2px;left:0;top:0;width:40px}.china-map-3d-container .corner-decoration.top-left:after{background:linear-gradient(180deg,var(--map3d-accent-primary),transparent);height:40px;left:0;top:0;width:2px}.china-map-3d-container .corner-decoration.top-right{right:0;top:0}.china-map-3d-container .corner-decoration.top-right:before{background:linear-gradient(270deg,var(--map3d-accent-primary),transparent);height:2px;right:0;top:0;width:40px}.china-map-3d-container .corner-decoration.top-right:after{background:linear-gradient(180deg,var(--map3d-accent-primary),transparent);height:40px;right:0;top:0;width:2px}.china-map-3d-container .corner-decoration.bottom-left{bottom:0;left:0}.china-map-3d-container .corner-decoration.bottom-left:before{bottom:0;height:2px;left:0;width:40px}.china-map-3d-container .corner-decoration.bottom-left:after{background:linear-gradient(0deg,var(--map3d-accent-primary),transparent);bottom:0;height:40px;left:0;width:2px}.china-map-3d-container .corner-decoration.bottom-right{bottom:0;right:0}.china-map-3d-container .corner-decoration.bottom-right:before{background:linear-gradient(270deg,var(--map3d-accent-primary),transparent);bottom:0;height:2px;right:0;width:40px}.china-map-3d-container .corner-decoration.bottom-right:after{background:linear-gradient(0deg,var(--map3d-accent-primary),transparent);bottom:0;height:40px;right:0;width:2px}.map-3d-status{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-glass-border);border-radius:20px;color:var(--map3d-text-secondary);display:flex;font-size:12px;gap:8px;left:50%;padding:8px 16px;position:absolute;top:24px;transform:translate(-50%);z-index:90}.map-3d-status-dot{animation:status-pulse 2s ease-in-out infinite;background:var(--map3d-accent-secondary);border-radius:50%;height:8px;width:8px}@keyframes status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.map-3d-info-card{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-glass-border);border-radius:16px;bottom:24px;box-shadow:0 2px 12px rgba(0,0,0,.08);left:20px;min-width:180px;padding:16px 20px;position:absolute;z-index:100}.map-3d-info-card-title{color:var(--map3d-text-muted);font-size:11px;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.map-3d-info-card-value{color:var(--map3d-text-primary);font-size:24px;font-weight:700;line-height:1}.map-3d-info-card-sub{color:var(--map3d-accent-secondary);font-size:12px;margin-top:6px}.map-3d-legend{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:var(--map3d-glass-bg);border:1px solid var(--map3d-glass-border);border-radius:14px;bottom:24px;box-shadow:0 2px 12px rgba(0,0,0,.08);padding:14px 18px;position:absolute;right:20px;z-index:100}.map-3d-legend-title{color:var(--map3d-text-muted);font-size:11px;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}.map-3d-legend-items{display:flex;flex-direction:column;gap:8px}.map-3d-legend-item{align-items:center;color:var(--map3d-text-secondary);display:flex;font-size:12px;gap:10px}.map-3d-legend-color{border-radius:4px;flex-shrink:0;height:14px;width:14px}.map-3d-legend-color.active{background:linear-gradient(135deg,#3498db,#2980b9);border:1px solid var(--map3d-accent-primary)}.map-3d-legend-color.inactive{background:rgba(155,161,166,.6);border:1px solid hsla(213,7%,76%,.5)}.map-3d-legend-color.highlight{background:linear-gradient(135deg,#5dade2,#3498db);border:1px solid #fff}.map3d-tooltip{display:flex;flex-direction:column;gap:6px;min-width:140px}.map3d-tooltip--active{min-width:150px}.map3d-tooltip--scatter{min-width:100px}.map3d-tooltip__title{font-size:16px;font-weight:600}.map3d-tooltip__title--inactive{color:#5f6368}.map3d-tooltip__title--active{align-items:center;color:#3498db;display:flex;gap:8px}.map3d-tooltip__title--scatter{color:#27ae60;font-size:14px}.map3d-tooltip__status-row{align-items:center;color:#6b7280;display:flex;font-size:12px;gap:6px}.map3d-tooltip__status-dot{border-radius:50%;display:inline-block;height:8px;width:8px}.map3d-tooltip__status-dot--inactive{background:linear-gradient(135deg,#9aa0a6,#80868b);border:1px solid #bdc1c6}.map3d-tooltip__status-dot--active{background:var(--map3d-accent-secondary);box-shadow:0 0 6px var(--map3d-accent-secondary)}.map3d-tooltip__badge{background:linear-gradient(135deg,rgba(46,204,113,.2),rgba(39,174,96,.15));border-radius:3px;color:#27ae60;display:inline-block;font-size:10px;padding:2px 6px}.map3d-tooltip__hint{color:#6b7280;font-size:11px;margin-top:2px}.map3d-tooltip__subtle{border-top:1px solid rgba(0,0,0,.08);color:#9aa0a6;font-size:11px;margin-top:2px;padding-top:6px}.map3d-tooltip__metric{color:#6b7280;font-size:12px;margin-top:2px}@media(max-width:1200px){.china-map-3d-container{height:clamp(550px,70vh,850px);min-height:550px}.map-3d-title-main{font-size:22px;letter-spacing:7px}}@media(max-width:1024px){.china-map-3d-container{border-radius:16px;height:clamp(500px,65vh,750px);min-height:500px}.map-3d-title-main{font-size:20px;letter-spacing:6px}.map-3d-info-card,.map-3d-legend{display:none}}@media(max-width:768px){.china-map-3d-container{border-radius:14px;height:clamp(450px,60vh,650px);min-height:450px}.map-3d-controls-left{left:12px;top:14px}.map-3d-layer-toggle{border-radius:10px;gap:10px;padding:8px 12px}.map-3d-controls-right{gap:6px;right:12px;top:14px}.map-3d-view-btn{border-radius:8px;font-size:11px;height:32px;width:52px}.map-3d-title{bottom:16px}.map-3d-title-main{font-size:18px;letter-spacing:5px}.map-3d-title-main:after{display:none}.map-3d-title-sub{font-size:9px;letter-spacing:4px;margin-top:8px}.map-3d-back-btn{border-radius:20px;bottom:70px;font-size:12px;padding:10px 20px}.corner-decoration{display:none}}@media(max-width:576px){.china-map-3d-container{border-radius:12px;height:clamp(400px,55vh,550px);min-height:400px}.map-3d-controls-left{left:10px;top:10px}.map-3d-layer-toggle{gap:8px;padding:6px 10px}.map-3d-controls-right{right:10px;top:10px}.map-3d-view-btn{font-size:10px;height:28px;width:46px}.map-3d-title{bottom:14px}.map-3d-title-main{font-size:16px;letter-spacing:4px}.map-3d-title-sub{font-size:8px;letter-spacing:3px}.map-3d-back-btn{bottom:60px;font-size:11px;padding:8px 16px}}@media(prefers-reduced-motion:reduce){.map-3d-back-btn,.map-3d-layer-toggle,.map-3d-loading-spinner,.map-3d-loading-spinner:before,.map-3d-status-dot,.map-3d-view-btn{animation:none;transition:none}}@media(prefers-color-scheme:dark){.china-map-3d-container{box-shadow:0 4px 24px rgba(0,0,0,.15),0 0 0 1px var(--map3d-border-color)}}@media(prefers-contrast:high){.map-3d-back-btn,.map-3d-layer-toggle,.map-3d-view-btn{border-width:2px}.map-3d-title-main{text-shadow:0 2px 4px rgba(0,0,0,.8)}}}@layer components{.map-toolbar{align-items:center;backdrop-filter:saturate(1.2) blur(2px);background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-md,10px);bottom:12px;box-shadow:var(--shadow-sm,0 4px 10px rgba(0,0,0,.08));display:inline-flex;gap:8px;left:50%;padding:6px 8px;position:absolute;transform:translate(-50%);z-index:1000}.map-toolbar button{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-sm,6px);color:var(--color-text);font-size:14px;min-height:36px;min-width:44px;padding:6px 10px}.map-toolbar button:hover{box-shadow:0 6px 12px rgba(15,23,42,.12);transform:translateY(-1px)}.map-toolbar button:active{box-shadow:0 2px 6px rgba(15,23,42,.12);transform:translateY(0)}.map-toolbar button:focus-visible{box-shadow:var(--focus-ring);outline:none}@media(max-width:768px){.map-toolbar{bottom:8px}.atlas-overlay{left:8px;top:8px}}}@layer components{.atlas-overlay{align-items:center;backdrop-filter:saturate(1.2) blur(2px);background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-md,10px);box-shadow:var(--shadow-sm,0 4px 10px rgba(0,0,0,.08));display:flex;gap:10px;left:12px;padding:8px 10px;position:absolute;top:12px;z-index:1000}.atlas-breadcrumb{align-items:center;display:inline-flex;font-size:12px;gap:8px}.atlas-breadcrumb,.atlas-breadcrumb .breadcrumb-item{color:var(--color-text)}.atlas-breadcrumb .breadcrumb-item.active{font-weight:600}.atlas-breadcrumb .separator{color:var(--color-text-secondary);opacity:.8}.atlas-overlay .breadcrumb-item:focus-visible,.atlas-overlay button:focus-visible{border-radius:6px;outline:2px solid var(--focus-ring);outline-offset:2px}}@layer components{.skeleton{background:var(--color-surface-muted);border-radius:var(--radius-sm);overflow:hidden;position:relative}.skeleton:after{animation:skeleton-shimmer 1.2s infinite;background:linear-gradient(90deg,transparent,rgba(var(--color-primary-rgb),.22),transparent);content:"";top:0;right:0;bottom:0;left:0;position:absolute;transform:translate(-100%)}@keyframes skeleton-shimmer{to{transform:translate(100%)}}@media(prefers-reduced-motion:reduce){.skeleton:after{animation:none}}.skeleton-line{border-radius:999px;height:12px;margin:8px 0;opacity:.6}.empty-state,.skeleton-line{background:var(--color-surface)}.empty-state{border:1px dashed var(--color-card-border);border-radius:var(--radius-md);color:var(--color-text-secondary);padding:20px}.empty-state .title{color:var(--color-text);font-size:var(--font-size-lg);margin-bottom:8px}.toast-container{bottom:16px;display:flex;flex-direction:column;gap:10px;position:fixed;right:16px;z-index:9999}.toast{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:var(--color-text);max-width:380px;min-width:220px;padding:12px 14px}.toast--success{border-color:rgba(16,185,129,.35)}.toast--error{border-color:rgba(239,68,68,.35)}.toast--info{border-color:rgba(59,130,246,.35)}.connection-status{align-items:center;border-radius:12px;cursor:default;display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:4px 10px;transition:all .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.connection-status__icon{font-size:10px;line-height:1}.connection-status__label{white-space:nowrap}.connection-status__channels{cursor:help;font-size:11px;opacity:.8}.status--connected{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3);color:#22c55e}.status--connected .connection-status__icon{color:#22c55e;text-shadow:0 0 4px rgba(34,197,94,.5)}.status--connecting{background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);color:#3b82f6}.status--connecting .connection-status__icon{animation:pulse-connecting 1.5s ease-in-out infinite;color:#3b82f6}}@layer components{@keyframes pulse-connecting{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.status--disconnected{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:#ef4444}.status--disconnected .connection-status__icon{color:#ef4444}.status--degraded{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);color:#f59e0b}.status--degraded .connection-status__icon{animation:pulse-degraded 2s ease-in-out infinite;color:#f59e0b}@keyframes pulse-degraded{0%,to{opacity:1}50%{opacity:.6}}@media(max-width:768px){.connection-status{font-size:11px;padding:3px 8px}.connection-status__channels,.connection-status__label{display:none}}}@layer components{.card{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-md);border-top:3px solid var(--color-primary);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--duration-normal) var(--ease-standard)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card.stock-card{border-top:3px solid var(--color-green-500)}.market-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;box-shadow:0 4px 12px rgba(0,0,0,.04);box-sizing:border-box;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:0;position:relative;transition:all .25s ease}#majorMarkets{display:grid;gap:var(--space-3);grid-template-columns:repeat(3,1fr)}#majorMarkets .market-card{height:100%}.market-card:before{background:linear-gradient(90deg,#3b82f6,#60a5fa);content:"";height:3px;left:0;position:absolute;right:0;top:0}.market-card:hover{border-color:rgba(59,130,246,.3);box-shadow:0 12px 24px rgba(59,130,246,.15);transform:translateY(-4px)}.market-card__header{background:linear-gradient(135deg,rgba(59,130,246,.06),rgba(37,99,235,.02));border-bottom:1px solid rgba(59,130,246,.08);padding:12px 16px}.market-card__body{display:flex;flex:1;flex-direction:column;gap:8px;padding:14px 16px}.market-card__title{color:var(--color-text);font-size:14px;font-weight:600;letter-spacing:.01em;line-height:1.3;margin:0}.market-card__value{color:var(--color-text);font-family:var(--font-family-mono);font-size:26px;font-variant-numeric:tabular-nums;font-weight:800;line-height:1.2;margin:0}.market-card__change{align-items:center;border-radius:20px;display:inline-flex;font-size:13px;font-variant-numeric:tabular-nums;font-weight:700;line-height:1;padding:5px 12px;width:-moz-fit-content;width:fit-content}.market-card__change.positive{background:linear-gradient(135deg,rgba(239,68,68,.12),rgba(220,38,38,.08));color:#dc2626}.market-card__change.negative{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(5,150,105,.08));color:#059669}.market-card__meta{border-top:1px solid var(--color-border);color:var(--color-text-tertiary);display:flex;flex-direction:column;font-size:12px;font-variant-numeric:tabular-nums;gap:2px;line-height:1.4;margin-top:auto;padding-top:8px}.market-card__meta-item{align-items:center;display:flex;justify-content:space-between}.market-card__meta-label{color:var(--color-text-tertiary)}.market-card__meta-value{color:var(--color-text-secondary);font-weight:600}#rankingsBoard{align-items:stretch;display:grid;flex:1;gap:var(--space-3);grid-template-columns:repeat(3,minmax(0,1fr))}.ranking-list{display:flex;flex-direction:column;gap:0;padding:0}.ranking-item{align-items:center;background:var(--color-surface);border:none;border-bottom:1px solid var(--color-border);border-radius:0;cursor:pointer;display:grid;font-size:13px;gap:var(--space-3);grid-template-columns:1fr auto auto;padding:12px 16px;text-align:left;transition:background .2s ease}.ranking-item:last-child{border-bottom:none}.ranking-item:hover{background:linear-gradient(135deg,rgba(59,130,246,.04),rgba(37,99,235,.02))}.ranking-item__name{color:var(--color-text);display:flex;flex-direction:column;font-weight:500;gap:2px;line-height:1.4;max-width:100%;overflow:visible;overflow-wrap:anywhere;text-overflow:unset;white-space:normal;word-break:break-word}.ranking-item__name .adcode{color:var(--color-text-tertiary);font-size:11px;font-weight:400}.ranking-item__value{color:var(--color-text);font-size:14px;font-variant-numeric:tabular-nums}.ranking-item__change,.ranking-item__value{font-family:var(--font-family-mono);font-weight:700;text-align:right}.ranking-item__change{border-radius:20px;font-size:12px;font-variant-numeric:tabular-nums;min-width:70px;padding:4px 10px;text-align:center}.ranking-item__change.positive{background:linear-gradient(135deg,rgba(239,68,68,.12),rgba(220,38,38,.08));color:#dc2626}.ranking-item__change.negative{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(5,150,105,.08));color:#059669}}@layer components{@media(max-width:768px){.ranking-item__name{line-height:1.2;overflow:hidden;overflow-wrap:anywhere;text-overflow:ellipsis;word-break:break-word}}@media(max-width:1024px){#rankingsBoard{grid-template-columns:1fr}}}@layer components{.news-feed{display:flex;flex:1;flex-direction:column;gap:var(--space-3);overflow-y:auto;padding-right:var(--space-1)}.watchlist-stack.panel.trading-panel{display:flex;flex-direction:column;padding:var(--space-3)}.watchlist-stack .panel-header{flex-shrink:0;margin-bottom:0;padding-bottom:var(--space-2)}.watchlist-stack .panel-body{display:flex;flex:1;flex-direction:column;margin:0;padding:0}.watchlist{align-items:stretch;display:grid;flex:1;gap:var(--space-3);grid-template-columns:1fr 1fr;min-height:0;overflow-y:auto}.watchlist-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 4px 12px rgba(0,0,0,.04);display:flex;flex-direction:column;min-height:0;overflow:hidden}.watchlist-card__header{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(37,99,235,.04));border-bottom:3px solid var(--color-primary);flex-shrink:0;padding:16px 20px}.watchlist-card__title{align-items:center;color:var(--color-text);display:flex;font-size:16px;font-weight:700;gap:8px;margin:0}.watchlist-card__title:before{content:"⭐";font-size:14px}.watchlist-card--recommend .watchlist-card__header{background:linear-gradient(135deg,rgba(245,158,11,.08),rgba(217,119,6,.04));border-bottom-color:#f59e0b}.watchlist-card--recommend .watchlist-card__title:before{content:"🔥"}.watchlist-card__body{flex:1;min-height:0;overflow-y:auto;padding:0}.watch-item{align-items:center;background:linear-gradient(145deg,#fff,#fafbfc);border:1px solid rgba(59,130,246,.1);border-radius:14px;display:grid;font-size:var(--font-size-sm);gap:var(--space-3);grid-template-columns:1fr auto auto;margin-bottom:10px;overflow:hidden;padding:16px 20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.watch-item:before{background:linear-gradient(180deg,#3b82f6,#60a5fa);bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:4px}.watch-item:last-child{margin-bottom:0}.watch-item--with-actions{grid-template-columns:1fr auto auto auto}.watch-item:hover{background:linear-gradient(145deg,#fff,#f0f7ff);border-color:rgba(59,130,246,.25);box-shadow:0 4px 16px rgba(59,130,246,.1);transform:translate(4px)}.watch-item:hover:before{opacity:1}.watch-item-info{display:flex;flex-direction:column;gap:6px}.watch-name{color:#1e293b;font-size:16px;font-weight:700;letter-spacing:-.01em}.watch-item-meta{background:rgba(59,130,246,.06);border-radius:6px;color:#64748b;display:inline-block;font-size:12px;font-variant-numeric:tabular-nums;letter-spacing:.02em;padding:2px 8px;width:-moz-fit-content;width:fit-content}.watch-price{color:#1e293b;font-family:var(--font-family-mono);font-size:16px;font-variant-numeric:tabular-nums;font-weight:700}.watch-change{border-radius:10px;font-size:13px;font-variant-numeric:tabular-nums;font-weight:700;min-width:70px;padding:6px 12px;text-align:center}.watch-change.positive{background:linear-gradient(135deg,rgba(239,68,68,.12),rgba(220,38,38,.08));border:1px solid rgba(239,68,68,.2);color:#dc2626}.watch-change.negative{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(5,150,105,.08));border:1px solid rgba(16,185,129,.2);color:#059669}.watch-item-actions{display:flex;justify-content:flex-end}.watch-remove{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-secondary);cursor:pointer;font-size:13px;font-weight:500;padding:6px 14px;transition:all .2s ease;white-space:nowrap}.watch-remove:hover{background:rgba(239,68,68,.05);border-color:#dc2626;color:#dc2626}.watchlist-empty{align-items:center;background:transparent;border:none;color:var(--color-text-tertiary);display:flex;flex-direction:column;gap:var(--space-2);justify-content:center;padding:var(--space-4);text-align:center}.watchlist-empty:before{display:none}.watchlist-empty p{font-size:13px;line-height:1.5;margin:0;max-width:240px}.watchlist-stack .btn--primary,.watchlist-stack .panel-header .btn--primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;box-shadow:0 4px 12px rgba(59,130,246,.35);color:#fff;font-size:14px;font-weight:700;padding:10px 24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.watchlist-stack .btn--primary:hover,.watchlist-stack .panel-header .btn--primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 24px rgba(59,130,246,.45);transform:translateY(-2px)}.watchlist-stack .btn--outline,.watchlist-stack .panel-header .btn--outline{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;box-shadow:0 4px 12px rgba(16,185,129,.35);color:#fff;font-size:14px;font-weight:700;padding:10px 24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.watchlist-stack .btn--outline:hover,.watchlist-stack .panel-header .btn--outline:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 8px 24px rgba(16,185,129,.45);color:#fff;transform:translateY(-2px)}}@layer components{@media(max-width:768px){.watchlist{grid-template-columns:1fr}}}@layer components;@layer components;@layer components{.gamify-guest{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:24px 16px;text-align:center}.gamify-guest__icon{font-size:48px;line-height:1}.gamify-guest__text{color:var(--color-text-secondary,#6b7280);font-size:14px;margin:0;max-width:280px}.gamify-level{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(59,130,246,.12);border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,.04),0 4px 16px rgba(59,130,246,.06);display:flex;gap:16px;margin-bottom:16px;overflow:hidden;padding:18px;position:relative}.gamify-level:before{background:linear-gradient(90deg,#f59e0b,#fbbf24);content:"";height:3px;left:0;position:absolute;right:0;top:0}.gamify-level__badge{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:14px;box-shadow:0 4px 12px rgba(0,0,0,.15),0 2px 4px rgba(0,0,0,.1);display:flex;flex-shrink:0;height:60px;justify-content:center;width:60px}.gamify-level__number{color:#fff;font-size:18px;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.2)}.gamify-level__info{flex:1;min-width:0}.gamify-level__progress{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(37,99,235,.05));border:1px solid rgba(59,130,246,.1);border-radius:5px;height:10px;overflow:hidden}.gamify-level__progress-bar{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:5px;box-shadow:0 0 8px rgba(59,130,246,.4);height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.gamify-level__stats{color:var(--color-text-secondary,#6b7280);display:flex;font-size:12px;font-weight:500;justify-content:space-between;margin-top:8px}.gamify-level__streak{align-items:center;background:linear-gradient(135deg,#ff6b35,#f7931e);border-radius:14px;box-shadow:0 4px 12px rgba(247,147,30,.3);display:flex;flex-direction:column;flex-shrink:0;padding:10px 14px}.gamify-level__streak-icon{font-size:22px;line-height:1}.gamify-level__streak-count{color:#fff;font-size:20px;font-weight:800;line-height:1.2}.gamify-level__streak-label{color:rgba(255,255,255,.9);font-size:11px;font-weight:500}.gamify-tasks{margin-top:12px}.gamify-tasks__header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:14px;padding-bottom:10px}.gamify-tasks__title{align-items:center;color:var(--color-text-primary,#1f2937);display:flex;font-size:15px;font-weight:700;gap:8px}.gamify-tasks__count{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(37,99,235,.05));border-radius:12px;color:var(--color-text-secondary,#6b7280);font-size:12px;font-weight:600;padding:4px 10px}.gamify-tasks__list{display:flex;flex-direction:column;gap:10px}.gamify-task{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(59,130,246,.1);border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.02);display:flex;justify-content:space-between;padding:14px 16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.gamify-task:hover{border-color:rgba(59,130,246,.25);box-shadow:0 4px 12px rgba(59,130,246,.1);transform:translateY(-2px)}.gamify-task--complete{background:linear-gradient(135deg,rgba(34,197,94,.08),rgba(34,197,94,.03));border-color:rgba(34,197,94,.25)}.gamify-task--complete:hover{border-color:rgba(34,197,94,.4);box-shadow:0 4px 12px rgba(34,197,94,.15)}.gamify-task--claimed{opacity:.75}.gamify-task__info{flex:1;margin-right:12px;min-width:0}.gamify-task__title{color:var(--color-text-primary,#1f2937);display:block;font-size:14px;font-weight:600;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gamify-task__progress{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(37,99,235,.05));border-radius:3px;height:6px;margin-bottom:6px;overflow:hidden}.gamify-task__progress-bar{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.gamify-task--complete .gamify-task__progress-bar{background:linear-gradient(90deg,#22c55e,#4ade80)}.gamify-task__status{color:var(--color-text-secondary,#9ca3af);font-size:12px;font-weight:500}.gamify-task__reward{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:6px}.gamify-task__xp{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(37,99,235,.05));border-radius:12px;color:#3b82f6;font-size:13px;font-weight:700;padding:4px 10px}.gamify-task--complete .gamify-task__xp{background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(34,197,94,.05));color:#22c55e}.gamify-task__btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:20px;box-shadow:0 2px 6px rgba(59,130,246,.3);color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px;transition:all .3s cubic-bezier(.4,0,.2,1)}.gamify-task__btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px rgba(59,130,246,.4);transform:translateY(-2px)}.gamify-task__btn:disabled{background:linear-gradient(135deg,#e5e7eb,#d1d5db);box-shadow:none;color:var(--color-text-secondary,#9ca3af);cursor:not-allowed}.gamify-task__btn--claimed{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 6px rgba(34,197,94,.3);color:#fff}@media(max-width:640px){.gamify-level{flex-wrap:wrap;gap:12px}.gamify-level__info{order:3;width:100%}.gamify-level__streak{margin-left:auto}.gamify-task{align-items:stretch;flex-direction:column;gap:8px}.gamify-task__info{margin-right:0}.gamify-task__reward{align-items:center;flex-direction:row;justify-content:space-between}}}@layer components;@layer components;@layer components{.hero-section{margin:0 auto var(--space-24);width:min(1200px,100%)}.hero-layout{background:linear-gradient(135deg,rgba(var(--color-teal-500-rgb),.16),rgba(15,23,42,.06)),var(--color-surface);border:1px solid rgba(var(--color-teal-500-rgb),.22);border-radius:calc(var(--radius-lg) + 6px);box-shadow:0 22px 40px rgba(15,23,42,.12);display:grid;gap:clamp(1.5rem,3vw,2.5rem);grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);overflow:hidden;padding:clamp(1.75rem,4vw,3rem);position:relative}.hero-layout:before{background:radial-gradient(circle at 10% 20%,rgba(var(--color-teal-500-rgb),.28),transparent 58%),radial-gradient(circle at 85% 30%,rgba(59,130,246,.2),transparent 62%);content:"";top:0;right:0;bottom:0;left:0;opacity:.6;pointer-events:none;position:absolute;transform:translateZ(0)}.hero-intro,.hero-layout:before,.hero-sidepanel{position:relative;z-index:1}.hero-eyebrow{align-items:center;background:rgba(var(--color-teal-500-rgb),.18);border-radius:var(--radius-full);color:var(--color-primary);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-6);letter-spacing:.08em;padding:var(--space-4) var(--space-10);text-transform:uppercase}.hero-title{color:var(--color-text);font-size:clamp(2rem,3.4vw,2.6rem);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);line-height:1.15;margin:clamp(.75rem,1.8vw,1.25rem) 0}.hero-description{color:rgba(var(--color-slate-500-rgb),.9);font-size:clamp(1rem,1.6vw,1.1rem);line-height:1.6;margin:0 0 clamp(1.25rem,2.5vw,1.75rem)}.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-12);margin-bottom:clamp(1.25rem,2.4vw,1.75rem)}.hero-actions .btn--lg{min-width:180px}.hero-meta{display:grid;gap:var(--space-12);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.hero-meta__item{backdrop-filter:blur(6px);background:rgba(var(--color-teal-500-rgb),.08);border:1px solid rgba(var(--color-teal-500-rgb),.18);border-radius:var(--radius-md);padding:var(--space-12) var(--space-16)}.hero-meta__item dt{color:rgba(var(--color-slate-500-rgb),.85);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.08em;margin-bottom:var(--space-4);text-transform:uppercase}.hero-meta__item dd{color:var(--color-text);font-size:var(--font-size-sm);line-height:1.5;margin:0}.hero-sidepanel{backdrop-filter:blur(12px);background:rgba(var(--color-teal-500-rgb),.08);border:1px solid rgba(var(--color-teal-500-rgb),.22);border-radius:var(--radius-lg);color:var(--color-text);display:flex;flex-direction:column;gap:var(--space-12);padding:var(--space-16)}.hero-sidepanel__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.hero-sidepanel__subtitle{color:rgba(var(--color-slate-500-rgb),.85);font-size:var(--font-size-sm);margin:0 0 var(--space-4)}.hero-spotlight{display:grid;gap:var(--space-10)}.hero-spotlight__item{align-items:center;background:rgba(255,255,255,.15);border:1px solid rgba(var(--color-teal-500-rgb),.18);border-radius:var(--radius-md);color:inherit;display:grid;gap:var(--space-12);grid-template-columns:auto 1fr auto;padding:var(--space-12) var(--space-16);position:relative;transition:transform var(--duration-normal) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),background var(--duration-fast) var(--ease-standard)}.hero-spotlight__item:hover{background:rgba(var(--color-teal-500-rgb),.16);border-color:rgba(var(--color-teal-500-rgb),.4);transform:translateY(-2px)}.hero-spotlight__icon{font-size:1.6rem;line-height:1}.hero-spotlight__label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.hero-spotlight__desc{display:block;margin-top:var(--space-2)}.hero-spotlight__cta,.hero-spotlight__desc{color:rgba(var(--color-slate-500-rgb),.85);font-size:var(--font-size-xs)}.hero-spotlight__cta{font-weight:var(--font-weight-semibold);letter-spacing:.12em;text-transform:uppercase}.hero-signal{align-items:center;align-self:flex-start;background:rgba(var(--color-teal-500-rgb),.12);border:1px solid rgba(var(--color-teal-500-rgb),.2);border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:var(--space-8);margin-top:var(--space-4);padding:var(--space-6) var(--space-12)}.hero-signal__dot{animation:hero-signal-pulse 2s infinite;background:var(--color-green-500);border-radius:50%;box-shadow:0 0 rgba(var(--color-green-500-rgb),.4);display:inline-flex;height:10px;width:10px}.hero-signal__text{color:rgba(var(--color-slate-500-rgb),.9)}@media(max-width:1024px){.hero-layout{grid-template-columns:minmax(0,1fr)}.hero-sidepanel{flex-direction:row;flex-wrap:wrap;gap:var(--space-16);padding:var(--space-16) clamp(1rem,3vw,1.5rem)}.hero-spotlight{display:flex;flex:1 1 260px;flex-direction:column}}@media(max-width:768px){.hero-actions{align-items:stretch;flex-direction:column}.hero-meta{grid-template-columns:1fr}.hero-sidepanel{flex-direction:column}.hero-spotlight__item{gap:var(--space-8);grid-template-columns:auto 1fr}.hero-spotlight__cta{display:none}}}@layer components{.map-main{display:flex;flex-direction:column;gap:var(--space-20)}.map-container{flex:1;min-height:unset}.map-header{align-items:flex-start;background:linear-gradient(90deg,rgba(31,184,205,.06),rgba(31,184,205,.12));border-bottom:1px solid var(--color-card-border-inner);display:flex;justify-content:space-between;padding:var(--space-16)}.map-title h2{color:var(--color-text);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:-.02em;margin:0 0 var(--space-2) 0}.map-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);opacity:.8}.map-controls{align-items:center;display:flex;gap:var(--space-12)}.map-content{padding:0;position:relative}.map-toolbar{display:flex;gap:var(--space-6);position:absolute;right:var(--space-16);top:var(--space-16);z-index:10}.echarts-map{background:linear-gradient(180deg,rgba(59,130,246,.02),rgba(59,130,246,.04));height:480px;width:100%}.echarts-chart{height:100%;width:100%}.map-legend-container{backdrop-filter:blur(8px);background:rgba(248,250,252,.95);border:1px solid rgba(226,232,240,.8);border-radius:var(--radius-md);bottom:var(--space-16);box-shadow:var(--shadow-md);max-width:260px;padding:var(--space-12);position:absolute;right:var(--space-16)}.legend-items{display:flex;flex-direction:column;gap:var(--space-6)}.legend-item{align-items:center;display:flex;font-size:var(--font-size-xs);gap:var(--space-8)}.legend-color{border-radius:var(--radius-sm);flex-shrink:0;height:16px;width:16px}.legend-text{color:var(--color-text);flex:1}@media(max-width:1024px){.echarts-map{height:clamp(380px,50vh,600px)}.map-legend-container{bottom:auto;margin-top:var(--space-16);position:relative;right:auto}}@media(max-width:768px){.echarts-map{height:clamp(320px,42vh,520px)}}@media(max-width:480px){.echarts-map{height:clamp(260px,40vh,460px)}.map-header{align-items:stretch;flex-direction:column;gap:var(--space-12)}}}@layer components{.quote-header{align-items:center;display:flex;flex-direction:column;gap:var(--space-6)}.quote-title{align-items:baseline;display:inline-flex;gap:var(--space-6)}.quote-name{color:var(--color-text);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.quote-code{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.quote-sub{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-8);justify-content:center}.meta-chip{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-full);padding:4px 10px}.meta-chip,.meta-time{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.quote-strip{align-items:center;display:flex;gap:var(--space-16);justify-content:center;margin:var(--space-16) 0 var(--space-12)}.quote-price{gap:var(--space-4)}.quote-change,.quote-price{align-items:baseline;display:inline-flex}.quote-change{font-weight:var(--font-weight-semibold);gap:var(--space-6)}.quote-change .chg-abs,.quote-change .chg-pct{font-size:var(--font-size-base)}.quote-change .chg-pct.up{color:var(--color-positive)}.quote-change .chg-pct.down{color:var(--color-negative)}.info-tabs{display:flex;flex-wrap:wrap;gap:var(--tablist-gap);justify-content:center;margin:var(--tablist-gap) 0}.quote-board{display:grid;gap:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-top:var(--space-12)}.quote-item{background:var(--color-surface);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-8) var(--space-12)}.quote-item .label{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.quote-item .value{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.quote-board-toggle{margin-top:var(--space-12);text-align:center}.basic-info-grid{display:grid;gap:var(--space-12);grid-template-columns:repeat(2,minmax(0,1fr))}.info-item{background:var(--color-surface);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-8) var(--space-12)}.info-item .label{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.info-item .value{color:var(--color-text);font-size:var(--font-size-sm)}.info-item.full-width{grid-column:1/-1}.basic-info-toggle{margin-top:var(--space-12);text-align:center}.current-price{color:var(--color-primary);display:block;font-family:var(--font-family-mono);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-8);text-shadow:0 0 10px rgba(59,130,246,.25)}.region-meta{display:flex;flex-wrap:wrap;gap:var(--space-24);justify-content:center}.region-stats{margin-bottom:var(--space-24)}.stats-grid{display:grid;gap:var(--space-12);grid-template-columns:repeat(2,1fr)}.region-features{margin-bottom:var(--space-24)}.region-features h4{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-12)}.features-list{display:flex;flex-wrap:wrap;gap:var(--space-8)}.feature-tag{background:var(--color-bg-4);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-full);color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-6) var(--space-12)}.region-cities{margin-bottom:var(--space-24)}.region-cities h4{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-12)}.city-board{display:flex;flex-direction:column;gap:var(--space-12)}.city-board__item{background:var(--color-bg-3);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-lg);cursor:pointer;padding:var(--space-12);transition:transform var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}.city-board__item:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.city-board__title{align-items:center;color:var(--color-text);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);justify-content:space-between;margin-bottom:var(--space-6)}.city-board__name{align-items:center;display:flex;gap:var(--space-6)}.city-board__change{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.city-board__meta{color:var(--color-text-secondary);display:flex;flex-wrap:wrap;font-size:var(--font-size-xs);gap:var(--space-12)}.region-chart{margin-bottom:var(--space-24)}.region-chart h4{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-12)}.chart-tabs{display:flex;flex-wrap:wrap;gap:var(--tablist-gap)}.indicator-notes{color:var(--color-text-secondary);display:flex;flex-direction:column;font-size:var(--font-size-xs);gap:var(--space-4);margin-top:var(--space-8)}.note-item{align-items:center;display:inline-flex;gap:6px}.note-dot{border-radius:50%;display:inline-block;height:8px;width:8px}.region-split{display:grid;gap:var(--space-16);grid-template-columns:1.6fr 1fr}.region-split__left{grid-column:1}.region-split__right{grid-column:2}@media(max-width:960px){.region-split{grid-template-columns:1fr}.region-split__left,.region-split__right{grid-column:1}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.current-price{font-size:var(--font-size-3xl)}}}@layer components;@layer components{.hd-panel{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:var(--radius-xl,16px);overflow:hidden;position:relative;transition:box-shadow .2s ease,transform .2s ease}.hd-panel:hover{box-shadow:0 10px 40px rgba(0,0,0,.08)}.hd-panel:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899);content:"";height:3px;left:0;position:absolute;right:0;top:0;z-index:10}.hd-panel__header{align-items:center;background:linear-gradient(180deg,rgba(59,130,246,.02) 0,transparent);border-bottom:1px solid var(--color-border,#e5e7eb);display:flex;gap:16px;justify-content:space-between;padding:16px 20px}.hd-panel__title{align-items:center;color:var(--color-text,#1f2937);display:flex;font-size:1.125rem;font-weight:600;gap:8px;margin:0}.hd-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:500;padding:4px 12px;transition:all .2s}.hd-badge--success{background:rgba(34,197,94,.1);color:#16a34a}.hd-badge--warning{background:rgba(245,158,11,.1);color:#d97706}.hd-badge--info{background:rgba(59,130,246,.1);color:#2563eb}.hd-badge--cosmetic{background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(236,72,153,.1));color:#7c3aed}.panel.trading-panel{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:var(--radius-xl,16px);overflow:hidden;position:relative;transition:box-shadow .2s ease,transform .2s ease}.panel.trading-panel:hover{box-shadow:0 10px 40px rgba(0,0,0,.08)}.panel.trading-panel:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899);content:"";height:3px;left:0;position:absolute;right:0;top:0;z-index:10}.panel.trading-panel .panel-header{align-items:center;background:linear-gradient(180deg,rgba(59,130,246,.02) 0,transparent);border-bottom:1px solid var(--color-border,#e5e7eb);display:flex;gap:16px;justify-content:space-between;padding:16px 20px}.panel.trading-panel .panel-title{color:var(--color-text,#1f2937);font-size:1.125rem;font-weight:600;margin:0}.panel.trading-panel .panel-subtitle{color:var(--color-text-secondary,#6b7280);font-size:.875rem;margin-top:4px}.panel.trading-panel .panel-body{padding:16px 20px}.account-panel .account-profile{align-items:center;display:flex;gap:16px;padding:20px}.account-panel .account-profile__avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;box-shadow:0 4px 12px rgba(59,130,246,.3);color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:64px;justify-content:center;width:64px}.account-panel .account-profile__info{flex:1}.account-panel .account-profile__name{color:var(--color-text,#1f2937);font-size:1.25rem;font-weight:600}.account-panel .account-profile__username{color:var(--color-text-secondary,#6b7280);font-size:.875rem}.account-panel .account-level{padding:0 20px 20px}.account-panel .account-level__badge{align-items:center;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:9999px;box-shadow:0 4px 12px rgba(245,158,11,.3);color:#fff;display:inline-flex;font-weight:600;gap:8px;padding:8px 16px}.account-panel .account-level__progress{margin-top:12px}.account-panel .account-level__bar{background:#e5e7eb;border-radius:9999px;height:8px;overflow:hidden}.account-panel .account-level__fill{background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:9999px;height:100%;transition:width .5s ease}.asset-panel .asset-highlight{background:linear-gradient(135deg,rgba(59,130,246,.05),rgba(139,92,246,.05));border-bottom:1px solid var(--color-border,#e5e7eb);padding:20px}.asset-panel .asset-highlight__main{text-align:center}.asset-panel .asset-highlight__label{color:var(--color-text-secondary,#6b7280);font-size:.875rem}.asset-panel .asset-highlight__value{margin-top:8px}.asset-panel .asset-highlight__value strong{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;font-size:2.5rem;font-weight:700;-webkit-text-fill-color:transparent;background-clip:text}.asset-panel .asset-highlight__unit{color:var(--color-text-secondary,#6b7280);font-size:1rem;margin-left:4px}.asset-panel .asset-highlight__change{background:rgba(34,197,94,.1);border-radius:9999px;color:#16a34a;display:inline-block;font-size:.875rem;font-weight:500;margin-top:8px;padding:4px 12px}.asset-panel .asset-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr);padding:20px}.asset-panel .asset-grid__item{align-items:center;background:var(--color-surface-alt,#f9fafb);border-radius:12px;display:flex;gap:12px;padding:16px;transition:all .2s}.asset-panel .asset-grid__item:hover{background:rgba(59,130,246,.05)}.asset-panel .asset-grid__icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;color:#fff;display:flex;height:44px;justify-content:center;width:44px}.asset-panel .asset-grid__label{color:var(--color-text-secondary,#6b7280);font-size:.875rem}.asset-panel .asset-grid__value{color:var(--color-text,#1f2937);font-size:1.25rem;font-weight:600}.section-nav{background:var(--color-surface,#fff);border-bottom:1px solid var(--color-border,#e5e7eb);margin-bottom:24px;padding:16px 20px}.section-nav-group{display:flex;flex-wrap:wrap;gap:8px}.section-nav .btn{border-radius:8px;font-weight:500;transition:all .2s}.section-nav .btn--secondary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;box-shadow:0 4px 12px rgba(59,130,246,.3);color:#fff}.section-nav .btn--ghost:hover{background:rgba(59,130,246,.1);color:#3b82f6}.section-nav-label{color:var(--color-text-secondary,#6b7280);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin:16px 0 8px;text-transform:uppercase}.section-nav-divider{background:var(--color-border,#e5e7eb);height:1px;margin:16px 0}.trading-buttons-group .btn--trading{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb)}.trading-buttons-group .btn--trading:hover{background:rgba(59,130,246,.05);border-color:#3b82f6}.stats-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:16px}.stats-grid>*{background:var(--color-surface-alt,#f9fafb);border-radius:12px;padding:20px;text-align:center;transition:all .2s}.stats-grid>:hover{background:rgba(59,130,246,.05);transform:translateY(-2px)}.rankings-panel .panel-grid{display:grid;gap:16px;grid-template-columns:repeat(3,1fr);padding:16px}@media(max-width:1024px){.rankings-panel .panel-grid{grid-template-columns:1fr}}.news-panel .news-feed{padding:16px}.news-panel .stream-status{align-items:center;color:var(--color-text-secondary,#6b7280);display:flex;font-size:.875rem;gap:8px}.news-panel .status-dot{animation:pulse 2s infinite;background:#22c55e;border-radius:50%;height:8px;width:8px}.notification-section,.preferences-section{background:var(--color-surface-alt,#f9fafb);border-radius:12px;margin-bottom:24px;padding:20px}.notification-section__header,.preferences-section__header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.notification-section__icon,.preferences-section__icon{font-size:1.5rem}.notification-section__title,.preferences-section__title{color:var(--color-text,#1f2937);font-size:1rem;font-weight:600}.preferences-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}@media(max-width:768px){.preferences-grid{grid-template-columns:1fr}}.preferences-field__label{color:var(--color-text,#1f2937);display:block;font-size:.875rem;font-weight:500;margin-bottom:8px}.preferences-field__input,.preferences-field__textarea{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:8px;color:var(--color-text,#1f2937);font-size:.875rem;padding:12px 16px;transition:all .2s;width:100%}.preferences-field__input:focus,.preferences-field__textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1);outline:none}.preferences-field__hint{color:var(--color-text-secondary,#6b7280);font-size:.75rem;margin-top:4px}.notification-toggle{align-items:center;background:var(--color-surface,#fff);border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:12px;padding:16px;transition:all .2s}.notification-toggle:hover{background:rgba(59,130,246,.05)}.notification-toggle__info{align-items:center;display:flex;gap:12px}.notification-toggle__icon{font-size:1.5rem}.notification-toggle__name{color:var(--color-text,#1f2937);font-size:.875rem;font-weight:500}.notification-toggle__desc{color:var(--color-text-secondary,#6b7280);font-size:.75rem}.notification-toggle__slider{background:#d1d5db;border-radius:9999px;height:24px;position:relative;transition:all .2s;width:44px}.notification-toggle__slider:after{background:#fff;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.1);content:"";height:20px;left:2px;position:absolute;top:2px;transition:all .2s;width:20px}.notification-toggle__input:checked+.notification-toggle__slider{background:#3b82f6}.notification-toggle__input:checked+.notification-toggle__slider:after{transform:translate(20px)}.notification-toggle__input{display:none}.btn{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:8px;justify-content:center;padding:10px 20px;transition:all .2s}.btn--primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;box-shadow:0 4px 12px rgba(59,130,246,.3);color:#fff}.btn--primary:hover{box-shadow:0 6px 20px rgba(59,130,246,.4);transform:translateY(-2px)}.btn--ghost{background:transparent;border:1px solid var(--color-border,#e5e7eb);color:var(--color-text,#1f2937)}.btn--ghost:hover{background:var(--color-surface-alt,#f9fafb);border-color:#3b82f6;color:#3b82f6}.btn--danger{background:#ef4444;border:none;color:#fff}.btn--danger:hover{background:#dc2626}.btn--sm{font-size:.75rem;padding:6px 12px}.avatar-upload{align-items:center;display:flex;flex-direction:column;gap:16px}.avatar-upload__preview{align-items:center;background:linear-gradient(135deg,#e0e7ff,#ddd6fe);border:4px solid #fff;border-radius:50%;box-shadow:0 8px 24px rgba(0,0,0,.1);display:flex;height:120px;justify-content:center;overflow:hidden;width:120px}.avatar-upload__placeholder{color:#9ca3af}.avatar-upload__hint{color:var(--color-text-secondary,#6b7280);font-size:.75rem;text-align:center}.alert{border-radius:12px;font-size:.875rem;padding:16px 20px}.alert--success{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);color:#16a34a}.alert--error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:#dc2626}.alert--warning{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);color:#d97706}.alert--info{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.2);color:#2563eb}.compliance-banner{background:linear-gradient(135deg,rgba(245,158,11,.1),rgba(239,68,68,.05));border:1px solid rgba(245,158,11,.2);border-radius:12px;color:var(--color-text,#1f2937);font-size:.875rem;margin:20px;padding:16px 24px}.compliance-banner strong{color:#d97706}.app-header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(255,255,255,.95);border-bottom:1px solid var(--color-border,#e5e7eb);position:sticky;top:0;z-index:100}.header-bar{justify-content:space-between;margin:0 auto;max-width:1440px;padding:12px 24px}.brand,.header-bar{align-items:center;display:flex}.brand{gap:12px;text-decoration:none}.brand-logo-wrapper{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;box-shadow:0 4px 12px rgba(59,130,246,.3);display:flex;height:40px;justify-content:center;width:40px}.brand-title{font-size:1.25rem;font-weight:700;margin:0}.gradient-text{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-subtitle{color:var(--color-text-secondary,#6b7280);font-size:.75rem;margin:0}.user-menu{align-items:center;background:var(--color-surface-alt,#f9fafb);border-radius:9999px;cursor:pointer;display:flex;gap:12px;padding:8px 16px;transition:all .2s}.user-menu:hover{background:rgba(59,130,246,.1)}.user-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:.875rem;font-weight:600;height:36px;justify-content:center;width:36px}.user-info{text-align:left}.user-info .fw-600{color:var(--color-text,#1f2937);font-size:.875rem;font-weight:600}.user-info .text-muted{color:var(--color-text-secondary,#6b7280);font-size:.75rem}.analytics-panel,[data-sections*=analytics]{background:var(--color-surface,#fff)}.analytics-panel .panel-header{align-items:center;border-bottom:1px solid var(--color-border,#e5e7eb);display:flex;justify-content:space-between;padding:16px 20px}.holdings-table{border-collapse:collapse;width:100%}.holdings-table th{background:var(--color-surface-alt,#f9fafb);color:var(--color-text-secondary,#6b7280);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:12px 16px;text-align:left;text-transform:uppercase}.holdings-table td,.holdings-table th{border-bottom:1px solid var(--color-border,#e5e7eb)}.holdings-table td{font-size:.875rem;padding:16px}.holdings-table tr:hover td{background:rgba(59,130,246,.02)}.holdings-table .stock-name{color:var(--color-text,#1f2937);font-weight:600}.holdings-table .stock-code{color:var(--color-text-secondary,#6b7280);font-family:monospace;font-size:.75rem}.chart-container{background:var(--color-surface-alt,#f9fafb);border-radius:12px;min-height:300px;padding:20px}.chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.chart-title{color:var(--color-text,#1f2937);font-size:1rem;font-weight:600}.period-selector{background:var(--color-surface-alt,#f9fafb);border-radius:8px;display:flex;gap:4px;padding:4px}.watchlist{padding:0}.market-card,.stats-card{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:12px;padding:20px;text-align:center}.market-card .card-title,.stats-card .card-title{color:var(--color-text-secondary,#6b7280);font-size:.875rem;margin-bottom:8px}.market-card .card-value,.stats-card .card-value{color:var(--color-text,#1f2937);font-family:monospace;font-size:1.5rem;font-weight:700}.market-card .card-change,.stats-card .card-change{align-items:center;display:inline-flex;font-size:.875rem;font-weight:500;gap:4px;margin-top:8px}.card-change.up{color:#16a34a}.card-change.down{color:#dc2626}.progress-bar{background:#e5e7eb;border-radius:9999px;height:8px;overflow:hidden}.progress-bar .progress-fill{background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:9999px;height:100%;transition:width .5s ease}.progress-bar.success .progress-fill{background:linear-gradient(90deg,#22c55e,#16a34a)}.progress-bar.warning .progress-fill{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-bar.danger .progress-fill{background:linear-gradient(90deg,#ef4444,#dc2626)}.empty-state{padding:48px 24px;text-align:center}.empty-state .empty-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;display:inline-block;height:24px;width:24px}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;border-radius:6px}@media(max-width:768px){.asset-panel .asset-grid,.dashboard-grid,.preferences-grid,.rankings-panel .panel-grid{grid-template-columns:1fr}.header-bar{padding:12px 16px}.brand-subtitle{display:none}.market-overview{flex-wrap:wrap;gap:var(--space-8)}.market-indicator{flex:1 1 auto;min-width:120px}}}@layer components{.card__body{padding:var(--space-16)}.card__footer,.card__header{border-bottom:1px solid var(--color-card-border-inner);padding:var(--space-16)}.status{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-6) var(--space-12)}.container{margin-left:auto;margin-right:auto;padding-left:var(--space-16);padding-right:var(--space-16);width:100%}@media(min-width:640px){.container{max-width:var(--container-sm)}}@media(min-width:768px){.container{max-width:var(--container-md)}}@media(min-width:1024px){.container{max-width:var(--container-lg)}}@media(min-width:1280px){.container{max-width:100%}}.mt-48{margin-top:calc(var(--space-16)*3)}.text-13{font-size:13px}.max-w-520{max-width:520px}.max-w-720{max-width:768px}.progress-slim{background:var(--color-surface-muted);border-radius:6px;height:8px;overflow:hidden}.progress-bar{background:var(--color-primary);height:100%}.loading-overlay{display:none!important;visibility:hidden!important}.loading-content{color:var(--color-white);text-align:center}.loading-spinner{animation:spin 1.2s linear infinite;border:4px solid rgba(31,184,205,.3);border-radius:50%;border-top:4px solid var(--color-teal-300);height:60px;margin:0 auto var(--space-20);width:60px}.loading-text{color:var(--color-teal-300);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-8)}.loading-subtext{color:var(--color-gray-300);font-size:var(--font-size-base)}.stock-up{color:var(--color-green-500)}.stock-down{color:var(--color-red-500)}.stock-neutral{color:var(--color-slate-500)}.hero-section{margin:0 auto var(--space-24);width:min(1200px,100%)}.hero-layout{background:linear-gradient(135deg,rgba(var(--color-teal-500-rgb),.16),rgba(15,23,42,.06)),var(--color-surface);border:1px solid rgba(var(--color-teal-500-rgb),.22);border-radius:calc(var(--radius-lg) + 6px);box-shadow:0 22px 40px rgba(15,23,42,.12);display:grid;gap:clamp(1.5rem,3vw,2.5rem);grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);overflow:hidden;padding:clamp(1.75rem,4vw,3rem);position:relative}.hero-layout:before{background:radial-gradient(circle at 10% 20%,rgba(var(--color-teal-500-rgb),.28),transparent 58%),radial-gradient(circle at 85% 30%,rgba(59,130,246,.2),transparent 62%);content:"";top:0;right:0;bottom:0;left:0;opacity:.6;pointer-events:none;position:absolute;transform:translateZ(0)}.hero-intro,.hero-layout:before,.hero-sidepanel{position:relative;z-index:1}.hero-eyebrow{align-items:center;background:rgba(var(--color-teal-500-rgb),.18);border-radius:var(--radius-full);color:var(--color-primary);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-6);letter-spacing:.08em;padding:var(--space-4) var(--space-10);text-transform:uppercase}.hero-title{color:var(--color-text);font-size:clamp(2rem,3.4vw,2.6rem);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);line-height:1.15;margin:clamp(.75rem,1.8vw,1.25rem) 0}.hero-description{color:rgba(var(--color-slate-500-rgb),.9);font-size:clamp(1rem,1.6vw,1.1rem);line-height:1.6;margin:0 0 clamp(1.25rem,2.5vw,1.75rem)}.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-12);margin-bottom:clamp(1.25rem,2.4vw,1.75rem)}.hero-actions .btn--lg{min-width:180px}.hero-meta{display:grid;gap:var(--space-12);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.hero-meta__item{backdrop-filter:blur(6px);background:rgba(var(--color-teal-500-rgb),.08);border:1px solid rgba(var(--color-teal-500-rgb),.18);border-radius:var(--radius-md);padding:var(--space-12) var(--space-16)}.hero-meta__item dt{color:rgba(var(--color-slate-500-rgb),.85);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.08em;margin-bottom:var(--space-4);text-transform:uppercase}.hero-meta__item dd{color:var(--color-text);font-size:var(--font-size-sm);line-height:1.5;margin:0}.hero-sidepanel{backdrop-filter:blur(12px);background:rgba(var(--color-teal-500-rgb),.08);border:1px solid rgba(var(--color-teal-500-rgb),.22);border-radius:var(--radius-lg);color:var(--color-text);display:flex;flex-direction:column;gap:var(--space-12);padding:var(--space-16)}.hero-sidepanel__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.hero-sidepanel__subtitle{color:rgba(var(--color-slate-500-rgb),.85);font-size:var(--font-size-sm);margin:0 0 var(--space-4)}.hero-spotlight{display:grid;gap:var(--space-10)}.hero-spotlight__item{align-items:center;background:rgba(255,255,255,.15);border:1px solid rgba(var(--color-teal-500-rgb),.18);border-radius:var(--radius-md);color:inherit;display:grid;gap:var(--space-12);grid-template-columns:auto 1fr auto;padding:var(--space-12) var(--space-16);position:relative;transition:transform var(--duration-normal) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),background var(--duration-fast) var(--ease-standard)}.hero-spotlight__item:hover{background:rgba(var(--color-teal-500-rgb),.16);border-color:rgba(var(--color-teal-500-rgb),.4);transform:translateY(-2px)}.hero-spotlight__icon{font-size:1.6rem;line-height:1}.hero-spotlight__label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.hero-spotlight__desc{display:block;margin-top:var(--space-2)}.hero-spotlight__cta,.hero-spotlight__desc{color:rgba(var(--color-slate-500-rgb),.85);font-size:var(--font-size-xs)}.hero-spotlight__cta{font-weight:var(--font-weight-semibold);letter-spacing:.12em;text-transform:uppercase}.hero-signal{align-items:center;align-self:flex-start;background:rgba(var(--color-teal-500-rgb),.12);border:1px solid rgba(var(--color-teal-500-rgb),.2);border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:var(--space-8);margin-top:var(--space-4);padding:var(--space-6) var(--space-12)}.hero-signal__dot{animation:hero-signal-pulse 2s infinite;background:var(--color-green-500);border-radius:50%;box-shadow:0 0 rgba(var(--color-green-500-rgb),.4);display:inline-flex;height:10px;width:10px}.hero-signal__text{color:rgba(var(--color-slate-500-rgb),.9)}@keyframes hero-signal-pulse{0%{box-shadow:0 0 rgba(var(--color-green-500-rgb),.45)}70%{box-shadow:0 0 0 10px rgba(var(--color-green-500-rgb),0)}to{box-shadow:0 0 rgba(var(--color-green-500-rgb),0)}}@media(max-width:1024px){.hero-layout{grid-template-columns:minmax(0,1fr)}.hero-sidepanel{flex-direction:row;flex-wrap:wrap;gap:var(--space-16);padding:var(--space-16) clamp(1rem,3vw,1.5rem)}.hero-spotlight{display:flex;flex:1 1 260px;flex-direction:column}}@media(max-width:768px){.hero-actions{align-items:stretch;flex-direction:column}.hero-meta{grid-template-columns:1fr}.hero-sidepanel{flex-direction:column}.hero-spotlight__item{gap:var(--space-8);grid-template-columns:auto 1fr}.hero-spotlight__cta{display:none}}.market-indicator{align-items:flex-start;display:flex;flex-direction:column;gap:var(--space-2);min-width:120px}.indicator-change,.indicator-value,.ticker-price{font-variant-numeric:tabular-nums}.indicator-label{color:rgba(255,255,255,.7);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.5px;text-transform:uppercase}.indicator-value{color:var(--color-white);font-size:var(--font-size-xl)}.indicator-change,.indicator-value{font-family:var(--font-family-mono);font-weight:var(--font-weight-bold)}.indicator-change{border-radius:var(--radius-sm);font-size:var(--font-size-sm);padding:var(--space-1) var(--space-6)}.indicator-change.positive{background:rgba(var(--color-positive-rgb),.15);color:var(--color-positive)}.indicator-change.negative{background:rgba(var(--color-negative-rgb),.15);color:var(--color-negative)}.container-fluid{margin:0 auto;max-width:100%;padding:0 5px}.main-content{background:var(--color-background);min-height:calc(100vh - 100px);padding:var(--space-2) 5px}.panel{display:flex;flex-direction:column;gap:var(--space-2);height:100%}.panel-actions{align-items:center;display:flex;gap:var(--space-8)}.panel-actions .btn{font-size:var(--font-size-sm);padding:var(--space-6) var(--space-12)}.tip,.tip-title{color:var(--color-text)}.tip-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-12)}.tip-row{margin-bottom:var(--space-8)}.tip-label{color:var(--color-text-secondary)}.tip-label--warning{color:var(--color-warning)}.tip-value{color:var(--color-text);font-weight:var(--font-weight-bold)}.tip-value--primary{color:var(--color-primary)}.tip-value--pos{color:var(--color-positive)}.tip-value--neg{color:var(--color-negative)}.tip-note{font-size:var(--font-size-xs);font-style:italic;margin-top:var(--space-8)}.tip-note,.tip-note--compact{color:var(--color-text-secondary)}.tip-note--compact{font-size:12px}.filter-group{display:flex;flex-direction:column;gap:var(--space-2)}.filter-label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.btn-icon{margin-right:var(--space-2)}.map-main{display:flex;flex-direction:column;gap:var(--space-20)}.map-container{flex:1;min-height:unset}.map-header{align-items:flex-start;background:linear-gradient(90deg,rgba(31,184,205,.06),rgba(31,184,205,.12));border-bottom:1px solid var(--color-card-border-inner);display:flex;justify-content:space-between;padding:var(--space-16)}.map-title h2{color:var(--color-text);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:-.02em;margin:0 0 var(--space-2) 0}.map-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);opacity:.8}.map-controls{align-items:center;display:flex;gap:var(--space-12)}.map-content{padding:0;position:relative}.map-toolbar{display:flex;gap:var(--space-6);position:absolute;right:var(--space-16);top:var(--space-16);z-index:10}.echarts-map{background:linear-gradient(180deg,rgba(59,130,246,.02),rgba(59,130,246,.04));height:480px;width:100%}.echarts-chart{height:100%;width:100%}.map-legend-container{backdrop-filter:blur(8px);background:rgba(248,250,252,.95);border:1px solid rgba(226,232,240,.8);border-radius:var(--radius-md);bottom:var(--space-16);box-shadow:var(--shadow-md);max-width:260px;padding:var(--space-12);position:absolute;right:var(--space-16)}.legend-items{display:flex;flex-direction:column;gap:var(--space-6)}.legend-item{align-items:center;display:flex;font-size:var(--font-size-xs);gap:var(--space-8)}.legend-color{border-radius:var(--radius-sm);flex-shrink:0;height:16px;width:16px}.legend-text{color:var(--color-text);flex:1}.stream-status{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--space-6)}.status-dot{background:var(--color-gray-300);border-radius:50%;height:8px;width:8px}.status-dot.active{animation:pulse-dot 2s ease-in-out infinite;background:var(--color-success)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.chart-container{background:var(--color-background);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-md);margin-top:var(--space-12)}.region-stats{padding:var(--space-20)}.quote-header{align-items:center;display:flex;flex-direction:column;gap:var(--space-6)}.quote-title{align-items:baseline;display:inline-flex;gap:var(--space-6)}.quote-name{color:var(--color-text);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.quote-code{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.quote-sub{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-8);justify-content:center}.meta-chip{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-full);padding:4px 10px}.meta-chip,.meta-time{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.quote-strip{align-items:center;display:flex;gap:var(--space-16);justify-content:center;margin:var(--space-16) 0 var(--space-12)}.quote-price{gap:var(--space-4)}.quote-change,.quote-price{align-items:baseline;display:inline-flex}.quote-change{font-weight:var(--font-weight-semibold);gap:var(--space-6)}.quote-change .chg-abs,.quote-change .chg-pct{font-size:var(--font-size-base)}.quote-change .chg-pct.up{color:var(--color-positive)}.quote-change .chg-pct.down{color:var(--color-negative)}.info-tabs{display:flex;flex-wrap:wrap;gap:var(--tablist-gap);justify-content:center;margin:var(--tablist-gap) 0}.quote-board{display:grid;gap:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-top:var(--space-12)}.quote-item{background:var(--color-surface);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-8) var(--space-12)}.quote-item .label{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.quote-item .value{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.quote-board-toggle{margin-top:var(--space-12);text-align:center}.basic-info-grid{display:grid;gap:var(--space-12);grid-template-columns:repeat(2,minmax(0,1fr))}.info-item{background:var(--color-surface);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-8) var(--space-12)}.info-item .label{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.info-item .value{color:var(--color-text);font-size:var(--font-size-sm)}.info-item.full-width{grid-column:1/-1}.basic-info-toggle{margin-top:var(--space-12);text-align:center}.current-price{color:var(--color-primary);display:block;font-family:var(--font-family-mono);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-8);text-shadow:0 0 10px rgba(59,130,246,.25)}.region-meta{display:flex;flex-wrap:wrap;gap:var(--space-24);justify-content:center}.region-stats{margin-bottom:var(--space-24)}.stats-grid{display:grid;gap:var(--space-12);grid-template-columns:repeat(2,1fr)}.region-features{margin-bottom:var(--space-24)}.region-features h4{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-12)}.features-list{display:flex;flex-wrap:wrap;gap:var(--space-8)}.feature-tag{background:var(--color-bg-4);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-full);color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-6) var(--space-12)}.region-cities{margin-bottom:var(--space-24)}.region-cities h4{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-12)}.city-board{display:flex;flex-direction:column;gap:var(--space-12)}.city-board__item{background:var(--color-bg-3);border:1px solid var(--color-card-border-inner);border-radius:var(--radius-lg);cursor:pointer;padding:var(--space-12);transition:transform var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}.city-board__item:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.city-board__title{align-items:center;color:var(--color-text);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);justify-content:space-between;margin-bottom:var(--space-6)}.city-board__name{align-items:center;display:flex;gap:var(--space-6)}.city-board__change{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.city-board__meta{color:var(--color-text-secondary);display:flex;flex-wrap:wrap;font-size:var(--font-size-xs);gap:var(--space-12)}.region-chart{margin-bottom:var(--space-24)}.region-chart h4{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-12)}.chart-tabs{display:flex;flex-wrap:wrap;gap:var(--tablist-gap)}.indicator-notes{color:var(--color-text-secondary);display:flex;flex-direction:column;font-size:var(--font-size-xs);gap:var(--space-4);margin-top:var(--space-8)}.note-item{align-items:center;display:inline-flex;gap:6px}.note-dot{border-radius:50%;display:inline-block;height:8px;width:8px}.region-split{display:grid;gap:var(--space-16);grid-template-columns:1.6fr 1fr}.region-split__left{grid-column:1}.region-split__right{grid-column:2}@media(max-width:960px){.region-split{grid-template-columns:1fr}.region-split__left,.region-split__right{grid-column:1}}.kline-chart-container{background:rgba(0,0,0,.02);border-radius:var(--radius-md);margin:var(--space-12) 0;padding:var(--space-12)}@media(max-width:1200px){.market-overview{gap:var(--space-16)}.echarts-map{height:450px}}@media(max-width:1024px){.header-content{flex-direction:column;gap:var(--space-12);text-align:center}.market-overview{flex-wrap:wrap;justify-content:center}.echarts-map{height:clamp(380px,50vh,600px)}.map-legend-container{bottom:auto;margin-top:var(--space-16);position:relative;right:auto}}@media(max-width:768px){.container-fluid{padding:0 var(--space-12)}.main-content{padding:var(--space-16) 0}.logo-section{flex-direction:column;gap:var(--space-8)}.logo-section h1{font-size:var(--font-size-xl)}.echarts-map{height:clamp(320px,42vh,520px)}.modal-content{margin:calc(var(--modal-padding)*.75);max-height:95vh}.stats-grid{grid-template-columns:1fr}}@media(max-width:480px){.main-header{padding:var(--space-12) 0}.logo-section h1{font-size:var(--font-size-lg)}.market-overview{gap:var(--space-12);grid-template-columns:repeat(2,1fr)}.echarts-map{height:clamp(260px,40vh,460px)}.current-price{font-size:var(--font-size-3xl)}.card{border-left:none;border-radius:0;border-right:none;margin:0 calc(var(--space-12)*-1)}.map-header{align-items:stretch;flex-direction:column;gap:var(--space-12)}.market-indicator{min-width:auto}.indicator-value{font-size:var(--font-size-lg)}}.modal-body::-webkit-scrollbar{width:4px}.modal-body::-webkit-scrollbar-track{background:var(--color-bg-1);border-radius:var(--radius-sm)}.modal-body::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:var(--radius-sm)}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--color-primary-hover)}@keyframes dataFlash{0%,to{background-color:transparent}50%{background-color:var(--color-bg-3)}}.positive{color:var(--color-positive)}.negative,.positive{font-weight:var(--font-weight-bold)}.negative{color:var(--color-negative)}.trade-position-card{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-12);padding:var(--space-16)}.trade-position-header{font-weight:var(--font-weight-semibold)}.trade-position-empty,.trade-position-header{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.trade-position-grid{display:grid;gap:var(--space-12);grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.trade-position-grid dd{color:var(--color-text);font-weight:var(--font-weight-semibold);margin:0}.trade-position-label{color:var(--color-text-secondary);font-size:var(--font-size-xs);margin-bottom:var(--space-4)}.trade-position-pnl__values{align-items:center;display:flex;gap:var(--space-8)}.trade-pnl{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}@media(max-width:768px){.trade-panel__header{align-items:flex-start;flex-direction:column}.trade-wallet{flex-wrap:wrap;gap:var(--space-6)}}.stock-card-positive{background:linear-gradient(90deg,rgba(16,185,129,.05),transparent);border-left:4px solid var(--color-green-500)}.stock-card-negative{background:linear-gradient(90deg,rgba(192,21,47,.05),transparent);border-left:4px solid var(--color-red-500)}.region-highlight{animation:regionGlow 2s ease-in-out infinite}@keyframes regionGlow{0%,to{opacity:1}50%{opacity:.7}}.stock-flash-up{animation:flashUp .5s ease-in-out}.stock-flash-down{animation:flashDown .5s ease-in-out}@keyframes flashUp{0%{background-color:rgba(16,185,129,.3)}to{background-color:transparent}}@keyframes flashDown{0%{background-color:rgba(192,21,47,.3)}to{background-color:transparent}}.trading-panel{background:linear-gradient(180deg,rgba(31,184,205,.05),transparent);border-top:3px solid var(--color-primary)}.trading-panel-header{background:linear-gradient(to right,rgba(var(--color-primary-rgb),.1),transparent);border-bottom:1px solid var(--color-border);padding:var(--space-12) var(--space-16)}.stock-table{border-collapse:collapse;width:100%}.stock-table th{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-align:left;text-transform:uppercase}.stock-table td,.stock-table th{border-bottom:1px solid var(--color-border);padding:var(--space-8) var(--space-12)}.stock-table td{font-size:var(--font-size-sm)}.stock-table tr:hover{background-color:rgba(31,184,205,.05)}.compliance-banner{align-items:flex-start;background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.25);border-radius:1rem;box-shadow:0 18px 40px rgba(15,23,42,.08);color:var(--color-text);display:flex;gap:.75rem;margin:0 auto 1.5rem;max-width:1024px;padding:1rem 1.5rem}.compliance-banner__content{display:flex;flex-direction:column;gap:.25rem}.compliance-banner__content p{font-size:.95rem;line-height:1.5;margin:0}@media(max-width:768px){.compliance-banner{flex-direction:column;gap:.5rem;padding:.85rem 1rem}}.simulation-notice{background:rgba(253,230,139,.22);border:1px solid rgba(250,204,21,.45);border-radius:.9rem;color:var(--color-text);font-size:.9rem;line-height:1.5;margin-bottom:1.25rem;padding:.85rem 1rem}.simulation-notice strong{font-weight:600;margin-right:.25rem}.simulation-notice__text{display:inline}}@layer theme{html{background-color:var(--color-background);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{display:flex;flex-direction:column;margin:0;min-height:100vh;padding:0}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin:0 0 var(--space-2)}h1{font-size:var(--font-size-3xl);letter-spacing:-.02em}h2{font-size:var(--font-size-2xl);letter-spacing:-.015em}h3{font-size:var(--font-size-xl);letter-spacing:-.01em}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-base)}p{line-height:var(--line-height-relaxed);margin:0 0 var(--space-4)}a{color:var(--color-primary);text-decoration:none;transition:var(--transition-default)}a:hover{color:var(--color-primary-hover);text-decoration:underline}.container{margin:0 auto}.container,.container-fluid{padding:0 var(--space-2);width:100%}.card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition-default)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{background-color:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.card-body,.card-footer,.card-header{padding:var(--space-4)}.card-footer{background-color:var(--color-surface-alt);border-top:1px solid var(--color-border)}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition-default)}.panel:hover{box-shadow:var(--shadow-md)}.btn{align-items:center;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-2);justify-content:center;line-height:var(--line-height-none);padding:var(--space-3) var(--space-4);text-decoration:none;transition:var(--transition-default);white-space:nowrap}.btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:var(--color-primary);box-shadow:var(--shadow-xs);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-active);box-shadow:var(--shadow-xs);transform:translateY(0)}.btn-secondary{background-color:var(--color-secondary);box-shadow:var(--shadow-xs);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--color-secondary-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary:active:not(:disabled){background-color:var(--color-secondary-active);box-shadow:var(--shadow-xs);transform:translateY(0)}.btn-outline{background-color:transparent;border-color:var(--color-primary);color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:rgba(var(--color-primary-rgb),.1);border-color:var(--color-primary-hover);color:var(--color-primary-hover)}.btn-text{background-color:transparent;border-color:transparent;color:var(--color-primary);padding:var(--space-3)}.btn-text:hover:not(:disabled){background-color:rgba(var(--color-primary-rgb),.1);color:var(--color-primary-hover)}.btn-sm{font-size:var(--font-size-xs);padding:var(--space-2) var(--space-3)}.btn-lg{font-size:var(--font-size-base);padding:var(--space-4) var(--space-5)}.form-group{margin-bottom:var(--space-4)}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.form-control,.form-label{color:var(--color-text);display:block}.form-control{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-sizing:border-box;font-size:var(--font-size-base);line-height:var(--line-height-normal);padding:var(--space-3) var(--space-4);transition:var(--transition-default);width:100%}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(52,152,219,.2);outline:none}.form-control::-moz-placeholder{color:var(--color-text-tertiary)}.form-control::placeholder{color:var(--color-text-tertiary)}.status-dot{background-color:var(--color-text-tertiary);border-radius:50%;display:inline-block;height:10px;width:10px}.status-dot.active{background-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(46,204,113,.3)}.loading-spinner{animation:spin 1s linear infinite;border:2px solid rgba(52,152,219,.2);border-radius:50%;border-top:2px solid var(--color-primary);display:inline-block;height:20px;width:20px}@media(max-width:768px){h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}.container{padding:0 var(--space-3)}.card,.panel{border-radius:var(--radius-md)}.btn{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3)}.btn-lg{padding:var(--space-3) var(--space-4)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease forwards}:root{--glass-bg:hsla(0,0%,100%,.85);--glass-border:hsla(0,0%,100%,.4);--glass-border-hover:rgba(52,152,219,.3);--glass-blur:blur(20px) saturate(180%);--glass-blur-light:blur(16px) saturate(150%);--glass-shadow:0 8px 32px rgba(31,38,135,.12),0 2px 8px rgb(0 0 0/4%);--glass-shadow-hover:0 16px 48px rgba(31,38,135,.18),0 8px 24px rgb(0 0 0/8%);--glass-inset:inset 0 1px 1px hsla(0,0%,100%,.6);--glass-transition:all .4s cubic-bezier(.4,0,.2,1)}.dashboard-frame .panel,.panel.trading-panel{backdrop-filter:var(--glass-blur);background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow),var(--glass-inset);overflow:hidden;position:relative;transition:var(--glass-transition)}.dashboard-frame .panel:before,.panel.trading-panel:before{background:linear-gradient(90deg,rgba(52,152,219,.8),rgba(46,204,113,.8) 50%,rgba(52,152,219,.8));border-radius:var(--radius-xl) var(--radius-xl) 0 0;content:"";height:3px;left:0;opacity:.9;position:absolute;right:0;top:0;z-index:1}.dashboard-frame .panel:hover,.panel.trading-panel:hover{border-color:var(--glass-border-hover);box-shadow:var(--glass-shadow-hover),inset 0 1px 1px rgba(255,255,255,.8);transform:translateY(-4px)}.dashboard-frame .map-panel{backdrop-filter:blur(24px) saturate(180%);background:rgba(255,255,255,.9)}.dashboard-frame .markets-panel{background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(240,248,255,.85))}.dashboard-frame .rankings-panel{background:linear-gradient(135deg,rgba(255,255,255,.88),rgba(248,250,255,.85))}.dashboard-frame .news-panel{background:rgba(255,255,255,.87)}.dashboard-frame .card,.panel .card{backdrop-filter:var(--glass-blur-light);background:rgba(255,255,255,.8);border:1px solid hsla(0,0%,100%,.35);box-shadow:0 4px 24px rgba(31,38,135,.1),0 1px 4px rgba(0,0,0,.03);transition:all .3s cubic-bezier(.4,0,.2,1)}.dashboard-frame .card:hover,.panel .card:hover{box-shadow:0 8px 32px rgba(31,38,135,.15),0 2px 8px rgba(0,0,0,.05);transform:translateY(-3px)}.dashboard-frame .quote-item,.panel .quote-item{backdrop-filter:blur(12px) saturate(140%);background:rgba(255,255,255,.75);border:1px solid hsla(0,0%,100%,.3);box-shadow:0 2px 16px rgba(31,38,135,.08),0 1px 3px rgba(0,0,0,.02),inset 0 .5px .5px rgba(255,255,255,.5);transition:all .25s cubic-bezier(.4,0,.2,1)}.dashboard-frame .quote-item:hover,.panel .quote-item:hover{border-color:rgba(52,152,219,.25);box-shadow:0 6px 24px rgba(31,38,135,.12),0 2px 6px rgba(0,0,0,.04),inset 0 .5px .5px rgba(255,255,255,.7);transform:translateY(-2px) scale(1.02)}.dashboard-frame .ranking-item,.rankings-panel .ranking-item{backdrop-filter:blur(10px) saturate(130%);background:rgba(255,255,255,.7);border:1px solid hsla(0,0%,100%,.25);box-shadow:0 2px 12px rgba(31,38,135,.06),inset 0 .5px .5px rgba(255,255,255,.4);transition:all .25s cubic-bezier(.4,0,.2,1)}.dashboard-frame .ranking-item:hover,.rankings-panel .ranking-item:hover{background:rgba(255,255,255,.85);border-color:rgba(52,152,219,.2);box-shadow:0 4px 20px rgba(31,38,135,.1),0 2px 6px rgba(0,0,0,.03),inset 0 .5px .5px rgba(255,255,255,.6);transform:translate(4px) scale(1.01)}}@layer theme{@media(max-width:768px){.dashboard-frame .panel,.panel.trading-panel{backdrop-filter:blur(16px) saturate(160%)}.dashboard-frame .panel:hover,.panel.trading-panel:hover{transform:translateY(-2px)}}@media(prefers-reduced-motion:reduce){.dashboard-frame .card,.dashboard-frame .panel,.dashboard-frame .ranking-item,.panel.trading-panel{transition:none}.dashboard-frame .card:hover,.dashboard-frame .panel:hover,.dashboard-frame .ranking-item:hover,.panel.trading-panel:hover{transform:none}}}@layer theme{*{transition:transform var(--transition-default),box-shadow var(--transition-default),background-color var(--transition-default),border-color var(--transition-default),opacity var(--transition-default)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.fade-in-up{animation:fadeInUp .6s ease-out forwards}.fade-in-left{animation:fadeInLeft .6s ease-out forwards}.fade-in-right{animation:fadeInRight .6s ease-out forwards}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes breathe{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}@keyframes wiggle{0%,7%{transform:rotate(0)}15%{transform:rotate(-15deg)}20%{transform:rotate(10deg)}25%{transform:rotate(-10deg)}30%{transform:rotate(6deg)}35%{transform:rotate(-4deg)}40%,to{transform:rotate(0)}}@keyframes bounce{0%,20%,53%,80%,to{transform:translateZ(0)}40%,43%{transform:translate3d(0,-8px,0)}70%{transform:translate3d(0,-4px,0)}90%{transform:translate3d(0,-2px,0)}}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.slide-in-top{animation:slideInFromTop .5s ease-out forwards}.slide-in-bottom{animation:slideInFromBottom .5s ease-out forwards}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.gradient-animate{animation:gradientShift 8s ease infinite;background:linear-gradient(-45deg,var(--color-primary),var(--color-secondary),var(--color-accent),var(--color-primary));background-size:400% 400%}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.shimmer{animation:shimmer 2s infinite;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.4),transparent);background-size:200px 100%}@keyframes typewriter{0%{width:0}to{width:100%}}@keyframes blinkCursor{0%,to{border-color:transparent}50%{border-color:var(--color-primary)}}.counter.animate{animation:countUp 2s ease-out forwards}@keyframes countUp{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes progressFill{0%{width:0}to{width:var(--progress-width,100%)}}.progress-bar{animation:progressFill 2s ease-out forwards}@keyframes ripple{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(4)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.float{animation:float 3s ease-in-out infinite}@keyframes heartbeat{0%,50%,to{transform:scale(1)}10%,5%{transform:scale(1.1)}}@keyframes swing{20%{transform:rotate(15deg)}40%{transform:rotate(-10deg)}60%{transform:rotate(5deg)}80%{transform:rotate(-5deg)}to{transform:rotate(0)}}.swing{animation:swing 1s ease-in-out;transform-origin:top center}@keyframes flip{0%{transform:perspective(400px) rotateY(0)}to{transform:perspective(400px) rotateY(180deg)}}@keyframes scalePulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@media(prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms;animation-iteration-count:1;transition-duration:.01ms}}@media(max-width:768px){.fade-in-left,.fade-in-right,.fade-in-up{animation-duration:.4s}.delay-1{animation-delay:.05s}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}}.interactive{cursor:pointer;transition:all var(--transition-default);-webkit-user-select:none;-moz-user-select:none;user-select:none}.interactive:hover{transform:translateY(-2px)}.interactive:active{transform:translateY(0);transition-duration:.1s}.interactive:focus{outline:2px solid var(--color-primary);outline-offset:2px}.loading-skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,rgba(52,152,219,.1),rgba(52,152,219,.2) 50%,rgba(52,152,219,.1));background-size:200px 100%}.loading-dots:after{animation:loadingDots 1.5s infinite;content:""}@keyframes loadingDots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}}@layer enhancements{#mainMap.echarts-map{background:linear-gradient(180deg,rgba(52,152,219,.03),rgba(52,152,219,.06));border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);height:clamp(420px,65vh,800px);min-height:480px;overflow:hidden;position:relative;width:100%}#mainMap.echarts-map:before{background:radial-gradient(circle at center,rgba(52,152,219,.05) 0,transparent 70%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}@media(max-width:768px){#mainMap.echarts-map{border-radius:var(--radius-lg);height:clamp(360px,58vh,600px);min-height:400px}}.map-toolbar{backdrop-filter:blur(10px);background:rgba(255,255,255,.9);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2);position:absolute;right:var(--space-4);top:var(--space-4);z-index:10}.map-toolbar .btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);height:40px;padding:0;width:40px}.map-toolbar .btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.atlas-overlay{backdrop-filter:blur(10px);background:rgba(255,255,255,.9);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);left:var(--space-4);padding:var(--space-3) var(--space-4);position:absolute;top:var(--space-4);z-index:10}.atlas-breadcrumb{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--space-2)}.atlas-breadcrumb .separator{color:var(--color-text-tertiary)}.atlas-breadcrumb .current{color:var(--color-text);font-weight:var(--font-weight-medium)}.map-legend-container{backdrop-filter:blur(10px);background:rgba(255,255,255,.9);border:1px solid var(--color-border);border-radius:var(--radius-lg);bottom:var(--space-4);box-shadow:var(--shadow-lg);max-width:300px;padding:var(--space-3) var(--space-4);position:absolute;right:var(--space-4);z-index:10}.map-legend-title{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-2)}.legend-items{flex-direction:column}.legend-item,.legend-items{display:flex;gap:var(--space-2)}.legend-item{align-items:center;font-size:var(--font-size-xs)}.legend-color{border-radius:var(--radius-sm);height:12px;width:20px}.echarts-tooltip{backdrop-filter:blur(10px);background:rgba(255,255,255,.95);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-4)}.echarts-tooltip h4{color:var(--color-text);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-2)}.echarts-tooltip-item{display:flex;font-size:var(--font-size-sm);justify-content:space-between;margin-bottom:var(--space-1)}.echarts-tooltip-label{color:var(--color-text-secondary)}.echarts-tooltip-value{color:var(--color-text);font-weight:var(--font-weight-medium)}.echarts-tooltip-value.positive{color:var(--color-positive)}.echarts-tooltip-value.negative{color:var(--color-negative)}.echarts-map .echarts-map-area:hover{filter:brightness(1.1);transition:filter .2s ease}@media(max-width:768px){.map-toolbar{padding:var(--space-1);right:var(--space-3);top:var(--space-3)}.map-toolbar .btn{height:36px;width:36px}.atlas-overlay{left:var(--space-3);top:var(--space-3)}.atlas-overlay,.map-legend-container{padding:var(--space-2) var(--space-3)}.map-legend-container{bottom:var(--space-3);max-width:250px;right:var(--space-3)}.legend-item,.map-legend-title{font-size:var(--font-size-xs)}.legend-color{height:10px;width:16px}}}@layer enhancements{.main-header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(248,249,250,.98));border-bottom:1px solid rgba(52,152,219,.1);box-shadow:0 4px 20px rgba(0,0,0,.08);position:sticky;top:0;transition:all var(--transition-default);z-index:1000}.main-header:before{background:var(--gradient-primary);content:"";height:3px;left:0;opacity:.8;position:absolute;right:0;top:0}.header-content{display:block;margin:0 auto;max-width:100%;padding:clamp(8px,1vw,12px) 5px}.header-hero{border:1px solid rgba(52,152,219,.12);border-radius:var(--radius-xl);box-shadow:0 8px 24px rgba(15,23,42,.08);overflow:hidden;position:relative}.header-hero__bg{background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(244,248,255,.92));top:0;right:0;bottom:0;left:0;position:absolute;z-index:0}.header-hero__glow{background:radial-gradient(circle at 10% 20%,rgba(52,152,219,.15),transparent 50%),radial-gradient(circle at 90% 10%,rgba(46,204,113,.12),transparent 45%);top:0;right:0;bottom:0;left:0;opacity:.7;position:absolute;z-index:0}.header-top{align-items:center;border-bottom:1px solid rgba(52,152,219,.08);display:flex;gap:var(--space-3);justify-content:space-between;padding:var(--space-4) var(--space-5);position:relative;z-index:1}.header-top__center,.header-top__left{flex:0 0 auto}.header-top__right{align-items:center;display:flex;flex:0 0 auto;gap:var(--space-4,16px);min-width:0}.logo-section{color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:8px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.logo-section:hover{transform:translateY(-2px)}.logo-section h1{align-items:center;display:flex;gap:12px;margin:0}.brand-logo{border-radius:12px;box-shadow:0 4px 12px rgba(59,130,246,.25),0 2px 4px rgba(0,0,0,.1);height:42px;transition:all .3s cubic-bezier(.4,0,.2,1);width:42px}.logo-section:hover .brand-logo{box-shadow:0 6px 16px rgba(59,130,246,.35),0 3px 6px rgba(0,0,0,.12);transform:scale(1.08) rotate(-3deg)}.brand-text{background:linear-gradient(135deg,#1e3a5f,#3b82f6);-webkit-background-clip:text;font-size:1.6rem;font-weight:800;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;line-height:1.2}.compliance-badge{align-items:center;background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(37,99,235,.05));border:1px solid rgba(59,130,246,.15);border-radius:20px;color:#3b82f6;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:5px 12px;transition:all .3s ease}.compliance-badge:hover{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(37,99,235,.08));border-color:rgba(59,130,246,.25);transform:translate(2px)}.badge-icon{font-size:13px}.badge-text{white-space:nowrap}.user-actions{display:flex}.header-auth-card{align-items:center;backdrop-filter:blur(12px);background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(59,130,246,.12);border-radius:16px;box-shadow:0 2px 8px rgba(0,0,0,.04),0 4px 16px rgba(59,130,246,.08);display:flex;gap:20px;overflow:hidden;padding:14px 24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.header-auth-card:before{background:linear-gradient(90deg,#3b82f6,#60a5fa,#3b82f6);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.header-auth-card:hover{border-color:rgba(59,130,246,.2);box-shadow:0 6px 20px rgba(0,0,0,.08),0 8px 24px rgba(59,130,246,.15);transform:translateY(-2px)}.header-auth-card:hover:before{opacity:1}.header-auth-card--signed{background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(240,248,255,.98));border-color:rgba(52,152,219,.25);min-width:200px;overflow:visible}.header-auth-card__user{align-items:center;border-radius:8px;color:inherit;cursor:pointer;display:flex;flex:1;gap:12px;margin:-6px;padding:6px;text-decoration:none;transition:background .2s ease}.header-auth-card__user:hover{background:rgba(52,152,219,.08)}.header-auth-card__avatar{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px rgba(52,152,219,.35);color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:44px;justify-content:center;min-width:44px;width:44px}.header-auth-card__meta{display:flex;flex-direction:column;gap:2px;min-width:80px}.header-auth-card__badge{color:#27ae60;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.header-auth-card__name{color:#1a1a2e;font-size:14px;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-auth-card__body{flex:1;min-width:0}.header-auth-card__eyebrow{color:#3b82f6;font-size:13px;font-weight:700;letter-spacing:.02em;margin:0 0 4px}.header-auth-card__hint{color:#64748b;font-size:12px;line-height:1.5;margin:0;max-width:220px}.header-auth-card__actions{display:flex;flex-shrink:0;gap:var(--space-2)}.header-auth-card__btn{font-size:var(--font-size-sm);min-width:80px;padding:var(--space-2) var(--space-4)}.update-time-badge{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(59,130,246,.15);border-radius:24px;box-shadow:0 2px 8px rgba(0,0,0,.04),0 4px 12px rgba(59,130,246,.08);display:inline-flex;font-size:13px;gap:8px;padding:8px 16px;transition:all .3s ease;white-space:nowrap}.update-time-badge:hover{border-color:rgba(59,130,246,.25);box-shadow:0 4px 12px rgba(0,0,0,.06),0 6px 16px rgba(59,130,246,.12)}.update-time-icon{font-size:14px}.update-time-label{color:#64748b;font-weight:500}.update-time-value{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(37,99,235,.05));border-radius:12px;color:#1e293b;font-variant-numeric:tabular-nums;font-weight:700;padding:3px 10px}.header-metrics{padding:var(--space-4) var(--space-5);position:relative;z-index:1}.market-overview{align-items:start;display:grid;gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr))}.market-indicator{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(59,130,246,.1);border-radius:14px;box-shadow:0 2px 6px rgba(0,0,0,.02),0 4px 12px rgba(59,130,246,.04);display:flex;flex-direction:column;gap:6px;height:100%;overflow:hidden;padding:16px 20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.market-indicator:before{background:linear-gradient(180deg,#3b82f6,#60a5fa);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:4px}.market-indicator:hover{background:linear-gradient(135deg,#fff,#f0f7ff);border-color:rgba(59,130,246,.2);box-shadow:0 6px 16px rgba(0,0,0,.06),0 8px 24px rgba(59,130,246,.1);transform:translateY(-3px)}.market-indicator:hover:before{opacity:1}.market-indicator:first-child{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(37,99,235,.04));border-color:rgba(59,130,246,.15)}.market-indicator:first-child:before{opacity:1}.indicator-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.indicator-value{color:#1e293b;font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:800;letter-spacing:-.02em;line-height:1.2}.indicator-change{align-items:center;border-radius:8px;display:inline-flex;font-size:12px;font-weight:700;padding:3px 8px;width:-moz-fit-content;width:fit-content}.indicator-change.positive{background:rgba(239,68,68,.1);color:#dc2626}.indicator-change.negative{background:rgba(34,197,94,.1);color:#16a34a}@media(max-width:1023px){.header-top__center{flex-basis:100%;order:3;text-align:center}.market-overview{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr))}.header-auth-card__hint{display:none}.header-auth-card{gap:var(--space-3);padding:var(--space-3)}}@media(max-width:768px){.header-content{padding:var(--space-3) var(--space-2)}.header-top{align-items:stretch;flex-direction:column;gap:var(--space-3);padding:var(--space-4) var(--space-3)}.header-top__center,.header-top__left,.header-top__right{width:100%}.header-top__center{order:2}.update-time-badge{justify-content:center}.logo-section{align-items:center;text-align:center}.logo-section h1{font-size:1.5rem}.badge-text{display:none}.user-actions{width:100%}.header-auth-card{align-items:stretch;flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.header-auth-card--signed{align-items:center;flex-direction:row;justify-content:space-between;padding:var(--space-3) var(--space-4)}.header-auth-card--signed .header-auth-card__user{display:flex;flex:1}.header-auth-card--signed .header-auth-card__actions{flex-direction:row}.header-auth-card__body{text-align:center}.header-auth-card__eyebrow{font-size:var(--font-size-sm)}.header-auth-card__hint{display:none}.header-auth-card__actions{flex-direction:column;gap:var(--space-2)}.header-auth-card__btn{justify-content:center;min-height:44px;width:100%}.header-metrics{gap:var(--space-3);padding:var(--space-4) var(--space-3)}.market-overview{gap:var(--space-2);grid-template-columns:1fr}.market-indicator{padding:var(--space-3) var(--space-4)}.market-indicator:hover{transform:none}}@media(max-width:479px){.header-content{padding:var(--space-2)}.header-metrics,.header-top{padding:var(--space-3) var(--space-2)}.logo-section h1{font-size:1.25rem}.market-indicator{padding:var(--space-2) var(--space-3)}.indicator-value{font-size:1.125rem}}.ticker-bar{background:linear-gradient(135deg,rgba(15,23,42,.03),rgba(59,130,246,.05) 50%,rgba(15,23,42,.03));border-bottom:1px solid rgba(59,130,246,.12);border-top:1px solid rgba(59,130,246,.12);box-shadow:inset 0 1px 2px rgba(0,0,0,.02),0 1px 3px rgba(59,130,246,.05);overflow:hidden;padding:12px 0;position:relative;white-space:nowrap}.ticker-bar:after,.ticker-bar:before{bottom:0;content:"";pointer-events:none;position:absolute;top:0;width:60px;z-index:2}.ticker-bar:before{background:linear-gradient(90deg,rgba(255,255,255,.95),rgba(255,255,255,0));left:0}.ticker-bar:after{background:linear-gradient(270deg,rgba(255,255,255,.95),rgba(255,255,255,0));right:0}.ticker-track{animation:ticker-left 40s linear infinite;display:inline-flex;gap:16px;padding:0 8px;will-change:transform}.ticker-bar:hover .ticker-track{animation-play-state:paused}@keyframes ticker-left{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(prefers-reduced-motion:reduce){.ticker-track{animation:none}}.ticker-item{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(59,130,246,.15);border-radius:10px;box-shadow:0 2px 4px rgba(0,0,0,.04),0 4px 8px rgba(59,130,246,.06);cursor:pointer;display:inline-flex;gap:10px;overflow:hidden;padding:8px 16px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.ticker-item:before{background:linear-gradient(180deg,#3b82f6,#60a5fa);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:3px}.ticker-item:hover{background:linear-gradient(135deg,#fff,#eff6ff);border-color:rgba(59,130,246,.3);box-shadow:0 4px 8px rgba(0,0,0,.06),0 8px 16px rgba(59,130,246,.12);transform:translateY(-2px) scale(1.02)}.ticker-item:hover:before{opacity:1}.ticker-name{color:#1e293b;font-size:13px;font-weight:600;letter-spacing:-.01em;white-space:nowrap}.ticker-price{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(37,99,235,.05));color:#3b82f6;font-size:14px;letter-spacing:-.02em;padding:3px 8px}.ticker-change,.ticker-price{border-radius:6px;font-family:var(--font-family-mono,"SF Mono","Monaco",monospace);font-weight:700}.ticker-change{align-items:center;display:inline-flex;font-size:12px;gap:2px;letter-spacing:-.01em;padding:4px 10px}.ticker-change.positive{background:linear-gradient(135deg,rgba(239,68,68,.12),rgba(220,38,38,.08));border:1px solid rgba(239,68,68,.2);color:#dc2626}.ticker-change.positive:before{content:"▲";font-size:8px;margin-right:2px}.ticker-change.negative{background:linear-gradient(135deg,rgba(34,197,94,.12),rgba(22,163,74,.08));border:1px solid rgba(34,197,94,.2);color:#16a34a}.ticker-change.negative:before{content:"▼";font-size:8px;margin-right:2px}@media(max-width:768px){.ticker-bar{padding:10px 0}.ticker-bar:after,.ticker-bar:before{width:30px}.ticker-item{gap:8px;padding:6px 12px}.ticker-name,.ticker-price{font-size:12px}.ticker-price{padding:2px 6px}.ticker-change{font-size:11px;padding:3px 8px}}#loginBtn{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;box-shadow:0 4px 12px rgba(59,130,246,.35);color:#fff;font-size:14px;font-weight:600;padding:10px 24px;transition:all .3s cubic-bezier(.4,0,.2,1)}#loginBtn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 24px rgba(59,130,246,.45);transform:translateY(-2px)}#registerBtn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;box-shadow:0 4px 12px rgba(16,185,129,.35);color:#fff;font-size:14px;font-weight:700;padding:10px 24px;transition:all .3s cubic-bezier(.4,0,.2,1)}#registerBtn:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 8px 24px rgba(16,185,129,.45);color:#fff;transform:translateY(-2px)}#logoutBtn{background:linear-gradient(135deg,var(--color-danger),#c0392b);box-shadow:0 4px 12px rgba(var(--color-error-rgb),.3);color:#fff}#logoutBtn:hover{box-shadow:0 8px 20px rgba(var(--color-error-rgb),.4);transform:translateY(-2px)}.main-content{background:linear-gradient(135deg,rgba(248,249,250,.8),rgba(240,248,255,.6) 50%,rgba(248,249,250,.8));flex:1;min-height:calc(100vh - 120px);padding:var(--space-2) 5px}.dashboard-frame{display:grid;gap:var(--space-3);grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto auto;margin:0 auto;max-width:100%;padding:0 5px}.compliance-banner{background:linear-gradient(135deg,rgba(255,193,7,.1),rgba(255,152,0,.1));border:1px solid rgba(255,193,7,.3);border-radius:var(--radius-md);grid-column:1/-1;margin-bottom:var(--space-2);overflow:hidden;padding:var(--space-2) var(--space-3);position:relative}.compliance-banner:before{animation:warning-pulse 2s ease-in-out infinite;background:linear-gradient(90deg,var(--color-warning),var(--color-danger),var(--color-warning));content:"";height:3px;left:0;position:absolute;right:0;top:0}}@layer enhancements{@keyframes warning-pulse{0%,to{opacity:.6}50%{opacity:1}}.compliance-banner__content p{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin:0;text-align:center}.panel{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(248,249,250,.9));border:1px solid rgba(52,152,219,.15);border-radius:var(--radius-xl);box-shadow:0 4px 20px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1);overflow:hidden;position:relative;transition:all var(--transition-default)}.panel:before{background:var(--gradient-primary);content:"";height:4px;left:0;opacity:.8;position:absolute;right:0;top:0}.panel:hover{border-color:rgba(52,152,219,.25);box-shadow:0 12px 40px rgba(0,0,0,.12),0 4px 12px rgba(52,152,219,.15);transform:translateY(-4px)}.map-panel{background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(240,248,255,.95));grid-column:1/-1}.map-panel:before{background:linear-gradient(90deg,var(--color-primary),var(--color-accent),var(--color-primary))}.markets-panel,.rankings-panel{grid-column:1/-1}.news-panel{grid-column:1}.activities-panel{grid-column:2}.watchlist-stack{grid-column:1}.gamify-panel{grid-column:2}.map-content{background:linear-gradient(135deg,rgba(240,248,255,.5),rgba(255,255,255,.8));padding:0}.map-content>#mainMap.echarts-map{border-radius:0 0 var(--radius-xl) var(--radius-xl);width:100%}.markets-panel .panel-body{padding:0}.stats-grid{display:grid;gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:0;padding:0}.stat-value{color:var(--color-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.stat-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.panel-grid{display:grid;gap:var(--space-4)}.panel-grid.cols-3{grid-template-columns:repeat(3,1fr)}.stream-status{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-2)}.status-dot{background:var(--color-text-tertiary);border-radius:50%;height:8px;width:8px}.status-dot.active{animation:pulse 2s infinite;background:var(--color-secondary);box-shadow:0 0 0 3px rgba(46,204,113,.3)}.news-feed{background:linear-gradient(135deg,rgba(240,248,255,.5),rgba(255,255,255,.8));border-radius:var(--radius-lg);padding:var(--space-4)}.marquee-container,.news-feed{overflow:hidden;position:relative}.marquee-container{height:480px;mask-image:linear-gradient(180deg,transparent,#000 5%,#000 95%,transparent);-webkit-mask-image:linear-gradient(180deg,transparent,#000 5%,#000 95%,transparent);padding:var(--space-2) 0}.marquee-content{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);position:relative;width:100%}.news-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:var(--space-3);overflow:hidden;padding:var(--space-4);position:relative;transition:all .2s ease}.news-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.news-card:before{background:var(--color-primary);bottom:0;content:"";left:0;opacity:.6;position:absolute;top:0;width:3px}.news-card__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-2)}.news-card__time{background:var(--color-surface-alt);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-family-mono);font-size:var(--font-size-xs);padding:2px 6px}.news-card__category{border-radius:10px;font-size:10px;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.news-card__title{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);line-height:1.4;margin:0 0 var(--space-2) 0}.news-card__summary{color:var(--color-text-secondary);display:-webkit-box;font-size:var(--font-size-xs);-webkit-line-clamp:3;line-clamp:3;line-height:1.6;margin:0 0 var(--space-3) 0;-webkit-box-orient:vertical;overflow:hidden}.news-card__footer{align-items:center;border-top:1px solid var(--color-divider);color:var(--color-text-tertiary);display:flex;font-size:var(--font-size-xs);justify-content:space-between;margin-top:var(--space-2);padding-top:var(--space-2)}.news-card__source{font-weight:var(--font-weight-medium)}.news-card__tags{display:flex;gap:6px}.news-card__tags .tag{background:rgba(52,152,219,.1);border-radius:4px;color:var(--color-primary);font-size:10px;padding:2px 6px}.feature-grid{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}#activitiesBoard,#activitiesBoard.feature-grid,.activities-panel .feature-grid,.watchlist{grid-template-columns:1fr 1fr}.watchlist{align-items:start;background:transparent;border-radius:var(--radius-lg);display:grid;gap:var(--space-4);min-height:0;padding:0}@media(max-width:768px){.watchlist{grid-template-columns:1fr}}.panel-actions{display:flex;gap:var(--space-2)}#gamifyPanel{display:flex;flex-direction:column;gap:0;padding:var(--space-3)}@media(max-width:1024px){.dashboard-frame{gap:var(--space-4);grid-template-columns:1fr;padding:0 var(--space-4)}.activities-panel,.gamify-panel,.map-panel,.markets-panel,.news-panel,.rankings-panel,.watchlist-stack{grid-column:1}.panel-grid.cols-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.main-content{padding:var(--space-4) 0}.dashboard-frame{gap:var(--space-3);padding:0 var(--space-3)}.panel-header{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.panel-body,.panel-header{padding:var(--space-4)}.panel-title{font-size:var(--font-size-lg)}.feature-grid,.stats-grid{grid-template-columns:1fr}.echarts-map{height:300px}}@media(max-width:480px){.dashboard-frame{padding:0 var(--space-2)}.compliance-banner,.panel-body,.panel-header{padding:var(--space-3)}.compliance-banner__content p{font-size:var(--font-size-xs)}}}@layer enhancements{.main-footer{margin-top:var(--space-1);padding:var(--space-1) 0}.main-footer .container{padding-left:var(--space-4);padding-right:var(--space-4)}.footer-shell{backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);background:rgba(255,255,255,.85);border:1px solid hsla(0,0%,100%,.45);border-radius:var(--radius-xl);box-shadow:0 18px 40px rgba(15,23,42,.08),0 6px 16px rgba(15,23,42,.05),inset 0 1px rgba(255,255,255,.7);overflow:hidden;padding:var(--space-6);position:relative}.footer-shell:before{background:linear-gradient(90deg,rgba(var(--color-primary-rgb),.85) 0,rgba(46,204,113,.75),rgba(var(--color-primary-rgb),.85));content:"";height:3px;left:0;opacity:.9;position:absolute;right:0;top:0}.footer-content{display:grid;gap:var(--space-6);grid-template-columns:1.6fr 1fr 1fr 1fr}.footer-section--brand{padding-right:var(--space-2)}.footer-brand{align-items:center;color:var(--color-text);display:inline-flex;gap:var(--space-3);text-decoration:none}.footer-logo{border-radius:8px;box-shadow:0 8px 16px rgba(15,23,42,.12);height:28px;width:28px}.footer-brand-text{display:flex;flex-direction:column;gap:2px;line-height:1.1}.footer-brand-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:.02em}.footer-brand-sub{color:var(--color-text-secondary);font-size:var(--font-size-xs);letter-spacing:.08em;text-transform:uppercase}.footer-title{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);margin:0 0 var(--space-3)}.footer-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6;margin:var(--space-3) 0 0}.footer-badges{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}.footer-badge{align-items:center;background:rgba(var(--color-primary-rgb),.08);border:1px solid rgba(var(--color-primary-rgb),.18);border-radius:var(--radius-full);color:var(--color-text-secondary);display:inline-flex;font-size:var(--font-size-xs);gap:6px;padding:6px 10px}.footer-links{display:grid;gap:10px;list-style:none;margin:0;padding:0}.footer-links a{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-decoration:none;transition:color var(--duration-fast) var(--ease-standard)}.footer-links a:hover{color:var(--color-primary)}.footer-actions{margin-top:var(--space-3)}.footer-note{font-size:var(--font-size-sm);line-height:1.6;margin:var(--space-3) 0 0}.footer-bottom,.footer-note{color:var(--color-text-tertiary)}.footer-bottom{align-items:center;border-top:1px solid var(--color-divider);display:flex;font-size:var(--font-size-xs);gap:var(--space-4);justify-content:space-between;margin-top:var(--space-5);padding-top:var(--space-4)}.footer-link-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;padding:6px 10px;transition:background var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard)}.footer-link-btn:hover{background:rgba(var(--color-primary-rgb),.08);color:var(--color-primary)}@media(max-width:980px){.footer-content{grid-template-columns:1.2fr 1fr 1fr}}@media(max-width:768px){.main-footer{margin-top:var(--space-6);padding:var(--space-6) 0}.footer-shell{padding:var(--space-5)}.footer-content{gap:var(--space-5);grid-template-columns:1fr}.footer-bottom{align-items:flex-start;flex-direction:column}}@media(max-width:480px){.footer-shell{padding:var(--space-4)}.footer-badges{gap:6px}}}:root{--brand-primary:#3498db;--brand-primary-dark:#2980b9;--color-success:#2ecc71;--color-warning:#f59e0b;--color-danger:#e74c3c;--color-info:#3498db;--gray-100:#f1f3f4;--gray-400:#bdc1c6;--color-primary:var(--brand-primary);--color-surface:#fff;--color-surface-alt:var(--gray-100);--color-text:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-border:rgba(0,0,0,.08);--color-primary-rgb:52,152,219;--color-success-rgb:46,204,113;--color-warning-rgb:245,158,11;--color-danger-rgb:231,76,60;--color-info-rgb:52,152,219;--gradient-primary:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-dark));--font-size-xs:11px;--font-size-sm:12px;--font-size-base:15px;--font-size-lg:18px;--font-weight-medium:500;--font-weight-semibold:600;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-12:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:10px;--radius-full:9999px;--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--duration-normal:.2s;--duration-slow:.3s;--transition-default:all .2s ease;--ease-standard:cubic-bezier(.4,0,.2,1);--btn-focus-shadow:0 0 0 3px rgba(52,152,219,.35);--btn-disabled-opacity:.55;--color-btn-primary-text:#fcfcf9}.text-muted{color:var(--color-text-secondary)}.ui-btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);gap:var(--space-2);justify-content:center;line-height:1.4;outline:none;padding:var(--space-2) var(--space-4);transition:var(--transition-default)}.ui-btn:focus-visible{box-shadow:var(--btn-focus-shadow)}.ui-btn--primary{background:var(--gradient-primary);color:var(--color-btn-primary-text)}.ui-btn--primary:hover:not(:disabled){filter:brightness(1.1)}.ui-btn--secondary{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text)}.ui-btn--secondary:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-primary)}.ui-btn--ghost{background:transparent;color:var(--color-text)}.ui-btn--ghost:hover:not(:disabled){background:rgba(var(--color-primary-rgb),.1)}.ui-btn--danger{background:var(--color-danger);color:#fff}.ui-btn--sm{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-3)}.ui-btn--lg{font-size:var(--font-size-lg);padding:var(--space-3) var(--space-6)}.ui-btn--disabled,.ui-btn:disabled{cursor:not-allowed;opacity:var(--btn-disabled-opacity)}.ui-btn--loading .ui-btn__spinner{animation:spin .8s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid transparent;height:16px;width:16px}.ui-btn-group{display:inline-flex}.ui-btn-group .ui-btn:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.ui-btn-group .ui-btn:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.ui-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.ui-card--elevated{box-shadow:var(--shadow-md)}.ui-card--hoverable{cursor:pointer;transition:var(--transition-default)}.ui-card--hoverable:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.ui-card__header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-4)}.ui-card__title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.ui-card__subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:var(--space-1) 0 0}.ui-card__body{padding:var(--space-4)}.ui-card__footer{align-items:center;background:var(--color-surface-alt);border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.ui-modal-container{top:0;right:0;bottom:0;left:0;pointer-events:none;position:fixed;z-index:1000}.ui-modal{align-items:center;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;opacity:0;pointer-events:auto;position:fixed;transition:opacity var(--duration-normal),visibility var(--duration-normal);visibility:hidden}.ui-modal--open{opacity:1;visibility:visible}.ui-modal--closing{opacity:0}.ui-modal__overlay{background:rgba(0,0,0,.5);top:0;right:0;bottom:0;left:0;position:absolute}.ui-modal__content{animation:modalSlideIn var(--duration-normal) var(--ease-standard);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-height:90vh;overflow:auto;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.ui-modal--sm{max-width:90vw;width:400px}.ui-modal--md{max-width:90vw;width:560px}.ui-modal--lg{max-width:90vw;width:800px}.ui-modal--xl{max-width:90vw;width:1100px}.ui-modal--full{height:95vh;width:95vw}.ui-modal__header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-4) var(--space-5)}.ui-modal__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.ui-modal__close{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:24px;line-height:1;padding:var(--space-1);transition:var(--transition-default)}.ui-modal__close:hover{color:var(--color-text)}.ui-modal__body{padding:var(--space-5)}.ui-modal__footer{border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-4) var(--space-5)}.ui-toast-container{flex-direction:column;pointer-events:none;position:fixed;right:var(--space-4);top:var(--space-4);z-index:2000}.ui-toast,.ui-toast-container{display:flex;gap:var(--space-3)}.ui-toast{align-items:flex-start;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-width:400px;min-width:280px;opacity:0;padding:var(--space-3) var(--space-4);pointer-events:auto;transform:translate(100%);transition:all var(--duration-normal) var(--ease-standard)}.ui-toast--open{opacity:1;transform:translate(0)}.ui-toast--closing{opacity:0;transform:translate(100%)}.ui-toast--success{border-left:4px solid var(--color-success)}.ui-toast--error{border-left:4px solid var(--color-danger)}.ui-toast--warning{border-left:4px solid var(--color-warning)}.ui-toast--info{border-left:4px solid var(--color-info)}.ui-toast__icon{font-size:18px;line-height:1}.ui-toast__icon--success{color:var(--color-success)}.ui-toast__icon--error{color:var(--color-danger)}.ui-toast__icon--warning{color:var(--color-warning)}.ui-toast__icon--info{color:var(--color-info)}.ui-toast__content{flex:1}.ui-toast__title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.ui-toast__message{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.ui-toast__close{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:18px;line-height:1;padding:0}.ui-skeleton{background:var(--color-surface-alt);border-radius:var(--radius-sm)}.ui-skeleton--animated{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--color-surface-alt) 0,var(--color-surface) 50%,var(--color-surface-alt) 100%);background-size:200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ui-skeleton--text{height:1em;margin-bottom:var(--space-2)}.ui-skeleton--title{height:1.5em;margin-bottom:var(--space-3)}.ui-skeleton--avatar{border-radius:50%;height:40px;width:40px}.ui-skeleton--image{border-radius:var(--radius-md);height:160px}.ui-skeleton--card{border-radius:var(--radius-md);height:200px}.ui-skeleton-text{display:flex;flex-direction:column}.ui-skeleton-card{background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden}.ui-skeleton-card__body{padding:var(--space-4)}.ui-skeleton-list{display:flex;flex-direction:column;gap:var(--space-3)}.ui-skeleton-list__item{align-items:center;display:flex;gap:var(--space-3)}.ui-skeleton-list__content{flex:1}.ui-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.ui-empty__icon{color:var(--color-text-tertiary);height:80px;margin-bottom:var(--space-4);width:80px}.ui-empty__icon svg{height:100%;width:100%}.ui-empty__title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-2)}.ui-empty__description{color:var(--color-text-secondary);margin:0 0 var(--space-4);max-width:300px}.ui-loading{align-items:center;display:inline-flex;gap:var(--space-2)}.ui-loading__spinner,.ui-spinner{animation:spin .8s linear infinite;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.ui-loading--sm .ui-loading__spinner,.ui-spinner--sm{height:14px;width:14px}.ui-loading--lg .ui-loading__spinner,.ui-spinner--lg{border-width:3px;height:32px;width:32px}.ui-loading-overlay{align-items:center;background:rgba(255,255,255,.9);display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;position:fixed;z-index:9999}.ui-loading-overlay--blur{backdrop-filter:blur(4px)}.ui-loading-overlay__content{align-items:center;display:flex;flex-direction:column;gap:var(--space-3)}.ui-loading-overlay__text{color:var(--color-text-secondary);margin:0}.ui-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1;padding:var(--space-1) var(--space-2)}.ui-badge--default{background:var(--color-surface-alt);color:var(--color-text-secondary)}.ui-badge--primary{background:rgba(var(--color-primary-rgb),.15);color:var(--color-primary)}.ui-badge--success{background:rgba(var(--color-success-rgb),.15);color:var(--color-success)}.ui-badge--warning{background:rgba(var(--color-warning-rgb),.15);color:var(--color-warning)}.ui-badge--danger{background:rgba(var(--color-danger-rgb),.15);color:var(--color-danger)}.ui-badge--info{background:rgba(var(--color-info-rgb),.15);color:var(--color-info)}.ui-badge--sm{font-size:10px;padding:2px 6px}.ui-badge--lg{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3)}.ui-status-badge{align-items:center;display:inline-flex;gap:var(--space-1)}.ui-status-badge__dot{border-radius:50%;height:8px;width:8px}.ui-status-badge--success .ui-status-badge__dot{background:var(--color-success)}.ui-status-badge--warning .ui-status-badge__dot{background:var(--color-warning)}.ui-status-badge--danger .ui-status-badge__dot{background:var(--color-danger)}.ui-status-badge--info .ui-status-badge__dot{background:var(--color-info)}.ui-status-badge--default .ui-status-badge__dot{background:var(--gray-400)}.ui-count-badge{align-items:center;background:var(--color-danger);border-radius:var(--radius-full);color:#fff;display:inline-flex;font-size:12px;font-weight:var(--font-weight-medium);height:20px;justify-content:center;min-width:20px;padding:0 6px}.ui-count-badge--dot{height:8px;min-width:8px;padding:0;width:8px}.ui-progress{background:var(--color-surface-alt);border-radius:var(--radius-full);height:8px;overflow:hidden;position:relative}.ui-progress--sm{height:4px}.ui-progress--lg{height:12px}.ui-progress__bar{background:var(--gradient-primary);border-radius:var(--radius-full);height:100%;transition:width var(--duration-slow) var(--ease-standard)}.ui-progress--success .ui-progress__bar{background:var(--color-success)}.ui-progress--warning .ui-progress__bar{background:var(--color-warning)}.ui-progress--danger .ui-progress__bar{background:var(--color-danger)}.ui-progress__bar--striped{background-image:linear-gradient(45deg,hsla(0,0%,100%,.15) 25%,transparent 0,transparent 50%,hsla(0,0%,100%,.15) 0,hsla(0,0%,100%,.15) 75%,transparent 0,transparent);background-size:1rem 1rem}.ui-progress__bar--animated{animation:progressStripe 1s linear infinite}@keyframes progressStripe{0%{background-position:1rem 0}to{background-position:0 0}}.ui-progress__label{color:var(--color-text-secondary);font-size:var(--font-size-xs);position:absolute;right:var(--space-2);top:50%;transform:translateY(-50%)}.ui-circular-progress{align-items:center;display:inline-flex;justify-content:center;position:relative}.ui-circular-progress svg{height:100%;width:100%}.ui-circular-progress__track{stroke:var(--color-surface-alt)}.ui-circular-progress__indicator{stroke:var(--color-primary);transition:stroke-dashoffset var(--duration-slow) var(--ease-standard)}.ui-circular-progress--success .ui-circular-progress__indicator{stroke:var(--color-success)}.ui-circular-progress--warning .ui-circular-progress__indicator{stroke:var(--color-warning)}.ui-circular-progress--danger .ui-circular-progress__indicator{stroke:var(--color-danger)}.ui-circular-progress__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);position:absolute}
