*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{margin:0;font-family:Noto Sans,-apple-system,Avenir Next,Segoe UI,Trebuchet MS,ui-sans-serif,system-ui,sans-serif;background:linear-gradient(135deg,#eef2ff,#fef3c7 45%,#dcfce7);color:#0f172a;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:100dvh}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;overflow-x:hidden}.sidebar{background:linear-gradient(180deg,#0f172a,#1a2744);color:#e2e8f0;display:flex;flex-direction:column;overflow-y:auto;position:sticky;top:0;height:100vh;z-index:300;scrollbar-width:thin;scrollbar-color:#334155 transparent}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:16px 16px 10px}.sidebar-brand-icon-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;flex-shrink:0}.sidebar-brand-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#3b82f6,#06b6d4);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:#fff;letter-spacing:1px;flex-shrink:0}.sidebar-brand-logo{width:36px;height:36px;border-radius:8px;flex-shrink:0}.sidebar-brand-version{font-size:.62rem;color:#64748b;letter-spacing:.5px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 20px 14px}.sidebar-user-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden}.sidebar-user-name{font-size:.85rem;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.8px;font-weight:500}.sidebar-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.3),rgba(139,92,246,.3),transparent);margin:4px 16px;box-shadow:0 0 4px #3b82f633}.sidebar-nav{flex:1;padding:8px 12px;display:flex;flex-direction:column;gap:2px}.nav-item-single{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:#94a3b8;text-decoration:none;font-size:.88rem;font-weight:500;transition:all .15s ease;cursor:pointer}.nav-item-single:hover{background:#3b82f61a;color:#e2e8f0}.nav-item-single.active{background:#3b82f626;color:#93c5fd}.nav-item-icon{width:22px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.6;transition:opacity .15s ease,color .15s ease;will-change:opacity,color}.nav-item-single:hover .nav-item-icon,.nav-group-header:hover .nav-item-icon{opacity:1;color:#93c5fd}.nav-item-single.active .nav-item-icon,.nav-group--open .nav-group-header .nav-item-icon{opacity:1;color:#60a5fa}.nav-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-group{border-radius:8px;transition:background .15s ease}.nav-group--open{background:#1e293b80}.nav-group+.nav-group:before,.nav-item-single+.nav-group:before,.nav-group+.nav-item-single:before{content:"";display:block;height:1px;margin:8px 12px;background:linear-gradient(90deg,transparent 0%,#3b82f6 25%,#8b5cf6 50%,#3b82f6 75%,transparent 100%);box-shadow:0 0 6px #3b82f673,0 0 12px #8b5cf640;border-radius:1px}.nav-sub-item+.nav-sub-item{border-top:1px solid rgba(59,130,246,.06)}.nav-sub-item+.nav-sub-group,.nav-sub-group+.nav-sub-item{border-top:1px solid rgba(139,92,246,.1)}.nav-sub-item.active{box-shadow:inset 3px 0 #60a5fa,0 0 8px #60a5fa26}.nav-group-header{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:8px;background:transparent;color:#94a3b8;font-size:.88rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left}.nav-group-header:hover{background:#3b82f61a;color:#e2e8f0}.nav-group--open .nav-group-header{color:#93c5fd;font-weight:600}.nav-group-chevron{font-size:1.1rem;transition:transform .2s ease;transform:rotate(0);opacity:.5;margin-left:auto}.nav-group-chevron--open{transform:rotate(90deg);opacity:.8}.nav-submenu{max-height:0;overflow:hidden;transition:max-height .2s ease-out;padding-left:12px;will-change:max-height}.nav-submenu--open{max-height:500px;padding-bottom:6px}.nav-sub-item{display:flex;align-items:center;padding:7px 12px 7px 34px;border-radius:6px;color:#94a3b8;text-decoration:none;font-size:.82rem;font-weight:400;transition:all .12s ease;position:relative}.nav-sub-item:before{content:"";position:absolute;left:18px;width:5px;height:5px;border-radius:50%;background:#475569;transition:all .15s ease}.nav-sub-item:hover{color:#e2e8f0;background:#3b82f61a}.nav-sub-item:hover:before{background:#93c5fd}.nav-sub-item.active{color:#93c5fd;background:#3b82f624;font-weight:500}.nav-sub-item.active:before{background:#60a5fa;width:6px;height:6px}.nav-sub-group{margin:2px 0;position:relative}.nav-sub-group-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 12px 7px 20px;border:none;border-radius:6px;background:none;color:#cbd5e1;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .12s ease}.nav-sub-group-header:hover{background:#06b6d41a;color:#e2e8f0}.nav-sub-group--open>.nav-sub-group-header{color:#67e8f9;text-shadow:0 0 10px rgba(6,182,212,.5)}.nav-sub-group-chevron{font-size:.85rem;transition:transform .2s ease;display:inline-block}.nav-sub-group-chevron--open{transform:rotate(90deg)}.nav-subgroup-flyout{position:fixed;min-width:220px;background:linear-gradient(145deg,#1e293b,#0f172a);border:1px solid rgba(6,182,212,.3);border-radius:10px;padding:8px;box-shadow:0 8px 32px #00000080,0 0 20px #06b6d41f;z-index:350;animation:flyout-in .15s ease}.nav-subgroup-flyout-title{padding:6px 10px;font-size:.68rem;font-weight:700;color:#67e8f9;text-transform:uppercase;letter-spacing:.8px;text-shadow:0 0 8px rgba(6,182,212,.5);border-bottom:1px solid rgba(6,182,212,.2);margin-bottom:4px}.nav-subgroup-flyout-item{display:block;padding:9px 14px;border-radius:6px;color:#cbd5e1;text-decoration:none;font-size:.82rem;font-weight:400;transition:all .12s ease}.nav-subgroup-flyout-item:hover{background:#06b6d41f;color:#e2e8f0;text-shadow:0 0 12px rgba(103,232,249,.5)}.nav-subgroup-flyout-item.active{color:#67e8f9;background:#06b6d42e;font-weight:500;text-shadow:0 0 14px rgba(6,182,212,.6)}.nav-sub-item--nested{padding-left:44px;font-size:.78rem}.nav-sub-item--nested:before{left:30px;width:4px;height:4px}.nav-flyout-subheader{padding:8px 10px 3px;font-size:.68rem;font-weight:700;color:#67e8f9;text-transform:uppercase;letter-spacing:.6px;border-top:1px solid rgba(6,182,212,.2);margin-top:4px;text-shadow:0 0 8px rgba(6,182,212,.5)}.nav-flyout-item--nested{padding-left:20px;font-size:.78rem}.sidebar-logout-btn{margin:8px 16px 16px;padding:10px;border:1px solid #334155;border-radius:8px;background:transparent;color:#94a3b8;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease}.sidebar-logout-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#f87171}.sidebar-brand-right{display:flex;flex-direction:column;align-items:center;gap:2px;margin-left:auto;flex-shrink:0}.sidebar-toggle{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:2px 4px;flex-shrink:0}.sidebar-toggle-chevrons{font-size:14px;font-weight:700;letter-spacing:1px;line-height:1;transition:color .2s ease,text-shadow .2s ease}.sidebar-toggle-chevrons--collapse{animation:chevron-color-collapse 2s ease-in-out infinite}.sidebar-toggle-chevrons--expand{animation:chevron-color-expand 2s ease-in-out infinite}@keyframes chevron-color-collapse{0%{color:#3b82f6;text-shadow:0 0 6px rgba(59,130,246,.4)}33%{color:#06b6d4;text-shadow:0 0 6px rgba(6,182,212,.4)}66%{color:#8b5cf6;text-shadow:0 0 6px rgba(139,92,246,.4)}to{color:#3b82f6;text-shadow:0 0 6px rgba(59,130,246,.4)}}@keyframes chevron-color-expand{0%{color:#f59e0b;text-shadow:0 0 6px rgba(245,158,11,.4)}33%{color:#10b981;text-shadow:0 0 6px rgba(16,185,129,.4)}66%{color:#06b6d4;text-shadow:0 0 6px rgba(6,182,212,.4)}to{color:#f59e0b;text-shadow:0 0 6px rgba(245,158,11,.4)}}.sidebar-toggle:hover .sidebar-toggle-chevrons{transform:scale(1.2);transition:transform .15s ease}.sidebar{width:260px;transition:width .25s ease,transform .25s ease;will-change:width,transform}.app-shell{transition:grid-template-columns .25s ease}.sidebar-brand-text{overflow:hidden;white-space:nowrap;transition:opacity .2s ease,width .25s ease}.nav-item-label{transition:opacity .2s ease,width .25s ease}.nav-group-chevron{transition:transform .2s ease,opacity .2s ease}.app-shell--collapsed{grid-template-columns:72px 1fr}.sidebar--collapsed{width:72px}.sidebar--collapsed{overflow:visible}.sidebar--collapsed .sidebar-brand{flex-direction:column;align-items:center;padding:10px 4px 6px;gap:4px}.sidebar--collapsed .sidebar-brand-icon{width:32px;height:32px;font-size:.72rem}.sidebar--collapsed .sidebar-brand-logo{width:30px;height:30px}.sidebar--collapsed .sidebar-brand-right{flex-direction:row;gap:0;margin-left:0}.sidebar--collapsed .sidebar-brand-version{display:none}.sidebar--collapsed .sidebar-toggle-chevrons{font-size:11px}.sidebar--collapsed .sidebar-user{justify-content:center;padding:8px}.sidebar--collapsed .sidebar-user-info{display:none}.sidebar--collapsed .sidebar-nav{padding:8px 6px}.sidebar--collapsed .nav-item-label{opacity:0;width:0;overflow:hidden;pointer-events:none;position:absolute}.sidebar--collapsed .nav-group-chevron{display:none!important}.sidebar--collapsed .nav-submenu{display:none}.sidebar--collapsed .nav-item-single,.sidebar--collapsed .nav-group-header{justify-content:center;padding:12px 8px;gap:0;position:relative;cursor:pointer}.sidebar--collapsed .nav-item-icon{width:auto;opacity:1}.sidebar--collapsed .sidebar-logout-btn{margin:8px 6px 16px;font-size:0;padding:10px;display:flex;align-items:center;justify-content:center}.sidebar--collapsed .sidebar-divider{margin:4px 8px}.sidebar--collapsed .nav-item-single[data-tooltip]:hover:after,.sidebar--collapsed .nav-group-header[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:#1e293b;color:#e2e8f0;padding:6px 12px;border-radius:6px;font-size:.8rem;font-weight:500;white-space:nowrap;z-index:100;box-shadow:0 4px 12px #0000004d;pointer-events:none}.sidebar--collapsed .nav-item-single[data-tooltip]:hover:before,.sidebar--collapsed .nav-group-header[data-tooltip]:hover:before{content:"";position:absolute;left:calc(100% + 6px);top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:#1e293b;z-index:100;pointer-events:none}.sidebar--collapsed .nav-group{position:relative}.nav-flyout{position:absolute;left:100%;top:0;min-width:220px;background:linear-gradient(145deg,#1e293b,#0f172a);border:1px solid rgba(6,182,212,.3);border-radius:10px;padding:8px;box-shadow:0 8px 32px #00000080,0 0 20px #06b6d41f;z-index:200;animation:flyout-in .15s ease}@keyframes flyout-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.nav-flyout-title{padding:6px 10px;font-size:.68rem;font-weight:700;color:#67e8f9;text-transform:uppercase;letter-spacing:.8px;text-shadow:0 0 8px rgba(6,182,212,.5);border-bottom:1px solid rgba(6,182,212,.2);margin-bottom:4px}.nav-flyout-item{display:block;padding:8px 12px;border-radius:6px;color:#cbd5e1;text-decoration:none;font-size:.82rem;font-weight:400;transition:all .12s ease}.nav-flyout-item:hover{background:#06b6d41f;color:#e2e8f0;text-shadow:0 0 12px rgba(103,232,249,.5)}.nav-flyout-item.active{color:#67e8f9;background:#06b6d42e;font-weight:500;text-shadow:0 0 14px rgba(6,182,212,.6)}.nav-group--flyout .nav-group-header[data-tooltip]:hover:after,.nav-group--flyout .nav-group-header[data-tooltip]:hover:before{display:none}.content{padding:24px}.content-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;min-height:40px}.top-actions{display:inline-flex;align-items:center;gap:10px}.top-law-link{text-decoration:none;background:linear-gradient(135deg,#0ea5e9,#2563eb);color:#fff;padding:8px 14px;border-radius:999px;font-weight:700;font-size:.85rem;letter-spacing:.2px;border:none;cursor:pointer;font-family:inherit}.top-law-link:hover{background:linear-gradient(135deg,#0284c7,#1d4ed8)}.top-law-link-alt{background:linear-gradient(135deg,#0891b2,#0f766e)}.top-law-link-alt:hover{background:linear-gradient(135deg,#0e7490,#115e59)}.muted-line{color:#64748b;margin-top:-4px}.login-layout{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:1.1fr .9fr}.login-brand{padding:56px 52px;color:#0b1220;background:radial-gradient(circle at 20% 20%,rgba(59,130,246,.25),transparent 45%),radial-gradient(circle at 80% 30%,rgba(16,185,129,.25),transparent 40%),radial-gradient(circle at 70% 80%,rgba(245,158,11,.22),transparent 45%);display:grid;align-content:center;gap:16px}.brand-head{display:flex;align-items:center;gap:14px}.login-brand h1{margin:0;font-size:2rem;line-height:1.2;max-width:560px}.login-brand p{margin:0;max-width:520px;color:#334155}.brand-logo{width:112px;height:112px;border-radius:24px;display:grid;place-items:center;background:linear-gradient(135deg,#2563eb,#0ea5e9,#22c55e);box-shadow:0 12px 24px #0f172a33;overflow:hidden}.brand-logo img{width:100%;height:100%;object-fit:cover}.brand-wordmark{display:grid;align-content:center;gap:2px}.brand-title{font-size:2rem;line-height:1;font-weight:800;letter-spacing:.2px;background:linear-gradient(135deg,#1d4ed8,#0891b2,#15803d);-webkit-background-clip:text;background-clip:text;color:transparent}.brand-subtitle{font-size:.88rem;color:#1e3a8a;letter-spacing:.35px;text-transform:uppercase;font-weight:700}.login-panel{display:grid;place-items:center;padding:24px}.card{width:380px;background:#fff;border-radius:12px;padding:22px;box-shadow:0 8px 24px #0f172a14;display:grid;gap:10px}.auth-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px}.auth-switch button{background:#e2e8f0;color:#0f172a;font-weight:600}.auth-switch button.active-auth{background:#2563eb;color:#fff}label{display:grid;gap:6px;font-size:.9rem}input,button,select,textarea{font:inherit}input,select,textarea{padding:8px 10px;border:1px solid #cbd5e1;border-radius:8px;background:#fff}button{padding:9px 12px;border:none;border-radius:8px;background:#0f172a;color:#fff;cursor:pointer}button:disabled{opacity:.55;cursor:not-allowed}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.kpi{background:#fff;border-radius:10px;padding:14px;box-shadow:0 2px 10px #0f172a0f;display:grid;gap:6px}.kpi span{color:#475569}.kpi strong{font-size:1.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-grad-1{background:linear-gradient(135deg,#dbeafe,#eff6ff)}.kpi-grad-2{background:linear-gradient(135deg,#dcfce7,#f0fdf4)}.kpi-grad-3{background:linear-gradient(135deg,#ffedd5,#fff7ed)}.kpi-grad-4{background:linear-gradient(135deg,#fee2e2,#fef2f2)}.kpi-grad-5{background:linear-gradient(135deg,#fef3c7,#fffbeb)}.kpi-grad-6{background:linear-gradient(135deg,#ede9fe,#f5f3ff)}.kpi-strip{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.kpi-compact{flex:1 1 0;min-width:120px;background:#fff;border-radius:8px;padding:10px 14px;box-shadow:0 1px 4px #0f172a0f}.kpi-compact span{display:block;color:#475569;font-size:.72rem;margin-bottom:2px}.kpi-compact strong{font-size:1.05rem}.kpi-compact-val{display:flex;align-items:baseline;gap:6px}.kpi-trend{font-size:.68rem;font-weight:700;white-space:nowrap}.kpi-trend--up{color:#dc2626}.kpi-trend--down{color:#16a34a}.kpi-val-row{display:flex;align-items:baseline;gap:8px}.status-pill{display:inline-block;font-size:.72rem;font-weight:600;padding:2px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.02em}.status-pill--danger{background:#fee2e2;color:#dc2626}.status-pill--info{background:#dbeafe;color:#2563eb}.status-pill--neutral{background:#f1f5f9;color:#475569}.controls-toolbar{display:flex;gap:12px;margin-bottom:12px;align-items:center;flex-wrap:wrap}.controls-toolbar input{min-width:280px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:10px}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;table-layout:auto;word-break:break-word}.table--compact td:nth-child(2){max-width:280px;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.table th,.table td{padding:10px;border-bottom:1px solid #e2e8f0;text-align:left;font-size:.9rem}.table tbody tr{cursor:pointer}.table-dense th,.table-dense td{padding:6px 8px;font-size:.8rem}.table-dense th{white-space:nowrap;font-size:.78rem;text-transform:uppercase;letter-spacing:.3px;color:#475569}.table-dense .badge{font-size:.68rem;padding:2px 6px}.active-row{background:#eff6ff}.two-col{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:14px}.panel{background:#fff;border-radius:10px;padding:14px;box-shadow:0 2px 10px #0f172a0f;display:grid;gap:10px;max-width:100%;overflow-x:hidden}.panel h3,.panel h4,.panel p{margin:0}.mini-list{display:grid;gap:8px}.mini-list div{display:grid;gap:2px;padding:8px;border:1px solid #e2e8f0;border-radius:8px}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.upload-inline{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.onboarding-create-layout{display:grid;gap:12px;margin-top:14px}.onboarding-bezel{background:linear-gradient(135deg,#eff6ff,#f8fafc);border:1px solid #dbeafe}.upload-bezel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:10px}.upload-bezel-card{background:#fff;border:1px solid #dbe3ef;border-radius:10px;padding:10px;display:grid;gap:8px}.upload-bezel-card h4{margin:0}.upload-input{max-width:360px;min-width:220px;font-size:.86rem;padding:6px 8px}.btn-danger{background:#b91c1c}.btn-warn{background:#b45309}.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.check-grid label{display:flex;align-items:center;gap:8px}.onboarding-filter{max-width:420px}.onboarding-sections{display:grid;gap:10px}.onboarding-group{border:1px solid #dbe3ef;border-radius:10px;padding:8px 10px;background:#f8fafc}.onboarding-group summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;font-weight:700;color:#0f172a}.onboarding-group summary::-webkit-details-marker{display:none}.onboarding-group summary small{font-weight:600;color:#475569}.onboarding-group-head,.onboarding-field-title{display:inline-flex;align-items:center;gap:6px}.onboarding-grid{margin-top:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.onboarding-field{background:#fff;border:1px solid #e2e8f0;border-radius:9px;padding:10px;display:grid;gap:6px}.onboarding-field-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.onboarding-field-head strong{font-size:.88rem;color:#0f172a}.onboarding-required{color:#b91c1c;font-size:.74rem;font-style:normal}.onboarding-help{color:#64748b;font-size:.75rem;line-height:1.35}.onboarding-ref{color:#334155;font-size:.72rem;font-weight:600}.category-picker{display:flex;flex-direction:column;gap:.5rem}.category-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.35rem .75rem;max-height:220px;overflow-y:auto;padding:.5rem;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.category-option{display:inline-flex;align-items:center;gap:.45rem;font-size:.86rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.35rem .75rem;max-height:240px;overflow-y:auto;padding:.5rem;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.info-tip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:999px;background:#1d4ed8;color:#fff;font-size:.67rem;font-weight:700;line-height:1;cursor:help}.tip-bubble{position:absolute;left:0;top:22px;min-width:260px;max-width:420px;background:#0f172a;color:#fff;border-radius:8px;padding:8px 10px;font-size:.72rem;line-height:1.35;z-index:20;display:none;box-shadow:0 8px 16px #0f172a33}.info-tip:hover .tip-bubble,.info-tip:focus-within .tip-bubble{display:block}.roadmap-topbar{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.roadmap-topbar label{min-width:300px}.roadmap-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.roadmap-timeline{display:grid;gap:6px}.roadmap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:10px}.roadmap-card{border:1px solid #dbe3ef;border-radius:10px;padding:10px;display:grid;gap:8px;background:#fff}.roadmap-card-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.roadmap-card-head h4{margin:0;font-size:.96rem}.roadmap-pill{color:#fff;font-weight:700;font-size:.75rem;border-radius:999px;padding:4px 8px}.roadmap-meter{background:#e2e8f0;border-radius:999px;overflow:hidden;height:10px}.roadmap-meter span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#16a34a,#0ea5e9)}.roadmap-missing{display:grid;gap:4px;font-size:.82rem;color:#334155}.result-list{display:grid;gap:12px}.tab-nav{display:flex;gap:4px;margin:8px 0 18px;flex-wrap:wrap;background:linear-gradient(180deg,#e8edf4,#dce3ed);border-radius:10px;padding:4px;box-shadow:inset 0 2px 4px #0000001f,0 1px #ffffffb3}.tab-btn,.tab-nav button{position:relative;background:transparent;color:#4a5a72;border:none;padding:9px 18px;border-radius:7px;font-weight:600;font-size:.85rem;cursor:pointer;letter-spacing:.01em;transition:all .2s ease;text-shadow:0 1px 0 rgba(255,255,255,.5)}.tab-btn:hover,.tab-nav button:hover{background:#ffffff73;color:#1e3a5f}.active-tab,.tab-nav button.tab-active{background:linear-gradient(180deg,#fff,#f1f5fb,#e4ecf7);color:#1e3a5f;box-shadow:0 1px 3px #00000026,0 1px #ffffffe6 inset,0 -1px 2px #0000000f inset;border-bottom:none;text-shadow:none}.active-tab:after,.tab-nav button.tab-active:after{content:"";position:absolute;bottom:3px;left:50%;transform:translate(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent,#2563eb,transparent);border-radius:1px}.tab-nav--consent{background:linear-gradient(180deg,#e0f2f1,#ccece8);box-shadow:inset 0 2px 4px #004d401a,0 1px #ffffffb3}.tab-nav--consent .tab-btn,.tab-nav--consent button{color:#37474f;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--consent .tab-btn:hover,.tab-nav--consent button:hover{background:#ffffff80;color:#004d40}.tab-nav--consent .active-tab,.tab-nav--consent button.tab-active{background:linear-gradient(180deg,#fff,#e8f5f3,#d5ede9);color:#00695c;box-shadow:0 1px 3px #004d402e,0 1px #ffffffe6 inset,0 -1px 2px #004d400f inset}.tab-nav--consent .active-tab:after,.tab-nav--consent button.tab-active:after{background:linear-gradient(90deg,transparent,#00897b,transparent)}.tab-nav--onboarding{background:linear-gradient(180deg,#e8eaf6,#d1d5f0);box-shadow:inset 0 2px 4px #303f9f1a,0 1px #ffffffb3}.tab-nav--onboarding .tab-btn,.tab-nav--onboarding button{color:#37474f;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--onboarding .tab-btn:hover,.tab-nav--onboarding button:hover{background:#ffffff80;color:#1a237e}.tab-nav--onboarding .active-tab,.tab-nav--onboarding button.tab-active{background:linear-gradient(180deg,#fff,#ede7f6,#d1c4e9);color:#283593;box-shadow:0 1px 3px #303f9f26,0 1px #fffc inset,0 -1px 2px #303f9f0f inset}.tab-nav--onboarding .active-tab:after,.tab-nav--onboarding button.tab-active:after{background:linear-gradient(90deg,transparent,#5c6bc0,transparent)}.tab-nav--dashboard{background:linear-gradient(180deg,#e3f2fd,#cce4f7);box-shadow:inset 0 2px 4px #0d47a11a,0 1px #ffffffb3}.tab-nav--dashboard .tab-btn,.tab-nav--dashboard button{color:#37474f;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--dashboard .tab-btn:hover,.tab-nav--dashboard button:hover{background:#ffffff80;color:#0d47a1}.tab-nav--dashboard .active-tab,.tab-nav--dashboard button.tab-active{background:linear-gradient(180deg,#fff,#e3f2fd,#bbdefb);color:#1565c0;box-shadow:0 1px 3px #0d47a126,0 1px #fffc inset,0 -1px 2px #0d47a10f inset}.tab-nav--dashboard .active-tab:after,.tab-nav--dashboard button.tab-active:after{background:linear-gradient(90deg,transparent,#1976d2,transparent)}.tab-nav--training{background:linear-gradient(180deg,#fff8e1,#ffecb3);box-shadow:inset 0 2px 4px #e67e001a,0 1px #ffffffb3}.tab-nav--training .tab-btn,.tab-nav--training button{color:#4e342e;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--training .tab-btn:hover,.tab-nav--training button:hover{background:#ffffff8c;color:#e65100}.tab-nav--training .active-tab,.tab-nav--training button.tab-active{background:linear-gradient(180deg,#fff,#fff3e0,#ffe0b2);color:#e65100;box-shadow:0 1px 3px #e6510026,0 1px #fffc inset,0 -1px 2px #e651000f inset}.tab-nav--training .active-tab:after,.tab-nav--training button.tab-active:after{background:linear-gradient(90deg,transparent,#f57c00,transparent)}.tab-nav--reporting{background:linear-gradient(180deg,#eceff1,#dce3e8);box-shadow:inset 0 2px 4px #37474f1a,0 1px #ffffffb3}.tab-nav--reporting .tab-btn,.tab-nav--reporting button{color:#455a64;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--reporting .tab-btn:hover,.tab-nav--reporting button:hover{background:#ffffff8c;color:#263238}.tab-nav--reporting .active-tab,.tab-nav--reporting button.tab-active{background:linear-gradient(180deg,#fff,#eceff1,#cfd8dc);color:#37474f;box-shadow:0 1px 3px #37474f26,0 1px #fffc inset,0 -1px 2px #37474f0f inset}.tab-nav--reporting .active-tab:after,.tab-nav--reporting button.tab-active:after{background:linear-gradient(90deg,transparent,#546e7a,transparent)}.tab-nav--workflow{background:linear-gradient(180deg,#ede7f6,#d1c4e9);box-shadow:inset 0 2px 4px #4a148c1a,0 1px #ffffffb3}.tab-nav--workflow .tab-btn,.tab-nav--workflow button{color:#4a148c;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--workflow .tab-btn:hover,.tab-nav--workflow button:hover{background:#ffffff8c;color:#311b92}.tab-nav--workflow .active-tab,.tab-nav--workflow button.tab-active{background:linear-gradient(180deg,#fff,#f3e5f5,#e1bee7);color:#6a1b9a;box-shadow:0 1px 3px #4a148c26,0 1px #fffc inset,0 -1px 2px #4a148c0f inset}.tab-nav--workflow .active-tab:after,.tab-nav--workflow button.tab-active:after{background:linear-gradient(90deg,transparent,#7b1fa2,transparent)}.tab-nav--integrations{background:linear-gradient(180deg,#e1f0f5,#cde3ed);box-shadow:inset 0 2px 4px #01579b1a,0 1px #ffffffb3}.tab-nav--integrations .tab-btn,.tab-nav--integrations button{color:#37474f;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--integrations .tab-btn:hover,.tab-nav--integrations button:hover{background:#ffffff8c;color:#01579b}.tab-nav--integrations .active-tab,.tab-nav--integrations button.tab-active{background:linear-gradient(180deg,#fff,#e1f5fe,#b3e5fc);color:#0277bd;box-shadow:0 1px 3px #01579b26,0 1px #fffc inset,0 -1px 2px #01579b0f inset}.tab-nav--integrations .active-tab:after,.tab-nav--integrations button.tab-active:after{background:linear-gradient(90deg,transparent,#0288d1,transparent)}.tab-nav--breach{background:linear-gradient(180deg,#fce4ec,#f8bbd0);box-shadow:inset 0 2px 4px #b71c1c1a,0 1px #ffffffb3}.tab-nav--breach .tab-btn,.tab-nav--breach button{color:#4e342e;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--breach .tab-btn:hover,.tab-nav--breach button:hover{background:#ffffff8c;color:#b71c1c}.tab-nav--breach .active-tab,.tab-nav--breach button.tab-active{background:linear-gradient(180deg,#fff,#fce4ec,#f8bbd0);color:#c62828;box-shadow:0 1px 3px #b71c1c26,0 1px #fffc inset,0 -1px 2px #b71c1c0f inset}.tab-nav--breach .active-tab:after,.tab-nav--breach button.tab-active:after{background:linear-gradient(90deg,transparent,#e53935,transparent)}.tab-nav--law{background:linear-gradient(180deg,#e0f2f1,#b2dfdb);box-shadow:inset 0 2px 4px #004d401a,0 1px #ffffffb3}.tab-nav--law .tab-btn,.tab-nav--law button{color:#263238;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--law .tab-btn:hover,.tab-nav--law button:hover{background:#ffffff8c;color:#004d40}.tab-nav--law .active-tab,.tab-nav--law button.tab-active{background:linear-gradient(180deg,#fff,#e0f7fa,#b2ebf2);color:#00695c;box-shadow:0 1px 3px #004d4026,0 1px #fffc inset,0 -1px 2px #004d400f inset}.tab-nav--law .active-tab:after,.tab-nav--law button.tab-active:after{background:linear-gradient(90deg,transparent,#00897b,transparent)}.tab-nav--vendor{background:linear-gradient(180deg,#dbeafe,#bfdbfe);box-shadow:inset 0 2px 4px #1e3a8a1a,0 1px #ffffffb3}.tab-nav--vendor .tab-btn,.tab-nav--vendor button{color:#1e3a5f;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--vendor .tab-btn:hover,.tab-nav--vendor button:hover{background:#ffffff8c;color:#1e3a8a}.tab-nav--vendor .active-tab,.tab-nav--vendor button.tab-active{background:linear-gradient(180deg,#fff,#dbeafe,#bfdbfe);color:#1e40af;box-shadow:0 1px 3px #1e3a8a26,0 1px #fffc inset,0 -1px 2px #1e3a8a0f inset}.tab-nav--vendor .active-tab:after,.tab-nav--vendor button.tab-active:after{background:linear-gradient(90deg,transparent,#2563eb,transparent)}.tab-nav--notice{background:linear-gradient(180deg,#e0f2f1,#ccece8);box-shadow:inset 0 2px 4px #004d401a,0 1px #ffffffb3}.tab-nav--notice .tab-btn,.tab-nav--notice button{color:#37474f;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--notice .tab-btn:hover,.tab-nav--notice button:hover{background:#ffffff80;color:#004d40}.tab-nav--notice .active-tab,.tab-nav--notice button.tab-active{background:linear-gradient(180deg,#fff,#e8f5f3,#d5ede9);color:#00695c;box-shadow:0 1px 3px #004d402e,0 1px #ffffffe6 inset,0 -1px 2px #004d400f inset}.tab-nav--notice .active-tab:after,.tab-nav--notice button.tab-active:after{background:linear-gradient(90deg,transparent,#00897b,transparent)}.tab-nav--dsr{background:linear-gradient(180deg,#fef3c7,#fde68a);box-shadow:inset 0 2px 4px #78350f1a,0 1px #ffffffb3}.tab-nav--dsr .tab-btn,.tab-nav--dsr button{color:#78350f;text-shadow:0 1px 0 rgba(255,255,255,.6)}.tab-nav--dsr .tab-btn:hover,.tab-nav--dsr button:hover{background:#ffffff8c;color:#92400e}.tab-nav--dsr .active-tab,.tab-nav--dsr button.tab-active{background:linear-gradient(180deg,#fff,#fffbeb,#fef3c7);color:#b45309;box-shadow:0 1px 3px #78350f2e,0 1px #ffffffe6 inset,0 -1px 2px #78350f0f inset}.tab-nav--dsr .active-tab:after,.tab-nav--dsr button.tab-active:after{background:linear-gradient(90deg,transparent,#d97706,transparent)}.dsr-verify-badge{display:inline-block;padding:1px 6px;border-radius:8px;font-size:.68rem;font-weight:600;white-space:nowrap}.dsr-verified{background:#d1fae5;color:#065f46}.dsr-pending{background:#fef3c7;color:#92400e}.dsr-not-verified{background:#fee2e2;color:#991b1b}.section-result{display:flex;align-items:center;gap:10px;margin-top:8px;padding:8px 12px;background:#f0f9ff;border:1px solid #e0e7ff;border-radius:6px;font-size:.85rem}.section-result .badge{flex-shrink:0}.section-result-bar{flex:1;height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.section-result-bar-fill{height:100%;border-radius:999px;transition:width .3s ease}.section-result-explanation{font-size:.82rem;color:#475569;margin-top:4px;line-height:1.4}.metric-list{display:grid;gap:10px}.metric-row{display:grid;grid-template-columns:190px 1fr auto;gap:8px;align-items:center}.metric-row small{color:#334155}.metric-meter{height:9px;background:#e2e8f0;border-radius:999px;overflow:hidden}.metric-meter span{display:block;height:100%;border-radius:999px}.dashboard-charts{margin-top:14px}.chart-panel h3{margin-bottom:10px}.pie-wrap{display:grid;grid-template-columns:160px 1fr;gap:14px;align-items:center}.legend-list{display:grid;gap:8px}.legend-list div{display:grid;grid-template-columns:12px 1fr auto;gap:8px;align-items:center}.legend-list span{width:12px;height:12px;border-radius:3px;display:inline-block}.trend-bars{display:flex;align-items:flex-end;gap:12px;min-height:150px;padding-top:8px}.bar-col{display:grid;gap:6px;justify-items:center}.bar{width:26px;border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,#2563eb,#0ea5e9)}.domain-list{display:grid;gap:10px}.domain-row{display:grid;grid-template-columns:240px 1fr auto;gap:10px;align-items:center}.domain-row small{display:block;color:#64748b}.domain-meter{background:#e2e8f0;height:10px;border-radius:999px;overflow:hidden}.domain-meter span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#22c55e,#0ea5e9)}.privacy-ops-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:14px 16px}.sla-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.sla-card{text-align:center;padding:16px 12px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.sla-card .sla-label{font-size:.72rem;color:#64748b;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.sla-card .sla-value{font-size:1.4rem;font-weight:800}.sla-card .sla-sub{font-size:.68rem;color:#94a3b8}.sla-green{color:#16a34a}.sla-amber{color:#f59e0b}.sla-red{color:#dc2626}.sla-muted{color:#94a3b8}.metric-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.metric-section:last-child{border-bottom:none}.metric-section h4{font-size:.95rem;color:#0f172a;margin:0 0 4px}.metric-section .metric-sub{font-size:.78rem;color:#64748b;margin:0 0 14px}.overdue-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-top:10px}.overdue-table th{text-align:left;padding:6px 10px;background:#fef2f2;color:#991b1b;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.03em}.overdue-table td{padding:6px 10px;border-bottom:1px solid #fecaca;color:#0f172a}.overdue-table tr:last-child td{border-bottom:none}.overdue-badge{display:inline-block;background:#dc2626;color:#fff;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:10px}.category-kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}.category-kpi{text-align:center;padding:14px 10px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.category-kpi .ck-label{font-size:.75rem;color:#64748b;font-weight:600;text-transform:uppercase}.category-kpi .ck-value{font-size:1.3rem;font-weight:800;color:#0f172a;margin-top:2px}.category-kpi .ck-sub{font-size:.7rem;color:#94a3b8}.domain-row.clickable{cursor:pointer}.domain-row.clickable:hover{background:#f1f5f9}.type-bar-chart{display:flex;align-items:flex-end;gap:10px;height:100px;margin-top:10px}.type-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.type-bar-col .bar{width:100%;border-radius:4px 4px 0 0;min-height:4px}.type-bar-col small{font-size:.65rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px;text-align:center}.error{color:#b91c1c}.field-error{display:block;color:#dc2626;font-size:.78rem;margin-top:2px}.success{color:#166534}.version-line{margin:2px 0 0;font-size:.78rem;color:#64748b;text-align:right}.relationships-panel{padding:14px}.relationships-canvas-wrap{position:relative;border:1px solid #dbe4f0;border-radius:12px;background:radial-gradient(circle at 50% 50%,#f8fafc 0,#eef2f7 55%,#e2e8f0);overflow:hidden}.relationships-svg{width:100%;min-height:580px;display:block}.relationships-svg--zoomable{transition:viewBox .5s ease}.crg-fullscreen{position:fixed!important;inset:0!important;z-index:9999!important;margin:0!important;border-radius:0!important;background:#fff!important;display:flex!important;flex-direction:column!important;overflow:hidden!important;padding:0!important}.crg-fullscreen .relationships-canvas-wrap{flex:1 1 0;min-height:0;border:none;border-radius:0}.crg-fullscreen .relationships-svg{width:100%;height:100%;min-height:0}.crg-fullscreen .crg-selected-panel{max-height:50vh}.crg-rotate-group{transition:transform 1.8s cubic-bezier(.25,.1,.25,1)}.crg-tooltip{position:absolute;pointer-events:none;z-index:50;background:#0f172aee;color:#f1f5f9;border-radius:8px;padding:10px 14px;font-size:.82rem;line-height:1.5;min-width:200px;max-width:340px;box-shadow:0 8px 24px #0000004d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.crg-tooltip-header{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-size:.88rem}.crg-tooltip-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.crg-tooltip-row{display:flex;align-items:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crg-tooltip-label{color:#94a3b8;font-size:.78rem;min-width:fit-content}.graph-node{transition:filter .2s ease;cursor:pointer}.graph-node:hover{filter:drop-shadow(0 4px 8px rgba(15,23,42,.25))}.crg-zoomable-node{transition:r .3s ease,filter .2s ease}.graph-node-text{font-size:10px;fill:#0f172a;font-weight:700;pointer-events:none}.graph-dept-node{pointer-events:none}.graph-dept-text{font-size:9.5px;fill:#334155}.graph-center-kpi{font-size:24px;fill:#fff;font-weight:800}.graph-center-label{font-size:11px;fill:#cbd5e1}.graph-center-sub{font-size:11px;fill:#86efac;font-weight:600}.graph-center-risk{fill:#fca5a5}.crg-selected-panel{position:absolute;bottom:16px;left:16px;z-index:40;background:#fffe;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #dbe4f0;border-radius:12px;padding:14px 16px;max-width:340px;max-height:420px;overflow-y:auto;box-shadow:0 4px 20px #00000014}.crg-selected-panel h4{margin:0 0 6px;font-size:.95rem}.crg-selected-panel p{margin:0 0 8px;font-size:.84rem}.crg-selected-status{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}.crg-status-chip{display:inline-flex;align-items:center;gap:4px;font-size:.76rem;padding:2px 8px;background:#f1f5f9;border-radius:4px}.legend-grid{display:grid;gap:6px}.legend-row{display:grid;grid-template-columns:16px 1fr auto;align-items:center;gap:8px;font-size:.86rem}.legend-dot{width:12px;height:12px;border-radius:999px;border:1px solid #0f172a}.crg-legend-bar{display:flex;flex-wrap:wrap;gap:6px 16px;margin-bottom:.5rem;padding:5px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center}.crg-legend-item{display:flex;align-items:center;gap:5px;font-size:.78rem}.crg-filter-badge{display:inline-flex;align-items:center;gap:8px;padding:4px 12px;background:#e8f0fe;border:1px solid #93c5fd;border-radius:6px;font-size:.84rem;color:#1e3a5f}.crg-filter-clear{background:none;border:none;color:#ef4444;cursor:pointer;font-weight:700;font-size:1rem;padding:0 2px;line-height:1}.hover-card{border:1px solid #e2e8f0;border-radius:10px;padding:10px;background:#f8fafc;display:grid;gap:2px}.hover-card p{margin:0;font-size:.83rem}.crg-kpis{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:.5rem}.crg-kpi{display:flex;flex-direction:column;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:6px 12px;min-width:80px;flex:1}.crg-kpi-value{font-size:1.15rem;font-weight:800;line-height:1.1}.crg-kpi-label{font-size:.68rem;color:#64748b;font-weight:500}.crg-kpi-top{display:flex;align-items:center;gap:4px}.crg-trend{font-size:.7rem;font-weight:600;white-space:nowrap}.crg-trend-up{color:#16a34a}.crg-trend-down{color:#dc2626}.crg-trend-flat{color:#94a3b8}.crg-trend-section{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px 18px;margin-bottom:12px}.crg-trend-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.crg-trend-header h3{font-size:.92rem;font-weight:600;color:#1e293b;margin:0}.crg-trend-range{display:flex;gap:4px}.crg-range-btn{padding:3px 10px;border:1px solid #e2e8f0;border-radius:4px;background:#f8fafc;font-size:.72rem;font-weight:500;color:#64748b;cursor:pointer;transition:.15s}.crg-range-btn:hover{background:#f1f5f9;color:#334155}.crg-range-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.crg-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:900px){.crg-charts-grid{grid-template-columns:1fr}}.crg-chart-card{background:#fafbfc;border:1px solid #f1f5f9;border-radius:8px;padding:10px 8px 6px}.crg-chart-wrap{position:relative}.crg-chart-ylabel{position:absolute;left:2px;top:4px;font-size:.68rem;color:#94a3b8;font-weight:500}.crg-area-chart{display:block;width:100%;height:auto}.crg-chart-tooltip{position:absolute;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:8px 10px;box-shadow:0 2px 8px #00000014;pointer-events:none;z-index:10;min-width:120px}.crg-chart-legend{display:flex;gap:14px;justify-content:center;padding:6px 0 0}.crg-chart-legend-item{display:flex;align-items:center;gap:4px;font-size:.72rem;color:#64748b;font-weight:500}.crg-cat-label{font-size:5px;fill:#334155;font-weight:600}.crg-ctrl-list{display:grid;gap:4px;max-height:340px;overflow-y:auto}.crg-ctrl-row{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;font-size:.8rem;cursor:default;transition:background .15s}.crg-ctrl-row:hover,.crg-ctrl-row--active{background:#f1f5f9}.crg-ctrl-dot{width:8px;height:8px;border-radius:50%}.crg-ctrl-info{display:flex;flex-direction:column;gap:1px;min-width:0}.crg-ctrl-id{font-weight:700;font-size:.78rem;color:#0f172a}.crg-ctrl-name{font-size:.72rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crg-ctrl-dept{font-size:.72rem;color:#94a3b8;text-align:right}@media(max-width:960px){.login-layout{grid-template-columns:1fr}.login-brand{padding:28px 20px;gap:10px}.login-brand h1{font-size:1.4rem}.brand-logo{width:84px;height:84px;border-radius:18px}.brand-head{flex-direction:column;align-items:flex-start;gap:8px}.brand-title{font-size:1.6rem}.app-shell{grid-template-columns:1fr;display:block}.sidebar{position:fixed;top:0;left:0;z-index:200;height:100vh;height:100dvh;width:280px;transform:translate(-100%);transition:transform .25s ease;-webkit-overflow-scrolling:touch}.sidebar--mobile-open{transform:translate(0)}.sidebar-toggle{display:none}.sidebar-nav{padding:4px 8px}.nav-group-header,.nav-item-single{padding:10px 12px;min-height:44px;touch-action:manipulation}.nav-sub-item{padding:8px 10px 8px 30px;min-height:40px;touch-action:manipulation}.content{padding:56px 12px 16px}.content-topbar{flex-wrap:wrap;gap:8px}.two-col{grid-template-columns:1fr}.pie-wrap{grid-template-columns:1fr;justify-items:center}.domain-row,.metric-row{grid-template-columns:1fr}.crg-selected-panel{max-width:280px}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.panel{padding:16px 12px}}.mobile-menu-btn{display:none}@media(max-width:960px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center;position:fixed;top:10px;left:10px;z-index:210;width:40px;height:40px;border:none;border-radius:8px;background:#1e293b;color:#e2e8f0;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 8px #0000004d}.mobile-menu-btn:active{background:#334155}.app-shell--mobile-open .mobile-menu-btn{background:#1e293be6}}.mobile-overlay{display:none}@media(max-width:960px){.mobile-overlay{display:block;position:fixed;inset:0;z-index:190;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}}.login-cta-links{display:flex;gap:12px;margin-top:1.5rem;flex-wrap:wrap}.login-cta-btn{display:inline-block;padding:10px 24px;background:#1e3a8a;border:1px solid #1e40af;border-radius:6px;color:#fff;text-decoration:none;font-weight:600;font-size:.95rem;transition:background .2s}.login-cta-btn:hover{background:#1e40af}.login-cta-btn-alt{background:#0e7490;border-color:#0891b2}.login-cta-btn-alt:hover{background:#0891b2}.services-page{min-height:100vh;background:#fff;color:#0f172a}.services-topbar{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:.6rem 2rem;background:#0b1220;border-bottom:1px solid rgba(255,255,255,.08)}.services-topbar-brand{color:#94a3b8;font-weight:700;font-size:.95rem;letter-spacing:.5px}.btn-services-login{display:inline-block;padding:.45rem 1.5rem;background:#2563eb;color:#fff;border-radius:6px;text-decoration:none;font-weight:600;font-size:.88rem;transition:background .15s}.btn-services-login:hover{background:#1d4ed8;color:#fff}.services-hero{background:linear-gradient(135deg,#0b1220,#1e3a5f);color:#fff;padding:4rem 2rem;text-align:center}.services-hero-inner{max-width:800px;margin:0 auto}.services-hero h1{font-size:2.2rem;margin:0 0 1rem;letter-spacing:-.5px}.services-hero-sub{font-size:1.1rem;opacity:.9;line-height:1.7;margin:0 0 2rem}.services-hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.btn-services-primary{display:inline-block;padding:12px 32px;background:#0ea5e9;color:#fff;border-radius:8px;text-decoration:none;font-weight:700;font-size:1rem;transition:background .2s}.btn-services-primary:hover{background:#0284c7}.btn-services-secondary{display:inline-block;padding:12px 32px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:background .2s}.btn-services-secondary:hover{background:#ffffff1a}.services-section{max-width:960px;margin:0 auto;padding:3rem 2rem}.services-section-alt{background:#f8fafc;max-width:100%}.services-section-alt>*{max-width:960px;margin-left:auto;margin-right:auto}.services-section-title{text-align:center;font-size:1.5rem;margin:0 0 2rem;color:#0f172a}.services-timeline{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}.timeline-item{text-align:center;padding:16px 24px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;min-width:180px}.timeline-item-urgent{border-color:#ef4444;background:#fef2f2}.timeline-date{font-weight:700;font-size:1.1rem;color:#1d4ed8;margin-bottom:4px}.timeline-item-urgent .timeline-date{color:#dc2626}.timeline-label{font-size:.88rem;color:#475569}.timeline-connector{width:40px;height:2px;background:#cbd5e1;flex-shrink:0}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.service-card{border:1px solid #e2e8f0;border-radius:10px;padding:24px;background:#fff;transition:box-shadow .2s}.service-card:hover{box-shadow:0 4px 20px #00000014}.service-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#0ea5e9,#1d4ed8);color:#fff;display:grid;place-items:center;font-weight:700;font-size:1rem;margin-bottom:12px}.service-card h3{margin:0 0 8px;font-size:1.05rem}.service-card p{margin:0;color:#475569;font-size:.9rem;line-height:1.6}.services-phases{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.phase-card{text-align:center;padding:20px}.phase-num{width:40px;height:40px;border-radius:50%;background:#1d4ed8;color:#fff;display:inline-grid;place-items:center;font-weight:700;font-size:1.1rem;margin:0 auto 12px}.phase-card h3{margin:0 0 6px;font-size:1.05rem}.phase-card p{margin:0;color:#475569;font-size:.88rem;line-height:1.5}.services-diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.diff-card{padding:24px;border-left:3px solid #0ea5e9;background:#f0f9ff;border-radius:0 8px 8px 0}.diff-card h3{margin:0 0 8px;font-size:1rem;color:#0c4a6e}.diff-card p{margin:0;color:#334155;font-size:.9rem;line-height:1.6}.services-penalty-table{width:100%;border-collapse:collapse;font-size:.92rem}.services-penalty-table th,.services-penalty-table td{padding:10px 14px;text-align:left;border-bottom:1px solid #e2e8f0}.services-penalty-table th{background:#f1f5f9;font-weight:600}.services-penalty-table td:last-child{font-weight:600;color:#dc2626;white-space:nowrap}.services-contact-sub{text-align:center;color:#475569;margin-bottom:1.5rem}.services-contact-form{max-width:600px;margin:0 auto;display:grid;gap:14px}.contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.services-contact-form label{display:grid;gap:4px;font-size:.9rem;font-weight:500}.services-contact-form input,.services-contact-form textarea,.services-contact-form select{padding:9px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:.92rem;font-family:inherit;width:100%;box-sizing:border-box}.services-contact-form button{padding:12px;background:#1d4ed8;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.services-contact-form button:hover{background:#1e40af}.services-contact-form button:disabled{opacity:.6;cursor:not-allowed}.services-success-box{text-align:center;padding:24px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;color:#166534;font-weight:500;max-width:600px;margin:0 auto}.services-footer{text-align:center;padding:2rem;background:#0b1220;color:#94a3b8;font-size:.9rem}.services-footer a{color:#93c5fd;text-decoration:none}.services-footer a:hover{text-decoration:underline}.services-footer-sep{margin:0 12px;opacity:.4}@media(max-width:768px){.services-grid,.services-diff-grid{grid-template-columns:1fr}.services-phases{grid-template-columns:1fr 1fr}.contact-form-row{grid-template-columns:1fr}.services-timeline{flex-direction:column}.timeline-connector{width:2px;height:24px}.services-hero{padding:2.5rem 1rem}.services-hero h1{font-size:1.5rem}.services-hero-actions{flex-direction:column;align-items:center}.services-section{padding:2rem 1rem}.services-phases{grid-template-columns:1fr}.services-topbar{padding:.5rem 1rem}}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.kpi-val{font-size:1.6rem;font-weight:800;color:#0f172a}.kpi-label{font-size:.82rem;color:#64748b;font-weight:600}.kpi-grad-danger{background:linear-gradient(135deg,#fee2e2,#fecaca)!important}.clickable-row{cursor:pointer;transition:background .15s}.clickable-row:hover{background:#f1f5f9}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:700;background:#e2e8f0;color:#334155}.badge-critical{background:#dc2626;color:#fff}.badge-high{background:#ea580c;color:#fff}.badge-medium{background:#d97706;color:#fff}.badge-low{background:#65a30d;color:#fff}.badge-active{background:#16a34a;color:#fff}.badge-withdrawn{background:#9333ea;color:#fff}.badge-expired{background:#64748b;color:#fff}.badge-ok{background:#dcfce7;color:#166534}.badge-warn{background:#fef9c3;color:#854d0e}.badge-muted{background:#f1f5f9;color:#64748b}.badge-success{background:#16a34a;color:#fff}.badge-sm{font-size:.68rem;padding:1px 6px;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:#0f172a80;display:grid;place-items:center;z-index:100}.modal-box{background:#fff;border-radius:12px;padding:24px;width:90%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 16px 48px #0f172a33}.modal-box h3{margin:0 0 16px}.modal-form{display:grid;gap:12px}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px;margin-top:8px}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.detail-header h3{margin:0;font-size:1.05rem;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.btn-close{padding:4px 12px;font-size:.82rem;background:#64748b}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;font-size:.88rem}.detail-desc{margin-top:8px;font-size:.88rem;color:#334155}.btn-sm{padding:5px 10px;font-size:.8rem;border-radius:6px}.btn-secondary{background:#94a3b8}.audit-trail{margin-top:16px;border-top:1px solid #e2e8f0;padding-top:12px}.audit-trail h4{margin:0 0 8px;font-size:.92rem}.audit-entry{display:flex;gap:10px;align-items:baseline;padding:4px 0;font-size:.82rem;border-bottom:1px solid #f1f5f9}.audit-action{font-weight:700;color:#1d4ed8;min-width:90px}.audit-meta{color:#64748b}.audit-notes{color:#475569;font-style:italic}.truncate-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breach-alert-banner{background:linear-gradient(135deg,#fecaca,#fee2e2);color:#991b1b;padding:12px 16px;border-radius:8px;font-weight:600;font-size:.9rem;border-left:4px solid #dc2626}.countdown-urgent{color:#dc2626;font-weight:800;font-size:.88rem}.countdown-ok{color:#16a34a;font-weight:600;font-size:.88rem}.template-box{margin-top:12px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.template-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f1f5f9}.template-content{margin:0;padding:12px;font-size:.82rem;white-space:pre-wrap;background:#fff;max-height:300px;overflow-y:auto}.sla-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:700}.sla-ok{background:#dcfce7;color:#166534}.sla-warning{background:#fef3c7;color:#92400e}.sla-overdue{background:#fee2e2;color:#991b1b}.withdraw-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.modal-wide{max-width:720px}.modal-detail{max-width:860px;width:95%;max-height:90vh;overflow-y:auto}.modal-detail .detail-header{position:sticky;top:0;background:#fff;z-index:1;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.modal-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;font-size:1.1rem;font-weight:700;color:#0f172a;letter-spacing:-.01em;line-height:1.3}.modal-close-btn{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;font-size:1.1rem;font-weight:400;cursor:pointer;-webkit-transition:all .15s ease;transition:all .15s ease;line-height:1;padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;flex-shrink:0;-ms-flex-negative:0}.modal-close-btn:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.modal-close-btn:focus{outline:2px solid #3b82f6;outline-offset:2px}.modal-form label{font-size:.82rem;font-weight:600;color:#334155;letter-spacing:.01em;display:block;margin-bottom:4px}.modal-form input,.modal-form select,.modal-form textarea{font-size:.88rem;color:#0f172a;border:1px solid #cbd5e1;border-radius:8px;padding:8px 12px;width:100%;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-transition:border-color .15s ease,box-shadow .15s ease;transition:border-color .15s ease,box-shadow .15s ease;background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none}.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus{border-color:#3b82f6;-webkit-box-shadow:0 0 0 3px rgba(59,130,246,.12);box-shadow:0 0 0 3px #3b82f61f;outline:none}.modal-form select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.modal-form textarea{resize:vertical;min-height:60px;line-height:1.5}.modal-form input[type=checkbox]{width:auto;-webkit-appearance:checkbox;-moz-appearance:checkbox;appearance:checkbox;margin-right:6px}.modal-form input[type=radio]{width:auto;-webkit-appearance:radio;-moz-appearance:radio;appearance:radio;margin-right:4px}.modal-form input[type=date]{-webkit-appearance:none;-moz-appearance:none;appearance:none}.modal-form fieldset{border:1px solid #e2e8f0;border-radius:8px;padding:14px 16px;margin:0;background:#fafbfc}.modal-form fieldset legend{font-size:.82rem;font-weight:700;color:#1e3a5f;padding:0 6px;letter-spacing:.02em;text-transform:uppercase}.modal-form .btn-row{margin-top:8px;padding-top:16px;border-top:1px solid #e2e8f0;display:-webkit-box;display:-ms-flexbox;display:flex;gap:8px;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end;-ms-flex-wrap:wrap;flex-wrap:wrap}@-webkit-keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@-webkit-keyframes modalSlideUp{0%{opacity:0;-webkit-transform:translateY(16px);transform:translateY(16px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{-webkit-animation:modalFadeIn .15s ease;animation:modalFadeIn .15s ease}.modal-box{-webkit-animation:modalSlideUp .2s ease;animation:modalSlideUp .2s ease}.modal-box::-webkit-scrollbar{width:6px}.modal-box::-webkit-scrollbar-track{background:transparent}.modal-box::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.modal-box::-webkit-scrollbar-thumb:hover{background:#94a3b8}.modal-box{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}@media(max-width:768px){.modal-box{width:95%;max-width:none;padding:16px;border-radius:10px;max-height:85vh}.modal-wide{max-width:none}.modal-detail{max-width:none;width:98%}.modal-header h3{font-size:1rem}.modal-form{gap:10px}.form-row-2{grid-template-columns:1fr;gap:10px}.modal-form label{font-size:.8rem}.modal-form input,.modal-form select,.modal-form textarea{font-size:.85rem;padding:10px 12px}.modal-form fieldset{padding:10px 12px}.modal-form fieldset legend{font-size:.78rem}.modal-form .btn-row{-webkit-box-pack:stretch;-ms-flex-pack:stretch;justify-content:stretch}.modal-form .btn-row button{-webkit-box-flex:1;-ms-flex:1;flex:1;min-width:0}}@media(max-width:480px){.modal-overlay{-webkit-box-align:end;-ms-flex-align:end;align-items:flex-end}.modal-box{width:100%;max-height:90vh;border-radius:16px 16px 0 0;padding:16px 14px 24px}.modal-header{padding-bottom:10px}.modal-header h3{font-size:.95rem}.modal-close-btn{width:28px;height:28px;font-size:.95rem}.modal-form input,.modal-form select,.modal-form textarea{font-size:16px;padding:10px}.modal-form .btn-row{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.modal-form .btn-row button{width:100%}}@media screen and (-ms-high-contrast:active),(-ms-high-contrast:none){.modal-overlay{display:-ms-flexbox;-ms-flex-pack:center;-ms-flex-align:center}.modal-box{-ms-flex-negative:0}.modal-header{display:-ms-flexbox;-ms-flex-pack:justify;-ms-flex-align:center}.modal-form{display:block}.modal-form>*{margin-bottom:12px}.form-row-2{display:-ms-flexbox;-ms-flex-wrap:wrap}.form-row-2>*{-ms-flex:0 0 48%;max-width:48%;margin-right:2%}}@supports (-webkit-touch-callout: none){.modal-form input,.modal-form select,.modal-form textarea{font-size:16px}}.bulk-action-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#1e293b;color:#f1f5f9;border-radius:8px;margin:8px 0;font-size:.85rem}.bulk-action-bar .bulk-count{font-weight:600;margin-right:auto}.bulk-action-bar button{padding:6px 14px;border-radius:6px;border:none;cursor:pointer;font-size:.82rem;font-weight:500}.bulk-action-bar .bulk-export{background:#3b82f6;color:#fff}.bulk-action-bar .bulk-export:hover{background:#2563eb}.bulk-action-bar .bulk-delete{background:#ef4444;color:#fff}.bulk-action-bar .bulk-delete:hover{background:#dc2626}.bulk-action-bar .bulk-clear{background:transparent;color:#94a3b8;text-decoration:underline}.table th.col-check,.table td.col-check{width:36px;text-align:center;padding:6px}.table td.col-check input[type=checkbox],.table th.col-check input[type=checkbox]{cursor:pointer;width:16px;height:16px}.dm-cat-grid{display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center;margin:6px 0 10px}.dm-cat-label{font-weight:600;font-size:.88rem;color:#334155;width:100%;margin-bottom:2px}.dm-cat-check{display:flex;align-items:center;gap:4px;font-size:.82rem;color:#475569;cursor:pointer}.dm-cat-check input[type=checkbox]{accent-color:#1d4ed8}.dm-checkbox-label{display:flex;align-items:center;gap:6px;font-weight:500;font-size:.9rem}.dm-checkbox-label input[type=checkbox]{accent-color:#1d4ed8;width:16px;height:16px}.assess-question{border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;margin-bottom:10px;background:#f8fafc}.assess-q-text{display:block;font-size:.9rem;font-weight:500;color:#1e293b;margin-bottom:8px}.assess-options{display:flex;gap:18px}.assess-opt{display:flex;align-items:center;gap:4px;font-size:.85rem;color:#475569;cursor:pointer}.assess-opt input[type=radio]{accent-color:#1d4ed8}.dpia-sections{margin-top:8px}.dpia-section-block{margin-bottom:16px}.dpia-section-block h5{margin:0 0 8px;font-size:.95rem;color:#1e3a5f;border-bottom:1px solid #e2e8f0;padding-bottom:4px}.timeline-widget{position:relative;padding-left:28px}.timeline-widget:before{content:"";position:absolute;left:10px;top:8px;bottom:8px;width:2px;background:#cbd5e1}.timeline-item{position:relative;padding:8px 0 18px}.timeline-dot{position:absolute;left:-24px;top:12px;width:14px;height:14px;border-radius:50%;background:#cbd5e1;border:2px solid #fff;box-shadow:0 0 0 2px #cbd5e1}.timeline-done .timeline-dot{background:#22c55e;box-shadow:0 0 0 2px #22c55e}.timeline-date{font-size:.78rem;color:#64748b;font-weight:600}.timeline-label{font-size:.95rem;font-weight:600;color:#0f172a}.timeline-desc{font-size:.82rem;color:#475569;margin-top:2px}.timeline-done .timeline-label{color:#166534}.penalty-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.penalty-card{border:1px solid #e2e8f0;border-radius:10px;padding:18px;background:#f8fafc}.penalty-card-warn{border-color:#f59e0b;background:#fffbeb}.penalty-card-danger{border-color:#ef4444;background:#fef2f2}.penalty-amount{font-size:1.15rem;font-weight:700;color:#0f172a;margin-bottom:6px}.penalty-card-warn .penalty-amount{color:#92400e}.penalty-card-danger .penalty-amount{color:#991b1b}.penalty-desc{font-size:.82rem;color:#475569;line-height:1.4}.notice-content-preview{margin-top:16px}.notice-content-preview h4{margin:0 0 8px;font-size:.95rem}.notice-content-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;font-size:.85rem;line-height:1.6;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto}.law-search-bar{display:flex;gap:8px;margin-bottom:10px}.law-mode-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.88rem;background:#fff;min-width:150px}.law-search-input{flex:1;padding:8px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:.92rem}.law-search-btn{padding:8px 20px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.law-search-btn:disabled{opacity:.5;cursor:not-allowed}.law-llm-toggle{display:inline-flex;align-items:center;gap:6px;margin-bottom:16px;font-size:.88rem;color:#475569;cursor:pointer}.law-llm-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#2563eb}.law-ai-panel{background:linear-gradient(135deg,#eff6ff,#f0fdf4);border:1px solid #bfdbfe;border-radius:12px;padding:16px 20px;margin-bottom:20px}.law-ai-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.law-ai-badge{background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.law-ai-note{font-size:.78rem;color:#64748b}.law-ai-content{font-size:.92rem;line-height:1.6;color:#1e293b}.law-ai-content strong{color:#1e40af}.law-ai-content h3{font-size:1rem;margin:12px 0 6px;color:#1e3a5f}.law-ai-content h4{font-size:.92rem;margin:10px 0 4px;color:#1e3a5f}.law-ai-content ul{margin:6px 0;padding-left:20px}.law-ai-content li{margin-bottom:4px}.law-ai-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 16px;color:#991b1b;font-size:.85rem;margin-bottom:16px}.law-results-heading{font-size:1rem;color:#475569;margin-bottom:10px;border-bottom:1px solid #e2e8f0;padding-bottom:6px}.law-result-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;margin-bottom:8px;transition:border-color .15s ease}.law-result-card:hover{border-color:#93c5fd}.law-result-meta{display:flex;gap:12px;margin-bottom:6px;font-size:.78rem}.law-result-doc{background:#dbeafe;color:#1e40af;padding:2px 8px;border-radius:4px;font-weight:600}.law-result-page{color:#64748b}.law-result-score{color:#94a3b8}.law-result-text{font-size:.88rem;line-height:1.55;color:#334155;margin:0}.chat-fab{position:fixed;bottom:24px;right:24px;z-index:9999;width:48px;height:48px;border-radius:50%;border:none;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-size:1.3rem;cursor:pointer;box-shadow:0 2px 12px #2563eb59;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}.chat-fab:hover{transform:scale(1.08);box-shadow:0 4px 18px #2563eb80}.chat-panel{position:fixed;top:0;right:0;z-index:9998;width:400px;max-width:100vw;height:100vh;background:#fff;box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;animation:chat-slide-in .2s ease-out}@keyframes chat-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-panel-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:linear-gradient(135deg,#1e40af,#6d28d9);color:#fff;font-size:.95rem}.chat-header-btn{background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:4px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}.chat-header-btn:hover{background:#ffffff59}.chat-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.chat-status-connected{background:#4ade80}.chat-status-disconnected{background:#f87171}.chat-banner{padding:.5rem 1rem;background:#fef3c7;color:#92400e;font-size:.82rem;border-bottom:1px solid #fde68a}.chat-provider-bar{display:flex;align-items:center;padding:.4rem 1rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.82rem}.chat-provider-label{display:flex;align-items:center;gap:.4rem;color:#475569;font-weight:500;width:100%}.chat-provider-select{flex:1;padding:.25rem .4rem;border:1px solid #cbd5e1;border-radius:4px;font-size:.82rem;background:#fff}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-empty{color:#94a3b8;font-size:.88rem;text-align:center;margin-top:2rem;line-height:1.5}.chat-bubble{max-width:88%;padding:.6rem .85rem;border-radius:12px;font-size:.88rem;line-height:1.5;word-break:break-word}.chat-bubble-user{align-self:flex-end;background:#2563eb;color:#fff;border-bottom-right-radius:4px}.chat-bubble-assistant{align-self:flex-start;background:#f1f5f9;color:#1e293b;border-bottom-left-radius:4px}.chat-bubble-content ul{margin:.25rem 0;padding-left:1.2rem}.chat-bubble-content li{margin:.15rem 0}.chat-charts{margin-top:.5rem}.chat-chart-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem;margin-bottom:.5rem}.chat-chart-title{font-size:.82rem;font-weight:600;color:#1e293b;margin-bottom:.25rem}.chat-chart-total{font-weight:400;color:#64748b;font-size:.78rem}.chat-chart-container{width:100%;min-height:200px}.chat-typing{color:#64748b;font-style:italic}.chat-sources{margin-top:.35rem;font-size:.78rem}.chat-sources-toggle{background:none;border:none;color:#64748b;cursor:pointer;padding:0;font-size:.78rem}.chat-sources-toggle:hover{color:#2563eb}.chat-sources-list{margin:.25rem 0 0;padding-left:1rem;color:#64748b}.chat-sources-list li{margin:.15rem 0}.chat-source-idx{background:#e2e8f0;color:#475569;padding:.1rem .35rem;border-radius:3px;font-size:.72rem;font-weight:600}.chat-input-area{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid #e2e8f0;background:#fafbfc}.chat-input{flex:1;padding:.5rem .75rem;border:1px solid #cbd5e1;border-radius:8px;font-size:.88rem;outline:none}.chat-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.chat-send-btn{background:#2563eb;color:#fff;border:none;border-radius:8px;padding:.5rem .75rem;cursor:pointer;font-size:1rem}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn:hover:not(:disabled){background:#1d4ed8}.chat-toolbar{display:flex;gap:.5rem;padding:.5rem 1rem;border-top:1px solid #e2e8f0;background:#fafbfc}.chat-toolbar-btn{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;padding:.35rem .75rem;font-size:.78rem;cursor:pointer;color:#475569}.chat-toolbar-btn:hover{background:#e2e8f0}.chat-toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.onboarding-guide{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1.5rem 1.75rem;margin-bottom:1.5rem;box-shadow:0 1px 6px #0000000a}.onboarding-guide-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.onboarding-guide-header h3{margin:0;font-size:1.1rem;color:#0f172a;font-weight:700}.onboarding-guide-dismiss{background:none;border:1px solid #94a3b8;border-radius:6px;padding:.25rem .75rem;font-size:.78rem;color:#64748b;cursor:pointer}.onboarding-guide-dismiss:hover{background:#f1f5f9;color:#334155}.onboarding-guide-desc{color:#64748b;font-size:.88rem;margin:.25rem 0 1.25rem;line-height:1.5}.onboarding-guide-steps{list-style:none;padding:0;margin:0;display:grid;gap:0}.onboarding-guide-steps li:before{display:none}.rpt-category{margin-bottom:2rem}.rpt-category-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.rpt-category-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;color:#fff;font-size:1.1rem;flex-shrink:0}.rpt-category-title{margin:0;font-size:1rem;color:#0f172a}.rpt-category-count{font-size:.78rem;color:#94a3b8}.rpt-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem}.rpt-tile{border:1px solid #e2e8f0;border-radius:10px;padding:1.1rem 1.25rem;display:flex;flex-direction:column;justify-content:space-between;gap:.85rem;transition:box-shadow .15s,border-color .15s}.rpt-tile:hover{box-shadow:0 2px 12px #00000012;border-color:#cbd5e1}.rpt-tile-body{flex:1}.rpt-tile-name{margin:0 0 .35rem;font-size:.95rem;color:#0f172a}.rpt-tile-desc{margin:0 0 .6rem;font-size:.82rem;color:#64748b;line-height:1.45}.rpt-tile-roles{display:flex;flex-wrap:wrap;gap:.3rem}.rpt-role-chip{font-size:.68rem;padding:.15rem .45rem;border-radius:4px;background:#ffffffb3;border:1px solid #e2e8f0;color:#64748b;font-weight:500}.rpt-tile-btn{width:100%;padding:.5rem;border:1.5px solid;border-radius:8px;background:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}.rpt-tile-btn:hover:not(:disabled){background:#f8fafc}.rpt-tile-btn:disabled{opacity:.5;cursor:not-allowed}.rpt-schedule-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.85rem;margin-bottom:1.5rem}.rpt-schedule-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.15rem;display:flex;flex-direction:column;gap:.75rem}.rpt-schedule-card:hover{box-shadow:0 2px 8px #0000000d}.rpt-schedule-top{display:flex;justify-content:space-between;align-items:center}.rpt-schedule-top h4{margin:0;font-size:.9rem;color:#0f172a}.rpt-status-active{font-size:.72rem;font-weight:600;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;padding:.15rem .5rem;border-radius:10px}.rpt-status-paused{font-size:.72rem;font-weight:600;color:#94a3b8;background:#f8fafc;border:1px solid #e2e8f0;padding:.15rem .5rem;border-radius:10px}.rpt-schedule-meta{display:flex;gap:1.25rem;flex-wrap:wrap}.rpt-meta-label{display:block;font-size:.7rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em;margin-bottom:2px}.rpt-meta-value{display:block;font-size:.82rem;color:#334155;font-weight:500;text-transform:capitalize}.rpt-schedule-remove{align-self:flex-start;font-size:.78rem;padding:.3rem .65rem;border:1px solid #fca5a5;border-radius:6px;background:#fff;color:#dc2626;cursor:pointer;transition:background .15s}.rpt-schedule-remove:hover{background:#fef2f2}.rpt-schedule-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:1.25rem}.rpt-schedule-form h4{margin:0 0 .75rem;font-size:.95rem;color:#0f172a}.rpt-schedule-form-row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.rpt-schedule-form-row label{display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;color:#475569;font-weight:500}.rpt-schedule-form-row label span{font-size:.78rem;color:#64748b}.rpt-schedule-form-row select{padding:.4rem .6rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.85rem;min-width:180px}.rpt-schedule-form-row button{padding:.45rem 1rem;font-size:.85rem}.topbar-actions-group{display:flex;align-items:center;gap:8px}.topbar-bell,.topbar-profile{position:relative}.topbar-bell-btn,.topbar-profile-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:#4a5568;display:flex;align-items:center;transition:background .15s}.topbar-bell-btn:hover,.topbar-profile-btn:hover{background:#edf2f7}.topbar-bell-badge{position:absolute;top:2px;right:0;background:#e53e3e;color:#fff;font-size:.65rem;font-weight:700;border-radius:10px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.topbar-profile-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center}.topbar-profile-avatar-lg{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.topbar-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:1000;min-width:320px;max-width:380px}.topbar-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #e2e8f0;font-weight:600;font-size:.9rem;color:#1a202c}.topbar-mark-all-btn{background:none;border:none;color:#6366f1;cursor:pointer;font-size:.8rem;font-weight:500}.topbar-mark-all-btn:hover{text-decoration:underline}.topbar-notification-list{max-height:360px;overflow-y:auto}.topbar-notification-empty{padding:24px 16px;text-align:center;color:#a0aec0;font-size:.85rem}.topbar-notification-item{padding:10px 16px;border-left:3px solid #a0aec0;cursor:pointer;transition:background .12s}.topbar-notification-item:hover{background:#f7fafc}.topbar-notification-item--unread{background:#ebf4ff}.topbar-notification-item--unread:hover{background:#dbeafe}.topbar-notification-title{font-weight:600;font-size:.82rem;color:#1a202c;margin-bottom:2px}.topbar-notification-body{font-size:.78rem;color:#4a5568;line-height:1.35;margin-bottom:2px}.topbar-notification-time{font-size:.7rem;color:#a0aec0}.topbar-profile-dropdown{min-width:260px}.topbar-profile-info{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid #e2e8f0}.topbar-profile-name{font-weight:600;font-size:.9rem;color:#1a202c;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:180px}.topbar-profile-role{font-size:.78rem;color:#718096}.topbar-profile-actions{display:flex;flex-direction:column}.topbar-profile-actions button{background:none;border:none;text-align:left;padding:10px 16px;font-size:.85rem;cursor:pointer;color:#2d3748;transition:background .12s}.topbar-profile-actions button:hover{background:#f7fafc}.topbar-pwd-form{padding:12px 16px;display:flex;flex-direction:column;gap:8px}.topbar-pwd-form input{padding:7px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.82rem}.topbar-pwd-form input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f126}.topbar-pwd-err{color:#e53e3e;font-size:.78rem}.topbar-pwd-ok{color:#38a169;font-size:.78rem}.topbar-pwd-btns{display:flex;gap:8px}.topbar-pwd-btns button{padding:6px 14px;border-radius:6px;font-size:.82rem;cursor:pointer;border:1px solid #e2e8f0;background:#fff}.topbar-pwd-btns button[type=submit]{background:#6366f1;color:#fff;border-color:#6366f1}.topbar-pwd-btns button[type=submit]:hover{background:#4f46e5}.consent-autocomplete-dropdown{position:absolute;z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto;list-style:none;margin:4px 0 0;padding:4px 0;width:100%}.consent-autocomplete-dropdown li{padding:8px 12px;cursor:pointer;font-size:.85rem;color:#2d3748}.consent-autocomplete-dropdown li:hover{background:#edf2f7}.doc-filter-row{display:flex;gap:16px;align-items:flex-end;margin-bottom:16px;flex-wrap:wrap}.doc-filter-label{display:flex;flex-direction:column;gap:4px;font-size:.78rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.03em}.doc-filter-select{padding:7px 28px 7px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:.88rem;background:#fff;color:#1e293b;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2364748b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:140px}.doc-filter-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.doc-search-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.doc-search-input{flex:1;min-width:200px;padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:.9rem}.doc-search-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f126}.doc-search-btn{padding:8px 16px;border:none;border-radius:6px;background:#6366f1;color:#fff;font-size:.85rem;cursor:pointer;white-space:nowrap}.doc-search-btn:hover{background:#4f46e5}.doc-search-btn:disabled{opacity:.5;cursor:not-allowed}.doc-search-clear{background:#94a3b8}.doc-search-clear:hover{background:#64748b}.doc-seed-btn{background:#059669;margin-left:auto}.doc-seed-btn:hover{background:#047857}.doc-seed-msg{padding:8px 12px;margin-bottom:12px;border-radius:6px;background:#d1fae5;color:#065f46;font-size:.85rem}.doc-seed-err{background:#fee2e2;color:#991b1b}.doc-search-status{font-size:.85rem;color:#64748b;margin-bottom:12px}.doc-layout{display:flex;gap:20px}.doc-sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:2px}.doc-cat-btn{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border:none;border-radius:6px;background:transparent;font-size:.85rem;cursor:pointer;text-align:left;color:#334155}.doc-cat-btn:hover{background:#f1f5f9}.doc-cat-active{background:#e0e7ff;color:#3730a3;font-weight:600}.doc-cat-count{font-size:.75rem;background:#e2e8f0;border-radius:10px;padding:1px 7px;color:#475569}.doc-cat-active .doc-cat-count{background:#c7d2fe;color:#3730a3}.doc-main{flex:1;min-width:0}.doc-toolbar{display:flex;gap:8px;margin-bottom:12px}.doc-expand-btn{padding:4px 12px;border:1px solid #cbd5e1;border-radius:4px;background:#fff;font-size:.8rem;cursor:pointer;color:#475569}.doc-expand-btn:hover{background:#f1f5f9}.doc-empty{padding:40px 20px;text-align:center;color:#94a3b8;font-size:.95rem}.doc-article-card{border:1px solid #e2e8f0;border-radius:8px;margin-bottom:8px;background:#fff;overflow:hidden}.doc-article-open{border-color:#a5b4fc}.doc-article-header{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:transparent;cursor:pointer;text-align:left;font-size:.92rem;color:#1e293b}.doc-article-header:hover{background:#f8fafc}.doc-article-chevron{font-size:1.1rem;color:#94a3b8;transition:transform .15s;display:inline-block}.doc-chevron-open{transform:rotate(90deg)}.doc-article-title{flex:1;font-weight:500}.doc-cat-badge{font-size:.72rem;background:#ede9fe;color:#5b21b6;padding:2px 8px;border-radius:10px;white-space:nowrap}.doc-score{font-size:.72rem;background:#dbeafe;color:#1e40af;padding:2px 8px;border-radius:10px;white-space:nowrap}.doc-article-content{padding:0 16px 16px;border-top:1px solid #f1f5f9}.doc-role-badges{display:flex;gap:4px;flex-wrap:wrap;margin:12px 0 8px}.doc-role-badge{font-size:.68rem;background:#fef3c7;color:#92400e;padding:2px 6px;border-radius:4px;font-weight:500}.doc-article-body{font-size:.88rem;line-height:1.65;color:#334155}.doc-article-body p{margin:.5em 0}.doc-md-h2{font-size:1.1rem;margin:1em 0 .4em;color:#1e293b}.doc-md-h3{font-size:1rem;margin:.8em 0 .3em;color:#334155}.doc-md-h4{font-size:.92rem;margin:.6em 0 .3em;color:#475569}.doc-md-ul{margin:.3em 0;padding-left:1.5em}.doc-md-li{margin:.15em 0}.doc-md-code{background:#f1f5f9;padding:1px 5px;border-radius:3px;font-size:.84em}.doc-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:12px;padding-top:8px;border-top:1px solid #f1f5f9}.doc-tag{font-size:.7rem;background:#f1f5f9;color:#64748b;padding:2px 8px;border-radius:10px}@media(max-width:768px){.doc-layout{flex-direction:column}.doc-sidebar{width:100%;flex-direction:row;flex-wrap:wrap;gap:4px}.doc-cat-btn{padding:6px 10px;font-size:.8rem}}.gap-tiles-row{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.gap-tile{flex:1;min-width:120px;padding:16px;border-radius:10px;text-align:center;background:#fff;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000a}.gap-tile-value{font-size:1.6rem;font-weight:700;line-height:1.2}.gap-tile-label{font-size:.75rem;color:#64748b;margin-top:4px;text-transform:uppercase;letter-spacing:.03em}.gap-tile-primary{border-left:4px solid #6366f1}.gap-tile-primary .gap-tile-value{color:#6366f1}.gap-tile-compliant{border-left:4px solid #16a34a}.gap-tile-compliant .gap-tile-value{color:#16a34a}.gap-tile-partial{border-left:4px solid #d97706}.gap-tile-partial .gap-tile-value{color:#d97706}.gap-tile-significant{border-left:4px solid #ea580c}.gap-tile-significant .gap-tile-value{color:#ea580c}.gap-tile-noncompliant{border-left:4px solid #dc2626}.gap-tile-noncompliant .gap-tile-value{color:#dc2626}.gap-tile-score{border-left:4px solid #0891b2}.gap-tile-score .gap-tile-value{color:#0891b2}.gap-tile-alert{border-left:4px solid #e11d48}.gap-tile-alert .gap-tile-value{color:#e11d48}.gap-rating-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap}.gap-rating-badge.gap-tile-compliant{background:#dcfce7;color:#166534}.gap-rating-badge.gap-tile-partial{background:#fef3c7;color:#92400e}.gap-rating-badge.gap-tile-significant{background:#ffedd5;color:#9a3412}.gap-rating-badge.gap-tile-noncompliant{background:#fee2e2;color:#991b1b}.gap-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.gap-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.gap-card:hover{border-color:#a5b4fc;box-shadow:0 2px 8px #6366f11a}.gap-card-active{border-color:#6366f1;box-shadow:0 2px 12px #6366f12e;background:#fafaff}.gap-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}.gap-card-org{font-weight:600;font-size:.92rem;color:#1e293b;flex:1}.gap-card-contact{font-size:.82rem;color:#64748b;margin-bottom:10px}.gap-card-metrics{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.gap-card-score{font-size:1.3rem;font-weight:700}.gap-card-meta{display:flex;gap:8px;font-size:.78rem;color:#64748b}.gap-card-high{color:#dc2626;font-weight:600}.gap-card-date{font-size:.75rem;color:#94a3b8}.gap-empty{padding:48px 20px;text-align:center;color:#94a3b8;font-size:.95rem}.gap-trend{font-size:.65rem;font-weight:600;margin-left:6px;vertical-align:middle}.gap-trend--up{color:#16a34a}.gap-trend--down{color:#dc2626}.gap-modal{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:24px;position:relative;width:90%;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #00000040;animation:gapModalIn .2s ease-out}@keyframes gapModalIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.gap-modal-close{position:absolute;top:12px;right:14px;border:none;background:none;font-size:1.5rem;color:#94a3b8;cursor:pointer;line-height:1;z-index:1}.gap-modal-close:hover{color:#475569}.gap-detail-title{margin:0 0 16px;font-size:1.05rem;color:#1e293b}.gap-detail-section{margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #e2e8f0}.gap-detail-section:last-of-type{border-bottom:none}.gap-detail-heading{margin:0 0 10px;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:#64748b;font-weight:600}.gap-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.gap-detail-item{display:flex;flex-direction:column;gap:1px}.gap-detail-label{font-size:.72rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em}.gap-detail-value{font-size:.88rem;color:#334155;word-break:break-word}.gap-score-display{display:flex;align-items:center;gap:12px;margin-bottom:8px}.gap-score-big{font-size:2rem;font-weight:700;line-height:1}.gap-score-summary{display:flex;gap:12px;font-size:.82rem;color:#64748b}.gap-cat-list{display:flex;flex-direction:column;gap:8px}.gap-cat-row{display:flex;align-items:center;gap:10px}.gap-cat-info{flex:1;min-width:0}.gap-cat-name{display:block;font-size:.84rem;color:#334155;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gap-cat-ref{font-size:.7rem;color:#94a3b8}.gap-cat-bar-wrap{width:80px;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;flex-shrink:0}.gap-cat-bar{height:100%;border-radius:3px;transition:width .3s}.gap-cat-pct{width:36px;text-align:right;font-size:.82rem;font-weight:600;flex-shrink:0}.gap-cat-gaps{font-size:.72rem;color:#dc2626;white-space:nowrap;flex-shrink:0}.gap-rec-list{margin:0;padding-left:1.2em;font-size:.84rem;color:#475569}.gap-rec-list li{margin-bottom:4px}.gap-pdf-btn{width:100%;margin-top:12px}@media(max-width:900px){.gap-cards-grid{grid-template-columns:1fr}.gap-tiles-row{gap:8px}.gap-tile{min-width:90px;padding:10px}.gap-tile-value{font-size:1.2rem}.gap-modal{width:96%;max-width:none;padding:16px}}.owner-section-title{margin:1.5rem 0 .75rem;font-size:1rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:8px}.owner-section-count{background:#e2e8f0;color:#475569;font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:10px}.owner-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.owner-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px;transition:box-shadow .15s,border-color .15s}.owner-card:hover{box-shadow:0 2px 12px #0000000f;border-color:#cbd5e1}.owner-card--pending{border-left:4px solid #d97706}.owner-card--active{border-left:4px solid #16a34a}.owner-card--overdue{border-left:4px solid #dc2626}.owner-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.owner-card-id{font-size:.78rem;font-weight:600;color:#64748b;letter-spacing:.02em}.owner-card-name{font-size:.92rem;font-weight:600;color:#1e293b;margin-bottom:6px;line-height:1.3}.owner-card-meta{display:flex;gap:12px;font-size:.78rem;color:#94a3b8;margin-bottom:8px}.owner-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border:1px solid}.owner-badge--risk{font-size:.65rem}.owner-due-date{font-size:.82rem;color:#64748b;margin-bottom:10px}.owner-due-label{font-weight:500}.owner-due-overdue{color:#dc2626;font-weight:600}.owner-card-actions{display:flex;gap:8px;margin-top:10px}.owner-decline-form{margin-top:8px}.owner-decline-form textarea{width:100%;font-size:.85rem;padding:6px 8px;border:1px solid #e2e8f0;border-radius:6px;resize:vertical;margin-bottom:6px}.btn-sm{padding:5px 14px;font-size:.8rem;border-radius:6px}.btn-outline-danger{background:transparent;color:#dc2626;border:1px solid #dc2626;cursor:pointer;border-radius:6px;transition:background .15s}.btn-outline-danger:hover{background:#fef2f2}.btn-danger{background:#dc2626;color:#fff;border:none;cursor:pointer}.btn-muted{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;cursor:pointer}.btn-muted:hover{background:#e2e8f0}@media(max-width:700px){.owner-cards-grid{grid-template-columns:1fr}}.sidebar-license-gate{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;text-align:center;gap:1rem}.sidebar-license-icon{color:#f59e0b;opacity:.8}.sidebar-license-msg{font-size:.85rem;color:#94a3b8;line-height:1.4}.sidebar-license-btn{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:.5rem 1.25rem;cursor:pointer;font-size:.85rem;transition:background .15s}.sidebar-license-btn:hover{background:#1d4ed8}.license-status-card,.license-action-card{background:#fff;border-radius:8px;padding:1.25rem;margin-bottom:1rem;box-shadow:0 1px 3px #00000014}.license-status-card h3,.license-action-card h3{margin:0 0 .75rem;font-size:1rem;color:#1e293b}.license-info-table{width:100%;border-collapse:collapse}.license-info-table td{padding:.4rem .6rem;border-bottom:1px solid #f1f5f9;font-size:.9rem}.license-info-table td:first-child{font-weight:600;color:#64748b;width:150px}.license-badge{display:inline-block;padding:.15rem .6rem;border-radius:99px;font-size:.8rem;font-weight:600}.license-badge--active{background:#dcfce7;color:#166534}.license-badge--inactive{background:#fef2f2;color:#991b1b}.license-upload-row{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}@media(pointer:coarse){button,a,.nav-sub-item,.nav-item-single,.nav-group-header{min-height:44px}input,select,textarea{min-height:44px;font-size:16px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.sidebar{padding-bottom:env(safe-area-inset-bottom)}.content{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.services-footer{padding-bottom:calc(2rem + env(safe-area-inset-bottom))}}@media(max-width:480px){.login-layout{grid-template-columns:1fr}.login-brand{padding:24px 16px}.login-brand h1{font-size:1.2rem}.login-panel{padding:16px}.login-panel .card{padding:20px 16px}.login-cta-links{flex-direction:column;gap:8px}.gap-assessment-shell{padding:0}.gap-assessment-shell>div{padding:1rem .75rem}.kpi-row{grid-template-columns:1fr 1fr}}.inq-status-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap}.inq-status-open{background:#dbeafe;color:#1e40af}.inq-status-responded{background:#fef3c7;color:#92400e}.inq-status-action-taken{background:#dcfce7;color:#166534}.inq-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;margin:12px 0;font-size:.88rem}.inq-message-box{margin-top:4px;padding:10px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.88rem;white-space:pre-wrap;word-break:break-word;font-family:Noto Sans,Noto Sans Devanagari,system-ui,sans-serif}.inq-status-update{display:flex;flex-direction:column;gap:10px;margin-top:12px;padding:14px;background:#f1f5f9;border-radius:8px}.inq-status-update label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;font-weight:600;color:#334155}.inq-status-update select,.inq-status-update textarea{padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:.88rem;font-family:inherit}.inq-audit-trail{list-style:none;padding:0;margin:8px 0 0}.inq-audit-trail li{padding:6px 0;border-bottom:1px solid #f1f5f9;font-size:.82rem;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.inq-audit-action{font-weight:600;color:#1e40af}.inq-audit-by{color:#475569}.inq-audit-at{color:#94a3b8;font-size:.78rem}.inq-audit-notes{color:#64748b;font-style:italic}.inq-analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.inq-analytics-section{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px}.inq-analytics-section h4{font-size:.92rem;font-weight:600;margin:0 0 12px;color:#1e293b}.inq-bar-list{display:flex;flex-direction:column;gap:6px}.inq-chart-row{display:flex;align-items:center;gap:8px}.inq-chart-label{min-width:120px;font-size:.8rem;color:#475569;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inq-chart-bar-wrap{flex:1;height:20px;background:#f1f5f9;border-radius:4px;overflow:hidden}.inq-chart-bar{height:100%;border-radius:4px;transition:width .3s ease}.inq-chart-count{min-width:32px;font-size:.8rem;font-weight:600;color:#0f172a}@media(max-width:768px){.inq-detail-grid,.inq-analytics-grid{grid-template-columns:1fr}}.ob-progress-bar{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 20px;margin-bottom:16px}.ob-progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.88rem;color:#475569}.ob-progress-label strong{color:#1e293b;font-size:.92rem}.ob-progress-track{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.ob-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#16a34a);transition:width .6s ease}.onboarding-step{padding:14px 18px;border-left:4px solid #cbd5e1;margin-bottom:6px;border-radius:0 10px 10px 0;background:#fafbfc;transition:border-color .2s,background .2s,box-shadow .2s}.onboarding-step:hover{background:#f1f5f9;box-shadow:0 1px 4px #0000000a}.onboarding-step.step-complete{border-left-color:#16a34a;background:linear-gradient(135deg,#f0fdf4,#ecfdf5)}.ob-step-row{display:flex;align-items:flex-start;gap:14px}.ob-step-num{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;border-radius:50%;background:#e2e8f0;color:#475569;font-weight:700;font-size:.82rem;flex-shrink:0}.step-complete .ob-step-num{background:#16a34a;color:#fff}.ob-step-body{flex:1;min-width:0}.ob-step-desc{display:block;font-size:.82rem;color:#64748b;margin-top:2px;line-height:1.5}.ob-detail-counts{display:inline;font-weight:600;color:#334155;font-size:.78rem}.step-link{background:none;border:none;padding:0;cursor:pointer;text-align:left;color:#2563eb;font-size:inherit;font-family:inherit;display:inline-flex;align-items:center;gap:8px}.step-link:hover{text-decoration:underline}.step-link strong{color:#1e293b;font-size:.92rem}.step-complete .step-link strong{color:#15803d}.ob-badge{display:inline-flex;align-items:center;padding:4px 14px;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;flex-shrink:0;margin-top:2px}.ob-badge--done{background:#16a34a;color:#fff;box-shadow:0 1px 3px #16a34a4d}.ob-badge--pending{background:#f1f5f9;color:#64748b;border:1px solid #cbd5e1}.step-check{display:inline-block;padding:4px 14px;background:#16a34a;color:#fff;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;box-shadow:0 1px 3px #16a34a4d}.btn-danger{background:#dc2626;color:#fff;border:none;padding:5px 12px;border-radius:6px;cursor:pointer;font-size:.82rem}.btn-danger:hover{background:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.topbar-lang-dropdown{position:absolute;top:100%;right:0;z-index:1000;min-width:220px;max-height:400px;overflow-y:auto;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f;padding:6px 0;margin-top:6px}.topbar-lang-option{display:flex;align-items:center;gap:10px;width:100%;padding:9px 16px;border:none;background:none;cursor:pointer;font-size:.9rem;color:#334155;text-align:left;transition:background .15s}.topbar-lang-option:hover{background:#f1f5f9}.topbar-lang-option--active{background:#eff6ff;color:#2563eb;font-weight:600}.topbar-lang-option--active:hover{background:#dbeafe}.topbar-lang-native{font-size:.95rem}.topbar-lang-english{color:#94a3b8;font-size:.8rem;margin-left:auto}[dir=rtl] .app-shell{direction:rtl;grid-template-columns:1fr 260px}[dir=rtl] .app-shell--collapsed{grid-template-columns:1fr 72px}[dir=rtl] .sidebar{order:2;direction:rtl;text-align:right}[dir=rtl] .content{order:1;direction:rtl}[dir=rtl] .sidebar-brand{flex-direction:row-reverse}[dir=rtl] .sidebar-brand-right{margin-left:0;margin-right:auto}[dir=rtl] .nav-group-header{flex-direction:row-reverse;text-align:right}[dir=rtl] .nav-group-chevron{transform:scaleX(-1);margin-left:0;margin-right:auto}[dir=rtl] .nav-group-chevron--open{transform:scaleX(-1) rotate(90deg)}[dir=rtl] .nav-sub-item{padding-left:12px;padding-right:38px;text-align:right}[dir=rtl] .nav-flyout{left:auto;right:100%}[dir=rtl] .content-topbar,[dir=rtl] .topbar-actions-group{flex-direction:row-reverse}[dir=rtl] .topbar-lang-dropdown,[dir=rtl] .topbar-dropdown{right:auto;left:0}[dir=rtl] .sidebar-toggle{margin-left:0;margin-right:auto}.email-config-form{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px;max-width:720px}.email-config-form label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:500;color:var(--text-secondary, #555)}.email-config-form input,.email-config-form select{padding:7px 10px;border:1px solid var(--border, #d0d5dd);border-radius:6px;font-size:13px;background:var(--bg-input, #fff);color:var(--text-primary, #1a1a2e)}.email-config-form .full-width{grid-column:1 / -1}.email-mode-helper{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin:14px 0}.email-mode-card{background:var(--bg-card, #f8f9fb);border:1px solid var(--border, #e2e6ea);border-radius:8px;padding:12px 14px;font-size:12px}.email-mode-card h4{margin:0 0 6px;font-size:13px;color:var(--accent, #1a73e8)}.email-mode-card code{font-size:11px;background:var(--bg-muted, #eef1f5);padding:2px 5px;border-radius:3px}.email-log-table{width:100%;border-collapse:collapse;font-size:12.5px}.email-log-table th{text-align:left;font-weight:600;padding:8px 10px;border-bottom:2px solid var(--border, #d0d5dd);color:var(--text-secondary, #555);font-size:11px;text-transform:uppercase;letter-spacing:.3px}.email-log-table td{padding:7px 10px;border-bottom:1px solid var(--border-light, #eee)}.email-log-table .badge-sent{background:#d4edda;color:#155724;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.email-log-table .badge-failed{background:#f8d7da;color:#721c24;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.email-rule-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light, #eee)}.email-rule-row .rule-label{flex:1;font-size:13px;font-weight:500}.email-rule-row .rule-roles{display:flex;gap:4px;flex-wrap:wrap}.email-rule-row .role-chip{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--bg-muted, #eef1f5);color:var(--text-secondary, #555);cursor:pointer}.email-rule-row .role-chip.active{background:var(--accent, #1a73e8);color:#fff}.smtp-test-result{margin-top:10px;padding:10px 14px;border-radius:6px;font-size:13px}.smtp-test-result.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.smtp-test-result.failure{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.email-toggle{position:relative;width:40px;height:22px;cursor:pointer}.email-toggle input{opacity:0;width:0;height:0}.email-toggle .slider{position:absolute;inset:0;background:#ccc;border-radius:22px;transition:background .2s}.email-toggle .slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}.email-toggle input:checked+.slider{background:var(--accent, #1a73e8)}.email-toggle input:checked+.slider:before{transform:translate(18px)}@keyframes pulse-green{0%,to{box-shadow:0 0 0 3px #16a36a4d}50%{box-shadow:0 0 0 8px #16a36a26}}
