.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;margin-bottom:var(--space-lg)}.header-logo{width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--transition-base)}.header-logo:hover{transform:scale(1.1)}.logo-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;width:22px;height:22px}.logo-dot{width:9px;height:9px;background-color:var(--color-primary);border-radius:3px;transition:all var(--transition-base)}.header-logo:hover .logo-dot{background-color:var(--color-accent-light);border-radius:50%}.header-context-pill{display:flex;align-items:center;gap:8px;background:#3b5da714;padding:6px 14px;border-radius:20px;cursor:pointer;transition:all var(--transition-base)}.header-context-pill:hover{background:#3b5da726;transform:translateY(-1px)}.context-icon{color:var(--color-primary);font-size:16px}.header-title{font-size:14px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.01em;margin:0}.header-avatar{position:relative;width:40px;height:40px;border-radius:50%;overflow:visible;cursor:pointer;transition:transform var(--transition-base)}.header-avatar:hover{transform:scale(1.08)}.header-avatar img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--color-blue-soft)}.avatar-status{position:absolute;bottom:1px;right:1px;width:10px;height:10px;background-color:var(--color-success);border-radius:50%;border:2px solid var(--color-white)}.header-avatar-dropdown{position:absolute;top:55px;right:0;background:var(--color-white);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001a;width:200px;z-index:100;display:flex;flex-direction:column;overflow:hidden;animation:fade-in-up .2s ease forwards}.header-dropdown-item{display:flex;align-items:center;gap:var(--space-md);padding:12px 16px;background:none;border:none;width:100%;text-align:left;cursor:pointer;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);transition:background .15s ease}.header-dropdown-item:hover{background:var(--color-bg-alt)}.header-dropdown-icon{font-size:16px;color:var(--color-text-secondary)}.greeting{margin-bottom:var(--space-xl)}.greeting-name{font-size:var(--font-size-2xl);font-weight:800;color:var(--color-text-primary);letter-spacing:-.03em;line-height:1.2;margin-bottom:var(--space-xs)}.greeting-time{font-size:var(--font-size-base);color:var(--color-text-secondary);font-weight:400}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#edf2f7);padding:var(--space-xl)}.login-card{background:var(--color-white);width:100%;max-width:420px;border-radius:var(--radius-xl);box-shadow:0 10px 30px #1b2a4a14;overflow:hidden;padding:var(--space-xl);border:1px solid rgba(27,42,74,.05)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{display:flex;justify-content:center;align-items:center;width:64px;height:64px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border-radius:var(--radius-lg);margin:0 auto var(--space-md);box-shadow:0 4px 12px #3b5da733}.logo-icon{font-size:32px}.login-title{font-size:24px;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-sm)}.login-subtitle{font-size:var(--font-size-md);color:var(--color-text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}.login-error-message{background:#dc35451a;color:var(--color-danger, #dc3545);padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;font-weight:500}.login-input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.login-input-group label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-left:2px}.login-input-wrapper{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:16px;color:var(--color-text-muted);font-size:18px}.login-input{width:100%;padding:14px 16px 14px 44px;border:2px solid var(--color-bg-alt);border-radius:var(--radius-md);font-size:var(--font-size-md);color:var(--color-text-primary);transition:all .2s ease;background:var(--color-bg-alt)}.login-input:focus{outline:none;border-color:var(--color-primary);background:var(--color-white);box-shadow:0 0 0 4px #3b5da71a}.login-btn{margin-top:var(--space-md);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--color-white);border:none;border-radius:var(--radius-md);padding:16px;font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;justify-content:center;align-items:center;gap:var(--space-sm)}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #3b5da740}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{background:var(--color-text-muted);cursor:not-allowed;opacity:.7}.login-footer{margin-top:var(--space-xl);text-align:center}.login-footer p{font-size:var(--font-size-xs);color:var(--color-text-muted)}.search-bar{display:flex;align-items:center;gap:var(--space-sm);background:var(--color-white);border:2px solid transparent;border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xl);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.search-bar--focused{border-color:var(--color-accent-light);box-shadow:var(--shadow-md),0 0 0 3px #3b5da71a}.search-icon{color:var(--color-text-muted);font-size:var(--font-size-lg);flex-shrink:0;transition:color var(--transition-base)}.search-bar--focused .search-icon{color:var(--color-accent-light)}.search-input{flex:1;border:none;outline:none;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:transparent;padding:var(--space-xs) 0}.search-input::placeholder{color:var(--color-text-muted);font-weight:400}.ongoing-projects{margin-bottom:var(--space-xl)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.section-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em}.view-all-btn{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:all var(--transition-base)}.view-all-btn:hover{color:var(--color-accent-light);background:var(--color-blue-soft)}.actions-grid{display:flex;flex-direction:column;gap:var(--space-md)}.action-card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:0 4px 16px #1b2a4a0a;display:flex;transition:all var(--transition-base);overflow:hidden;position:relative}.action-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #1b2a4a14}.action-card-main{flex:1;display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:transparent;border:none;text-align:left;cursor:pointer;transition:background .2s}.action-card-secondary{display:flex;align-items:center;justify-content:center;padding:0 var(--space-lg);background:#1b2a4a05;border:none;border-left:1px solid rgba(27,42,74,.05);color:var(--color-text-secondary);font-size:20px;cursor:pointer;transition:all var(--transition-base)}.action-card-main.blue-hover:hover{background:#3b5da708}.action-card-main.red-hover:hover{background:#dc354508}.action-card-secondary:hover{background:#3b5da71a;color:var(--color-primary)}.action-icon-wrapper{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:24px;transition:all var(--transition-base)}.blue-icon{background:#3b5da71a;color:var(--color-primary)}.red-icon{background:#dc35451a;color:var(--color-danger, #dc3545)}.action-card-main.blue-hover:hover .blue-icon{background:var(--color-primary);color:var(--color-white)}.action-card-main.red-hover:hover .red-icon{background:var(--color-danger, #dc3545);color:var(--color-white)}.action-info{display:flex;flex-direction:column;gap:4px}.action-title{font-size:var(--font-size-base);font-weight:700;color:var(--color-text-primary);line-height:1.2}.action-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--max-width);height:var(--bottom-nav-height);background:var(--color-white);border-top:1px solid rgba(27,42,74,.06);z-index:100;box-shadow:0 -4px 20px #1b2a4a0f}.nav-items{display:flex;align-items:center;justify-content:space-around;height:100%;padding:0 var(--space-sm);position:relative}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:all var(--transition-base);position:relative;color:var(--color-text-muted);min-width:48px}.nav-item:hover{color:var(--color-text-secondary)}.nav-item--active{color:var(--color-primary)}.nav-icon{font-size:20px;transition:all var(--transition-base)}.nav-item--active .nav-icon{transform:scale(1.1)}.nav-label{font-size:10px;font-weight:500;letter-spacing:.02em;transition:color var(--transition-base)}.nav-item--active .nav-label{font-weight:600}.nav-indicator{position:absolute;top:calc(-1 * var(--space-xs) - 1px);left:50%;transform:translate(-50%);width:20px;height:3px;background:var(--color-primary);border-radius:0 0 var(--radius-full) var(--radius-full);animation:scaleIn .3s ease both}.nav-center-btn{position:relative;top:-20px;display:flex;align-items:center;justify-content:center;z-index:10}.center-btn-inner{width:56px;height:56px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #1b2a4a4d;transition:all var(--transition-base)}.center-btn-inner:hover{transform:scale(1.1);box-shadow:0 8px 28px #1b2a4a66}.center-btn-inner:active{transform:scale(.95)}.center-icon{color:var(--color-white);font-size:24px;stroke-width:2.5}.sidebar-overlay{position:fixed;inset:0;background:#0f1b3380;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;opacity:0;visibility:hidden;transition:all .35s ease}.sidebar-overlay--visible{opacity:1;visibility:visible}.sidebar{position:fixed;top:0;right:0;width:320px;max-width:85vw;height:100vh;background:var(--color-white);z-index:300;transform:translate(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 40px #1b2a4a26;overflow:hidden}.sidebar--open{transform:translate(0)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl) var(--space-xl) var(--space-md);border-bottom:1px solid rgba(27,42,74,.06)}.sidebar-title{font-size:var(--font-size-xl);font-weight:800;color:var(--color-text-primary);letter-spacing:-.03em}.sidebar-close{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);background:var(--color-bg);transition:all var(--transition-base);font-size:18px}.sidebar-close:hover{background:var(--color-blue-soft);color:var(--color-primary);transform:rotate(90deg)}.sidebar-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:var(--space-md) var(--space-xl) var(--space-sm);font-weight:400}.sidebar-menu{flex:1;padding:var(--space-sm) var(--space-md);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-menu-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);transition:all var(--transition-base);text-align:left;width:100%;animation:sidebarItemSlide .4s cubic-bezier(.4,0,.2,1) both}.sidebar--open .sidebar-menu-item{animation-name:sidebarItemSlide}@keyframes sidebarItemSlide{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.sidebar-menu-item:hover{background:var(--color-blue-soft);transform:translate(4px)}.sidebar-menu-item:active{transform:translate(2px) scale(.98)}.menu-item-icon{width:44px;height:44px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-blue-soft) 0%,#D6E2F5 100%);display:flex;align-items:center;justify-content:center;color:var(--color-primary);font-size:20px;flex-shrink:0;transition:all var(--transition-base)}.sidebar-menu-item:hover .menu-item-icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:var(--color-white);transform:scale(1.05)}.menu-item-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.menu-item-label{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);letter-spacing:-.01em}.menu-item-description{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:400}.menu-item-arrow{font-size:var(--font-size-xl);color:var(--color-text-muted);font-weight:300;transition:all var(--transition-base);flex-shrink:0}.sidebar-menu-item:hover .menu-item-arrow{color:var(--color-primary);transform:translate(4px)}.sidebar-footer{padding:var(--space-lg) var(--space-xl);border-top:1px solid rgba(27,42,74,.06)}.sidebar-footer-decoration{width:40px;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent-light));border-radius:var(--radius-full);margin:0 auto;opacity:.3}.under-construction{display:flex;align-items:center;justify-content:center;min-height:65vh;padding:var(--space-xl)}.uc-content{text-align:center;max-width:300px}.uc-icon-wrapper{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--color-blue-soft) 0%,#D6E2F5 100%);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-xl);animation:pulse 2.5s ease-in-out infinite}.uc-icon{font-size:36px;color:var(--color-primary);animation:rotateIcon 3s ease-in-out infinite}@keyframes rotateIcon{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.uc-title{font-size:var(--font-size-xl);font-weight:800;color:var(--color-text-primary);margin-bottom:var(--space-sm);letter-spacing:-.03em}.uc-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-xs);line-height:1.5}.uc-subtitle strong{color:var(--color-primary);font-weight:600}.uc-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-xl)}.uc-dots{display:flex;align-items:center;justify-content:center;gap:8px}.uc-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary);opacity:.3;animation:dotBounce 1.4s ease-in-out infinite}.uc-dot:nth-child(2){animation-delay:.2s}.uc-dot:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}.alert-overlay{position:fixed;inset:0;background:#0f1b3380;z-index:1000;animation:fadeIn .2s ease both}.alert-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:340px;max-width:88vw;background:var(--color-white);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-xl) var(--space-lg);z-index:1001;text-align:center;box-shadow:0 20px 50px #1b2a4a4d;animation:modalSlideIn .3s cubic-bezier(.4,0,.2,1) both}.alert-icon-wrapper{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}.alert-icon{font-size:26px}.alert-bg-success{background:#2ecc711a}.alert-icon-success{color:var(--color-success, #2ecc71)}.alert-bg-error{background:#e74c3c1a}.alert-icon-error{color:var(--color-danger, #e74c3c)}.alert-bg-warning{background:#f1c40f1a}.alert-icon-warning{color:var(--color-warning, #f1c40f)}.alert-bg-info{background:#3498db1a}.alert-icon-info{color:var(--color-info, #3498db)}.alert-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-sm)}.alert-message{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-lg)}.alert-actions{display:flex;justify-content:center}.alert-btn{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:var(--color-white);border:none;padding:10px 30px;box-shadow:0 4px 12px #1b2a4a33}.alert-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #1b2a4a4d}.alert-btn:active{transform:translateY(0)}.modal-overlay{position:fixed;inset:0;background:#0f1b3399;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:400;animation:fadeIn .25s ease both}.modal-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:420px;max-width:92vw;max-height:88vh;background:var(--color-white);border-radius:var(--radius-xl);z-index:500;display:flex;flex-direction:column;box-shadow:0 24px 60px #1b2a4a40;animation:modalSlideIn .35s cubic-bezier(.4,0,.2,1) both;overflow:hidden}@keyframes modalSlideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl) var(--space-md);border-bottom:1px solid rgba(27,42,74,.06);flex-shrink:0}.modal-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em}.modal-close-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);background:var(--color-bg);transition:all var(--transition-base);font-size:16px}.modal-close-btn:hover{background:var(--color-blue-soft);color:var(--color-primary);transform:rotate(90deg)}.modal-scroll-area{overflow-y:auto;flex:1;min-height:0}.modal-form{padding:var(--space-md) var(--space-xl) var(--space-sm);display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);letter-spacing:.01em}.form-required{color:var(--color-danger);margin-left:3px;font-weight:400}.form-input{width:100%;padding:10px 14px;border:2px solid rgba(27,42,74,.1);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg);transition:all var(--transition-base);outline:none}.form-input:focus{border-color:var(--color-accent-light);background:var(--color-white);box-shadow:0 0 0 3px #3b5da71a}.form-input::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:70px}.form-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A8BA8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}.form-select:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%233B5DA7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}.multiselect-container{border:2px solid rgba(27,42,74,.1);border-radius:var(--radius-sm);background:var(--color-bg);overflow:hidden}.multiselect-options{max-height:140px;overflow-y:auto;padding:4px}.multiselect-empty{padding:12px;text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted)}.multiselect-option{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:all var(--transition-base);-webkit-user-select:none;user-select:none}.multiselect-option:hover{background:var(--color-blue-soft)}.multiselect-option--selected{background:#3b5da714}.multiselect-checkbox{display:none}.multiselect-check{width:20px;height:20px;border:2px solid rgba(27,42,74,.2);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-base);font-size:12px;color:var(--color-white)}.multiselect-option--selected .multiselect-check{background:var(--color-primary);border-color:var(--color-primary)}.multiselect-label{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.3}.multiselect-label strong{color:var(--color-accent-light);font-weight:700;font-size:var(--font-size-xs)}.multiselect-count{display:block;padding:6px 12px;font-size:var(--font-size-xs);color:var(--color-accent-light);font-weight:600;border-top:1px solid rgba(27,42,74,.06);background:#3b5da70a}.tags-container{border:2px solid rgba(27,42,74,.1);border-radius:var(--radius-sm);background:var(--color-bg);padding:6px;display:flex;flex-direction:column;gap:8px;transition:all var(--transition-base)}.tags-container:focus-within{border-color:var(--color-accent-light);background:var(--color-white);box-shadow:0 0 0 3px #3b5da71a}.tags-list{display:flex;flex-wrap:wrap;gap:6px}.tag-item{display:flex;align-items:center;gap:6px;background:#3b5da71a;color:var(--color-accent-light);padding:4px 8px;border-radius:4px;font-size:var(--font-size-sm);font-weight:600;border:1px solid rgba(59,93,167,.2)}.tag-remove-btn{background:none;border:none;color:inherit;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:2px;border-radius:50%;margin-right:-2px}.tag-remove-btn:hover{background:#3b5da733;color:var(--color-danger)}.tags-input{border:none;background:transparent;padding:4px 6px;font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);outline:none;flex:1;min-width:120px}.tags-input::placeholder{color:var(--color-text-muted)}.tags-hint{font-size:11px;color:var(--color-text-muted);padding:0 4px}.image-upload-container{width:100%}.image-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px;border:2px dashed rgba(27,42,74,.15);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;transition:all var(--transition-base)}.image-upload-area:hover{border-color:var(--color-accent-light);background:#3b5da70a}.image-upload-input{display:none}.image-upload-icon{font-size:28px;color:var(--color-text-muted)}.image-upload-area:hover .image-upload-icon{color:var(--color-accent-light)}.image-upload-text{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.image-upload-hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.image-preview{position:relative;display:inline-block;border-radius:var(--radius-sm);overflow:hidden;border:2px solid rgba(27,42,74,.1)}.image-preview-img{display:block;max-width:100%;max-height:150px;object-fit:contain;border-radius:var(--radius-sm)}.image-remove-btn{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:all var(--transition-base)}.image-remove-btn:hover{background:var(--color-danger);transform:scale(1.1)}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition-base)}.btn-save{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:var(--color-white);border:none;box-shadow:0 4px 12px #1b2a4a33}.btn-save:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #1b2a4a4d}.btn-save:active:not(:disabled){transform:translateY(0)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-save--success{background:linear-gradient(135deg,var(--color-success) 0%,#2ecc71 100%)}.btn-cancel{background:transparent;color:var(--color-text-secondary);border:2px solid rgba(27,42,74,.1)}.btn-cancel:hover{background:var(--color-bg);border-color:#1b2a4a33}.btn-loading{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-white);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-list{border-top:1px solid rgba(27,42,74,.06);padding:var(--space-md) var(--space-xl) var(--space-xl)}.list-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.list-items{display:flex;flex-direction:column;gap:6px}.list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--color-bg);border-radius:var(--radius-sm);transition:all var(--transition-base);animation:fadeInUp .3s ease both;gap:10px}.list-item:hover{background:var(--color-blue-soft)}.list-item-thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid rgba(27,42,74,.08)}.list-item-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.list-item-code{font-size:var(--font-size-xs);font-weight:700;color:var(--color-accent-light);letter-spacing:.03em;text-transform:uppercase}.list-item-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary)}.list-item-desc{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.list-item-ref{font-size:var(--font-size-xs);color:var(--color-accent-light);font-weight:500;display:flex;align-items:center;gap:4px}.list-item-barcode{font-size:var(--font-size-xs);color:var(--color-text-muted);font-family:monospace;letter-spacing:.05em}.list-item-actions{display:flex;gap:4px;flex-shrink:0}.list-action-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all var(--transition-base)}.list-action-edit{color:var(--color-accent-light);background:transparent}.list-action-edit:hover{background:var(--color-blue-soft);transform:scale(1.1)}.list-action-delete{color:var(--color-text-muted);background:transparent}.list-action-delete:hover{color:var(--color-danger);background:#e74c3c14;transform:scale(1.1)}.confirm-overlay{position:fixed;inset:0;background:#0f1b3380;z-index:600;animation:fadeIn .2s ease both}.confirm-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:340px;max-width:88vw;background:var(--color-white);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-xl) var(--space-lg);z-index:700;text-align:center;box-shadow:0 20px 50px #1b2a4a4d;animation:modalSlideIn .3s cubic-bezier(.4,0,.2,1) both}.confirm-icon-wrapper{width:56px;height:56px;border-radius:50%;background:#e74c3c1a;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}.confirm-icon{font-size:26px;color:var(--color-danger)}.confirm-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-xs)}.confirm-message{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-xs)}.confirm-message strong{color:var(--color-text-primary)}.confirm-warning{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.confirm-actions{display:flex;gap:var(--space-sm);justify-content:center}.btn-delete{background:linear-gradient(135deg,#e74c3c,#c0392b);color:var(--color-white);border:none;box-shadow:0 4px 12px #e74c3c40}.btn-delete:hover{transform:translateY(-1px);box-shadow:0 6px 16px #e74c3c59}.btn-delete:active{transform:translateY(0)}.ep-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:460px;max-width:94vw;max-height:88vh;background:var(--color-white);border-radius:var(--radius-xl);z-index:500;display:flex;flex-direction:column;box-shadow:0 24px 60px #1b2a4a40;animation:modalSlideIn .35s cubic-bezier(.4,0,.2,1) both;overflow:hidden}.ep-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl) var(--space-sm);flex-shrink:0}.ep-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em}.ep-search{display:flex;align-items:center;gap:8px;margin:0 var(--space-xl) var(--space-md);padding:10px 14px;border:2px solid rgba(27,42,74,.1);border-radius:var(--radius-sm);background:var(--color-bg);flex-shrink:0;transition:all var(--transition-base)}.ep-search:focus-within{border-color:var(--color-accent-light);background:var(--color-white);box-shadow:0 0 0 3px #3b5da71a}.ep-search-icon{font-size:16px;color:var(--color-text-muted);flex-shrink:0}.ep-search:focus-within .ep-search-icon{color:var(--color-accent-light)}.ep-search-input{flex:1;border:none;outline:none;background:transparent;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary)}.ep-search-input::placeholder{color:var(--color-text-muted)}.ep-search-clear{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--color-text-muted);background:#1b2a4a14;cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.ep-search-clear:hover{background:#1b2a4a26;color:var(--color-text-primary)}.ep-content{overflow-y:auto;flex:1;min-height:0;padding:0 var(--space-xl) var(--space-xl)}.ep-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-2xl) 0;color:var(--color-text-muted)}.ep-spinner{width:28px;height:28px;border-width:3px;border-top-color:var(--color-primary);border-color:#1b2a4a1a}.ep-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-2xl) 0;text-align:center}.ep-empty-icon{font-size:40px;color:var(--color-text-muted);opacity:.4;margin-bottom:var(--space-xs)}.ep-empty p{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-secondary)}.ep-empty span{font-size:var(--font-size-sm);color:var(--color-text-muted)}.ep-list{display:flex;flex-direction:column;gap:8px}.ep-product{border:2px solid rgba(27,42,74,.08);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-base);animation:fadeInUp .3s ease both}.ep-product--expanded{border-color:var(--color-accent-light);box-shadow:0 4px 16px #3b5da71a}.ep-product-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px;background:transparent;cursor:pointer;transition:all var(--transition-base);gap:10px}.ep-product-header:hover{background:var(--color-bg)}.ep-product-left{display:flex;align-items:center;gap:10px;min-width:0}.ep-product-img{width:42px;height:42px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid rgba(27,42,74,.08)}.ep-product-img-placeholder{width:42px;height:42px;border-radius:8px;background:var(--color-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-muted);font-size:18px}.ep-product-info{display:flex;flex-direction:column;gap:1px;min-width:0}.ep-product-code{font-size:var(--font-size-xs);font-weight:700;color:var(--color-accent-light);letter-spacing:.03em;text-transform:uppercase}.ep-product-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ep-product-abbr{font-size:var(--font-size-xs);color:var(--color-text-muted)}.ep-product-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.ep-product-badge{font-size:var(--font-size-xs);font-weight:600;color:var(--color-accent-light);background:#3b5da714;padding:3px 8px;border-radius:20px;white-space:nowrap}.ep-chevron{font-size:16px;color:var(--color-text-muted);transition:transform .2s ease}.ep-materials{border-top:1px solid rgba(27,42,74,.06);background:var(--color-bg);animation:slideDown .25s ease both}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.ep-mat-empty{display:flex;align-items:center;gap:8px;padding:16px;color:var(--color-text-muted);font-size:var(--font-size-sm)}.ep-mat-list{padding:8px}.ep-mat-header-row{display:grid;grid-template-columns:36px 70px 1fr 90px;gap:8px;padding:4px 8px 8px;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.ep-mat-item{display:grid;grid-template-columns:36px 70px 1fr 90px;gap:8px;align-items:center;padding:8px;background:var(--color-white);border-radius:8px;margin-bottom:4px;transition:all var(--transition-base);animation:fadeInUp .2s ease both}.ep-mat-item:hover{box-shadow:0 2px 8px #1b2a4a14}.ep-mat-thumb{width:36px;height:36px;border-radius:6px;object-fit:cover;border:1px solid rgba(27,42,74,.06)}.ep-mat-thumb-placeholder{width:36px;height:36px;border-radius:6px;background:var(--color-bg);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:14px}.ep-mat-code{font-size:var(--font-size-xs);font-weight:700;color:var(--color-accent-light);text-transform:uppercase}.ep-mat-info{display:flex;flex-direction:column;gap:1px;min-width:0}.ep-mat-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ep-mat-abbr{font-size:var(--font-size-xs);color:var(--color-text-muted)}.ep-mat-barcode{font-size:var(--font-size-xs);color:var(--color-text-muted);font-family:monospace;letter-spacing:.03em}.scan-modal-container{width:380px;max-width:90vw}.scan-tabs{display:flex;border-bottom:2px solid rgba(27,42,74,.08);background:#1b2a4a05}.scan-tab{flex:1;padding:14px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);background:transparent;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-base);margin-bottom:-2px}.scan-tab:hover{color:var(--color-primary);background:#1b2a4a0a}.scan-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:var(--color-white)}.scan-content{padding:var(--space-xl)}.scan-camera-view{display:flex;align-items:center;justify-content:center}.scan-camera-placeholder{width:100%;aspect-ratio:1;background:#000;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;color:var(--color-white)}.scan-camera-icon-large{font-size:48px;opacity:.3;margin-bottom:16px}.scan-camera-title{font-size:var(--font-size-base);font-weight:600;margin-bottom:4px}.scan-camera-desc{font-size:var(--font-size-xs);opacity:.6;text-align:center;padding:0 20px}.scan-target-box{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;height:40%;border:2px solid rgba(255,255,255,.3);border-radius:8px}.scan-target-box:before,.scan-target-box:after{content:"";position:absolute;width:20px;height:20px;border-color:#2ecc71;border-style:solid}.scan-target-box:before{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:8px 0 0}.scan-target-box:after{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 8px}.scan-target-line{position:absolute;top:0;left:0;width:100%;height:2px;background:#e74c3c;box-shadow:0 0 8px #e74c3c;animation:scanLine 2s linear infinite}@keyframes scanLine{0%{top:0;opacity:0}10%{opacity:1}90%{opacity:1}to{top:100%;opacity:0}}.scan-manual-form{display:flex;flex-direction:column;gap:var(--space-lg)}.scan-manual-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.scan-input{font-size:24px;letter-spacing:.1em;text-align:center;padding:16px;font-family:monospace}.scan-submit-btn{width:100%;justify-content:center;padding:14px;font-size:var(--font-size-base)}.ip-modal-container{width:440px}.ip-title-icon{color:var(--color-primary);font-size:22px}.ip-modal-body{padding:var(--space-xl)}.ip-form{display:flex;flex-direction:column;gap:var(--space-lg)}.ip-datetime-row{display:flex;gap:var(--space-md)}.ip-datetime-row .form-group{flex:1;margin-bottom:0}.ip-input-with-icon{position:relative;display:flex;align-items:center}.ip-input-with-icon .ip-input-icon{position:absolute;left:12px;color:var(--color-text-muted);font-size:16px;pointer-events:none}.ip-input-with-icon .form-input{padding-left:38px}.ip-submit-btn{margin-top:var(--space-md);padding:14px;font-size:var(--font-size-base)}.ip-submit-btn:disabled{background:var(--color-text-muted);cursor:not-allowed;opacity:.7}.nch-summary-section{margin-bottom:var(--space-xl)}.nch-summary-card{background:linear-gradient(135deg,#dc35451a,#dc354505);border:1px solid rgba(220,53,69,.2);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md);cursor:pointer;transition:all .2s ease}.nch-summary-card:active{transform:scale(.98)}.nch-summary-icon-box{background:#dc354526;width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.nch-summary-icon{font-size:24px;color:var(--color-danger, #dc3545)}.nch-summary-text{flex:1}.nch-summary-title{margin:0 0 4px;font-size:var(--font-size-md);font-weight:700;color:var(--color-danger, #dc3545)}.nch-summary-desc{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.nc-modal-container{max-width:500px;width:90%}.nc-modal-content{max-height:60vh;overflow-y:auto;padding:var(--space-md) 0}.nch-list{display:flex;flex-direction:column;gap:var(--space-sm)}.nch-card{background:var(--color-bg-light);padding:var(--space-md);border-radius:var(--radius-md);border-left:4px solid var(--color-danger, #dc3545);display:flex;justify-content:space-between;align-items:center}.nch-card-main{display:flex;gap:var(--space-md);align-items:center}.nch-time{font-size:11px;color:var(--color-text-muted);font-weight:600;text-align:center;line-height:1.2}.nch-details{display:flex;flex-direction:column;gap:4px}.nch-mat-name{margin:0;font-size:var(--font-size-sm);color:var(--color-text-primary)}.nch-prod-name{margin:0;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.nch-status{display:flex;align-items:center}.nch-badge{padding:4px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.nch-badge-danger{background:#dc35451a;color:var(--color-danger, #dc3545)}.producao-atual-section{margin-bottom:var(--space-xl)}.producao-table-container{background:var(--color-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 12px #1b2a4a0a;border:1px solid rgba(27,42,74,.05)}.producao-table{width:100%;border-collapse:collapse;text-align:left}.producao-table th{background:#3b5da708;padding:12px 16px;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(27,42,74,.05)}.producao-table td{padding:14px 16px;font-size:var(--font-size-sm);color:var(--color-text-primary);border-bottom:1px solid rgba(27,42,74,.05);vertical-align:middle}.producao-table tbody tr:last-child td{border-bottom:none}.linha-nome-sm{color:var(--color-text-secondary);font-size:11px;display:block;margin-top:2px}.prod-name-highlight{font-weight:600;color:var(--color-primary)}.prod-name-empty{color:var(--color-text-muted);font-style:italic;font-size:13px}.prod-time-sm{font-size:12px;color:var(--color-text-secondary);white-space:nowrap}.lp-modal-container{width:440px;max-width:90vw}.lp-title-icon{color:var(--color-primary);font-size:22px}.lp-modal-body{padding:var(--space-lg);background:#1b2a4a05}.lp-scroll-area{max-height:60vh;overflow-y:auto}.lp-empty-message{text-align:center;color:var(--color-text-secondary);padding:var(--space-xl) 0}.lp-card{background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);box-shadow:0 2px 8px #0000000a;position:relative;border:1px solid rgba(27,42,74,.08)}.lp-card:last-child{margin-bottom:0}.lp-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.lp-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:12px;letter-spacing:.5px}.lp-badge-blue{background:#3b5da71a;color:var(--color-primary)}.lp-date{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.lp-prod-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.lp-fab-name{font-size:var(--font-size-xs);color:var(--color-text-muted)}.lp-card-actions{position:absolute;bottom:var(--space-md);right:var(--space-md);display:flex;gap:var(--space-xs)}.lp-action-btn{background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:16px;padding:6px;border-radius:4px;transition:all var(--transition-base)}.lp-edit-btn:hover{color:var(--color-primary);background:#3b5da71a}.lp-delete-btn:hover{color:var(--color-danger, #dc3545);background:#dc35451a}.lp-edit-form{display:flex;flex-direction:column;gap:var(--space-sm)}.lp-form-row{display:flex;flex-direction:column;gap:4px}.lp-form-row label{font-size:12px;color:var(--color-text-secondary)}.lp-actions-row{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-sm)}.lp-btn{padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px;border:none}.lp-btn-cancel{background:transparent;color:var(--color-text-secondary)}.lp-btn-cancel:hover{background:#1b2a4a0d}.lp-btn-save{background:var(--color-primary);color:var(--color-white)}.lp-btn-delete{background:var(--color-danger, #dc3545);color:var(--color-white)}.lp-delete-confirm{text-align:center;padding:var(--space-sm) 0}.lp-warning-icon{font-size:24px;color:var(--color-warning, #f39c12);margin-bottom:8px}.lp-delete-confirm p{font-size:14px;color:var(--color-text-primary);margin-bottom:12px}.ctx-modal-container{width:400px;max-width:90vw}.ctx-mandatory{box-shadow:0 10px 40px #1b2a4a26}.ctx-modal-header{border-bottom:1px solid rgba(27,42,74,.05)}.ctx-title-icon{color:var(--color-success);font-size:22px}.ctx-modal-body{padding:var(--space-xl)}.ctx-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-lg);line-height:1.5}.ctx-form{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.ctx-form-row{display:flex;flex-direction:column;gap:8px}.ctx-form-row label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.ctx-actions{display:flex;justify-content:flex-end;gap:var(--space-md)}.ctx-btn{padding:12px 20px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;border:none;transition:all var(--transition-base)}.ctx-btn-cancel{background:transparent;color:var(--color-text-secondary)}.ctx-btn-cancel:hover{background:#1b2a4a0d;color:var(--color-text-primary)}.ctx-btn-save{background:var(--color-primary);color:var(--color-white);flex:1}.ctx-btn-save:hover{background:var(--color-primary-dark)}.ctx-btn-save:disabled{background:var(--color-text-muted);cursor:not-allowed;opacity:.7}.senha-form{display:flex;flex-direction:column;padding:var(--space-md);gap:var(--space-md)}.senha-error-msg{background:#dc35451a;color:var(--color-danger, #dc3545);padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;font-weight:500}.senha-success-msg{background:#28a7451a;color:var(--color-success, #28a745);padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;font-weight:500}.app{display:flex;flex-direction:column;min-height:100vh;position:relative;background:var(--color-bg)}.app-content{flex:1;padding:var(--space-lg) var(--space-xl);padding-bottom:calc(var(--bottom-nav-height) + var(--space-xl));overflow-y:auto}:root{--color-primary: #1B2A4A;--color-primary-light: #2D4373;--color-primary-dark: #0F1B33;--color-accent: #1E3A6E;--color-accent-light: #3B5DA7;--color-blue-soft: #E8EEF7;--color-blue-muted: #C5D3EA;--color-white: #FFFFFF;--color-bg: #F4F6FB;--color-bg-card: #FFFFFF;--color-text-primary: #1B2A4A;--color-text-secondary: #7A8BA8;--color-text-muted: #A3B1C6;--color-progress-bg: #E8EEF7;--color-progress-fill: #1E3A6E;--color-shadow: rgba(27, 42, 74, .08);--color-shadow-strong: rgba(27, 42, 74, .15);--color-danger: #E74C3C;--color-success: #27AE60;--color-warning: #F39C12;--color-orange-soft: #FDF0E6;--color-orange: #E8842C;--color-green-soft: #E6F7EE;--color-green: #27AE60;--color-purple-soft: #F0E6F7;--color-purple: #8E44AD;--color-blue-tag: #E8EEF7;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .625rem;--font-size-sm: .75rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 1.75rem;--font-size-3xl: 2rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 2.5rem;--space-3xl: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 8px var(--color-shadow);--shadow-md: 0 4px 16px var(--color-shadow);--shadow-lg: 0 8px 32px var(--color-shadow-strong);--shadow-card: 0 2px 12px rgba(27, 42, 74, .06);--shadow-card-hover: 0 8px 24px rgba(27, 42, 74, .12);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--max-width: 430px;--bottom-nav-height: 72px}*,*:before,*:after{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-family);background-color:#e8eef7;color:var(--color-text-primary);line-height:1.5;display:flex;justify-content:center;min-height:100vh}#root{width:100%;max-width:var(--max-width);min-height:100vh;position:relative;background-color:var(--color-bg);box-shadow:0 0 60px #1b2a4a1a}img{max-width:100%;display:block}a{text-decoration:none;color:inherit}button{border:none;background:none;cursor:pointer;font-family:inherit}ul,ol{list-style:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--color-blue-muted);border-radius:var(--radius-full)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes progressFill{0%{width:0}}.animate-fade-in-up{animation:fadeInUp .5s var(--transition-slow) both}.animate-fade-in{animation:fadeIn .4s ease both}.animate-slide-in-right{animation:slideInRight .5s var(--transition-slow) both}.animate-scale-in{animation:scaleIn .4s var(--transition-slow) both}
