.app-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-family:inherit;font-weight:500;cursor:pointer;border:none;transition:all .2s ease;position:relative;white-space:nowrap}.app-button--small{height:36px;padding:0 16px;font-size:var(--font-size-small);border-radius:6px}.app-button--medium{height:40px;padding:0 20px;font-size:var(--font-size-body);border-radius:8px}.app-button--large{height:44px;padding:0 24px;font-size:var(--font-size-body);border-radius:8px}.app-button--primary{background-color:var(--color-primary);color:#fff}.app-button--primary:hover:not(:disabled){background-color:var(--color-primary-dark);box-shadow:0 2px 4px #1e40af33}.app-button--primary:active:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(1px)}.app-button--secondary{background-color:var(--color-bg-primary);color:var(--color-primary);border:1px solid var(--color-primary)}.app-button--secondary:hover:not(:disabled){background-color:var(--color-secondary);box-shadow:0 2px 4px #1e40af1a}.app-button--secondary:active:not(:disabled){background-color:var(--color-secondary-dark);transform:translateY(1px)}.app-button--danger{background-color:var(--color-error);color:#fff}.app-button--danger:hover:not(:disabled){background-color:#dc2626;box-shadow:0 2px 4px #ef444433}.app-button--danger:active:not(:disabled){background-color:#dc2626;transform:translateY(1px)}.app-button:disabled{background-color:var(--color-secondary-dark);color:var(--color-text-light);cursor:not-allowed;opacity:.6}.app-button--secondary:disabled{background-color:var(--color-bg-primary);border-color:var(--color-border);color:var(--color-text-light)}.app-button__spinner{width:14px;height:14px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:button-spin .6s linear infinite}.app-button__content{display:inline-flex;align-items:center}@keyframes button-spin{to{transform:rotate(360deg)}}.app-card{background-color:var(--color-bg-primary);border-radius:10px;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:box-shadow .2s ease}.app-card:hover{box-shadow:0 4px 6px #0000001a}.app-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-md);border-bottom:1px solid var(--color-border)}.app-card__header-content{flex:1}.app-card__title{font-size:var(--font-size-h2);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0;line-height:1.4}.app-card__description{font-size:var(--font-size-small);color:var(--color-text-secondary);margin:0;line-height:1.5}.app-card__header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.app-card__content{padding:var(--spacing-lg)}.app-card:not(:has(.app-card__header)) .app-card__content{padding:var(--spacing-lg)}.home-page{width:100%}.home-hero{padding:var(--spacing-2xl) 0;background:linear-gradient(180deg,var(--color-bg-secondary) 0%,var(--color-bg-primary) 100%)}.home-hero__content{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md);display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);align-items:center}.home-hero__left{display:flex;flex-direction:column;gap:var(--spacing-lg)}.home-hero__title{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0;line-height:1.2}.home-hero__subtitle{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:1.6;margin:0}.home-hero__actions{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.home-hero__actions a{text-decoration:none}.home-hero__right{display:flex;justify-content:center;align-items:center}.home-hero__image-placeholder{width:100%;max-width:500px;aspect-ratio:1;background-color:var(--color-bg-primary);border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md)}.home-hero__placeholder-content{padding:var(--spacing-lg);text-align:center}.home-features{padding:var(--spacing-2xl) 0;background-color:var(--color-bg-primary)}.home-features__container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md);display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl)}.home-feature-card{text-align:center;height:100%;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.home-feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.home-feature-card__icon{font-size:48px;margin-bottom:var(--spacing-md)}.home-feature-card__title{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.home-feature-card__description{font-size:var(--font-size-small);color:var(--color-text-secondary);line-height:1.6;margin:0;flex:1}.home-cta{padding:var(--spacing-2xl) 0;background-color:var(--color-bg-secondary);border-top:1px solid var(--color-border)}.home-cta__container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md);text-align:center;display:flex;flex-direction:column;gap:var(--spacing-md)}.home-cta__text{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;line-height:1.6}.home-cta__link{color:var(--color-primary);text-decoration:none;font-weight:500;margin-left:var(--spacing-xs);transition:color .2s ease}.home-cta__link:hover{color:var(--color-primary-dark);text-decoration:underline}@media (max-width: 968px){.home-hero__content{grid-template-columns:1fr;gap:var(--spacing-xl)}.home-hero__right{order:-1}.home-hero__image-placeholder{max-width:400px}.home-features__container{grid-template-columns:1fr;gap:var(--spacing-lg)}}@media (max-width: 768px){.home-hero{padding:var(--spacing-xl) 0}.home-hero__title{font-size:28px}.home-hero__actions{flex-direction:column;width:100%}.home-hero__actions a,.home-hero__actions button{width:100%}.home-features,.home-cta{padding:var(--spacing-xl) 0}}.app-input{display:flex;flex-direction:column;gap:var(--spacing-sm)}.app-input--full-width{width:100%}.app-input__label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.app-input__required{color:var(--color-error);font-weight:700}.app-input__field{width:100%;height:40px;padding:0 var(--spacing-md);font-size:var(--font-size-body);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;outline:none;transition:all .2s ease}.app-input__field::placeholder{color:var(--color-text-light)}.app-input__field:hover:not(:disabled){border-color:var(--color-border-dark)}.app-input__field:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e40af1a}.app-input__field:disabled{background-color:var(--color-secondary);color:var(--color-text-light);cursor:not-allowed}.app-input__field--error{border-color:var(--color-error)}.app-input__field--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #ef44441a}.app-input__helper{font-size:12px;color:var(--color-text-secondary);margin-top:-4px}.app-input__helper--error{color:var(--color-error)}.app-toast-container{position:fixed;top:80px;right:var(--spacing-md);z-index:10000;display:flex;flex-direction:column;gap:var(--spacing-sm);max-width:400px;pointer-events:none}.app-toast{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:8px;box-shadow:0 4px 12px #00000026;background-color:var(--color-bg-primary);pointer-events:auto;animation:toast-slide-in .3s ease;min-width:300px}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.app-toast--success{border-left:4px solid var(--color-success)}.app-toast--success .app-toast__icon{color:var(--color-success)}.app-toast--error{border-left:4px solid var(--color-error)}.app-toast--error .app-toast__icon{color:var(--color-error)}.app-toast--info{border-left:4px solid var(--color-info)}.app-toast--info .app-toast__icon{color:var(--color-info)}.app-toast__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.app-toast__message{flex:1;font-size:var(--font-size-small);color:var(--color-text-primary);line-height:1.5}.app-toast__close{flex-shrink:0;background:none;border:none;font-size:20px;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:color .2s}.app-toast__close:hover{color:var(--color-text-primary)}.captcha-input{display:flex;flex-direction:column;gap:var(--spacing-sm)}.captcha-input__label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.captcha-input__required{color:var(--color-error);font-weight:700}.captcha-input__row{display:flex;gap:var(--spacing-md);align-items:flex-start}.captcha-input__image-wrapper{flex:1;height:60px;min-height:60px;min-width:180px;border:1px solid var(--color-border);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-primary);cursor:pointer;transition:border-color .2s ease}@media (max-width: 480px){.captcha-input__image-wrapper{min-width:150px;height:50px;min-height:50px}.captcha-input__refresh{height:50px;padding:0 var(--spacing-sm);font-size:var(--font-size-small)}.captcha-input__row{gap:var(--spacing-sm)}}.captcha-input__image-wrapper:hover{border-color:var(--color-primary)}.captcha-input__image{width:100%;height:100%;object-fit:contain;cursor:pointer}.captcha-input__placeholder{font-size:var(--font-size-small);color:var(--color-text-light);padding:var(--spacing-sm);text-align:center}.captcha-input__refresh{padding:0 var(--spacing-md);height:60px;font-size:var(--font-size-small);color:var(--color-primary);background:none;border:1px solid var(--color-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:inherit}.captcha-input__refresh:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.captcha-input__refresh:disabled{opacity:.5;cursor:not-allowed}.login-page{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-md);background-color:var(--color-bg-secondary)}.login-page__container{max-width:960px;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);align-items:center}.login-page__left{display:flex;flex-direction:column;gap:var(--spacing-lg)}.login-page__welcome{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0;line-height:1.2}.login-page__description{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:1.6;margin:0}.login-page__right{display:flex;justify-content:center}.login-card{width:100%;max-width:480px}.login-card__title{font-size:var(--font-size-h2);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xl) 0;text-align:center}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.login-form__captcha{display:flex;flex-direction:column;gap:var(--spacing-sm)}.login-form__captcha-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.login-form__required{color:var(--color-error);font-weight:700}.login-form__captcha-row{display:flex;gap:var(--spacing-md);align-items:flex-start}.login-form__captcha-image-wrapper{flex:1;height:40px;border:1px solid var(--color-border);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-primary);cursor:pointer;transition:border-color .2s ease}.login-form__captcha-image-wrapper:hover{border-color:var(--color-primary)}.login-form__captcha-image{width:100%;height:100%;object-fit:contain;cursor:pointer}.login-form__captcha-placeholder{font-size:var(--font-size-small);color:var(--color-text-light);padding:var(--spacing-sm)}.login-form__captcha-refresh{padding:0 var(--spacing-md);height:40px;font-size:var(--font-size-small);color:var(--color-primary);background:none;border:1px solid var(--color-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.login-form__captcha-refresh:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.login-form__captcha-refresh:disabled{opacity:.5;cursor:not-allowed}.login-form__submit{width:100%;margin-top:var(--spacing-sm)}.login-form__footer{text-align:center;margin-top:var(--spacing-md)}.login-form__footer-text{font-size:var(--font-size-small);color:var(--color-text-secondary)}.login-form__footer-link{font-size:var(--font-size-small);color:var(--color-primary);text-decoration:none;margin-left:var(--spacing-xs);font-weight:500;transition:color .2s ease}.login-form__footer-link:hover{color:var(--color-primary-dark);text-decoration:underline}@media (max-width: 768px){.login-page__container{grid-template-columns:1fr;gap:var(--spacing-xl)}.login-page__left{text-align:center}.login-page__welcome{font-size:28px}.login-card{max-width:100%}}.register-page{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-md);background-color:var(--color-bg-secondary)}.register-page__container{max-width:960px;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);align-items:center}.register-page__left{display:flex;flex-direction:column;gap:var(--spacing-lg)}.register-page__welcome{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0;line-height:1.2}.register-page__description{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:1.6;margin:0}.register-page__right{display:flex;justify-content:center}.register-card{width:100%;max-width:480px}.register-card__title{font-size:var(--font-size-h2);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xl) 0;text-align:center}.register-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.register-form__captcha{display:flex;flex-direction:column;gap:var(--spacing-sm)}.register-form__captcha-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.register-form__required{color:var(--color-error);font-weight:700}.register-form__captcha-row{display:flex;gap:var(--spacing-md);align-items:flex-start}.register-form__captcha-image-wrapper{flex:1;height:40px;border:1px solid var(--color-border);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-primary);cursor:pointer;transition:border-color .2s ease}.register-form__captcha-image-wrapper:hover{border-color:var(--color-primary)}.register-form__captcha-image{width:100%;height:100%;object-fit:contain;cursor:pointer}.register-form__captcha-placeholder{font-size:var(--font-size-small);color:var(--color-text-light);padding:var(--spacing-sm)}.register-form__captcha-refresh{padding:0 var(--spacing-md);height:40px;font-size:var(--font-size-small);color:var(--color-primary);background:none;border:1px solid var(--color-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.register-form__captcha-refresh:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.register-form__captcha-refresh:disabled{opacity:.5;cursor:not-allowed}.register-form__submit{width:100%;margin-top:var(--spacing-sm)}.register-form__footer{text-align:center;margin-top:var(--spacing-md)}.register-form__footer-text{font-size:var(--font-size-small);color:var(--color-text-secondary)}.register-form__footer-link{font-size:var(--font-size-small);color:var(--color-primary);text-decoration:none;margin-left:var(--spacing-xs);font-weight:500;transition:color .2s ease}.register-form__footer-link:hover{color:var(--color-primary-dark);text-decoration:underline}.register-form__terms{font-size:var(--font-size-tiny);color:var(--color-text-light);text-align:center;margin:var(--spacing-sm) 0 0 0;line-height:1.5}@media (max-width: 768px){.register-page__container{grid-template-columns:1fr;gap:var(--spacing-xl)}.register-page__left{text-align:center}.register-page__welcome{font-size:28px}.register-card{max-width:100%}}.app-table{width:100%;overflow-x:auto}.app-table__table{width:100%;border-collapse:collapse;background-color:var(--color-bg-primary)}.app-table__header{background-color:var(--color-secondary);font-weight:600;font-size:var(--font-size-small);color:var(--color-text-primary);padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}.app-table__cell{padding:var(--spacing-md);font-size:var(--font-size-body);color:var(--color-text-primary);border-bottom:1px solid var(--color-border);height:44px;vertical-align:middle}.app-table__row{transition:background-color .15s ease}.app-table__row--clickable{cursor:pointer;transition:background-color .15s ease}.app-table__row--clickable:hover{background-color:var(--color-secondary-light)}tbody tr:not(.app-table__row--clickable):hover{background-color:var(--color-secondary-light)}.app-table__loading,.app-table__empty{text-align:center;padding:var(--spacing-2xl)!important}.app-table__loading-content,.app-table__empty-content{color:var(--color-text-secondary);font-size:var(--font-size-small)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;min-height:200px}.empty-state--compact{padding:var(--spacing-xl) var(--spacing-md);min-height:160px}.empty-state__icon{margin-bottom:var(--spacing-md);color:var(--color-text-light);display:flex;align-items:center;justify-content:center}.empty-state__icon--default{width:64px;height:64px}.empty-state__icon--default svg{width:100%;height:100%;color:var(--color-text-light)}.empty-state__title{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.empty-state__description{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;line-height:1.6;max-width:400px}.empty-state__action{margin-top:var(--spacing-lg)}.kline-page{min-height:calc(100vh - 64px);background-color:var(--color-bg-secondary);padding:var(--spacing-2xl) 0}.kline-page__container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.kline-page__header{margin-bottom:var(--spacing-2xl)}.kline-page__title{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.kline-page__description{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;line-height:1.6}.kline-page__content{display:grid;grid-template-columns:360px 1fr;gap:40px;align-items:start}.kline-page__sidebar{position:sticky;top:var(--spacing-xl)}.kline-query-card__header{margin-bottom:var(--spacing-lg)}.kline-query-card__title{font-size:20px;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.kline-query-card__subtitle{font-size:13px;color:var(--color-text-secondary);margin:0;line-height:1.5}.kline-query-card__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.kline-query-card__submit{width:100%;height:44px;margin-top:var(--spacing-xs)}.kline-query-card__error{padding:var(--spacing-sm) var(--spacing-md);background-color:#ef44441a;border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-small);line-height:1.5}.kline-query-card__trading-time-hint{margin-top:var(--spacing-sm);font-size:14px;color:var(--color-text-secondary);line-height:1.4;padding:var(--spacing-xs) 0}.kline-page__main{min-width:0}.kline-result-card__header{margin-bottom:var(--spacing-lg)}.kline-result-card__title{font-size:20px;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.kline-result-card__subtitle{font-size:14px;color:var(--color-text-secondary);margin:0;line-height:1.6;display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.kline-result-card__subtitle span{white-space:nowrap}.kline-result-card__content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.kline-result-card__empty{min-height:160px;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-secondary);border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xl)}.kline-result-card__empty p{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;text-align:center}.kline-result-card__table-wrapper{overflow-x:auto;max-height:600px;overflow-y:auto}.kline-result-card__chart-placeholder{min-height:260px;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xl);margin-top:var(--spacing-lg)}.kline-result-card__chart-placeholder p{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;text-align:center}@media (max-width: 1024px){.kline-page__content{grid-template-columns:1fr;gap:var(--spacing-xl)}.kline-page__sidebar{position:static}}@media (max-width: 768px){.kline-page{padding:var(--spacing-xl) 0}.kline-page__title{font-size:28px}.kline-page__description{font-size:var(--font-size-small)}.kline-result-card__subtitle{flex-direction:column;gap:var(--spacing-xs)}}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md)}.loading-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#ffffffe6;z-index:9999}.loading-inline{padding:var(--spacing-2xl)}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-secondary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-text{font-size:var(--font-size-small);color:var(--color-text-secondary);margin:0}@keyframes spin{to{transform:rotate(360deg)}}.trade-plan{background-color:var(--color-bg-secondary);padding:var(--spacing-2xl) 0;min-height:calc(100vh - 200px)}.trade-plan__container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.trade-plan__header{margin-bottom:var(--spacing-2xl)}.trade-plan__title{font-size:var(--font-size-h1);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.trade-plan__description{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0}.trade-plan__form{padding:var(--spacing-md) 0}.trade-plan__form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.trade-plan__form-col{display:flex;flex-direction:column;gap:var(--spacing-md)}.trade-plan__form-select-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.trade-plan__form-label{font-size:var(--font-size-body);font-weight:500;color:var(--color-text-primary)}.trade-plan__form-required{color:var(--color-error);margin-left:var(--spacing-xs)}.trade-plan__form-select{height:40px;padding:0 var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-body);color:var(--color-text-primary);background-color:var(--color-bg-primary);cursor:pointer}.trade-plan__form-select:focus{outline:none;border-color:var(--color-primary)}.trade-plan__form-helper{font-size:var(--font-size-small);color:var(--color-text-secondary)}.trade-plan__form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.trade-plan__form-error{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:#fff1f0;border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-small)}.trade-plan__loading{margin:var(--spacing-2xl) 0;display:flex;justify-content:center;align-items:center;min-height:200px}.trade-plan__kpi-section{margin:var(--spacing-2xl) 0}.trade-plan__section-title{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0}.trade-plan__kpi-grid{display:flex;flex-direction:column;gap:var(--spacing-lg)}.trade-plan__kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.trade-plan__kpi-row:last-child{grid-template-columns:repeat(2,1fr);max-width:calc(66.666% + var(--spacing-lg))}.trade-plan__kpi-card{padding:var(--spacing-lg)}.trade-plan__kpi-title{font-size:var(--font-size-body);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.trade-plan__kpi-value{font-size:28px;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);line-height:1.2}.trade-plan__kpi-label{font-size:var(--font-size-small);color:var(--color-text-secondary);line-height:1.4}.trade-plan__table-section,.trade-plan__empty{margin:var(--spacing-2xl) 0}@media (max-width: 900px){.trade-plan__form-row,.trade-plan__kpi-row{grid-template-columns:1fr}.trade-plan__kpi-row:last-child{grid-template-columns:1fr;max-width:100%}}.date-input{display:flex;flex-direction:column;gap:var(--spacing-sm)}.date-input--full-width{width:100%}.date-input__label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.date-input__required{color:var(--color-error);font-weight:700}.date-input__field{width:100%;min-width:180px;height:40px;padding:0 var(--spacing-md);font-size:var(--font-size-body);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;outline:none;transition:all .2s ease}.date-input__field::placeholder{color:var(--color-text-light)}.date-input__field:hover:not(:disabled){border-color:var(--color-border-dark)}.date-input__field:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e40af1a}.date-input__field:disabled{background-color:var(--color-secondary);color:var(--color-text-light);cursor:not-allowed}.date-input__field--error{border-color:var(--color-error)}.date-input__field--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #ef44441a}.date-input__helper{font-size:12px;color:var(--color-text-secondary);margin-top:-4px}.date-input__helper--error{color:var(--color-error)}.app-pagination{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;flex-wrap:wrap;gap:var(--spacing-md)}.app-pagination__info{font-size:var(--font-size-small);color:var(--color-text-secondary)}.app-pagination__controls{display:flex;align-items:center;gap:var(--spacing-xs)}.app-pagination__button{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-small);color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-family:inherit}.app-pagination__button:hover:not(:disabled){background-color:var(--color-secondary);border-color:var(--color-primary);color:var(--color-primary)}.app-pagination__button:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-secondary)}.app-pagination__pages{display:flex;align-items:center;gap:var(--spacing-xs)}.app-pagination__page{min-width:36px;height:36px;padding:0 var(--spacing-sm);font-size:var(--font-size-small);color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;justify-content:center}.app-pagination__page:hover:not(:disabled){background-color:var(--color-secondary);border-color:var(--color-primary);color:var(--color-primary)}.app-pagination__page--active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.app-pagination__page--active:hover:not(:disabled){background-color:var(--color-primary-dark)}.app-pagination__page:disabled{opacity:.5;cursor:not-allowed}.app-pagination__ellipsis{padding:0 var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-small);-webkit-user-select:none;user-select:none}@media (max-width: 768px){.app-pagination{flex-direction:column;align-items:stretch}.app-pagination__info{text-align:center}.app-pagination__controls{justify-content:center}.app-pagination__pages{flex-wrap:wrap;justify-content:center}}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;line-height:1}.status-badge--success{background-color:#10b981;color:#fff}.status-badge--fail{background-color:#ef4444;color:#fff}.trade-plans-page{min-height:calc(100vh - 64px);background-color:var(--color-bg-secondary);padding:var(--spacing-2xl) 0}.trade-plans-page__container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.trade-plans-page__header{margin-bottom:var(--spacing-md)}.trade-plans-page__title{font-size:20px;font-weight:600;color:var(--color-text-primary);margin:24px 0 16px}.trade-plans-page__filters{display:flex;flex-direction:row;align-items:flex-start;gap:var(--spacing-md);margin-bottom:20px}.trade-plans-page__table-wrapper{margin-bottom:var(--spacing-md)}.trade-plans-page__pagination{display:flex;justify-content:flex-end;margin-top:var(--spacing-md)}@media (max-width: 900px){.trade-plans-page__filters{flex-direction:column;gap:12px}.trade-plans-page__filters .app-input,.trade-plans-page__filters .date-input{width:100%}.trade-plans-page__table-wrapper{overflow-x:auto}}.trade-plan-detail-page{min-height:100vh;padding:24px;background-color:#f5f5f5}.trade-plan-detail-page__container{max-width:1200px;margin:0 auto}.trade-plan-detail-page__header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.trade-plan-detail-page__title{font-size:24px;font-weight:600;color:#333;margin:0}.trade-plan-detail-page__card{margin-bottom:24px}.trade-plan-detail-page__card-title{font-size:18px;font-weight:600;color:#333;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid #e0e0e0}.trade-plan-detail-page__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.trade-plan-detail-page__item{display:flex;flex-direction:column;gap:8px}.trade-plan-detail-page__item--full{grid-column:1 / -1}.trade-plan-detail-page__label{font-size:14px;color:#666;font-weight:500}.trade-plan-detail-page__value{font-size:16px;color:#333}.trade-plan-detail-page__empty{text-align:center;padding:40px;color:#999;font-size:16px}@media (max-width: 768px){.trade-plan-detail-page{padding:16px}.trade-plan-detail-page__header{flex-direction:column;align-items:flex-start}.trade-plan-detail-page__title{font-size:20px}.trade-plan-detail-page__grid{grid-template-columns:1fr}}.app-switch{display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;position:relative}.app-switch--disabled{opacity:.6;cursor:not-allowed}.app-switch__input{position:absolute;opacity:0;width:0;height:0}.app-switch__slider{position:relative;display:inline-block;transition:background-color .3s ease;border-radius:20px;background-color:var(--color-secondary-dark);transition:all .3s ease}.app-switch--small .app-switch__slider{width:36px;height:20px}.app-switch--medium .app-switch__slider{width:44px;height:24px}.app-switch__slider:before{content:"";position:absolute;background-color:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 4px #0003}.app-switch--small .app-switch__slider:before{width:16px;height:16px;top:2px;left:2px}.app-switch--medium .app-switch__slider:before{width:20px;height:20px;top:2px;left:2px}.app-switch__input:checked+.app-switch__slider{background-color:var(--color-primary)}.app-switch__input:checked+.app-switch__slider:before{transform:translate(20px)}.app-switch--small .app-switch__input:checked+.app-switch__slider:before{transform:translate(16px)}.app-switch__input:focus+.app-switch__slider{box-shadow:0 0 0 3px #1e40af1a}.app-switch__input:disabled+.app-switch__slider{opacity:.5;cursor:not-allowed}.app-switch__label{font-size:var(--font-size-small);color:var(--color-text-primary);-webkit-user-select:none;user-select:none}.app-switch--disabled .app-switch__label{color:var(--color-text-light)}.admin-sidebar{width:240px;background-color:var(--color-bg-primary);border-right:1px solid var(--color-border);height:calc(100vh - 64px);position:sticky;top:64px;display:flex;flex-direction:column;flex-shrink:0}.admin-sidebar__header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.admin-sidebar__title{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0}.admin-sidebar__nav{flex:1;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-sidebar__item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text-primary);transition:all .2s ease;font-size:var(--font-size-body)}.admin-sidebar__item:hover{background-color:var(--color-secondary);color:var(--color-primary)}.admin-sidebar__item--active{background-color:var(--color-primary);color:#fff}.admin-sidebar__item--active:hover{background-color:var(--color-primary-dark);color:#fff}.admin-sidebar__icon{font-size:20px;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.admin-sidebar__text{font-weight:500}@media (max-width: 968px){.admin-sidebar{width:200px}}@media (max-width: 768px){.admin-sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--color-border)}.admin-sidebar__nav{flex-direction:row;overflow-x:auto}.admin-sidebar__item{white-space:nowrap;flex-shrink:0}}.admin-layout{display:flex;min-height:calc(100vh - 64px);background-color:var(--color-bg-secondary)}.admin-layout__content{flex:1;padding:var(--spacing-xl) var(--spacing-lg);max-width:calc(100% - 240px);width:100%}@media (max-width: 968px){.admin-layout__content{max-width:calc(100% - 200px)}}@media (max-width: 768px){.admin-layout{flex-direction:column}.admin-layout__content{max-width:100%;padding:var(--spacing-lg) var(--spacing-md)}}.admin-page{width:100%;max-width:1400px;margin:0 auto}.admin-page__header{margin-bottom:var(--spacing-xl)}.admin-page__title{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.admin-page__description{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;line-height:1.6}.admin-page__card,.admin-page__filter-card{margin-bottom:var(--spacing-lg)}.admin-page__filters{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--spacing-md);align-items:flex-end}.admin-page__filter-input{flex:1}.admin-page__filter-action{display:flex;align-items:flex-end}.admin-switch-placeholder{font-size:var(--font-size-small);color:var(--color-text-secondary)}.admin-switch-cell{display:flex;align-items:center;gap:var(--spacing-sm)}.admin-switch-cell__loading{font-size:var(--font-size-tiny);color:var(--color-text-light);margin-left:var(--spacing-xs)}.admin-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-small);font-weight:500;background-color:var(--color-secondary);color:var(--color-text-secondary)}.admin-badge--admin{background-color:#1e40af1a;color:var(--color-primary)}.admin-status{font-size:var(--font-size-small);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-weight:500}.admin-status--success{background-color:#10b9811a;color:var(--color-success)}.admin-status--error{background-color:#ef44441a;color:var(--color-error)}.admin-page__pagination{margin-top:var(--spacing-lg);display:flex;justify-content:flex-end}.admin-page__pagination-placeholder{margin-top:var(--spacing-lg);padding:var(--spacing-md);text-align:center;background-color:var(--color-secondary);border-radius:var(--radius-md)}.admin-page__pagination-text{font-size:var(--font-size-small);color:var(--color-text-secondary);margin:0}.admin-page__card-title{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.admin-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.admin-detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-detail-item--full{grid-column:1 / -1}.admin-detail-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary)}.admin-detail-value{font-size:var(--font-size-body);color:var(--color-text-primary)}.admin-page__loading,.admin-page__empty{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.admin-filters{display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-filters__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);align-items:flex-end}.admin-filters__item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-filters__label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary)}.admin-filters__select{padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-body);background-color:var(--color-bg);color:var(--color-text-primary)}.admin-filters__actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}@media (max-width: 968px){.admin-page__filters{grid-template-columns:1fr;gap:var(--spacing-md)}.admin-page__filter-action,.admin-page__filter-action button{width:100%}.admin-filters__row,.admin-detail-grid{grid-template-columns:1fr}}.about-page{min-height:calc(100vh - 64px);background-color:var(--color-bg-secondary);padding:var(--spacing-2xl) 0}.about-page__container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.about-page__title{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-2xl) 0;text-align:center}.about-page__content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.about-section{margin-bottom:0}.about-section__heading{font-size:var(--font-size-h2);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0;line-height:1.4}.about-section__body{font-size:var(--font-size-body);color:var(--color-text-primary);line-height:1.8}.about-section__body p{margin:0 0 var(--spacing-md) 0}.about-section__body p:last-child{margin-bottom:0}.about-section__body strong{font-weight:600;color:var(--color-text-primary)}.about-section__body ol,.about-section__body ul{margin:var(--spacing-md) 0;padding-left:var(--spacing-xl);line-height:1.8}.about-section__body ol{list-style-type:decimal}.about-section__body ul{list-style-type:disc}.about-section__body li{margin-bottom:var(--spacing-sm)}.about-section__body li:last-child{margin-bottom:0}.about-section__body ul ul{margin-top:var(--spacing-xs);margin-bottom:var(--spacing-xs)}@media (max-width: 768px){.about-page{padding:var(--spacing-xl) 0}.about-page__title{font-size:28px;margin-bottom:var(--spacing-xl)}.about-section__heading{font-size:var(--font-size-h3)}.about-section__body{font-size:var(--font-size-small)}}.ui-demo{max-width:1200px;margin:0 auto;padding:var(--spacing-lg)}.ui-demo__header{margin-bottom:var(--spacing-2xl)}.ui-demo__header h1{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.ui-demo__header p{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0}.ui-demo__content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.ui-demo__section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.ui-demo__group{display:flex;flex-direction:column;gap:var(--spacing-md)}.ui-demo__group h3{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0}.ui-demo__buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:center}.user-info-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:4px;background-color:var(--color-secondary, #f5f5f5);cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none;white-space:nowrap}.user-info-bar:hover{background-color:var(--color-secondary-dark, #e8e8e8)}.user-info-label{font-size:14px;color:var(--color-text-secondary, #666)}.user-info-username{font-size:14px;font-weight:600;color:var(--color-text-primary, #333)}.user-info-dropdown-icon{font-size:12px;color:var(--color-text-secondary, #666);transition:transform .2s}@media (max-width: 768px){.user-info-bar{padding:6px 12px}.user-info-label,.user-info-dropdown-icon{display:none}}.header{position:sticky;top:0;z-index:100;background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.header-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md);height:64px;display:flex;align-items:center;justify-content:space-between}.header-logo{font-size:var(--font-size-h2);font-weight:700;color:var(--color-primary);text-decoration:none;transition:color .2s}.header-logo:hover{color:var(--color-primary-dark)}.header-nav{display:flex;align-items:center;gap:var(--spacing-lg);flex:1;justify-content:center}.header-nav-item{color:var(--color-text-primary);text-decoration:none;font-size:var(--font-size-body);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all .2s;background:none;border:none;cursor:pointer;font-family:inherit}.header-nav-item:hover{background-color:var(--color-secondary);color:var(--color-primary)}.header-nav-button{background-color:var(--color-primary);color:#fff;font-weight:500}.header-nav-button:hover{background-color:var(--color-primary-dark);color:#fff}.header-menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--spacing-sm);z-index:101}.header-menu-toggle span{width:24px;height:2px;background-color:var(--color-text-primary);transition:all .3s;border-radius:2px}.header-menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.header-menu-toggle.active span:nth-child(2){opacity:0}.header-menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (max-width: 768px){.header-container{padding:0 var(--spacing-md)}.header-nav{display:none;position:absolute;top:100%;left:0;right:0;background-color:var(--color-bg-primary);border-top:1px solid var(--color-border);flex-direction:column;padding:var(--spacing-md);gap:var(--spacing-sm);box-shadow:var(--shadow-md)}.header-nav.open{display:flex}.header-nav-item{width:100%;text-align:left;padding:var(--spacing-md)}.header-menu-toggle{display:flex}}.footer{background-color:var(--color-bg-primary);border-top:1px solid var(--color-border);margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-md) var(--spacing-lg)}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.footer-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.footer-title{font-size:var(--font-size-h3);font-weight:700;color:var(--color-primary);margin:0}.footer-description{font-size:var(--font-size-small);color:var(--color-text-secondary);line-height:1.6;margin:0}.footer-heading{font-size:var(--font-size-body);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.footer-links li a{color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-small);transition:color .2s}.footer-links li a:hover{color:var(--color-primary)}.footer-bottom{border-top:1px solid var(--color-border);padding-top:var(--spacing-lg);text-align:center}.footer-copyright{font-size:var(--font-size-small);color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.footer-disclaimer{font-size:var(--font-size-tiny);color:var(--color-text-light);margin:0}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:var(--spacing-lg)}.footer-bottom{text-align:left}}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-main{flex:1;max-width:1200px;margin:0 auto;padding:var(--spacing-lg) var(--spacing-md);width:100%}@media (max-width: 768px){.layout-main{padding:var(--spacing-md)}}:root{--color-primary: #1e40af;--color-primary-dark: #1e3a8a;--color-primary-light: #3b82f6;--color-secondary: #f1f5f9;--color-secondary-light: #f8fafc;--color-secondary-dark: #e2e8f0;--color-accent: #10b981;--color-accent-alt: #f59e0b;--color-text-primary: #1f2937;--color-text-secondary: #6b7280;--color-text-light: #9ca3af;--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-border: #e5e7eb;--color-border-dark: #d1d5db;--color-error: #ef4444;--color-success: #10b981;--color-warning: #f59e0b;--color-info: #3b82f6;--font-size-h1: 32px;--font-size-h2: 24px;--font-size-h3: 20px;--font-size-body: 16px;--font-size-small: 14px;--font-size-tiny: 12px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text-primary);background-color:var(--color-bg-secondary);line-height:1.6}#root,.app{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
