:root{--color-primary: #0d9488;--color-primary-hover: #0f766e;--color-primary-light: #ccfbf1;--color-accent: #14b8a6;--color-accent-hover: #2dd4bf;--color-navy: #01213a;--color-navy-light: #0a3a5c;--color-text: #1e293b;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-bg: #f8fafc;--color-bg-card: #ffffff;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.breadcrumb{margin-bottom:20px}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;gap:6px 4px;list-style:none;padding:0;margin:0;font-size:.9rem}.breadcrumb-item{display:flex;align-items:center;gap:6px}.breadcrumb-sep{color:var(--color-text-muted);pointer-events:none}.breadcrumb a{color:var(--color-text-muted);text-decoration:none}.breadcrumb a:hover{color:var(--color-primary)}.breadcrumb-current{color:var(--color-text);font-weight:600}.password-input-wrap{width:100%}.password-input-inner{position:relative;display:flex;align-items:center}.password-input-inner .login-input{padding-right:48px;width:100%}.password-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:1.1rem;padding:4px;opacity:.7;line-height:1}.password-toggle:hover{opacity:1}.password-strength{margin-top:8px;display:flex;align-items:center;gap:10px}.password-strength-bars{display:flex;gap:4px}.password-strength-bar{width:24px;height:4px;border-radius:2px;background:var(--color-border);transition:background var(--transition-fast)}.password-strength-bar.strength-1{background:#dc2626}.password-strength-bar.strength-2{background:#f59e0b}.password-strength-bar.strength-3{background:#eab308}.password-strength-bar.strength-4{background:var(--color-primary)}.password-strength-label{font-size:.8rem;color:var(--color-text-muted)}.page-search-wrap{max-width:1100px;margin:0 auto 20px}.page-search{width:100%;max-width:320px;padding:10px 14px 10px 36px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;background:var(--color-bg-card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM6.5 12a5.5 5.5 0 1 1 0-11 5.5 5.5 0 0 1 0 11z'/%3E%3C/svg%3E") no-repeat 12px center}.page-search:focus{outline:none;border-color:var(--color-primary)}.faq-section{max-width:640px;margin:48px auto 0;padding-top:32px;border-top:1px solid var(--color-border)}.faq-section h2{font-size:1.25rem;font-weight:700;color:var(--color-navy);margin:0 0 20px;text-align:center}.faq-list{list-style:none;padding:0;margin:0}.faq-item{border-bottom:1px solid var(--color-border)}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 0;background:none;border:none;font-size:1rem;font-weight:600;color:var(--color-text);text-align:left;cursor:pointer;font-family:inherit}.faq-question:hover{color:var(--color-primary)}.faq-question .faq-icon{flex-shrink:0;margin-left:12px;transition:transform var(--transition-fast)}.faq-item.open .faq-icon{transform:rotate(180deg)}.faq-answer{padding:0 0 16px;font-size:.95rem;color:var(--color-text-muted);line-height:1.6}.faq-answer-inner{padding:0;margin:0}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--color-bg)}.error-boundary-card{max-width:420px;text-align:center;background:var(--color-bg-card);padding:48px 32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.error-boundary-icon{color:var(--color-text-muted);margin-bottom:24px}.error-boundary-card h1{font-size:1.5rem;font-weight:700;color:var(--color-navy);margin:0 0 12px}.error-boundary-card p{font-size:.95rem;color:var(--color-text-muted);margin:0 0 24px;line-height:1.5}.error-boundary-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.error-boundary-btn{padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.error-boundary-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.error-boundary-link{padding:12px 24px;font-size:1rem;font-weight:600;color:var(--color-primary);text-decoration:none;border-radius:var(--radius-md);border:2px solid var(--color-border);transition:border-color var(--transition-fast),color var(--transition-fast)}.error-boundary-link:hover{border-color:var(--color-primary);color:var(--color-primary-hover)}.fullpage-loader{position:fixed;inset:0;background:linear-gradient(160deg,#f0fdfa,#f8fafc,#e0f2fe);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .25s ease}.fullpage-loader .spinner{animation:spin .8s cubic-bezier(.5,0,.5,1) infinite}.fullpage-loader p{margin:16px 0 0;font-size:.95rem;font-weight:500;color:var(--color-text-muted)}.fullpage-loader-brand{font-size:.8rem!important;color:var(--color-primary)!important;font-weight:600!important;margin-top:8px!important;letter-spacing:.02em;animation:fadeIn .6s ease .3s both}.spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s cubic-bezier(.5,0,.5,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-loading{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:40px;padding:10px 20px;font-size:.95rem;font-weight:600;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.btn-loading:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-loading:disabled{cursor:not-allowed;opacity:.85}.btn-loading--active .btn-loading-text{visibility:hidden}.btn-loading-spinner{position:absolute;display:inline-flex;align-items:center;justify-content:center}.btn-loading-spinner-dot{width:18px;height:18px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}.btn-loading--primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;box-shadow:0 2px 8px #0d948859}.btn-loading--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 14px #0d948866}.btn-loading--secondary{background:var(--color-bg-card);color:var(--color-navy);border:1px solid var(--color-border)}.btn-loading--secondary:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.btn-loading--danger{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}.btn-loading--danger:hover:not(:disabled){transform:translateY(-2px)}.btn-loading--ghost{background:transparent;color:var(--color-text)}.btn-loading--ghost:hover:not(:disabled){background:#0000000d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn .35s ease forwards}.animate-slide-up{animation:slideUp .4s cubic-bezier(.4,0,.2,1) forwards}.animate-scale-in{animation:scaleIn .3s ease forwards}.page-transition-enter{opacity:0;transform:translateY(8px)}.page-transition-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.toast{position:fixed;top:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:9998;animation:toastIn .3s ease;max-width:90%}.toast-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.toast-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.toast-icon{font-weight:700;flex-shrink:0}.toast-message{font-size:.95rem;font-weight:500}.toast-close{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.7;padding:0 4px;line-height:1}.toast-close:hover{opacity:1}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.page-wrap{min-height:100vh;padding:32px 24px 48px;background:var(--color-bg);font-family:inherit}.page-header{max-width:1100px;margin:0 auto 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.page-title{font-size:clamp(1.5rem,3vw,1.75rem);font-weight:800;color:var(--color-navy);margin:0;letter-spacing:-.02em}.page-actions{display:flex;gap:12px;flex-wrap:wrap}.btn-primary{background:var(--color-primary);color:#fff;padding:12px 24px;font-size:.95rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-card);color:var(--color-navy);padding:12px 24px;font-size:.95rem;font-weight:600;border:2px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.leak-playbook{margin-top:16px;margin-bottom:16px;padding:14px 16px;border-radius:var(--radius-md);background:#f1f5f9;border:1px dashed #cbd5e1}.leak-playbook-title{font-size:.9rem;font-weight:700;color:#0f172a;margin:0 0 8px}.leak-playbook-list{margin:0;padding-left:18px;font-size:.85rem;color:#4b5563;line-height:1.6}.leak-playbook-item-tag{display:inline-block;margin-right:6px;padding:2px 8px;border-radius:999px;background:#e0f2fe;color:#0369a1;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.org-container{min-height:100vh;padding:32px 24px 48px;background:var(--color-bg);font-family:inherit}.org-header{max-width:1100px;margin:0 auto 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.org-header h1{font-size:clamp(1.5rem,3vw,1.75rem);font-weight:800;color:var(--color-navy);margin:0;letter-spacing:-.02em}.create-btn{background:var(--color-primary);color:#fff;padding:12px 24px;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}button.create-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.create-card{max-width:520px;margin:0 auto 40px;background:var(--color-bg-card);padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.create-card h2{font-size:1.35rem;margin-bottom:20px;color:var(--color-navy);text-align:center;font-weight:700}.create-form input{width:100%;padding:14px 16px;margin-bottom:16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;box-sizing:border-box;font-family:inherit}.create-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d948826}.submit-btn{width:100%;padding:14px;background:var(--color-primary);color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.submit-btn:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.error-message{background:#fef2f2;color:#b91c1c;padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;text-align:center;font-size:.9rem;border:1px solid #fecaca}.org-list{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.org-card{background:var(--color-bg-card);padding:28px 24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:box-shadow var(--transition-normal),transform var(--transition-normal);cursor:pointer;text-decoration:none;color:inherit;display:block}.org-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#0d948833}.org-card h3{font-size:1.25rem;font-weight:700;color:var(--color-navy);margin-bottom:8px}.org-card p{color:var(--color-text-muted);font-size:.95rem;margin:0}.empty-state,.loading-text{text-align:center;padding:48px 24px;color:var(--color-text-muted);font-size:1rem;grid-column:1 / -1}.onboarding-card{max-width:560px;margin:0 auto 32px;background:linear-gradient(135deg,#f0fdfa,#ecfeff);padding:28px 32px;border-radius:var(--radius-lg);border:1px solid rgba(13,148,136,.2)}.onboarding-card h2{font-size:1.25rem;font-weight:700;color:var(--color-text);margin:0 0 20px}.onboarding-steps{margin:0 0 24px;padding-left:22px;color:var(--color-text-muted);font-size:.95rem;line-height:1.7}.onboarding-steps li{margin-bottom:10px}.onboarding-cta{display:inline-block;padding:12px 24px;background:var(--color-primary);color:#fff;font-size:.95rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s ease,transform .2s ease}.onboarding-cta:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.empty-state-improved{padding:48px 24px!important;text-align:center;grid-column:1 / -1}.empty-state-icon{font-size:2.5rem;color:var(--color-primary);opacity:.6;margin-bottom:16px}.empty-state-title{font-size:1.2rem!important;font-weight:700!important;color:var(--color-text)!important;margin:0 0 8px!important}.empty-state-desc{font-size:.95rem!important;color:var(--color-text-muted)!important;margin:0 0 24px!important}.empty-state-cta{padding:14px 28px;background:var(--color-primary);color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s ease,transform .2s ease}.empty-state-cta:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.create-btn-primary{background:var(--color-primary)!important}.create-btn-primary:hover{background:var(--color-primary-hover)!important}@media(max-width:768px){.org-header{flex-direction:column;text-align:center}.org-header h1{font-size:28px}.org-list{grid-template-columns:1fr}.create-card{padding:24px}}.installs-container{min-height:100vh;padding:32px 24px 48px;background:var(--color-bg);font-family:inherit}.installs-header{max-width:1100px;margin:0 auto 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.installs-header h1{font-size:clamp(1.5rem,3vw,1.75rem);font-weight:800;color:var(--color-navy);margin:0;letter-spacing:-.02em}.header-buttons{display:flex;gap:12px;flex-wrap:wrap}.create-install-card{max-width:560px;margin:0 auto 40px;background:var(--color-bg-card);padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.create-install-card h2{text-align:center;margin-bottom:24px;color:var(--color-navy);font-size:1.35rem;font-weight:700}.install-form select,.install-form input{width:100%;padding:14px 16px;margin-bottom:16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;box-sizing:border-box;font-family:inherit}.install-form select:focus,.install-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d948826}.installs-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px}.install-card{background:var(--color-bg-card);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.install-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#0d948826}.install-info h3.install-name{font-size:1.15rem;color:var(--color-primary);cursor:pointer;margin-bottom:8px;font-weight:700}.install-info h3.install-name:hover{text-decoration:underline}.install-info p{color:var(--color-text-muted);font-size:.9rem;margin:0}.install-actions button{padding:10px 20px;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;font-size:.9rem;transition:background-color var(--transition-fast),transform var(--transition-fast)}.btn-connect{background:var(--color-primary);color:#fff}.btn-connect:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.btn-connected{background:var(--color-primary-light);color:#065f46;cursor:default}.btn-no-permission{background:var(--color-border);color:var(--color-text-muted);cursor:not-allowed}@media(max-width:768px){.installs-header{flex-direction:column;text-align:center}.installs-grid{grid-template-columns:1fr}.install-card{flex-direction:column;align-items:flex-start;gap:16px}.install-actions,.install-actions button{width:100%}}.team-container{min-height:100vh;padding:32px 24px 48px;background:var(--color-bg);font-family:inherit}.team-title{text-align:center;font-size:clamp(1.5rem,3vw,1.75rem);font-weight:800;color:var(--color-navy);margin:0 0 32px;letter-spacing:-.02em}.no-permission{min-height:60vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:1.1rem;color:#b91c1c}.add-member-card{max-width:560px;margin:0 auto 40px;background:var(--color-bg-card);padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.add-member-card h2{text-align:center;margin-bottom:24px;color:var(--color-navy);font-size:1.35rem;font-weight:700}.add-member-form input,.add-member-form select{width:100%;padding:14px 16px;margin-bottom:16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;box-sizing:border-box;font-family:inherit}.add-member-form input:focus,.add-member-form select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d948826}.team-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px}.member-card{background:var(--color-bg-card);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.member-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.member-info{display:flex;align-items:center;gap:16px}.avatar{width:52px;height:52px;background:var(--color-primary);color:#fff;font-size:1.25rem;font-weight:700;border-radius:50%;display:flex;justify-content:center;align-items:center;flex-shrink:0}.member-info h3{margin:0;font-size:1.05rem;color:var(--color-navy);text-transform:capitalize;font-weight:700}.member-info .email{margin:4px 0 0;color:var(--color-text-muted);font-size:.9rem}.member-info .role{margin:8px 0 0}.badge-owner{background:#f59e0b;color:#fff;padding:4px 10px;border-radius:100px;font-size:.75rem;font-weight:600}.badge-role{background:var(--color-primary-light);color:var(--color-primary);padding:4px 10px;border-radius:100px;font-size:.75rem;font-weight:600}.member-actions{display:flex;flex-direction:column;gap:10px}.role-select{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;min-width:140px}.btn-remove{background:#dc2626;color:#fff;padding:8px 16px;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;font-size:.9rem;transition:background-color var(--transition-fast)}.btn-remove:hover{background:#b91c1c}@media(max-width:768px){.team-grid{grid-template-columns:1fr}.member-card{flex-direction:column;align-items:flex-start;gap:20px}.member-actions,.role-select,.btn-remove{width:100%}}.roles-container{min-height:100vh;padding:32px 24px 48px;background:var(--color-bg);font-family:inherit}.roles-header{max-width:1100px;margin:0 auto 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.roles-header h1{font-size:clamp(1.5rem,3vw,1.75rem);font-weight:800;color:var(--color-navy);margin:0;letter-spacing:-.02em}.roles-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.role-card{background:var(--color-bg-card);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.role-card h3{text-transform:capitalize;font-weight:700;font-size:1.15rem;color:var(--color-navy);margin:0}.role-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#0d948826}.role-info h3{font-size:1.15rem;font-weight:700;color:var(--color-navy);margin:0 0 8px}.badge-default{font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:100px;margin-left:8px;background:var(--color-primary);color:#fff}.btn-edit{background:var(--color-navy);color:#fff;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;font-size:.9rem;transition:background-color var(--transition-fast),transform var(--transition-fast)}.btn-edit:hover{background:var(--color-navy-light);transform:translateY(-1px)}.empty-state,.loading-text{grid-column:1 / -1;text-align:center;padding:60px;color:#6b7280;font-size:18px}.empty-state p{margin:10px 0}@media(max-width:768px){.roles-header{flex-direction:column;text-align:center}.roles-grid{grid-template-columns:1fr}.role-card{flex-direction:column;align-items:flex-start;gap:16px}.btn-edit{width:100%}}.create-role-container{min-height:100vh;padding:32px 24px;background:var(--color-bg);font-family:inherit}.create-role-container .breadcrumb{max-width:480px;margin-left:auto;margin-right:auto;margin-bottom:24px}.create-role-container .create-role-card{margin:0 auto}.create-role-card{background:var(--color-bg-card);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);width:100%;max-width:480px;text-align:center}.create-role-card h1{font-size:1.6rem;font-weight:800;color:var(--color-navy);margin-bottom:8px;letter-spacing:-.02em}.create-role-card .subtitle{color:var(--color-text-muted);font-size:.95rem;margin-bottom:28px;display:block}.create-role-form input{width:100%;padding:14px 16px;margin-bottom:24px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-sizing:border-box;font-family:inherit}.create-role-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d948826}.create-role-form input:disabled{background:var(--color-bg);cursor:not-allowed}.form-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn-cancel{padding:12px 24px;font-size:1rem;font-weight:600;border:2px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:var(--color-bg-card);color:var(--color-text);transition:border-color var(--transition-fast),background var(--transition-fast)}.btn-cancel:hover{border-color:var(--color-text-muted);background:var(--color-bg)}.btn-submit{padding:12px 24px;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;background:var(--color-primary);color:#fff;transition:background-color var(--transition-fast),transform var(--transition-fast);min-width:140px}.btn-submit:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn-submit:disabled{background:var(--color-text-muted);cursor:not-allowed;opacity:.8}@media(max-width:480px){.create-role-card{padding:30px 20px}.create-role-card h1{font-size:24px}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}.permissions-container{min-height:100vh;display:flex;justify-content:center;padding:32px 24px;background:var(--color-bg);font-family:inherit}.permissions-card{background:var(--color-bg-card);padding:36px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);width:100%;max-width:640px}.permissions-card h1{font-size:1.5rem;font-weight:800;color:var(--color-navy);margin-bottom:8px;text-align:center;letter-spacing:-.02em}.permissions-card .role-name{color:var(--color-primary);text-transform:capitalize;font-weight:700}.permissions-card .subtitle{text-align:center;color:var(--color-text-muted);font-size:.95rem;margin-bottom:28px;display:block}.permissions-actions-row{display:flex;gap:12px;margin-bottom:16px}.btn-permission-toggle{padding:8px 16px;font-size:.9rem;font-weight:500;color:var(--color-primary);background:var(--color-primary-light);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.btn-permission-toggle:hover{background:var(--color-primary);color:#fff}.permissions-list{margin-bottom:32px}.permission-item{display:flex;align-items:flex-start;padding:14px 16px;margin-bottom:10px;background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:border-color var(--transition-fast),background var(--transition-fast);cursor:pointer}.permission-item:hover{background:var(--color-primary-light);border-color:#0d948840}.permission-item input[type=checkbox]{margin-top:3px;margin-right:14px;width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.permission-label{flex:1;font-size:.95rem}.permission-label strong{display:block;color:var(--color-navy)}.permission-label .description{display:block;font-size:.85rem;color:var(--color-text-muted);margin-top:4px}.actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.btn-save{padding:12px 24px;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;min-width:160px;background:var(--color-primary);color:#fff;transition:background-color var(--transition-fast),transform var(--transition-fast)}.btn-save:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn-save:disabled{background:var(--color-text-muted);cursor:not-allowed;opacity:.8}.loading-text,.empty-text{text-align:center;color:var(--color-text-muted);font-size:1rem;padding:40px}.permissions-container .no-permission{min-height:60vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:1.1rem;color:#b91c1c}@media(max-width:600px){.permissions-card{padding:30px 20px}.permission-item{flex-direction:column;align-items:flex-start}.permission-item input[type=checkbox]{margin-bottom:10px}.actions{flex-direction:column}.btn-cancel,.btn-save{width:100%}}.alert{padding:14px;border-radius:10px;text-align:center;font-weight:600;font-size:16px}.alert.success{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert.error{background-color:#fee2e2;color:#dc2626;border:1px solid #fecaca}.products-content{padding:1.5rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#64748b;font-size:.95rem}.alert-danger{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;border-left:4px solid #ef4444;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem}.alert-danger strong{display:block;color:#dc2626;font-size:1rem;margin-bottom:.5rem}.alert-danger p{color:#991b1b;font-size:.875rem;margin:0;line-height:1.5}.empty-state{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;border:1px dashed #cbd5e1}.empty-state p{color:#64748b;margin:.25rem 0;font-size:.95rem}.empty-state p:first-child{font-weight:600;color:#475569;font-size:1.05rem}.products-table-wrapper{background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000f;overflow:hidden;border:1px solid #e2e8f0}.products-table{width:100%;border-collapse:collapse;font-size:.9rem}.products-table thead{background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.products-table th{padding:1rem 1.25rem;text-align:left;font-weight:600;color:#475569;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e2e8f0}.products-table tbody tr{transition:background .2s ease;border-bottom:1px solid #f1f5f9}.products-table tbody tr:hover{background:#f8fafc}.products-table tbody tr:last-child{border-bottom:none}.products-table td{padding:1rem 1.25rem;color:#334155;vertical-align:middle}.image-cell{width:70px}.image-cell img{width:50px;height:50px;object-fit:contain;border-radius:8px;border:1px solid #e2e8f0;box-shadow:0 2px 6px #0000000f}.no-image{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:8px;font-size:.65rem;color:#94a3b8;text-align:center}.title-cell{font-weight:500;color:#1e293b;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{display:inline-block;padding:.35rem .75rem;border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.03em}.status-active{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;border:1px solid #86efac}.status-draft{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #fcd34d}.status-archived{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#64748b;border:1px solid #cbd5e1}.status-unknown{background:#f1f5f9;color:#64748b;border:1px solid #cbd5e1}.price-cell{font-weight:600;color:#059669;font-family:Segoe UI,system-ui,sans-serif}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-top:1px solid #e2e8f0}.pagination button{padding:.6rem 1.25rem;border:1px solid #cbd5e1;background:#fff;border-radius:8px;font-size:.85rem;font-weight:500;color:#475569;cursor:pointer;transition:all .2s ease}.pagination button:hover:not(:disabled){background:#16d4a8;color:#fff;border-color:transparent;transform:translateY(-1px)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{font-size:.875rem;color:#64748b;font-weight:500}@media(max-width:768px){.products-content{padding:1rem}.products-table{font-size:.8rem}.products-table th,.products-table td{padding:.75rem}.title-cell{max-width:120px}.pagination{flex-wrap:wrap;gap:.75rem}.pagination button{padding:.5rem 1rem;font-size:.8rem}}.ph-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:9999;overflow-y:auto;padding:24px;box-sizing:border-box}.ph-modal{background:#fff;width:100%;max-width:520px;max-height:calc(100vh - 48px);overflow-y:auto;border-radius:14px;box-shadow:0 20px 40px #0003;padding:20px;animation:fadeIn .2s ease-in-out;margin:auto;flex-shrink:0}.ph-header{display:flex;align-items:center;gap:12px;border-bottom:1px solid #eee;padding-bottom:12px}.ph-icon{background:#eef4ff;color:#2563eb;font-size:20px;padding:10px;border-radius:50%}.ph-header h3{margin:0;font-size:18px}.ph-header p{margin:0;font-size:13px;color:#6b7280}.ph-close{margin-left:auto;background:none;border:none;font-size:18px;cursor:pointer}.ph-product-box{background:#f9fafb;padding:14px;border-radius:10px;margin-top:16px}.ph-product-box span{font-size:12px;color:#6b7280}.ph-product-box strong{display:block;margin-top:4px;font-size:15px}.ph-issues{margin-top:18px}.ph-issues h4{font-size:14px;margin-bottom:10px}.ph-issue-item{background:#fff1f2;border:1px solid #fecaca;color:#b91c1c;padding:12px;border-radius:10px;margin-bottom:8px;font-size:14px}.ph-healthy{background:#ecfdf5;border:1px solid #bbf7d0;color:#047857;padding:12px;border-radius:10px;font-size:14px}.ph-close-btn{margin-top:18px;width:100%;background:#16d4a8;color:#fff;border:none;padding:12px;border-radius:10px;font-size:15px;cursor:pointer}.ph-close-btn:hover{background:#3ae0b4}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.notfound-container{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:24px;background:var(--color-bg)}.notfound-content{text-align:center;max-width:420px}.notfound-code{display:block;font-size:4rem;font-weight:800;color:var(--color-primary);line-height:1;margin-bottom:8px;letter-spacing:-.04em}.notfound-content h1{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0 0 12px}.notfound-content p{font-size:.95rem;color:var(--color-text-muted);line-height:1.6;margin:0 0 24px}.notfound-btn{display:inline-block;padding:14px 28px;background:var(--color-primary);color:#fff;font-weight:600;font-size:1rem;border-radius:var(--radius-md);text-decoration:none;transition:background-color .2s ease,transform .2s ease}.notfound-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.notfound-links{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 24px;margin-top:28px;padding-top:24px;border-top:1px solid var(--color-border)}.notfound-links a{font-size:.95rem;font-weight:600;color:var(--color-primary);text-decoration:none}.notfound-links a:hover{text-decoration:underline}.profile-page{max-width:560px;margin:0 auto;padding:24px}.profile-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:24px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.profile-card h1{font-size:1.35rem;margin:0 0 20px;color:var(--color-navy)}.profile-card h2{font-size:1.1rem;margin:0 0 16px;color:var(--color-navy)}.profile-form label{display:block;margin-bottom:16px;font-weight:500;color:var(--color-text)}.profile-input{display:block;width:100%;margin-top:6px;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem}.profile-msg{margin:0 0 12px;font-size:.9rem}.profile-msg.success{color:var(--color-primary-hover)}.profile-msg.error{color:#b91c1c}
