@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#faf9f7;--surface:#ffffff;--surface2:#f5f3ef;--surface3:#ede9e3;--border:#e8e2d8;--border2:#d6cfc3;--text:#1a1612;--text2:#5c5044;--text3:#9c8e80;--accent:#6b3a1f;--accent2:#8B4513;--accent3:#a0522d;--accent-soft:rgba(107,58,31,0.08);--accent-mid:rgba(107,58,31,0.15);--gold:#B8860B;--gold-soft:rgba(184,134,11,0.12);--red:#c0392b;--yellow:#d97706;--green:#16a34a;--blue:#1d4ed8;--shadow-sm:0 1px 3px rgba(26,22,18,0.08),0 1px 2px rgba(26,22,18,0.04);--shadow:0 4px 12px rgba(26,22,18,0.08),0 2px 4px rgba(26,22,18,0.04);--shadow-lg:0 20px 40px rgba(26,22,18,0.12),0 8px 16px rgba(26,22,18,0.06);--font-display:"Cormorant Garamond",Georgia,serif;--font:"DM Sans",sans-serif;--mono:"DM Mono",monospace;--radius:10px;--radius-sm:6px;--radius-lg:16px;--cream:#f0ebe0;--cream-dark:#e8e0d0;--cream-mid:#ede5d6;--brown:#2c1a0e;--brown-mid:#4a2e18;--brown-light:#7a5c3e;--gold-site:#b5821a;--gold-light:#d4a043;--gold-warm:#e8a917;--border-site:rgba(44,26,14,0.1);--border-mid:rgba(44,26,14,0.18);--navy:#233E99}.contact-input{width:100%;padding:14px 18px;border:1.5px solid #eee;border-radius:10px;font-family:Outfit,sans-serif;fontSize:.95rem;outline:none;transition:border-color .2s;background:#fdfdfd}.contact-input:focus{border-color:var(--navy);background:#fff}.contact-btn{background:var(--navy);color:#fff;border:none;border-radius:10px;padding:16px 32px;font-weight:700;font-family:Outfit,sans-serif;cursor:pointer;transition:transform .2s,background .2s}.contact-btn:hover{background:#1a2f75;transform:translateY(-2px)}.contact-btn:active{transform:translateY(0)}.rv{opacity:0;transform:translateY(32px);transition:opacity .75s cubic-bezier(.22,1,.36,1),transform .75s cubic-bezier(.22,1,.36,1)}.rv.in,.rv[data-rv=in]{opacity:1;transform:translateY(0)}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--surface2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.erp-root{height:100vh;height:100dvh}.auth-screen,.erp-root{display:flex;overflow:hidden}.auth-screen{width:100vw;min-height:100vh;background:linear-gradient(135deg,#faf9f7,#f0ebe3 50%,#e8e0d4);align-items:center;justify-content:center;position:relative;padding:100px 20px}.auth-screen:before{width:600px;height:600px;background:radial-gradient(circle,rgba(107,58,31,.06) 0,transparent 70%);top:-100px;right:-100px}.auth-screen:after,.auth-screen:before{content:"";position:absolute;border-radius:50%}.auth-screen:after{width:400px;height:400px;background:radial-gradient(circle,rgba(184,134,11,.05) 0,transparent 70%);bottom:-50px;left:-50px}.auth-card{padding:52px 48px;width:440px}.auth-card,.signup-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);position:relative;z-index:1}.signup-card{width:860px;max-height:92vh;overflow-y:auto;display:grid;grid-template-columns:300px 1fr}.signup-left{background:linear-gradient(160deg,var(--accent) 0,#5a2e10 60%,#3d1e0a 100%);border-radius:var(--radius-lg) 0 0 var(--radius-lg);padding:48px 36px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.signup-left:before{width:250px;height:250px;background:rgba(255,255,255,.04);top:-60px;right:-80px}.signup-left:after,.signup-left:before{content:"";position:absolute;border-radius:50%}.signup-left:after{width:180px;height:180px;background:rgba(184,134,11,.12);bottom:40px;left:-40px}.signup-left-content{position:relative;z-index:1}.signup-left-logo{display:flex;align-items:center;gap:12px;margin-bottom:40px;text-decoration:none;color:inherit;cursor:pointer}.signup-left-icon{width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;font-size:22px;border:1px solid rgba(255,255,255,.2)}.signup-left-brand{font-family:var(--font-display);font-size:22px;font-weight:700;color:white}.signup-left-sub{font-size:10px;color:rgba(255,255,255,.5);letter-spacing:1.2px;text-transform:uppercase;margin-top:1px}.signup-left-heading{font-family:var(--font-display);font-size:32px;font-weight:600;color:white;line-height:1.25;margin-bottom:16px}.signup-left-desc{font-size:13px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:36px}.signup-role-preview{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;gap:10px}.signup-role-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.signup-role-name{font-size:13px;font-weight:600;color:white}.signup-role-desc{font-size:11px;color:rgba(255,255,255,.5);margin-top:1px}.signup-left-footer{position:relative;z-index:1}.signup-left-signin{font-size:12px;color:rgba(255,255,255,.5)}.signup-left-signin a,.signup-left-signin span{color:rgba(255,255,255,.85);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.signup-left-signin a:hover,.signup-left-signin span:hover{color:white}.signup-right{padding:44px 40px}.signup-right-header{margin-bottom:30px}.signup-right-title{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--text);margin-bottom:5px}.signup-right-sub{font-size:13px;color:var(--text2)}.role-selector-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:22px}.role-selector-item{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:10px}.role-selector-item:hover{border-color:var(--border2);background:var(--surface2)}.role-selector-item.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px rgba(107,58,31,.06)}.role-selector-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.role-selector-label{font-size:13px;font-weight:600;color:var(--text)}.role-selector-sub{font-size:10px;color:var(--text3);margin-top:1px}.role-selector-check{margin-left:auto;font-size:14px;color:var(--accent);opacity:0;transition:opacity .15s}.role-selector-item.selected .role-selector-check{opacity:1}.step-indicator{display:flex;align-items:center;gap:6px;margin-bottom:28px}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);transition:all .2s}.step-dot.active{background:var(--accent);width:24px;border-radius:4px}.step-dot.done{background:var(--green)}.step-label{font-size:11px;color:var(--text3);margin-left:6px;font-weight:500}.signup-success{flex-direction:column;padding:60px 40px;text-align:center;min-height:400px}.signup-success,.success-icon{display:flex;align-items:center;justify-content:center}.success-icon{width:72px;height:72px;border-radius:50%;background:rgba(22,163,74,.1);border:2px solid rgba(22,163,74,.3);font-size:32px;margin-bottom:24px;animation:successPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes successPop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.success-title{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--text);margin-bottom:10px}.success-desc{font-size:14px;color:var(--text2);line-height:1.6;max-width:320px;margin-bottom:32px}.success-user-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;width:100%;max-width:320px;text-align:left;margin-bottom:28px}.success-user-row{display:flex;align-items:center;gap:12px}.success-avatar{width:42px;height:42px;border-radius:10px;justify-content:center;font-size:16px;font-weight:700;color:white;flex-shrink:0}.auth-logo,.success-avatar{display:flex;align-items:center}.auth-logo{gap:12px;margin-bottom:40px;text-decoration:none;color:inherit;cursor:pointer;border-radius:12px;outline:none}.auth-logo:hover{background:rgba(107,58,31,.04)}.auth-logo:focus-visible{box-shadow:0 0 0 3px rgba(107,58,31,.18)}.auth-logo-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent3));display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 12px rgba(107,58,31,.3)}.auth-logo-text{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:.3px;color:var(--text)}.auth-logo-sub{font-size:11px;color:var(--text3);font-weight:400;letter-spacing:1.2px;text-transform:uppercase;margin-top:1px}.auth-divider{width:40px;height:2px;background:linear-gradient(90deg,var(--accent),var(--gold));margin-bottom:8px}.auth-title{font-family:var(--font-display);font-size:30px;font-weight:600;margin-bottom:6px;color:var(--text)}.auth-sub{font-size:13px;color:var(--text2);margin-bottom:36px;line-height:1.5}.auth-label{font-size:11px;font-weight:600;color:var(--text2);letter-spacing:.8px;text-transform:uppercase;margin-bottom:7px;display:block}.auth-input{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:all .2s;margin-bottom:18px}.input-row{position:relative}.auth-input.has-action{padding-right:74px}.input-action{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:1px solid var(--border);background:var(--surface);color:var(--text2);height:28px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.input-action:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.input-action:active{transform:translateY(-50%) scale(.98)}.auth-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px rgba(107,58,31,.08)}.auth-input.error{border-color:var(--red)}.auth-select{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;margin-bottom:28px;cursor:pointer;appearance:none;transition:all .2s}.auth-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(107,58,31,.08)}.auth-link{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:6px 10px;border-radius:999px;color:var(--accent2);font-weight:600;text-decoration:underline;text-underline-offset:3px;cursor:pointer;transition:all .15s}.auth-link:hover{color:var(--accent3);background:var(--accent-soft)}.auth-link:active{background:var(--accent-mid)}.auth-link:focus-visible{outline:none;background:var(--accent-soft);box-shadow:0 0 0 3px rgba(107,58,31,.18)}.date-field{position:relative;width:100%}.date-field.disabled{opacity:.7}.date-trigger-row{width:100%;padding:0;display:flex;align-items:center;gap:10px}.date-input::placeholder{color:var(--text3)}.date-icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .15s}.date-icon-btn:hover{background:var(--surface3);color:var(--text);border-color:var(--border2)}.date-icon-btn:disabled{cursor:not-allowed;opacity:.7}.date-icon-btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(107,58,31,.18)}.date-popover{position:absolute;z-index:50;top:calc(100% + 8px);left:0;width:280px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 14px 40px rgba(16,24,40,.16);padding:12px}.date-popover-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.date-month{font-size:13px;font-weight:700;color:var(--text);font-family:var(--font-display)}.date-nav{width:34px;height:34px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.date-nav:hover{background:var(--surface3);color:var(--text);border-color:var(--border2)}.date-scroll{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:8px;margin-bottom:10px}.date-scroll-select{width:100%;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:12px;font-weight:700;padding:0 10px;outline:none;cursor:pointer}.date-scroll-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(107,58,31,.12);background:var(--surface)}.date-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:8px}.date-dow-cell{font-size:10px;font-weight:700;color:var(--text3);text-align:center}.date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.date-cell{height:34px;border-radius:10px;border:1px solid transparent;background:var(--surface2);color:var(--text);font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.date-cell.empty{background:transparent;border-color:transparent;cursor:default}.date-cell:hover{background:var(--surface3)}.date-cell.today{border-color:var(--accent-mid)}.date-cell.selected{background:var(--accent);color:#fff;border-color:var(--accent)}.date-cell:disabled{opacity:.35;cursor:not-allowed}.date-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.date-action{border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s}.date-action:hover{background:var(--surface3);color:var(--text);border-color:var(--border2)}.btn-primary{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:var(--radius-sm);padding:13px;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;letter-spacing:.3px;transition:all .2s;box-shadow:0 4px 12px rgba(107,58,31,.3)}.btn-primary:hover{background:linear-gradient(135deg,var(--accent2),var(--accent3));transform:translateY(-1px);box-shadow:0 6px 16px rgba(107,58,31,.35)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.demo-users{margin-top:28px;padding-top:22px;border-top:1px solid var(--border)}.demo-title{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-weight:500}.demo-chips{display:flex;flex-wrap:wrap;gap:6px}.demo-chip{font-size:11px;padding:5px 12px;border-radius:20px;cursor:pointer;border:1px solid var(--border2);color:var(--text2);background:var(--surface2);transition:all .15s;font-family:var(--mono);font-weight:500}.demo-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.auth-switch{margin-top:22px;text-align:center;font-size:13px;color:var(--text2)}.auth-switch a{color:var(--accent);font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.auth-switch a:hover{color:var(--accent2)}.form-error{font-size:11px;color:var(--red)}.form-error,.password-strength{margin-top:-14px;margin-bottom:14px}.strength-bar{display:flex;gap:4px;margin-top:4px}.strength-seg{height:3px;flex:1;border-radius:2px;background:var(--border2);transition:background .2s}.strength-label{font-size:11px;color:var(--text3);margin-top:3px}.sidebar{width:248px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;box-shadow:var(--shadow-sm);position:fixed;top:0;bottom:0;left:0;z-index:400;transform:translateX(-105%);transition:transform .18s ease}.sidebar.open{transform:translateX(0)}.sidebar-header{padding:22px 20px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;cursor:pointer;outline:none;transition:background .15s,box-shadow .15s}.sidebar-header:hover{background:var(--surface2)}.sidebar-header:focus-visible{box-shadow:0 0 0 3px rgba(107,58,31,.18)}.logo-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent3));display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 2px 8px rgba(107,58,31,.25)}.logo-text{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);letter-spacing:.2px}.logo-sub{font-size:10px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-top:1px}.sidebar-user{margin:14px 12px 8px;background:var(--surface2);border-radius:var(--radius-sm);padding:12px 14px;gap:10px;border:1px solid var(--border)}.sidebar-user,.user-avatar{display:flex;align-items:center}.user-avatar{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent3));justify-content:center;font-size:13px;font-weight:700;color:white;flex-shrink:0}.user-name{font-size:13px;font-weight:600;color:var(--text)}.user-role{font-size:10px;color:var(--accent);font-weight:600;letter-spacing:.5px;text-transform:uppercase;font-family:var(--mono);margin-top:1px}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.nav-section{padding:14px 20px 6px}.nav-section-label{font-size:10px;color:var(--text3);font-weight:600;letter-spacing:1.2px;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;margin:1px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);font-size:13px;font-weight:500;transition:all .15s}.btn,.btn-primary,.demo-chip,.nav-item,.role-selector-item,.signup-role-preview{touch-action:manipulation}.nav-item:active{transform:scale(.99)}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-mid);font-weight:600}.nav-icon{width:18px;text-align:center;font-size:14px;flex-shrink:0}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.logout-btn{width:100%;display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;color:var(--text3);font-family:var(--font);font-size:13px;font-weight:500;transition:all .15s}.logout-btn:hover{background:rgba(192,57,43,.06);color:var(--red)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:58px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:var(--surface);flex-shrink:0}.topbar-home{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;text-decoration:none;color:white;background:linear-gradient(135deg,var(--accent),var(--accent3));box-shadow:0 2px 10px rgba(107,58,31,.22);border:1px solid rgba(107,58,31,.15);transition:all .15s}.topbar-home:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(107,58,31,.28)}.topbar-home:active{transform:translateY(0)}.topbar-home:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(107,58,31,.18),0 4px 14px rgba(107,58,31,.28)}.topbar-title{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text)}.topbar-actions{display:flex;align-items:center;gap:10px}.content{flex:1;overflow-y:auto;padding:28px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 20px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}button.kpi-card{width:100%;text-align:left;cursor:pointer;appearance:none}button.kpi-card:focus-visible{outline:2px solid var(--accent-mid);outline-offset:2px}.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.kpi-accent-bar{position:absolute;top:0;left:0;right:0;height:3px}.kpi-icon{font-size:22px;margin-bottom:12px}.kpi-label{font-size:11px;color:var(--text3);font-weight:600;letter-spacing:.8px;text-transform:uppercase;margin-bottom:8px}.kpi-value{font-family:var(--font-display);font-size:38px;font-weight:700;letter-spacing:-1px;margin-bottom:2px;line-height:1}.kpi-sub{font-size:12px;color:var(--text2);margin-top:4px}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.table-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.table-title{font-size:14px;font-weight:600;color:var(--text)}.table-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}table{width:100%;border-collapse:collapse}th{padding:10px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.8px;text-transform:uppercase;background:var(--surface2)}td,th{border-bottom:1px solid var(--border)}td{padding:12px 16px;font-size:13px;vertical-align:middle;color:var(--text)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface2)}.td-mono{font-family:var(--mono);font-size:12px;color:var(--accent);font-weight:500}.table-link{background:transparent;border:none;padding:0;cursor:pointer;text-align:left;color:var(--blue)}.table-link:hover{text-decoration:underline}.table-link:focus-visible{outline:2px solid rgba(29,78,216,.35);outline-offset:2px;border-radius:4px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;font-family:var(--mono)}.badge-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.status-sla{display:flex;gap:8px;flex-wrap:wrap}.btn,.status-sla{align-items:center}.btn{padding:8px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;transition:all .15s;display:inline-flex;gap:6px}.btn-accent{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 2px 8px rgba(107,58,31,.25)}.btn-accent:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(107,58,31,.3)}.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--border2);background:var(--surface3)}.btn-danger{background:rgba(192,57,43,.08);color:var(--red);border:1px solid rgba(192,57,43,.2)}.btn-danger:hover{background:rgba(192,57,43,.14)}.btn-sm{padding:5px 11px;font-size:12px}.search-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px 7px 32px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;width:220px;transition:all .2s}.search-input:focus{border-color:var(--accent);width:260px}.search-wrap{position:relative}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:12px}.select-filter{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;color:var(--text2);font-family:var(--font);font-size:12px;outline:none;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:rgba(26,22,18,.5);z-index:100;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:700px;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-lg{width:860px}.modal-header{padding:22px 26px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:var(--font-display);font-size:20px;font-weight:600}.modal-body{padding:24px 26px}.modal-footer{padding:16px 26px;border-top:1px solid var(--border);justify-content:flex-end;gap:10px;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.close-btn,.modal-footer{display:flex;background:var(--surface2)}.close-btn{border:1px solid var(--border);color:var(--text3);width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;align-items:center;justify-content:center;transition:all .15s}.close-btn:hover{color:var(--text);background:var(--surface3)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.bulk-nav{display:flex;gap:8px;flex-wrap:wrap}.bulk-pill{min-width:34px;justify-content:center}.bulk-pill.active{background:var(--accent-soft);border-color:rgba(107,58,31,.25);color:var(--accent)}.bulk-pill.partial{border-color:rgba(107,58,31,.35);color:var(--accent);background:rgba(107,58,31,.04)}.bulk-pill.partial:hover{border-color:rgba(107,58,31,.45);background:rgba(107,58,31,.06);color:var(--accent)}.bulk-pill.filled{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:rgba(107,58,31,.35);color:#fff}.bulk-pill.filled:hover{background:linear-gradient(135deg,var(--accent2),var(--accent3));border-color:rgba(107,58,31,.45);color:#fff}.bulk-pill.active.filled{box-shadow:0 0 0 3px rgba(107,58,31,.12)}.bulk-ticket-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full{grid-column:1/-1}.form-label{font-size:11px;font-weight:600;color:var(--text2);letter-spacing:.5px;text-transform:uppercase}.form-input,.form-select,.form-textarea{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(107,58,31,.06);background:var(--surface)}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-section{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:1.2px;text-transform:uppercase;margin:22px 0 14px;padding-bottom:8px;border-bottom:2px solid var(--accent-mid)}.detail-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:20px}.detail-card{background:var(--surface2);border-radius:var(--radius-sm);padding:16px;border:1px solid var(--border)}.detail-label{font-size:10px;color:var(--text3);font-weight:600;letter-spacing:.8px;text-transform:uppercase;margin-bottom:5px}.detail-value{font-size:14px;font-weight:600;color:var(--text)}.timeline{display:flex;align-items:center;gap:0;margin-bottom:24px;overflow-x:auto;padding:4px 0 12px}.timeline-step{flex:1;min-width:80px}.timeline-node,.timeline-step{display:flex;align-items:center}.timeline-node{flex-direction:column;gap:5px;flex:1}.timeline-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:2px solid var(--border);background:var(--surface2);color:var(--text3);flex-shrink:0}.timeline-circle.done{background:var(--accent);border-color:var(--accent);color:white}.timeline-circle.current{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:white}.timeline-label{font-size:9px;color:var(--text3);font-weight:500;text-align:center;max-width:70px;line-height:1.3}.timeline-label.current,.timeline-label.done{color:var(--text2)}.timeline-line{flex:1;height:2px;background:var(--border);min-width:20px}.timeline-line.done{background:var(--accent)}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:10px 20px;font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab.disabled{opacity:.55;cursor:not-allowed}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding:8px 0}.bar-col{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1}.bar{width:100%;border-radius:4px 4px 0 0;background:var(--accent);min-height:4px}.bar-label{font-size:10px;color:var(--text3);font-weight:500;text-align:center}.bar-val{font-size:11px;color:var(--text2);font-weight:600;font-family:var(--mono)}.sla-bar{height:6px;border-radius:3px;background:var(--surface3);overflow:hidden;margin-top:6px}.sla-fill{height:100%;border-radius:3px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--border);font-size:13px}.info-row:last-child{border-bottom:none}.info-key{color:var(--text2)}.info-val{font-weight:600;color:var(--text)}.access-chip{padding:3px 9px;border-radius:4px;font-size:11px;font-weight:600;font-family:var(--mono)}.access-full{background:rgba(22,163,74,.1);color:var(--green)}.access-partial{background:rgba(217,119,6,.1);color:var(--yellow)}.access-none{color:var(--text3)}.access-none,.tag{background:var(--surface2)}.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;color:var(--text2);border:1px solid var(--border);font-family:var(--mono)}.empty-state{text-align:center;padding:52px;color:var(--text3)}.empty-icon{font-size:36px;margin-bottom:14px;opacity:.5}.empty-text{font-size:14px;color:var(--text3)}.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch}.page-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.page-header-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .15s}.sidebar-toggle:hover{background:var(--surface3);color:var(--text)}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:350;background:rgba(26,22,18,.36);opacity:0;pointer-events:none;transition:opacity .18s ease}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.page-header{margin-bottom:24px}.page-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--text)}.page-sub{font-size:13px;color:var(--text2);margin-top:3px}.notification{position:fixed;top:20px;right:20px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--green);border-radius:var(--radius);padding:14px 18px;z-index:200;font-size:13px;color:var(--text);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}.role-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .2s;box-shadow:var(--shadow-sm)}.role-card:hover{box-shadow:var(--shadow);border-color:var(--border2)}.perm-matrix{width:100%;border-collapse:collapse}.perm-matrix th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.8px;text-transform:uppercase;border-bottom:2px solid var(--border);background:var(--surface2)}.perm-matrix td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.perm-matrix tr:last-child td{border-bottom:none}.perm-matrix tr:hover td{background:var(--surface2)}.perm-checkbox{width:17px;height:17px;accent-color:var(--accent);cursor:pointer}.color-picker-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.color-swatch{width:26px;height:26px;border-radius:6px;cursor:pointer;transition:all .15s;border:2px solid transparent;flex-shrink:0}.color-swatch.active{border-color:var(--text);transform:scale(1.15)}.new-role-badge{background:var(--gold-soft);color:var(--gold);border-radius:10px;border:1px solid rgba(184,134,11,.2)}.new-role-badge,.system-badge{font-size:10px;padding:2px 7px;font-weight:600;font-family:var(--mono)}.system-badge{background:var(--accent-soft);color:var(--accent);border-radius:10px;border:1px solid var(--accent-mid)}@media (max-width:900px){.auth-screen{padding:16px 16px calc(16px + env(safe-area-inset-bottom))}.auth-card{width:100%;max-width:440px;padding:36px 24px}.signup-card{width:100%;max-width:560px;grid-template-columns:1fr;max-height:none;overflow-y:visible}.signup-left{border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:26px 20px}.signup-left-logo{margin-bottom:18px}.signup-left-heading{font-size:26px;margin-bottom:10px}.signup-left-desc{margin-bottom:14px}.signup-left-footer,.signup-role-preview{display:none}.signup-right{padding:24px 20px}.role-selector-grid{grid-template-columns:1fr}.sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .15s}.sidebar-toggle:hover{background:var(--surface3);color:var(--text)}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:350;background:rgba(26,22,18,.36);opacity:0;pointer-events:none;transition:opacity .18s ease}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.sidebar{position:fixed;top:0;bottom:0;left:0;z-index:400;transform:translateX(-105%);transition:transform .18s ease}.sidebar.open{transform:translateX(0)}.main{min-width:0}.topbar{padding:0 16px}.topbar-title{max-width:54vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.content{padding:16px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:12px}.kpi-card{padding:18px 16px}.kpi-value{font-size:32px}.two-col{grid-template-columns:1fr}.bulk-ticket-grid,.form-grid{grid-template-columns:1fr;gap:12px}.bulk-ticket-grid>*{grid-column:auto!important}.detail-grid{grid-template-columns:1fr}.table-header{flex-wrap:wrap;gap:10px}.search-input,.search-input:focus{width:min(440px,100%)}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{white-space:nowrap}.modal,.modal-lg{width:92vw;max-width:700px}.modal-header{padding:18px 18px 14px}.modal-body{padding:18px}.modal-footer{padding:12px 18px}}@media (max-width:520px){.auth-card{padding:28px 18px}.auth-title{font-size:26px}.signup-left-heading,.signup-right-title{font-size:22px}.topbar-title{max-width:48vw;font-size:18px}.kpi-grid{grid-template-columns:1fr}.topbar{padding:0 12px;height:54px}.content{padding:14px 14px calc(14px + env(safe-area-inset-bottom))}.page-title{font-size:20px}.page-sub{font-size:12px}.table-header{padding:14px}td,th{padding:10px 12px}tr:hover td{background:transparent}.modal-overlay{align-items:flex-end}.modal,.modal-lg{width:100vw;max-width:100vw;max-height:92dvh;border-radius:18px 18px 0 0}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%;justify-content:center}.auth-input,.form-input,.form-select,.form-textarea,.search-input,.select-filter{font-size:16px}.topbar-actions .btn{padding:6px 10px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation:none!important;transition:none!important}}.nv-dropdown{position:relative}.nv-dropdown-trigger{display:inline-flex;align-items:center;gap:5px;font-size:.83rem;color:var(--brown-mid);font-weight:600;text-decoration:none;padding:9px 16px;border:1.5px solid transparent;border-radius:8px;cursor:pointer;background:transparent;font-family:Outfit,sans-serif;transition:border-color .2s,color .2s}.nv-dropdown-trigger:hover{border-color:var(--gold);color:var(--brown)}.nv-dropdown-trigger svg{transition:transform .25s}.nv-dropdown:hover .nv-dropdown-trigger svg{transform:rotate(180deg)}.nv-dropdown-menu{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(8px);min-width:220px;background:rgba(255,255,255,.97);backdrop-filter:blur(18px);border:1px solid var(--border-mid);border-radius:12px;padding:8px 0;box-shadow:0 12px 40px rgba(44,26,14,.14);opacity:0;visibility:hidden;transition:opacity .22s,transform .22s,visibility .22s;pointer-events:none;z-index:1001}.nv-dropdown:hover .nv-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto}.nv-dropdown-menu a{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:.84rem;color:var(--brown-mid);font-weight:500;text-decoration:none;transition:background .15s,color .15s,padding-left .2s}.nv-dropdown-menu a:hover{background:rgba(181,130,26,.08);color:var(--brown);padding-left:20px}.nv-dropdown-menu a img{width:24px;height:24px;object-fit:contain;border-radius:4px;background:#f5f5f5}.nv-dropdown-menu a:first-child{border-radius:12px 12px 0 0}.nv-dropdown-menu a:last-child{border-radius:0 0 12px 12px}.ft-wrap{background:#1a1c23;color:rgba(255,255,255,.7);padding:80px 6vw 40px;font-family:Outfit,sans-serif;position:relative;overflow:hidden}.ft-wrap:before{content:"";position:absolute;inset:0;background:url(/hero.webp) 50%/cover no-repeat;opacity:.05;pointer-events:none}.ft-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;max-width:1200px;margin:0 auto}.ft-col h4{color:#fff;font-size:1.1rem;font-weight:700;margin-bottom:24px;position:relative;display:inline-block}.ft-col h4:after{content:"";position:absolute;left:calc(100% + 12px);top:50%;width:30px;height:2px;background:var(--gold-warm,#e8a917);vertical-align:middle}.ft-links{list-style:none;display:flex;flex-direction:column;gap:12px}.ft-links a{color:inherit;text-decoration:none;font-size:.9rem;transition:color .2s,padding-left .2s}.ft-links a:hover{color:#fff;padding-left:5px}.ft-text{font-size:.9rem;line-height:1.7;margin-bottom:24px;max-width:300px}.ft-social{display:flex;gap:12px;margin-top:20px}.ft-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s,transform .2s;text-decoration:none;border:1px solid rgba(255,255,255,.1)}.ft-social a:hover{background:var(--gold);transform:translateY(-3px)}.ft-bottom{margin-top:60px;padding-top:30px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;position:relative;z-index:1}.ft-copy{font-size:.85rem}@media (max-width:768px){.ft-grid{grid-template-columns:1fr 1fr;gap:30px}.ft-bottom{justify-content:center;text-align:center}}@media (max-width:480px){.ft-grid{grid-template-columns:1fr}}.is-erp .nv,.is-excluded .ft-wrap,.is-excluded .nv,.is-excluded .wa-float{display:none!important}.root-layout-inner:not(.is-excluded) .main-content{min-height:80vh}