:root{--bg-primary:#0a0e17;--bg-secondary:#0f1420;--bg-card:#141a28;--bg-card-hover:#1a2236;--bg-elevated:#1c2437;--bg-input:#0d1219;--bg-surface:#141a28b3;--border-primary:#303e5680;--border-subtle:#303e5640;--border-accent-green:#00e67659;--border-accent-blue:#42a5f559;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#596575;--text-inverse:#0a0e14;--accent-green:#00e676;--accent-green-dim:#00e6761f;--accent-green-bg:#00e6760f;--accent-blue:#42a5f5;--accent-blue-dim:#42a5f51f;--accent-blue-bg:#42a5f50f;--accent-red:#ef5350;--accent-red-dim:#ef53501f;--accent-red-bg:#ef53500f;--accent-orange:#ffa726;--accent-orange-dim:#ffa7261f;--accent-orange-bg:#ffa7260f;--accent-cyan:#26c6da;--accent-purple:#ab47bc;--gradient-primary:linear-gradient(135deg, #00e676 0%, #00c853 50%, #00bfa5 100%);--gradient-blue:linear-gradient(135deg, #42a5f5 0%, #1e88e5 100%);--gradient-hero:linear-gradient(135deg, #0a0e17 0%, #0f1f3d 50%, #0a0e17 100%);--gradient-card:linear-gradient(145deg, #141a28d9 0%, #0f1420f2 100%);--gradient-glass:linear-gradient(135deg, #ffffff08 0%, #ffffff03 100%);--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-glow-green:0 0 30px #00e6761a;--shadow-glow-blue:0 0 30px #42a5f51a;--shadow-glow-red:0 0 30px #ef53501a;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--transition-spring:.35s cubic-bezier(.34, 1.56, .64, 1);--font-primary:"Inter", "Noto Sans Thai", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);background-color:var(--bg-primary);color:var(--text-primary);background-image:radial-gradient(at 20% 0,#00e67608 0%,#0000 50%),radial-gradient(at 80% 100%,#42a5f505 0%,#0000 50%);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}#app{width:100%;max-width:1200px;min-height:100vh;padding:var(--space-lg) var(--space-lg) var(--space-3xl);flex-direction:column;margin:0 auto;display:flex}.page-enter{animation:.4s forwards pageEnter}@keyframes pageEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-subtle)}.dashboard-header__inner{justify-content:space-between;align-items:center;display:flex}.dashboard-header__brand{align-items:center;gap:var(--space-md);display:flex}.dashboard-header__logo{background:var(--gradient-primary);border-radius:var(--radius-md);width:44px;height:44px;color:var(--bg-primary);justify-content:center;align-items:center;display:flex;box-shadow:0 0 24px #00e67633}.dashboard-header__title{letter-spacing:-.5px;font-size:1.5rem;font-weight:800}.dashboard-header__title span{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.dashboard-header__badge{color:var(--text-muted);padding:var(--space-xs) var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.upload-section{margin-bottom:var(--space-lg)}.upload-grid{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.upload-card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base);position:relative;overflow:hidden}.upload-card:before{content:"";height:2px;transition:background var(--transition-base);background:0 0;position:absolute;top:0;left:0;right:0}.upload-card:hover{border-color:var(--border-accent-blue);box-shadow:var(--shadow-glow-blue)}.upload-card:hover:before{background:var(--gradient-blue)}.upload-card--has-file{border-color:var(--border-accent-green)}.upload-card--has-file:before{background:var(--gradient-primary)!important}.upload-card--has-file:hover{box-shadow:var(--shadow-glow-green)}.upload-card__icon{color:var(--accent-blue);margin-bottom:var(--space-md);align-items:center;display:flex}.upload-card--has-file .upload-card__icon{color:var(--accent-green)}.upload-card__title{margin-bottom:var(--space-xs);font-size:1.1rem;font-weight:700}.upload-card__desc{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.8rem}.upload-card__dropzone{border:2px dashed var(--border-primary);border-radius:var(--radius-md);padding:var(--space-xl) var(--space-md);cursor:pointer;transition:all var(--transition-base);background:var(--bg-surface);justify-content:center;align-items:center;display:flex}.upload-card__dropzone:hover{border-color:var(--accent-blue);background:var(--accent-blue-bg)}.upload-card__dropzone--dragover{border-color:var(--accent-green);background:var(--accent-green-bg);box-shadow:inset 0 0 30px #00e6760d}.upload-card__dropzone-content{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.upload-card__dropzone-icon{color:var(--text-muted)}.upload-card__dropzone-text{color:var(--text-secondary);font-size:.85rem}.upload-card__browse{color:var(--accent-blue);text-underline-offset:2px;font-weight:600;text-decoration:underline}.upload-card__dropzone-hint{color:var(--text-muted);font-size:.72rem}.upload-card__input{display:none}.upload-card__file-info{padding:var(--space-md);background:var(--accent-green-bg);border:1px solid var(--border-accent-green);border-radius:var(--radius-md);justify-content:space-between;align-items:center;animation:.3s forwards fadeSlideIn;display:flex}.upload-card__file-badge{align-items:center;gap:var(--space-sm);color:var(--accent-green);font-size:.85rem;font-weight:500;display:flex}.upload-card__file-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.upload-card__remove-btn{color:var(--text-muted);padding:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.upload-card__remove-btn:hover{color:var(--accent-red);background:var(--accent-red-dim)}.action-buttons{align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.btn{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;padding:12px 24px;font-size:.9rem;font-weight:600;display:inline-flex}.btn--primary{background:var(--gradient-primary);color:var(--bg-primary);box-shadow:0 4px 16px #00e67633}.btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #00e67659}.btn--primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.btn--outline{border:1px solid var(--border-primary);color:var(--text-primary);background:0 0}.btn--outline:hover{border-color:var(--accent-blue);background:var(--accent-blue-bg);color:var(--accent-blue)}.btn--ghost{color:var(--text-secondary);background:0 0}.btn--ghost:hover{color:var(--text-primary);background:#ffffff0d}.btn--danger:hover{color:var(--accent-red);background:var(--accent-red-bg)}.btn--success{border-color:var(--accent-green)!important;color:var(--accent-green)!important;background:var(--accent-green-bg)!important}.btn__spinner{border:2px solid var(--bg-primary);border-top-color:#0000;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.summary-cards{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(5,1fr);animation:.5s forwards fadeSlideIn;display:grid}.summary-card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base);position:relative;overflow:hidden}.summary-card:after{content:"";height:2px;position:absolute;top:0;left:0;right:0}.summary-card:hover{transform:translateY(-2px)}.summary-card--blue:after{background:var(--gradient-blue)}.summary-card--blue:hover{border-color:var(--border-accent-blue);box-shadow:var(--shadow-glow-blue)}.summary-card--blue .summary-card__icon{color:var(--accent-blue);background:var(--accent-blue-dim)}.summary-card--green:after{background:var(--gradient-primary)}.summary-card--green:hover{border-color:var(--border-accent-green);box-shadow:var(--shadow-glow-green)}.summary-card--green .summary-card__icon{color:var(--accent-green);background:var(--accent-green-dim)}.summary-card--red:after{background:linear-gradient(135deg, var(--accent-red) 0%, #c62828 100%)}.summary-card--red:hover{box-shadow:var(--shadow-glow-red)}.summary-card--red .summary-card__icon{color:var(--accent-red);background:var(--accent-red-dim)}.summary-card--orange:after{background:linear-gradient(135deg, var(--accent-orange) 0%, #ef6c00 100%)}.summary-card--orange:hover{box-shadow:0 0 30px #ffa7261a}.summary-card--orange .summary-card__icon{color:var(--accent-orange);background:var(--accent-orange-dim)}.summary-card__header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.summary-card__icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.summary-card__label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.78rem;font-weight:500}.summary-card__value{letter-spacing:-.3px;word-break:break-all;font-size:1.15rem;font-weight:800;line-height:1.3}.summary-card--green .summary-card__value{color:var(--accent-green)}.summary-card--red .summary-card__value{color:var(--accent-red)}.results-container{scroll-margin-top:var(--space-lg)}.results-section{opacity:0;animation:.5s .15s forwards fadeSlideIn}.results-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.results-header__title{align-items:center;gap:var(--space-sm);font-size:1.2rem;font-weight:700;display:flex}.results-header__count{color:var(--text-muted);background:var(--bg-card);border-radius:var(--radius-full);border:1px solid var(--border-subtle);padding:2px 10px;font-size:.75rem;font-weight:500}.results-table-wrapper{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:auto hidden}.results-table{border-collapse:collapse;width:100%;min-width:600px}.results-table th{background:var(--bg-elevated);padding:var(--space-md) var(--space-lg);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid var(--border-primary);white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:.75rem;font-weight:600}.results-table__th--sortable{cursor:pointer;transition:color var(--transition-fast)}.results-table__th--sortable:hover{color:var(--accent-blue)}.results-table__th--right{text-align:right!important}.sort-icon{color:var(--accent-blue);margin-left:4px;font-size:.7rem}.sort-icon--inactive{color:var(--text-muted);opacity:.5}.results-table td{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);font-size:.88rem}.results-table__row{opacity:0;animation:.3s forwards rowEnter}.results-table tbody tr:hover{background:#ffffff05}.results-table__subid{font-weight:700;font-family:var(--font-primary);color:var(--accent-cyan);letter-spacing:.5px}.results-table__money{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}.results-table__roi{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.results-table__profit--positive{color:var(--accent-green)}.results-table__profit--negative{color:var(--accent-red)}@keyframes rowEnter{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.help-section{margin-top:var(--space-2xl);margin-bottom:var(--space-xl)}.help-section__toggle{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-base);cursor:pointer;font-size:.9rem;font-weight:500;display:flex}.help-section__toggle:hover{color:var(--text-primary);border-color:var(--border-accent-blue);background:var(--bg-card-hover)}.help-section__toggle-icon{color:var(--accent-blue);align-items:center;display:flex}.help-section__chevron{transition:transform var(--transition-base);align-items:center;margin-left:auto;display:flex}.help-section__chevron--open{transform:rotate(180deg)}.help-section__content{max-height:0;transition:max-height var(--transition-slow), opacity var(--transition-base);opacity:0;overflow:hidden}.help-section__content--open{opacity:1;max-height:500px}.help-section__body{padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:0 0 var(--radius-md) var(--radius-md);border-top:none}.help-section__intro{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.88rem;line-height:1.7}.help-section__example{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-md);margin-bottom:var(--space-lg);align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.help-section__example-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.help-section__example-code{color:var(--accent-green);background:var(--accent-green-bg);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font-primary);font-weight:600}.help-section__grid{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.help-section__col h4{color:var(--text-primary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.5px;font-size:.82rem;font-weight:600}.help-section__col ul{list-style:none}.help-section__col li{color:var(--text-secondary);padding:var(--space-xs) 0;padding-left:var(--space-md);font-size:.82rem;position:relative}.help-section__col li:before{content:"›";color:var(--accent-blue);font-weight:700;position:absolute;left:0}.help-section__col code{background:var(--bg-elevated);color:var(--accent-cyan);font-size:.78rem;font-family:var(--font-primary);border-radius:3px;padding:1px 6px;font-weight:600}.help-section__col strong{color:var(--text-primary)}.error-banner{align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--accent-red-bg);border-radius:var(--radius-md);margin-bottom:var(--space-lg);border:1px solid #ef53504d;animation:.3s forwards fadeSlideIn;display:flex}.error-banner--exit{animation:.3s forwards fadeSlideOut}.error-banner__icon{color:var(--accent-red);flex-shrink:0;margin-top:2px}.error-banner__message{color:var(--text-primary);white-space:pre-line;flex:1;font-size:.88rem;line-height:1.6}.error-banner__close{color:var(--text-muted);padding:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast);flex-shrink:0}.error-banner__close:hover{color:var(--accent-red);background:var(--accent-red-dim)}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (width<=1024px){.summary-cards{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){#app{padding:var(--space-md)}.upload-grid{grid-template-columns:1fr}.summary-cards{grid-template-columns:repeat(2,1fr)}.help-section__grid{grid-template-columns:1fr}.dashboard-header__inner{align-items:flex-start;gap:var(--space-sm);flex-direction:column}.action-buttons{flex-wrap:wrap}.btn{flex:1;justify-content:center;min-width:140px}}@media (width<=480px){.summary-cards{grid-template-columns:1fr}.dashboard-header__title{font-size:1.2rem}.summary-card__value{font-size:1rem}}
