.container{max-width:1200px;margin:0 auto;padding:1rem 1rem 3rem}.header{margin-bottom:2rem;padding:.5rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem}.header h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem;letter-spacing:-.02em}.header .subtitle{color:var(--muted);font-size:.8125rem}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:.625rem .875rem;font-size:.8125rem;font-weight:500;color:var(--muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0;-webkit-tap-highlight-color:transparent}.tab:active{transform:scale(.98)}.tab:hover{color:var(--foreground)}.tab.active{color:var(--foreground);border-bottom-color:var(--foreground)}.content{min-height:300px}.tab-content{display:none;animation:fadeIn .3s}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1.5rem}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;transition:all .2s}.stat-card:active{transform:scale(.98)}.stat-card:hover{border-color:var(--foreground)}.stat-card .label{font-size:.6875rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.stat-card .value{font-size:1.5rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.25rem}.stat-card .description{font-size:.75rem;color:var(--muted)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1.5rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.card-title{font-size:1rem;font-weight:600;letter-spacing:-.01em}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -1rem;padding:0 1rem}table{width:100%;border-collapse:collapse;font-size:.8125rem;min-width:600px}table th{text-align:left;font-weight:500;color:var(--muted);padding:.625rem .5rem;border-bottom:1px solid var(--border);font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}table td{padding:.875rem .5rem;border-bottom:1px solid var(--border);vertical-align:middle}table tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:500;letter-spacing:.01em;white-space:nowrap}.badge.admin{background:var(--foreground);color:var(--card)}.badge.user{background:var(--secondary);color:var(--muted)}.badge.pending{background:#fef3c7;color:#92400e}.badge.approved{background:#d1fae5;color:#065f46}.badge.declined{background:#fee2e2;color:#991b1b}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .875rem;font-size:.8125rem;font-weight:500;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s;background:var(--card);color:var(--foreground);text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn:active{transform:scale(.97)}.btn:hover{background:var(--secondary)}.btn-primary{background:var(--foreground);color:var(--card);border-color:var(--foreground)}.btn-primary:hover{opacity:.9}.btn-sm{padding:.375rem .625rem;font-size:.75rem}.btn-group{display:flex;gap:.5rem;flex-wrap:wrap}.input{width:100%;padding:.625rem .75rem;font-size:.875rem;border:1px solid var(--border);border-radius:6px;background:var(--card);transition:all .2s}.input:focus{outline:none;border-color:var(--foreground)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--foreground)}.form-group textarea{resize:vertical;min-height:100px;font-family:inherit}.form-group small{display:block;margin-top:.25rem;color:var(--muted);font-size:.75rem}.search-box{margin-bottom:1rem}.filters{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.pagination{display:flex;gap:.5rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}.pagination button{min-width:2rem;height:2rem;padding:0 .5rem;font-size:.875rem;border:1px solid var(--border);background:var(--card);border-radius:4px;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.pagination button:active{transform:scale(.95)}.pagination button:hover:not(.active){background:var(--secondary)}.pagination button.active{background:var(--foreground);color:var(--card);border-color:var(--foreground)}.loading{text-align:center;padding:2rem;color:var(--muted);font-size:.875rem}.skeleton{background:linear-gradient(90deg,var(--secondary) 0%,var(--border) 50%,var(--secondary) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:4px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty{text-align:center;padding:2rem;color:var(--muted)}.error{background:#fee2e2;color:#991b1b;padding:.875rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem;border:1px solid #fecaca}.error-retry{margin-top:.5rem}.success{background:#d1fae5;color:#065f46;padding:.875rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem;border:1px solid #a7f3d0}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:1000;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.modal.active{display:flex}.modal-content{background:var(--card);padding:1.5rem;border-radius:var(--radius);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;border:1px solid var(--border)}.modal-header{margin-bottom:1.5rem}.modal-header h2{font-size:1.125rem;font-weight:600;letter-spacing:-.01em}.modal-footer{margin-top:1.5rem;display:flex;gap:.75rem;justify-content:flex-end;flex-wrap:wrap}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--border);border-top-color:var(--foreground);border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 640px){.container{padding:.75rem}.header{margin-bottom:1.5rem}.header h1{font-size:1.25rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.stat-card{padding:.875rem}.stat-card .value{font-size:1.25rem}.card{padding:.875rem}.card-header{flex-direction:column;align-items:flex-start}.card-title{font-size:.9375rem}table{font-size:.75rem}table th,table td{padding:.625rem .375rem}.btn-group{width:100%}.btn-group .btn{flex:1}.modal-content{padding:1.25rem}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:420px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:32px}.logo{font-size:48px;margin-bottom:12px;animation:bounce 1s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1{color:#667eea;font-size:28px;font-weight:700;margin-bottom:8px}.subtitle{color:#718096;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.error-message{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:8px;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-icon{font-size:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#2d3748;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .2s;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.btn-login{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.spinner{border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;width:16px;height:16px;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{margin-top:24px;text-align:center}.hint{background:#edf2f7;padding:12px;border-radius:8px;font-size:13px;color:#4a5568;margin-bottom:16px}.hint code{background:#cbd5e0;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:12px;color:#2d3748}.copyright{color:#a0aec0;font-size:12px}@media (max-width: 480px){.login-container{padding:30px 24px}.login-header h1{font-size:24px}.logo{font-size:40px}}.user-container{min-height:100vh;max-height:100vh;display:flex;flex-direction:column;overflow:hidden}.user-header{background:var(--bg);padding:16px 0;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.user-header-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center}.user-logo{font-size:16px;font-weight:600;color:var(--text);letter-spacing:-.3px}.user-balance-container{display:flex;align-items:center;gap:8px}.user-balance{font-size:13px;color:var(--text-secondary);padding:8px 14px;background:var(--bg-secondary);border-radius:8px;font-weight:500;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all .2s;border:1px solid var(--border)}.user-balance:hover{background:var(--bg);border-color:var(--border-dark)}.user-main{flex:1;overflow-y:auto;background:var(--bg-secondary)}.user-main-content{max-width:1200px;margin:0 auto;padding:24px}.user-welcome{text-align:center;padding:32px 0;margin-bottom:24px}.user-welcome-title{font-size:28px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}.user-welcome-subtitle{color:var(--text-secondary);font-size:15px}.user-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:32px}.user-feature-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:24px;cursor:pointer;transition:all .2s}.user-feature-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.user-feature-icon{font-size:32px;margin-bottom:16px;display:block}.user-feature-title{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--text)}.user-feature-description{font-size:14px;color:var(--text-light);line-height:1.5}.user-history{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:24px}.user-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.user-history-title{font-size:18px;font-weight:600}.user-history-item{padding:16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;transition:background .2s}.user-history-item:hover{background:var(--bg-secondary)}.user-history-item:last-child{border-bottom:none}.user-history-item-info{flex:1}.user-history-item-title{font-weight:500;margin-bottom:4px}.user-history-item-meta{font-size:13px;color:var(--text-light)}.user-history-item-date{font-size:13px;color:var(--text-light);text-align:right}.user-empty{text-align:center;padding:48px 24px;color:var(--text-light)}@media (max-width: 768px){.user-main-content{padding:16px}.user-welcome{padding:24px 0}.user-welcome-title{font-size:24px}.user-features-grid{grid-template-columns:1fr;gap:12px}.user-feature-card{padding:20px}.user-history{padding:16px}}:root{--primary: #0070f3;--success: #10b981;--danger: #ef4444;--text: #000000;--text-secondary: #525252;--text-light: #737373;--bg: #ffffff;--bg-secondary: #fafafa;--border: #e5e5e5;--border-dark: #d4d4d4}html{height:100%;overflow:hidden}body{overflow:hidden;height:100%;position:fixed;width:100%;-webkit-overflow-scrolling:touch;touch-action:pan-y}.webapp-container{height:100vh;display:flex;flex-direction:column;overflow:hidden;position:relative}.webapp-header{background:var(--bg);padding:16px 0;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.webapp-header-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center}.webapp-logo{font-size:16px;font-weight:600;color:var(--text);letter-spacing:-.3px}.webapp-balance{font-size:14px;color:var(--text-light);padding:6px 12px;background:var(--bg-secondary);border-radius:6px;cursor:pointer;transition:all .2s}.webapp-balance:hover{background:var(--border)}.webapp-balance-amount{color:var(--text);font-weight:600;margin-left:4px}.webapp-tab-nav{background:var(--bg);border-bottom:1px solid var(--border);display:flex;justify-content:flex-start;position:sticky;top:61px;z-index:99;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.webapp-tab-nav::-webkit-scrollbar{display:none}.webapp-tab-button{flex:0 0 auto;min-width:fit-content;padding:14px 20px;border:none;background:transparent;color:var(--text-light);font-size:14px;font-weight:600;cursor:pointer;position:relative;transition:color .2s;font-family:inherit;white-space:nowrap}.webapp-tab-button.active{color:var(--text)}.webapp-tab-button:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--text);transform:scaleX(0);transition:transform .2s}.webapp-tab-button.active:after{transform:scaleX(1)}.webapp-content{flex:1;overflow-y:auto;overflow-x:hidden;height:100%;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.webapp-main{max-width:1200px;width:100%;margin:0 auto;padding:32px 24px 80px}.webapp-section-header{margin-bottom:24px}.webapp-section-title{font-size:22px;font-weight:600;margin-bottom:6px;color:var(--text);letter-spacing:-.4px}.webapp-section-subtitle{font-size:14px;color:var(--text-light);line-height:1.5}.webapp-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:20px;cursor:pointer;transition:all .2s}.webapp-card:hover{border-color:var(--border-dark);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.webapp-card.disabled{opacity:.6;cursor:not-allowed}.webapp-card-header{display:flex;align-items:center;gap:16px;margin-bottom:12px}.webapp-card-icon{font-size:40px;line-height:1}.webapp-card-title{font-size:18px;font-weight:600;color:var(--text);letter-spacing:-.3px}.webapp-card-description{font-size:14px;color:var(--text-light);line-height:1.5}.webapp-card-meta{display:flex;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.webapp-form-label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text)}.webapp-form-input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit;background:var(--bg);color:var(--text);transition:border-color .2s}.webapp-form-input:focus{outline:none;border-color:var(--primary)}.webapp-form-input.error{border-color:var(--danger)}.webapp-form-textarea{min-height:100px;resize:vertical}.webapp-form-select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit;background:var(--bg);color:var(--text);cursor:pointer}.webapp-form-error{color:var(--danger);font-size:13px;margin-top:6px;display:none}.webapp-form-error.show{display:block}.webapp-form-hint{font-size:13px;color:var(--text-light);margin-top:6px}.webapp-btn{width:100%;padding:14px 20px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.webapp-btn-primary{background:var(--primary);color:#fff}.webapp-btn-primary:hover{background:#0051cc}.webapp-btn-primary:disabled{background:var(--border);color:var(--text-light);cursor:not-allowed}.webapp-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-bottom:24px}.webapp-template-item{border:2px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s}.webapp-template-item:hover{border-color:var(--primary);transform:translateY(-2px)}.webapp-template-item.selected{border-color:var(--primary);box-shadow:0 0 0 3px #0070f31a}.webapp-template-image{width:100%;height:120px;object-fit:cover;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700}.webapp-template-name{padding:12px;font-size:13px;font-weight:600;text-align:center;color:var(--text)}.webapp-history-list{margin-top:24px}.webapp-history-item{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;transition:all .2s}.webapp-history-item:hover{border-color:var(--border-dark);transform:translate(4px)}.webapp-history-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}.webapp-history-meta{font-size:13px;color:var(--text-light)}.webapp-profile-header{text-align:center;padding:32px 0;border-bottom:1px solid var(--border);margin-bottom:24px}.webapp-profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin:0 auto 16px}.webapp-profile-name{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}.webapp-profile-username{font-size:14px;color:var(--text-light)}.webapp-profile-balance{font-size:18px;font-weight:700;color:var(--primary);margin-top:12px}.webapp-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.webapp-stat-item{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}.webapp-stat-value{font-size:24px;font-weight:700;color:var(--text);margin-bottom:4px}.webapp-stat-label{font-size:13px;color:var(--text-light)}.webapp-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100px);background:var(--text);color:#fff;padding:14px 20px;border-radius:12px;font-size:14px;font-weight:500;z-index:10000;max-width:calc(100% - 48px);transition:transform .3s;box-shadow:0 8px 24px #0000004d}.webapp-toast.show{transform:translate(-50%) translateY(0)}.webapp-toast.error{background:var(--danger)}.webapp-toast.success{background:var(--success)}.webapp-loading{display:flex;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-light)}.webapp-spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite}.webapp-empty{text-align:center;padding:48px 24px;color:var(--text-light)}.webapp-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto;-webkit-overflow-scrolling:touch}.webapp-modal-content{background:var(--bg);border-radius:16px;padding:28px;max-width:600px;width:100%;max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;position:relative;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}.webapp-modal-content::-webkit-scrollbar{width:8px}.webapp-modal-content::-webkit-scrollbar-track{background:transparent}.webapp-modal-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.webapp-modal-content::-webkit-scrollbar-thumb:hover{background:var(--border-dark)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.webapp-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:var(--bg-secondary);border:none;border-radius:50%;color:var(--text);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.webapp-modal-close:hover{background:var(--border);transform:scale(1.1)}.webapp-modal-title{font-size:24px;font-weight:700;margin-bottom:20px;color:var(--text)}.webapp-range-container{margin:16px 0}.webapp-range-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.webapp-range-value{font-weight:700;color:var(--primary)}.webapp-range-input{width:100%;height:6px;border-radius:3px;background:var(--border);outline:none;-webkit-appearance:none}.webapp-range-input::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer}.webapp-range-input::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer;border:none}@media (max-width: 768px){.webapp-main{padding:24px 16px 80px}.webapp-template-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.webapp-stats-grid{grid-template-columns:1fr}}.webapp-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);animation:fadeIn .15s cubic-bezier(.16,1,.3,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.webapp-modal-content{background:#fffffffa;border-radius:12px;width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 0 0 1px #00000008,0 1px 3px #0000000d,0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid rgba(0,0,0,.08);animation:slideUp .2s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.webapp-modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,#667eea4d,#764ba24d,#667eea4d)}@keyframes slideUp{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.webapp-modal-header{padding:20px 24px;background:linear-gradient(180deg,#fafafacc,#fff6);border-bottom:1px solid rgba(0,0,0,.06);display:flex;justify-content:space-between;align-items:center;position:relative}.webapp-modal-title{font-size:17px;font-weight:600;color:#000;margin:0;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.webapp-modal-close{background:transparent;border:1px solid rgba(0,0,0,.06);font-size:20px;color:#00000080;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s cubic-bezier(.16,1,.3,1);line-height:1}.webapp-modal-close:hover{background:#0000000a;border-color:#0000001a;color:#000c}.webapp-modal-close:active{transform:scale(.96)}.webapp-modal-body{padding:24px;overflow-y:auto;flex:1;background:#fff}.webapp-modal-footer{padding:16px 24px;background:linear-gradient(180deg,#fff6,#fafafacc);border-top:1px solid rgba(0,0,0,.06);display:flex;gap:8px;justify-content:flex-end}.webapp-form-textarea{width:100%;padding:12px;border:1px solid rgba(0,0,0,.1);border-radius:6px;font-size:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;resize:vertical;transition:all .15s cubic-bezier(.16,1,.3,1);background:#fff;color:#000;min-height:180px}.webapp-form-textarea:hover{border-color:#00000026}.webapp-form-textarea:focus{outline:none;border-color:#0000004d;box-shadow:0 0 0 3px #00000005}.webapp-improvement-section{display:flex;gap:8px;align-items:flex-start}.webapp-improvement-section .webapp-form-input{flex:1;padding:10px 12px;border:1px solid rgba(0,0,0,.1);border-radius:6px;font-size:14px;transition:all .15s cubic-bezier(.16,1,.3,1)}.webapp-improvement-section .webapp-form-input:hover{border-color:#00000026}.webapp-improvement-section .webapp-form-input:focus{outline:none;border-color:#0000004d;box-shadow:0 0 0 3px #00000005}.webapp-improvement-section .webapp-btn{white-space:nowrap;min-height:38px;padding:0 16px;font-size:14px;font-weight:500;background:#000;color:#fff;border:1px solid #000;border-radius:6px;cursor:pointer;transition:all .15s cubic-bezier(.16,1,.3,1)}.webapp-improvement-section .webapp-btn:hover{background:#000000d9}.webapp-improvement-section .webapp-btn:active{transform:scale(.98)}.webapp-improvement-section .webapp-btn:disabled{opacity:.5;cursor:not-allowed}.webapp-alert{padding:12px 14px;border-radius:6px;font-size:13px;margin-top:14px;animation:fadeIn .15s cubic-bezier(.16,1,.3,1);line-height:1.5}.webapp-alert-error{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.webapp-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:50px 20px;gap:16px}.webapp-loading p{color:#00000080;font-size:14px;margin:0;font-weight:400}.webapp-spinner{width:40px;height:40px;border:2px solid rgba(0,0,0,.1);border-top-color:#000;border-radius:50%;animation:spin .7s linear infinite}.webapp-form-label{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:14px;font-weight:500;color:#000;margin-bottom:8px}.webapp-improvement-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#0000000f;color:#0009;font-size:11px;font-weight:500;border-radius:4px;margin-left:auto;border:1px solid rgba(0,0,0,.08)}.webapp-modal-footer .webapp-btn-secondary{background:transparent;color:#000000b3;border:1px solid rgba(0,0,0,.1);padding:0 16px;height:38px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .15s cubic-bezier(.16,1,.3,1)}.webapp-modal-footer .webapp-btn-secondary:hover{background:#0000000a;border-color:#00000026}.webapp-modal-footer .webapp-btn-secondary:active{transform:scale(.98)}.webapp-modal-footer .webapp-btn-primary{background:#000;color:#fff;border:1px solid #000;padding:0 16px;height:38px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .15s cubic-bezier(.16,1,.3,1)}.webapp-modal-footer .webapp-btn-primary:hover{background:#000000d9}.webapp-modal-footer .webapp-btn-primary:active{transform:scale(.98)}.webapp-modal-footer .webapp-btn-primary:disabled,.webapp-modal-footer .webapp-btn-secondary:disabled{opacity:.5;cursor:not-allowed;transform:none}.webapp-form-hint{font-size:13px;color:#00000080;margin-top:6px;line-height:1.5}.webapp-ai-context-button{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#000;color:#fff;border:1px solid #000;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s cubic-bezier(.16,1,.3,1);margin-top:8px}.webapp-ai-context-button:hover{background:#000000d9;transform:translateY(-1px);box-shadow:0 4px 8px #0000001f}.webapp-ai-context-button:active{transform:translateY(0) scale(.98)}.webapp-ai-context-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.webapp-alert-success{background:#22c55e1a;color:#16a34a;border:1px solid rgba(34,197,94,.2)}.webapp-form-group{margin-bottom:20px}.webapp-form-group:last-child{margin-bottom:0}.webapp-fallback{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;position:relative;overflow:hidden}.webapp-fallback-gradient{background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:200% 200%;animation:gradientShift 8s ease infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.webapp-fallback-content{text-align:center;max-width:420px;position:relative;z-index:1;background:#fffffffa;padding:48px 32px;border-radius:24px;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff1a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.webapp-fallback-illustration{position:relative;width:120px;height:120px;margin:0 auto 32px;display:flex;align-items:center;justify-content:center}.webapp-fallback-circle{position:absolute;width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);opacity:.15;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.15}50%{transform:scale(1.1);opacity:.25}}.webapp-fallback-emoji{font-size:56px;position:relative;z-index:1;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.webapp-fallback h2{font-size:28px;font-weight:700;color:var(--text);margin-bottom:12px;letter-spacing:-.03em;line-height:1.2}.webapp-fallback p{font-size:16px;color:var(--text-secondary);margin-bottom:32px;line-height:1.6;font-weight:400}.webapp-fallback-button{width:100%;padding:14px 28px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);font-family:inherit;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-bottom:12px;box-shadow:0 4px 12px #667eea4d}.webapp-fallback-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.webapp-fallback-button:active{transform:translateY(0) scale(.98)}.webapp-fallback-button.secondary{background:transparent;color:var(--text-secondary);border:2px solid var(--border);box-shadow:none}.webapp-fallback-button.secondary:hover{background:var(--bg-secondary);border-color:var(--border-dark);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.webapp-loader{width:48px;height:48px;border:4px solid rgba(102,126,234,.2);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}.webapp-fallback-gradient .webapp-loader{border:4px solid rgba(255,255,255,.3);border-top-color:#fff}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.webapp-tab-nav{padding:0 16px}.webapp-tab-button{padding:14px 16px;font-size:13px}.webapp-main{padding:24px 16px 60px}.webapp-modal-overlay{padding:0}.webapp-modal-content{max-width:100%;max-height:100vh;height:auto;border-radius:0;border:none;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.webapp-modal-content:before{display:none}.webapp-modal-header,.webapp-modal-body,.webapp-modal-footer{padding:16px}.webapp-modal-title{font-size:16px}.webapp-improvement-section{flex-direction:column}.webapp-improvement-section .webapp-btn{width:100%;justify-content:center}.webapp-form-textarea{min-height:140px;font-size:16px}.webapp-improvement-section .webapp-form-input{font-size:16px}.webapp-improvement-badge{margin-left:0;font-size:10px}.webapp-modal-footer{flex-direction:column-reverse}.webapp-modal-footer .webapp-btn-secondary,.webapp-modal-footer .webapp-btn-primary{width:100%;justify-content:center}.webapp-fallback{padding:16px}.webapp-fallback-content{padding:40px 24px;border-radius:20px}.webapp-fallback-illustration{width:100px;height:100px;margin-bottom:24px}.webapp-fallback-emoji{font-size:48px}.webapp-fallback h2{font-size:24px}.webapp-fallback p{font-size:15px;margin-bottom:24px}.webapp-fallback-button{padding:12px 24px;font-size:15px}}*{margin:0;padding:0;box-sizing:border-box}:root{--background: #fafafa;--foreground: #000;--card: #fff;--card-foreground: #000;--border: #e5e5e5;--primary: #000;--primary-foreground: #fff;--secondary: #f5f5f5;--muted: #737373;--accent: #0070f3;--success: #0070f3;--danger: #e00;--warning: #f5a623;--radius: 8px}html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:var(--background);color:var(--foreground);line-height:1.6;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;min-height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}#root{min-height:100vh}
