:root{--color-primary:#7da7c7;--color-primary-dark:#6a93b2;--color-primary-light:#a5c0d6;--color-bg:#f5f7f9;--color-bg-secondary:#e9e4de;--color-card-bg:#fff;--color-text:#2f3a45;--color-text-secondary:#6b7280;--color-border:#e2e6ea;--color-border-subtle:#c6c8d1;--color-muted:#c6c8d1;--color-value-bg:#fff;--bg-secondary:var(--color-bg-secondary);--border-color:var(--color-border);--text-secondary:var(--color-text-secondary);--color-success:#a9c7b6;--color-success-light:#e6f1ec;--color-warning:#c9bfae;--color-warning-light:#f3eee7;--color-error:#b6a7b3;--color-error-light:#f2edf0;--color-info:#7da7c7;--color-info-light:#e7eef4;--color-danger:var(--color-error);--color-danger-light:var(--color-error-light);--color-success-bg:var(--color-success-light);--color-success-text:var(--color-success);--color-warning-bg:var(--color-warning-light);--color-warning-text:var(--color-warning);--color-error-bg:var(--color-error-light);--color-error-text:var(--color-error);--color-info-bg:var(--color-info-light);--color-info-border:var(--color-primary-light);--color-info-text:var(--color-primary);--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-size-sm:0.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;--border-radius:10px;--border-radius-lg:12px;--shadow-sm:0 1px 2px 0 #2f3a450f;--shadow-md:0 8px 20px -8px #2f3a452e;--shadow-lg:0 18px 50px -24px #2f3a4552}[data-theme=dark]{--color-bg:#1f252c;--color-bg-secondary:#2a323b;--color-card-bg:#222a33;--color-text:#e8edf1;--color-text-secondary:#b6c0c9;--color-border:#3a4350;--color-border-subtle:#4b5563;--color-muted:#626e7a;--color-value-bg:#2a323b;--color-primary-light:#9bbbd3;--color-success:#9cb7a8;--color-success-light:#2b3731;--color-warning:#b7ad9f;--color-warning-light:#332f2b;--color-error:#b19aa7;--color-error-light:#322c31;--color-info:#9bbbd3;--color-info-light:#26303a;--color-danger:var(--color-error);--color-danger-light:var(--color-error-light);--bg-secondary:var(--color-bg-secondary);--border-color:var(--color-border);--text-secondary:var(--color-text-secondary);--color-success-bg:var(--color-success-light);--color-success-text:var(--color-success);--color-warning-bg:var(--color-warning-light);--color-warning-text:var(--color-warning);--color-error-bg:var(--color-error-light);--color-error-text:var(--color-error);--color-info-bg:var(--color-info-light);--color-info-border:var(--color-primary-light);--color-info-text:var(--color-primary);--shadow-sm:0 1px 2px 0 #00000059;--shadow-md:0 10px 24px -12px #0009;--shadow-lg:0 20px 50px -28px #000000b3}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background-color:#e9e4de;background-color:var(--color-bg-secondary);border-color:#e2e6ea;border-color:var(--color-border);color:#2f3a45;color:var(--color-text)}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:#6b7280;color:var(--color-text-secondary)}[data-theme=dark] .btn-secondary{background-color:#e9e4de;background-color:var(--color-bg-secondary);border-color:#e2e6ea;border-color:var(--color-border);color:#2f3a45;color:var(--color-text)}[data-theme=dark] .btn-secondary:hover{background-color:#e2e6ea;background-color:var(--color-border)}[data-theme=dark] .btn-outline{border-color:#e2e6ea;border-color:var(--color-border);color:#2f3a45;color:var(--color-text)}[data-theme=dark] .btn-outline:hover,[data-theme=dark] .dashboard-card{background-color:#e9e4de;background-color:var(--color-bg-secondary)}[data-theme=dark] .dashboard-card{border-color:#e2e6ea;border-color:var(--color-border)}[data-theme=dark] .dashboard-card-header{background-color:#a5c0d6;background-color:var(--color-primary-light);border-bottom-color:#00000014}[data-theme=dark] .dashboard-card-header h3{color:#1f252c}[data-theme=dark] .modal-content{background-color:#f5f7f9;background-color:var(--color-bg);border-color:#e2e6ea;border-color:var(--color-border)}[data-theme=dark] .modal-overlay{background-color:#000000b3}[data-theme=dark] .sidebar,[data-theme=dark] .topbar{background-color:#fff;background-color:var(--color-card-bg);border-color:#e2e6ea;border-color:var(--color-border)}[data-theme=dark] .topbar-role-badge{background-color:#9bbbd333;color:#a5c0d6;color:var(--color-primary-light)}[data-theme=dark] .data-table th{background-color:#f5f7f9;background-color:var(--color-bg);color:#2f3a45;color:var(--color-text)}[data-theme=dark] .data-table td,[data-theme=dark] .data-table th{border-color:#e2e6ea;border-color:var(--color-border)}[data-theme=dark] .data-table tbody tr:hover{background-color:#ffffff08}[data-theme=dark] .form-hint{color:#6b7280;color:var(--color-text-secondary)}[data-theme=dark] .form-error{background-color:#ef444426;border-color:#ef44444d}[data-theme=dark] .status-badge{background-color:#ffffff1a}[data-theme=dark] .nav-link:hover{background-color:#ffffff0d}[data-theme=dark] .nav-link.active{background-color:#60a5fa26;color:#a5c0d6;color:var(--color-primary-light)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7f9;background-color:var(--color-bg);color:#2f3a45;color:var(--color-text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:1rem;font-size:var(--font-size-base);line-height:1.5}svg[stroke]{stroke-linecap:round;stroke-linejoin:round;stroke-width:1.5}a{color:#7da7c7;color:var(--color-primary);text-decoration:underline}a:hover{text-decoration:none}:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}[data-theme=dark] :focus-visible{outline-color:#a5c0d6;outline-color:var(--color-primary-light)}button{cursor:pointer;font-family:inherit}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.text-secondary{color:#6b7280;color:var(--color-text-secondary)}fieldset:disabled{opacity:.6;pointer-events:none}fieldset:disabled .btn,fieldset:disabled .form-input{cursor:not-allowed}.loading-screen{align-items:center;color:#6b7280;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md);justify-content:center;min-height:100vh}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #e2e6ea;border-top-color:#7da7c7;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:32px;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.loading-spinner-lg{border-width:4px;height:48px;width:48px}.loading-with-cancel{gap:16px;gap:var(--spacing-md);padding:24px;padding:var(--spacing-lg);text-align:center}.loading-spinner-container,.loading-with-cancel{align-items:center;display:flex;flex-direction:column}.loading-spinner-container{gap:8px;gap:var(--spacing-sm)}.loading-message{color:#6b7280;color:var(--color-text-secondary)}.loading-message,.loading-slow-warning{font-size:.875rem;font-size:var(--font-size-sm)}.loading-slow-warning{align-items:center;background-color:#eab3081a;border-radius:10px;border-radius:var(--border-radius);color:#c9bfae;color:var(--color-warning);display:flex;gap:4px;gap:var(--spacing-xs);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.loading-timeout-warning{background-color:#f2edf0;background-color:var(--color-error-light);color:#b6a7b3;color:var(--color-danger)}.loading-cancel-btn{margin-top:8px;margin-top:var(--spacing-sm)}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-overlay-content{align-items:center;background-color:#fff;background-color:var(--color-card-bg);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 18px 50px -24px #2f3a4552;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md);max-width:400px;padding:32px;padding:var(--spacing-xl);text-align:center}.loading-overlay-message{color:#2f3a45;color:var(--color-text);font-size:1.125rem;font-size:var(--font-size-lg);font-weight:500;margin:0}.loading-overlay-slow{color:#c9bfae;color:var(--color-warning);font-size:.875rem;font-size:var(--font-size-sm);margin:0}.loading-overlay-timeout{color:#b6a7b3;color:var(--color-danger)}.loading-overlay-cancel{margin-top:8px;margin-top:var(--spacing-sm)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.form-input,.form-label{color:#2f3a45;color:var(--color-text)}.form-input{background-color:#fff;background-color:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);font-family:inherit;font-size:1rem;font-size:var(--font-size-base);padding:10px 12px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.form-input:focus{border-color:#7da7c7;border-color:var(--color-primary);box-shadow:0 0 0 3px #7da7c740;outline:none}.form-input::placeholder{color:#6b7280;color:var(--color-text-secondary);opacity:.6}.form-group-error .form-label{color:#b6a7b3;color:var(--color-error)}.form-input-error{background-color:#f2edf0;background-color:var(--color-error-light)}.form-input-error,.form-input-error:focus{border-color:#b6a7b3!important;border-color:var(--color-error)!important}.form-input-error:focus{box-shadow:0 0 0 3px #b6a7b333!important}.form-error-message{color:#b6a7b3;color:var(--color-error);display:block;font-size:.875rem;font-size:var(--font-size-sm);font-weight:400;margin-top:4px}.form-group-error .form-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23b6a7b3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M12 8v4M12 16h.01'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:18px;padding-right:36px}.form-row{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:1fr 1fr}.btn{align-items:center;border:1px solid #0000;border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:inline-flex;font-family:inherit;font-size:1rem;font-size:var(--font-size-base);font-weight:500;gap:8px;gap:var(--spacing-sm);justify-content:center;padding:10px 20px;text-decoration:none;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.btn-spinner{animation:spin .8s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;flex-shrink:0;height:16px;width:16px}.btn-spinner-light{border-color:#fff #ffffff4d #ffffff4d;border-top-color:var(--color-card-bg)}.btn-loading{position:relative}.btn-primary{background-color:#7da7c7;background-color:var(--color-primary);border-color:#7da7c7;border-color:var(--color-primary);color:#fff;color:var(--color-card-bg)}.btn-primary:hover:not(:disabled){background-color:#6a93b2;background-color:var(--color-primary-dark);border-color:#6a93b2;border-color:var(--color-primary-dark);box-shadow:0 0 0 3px #a5c0d659}.btn-outline{background-color:initial;border-color:#e2e6ea;border-color:var(--color-border);color:#2f3a45;color:var(--color-text)}.btn-outline:hover:not(:disabled){background-color:#e9e4de;background-color:var(--color-bg-secondary);box-shadow:0 0 0 3px #a5c0d640}.btn-full{width:100%}.btn-sm{font-size:.875rem;font-size:var(--font-size-sm);padding:6px 12px}.btn-secondary{background-color:#f5f7f9;background-color:var(--color-bg);border-color:#e2e6ea;border-color:var(--color-border);color:#2f3a45;color:var(--color-text)}.btn-secondary:hover:not(:disabled){background-color:#e9e4de;background-color:var(--color-bg-secondary);box-shadow:0 0 0 3px #a5c0d633}.btn-danger{color:var(--color-card-bg)}.btn-danger:hover:not(:disabled){background-color:#b6a7b3;background-color:var(--color-error);border-color:#b6a7b3;border-color:var(--color-error);box-shadow:0 0 0 3px #a5c0d640}.btn-success{color:#fff;color:var(--color-card-bg)}.btn-success,.btn-success:hover:not(:disabled){background-color:#a9c7b6;background-color:var(--color-success);border-color:#a9c7b6;border-color:var(--color-success)}.btn-success:hover:not(:disabled){box-shadow:0 0 0 3px #a5c0d640}.form-error{background:#f2edf0;background:var(--color-error-light);border:1px solid #b6a7b3;border:1px solid var(--color-error);border-radius:10px;border-radius:var(--border-radius);color:#b6a7b3;color:var(--color-error);font-size:.875rem;font-size:var(--font-size-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.form-hint{color:#6b7280;color:var(--color-text-secondary);font-size:.8125rem}.form-group label{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.form-group input,.form-group select,.form-group textarea{background-color:#fff;background-color:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);color:#2f3a45;color:var(--color-text);font-family:inherit;font-size:1rem;font-size:var(--font-size-base);padding:10px 12px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#7da7c7;border-color:var(--color-primary);box-shadow:0 0 0 3px #7da7c740;outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:#6b7280;color:var(--color-text-secondary);opacity:.6}.auth-page{align-items:center;background:linear-gradient(180deg,#f5f7f9,#e9e4de);background:linear-gradient(180deg,var(--color-bg) 0,var(--color-bg-secondary) 100%);display:flex;justify-content:center;min-height:100vh;padding:24px;padding:var(--spacing-lg)}.auth-container{max-width:420px;width:100%}.auth-header{margin-bottom:32px;margin-bottom:var(--spacing-xl);text-align:center}.auth-logo{align-items:center;background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:9999px;box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);display:inline-flex;justify-content:center;margin-bottom:16px;margin-bottom:var(--spacing-md);padding:10px 14px}.auth-title{color:#2f3a45;color:var(--color-text);font-size:1.875rem;font-size:var(--font-size-3xl);font-weight:700;margin:0}.auth-subtitle{color:#6b7280;color:var(--color-text-secondary);font-size:1rem;font-size:var(--font-size-base);margin:4px 0 0}.auth-form{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 18px 50px -24px #2f3a4552;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md);padding:32px;padding:var(--spacing-xl)}.auth-form-title{color:#2f3a45;color:var(--color-text);font-size:1.125rem;font-size:var(--font-size-lg);font-weight:600;margin:0 0 8px;margin:0 0 var(--spacing-sm)}.auth-error{border:1px solid #b6a7b3;border:1px solid var(--color-error);border-radius:10px;border-radius:var(--border-radius);color:#b6a7b3;color:var(--color-error);font-size:.875rem;font-size:var(--font-size-sm);padding:10px 14px}.auth-error,[data-theme=dark] .auth-error{background-color:#f2edf0;background-color:var(--color-error-light)}[data-theme=dark] .auth-error{border-color:#b6a7b3;border-color:var(--color-error)}.auth-warning{border:1px solid #c9bfae;border:1px solid var(--color-warning);border-radius:10px;border-radius:var(--border-radius);font-size:.875rem;font-size:var(--font-size-sm);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:10px 14px}.auth-warning,[data-theme=dark] .auth-warning{background-color:#f3eee7;background-color:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}[data-theme=dark] .auth-warning{border-color:#c9bfae;border-color:var(--color-warning)}.auth-footer-text{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin:0;text-align:center}.auth-link{color:#7da7c7;color:var(--color-primary);font-weight:500}.auth-link:hover{text-decoration:underline}.skip-link:focus{clip:auto;background:#7da7c7;background:var(--color-primary);border-radius:10px;border-radius:var(--border-radius);color:#fff;color:var(--color-card-bg);font-weight:500;height:auto;left:8px;left:var(--spacing-sm);overflow:visible;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);position:fixed;top:8px;top:var(--spacing-sm);white-space:normal;width:auto;z-index:10000}.app-layout{background-color:#f5f7f9;background-color:var(--color-bg);display:flex;min-height:100vh}.app-main-area{display:flex;flex:1 1;flex-direction:column;margin-left:240px;min-width:0;transition:margin-left .2s ease}.app-content{flex:1 1;max-width:1400px;padding:32px;padding:var(--spacing-xl);width:100%}.sidebar{background-color:#fff;background-color:var(--color-card-bg);border-right:1px solid #e2e6ea;border-right:1px solid var(--color-border);bottom:0;box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;left:0;position:fixed;top:0;transition:transform .2s ease;width:240px;z-index:100}.sidebar-overlay{display:none}.sidebar-header{border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);justify-content:space-between;min-height:57px;padding:15px 24px;padding:15px var(--spacing-lg)}.sidebar-brand,.sidebar-header{align-items:center;display:flex}.sidebar-brand{gap:8px;gap:var(--spacing-sm)}.sidebar-brand-text{color:#2f3a45;color:var(--color-text);font-size:1.25rem;font-size:var(--font-size-xl);font-weight:700}.sidebar-close-btn{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);cursor:pointer;display:none;height:32px;justify-content:center;width:32px}.sidebar-close-btn:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);color:#2f3a45;color:var(--color-text)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:8px 0;padding:var(--spacing-sm) 0}.sidebar-nav-list{list-style:none;margin:0;padding:0}.sidebar-nav-link{align-items:center;border-left:3px solid #0000;color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;gap:12px;padding:12px 24px;padding:12px var(--spacing-lg);text-decoration:none;transition:background-color .15s ease,color .15s ease}.sidebar-nav-link:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);box-shadow:inset 0 0 0 1px #a5c0d659,0 0 0 3px #a5c0d633;color:#2f3a45;color:var(--color-text);text-decoration:none}.sidebar-nav-link:focus-visible{background-color:#e9e4de;background-color:var(--color-bg-secondary);outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:-2px}.sidebar-nav-link-active{background-color:#7da7c726;border-left-color:#7da7c7;border-left-color:var(--color-primary);color:#7da7c7;color:var(--color-primary)}.sidebar-nav-link-active:hover{background-color:#7da7c738;color:#7da7c7;color:var(--color-primary)}.sidebar-nav-icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.sidebar-nav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-footer{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg)}.sidebar-user-badge{align-items:center;display:flex}.sidebar-user-role{background-color:#7da7c72e;border-radius:9999px;color:#7da7c7;color:var(--color-primary);font-size:.75rem;font-weight:500;padding:2px 10px;text-transform:capitalize}.topbar{background-color:#fff;background-color:var(--color-card-bg);border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);justify-content:space-between;min-height:57px;padding:10px 24px;padding:10px var(--spacing-lg)}.topbar,.topbar-left{align-items:center;display:flex}.topbar-left{gap:16px;gap:var(--spacing-md)}.topbar-agency{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.topbar-agency-logo{background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:6px;height:28px;object-fit:cover;width:28px}.topbar-menu-btn{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);color:#2f3a45;color:var(--color-text);cursor:pointer;display:none;height:36px;justify-content:center;width:36px}.topbar-menu-btn:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary)}.topbar-menu-btn:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.topbar-agency-name{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.topbar-right{align-items:center;display:flex;gap:16px;gap:var(--spacing-md)}.topbar-user-icon{align-items:center;background:#e9e4de;background:var(--color-bg-secondary);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:50%;display:inline-flex;flex-shrink:0;height:26px;justify-content:center;width:26px}.topbar-user-icon,.topbar-user-name{color:#2f3a45;color:var(--color-text)}.topbar-user-name{font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.topbar-role-badge{background-color:#7da7c72e;border-radius:9999px;color:#7da7c7;color:var(--color-primary);font-size:.75rem;font-weight:500;padding:2px 8px;text-transform:capitalize}.theme-toggle-btn{align-items:center;background:#0000;border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;padding:0;transition:all .2s ease;width:36px}.theme-toggle-btn:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);border-color:#6b7280;border-color:var(--color-text-secondary);color:#2f3a45;color:var(--color-text)}.theme-toggle-btn:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.theme-toggle-btn svg{height:18px;width:18px}.page-container{max-width:1200px}.page-header{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.page-title{color:#2f3a45;color:var(--color-text);font-size:1.5rem;font-size:var(--font-size-2xl);font-weight:700;margin:0 0 4px}.page-subtitle{color:#6b7280;color:var(--color-text-secondary);font-size:1rem;font-size:var(--font-size-base);margin:0}.page-empty-state{align-items:center;background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);display:flex;flex-direction:column;justify-content:center;padding:60px 32px;padding:60px var(--spacing-xl);text-align:center}.empty-state-icon{color:#6b7280;color:var(--color-text-secondary);margin-bottom:16px;margin-bottom:var(--spacing-md);opacity:.4}.empty-state-title{color:#2f3a45;color:var(--color-text);font-size:1.125rem;font-size:var(--font-size-lg);font-weight:600;margin:0 0 8px;margin:0 0 var(--spacing-sm)}.empty-state-description{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin:0;max-width:360px}.dashboard-page{background-color:#e9e4de;background-color:var(--color-bg-secondary);min-height:100vh}.dashboard-header{align-items:center;background-color:#f5f7f9;background-color:var(--color-bg);border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg)}.dashboard-header-left{gap:8px;gap:var(--spacing-sm)}.dashboard-header-left,.dashboard-logo{align-items:center;display:flex}.dashboard-brand{color:#2f3a45;color:var(--color-text);font-size:1.25rem;font-size:var(--font-size-xl);font-weight:700;margin:0}.dashboard-agency-name{border-left:1px solid #e2e6ea;border-left:1px solid var(--color-border);color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin-left:8px;margin-left:var(--spacing-sm);padding-left:8px;padding-left:var(--spacing-sm)}.dashboard-header-right{align-items:center;display:flex;gap:16px;gap:var(--spacing-md)}.dashboard-user-info{align-items:center;color:#2f3a45;color:var(--color-text);display:flex;font-size:.875rem;font-size:var(--font-size-sm);gap:8px;gap:var(--spacing-sm)}.dashboard-role-badge{background-color:#7da7c72e;border-radius:9999px;color:#7da7c7;color:var(--color-primary);display:inline-block;font-size:.75rem;font-weight:500;padding:2px 8px;text-transform:capitalize}.dashboard-main{margin:0 auto;max-width:1200px;padding:32px;padding:var(--spacing-xl)}.dashboard-welcome{margin-bottom:32px;margin-bottom:var(--spacing-xl)}.dashboard-welcome h2{font-size:1.5rem;font-size:var(--font-size-2xl);font-weight:600;margin:0 0 4px}.dashboard-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.dashboard-card{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);overflow:hidden}.dashboard-card-full{grid-column:1/-1}.dashboard-card-header{align-items:center;background-color:#7da7c7;background-color:var(--color-primary);border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);display:flex;padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg)}.dashboard-card-title-row{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.dashboard-card-header h3{color:#fff;color:var(--color-card-bg);font-size:1rem;font-size:var(--font-size-base);font-weight:600;margin:0}.dashboard-card-body{padding:24px;padding:var(--spacing-lg)}.dashboard-empty-state{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin:0;padding:16px 0;padding:var(--spacing-md) 0;text-align:center}@media (min-width:1024px){.sidebar{display:flex;transform:translateX(0)}.sidebar-close-btn,.topbar-menu-btn{display:none}.sidebar-overlay{display:none!important}}@media (max-width:1023px){.sidebar{transform:translateX(-100%);transition:transform .25s ease}.sidebar-open{box-shadow:4px 0 20px #00000026;transform:translateX(0)}.sidebar-overlay{background:#0006;bottom:0;display:block;left:0;position:fixed;right:0;top:0;z-index:99}.sidebar-close-btn,.topbar-menu-btn{display:flex}.app-main-area{margin-left:0}}@media (max-width:767px){.form-row,.form-row-3{grid-template-columns:1fr}.modal-overlay{padding:8px;padding:var(--spacing-sm)}.modal-content{margin:8px auto;margin:var(--spacing-sm) auto}.modal-body{max-height:70vh}.data-table-container{overflow-x:auto}.detail-card-header{flex-direction:column;text-align:center}.detail-grid{grid-template-columns:1fr}.toast-container{left:8px;left:var(--spacing-sm);max-width:none;right:8px;right:var(--spacing-sm)}.auth-page{padding:16px;padding:var(--spacing-md)}.auth-form{padding:24px;padding:var(--spacing-lg)}.app-content{padding:16px;padding:var(--spacing-md)}.page-container{max-width:100%}.page-title{font-size:1.25rem;font-size:var(--font-size-xl)}.topbar{padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.topbar-role-badge,.topbar-user-name{display:none}.topbar-agency-name{font-size:.75rem;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-header{flex-direction:column;gap:8px;gap:var(--spacing-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.dashboard-header-right{justify-content:space-between;width:100%}.dashboard-main{padding:16px;padding:var(--spacing-md)}.dashboard-grid{grid-template-columns:1fr}.empty-state-container,.page-empty-state{padding:40px 16px;padding:40px var(--spacing-md)}}@media (max-width:400px){.app-content{padding:8px;padding:var(--spacing-sm)}.page-container{max-width:100%}.page-title{font-size:1.125rem;font-size:var(--font-size-lg)}.page-subtitle{font-size:.8125rem}.auth-page{padding:8px;padding:var(--spacing-sm)}.auth-form{padding:16px;padding:var(--spacing-md)}.topbar{gap:4px;gap:var(--spacing-xs);padding:8px;padding:var(--spacing-sm)}.topbar-agency-name{max-width:80px}.btn-sm{font-size:.75rem;padding:4px 8px}.dashboard-card-header{padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.dashboard-card-body{padding:16px;padding:var(--spacing-md)}.empty-state-container,.page-empty-state{padding:32px 8px;padding:32px var(--spacing-sm)}}.toast-container{flex-direction:column;max-width:400px;position:fixed;right:24px;right:var(--spacing-lg);top:24px;top:var(--spacing-lg);z-index:10000}.toast,.toast-container{display:flex;gap:8px;gap:var(--spacing-sm)}.toast{align-items:center;animation:toastIn .3s ease;background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 8px 20px -8px #2f3a452e;box-shadow:var(--shadow-md);font-size:.875rem;font-size:var(--font-size-sm);padding:12px 16px}.toast-success{border-left:4px solid #a9c7b6;border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid #b6a7b3;border-left:4px solid var(--color-error)}.toast-info{border-left:4px solid #7da7c7;border-left:4px solid var(--color-info)}.toast-icon{flex-shrink:0;font-weight:700}.toast-success .toast-icon{color:#a9c7b6;color:var(--color-success)}.toast-error .toast-icon{color:#b6a7b3;color:var(--color-error)}.toast-info .toast-icon{color:#7da7c7;color:var(--color-info)}.toast-message{color:#2f3a45;color:var(--color-text);flex:1 1}.toast-close{background:none;border:none;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;font-size:18px;line-height:1;padding:0 4px}.toast-close:hover{color:#2f3a45;color:var(--color-text)}.toast-exit{animation:toastOut .3s ease forwards}@keyframes toastIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes toastOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.modal-overlay{align-items:flex-start;background:#2f3a4559;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:32px;padding:var(--spacing-xl);position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalIn .2s ease;background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 18px 50px -24px #2f3a4552;box-shadow:var(--shadow-lg);margin:48px auto;max-width:520px;width:100%}.modal-lg{max-width:680px}.modal-header{align-items:center;border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:32px;padding:var(--spacing-xl)}.modal-title{font-size:1.25rem;font-size:var(--font-size-xl);font-weight:600;margin:0}.modal-close-btn{background:none;border:none;border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);cursor:pointer;font-size:24px;line-height:1;padding:4px}.modal-close-btn:hover{background:#e9e4de;background:var(--color-bg-secondary);color:#2f3a45;color:var(--color-text)}.modal-close-btn:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.modal-body{display:flex;flex-direction:column;gap:24px;gap:var(--spacing-lg);max-height:70vh;overflow-y:auto;padding:32px;padding:var(--spacing-xl)}.modal-body .form-group{gap:10px;margin-bottom:16px;margin-bottom:var(--spacing-md)}.modal-body .form-row,.modal-body .form-row-3{gap:24px;gap:var(--spacing-lg)}.modal-body .checkbox-group{gap:8px;gap:var(--spacing-sm)}.modal-footer{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);display:flex;gap:16px;gap:var(--spacing-md);justify-content:flex-end;padding:24px 32px;padding:var(--spacing-lg) var(--spacing-xl)}@keyframes modalIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.form-row-3{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:1fr 1fr 1fr}.form-section-title{border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;letter-spacing:.05em;margin:8px 0 0;margin:var(--spacing-sm) 0 0;padding-bottom:4px;padding-bottom:var(--spacing-xs);text-transform:none}.form-textarea{font-family:inherit;min-height:80px;resize:vertical}.checkbox-group{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.checkbox-label{color:#2f3a45;color:var(--color-text)}.checkbox-label input[type=checkbox]{cursor:pointer}.chip-group{display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs)}.chip{align-items:center;background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:9999px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8125rem;font-weight:500;padding:4px 12px;transition:all .15s ease}.chip:hover{border-color:#a5c0d6;border-color:var(--color-primary-light)}.chip-active,.chip:hover{color:#7da7c7;color:var(--color-primary)}.chip-active{background:#7da7c72e;border-color:#7da7c7;border-color:var(--color-primary)}.chip-readonly{cursor:default}.data-table-container{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);overflow:hidden}.data-table{border-collapse:collapse;font-size:.875rem;font-size:var(--font-size-sm);width:100%}.data-table thead{background:#e9e4de;background:var(--color-bg-secondary);border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border)}.data-table th{color:#6b7280;color:var(--color-text-secondary);font-size:.8125rem;font-weight:600;letter-spacing:.03em;padding:10px 16px;text-align:left;text-transform:none;white-space:nowrap}.data-table td{border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);color:#2f3a45;color:var(--color-text);padding:12px 16px}.data-table tbody tr:last-child td{border-bottom:none}.data-table-row-clickable{cursor:pointer;transition:background-color .1s ease}.data-table-row-clickable:hover{background-color:#7da7c71f}.data-table-row-clickable:focus{background-color:#7da7c71f;outline:none}.data-table-row-clickable:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:-2px}.table-user-cell{gap:8px;gap:var(--spacing-sm)}.table-avatar,.table-user-cell{align-items:center;display:flex}.table-avatar{background:#1a56db14;border-radius:50%;color:#7da7c7;color:var(--color-primary);flex-shrink:0;font-size:.75rem;font-weight:600;height:32px;justify-content:center;text-transform:none;width:32px}.table-user-name{font-weight:500}.sortable-header{cursor:pointer;transition:background-color .1s ease;-webkit-user-select:none;user-select:none}.sortable-header:hover{background:#1a56db14;color:#7da7c7;color:var(--color-primary)}.sort-indicator{display:inline-block;font-size:.75rem;margin-left:4px;min-width:12px}.sort-inactive{opacity:.3}.sort-active{color:#7da7c7;color:var(--color-primary);font-weight:700}.detail-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.client-tab-content{padding:24px;padding:var(--spacing-lg);padding-top:16px;padding-top:var(--spacing-md)}.client-tab-content .detail-sections{padding:0}.client-detail-tabs,.trip-detail-header{padding:0 24px;padding:0 var(--spacing-lg)}.trip-detail-actions{padding-right:24px;padding-right:var(--spacing-lg)}.trip-tab-content{padding:24px;padding:var(--spacing-lg);padding-top:16px;padding-top:var(--spacing-md)}.trip-tab-content .detail-sections{padding:24px 0 0;padding:var(--spacing-lg) 0 0}.detail-card{background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);overflow:hidden}.detail-card-header{align-items:center;background:#e9e4de;background:var(--color-bg-secondary);border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);display:flex;gap:24px;gap:var(--spacing-lg);padding:32px;padding:var(--spacing-xl)}.detail-avatar{align-items:center;background:#7da7c72e;border-radius:50%;color:#7da7c7;color:var(--color-primary);display:flex;flex-shrink:0;height:56px;justify-content:center;text-transform:none;width:56px}.detail-avatar,.detail-name{font-size:1.25rem;font-weight:700}.detail-name{font-size:var(--font-size-xl);margin:0}.detail-meta{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin:2px 0 0}.detail-sections{padding:24px;padding:var(--spacing-lg)}.detail-section{border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding-bottom:24px;padding-bottom:var(--spacing-lg)}.detail-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-section-title{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;letter-spacing:.05em;margin:0 0 16px;margin:0 0 var(--spacing-md);text-transform:none}.detail-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.detail-field{display:flex;flex-direction:column;gap:2px}.detail-field-label{color:#6b7280;color:var(--color-text-secondary);font-size:.75rem;font-weight:500;letter-spacing:.03em;text-transform:none}.detail-field-value{align-items:center;background:#fff;background:var(--color-value-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);display:inline-flex;font-size:1rem;font-size:var(--font-size-base);min-height:28px;padding:4px 8px}.detail-field-value,.detail-notes{color:#2f3a45;color:var(--color-text)}.detail-notes{font-size:.875rem;font-size:var(--font-size-sm);line-height:1.6;margin:0;white-space:pre-wrap}.status-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.8125rem;font-weight:500;padding:2px 10px}.status-success{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.status-success:before{content:"✓ ";font-weight:700}.status-warning{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.status-warning:before{content:"⚠ "}.status-error{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.status-error:before{content:"✕ ";font-weight:700}.status-neutral{background:#e9e4de;background:var(--color-bg-secondary);color:#6b7280;color:var(--color-text-secondary)}.status-neutral:before{content:"○ "}.status-info{background:#1d4ed81a;color:#7da7c7;color:var(--color-info)}.status-info:before{content:"ℹ "}.payment-overdue{color:#b6a7b3;color:var(--color-error);font-weight:600}.overdue-badge{background-color:#b6a7b3;background-color:var(--color-error);border-radius:.25rem;color:#fff;display:inline-block;font-size:.65rem;font-weight:700;margin-left:.5rem;padding:.125rem .375rem;text-transform:none}.status-overdue{background:#dc26261f!important;border:1px solid #dc26264d;color:#b6a7b3!important;color:var(--color-error)!important}.stage-buttons{display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs)}.settings-tabs{border-bottom:2px solid #e2e6ea;border-bottom:2px solid var(--color-border);gap:0}.settings-tab{background:none;border-bottom:2px solid #0000;font-family:inherit;margin-bottom:-2px;padding:8px 24px;padding:var(--spacing-sm) var(--spacing-lg);transition:all .15s ease}.settings-tab.active{border-bottom-color:#7da7c7;border-bottom-color:var(--color-primary)}.role-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.8125rem;font-weight:500;padding:2px 10px;white-space:nowrap}.user-name-cell{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.user-avatar-sm{align-items:center;background:#7da7c72e;border-radius:50%;display:flex;flex-shrink:0;font-size:.75rem;font-weight:600;height:32px;justify-content:center;text-transform:none;width:32px}.user-avatar-sm,.you-badge{color:#7da7c7;color:var(--color-primary)}.you-badge{background:#1a56db14;border-radius:9999px;font-size:.6875rem;font-weight:500;margin-left:4px;padding:1px 6px}.status-indicator{font-size:.875rem;font-size:var(--font-size-sm);gap:6px}.status-indicator:before{flex-shrink:0}.status-active:before{background-color:#a9c7b6;background-color:var(--color-success)}.status-inactive:before{background-color:#6b7280;background-color:var(--color-text-secondary)}.status-active{color:#a9c7b6;color:var(--color-success)}.status-inactive{color:#6b7280;color:var(--color-text-secondary)}.inactive-row{opacity:.5}.invite-success{padding:16px 0;padding:var(--spacing-md) 0;text-align:center}.invite-success-icon{align-items:center;background:#e6f1ec;background:var(--color-success-light);border-radius:50%;color:#a9c7b6;color:var(--color-success);display:flex;font-size:1.5rem;font-weight:700;height:48px;justify-content:center;margin:0 auto 16px;margin:0 auto var(--spacing-md);width:48px}.invite-credentials{background:#e9e4de;background:var(--color-bg-secondary);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);margin:16px 0;margin:var(--spacing-md) 0;padding:16px;padding:var(--spacing-md);text-align:left}.invite-credentials-label{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;margin-bottom:8px!important;margin-bottom:var(--spacing-sm)!important}.invite-credentials p{margin:4px 0}.invite-credentials p,.invite-note{font-size:.875rem;font-size:var(--font-size-sm)}.invite-note{margin-top:8px!important;margin-top:var(--spacing-sm)!important}.invite-note,.modal-close{color:#6b7280;color:var(--color-text-secondary)}.modal-close{background:none;border:none;border-radius:10px;border-radius:var(--border-radius);cursor:pointer;font-size:24px;line-height:1;padding:4px}.modal-close:hover{background:#e9e4de;background:var(--color-bg-secondary);color:#2f3a45;color:var(--color-text)}.approval-card{align-items:flex-start;background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);display:flex;gap:24px;gap:var(--spacing-lg);justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md);padding:24px;padding:var(--spacing-lg)}.approval-card-info{flex:1 1}.approval-card-title{font-size:1rem;font-size:var(--font-size-base);font-weight:600;margin:0 0 4px;margin:0 0 var(--spacing-xs)}.approval-card-meta{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin:0}.approval-card-actions{display:flex;flex-shrink:0;gap:8px;gap:var(--spacing-sm)}.approval-status-pending{color:#c9bfae;color:var(--color-warning)}.approval-status-approved{color:#a9c7b6;color:var(--color-success)}.approval-status-denied{color:#b6a7b3;color:var(--color-error)}.app-layout,.app-main-area,body,html{max-width:100vw;overflow-x:hidden}.app-content{overflow-x:hidden}.portal-login-container{align-items:center;background:linear-gradient(135deg,#f5f7f9,#e9e4de);background:linear-gradient(135deg,var(--color-bg) 0,var(--color-bg-secondary) 100%);display:flex;justify-content:center;min-height:100vh;padding:1rem}.portal-login-card{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 18px 50px -24px #2f3a4552;box-shadow:var(--shadow-lg);max-width:420px;padding:2.5rem;width:100%}.portal-login-header{margin-bottom:2rem;text-align:center}.portal-logo{display:flex;justify-content:center;margin-bottom:1rem}.portal-login-header h1{color:#2f3a45;color:var(--color-text);font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.portal-subtitle{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;margin:0}.portal-login-form{display:flex;flex-direction:column;gap:1rem}.portal-form-group{display:flex;flex-direction:column;gap:.375rem}.portal-form-group label{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-weight:500}.portal-form-group input,.portal-form-group select,.portal-form-group textarea{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:8px;color:#2f3a45;color:var(--color-text);font-family:inherit;font-size:.875rem;padding:.625rem .75rem;transition:border-color .15s ease}.portal-form-group input:focus,.portal-form-group select:focus,.portal-form-group textarea:focus{border-color:#7da7c7;border-color:var(--color-primary);box-shadow:0 0 0 3px #7da7c740;outline:none}.portal-login-btn{background:#7da7c7;background:var(--color-primary);border:none;border-radius:8px;color:#fff;color:var(--color-card-bg);cursor:pointer;font-size:.875rem;font-weight:600;margin-top:.5rem;padding:.75rem;transition:background-color .15s ease}.portal-login-btn:hover:not(:disabled){background:#6a93b2;background:var(--color-primary-dark)}.portal-login-btn:disabled{cursor:not-allowed;opacity:.6}.portal-error-message{background:#f2edf0;background:var(--color-error-light);border:1px solid #b6a7b3;border:1px solid var(--color-error);border-radius:8px;color:#b6a7b3;color:var(--color-error);font-size:.875rem;padding:.75rem;text-align:center}.portal-login-footer{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);margin-top:1.5rem;padding-top:1.5rem;text-align:center}.portal-login-footer p{color:#6b7280;color:var(--color-text-secondary);font-size:.8125rem;margin:0}.portal-login-footer a{color:#7da7c7;color:var(--color-primary);font-weight:500;text-decoration:none}.portal-login-footer a:hover{text-decoration:underline}.portal-layout{background:#f5f7f9;background:var(--color-bg);display:flex;flex-direction:column;min-height:100vh}.portal-header{background:#fff;background:var(--color-card-bg);border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);height:60px;justify-content:space-between;padding:0 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.portal-brand,.portal-header,.portal-header-left{align-items:center;display:flex}.portal-brand{color:#2f3a45;color:var(--color-text);gap:.5rem;text-decoration:none}.portal-brand-name{font-size:1rem;font-weight:600}.portal-badge{background:#7da7c733;border-radius:4px;color:#7da7c7;color:var(--color-primary);font-size:.625rem;font-weight:700;letter-spacing:.05em;padding:.125rem .375rem;text-transform:none;vertical-align:middle}.portal-nav{gap:.25rem}.portal-nav,.portal-nav-link{align-items:center;display:flex}.portal-nav-link{border-radius:6px;color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;gap:.375rem;padding:.5rem .75rem;text-decoration:none;transition:all .15s ease}.portal-nav-link:hover{background:#e9e4de;background:var(--color-bg-secondary);color:#2f3a45;color:var(--color-text)}.portal-nav-link.active{background:#7da7c72e;color:#7da7c7;color:var(--color-primary)}.portal-header-right{align-items:center;display:flex;gap:1rem}.portal-user-name{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-weight:500}.portal-logout-btn{background:none;border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:6px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;font-size:.8125rem;padding:.375rem .75rem;transition:all .15s ease}.portal-logout-btn:hover{background:#f2edf0;background:var(--color-error-light);border-color:#b6a7b3;border-color:var(--color-error);color:#b6a7b3;color:var(--color-error)}.portal-main{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.portal-page{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.portal-page-header{margin-bottom:2rem}.portal-page-header h1{color:#2f3a45;color:var(--color-text);font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.portal-page-subtitle{font-size:.9375rem;margin:0}.portal-loading,.portal-page-subtitle{color:#6b7280;color:var(--color-text-secondary)}.portal-loading{align-items:center;display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md);justify-content:center;min-height:200px;padding:3rem;text-align:center}.portal-error{background:#f2edf0;background:var(--color-error-light);border:1px solid #b6a7b3;border:1px solid var(--color-error);border-radius:8px;color:#b6a7b3;color:var(--color-error);margin-bottom:1rem;padding:1rem}.portal-empty-state{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;padding:4rem 2rem;text-align:center}.portal-empty-icon{font-size:3rem;margin-bottom:1rem}.portal-empty-state h2{color:#2f3a45;color:var(--color-text);font-size:1.25rem;margin:0 0 .5rem}.portal-empty-state p{color:#6b7280;color:var(--color-text-secondary);font-size:.9375rem;margin:0}.portal-trips-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.portal-trip-card{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;color:#2f3a45;color:var(--color-text);display:block;padding:1.25rem;text-decoration:none;transition:all .15s ease}.portal-trip-card:hover{border-color:#7da7c7;border-color:var(--color-primary);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);text-decoration:none;transform:translateY(-2px)}.portal-trip-card-header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.5rem}.portal-trip-card-header h3{font-size:1.0625rem;font-weight:600;margin:0}.portal-stage-badge{border-radius:9999px;font-size:.6875rem;font-weight:600;letter-spacing:.03em;padding:.1875rem .5rem;text-transform:none;white-space:nowrap}.portal-trip-destination{font-size:.875rem;margin:0 0 .5rem}.portal-trip-dates,.portal-trip-destination{color:#6b7280;color:var(--color-text-secondary)}.portal-trip-dates{align-items:center;display:flex;font-size:.8125rem;gap:.5rem;margin-bottom:.5rem}.portal-date-separator{color:#7da7c7;color:var(--color-primary)}.portal-trip-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#6b7280;color:var(--color-text-secondary);display:-webkit-box;font-size:.8125rem;margin:0;overflow:hidden}.portal-back-link{color:#7da7c7;color:var(--color-primary);display:inline-block;font-size:.875rem;font-weight:500;margin-bottom:1rem;text-decoration:none}.portal-back-link:hover{text-decoration:underline}.portal-trip-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.portal-trip-header h1{font-size:1.5rem;font-weight:700;margin:0}.portal-trip-destination-large{color:#6b7280;color:var(--color-text-secondary);font-size:.9375rem;margin:.25rem 0 0}.portal-stage-badge-large{background:#7da7c7;background:var(--color-primary);border-radius:8px;color:#fff;color:var(--color-card-bg);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.375rem .75rem;text-transform:none;white-space:nowrap}.portal-trip-dates-bar{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.portal-date-item{display:flex;flex-direction:column}.portal-date-label{color:#6b7280;color:var(--color-text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.125rem;text-transform:none}.portal-date-value{align-items:center;background:#fff;background:var(--color-value-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);color:#2f3a45;color:var(--color-text);display:inline-flex;font-size:1rem;font-weight:600;padding:4px 8px}.portal-tabs{border-bottom:2px solid #e2e6ea;border-bottom:2px solid var(--color-border);display:flex;gap:0;margin-bottom:1.5rem}.portal-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.25rem;transition:all .15s ease}.portal-tab,.portal-tab *{cursor:pointer}.portal-tab:hover{color:#2f3a45;color:var(--color-text)}.portal-tab.active{border-bottom-color:#7da7c7;border-bottom-color:var(--color-primary);color:#7da7c7;color:var(--color-primary);font-weight:600}.portal-tab-content{animation:fadeIn .2s ease}.portal-section{margin-bottom:2rem}.portal-section h2{color:#2f3a45;color:var(--color-text);font-size:1.125rem;font-weight:600;margin:0 0 .75rem}.portal-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.portal-section-header h2{margin:0}.portal-summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.portal-summary-card{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;padding:1.25rem;text-align:center}.portal-summary-label{color:#6b7280;color:var(--color-text-secondary);display:block;font-size:.8125rem;margin-bottom:.375rem}.portal-summary-value{color:#2f3a45;color:var(--color-text);display:block;font-size:1.5rem;font-weight:700}.portal-form{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;margin-bottom:1.5rem;padding:1.5rem}.portal-form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.portal-form-group.full-width{grid-column:1/-1}.portal-form-actions{display:flex;justify-content:flex-end;margin-top:1rem}.portal-submit-btn{background:#7da7c7;background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:background-color .15s ease}.portal-submit-btn:hover:not(:disabled){background:#6a93b2;background:var(--color-primary-dark)}.portal-submit-btn:disabled{cursor:not-allowed;opacity:.6}.portal-add-btn{background:#fff;background:var(--color-card-bg);border:1px solid #7da7c7;border:1px solid var(--color-primary);border-radius:8px;color:#7da7c7;color:var(--color-primary);cursor:pointer;font-size:.8125rem;font-weight:600;padding:.5rem 1rem;transition:all .15s ease}.portal-add-btn:hover{background:#7da7c71f}.portal-message{border-radius:8px;font-size:.875rem;margin-bottom:1rem;padding:.75rem 1rem}.portal-message.success{background:#e6f1ec;background:var(--color-success-light);border:1px solid #a9c7b6;border:1px solid var(--color-success);color:#a9c7b6;color:var(--color-success)}.portal-message.error{background:#f2edf0;background:var(--color-error-light);border:1px solid #b6a7b3;border:1px solid var(--color-error);color:#b6a7b3;color:var(--color-error)}.portal-empty-section{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;color:#6b7280;color:var(--color-text-secondary);font-size:.9375rem;padding:2rem;text-align:center}.portal-travelers-list{display:flex;flex-direction:column;gap:.75rem}.portal-traveler-card{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;padding:1rem 1.25rem}.portal-traveler-name{color:#2f3a45;color:var(--color-text);font-size:1rem;font-weight:600;margin-bottom:.375rem}.portal-traveler-details{color:#6b7280;color:var(--color-text-secondary);display:flex;flex-wrap:wrap;font-size:.8125rem;gap:.5rem 1rem}.portal-traveler-needs{color:#c9bfae;color:var(--color-warning);font-size:.8125rem;font-style:italic;margin-top:.375rem}.portal-bookings-list{display:flex;flex-direction:column;gap:.75rem}.portal-booking-card{background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;padding:1rem 1.25rem}.portal-booking-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.portal-booking-type{font-size:.9375rem;font-weight:600;text-transform:capitalize}.portal-booking-status{border-radius:9999px;font-size:.75rem;font-weight:600;padding:.125rem .5rem;text-transform:capitalize}.portal-booking-status.status-booked{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.portal-booking-status.status-planned{background:#e9e4de;background:var(--color-bg-secondary);color:#6b7280;color:var(--color-text-secondary)}.portal-booking-status.status-quoted{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.portal-booking-status.status-canceled{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.portal-booking-supplier{font-size:.875rem}.portal-booking-confirmation,.portal-booking-supplier{color:#6b7280;color:var(--color-text-secondary);margin-bottom:.25rem}.portal-booking-confirmation{font-family:monospace;font-size:.8125rem}.portal-booking-dates{color:#6b7280;color:var(--color-text-secondary);font-size:.8125rem;margin-bottom:.5rem}.portal-booking-financial{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);color:#2f3a45;color:var(--color-text);display:flex;flex-wrap:wrap;font-size:.8125rem;gap:.5rem 1rem;padding-top:.5rem}.portal-payment-due{color:#b6a7b3;color:var(--color-error);font-weight:500}.portal-payment-summary{background:linear-gradient(135deg,#f5f7f9,#e9e4de);background:linear-gradient(135deg,var(--color-bg) 0,var(--color-bg-secondary) 100%);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.portal-payment-summary h3{color:#2f3a45;color:var(--color-text);font-size:1rem;font-weight:600;margin:0 0 1rem}.portal-payment-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.portal-payment-card{background:#fff;background:var(--color-card-bg);border-radius:8px;box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);padding:1rem;text-align:center}.portal-payment-label{color:#6b7280;color:var(--color-text-secondary);display:block;font-size:.75rem;letter-spacing:.02em;margin-bottom:.25rem;text-transform:none}.portal-payment-value{color:#2f3a45;color:var(--color-text);display:block;font-size:1.25rem;font-weight:700}.portal-payment-card .portal-payment-status{color:#6b7280;color:var(--color-text-secondary);display:block;font-size:.75rem;margin-top:.25rem}.portal-booking-payment-details{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);margin-top:.75rem;padding-top:.75rem}.portal-payment-row{align-items:center;display:flex;font-size:.875rem;justify-content:space-between;padding:.375rem 0}.portal-payment-item-label{color:#6b7280;color:var(--color-text-secondary)}.portal-payment-item-value{align-items:center;background:#fff;background:var(--color-value-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);color:#2f3a45;color:var(--color-text);display:flex;font-weight:500;gap:.5rem;padding:2px 8px}.portal-payment-badge{border-radius:10px;font-size:.75rem;font-weight:500;padding:.125rem .5rem}.portal-payment-badge.paid{background-color:#e6f1ec;background-color:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.portal-payment-badge.due{background-color:#f3eee7;background-color:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.portal-payment-due-date .portal-due-date-highlight{color:#b6a7b3;color:var(--color-error);font-weight:600}.portal-payment-due-date.overdue{background-color:#f2edf0;background-color:var(--color-error-light);border-left:3px solid #b6a7b3;border-left:3px solid var(--color-error);padding-left:.5rem}.portal-overdue-date{color:#b6a7b3;color:var(--color-error);font-weight:700}.portal-overdue-badge{background-color:#b6a7b3;background-color:var(--color-error);border-radius:.25rem;color:#fff;color:var(--color-card-bg);display:inline-block;font-size:.65rem;font-weight:700;margin-left:.5rem;padding:.125rem .375rem;text-transform:none}.portal-payment-overall{border-top:1px dashed #e2e6ea;border-top:1px dashed var(--color-border);margin-top:.5rem;padding-top:.5rem}.portal-payment-status-badge{border-radius:12px;font-size:.8125rem;font-weight:600;padding:.25rem .75rem}.portal-payment-status-badge.deposit_paid{background-color:#f3eee7;background-color:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.portal-payment-status-badge.final_due{background-color:#f2edf0;background-color:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.portal-payment-status-badge.paid_in_full{background-color:#e6f1ec;background-color:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.portal-documents-list{display:flex;flex-direction:column;gap:.5rem}.portal-document-card{align-items:center;background:#fff;background:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;display:flex;gap:.75rem;padding:.875rem 1.25rem}.portal-doc-icon{font-size:1.25rem}.portal-doc-info{display:flex;flex:1 1;flex-direction:column}.portal-doc-name{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-weight:500}.portal-doc-type{font-size:.75rem;text-transform:capitalize}.portal-doc-date,.portal-doc-type{color:#6b7280;color:var(--color-text-secondary)}.portal-doc-date{font-size:.8125rem}@media (max-width:768px){.portal-header{padding:0 1rem}.portal-main{padding:1rem}.portal-nav{display:none}.portal-brand-name{font-size:.875rem}.portal-user-name{display:none}.portal-form-grid,.portal-trips-grid{grid-template-columns:1fr}.portal-summary-grid{grid-template-columns:repeat(3,1fr)}.portal-trip-header{flex-direction:column;gap:.5rem}.portal-trip-dates-bar{flex-direction:column;gap:.75rem}.portal-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.portal-tab{font-size:.8125rem;padding:.625rem .75rem;white-space:nowrap}.portal-booking-financial{flex-direction:column;gap:.25rem}}.tasks-container{gap:32px;gap:var(--spacing-xl)}.tasks-container,.tasks-section{display:flex;flex-direction:column}.tasks-section{gap:16px;gap:var(--spacing-md)}.tasks-section-title{align-items:center;color:#2f3a45;color:var(--color-text);display:flex;font-size:1.125rem;font-size:var(--font-size-lg);font-weight:600;gap:8px;gap:var(--spacing-sm);margin:0}.tasks-section-urgent{color:#b6a7b3;color:var(--color-error)}.tasks-section-completed{color:#a9c7b6;color:var(--color-success)}.tasks-list{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.task-card{background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);padding:16px;padding:var(--spacing-md);transition:box-shadow .15s ease}.task-card:hover{box-shadow:0 8px 20px -8px #2f3a452e;box-shadow:var(--shadow-md)}.task-card-overdue{border-left:3px solid #b6a7b3;border-left:3px solid var(--color-error)}.task-card-completed{background:#e9e4de;background:var(--color-bg-secondary);opacity:.7}.task-card-header{align-items:flex-start;display:flex;gap:16px;gap:var(--spacing-md);justify-content:space-between;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.task-card-title-row{align-items:center;display:flex;flex:1 1;gap:8px;gap:var(--spacing-sm);min-width:0}.task-checkbox{align-items:center;background:#0000;border:2px solid #e2e6ea;border:2px solid var(--color-border);border-radius:50%;cursor:pointer;display:flex;height:22px;justify-content:center;min-width:22px;transition:all .15s ease;width:22px}.task-checkbox:hover{background:#1a56db0d;border-color:#7da7c7;border-color:var(--color-primary)}.task-checkbox .checkbox-icon{background:#0000;border-radius:50%;display:block;height:10px;transition:background .15s ease;width:10px}.task-checkbox:hover .checkbox-icon{background:#7da7c7;background:var(--color-primary)}.task-checkbox-completed{background:#a9c7b6;background:var(--color-success);border-color:#a9c7b6;border-color:var(--color-success);color:#fff;cursor:default}.task-card-title{color:#2f3a45;color:var(--color-text);flex:1 1;font-size:1rem;font-size:var(--font-size-base);font-weight:600;margin:0;min-width:0}.task-title-completed{color:#6b7280;color:var(--color-text-secondary);text-decoration:line-through}.priority-badge{border-radius:9999px;flex-shrink:0;font-size:.75rem;font-weight:600;letter-spacing:.025em;padding:2px 8px;text-transform:none}.priority-urgent{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.priority-normal{background:#6b72801a}.priority-normal,.task-card-description{color:#6b7280;color:var(--color-text-secondary)}.task-card-description{line-height:1.5;margin:0 0 16px;margin:0 0 var(--spacing-md)}.task-card-description,.task-card-meta{font-size:.875rem;font-size:var(--font-size-sm)}.task-card-meta{display:flex;flex-wrap:wrap;gap:16px;gap:var(--spacing-md)}.task-meta-item{align-items:center;display:flex;gap:4px;gap:var(--spacing-xs)}.task-meta-label{color:#6b7280;color:var(--color-text-secondary)}.task-meta-value{color:#2f3a45;color:var(--color-text);font-weight:500}.task-system-badge{background:#6b72801a;border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);font-size:.7rem;font-weight:500;padding:2px 6px}.text-danger{color:#b6a7b3!important;color:var(--color-error)!important;font-weight:600}.modal-md{max-width:550px}@media (max-width:768px){.task-card-header{align-items:stretch;flex-direction:column}.task-card-title-row{flex-wrap:wrap}.task-card-meta{flex-direction:column;gap:8px;gap:var(--spacing-sm)}.filters-row{flex-direction:column!important}.filters-row input,.filters-row select{min-width:0!important;min-width:auto!important;width:100%!important}}.dashboard-card-count{background:#7da7c7;background:var(--color-primary);border-radius:9999px;color:#fff;font-size:.75rem;font-weight:600;min-width:20px;padding:2px 8px;text-align:center}.dashboard-deadlines-list,.dashboard-tasks-list,.dashboard-trips-list{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.dashboard-task-item{align-items:flex-start;background:#f5f7f9;background:var(--color-bg);border:1px solid #c6c8d1;border:1px solid var(--color-border-subtle);border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:8px;padding:var(--spacing-sm);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.dashboard-task-item:hover{background:#e9e4de;background:var(--color-bg-secondary);border-color:#a5c0d6;border-color:var(--color-primary-light);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm)}.dashboard-task-item.task-overdue{border-left:3px solid #b6a7b3;border-left:3px solid var(--color-error);padding-left:5px;padding-left:calc(var(--spacing-sm) - 3px)}.dashboard-task-item.task-urgent{background:#ef44440d}.dashboard-task-checkbox{flex-shrink:0;padding-top:2px}.task-complete-btn{align-items:center;background:#0000;border:2px solid #e2e6ea;border:2px solid var(--color-border);border-radius:50%;cursor:pointer;display:flex;height:18px;justify-content:center;transition:all .15s ease;width:18px}.task-complete-btn:hover{background:#e6f1ec;background:var(--color-success-light);border-color:#a9c7b6;border-color:var(--color-success)}.task-complete-btn .checkbox-circle{background:#0000;border-radius:50%;display:block;height:8px;transition:background .15s ease;width:8px}.task-complete-btn:hover .checkbox-circle{background:#a9c7b6;background:var(--color-success)}.dashboard-task-content{flex:1 1;min-width:0}.dashboard-task-title{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;line-height:1.3}.dashboard-task-meta{color:#6b7280;color:var(--color-text-secondary);display:flex;flex-wrap:wrap;font-size:.75rem;gap:8px;gap:var(--spacing-sm);margin-top:2px}.task-meta-category{background:#e9e4de;background:var(--color-bg-secondary);border-radius:10px;border-radius:var(--border-radius);padding:1px 6px}.dashboard-task-badges{display:flex;flex-shrink:0;gap:4px;gap:var(--spacing-xs)}.badge{border-radius:10px;border-radius:var(--border-radius);font-size:.65rem;font-weight:600;letter-spacing:.025em;padding:2px 6px;text-transform:none}.badge-urgent{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.badge-overdue{background:#b6a7b3;background:var(--color-error);color:#fff}.dashboard-trip-item{align-items:center;background:#f5f7f9;background:var(--color-bg);border:1px solid #c6c8d1;border:1px solid var(--color-border-subtle);border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:flex;justify-content:space-between;padding:8px;padding:var(--spacing-sm);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.dashboard-trip-item:hover{background:#e9e4de;background:var(--color-bg-secondary);border-color:#a5c0d6;border-color:var(--color-primary-light);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm)}.dashboard-trip-info{flex:1 1;min-width:0}.dashboard-trip-name{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.dashboard-trip-meta{color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.75rem;gap:8px;gap:var(--spacing-sm);margin-top:2px}.dashboard-trip-meta span:not(:last-child):after{content:"•";margin-left:8px;margin-left:var(--spacing-sm)}.stage-badge{border-radius:10px;border-radius:var(--border-radius);font-size:.7rem;font-weight:500;padding:3px 8px;text-transform:capitalize}.stage-inquiry{background:#e9e4de;background:var(--color-bg-secondary);color:#6b7280;color:var(--color-text-secondary)}.stage-quoted{background:#e7eef4;background:var(--color-info-light);color:#7da7c7;color:var(--color-info)}.stage-booked{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.stage-payment{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.stage-traveling{background:#e7eef4;background:var(--color-info-light);color:#c6c8d1;color:var(--color-muted)}.dashboard-deadline-item{align-items:center;background:#f5f7f9;background:var(--color-bg);border:1px solid #c6c8d1;border:1px solid var(--color-border-subtle);border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:8px;padding:var(--spacing-sm);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.dashboard-deadline-item:hover{background:#e9e4de;background:var(--color-bg-secondary);border-color:#a5c0d6;border-color:var(--color-primary-light);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm)}.deadline-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;height:32px;justify-content:center;width:32px}.deadline-payment{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.deadline-travel{background:#e7eef4;background:var(--color-info-light);color:#7da7c7;color:var(--color-info)}.deadline-info{flex:1 1;min-width:0}.deadline-label{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.deadline-trip{color:#6b7280;color:var(--color-text-secondary);font-size:.75rem}.deadline-date{color:#2f3a45;color:var(--color-text);font-weight:500}.btn-link,.deadline-date{font-size:.875rem;font-size:var(--font-size-sm)}.btn-link{background:none;border:none;color:#7da7c7;color:var(--color-primary);cursor:pointer;padding:8px;padding:var(--spacing-sm);text-align:center;width:100%}.btn-link:hover{text-decoration:underline}.dashboard-atrisk-list{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.dashboard-atrisk-item{align-items:center;background:#f5f7f9;background:var(--color-bg);border:1px solid #c6c8d1;border-left:3px solid #c6c8d1;border:1px solid var(--color-border-subtle);border-left-width:3px;border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:8px;padding:var(--spacing-sm);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.dashboard-atrisk-item:hover{background:#e9e4de;background:var(--color-bg-secondary);border-color:#a5c0d6;border-color:var(--color-primary-light);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm)}.dashboard-atrisk-item.atrisk-overdue{background:#ef44440d;border-left:3px solid #b6a7b3;border-left:3px solid var(--color-error)}.dashboard-atrisk-item.atrisk-overdue:hover{background:#f2edf0;background:var(--color-error-light);border-color:#b6a7b3;border-color:var(--color-error)}.dashboard-atrisk-item.atrisk-urgent{background:#f59e0b0d;border-left:3px solid #c9bfae;border-left:3px solid var(--color-warning)}.dashboard-atrisk-item.atrisk-urgent:hover{background:#f3eee7;background:var(--color-warning-light);border-color:#c9bfae;border-color:var(--color-warning)}.atrisk-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.875rem;font-size:var(--font-size-sm);font-weight:700;height:32px;justify-content:center;width:32px}.atrisk-icon-overdue{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.atrisk-icon-urgent{background:#f59e0b26;color:#c9bfae;color:var(--color-warning)}.atrisk-icon-warning{background:#e7eef4;background:var(--color-info-light);color:#7da7c7;color:var(--color-info)}.atrisk-info{flex:1 1;min-width:0}.atrisk-supplier{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.atrisk-meta{color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.75rem;gap:4px;gap:var(--spacing-xs)}.atrisk-meta span:after{content:" \00b7 "}.atrisk-meta span:last-child:after{content:""}.atrisk-details{flex-shrink:0;text-align:right}.atrisk-amount{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600}.atrisk-due{color:#6b7280;color:var(--color-text-secondary);font-size:.75rem}.atrisk-due.text-danger{color:#b6a7b3;color:var(--color-error);font-weight:500}.atrisk-due.text-warning{color:#c9bfae;color:var(--color-warning);font-weight:500}.commission-pipeline-widget{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.commission-pipeline-flow{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm);justify-content:space-between}.pipeline-stage{border-radius:10px;border-radius:var(--border-radius);cursor:pointer;flex:1 1;padding:8px;padding:var(--spacing-sm);text-align:center;transition:transform .15s ease,box-shadow .15s ease}.pipeline-stage:hover{box-shadow:0 8px 20px -8px #2f3a452e;box-shadow:var(--shadow-md);transform:translateY(-2px)}.pipeline-expected{background:#e7eef4;background:var(--color-info-light);border:1px solid #3b82f64d}.pipeline-submitted{background:#f3eee7;background:var(--color-warning-light);border:1px solid #f59e0b4d}.pipeline-paid{background:#e6f1ec;background:var(--color-success-light);border:1px solid #10b9814d}.pipeline-stage-label{color:#6b7280;color:var(--color-text-secondary);font-size:.7rem;font-weight:600;letter-spacing:.5px;text-transform:none}.pipeline-stage-count{color:#2f3a45;color:var(--color-text);font-size:1.25rem;font-weight:700}.pipeline-stage-amount{color:#6b7280;color:var(--color-text-secondary);font-size:.75rem}.pipeline-arrow{color:var(--color-text-tertiary);flex-shrink:0;font-size:1rem}.commission-summary-row{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);display:flex;gap:8px;gap:var(--spacing-sm);justify-content:space-between;padding-top:8px;padding-top:var(--spacing-sm)}.commission-summary-item{align-items:center;display:flex;flex:1 1;flex-direction:column}.summary-label{color:#6b7280;color:var(--color-text-secondary);font-size:.7rem}.summary-value{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-weight:600}.summary-received{color:#a9c7b6;color:var(--color-success)}.summary-outstanding{color:#c9bfae;color:var(--color-warning)}.recent-activity-list{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.recent-activity-item{align-items:flex-start;border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);transition:background .15s ease}.recent-activity-item:hover{background:#e9e4de;background:var(--color-bg-secondary)}.activity-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;justify-content:center;margin-top:2px;width:24px}.activity-icon-create{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.activity-icon-update{background:#e7eef4;background:var(--color-info-light);color:#7da7c7;color:var(--color-info)}.activity-icon-delete{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-danger)}.activity-info{flex:1 1;min-width:0}.activity-description{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);line-height:1.3}.activity-meta{color:var(--color-text-tertiary);display:flex;font-size:.7rem;gap:4px;gap:var(--spacing-xs);margin-top:2px}.activity-user{font-weight:500}.activity-time:before{content:" \00b7 ";margin-right:4px;margin-right:var(--spacing-xs)}.dashboard-quick-access{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.quick-access-section{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.quick-access-label{color:#6b7280;color:var(--color-text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:none}.quick-access-list{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.quick-access-item{align-items:center;background:#f5f7f9;background:var(--color-bg);border:1px solid #c6c8d1;border:1px solid var(--color-border-subtle);border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:8px;padding:var(--spacing-sm);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.quick-access-item:hover{background:#e9e4de;background:var(--color-bg-secondary);border-color:#a5c0d6;border-color:var(--color-primary-light);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm)}.quick-access-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.875rem;height:28px;justify-content:center;width:28px}.quick-access-icon-client{background:#e7eef4;background:var(--color-info-light);color:#7da7c7;color:var(--color-info)}.quick-access-icon-trip{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.quick-access-info{flex:1 1;min-width:0}.quick-access-name{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-access-meta{color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.75rem;gap:4px;gap:var(--spacing-xs)}.quick-access-meta span:after{content:" \00b7 "}.quick-access-meta span:last-child:after{content:""}.quick-access-destination{font-style:italic}.dashboard-card-wide{grid-column:span 2}@media (max-width:768px){.dashboard-card-wide{grid-column:span 1}}.planner-performance-widget{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.planner-performance-table{display:flex;flex-direction:column;gap:2px}.planner-performance-header,.planner-performance-row{grid-gap:8px;grid-gap:var(--spacing-sm);align-items:center;display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:2fr 1fr 1fr 1fr 1fr;padding:8px;padding:var(--spacing-sm)}.planner-performance-header{border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);color:#6b7280;color:var(--color-text-secondary);font-size:.7rem;font-weight:600;letter-spacing:.5px;padding-bottom:8px;padding-bottom:var(--spacing-sm);text-transform:none}.planner-performance-row{border-bottom:1px solid #c6c8d1;border-bottom:1px solid var(--color-border-subtle);font-size:.875rem;font-size:var(--font-size-sm);transition:background .15s ease}.planner-performance-row:hover{background:#e9e4de;background:var(--color-bg-secondary)}.planner-performance-row:last-child{border-bottom:none}.planner-col-name{display:flex;flex-direction:column;gap:2px}.planner-name{color:#2f3a45;color:var(--color-text);font-weight:500}.planner-role{color:#6b7280;color:var(--color-text-secondary);font-size:.7rem;text-transform:capitalize}.planner-col-rate,.planner-col-revenue,.planner-col-trips{color:#2f3a45;color:var(--color-text);text-align:center}.conversion-badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:600;padding:2px 8px}.conversion-high{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.conversion-medium{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.conversion-low{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.conversion-na{color:#6b7280;color:var(--color-text-secondary);font-size:.75rem}.planner-performance-totals{background:#e9e4de;background:var(--color-bg-secondary);border-radius:10px;border-radius:var(--border-radius);display:flex;justify-content:space-around;margin-top:8px;margin-top:var(--spacing-sm);padding:16px;padding:var(--spacing-md)}.performance-total-item{align-items:center;display:flex;flex-direction:column;gap:4px}.total-label{color:#6b7280;color:var(--color-text-secondary);font-size:.7rem;letter-spacing:.5px;text-transform:none}.total-value{color:#2f3a45;color:var(--color-text);font-size:1rem;font-weight:600}@media (max-width:768px){.planner-performance-header,.planner-performance-row{font-size:.75rem;grid-template-columns:1.5fr .75fr .75fr .75fr 1fr;padding:4px;padding:var(--spacing-xs)}.planner-performance-totals{flex-wrap:wrap;gap:8px;gap:var(--spacing-sm)}.performance-total-item{flex:1 1 45%}}.topbar-center{display:flex;flex:1 1;justify-content:center;padding:0 24px;padding:0 var(--spacing-lg)}.global-search{max-width:420px;position:relative;width:100%}.global-search-input-wrapper{align-items:center;display:flex;position:relative}.global-search-icon{color:#6b7280;color:var(--color-text-secondary);left:12px;pointer-events:none;position:absolute}.global-search-input{background-color:#e9e4de;background-color:var(--color-bg-secondary);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);color:#2f3a45;color:var(--color-text);font-family:inherit;font-size:.875rem;font-size:var(--font-size-sm);padding:8px 12px 8px 36px;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease;width:100%}.global-search-input:focus{background-color:#f5f7f9;background-color:var(--color-bg);border-color:#7da7c7;border-color:var(--color-primary);box-shadow:0 0 0 3px #7da7c72e;outline:none}.global-search-input::placeholder{color:#6b7280;color:var(--color-text-secondary);opacity:.7}.global-search-spinner{animation:spin .8s linear infinite;border:2px solid #e2e6ea;border-top-color:#7da7c7;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:16px;position:absolute;right:12px;width:16px}.global-search-dropdown{background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 10px 40px #00000026;left:0;margin-top:4px;max-height:400px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.global-search-empty,.global-search-loading{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);padding:24px;padding:var(--spacing-lg);text-align:center}.global-search-empty-title{color:var(--color-text-primary);font-weight:500;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.global-search-empty-hint{color:var(--color-text-tertiary);font-size:.75rem}.global-search-section{padding:8px 0;padding:var(--spacing-sm) 0}.global-search-section:not(:last-child){border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border)}.global-search-section-title{align-items:center;color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.75rem;font-weight:600;gap:8px;gap:var(--spacing-sm);letter-spacing:.03em;margin:0;padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md);text-transform:none}.global-search-section-title svg{opacity:.6}.global-search-result{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-family:inherit;gap:8px;gap:var(--spacing-sm);padding:10px 16px;padding:10px var(--spacing-md);text-align:left;transition:background-color .1s ease;width:100%}.global-search-result:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary)}.global-search-result-name{color:#2f3a45;color:var(--color-text);flex-shrink:0;font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.global-search-result-meta{color:#6b7280;color:var(--color-text-secondary);flex:1 1;font-size:.8125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.global-search-result-badge{border-radius:10px;border-radius:var(--border-radius);flex-shrink:0;font-size:.7rem;font-weight:500;padding:2px 8px;text-transform:capitalize}.global-search-result-badge.stage-inquiry{background:#e9e4de;background:var(--color-bg-secondary);color:#6b7280;color:var(--color-text-secondary)}.global-search-result-badge.stage-quoted{background:#e7eef4;background:var(--color-info-light);color:#7da7c7;color:var(--color-info)}.global-search-result-badge.stage-booked{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.global-search-result-badge.stage-final_payment_pending{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.global-search-result-badge.stage-traveling{background:#e7eef4;background:var(--color-info-light);color:#c6c8d1;color:var(--color-muted)}.global-search-result-badge.stage-completed{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.global-search-result-badge.stage-canceled{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.global-search-result-badge.booking-planned,.global-search-result-badge.stage-archived{background:#e9e4de;background:var(--color-bg-secondary);color:#6b7280;color:var(--color-text-secondary)}.global-search-result-badge.booking-quoted{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.global-search-result-badge.booking-booked{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.global-search-result-badge.booking-canceled{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}@media (max-width:1023px){.topbar-center{display:none}}@media (min-width:1024px){.topbar-center{display:flex}}.tabs-container{display:flex;justify-content:flex-start}.tabs{align-items:center;background:#e9e4de;background:var(--color-bg-secondary);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:9999px;box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);display:inline-flex;gap:6px;padding:6px}.tab{background:#0000;border:none;border-radius:9999px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;padding:8px 16px;transition:background-color .15s ease,color .15s ease,box-shadow .15s ease}.tab:hover{background:#7da7c71f;color:#2f3a45;color:var(--color-text)}.tab:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.tab.active{background:#fff;background:var(--color-card-bg);box-shadow:0 1px 2px 0 #2f3a450f;box-shadow:var(--shadow-sm);color:#7da7c7;color:var(--color-primary)}.templates-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.template-card{background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);cursor:pointer;display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm);padding:24px;padding:var(--spacing-lg);transition:all .2s ease}.template-card:hover{border-color:#7da7c7;border-color:var(--color-primary);box-shadow:0 8px 20px -8px #2f3a452e;box-shadow:var(--shadow-md)}.template-card-header{align-items:flex-start;display:flex;justify-content:space-between}.template-card-icon{align-items:center;background:#7da7c72e;border-radius:10px;border-radius:var(--border-radius);color:#7da7c7;color:var(--color-primary);display:flex;height:40px;justify-content:center;width:40px}.template-card-badges{display:flex;gap:4px;gap:var(--spacing-xs)}.template-card-name{color:#2f3a45;color:var(--color-text);font-size:1.125rem;font-size:var(--font-size-lg);font-weight:600;margin-top:8px;margin-top:var(--spacing-sm)}.template-card-subject{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-card-meta,.template-card-subject{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm)}.template-card-meta{display:flex;gap:8px;gap:var(--spacing-sm);margin-top:4px;margin-top:var(--spacing-xs)}.template-card-actions{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);display:flex;gap:8px;gap:var(--spacing-sm);margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.template-detail .detail-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.template-icon{align-items:center;background:#7da7c72e;border-radius:10px;border-radius:var(--border-radius);color:#7da7c7;color:var(--color-primary);display:flex;height:48px;justify-content:center;width:48px}.template-badges{display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs);margin-top:4px;margin-top:var(--spacing-xs)}.template-subject-preview{font-size:1.125rem;font-size:var(--font-size-lg);font-weight:500}.template-body-preview,.template-subject-preview{background:#e9e4de;background:var(--color-bg-secondary);border-radius:10px;border-radius:var(--border-radius);color:#2f3a45;color:var(--color-text);padding:16px;padding:var(--spacing-md)}.template-body-preview{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:.875rem;font-size:var(--font-size-sm);line-height:1.6;max-height:400px;overflow-y:auto;white-space:pre-wrap}.template-variables-bar{align-items:center;background:#e9e4de;background:var(--color-bg-secondary);border-radius:10px;border-radius:var(--border-radius);display:flex;flex-wrap:wrap;gap:4px;gap:var(--spacing-xs);margin-bottom:8px;margin-bottom:var(--spacing-sm);padding:8px;padding:var(--spacing-sm)}.template-variables-label{margin-right:8px;margin-right:var(--spacing-sm)}.template-variables-label,.template-variables-more{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm)}.template-variables-more{background:#e2e6ea;background:var(--color-border);border-radius:10px;border-radius:var(--border-radius);cursor:help;padding:2px 8px}.template-preview{display:flex;flex-direction:column;gap:24px;gap:var(--spacing-lg)}.preview-section{display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.preview-label{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;letter-spacing:.5px;text-transform:none}.preview-content{background:#e9e4de;background:var(--color-bg-secondary);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);padding:16px;padding:var(--spacing-md)}.preview-subject{font-weight:500}.preview-body,.preview-subject{color:#2f3a45;color:var(--color-text)}.preview-body{font-size:.875rem;font-size:var(--font-size-sm);line-height:1.6;white-space:pre-wrap}.preview-sample-data{display:flex;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm)}.sample-data-item{background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);padding:4px 8px}.sample-data-item strong{color:#2f3a45;color:var(--color-text)}.btn-xs{font-size:12px;padding:4px 8px}.btn-danger{border-color:#b6a7b3;border-color:var(--color-error);color:#b6a7b3;color:var(--color-error)}.btn-danger:hover{background:#b6a7b3;background:var(--color-error);color:#fff}.modal-xl{max-width:900px}.status-badge.status-sm{font-size:11px;padding:2px 6px}@media (max-width:767px){.templates-grid{grid-template-columns:1fr}.template-card-actions{flex-wrap:wrap}}.notification-bell{margin-right:16px;margin-right:var(--spacing-md);position:relative}.notification-bell-btn{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);display:flex;height:40px;justify-content:center;position:relative;transition:background-color .15s,color .15s;width:40px}.notification-bell-btn:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);color:#2f3a45;color:var(--color-text)}.notification-bell-btn:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.notification-bell-btn.has-urgent{animation:bell-shake .5s ease-in-out;color:#c9bfae;color:var(--color-warning)}@keyframes bell-shake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}50%{transform:rotate(10deg)}75%{transform:rotate(-5deg)}}.notification-badge{background-color:#7da7c7;background-color:var(--color-primary);border-radius:9px;color:#fff;color:var(--color-card-bg);font-size:11px;font-weight:600;height:18px;line-height:18px;min-width:18px;padding:0 5px;position:absolute;right:2px;text-align:center;top:2px}.notification-badge.urgent{animation:pulse 2s infinite;background-color:#c9bfae;background-color:var(--color-warning)}.notification-dropdown{background-color:#fff;background-color:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 18px 50px -24px #2f3a4552;box-shadow:var(--shadow-lg);max-height:480px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:360px;z-index:1100}.notification-dropdown-header{align-items:center;border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:16px;padding:var(--spacing-md)}.notification-dropdown-header h3{font-size:1rem;font-size:var(--font-size-base);font-weight:600;margin:0}.notification-list{max-height:400px;overflow-y:auto}.notification-empty{color:#6b7280;color:var(--color-text-secondary);padding:32px;padding:var(--spacing-xl);text-align:center}.notification-item{align-items:flex-start;border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:16px;padding:var(--spacing-md);position:relative;transition:background-color .15s}.notification-item:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary)}.notification-item:last-child{border-bottom:none}.notification-item.unread{background-color:#7da7c71f}.notification-item.urgent{border-left:3px solid #c9bfae;border-left:3px solid var(--color-warning)}.notification-item.urgent.unread{background-color:#c9bfae33}.notification-icon{align-items:center;background-color:#e9e4de;background-color:var(--color-bg-secondary);border-radius:50%;color:#6b7280;color:var(--color-text-secondary);display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.notification-item.urgent .notification-icon{background-color:#c9bfae40;color:#c9bfae;color:var(--color-warning)}.notification-content{flex:1 1;min-width:0}.notification-title{color:#2f3a45;color:var(--color-text);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;margin-bottom:2px}.notification-item.urgent .notification-title{color:#c9bfae;color:var(--color-warning)}.notification-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:12px;line-height:1.4;overflow:hidden;text-overflow:ellipsis}.notification-message,.notification-time{color:#6b7280;color:var(--color-text-secondary)}.notification-time{font-size:11px;margin-top:4px}.notification-dismiss{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);display:flex;flex-shrink:0;height:24px;justify-content:center;opacity:0;transition:opacity .15s,background-color .15s;width:24px}.notification-item:hover .notification-dismiss{opacity:1}.notification-dismiss:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);color:#2f3a45;color:var(--color-text)}.notification-actions{display:flex;flex-direction:column;flex-shrink:0;gap:4px;opacity:0;transition:opacity .15s}.notification-item:hover .notification-actions{opacity:1}.notification-snooze{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);cursor:pointer;display:flex;height:24px;justify-content:center;transition:background-color .15s;width:24px}.notification-snooze:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);color:#7da7c7;color:var(--color-primary)}.snooze-menu{background-color:#fff;background-color:var(--color-card-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);box-shadow:0 8px 20px -8px #2f3a452e;box-shadow:var(--shadow-md);min-width:150px;padding:8px;padding:var(--spacing-sm);position:absolute;right:50px;top:50%;transform:translateY(-50%);z-index:1200}.snooze-menu-title{color:#6b7280;color:var(--color-text-secondary);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;padding:4px 8px;text-transform:none}.snooze-option{background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);color:#2f3a45;color:var(--color-text);cursor:pointer;display:block;font-size:.875rem;font-size:var(--font-size-sm);padding:8px;text-align:left;transition:background-color .15s;width:100%}.snooze-option:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);color:#7da7c7;color:var(--color-primary)}@media (max-width:480px){.notification-dropdown{left:8px;max-height:calc(100vh - 80px);position:fixed;right:8px;top:60px;width:auto}}.agency-settings-form{max-width:600px}.logo-upload-section{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.logo-preview-container{align-items:center;background-color:#e9e4de;background-color:var(--color-bg-secondary);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);display:flex;gap:16px;gap:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.logo-preview{border-radius:10px;border-radius:var(--border-radius);max-height:60px;max-width:120px;object-fit:contain}.logo-actions,.logo-upload-placeholder{display:flex;gap:8px;gap:var(--spacing-sm)}.logo-upload-placeholder{align-items:center;background-color:#e9e4de;background-color:var(--color-bg-secondary);border:2px dashed #e2e6ea;border:2px dashed var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);cursor:pointer;flex-direction:column;justify-content:center;padding:32px;padding:var(--spacing-xl);transition:border-color .2s,background-color .2s}.logo-upload-placeholder:hover{background-color:#7da7c71f;border-color:#7da7c7;border-color:var(--color-primary)}.logo-upload-placeholder:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.upload-icon{font-size:32px;line-height:1}.upload-hint{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm)}.color-picker-section{position:relative}.color-preview-box{align-items:center;border:2px solid #e2e6ea;border:2px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:inline-flex;height:44px;justify-content:center;transition:border-color .2s;width:100px}.color-preview-box:hover{border-color:#7da7c7;border-color:var(--color-primary)}.color-hex{color:#fff;font-family:monospace;font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;text-shadow:0 1px 2px #0000004d;text-transform:none}.color-picker-dropdown{background-color:#f5f7f9;background-color:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 8px 20px -8px #2f3a452e;box-shadow:var(--shadow-md);left:0;margin-top:8px;margin-top:var(--spacing-sm);min-width:260px;padding:16px;padding:var(--spacing-md);position:absolute;top:100%;z-index:100}.color-grid{grid-gap:4px;grid-gap:var(--spacing-xs);display:grid;gap:4px;gap:var(--spacing-xs);grid-template-columns:repeat(8,1fr);margin-bottom:16px;margin-bottom:var(--spacing-md)}.color-swatch{border:2px solid #0000;border-radius:10px;border-radius:var(--border-radius);cursor:pointer;height:28px;transition:transform .15s,border-color .15s;width:28px}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:#2f3a45;border-color:var(--color-text);box-shadow:0 0 0 2px #f5f7f9;box-shadow:0 0 0 2px var(--color-bg)}.custom-color-input{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);display:flex;gap:8px;gap:var(--spacing-sm);padding-top:8px;padding-top:var(--spacing-sm)}.custom-color-input input{flex:1 1;font-family:monospace;text-transform:none}.form-info-box{align-items:center;background-color:#e7eef4;background-color:var(--color-info-light);border:1px solid #a5c0d6;border:1px solid var(--color-primary-light);border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.875rem;font-size:var(--font-size-sm);gap:8px;gap:var(--spacing-sm);margin-top:16px;margin-top:var(--spacing-md);padding:16px;padding:var(--spacing-md)}.info-icon{flex-shrink:0}.form-actions{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);display:flex;gap:16px;gap:var(--spacing-md);justify-content:flex-start;margin-top:24px;margin-top:var(--spacing-lg);padding-top:24px;padding-top:var(--spacing-lg)}.btn-danger{border:none;color:#fff}.btn-danger,.btn-danger:hover{background-color:#b6a7b3;background-color:var(--color-error)}.settings-tabs{border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding-bottom:8px;padding-bottom:var(--spacing-sm)}.settings-tab{background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);color:#6b7280;color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:color .2s,background-color .2s}.settings-tab:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary);color:#2f3a45;color:var(--color-text)}.settings-tab.active{background-color:#7da7c72e;color:#7da7c7;color:var(--color-primary)}.workflow-settings-form{max-width:600px}.settings-description{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);line-height:1.5;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.input-with-suffix{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.input-with-suffix input{text-align:center;width:80px}.input-suffix{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);white-space:nowrap}.audit-log-filters{border-bottom:1px solid #e2e6ea;border-bottom:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:16px;gap:var(--spacing-md);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding-bottom:16px;padding-bottom:var(--spacing-md)}.audit-log-filters .filter-group{display:flex;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.audit-log-filters .filter-group label:not(.checkbox-label){color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500}.audit-log-filters .filter-group select{background-color:#f5f7f9;background-color:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);font-size:.875rem;font-size:var(--font-size-sm);min-width:180px;padding:8px 12px}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.875rem;font-size:var(--font-size-sm);gap:8px;gap:var(--spacing-sm)}.checkbox-label input[type=checkbox]{accent-color:#7da7c7;accent-color:var(--color-primary);height:16px;width:16px}.audit-log-count{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin-bottom:16px;margin-bottom:var(--spacing-md)}.audit-logs-table{width:100%}.audit-logs-table .timestamp-cell{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);white-space:nowrap}.audit-logs-table .details-cell{max-width:300px}.audit-logs-table .details-text{color:#6b7280;color:var(--color-text-secondary);display:block;font-size:.875rem;font-size:var(--font-size-sm);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entity-info{text-transform:capitalize}.entity-id{font-size:.875rem;font-size:var(--font-size-sm);margin-left:4px;margin-left:var(--spacing-xs)}.action-badge,.entity-id{color:#6b7280;color:var(--color-text-secondary)}.action-badge{background-color:#e9e4de;background-color:var(--color-bg-secondary);border-radius:4px;display:inline-block;font-size:12px;font-weight:500;padding:4px 8px;white-space:nowrap}.action-badge.action-approve{background-color:#e6f1ec;background-color:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.action-badge.action-deny{background-color:#f2edf0;background-color:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.action-badge.action-create{background-color:#e7eef4;background-color:var(--color-info-light);color:#7da7c7;color:var(--color-primary)}.action-badge.action-update{background-color:#f3eee7;background-color:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.action-badge.action-delete{background-color:#f2edf0;background-color:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.pagination{align-items:center;border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);display:flex;gap:16px;gap:var(--spacing-md);justify-content:center;margin-top:24px;margin-top:var(--spacing-lg);padding-top:16px;padding-top:var(--spacing-md)}.pagination-info{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm)}.table-responsive{overflow-x:auto}.profile-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg)}.profile-form .form-row{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:1fr 1fr}.profile-view{flex-direction:column}.profile-header,.profile-view{display:flex;gap:24px;gap:var(--spacing-lg)}.profile-header{align-items:center}.profile-avatar-large{align-items:center;background:linear-gradient(135deg,#7da7c7,#a5c0d6);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));border-radius:50%;color:#fff;display:flex;font-size:1.75rem;font-weight:600;height:80px;justify-content:center;text-transform:none;width:80px}.profile-name-section h2{color:#2f3a45;color:var(--color-text);font-size:1.5rem;font-weight:600;margin:0 0 4px}.profile-email{color:#6b7280;color:var(--color-text-secondary);font-size:1rem;font-size:var(--font-size-base);margin:0}.profile-details{border-top:1px solid #e2e6ea;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm);padding-top:16px;padding-top:var(--spacing-md)}.profile-detail-row{align-items:center;display:flex;justify-content:space-between;padding:8px 0}.profile-detail-label{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm)}.profile-detail-value{align-items:center;background:#fff;background:var(--color-value-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);color:#2f3a45;color:var(--color-text);display:inline-flex;font-weight:500;padding:4px 8px}.status-info{flex-direction:column}.status-info,.status-item{display:flex;gap:8px;gap:var(--spacing-sm)}.status-item{align-items:center;padding:8px 0}.status-icon{font-size:1.25rem}.status-active-icon{color:#a9c7b6;color:var(--color-success)}.topbar-user-info{align-items:center;border-radius:6px;cursor:pointer;display:flex;flex-direction:row!important;gap:8px;gap:var(--spacing-sm);padding:4px 8px;text-decoration:none;transition:background-color .15s ease;white-space:nowrap}.topbar-user-info:hover{background-color:#e9e4de;background-color:var(--color-bg-secondary)}.topbar-user-info:focus-visible{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}@media (max-width:768px){.profile-form .form-row{grid-template-columns:1fr}.profile-header{flex-direction:column;text-align:center}}.breadcrumb{margin-bottom:16px;margin-bottom:var(--spacing-md)}.breadcrumb-list{flex-wrap:wrap;list-style:none;margin:0;padding:0}.breadcrumb-item,.breadcrumb-list{align-items:center;display:flex;gap:4px;gap:var(--spacing-xs)}.breadcrumb-link{border-radius:10px;border-radius:var(--border-radius);color:#7da7c7;color:var(--color-primary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);text-decoration:none;transition:background-color .15s ease,color .15s ease}.breadcrumb-link:hover{background-color:#7da7c7;background-color:var(--color-primary);color:#fff;text-decoration:none}.breadcrumb-link:focus{outline:2px solid #7da7c7;outline:2px solid var(--color-primary);outline-offset:2px}.breadcrumb-separator{align-items:center;color:#6b7280;color:var(--color-text-secondary);display:flex}.breadcrumb-separator svg{height:14px;width:14px}.breadcrumb-current{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}[data-theme=dark] .breadcrumb-link{color:#a5c0d6;color:var(--color-primary-light)}[data-theme=dark] .breadcrumb-link:hover{background-color:#7da7c7;background-color:var(--color-primary);color:#fff}@media (max-width:480px){.breadcrumb-list{gap:2px}.breadcrumb-current,.breadcrumb-link{font-size:.75rem;padding:2px 4px}.breadcrumb-separator svg{height:12px;width:12px}}.pipeline-arrow{font-size:1.5rem;min-width:40px}.commission-pipeline-card{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.commission-pipeline-card:hover{box-shadow:0 8px 20px -8px #2f3a452e;box-shadow:var(--shadow-md);transform:translateY(-2px)}@media (max-width:900px){.pipeline-arrow{display:none!important}}.portal-feedback-notice{background:#f5f7f9;background:var(--color-bg);border:1px dashed #e2e6ea;border:1px dashed var(--color-border);border-radius:10px;color:#6b7280;color:var(--color-text-secondary);padding:2rem;text-align:center}.portal-feedback-notice p{margin:.5rem 0}.portal-feedback-status{font-size:.9rem;margin-top:1rem}.portal-feedback-form{background:#fff;border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;padding:1.5rem}.portal-feedback-intro{color:#6b7280;color:var(--color-text-secondary);font-size:.9375rem;margin-bottom:1.5rem}.portal-star-rating{margin-bottom:1.25rem}.portal-rating-label{color:#2f3a45;color:var(--color-text);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.portal-stars{display:flex;gap:.25rem}.portal-star{background:none;border:none;color:#c6c8d1;color:var(--color-muted);cursor:pointer;font-size:1.75rem;padding:0;transition:transform .1s ease}.portal-star:hover{transform:scale(1.15)}.portal-star.filled{color:#c9bfae;color:var(--color-warning)}.portal-checkbox-label{align-items:center;color:#2f3a45;color:var(--color-text);cursor:pointer;display:flex;font-size:.9375rem;gap:.5rem}.portal-checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.portal-feedback-submitted{background:linear-gradient(135deg,#e6f1ec,#fff);background:linear-gradient(135deg,var(--color-success-light) 0,var(--color-card-bg) 100%);border:1px solid #a9c7b6;border:1px solid var(--color-success);border-radius:12px;padding:1.5rem}.portal-feedback-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.portal-feedback-checkmark{align-items:center;background:#a9c7b6;background:var(--color-success);border-radius:50%;color:#fff;display:flex;font-size:1.25rem;height:32px;justify-content:center;width:32px}.portal-feedback-header h3{color:#a9c7b6;color:var(--color-success);font-size:1.125rem;margin:0}.portal-feedback-date{color:#6b7280;color:var(--color-text-secondary);font-size:.8125rem;margin-bottom:1rem}.portal-feedback-summary{background:#fff;border-radius:8px;margin-top:1rem;padding:1rem}.portal-feedback-rating-display{align-items:center;border-bottom:1px solid #e9e4de;border-bottom:1px solid var(--color-bg-secondary);display:flex;justify-content:space-between;padding:.5rem 0}.portal-feedback-rating-display:last-of-type{border-bottom:none}.portal-rating-stars{color:#c9bfae;color:var(--color-warning);font-size:1.25rem;letter-spacing:2px}.portal-feedback-recommend{background:#f3eee7;background:var(--color-warning-light);border-radius:6px;color:#c9bfae;color:var(--color-warning);font-size:.9375rem;margin-top:1rem;padding:.75rem}.portal-feedback-text{border-top:1px solid #e9e4de;border-top:1px solid var(--color-bg-secondary);margin-top:1rem;padding-top:1rem}.portal-feedback-text strong{color:#6b7280;color:var(--color-text-secondary);display:block;font-size:.8125rem;margin-bottom:.25rem}.portal-feedback-text p{color:#2f3a45;color:var(--color-text);font-size:.9375rem;margin:0}.portal-ack-intro{color:#6b7280;color:var(--color-text-secondary);font-size:.9375rem;margin-bottom:1.5rem}.portal-ack-list{display:flex;flex-direction:column;gap:1.5rem}.portal-ack-section{display:flex;flex-direction:column;gap:.75rem}.portal-ack-section-title{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.5px;margin:0;text-transform:none}.portal-ack-card{background:#fff;border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;padding:1.25rem;transition:box-shadow .15s ease}.portal-ack-card.pending{background:linear-gradient(135deg,#f3eee7,#fff);background:linear-gradient(135deg,var(--color-warning-light) 0,var(--color-card-bg) 100%);border-left:4px solid #c9bfae;border-left:4px solid var(--color-warning)}.portal-ack-card.confirmed{background:#f5f7f9;background:var(--color-bg);border-left:4px solid #a9c7b6;border-left:4px solid var(--color-success);opacity:.85}.portal-ack-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.portal-ack-type{border-radius:9999px;font-size:.6875rem;font-weight:600;letter-spacing:.5px;padding:.125rem .5rem;text-transform:none}.portal-ack-type.type-info{background:#e7eef4;background:var(--color-info-light);color:#6a93b2;color:var(--color-primary-dark)}.portal-ack-type.type-document{background:#e9e4de;background:var(--color-bg-secondary);color:#c6c8d1;color:var(--color-muted)}.portal-ack-type.type-itinerary{background:#e6f1ec;background:var(--color-success-light);color:#a9c7b6;color:var(--color-success)}.portal-ack-type.type-booking{background:#f3eee7;background:var(--color-warning-light);color:#c9bfae;color:var(--color-warning)}.portal-ack-type.type-payment{background:#f2edf0;background:var(--color-error-light);color:#b6a7b3;color:var(--color-error)}.portal-ack-type.type-terms{background:#f5f7f9;background:var(--color-bg)}.portal-ack-date,.portal-ack-type.type-terms{color:#6b7280;color:var(--color-text-secondary)}.portal-ack-date{font-size:.75rem}.portal-ack-title{color:#2f3a45;color:var(--color-text);font-size:1rem;font-weight:600;margin:0 0 .25rem}.portal-ack-desc{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5;margin:0 0 1rem}.portal-ack-btn{align-items:center;background:linear-gradient(135deg,#a9c7b6,#e6f1ec);background:linear-gradient(135deg,var(--color-success) 0,var(--color-success-light) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:transform .1s ease,box-shadow .15s ease}.portal-ack-btn:hover:not(:disabled){box-shadow:0 4px 12px #0596694d;transform:translateY(-1px)}.portal-ack-btn:disabled{cursor:not-allowed;opacity:.6}.role-editable{align-items:center;display:inline-flex;gap:.5rem}.btn-edit-role{background:none;border:none;cursor:pointer;font-size:.875rem;line-height:1;opacity:.5;padding:.25rem;transition:opacity .15s ease}.btn-edit-role:hover{opacity:1}.role-editor{align-items:center;display:inline-flex;flex-wrap:wrap;gap:.5rem}.role-select{background:#f5f7f9;background:var(--color-bg);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);font-size:.875rem;min-width:100px;padding:.375rem .5rem}.role-select:focus{border-color:#7da7c7;border-color:var(--color-primary);box-shadow:0 0 0 2px #7da7c72e;outline:none}.role-error{color:#b6a7b3;color:var(--color-error);display:block;font-size:.75rem;margin-top:.25rem;width:100%}.inactive-row{background:#e9e4de;background:var(--color-bg-secondary);opacity:.6}.status-indicator{align-items:center;display:inline-flex;font-size:.8125rem;font-weight:500;gap:.375rem}.status-indicator:before{border-radius:50%;content:"";height:8px;width:8px}.status-active:before{background:#a9c7b6;background:var(--color-success)}.status-inactive:before{background:#6b7280;background:var(--color-text-secondary)}.notification-prefs-list{display:flex;flex-direction:column;gap:12px}.notification-pref-item{align-items:center;background:#e9e4de;background:var(--color-bg-secondary);border:1px solid #e2e6ea;border:1px solid var(--color-border);border-radius:10px;border-radius:var(--border-radius);display:flex;justify-content:space-between;padding:12px 16px}.notification-pref-info{display:flex;flex-direction:column;gap:2px}.notification-pref-label{color:#2f3a45;color:var(--color-text);font-size:.9375rem;font-weight:500}.notification-pref-desc{color:#6b7280;color:var(--color-text-secondary);font-size:.8125rem}.toggle-switch{display:inline-block;flex-shrink:0;height:26px;position:relative;width:48px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#e2e6ea;background-color:var(--color-border);border-radius:26px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:20px;left:3px;position:absolute;transition:.3s;width:20px}.toggle-switch input:checked+.toggle-slider{background-color:#7da7c7;background-color:var(--color-primary)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 2px #1a56db33}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(22px)}.network-error-banner{animation:slideDown .3s ease-out;background-color:#f2edf0;background-color:var(--color-error-light);border-bottom:1px solid #b6a7b3;border-bottom:1px solid var(--color-error);left:0;padding:16px;padding:var(--spacing-md);position:fixed;right:0;top:0;z-index:10000}[data-theme=dark] .network-error-banner{background-color:#b6a7b3;background-color:var(--color-error);border-bottom-color:#b6a7b3;border-bottom-color:var(--color-error)}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.network-error-content{align-items:center;display:flex;gap:16px;gap:var(--spacing-md);margin:0 auto;max-width:1200px}.network-error-icon{align-items:center;color:#b6a7b3;color:var(--color-error);display:flex;flex-shrink:0;justify-content:center}.network-error-text{flex:1 1}.network-error-title{font-size:1rem;font-size:var(--font-size-base);font-weight:600}.network-error-message,.network-error-title,[data-theme=dark] .network-error-title{color:#b6a7b3;color:var(--color-error)}.network-error-message{font-size:.875rem;font-size:var(--font-size-sm);margin-top:2px}[data-theme=dark] .network-error-message{color:#b6a7b3;color:var(--color-error)}.network-error-actions{align-items:center;display:flex;flex-shrink:0;gap:8px;gap:var(--spacing-sm)}.network-error-retry{align-items:center;display:inline-flex;font-size:.875rem;font-size:var(--font-size-sm);gap:4px;gap:var(--spacing-xs);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.network-error-retry:disabled{cursor:not-allowed;opacity:.6}.network-error-dismiss{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--border-radius);cursor:pointer;display:flex;justify-content:center;padding:4px;padding:var(--spacing-xs);transition:background-color .15s}.network-error-dismiss,[data-theme=dark] .network-error-dismiss{color:#b6a7b3;color:var(--color-error)}.network-error-dismiss:hover{background-color:#991b1b1a}[data-theme=dark] .network-error-dismiss:hover{background-color:#fca5a51a}.network-error-fallback{align-items:center;background-color:#f5f7f9;background-color:var(--color-bg);display:flex;justify-content:center;min-height:100vh;padding:32px;padding:var(--spacing-xl)}.network-error-fallback-content{max-width:480px;text-align:center}.network-error-fallback-icon{background-color:#f2edf0;background-color:var(--color-error-light);border-radius:50%;color:#b6a7b3;color:var(--color-error);display:inline-flex;margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:24px;padding:var(--spacing-lg)}[data-theme=dark] .network-error-fallback-icon{background-color:#b6a7b3;background-color:var(--color-error)}.network-error-fallback-title{color:#2f3a45;color:var(--color-text);font-size:1.5rem;font-size:var(--font-size-2xl);font-weight:600;margin:0 0 16px;margin:0 0 var(--spacing-md)}.network-error-fallback-message{color:#6b7280;color:var(--color-text-secondary);font-size:1rem;font-size:var(--font-size-base);line-height:1.6;margin:0 0 32px;margin:0 0 var(--spacing-xl)}.network-error-fallback-actions{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.network-error-fallback-actions .btn{align-items:center;display:inline-flex;font-size:1rem;font-size:var(--font-size-base);gap:8px;gap:var(--spacing-sm);padding:16px 32px;padding:var(--spacing-md) var(--spacing-xl)}.network-error-fallback-actions .btn:disabled{cursor:not-allowed;opacity:.6}.network-error-fallback-hint{color:#6b7280;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--font-size-sm);margin:0}@media (max-width:640px){.network-error-content{flex-wrap:wrap}.network-error-text{flex-basis:100%;margin-top:8px;margin-top:var(--spacing-sm);order:2;text-align:center}.network-error-icon{order:1}.network-error-actions{flex-basis:100%;justify-content:center;margin-top:16px;margin-top:var(--spacing-md);order:3}}.form-field-footer{align-items:center;display:flex;justify-content:space-between;margin-top:4px;margin-top:var(--spacing-xs);min-height:20px}.form-field-footer .form-error-message{flex:1 1;margin:0}.character-count{color:#6b7280;color:var(--color-text-secondary);font-size:var(--font-size-xs);margin-left:auto;padding-left:8px;padding-left:var(--spacing-sm)}.character-count-warning{color:#c9bfae;color:var(--color-warning);font-weight:500}.character-count-error{color:#b6a7b3;color:var(--color-error);font-weight:600}.draft-restored-banner{align-items:center;background-color:#e7eef4;background-color:var(--color-info-bg,var(--color-info-light));border:1px solid #a5c0d6;border:1px solid var(--color-info-border,var(--color-primary-light));border-radius:10px;border-radius:var(--border-radius);color:#7da7c7;color:var(--color-info-text,var(--color-primary));display:flex;font-size:.875rem;font-size:var(--font-size-sm);gap:8px;gap:var(--spacing-sm);margin-bottom:16px;margin-bottom:var(--spacing-md);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.draft-restored-icon{flex-shrink:0;font-size:1.125rem;font-size:var(--font-size-lg)}.draft-restored-text{flex:1 1}.draft-restored-dismiss{background:none;border:none;color:#7da7c7;color:var(--color-info-text,var(--color-primary));cursor:pointer;font-size:1.125rem;font-size:var(--font-size-lg);line-height:1;opacity:.7;padding:4px;padding:var(--spacing-xs);transition:opacity var(--transition-fast)}.draft-restored-dismiss:hover{opacity:1}.form-dirty-indicator{animation:pulse 2s ease-in-out infinite;background-color:#c9bfae;background-color:var(--color-warning);border-radius:50%;display:inline-block;height:8px;margin-left:8px;margin-left:var(--spacing-sm);width:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.unsaved-changes-dialog{max-width:420px}.unsaved-warning-icon{color:#c9bfae;color:var(--color-warning);font-size:1.25em}.unsaved-changes-dialog .modal-body p{color:#6b7280;color:var(--color-text-secondary);line-height:1.5}.unsaved-changes-dialog .modal-footer{gap:16px;gap:var(--spacing-md)}.unsaved-changes-dialog .btn-danger{background-color:initial;border-color:#b6a7b3;border-color:var(--color-error);color:#b6a7b3;color:var(--color-error)}.unsaved-changes-dialog .btn-danger:hover{background-color:#b6a7b3;background-color:var(--color-error);color:#fff}
/*# sourceMappingURL=main.793c6bb5.css.map*/