:root{--primary-color: #064e3b;--primary-hover: #0a5e40;--secondary-color: #646464;--success-color: #059669;--danger-color: #dc2626;--warning-color: #d97706;--bg-primary: #ffffff;--bg-secondary: #f8f8f8;--bg-tertiary: #efefef;--text-primary: #0d0d0d;--text-secondary: #3d3d3d;--text-muted: #8f8f8f;--border-color: #eaeaea;--border-hover: #cbcbcb;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--leading-xs: 1;--leading-tight: 1.25;--leading-normal: 1.4;--leading-relaxed: 1.6;--message-user-bg: #f4f4f4;--message-assistant-bg: transparent;--message-quote-bg: #f4f4f4;--scrollbar-track: transparent;--scrollbar-thumb: #0000001a;--scrollbar-thumb-hover: #909090}[data-theme=dark]{--bg-primary: #181818;--bg-secondary: #212121;--bg-tertiary: #303030;--text-primary: #fff;--text-secondary: #f1f5f9;--text-muted: #afafaf;--border-color: #3a3a3a;--border-hover: #404040;--shadow: 0 1px 3px 0 rgb(0 0 0 / .3), 0 1px 2px -1px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .3), 0 4px 6px -4px rgb(0 0 0 / .3);--message-user-bg: var(--bg-tertiary);--message-assistant-bg: var(--bg-primary);--message-quote-bg: var(--bg-tertiary);--scrollbar-track: transparent;--scrollbar-thumb: #ffffff1a;--scrollbar-thumb-hover: var(--text-muted)}svg{display:inline-block;vertical-align:middle}.icon{display:inline-flex;align-items:center;justify-content:center}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}*,*:before,*:after{font-family:inherit}html{width:100%;height:100%;margin:0;padding:0;overflow:hidden;-webkit-text-size-adjust:100%}body{width:100%;height:100%;margin:0;padding:0;overflow:hidden;-webkit-text-size-adjust:100%;overscroll-behavior:none}body{font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);font-size:var(--text-base);line-height:var(--leading-normal)}#root{height:100%;width:100%;overflow:auto}.w-100{width:100%}button,input,textarea,select{font-family:inherit}.form-error{color:var(--danger-color);font-size:var(--text-sm);font-weight:400;margin-bottom:16px}.form-success{color:var(--success-color);font-size:var(--text-sm);font-weight:400;margin-bottom:16px}.app{display:flex;height:100%;width:100%;position:relative;overflow:hidden;padding-top:env(safe-area-inset-top);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left)}.tauri-ios .app{padding-bottom:24px}.tauri-ios.keyboard-open,.tauri-android.keyboard-open{touch-action:none;overflow:hidden}@media (max-width: 768px){.tauri-ios.keyboard-open .app,.tauri-android.keyboard-open .app{position:fixed;top:0;left:0;right:0;height:var(--viewport-height, 100dvh);padding-bottom:8px;transition:height .3s ease}}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--border-hover)}.icon-btn{width:40px;height:40px;padding:0;background:none;border:none;border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}input,select,textarea{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:var(--text-base);transition:border-color .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #064e3b1a}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.leading-tight{line-height:var(--leading-tight)}.leading-normal{line-height:var(--leading-normal)}.leading-relaxed{line-height:var(--leading-relaxed)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.opacity-50{opacity:.5}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-4{gap:16px}.p-2{padding:8px}.p-4{padding:16px}.rounded{border-radius:6px}.shadow{box-shadow:var(--shadow)}.shadow-lg{box-shadow:var(--shadow-lg)}.mobile-overlay{display:none;position:fixed;inset:0;background-color:#0006;z-index:999}@media (max-width: 768px){.mobile-overlay.open{display:block}.main-content{margin-left:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y}}@media (min-width: 1400px){.main-content{max-width:calc(100vw - 300px)}}.password-input{flex:1;padding-right:45px}.password-input::-ms-reveal{display:none}.password-input::-webkit-credentials-auto-fill-button{display:none!important;visibility:hidden;pointer-events:none;position:absolute;right:0}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:4px;font-size:var(--text-base);line-height:1;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px}.password-toggle:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.password-toggle:disabled:hover{background:none;color:var(--text-muted)}.payment-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background-color:var(--bg-secondary)}.payment-card{background-color:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);padding:48px 40px;max-width:480px;width:100%;text-align:center}.payment-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.payment-icon-success{background-color:#0596691a;color:var(--success-color)}.payment-icon-cancel{background-color:#dc26261a;color:var(--danger-color)}.payment-title{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-bottom:12px;line-height:var(--leading-tight)}.payment-message{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:16px;line-height:var(--leading-relaxed)}.payment-hint{font-size:var(--text-sm);color:var(--text-muted);line-height:var(--leading-relaxed)}.payment-order-id{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:24px}.payment-order-id code{background-color:var(--bg-tertiary);padding:4px 8px;border-radius:4px;font-family:monospace;font-size:var(--text-xs);color:var(--text-secondary)}.payment-instructions{background-color:var(--bg-secondary);border-radius:8px;padding:16px;margin-bottom:24px}.payment-desktop-hint{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:12px;line-height:var(--leading-relaxed)}.payment-redirect-notice{font-size:var(--text-sm);color:var(--text-muted);margin:0}.payment-actions{margin-top:24px}.payment-btn{padding:12px 24px;font-size:var(--text-base);width:100%;justify-content:center}.payment-icon-loading{background-color:#064e3b1a;color:var(--primary-color)}.payment-spinner{animation:spin 1.5s linear infinite}@media (max-width: 480px){.payment-card{padding:32px 24px}.payment-icon{width:64px;height:64px}.payment-icon svg{width:48px;height:48px}.payment-title{font-size:var(--text-xl)}}.payment-receipt{max-width:520px;text-align:left}.receipt-status{text-align:center;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.receipt-status .payment-icon{margin-bottom:16px}.payment-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.receipt-sections{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.receipt-section{background-color:var(--bg-secondary);border-radius:8px;padding:16px}.receipt-section-title{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);letter-spacing:.05em;margin:0 0 12px}.receipt-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:8px}.receipt-row:last-child{margin-bottom:0}.receipt-label{font-size:var(--text-sm);color:var(--text-muted);flex-shrink:0}.receipt-value{font-size:var(--text-sm);color:var(--text-primary);word-break:break-word}.receipt-muted{color:var(--text-muted);font-style:italic}.receipt-mono{font-family:monospace;font-size:var(--text-xs);background-color:var(--bg-tertiary);padding:2px 6px;border-radius:4px}.receipt-total{padding-top:12px;margin-top:4px;border-top:1px dashed var(--border-color)}.receipt-total .receipt-label,.receipt-total .receipt-value{font-weight:600;font-size:var(--text-base)}.payment-receipt .payment-desktop-hint{text-align:center;margin-bottom:16px}.payment-receipt .payment-btn{margin-top:8px}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--bg-tertiary) 50%,var(--bg-secondary) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;display:inline-block}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton.mb-6{margin-bottom:6px}.skeleton.mb-8{margin-bottom:8px}.skeleton.mb-12{margin-bottom:12px}.skeleton.mb-20{margin-bottom:20px}.message-skeleton{padding:16px 20px;border-radius:16px;max-width:600px;margin-bottom:24px}.message-skeleton.user{background-color:var(--message-user-bg);margin-left:auto}.message-skeleton.assistant{background-color:var(--message-assistant-bg);margin-right:auto}.message-skeleton-content{display:flex;flex-direction:column}.chat-loading-container{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.chat-loading-content{display:flex;flex-direction:column;align-items:center;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spinner-rotate .8s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:14px;margin:0}.template-skeleton{display:flex;flex-direction:column;gap:16px}.template-category-skeleton{border-bottom:1px solid var(--border-color);padding-bottom:16px}.template-category-header-skeleton{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding:14px 0}.template-items-skeleton{display:flex;flex-direction:column;gap:8px;margin-top:8px}.template-item-skeleton{display:flex;align-items:center;justify-content:space-between;padding:12px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.template-item-left{display:flex;align-items:center;gap:12px;flex:1}.template-item-text{display:flex;flex-direction:column;flex:1}.typing-skeleton{padding:16px 20px;border-radius:16px;background-color:var(--bg-secondary);max-width:fit-content;margin-bottom:24px}.typing-skeleton-content{display:flex;align-items:center}.typing-dots{display:flex;gap:4px}.typing-dots .dot{width:8px;height:8px;background-color:var(--primary-color);border-radius:50%;animation:typing-bounce 1.4s infinite ease-in-out}.typing-dots .dot:nth-child(1){animation-delay:-.32s}.typing-dots .dot:nth-child(2){animation-delay:-.16s}@keyframes typing-bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.conversations-skeleton{display:flex;flex-direction:column;gap:12px;padding:12px}.conversation-item-skeleton{padding:12px;border-radius:8px;background-color:var(--bg-secondary);border:1px solid var(--border-color)}@media (max-width: 768px){.chat-loading-container{padding:16px}.message-skeleton{padding:12px 16px;margin-bottom:16px}.template-item-skeleton{padding:10px}}.modal-overlay{position:fixed;inset:0;background-color:#0000001a;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.modal-overlay.open{opacity:1;visibility:visible}.modal-content{background-color:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);max-width:520px;width:90%;max-height:88vh;max-height:88dvh;display:flex;flex-direction:column;overflow:hidden;transform:scale(.95) translateY(20px);transition:transform .2s ease}.modal-overlay.open .modal-content{transform:scale(1) translateY(0)}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-tabs{flex-shrink:0}.modal-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}@media (max-width: 768px){.modal-title{font-size:var(--text-base)}}.modal-close-btn{background:none;border:none;color:var(--text-muted);font-size:var(--text-lg);cursor:pointer;padding:4px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.modal-close-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-back-icon{display:none}.modal-close-x{display:inline}.modal-content.subscription-management{max-width:780px}.modal-content.auth .modal-header,.modal-content.plan-selection .modal-header,.modal-content.template-library .modal-header,.modal-content.settings .modal-header,.modal-content.subscription-management .modal-header{position:relative;justify-content:center}.modal-content.auth .modal-title,.modal-content.plan-selection .modal-title,.modal-content.template-library .modal-title,.modal-content.settings .modal-title,.modal-content.subscription-management .modal-title{text-align:center}.modal-content.auth .modal-close-btn,.modal-content.plan-selection .modal-close-btn,.modal-content.template-library .modal-close-btn,.modal-content.settings .modal-close-btn,.modal-content.subscription-management .modal-close-btn{position:absolute;left:20px}@media (max-width: 768px){.modal-content.auth .modal-close-btn,.modal-content.plan-selection .modal-close-btn,.modal-content.template-library .modal-close-btn,.modal-content.settings .modal-close-btn,.modal-content.subscription-management .modal-close-btn{left:12px}}.modal-content.auth .modal-back-icon,.modal-content.plan-selection .modal-back-icon,.modal-content.template-library .modal-back-icon,.modal-content.settings .modal-back-icon,.modal-content.subscription-management .modal-back-icon{display:block;color:var(--text-primary)}.modal-content.auth .modal-close-x,.modal-content.plan-selection .modal-close-x,.modal-content.template-library .modal-close-x,.modal-content.settings .modal-close-x,.modal-content.subscription-management .modal-close-x{display:none}.modal-body{padding:24px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.modal-footer{flex-shrink:0;padding:16px 24px 20px 16px;border-top:1px solid var(--border-color);background-color:var(--bg-primary);display:flex;gap:12px;justify-content:flex-end}.modal-footer .btn-primary{min-width:480px}.modal-content.confirm{max-width:500px}.modal-content.confirm .modal-title{color:var(--text-primary)}.confirm-message{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5;margin-bottom:24px}.confirm-actions{display:flex;gap:12px;justify-content:flex-end}.confirm-btn{padding:10px 16px;border:none;border-radius:8px;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.confirm-btn.cancel{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.confirm-btn.cancel:hover{background-color:var(--bg-secondary);border-color:var(--border-hover)}.confirm-btn.cancel:active{transform:scale(.98)}.confirm-btn.delete,.confirm-btn.danger{background-color:var(--danger-color);color:#fff}.confirm-btn.delete:hover:not(:disabled),.confirm-btn.danger:hover:not(:disabled){background-color:#b91c1c}.confirm-btn.delete:active:not(:disabled),.confirm-btn.danger:active:not(:disabled){transform:scale(.98)}.confirm-btn.delete:disabled,.confirm-btn.danger:disabled{background-color:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.modal-content.auth{max-width:450px}.auth-tabs{display:flex;border-bottom:1px solid var(--border-color);margin:0}.auth-tab{flex:1;padding:16px 20px;background:none;border:none;color:var(--text-muted);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.auth-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.auth-tab:hover:not(.active){color:var(--text-primary);background-color:var(--bg-tertiary)}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.form-input{padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);transition:all .2s ease}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-input.error{border-color:var(--danger-color)}.form-input.error:focus{box-shadow:0 0 0 3px #ef44441a}.auth-submit{padding:14px 20px;background-color:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px}.auth-submit:hover:not(:disabled){background-color:var(--primary-hover)}.auth-submit:disabled{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;transform:none}.auth-loading{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}.auth-divider{text-align:center;position:relative;margin:24px 0;color:var(--text-muted);font-size:var(--text-xs)}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:var(--border-color)}.auth-divider span{background-color:var(--bg-primary);padding:0 12px}@media (max-width: 768px){.modal-overlay:has(.modal-content.auth),.modal-overlay:has(.modal-content.plan-selection),.modal-overlay:has(.modal-content.template-library),.modal-overlay:has(.modal-content.settings),.modal-overlay:has(.modal-content.subscription-management){align-items:stretch;justify-content:stretch}.modal-content.auth,.modal-content.plan-selection,.modal-content.template-library,.modal-content.settings,.modal-content.subscription-management{width:100%;height:100vh;height:100dvh;max-width:100%;max-height:100vh;max-height:100dvh;border-radius:0;border:none;box-shadow:none;margin:0}.modal-content.confirm{width:85%;max-width:320px;border-radius:14px;box-shadow:0 10px 40px #00000040}.modal-content.plan-selection .modal-content .modal-header,.modal-content.settings .modal-content .modal-header,.modal-content.subscription-management .modal-content .modal-header{padding-top:16px}.modal-content.auth .modal-header,.modal-content.plan-selection .modal-header,.modal-content.template-library .modal-header,.modal-content.settings .modal-header,.modal-content.subscription-management .modal-header{padding-top:max(16px,calc(env(safe-area-inset-top) + 12px));padding-right:16px;padding-bottom:12px;padding-left:16px}.modal-content.auth .modal-body,.modal-content.plan-selection .modal-body,.modal-content.template-library .modal-body,.modal-content.settings .modal-body,.modal-content.subscription-management .modal-body{overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-content.auth .modal-footer,.modal-content.plan-selection .modal-footer,.modal-content.template-library .modal-footer,.modal-content.settings .modal-footer,.modal-content.subscription-management .modal-footer{padding-bottom:max(16px,calc(env(safe-area-inset-bottom) + 12px))}.modal-footer .btn-primary{min-width:auto}.modal-content.confirm .modal-header{display:flex;justify-content:space-between}.modal-content.confirm .modal-title{text-align:left}.modal-content.confirm .confirm-actions{justify-content:stretch}.modal-content.confirm .confirm-btn{flex:1;justify-content:center}}.trial-info{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-top:16px}.trial-info h4{margin:0 0 8px;color:var(--text-primary);font-size:var(--text-sm);font-weight:600}.trial-info p{margin:0;color:var(--text-secondary);font-size:var(--text-xs);line-height:1.4}.trial-status{align-items:center}.trial-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:var(--text-xs);font-weight:500}.trial-badge.active{background-color:#22c55e1a;color:var(--success-color)}.trial-badge.expired{background-color:#ef44441a;color:var(--danger-color)}.forgot-password-link,.back-to-login{text-align:center;margin-top:16px}.link-button{background:none;border:none;color:var(--primary-color);font-size:var(--text-sm);cursor:pointer;text-decoration:underline;transition:color .2s ease;padding:4px}.link-button:hover:not(:disabled){color:var(--primary-hover)}.link-button:disabled{color:var(--text-muted);cursor:not-allowed;text-decoration:none}.modal-content.error .modal-title{color:var(--danger-color)}.modal-content.success .modal-title{color:var(--primary-color)}.error-message{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5;margin-bottom:20px}.error-actions{display:flex;justify-content:flex-end}.error-btn{padding:10px 16px;background-color:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:background-color .2s ease}.error-btn:hover{background-color:var(--primary-hover)}.success-message{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5;margin-bottom:20px}.auth-reason-message{display:flex;align-items:flex-start;background-color:#dc26260f;border-radius:8px;padding:16px;margin-bottom:20px;gap:8px}.reason-icon{color:var(--danger-color);flex-shrink:0}.reason-text{flex:1}.reason-text strong{color:var(--danger-color);font-size:14px;font-weight:600;display:block;margin-bottom:4px}.reason-text p{color:var(--text-secondary);font-size:13px;margin:0;line-height:1.4}.social-divider{display:flex;align-items:center;text-align:center;margin:6px 0 4px;color:var(--text-muted);font-size:var(--text-xs)}.social-divider:before,.social-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.social-divider span{padding:0 16px;text-transform:lowercase}.social-buttons{display:flex;flex-direction:column;gap:12px}.social-button{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:12px;position:relative;overflow:hidden}.social-button:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--border-hover)}.social-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000000a}.social-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.social-button svg{width:20px;height:20px;flex-shrink:0}.social-button.apple{position:relative;background-color:#000;color:#fff;border-color:#000}.social-button.apple:hover:not(:disabled){background-color:#1a1a1a;border-color:#1a1a1a}.social-button.google{position:relative}.social-button.google:hover:not(:disabled){background-color:#f8fafc;border-color:#e2e8f0}@media (prefers-color-scheme: dark){.social-button{background-color:var(--bg-secondary)}.social-button:hover:not(:disabled){background-color:var(--bg-tertiary);border-color:var(--border-hover)}.social-button.apple{background-color:#fff;color:#000;border-color:#fff}.social-button.apple:hover:not(:disabled){background-color:#f5f5f5;border-color:#f5f5f5}.social-button.google:hover:not(:disabled){background-color:#f8fafc0d}}.password-input-container{position:relative;display:flex;align-items:center}.password-input{padding-right:44px!important;flex:1}.password-toggle{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.password-toggle:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.password-toggle:disabled{opacity:.5;cursor:not-allowed}.delete-warning{background:#eab3081a;border:1px solid rgba(234,179,8,.3);border-radius:8px;padding:16px;margin-bottom:24px}.delete-warning p{margin:0 0 12px;color:var(--text-primary);font-size:var(--text-sm);line-height:1.5}.delete-warning ul{margin:12px 0;padding-left:24px;color:var(--text-secondary);font-size:var(--text-sm)}.delete-warning li{margin:8px 0;line-height:1.4}.grace-period-notice{margin-top:16px;padding-top:16px;border-top:1px solid rgba(234,179,8,.3);color:var(--text-primary);font-size:var(--text-sm)}.grace-period-notice strong{color:var(--text-primary);font-weight:600}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:4px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px;line-height:1}.modal-close:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-close:disabled{opacity:.5;cursor:not-allowed}.payment-result-modal{max-width:520px;position:relative;display:flex;flex-direction:column}.payment-result-modal .modal-close-btn{position:absolute;top:16px;right:16px;z-index:1}.payment-result-content{padding:48px 40px;text-align:center;overflow-y:auto;flex:1;min-height:0}.payment-result-content.payment-receipt{text-align:left;padding-bottom:24px}.payment-result-content.payment-receipt .receipt-status{text-align:center}.receipt-sections{max-height:none}.payment-result-modal .payment-btn-footer{flex-shrink:0;padding:16px 40px 32px;background-color:var(--bg-primary);border-top:1px solid var(--border-color);position:sticky;bottom:0}.payment-result-modal .payment-btn-footer .payment-btn{width:100%}@media (max-width: 480px){.payment-result-modal{width:95%}.payment-result-content{padding:32px 24px 16px}.payment-result-modal .payment-btn-footer{padding:16px 24px 24px}}.sidebar{width:300px;background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100%;transition:width .3s ease,transform .3s ease}.sidebar-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;gap:12px;align-items:center;flex-shrink:0}.new-chat-btn{flex:1;padding:12px 16px;background-color:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s ease}.new-chat-btn:hover{background-color:var(--primary-hover)}.new-chat-btn .icon{font-size:var(--text-lg);font-weight:700}.header-actions{display:flex;gap:4px}.mobile-close-btn{display:none}.email-verification-banner{margin:8px 0;padding:12px;background:#05966914;border:1px solid rgba(5,150,105,.2);border-radius:8px;display:flex;flex-direction:column;gap:10px}.verification-content{display:flex;flex-direction:column;gap:4px}.verification-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.verification-text{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5}.resend-verification-btn{padding:8px 12px;background:var(--primary-color);border:1px solid var(--primary-color);border-radius:6px;font-size:var(--text-xs);font-weight:500;color:#fff;cursor:pointer;transition:all .2s ease;align-self:flex-start}.resend-verification-btn:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.resend-verification-btn:disabled{opacity:.5;cursor:not-allowed}.trial-status-section{padding:12px 16px;border-bottom:1px solid var(--border-color);background-color:var(--bg-tertiary);flex-shrink:0}.user-info{display:flex;align-items:center;justify-content:space-between}.user-details{display:flex;flex-direction:column;gap:2px}.user-email{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.logout-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:4px;transition:all .2s ease}.logout-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.messages-count{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);display:block;margin-bottom:4px}.messages-bar{width:100%;height:4px;background-color:var(--border-hover);border-radius:2px;overflow:hidden}.messages-progress{height:100%;background-color:var(--primary-color);border-radius:2px;transition:width .3s ease}.trial-time{display:flex;flex-direction:column;gap:4px;margin-top:4px}.trial-remaining{font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.trial-expiry{font-size:var(--text-xs);color:var(--text-muted)}.settings-panel{padding:16px;border-bottom:1px solid var(--border-color);background-color:var(--bg-tertiary)}.user-account-section{position:relative;padding:8px;border-top:1px solid var(--border-color);flex-shrink:0}.user-account-button{width:100%;display:flex;align-items:center;gap:12px;padding:10px;background:none;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease;color:var(--text-primary)}.user-account-button:hover{background-color:var(--bg-tertiary)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--text-sm);flex-shrink:0}.user-info-details{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:3px;min-width:0}.user-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap;width:100%}.user-plan{font-size:var(--text-xs);color:var(--text-muted);font-weight:400}.dropdown-arrow{display:flex;align-items:center;justify-content:center;width:16px;height:16px;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-arrow span{font-size:var(--text-xs);color:var(--text-muted)}.user-dropdown-menu{position:absolute;bottom:100%;left:16px;right:16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #00000026;padding:4px;z-index:1000;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;border-radius:6px;cursor:pointer;font-size:var(--text-sm);font-weight:500;text-align:left;color:var(--text-primary);transition:background-color .2s ease}.dropdown-menu-item:hover{background-color:var(--bg-tertiary)}.dropdown-menu-item.upgrade-item{color:var(--primary-color)}.dropdown-menu-item.upgrade-item:hover{background-color:#064e3b1a}.dropdown-menu-item.manage-item:hover,.dropdown-menu-item.logout-item:hover{background-color:var(--bg-tertiary)}.dropdown-menu-item.danger-item{color:var(--danger-color)}.dropdown-menu-item.danger-item:hover{background-color:#ef44441a}.menu-icon{font-size:var(--text-base);display:flex;align-items:center;justify-content:center;width:20px}.dropdown-menu-item.help-item{position:relative;cursor:pointer;display:flex;align-items:center;justify-content:space-between}.help-item-content{display:flex;align-items:center;gap:12px;flex:1}.submenu-arrow{display:flex;align-items:center;justify-content:center;width:16px;height:16px;transition:transform .2s ease}.submenu-arrow.open{transform:rotate(90deg)}.help-submenu-popup{position:absolute;left:100%;top:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #00000026;padding:4px;min-width:200px;z-index:1001;animation:slideInRight .2s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.submenu-link{display:block;padding:10px 12px;text-decoration:none;color:var(--text-primary);font-size:var(--text-sm);font-weight:400;border-radius:4px;transition:background-color .2s ease;white-space:nowrap}.submenu-link:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.chat-list-container{flex:1;position:relative;overflow:hidden;min-height:0;display:flex;flex-direction:column}.chat-list-container.restricted{position:relative}.chat-history-overlay{position:absolute;inset:0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:10;animation:fadeIn .3s ease}.overlay-content{padding:24px;margin:8px;text-align:center;width:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 8px 32px #064e3b26}.overlay-content h3{margin:0 0 12px;color:var(--primary-text);font-size:var(--text-lg);font-weight:600}.overlay-content p{margin:0 0 20px;color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5}.overlay-buttons{display:flex;flex-direction:column;gap:8px}.overlay-btn{padding:12px 16px;border:none;border-radius:8px;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.overlay-btn.primary{background-color:var(--primary-color);color:#fff}.overlay-btn.primary:hover{background-color:var(--primary-hover)}.overlay-btn.secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.overlay-btn.secondary:hover{background-color:var(--bg-tertiary);border-color:var(--border-hover)}.settings-item label{display:block;margin-bottom:4px;font-size:var(--text-xs);font-weight:500;color:var(--text-secondary)}.api-key-input{width:100%;margin-bottom:8px}.chat-list{flex:1;overflow-y:auto;padding:8px;transition:all .3s ease;-webkit-overflow-scrolling:touch;min-height:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center;padding:32px 16px}.empty-state p{margin-bottom:4px}.empty-subtitle{font-size:var(--text-xs)}.chat-item{padding:12px 10px;margin-bottom:4px;border-radius:8px;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;gap:12px;position:relative}.chat-item:hover{background-color:var(--bg-tertiary)}.chat-item.active{background-color:var(--primary-color);color:#fff}.chat-item.active .chat-date{color:#fffc}.chat-item.disabled{cursor:not-allowed;opacity:.7}.chat-item.disabled:hover{background-color:var(--bg-secondary);transform:none}.chat-item.disabled .delete-chat-btn{opacity:.4;cursor:not-allowed}.chat-item.disabled .delete-chat-btn:hover{background-color:transparent;color:var(--text-muted)}.chat-item.optimistic{opacity:.7;position:relative}.chat-item.optimistic:after{content:"";position:absolute;right:8px;top:50%;transform:translateY(-50%);width:12px;height:12px;border:2px solid var(--primary-color);border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:translateY(-50%) rotate(0)}to{transform:translateY(-50%) rotate(360deg)}}.chat-content{flex:1;min-width:0}.chat-title{font-weight:500;font-size:var(--text-sm);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-date{font-size:var(--text-xs);color:var(--text-muted)}.delete-chat-btn{padding:8px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;opacity:0;transition:all .2s ease;font-size:var(--text-sm)}.chat-item:hover .delete-chat-btn{opacity:1}.delete-chat-btn:hover{background-color:var(--danger-color);color:#fff}.chat-item.active .delete-chat-btn{color:#fffc}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color);flex-shrink:0}.app-info h3{font-size:var(--text-base);font-weight:600;margin-bottom:4px;color:var(--primary-color)}[data-theme=dark] .app-info h3{color:var(--text-primary)}.app-name-clickable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .2s ease;display:flex;align-items:center}.app-name-clickable:hover{opacity:.8}.app-name-clickable:active{opacity:.6}.app-version{font-size:var(--text-xs);font-weight:500;color:var(--text-muted);background-color:var(--surface-secondary);padding:2px 8px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.app-info p{font-size:var(--text-xs);color:var(--text-muted);line-height:1.4}@media (max-width: 1024px){.sidebar{width:250px}}@media (max-width: 768px){.sidebar{position:fixed;z-index:1000;left:0;top:0;bottom:0;transform:translate(-100%);width:84%;box-shadow:var(--shadow-lg);padding-top:env(safe-area-inset-top);padding-bottom:max(24px,env(safe-area-inset-bottom))}.sidebar.open{transform:translate(0)}.mobile-close-btn{display:flex}.delete-chat-btn{opacity:1}.sidebar-header{padding:12px}.new-chat-btn{padding:10px 14px;font-size:var(--text-sm)}.chat-title{font-size:var(--text-sm)}.chat-date{font-size:var(--text-xs)}.overlay-content h3{font-size:var(--text-base);margin-bottom:10px}.overlay-content p{margin-bottom:16px}.overlay-btn{padding:10px 14px}.overlay-buttons{gap:6px}.user-account-button{gap:10px}.user-avatar{width:32px;height:32px;font-size:var(--text-xs)}.dropdown-menu-item{padding:12px 14px}.help-submenu-popup{position:absolute;inset:auto 0 100%;min-width:auto;width:auto;margin:0 0 50px}}.contract-download-container{margin-top:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow)}.contract-info-box{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px;padding:12px;background:var(--bg-primary);border-radius:8px}.contract-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);border-radius:8px;color:#fff}.contract-details{flex:1;min-width:0}.contract-type{font-weight:700;font-size:15px;color:var(--text-primary);margin-bottom:4px;word-break:break-word}.contract-meta{font-size:12px;color:var(--text-secondary);font-weight:400;margin-bottom:6px}.contract-preview{font-size:12px;color:var(--text-secondary);line-height:1.4;max-height:40px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.contract-download-btn{width:100%;padding:12px 16px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.contract-download-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.contract-download-btn:active:not(:disabled){transform:translateY(0)}.contract-download-btn:disabled{opacity:.7;cursor:not-allowed}.download-spinner{animation:spin 1s linear infinite}.download-error{margin-top:8px;padding:8px 12px;background:#dc26261a;color:var(--danger-color);border:1px solid rgba(220,38,38,.2);border-radius:6px;font-size:12px;display:flex;align-items:center;gap:6px}.contract-expired{padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:14px;display:flex;align-items:center;gap:8px;justify-content:center}.contract-download-btn.upgrade-required{background:var(--warning-color)}.contract-download-btn.upgrade-required:hover:not(:disabled){background:#b45309}@media (max-width: 768px){.contract-download-container{padding:12px}.contract-info-box{padding:10px}.contract-icon{width:36px;height:36px}.contract-type{font-size:14px}.contract-meta{font-size:11px}.contract-download-btn{padding:10px 14px;font-size:13px}}.message-bubble{display:flex;flex-direction:column}.message-bubble.user{align-self:flex-end;max-width:70%}.message-bubble.assistant{align-self:flex-start}.message-content{border-radius:18px;line-height:var(--leading-relaxed);font-size:var(--text-base)}.message-bubble.user .message-content{padding:6px 16px;background-color:var(--message-user-bg);color:var(--text-primary)}.message-bubble.assistant .message-content{color:var(--text-primary)}.ai-response{display:flex;flex-direction:column;gap:16px}.ai-answer{line-height:var(--leading-relaxed);padding:6px 0}.law-quotes{padding-top:16px;border-top:1px solid var(--border-color)}.quotes-header{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--primary-color);font-size:var(--text-sm)}.quotes-header.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .2s;margin-bottom:0}.quotes-header.clickable:hover{opacity:.7}.quotes-header-text{flex:1}.chevron-icon{display:inline-flex;align-items:center;transition:transform .2s ease;color:var(--text-secondary)}.chevron-icon.expanded{transform:rotate(0)}.quotes-icon{font-size:var(--text-base);color:var(--primary-color);display:inline-flex;align-items:center}.quotes-content{display:flex;flex-direction:column;gap:4px;margin-top:12px}.quote-item{padding:12px 16px;background-color:var(--message-quote-bg);border-left:2px solid var(--primary-color);border-top-right-radius:18px;border-bottom-right-radius:18px;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word}@media (max-width: 768px){.quotes-header{gap:6px;font-size:var(--text-sm)}.quotes-icon{font-size:var(--text-sm)}}.user-message-with-document{display:flex;flex-direction:column;gap:8px}.message-text{flex:1}.document-indicator{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#0000000f;border-radius:8px;font-size:var(--text-sm);color:var(--text-secondary)}.document-icon{flex-shrink:0;color:var(--primary-color)}.document-text{font-weight:500;color:var(--text-primary);word-break:break-word}.message-content ul{margin:8px 0;padding-left:20px;list-style-type:disc}.message-content ol{margin:8px 0;padding-left:20px;list-style-type:decimal}.message-content li{margin:8px 0;line-height:var(--leading-normal)}.message-content strong{font-weight:600;color:var(--text-primary);line-height:3}.message-content em{font-style:italic}.message-content p{margin:8px 0}.message-content p:first-child{margin-top:0}.message-content p:last-child{margin-bottom:0}.quote-item ul,.quote-item ol{margin:4px 0;line-height:var(--leading-xs)}.quote-item li{margin:2px 0}@media (max-width: 768px){.message-content ul,.message-content ol{padding-left:16px}}.message-actions{display:flex;align-items:center;gap:8px}.feedback-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;position:relative}.feedback-btn:hover{background-color:var(--hover-bg);color:var(--text-primary);border-color:var(--text-secondary)}.feedback-btn:active{transform:scale(.95)}.feedback-btn.active{background-color:var(--bg-tertiary)}.feedback-btn:disabled{opacity:.5;cursor:not-allowed}.feedback-notification{position:fixed;top:60px;left:50%;transform:translate(-50%) translateY(-100%);background-color:#fff;color:var(--text-primary);padding:12px 24px;border-radius:8px;font-size:var(--text-sm);font-weight:500;box-shadow:0 2px 8px #0000001a;z-index:1000;animation:slideDown .3s ease-out forwards;pointer-events:none}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-100%)}to{opacity:1;transform:translate(-50%) translateY(0)}}.feedback-notification.removing{animation:slideUpOut .3s ease-out forwards}@keyframes slideUpOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-100%)}}@media (max-width: 768px){.feedback-notification{top:76px;max-width:90%;padding:10px 20px;font-size:13px;text-align:center;white-space:nowrap}}@media (min-width: 769px){.modal-content.template-library{max-width:800px;width:95%;max-height:90vh;max-height:90dvh}}.template-library-content{display:flex;flex-direction:column;gap:20px;height:100%}.template-search{display:flex;align-items:center;padding:8px 12px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease}.template-search:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.template-search svg{color:var(--text-muted);flex-shrink:0}.template-search-input{flex:1;border:none;background:none;color:var(--text-primary);font-size:var(--text-sm);outline:none}.template-search-input::placeholder{color:var(--text-muted)}.template-accordion{display:flex;flex-direction:column;gap:0;overflow-y:auto;max-height:60vh;min-height:0;flex:1}@media (min-height: 768px){.template-accordion{max-height:none}}@media (max-width: 768px){.template-accordion{max-height:none;flex:1}}.template-accordion::-webkit-scrollbar{width:8px}.template-accordion::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.template-accordion::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.template-accordion::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.category-section{border-bottom:1px solid var(--border-color);overflow:hidden;transition:all .2s ease;flex-shrink:0}.category-section:hover{border-color:var(--border-hover)}.category-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 0;background-color:transparent;border:none;cursor:pointer;transition:all .2s ease;color:var(--text-primary)}.category-header:hover{background-color:var(--bg-secondary)}.category-header-content{display:flex;align-items:center;gap:8px}.category-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.category-count{font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.category-templates{display:flex;flex-direction:column;gap:8px;background-color:var(--bg-primary);margin:8px 0}.template-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease;cursor:pointer}.template-item:hover{border-color:var(--border-hover);background-color:var(--bg-tertiary);box-shadow:0 2px 6px #0000000f}.template-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.template-icon{font-size:24px;flex-shrink:0}.template-details{flex:1;min-width:0}.template-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.template-description{margin:0;font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-download-btn{padding:10px;background-color:transparent;color:var(--text-primary);border:none;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0;pointer-events:none}.template-download-btn:hover{background-color:var(--bg-secondary)}.template-download-btn:active{transform:translateY(0)}.templates-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.templates-empty p{margin:0;font-size:var(--text-sm)}.templates-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite}.templates-loading p{margin:0;color:var(--text-muted);font-size:var(--text-sm)}@media (max-width: 768px){.template-library-content{gap:16px}.template-item{padding:12px}.template-icon{font-size:20px}.template-name{font-size:var(--text-xs)}.template-description{font-size:11px}.template-download-btn{padding:8px}.template-download-btn svg{width:16px;height:16px}}.chat-area{flex:1;display:flex;flex-direction:column;background-color:var(--bg-primary);overflow:hidden;min-height:0}.chat-content-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}@media (max-width: 768px){.chat-content-wrapper{overflow:hidden}}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:32px;overflow-y:auto;-webkit-overflow-scrolling:touch}.welcome-content{text-align:center;max-width:600px;width:100%}.welcome-content h1{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);margin-bottom:8px}.welcome-content>p{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:40px}.example-questions{text-align:left;background-color:var(--bg-primary);border-radius:12px;margin-bottom:32px}.example-questions h3{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.question-examples{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.example-question{padding:12px 16px;background-color:var(--bg-secondary);border-radius:8px;color:var(--text-secondary);font-size:15px}.example-question.clickable{cursor:pointer;transition:all .2s ease}.example-question.clickable:hover{background-color:var(--bg-secondary);border-color:var(--primary-color);color:var(--text-primary)}.start-hint{font-size:var(--text-sm);color:var(--text-muted)}.messages-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;justify-content:center;min-height:0;-webkit-overflow-scrolling:touch}.messages-container{padding:24px;display:flex;flex-direction:column;gap:24px;box-sizing:border-box;max-width:800px;width:100%}.messages-container:after{content:"";height:24px;flex-shrink:0}.empty-chat{flex:1;display:flex;align-items:center;justify-content:center}.empty-chat-content{text-align:center;padding:48px 24px}.empty-icon{font-size:var(--text-4xl);margin-bottom:16px;display:block}.empty-chat-content h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:12px}.empty-chat-content p{color:var(--text-secondary);margin-bottom:8px}.loading-indicator{display:flex;align-items:center;gap:12px;padding:16px 20px;background-color:var(--bg-secondary);border-radius:16px;max-width:fit-content;color:var(--text-secondary);font-size:var(--text-sm)}.typing-animation{display:flex;gap:3px}.typing-animation .dot{width:6px;height:6px;background-color:var(--primary-color);border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-animation .dot:nth-child(1){animation-delay:-.32s}.typing-animation .dot:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.input-form{flex-shrink:0;padding:12px 24px 24px;background-color:var(--bg-primary)}.input-container{max-width:800px;margin:0 auto}.message-input-wrapper{flex:1;position:relative;display:flex;align-items:flex-end;border:1px solid var(--border-color);border-radius:50px;background-color:var(--bg-primary);transition:border-color .2s ease}.message-input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #064e3b1a}.message-input{flex:1;min-height:48px;max-height:120px;padding:14px 84px 14px 20px;border:none;border-radius:50px;background-color:transparent;color:var(--text-primary);font-size:var(--text-base);line-height:var(--leading-normal);resize:none;overflow-y:hidden;font-family:inherit}.message-input:focus{outline:none}.message-input:disabled{opacity:.6;cursor:not-allowed}.message-input::placeholder{color:var(--text-muted)}.send-button-inline{position:absolute;right:6px;top:50%;transform:translateY(-50%);z-index:2;padding:8px;background-color:var(--primary-color);color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:38px;height:38px}.send-button-inline:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-50%) scale(1.05)}.send-button-inline:disabled{background-color:var(--border-color);cursor:not-allowed}.send-icon{font-size:var(--text-base);font-weight:700;transform:translate(-1px)}.file-upload-btn-inline{position:absolute;left:8px;top:50%;transform:translateY(-50%);z-index:2;padding:8px;background:none;border:none;color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;border-radius:50%;min-width:38px;height:38px}.file-upload-btn-inline:hover:not(:disabled){background-color:var(--bg-secondary)}.file-upload-btn-inline:disabled{opacity:.6;cursor:not-allowed}.mic-btn-inline{position:absolute;right:48px;top:50%;transform:translateY(-50%);z-index:2;padding:8px;background:none;border:none;color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;border-radius:50%;min-width:38px;height:38px}.mic-btn-inline:hover:not(:disabled){background-color:var(--bg-secondary)}.mic-btn-inline:disabled{opacity:.6;cursor:not-allowed}.mic-btn-inline.recording{color:#ef4444;background-color:#ef44441a;animation:pulse-recording 1.5s ease-in-out infinite}.mic-btn-inline.recording:hover{color:#dc2626;background-color:#dc262626}.mic-btn-inline.processing{color:var(--primary-color);background-color:#064e3b1a}@keyframes pulse-recording{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.file-preview{padding:12px 0;margin-bottom:12px;max-width:800px;margin-left:auto;margin-right:auto}.file-preview-content{display:flex;align-items:center;justify-content:space-between;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:12px 16px}.file-info{display:flex;align-items:center;gap:12px;flex:1}.file-icon{font-size:var(--text-xl);display:flex;align-items:center;justify-content:center}.file-details{display:flex;flex-direction:column;gap:2px}.file-name{font-weight:500;color:var(--text-primary);font-size:var(--text-sm)}.file-meta{font-size:var(--text-xs);color:var(--text-muted)}.file-remove-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.file-remove-btn:hover{color:var(--text-primary);background-color:var(--bg-primary)}.file-processing{display:flex;flex-direction:column;gap:4px;min-width:120px}.processing-bar{width:100%;height:4px;background-color:var(--bg-primary);border-radius:2px;overflow:hidden}.processing-progress{height:100%;background-color:var(--primary-color);transition:width .3s ease;border-radius:2px}.processing-text{font-size:var(--text-xs);color:var(--text-muted);text-align:center}.processing-spinner{display:inline-block;animation:spin 2s linear infinite}.input-hint{text-align:center;font-size:var(--text-xs);color:var(--text-muted);margin-top:12px;max-width:800px;margin-left:auto;margin-right:auto}.feature-actions{display:flex;gap:8px;justify-content:left;align-items:start;margin-bottom:8px;max-width:800px;margin-left:auto;margin-right:auto}.feature-action-btn{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background-color:var(--message-user-bg);border:none;border-radius:50px;color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;cursor:pointer;transition:all .2s ease}.feature-action-btn:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.feature-action-btn:active:not(:disabled){transform:translateY(0)}.feature-action-btn:disabled{opacity:.5;cursor:not-allowed}.chat-feature-icon{display:flex;align-items:center;justify-content:center;transition:all .2s ease}.feature-label{font-size:var(--text-xs);font-weight:600;letter-spacing:.3px}@media (max-width: 1024px){.welcome-content h1{font-size:var(--text-2xl)}.welcome-content>p{font-size:var(--text-base)}}@media (max-width: 768px){.chat-area{overflow:hidden}.welcome-screen{padding:16px;overflow-y:auto;overflow-x:hidden;align-items:center;justify-content:center;min-height:0}.welcome-content h1{font-size:var(--text-2xl);margin-bottom:6px}.welcome-content>p{font-size:var(--text-sm);margin-bottom:16px}.welcome-content{max-width:none;padding:0;width:100%;flex-shrink:1}.example-questions{font-size:var(--text-sm);padding:16px 0;margin-bottom:4px;margin-left:-16px;margin-right:-16px}.example-questions h3{padding:0 16px}.question-examples{justify-content:start;overflow-x:auto;padding-bottom:8px;padding-left:16px;padding-right:16px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.question-examples::-webkit-scrollbar{height:4px}.question-examples::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:2px;margin-left:16px;margin-right:16px}.question-examples::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px;margin-left:16px;margin-right:16px}.question-examples::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.example-question{flex:0 0 auto;min-width:180px;max-width:200px;margin-bottom:4px;white-space:normal;word-wrap:break-word}.messages-wrapper{overflow-y:auto;overflow-x:hidden}.messages-container:after{height:16px}.empty-chat-content{padding:24px 16px}.empty-chat-content h3{font-size:var(--text-lg)}.input-form{padding:12px 16px 16px;padding-bottom:max(16px,env(safe-area-inset-bottom));z-index:100;background-color:var(--bg-primary);flex-shrink:0}.tauri-ios .input-form{padding-bottom:env(safe-area-inset-bottom)}.message-input{font-size:var(--text-base);padding:14px 72px 14px 18px;min-height:44px;max-height:100px}.file-upload-btn-inline{min-width:36px;height:36px;padding:6px}.mic-btn-inline{right:42px;min-width:36px;height:36px;padding:6px}.file-preview{margin-bottom:8px}.file-preview-content{padding:10px 12px}.file-name,.file-meta{font-size:var(--text-xs)}.send-button-inline{min-width:36px;height:36px;padding:6px}.send-icon{font-size:var(--text-sm)}.loading-indicator{padding:12px 16px;font-size:var(--text-xs)}}.law-selector{padding:16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px;--law-selector-height: auto}.law-selector-header{display:flex;align-items:center;gap:12px}.law-selector-auth{display:flex;gap:8px;margin-left:auto}.law-selector-auth-m{display:none}.law-auth-btn{padding:6px 12px;font-size:var(--text-xs);font-weight:500;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;white-space:nowrap}.law-auth-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.law-auth-btn.primary{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.law-auth-btn.primary:hover{background-color:var(--primary-hover);border-color:var(--primary-hover)}.law-selector-label{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--text-primary);font-size:var(--text-sm);white-space:nowrap}.app-logo{height:17px;width:auto}.app-logo.light-logo{display:block}.app-logo.dark-logo,[data-theme=dark] .app-logo.light-logo{display:none}[data-theme=dark] .app-logo.dark-logo{display:block}.mobile-menu-btn{display:none;background-color:transparent;color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:var(--text-base);font-weight:700;transition:background-color .2s ease}.new-conversation-btn{display:none;background:none;color:var(--text-primary);border:none;cursor:pointer;transition:all .2s ease;align-items:center;justify-content:center;width:40x;height:40px;padding:8px;margin-left:auto}.law-select-container{position:relative;flex:1;max-width:400px;margin:0 auto}.law-select{width:100%;padding:8px 40px 8px 12px;font-size:var(--text-sm);font-weight:400;background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;cursor:text;transition:border-color .2s ease}.law-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #064e3b1a}.law-select::placeholder{color:var(--text-muted)}.clear-button{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);border-radius:3px;transition:all .2s ease}.clear-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.law-dropdown{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;box-shadow:var(--shadow-lg);max-height:200px;overflow-y:auto;z-index:1000;margin-top:4px}.law-option{padding:10px 12px;font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid var(--border-color)}.law-option:last-child{border-bottom:none}.law-option:hover,.law-option.highlighted{background-color:var(--bg-secondary)}.no-results{padding:12px;font-size:var(--text-sm);color:var(--text-muted);text-align:center;font-style:italic}.highlight{background-color:var(--primary-color);color:#fff;padding:1px 2px;border-radius:3px;font-weight:600}@media (max-width: 768px){.mobile-menu-btn{display:flex;width:40px;height:40px;padding:0;align-items:center;justify-content:center}.new-conversation-btn{display:flex}.law-selector{position:sticky;top:0;z-index:100;flex-shrink:0;padding:12px 16px;flex-direction:column;align-items:flex-start;min-height:auto;--law-selector-height: auto;background-color:var(--bg-primary)}.law-selector-header{width:100%;position:relative;display:flex;align-items:center}.law-selector-label{font-size:var(--text-sm);position:absolute;left:50%;transform:translate(-50%);white-space:nowrap;z-index:1}.law-selector-auth{display:none}.law-selector-auth-m{display:flex;margin-left:auto}.law-auth-btn.primary{display:none}.law-auth-btn{padding:6px 12px}.law-select-container{max-width:100%;width:100%;margin:8px 0 0}.law-select{padding:12px 35px 12px 10px;font-size:var(--text-base)}.clear-button{right:6px;font-size:var(--text-sm)}}.announcement-banner{position:relative;z-index:100;background:#3d3d3d;color:#fff;padding:6px 16px;box-shadow:0 2px 8px #0000001a}.announcement-banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:10px}.announcement-banner-content>svg{flex-shrink:0;opacity:.9}.announcement-banner-text{margin:0;font-size:14px;line-height:1.5;color:#fff;text-align:center}.announcement-banner-text strong{font-weight:600;margin-right:4px}@media (max-width: 768px){.announcement-banner-text{font-size:13px}.announcement-banner-content{gap:8px}}.auth-page{position:fixed;inset:0;display:flex;background:var(--bg-primary);overflow:hidden}.auth-page-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px;overflow-y:auto;background:var(--bg-primary)}.auth-page-form-container{width:100%;max-width:440px;animation:fadeSlideIn .4s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-page-brand{text-align:center;margin-bottom:32px}.auth-page-logo{height:26px;width:auto;margin-bottom:16px}.auth-page-logo.light-logo{display:block;margin:0 auto 16px}.auth-page-logo.dark-logo{display:none}@media (prefers-color-scheme: dark){.auth-page-logo.light-logo{display:none}.auth-page-logo.dark-logo{display:block;margin:0 auto 16px}}.dark .auth-page-logo.light-logo,html[data-theme=dark] .auth-page-logo.light-logo{display:none}.dark .auth-page-logo.dark-logo,html[data-theme=dark] .auth-page-logo.dark-logo{display:block;margin:0 auto 16px}.auth-page-brand-subtitle{font-size:15px;color:var(--text-muted);margin:0}.auth-page-title{text-align:center;margin-bottom:30px}.auth-page-title h2{font-size:15px;font-weight:500;color:var(--text-primary);margin:0}.auth-page-reason{display:flex;gap:12px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:20px;color:var(--text-secondary)}.auth-page-reason.info{background:#064e3b0d;border-color:#064e3b33;color:var(--primary-color)}.auth-page-reason strong{display:block;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.auth-page-reason p{margin:0;font-size:14px;line-height:1.5}.auth-page-tabs{display:flex;gap:8px;background:var(--bg-secondary);padding:4px;border-radius:12px;margin-bottom:24px}.auth-page-tab{flex:1;padding:10px 16px;font-size:15px;font-weight:500;color:var(--text-muted);background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.auth-page-tab:hover:not(:disabled){color:var(--text-primary)}.auth-page-tab.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.auth-page-tab:disabled{cursor:not-allowed;opacity:.6}.auth-page-back-title{margin-bottom:24px}.auth-page-back-title h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.auth-page-form{display:flex;flex-direction:column;gap:24px}.auth-page-form-group{display:flex;flex-direction:column;gap:8px}.auth-page-label{font-size:14px;font-weight:500;color:var(--text-primary)}.auth-page-input{width:100%;padding:12px 16px;font-size:15px;color:var(--text-primary);background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:10px;transition:all .2s ease;outline:none}.auth-page-input:hover:not(:disabled){border-color:var(--text-muted)}.auth-page-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #064e3b1a}.auth-page-input.error{border-color:var(--danger-color)}.auth-page-input:disabled{opacity:.6;cursor:not-allowed}.auth-page-input[type=password]::-ms-reveal,.auth-page-input[type=password]::-ms-clear{display:none}.auth-page-input[type=password]::-webkit-credentials-auto-fill-button,.auth-page-input[type=password]::-webkit-contacts-auto-fill-button{visibility:hidden;pointer-events:none;position:absolute}.auth-page-password-wrapper{position:relative}.auth-page-password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.auth-page-password-toggle:hover:not(:disabled){color:var(--text-primary);background:var(--bg-tertiary)}.auth-page-password-toggle:disabled{cursor:not-allowed}.auth-page-error{font-size:13px;color:var(--danger-color);margin-top:4px}.auth-page-success{padding:12px 16px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:8px;color:#059669;font-size:14px;font-weight:500}.auth-page-submit{width:100%;padding:14px 24px;font-size:15px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.auth-page-submit:hover:not(:disabled){transform:translateY(-1px)}.auth-page-submit:active:not(:disabled){transform:translateY(0)}.auth-page-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-page-loading{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.auth-page-divider{display:flex;align-items:center;text-align:center;color:var(--text-muted);font-size:14px;margin:24px 0}.auth-page-divider:before,.auth-page-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.auth-page-divider span{padding:0 16px}.auth-page-social-top{display:flex;flex-direction:column;gap:12px}.auth-page-social-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;font-size:15px;font-weight:500;color:var(--text-primary);background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease}.auth-page-social-btn:hover:not(:disabled){border-color:var(--text-muted);background:var(--bg-secondary)}.auth-page-social-btn:disabled{opacity:.6;cursor:not-allowed}.auth-page-social-btn svg{flex-shrink:0}.auth-page-email-wrapper{position:relative}.auth-page-email-change{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.auth-page-email-change:hover{color:var(--primary-color);background:var(--bg-tertiary)}.auth-page-terms{text-align:center;font-size:12px;line-height:1.5;color:var(--text-muted);margin-top:16px;padding:0 8px}.auth-page-terms a{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:all .2s ease}.auth-page-terms a:hover{color:var(--text-secondary)}.auth-page-footer-link{text-align:center;margin-top:8px}.auth-page-link-btn{background:none;border:none;color:var(--primary-color);font-size:14px;font-weight:500;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease}.auth-page-link-btn:hover:not(:disabled){background:#064e3b1a;color:var(--primary-hover)}.auth-page-link-btn:disabled{opacity:.6;cursor:not-allowed}.auth-page-carousel-side{flex:1;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover))}.auth-page-carousel{width:100%;height:100%;position:relative}.auth-page-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease-in-out}.auth-page-slide.active{opacity:1}.auth-page-slide-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#064e3be6,#0a5e40cc);display:flex;align-items:center;justify-content:center;padding:60px}.auth-page-slide-content{max-width:600px;text-align:center;color:#fff}.auth-page-slide-content h2{font-size:40px;font-weight:700;margin:0 0 20px;line-height:1.2}.auth-page-slide-content p{font-size:18px;line-height:1.6;opacity:.95;margin:0}.auth-page-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;z-index:10}.auth-page-carousel-arrow:hover{background:#ffffff4d;transform:translateY(-50%) scale(1.05)}.auth-page-carousel-arrow:active{transform:translateY(-50%) scale(.95)}.auth-page-carousel-arrow.prev{left:30px}.auth-page-carousel-arrow.next{right:30px}.auth-page-carousel-indicators{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;gap:12px;z-index:10}.auth-page-indicator{width:8px;height:8px;border-radius:50%;background:#fff6;border:none;cursor:pointer;transition:all .3s ease;padding:0}.auth-page-indicator:hover{background:#fff9}.auth-page-indicator.active{width:24px;border-radius:4px;background:#fff}@media (max-width: 768px){.auth-page{flex-direction:column}.auth-page-carousel-side{display:none}.auth-page-form-side{padding:20px 16px}.auth-page-form-container{max-width:100%}.auth-page-brand{margin-bottom:24px}.auth-page-logo{width:auto;height:24px;margin-bottom:12px}.auth-page-brand-title{font-size:24px}.auth-page-brand-subtitle{font-size:14px}.auth-page-reason{padding:12px;margin-bottom:20px}.auth-page-tabs{margin-bottom:20px}.auth-page-tab{padding:8px 12px;font-size:14px}.auth-page-back-title h2{font-size:20px}.auth-page-form{gap:20px}.auth-page-input{padding:11px 14px;font-size:16px}.auth-page-submit{padding:13px 20px}.auth-page-social{flex-direction:column}.auth-page-social-btn{width:100%}.auth-page-divider{margin:20px 0}.auth-page-title h2{font-size:14px}}@media (prefers-color-scheme: dark){.auth-page-slide-overlay{background:linear-gradient(135deg,#064e3bf2,#0a5e40e6)}}.modal-content.plan-selection{max-width:1140px;width:95%;overflow-y:auto}.plan-selection-content{position:relative}.processing-overlay{position:fixed;inset:0;background:#fffffff2;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;border-radius:0}[data-theme=dark] .processing-overlay{background:#141417f2}.processing-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-message{margin-top:16px;font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.current-status{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--bg-tertiary);border-radius:8px;margin-bottom:20px;border:1px solid var(--border-color)}.status-info,.usage-info{display:flex;flex-direction:column;gap:4px}.status-label,.usage-label{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.status-value,.usage-value{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.status-value.trial,.status-value.probni-period{color:var(--warning-color)}.status-value.premium{color:var(--success-color)}.billing-toggle-container{display:flex;justify-content:center;margin-bottom:24px}.billing-toggle{display:flex;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50px;padding:4px;position:relative;overflow:hidden}.billing-option{position:relative;padding:12px 20px;border:none;background:transparent;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;border-radius:50px;display:flex;align-items:center;gap:8px;min-width:100px;justify-content:center}.billing-option:hover{color:var(--text-primary)}.billing-option.active{background:var(--primary-color);color:#fff;font-weight:600}.discount-badge{background:#fff3;color:inherit;padding:2px 6px;border-radius:4px;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.billing-option:not(.active) .discount-badge{background:var(--success-color);color:#fff}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:32px;justify-content:center}.plans-grid.single-plan{grid-template-columns:1fr;max-width:400px;margin:0 auto 32px}.plans-grid.multi-plan{grid-template-columns:repeat(auto-fit,380px);gap:32px;justify-content:center;margin:0 auto 30px}@media (max-width: 768px){.plans-grid.multi-plan{grid-template-columns:1fr;gap:24px;margin:0 auto 24px}}.plans-grid:has(.plan-card:only-child){grid-template-columns:1fr;max-width:400px;margin:0 auto 32px}.plan-card{position:relative;padding:24px;border:2px solid var(--border-color);border-radius:12px;background:var(--bg-primary);transition:all .3s ease;overflow:visible}.plan-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.plan-card.selected{border-color:var(--primary-color);background:var(--bg-secondary);box-shadow:0 0 0 1px var(--primary-color)}.plan-card.current-plan{border-color:var(--success-color);background:#22c55e0d}.plan-card.disabled{opacity:.6;cursor:not-allowed}.plan-card.disabled:hover{transform:none;border-color:var(--border-color);box-shadow:none}.plan-card.popular{border-color:var(--primary-color);position:relative}.popular-badge{position:absolute;top:-16px;left:50%;transform:translate(-50%);background:var(--primary-color);color:#fff;padding:6px 16px;border-radius:50px;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;z-index:1}.plan-header{text-align:center;margin-bottom:24px}.plan-name{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:8px}.plan-target{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:16px;font-style:italic}.plan-price-container{display:flex;flex-direction:column;align-items:center;gap:4px}.original-price{font-size:var(--text-lg);font-weight:500;color:var(--text-muted);text-decoration:line-through;line-height:1}.plan-price{font-size:var(--text-3xl);font-weight:800;color:var(--primary-color);line-height:1}.monthly-equivalent{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);padding:4px 12px;border-radius:20px;line-height:1;margin-top:6px}.plan-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.plan-badge.current{background:var(--success-color);color:#fff}.plan-badge.recommended{background:var(--primary-color);color:#fff}.plan-badge.contact{background:var(--warning-color);color:#fff}.plan-badge.default{background:var(--bg-tertiary);color:var(--text-secondary)}.plan-features{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.feature-item{display:flex;align-items:center;gap:12px}.feature-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;flex-shrink:0}.feature-item:not(.disabled) .feature-icon{background:#10b981;color:#fff}.feature-item.disabled .feature-icon{background:#f3f4f6;color:#9ca3af}.feature-text{font-size:15px;color:var(--text-primary);line-height:1.4}.feature-item.disabled .feature-text{color:#9ca3af}.selection-indicator{display:flex;align-items:center;gap:8px;margin-top:16px;padding:8px 12px;background:#3b82f61a;border:1px solid var(--primary-color);border-radius:6px;font-size:var(--text-xs);font-weight:600;color:var(--primary-color)}.indicator-icon{font-size:var(--text-xs)}.btn-primary,.btn-secondary{padding:12px 24px;border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease;border:none;min-width:120px}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled,.btn-primary.disabled{background:var(--border-color);color:var(--text-muted);cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-hover)}@media (max-width: 768px){.modal-content.plan-selection{width:100%;max-width:100%}.current-status{flex-direction:column;gap:16px;align-items:flex-start}.billing-toggle{padding:3px}.billing-option{padding:10px 16px;font-size:var(--text-sm);min-width:80px}.discount-badge{font-size:var(--text-xs);padding:1px 4px}.plans-grid{grid-template-columns:1fr;gap:16px}.plan-card{padding:20px}.plan-name{font-size:var(--text-xl)}.plan-price{font-size:var(--text-2xl)}.original-price{font-size:var(--text-base)}.monthly-equivalent{font-size:var(--text-xs);padding:3px 10px}.modal-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%;min-width:unset}}.subscription-footer{margin-top:32px;padding-top:20px;border-top:1px solid var(--border-color);text-align:center}.cancel-subscription-link{background:none;border:none;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;padding:8px 16px;transition:color .2s ease}.cancel-subscription-link:hover{color:var(--danger-color)}.subscription-actions{display:flex;justify-content:center;align-items:center;gap:12px;margin:24px 0;flex-wrap:wrap}.cancel-subscription-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:transparent;color:var(--danger-color);border:2px solid var(--danger-color);border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-subscription-btn:hover{background:var(--danger-color);color:#fff}.subscription-note{padding:16px;background:var(--bg-tertiary);border-radius:8px;border-left:4px solid var(--warning-color);margin-top:20px}.subscription-note p{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.5}.billing-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:16px;text-align:center;line-height:1.5}.billing-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:4px}.billing-equivalent{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px;font-weight:500}.current-plan-badge{background:var(--success-color);color:#fff;font-size:var(--text-xs);font-weight:600;padding:4px 8px;border-radius:12px;margin-top:8px;text-align:center}.billing-options-compact{background:var(--bg-secondary);border-radius:8px;padding:4px;margin-bottom:24px}.billing-option-row{display:flex;align-items:center;padding:12px 16px;cursor:pointer;border-radius:6px;transition:background .2s ease}.billing-option-row:hover{background:var(--bg-tertiary)}.billing-option-row.active{background:var(--bg-primary)}.billing-option-radio{width:18px;height:18px;border:2px solid var(--border-color);border-radius:50%;margin-right:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s ease}.billing-option-row.active .billing-option-radio{border-color:var(--primary-color)}.billing-option-radio .radio-dot{width:10px;height:10px;border-radius:50%;background:transparent;transition:background .2s ease}.billing-option-row.active .radio-dot{background:var(--primary-color)}.billing-option-label{flex:1;font-size:var(--text-sm);font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:8px}.billing-discount-tag{background:var(--success-color);color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px}.billing-current-tag{color:var(--text-muted);font-size:var(--text-xs);font-weight:400}.billing-option-price{font-size:var(--text-sm);color:var(--text-secondary);text-align:right}.billing-option-row.active .billing-option-price{color:var(--text-primary);font-weight:500}.price-equivalent{font-size:var(--text-sm)}.restore-link-container{text-align:center;margin-top:8px}.subscription-payment-methods-section{margin:24px 0;padding:20px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color)}.billing-confirm-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;border-radius:8px}.billing-confirm-dialog{background:var(--bg-primary);border-radius:12px;padding:24px;max-width:320px;width:90%;text-align:center;box-shadow:0 8px 32px #0003}.billing-confirm-dialog h4{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 20px}.billing-confirm-change{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px;padding:12px;background:var(--bg-secondary);border-radius:8px}.billing-from{color:var(--text-secondary);font-size:var(--text-sm)}.billing-to{color:var(--primary-color);font-weight:600;font-size:var(--text-sm)}.billing-confirm-price{margin-bottom:12px}.billing-confirm-price .new-price{font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.billing-confirm-price .price-detail{font-size:var(--text-sm);color:var(--text-secondary);margin-top:4px}.billing-confirm-note{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 20px;line-height:1.4}.billing-confirm-actions{display:flex;gap:12px}.billing-confirm-cancel,.billing-confirm-submit{flex:1;padding:12px 16px;border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.billing-confirm-cancel{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.billing-confirm-cancel:hover{background:var(--bg-tertiary)}.billing-confirm-submit{background:var(--primary-color);border:none;color:#fff}.billing-confirm-submit:hover{background:var(--primary-hover)}.subscription-billing-section{margin:24px 0}.subscription-billing-section h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:8px;text-align:center}.subscription-billing-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:20px;text-align:center;line-height:1.5;padding:0 16px}.subscription-billing-options{display:flex;flex-direction:column;gap:12px;max-width:400px;margin:0 auto}.subscription-billing-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;position:relative}.subscription-billing-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.subscription-billing-card.active{border-color:var(--primary-color);background:var(--bg-primary);box-shadow:0 0 0 1px var(--primary-color)}.subscription-billing-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.subscription-billing-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.subscription-billing-price{font-size:var(--text-2xl);font-weight:700;color:var(--primary-color);margin-bottom:4px}.subscription-billing-equivalent{font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg-tertiary);padding:4px 8px;border-radius:6px;display:inline-block;margin-bottom:4px}.subscription-billing-savings{font-size:var(--text-sm);color:var(--success-color);font-weight:600}.subscription-discount-badge{background:var(--success-color);color:#fff;font-size:var(--text-xs);font-weight:600;padding:4px 8px;border-radius:12px}.subscription-current-badge{background:var(--primary-color);color:#fff;font-size:var(--text-xs);font-weight:600;padding:4px 8px;border-radius:12px}@media (min-width: 640px){.subscription-billing-options{flex-direction:row;max-width:none}.subscription-billing-card{flex:1}}.confirmation-modal{max-width:400px}.confirmation-content{text-align:center;padding:20px 0}.confirmation-icon{margin-bottom:16px;color:var(--warning-color)}.confirmation-content h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:12px}.confirmation-content p{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin:0}.btn-danger{background:var(--danger-color);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.plan-action{margin-top:auto;padding-top:20px}.btn-plan{width:100%;padding:12px 24px;border:none;border-radius:8px;font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all .2s ease}.btn-plan.upgrade{background:var(--primary-color);color:#fff}.btn-plan.upgrade:hover{background:var(--primary-color);transform:translateY(-1px)}.btn-plan.current{background:var(--primary-color);color:#fff;cursor:default}.btn-plan:disabled{opacity:.6;cursor:not-allowed;transform:none}.plan-card{display:flex;flex-direction:column;min-height:400px}.subscription-plan-section{margin:24px 0;padding:20px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);text-align:center}.subscription-plan-section h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:8px}.subscription-plan-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.change-plan-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.change-plan-btn:hover{background:var(--primary-hover)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0}.back-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;font-size:var(--text-sm);cursor:pointer;transition:all .2s ease}.back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.plan-change-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.plan-change-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:20px;transition:all .2s ease;text-align:center}.plan-change-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.plan-change-card.current{border-color:var(--success-color);background:var(--bg-primary);box-shadow:0 0 0 1px var(--success-color)}.plan-change-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.plan-change-header h4{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.current-plan-badge{background:var(--success-color);color:#fff;font-size:var(--text-xs);font-weight:600;padding:4px 8px;border-radius:12px}.plan-change-pricing{margin-bottom:16px}.monthly-price,.yearly-price{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:4px}.monthly-price{font-weight:600;color:var(--text-primary)}.plan-change-btn{width:100%;padding:10px 16px;border:none;border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.plan-change-btn.change{background:var(--primary-color);color:#fff}.plan-change-btn.change:hover{background:var(--primary-hover);transform:translateY(-1px)}.plan-change-btn.current{background:var(--success-color);color:#fff;cursor:default}.plan-change-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.restore-purchases-section{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;margin-top:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.restore-purchases-hint{font-size:var(--text-sm);color:var(--text-secondary);margin:0;display:flex;align-items:center;gap:6px}.restore-purchases-link{background:transparent;border:none;color:var(--primary-color);font-size:var(--text-sm);font-weight:500;cursor:pointer;padding:4px 8px;border-radius:4px;display:flex;align-items:center;gap:6px;transition:all .2s ease}.restore-purchases-link:hover{background:var(--bg-hover);color:var(--primary-hover)}.restore-purchases-link:active{transform:scale(.98)}.restore-purchases-btn{display:inline-flex;align-items:center;gap:6px;padding:0;background:none;color:var(--text-secondary);border:none;font-size:var(--text-sm);font-weight:500;cursor:pointer;text-decoration:underline;transition:color .2s ease}.restore-purchases-btn:hover{color:var(--primary-color)}.restore-purchases-btn:active{opacity:.8}.manage-subscription-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.manage-subscription-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.manage-subscription-btn:active{transform:translateY(0)}.manage-subscription-btn.web_api{background:var(--danger-color)}.manage-subscription-btn.web_api:hover{background:#dc2626}@media (max-width: 768px){.section-header{flex-direction:column;gap:12px;text-align:center}.plan-change-grid{grid-template-columns:1fr}.subscription-actions{flex-direction:column;width:100%}.restore-purchases-btn,.manage-subscription-btn{width:100%;justify-content:center}}.payment-logos-section{padding-top:16px;padding-bottom:16px}.payment-logos-section .card-logos{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.payment-logos-section .card-logos a{display:inline-flex;align-items:center}.payment-logos-section .card-logos img{height:28px;width:auto;object-fit:contain}.checkout-step{max-width:480px;margin:0 auto}.checkout-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);text-align:center;margin-bottom:24px}.checkout-order-summary{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:20px}.order-item{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid var(--border-color);margin-bottom:16px}.order-item-details{display:flex;flex-direction:column;gap:4px}.order-item-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.order-item-period{font-size:var(--text-sm);color:var(--text-secondary)}.order-item-price{font-size:var(--text-base);font-weight:600;color:var(--text-primary);text-align:right}.order-total{display:flex;justify-content:space-between;align-items:center}.order-total-label{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.order-total-price{font-size:var(--text-xl);font-weight:700;color:var(--primary-color)}.checkout-terms{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px;margin-bottom:24px}.terms-checkbox-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer}.terms-checkbox{width:20px;height:20px;margin:2px 0 0;cursor:pointer;accent-color:var(--primary-color);flex-shrink:0}.terms-text{font-size:var(--text-sm);color:var(--text-primary);line-height:1.5}.terms-text a{color:var(--primary-color);text-decoration:underline;font-weight:500}.terms-text a:hover{color:var(--primary-hover)}.btn-pay{background:var(--primary-color);color:#fff;font-weight:600;transition:all .2s ease}.btn-pay:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-pay:disabled{background:var(--border-color);color:var(--text-muted);cursor:not-allowed;transform:none}@media (max-width: 768px){.checkout-step{max-width:100%}}.modal-content.plan-selection .modal-footer{justify-content:center}.checkout-stepper{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:24px;padding:0 20px}.checkout-stepper .step{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;background:var(--bg-secondary);border:2px solid var(--border-color);transition:all .2s ease}.checkout-stepper .step.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.checkout-stepper .step.completed{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.checkout-stepper .step-number{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:600;background:var(--bg-tertiary);color:var(--text-secondary)}.checkout-stepper .step.active .step-number{background:#fff3;color:#fff}.checkout-stepper .step.completed .step-number{background:var(--primary-color);color:#fff}.checkout-stepper .step-label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.checkout-stepper .step.active .step-label{color:#fff}.checkout-stepper .step.completed .step-label{color:var(--text-primary)}.checkout-stepper .step-connector{width:40px;height:2px;background:var(--border-color);margin:0 4px}.checkout-stepper .step-connector.completed{background:var(--primary-color)}@media (max-width: 480px){.checkout-stepper .step{padding:6px 12px}.checkout-stepper .step-label{display:none}.checkout-stepper .step-connector{width:24px}}.checkout-info-box{border-radius:12px;padding:16px 20px;margin-bottom:20px}.checkout-info-box.immediate{background:var(--bg-secondary);border:1px solid var(--border-color)}.checkout-info-box.scheduled{background:#f59e0b14;border:1px solid rgba(245,158,11,.25)}.info-box-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-weight:600;font-size:var(--text-base)}.checkout-info-box.immediate .info-box-header{color:var(--primary-color)}.checkout-info-box.scheduled .info-box-header{color:#b45309}[data-theme=dark] .checkout-info-box.immediate .info-box-header{color:var(--primary-color)}[data-theme=dark] .checkout-info-box.scheduled .info-box-header{color:#fbbf24}.info-box-content{display:flex;flex-direction:column;gap:10px}.info-box-main{font-size:var(--text-base);color:var(--text-primary);margin:0;font-weight:500}.info-box-detail{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.5}.info-box-badge{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-xs);font-weight:600;padding:6px 12px;border-radius:20px;width:fit-content}.checkout-info-box.scheduled .info-box-badge{background:#f59e0b26;color:#b45309}[data-theme=dark] .checkout-info-box.scheduled .info-box-badge{color:#fbbf24}.price-breakdown{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;margin-top:12px}.price-breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.price-breakdown-row:first-child{font-weight:600;font-size:var(--text-base);color:var(--text-primary);border-bottom:1px solid var(--border-color);padding-bottom:12px;margin-bottom:4px}.price-breakdown-row .price-amount{font-size:var(--text-lg);font-weight:700;color:var(--primary-color)}.price-breakdown-row.secondary{font-size:var(--text-sm);color:var(--text-secondary)}.payment-logos-section.checkout{padding:24px 0 0;border-top:1px solid var(--border-color);margin-top:8px}.payment-logos-label{display:flex;align-items:center;justify-content:center;gap:6px;font-size:var(--text-xs);font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.payment-logos-label svg{color:var(--primary-color)}.checkout-btn{min-width:200px;padding:14px 32px;font-size:var(--text-base)}@media (max-width: 768px){.checkout-btn{width:100%}}.cancellation-notice.pending{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:16px;width:100%}.cancellation-notice-content{display:flex;align-items:flex-start;gap:12px}.cancellation-notice-icon{margin-top:2px;flex-shrink:0}.cancellation-notice-icon.pending{color:#f59e0b}.cancellation-notice-body{flex:1}.cancellation-notice-title{margin:0 0 8px;font-weight:600;color:#f59e0b}.cancellation-notice-text{margin:0 0 12px;font-size:14px;line-height:1.5;color:var(--text-secondary)}.cancellation-notice-text strong{color:var(--text-primary)}.reactivate-btn{background:transparent;border:1px solid #f59e0b;color:#f59e0b;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.reactivate-btn:hover{background:#f59e0b1a}.settings-tabs{display:flex;gap:8px;border-bottom:1px solid var(--border-color);padding:0 24px;background:var(--bg-primary)}.settings-tab{padding:12px 20px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.settings-tab:hover{color:var(--text-primary)}.settings-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.settings-content{padding:0 4px;overflow:visible}.settings-section{margin-bottom:20px}.settings-section h4{font-size:16px;font-weight:600;color:var(--text-primary)}.settings-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.settings-info-group{background:var(--bg-secondary);border-radius:8px;padding:8px 16px;margin-bottom:24px}.settings-info-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color)}.settings-info-item:last-child{border-bottom:none}.settings-label{font-size:14px;color:var(--text-secondary)}.settings-value{font-size:14px;font-weight:500;color:var(--text-primary)}.settings-value.status-active{color:var(--success-color)}.settings-actions{display:flex;flex-direction:column;gap:16px}.settings-btn{padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-align:center;width:100%}.settings-btn:disabled{opacity:.5;cursor:not-allowed}.settings-btn-primary{background:var(--primary-color);color:#fff}.settings-btn-primary:hover:not(:disabled){background:var(--primary-hover)}.settings-btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.settings-btn-secondary:hover:not(:disabled){background:var(--bg-tertiary)}.settings-btn-danger{background:#dc3545;color:#fff;width:fit-content}.settings-btn-danger:hover:not(:disabled){background:#c82333}.settings-btn-sm{padding:8px 16px;font-size:13px}.settings-loading,.settings-empty{text-align:center;padding:32px;color:var(--text-secondary)}.sessions-list{display:flex;flex-direction:column;gap:12px}.session-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.session-icon{font-size:30px;flex-shrink:0}.session-info{flex:1;min-width:0}.session-device{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px;display:flex;align-items:center;gap:8px}.session-current-badge{display:inline-block;padding:2px 8px;background:var(--primary-color);color:#fff;font-size:11px;font-weight:600;border-radius:4px;text-transform:uppercase}.session-meta{font-size:12px;color:var(--text-secondary);display:flex;flex-direction:column;gap:2px}.session-revoke-btn{padding:8px 16px;background:transparent;border:1px solid var(--border-color);border-radius:6px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0}.session-revoke-btn:hover:not(:disabled){background:#dc3545;color:#fff;border-color:#dc3545}.session-revoke-btn:disabled{opacity:.5;cursor:not-allowed}.password-change-form{max-width:500px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--text-primary)}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary-color)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.password-requirements{padding:12px 16px;background:var(--bg-secondary);border-radius:8px;margin-bottom:20px;border:1px solid var(--border-color)}.password-requirements p{margin:0 0 8px;font-size:13px;font-weight:500;color:var(--text-primary)}.password-requirements ul{margin:0;padding-left:20px}.password-requirements li{font-size:13px;color:var(--text-secondary);margin:4px 0}@media (max-width: 768px){.settings-tabs{padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{padding:12px 16px;font-size:13px}.settings-section-header{flex-direction:row;align-items:center;gap:12px}.settings-section-header .settings-btn-sm{width:100%}.session-item{flex-wrap:wrap}.session-icon,.session-info{flex-shrink:0}.session-info{flex:1;min-width:200px}.session-revoke-btn{width:100%;flex-basis:100%}}.payment-methods-manager{padding:0}.payment-methods-header{margin-bottom:12px}.payment-methods-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.payment-methods-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px;color:var(--text-secondary)}.payment-methods-loading .loading-spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.payment-methods-error{display:flex;align-items:center;gap:8px;padding:12px 16px;margin-top:16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:14px}.payment-methods-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;color:var(--text-secondary);background:var(--bg-secondary);border-radius:12px}.payment-methods-empty svg{opacity:.4}.payment-methods-empty p{margin:0 0 16px;font-size:14px;color:var(--text-muted)}.payment-methods-list{display:flex;flex-direction:column;gap:12px}.payment-method-card{display:flex;align-items:flex-start;gap:16px;padding:16px;background:var(--bg-secondary);border-radius:12px;transition:all .2s ease}.payment-method-card.processing{opacity:.6;pointer-events:none}.payment-method-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--bg-primary);border-radius:10px;color:var(--text-secondary)}.payment-method-info{flex:1;min-width:0}.payment-method-brand{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.payment-method-number{font-size:14px;font-family:SF Mono,Monaco,Inconsolata,monospace;color:var(--text-secondary);letter-spacing:.5px}.payment-method-expiry{font-size:12px;color:var(--text-muted);margin-top:4px}.payment-method-actions{display:flex;gap:8px}.payment-method-actions button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.delete-method-btn{background:#ef44441a;color:#ef4444}.delete-method-btn:hover:not(:disabled){background:#ef444433}.payment-method-actions button:disabled{opacity:.5;cursor:not-allowed}.add-payment-method-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;color:var(--primary-color);background:transparent;border:1px dashed var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease}.add-payment-method-btn:hover{border-color:var(--primary-color);background:#064e3b0d}.add-payment-method-btn.secondary{margin-top:12px}.payment-methods-note{margin:12px 0 0;font-size:12px;color:var(--text-muted);text-align:center}.payment-methods-notice{margin:8px 0 16px;font-size:12px;color:var(--text-muted);font-style:italic}@media (prefers-color-scheme: dark){.payment-method-card{background:#ffffff08}.payment-method-icon{background:#ffffff0d}.payment-methods-empty{background:#ffffff08}}@media (max-width: 480px){.payment-method-card{flex-wrap:wrap;gap:12px}.payment-method-info{flex:1 1 calc(100% - 64px)}.payment-method-actions{width:100%;justify-content:flex-end}}.update-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.update-modal{background:var(--bg-primary);border-radius:12px;padding:24px;max-width:500px;width:90%;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.update-header{text-align:center;margin-bottom:20px}.update-header h2{margin:0 0 8px;color:var(--text-primary);font-size:var(--text-2xl)}.update-version{color:var(--text-muted);font-size:var(--text-sm);margin:0}.update-notes{background:var(--bg-secondary);border-radius:8px;padding:16px;margin-bottom:20px}.update-notes h3{margin:0 0 8px;color:var(--text-primary);font-size:var(--text-base)}.update-notes p{margin:0;color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed);white-space:pre-wrap}.update-error{background:#dc26261a;border:1px solid var(--danger-color);border-radius:8px;padding:12px;margin-bottom:20px}.update-error p{margin:0;color:var(--danger-color);font-size:var(--text-sm)}.update-downloading{text-align:center;padding:20px 0}.update-downloading p{margin:0 0 12px;color:var(--text-secondary);font-size:var(--text-sm)}.progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--primary-hover));border-radius:4px;transition:width .3s ease}.progress-text{font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.update-actions{display:flex;gap:12px;margin-top:20px}.update-button{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:var(--text-base);font-weight:500;cursor:pointer;transition:all .2s ease}.update-now{background:var(--primary-color);color:#fff}.update-now:hover{background:var(--primary-hover)}.update-now:active{transform:translateY(0)}.update-later{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.update-later:hover{background:var(--bg-secondary);border-color:var(--border-hover)}.update-later:active{background:var(--bg-tertiary);opacity:.8}
