.toast-container{position:fixed;top:var(--spacing-xl);right:var(--spacing-xl);z-index:var(--z-notification);display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:320px;max-width:400px;pointer-events:auto;position:relative;overflow:hidden}.toast:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:currentColor}.toast__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:#ffffff1a}.toast__message{flex:1;margin:0;font-size:var(--font-size-sm);line-height:1.4;color:var(--color-text-primary)}.toast__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-base)}.toast__close:hover{background:#ffffff1a;color:var(--color-text-primary)}.toast--success{color:var(--color-success)}.toast--error{color:var(--color-error)}.toast--warning{color:var(--color-warning)}.toast--info{color:var(--color-info)}@media(max-width:768px){.toast-container{top:var(--spacing-md);right:var(--spacing-md);left:var(--spacing-md)}.toast{min-width:unset;max-width:unset}}.otp-input-container{display:flex;gap:var(--spacing-md);justify-content:center;margin:var(--spacing-xl) 0}.otp-input{width:56px;height:auto;padding:14px 0;line-height:1;font-size:24px;font-weight:600;font-family:-apple-system,SF Pro Display,Helvetica Neue,Arial,sans-serif;text-align:center;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);outline:none;transition:all var(--transition-base);caret-color:var(--color-accent-primary);touch-action:manipulation;direction:ltr;unicode-bidi:bidi-override;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-sizing:border-box}.otp-input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 4px #d4af3726;transform:scale(1.05)}.otp-input:not(:placeholder-shown){border-color:var(--color-accent-primary);background:#d4af370d}.otp-input:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.otp-input-container{gap:var(--spacing-sm)}.otp-input{width:48px;font-size:20px;padding:12px 0}}@media(max-width:480px){.otp-input-container{gap:8px;margin:var(--spacing-lg) 0}.otp-input{width:42px;font-size:18px;padding:10px 0;border-radius:var(--radius-md)}}@media(max-width:375px){.otp-input-container{gap:5px}.otp-input{width:36px;font-size:16px;padding:9px 0}}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-family:var(--font-body);font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);outline:none;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn--sm{padding:.5rem 1rem;font-size:var(--font-size-sm)}.btn--md{padding:.75rem 1.5rem;font-size:var(--font-size-base)}.btn--lg{padding:1rem 2rem;font-size:var(--font-size-lg)}.btn--primary{background:var(--color-accent-gradient);color:var(--color-bg-primary);box-shadow:0 4px 12px #d4af374d}.btn--primary:hover{box-shadow:0 6px 20px #d4af3766}.btn--secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn--secondary:hover{border-color:var(--color-accent-primary);background:var(--color-surface-hover)}.btn--success{background:var(--color-success);color:#fff;box-shadow:0 4px 12px #10b9814d}.btn--success:hover{box-shadow:0 6px 20px #10b98166}.btn--error{background:var(--color-error);color:#fff;box-shadow:0 4px 12px #ef44444d}.btn--error:hover{box-shadow:0 6px 20px #ef444466}.btn--ghost{background:transparent;color:var(--color-text-primary)}.btn--ghost:hover{background:var(--color-surface-hover)}.btn--outline{background:transparent;color:var(--color-accent-primary);border:2px solid var(--color-accent-primary)}.btn--outline:hover{background:#d4af371a}.btn--full{width:100%}.btn--loading{position:relative;color:transparent;pointer-events:none}.btn__spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.btn__icon{flex-shrink:0}.btn__icon--left{margin-right:calc(var(--spacing-xs) * -1)}.btn__icon--right{margin-left:calc(var(--spacing-xs) * -1)}.btn__text{display:flex;align-items:center}.otp-login{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);overflow:hidden}.otp-login__background{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.otp-login__gradient{position:absolute;border-radius:50%;filter:blur(100px);opacity:.3;animation:float 20s infinite ease-in-out}.otp-login__gradient--1{width:500px;height:500px;background:radial-gradient(circle,var(--color-accent-primary),transparent);top:-250px;left:-250px;animation-delay:0s}.otp-login__gradient--2{width:400px;height:400px;background:radial-gradient(circle,var(--color-info),transparent);bottom:-200px;right:-200px;animation-delay:7s}.otp-login__gradient--3{width:300px;height:300px;background:radial-gradient(circle,var(--color-accent-secondary),transparent);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:3.5s}@keyframes float{0%,to{transform:translate(0)}33%{transform:translate(30px,-30px)}66%{transform:translate(-20px,20px)}}.otp-login__container{position:relative;display:grid;grid-template-columns:1fr 1fr;max-width:1200px;width:100%;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-2xl);overflow:hidden;box-shadow:0 25px 50px -12px #00000080}.otp-login__left{padding:var(--spacing-3xl);background:linear-gradient(135deg,var(--color-bg-tertiary),var(--color-bg-secondary));display:flex;flex-direction:column;justify-content:space-between}.otp-login__brand{margin-bottom:var(--spacing-3xl)}.otp-login__logo{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--color-accent-gradient);border-radius:var(--radius-xl);color:var(--color-bg-primary);margin-bottom:var(--spacing-lg)}.otp-login__brand-title{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-sm);background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.otp-login__brand-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin:0}.otp-login__features{display:flex;flex-direction:column;gap:var(--spacing-xl)}.otp-login__feature{display:flex;gap:var(--spacing-lg);align-items:flex-start}.otp-login__feature-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-accent-primary);flex-shrink:0}.otp-login__feature h3{font-size:var(--font-size-lg);margin:0 0 var(--spacing-xs);color:var(--color-text-primary)}.otp-login__feature p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:1.5}.otp-login__right{padding:var(--spacing-3xl);display:flex;flex-direction:column;justify-content:center}.otp-login__card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl)}.otp-login__card-header{text-align:center;margin-bottom:var(--spacing-2xl)}.otp-login__card-header h2{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm)}.otp-login__card-header p{color:var(--color-text-secondary);margin:0}.otp-login__quote-id{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.otp-login__quote-id span{font-family:var(--font-display);font-weight:600;color:var(--color-accent-primary);margin-left:var(--spacing-xs)}.otp-login__card-body{margin-bottom:var(--spacing-xl)}.otp-login__help{text-align:center;margin-top:var(--spacing-xl)}.otp-login__help p{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0 0 var(--spacing-sm)}.otp-login__help-link{background:none;border:none;color:var(--color-accent-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;text-decoration:underline;transition:color var(--transition-base)}.otp-login__help-link:hover{color:var(--color-accent-secondary)}.otp-login__loading{text-align:center;padding:var(--spacing-lg);background:var(--color-surface);border-radius:var(--radius-md);margin-top:var(--spacing-lg)}.otp-login__loading-spinner{width:40px;height:40px;margin:0 auto var(--spacing-md);border:3px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin .8s linear infinite}.otp-login__loading p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.otp-login__footer{text-align:center;margin-top:var(--spacing-xl)}.otp-login__footer p{display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0}.otp-login__error{color:#ef4444;font-size:var(--font-size-sm);margin-top:var(--spacing-sm);text-align:center;padding:var(--spacing-sm) var(--spacing-md);background:#ef444414;border-radius:var(--radius-md)}.otp-login__email-field{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-base)}.otp-login__email-field:focus-within{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #d4af3726}.otp-login__email-field svg{color:var(--color-text-tertiary);flex-shrink:0}.otp-login__email-field input{flex:1;background:transparent;border:none;outline:none;color:var(--color-text-primary);font-size:var(--font-size-base);min-width:0}.otp-login__email-field input::placeholder{color:var(--color-text-tertiary)}.otp-login__blocked{text-align:center;padding:var(--spacing-lg) 0}.otp-login__blocked-icon{margin-bottom:var(--spacing-md);display:flex;justify-content:center}.otp-login__blocked-title{font-size:var(--font-size-xl);font-weight:700;color:#e53e3e;margin:0 0 var(--spacing-sm)}.otp-login__blocked-message{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0 0 var(--spacing-lg);line-height:1.6}.otp-login__blocked-hint{margin-top:var(--spacing-md);font-size:12px;color:var(--color-text-tertiary)}.otp-login__bypass{margin-top:var(--spacing-lg);padding:var(--spacing-lg);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);text-align:left}.otp-login__bypass-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--spacing-sm);display:block}.otp-login__bypass-input{width:100%;padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:16px;outline:none;box-sizing:border-box;margin-top:var(--spacing-xs);transition:border-color var(--transition-base)}.otp-login__bypass-input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #d4af3726}@media(max-width:1024px){.otp-login__container{grid-template-columns:1fr}.otp-login__left,.otp-login__right{padding:var(--spacing-2xl)}.otp-login__features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.otp-login__feature{flex-direction:column;text-align:center}}@media(max-width:768px){.otp-login{padding:var(--spacing-md)}.otp-login__left,.otp-login__right{padding:var(--spacing-xl)}.otp-login__brand-title{font-size:var(--font-size-3xl)}.otp-login__card{padding:var(--spacing-xl)}.otp-login__features{grid-template-columns:1fr}}@media(max-width:480px){.otp-login{padding:var(--spacing-sm);align-items:flex-start;padding-top:env(safe-area-inset-top,20px);padding-top:calc(20px + env(safe-area-inset-top,0px))}.otp-login__left{display:none}.otp-login__container{border-radius:var(--radius-xl);box-shadow:0 8px 32px #0000004d;margin-top:20px}.otp-login__right{padding:var(--spacing-lg)}.otp-login__card{padding:var(--spacing-md);border-radius:var(--radius-lg)}.otp-login__card-header{margin-bottom:var(--spacing-lg)}.otp-login__card-header h2{font-size:var(--font-size-2xl)}.otp-login__quote-id{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:12px}.otp-login__bypass{padding:var(--spacing-md)}.otp-login__footer{margin-top:var(--spacing-md)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--spacing-xl)}.modal{position:relative;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #00000080;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;z-index:var(--z-modal)}.modal--fullscreen{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;padding:0;display:flex;flex-direction:column}.modal__body{flex:1;overflow:hidden}.modal--sm{width:100%;max-width:450px;min-width:200px}.modal--md{width:100%;max-width:600px}.modal--lg{width:100%;max-width:900px}.modal--xl{width:100%;max-width:1200px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xl);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal__title{font-size:var(--font-size-2xl);font-weight:600;margin:0;color:var(--color-text-primary)}.modal__close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-base)}.modal__close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.modal__body{padding:var(--spacing-xl);overflow-y:auto;flex:1}.modal__body::-webkit-scrollbar{width:8px}.modal__body::-webkit-scrollbar-track{background:transparent}.modal__body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.modal__body::-webkit-scrollbar-thumb:hover{background:var(--color-accent-primary)}@media(max-width:768px){.modal-backdrop{padding:0;align-items:flex-end}.modal{width:100%;max-width:100%;max-height:92vh;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;border-bottom:none;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal__header{padding:var(--spacing-lg);padding-top:20px;position:relative}.modal__header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#d0d0d0;border-radius:2px}.modal__title{font-size:var(--font-size-xl)}.modal__body{padding:var(--spacing-lg);padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px))}.modal--fullscreen{border-radius:0!important;max-height:100vh!important;animation:none}}@media(max-width:480px){.modal__header{padding:var(--spacing-md);padding-top:20px}.modal__body{padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px))}}.quote-header{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 15px #0000001a;animation:fadeIn .5s ease;overflow:hidden;min-width:0}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.header-left{display:flex;align-items:center;gap:15px;flex-wrap:wrap;min-width:0;flex:1}.header-left h1{font-size:28px;color:#333;margin:0;min-width:0;word-break:break-word}.status-badge{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;text-transform:uppercase;white-space:nowrap}.status-badge.draft{background:#f0f0f0;color:#666}.status-badge.active{background:#e3f2fd;color:#1976d2}.status-badge.won{background:#e8f5e9;color:#2e7d32}.status-badge.lost{background:#ffebee;color:#c62828}.status-badge.closed{background:#f5f5f5;color:#616161}.header-right{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}.btn-chat-custom{padding:12px 24px!important;border-radius:8px!important;border:none;cursor:pointer;display:inline-flex!important;align-items:center!important;justify-content:center!important;background:#3f7af8;color:#fff;font-size:18px!important;line-height:0!important;transition:all .3s ease;white-space:nowrap}.btn-chat-custom:hover{transform:translateY(-2px);background:#1d4ed8;box-shadow:0 4px 12px #3f7af84d}.btn-chat-custom:active{transform:scale(.95)}.comments-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:999;animation:fadeIn .3s ease forwards}.comments-sidebar{position:fixed;top:0;right:0;width:450px;height:100dvh;background:#fff;z-index:1000;box-shadow:-5px 0 15px #0000001a;display:flex;flex-direction:column;animation:slideIn .3s ease-out forwards}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOut{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.comments-sidebar.closing{animation:slideOut .3s ease-in forwards}.comments-overlay.closing{animation:fadeOut .3s ease-in forwards}.comments-sidebar .comments-card{height:100%;margin:0;border-radius:0}.btn-outline{background:#fff;color:#667eea;border:2px solid #667eea;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-align:left;display:flex;align-items:center;gap:8px;white-space:nowrap}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.btn-success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-success:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.btn-danger{background:linear-gradient(135deg,#f44336,#e53935);color:#fff}.btn-wait{background:linear-gradient(135deg,#f44336,#e53935);color:#fff}.btn-wait:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.btn-share{background:linear-gradient(135deg,#f44336,#e53935);color:#fff}.btn-share:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.btn-logout{background:linear-gradient(135deg,#757575,#616161);color:#fff}.btn-logout:hover{transform:translateY(-2px);box-shadow:0 4px 12px #7575754d}.header-info{border-top:2px solid #f0f0f0;padding-top:20px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.info-item{display:flex;flex-direction:column;gap:5px;min-width:0}.info-label{font-size:13px;color:#888;font-weight:500}.info-value{font-size:16px;color:#333;font-weight:600;word-break:break-word}.info-value.total{font-size:20px;color:#4caf50}@media(max-width:768px){.quote-header{padding:14px 12px;border-radius:10px}.comments-sidebar{width:100%}.header-top{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:14px}.header-left{width:100%;gap:8px}.header-left h1{font-size:17px;word-break:break-all}.header-right{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}.header-right .btn,.header-right .btn-outline,.header-right .btn-chat-custom{width:100%!important;justify-content:center!important;padding:10px 8px!important;font-size:12px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.info-grid{grid-template-columns:1fr 1fr;gap:10px}.info-label{font-size:12px}.info-value{font-size:13px}.info-value.total{font-size:15px}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}@media(max-width:480px){.quote-header{padding:10px}.header-left h1{font-size:15px}.header-right{grid-template-columns:1fr 1fr;gap:6px}.header-right .btn,.header-right .btn-outline,.header-right .btn-chat-custom{font-size:11px!important;padding:9px 6px!important}.info-grid{grid-template-columns:1fr 1fr;gap:8px}}.share-choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:4px}.share-choice-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 14px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;text-align:center;transition:border-color .2s,box-shadow .2s,transform .15s;font-family:inherit}.share-choice-card:hover{border-color:#3f7af8;box-shadow:0 4px 14px #3f7af826;transform:translateY(-2px)}.share-choice-card--delega:hover{border-color:#4caf50;box-shadow:0 4px 14px #4caf5026}.share-choice-icon{font-size:32px;line-height:1}.share-choice-label{font-weight:700;font-size:15px;color:#1a202c}.share-choice-desc{font-size:12px;color:#718096;line-height:1.5}.delega-info-box{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;font-size:13px;color:#166534;line-height:1.5}.delega-info-icon{font-size:16px;flex-shrink:0;margin-top:1px}.delega-info-box p{margin:0}@media(max-width:480px){.share-choice-grid{grid-template-columns:1fr}.share-choice-card{flex-direction:row;text-align:left;padding:14px;gap:12px}.share-choice-icon{font-size:24px;flex-shrink:0}}.header-readonly-badge{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:600;white-space:nowrap;border:1.5px solid transparent}.header-readonly-badge--signed,.header-readonly-badge--rejected{background:#f0fdf4;border-color:#86efac;color:#166534}.header-readonly-badge--onhold{background:#fffbeb;border-color:#fde68a;color:#92400e}.btn-resume{padding:12px 28px;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;box-shadow:0 2px 8px #f59e0b40}.btn-resume:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66}.btn-resume:disabled{opacity:.6;cursor:not-allowed;transform:none}.header-readonly-badge:not([class*=--]){background:#f0fdf4;border-color:#86efac;color:#166534}@media(max-width:768px){.header-readonly-badge{width:100%;justify-content:center;grid-column:1 / -1}.btn-resume{width:100%;justify-content:center}}.sign-modal{padding:8px 0}.sign-modal__status{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 0;color:var(--color-text-secondary)}.sign-modal__channel-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.sign-modal__channel-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border:2px solid var(--border-color, #e0e0e0);border-radius:8px;background:transparent;cursor:pointer;font-size:13px;transition:border-color .15s}.sign-modal__channel-card--active{border-color:#185fa5;background:#e6f1fb}.sign-modal__phone-field{margin-bottom:14px}.sign-modal__phone-field label{display:block;font-size:12px;color:#666;margin-bottom:4px}.sign-modal__confirm-btn{width:100%;padding:10px;background:#185fa5;color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer}.sign-modal__email{font-size:13px;color:var(--color-accent-primary);font-weight:600}.sign-modal__info{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:#d4af3714;border:1px solid rgba(212,175,55,.2);border-radius:8px;margin-bottom:16px}.sign-modal__icon{color:var(--color-accent-primary);flex-shrink:0;margin-top:2px}.sign-modal__info p{font-size:14px;color:var(--color-text-secondary);margin:0;line-height:1.5}.sign-modal__error{background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:8px;padding:10px 14px;font-size:13px;color:#ef4444;margin-bottom:12px}.sign-modal__verifying{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;color:var(--color-text-secondary);font-size:14px}.sign-modal__spinner{animation:spin 1s linear infinite;color:var(--color-accent-primary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sign-modal__resend{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px}.sign-modal__resend p{font-size:13px;color:var(--color-text-tertiary);margin:0}.sign-modal__resend-btn{background:none;border:none;color:var(--color-accent-primary);font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.sign-modal__resend-btn:disabled{opacity:.5;cursor:not-allowed}.sign-modal__legal{margin-top:20px;padding:12px;background:var(--color-surface, #f9f9f9);border-radius:6px;font-size:11px;color:var(--color-text-tertiary);line-height:1.6;text-align:center}.sign-modal__success{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 0;text-align:center}.sign-modal__success-icon{color:#22c55e}.sign-modal__success h3{font-size:22px;margin:0;color:var(--color-text-primary, #111)}.sign-modal__certificate{background:#f0fdf4;border:1px solid #86efac;border-radius:10px;padding:16px 24px;width:100%}.sign-modal__cert-label{font-size:12px;color:#16a34a;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}.sign-modal__cert-date,.sign-modal__cert-email{font-size:14px;color:#333;margin:4px 0 0}.sign-modal__notify{font-size:13px;color:var(--color-text-secondary);margin:0}.sign-modal__hash-box{margin-top:16px;background:#f0f4ff;border:1px solid #c7d4f8;border-radius:8px;padding:12px 14px;text-align:left}.sign-modal__hash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.sign-modal__hash-label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.sign-modal__hash-copy{display:flex;align-items:center;gap:4px;font-size:12px;color:#3f7af8;background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s}.sign-modal__hash-copy:hover{background:#dbeafe}.sign-modal__hash-value{display:block;font-family:Courier New,Courier,monospace;font-size:11px;color:#1e40af;word-break:break-all;line-height:1.5}.sign-modal__hash-note{margin-top:8px;font-size:11px;color:#9ca3af;font-style:italic}.sign-modal__pdf-status{margin-top:12px;font-size:13px;padding:6px 12px;border-radius:6px}.sign-modal__pdf-status--ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.sign-modal__pdf-status--pending{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.sign-modal__pdf-ready{display:flex;flex-direction:column;align-items:stretch;gap:8px;margin-top:12px}.sign-modal__download-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:10px 14px;background:#185fa5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.sign-modal__download-btn:hover:not(:disabled){background:#145088}.sign-modal__download-btn:disabled{opacity:.6;cursor:not-allowed}.sign-modal__download-error{font-size:12px;color:#ef4444;margin:0;text-align:center}.sign-modal__pending-notice{display:flex;align-items:flex-start;gap:8px;width:100%;padding:12px 14px;border-radius:8px;font-size:13px;line-height:1.5;text-align:left}.sign-modal__pending-notice p{margin:0;flex:1}.sign-modal__pending-notice-icon{display:flex;align-items:center;flex-shrink:0;margin-top:1px}.sign-modal__pending-notice-icon--entity{opacity:.75}.sign-modal__pending-notice--info{background:#3b82f612;border:1px solid rgba(59,130,246,.25);color:#1d4ed8}.sign-modal__pending-notice--info .sign-modal__pending-notice-icon{color:#3b82f6}.sign-modal__pending-notice--warning{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);color:#92400e}.sign-modal__pending-notice--warning .sign-modal__pending-notice-icon{color:#f59e0b}@media(max-width:480px){.sign-modal__channel-grid{grid-template-columns:1fr}.sign-modal__certificate{padding:12px 16px}.sign-modal__success h3{font-size:18px}}.sign-modal__name-field{margin-bottom:20px;padding:14px 16px;background:#f8faff;border:1px solid #c7d4f8;border-radius:10px}.sign-modal__name-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#1e40af;margin-bottom:8px}.sign-modal__name-input{width:100%;padding:10px 12px;border:1.5px solid #c7d4f8;border-radius:8px;font-size:15px;font-family:inherit;color:#1a202c;background:#fff;outline:none;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.sign-modal__name-input:focus{border-color:#3f7af8;box-shadow:0 0 0 3px #3f7af81f}.sign-modal__name-input--error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.sign-modal__name-hint{font-size:12px;color:#6b7280;margin:6px 0 0;line-height:1.4}.sign-modal__name-hint--error{color:#ef4444}.sign-modal__delegate-badge{display:inline-flex;align-items:center;gap:6px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:5px 10px;font-size:13px;color:#1e40af;margin-bottom:12px}.sign-modal__subtitle{font-size:14px;color:#555;margin:0 0 14px}.sign-modal__order-block{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;background:#fefce8;border:1.5px solid #fde68a;border-radius:12px;text-align:center}.sign-modal__order-icon{font-size:36px;line-height:1}.sign-modal__order-title{font-size:17px;font-weight:700;color:#92400e;margin:0}.sign-modal__order-desc{font-size:13px;color:#78350f;margin:0}.sign-modal__order-list{list-style:none;padding:0;margin:0;width:100%;display:flex;flex-direction:column;gap:8px}.sign-modal__order-signer{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff;border:1px solid #fde68a;border-radius:8px;text-align:left}.sign-modal__order-num{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f59e0b;color:#fff;border-radius:50%;font-size:13px;font-weight:700;flex-shrink:0}.sign-modal__order-role{font-size:12px;color:#6b7280}.sign-modal__order-email{font-size:12px;color:#9ca3af;margin-top:2px}.sign-modal__order-hint{font-size:12px;color:#92400e;margin:0;font-style:italic}.action-otp-modal{padding:8px 0;min-height:200px;display:flex;flex-direction:column}.action-otp-modal__status{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:40px 0;color:#6b7280;font-size:15px}.action-otp-modal__spinner{animation:aotp-spin 1s linear infinite;color:#6b7280}@keyframes aotp-spin{to{transform:rotate(360deg)}}.action-otp-modal__spinner--sm{width:18px;height:18px}.action-otp-modal__info{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-left:4px solid #6b7280;border-radius:0 6px 6px 0;margin-bottom:16px;font-size:14px;color:#374151;line-height:1.5}.action-otp-modal__info p{margin:0}.action-otp-modal__reason{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:10px 14px;font-size:13px;color:#4b5563;margin-bottom:14px;display:flex;gap:6px;flex-wrap:wrap}.action-otp-modal__reason-label{font-weight:600;color:#374151}.action-otp-modal__reason-text{color:#6b7280}.action-otp-modal__error{background:#fff5f5;border:1px solid #fed7d7;color:#c53030;border-radius:6px;padding:10px 14px;font-size:13px;margin-bottom:12px}.action-otp-modal__verifying{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:13px;margin-top:12px;justify-content:center}.action-otp-modal__resend{margin-top:16px;text-align:center;font-size:13px;color:#9ca3af}.action-otp-modal__resend p{margin:0 0 4px}.action-otp-modal__resend-btn{background:none;border:none;color:#3b82f6;font-size:13px;cursor:pointer;text-decoration:underline;padding:0}.action-otp-modal__resend-btn:disabled{color:#9ca3af;cursor:not-allowed;text-decoration:none}.action-otp-modal__success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:24px 8px}.action-otp-modal__success h3{margin:0;font-size:20px;font-weight:700;color:#1f2937}.action-otp-modal__success p{margin:0;font-size:14px;color:#6b7280;line-height:1.6;max-width:320px}.action-otp-modal__success-icon--reject{color:#e53e3e}.action-otp-modal__success-icon--wait{color:#f59e0b}.comments-card{display:flex;flex-direction:column;height:100%;background:#fff;overflow:hidden}.comments-header{padding:15px 20px;background:linear-gradient(135deg,#63a0eb,#63a0eb);color:#fff;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.comments-header h3{margin:0;font-size:18px;font-weight:600}.toggle-btn{background:#fff3;border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px}.toggle-btn:hover{background:#ffffff4d;transform:scale(1.1)}.comments-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.chat-message{display:flex;margin-bottom:15px}.chat-container{flex:1;overflow-y:auto;padding:20px;background:#f9f9f9;display:flex;flex-direction:column}.no-comments{text-align:center;padding:40px 20px;color:#999;font-style:italic}.chat-message{display:flex;margin-bottom:15px;animation:messageSlide .3s ease}@keyframes messageSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.my-message{justify-content:flex-end}.chat-message.other-message{justify-content:flex-start}.bubble{max-width:80%;padding:10px 14px;border-radius:15px;font-size:14px}.my-message .bubble{background:#53baff;color:#fff;border-bottom-right-radius:2px}.other-message .bubble{background:#fff;border:1px solid #ddd;border-bottom-left-radius:2px}.other-message .bubble{background:#fff;color:#333;border:1px solid #e0e0e0;border-bottom-left-radius:4px}.message-header{font-size:12px;margin-bottom:5px;opacity:.9}.bubble p{margin:0;line-height:1.5;font-size:14px}.msg-time{display:block;font-size:11px;margin-top:5px;opacity:.7;text-align:right}.comment-input-area{padding:15px;background:#fff;border-top:1px solid #eee;display:flex;flex-direction:column;gap:8px;flex-shrink:0}.comment-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;resize:none;font-size:16px}.comment-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.comment-input:disabled{background:#f5f5f5;cursor:not-allowed}.btn-primary{background:#0c0c0c;color:#fff;border:none;padding:10px;border-radius:8px;font-weight:600;cursor:pointer;align-self:flex-end}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #63a0eb}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.chat-container::-webkit-scrollbar{width:8px}.chat-container::-webkit-scrollbar-track{background:#f1f1f1}.chat-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.chat-container::-webkit-scrollbar-thumb:hover{background:#555}@media(max-width:768px){.bubble{max-width:85%}}.quote-details-card{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 15px #0000001a;overflow:hidden;min-width:0}.quote-details-card h2{font-size:22px;color:#333;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}.detail-section{background:#f9f9f9;padding:20px;border-radius:8px;min-width:0}.detail-section h3{font-size:16px;color:#555;margin-bottom:15px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid #e0e0e0;gap:10px}.detail-row:last-child{border-bottom:none}.detail-label{font-size:14px;color:#666;font-weight:500;flex-shrink:0}.detail-value{font-size:14px;color:#333;font-weight:600;text-align:right;word-break:break-word;min-width:0}.detail-value.discount{color:#f44336}.detail-row.total-row{margin-top:10px;padding-top:15px;border-top:2px solid #4caf50;border-bottom:none}.detail-row.total-row .detail-label,.detail-row.total-row .detail-value{font-size:16px;color:#4caf50}@media(max-width:768px){.quote-details-card{padding:14px 12px}.quote-details-card h2{font-size:18px;margin-bottom:15px}.details-grid{grid-template-columns:1fr;gap:12px}.detail-section{padding:14px}}@media(max-width:480px){.quote-details-card{padding:10px}.detail-label,.detail-value{font-size:12px}}.products-card{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 15px #0000001a}.products-card h2{font-size:22px;color:#333;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.no-products{text-align:center;padding:40px;color:#999;font-style:italic}.products-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.products-table{width:100%;border-collapse:collapse;font-size:14px}.products-table thead{background:linear-gradient(135deg,#63a0eb,#63a0eb);color:#fff}.products-table th{padding:15px 12px;text-align:left;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.products-table th:first-child{width:50px;text-align:center}.products-table tbody tr.product-row{border-bottom:1px solid #e0e0e0;transition:background-color .2s ease}.products-table tbody tr.product-row:hover{background-color:#f5f5f5}.products-table td{padding:15px 12px;vertical-align:middle}.expand-btn{width:32px;height:32px;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;margin:0 auto}.expand-btn:hover{background:#667eea;color:#fff;transform:scale(1.1)}.product-name{font-weight:600;color:#333}.total-cell{font-weight:700;color:#4caf50}.expanded-row{background:#f9f9f9}.expanded-row td{padding:0}.product-details{padding:20px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.detail-group{margin-bottom:15px}.detail-group:last-child{margin-bottom:0}.detail-group strong{display:block;color:#667eea;margin-bottom:8px;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.detail-group p{margin:0;color:#555;line-height:1.6}.price-breakdown{background:#fff;padding:15px;border-radius:8px;border:1px solid #e0e0e0}.price-breakdown div{padding:5px 0;display:flex;justify-content:space-between}.products-table tfoot{background:#f5f5f5;font-weight:700}.products-table tfoot td{padding:20px 12px;font-size:16px}.total-row .total-cell{font-size:18px}@media(max-width:768px){.products-card{padding:16px}.products-card h2{font-size:18px;margin-bottom:15px}.products-table{font-size:12px;min-width:500px}.products-table th,.products-table td{padding:10px 8px}.product-name{font-size:12px}}@media(max-width:480px){.products-card{padding:12px}}.attachments-card{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 15px #0000001a}.attachments-card h2{font-size:22px;color:#333;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.fullscreen-modal{width:100vw;height:100vh;max-width:100vw;max-height:100vh;margin:0;padding:0}.fullscreen-preview{width:100%;height:calc(100vh - 60px);background:#111;display:flex;align-items:center;justify-content:center}.fullscreen-media{width:100%;height:100%;border:none;object-fit:contain}.fullscreen-text{width:100%;height:100%;padding:24px;background:#111;color:#fff;overflow:auto;white-space:pre-wrap}.no-attachments{text-align:center;padding:40px;color:#999;font-style:italic}.attachments-list{display:flex;flex-direction:column;gap:15px}.attachment-item{display:flex;align-items:center;gap:15px;padding:15px;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0;transition:all .3s ease}.attachment-item:hover{background:#f0f0f0;border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.attachment-icon{font-size:32px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;flex-shrink:0}.attachment-info{flex:1;min-width:0}.attachment-name{font-weight:600;color:#333;font-size:14px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-meta{font-size:12px;color:#888}.attachment-actions{display:flex;gap:8px;flex-shrink:0}.btn-icon{width:40px;height:40px;border:none;background:#fff;border-radius:50%;font-size:18px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 5px #0000001a}.btn-icon:hover{background:#667eea;transform:translateY(-2px);box-shadow:0 4px 10px #667eea4d}.file-preview{max-width:100%;max-height:80vh;overflow:auto}.file-preview img{display:block;margin:0 auto;max-width:100%;border-radius:8px}.file-preview pre{background:#f5f5f5;padding:20px;border-radius:8px;overflow-x:auto;font-size:13px;line-height:1.6}@media(max-width:768px){.attachments-card{padding:16px}.attachments-card h2{font-size:18px}.attachment-item{flex-wrap:wrap;gap:10px}.attachment-actions{width:100%;justify-content:flex-end}}@media(max-width:480px){.attachments-card{padding:12px}.attachment-icon{width:40px;height:40px;font-size:24px}}.negotiation-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 4px 15px #0000001a;margin-bottom:20px}.negotiation-card h3{font-size:20px;color:#333;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #f0f0f0}.negotiation-status{margin-bottom:20px}.negotiation-status h4{font-size:14px;color:#666;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.status-item{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#f9f9f9;border-radius:8px;margin-bottom:8px}.status-item span:first-child{font-weight:600;color:#555;font-size:14px}.nego-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.nego-badge.approved{background:#e8f5e9;color:#2e7d32}.nego-badge.rejected{background:#ffebee;color:#c62828}.nego-badge.pending{background:#fff3e0;color:#e65100}.negotiation-comments{margin-top:15px;padding:15px;background:#f5f5f5;border-left:4px solid #667eea;border-radius:4px}.negotiation-comments strong{display:block;color:#667eea;font-size:13px;margin-bottom:8px}.negotiation-comments p{margin:0;color:#555;line-height:1.6;font-size:14px}.negotiation-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.btn-outline{background:#fff;color:#667eea;border:2px solid #667eea;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-align:left;display:flex;align-items:center;gap:8px}.btn-outline:hover:not(:disabled){background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-outline:disabled{opacity:.5;cursor:not-allowed;transform:none}.current-values{background:#f9f9f9;padding:20px;border-radius:8px;border:1px solid #e0e0e0}.current-values h4{font-size:14px;color:#666;margin-bottom:15px;text-transform:uppercase;letter-spacing:.5px}.value-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #e0e0e0}.value-item:last-child{border-bottom:none}.value-item span{font-size:14px;color:#666}.value-item strong{font-size:14px;color:#333}.modal-content{padding:20px 0}.modal-content p{margin-bottom:20px;color:#555;line-height:1.6}.modal-content label{display:block;font-weight:600;color:#333;margin-bottom:8px;font-size:14px}.input-field{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:16px;font-family:inherit;transition:border-color .3s ease;box-sizing:border-box}textarea.input-field{resize:vertical;min-height:100px}.budget-type-selector{display:flex;gap:20px;margin-bottom:20px;flex-wrap:wrap}.budget-type-selector label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500}.budget-type-selector input[type=radio]{cursor:pointer}.budget-range{display:grid;grid-template-columns:1fr 1fr;gap:15px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:25px;padding-top:20px;border-top:1px solid #e0e0e0}@media(max-width:768px){.negotiation-card{padding:16px}.budget-range{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}@media(max-width:480px){.negotiation-card{padding:12px}.status-item{flex-direction:column;align-items:flex-start;gap:6px}}.token-expiry-timer{position:fixed;top:20px;right:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border-radius:12px;box-shadow:0 4px 20px #667eea66;display:flex;align-items:center;gap:10px;font-size:14px;z-index:1000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.token-expiry-timer.warning{background:linear-gradient(135deg,#f093fb,#f5576c);animation:pulse 2s ease-in-out infinite}.token-expiry-timer.critical{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);animation:criticalPulse 1s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 4px 20px #f093fb66}50%{box-shadow:0 6px 30px #f5576c99}}@keyframes criticalPulse{0%,to{box-shadow:0 4px 20px #ff6b6b66;transform:scale(1)}50%{box-shadow:0 8px 40px #ee5a6fcc;transform:scale(1.02)}}.timer-icon{flex-shrink:0}.timer-text{font-weight:400}.timer-text strong{font-weight:700;font-size:16px}@media(max-width:768px){.token-expiry-timer{top:10px;right:10px;left:10px;padding:10px 16px;font-size:13px}.timer-text strong{font-size:14px}}.doc-upload{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 15px #00000014;margin-bottom:20px}.doc-upload__title{font-size:18px;font-weight:700;color:#222;margin:0 0 6px}.doc-upload__subtitle{font-size:13px;color:#666;margin:0 0 20px;line-height:1.5}.doc-upload__dropzone{border:2px dashed #d0d0d0;border-radius:10px;padding:36px 20px;text-align:center;cursor:pointer;transition:all .25s ease;background:#fafafa;margin-bottom:16px;outline:none}.doc-upload__dropzone:hover,.doc-upload__dropzone:focus{border-color:#667eea;background:#667eea0a}.doc-upload__dropzone--over{border-color:#667eea;background:#667eea14;transform:scale(1.01)}.doc-upload__drop-icon{color:#667eea;margin-bottom:12px}.doc-upload__drop-text{font-size:15px;color:#444;margin:0 0 6px}.doc-upload__drop-text span{color:#667eea;font-weight:600;text-decoration:underline}.doc-upload__drop-hint{font-size:12px;color:#999;margin:0}.doc-upload__item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;margin-bottom:8px;border:1px solid #e5e5e5;background:#fff;overflow:hidden}.doc-upload__item--uploading{border-color:#93c5fd;background:#eff6ff}.doc-upload__item--done{border-color:#86efac;background:#f0fdf4}.doc-upload__item--error{border-color:#fca5a5;background:#fff5f5}.doc-upload__item-icon{font-size:22px;flex-shrink:0}.doc-upload__item-info{flex:1;min-width:0}.doc-upload__item-name{display:block;font-size:14px;font-weight:600;color:#222;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-upload__item-meta{display:block;font-size:12px;color:#777;margin-top:2px}.doc-upload__item--error .doc-upload__item-meta{color:#dc2626}.doc-upload__item-status{display:flex;align-items:center;gap:6px;flex-shrink:0}.doc-upload__spinner{display:inline-block;width:18px;height:18px;border:2px solid #bfdbfe;border-top-color:#3b82f6;border-radius:50%;animation:upload-spin .7s linear infinite}@keyframes upload-spin{to{transform:rotate(360deg)}}.doc-upload__icon-done{color:#22c55e}.doc-upload__icon-error{color:#ef4444}.doc-upload__remove{background:none;border:none;cursor:pointer;color:#aaa;padding:2px;display:flex;align-items:center;border-radius:4px;transition:color .2s}.doc-upload__remove:hover{color:#555}.doc-upload__history{margin-top:20px;padding-top:16px;border-top:1px solid #f0f0f0}.doc-upload__history-title{font-size:13px;color:#888;text-transform:uppercase;letter-spacing:.4px;margin:0 0 12px}.doc-upload__history-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:13px}.doc-upload__history-item:last-child{border-bottom:none}.doc-upload__history-info{flex:1;min-width:0}.doc-upload__history-name{display:block;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-upload__history-date{font-size:11px;color:#999}@media(max-width:768px){.doc-upload{padding:16px}.doc-upload__dropzone{padding:24px 16px}}@media(max-width:480px){.doc-upload{padding:12px}.doc-upload__dropzone{padding:20px 12px}.doc-upload__drop-text{font-size:13px}}.quote-dashboard{min-height:100vh;background:linear-gradient(135deg,#b3d0f3,#f0f7ff);padding:20px;overflow-x:hidden;box-sizing:border-box}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#fff}.error-container{text-align:center;padding:40px;color:#fff;font-size:18px}.dashboard-content{display:grid;grid-template-columns:1fr 400px;grid-template-rows:auto auto;grid-template-areas:"main-top    sidebar" "main-bottom sidebar";gap:20px;max-width:1400px;margin:20px auto 0;min-width:0;align-items:start}.main-column-top{grid-area:main-top;display:flex;flex-direction:column;gap:20px;min-width:0}.main-column-bottom{grid-area:main-bottom;display:flex;flex-direction:column;gap:20px;min-width:0}.sidebar-column{grid-area:sidebar;display:flex;flex-direction:column;gap:20px;min-width:0}@media(max-width:1200px){.dashboard-content{grid-template-columns:1fr;grid-template-areas:"main-top" "sidebar" "main-bottom"}}@media(max-width:768px){.quote-dashboard{padding:10px}.dashboard-content{gap:10px;margin-top:10px}}@media(max-width:480px){.quote-dashboard{padding:6px}.dashboard-content{gap:8px;margin-top:8px}}.third-party-container{min-height:100vh;background:url(https://img.freepik.com/foto-gratuito/astratto-elegante-sfondo-blu-con-lo-spazio-del-testo_1017-46767.jpg?t=st=1741363985~exp=1741367585~hmac=f3e510e67fc2f9b6db33663404841d7b932a4ffe6e23b2207b8f463ed71da542&w=1380) no-repeat center center;background-size:cover;padding:20px;display:flex;align-items:center;justify-content:center}.main-container-tp{display:flex;max-width:1200px;width:100%;background:#fffffff2;border-radius:10px;overflow:hidden;box-shadow:0 8px 20px #0003;animation:fadeIn 1s ease}.left-panel-tp{flex:1;min-width:320px;background:url(https://www.senati.edu.pe/sites/default/files/2018/carrera/10/carreras-tecnica-ingeneria-de-software-1800-x-1190.jpg) no-repeat center center;background-size:cover;min-height:600px;position:relative}.suite-info{position:relative;z-index:1;padding:30px;color:#fff}.right-panel-tp{flex:1;min-width:320px;background-color:#f8f9fa;display:flex;flex-direction:column;justify-content:center;padding:40px}.login-container-tp{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:30px;width:100%;max-width:400px;margin:0 auto;text-align:center}.step-container{animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.login-container-tp h1{font-size:24px;margin-bottom:15px;text-transform:uppercase;letter-spacing:1px;color:#0078d4;font-weight:700}.login-container-tp p{font-size:14px;margin-bottom:20px;color:#555;line-height:1.4}.step-description{font-size:14px;color:#666;margin-bottom:15px}.email-input-tp{width:100%;padding:14px;margin-bottom:20px;border:1px solid #ddd;border-radius:8px;font-size:16px;outline:none;transition:border-color .3s ease,box-shadow .3s ease;background:#f8f8f8;box-sizing:border-box}.email-input-tp:focus{border-color:#00adb5;box-shadow:0 0 8px #00adb580}.btn-tp{width:100%;padding:12px 25px;border:none;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;transition:background .3s,transform .3s;box-shadow:0 4px 12px #00000040}.btn-primary-tp{background:#004e89;color:#fff}.btn-primary-tp:hover{background:#00345c;transform:translateY(-2px)}.btn-secondary-tp{background:#f0f0f0;color:#333;margin-top:10px}.btn-secondary-tp:hover{background:#e0e0e0;transform:translateY(-2px)}.btn-link-tp{background:#00adb5;color:#fff;text-decoration:none;display:inline-block}.btn-link-tp:hover{background:#008b92;transform:translateY(-2px)}.version-info{margin-top:30px;text-align:left;font-size:12px;color:#666;padding-top:20px;border-top:1px solid rgba(0,0,0,.1)}.version-info label{display:block;margin-bottom:8px}.otp-modal-content{padding:20px 0;text-align:center}.otp-modal-content p{margin-bottom:15px;color:#555}.email-display{background:#f0f0f0;padding:10px;border-radius:8px;margin-bottom:20px;color:#333}.loading-text{margin-top:15px;color:#667eea;font-weight:600}@media(max-width:768px){.third-party-container{padding:16px;align-items:flex-start}.main-container-tp{flex-direction:column}.left-panel-tp{min-height:160px;min-width:unset}.right-panel-tp{padding:24px 20px;min-width:unset}.login-container-tp{padding:24px 16px;max-width:100%;box-shadow:none;background:transparent}.login-container-tp h1{font-size:22px}}@media(max-width:480px){.third-party-container{padding:12px;background-attachment:fixed}.left-panel-tp{display:none}.main-container-tp{border-radius:12px}.right-panel-tp{padding:20px 16px}}.tp-dashboard{min-height:100vh;background:linear-gradient(135deg,#b3d0f3,#f0f7ff);padding:30px 20px}.tp-loading,.tp-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#fff}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.tp-content-wrapper{display:flex;gap:20px;align-items:flex-start;width:100%}.tp-main-content{flex:0 0 75%;max-width:75%}.tp-side-comments{flex:0 0 23%;max-width:23%;position:sticky;top:20px}@media(max-width:1024px){.tp-content-wrapper{flex-direction:column}.tp-main-content,.tp-side-comments{flex:0 0 100%;max-width:100%}}@keyframes spin{to{transform:rotate(360deg)}}.tp-document{max-width:1200px;margin:0 auto 20px;background-color:#fff;border-radius:12px;box-shadow:0 4px 15px #00000026;padding:30px;animation:fadeIn 1.5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tp-title{color:#333;margin-bottom:25px;font-size:28px;font-weight:700;display:flex;align-items:center;gap:10px}.gradient-text{color:#667eea}.tp-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.tp-card{padding:25px;border-radius:12px;color:#fff;box-shadow:0 4px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.tp-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0003}.tp-card strong{display:block;font-size:14px;margin-bottom:10px;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.tp-card span{font-size:20px;font-weight:700}.card-blue{background:linear-gradient(135deg,#4f6ef7,#63a0eb)}.card-green{background:linear-gradient(135deg,#4caf50,#45a049)}.card-dark{background:linear-gradient(135deg,#393e46,#2a2e35)}.section-title{font-size:24px;color:#333;margin-top:30px;margin-bottom:15px;font-weight:600}.tp-table-container{max-height:400px;overflow-y:auto;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid #ccc;background-color:#fff;border-radius:8px;margin-bottom:30px}.tp-products-table{width:100%;border-collapse:collapse;font-size:14px;background-color:#f9f9f9}.tp-products-table thead{position:sticky;top:0;z-index:10}.tp-products-table th{background:linear-gradient(135deg,#63a0eb,#63a0eb);color:#fff;padding:15px 12px;text-align:left;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.tp-products-table td{padding:12px 8px;border-bottom:1px solid #ddd}.tp-products-table tbody tr:hover{background-color:#f0f0f0}.tp-attachments{margin-top:30px;padding:20px;background:#f9f9f9;border-radius:8px}.tp-attachments h3{font-size:20px;color:#333;margin-bottom:15px}.tp-attachment-list{display:flex;flex-direction:column;gap:10px}.tp-attachment-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#fff;border-radius:6px;border:1px solid #ddd}.attachment-name{font-weight:500;color:#333;flex:1}.btn-download{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-download:hover{transform:translateY(-2px);box-shadow:0 4px 10px #667eea4d}.tp-total{margin-top:30px;font-size:24px;color:#333;font-weight:700;text-align:left;padding:20px;background:#f9f9f9;border-radius:8px;border-left:4px solid #4caf50}.tp-total span{color:#4caf50}.tp-actions{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.tp-action-btn{padding:15px 30px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:center;gap:8px}.btn-confirm{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-confirm:hover{transform:translateY(-2px);box-shadow:0 6px 18px #4caf5066}.btn-wait{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.btn-wait:hover{transform:translateY(-2px);box-shadow:0 6px 18px #ff980066}.btn-reject{background:linear-gradient(135deg,#f44336,#e53935);color:#fff}.btn-reject:hover{transform:translateY(-2px);box-shadow:0 6px 18px #f4433666}.btn-share{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-share:hover{transform:translateY(-2px);box-shadow:0 6px 18px #667eea66}.modal-content-tp{padding:20px 0}.modal-content-tp p{margin-bottom:20px;color:#555;line-height:1.6}.input-field{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:16px;margin-bottom:20px;transition:border-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.input-field:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.btn-primary{background:#63a0eb;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f5f5f5;color:#666;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#e0e0e0}.btn-danger{background:linear-gradient(135deg,#f44336,#e53935);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}@media(max-width:768px){.tp-dashboard{padding:12px 8px}.tp-document{padding:16px;border-radius:10px}.tp-title{font-size:20px;margin-bottom:16px}.tp-summary{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.tp-card{padding:16px}.tp-card span{font-size:16px}.tp-products-table{font-size:12px;min-width:480px}.tp-products-table th,.tp-products-table td{padding:8px 4px}.tp-actions{grid-template-columns:1fr 1fr;gap:10px}.tp-action-btn{padding:12px 16px;font-size:14px}.tp-attachment-item{flex-direction:column;align-items:flex-start;gap:10px}.btn-download{width:100%;justify-content:center}}@media(max-width:480px){.tp-summary,.tp-actions{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions button{width:100%}.section-title{font-size:18px}}:root{--color-bg-primary: #f0f7ff;--color-bg-secondary: #b3d0f3;--color-bg-tertiary: #90c3fa;--color-bg-elevated: #d1e1f5;--color-surface: rgba(74, 144, 188, .05);--color-surface-hover: rgba(74, 144, 188, .1);--color-accent-primary: #4a90bc;--color-accent-secondary: #005a8d;--color-accent-gradient: linear-gradient(135deg, #4a90bc 0%, #005a8d 100%);--color-text-primary: #1e293b;--color-text-secondary: #475569;--color-text-tertiary: #94a3b8;--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--color-info: #3b82f6;--color-border: rgba(255, 255, 255, .1);--color-border-hover: rgba(255, 255, 255, .2);--font-display: "Libre Baskerville", serif;--font-body: "Outfit", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(212, 175, 55, .3);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--z-notification: 1080}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-primary);overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(244,208,63,.03) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(59,130,246,.02) 0%,transparent 50%);pointer-events:none;z-index:-1}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-accent-primary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-secondary)}::selection{background:var(--color-accent-primary);color:var(--color-bg-primary)}::-moz-selection{background:var(--color-accent-primary);color:var(--color-bg-primary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--color-text-primary)}h1{font-size:var(--font-size-5xl)}h2{font-size:var(--font-size-4xl)}h3{font-size:var(--font-size-3xl)}h4{font-size:var(--font-size-2xl)}h5{font-size:var(--font-size-xl)}h6{font-size:var(--font-size-lg)}p{margin-bottom:var(--spacing-md);color:var(--color-text-secondary)}a{color:var(--color-accent-primary);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--color-accent-secondary)}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none;transition:all var(--transition-base)}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-base);outline:none}input:focus,textarea:focus,select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #d4af371a}input::placeholder,textarea::placeholder{color:var(--color-text-tertiary)}.container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-xl)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes glow{0%,to{box-shadow:0 0 20px #d4af374d}50%{box-shadow:0 0 30px #d4af3780}}.animate-fade-in{animation:fadeIn .5s ease-out forwards}.animate-slide-up{animation:slideUp .5s ease-out forwards}.animate-slide-down{animation:slideDown .5s ease-out forwards}.animate-scale-in{animation:scaleIn .3s ease-out forwards}@media(max-width:1024px){:root{--font-size-5xl: 2.5rem;--font-size-4xl: 2rem;--font-size-3xl: 1.5rem}.container{padding:0 var(--spacing-lg)}}@media(max-width:768px){:root{--font-size-5xl: 2rem;--font-size-4xl: 1.75rem;--font-size-3xl: 1.25rem}.container{padding:0 var(--spacing-md)}}
