.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.auth-card{background:#fff;padding:3rem;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:450px}.auth-logo{text-align:center;margin-bottom:1rem}.auth-logo img{height:64px;width:auto;object-fit:contain}.auth-card h1{color:#5b4d7a;font-size:1.5rem;margin-bottom:.5rem;text-align:center;letter-spacing:.02em}.auth-card h2{font-size:1.5rem;margin-bottom:2rem;text-align:center;color:var(--text-dark)}.auth-card .form-group{margin-bottom:1.25rem}.auth-card .form-group label{display:block;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.auth-card .form-group input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.auth-card .form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb26}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:.5rem;margin-bottom:1rem;text-align:center}.auth-link{text-align:center;margin-top:1.5rem;color:var(--text-light)}.auth-link a{color:var(--primary-color);text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.demo-credentials{margin-top:1.5rem;padding:1rem;background:#f0f9ff;border-radius:.5rem;font-size:.875rem;color:var(--text-light)}.demo-credentials p{margin:0}@media(max-width:480px){.auth-card{padding:2rem}}.dashboard{min-height:100vh;background:var(--bg-light)}.dashboard-header{background:var(--white);box-shadow:var(--shadow);padding:1.5rem 0;position:sticky;top:0;z-index:100}.dashboard-header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{font-size:1.5rem;color:var(--primary-color);margin:0}.user-info{display:flex;align-items:center;gap:1rem}.dashboard-content{max-width:1200px;margin:0 auto;padding:2rem}.dashboard-nav{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.dashboard-nav button{padding:.75rem 1.25rem;border:none;background:var(--white);color:var(--text-dark);border-radius:12px;cursor:pointer;font-weight:600;font-size:.9375rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.dashboard-nav button:hover{background:var(--primary-color);color:var(--white);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb40}.dashboard-nav button.active{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white);box-shadow:0 4px 12px #2563eb4d}.dashboard-main{background:var(--white);padding:2rem;border-radius:1rem;box-shadow:var(--shadow)}.dashboard-main h2{margin-bottom:1.5rem;color:var(--text-dark)}.dashboard-main h3{margin-top:2rem;margin-bottom:1rem;color:var(--text-dark)}.timesheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.month-summary{display:flex;gap:1rem}.summary-card{padding:1rem 1.5rem;border-radius:.5rem;box-shadow:var(--shadow);min-width:150px}.summary-approved{background:linear-gradient(135deg,var(--secondary-color) 0%,#059669 100%);color:var(--white)}.summary-pending{background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--white)}.summary-total{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white)}.summary-content{display:flex;flex-direction:column;gap:.25rem}.summary-label{font-size:.75rem;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:1.75rem;font-weight:700;line-height:1}.summary-sublabel{font-size:.75rem;opacity:.8}.current-month-summary{margin-top:2rem;padding:1.5rem;background:var(--bg-light);border-radius:.5rem}.current-month-summary h3{margin-top:0;margin-bottom:1rem}.month-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.user-month-stat{background:var(--white);padding:1rem;border-radius:.5rem;border:2px solid #e5e7eb;display:flex;flex-direction:column;gap:.5rem}.user-month-name{font-weight:600;color:var(--text-dark);font-size:.875rem}.user-month-days{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:1.5rem}.stat-card{background:var(--bg-light);padding:1.5rem;border-radius:.5rem;text-align:center}.stat-card h3{font-size:.875rem;color:var(--text-light);margin:0 0 .5rem}.stat-number{font-size:2rem;font-weight:700;color:var(--primary-color);margin:0}.data-table{width:100%;border-collapse:collapse;margin-top:1rem}.data-table th,.data-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e5e7eb}.data-table th{background:var(--bg-light);font-weight:600;color:var(--text-dark)}.data-table tr:hover{background:var(--bg-light)}.badge{padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500}.badge-pending{background:#fef3c7;color:#92400e}.badge-approved{background:#d1fae5;color:#065f46}.badge-rejected{background:#fee2e2;color:#991b1b}.badge-admin{background:#dbeafe;color:#1e40af}.badge-collaborateur{background:#e0e7ff;color:var(--primary-dark)}.badge-prestataire{background:#fce7f3;color:#831843}.form-card{background:var(--bg-light);padding:1.5rem;border-radius:.5rem;margin-bottom:2rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-dark)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-color)}.file-link-small{color:var(--primary-color);text-decoration:none;margin-right:.5rem;font-size:1rem;display:inline-block}.file-link-small:hover{transform:scale(1.2)}.form-control{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;margin-bottom:1rem}.upload-section{background:var(--bg-light);padding:1.5rem;border-radius:.5rem;margin-bottom:2rem}.upload-section h3{margin-top:0}.certifications-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.cert-card{background:var(--bg-light);padding:1.5rem;border-radius:.5rem;border:2px solid #e5e7eb}.cert-card h3{margin-top:0;color:var(--primary-color)}.cert-card p{color:var(--text-light);margin:.5rem 0}.loading{text-align:center;padding:2rem;color:var(--text-light)}.collab-dashboard{display:flex;min-height:100vh;background:#f1f5f9}.collab-sidebar{width:260px;min-width:260px;background:#fff;box-shadow:4px 0 24px #0000000a;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.collab-sidebar-logo{padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:.6rem}.collab-sidebar-logo img{height:38px;width:auto;object-fit:contain}.collab-sidebar-logo span{font-size:1.05rem;font-weight:700;color:var(--primary-color);letter-spacing:.02em}.collab-sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:4px}.collab-nav-item{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;border:none;background:transparent;color:#64748b;font-size:.9375rem;font-weight:500;cursor:pointer;text-align:left;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);border-left:3px solid transparent}.collab-nav-item:hover{background:#f8fafc;color:#334155}.collab-nav-item.active{background:var(--primary-light);color:var(--primary-color);border-left-color:var(--primary-color);font-weight:600}.collab-nav-icon{font-size:1.2rem;width:1.5rem;text-align:center;opacity:.9}.collab-nav-item.active .collab-nav-icon{opacity:1}.collab-nav-label{flex:1}.collab-sidebar-footer{padding:1rem 1rem 1.25rem;border-top:1px solid #e2e8f0}.collab-nav-icon-btn{width:100%;max-width:44px;height:44px;border:none;background:#f1f5f9;border-radius:12px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000a}.collab-nav-icon-btn:hover{background:#e2e8f0;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.collab-main-wrap{flex:1;display:flex;flex-direction:column;min-width:0}.collab-header{background:#fff;padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px #0000000d}.collab-header-merite .collab-header-left{display:flex;align-items:center;gap:1.5rem;flex:1;max-width:480px}.collab-header-merite .collab-brand{font-size:1.125rem;font-weight:700;color:#1e293b;letter-spacing:.02em}.collab-search-wrap{flex:1;position:relative;display:flex;align-items:center}.collab-search-icon{position:absolute;left:.75rem;font-size:.9rem;opacity:.6;pointer-events:none}.collab-search-input{width:100%;padding:.5rem .75rem .5rem 2.25rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#f8fafc;transition:border-color .2s}.collab-search-input:focus{outline:none;border-color:var(--primary-color);background:#fff}.collab-notif-btn{position:relative;padding:.5rem;border:none;background:transparent;cursor:pointer;border-radius:8px;transition:background .2s}.collab-notif-btn:hover{background:#f1f5f9}.collab-notif-icon{font-size:1.2rem}.collab-notif-dot{position:absolute;top:.35rem;right:.35rem;width:8px;height:8px;border-radius:50%;background:#ef4444}.collab-logout-btn{width:100%;justify-content:flex-start;color:#64748b}.collab-logout-btn:hover{background:#fef2f2;color:#dc2626}.collab-breadcrumb{font-size:.875rem;color:#64748b;font-weight:500}.collab-breadcrumb strong{color:#1e293b;font-weight:600}.collab-header-right{display:flex;align-items:center;gap:1rem}.collab-user-name{font-size:.9375rem;font-weight:600;color:#1e293b}.collab-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-color) 100%);color:#fff;font-size:.8rem;font-weight:600;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #4338ca40;transition:transform .2s}.collab-user-avatar:hover{transform:scale(1.05)}.collab-status-dot{width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #fff,0 0 0 3px #22c55e}.collab-main{flex:1;padding:1.75rem;overflow:auto}.collab-dashboard-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.collab-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0;transition:box-shadow .2s,transform .2s}.collab-card:hover{box-shadow:0 8px 24px #00000014}.collab-card-title{font-size:.9375rem;font-weight:600;color:#475569;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.collab-card-heures{display:flex;flex-direction:column;gap:.25rem}.collab-heures-value{font-size:1.75rem;font-weight:700;color:#1e293b}.collab-heures-label{font-size:.875rem;color:#64748b}.collab-progress-wrap{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-top:.75rem}.collab-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,var(--primary-color) 100%);border-radius:4px;transition:width .4s ease}.collab-progress-pct{font-size:.8125rem;color:#64748b;margin-top:.35rem;display:inline-block}.collab-mission-badge{width:40px;height:40px;border-radius:50%;background:#dcfce7;color:#166534;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}.collab-mission-client,.collab-mission-date{font-size:.875rem;color:#475569;margin:0 0 .25rem}.collab-mission-empty{font-size:.875rem;color:#94a3b8;margin:0}.collab-status-pill{display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;margin-top:.5rem}.collab-status-pill.green{background:#dcfce7;color:#166534}.collab-cra-pending{display:flex;flex-direction:column;gap:.5rem}.collab-cra-hours{font-size:1.5rem;font-weight:700;color:#1e293b}.collab-cra-desc{font-size:.875rem;color:#64748b;margin:0}.collab-conges-line{font-size:.9375rem;color:#334155;margin:0 0 .35rem}.collab-link{background:none;border:none;color:var(--primary-color);font-size:.875rem;font-weight:600;cursor:pointer;padding:.35rem 0;margin-bottom:.5rem;transition:all .2s cubic-bezier(.4,0,.2,1);border-radius:8px}.collab-link:hover{color:var(--primary-dark);text-decoration:underline}.collab-activity-list{list-style:none;padding:0;margin:0;font-size:.875rem;color:#475569}.collab-activity-list li{padding:.35rem 0;border-bottom:1px solid #f1f5f9}.collab-activity-list li:last-child{border-bottom:none}.collab-activity-empty{color:#94a3b8}.collab-toast{position:fixed;bottom:1.5rem;right:1.5rem;padding:.875rem 1.25rem;border-radius:12px;box-shadow:0 10px 40px #00000026;display:flex;align-items:center;gap:.75rem;font-size:.9375rem;font-weight:500;z-index:9999;animation:collab-toast-in .3s ease}@keyframes collab-toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.collab-toast-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.collab-toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.collab-toast-icon{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700}.collab-toast-success .collab-toast-icon{background:#10b981;color:#fff}.collab-toast-error .collab-toast-icon{background:#ef4444;color:#fff}.collab-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:var(--primary-color);border-radius:50%;animation:collab-spin .8s linear infinite}.collab-spinner-sm{width:24px;height:24px;border-width:2px}@keyframes collab-spin{to{transform:rotate(360deg)}}.collab-loading-block{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem;color:#64748b;font-size:.9375rem}.collab-loading-block p,.collab-loading-inline span{margin:0}.collab-loading-inline{display:flex;align-items:center;gap:.75rem;padding:1rem 0;color:#64748b;font-size:.9375rem}.collab-empty-state{text-align:center;padding:2rem 1.5rem;background:#f8fafc;border-radius:12px;border:1px dashed #e2e8f0}.collab-empty-state-large{padding:3rem 2rem;margin-top:.5rem}.collab-empty-icon{font-size:2.5rem;display:block;margin-bottom:.75rem;opacity:.7}.collab-empty-state-large .collab-empty-icon{font-size:3rem;margin-bottom:1rem}.collab-empty-title{font-size:1rem;font-weight:600;color:#334155;margin:0 0 .35rem}.collab-empty-desc{font-size:.875rem;color:#64748b;margin:0}.collab-main .data-table{border-radius:10px;overflow:hidden;border:1px solid #e2e8f0}.collab-main .data-table th{background:#f8fafc;font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em;color:#475569}.collab-main .data-table td{font-size:.9375rem}.collab-placeholder{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0;text-align:center}.collab-placeholder-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.collab-placeholder h2{margin:0 0 .5rem;color:#1e293b;font-size:1.25rem}.collab-placeholder p{color:#64748b;margin:0;font-size:.9375rem}.profile-page-merite{max-width:1200px}.profile-page-merite .profile-page-title{font-size:1.35rem;color:#1e293b;margin:0 0 1.5rem;display:flex;align-items:center;gap:.5rem}.profile-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.profile-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0}.profile-card-title{font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #f1f5f9}.profile-field{margin-bottom:1rem}.profile-field label,.profile-card .form-group label{display:block;font-size:.8125rem;color:#64748b;margin-bottom:.35rem}.profile-value{font-size:.9375rem;font-weight:500;color:#1e293b}.profile-card .form-group{margin-bottom:1rem}.profile-card .form-group input,.profile-card .form-group select{width:100%;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9375rem}.profile-skills-wrap{margin-bottom:1rem}.profile-skills-wrap>label{display:block;font-size:.8125rem;color:#64748b;margin-bottom:.5rem}.profile-chips{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.profile-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .6rem;background:var(--primary-light);color:var(--primary-color);border-radius:9999px;font-size:.8125rem;font-weight:500}.profile-chip-remove{padding:0;margin:0;border:none;background:none;color:var(--primary-color);cursor:pointer;font-size:1rem;line-height:1;opacity:.8}.profile-chip-remove:hover{opacity:1;color:var(--primary-dark)}.profile-chips-readonly .profile-chip{padding:.35rem .6rem}.profile-link-download{background:none;border:none;color:var(--primary-color);font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:underline;padding:0}.profile-link-download:hover{color:var(--primary-color)}.profile-coord-readonly .profile-coord-row .profile-value{flex:1;font-size:.9375rem;color:#1e293b}.profile-chip-input{min-width:140px;padding:.35rem .5rem;border:1px dashed #c7d2fe;border-radius:8px;font-size:.8125rem;background:transparent}.profile-chip-input:focus{outline:none;border-color:var(--primary-color)}.profile-cv-line{display:flex;align-items:center;gap:.5rem;margin-top:1rem;margin-bottom:1rem;flex-wrap:wrap}.profile-cv-label{font-size:.875rem;color:#64748b}.profile-cv-file{font-size:.8125rem;max-width:180px}.profile-card-desc{font-size:.875rem;color:#64748b;margin:0 0 1rem;line-height:1.5}.btn-pdf-merite{padding:.6rem 1.25rem;font-weight:600}.btn-outline-merite{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--primary-color);background:transparent;color:var(--primary-color);border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s}.btn-outline-merite:hover{background:var(--primary-color);color:#fff}.profile-coord-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.profile-coord-row{display:flex;align-items:center;gap:.75rem}.profile-coord-icon{font-size:1rem;width:1.5rem;text-align:center;opacity:.8}.profile-coord-label{font-size:.8125rem;color:#64748b;min-width:60px}.profile-coord-row input{flex:1;padding:.4rem .6rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem}.profile-no-obtention{text-align:center;padding:2rem 1rem;color:#64748b}.profile-no-obtention-icon{font-size:2.5rem;display:block;margin-bottom:.75rem;opacity:.6}.profile-no-obtention p{margin:0 0 .25rem;font-size:.9375rem}.profile-no-obtention-desc{font-size:.8125rem;opacity:.9}.profile-card-missions .data-table-compact{font-size:.8125rem}.profile-card-missions .data-table-compact th,.profile-card-missions .data-table-compact td{padding:.5rem .4rem}@media(max-width:900px){.profile-cards-grid{grid-template-columns:1fr}}.collab-main .dashboard-main{margin:0;max-width:none}.collab-main .calendar-section,.collab-main .documents-section,.collab-main .profile-section{background:#fff;border-radius:16px;padding:1.75rem;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0}.collab-main .documents-section h2,.collab-main .profile-section h2{font-size:1.35rem;color:#1e293b;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--primary-light)}.collab-main .documents-section h3,.collab-main .profile-section h3{font-size:1.05rem;color:#334155;margin:1.5rem 0 1rem}.collab-main .form-card{border-radius:12px;border:1px solid #e2e8f0}.collab-main .form-group input,.collab-main .form-group textarea,.collab-main .form-group select{border-radius:8px;transition:border-color .2s,box-shadow .2s}.collab-main .form-group input:focus,.collab-main .form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #4338ca26}.collab-success-msg{background:#ecfdf5;color:#065f46;padding:.75rem 1rem;border-radius:10px;font-size:.875rem;font-weight:500;margin-bottom:1rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.collab-dashboard{flex-direction:column}.collab-sidebar{width:100%;height:auto;flex-direction:row;flex-wrap:wrap;padding:.5rem}.collab-sidebar-nav{flex-direction:row;flex-wrap:wrap;padding:.5rem}.collab-nav-item{padding:.5rem .75rem;font-size:.875rem}.collab-dashboard-cards{grid-template-columns:1fr}}.expense-notes-section .expense-filters{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:1.5rem}.expense-notes-section .expense-filters select{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem}.expense-actions-top{margin-bottom:1rem}.expense-form-card{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;margin-bottom:1.5rem}.expense-form-card h3{margin:0 0 1rem;font-size:1.1rem;color:#1e293b}.expense-lines-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-weight:500;color:#475569}.expense-line-block{margin-bottom:1rem;padding:.75rem;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.expense-line-row{display:grid;grid-template-columns:120px 120px 100px 80px 90px 1fr 40px;gap:.5rem;align-items:center}.expense-line-row input,.expense-line-row select{padding:.4rem .5rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem}.expense-line-desc{min-width:0}.expense-line-justificatifs{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #e2e8f0;font-size:.8125rem}.expense-justif-label{color:#64748b;margin-right:.25rem}.expense-justif-input{font-size:.75rem;max-width:200px}.expense-form-total{margin:1rem 0;font-size:1rem}.expense-form-actions{display:flex;gap:.75rem;margin-top:1rem}.expense-notes-table{margin-top:.5rem}.badge-expense-draft{background:#f1f5f9;color:#475569}.badge-expense-submitted{background:#dbeafe;color:#1e40af}.badge-expense-in_validation{background:#fef3c7;color:#92400e}.badge-expense-rejected{background:#fee2e2;color:#991b1b}.badge-expense-reimbursed{background:#d1fae5;color:#065f46}.expense-detail-card{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;margin-top:1.5rem}.expense-detail-card h3{margin:0 0 1rem;font-size:1.05rem;color:#1e293b}.expense-detail-card .data-table{margin:1rem 0}@media(max-width:900px){.expense-line-row{grid-template-columns:1fr 1fr 80px}.expense-line-row .expense-line-desc{grid-column:1 / -1}}@media(max-width:768px){.dashboard-content,.dashboard-main{padding:1rem}.data-table{font-size:.875rem}.data-table th,.data-table td{padding:.5rem}}.month-calendar{background:var(--white);border-radius:.5rem;padding:1.5rem;box-shadow:var(--shadow)}.month-calendar.month-readonly .calendar-day:not(.weekend-disabled){cursor:not-allowed;opacity:.85}.calendar-day.has-timesheet.approved{cursor:not-allowed}.calendar-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.calendar-month-year{flex:1;text-align:center;font-size:1.5rem;font-weight:600;color:var(--text-dark);margin:0}.btn-nav-month{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white);border:none;width:44px;height:44px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #2563eb4d}.btn-nav-month:hover{transform:scale(1.08);box-shadow:0 4px 16px #2563eb66}.btn-current-month{padding:.6rem 1.25rem;background:var(--white);border:2px solid var(--primary-color);color:var(--primary-color);border-radius:12px;cursor:pointer;font-weight:600;font-size:.9375rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.btn-current-month:hover{background:var(--primary-color);color:var(--white);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb40}.calendar-readonly-hint{font-size:.875rem;color:var(--text-light);background:#fef3c7;padding:.5rem 1rem;border-radius:8px;margin-bottom:1rem;text-align:center}.calendar-actions{display:flex;gap:.5rem;margin-bottom:1.5rem;justify-content:center;flex-wrap:wrap}.btn-action{padding:.6rem 1.25rem;border-radius:12px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:none;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 2px 6px #00000014}.btn-action:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 14px #0000001f}.btn-action:active:not(:disabled){transform:translateY(0)}.btn-action:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-action.loading{pointer-events:none}.btn-full-month{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white)}.btn-full-month:hover:not(:disabled){box-shadow:0 6px 20px #2563eb59}.btn-reset{background:linear-gradient(135deg,#64748b,#475569);color:var(--white)}.btn-reset:hover:not(:disabled){box-shadow:0 4px 14px #47556959}.btn-submit{background:linear-gradient(135deg,var(--secondary-color) 0%,#059669 100%);color:var(--white)}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #10b98166}.btn-icon{font-size:1rem;line-height:1;opacity:.9}.btn-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-text{font-size:.8125rem;line-height:1.2;font-weight:500}.btn-subtext{font-size:.6875rem;opacity:.85;font-weight:400;margin-left:.125rem}.calendar-preview{background:var(--white);padding:0;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;min-width:450px;max-width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.preview-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white);padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}.preview-header h3{margin:0;color:var(--white);font-size:1.5rem}.preview-close-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:var(--white);width:36px;height:36px;border-radius:50%;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);line-height:1}.preview-close-btn:hover{background:#ffffff59;transform:scale(1.08);box-shadow:0 2px 8px #0003}.calendar-preview .preview-content{padding:2rem;overflow-y:auto;flex:1}.preview-content{display:flex;flex-direction:column;gap:1rem}.preview-row{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem 1.25rem;background:var(--bg-light);border-radius:.5rem;gap:1rem;margin-bottom:.75rem;transition:all .3s ease;border:2px solid transparent}.preview-row:hover{border-color:var(--primary-color);background:#f0f9ff}.preview-row.highlight{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:var(--primary-color)}.preview-row.description-row{flex-direction:column;align-items:flex-start}.preview-row.file-row{background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.preview-row strong{color:var(--text-dark);min-width:140px;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.preview-row span{color:var(--text-light);text-align:right;flex:1;word-break:break-word}.preview-value{font-weight:600;color:var(--primary-color);font-size:1.1rem}.preview-description{text-align:left;color:var(--text-dark);line-height:1.6;margin-top:.5rem}.no-file{color:#9ca3af;font-style:italic}.file-link{color:var(--primary-color);text-decoration:none;display:inline-flex;align-items:center;gap:.75rem;font-weight:600;padding:.5rem 1rem;background:var(--white);border-radius:.5rem;border:2px solid var(--primary-color);transition:all .3s ease}.file-link:hover{background:var(--primary-color);color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow)}.file-icon{font-size:1.25rem}.file-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-download{font-size:1rem;opacity:.7}.file-link:hover .file-download{opacity:1;animation:bounce .5s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1.5rem}.calendar-header{display:contents}.calendar-day-name{text-align:center;font-weight:600;color:var(--text-light);padding:.5rem;font-size:.875rem}.calendar-day{aspect-ratio:1;border:2px solid #e5e7eb;border-radius:.5rem;padding:.5rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;justify-content:space-between;background:var(--white);position:relative}.calendar-day:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow)}.calendar-day.empty{border:none;cursor:default;background:transparent}.calendar-day.today{border-color:var(--primary-color);background:#eff6ff;font-weight:700}.calendar-day.weekend{background:#f9fafb}.calendar-day.weekend-disabled{cursor:not-allowed;opacity:.5}.calendar-day.weekend-disabled:hover{transform:none;border-color:#e5e7eb;box-shadow:none}.calendar-day.past{opacity:.6}.calendar-day.has-timesheet{border-width:3px}.calendar-day.has-timesheet.approved{border-color:var(--secondary-color);background:#d1fae5}.calendar-day.has-timesheet.pending{border-color:#f59e0b;background:#fef3c7}.calendar-day.has-timesheet.rejected{border-color:#ef4444;background:#fee2e2}.day-number{font-weight:600;font-size:1rem;color:var(--text-dark)}.day-timesheet{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-top:auto}.timesheet-days{font-size:.875rem;font-weight:700;color:var(--text-dark)}.timesheet-status{font-size:1rem}.timesheet-status.approved{color:var(--secondary-color)}.timesheet-status.pending{color:#f59e0b}.timesheet-status.rejected{color:#ef4444}.calendar-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.calendar-form{background:var(--white);padding:2rem;border-radius:1rem;box-shadow:var(--shadow-lg);min-width:400px;max-width:90%}.calendar-form h3{margin-top:0;margin-bottom:1.5rem;color:var(--text-dark)}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.form-actions .btn{flex:1}.calendar-legend{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;padding-top:1rem;border-top:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-light)}.legend-color{width:20px;height:20px;border-radius:.25rem;border:2px solid #e5e7eb}.legend-color.today{border-color:var(--primary-color);background:#eff6ff}.legend-color.has-timesheet.approved{border-color:var(--secondary-color);background:#d1fae5}.legend-color.has-timesheet.pending{border-color:#f59e0b;background:#fef3c7}.legend-color.has-timesheet.rejected{border-color:#ef4444;background:#fee2e2}@media(max-width:768px){.calendar-day{padding:.25rem;font-size:.75rem}.day-number{font-size:.875rem}.timesheet-days{font-size:.75rem}.calendar-form{min-width:auto;width:90%;padding:1.5rem}}.file-upload-container{width:100%}.file-upload-dropzone{border:2px dashed #d1d5db;border-radius:.75rem;padding:2.5rem 1.5rem;text-align:center;background:#f9fafb;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.file-upload-dropzone:hover:not(.disabled){border-color:#3b82f6;background:#eff6ff}.file-upload-dropzone.drag-active{border-color:#3b82f6;background:#dbeafe;transform:scale(1.02)}.file-upload-dropzone.disabled{opacity:.6;cursor:not-allowed;background:#f3f4f6}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.dropzone-icon{font-size:3rem;margin-bottom:.5rem}.dropzone-text{display:flex;flex-direction:column;gap:.25rem}.dropzone-text strong{font-size:1.125rem;color:#1f2937;font-weight:600}.dropzone-text span{font-size:.875rem;color:#6b7280}.dropzone-info{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem;font-size:.75rem;color:#9ca3af}.dropzone-counter{display:flex;gap:.75rem;margin-top:.5rem;font-size:.875rem;padding:.5rem 1rem;background:#e0e7ff;border-radius:.5rem}.counter-current{color:#4f46e5;font-weight:600}.counter-remaining{color:#6366f1}.file-upload-error{margin-top:1rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;display:flex;align-items:center;gap:.5rem;font-size:.875rem}.error-icon{font-size:1.125rem}.file-list{margin-top:1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden}.file-list-header{padding:.75rem 1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.875rem;color:#374151}.btn-clear-all{background:transparent;border:1px solid #fecaca;color:#dc2626;cursor:pointer;font-size:.875rem;font-weight:600;padding:.4rem .75rem;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-clear-all:hover{background:#fee2e2;transform:translateY(-1px);box-shadow:0 2px 8px #ef444433}.file-items{display:flex;flex-direction:column}.file-item{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid #f3f4f6;transition:background .2s}.file-item:last-child{border-bottom:none}.file-item:hover{background:#f9fafb}.file-icon{font-size:1.5rem;flex-shrink:0}.file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.file-name{font-weight:500;color:#1f2937;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280}.file-error{color:#dc2626;font-weight:500}.btn-remove-file{background:#fee2e2;border:none;color:#dc2626;width:2.25rem;height:2.25rem;border-radius:50%;cursor:pointer;font-size:1.125rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;box-shadow:0 1px 3px #ef444433}.btn-remove-file:hover{background:#fecaca;transform:scale(1.08);box-shadow:0 2px 8px #ef44444d}@media(max-width:640px){.file-upload-dropzone{padding:1.5rem 1rem}.dropzone-icon{font-size:2rem}.dropzone-text strong{font-size:1rem}.dropzone-info{font-size:.7rem}.dropzone-counter{flex-direction:column;gap:.25rem}}.header{position:fixed;top:0;left:0;right:0;background:var(--white);box-shadow:var(--shadow);z-index:1000;padding:1rem 0}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.header-content{display:flex;justify-content:space-between;align-items:center}.logo-link{text-decoration:none;display:flex;align-items:center;gap:.5rem}.logo-img{height:42px;width:auto;display:block;object-fit:contain}.logo-text{font-size:1.35rem;font-weight:700;color:#5b4d7a;letter-spacing:-.5px}.nav{display:flex;gap:2rem;align-items:center}.nav a{text-decoration:none;color:var(--text-dark);font-weight:500;transition:color .3s ease;position:relative}.nav a:hover{color:var(--primary-color)}.nav a:after{content:"";position:absolute;bottom:-5px;left:0;width:0;height:2px;background:var(--primary-color);transition:width .3s ease}.nav a:hover:after{width:100%}.auth-buttons{display:flex;gap:1rem;align-items:center;margin-left:1rem}.btn-nav{padding:.6rem 1.25rem;border-radius:12px;text-decoration:none;font-weight:600;font-size:.9375rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center}.btn-login{color:var(--primary-color);border:2px solid var(--primary-color);background:transparent;box-shadow:none}.btn-login:hover{background:var(--primary-color);color:var(--white);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb40}.btn-register{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white);border:2px solid transparent}.btn-register:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59}.menu-toggle{display:none;flex-direction:column;gap:5px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;padding:.6rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.menu-toggle:hover{background:#f1f5f9;box-shadow:0 2px 8px #00000014}.menu-toggle span{width:22px;height:2.5px;background:var(--text-dark);transition:all .2s ease;border-radius:2px}@media(max-width:768px){.menu-toggle{display:flex}.nav{position:absolute;top:100%;left:0;right:0;background:var(--white);flex-direction:column;padding:2rem;box-shadow:var(--shadow-lg);transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .3s ease}.nav-open{transform:translateY(0);opacity:1;visibility:visible}.nav a{padding:.5rem 0;width:100%;text-align:center}.auth-buttons{margin-left:0;margin-top:1rem;width:100%;flex-direction:column;gap:.5rem}.btn-nav{width:100%;text-align:center;padding:.75rem}}.hero{min-height:100vh;display:flex;align-items:center;padding-top:80px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.hero-content{animation:fadeInUp .8s ease}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem;color:var(--text-dark)}.highlight{color:var(--primary-color)}.hero-subtitle{font-size:1.25rem;color:var(--text-light);margin-bottom:2rem;line-height:1.8}.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap}.hero .btn{padding:.875rem 2rem;font-size:1rem}.hero-image{display:flex;justify-content:center;align-items:center;animation:fadeIn 1s ease}.hero-graphic{position:relative;width:400px;height:400px}.graphic-circle{position:absolute;border-radius:50%;animation:float 6s ease-in-out infinite}.graphic-circle:nth-child(1){width:200px;height:200px;background:var(--primary-color);opacity:.2;top:0;left:0;animation-delay:0s}.graphic-circle:nth-child(2){width:150px;height:150px;background:var(--secondary-color);opacity:.3;top:100px;right:0;animation-delay:2s}.graphic-circle:nth-child(3){width:100px;height:100px;background:var(--primary-color);opacity:.4;bottom:0;left:50%;transform:translate(-50%);animation-delay:4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@media(max-width:968px){.hero .container{grid-template-columns:1fr;text-align:center}.hero-title{font-size:2.5rem}.hero-buttons{justify-content:center}.hero-graphic{width:300px;height:300px}}@media(max-width:480px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}}.about{padding:6rem 0;background:var(--white)}.section-header{text-align:center;margin-bottom:4rem}.section-title{font-size:2.5rem;font-weight:700;color:var(--text-dark);margin-bottom:1rem}.section-subtitle{font-size:1.25rem;color:var(--text-light)}.about-content{max-width:900px;margin:0 auto}.about-text p{font-size:1.125rem;color:var(--text-light);margin-bottom:1.5rem;line-height:1.8}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem;padding-top:3rem;border-top:1px solid #e5e7eb}.stat-item{text-align:center}.stat-number{font-size:3rem;font-weight:700;color:var(--primary-color);margin-bottom:.5rem}.stat-label{font-size:1rem;color:var(--text-light);font-weight:500}@media(max-width:768px){.about{padding:4rem 0}.section-title{font-size:2rem}.stats{grid-template-columns:1fr;gap:2rem}}.services{padding:6rem 0;background:var(--bg-light)}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:3rem}.service-card{background:var(--white);padding:2.5rem;border-radius:1rem;box-shadow:var(--shadow);transition:all .3s ease;text-align:center}.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.service-icon{font-size:3rem;margin-bottom:1.5rem}.service-title{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem}.service-description{color:var(--text-light);line-height:1.6}@media(max-width:768px){.services{padding:4rem 0}.services-grid{grid-template-columns:1fr}}.contact{padding:6rem 0;background:var(--white)}.contact-content{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;margin-top:3rem}.contact-info{display:flex;flex-direction:column;gap:2rem}.info-item{display:flex;gap:1.5rem;align-items:flex-start}.info-icon{font-size:2rem;flex-shrink:0}.info-item h3{font-size:1.25rem;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.info-item p{color:var(--text-light)}.contact-form{background:var(--bg-light);padding:2.5rem;border-radius:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.form-group input,.form-group textarea{width:100%;padding:.875rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;font-family:inherit;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color)}@media(max-width:968px){.contact-content{grid-template-columns:1fr}}@media(max-width:768px){.contact{padding:4rem 0}}.footer{background:var(--text-dark);color:var(--white);padding:3rem 0 1rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}.footer-section h3,.footer-section h4{margin-bottom:1rem;color:var(--white)}.footer-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.footer-logo img{height:36px;width:auto;object-fit:contain}.footer-logo span{font-size:1.25rem;font-weight:700;color:#a78bfa;letter-spacing:.02em}.footer-section p{color:#9ca3af;line-height:1.6}.footer-section ul{list-style:none}.footer-section ul li{margin-bottom:.5rem}.footer-section ul li a{color:#9ca3af;text-decoration:none;transition:color .3s ease}.footer-section ul li a:hover{color:var(--white)}.social-links{display:flex;gap:1rem}.social-links a{font-size:1.5rem;text-decoration:none;transition:transform .3s ease}.social-links a:hover{transform:scale(1.2)}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid #374151;color:#9ca3af}@media(max-width:768px){.footer-content{grid-template-columns:1fr;text-align:center}.social-links{justify-content:center}}.public-home{min-height:100vh}.App{min-height:100vh;background:var(--white)}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #2563eb;--primary-dark: #1e40af;--primary-light: #dbeafe;--secondary-color: #10b981;--text-dark: #1f2937;--text-light: #6b7280;--bg-light: #f9fafb;--white: #ffffff;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-dark);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.btn,button.btn,a.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;line-height:1.25;border-radius:12px;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;font-family:inherit;box-shadow:0 1px 3px #00000014}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb59}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:var(--white)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.btn-secondary{background:var(--white);color:var(--text-dark);border:2px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.btn-success{background:linear-gradient(135deg,var(--secondary-color) 0%,#059669 100%);color:var(--white)}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:var(--white)}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ef444466}.btn-sm{padding:.5rem 1rem;font-size:.8125rem;border-radius:10px}.btn-full{width:100%}.btn:not(.btn-primary):not(.btn-secondary):not(.btn-success):not(.btn-danger){background:#f1f5f9;color:var(--text-dark);border:1px solid #e2e8f0}.btn:not(.btn-primary):not(.btn-secondary):not(.btn-success):not(.btn-danger):hover:not(:disabled){background:#e2e8f0;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 2px 8px #0000000f}
