:root{--color-primary-dark: #243044;--color-primary-light: #44546A;--color-secondary-dark: #70181A;--color-secondary-light: #E03A3E;--color-primary: #243044;--color-success: #2e7d32;--color-success-dark: #1b5e20;--color-success-light: #e8f5e9;--color-warning: #ed6c02;--color-warning-dark: #e65100;--color-warning-light: #fff3e0;--color-warning-bg: #fff3cd;--color-error: #d32f2f;--color-error-dark: #c62828;--color-error-light: #ffebee;--color-error-bg: #ffebee;--color-accent-teal: #458F9C;--color-accent-teal-dark: #2d5f6a;--color-accent-teal-darker: #1e3f47;--color-accent-teal-light: #6ba8b3;--color-accent-teal-lighter: #9ac6ce;--color-accent-teal-lightest: #cfe5e9;--color-accent-green: #38BDA0;--color-accent-green-dark: #2a8f7a;--color-accent-green-darker: #1d6054;--color-accent-green-light: #61cdb3;--color-accent-green-lighter: #93ddc9;--color-accent-green-lightest: #d1f1e8;--color-accent-yellow: #EEB959;--color-accent-yellow-dark: #d49e38;--color-accent-yellow-darker: #a67a25;--color-accent-yellow-light: #f3ca7f;--color-accent-yellow-lighter: #f7dba5;--color-accent-yellow-lightest: #fcf0d9;--color-accent-orange: #E98645;--color-accent-orange-dark: #c96d2d;--color-accent-orange-darker: #9e5420;--color-accent-orange-light: #efa36e;--color-accent-orange-lighter: #f5c09a;--color-accent-orange-lightest: #fbe5d4;--color-white: #ffffff;--color-gray-light: #f5f5f5;--color-gray: #e0e0e0;--color-gray-dark: #666666;--color-text-primary: #213547;--color-text-secondary: #666666;--color-text-muted: #666666;--color-text-muted-light: #eeeeee;--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f5;--color-bg-hover: #f0f0f0;--color-border: #e0e0e0;--color-surface: #ffffff;--color-surface-alt: #f5f5f5;--color-primary-hover: #1b2838;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15), 0 8px 10px rgba(0, 0, 0, .08);--shadow-2xl: 0 25px 50px rgba(0, 0, 0, .2);--shadow-teal: 0 4px 12px rgba(69, 143, 156, .15);--shadow-red: 0 4px 12px rgba(224, 58, 62, .2);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;font-family:Arial,Helvetica,sans-serif;line-height:1.5;font-weight:400;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;color-scheme:light;color:var(--color-text-primary);background-color:var(--color-white);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-secondary-light);text-decoration:inherit}a:hover{color:var(--color-secondary-dark)}html,body,#root{margin:0;padding:0;width:100%;height:100%;min-height:100vh;background:#f0f2f5}h1{font-size:3.2em;line-height:1.1}button{border-radius:6px;border:1px solid transparent;padding:.6em 1.5em;font-size:1em;font-weight:600;font-family:inherit;background:linear-gradient(180deg,var(--color-secondary-light) 0%,var(--color-secondary-dark) 100%);color:var(--color-white);cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);text-transform:none;position:relative;overflow:hidden}button:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .2s ease}button:hover:before{opacity:1}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-red)}button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}button:focus,button:focus-visible{outline:3px solid var(--color-secondary-light);outline-offset:2px}button:disabled{background:var(--color-gray);color:var(--color-gray-dark);cursor:not-allowed;transform:none;box-shadow:none}button:disabled:before{display:none}button.btn-secondary{background:var(--color-white);color:var(--color-primary-dark);border:2px solid var(--color-primary-dark)}button.btn-secondary:before{background:var(--color-primary-dark);opacity:0}button.btn-secondary:hover{color:var(--color-white);box-shadow:var(--shadow-md)}button.btn-secondary:hover:before{opacity:1}button.btn-teal{background:linear-gradient(180deg,var(--color-accent-teal) 0%,var(--color-accent-teal-dark) 100%)}button.btn-teal:hover{box-shadow:var(--shadow-teal)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg-secondary);gap:1.5rem}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-gray);border-top-color:var(--color-accent-teal);border-radius:50%;animation:loading-spin .8s linear infinite}.loading-container p{color:var(--color-text-secondary);font-size:1rem;font-weight:500;margin:0}@keyframes loading-spin{to{transform:rotate(360deg)}}.new-user-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.new-user-modal{background:var(--color-surface, #fff);border-radius:12px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.new-user-modal-header{padding:24px 24px 0}.new-user-modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.new-user-modal-body{padding:20px 24px}.new-user-modal-body p{margin:0 0 12px;color:var(--color-text-secondary, #666);line-height:1.5}.new-user-modal-body p strong{color:var(--color-text-primary, #1a1a1a)}.new-user-modal-features{background:var(--color-surface-alt, #f5f5f5);border-radius:8px;padding:16px;margin-top:16px}.new-user-modal-features p{margin:0 0 8px;font-weight:500;color:var(--color-text-primary, #1a1a1a)}.new-user-modal-features ul{margin:0;padding-left:20px}.new-user-modal-features li{color:var(--color-text-secondary, #666);margin-bottom:4px}.new-user-modal-error{background:var(--color-error-bg, #fef2f2);color:var(--color-error, #dc2626);padding:12px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.new-user-modal-field{margin-bottom:16px}.new-user-modal-field label{display:block;margin-bottom:6px;font-weight:500;color:var(--color-text-primary, #1a1a1a)}.new-user-modal-field input{width:100%;padding:10px 14px;border:1px solid var(--color-border, #e0e0e0);border-radius:8px;font-size:1rem;background:var(--color-surface, #fff);color:var(--color-text-primary, #1a1a1a);transition:border-color .2s,box-shadow .2s}.new-user-modal-field input:focus{outline:none;border-color:var(--color-primary, #2563eb);box-shadow:0 0 0 3px #2563eb1a}.new-user-modal-field input.disabled{background:var(--color-surface-alt, #f5f5f5);color:var(--color-text-secondary, #666);cursor:not-allowed}.new-user-modal-field .field-note{display:block;margin-top:4px;font-size:.8rem;color:var(--color-text-muted, #999)}.new-user-modal-actions{display:flex;gap:12px;padding:16px 24px 24px}.new-user-modal-btn{flex:1;padding:12px 20px;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s}.new-user-modal-btn.primary{background:var(--color-primary, #2563eb);color:#fff;border:none}.new-user-modal-btn.primary:hover:not(:disabled){background:var(--color-primary-hover, #1d4ed8)}.new-user-modal-btn.secondary{background:transparent;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #e0e0e0)}.new-user-modal-btn.secondary:hover:not(:disabled){background:var(--color-surface-alt, #f5f5f5)}.new-user-modal-btn:disabled{opacity:.6;cursor:not-allowed}.session-timeout-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.session-timeout-modal{background:var(--color-surface, #fff);border-radius:12px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;overflow:hidden;text-align:center}.session-timeout-modal-header{padding:24px 24px 0}.session-timeout-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-warning-bg, #fef3c7);color:var(--color-warning, #d97706);border-radius:50%;margin-bottom:16px}.session-timeout-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.session-timeout-modal-body{padding:20px 24px}.session-timeout-modal-body p{margin:0 0 8px;color:var(--color-text-secondary, #666);line-height:1.5}.session-timeout-countdown{font-size:3rem;font-weight:700;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;color:var(--color-warning, #d97706);padding:16px 0;letter-spacing:2px}.session-timeout-hint{font-size:.9rem;color:var(--color-text-muted, #999);margin-top:12px}.session-timeout-modal-actions{display:flex;gap:12px;padding:16px 24px 24px}.session-timeout-btn{flex:1;padding:12px 20px;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s}.session-timeout-btn.primary{background:var(--color-primary, #2563eb);color:#fff;border:none}.session-timeout-btn.primary:hover:not(:disabled){background:var(--color-primary-hover, #1d4ed8)}.session-timeout-btn.secondary{background:transparent;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #e0e0e0)}.session-timeout-btn.secondary:hover:not(:disabled){background:var(--color-surface-alt, #f5f5f5)}.session-timeout-btn:disabled{opacity:.6;cursor:not-allowed}.terms-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.terms-modal{background:var(--color-surface, #fff);border-radius:12px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.terms-modal-header{padding:24px 24px 0;text-align:center}.terms-modal-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:#e8f4fd;color:#1976d2;border-radius:50%;margin-bottom:16px}.terms-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.terms-modal-body{padding:20px 24px 24px}.terms-modal-body>p{margin:0 0 16px;color:var(--color-text-secondary, #666);line-height:1.5;font-size:.95rem;text-align:center}.terms-list{display:flex;flex-direction:column;gap:10px}.terms-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1px solid var(--color-border, #e0e0e0);border-radius:8px;background:var(--color-surface-alt, #fafafa)}.terms-item.accepted{border-color:#4caf50;background:#f1f8e9}.terms-item-info{display:flex;flex-direction:column;gap:2px}.terms-item-title{font-weight:600;font-size:.95rem;color:var(--color-text-primary, #1a1a1a)}.terms-item-version{font-size:.75rem;color:var(--color-text-muted, #999)}.terms-accept-btn{padding:8px 20px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s;background:var(--color-primary, #2563eb);color:#fff;border:none}.terms-accept-btn:hover:not(:disabled){background:var(--color-primary-hover, #1d4ed8)}.terms-accept-btn:disabled{opacity:.6;cursor:not-allowed}.terms-accepted-check{display:flex;align-items:center;gap:6px;color:#4caf50;font-weight:600;font-size:.9rem}.terms-accepted-check svg{flex-shrink:0}.terms-item.has-content{flex-direction:column;align-items:stretch}.terms-item.has-content>.terms-item-info{display:flex;justify-content:space-between;align-items:center;flex-direction:row}.terms-item-content{max-height:200px;overflow-y:auto;white-space:pre-wrap;border:1px solid var(--color-border, #e0e0e0);border-radius:6px;padding:12px;margin-top:8px;font-size:.85rem;line-height:1.5;color:var(--color-text-primary, #333);background:#fff}.solution-panel h2,.solution-panel .panel-hint{flex-shrink:0}.solution-grid{display:flex;flex-direction:column;gap:.75rem;flex:1;overflow-y:auto;padding-right:.5rem}.solution-card{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e0e0e0);border-radius:8px;padding:1rem;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);position:relative;overflow:hidden}.solution-card:hover{border-color:var(--color-accent-teal);box-shadow:var(--shadow-teal);transform:translateY(-2px)}.solution-card-image{width:100%;height:80px;margin-bottom:.75rem;border-radius:4px;overflow:hidden;background:var(--color-background, #f5f5f5)}.solution-card-image img{width:100%;height:100%;object-fit:cover}.solution-card-content{display:flex;flex-direction:column;gap:.5rem}.solution-card-name{margin:0;font-size:1rem;font-weight:600;color:var(--color-text, #333333)}.solution-card-description{margin:0;font-size:.8rem;color:var(--color-text-secondary, #666666);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.solution-card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem}.solution-card-parts{font-size:.75rem;color:var(--color-text-secondary, #666666);background:var(--color-background, #f5f5f5);padding:.25rem .5rem;border-radius:4px}.solution-card-cta{font-size:.8rem;font-weight:500;color:var(--color-primary, #0066cc)}.solution-card.disabled{opacity:.5;cursor:not-allowed}.solution-card.disabled:hover{border-color:var(--color-border, #e0e0e0);box-shadow:none;transform:none}.panel-hint.email-required{color:var(--color-warning, #b36b00);background:var(--color-warning-bg, #fff8e6);padding:.75rem 1rem;border-radius:4px;border:1px solid var(--color-warning-border, #ffe0a3)}.solution-card-no-access{font-size:.8rem;font-weight:500;color:var(--color-text-muted, #999);font-style:italic}.solution-card.coming-soon{opacity:.7;cursor:pointer}.solution-card.coming-soon:hover{border-color:var(--color-accent-yellow);box-shadow:0 4px 12px #eeb95926;transform:translateY(-1px)}.solution-card-coming-soon{font-size:.8rem;font-weight:600;color:var(--color-accent-yellow-dark, #d49e38);background:var(--color-accent-yellow-lightest, #fcf0d9);padding:.25rem .5rem;border-radius:4px}.coming-soon-message{background:var(--color-accent-yellow-lightest, #fcf0d9);border:1px solid var(--color-accent-yellow, #EEB959);color:var(--color-accent-yellow-darker, #a67a25);padding:.75rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;margin-bottom:.75rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.solution-panel{height:auto;max-height:none;overflow-y:visible}.solution-grid{overflow-y:visible;padding-right:0;gap:1rem}.solution-card{padding:1.25rem}.solution-card-title{font-size:1.125rem}.solution-card-description{font-size:.9375rem;-webkit-line-clamp:3}.solution-card-actions .btn-configure{min-height:44px;padding:.75rem 1rem;font-size:.9375rem}.solution-loading,.solution-error{min-height:200px}.solutions-hint{font-size:.875rem}}.modal-overlay{position:fixed;inset:0;background:#243044cc;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.modal-content{background:var(--color-white);border-radius:8px;width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #2430444d;position:relative}.modal-content.pandadoc-combined-modal{max-width:650px}.modal-header{padding:2rem 2rem 1.5rem;border-bottom:3px solid var(--color-secondary-light);background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary-light) 100%);position:relative;overflow:hidden}.modal-header:before{content:"";position:absolute;top:0;right:0;width:300px;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.05) 30%,rgba(255,255,255,.05) 70%,transparent 70%);background-size:20px 20px;opacity:.3}.modal-header-content{display:flex;align-items:center;gap:1rem;position:relative;z-index:1}.modal-logo{height:45px;width:auto}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-white)!important;flex:1}.modal-close{position:absolute;top:1.5rem;right:1.5rem;background:#ffffff1a;border:none;font-size:1.5rem;color:var(--color-white);cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;font-weight:300;z-index:10}.modal-close:hover{background:#fff3;transform:rotate(90deg)}.modal-body{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;background:radial-gradient(circle at 100% 0%,rgba(69,143,156,.03) 0%,transparent 50%),radial-gradient(circle at 0% 100%,rgba(224,58,62,.03) 0%,transparent 50%),var(--color-white)}.form-section{display:flex;flex-direction:column;gap:1rem}.form-section h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-primary-dark);padding-bottom:.5rem;border-bottom:2px solid var(--color-gray-light)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem}@media(max-width:500px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-group label{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.025em}.form-group input{padding:.5rem .75rem;border:1px solid var(--color-gray);border-radius:4px;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus{outline:none;border-color:var(--color-accent-teal);box-shadow:0 0 0 3px #458f9c1a}.form-group input::placeholder{color:#aaa}.form-group input.disabled-input{background:var(--color-gray-light);color:var(--color-text-secondary);cursor:not-allowed}.form-group input:disabled{background:var(--color-gray-light);color:var(--color-text-secondary);cursor:not-allowed}.field-hint{font-size:.7rem;color:var(--color-text-secondary);font-style:italic}.doc-preview{padding:1.25rem;background:var(--color-gray-light);border-radius:6px;border-left:4px solid var(--color-accent-teal);font-size:.875rem;display:flex;flex-direction:column;gap:.625rem}.doc-preview p{margin:0;color:var(--color-text-secondary);line-height:1.6}.doc-preview strong{color:var(--color-primary-dark);font-weight:600}.error-message{padding:1rem;background:#fee2e2;border:1px solid var(--color-secondary-light);border-left:4px solid var(--color-secondary-dark);border-radius:6px;color:var(--color-secondary-dark);font-size:.875rem;font-weight:500;line-height:1.5}.success-message{padding:1rem;background:#d1fae5;border:1px solid var(--color-accent-green);border-left:4px solid var(--color-accent-green);border-radius:6px;color:#065f46;font-size:.875rem;display:flex;flex-direction:column;gap:.5rem}.success-message p{margin:0;font-weight:600}.success-message a{color:var(--color-accent-teal);font-weight:500;text-decoration:none;transition:color .2s ease}.success-message a:hover{color:var(--color-primary-dark);text-decoration:underline}.modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--color-gray);display:flex;flex-direction:column;gap:.75rem;background:var(--color-gray-light)}.modal-footer .btn-secondary{background-color:var(--color-white);color:var(--color-primary-dark);border:2px solid var(--color-primary-dark);padding:.75rem 1.5rem;font-weight:600;transition:all .2s ease;width:100%}.modal-footer .btn-secondary:hover:not(:disabled){background-color:var(--color-primary-dark);color:var(--color-white)}.modal-footer .btn-primary{background-color:var(--color-secondary-light);color:var(--color-white);border:none;padding:.75rem 1.5rem;font-weight:600;transition:all .2s ease;width:100%}.modal-footer .btn-primary:hover:not(:disabled){background-color:var(--color-secondary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #e03a3e4d}.modal-footer .btn-primary:disabled,.modal-footer .btn-secondary:disabled{background-color:var(--color-gray);color:var(--color-gray-dark);border-color:var(--color-gray);cursor:not-allowed;opacity:.6;transform:none;box-shadow:none}.share-modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:560px;max-height:90vh;overflow-y:auto}.share-config-name{padding:0 1.5rem;font-size:.95rem;color:var(--color-text-secondary, #666);font-family:monospace;background:var(--color-bg-secondary, #f5f5f5);padding:.5rem 1.5rem;border-bottom:1px solid var(--color-border, #eee)}.existing-shares{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border, #eee)}.existing-shares h3{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--color-text-primary, #333)}.shares-loading,.no-shares{font-size:.9rem;color:var(--color-text-muted, #666);padding:.5rem 0}.shares-list{list-style:none;padding:0;margin:0}.share-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;background:var(--color-bg-secondary, #f8f9fa);border-radius:6px;margin-bottom:.5rem}.share-item:last-child{margin-bottom:0}.share-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex:1}.share-type-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:.15rem .4rem;border-radius:4px}.share-type-badge.user{background:var(--color-info-bg, #e3f2fd);color:var(--color-info, #1565c0)}.share-type-badge.company{background:var(--color-purple-bg, #f3e5f5);color:var(--color-purple, #7b1fa2)}.share-target{font-weight:500;color:var(--color-text-primary, #333)}.share-email,.share-gp-id{font-size:.8rem;color:var(--color-text-muted, #666)}.permission-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:.15rem .4rem;border-radius:4px}.permission-badge.view{background:var(--color-success-bg, #e8f5e9);color:var(--color-success, #2e7d32)}.permission-badge.edit{background:var(--color-warning-bg, #fff3e0);color:var(--color-warning, #ef6c00)}.expires-at{font-size:.75rem;color:var(--color-text-muted, #888)}.btn-remove-share{padding:.3rem .6rem;font-size:.8rem;background:transparent;color:var(--color-error, #c62828);border:1px solid var(--color-error, #c62828);border-radius:4px;cursor:pointer;transition:all .15s}.btn-remove-share:hover:not(:disabled){background:var(--color-error, #c62828);color:#fff}.btn-remove-share:disabled{opacity:.5;cursor:not-allowed}.share-form{padding:1.5rem}.share-form h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--color-text-primary, #333)}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.share-type-group{flex:1}.permission-group{flex:0 0 140px}.share-type-toggle{display:flex;border:1px solid var(--color-border, #ddd);border-radius:6px;overflow:hidden}.toggle-btn{flex:1;padding:.5rem 1rem;border:none;background:transparent;font-size:.9rem;cursor:pointer;transition:all .15s;color:var(--color-text-secondary, #666)}.toggle-btn.active{background:var(--color-primary, #1976d2);color:#fff}.toggle-btn:not(.active):hover{background:var(--color-bg-secondary, #f5f5f5)}.permission-group select{width:100%;padding:.5rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.9rem;background:#fff}.search-group{position:relative}.search-indicator{position:absolute;right:.75rem;top:2.1rem;font-size:.8rem;color:var(--color-text-muted, #888)}.selected-target{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;background:var(--color-success-bg, #e8f5e9);border:1px solid var(--color-success, #4caf50);border-radius:6px}.selected-label{font-size:.8rem;font-weight:600;color:var(--color-success, #2e7d32)}.selected-value{flex:1;font-size:.9rem;color:var(--color-text-primary, #333)}.selected-email,.selected-gp-id{font-size:.85rem;color:var(--color-text-muted, #666)}.btn-clear-selection{background:none;border:none;font-size:1.2rem;color:var(--color-text-muted, #666);cursor:pointer;padding:0 .25rem;line-height:1}.btn-clear-selection:hover{color:var(--color-error, #c62828)}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--color-border, #ddd);border-radius:6px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto;z-index:10;list-style:none;padding:0;margin:.25rem 0 0}.search-result-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;cursor:pointer;transition:background .15s}.search-result-item:hover{background:var(--color-bg-secondary, #f5f5f5)}.result-name{font-weight:500;color:var(--color-text-primary, #333)}.result-email,.result-gp-id{font-size:.85rem;color:var(--color-text-muted, #666)}.share-modal-content .form-group{margin-bottom:1rem;position:relative}.share-modal-content .form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--color-text-primary, #333);font-size:.9rem}.share-modal-content .form-group input,.share-modal-content .form-group select{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.9rem}.share-modal-content .form-group input:focus,.share-modal-content .form-group select:focus{outline:none;border-color:var(--color-primary, #1976d2)}.share-modal-content .form-hint{display:block;margin-top:.35rem;font-size:.8rem;color:var(--color-text-muted, #666)}.share-modal-content .form-error{padding:.75rem 1rem;background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828);border-radius:6px;margin-bottom:1rem;font-size:.9rem}.share-modal-content .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;margin-top:.5rem}.company-target-group .company-target-display{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--color-purple-bg, #f3e5f5);border:1px solid var(--color-purple, #9c27b0);border-radius:6px}.company-target-display .company-name{font-weight:600;color:var(--color-text-primary, #333)}.company-target-display .company-gp-id{font-size:.85rem;color:var(--color-text-muted, #666);font-family:monospace}.company-target-group .no-company-selected{padding:.75rem 1rem;background:var(--color-warning-bg, #fff3e0);border:1px solid var(--color-warning, #ef6c00);border-radius:6px;font-size:.9rem;color:var(--color-warning, #ef6c00)}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.delete-modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.delete-modal-body{padding:1.5rem;text-align:center}.delete-warning-icon{width:60px;height:60px;margin:0 auto 1rem;border-radius:50%;background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828);font-size:2rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:3px solid var(--color-error, #c62828)}.delete-confirm-text{font-size:1.1rem;color:var(--color-text-primary, #333);margin:0 0 1rem}.delete-config-name{font-family:monospace;font-size:1rem;font-weight:600;padding:.75rem 1rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:6px;color:var(--color-text-primary, #333);margin-bottom:1rem}.delete-external-warning{padding:.75rem 1rem;background:var(--color-info-bg, #e3f2fd);border:1px solid var(--color-info, #1565c0);border-radius:6px;font-size:.9rem;color:var(--color-info, #1565c0);text-align:left;margin-bottom:1rem}.delete-external-warning strong{text-transform:capitalize}.delete-shares-loading{font-size:.9rem;color:var(--color-text-muted, #666);padding:.5rem 0}.delete-shares-warning{padding:1rem;background:var(--color-warning-bg, #fff3e0);border:1px solid var(--color-warning, #ef6c00);border-radius:6px;text-align:left;margin-bottom:1rem}.shares-warning-header{font-size:.9rem;font-weight:600;color:var(--color-warning, #ef6c00);margin-bottom:.75rem}.delete-shares-list{list-style:none;padding:0;margin:0;max-height:150px;overflow-y:auto}.delete-share-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.9rem;color:var(--color-text-primary, #333);border-bottom:1px solid rgba(0,0,0,.1)}.delete-share-item:last-child{border-bottom:none}.delete-share-item .share-type-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;padding:.15rem .4rem;border-radius:4px}.delete-share-item .share-type-badge.user{background:var(--color-info-bg, #e3f2fd);color:var(--color-info, #1565c0)}.delete-share-item .share-type-badge.company{background:var(--color-purple-bg, #f3e5f5);color:var(--color-purple, #7b1fa2)}.delete-error{padding:.75rem 1rem;background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828);border-radius:6px;font-size:.9rem;text-align:left}.delete-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border, #eee);background:var(--color-bg-secondary, #f8f9fa);border-radius:0 0 8px 8px}.btn-delete{padding:.6rem 1.25rem;background:var(--color-error, #c62828);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-delete:hover:not(:disabled){background:var(--color-error-dark, #b71c1c)}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.filter-modal-content{background:#fff;border-radius:12px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.filter-modal-content .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e9ecef}.filter-modal-content .modal-header h2{margin:0;font-size:1.1rem;color:#1a1a2e}.filter-modal-content .modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;line-height:1}.filter-modal-content .modal-close:hover{color:#333}.filter-section{padding:1rem 1.25rem;border-bottom:1px solid #f0f0f0}.filter-section:last-of-type{border-bottom:none}.filter-section h3{margin:0 0 .75rem;font-size:.85rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.3px}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#333}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-secondary-light, #c62828)}.filter-section input[type=text],.filter-section input[type=number],.filter-section input[type=date]{width:100%;padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;transition:border-color .15s}.filter-section input:focus,.filter-section select:focus{outline:none;border-color:var(--color-secondary-light, #c62828)}.solution-type-select{width:100%;padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer;transition:border-color .15s}.solution-type-select:hover{border-color:#bbb}.price-range-inputs{display:flex;align-items:center;gap:.5rem}.price-range-inputs input{flex:1}.range-separator{font-size:.85rem;color:#888}.date-range-inputs{display:flex;gap:1rem}.date-input-group{flex:1;display:flex;flex-direction:column;gap:.25rem}.date-input-group label{font-size:.75rem;color:#888}.filter-modal-content .modal-actions{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid #e9ecef;background:#f8f9fa;border-radius:0 0 12px 12px}.filter-modal-content .btn-reset{margin-right:auto;padding:.5rem 1rem;background:transparent;color:#888;border:none;border-radius:6px;font-size:.85rem;cursor:pointer}.filter-modal-content .btn-reset:hover{color:#c62828}.filter-modal-content .btn-cancel{padding:.5rem 1rem;background:transparent;color:#666;border:1px solid #ddd;border-radius:6px;font-size:.85rem;cursor:pointer}.filter-modal-content .btn-cancel:hover{background:#f0f0f0}.filter-modal-content .btn-apply{padding:.5rem 1rem;background:var(--color-secondary-light, #c62828);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer}.filter-modal-content .btn-apply:hover{background:var(--color-secondary-dark, #8b0000)}.saved-configs-panel{height:fit-content;max-height:100%;overflow-y:auto;padding:1rem;background:#fff;border-radius:8px;box-shadow:var(--shadow-sm);transition:box-shadow .3s ease}.saved-configs-panel:hover{box-shadow:var(--shadow-md)}.saved-configs-panel .panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.saved-configs-panel .panel-header h2{margin:0;font-size:1.1rem;color:#1a1a2e;position:relative;padding-bottom:.5rem}.saved-configs-panel .panel-header h2:after{content:"";position:absolute;bottom:0;left:0;width:50px;height:3px;background:var(--color-secondary-light);border-radius:2px}.saved-configs-panel h2{margin:0 0 1rem;font-size:1.1rem;color:#1a1a2e;position:relative;padding-bottom:.5rem}.saved-configs-panel h2:after{content:"";position:absolute;bottom:.5rem;left:0;width:50px;height:3px;background:var(--color-secondary-light);border-radius:2px}.btn-filter{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#f0f0f0;border:1px solid #ddd;border-radius:6px;cursor:pointer;color:#666;transition:all .15s}.btn-filter:hover{background:#e0e0e0;color:#333}.btn-filter.active{background:var(--color-secondary-light, #c62828);border-color:var(--color-secondary-light, #c62828);color:#fff}.btn-filter.active:hover{background:var(--color-secondary-dark, #8b0000)}.filter-badge{position:absolute;top:-3px;right:-3px;width:8px;height:8px;background:#4caf50;border-radius:50%;border:2px solid white}.configs-section{margin-bottom:1.5rem}.configs-section:last-child{margin-bottom:0}.configs-section-header{font-size:.8rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e9ecef;display:flex;align-items:center;justify-content:space-between}.configs-section-header .count{background:#e9ecef;padding:.15rem .5rem;border-radius:10px;font-size:.7rem;font-weight:600}.configs-section.company-configs .configs-section-header{color:var(--color-accent-teal-dark);border-bottom-color:var(--color-accent-teal-lightest)}.configs-section.company-configs .configs-section-header .count{background:var(--color-accent-teal-lightest);color:var(--color-accent-teal-dark)}.config-card{position:relative;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:.75rem;margin-bottom:.5rem;transition:border-color .15s,background .15s;overflow:hidden}.config-card:last-child{margin-bottom:0}.config-card:hover{border-color:var(--color-secondary-light, #c62828);background:#fef2f2}.config-card>*{position:relative;z-index:1}.config-card-header{margin-bottom:.25rem;padding-right:60px}.config-card-name{font-size:.8rem;font-weight:600;color:var(--color-secondary-light, #c62828);font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;word-break:break-all}.config-card-sku{font-size:.7rem;color:#888;margin-bottom:.5rem}.config-card-info{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;margin-bottom:.75rem}.config-card-price{font-weight:600;color:#1a1a2e}.config-card-date{font-size:.7rem;color:#888}.config-card-actions{display:flex;gap:.5rem}.config-card-actions button{flex:1;padding:.4rem .5rem;font-size:.75rem;font-weight:500;border-radius:4px;cursor:pointer;transition:background .15s,color .15s}.config-card-actions button:disabled{opacity:.6;cursor:not-allowed}.btn-edit{background:transparent;color:var(--color-secondary-light, #c62828);border:1px solid var(--color-secondary-light, #c62828)}.btn-edit:hover:not(:disabled){background:var(--color-secondary-light, #c62828);color:#fff}.btn-view{background:transparent;color:#1976d2;border:1px solid #1976d2}.btn-view:hover:not(:disabled){background:#1976d2;color:#fff}.config-card-corner-actions{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.25rem;z-index:10}.btn-corner-action{width:26px;height:26px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;color:#999;border:none;border-radius:4px;cursor:pointer;transition:all .15s}.btn-corner-action:disabled{opacity:.5;cursor:not-allowed}.btn-corner-action svg{flex-shrink:0}.btn-share-corner:hover:not(:disabled){background:#e3f2fd;color:#1565c0}.btn-delete-corner:hover:not(:disabled){background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828)}.btn-add-cart{background:var(--color-secondary-light, #c62828);color:#fff;border:none}.btn-add-cart:hover:not(:disabled){background:var(--color-secondary-dark, #8b0000)}.configs-loading{padding:2rem 1rem;text-align:center;color:#888}.configs-loading .loading-spinner{width:32px;height:32px;border:3px solid var(--color-accent-teal-lightest);border-top-color:var(--color-accent-teal);border-radius:50%;animation:spin .7s cubic-bezier(.68,-.55,.265,1.55) infinite;margin:0 auto .75rem}.configs-loading p{font-size:.85rem;margin:0}.configs-empty{padding:1.5rem 1rem;text-align:center;color:#888}.configs-empty p{margin:0 0 .5rem;font-size:.85rem}.configs-empty p:last-child{margin-bottom:0}.configs-empty-hint{font-size:.75rem;color:#aaa}.btn-clear-filters{margin-top:.75rem;padding:.4rem 1rem;background:transparent;color:var(--color-secondary-light, #c62828);border:1px solid var(--color-secondary-light, #c62828);border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .15s}.btn-clear-filters:hover{background:var(--color-secondary-light, #c62828);color:#fff}.configs-error{padding:1rem;background:#ffebee;color:#c62828;border-radius:6px;font-size:.85rem;text-align:center}.configs-error p{margin:0 0 .75rem}.configs-error button{padding:.4rem 1rem;background:#c62828;color:#fff;border:none;border-radius:4px;font-size:.8rem;cursor:pointer}.configs-error button:hover{background:#8b0000}.saved-configs-panel::-webkit-scrollbar{width:6px}.saved-configs-panel::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.saved-configs-panel::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.saved-configs-panel::-webkit-scrollbar-thumb:hover{background:#aaa}@media(max-width:768px){.saved-configs-panel{max-height:none;height:auto;min-height:300px;overflow-y:visible}.btn-filter{width:44px;height:44px}.config-card-corner-actions button{width:40px;height:40px;padding:.5rem}.config-card-corner-actions svg{width:18px;height:18px}.config-card-actions{flex-direction:column;gap:.5rem;align-items:stretch}.config-card-actions button{width:100%;justify-content:center}.config-card-title{font-size:1rem}.config-card-meta{font-size:.875rem}.section-title{font-size:1rem}.saved-configs-panel::-webkit-scrollbar{display:none}}.company-selector{position:relative}.company-selector-trigger{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;max-width:200px}.company-selector-trigger:hover{background:#ffffff40;border-color:#ffffff80}.company-selector-display{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:4px;font-size:.8rem;font-weight:500;max-width:200px}.company-icon{display:flex;align-items:center;opacity:.8}.company-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;text-align:left}.company-dropdown-arrow{display:flex;align-items:center;opacity:.7;transition:transform .15s}.company-selector-trigger[aria-expanded=true] .company-dropdown-arrow{transform:rotate(180deg)}.company-selector-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:280px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:1000;overflow:hidden}.dropdown-header{padding:.75rem 1rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#888}.dropdown-divider{height:1px;background:#eee;margin:.25rem 0}.dropdown-item{display:flex;align-items:flex-start;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}.dropdown-item:hover{background:#f5f5f5}.dropdown-item.active{background:#e8f4fd}.item-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;flex-shrink:0;margin-top:2px}.item-icon.personal{background:#f0f0f0;color:#666}.item-icon.company{background:#e3f2fd;color:#1976d2}.item-content{flex:1;min-width:0}.item-name{display:block;font-size:.9rem;font-weight:500;color:#333;margin-bottom:.15rem}.item-desc{display:block;font-size:.75rem;color:#888}.item-meta{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#888}.role-badge{display:inline-block;padding:.1rem .35rem;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase}.role-badge.admin{background:#fff3e0;color:#e65100}.gp-id{font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.7rem}.item-check{color:#1976d2;font-weight:600;font-size:.9rem;margin-left:auto;padding-left:.5rem}.persona-badge{display:inline-block;padding:.1rem .4rem;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.persona-badge-dropdown{display:inline-block;margin-left:6px;padding:.1rem .35rem;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:capitalize;vertical-align:middle}.persona-badge-dropdown.type-internal{background:#e3f2fd;color:#1565c0}.persona-badge-dropdown.type-vendor{background:#f3e5f5;color:#7b1fa2}.persona-badge-dropdown.type-integrator{background:#e8f5e9;color:#2e7d32}.persona-badge-dropdown.type-client{background:#fff3e0;color:#e65100}.persona-badge-dropdown.type-public{background:#f5f5f5;color:#616161}.mobile-tab-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--color-surface, #ffffff);border-top:1px solid var(--color-border, #e0e0e0);padding:.5rem 0;z-index:1000;box-shadow:0 -2px 8px #0000001a}@media(max-width:768px){.mobile-tab-nav{display:flex;justify-content:space-around;align-items:center}}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;background:transparent;border:none;color:var(--color-text-secondary, #666);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);position:relative;min-height:56px;min-width:56px}.mobile-tab:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:0;height:3px;background:var(--color-accent-teal);border-radius:0 0 3px 3px;transition:width var(--duration-normal) var(--ease-spring)}.mobile-tab.active:before{width:60%}.mobile-tab:active{background:var(--color-surface-alt, #f5f5f5);transform:scale(.95)}.mobile-tab.active{color:var(--color-accent-teal)}.mobile-tab-icon{width:24px;height:24px;stroke-width:2}.mobile-tab-label{font-size:.75rem;font-weight:500;position:relative;display:flex;align-items:center;gap:.25rem}.mobile-tab-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--color-secondary-light, #E03A3E);color:#fff;font-size:.65rem;font-weight:700;min-width:20px;height:20px;padding:0 .3rem;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);animation:fadeInScale var(--duration-normal) var(--ease-spring)}.mobile-tab:focus-visible{outline:2px solid var(--color-primary, #2563eb);outline-offset:-2px}.display-rules-toolbar{display:flex;align-items:center;gap:.6rem;padding:.3rem .6rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:6px;font-size:.75rem}.display-rules-toolbar.has-overrides{border-color:#f59e0b;background:#f59e0b1a}.override-indicator{width:8px;height:8px;border-radius:50%;background:#f59e0b;flex-shrink:0}.toolbar-toggle{display:flex;align-items:center;gap:.3rem;cursor:pointer;white-space:nowrap;color:#ffffffd9}.toolbar-toggle input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:#3b82f6}.toggle-label{-webkit-user-select:none;user-select:none}.toolbar-divider{width:1px;height:16px;background:#ffffff40}@media(max-width:900px){.display-rules-toolbar{display:none}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Arial,Helvetica,sans-serif;background:#f0f2f5}.diagonal-accent{position:relative;overflow:hidden}.diagonal-accent:after{content:"";position:absolute;bottom:0;right:0;width:300px;height:200px;background:linear-gradient(135deg,transparent 0%,transparent 48%,var(--color-primary-dark) 48%,var(--color-primary-dark) 100%);pointer-events:none;z-index:0}.diagonal-accent-sm:after{content:"";position:absolute;bottom:0;right:0;width:80px;height:60px;background:linear-gradient(135deg,transparent 0%,transparent 48%,var(--color-primary-light) 48%,var(--color-primary-light) 100%);opacity:.1;pointer-events:none;z-index:0}.diagonal-accent-teal:after{background:linear-gradient(135deg,transparent 0%,transparent 48%,var(--color-accent-teal) 48%,var(--color-accent-teal) 100%)}.diagonal-accent-red:after{background:linear-gradient(135deg,transparent 0%,transparent 48%,var(--color-secondary-light) 48%,var(--color-secondary-light) 100%)}.app{min-height:100vh;display:flex;flex-direction:column;position:relative;background:#f0f2f5}.app-header{background:var(--color-primary-dark);color:#fff;padding:.75rem 2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;position:relative;z-index:10}.header-left{display:flex;align-items:center;justify-content:flex-start}.app-logo{height:30px;width:auto}.header-center{display:flex;flex-direction:column;align-items:center;text-align:center}.header-right{display:flex;align-items:center;justify-content:flex-end}.app-header h1{font-size:1.5rem;margin-bottom:.25rem}.app-header p{opacity:.7;font-size:.875rem}.header-user{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem}.user-name{font-size:.9rem;font-weight:500}.user-role{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase}.user-role.role-public{background:#fff3;color:#fff}.user-role.role-registered{background:var(--color-accent-green-lightest);color:var(--color-accent-green-dark)}.user-role.role-internal{background:var(--color-accent-teal-lightest);color:var(--color-accent-teal-dark)}.btn-my-configs,.btn-my-companies{padding:.4rem .75rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.8rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}.btn-my-configs:hover,.btn-my-companies:hover{background:#ffffff40;border-color:#ffffff80;color:#fff}.btn-admin{padding:.4rem .75rem;background:var(--color-secondary-light);color:#fff;border:none;border-radius:4px;font-size:.8rem;font-weight:600;text-decoration:none;transition:background .15s}.btn-admin:hover{background:var(--color-secondary-dark);color:#fff}.btn-logout{padding:.4rem .75rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.btn-logout:hover{background:#ffffff40;border-color:#ffffff80}.btn-login-link{padding:.4rem .75rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.8rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}.btn-login-link:hover{background:#ffffff40;border-color:#ffffff80}.app-main{display:grid;grid-template-columns:280px 1fr 1fr;gap:1.5rem;padding:1.5rem;flex:1;width:100%;height:calc(100vh - 80px);overflow:hidden;position:relative;z-index:1;background:#f0f2f5}.app-panel{display:block;height:100%;overflow:hidden}@media(max-width:1024px){.app-main{grid-template-columns:280px 1fr;gap:1rem;padding:1rem}.app-panel[data-panel=saved]{grid-row:1;grid-column:1}.app-panel[data-panel=solutions]{grid-row:2;grid-column:1}.app-panel[data-panel=cart]{grid-row:1 / 3;grid-column:2}}@media(max-width:768px){.app-main{display:block;padding:.75rem;padding-bottom:72px;height:calc(100vh - 60px);overflow-y:auto;overflow-x:hidden}.app-panel{display:none;height:auto;min-height:calc(100vh - 132px - 1.5rem)}.app-panel.active{display:block}.app-header{padding:.5rem 1rem;grid-template-columns:auto 1fr auto;gap:.5rem;height:60px}.app-logo{height:36px}.header-center h1{font-size:1.125rem}.header-center p{font-size:.75rem}.header-user{gap:.5rem}.header-user .btn-my-companies,.header-user .btn-admin{display:none}.user-info{gap:.25rem}.user-name{font-size:.8rem;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:.65rem;padding:.15rem .35rem}.btn-logout{padding:.35rem .6rem;font-size:.75rem}}@media(max-width:480px){.app-header{grid-template-columns:auto 1fr}.header-center{display:none}.header-right{justify-content:flex-end}.user-name{display:none}.app-main{padding:.5rem;padding-bottom:68px}}.panel{background:#fff;border-radius:8px;box-shadow:var(--shadow-sm);padding:1.25rem;position:relative;overflow:hidden;transition:box-shadow .3s ease}.panel:hover{box-shadow:var(--shadow-md)}.panel h2{font-size:1.125rem;color:#1a1a2e;margin-bottom:.5rem;position:relative;padding-bottom:.5rem}.panel h2:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:3px;background:var(--color-secondary-light);border-radius:2px}.panel-hint{font-size:.75rem;color:#666;margin-bottom:1rem}.solution-panel{display:flex;flex-direction:column;height:100%;max-height:100%;overflow:hidden}.catalog-panel{height:fit-content;position:sticky;top:1.5rem}.catalog-list{display:flex;flex-direction:column;gap:.5rem}.catalog-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:.75rem;cursor:grab;transition:all var(--duration-fast) var(--ease-smooth);-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.catalog-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(69,143,156,.1),transparent);transition:left .5s ease}.catalog-item:hover:before{left:100%}.catalog-item:hover{border-color:var(--color-accent-teal);background:var(--color-accent-teal-lightest)}.catalog-item:active{cursor:grabbing}.catalog-item.dragging{background:#fff;box-shadow:0 8px 24px #00000026;border-color:var(--color-secondary-light)}.catalog-item-id{font-size:.7rem;font-weight:600;color:var(--color-secondary-light);text-transform:uppercase;letter-spacing:.5px}.catalog-item-name{font-size:.875rem;font-weight:500;color:#1a1a2e;margin:.25rem 0}.catalog-item-price{font-size:.75rem;color:#666}.cart-panel{display:flex;flex-direction:column;height:100%;max-height:100%;overflow:hidden}.cart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-shrink:0}.cart-header h2{margin-bottom:0}.display-mode-toggle{display:flex;gap:0;margin-bottom:1rem;border:1px solid #dee2e6;border-radius:6px;overflow:hidden;flex-shrink:0}.display-mode-toggle .toggle-btn{flex:1;padding:.5rem .75rem;background:#f8f9fa;border:none;font-size:.75rem;font-weight:500;color:#666;cursor:pointer;transition:all .15s}.display-mode-toggle .toggle-btn:first-child{border-right:1px solid #dee2e6}.display-mode-toggle .toggle-btn:hover:not(.active){background:#e9ecef}.display-mode-toggle .toggle-btn.active{background:var(--color-secondary-light);color:#fff}.cart-items-container{flex:1;min-height:200px;border:1px solid #dee2e6;border-radius:8px;transition:all .2s ease;overflow-y:auto}.cart-items-container.empty{display:flex;align-items:center;justify-content:center;border-style:dashed}.cart-empty{text-align:center;color:#999}.cart-empty p{font-size:.875rem}.cart-items{padding:.75rem;display:flex;flex-direction:column;gap:.75rem}.cart-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:1rem;transition:all var(--duration-fast) var(--ease-smooth);position:relative}.cart-item:hover{background:#fff;border-color:var(--color-accent-teal-light);box-shadow:var(--shadow-sm)}.cart-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.cart-item-id{font-size:.7rem;font-weight:600;color:var(--color-secondary-light);text-transform:uppercase;letter-spacing:.5px}.cart-item-id.has-config-id{font-size:.75rem;color:#00a86b;font-family:SF Mono,Monaco,Inconsolata,monospace}.cart-item-status{font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:3px;text-transform:uppercase}.cart-item-status.status-not_configured{background:var(--color-accent-yellow-lightest);color:var(--color-accent-yellow-darker)}.cart-item-status.status-configured{background:var(--color-accent-green-lightest);color:var(--color-accent-green-darker)}.cart-item-status.status-error{background:#f8d7da;color:#721c24}.cart-item-name{font-size:.9375rem;font-weight:500;color:#1a1a2e;margin-bottom:.25rem}.cart-item-pricing{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;gap:1rem}.cart-item-quantity{display:flex;align-items:center;gap:.25rem}.qty-btn{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid var(--color-accent-teal-light);border-radius:var(--radius-md);font-size:1.125rem;font-weight:700;color:var(--color-accent-teal);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);box-shadow:var(--shadow-xs)}.qty-btn:hover:not(:disabled){background:var(--color-accent-teal);color:#fff;border-color:var(--color-accent-teal);transform:scale(1.1);box-shadow:var(--shadow-sm)}.qty-btn:active:not(:disabled){transform:scale(.95)}.qty-btn:disabled{opacity:.4;cursor:not-allowed;border-color:var(--color-gray);color:var(--color-gray)}.qty-value{min-width:2rem;text-align:center;font-weight:600;font-size:.9375rem}.cart-item-price{display:flex;flex-direction:column;align-items:flex-end;text-align:right}.unit-price{font-size:.75rem;color:#888}.line-total{font-size:.9375rem;font-weight:600;color:#1a1a2e}.cart-item-actions{display:flex;gap:.5rem}.viewer-link-row{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #e0e0e0}.viewer-link{font-size:.75rem;color:#2563eb;text-decoration:none}.viewer-link:hover{text-decoration:underline}.btn-copy{display:flex;align-items:center;justify-content:center;padding:.25rem;background:transparent;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#666}.btn-copy:hover{background:#f0f0f0;color:#333}.parts-breakdown{margin:.75rem 0;padding:.75rem;background:#f8f9fa;border-radius:4px}.part-line{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0;border-bottom:1px solid #e9ecef}.part-line:last-child{border-bottom:none}.part-line-info{display:flex;flex-direction:column;gap:.125rem}.part-line-name{font-size:.8125rem;font-weight:500;color:#1a1a2e}.part-line-sku{font-size:.6875rem;color:#888;font-family:SF Mono,Monaco,Inconsolata,monospace}.part-line-pricing{display:flex;align-items:center;gap:.75rem}.part-line-qty{font-size:.75rem;color:#666}.part-line-total{font-size:.8125rem;font-weight:600;color:#1a1a2e}.parts-list-compact{margin:.5rem 0;padding:.5rem .75rem;background:#f8f9fa;border-radius:4px;font-size:.8125rem}.part-line-compact{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;color:#555}.part-line-compact .part-line-name{font-weight:400;color:#555}.part-line-compact .part-line-price{font-weight:500;color:#1a1a2e}.bundle-line{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;margin-bottom:.25rem}.bundle-pn{font-size:.75rem;font-weight:600;color:var(--color-secondary-light);text-transform:uppercase;letter-spacing:.5px;min-width:100px}.bundle-pn.has-config-id{color:#00a86b;font-family:SF Mono,Monaco,Inconsolata,monospace}.bundle-price{display:flex;flex-direction:column;align-items:flex-end;margin-left:auto}.parts-list-compact.bundle-mode{background:transparent;padding:.25rem 0;margin:0;border-top:1px solid #e9ecef}.parts-list-compact.bundle-mode .part-line-compact{padding:.15rem 0}.parts-list-compact.bundle-mode .part-line-name{font-size:.75rem;color:#888}.parts-list-detailed{margin:.5rem 0;background:#f8f9fa;border-radius:6px;overflow:hidden}.part-line-detailed{display:grid;grid-template-columns:1fr auto auto;gap:.75rem;align-items:center;padding:.5rem .75rem;border-bottom:1px solid #e9ecef}.part-line-detailed:last-of-type{border-bottom:none}.part-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.part-pn{font-size:.7rem;font-weight:600;color:var(--color-secondary-light);font-family:SF Mono,Monaco,Inconsolata,monospace;text-transform:uppercase}.part-name{font-size:.8rem;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.part-qty{font-size:.8rem;font-weight:600;color:#333;min-width:30px;text-align:center}.part-price{font-size:.85rem;font-weight:600;color:#1a1a2e;min-width:70px;text-align:right}.parts-total-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#e9ecef;border-top:1px solid #dee2e6}.parts-qty-control{display:flex;align-items:center;gap:.5rem}.parts-qty-label{font-size:.75rem;color:#666;font-weight:500}.parts-total{display:flex;align-items:center;gap:.5rem}.parts-total-label{font-size:.75rem;color:#666;font-weight:500}.parts-total-amount{font-size:1rem;font-weight:700;color:#1a1a2e}.btn-configure{flex:1;padding:.5rem .75rem;background:var(--color-secondary-light);color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-configure:hover{background:var(--color-secondary-dark)}.btn-remove{padding:.5rem .75rem;background:#dc3545;color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-remove:hover{background:#c82333}.btn-clear{padding:.375rem .75rem;background:#6c757d;color:#fff;border:none;border-radius:4px;font-size:.75rem;cursor:pointer}.btn-clear:hover{background:#5a6268}.cart-summary{margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef;flex-shrink:0}.cart-total{display:flex;justify-content:space-between;align-items:center;font-weight:500}.total-amount{font-size:1.25rem;color:var(--color-secondary-light)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.solution-card,.config-card,.cart-item{animation:fadeIn var(--duration-normal) var(--ease-smooth)}.skeleton{background:linear-gradient(90deg,var(--color-gray-light) 0%,var(--color-gray) 50%,var(--color-gray-light) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:.5rem}.skeleton-text:last-child{width:80%}.skeleton-title{height:1.5em;width:60%;margin-bottom:.75rem}.skeleton-card{padding:1rem;background:#fff;border-radius:8px;box-shadow:var(--shadow-sm);margin-bottom:.75rem}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-button{height:2.5rem;width:100px;border-radius:6px}.loading{text-align:center;padding:2rem;color:#666}.error{text-align:center;padding:2rem;color:#dc3545}.error button{margin-top:.5rem;padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-pandadoc{width:100%;padding:.75rem 1rem;background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-secondary-light) 100%);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all var(--duration-normal) var(--ease-spring);margin-top:1rem;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.btn-pandadoc:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%);opacity:0;transition:opacity var(--duration-fast) ease}.btn-pandadoc:hover:before{opacity:1}.btn-pandadoc:hover{transform:translateY(-3px);box-shadow:var(--shadow-xl)}.btn-pandadoc:active{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-pandadoc:disabled{background:#adb5bd;cursor:not-allowed;transform:none;box-shadow:none}.btn-send-to-sales{width:100%;padding:.75rem 1rem;background:linear-gradient(135deg,var(--color-accent-teal) 0%,#3a7a86 100%);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all var(--duration-normal) var(--ease-spring);margin-top:1rem;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.btn-send-to-sales:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%);opacity:0;transition:opacity var(--duration-fast) ease}.btn-send-to-sales:hover:before{opacity:1}.btn-send-to-sales:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-xl)}.btn-send-to-sales:active:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-send-to-sales:disabled{background:var(--color-accent-teal);opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.sales-send-success{background:#d1fae5;border:1px solid var(--color-accent-green);border-left:4px solid var(--color-accent-green);color:#065f46;padding:.75rem 1rem;border-radius:6px;font-size:.875rem;margin-top:.75rem;animation:fadeIn .3s ease}.sales-send-error{background:#fee2e2;border:1px solid var(--color-secondary-light);border-left:4px solid var(--color-secondary-dark);color:var(--color-secondary-dark);padding:.75rem 1rem;border-radius:6px;font-size:.875rem;margin-top:.75rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.external-cart-item{border-left:3px solid var(--color-accent-teal)}.external-cart-item.loading{opacity:.7}.external-cart-item.has-error{border-left-color:#ef4444}.external-source-badge{display:inline-block;font-size:.625rem;font-weight:600;text-transform:uppercase;color:#fff;background:var(--color-accent-teal);padding:.125rem .375rem;border-radius:3px;margin-left:.5rem;letter-spacing:.025em;vertical-align:middle}.external-config-id{font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.75rem;color:var(--color-accent-teal)}.external-item-description{font-size:.8125rem;color:#666;margin:.25rem 0 .5rem;line-height:1.4}.external-item-error{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;margin:.5rem 0}.external-item-error .error-message{flex:1;font-size:.8125rem;color:#dc2626}.external-item-error .btn-refresh{font-size:.75rem;padding:.25rem .5rem;background:#fff;border:1px solid #fecaca;border-radius:4px;color:#dc2626;cursor:pointer}.external-item-error .btn-refresh:hover{background:#fef2f2}.external-item-loading{display:flex;align-items:center;gap:.5rem;padding:.375rem;font-size:.75rem;color:#666}.external-item-loading .loading-spinner{width:14px;height:14px;border:2px solid #e0e0e0;border-top-color:var(--color-accent-teal);border-radius:50%;animation:spin 1s linear infinite}.btn-refresh-small{display:flex;align-items:center;justify-content:center;padding:.375rem;background:transparent;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#666}.btn-refresh-small:hover{background:#f0f0f0;color:#333}.external-item-meta{font-size:.6875rem;color:#999;margin-top:.25rem;font-style:italic}@media(max-width:768px){button,.btn,.btn-primary,.btn-secondary,.qty-btn,a.btn{min-height:44px;min-width:44px;padding:.75rem 1rem}.qty-btn{width:44px;height:44px;font-size:1.125rem}body{font-size:16px}.panel h2,.section-title{font-size:1.25rem}.panel-hint{font-size:.875rem}.config-card-title,.solution-card-title,.cart-item-title{font-size:1rem}.config-card-meta,.solution-card-description,.part-line-name{font-size:.875rem}.config-card,.solution-card,.cart-item{padding:1rem;margin-bottom:.75rem}.config-card-corner-actions button{width:40px;height:40px;padding:.5rem}.solution-card{padding:1.25rem}input,select,textarea{min-height:44px;font-size:16px;padding:.75rem}.modal-content{width:95%;max-width:400px;margin:1rem}}@supports (padding: max(0px)){.app-header{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right))}.mobile-tab-nav{padding-left:max(.5rem,env(safe-area-inset-left));padding-right:max(.5rem,env(safe-area-inset-right));padding-bottom:max(.5rem,env(safe-area-inset-bottom))}@media(max-width:768px){.app-main{padding-bottom:calc(72px + env(safe-area-inset-bottom))}}}*:focus-visible{outline:3px solid var(--color-accent-teal);outline-offset:3px;border-radius:4px;animation:focusPulse 1.5s ease-in-out infinite}@keyframes focusPulse{0%,to{outline-color:var(--color-accent-teal)}50%{outline-color:var(--color-accent-teal-light)}}*:focus:not(:focus-visible){outline:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--color-accent-teal);outline-offset:2px;box-shadow:0 0 0 4px var(--color-accent-teal-lightest)}@media(min-width:769px){.mobile-only{display:none!important}}@media(max-width:768px){.desktop-only{display:none!important}}button,.btn{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}@media(max-width:768px){.app-main,.panel{-webkit-overflow-scrolling:touch}}.product-designer{min-height:100vh;display:flex;flex-direction:column;background:#f0f2f5}.designer-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:#1a1a2e;color:#fff;gap:1rem}.back-link{color:#ffffffb3;text-decoration:none;font-size:.875rem}.back-link:hover{color:#fff}.designer-header h1{font-size:1.125rem;font-weight:600;margin:0}.header-center{flex:1;max-width:400px}.config-name-input{width:100%;padding:.5rem .75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.875rem;text-align:center}.config-name-input::placeholder{color:#ffffff80}.config-name-input:focus{outline:none;border-color:var(--color-secondary-light);background:#ffffff26}.header-actions{display:flex;gap:.5rem}.designer-main{flex:1;display:grid;grid-template-columns:260px 1fr 280px;gap:1rem;padding:1rem;overflow:hidden}.steps-panel,.option-editor{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e9ecef}.panel-header h2{font-size:.9375rem;font-weight:600;color:#1a1a2e;margin:0}.steps-list{flex:1;overflow-y:auto;padding:.5rem}.step-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:.5rem;cursor:pointer;transition:all .15s}.step-item:hover{border-color:var(--color-secondary-light)}.step-item.selected{border-color:var(--color-secondary-light);background:#fee2e2}.step-item.dragging{background:#fff;box-shadow:0 8px 24px #00000026}.step-drag-handle{cursor:grab;color:#999;font-size:.75rem;padding:.25rem}.step-drag-handle:active{cursor:grabbing}.step-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-secondary-light);color:#fff;border-radius:50%;font-size:.75rem;font-weight:600;flex-shrink:0}.step-name{flex:1;font-size:.8125rem;font-weight:500;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step-options-count{font-size:.6875rem;color:#666;flex-shrink:0}.step-delete-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#999;cursor:pointer;font-size:1rem;border-radius:4px;flex-shrink:0}.step-delete-btn:hover{background:#dc3545;color:#fff}.options-canvas{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;overflow:hidden}.canvas-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e9ecef;gap:1rem}.step-info{display:flex;align-items:center;gap:1rem;flex:1}.step-name-input{flex:1;max-width:300px;padding:.5rem .75rem;border:1px solid #e9ecef;border-radius:4px;font-size:.9375rem;font-weight:500}.step-name-input:focus{outline:none;border-color:var(--color-secondary-light)}.required-toggle{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#666;cursor:pointer}.required-toggle input{cursor:pointer}.options-grid{flex:1;overflow-y:auto;padding:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;align-content:start}.option-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:1rem;cursor:pointer;transition:all .15s}.option-card:hover{border-color:var(--color-secondary-light)}.option-card.selected{border-color:var(--color-secondary-light);background:#fee2e2}.option-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.option-part-number{font-size:.6875rem;font-weight:600;color:var(--color-secondary-light);text-transform:uppercase}.option-delete-btn{width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#999;cursor:pointer;font-size:.875rem;border-radius:4px}.option-delete-btn:hover{background:#dc3545;color:#fff}.option-card-name{font-size:.875rem;font-weight:500;color:#1a1a2e;margin-bottom:.25rem}.option-card-price{font-size:.8125rem;color:#28a745;font-weight:500}.option-editor{overflow-y:auto}.btn-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#666;cursor:pointer;font-size:1.25rem;border-radius:4px}.btn-close:hover{background:#e9ecef}.editor-form{padding:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:.375rem}.form-group input,.form-group textarea{width:100%;padding:.5rem .75rem;border:1px solid #e9ecef;border-radius:4px;font-size:.875rem}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-secondary-light)}.form-group textarea{resize:vertical;min-height:60px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:#999;height:100%}.empty-state p{margin:0;font-size:.875rem}.empty-state .hint{font-size:.75rem;margin-top:.25rem}.btn-add{padding:.375rem .75rem;background:#28a745;color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;white-space:nowrap}.btn-add:hover{background:#218838}.btn-secondary{padding:.5rem 1rem;background:#6c757d;color:#fff;border:none;border-radius:4px;font-size:.8125rem;font-weight:500;cursor:pointer}.btn-secondary:hover{background:#5a6268}.btn-danger{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;font-size:.8125rem;font-weight:500;cursor:pointer}.btn-danger:hover{background:#c82333}.configurator-shell{height:100vh;display:flex;flex-direction:column;background:#1a1a1a}.configurator-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-primary-dark);border-bottom:1px solid var(--color-primary-light);gap:1rem;flex-shrink:0}.header-left{display:flex;align-items:center;gap:1rem}.configurator-logo{height:40px;width:auto}.btn-back{padding:.5rem .75rem;background:transparent;color:#aaa;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:.8125rem}.btn-back:hover{background:#333;color:#fff}.header-title h1{margin:0;font-size:1rem;color:#fff;font-weight:600}.item-id{font-size:.75rem;color:#888}.header-center{flex:1;display:flex;justify-content:center}.config-summary{display:flex;align-items:center;gap:.75rem;font-size:.8125rem;color:#ccc}.summary-item strong{color:var(--color-secondary-light)}.summary-divider{color:#555}.header-right{display:flex;align-items:center;gap:1.5rem}.price-display{display:flex;flex-direction:column;align-items:flex-end}.price-label{font-size:.6875rem;color:#888;text-transform:uppercase}.price-value{font-size:1.25rem;font-weight:700;color:#00e676}.price-loading{font-size:.8125rem;color:#888}.header-actions{display:flex;align-items:center;gap:.75rem}.view-only-badge{display:inline-block;padding:.35rem .75rem;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:20px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#fff}.btn-primary{padding:.5rem 1rem;background:var(--color-secondary-light);color:#fff;border:none;border-radius:4px;font-size:.8125rem;font-weight:500;cursor:pointer}.btn-primary:hover{background:var(--color-secondary-dark)}.btn-primary:disabled{background:#444;color:#888;cursor:not-allowed}.btn-secondary{padding:.5rem 1rem;background:transparent;color:#ccc;border:1px solid #444;border-radius:4px;font-size:.8125rem;cursor:pointer}.btn-secondary:hover{background:#333;color:#fff}.configurator-main{flex:1;position:relative;overflow:hidden}.configurator-main iframe{width:100%;height:100%;border:none;opacity:0;transition:opacity .3s ease}.configurator-main iframe.ready{opacity:1}.configurator-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1a1a1a;color:#888;z-index:10}.loading-spinner{width:40px;height:40px;border:3px solid #333;border-top-color:var(--color-secondary-light);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.configurator-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#ccc;text-align:center;padding:2rem}.configurator-error h2{margin:0 0 .5rem;color:#fff}.configurator-error p{margin:0 0 1.5rem;color:#888}.configurator-error button{padding:.75rem 1.5rem;background:var(--color-secondary-light);color:#fff;border:none;border-radius:4px;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.parts-selection-modal{background:var(--color-surface, #ffffff);border-radius:12px;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-header{padding:1.5rem;border-bottom:1px solid var(--color-border, #e0e0e0)}.modal-header h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--color-text, #333333)}.modal-header p{margin:0;font-size:.875rem;color:var(--color-text-secondary, #666666)}.parts-list{flex:1;overflow-y:auto;padding:.5rem}.part-row{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s ease}.part-row:hover{background:#fafafa;border-color:#e0e0e0}.part-row.selected{background:#fee2e2;border:2px solid var(--color-secondary-light)}.part-row.required{cursor:default}.part-checkbox{padding-top:2px}.part-checkbox input{width:18px;height:18px;cursor:pointer}.part-checkbox input:disabled{cursor:default;opacity:.6}.part-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.part-name{font-weight:600;color:var(--color-text, #333333)}.part-sku{font-size:.75rem;color:var(--color-text-secondary, #666666);font-family:monospace}.part-required-badge{display:inline-block;font-size:.65rem;font-weight:600;text-transform:uppercase;color:var(--color-warning, #b45309);background:var(--color-warning-light, #fef3c7);padding:.125rem .375rem;border-radius:4px;width:fit-content}.part-description{font-size:.8rem;color:var(--color-text-secondary, #666666);line-height:1.4}.part-price{font-weight:600;color:var(--color-text, #333333);white-space:nowrap}.modal-footer{padding:1.5rem;border-top:1px solid var(--color-border, #e0e0e0);display:flex;flex-direction:column;gap:1rem}.selected-total{display:flex;justify-content:space-between;align-items:center;font-size:1.1rem}.total-label{color:var(--color-text-secondary, #666666)}.total-value{font-weight:700;color:var(--color-text, #333333)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-secondary{padding:.75rem 1.25rem;border:1px solid var(--color-border, #e0e0e0);border-radius:6px;background:var(--color-surface, #ffffff);color:var(--color-text, #333333);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--color-background, #f5f5f5)}.btn-primary{padding:.75rem 1.25rem;border:none;border-radius:6px;background:var(--color-secondary-light);color:#fff;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--color-secondary-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.pending-approval-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-bg-secondary, #f5f5f5)}.pending-approval-card{max-width:500px;width:100%;background:var(--color-bg-primary, #ffffff);border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2.5rem;text-align:center}.pending-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:var(--color-warning-bg, #fff3cd);border-radius:50%;display:flex;align-items:center;justify-content:center}.pending-icon svg{width:40px;height:40px;color:var(--color-warning, #856404)}.pending-approval-card h1{font-size:1.75rem;margin:0 0 1rem;color:var(--color-text-primary, #333)}.pending-approval-card .greeting{font-size:1.1rem;color:var(--color-text-secondary, #666);margin-bottom:1rem}.pending-approval-card .message{color:var(--color-text-secondary, #666);line-height:1.6;margin-bottom:1.5rem}.info-box{background:var(--color-bg-secondary, #f8f9fa);border-radius:8px;padding:1rem;text-align:left;margin-bottom:1.5rem}.info-box.abetech{background:var(--color-primary-light, #e3f2fd);border:1px solid var(--color-primary, #1976d2)}.info-box strong{display:block;margin-bottom:.5rem;color:var(--color-text-primary, #333)}.info-box p{margin:0;font-size:.9rem;color:var(--color-text-secondary, #666)}.info-box ul{margin:0;padding-left:1.25rem;font-size:.9rem;color:var(--color-text-secondary, #666)}.info-box li{margin-bottom:.25rem}.account-details{background:var(--color-bg-secondary, #f8f9fa);border-radius:8px;padding:1rem;margin-bottom:1.5rem;text-align:left}.account-details h3{font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #999);margin:0 0 .75rem}.account-details dl{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;margin:0}.account-details dt{font-weight:500;color:var(--color-text-secondary, #666)}.account-details dd{margin:0;color:var(--color-text-primary, #333)}.account-details .status{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500}.account-details .status.pending{background:var(--color-warning-bg, #fff3cd);color:var(--color-warning, #856404)}.actions{display:flex;gap:1rem;justify-content:center}.btn-refresh,.btn-contact{padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s}.btn-refresh{display:flex;align-items:center;gap:.5rem;background:var(--color-accent-teal, #458f9c);color:#fff;border:none}.btn-refresh:hover{background:var(--color-accent-teal-dark, #3a7a85)}.btn-contact{background:transparent;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #ddd)}.btn-contact:hover{background:var(--color-bg-secondary, #f5f5f5);border-color:var(--color-text-secondary, #666)}.admin-app{min-height:100vh;display:flex;flex-direction:column;background:#f0f2f5}.admin-app .app-header{background:var(--color-primary-dark);color:#fff;padding:.75rem 2rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}.admin-app .header-left{display:flex;align-items:center;justify-content:flex-start}.admin-app .app-logo{height:50px;width:auto}.admin-app .header-center{display:flex;flex-direction:column;align-items:center;text-align:center}.admin-app .header-center h1{font-size:1.5rem;margin-bottom:.25rem}.admin-app .header-center p{opacity:.7;font-size:.875rem;margin:0}.admin-app .header-right{display:flex;align-items:center;justify-content:flex-end}.admin-app .header-user{display:flex;align-items:center;gap:1rem}.admin-app .user-info{display:flex;align-items:center;gap:.5rem}.admin-app .user-name{font-size:.9rem;font-weight:500}.admin-app .user-role{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase}.admin-app .user-role.role-public{background:#fff3;color:#fff}.admin-app .user-role.role-registered{background:#38bda04d;color:#7eecd4}.admin-app .user-role.role-internal{background:#458f9c66;color:#8dd8e8}.admin-nav .btn-back-to-app{padding:.5rem 1rem;background:transparent;color:var(--color-text-secondary, #666);border:none;border-radius:6px;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .15s}.admin-nav .btn-back-to-app:hover{color:var(--color-text-primary, #333)}.admin-nav .nav-divider{width:1px;height:20px;background:#ddd;margin:0 .5rem;align-self:center}.admin-app .btn-logout{padding:.4rem .75rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.admin-app .btn-logout:hover{background:#ffffff40;border-color:#ffffff80;transform:none;box-shadow:none}.admin-main{flex:1;padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.admin-main .user-management-page,.admin-main .access-requests-page,.admin-main .user-detail-page,.admin-main .audit-log-page{padding:0;max-width:none;margin:0}.admin-panel{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.admin-nav{display:flex;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.admin-nav-link{padding:.5rem 1rem;background:transparent;color:var(--color-text-secondary);text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:all .15s}.admin-nav-link:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.admin-nav-link.active{background:var(--color-primary-dark);color:#fff}.admin-nav-link .badge{background:var(--color-warning);color:#fff;padding:.125rem .5rem;border-radius:10px;font-size:.75rem;margin-left:.5rem}.admin-main button{background-color:#1976d2;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .15s}.admin-main button:hover:not(:disabled){background-color:#1565c0;transform:none;box-shadow:none}.admin-main button:disabled{background-color:#ccc;color:#666;cursor:not-allowed}.admin-main button.btn-secondary,.admin-main button.btn-outline{background-color:transparent;color:#333;border:1px solid #ddd}.admin-main button.btn-secondary:hover:not(:disabled),.admin-main button.btn-outline:hover:not(:disabled){background-color:#f5f5f5}.admin-main button.btn-danger,.admin-main button.btn-reject{background-color:#dc3545;color:#fff}.admin-main button.btn-danger:hover:not(:disabled),.admin-main button.btn-reject:hover:not(:disabled){background-color:#c82333}.admin-main button.btn-success,.admin-main button.btn-approve{background-color:#28a745;color:#fff}.admin-main button.btn-success:hover:not(:disabled),.admin-main button.btn-approve:hover:not(:disabled){background-color:#218838}.admin-main button.btn-warning,.admin-main button.btn-suspend{background-color:#ff9800;color:#fff}.admin-main button.btn-warning:hover:not(:disabled),.admin-main button.btn-suspend:hover:not(:disabled){background-color:#f57c00}.user-management-page{padding:1.5rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.pending-requests-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-primary, #1976d2);color:#fff;text-decoration:none;border-radius:6px;font-weight:500}.pending-requests-link:hover{background:var(--color-primary-dark, #1565c0)}.pending-requests-link .badge{background:var(--color-warning, #ff9800);color:#fff;padding:.125rem .5rem;border-radius:10px;font-size:.8rem}.checkbox-filter{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem}.users-table-container{overflow-x:auto;background:var(--color-bg-primary, white);border-radius:8px;box-shadow:0 1px 3px #0000001a}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border, #eee)}.users-table th{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f9f9f9)}.users-table tbody tr:hover{background:var(--color-bg-hover, #f5f5f5)}.user-info{display:flex;flex-direction:column}.user-info strong{font-weight:500}.user-info .email{font-size:.85rem;color:var(--color-text-muted, #666)}.role-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:capitalize}.role-badge.internal{background:#e3f2fd;color:#1565c0}.role-badge.partner_client{background:#fff3e0;color:#e65100}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:capitalize}.status-badge.suspended{background:var(--color-error-light, #ffebee);color:var(--color-error, #c62828)}.status-badge.rejected{background:var(--color-text-muted-light, #eeeeee);color:var(--color-text-muted, #616161)}.abetech-badge{font-size:.85rem;font-weight:500;color:var(--color-text-primary, #333)}.external-badge{font-size:.85rem;color:var(--color-text-muted, #666)}.btn-view,.btn-approve,.btn-suspend{padding:.375rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500;cursor:pointer;text-decoration:none;border:none;transition:background .2s}.btn-view{background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333)}.btn-view:hover{background:var(--color-border, #ddd)}.btn-approve:hover{background:var(--color-success-dark, #388e3c)}.btn-suspend{background:var(--color-warning, #ff9800);color:#fff}.access-requests-page{padding:1.5rem;max-width:900px;margin:0 auto}.requests-container{min-height:300px}.empty-state{text-align:center;padding:3rem;background:var(--color-bg-primary, white);border-radius:12px;box-shadow:0 1px 3px #0000001a}.empty-state svg{width:64px;height:64px;color:var(--color-success, #4caf50);margin-bottom:1rem}.empty-state h2{margin:0 0 .5rem;font-size:1.25rem}.empty-state p{margin:0;color:var(--color-text-muted, #666)}.requests-list{display:flex;flex-direction:column;gap:1rem}.request-card{background:var(--color-bg-primary, white);border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px #0000001a;border-left:4px solid var(--color-border, #ddd)}.request-card.abetech{border-left-color:var(--color-primary, #1976d2);background:linear-gradient(to right,var(--color-primary-light, #e3f2fd) 0%,var(--color-bg-primary, white) 30%)}.request-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.request-type{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.request-type.registration{background:var(--color-primary-light, #e3f2fd);color:var(--color-primary-dark, #1565c0)}.request-type.upgrade{background:var(--color-warning-light, #fff3e0);color:var(--color-warning-dark, #e65100)}.request-type.permission{background:var(--color-success-light, #e8f5e9);color:var(--color-success-dark, #2e7d32)}.request-time{font-size:.85rem;color:var(--color-text-muted, #666)}.request-user{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem}.request-user strong{font-size:1.1rem}.request-user .email{color:var(--color-text-muted, #666);font-size:.9rem}.request-user .abetech-badge{background:var(--color-primary, #1976d2);color:#fff;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.request-reason,.request-detail{padding:.5rem .75rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:4px;font-size:.9rem;margin-bottom:.75rem}.request-reason strong,.request-detail strong{margin-right:.5rem}.request-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border, #eee)}.btn-approve,.btn-approve-internal,.btn-reject,.btn-view-user{padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;border:none;text-decoration:none;transition:background .2s}.btn-approve{background:var(--color-success, #4caf50);color:#fff}.btn-approve:hover:not(:disabled){background:var(--color-success-dark, #388e3c)}.btn-approve-internal{background:var(--color-primary, #1976d2);color:#fff}.btn-approve-internal:hover:not(:disabled){background:var(--color-primary-dark, #1565c0)}.btn-reject{background:var(--color-error, #f44336);color:#fff}.btn-reject:hover:not(:disabled){background:var(--color-error-dark, #d32f2f)}.btn-view-user{background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333)}.btn-view-user:hover{background:var(--color-border, #ddd)}.btn-approve:disabled,.btn-approve-internal:disabled,.btn-reject:disabled{opacity:.5;cursor:not-allowed}.user-detail-page{padding:1.5rem;max-width:1200px;margin:0 auto}.page-header{margin-bottom:1.5rem}.page-header-left{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.btn-back{display:inline-block;color:var(--color-text-muted, #666);text-decoration:none;font-size:.9rem}.btn-back:hover{color:var(--color-primary, #1976d2)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:900px){.detail-grid{grid-template-columns:1fr}}.detail-section{background:var(--color-bg-primary, white);border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.detail-section h2{margin:0 0 1rem;font-size:1.1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border, #eee)}.section-note{margin:0 0 1rem;font-size:.85rem;color:var(--color-text-muted, #666)}.info-list{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;margin:0}.info-list dt{font-weight:500;color:var(--color-text-muted, #666)}.info-list dd{margin:0}.info-list .badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.info-list .badge.abetech{background:var(--color-primary-light, #e3f2fd);color:var(--color-primary-dark, #1565c0)}.info-list .badge.external{background:var(--color-bg-secondary, #f5f5f5);color:var(--color-text-muted, #666)}.editable-field{display:inline-flex;align-items:center;gap:.5rem}.btn-inline-edit{background:none;border:none;cursor:pointer;font-size:.85rem;padding:.125rem .25rem;color:var(--color-text-muted, #999);border-radius:3px;transition:color .15s,background .15s}.btn-inline-edit:hover{color:var(--color-primary, #1976d2);background:var(--color-primary-light, #e3f2fd)}.inline-edit{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.inline-edit input{padding:.375rem .5rem;border:1px solid var(--color-primary, #1976d2);border-radius:4px;font-size:.95rem;min-width:220px;outline:none}.inline-edit input:focus{box-shadow:0 0 0 2px #1976d233}.btn-inline-save{padding:.375rem .75rem;background:var(--color-success, #4caf50);color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer}.btn-inline-save:hover:not(:disabled){background:var(--color-success-dark, #388e3c)}.btn-inline-cancel{padding:.375rem .75rem;background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333);border:none;border-radius:4px;font-size:.85rem;cursor:pointer}.btn-inline-cancel:hover{background:var(--color-border, #ddd)}.inline-edit-error{width:100%;color:var(--color-error, #c62828);font-size:.85rem}.date-suffix{margin-left:.5rem;color:var(--color-text-muted, #666);font-size:.9rem}.rejection-reason{color:var(--color-error, #c62828);font-style:italic}.role-status-section{grid-column:span 1}.control-group{margin-bottom:1.5rem}.control-group:last-child{margin-bottom:0}.control-group label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--color-text-muted, #666)}.button-group{display:flex;flex-wrap:wrap;gap:.5rem}.status-btn,.role-btn{padding:.5rem 1rem;border:1px solid var(--color-border, #ddd);border-radius:6px;background:var(--color-bg-primary, white);color:var(--color-text-primary, #333);cursor:pointer;font-size:.9rem;font-weight:500;text-transform:capitalize;transition:all .2s}.status-btn:hover:not(:disabled),.role-btn:hover:not(:disabled){background:var(--color-bg-secondary, #f5f5f5)}.status-btn:disabled,.role-btn:disabled{cursor:not-allowed}.status-btn.active,.role-btn.active{color:#fff;border-color:transparent}.status-btn.pending.active{background:var(--color-warning, #ff9800)}.status-btn.active.active{background:var(--color-success, #4caf50)}.status-btn.suspended.active{background:var(--color-error, #f44336)}.status-btn.rejected.active{background:var(--color-text-muted, #616161)}.role-btn.partner_client.active{background:var(--color-success, #4caf50)}.role-btn.internal.active{background:var(--color-primary, #1976d2)}.configurator-permissions-section{grid-column:span 2}@media(max-width:900px){.configurator-permissions-section{grid-column:span 1}}.configurator-groups{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.configurator-group{padding:1rem;background:var(--color-bg-secondary, #f9f9f9);border-radius:8px;border:1px solid var(--color-border, #eee)}.configurator-group h4{margin:0 0 .75rem;font-size:1rem;color:var(--color-text-primary, #333)}.configurator-permissions{display:flex;flex-direction:column;gap:.5rem}.configurator-permissions .permission-item{background:var(--color-bg-primary, white)}.permissions-section{grid-column:span 2}@media(max-width:900px){.permissions-section{grid-column:span 1}}.permission-category{margin-bottom:1.5rem}.permission-category:last-child{margin-bottom:0}.permission-category h3{margin:0 0 .75rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #666)}.permission-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.5rem}.permission-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:1px solid var(--color-border, #eee);border-radius:6px;cursor:pointer;transition:all .2s}.permission-item:hover{background:var(--color-bg-secondary, #f9f9f9)}.permission-item.active{background:var(--color-success-light, #e8f5e9);border-color:var(--color-success, #4caf50)}.permission-item input{margin-top:.2rem}.permission-info{display:flex;flex-direction:column}.permission-info strong{font-size:.9rem}.permission-info span{font-size:.8rem;color:var(--color-text-muted, #666)}.audit-section{grid-column:span 2}@media(max-width:900px){.audit-section{grid-column:span 1}}.empty-audit{color:var(--color-text-muted, #666);text-align:center;padding:1rem}.audit-list{max-height:300px;overflow-y:auto}.audit-entry{display:flex;flex-wrap:wrap;gap:.5rem 1rem;padding:.75rem 0;border-bottom:1px solid var(--color-border, #eee)}.audit-entry:last-child{border-bottom:none}.audit-action{font-weight:500;font-family:monospace;font-size:.85rem;background:var(--color-bg-secondary, #f5f5f5);padding:.125rem .5rem;border-radius:4px}.audit-time,.audit-actor{font-size:.85rem;color:var(--color-text-muted, #666)}.view-full-audit{display:inline-block;margin-top:1rem;color:var(--color-primary, #1976d2);text-decoration:none;font-size:.9rem}.view-full-audit:hover{text-decoration:underline}.memberships-section{grid-column:span 2}@media(max-width:900px){.memberships-section{grid-column:span 1}}.add-to-company-form{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;padding:1rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:6px}.add-to-company-form select{padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.9rem;background:var(--color-bg-primary, white);min-width:150px}.add-to-company-form select:first-child{flex:1;min-width:200px}.add-to-company-form .hidden-checkbox{display:flex;align-items:center;gap:.35rem;font-size:.9rem;color:var(--color-text-muted, #666);cursor:pointer;padding:0 .5rem}.add-to-company-form .hidden-checkbox input{cursor:pointer}.btn-add-company{padding:.5rem 1rem;background:var(--color-success, #28a745);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;white-space:nowrap}.btn-add-company:hover:not(:disabled){background:var(--color-success-dark, #218838)}.btn-add-company:disabled{opacity:.5;cursor:not-allowed}.empty-memberships{color:var(--color-text-muted, #666);text-align:center;padding:1.5rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:6px}.memberships-table{width:100%;border-collapse:collapse}.memberships-table th,.memberships-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border, #eee)}.memberships-table th{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f9f9f9)}.memberships-table tbody tr:last-child td{border-bottom:none}.memberships-table tbody tr.hidden-membership{opacity:.7;background:repeating-linear-gradient(-45deg,transparent,transparent 5px,rgba(0,0,0,.02) 5px,rgba(0,0,0,.02) 10px)}.memberships-table .company-info{display:flex;flex-direction:column;gap:.15rem}.memberships-table .company-info strong{font-size:.95rem}.memberships-table .company-info .gp-id{font-size:.8rem;font-family:monospace;color:var(--color-text-muted, #666)}.memberships-table .company-info .company-status{display:inline-block;font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:3px;text-transform:uppercase;width:fit-content}.memberships-table .company-info .company-status.suspended{background:var(--color-error-light, #ffebee);color:var(--color-error, #c62828)}.memberships-table .company-info .company-status.inactive{background:var(--color-bg-secondary, #f5f5f5);color:var(--color-text-muted, #666)}.memberships-table .role-select,.memberships-table .status-select{padding:.35rem .5rem;border:1px solid var(--color-border, #ddd);border-radius:4px;font-size:.85rem;background:var(--color-bg-primary, white)}.btn-remove-membership{padding:.35rem .75rem;background:transparent;color:var(--color-error, #c62828);border:1px solid var(--color-error, #c62828);border-radius:4px;font-size:.85rem;cursor:pointer}.btn-remove-membership:hover{background:var(--color-error, #c62828);color:#fff}@media(max-width:768px){.add-to-company-form{flex-direction:column}.add-to-company-form select{width:100%}.memberships-table{display:block;overflow-x:auto}}.btn-save{padding:.5rem 1.25rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer}.btn-cancel{padding:.5rem 1.25rem;background:#fff;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.9rem;cursor:pointer}.unsaved-indicator{display:inline-block;font-size:.75rem;font-weight:500;color:var(--color-warning-dark, #f57f17);background:#fff8e1;padding:.15rem .5rem;border-radius:4px;margin-left:.5rem;vertical-align:middle}.memberships-table tbody tr.membership-changed{background:#fff8e1}.danger-zone-section{grid-column:span 2;border:1px solid var(--color-error, #c62828)}@media(max-width:900px){.danger-zone-section{grid-column:span 1}}.danger-zone-section h2{color:var(--color-error, #c62828);border-bottom-color:var(--color-error-light, #ffcdd2)}.danger-zone-content{display:flex;flex-direction:column;gap:1rem}.danger-action{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;background:var(--color-error-bg, #fff5f5);border-radius:6px}.danger-info{display:flex;flex-direction:column;gap:.25rem}.danger-info strong{font-size:.95rem;color:var(--color-text-primary, #333)}.danger-info span{font-size:.85rem;color:var(--color-text-muted, #666)}.btn-danger{padding:.5rem 1rem;background:transparent;color:var(--color-error, #c62828);border:1px solid var(--color-error, #c62828);border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s}.btn-danger:hover:not(:disabled){background:var(--color-error, #c62828);color:#fff}.btn-danger:disabled{opacity:.5;cursor:not-allowed}@media(max-width:600px){.danger-action{flex-direction:column;align-items:flex-start}.btn-danger{width:100%}}.audit-log-page{padding:1.5rem;max-width:1400px;margin:0 auto}.page-header-left{display:flex;align-items:center;gap:1rem}.page-header h1{margin:0;font-size:1.75rem}.page-header .subtitle{margin:.25rem 0 0;color:var(--color-text-muted, #666)}.btn-back-to-app{padding:.5rem 1rem;background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333);text-decoration:none;border-radius:6px;font-weight:500;font-size:.9rem;transition:background .15s;align-self:flex-start}.btn-back-to-app:hover{background:var(--color-border, #ddd);color:var(--color-text-primary, #333)}.btn-back{padding:.5rem 1rem;background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333);text-decoration:none;border-radius:6px;font-weight:500}.filter-select,.date-input{padding:.5rem 1rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;background:#fff}.log-table-container{overflow-x:auto;background:var(--color-bg-primary, white);border-radius:8px;box-shadow:0 1px 3px #0000001a}.log-table{width:100%;border-collapse:collapse;table-layout:fixed}.log-table th,.log-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border, #eee);overflow:hidden;text-overflow:ellipsis}.log-table th{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f9f9f9);resize:horizontal;overflow:auto;min-width:80px}.log-table th:nth-child(1){width:150px}.log-table th:nth-child(2){width:180px}.log-table th:nth-child(3){width:120px}.log-table th:nth-child(4){width:120px}.log-table th:nth-child(5){width:auto}.log-table tbody tr:hover{background:var(--color-bg-hover, #f5f5f5)}.action-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;font-family:monospace}.action-badge.created{background:var(--color-primary-light, #e3f2fd);color:var(--color-primary-dark, #1565c0)}.action-badge.approved,.action-badge.granted{background:var(--color-success-light, #e8f5e9);color:var(--color-success-dark, #2e7d32)}.action-badge.rejected,.action-badge.revoked{background:var(--color-error-light, #ffebee);color:var(--color-error, #c62828)}.action-badge.changed{background:var(--color-warning-light, #fff3e0);color:var(--color-warning-dark, #e65100)}.action-badge.login{background:var(--color-bg-secondary, #f5f5f5);color:var(--color-text-muted, #666)}.user-link,.actor-link{color:var(--color-primary, #1976d2);text-decoration:none;font-family:monospace;font-size:.85rem}.user-link:hover,.actor-link:hover{text-decoration:underline}.system-actor{font-style:italic;color:var(--color-text-muted, #666);font-size:.85rem}.details-cell{max-width:400px}.detail-row{display:flex;gap:.5rem;font-size:.8rem;margin-bottom:.25rem}.detail-row:last-child{margin-bottom:0}.detail-row .label{font-weight:500;color:var(--color-text-muted, #666)}.detail-row code{font-size:.75rem;background:var(--color-bg-secondary, #f5f5f5);padding:.125rem .25rem;border-radius:3px;word-break:break-all}.detail-row.old code{text-decoration:line-through;opacity:.7}.no-details{color:var(--color-text-muted, #999)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border, #eee)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--color-text-primary, #333)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted, #666);cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--color-text-primary, #333)}.modal-content form{padding:1.5rem}.form-error{padding:.75rem 1rem;background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828);border-radius:6px;margin-bottom:1rem;font-size:.9rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--color-text-primary, #333);font-size:.95rem}.form-group input,.form-group textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary, #1976d2)}.form-group input:disabled,.form-group textarea:disabled{background:var(--color-bg-secondary, #f5f5f5);cursor:not-allowed}.form-group textarea{resize:vertical;font-family:inherit}.form-hint{display:block;margin-top:.35rem;font-size:.8rem;color:var(--color-text-muted, #666)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--color-border, #eee);margin-top:1rem}.btn-cancel{padding:.6rem 1.25rem;background:transparent;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer}.btn-submit{padding:.6rem 1.25rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer}.btn-submit:hover:not(:disabled){background:var(--color-primary-dark, #1565c0)}.btn-submit:disabled,.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.company-list-page{padding:0}.page-actions{display:flex;justify-content:flex-end;margin-bottom:1rem}.btn-create{padding:.6rem 1.2rem;background-color:#28a745;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer}.btn-create:hover{background-color:#218838}.filters-bar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:8px}.search-input{flex:1;min-width:200px;padding:.5rem 1rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem}.filter-select{padding:.5rem 1rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;background:#fff}.filters-bar .btn-refresh{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background-color:var(--color-accent-teal, #458f9c);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.filters-bar .btn-refresh:hover:not(:disabled){background-color:var(--color-accent-teal-dark, #3a7a85);transform:rotate(45deg)}.filters-bar .btn-refresh:disabled{opacity:.5;cursor:not-allowed;transform:none}.error-message{padding:1rem;background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828);border-radius:6px;margin-bottom:1rem}.companies-table-container{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.companies-table{width:100%;border-collapse:collapse}.companies-table th,.companies-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border, #eee)}.companies-table th{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f9f9f9)}.companies-table tbody tr:hover{background:var(--color-bg-hover, #f5f5f5)}.gp-id-cell code{background:var(--color-bg-secondary, #f0f0f0);padding:.25rem .5rem;border-radius:4px;font-size:.9rem;color:var(--color-text-primary, #333)}.company-name-link{color:var(--color-primary, #1976d2);text-decoration:none;font-weight:500}.company-name-link:hover{text-decoration:underline}.count-cell{font-weight:500;color:var(--color-text-muted, #666)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:capitalize}.status-badge.inactive{background:var(--color-text-muted-light, #eeeeee);color:var(--color-text-muted, #616161)}.actions-cell{display:flex;gap:.5rem}.btn-view{padding:.35rem .75rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:4px;font-size:.85rem;text-decoration:none;cursor:pointer}.btn-view:hover{background:var(--color-primary-dark, #1565c0)}.btn-suspend{padding:.35rem .75rem;background:var(--color-warning, #ff9800);color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer}.btn-suspend:hover{background:var(--color-warning-dark, #f57c00)}.btn-activate{padding:.35rem .75rem;background:var(--color-success, #28a745);color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer}.btn-activate:hover{background:var(--color-success-dark, #218838)}.loading-cell,.empty-cell{text-align:center;padding:2rem!important;color:var(--color-text-muted, #666)}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem}.company-type-badge{display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:capitalize}.company-type-badge.type-internal{background:#e3f2fd;color:#1565c0}.company-type-badge.type-vendor{background:#f3e5f5;color:#7b1fa2}.company-type-badge.type-integrator{background:#e8f5e9;color:#2e7d32}.company-type-badge.type-client{background:#fff3e0;color:#e65100}.company-type-badge.type-public{background:#f5f5f5;color:#616161}.company-detail-page{padding:0}.detail-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:1024px){.detail-grid{grid-template-columns:1fr 1fr}.members-section{grid-column:span 2}}.detail-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.detail-section h2{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary, #333);border-bottom:1px solid var(--color-border, #eee);padding-bottom:.75rem}.section-hint{font-size:.85rem;color:var(--color-text-muted, #666);margin-top:-.5rem;margin-bottom:1rem}.info-row{margin-bottom:1rem}.info-row label{display:block;font-weight:500;margin-bottom:.35rem;color:var(--color-text-secondary, #555);font-size:.9rem}.info-row input,.info-row textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem}.info-row input:focus,.info-row textarea:focus{outline:none;border-color:var(--color-primary, #1976d2)}.info-row textarea{resize:vertical;font-family:inherit}.gp-id-display code{background:var(--color-bg-secondary, #f0f0f0);padding:.5rem .75rem;border-radius:6px;display:inline-block;font-size:1rem;font-weight:500}.status-buttons{display:flex;gap:.5rem}.status-btn{padding:.4rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:4px;background:#fff;color:var(--color-text-secondary, #666);font-size:.85rem;cursor:pointer}.status-btn:hover:not(:disabled){background:var(--color-bg-secondary, #f5f5f5)}.status-btn.active{background:var(--color-primary, #1976d2);color:#fff;border-color:var(--color-primary, #1976d2)}.status-btn:disabled{opacity:.5;cursor:not-allowed}.btn-save{margin-top:1rem;padding:.6rem 1.5rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer}.btn-save:hover:not(:disabled){background:var(--color-primary-dark, #1565c0)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.domains-list{margin-bottom:1rem}.empty-domains,.empty-members{padding:1rem;text-align:center;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f5f5f5);border-radius:6px}.domain-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:6px;margin-bottom:.5rem}.domain-name{font-family:monospace;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.primary-badge{font-size:.7rem;font-weight:600;padding:.15rem .4rem;background:var(--color-primary, #1976d2);color:#fff;border-radius:3px;text-transform:uppercase;font-family:sans-serif}.btn-remove-domain{padding:.25rem .5rem;background:transparent;color:var(--color-error, #c62828);border:1px solid var(--color-error, #c62828);border-radius:4px;font-size:.8rem;cursor:pointer}.add-domain-form{display:flex;gap:.5rem}.add-domain-form input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem}.btn-add-domain{padding:.5rem 1rem;background:var(--color-success, #28a745);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;white-space:nowrap}.btn-add-domain:hover:not(:disabled){background:var(--color-success-dark, #218838)}.btn-add-domain:disabled{opacity:.5;cursor:not-allowed}.add-member-form{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:1rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:6px}.add-member-form input[type=email]{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem}.add-member-form select{padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;background:#fff}.hidden-checkbox{display:flex;align-items:center;gap:.35rem;font-size:.9rem;color:var(--color-text-secondary, #666);cursor:pointer}.btn-add-member{padding:.5rem 1rem;background:var(--color-success, #28a745);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer}.btn-add-member:hover:not(:disabled){background:var(--color-success-dark, #218838)}.btn-add-member:disabled{opacity:.5;cursor:not-allowed}.members-table th,.members-table td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--color-border, #eee)}.members-table tbody tr.hidden-member{background:#fff8e1}.member-info .abetech-badge{display:inline-block;margin-top:.25rem;font-size:.7rem;font-weight:600;padding:.1rem .35rem;background:var(--color-primary-light, #e3f2fd);color:var(--color-primary-dark, #1565c0);border-radius:3px;text-transform:uppercase}.role-select,.status-select{padding:.3rem .5rem;border:1px solid var(--color-border, #ddd);border-radius:4px;font-size:.85rem;background:#fff}.btn-remove-member{padding:.25rem .5rem;background:transparent;color:var(--color-error, #c62828);border:1px solid var(--color-error, #c62828);border-radius:4px;font-size:.8rem;cursor:pointer}.btn-remove-member:hover{background:var(--color-error, #c62828);color:#fff}.type-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.type-btn{padding:.4rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:4px;background:#fff;color:var(--color-text-secondary, #666);font-size:.85rem;cursor:pointer;transition:background .15s,border-color .15s}.type-btn:hover:not(:disabled){background:var(--color-bg-secondary, #f5f5f5)}.type-btn:disabled{opacity:.5;cursor:not-allowed}.type-btn.type-internal.active{background:#1565c0;color:#fff;border-color:#1565c0}.type-btn.type-vendor.active{background:#7b1fa2;color:#fff;border-color:#7b1fa2}.type-btn.type-integrator.active{background:#2e7d32;color:#fff;border-color:#2e7d32}.type-btn.type-client.active{background:#e65100;color:#fff;border-color:#e65100}.type-btn.type-public.active{background:#616161;color:#fff;border-color:#616161}.type-changed-at{display:block;margin-top:.4rem;font-size:.8rem;color:var(--color-text-muted, #999)}.save-cancel-buttons{display:flex;gap:.5rem;margin-top:1rem}.btn-cancel{padding:.6rem 1.5rem;background:#fff;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;cursor:pointer}.btn-cancel:hover:not(:disabled){background:var(--color-bg-secondary, #f5f5f5)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.unsaved-indicator{display:inline-block;font-size:.8rem;font-weight:500;color:var(--color-warning-dark, #f57f17);background:#fff8e1;padding:.2rem .6rem;border-radius:4px;margin-left:.5rem}.members-table tbody tr.member-changed{background:#fff8e1}.vendor-settings-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.vendor-setting-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--color-border, #eee);border-radius:6px;cursor:pointer}.vendor-setting-item:hover{background:var(--color-bg-hover, #f5f5f5)}.vendor-setting-item.changed{background:#fff8e1;border-color:var(--color-warning-dark, #f57f17)}.vendor-setting-item input[type=checkbox]{width:16px;height:16px;cursor:pointer}.vendor-name{font-weight:500;flex:1}.hidden-badge{font-size:.75rem;font-weight:600;padding:.15rem .4rem;background:#ffcdd2;color:#c62828;border-radius:3px;text-transform:uppercase}.abuse-flags-page{padding:1.5rem;max-width:1400px;margin:0 auto}.abuse-flags-page .filters-bar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--color-bg-secondary, #f5f5f5);border-radius:8px}.abuse-flags-page .filter-select{padding:.5rem 1rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;background:#fff}.abuse-flags-page .btn-refresh{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background-color:var(--color-accent-teal, #458f9c);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.abuse-flags-page .btn-refresh:hover:not(:disabled){background-color:var(--color-accent-teal-dark, #3a7a85);transform:rotate(45deg)}.abuse-flags-page .btn-refresh:disabled{opacity:.5;cursor:not-allowed;transform:none}.abuse-flags-page .error-message{padding:1rem;background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828);border-radius:6px;margin-bottom:1rem}.flags-table-container{overflow-x:auto;background:var(--color-bg-primary, white);border-radius:8px;box-shadow:0 1px 3px #0000001a}.flags-table{width:100%;border-collapse:collapse}.flags-table th,.flags-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border, #eee)}.flags-table th{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f9f9f9)}.flags-table tbody tr:hover{background:var(--color-bg-hover, #f5f5f5)}.flags-table .loading-cell,.flags-table .empty-cell{text-align:center;padding:2rem!important;color:var(--color-text-muted, #666)}.flag-type-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;font-family:monospace;background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333)}.severity-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.severity-badge.low{background:#e8f5e9;color:#2e7d32}.severity-badge.medium{background:#fff3e0;color:#e65100}.severity-badge.high{background:#ffebee;color:#c62828}.severity-badge.critical{background:#f3e5f5;color:#6a1b9a}.status-badge-flag{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.status-badge-flag.open{background:#fff3e0;color:#e65100}.status-badge-flag.reviewing{background:#e3f2fd;color:#1565c0}.status-badge-flag.dismissed{background:#f5f5f5;color:#757575}.status-badge-flag.actioned{background:#e8f5e9;color:#2e7d32}.status-badge-flag.escalated{background:#fce4ec;color:#c62828}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem}.timestamp-cell{font-size:.85rem;white-space:nowrap}.user-cell{font-size:.85rem;font-family:monospace}.btn-action-flag{padding:.35rem .75rem;font-size:.8rem;font-weight:500;border:1px solid var(--color-border, #ddd);border-radius:4px;background:#fff;cursor:pointer;color:var(--color-primary, #1976d2);transition:background .15s}.btn-action-flag:hover{background:var(--color-bg-secondary, #f5f5f5)}.action-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.action-modal{background:#fff;border-radius:12px;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d;padding:24px}.action-modal h3{margin:0 0 16px;font-size:1.1rem}.action-modal label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px;color:var(--color-text-muted, #666)}.action-modal select,.action-modal textarea{width:100%;padding:.5rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;margin-bottom:12px;font-family:inherit}.action-modal textarea{resize:vertical;min-height:80px}.action-modal-buttons{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.action-modal-buttons button{padding:.5rem 1.25rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer}.btn-cancel{background:transparent;border:1px solid var(--color-border, #ddd);color:var(--color-text-secondary, #666)}.btn-submit-action{background:var(--color-primary, #2563eb);color:#fff;border:none}.btn-submit-action:hover:not(:disabled){background:var(--color-primary-hover, #1d4ed8)}.btn-submit-action:disabled{opacity:.6;cursor:not-allowed}.abuse-flags-page .pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem}.abuse-flags-page .pagination span{color:var(--color-text-muted, #666);font-size:.9rem}.terms-management-page{padding:0}.terms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.terms-header h2{margin:0;font-size:1.25rem;color:var(--color-text-primary, #333)}.btn-add-terms{padding:.5rem 1rem;background:var(--color-success, #28a745);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer}.btn-add-terms:hover{background:var(--color-success-dark, #218838)}.terms-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.terms-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;position:relative}.terms-card.editing{border:2px solid var(--color-primary, #1976d2);box-shadow:0 2px 8px #1976d226}.terms-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.terms-card-header h3{margin:0;font-size:1.1rem;color:var(--color-text-primary, #333)}.terms-card-actions{display:flex;gap:.313rem}.terms-card-actions .btn-edit-terms,.terms-card-actions .btn-bump-version{padding:.156rem .313rem;border:1px solid var(--color-border, #ddd);border-radius:4px;background:#fff;color:var(--color-text-secondary, #666);font-size:.75rem;cursor:pointer}.terms-card-actions .btn-edit-terms:hover{background:var(--color-bg-secondary, #f5f5f5);border-color:var(--color-primary, #1976d2);color:var(--color-primary, #1976d2)}.terms-card-actions .btn-bump-version:hover{background:var(--color-bg-secondary, #f5f5f5);border-color:var(--color-warning, #f9a825);color:var(--color-warning-dark, #f57f17)}.terms-card-actions .btn-delete-terms{padding:.156rem .313rem;border:1px solid var(--color-error, #c62828);border-radius:4px;background:#fff;color:var(--color-error, #c62828);font-size:.75rem;cursor:pointer}.terms-card-actions .btn-delete-terms:hover{background:var(--color-error, #c62828);color:#fff}.terms-card-details{display:flex;flex-direction:column;gap:.5rem}.terms-detail-row{display:flex;gap:.5rem;align-items:baseline;font-size:.9rem}.terms-detail-row .label{font-weight:500;color:var(--color-text-secondary, #666);min-width:110px;flex-shrink:0}.terms-detail-row .value{color:var(--color-text-primary, #333)}.terms-detail-row .value a{color:var(--color-primary, #1976d2);text-decoration:none}.terms-detail-row .value a:hover{text-decoration:underline}.terms-type-badge{display:inline-block;padding:.15rem .5rem;border-radius:3px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.terms-type-badge.tos{background:#e3f2fd;color:#1565c0}.terms-type-badge.privacy{background:#f3e5f5;color:#7b1fa2}.terms-type-badge.nda{background:#e8f5e9;color:#2e7d32}.terms-type-badge.acceptable_use{background:#fff3e0;color:#e65100}.acceptance-badges{display:flex;flex-wrap:wrap;gap:.3rem}.company-type-badge{display:inline-block;padding:.1rem .4rem;border-radius:3px;font-size:.7rem;font-weight:600;text-transform:uppercase;background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-secondary, #666)}.company-type-badge.internal{background:#e3f2fd;color:#1565c0}.company-type-badge.vendor{background:#f3e5f5;color:#7b1fa2}.company-type-badge.integrator{background:#e8f5e9;color:#2e7d32}.company-type-badge.client{background:#fff3e0;color:#e65100}.company-type-badge.public{background:#f5f5f5;color:#616161}.terms-edit-form{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border, #eee);display:flex;flex-direction:column;gap:.75rem}.terms-edit-form .form-group{display:flex;flex-direction:column;gap:.25rem}.terms-edit-form .form-group label{font-weight:500;font-size:.85rem;color:var(--color-text-secondary, #555)}.terms-edit-form .form-group input,.terms-edit-form .form-group select,.terms-edit-form .form-group textarea{padding:.4rem .6rem;border:1px solid var(--color-border, #ddd);border-radius:4px;font-size:.9rem}.terms-edit-form .form-group textarea{min-height:120px;resize:vertical;font-family:inherit}.terms-edit-form .form-group input:focus,.terms-edit-form .form-group select:focus,.terms-edit-form .form-group textarea:focus{outline:none;border-color:var(--color-primary, #1976d2)}.terms-edit-form .checkbox-group{display:flex;flex-direction:row;flex-wrap:wrap;gap:.25rem .5rem}.terms-edit-form .checkbox-group label{display:flex;align-items:center;gap:.25rem;font-size:.85rem;font-weight:400;color:var(--color-text-primary, #333);text-transform:none;cursor:pointer;white-space:nowrap}.terms-edit-form .checkbox-group label input[type=checkbox]{width:auto}.terms-edit-buttons{display:flex;gap:.313rem;margin-top:.5rem}.terms-edit-form .terms-edit-buttons .btn-save{padding:.219rem .563rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer}.terms-edit-form .terms-edit-buttons .btn-save:hover:not(:disabled){background:var(--color-primary-dark, #1565c0)}.terms-edit-form .terms-edit-buttons .btn-save:disabled{opacity:.5;cursor:not-allowed}.terms-edit-form .terms-edit-buttons .btn-cancel{padding:.219rem .563rem;background:#fff;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #ddd);border-radius:4px;font-size:.8rem;cursor:pointer}.terms-edit-form .terms-edit-buttons .btn-cancel:hover{background:var(--color-bg-secondary, #f5f5f5)}.terms-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.terms-modal{background:#fff;border-radius:8px;padding:1.5rem;width:480px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000026}.terms-modal h3{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary, #333)}.terms-modal .form-group{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.25rem}.terms-modal .form-group label{font-weight:500;font-size:.85rem;color:var(--color-text-secondary, #555)}.terms-modal .form-group input,.terms-modal .form-group select,.terms-modal .form-group textarea{padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem}.terms-modal .form-group textarea{min-height:120px;resize:vertical;font-family:inherit}.terms-modal .form-group input:focus,.terms-modal .form-group select:focus,.terms-modal .form-group textarea:focus{outline:none;border-color:var(--color-primary, #1976d2)}.terms-modal .checkbox-group{display:flex;flex-direction:row;flex-wrap:wrap;gap:.25rem .5rem}.terms-modal .checkbox-group label{display:flex;align-items:center;gap:.25rem;font-size:.85rem;font-weight:400;color:var(--color-text-primary, #333);text-transform:none;cursor:pointer;white-space:nowrap}.terms-modal .checkbox-group label input[type=checkbox]{width:auto}.terms-modal-buttons{display:flex;gap:.5rem;margin-top:1rem;justify-content:flex-end}.terms-modal .terms-modal-buttons .btn-create{padding:.4rem 1rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer}.terms-modal .terms-modal-buttons .btn-create:hover:not(:disabled){background:var(--color-primary-dark, #1565c0)}.terms-modal .terms-modal-buttons .btn-create:disabled{opacity:.5;cursor:not-allowed}.terms-modal .terms-modal-buttons .btn-cancel{padding:.4rem 1rem;background:#fff;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.85rem;cursor:pointer}.terms-modal .terms-modal-buttons .btn-cancel:hover{background:var(--color-bg-secondary, #f5f5f5)}.terms-empty{text-align:center;padding:3rem;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f5f5f5);border-radius:8px}.terms-management-page .loading-state,.terms-management-page .error-state{text-align:center;padding:3rem;color:var(--color-text-muted, #666)}.terms-error{color:var(--color-error, #c62828);font-size:.85rem;margin-top:.25rem}.my-company-list-page{padding:1.5rem;max-width:1200px;margin:0 auto}.btn-back-to-app{padding:.5rem 1rem;background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333);text-decoration:none;border-radius:6px;font-weight:500;font-size:.9rem;transition:background .15s}.btn-back-to-app:hover{background:var(--color-border, #ddd)}.error-message{padding:1rem;background:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828);border-radius:6px;margin-bottom:1.5rem}.loading-state{text-align:center;padding:3rem;color:var(--color-text-muted, #666)}.empty-state{text-align:center;padding:4rem 2rem;background:var(--color-bg-secondary, #f9f9f9);border-radius:8px}.empty-state svg{width:64px;height:64px;color:var(--color-text-muted, #999);margin-bottom:1rem}.empty-state h2{margin:0 0 .5rem;color:var(--color-text-primary, #333)}.empty-state p{margin:0 0 .5rem;color:var(--color-text-muted, #666)}.empty-state .hint{font-size:.9rem;color:var(--color-text-muted, #888)}.companies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.company-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.company-card-header{padding:1.25rem;background:var(--color-bg-secondary, #f9f9f9);border-bottom:1px solid var(--color-border, #eee)}.company-card-header h2{margin:0 0 .75rem;font-size:1.25rem;color:var(--color-text-primary, #333)}.company-card-header .badges{display:flex;gap:.5rem}.company-card-body{padding:1.25rem}.info-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem}.info-item:last-child{margin-bottom:0}.info-item .label{color:var(--color-text-muted, #666)}.company-card-actions{padding:1rem 1.25rem;border-top:1px solid var(--color-border, #eee);display:flex;gap:.75rem;flex-wrap:wrap}.btn-manage{padding:.5rem 1rem;background:var(--color-primary, #1976d2);color:#fff;text-decoration:none;border-radius:6px;font-weight:500;font-size:.9rem;transition:background .15s}.btn-manage:hover{background:var(--color-primary-dark, #1565c0);color:#fff}.btn-manage-secondary{padding:.5rem 1rem;background:transparent;color:var(--color-primary, #1976d2);text-decoration:none;border:1px solid var(--color-primary, #1976d2);border-radius:6px;font-weight:500;font-size:.9rem;transition:all .15s}.btn-manage-secondary:hover{background:var(--color-primary-light, #e3f2fd);color:var(--color-primary-dark, #1565c0)}.no-admin-access{color:var(--color-text-muted, #888);font-size:.9rem;font-style:italic}.role-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.role-badge.admin{background:var(--color-primary-light, #e3f2fd);color:var(--color-primary-dark, #1565c0)}.role-badge.member{background:var(--color-bg-secondary, #f5f5f5);color:var(--color-text-muted, #666)}.status-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.status-badge.active{background:var(--color-success-light, #e8f5e9);color:var(--color-success-dark, #2e7d32)}.status-badge.suspended{background:var(--color-warning-light, #fff3e0);color:var(--color-warning-dark, #e65100)}.status-badge.inactive{background:var(--color-bg-secondary, #f5f5f5);color:var(--color-text-muted, #666)}.status-badge.pending{background:var(--color-warning-light, #fff3e0);color:var(--color-warning-dark, #e65100)}@media(max-width:768px){.page-header{flex-direction:column;gap:1rem}.companies-grid{grid-template-columns:1fr}}.company-members-page{padding:1.5rem;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.btn-manage-domains{padding:.5rem 1rem;background:transparent;color:var(--color-primary, #1976d2);text-decoration:none;border:1px solid var(--color-primary, #1976d2);border-radius:6px;font-weight:500;font-size:.9rem}.btn-manage-domains:hover{background:var(--color-primary-light, #e3f2fd)}.invite-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:1.5rem}.invite-section h2{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary, #333)}.invite-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.invite-form input[type=email]{flex:1;min-width:250px;padding:.6rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem}.invite-form input:focus{outline:none;border-color:var(--color-primary, #1976d2)}.invite-form select{padding:.6rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;background:#fff}.invite-form button{padding:.6rem 1.25rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer}.invite-form button:hover:not(:disabled){background:var(--color-primary-dark, #1565c0)}.invite-form button:disabled{opacity:.5;cursor:not-allowed}.invite-hint{margin:.75rem 0 0;font-size:.85rem;color:var(--color-text-muted, #666)}.members-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.members-section h2{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary, #333);border-bottom:1px solid var(--color-border, #eee);padding-bottom:.75rem}.empty-members{padding:2rem;text-align:center;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f5f5f5);border-radius:6px}.members-list{overflow-x:auto}.members-table{width:100%;border-collapse:collapse}.members-table th,.members-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border, #eee)}.members-table th{font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #666);background:var(--color-bg-secondary, #f9f9f9)}.members-table tbody tr:hover{background:var(--color-bg-hover, #f5f5f5)}.member-info{display:flex;flex-direction:column}.member-info strong{color:var(--color-text-primary, #333)}.member-info .email{font-size:.85rem;color:var(--color-text-muted, #666)}.role-select,.status-select{padding:.35rem .5rem;border:1px solid var(--color-border, #ddd);border-radius:4px;font-size:.85rem;background:#fff}.btn-remove{padding:.3rem .6rem;background:transparent;color:var(--color-error, #c62828);border:1px solid var(--color-error, #c62828);border-radius:4px;font-size:.8rem;cursor:pointer}.btn-remove:hover{background:var(--color-error, #c62828);color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border, #eee)}.pagination button{padding:.5rem 1rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.pagination button:hover:not(:disabled){background:var(--color-primary-dark, #1565c0)}.pagination span{color:var(--color-text-muted, #666);font-size:.9rem}@media(max-width:768px){.page-header{flex-direction:column;gap:1rem}.invite-form{flex-direction:column;align-items:stretch}.invite-form input[type=email],.invite-form select,.invite-form button{width:100%}}.company-domains-page{padding:1.5rem;max-width:900px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.page-header-left{display:flex;align-items:flex-start;gap:1rem}.page-header-left h1{margin:0;font-size:1.75rem;color:var(--color-text-primary, #333)}.page-header-left .subtitle{margin:.25rem 0 0;color:var(--color-text-muted, #666)}.btn-back{padding:.5rem 1rem;background:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-primary, #333);text-decoration:none;border-radius:6px;font-weight:500;font-size:.9rem}.btn-back:hover{background:var(--color-border, #ddd)}.btn-manage-members{padding:.5rem 1rem;background:transparent;color:var(--color-primary, #1976d2);text-decoration:none;border:1px solid var(--color-primary, #1976d2);border-radius:6px;font-weight:500;font-size:.9rem}.btn-manage-members:hover{background:var(--color-primary-light, #e3f2fd)}.loading-state,.error-state{text-align:center;padding:3rem;color:var(--color-text-muted, #666)}.error-state a{display:block;margin-top:1rem;color:var(--color-primary, #1976d2)}.info-banner{display:flex;gap:.75rem;padding:1rem;background:var(--color-primary-light, #e3f2fd);border-radius:8px;margin-bottom:1.5rem}.info-banner svg{width:24px;height:24px;color:var(--color-primary, #1976d2);flex-shrink:0;margin-top:.1rem}.info-banner p{margin:0;font-size:.9rem;color:var(--color-primary-dark, #1565c0);line-height:1.5}.add-domain-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:1.5rem}.add-domain-section h2{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary, #333)}.add-domain-form{display:flex;gap:.75rem}.add-domain-form input{flex:1;padding:.6rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem;font-family:monospace}.add-domain-form input:focus{outline:none;border-color:var(--color-primary, #1976d2)}.add-domain-form button{padding:.6rem 1.25rem;background:var(--color-success, #28a745);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;white-space:nowrap}.add-domain-form button:hover:not(:disabled){background:var(--color-success-dark, #218838)}.add-domain-form button:disabled{opacity:.5;cursor:not-allowed}.form-hint{margin:.75rem 0 0;font-size:.85rem;color:var(--color-text-muted, #666)}.domains-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.domains-section h2{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary, #333);border-bottom:1px solid var(--color-border, #eee);padding-bottom:.75rem}.empty-domains{padding:2rem;text-align:center;background:var(--color-bg-secondary, #f5f5f5);border-radius:6px}.empty-domains p{margin:0 0 .5rem;color:var(--color-text-muted, #666)}.empty-domains .hint{font-size:.85rem;color:var(--color-text-muted, #888)}.domains-list{display:flex;flex-direction:column;gap:.75rem}.domain-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-bg-secondary, #f9f9f9);border-radius:6px}.domain-info{display:flex;align-items:center;gap:.5rem;flex:1}.domain-name{font-family:monospace;font-size:1rem;font-weight:500;color:var(--color-text-primary, #333)}.primary-badge{font-size:.7rem;font-weight:600;padding:.15rem .4rem;background:var(--color-primary, #1976d2);color:#fff;border-radius:3px;text-transform:uppercase}.domain-meta{flex-shrink:0}.added-date{font-size:.85rem;color:var(--color-text-muted, #666)}.btn-remove-domain{padding:.35rem .75rem;background:transparent;color:var(--color-error, #c62828);border:1px solid var(--color-error, #c62828);border-radius:4px;font-size:.85rem;cursor:pointer;flex-shrink:0}.btn-remove-domain:hover{background:var(--color-error, #c62828);color:#fff}@media(max-width:768px){.page-header{flex-direction:column;gap:1rem}.add-domain-form{flex-direction:column}.domain-item{flex-direction:column;align-items:flex-start}.domain-meta{order:1}.btn-remove-domain{order:2;align-self:flex-end}}.my-configurations-page{min-height:100vh;background:var(--color-bg-primary, #f5f5f5)}.my-configurations-page .page-header{background:var(--color-header-bg, #1a1a1a);color:#fff;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}.my-configurations-page .header-left{display:flex;align-items:center;gap:1.5rem}.my-configurations-page .btn-back{color:var(--color-text-muted, #888);text-decoration:none;font-size:.9rem}.my-configurations-page .btn-back:hover{color:#fff}.my-configurations-page h1{margin:0;font-size:1.5rem;font-weight:600}.my-configurations-page .page-content{padding:2rem;max-width:1400px;margin:0 auto}.filters-row{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.35rem}.filter-group label{font-size:.8rem;font-weight:600;color:var(--color-text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.filter-group select,.filter-group input{padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.9rem;background:#fff;min-width:150px}.filter-group.search-group{flex:1;min-width:200px}.filter-group.search-group input{width:100%;max-width:300px}.loading-state,.empty-state,.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;background:#fff;border-radius:8px;border:1px solid var(--color-border, #eee)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border, #eee);border-top-color:var(--color-primary, #1976d2);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.empty-state p{margin:0 0 1rem;color:var(--color-text-secondary, #666)}.empty-state button,.error-message button{padding:.5rem 1rem;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:6px;cursor:pointer}.error-message{background:var(--color-error-bg, #ffebee);border-color:var(--color-error, #c62828);color:var(--color-error, #c62828)}.error-message button{margin-top:1rem}.configurations-table{width:100%;background:#fff;border-radius:8px;border:1px solid var(--color-border, #eee);border-collapse:collapse;overflow:hidden}.configurations-table th,.configurations-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border, #eee)}.configurations-table th{background:var(--color-bg-secondary, #f8f9fa);font-size:.8rem;font-weight:600;color:var(--color-text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.configurations-table tbody tr:hover{background:var(--color-bg-hover, #fafafa)}.configurations-table tbody tr:last-child td{border-bottom:none}.col-id code{font-size:.9rem;background:var(--color-bg-secondary, #f5f5f5);padding:.2rem .4rem;border-radius:4px}.col-price{font-weight:500;font-family:system-ui,-apple-system,sans-serif}.col-client{color:var(--color-text-secondary, #666)}.status-badge{display:inline-block;padding:.2rem .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;border-radius:4px}.status-draft{background:var(--color-warning-bg, #fff3e0);color:var(--color-warning, #ef6c00)}.status-quoted{background:var(--color-info-bg, #e3f2fd);color:var(--color-info, #1565c0)}.status-ordered{background:var(--color-success-bg, #e8f5e9);color:var(--color-success, #2e7d32)}.status-archived{background:var(--color-bg-secondary, #f5f5f5);color:var(--color-text-muted, #888)}.visibility-badge{display:inline-block;padding:.2rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;border-radius:4px}.visibility-badge.private{background:var(--color-bg-secondary, #f5f5f5);color:var(--color-text-muted, #888)}.visibility-badge.shared{background:var(--color-purple-bg, #f3e5f5);color:var(--color-purple, #7b1fa2)}.visibility-badge.company{background:var(--color-info-bg, #e3f2fd);color:var(--color-info, #1565c0)}.col-actions{white-space:nowrap}.btn-action{padding:.35rem .75rem;font-size:.8rem;border-radius:4px;cursor:pointer;transition:all .15s;margin-right:.5rem}.btn-action:last-child{margin-right:0}.btn-share{background:transparent;color:var(--color-primary, #1976d2);border:1px solid var(--color-primary, #1976d2)}.btn-share:hover:not(:disabled){background:var(--color-primary, #1976d2);color:#fff}.btn-action:disabled{opacity:.4;cursor:not-allowed}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.pagination button{padding:.5rem 1rem;background:#fff;border:1px solid var(--color-border, #ddd);border-radius:6px;cursor:pointer;font-size:.9rem}.pagination button:hover:not(:disabled){background:var(--color-bg-secondary, #f5f5f5)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:.9rem;color:var(--color-text-secondary, #666)}.dev-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#1a1a2e,#16213e)}.dev-login-container{max-width:700px;width:100%;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 20px #0003}.dev-login-header{text-align:center;margin-bottom:2rem}.dev-badge{display:inline-block;padding:.25rem .75rem;background:#ff6b35;color:#fff;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:4px;margin-bottom:.5rem}.dev-login-header h1{margin:.5rem 0;font-size:1.5rem;color:#1a1a2e}.dev-login-header p{margin:0;color:#666;font-size:.9rem}.preset-accounts h2,.custom-login h2{font-size:1rem;color:#333;margin:0 0 1rem;font-weight:600}.account-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.account-card{display:flex;flex-direction:column;padding:1rem;border:1px solid #e0e0e0;border-radius:8px;background:#f9f9f9;cursor:pointer;text-align:left;transition:all .2s}.account-card:hover:not(:disabled){background:#e3f2fd;border-color:#1976d2;transform:translateY(-2px)}.account-card:disabled{opacity:.5;cursor:not-allowed}.account-name{font-weight:600;color:#1a1a2e;margin-bottom:.25rem}.account-email{font-size:.85rem;color:#666;font-family:monospace;margin-bottom:.5rem}.account-desc{font-size:.8rem;color:#888}.divider{display:flex;align-items:center;margin:2rem 0;gap:1rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.divider span{color:#999;font-size:.85rem;text-transform:uppercase}.custom-login form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:#333}.form-group input{padding:.75rem 1rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.form-group input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.btn-login{padding:.75rem 1.5rem;background:#1976d2;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-login:hover:not(:disabled){background:#1565c0}.btn-login:disabled{opacity:.5;cursor:not-allowed}.error-message{margin-top:1rem;padding:1rem;background:#ffebee;color:#c62828;border-radius:6px;text-align:center}.dev-login-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #e0e0e0}.dev-login-footer p{margin:0;font-size:.85rem;color:#666;line-height:1.5}.dev-login-footer strong{color:#ff6b35}.external-callback-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary, #f5f5f5);padding:2rem}.callback-container{background:#fff;border-radius:8px;padding:3rem;text-align:center;max-width:400px;width:100%;box-shadow:0 2px 8px #0000001a}.callback-container h2{margin:1rem 0 .5rem;font-size:1.5rem;color:var(--text-primary, #333)}.callback-container p{color:var(--text-secondary, #666);margin:.5rem 0}.callback-spinner{width:48px;height:48px;border:4px solid var(--border-color, #e0e0e0);border-top-color:var(--primary-color, #2563eb);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.callback-success-icon{width:64px;height:64px;background:var(--success-color, #22c55e);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto}.callback-error-icon{width:64px;height:64px;background:var(--error-color, #ef4444);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto}.callback-error-message{color:var(--error-color, #ef4444);font-weight:500}.callback-redirect{font-size:.875rem;color:var(--text-muted, #999);margin-top:1rem}.callback-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}.callback-btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;border:none}.callback-btn-primary{background:var(--primary-color, #2563eb);color:#fff}.callback-btn-primary:hover{background:var(--primary-hover, #1d4ed8)}.callback-btn-secondary{background:transparent;color:var(--text-secondary, #666);border:1px solid var(--border-color, #e0e0e0)}.callback-btn-secondary:hover{background:var(--bg-secondary, #f5f5f5)}
