:root{--bg:#f8fafc;--bg-deep:#0f172a;--panel:#fff;--text:#334155;--text-soft:#64748b;--primary:#6366f1;--primary-strong:#4f46e5;--secondary:#ec4899;--danger:#dc2626;--warning:#d97706;--success:#059669;--sidebar-bg:#1e293b;--sidebar-text:#94a3b8;--sidebar-active-bg:rgba(255,255,255,.08);--sidebar-active-text:#fff;--border:rgba(226,232,240,.8);--shadow:0 10px 25px -5px rgba(0,0,0,.04),0 8px 10px -6px rgba(0,0,0,.04);--radius:16px;--transition:.3s cubic-bezier(.4,0,.2,1);--sidebar-width:320px}
*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at top left,rgba(37,99,235,.18),transparent 22%),radial-gradient(circle at top right,rgba(124,58,237,.14),transparent 22%),linear-gradient(180deg,#eef5ff 0%,#f8fafc 46%,#f4f7fb 100%);color:var(--text);line-height:1.55}a{color:inherit;text-decoration:none}code{background:rgba(37,99,235,.08);color:var(--primary-strong);padding:.18rem .35rem;border-radius:8px;font-size:.92rem}
.layout-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh;transition:grid-template-columns var(--transition)}body.menu-hidden .layout-shell{grid-template-columns:0 1fr}
.sidebar{position:sticky;top:0;height:100vh;width:var(--sidebar-width);padding:32px 20px;display:flex;flex-direction:column;overflow:hidden;color:#e2e8f0;z-index:25;border-right:1px solid rgba(255,255,255,.05);background:radial-gradient(circle at top left,rgba(96,165,250,.18),transparent 26%),radial-gradient(circle at top right,rgba(167,139,250,.16),transparent 24%),linear-gradient(180deg,#07111f 0%,#0b1220 38%,#111c2d 100%);box-shadow:inset -1px 0 0 rgba(255,255,255,.06),18px 0 50px rgba(2,6,23,.18);transition:transform var(--transition),opacity var(--transition),visibility var(--transition)}
.sidebar::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.05),transparent 22%),linear-gradient(135deg,rgba(59,130,246,.08),transparent 45%);pointer-events:none}
.sidebar::after{content:"";position:absolute;top:18px;left:14px;right:14px;bottom:18px;border-radius:28px;border:1px solid rgba(255,255,255,.05);pointer-events:none}
body.menu-hidden .sidebar{transform:translateX(-100%);opacity:0;visibility:hidden}
.brand-block{position:relative;padding:18px 18px 20px;margin-bottom:20px;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.04));border:1px solid rgba(148,163,184,.16);box-shadow:inset 0 1px 0 rgba(255,255,255,.07),0 16px 32px rgba(2,6,23,.18);backdrop-filter:blur(14px)}
.brand-title,.guest-brand{font-size:1.34rem;font-weight:800;line-height:1.2;letter-spacing:.02em;color:#f8fafc}.brand-title{background:linear-gradient(to right,#fff,var(--sidebar-text));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.brand-tagline,.guest-tagline,.page-eyebrow,.cell-subtext,.role-subtext,.user-meta,.auth-note,.info-banner,small{color:var(--text-soft)}.sidebar .brand-tagline{margin-top:6px;color:rgba(226,232,240,.72);font-size:.94rem;line-height:1.5}
.nav-menu{position:relative;display:flex;flex-direction:column;gap:.5rem;padding:4px;max-height:calc(100vh - 250px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.34) transparent}
.nav-menu::-webkit-scrollbar{width:8px}.nav-menu::-webkit-scrollbar-track{background:transparent}.nav-menu::-webkit-scrollbar-thumb{background:rgba(148,163,184,.26);border-radius:999px}
.nav-level,.nav-group{display:flex;flex-direction:column;gap:.38rem}
.nav-level-1,.nav-level-2,.nav-level-3,.nav-level-4{margin-left:.9rem;padding-left:.95rem;border-left:1px solid rgba(148,163,184,.14)}
.nav-group-row{display:flex;align-items:center;gap:.5rem}
.nav-group-link,.nav-group-label,.nav-static,.nav-link{min-height:48px;border-radius:16px}
.nav-group-link,.nav-link{position:relative;display:flex;align-items:center;gap:14px;min-height:48px;margin-bottom:4px;padding:12px 18px;color:rgba(226,232,240,.9);font-size:.95rem;font-weight:500;text-decoration:none;word-wrap:break-word;overflow:visible;border:1px solid transparent;background:rgba(255,255,255,.02);transition:background .2s ease,color .2s ease,transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.nav-group-label,.nav-static{display:flex;align-items:center;padding:.78rem .95rem;color:rgba(226,232,240,.84);background:rgba(255,255,255,.04);border:1px solid rgba(148,163,184,.1)}
.nav-link:hover,.nav-group-link:hover{color:#fff;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(59,130,246,.1));border-color:rgba(96,165,250,.18);transform:translateX(2px);box-shadow:0 10px 22px rgba(2,6,23,.16)}
.nav-link.active,.nav-group-link.active{color:var(--sidebar-active-text);font-weight:600;background:linear-gradient(90deg,rgba(99,102,241,.15) 0%,transparent 100%);border-left:4px solid var(--primary);border-radius:0 12px 12px 0;margin-left:-24px;padding-left:20px}
.nav-link.active::before{content:"";position:absolute;left:-20px;width:4px;height:20px;background:var(--primary);border-radius:0 4px 4px 0;box-shadow:0 0 15px var(--primary)}
.nav-link-main{display:flex;align-items:center;gap:.78rem;min-width:0;width:100%}
.nav-icon{width:34px;height:34px;flex:0 0 34px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;font-size:1.1rem;line-height:1;opacity:.8;color:#dbeafe;background:rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.nav-link:hover .nav-icon,.nav-group-link:hover .nav-icon,.nav-link.active .nav-icon,.nav-group-link.active .nav-icon{color:#fff;opacity:1;background:rgba(255,255,255,.12)}.nav-link.active .nav-icon{color:var(--primary)}
.nav-label{display:block;flex:1;min-width:0;line-height:1.4;font-size:.95rem;font-weight:650;letter-spacing:.01em;white-space:normal;overflow:hidden;text-overflow:ellipsis}
.nav-subtext{display:block;margin-top:2px;font-size:.75rem;color:var(--text-soft)}
.nav-link-child,.nav-group-label.nav-link-child,.nav-static.nav-link-child{min-height:42px;padding-top:.64rem;padding-bottom:.64rem;border-radius:14px}
.nav-group-label .nav-label,.nav-static .nav-label{font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;opacity:.92}
.nav-group-toggle{flex:0 0 44px;width:44px;min-height:44px;position:relative;z-index:5;pointer-events:auto;cursor:pointer;color:#cbd5e1;border:1px solid rgba(148,163,184,.12);border-radius:14px;background:rgba(255,255,255,.05);transition:background-color .18s ease,transform .18s ease,border-color .18s ease,color .18s ease}
.nav-group-toggle:hover{color:#fff;background:rgba(255,255,255,.1);border-color:rgba(96,165,250,.2);transform:translateY(-1px)}
.nav-group-caret{display:inline-block;transition:transform .18s ease}.nav-group.is-open .nav-group-caret{transform:rotate(0)}.nav-group:not(.is-open) .nav-group-caret{transform:rotate(-90deg)}
.nav-group.is-open>.nav-group-children,.nav-group-children{display:block}.nav-group-children[hidden]{display:none!important}
.main-column{min-width:0;display:flex;flex-direction:column}
.site-header,.guest-header{display:flex;justify-content:space-between;gap:20px;align-items:stretch;margin:24px 32px 20px;padding:18px 22px;border-radius:24px;background:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 15px rgba(0,0,0,.02);backdrop-filter:blur(12px)}
.header-main{display:flex;align-items:center;gap:14px;min-width:0;flex:1}.page-head{min-width:0}.page-title{margin:6px 0 0;font-size:clamp(1.6rem,3vw,2.2rem);line-height:1.2}
.user-panel{min-width:320px;padding:2px 0 2px 18px;border-left:1px solid rgba(148,163,184,.18);display:flex;flex-direction:column;justify-content:center;gap:6px;text-align:right}.user-name{font-weight:700}.header-actions{justify-content:flex-end}
.content-area,.guest-content{padding:0 32px 28px}.guest-content{display:flex;align-items:center;justify-content:center;flex:1;flex-direction:column;gap:16px}.guest-content>.flash-stack{width:100%;max-width:540px;margin:0}.guest-content>.auth-card{width:100%;max-width:540px}.guest-content>*{flex:0 0 auto}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);backdrop-filter:blur(14px);transition:transform var(--transition),box-shadow var(--transition)}.card:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px rgba(0,0,0,.05)}.card-error{border-left:5px solid var(--danger)}.spaced-top{margin-top:28px}
.grid-two{display:grid;grid-template-columns:1.05fr 1.35fr;gap:28px}
.section-header{margin-bottom:18px}.section-header h2,.role-card h3,.auth-card h2{margin:0 0 6px}.section-header p,.auth-intro p{margin:0;color:var(--text-soft)}
.form-grid,.contract-form-grid,.config-preview-grid,.config-notif-grid,.gdrive-test-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.form-field{display:flex;flex-direction:column;gap:8px}.full-width,.contract-form-grid .full-width,.config-card.full-span{grid-column:1/-1}
label{font-weight:700;font-size:.96rem}input,select,textarea,button{font:inherit}
input,select,textarea{width:100%;padding:13px 14px;background:rgba(255,255,255,.98);border:1px solid var(--border);border-radius:14px;color:var(--text);transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}
input:focus,select:focus,textarea:focus{outline:none;border-color:rgba(37,99,235,.5);box-shadow:0 0 0 4px rgba(37,99,235,.12);transform:translateY(-1px)}
textarea{resize:vertical;min-height:120px}
.button-row,.action-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.inline-form{display:inline-flex;margin:0}
.btn{border:0;cursor:pointer;border-radius:14px;padding:12px 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform var(--transition),opacity var(--transition),box-shadow var(--transition),background var(--transition);font-weight:700}
.btn:hover{transform:translateY(-1px)}.btn-primary{color:#fff;background:linear-gradient(90deg,var(--primary),var(--secondary));box-shadow:0 14px 22px rgba(37,99,235,.24)}.btn-danger{color:#fff;background:linear-gradient(90deg,#ef4444,#dc2626)}.btn-ghost{background:rgba(255,255,255,.86);color:var(--text);border:1px solid var(--border)}.btn-sm{padding:9px 12px;border-radius:12px;font-size:.92rem}.btn-block{width:100%}
.btn-icon,.config-notif-page .btn-icon{min-width:38px;width:38px;height:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;border-radius:12px}.btn-icon-only{min-width:40px;width:40px;height:40px;padding:0;font-size:1rem;line-height:1}.btn-icon-text{min-height:46px}
.table-wrap{overflow-x:auto;border-radius:18px;border:1px solid rgba(148,163,184,.18)}.table-wrap table{width:100%;border-collapse:collapse;min-width:780px}
th,td{padding:14px 16px;text-align:left;vertical-align:top}th{background:rgba(15,23,42,.04);color:var(--text-soft);font-size:.84rem;text-transform:uppercase;letter-spacing:.06em}tr+tr td{border-top:1px solid rgba(148,163,184,.16)}
.status-pill,.tag-pill,.contract-badge,.badge{display:inline-flex;align-items:center;border-radius:999px;font-weight:700}
.status-pill,.tag-pill{padding:6px 10px;font-size:.82rem}.status-pill.ok{background:rgba(5,150,105,.14);color:var(--success)}.status-pill.off{background:rgba(220,38,38,.12);color:var(--danger)}
.tag-pill.user-can{background:rgba(37,99,235,.12);color:var(--primary-strong)}.tag-pill.custom{background:rgba(124,58,237,.14);color:var(--secondary)}
.flash-stack{display:grid;gap:12px;margin-bottom:22px}.flash{padding:14px 16px;border-radius:16px;border:1px solid transparent;font-weight:600}.flash-success{background:rgba(5,150,105,.12);color:var(--success);border-color:rgba(5,150,105,.16)}.flash-error{background:rgba(220,38,38,.1);color:var(--danger);border-color:rgba(220,38,38,.18)}.flash-warning{background:rgba(217,119,6,.12);color:var(--warning);border-color:rgba(217,119,6,.16)}.flash-info{background:rgba(37,99,235,.1);color:var(--primary-strong);border-color:rgba(37,99,235,.16)}
.role-grid,.config-menu-role-grid,.contract-summary-grid,.dashboard-kpis{display:grid;gap:18px}.role-grid,.config-menu-role-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.dashboard-kpis{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.contract-summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.role-card,.contract-summary-card,.dashboard-hero,.dashboard-card,.kpi-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 8px 24px rgba(15,23,42,.05)}.role-card{padding:18px;border-radius:18px;border:1px solid rgba(148,163,184,.18);background:rgba(255,255,255,.88)}
.checkbox-list{display:grid;gap:10px;max-height:440px;overflow-y:auto;padding-right:4px}.check-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:14px;background:rgba(241,245,249,.88);border:1px solid rgba(148,163,184,.14)}.check-item input{width:18px;height:18px;margin-top:2px}.check-item span{display:flex;flex-direction:column;gap:3px}.check-item small{color:var(--text-soft)}
.info-banner{padding:14px 16px;border-radius:16px;background:rgba(37,99,235,.08);border:1px solid rgba(37,99,235,.12)}
.site-footer,.guest-footer{margin:24px 32px 30px;padding:16px 18px;border-radius:18px;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.68);display:flex;justify-content:space-between;gap:12px;box-shadow:var(--shadow)}
.guest-wrapper{min-height:100vh;display:flex;flex-direction:column}.auth-card{max-width:540px;width:100%}.auth-intro{margin-bottom:20px}.auth-shell{width:100%;max-width:540px;display:grid;gap:16px}.auth-shell .flash-stack{margin-bottom:0}.auth-shell .auth-card{max-width:100%}
.badge{margin-bottom:10px;padding:7px 12px;background:rgba(37,99,235,.1);color:var(--primary-strong)}
.menu-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:0;border-radius:14px;background:linear-gradient(90deg,var(--primary),var(--secondary));color:#fff;cursor:pointer;font-weight:700;box-shadow:0 12px 22px rgba(37,99,235,.2);flex-shrink:0}.menu-toggle-icon{font-size:1rem;line-height:1}.backdrop{display:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
body.modal-open{overflow:hidden}
.app-modal{position:fixed;inset:0;z-index:3000;display:none}.app-modal[aria-hidden="true"]{display:none!important}.app-modal.is-open{display:block}
.app-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.56);backdrop-filter:blur(3px)}
.app-modal-scroll{position:relative;z-index:1;width:100%;height:100%;overflow-y:auto;padding:32px 18px}
.app-modal-dialog,.config-menu-modal-dialog{width:min(920px,100%);margin:0 auto;background:rgba(255,255,255,.98);border:1px solid rgba(255,255,255,.7);border-radius:24px;box-shadow:0 30px 80px rgba(15,23,42,.24);overflow:hidden;position:relative}
.config-menu-modal-dialog{width:min(920px,calc(100vw - 32px))}.config-menu-role-dialog{width:min(1160px,calc(100vw - 32px))}.app-confirm-dialog{width:min(520px,calc(100vw - 32px))}.contract-files-dialog{width:min(920px,calc(100vw - 32px))}.forgot-password-modal .forgot-password-dialog{width:min(460px,100%)}.generate-password-modal .generate-password-dialog{width:min(520px,100%)}
.app-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 22px;border-bottom:1px solid rgba(148,163,184,.14);background:linear-gradient(180deg,rgba(248,250,252,.9),rgba(255,255,255,.96))}
.app-modal-title{margin:0 0 6px;font-size:1.2rem;font-weight:800;color:var(--text)}.app-modal-subtitle{margin:0;color:var(--text-soft);font-size:.94rem}.app-modal-body{padding:22px}
.app-modal-close{border:0;background:rgba(148,163,184,.12);color:var(--text);width:42px;height:42px;border-radius:14px;cursor:pointer;font-size:1.2rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition),transform var(--transition)}.app-modal-close:hover{background:rgba(148,163,184,.18);transform:translateY(-1px)}
.customer-page,.contract-page,.dashboard-page,.config-notif-page,.sla-page,.config-menu-page{display:grid;gap:18px}
.customer-toolbar,.contract-toolbar,.sla-toolbar,.config-menu-hero,.dashboard-head-actions,.customer-list-foot,.customer-list-head,.contract-list-head,.contract-list-foot,.sla-list-head,.sla-list-foot,.contract-list-actions,.sla-filter-actions,.customer-actions,.contract-actions,.sla-actions{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.customer-toolbar{gap:16px}.contract-toolbar{margin-bottom:16px;gap:16px}.sla-toolbar{gap:16px}.dashboard-head-actions{justify-content:space-between}
.customer-toolbar-left h2,.sla-toolbar-left h2,.config-menu-title{margin:0 0 6px;font-size:1.35rem}.contract-toolbar-left h2{margin:0 0 6px;font-size:22px;line-height:1.3}
.customer-toolbar-left p,.sla-toolbar-left p,.config-menu-subtitle,.customer-list-head p,.sla-list-head p,.dashboard-hero p,.card-head p,.summary-label,.kpi-label,.kpi-note,.legend-item small,.column-label,.column-value{margin:0;color:#64748b}
.contract-toolbar-left p,.contract-list-head p,.contract-sub,.customer-subtext,.customer-empty,.contract-empty,.sla-empty,.contract-required-note,.form-hint,.customer-live-search-empty{color:#6b7280}
.customer-filter-card,.customer-list-card,.sla-filter-card,.sla-list-card{background:var(--panel);border:1px solid rgba(255,255,255,.68);border-radius:22px;box-shadow:var(--shadow);backdrop-filter:blur(14px)}.customer-list-card,.sla-list-card,.contract-list-card,.config-card{overflow:hidden}
.contract-filter-card,.contract-list-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 10px 28px rgba(15,23,42,.04)}.contract-filter-card{padding:18px;overflow:hidden;transition:max-height .25s ease,opacity .2s ease,padding .2s ease,margin .2s ease,border .2s ease;max-height:520px;opacity:1}.contract-filter-card.is-collapsed{max-height:0;opacity:0;padding-top:0;padding-bottom:0;margin:0;border-width:0;box-shadow:none}.contract-filter-card.is-collapsed .contract-filter-grid{pointer-events:none}
.customer-filter-card,.sla-filter-card{padding:18px}.sla-filter-card{overflow-x:auto}
.customer-filter-grid{display:grid;grid-template-columns:minmax(0,1.6fr) 220px 190px auto;gap:14px;align-items:end}.contract-filter-grid{display:grid;grid-template-columns:1.6fr 220px 280px 180px auto;gap:14px;align-items:end}.sla-filter-grid{display:flex;align-items:end;gap:14px;flex-wrap:nowrap;min-width:1120px}
.customer-filter-grid .form-field,.contract-filter-grid .form-field,.contract-form-grid .form-field,.sla-filter-grid .form-field{margin:0}
.sla-filter-grid .sla-search-field{flex:1 0 380px;min-width:380px}.sla-filter-grid .sla-priority-field{width:220px}.sla-filter-grid .sla-status-field{width:200px}.sla-filter-grid .sla-perpage-field{width:170px}.sla-filter-actions{flex:0 0 auto;flex-wrap:nowrap;white-space:nowrap}
.customer-list-head,.sla-list-head{padding:20px 22px 16px;border-bottom:1px solid rgba(148,163,184,.14)}.contract-list-head{padding:20px 22px 14px;border-bottom:1px solid #eef2f7}
.customer-list-head h3,.sla-list-head h3,.card-head h3,.dashboard-hero h2{margin:0 0 4px}.contract-list-head h3{margin:0;font-size:18px}
.customer-table-wrap,.contract-table-wrap,.sla-table-wrap,.contract-files-table-wrap{overflow-x:auto}.contract-files-table-wrap{width:100%}
.customer-table,.contract-table,.sla-table{width:100%;border-collapse:separate;border-spacing:0}
.customer-table th,.sla-table th{background:rgba(15,23,42,.04);font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-soft);border-bottom:1px solid rgba(148,163,184,.14);white-space:nowrap}
.contract-table thead th{padding:14px 18px;text-align:left;font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:#6b7280;background:#f8fafc;border-bottom:1px solid #e5e7eb;white-space:nowrap}
.customer-table td,.sla-table td{border-bottom:1px solid rgba(148,163,184,.12);background:rgba(255,255,255,.72)}.contract-table tbody td{padding:18px;border-bottom:1px solid #f1f5f9;vertical-align:top}
.customer-table tbody tr:hover td,.sla-table tbody tr:hover td{background:rgba(248,250,252,.96)}.contract-table tbody tr:hover{background:#fafcff}
.customer-name-stack,.customer-contact-stack,.sla-name-stack,.sla-meta-stack,.contract-name{display:flex;flex-direction:column;gap:4px}
.customer-code,.sla-code{font-weight:800;color:var(--text)}.contract-title{font-weight:700;color:#111827}.contract-sub{font-size:13px}.customer-subtext,.sla-subtext{font-size:.92rem}
.customer-list-foot,.sla-list-foot,.contract-list-foot{padding:16px 22px 20px;align-items:center;gap:14px;flex-wrap:wrap}.contract-list-foot{gap:16px;background:#fff}
.customer-pagination,.sla-pagination,.contract-pagination{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.customer-pagination .btn[aria-current="page"],.sla-pagination .btn[aria-current="page"]{background:linear-gradient(90deg,var(--primary),var(--secondary));color:#fff;border-color:transparent;box-shadow:0 12px 22px rgba(37,99,235,.2);pointer-events:none}.contract-pagination .btn[aria-current="page"]{pointer-events:none;background:#111827;color:#fff;border-color:#111827}
.customer-empty,.sla-empty{padding:28px 22px;text-align:center}.contract-empty{padding:34px 22px;text-align:center}
.contract-badge{padding:7px 10px;font-size:12px;line-height:1}.contract-badge.status-draft{background:#f3f4f6;color:#6b7280}.contract-badge.status-active{background:#ecfdf3;color:#027a48}.contract-badge.status-expired{background:#fee2e2;color:#b91c1c}.contract-badge.status-closed{background:#e2e8f0;color:#334155}.contract-badge.status-renewed{background:#e0f2fe;color:#075985}
#selected_sla_ids{min-height:220px}.text-danger{color:#dc2626;font-weight:700}.contract-cell-plain{white-space:normal;line-height:1.45}.contract-actions-icons,.config-notif-page .contract-actions-icons{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;justify-content:flex-start}.contract-file-open-btn{display:inline-flex;align-items:center;gap:6px}.contract-files-table td,.contract-files-table th{vertical-align:middle}.contract-empty-cell{text-align:center;color:#6b7280}.contract-table td[data-label="Aksi"] .inline-form,.config-notif-page .inline-form{margin:0}
.dashboard-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:18px}.card-section,.dashboard-card{padding:18px}.dashboard-filter{min-width:180px}.compact-field label{display:block;margin-bottom:6px;font-size:12px;color:#475569}.compact-field select{width:100%}
.kpi-card{padding:16px;display:grid;gap:8px}.kpi-value{font-size:28px;line-height:1.1;color:#0f172a}.kpi-value.small{font-size:20px}.kpi-card.warning{border-color:#fcd34d}.kpi-card.success{border-color:#86efac}.kpi-card.muted{border-color:#cbd5e1}
.dashboard-grid{display:grid;gap:18px}.dashboard-grid.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}.dashboard-grid.one-col{grid-template-columns:minmax(0,1fr)}
.card-head{margin-bottom:16px}.empty-state{padding:20px;border:1px dashed #cbd5e1;border-radius:12px;color:#64748b;text-align:center;background:#f8fafc}
.donut-layout{display:grid;grid-template-columns:220px 1fr;gap:18px;align-items:center}.donut-layout.stacked{display:flex;flex-direction:column;align-items:center;gap:18px}.donut-layout.stacked .legend-list{width:100%}
.donut-chart{width:220px;height:220px;border-radius:999px;position:relative}.donut-hole{position:absolute;inset:50%;transform:translate(-50%,-50%);width:112px;height:112px;border-radius:999px;background:#fff;display:grid;place-items:center;text-align:center;box-shadow:inset 0 0 0 1px #e5e7eb}.donut-hole strong{display:block;font-size:24px;color:#0f172a}.donut-hole span,.legend-item small,.column-label,.column-value{font-size:12px}
.legend-list,.bar-list{display:grid}.legend-list{gap:10px}.bar-list{gap:12px}.legend-item{display:flex;gap:10px;align-items:center}.legend-dot{width:12px;height:12px;border-radius:999px;flex:0 0 12px}
.bar-meta{display:flex;justify-content:space-between;gap:12px;margin-bottom:6px;font-size:13px}.bar-track{width:100%;height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden}.bar-track span{display:block;height:100%;background:linear-gradient(90deg,#2563eb,#0ea5e9);border-radius:999px}
.column-chart,.dashboard-page .dashboard-card .column-chart{display:flex!important;gap:14px!important;align-items:flex-end!important;min-height:220px!important;padding-top:10px!important}.column-chart{grid-template-columns:repeat(12,minmax(0,1fr))}.column-chart.compact,.dashboard-page .dashboard-card .column-chart.compact{min-height:210px!important}
.column-item,.dashboard-page .dashboard-card .column-item{display:flex!important;gap:10px!important;align-items:center!important;justify-content:flex-end!important;justify-items:center;flex:1 1 0!important;flex-direction:column!important;min-width:0!important}
.column-value{font-size:13px;font-weight:700;color:#475569;line-height:1;min-height:18px}.column-label{font-size:12px;font-weight:600;line-height:1}
.column-bar,.dashboard-page .dashboard-card .column-bar{position:relative!important;display:block!important;width:44px!important;height:145px!important;min-height:145px!important;padding:0!important;background:#f1f5f9!important;border:1px solid #cbd5e1!important;border-radius:16px!important;overflow:hidden!important}
.column-bar{display:flex;align-items:end;justify-content:center}.column-bar span,.dashboard-page .dashboard-card .column-bar>span{position:absolute!important;left:0!important;right:0!important;bottom:0!important;top:auto!important;display:block!important;width:100%!important;height:0;min-height:0!important;border-radius:0!important;background:linear-gradient(180deg,#60a5fa 0%,#2563eb 100%)!important;transition:height .25s ease;z-index:1!important}
.column-bar.danger span,.dashboard-page .dashboard-card .column-bar.danger>span{background:linear-gradient(180deg,#fda4af 0%,#dc2626 100%)!important}.column-bar>span[style*="height: 100%"],.dashboard-page .dashboard-card .column-bar>span[style*="height: 100%"]{border-radius:14px!important}
.dashboard-table{width:100%;border-collapse:collapse}.dashboard-table th,.dashboard-table td{padding:12px 10px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:top;font-size:13px}.dashboard-table th{font-size:12px;color:#64748b;background:#f8fafc}
.status-pill{padding:4px 10px;font-size:12px;font-weight:600}.status-pill.status-active{background:#dcfce7;color:#166534}.status-pill.status-draft{background:#e2e8f0;color:#334155}.status-pill.status-expired{background:#fee2e2;color:#991b1b}.status-pill.status-closed{background:#ede9fe;color:#5b21b6}
.config-card .card-section{padding:18px}.config-separator{margin:18px 0;border:0;border-top:1px solid #e5e7eb}.config-placeholder-help{margin-bottom:16px}.config-placeholder-list,.config-menu-action-picker,.config-menu-action-summary{display:flex;gap:8px;flex-wrap:wrap}.config-placeholder-list{margin-top:10px}.config-preview-box{border:1px solid #e5e7eb;border-radius:16px;background:#f8fafc;padding:14px}.config-preview-box h4{margin:0 0 10px;font-size:15px}.config-preview-box pre{margin:0;white-space:pre-wrap;word-break:break-word;font-family:inherit;color:#334155}
.forgot-password-modal .app-modal-body .form-grid{grid-template-columns:1fr}
.config-users-password-wrap{display:flex;gap:10px;align-items:center}.config-users-password-wrap input{flex:1}.config-users-generate-btn{white-space:nowrap}
.generate-password-modal .generated-password-box{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 14px;border:1px dashed #cbd5e1;border-radius:12px;background:#f8fafc}.generate-password-modal .generated-password-value{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:16px;font-weight:700;letter-spacing:.4px;color:#0f172a;word-break:break-all}
.password-change-card{max-width:620px;width:100%}.password-strength-panel{display:grid;gap:10px;padding:14px;border:1px solid rgba(148,163,184,.18);border-radius:16px;background:rgba(248,250,252,.92)}.password-strength-item{display:flex;align-items:center;gap:10px;color:var(--text-soft);font-weight:600;transition:color var(--transition)}.password-strength-dot{width:12px;height:12px;border-radius:999px;background:rgba(148,163,184,.38);flex:0 0 12px;transition:background var(--transition),transform var(--transition)}.password-strength-item.is-valid{color:var(--success)}.password-strength-item.is-valid .password-strength-dot{background:var(--success);transform:scale(1.05)}
.config-menu-action-row{gap:8px;flex-wrap:nowrap}.config-menu-action-stack,.config-menu-role-card,.config-menu-role-head{display:flex;flex-direction:column}.config-menu-action-stack{gap:6px;align-items:flex-start}.config-menu-role-card{display:grid;gap:14px}.config-menu-role-head{display:grid;gap:12px}.config-menu-visibility-check{margin:0}
.config-menu-action-chip{position:relative;display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;border:1px solid rgba(148,163,184,.18);background:rgba(248,250,252,.95);cursor:pointer;transition:border-color var(--transition),background var(--transition),transform var(--transition),box-shadow var(--transition)}.config-menu-action-chip:hover{transform:translateY(-1px);border-color:rgba(37,99,235,.3)}.config-menu-action-chip input{width:18px;height:18px;margin:0;flex:0 0 18px}.config-menu-action-icon{width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(37,99,235,.08);font-size:.95rem}.config-menu-action-text{font-weight:700;letter-spacing:.02em}.config-menu-action-chip:has(input:checked){border-color:rgba(37,99,235,.35);background:rgba(239,246,255,.98);box-shadow:0 10px 24px rgba(37,99,235,.12)}
.app-confirm-body{display:flex;gap:16px;align-items:flex-start;margin-bottom:18px}.app-confirm-icon{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 52px;font-size:1.35rem;font-weight:800;color:#b91c1c;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.18)}.app-confirm-content{flex:1;min-width:0}.app-confirm-message{margin:0;color:var(--text);line-height:1.6}.app-confirm-actions{justify-content:flex-end}
.contract-page .form-field>label{ text-transform:uppercase;letter-spacing:.04em}
.config-gdrive-page .gdrive-toggle-field.is-hidden,.is-hidden{display:none!important}.config-gdrive-page .gdrive-config-form{align-items:start}
.gdrive-test-result{margin-bottom:18px;padding:16px 18px;border-radius:18px;border:1px solid #e5e7eb;background:#f8fafc;display:grid;gap:12px}.gdrive-test-result.is-success{background:rgba(5,150,105,.08);border-color:rgba(5,150,105,.18)}.gdrive-test-result.is-error{background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.18)}.gdrive-test-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.gdrive-test-message{margin:0;color:var(--text);font-weight:600}.gdrive-test-item{padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.72);border:1px solid rgba(148,163,184,.14);word-break:break-word}.gdrive-test-item small{display:block;margin-bottom:6px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em}
.form-alert{margin-bottom:16px;padding:14px 16px;border-radius:12px;border:1px solid #fecaca;background:#fef2f2;color:#991b1b}.form-alert-title{font-weight:700;margin-bottom:8px}.form-alert-list{margin:0;padding-left:18px}
.contract-required-note{margin-bottom:14px;font-size:13px}
.contract-doc-toggle,.app-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer}.contract-doc-toggle input[type="checkbox"]{width:18px;height:18px;margin:0}.contract-doc-toggle span,.app-switch-text{font-weight:700}.contract-doc-toggle span{letter-spacing:.02em}
#contract-document-section{margin-top:6px;padding:14px;border:1px solid #e5e7eb;border-radius:12px;background:#fafafa}.form-hint{display:block;margin-top:6px;font-size:12px}
.app-switch{user-select:none}.app-switch input{position:absolute;opacity:0;pointer-events:none}.app-switch-slider{position:relative;width:54px;height:30px;border-radius:999px;background:#d1d5db;transition:background .2s ease;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}.app-switch-slider::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:transform .2s ease;box-shadow:0 1px 3px rgba(0,0,0,.18)}.app-switch input:checked+.app-switch-slider{background:#ef4444}.app-switch input:checked+.app-switch-slider::after{transform:translateX(24px)}.app-switch-text{font-size:12px;letter-spacing:.04em}
.idle-timeout-widget-sidebar{max-width:100%}.idle-timeout-head{display:flex;align-items:center;gap:8px;min-width:0}.idle-timeout-dot{width:8px;height:8px;border-radius:999px;flex:0 0 8px;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.14);transition:background .22s ease,box-shadow .22s ease}.idle-timeout-label{font-size:10px;font-weight:800;letter-spacing:.12em;line-height:1.2;color:rgba(226,232,240,.7)}.idle-timeout-value{font-size:1.05rem;line-height:1;font-weight:800;letter-spacing:.03em;color:#f8fafc;font-variant-numeric:tabular-nums}.idle-timeout-note{font-size:11px;line-height:1.45;color:rgba(226,232,240,.6)}
.dashboard-export-btn{flex:0 0 auto;min-width:42px;width:42px;height:42px;border-radius:12px;font-size:18px;font-weight:700}.dashboard-export-btn:hover{transform:translateY(-1px)}
.contract-row-warning td{background:#fffbeb!important;border-top:1px solid #fde68a;border-bottom:1px solid #fde68a}.contract-row-warning{box-shadow:inset 4px 0 0 #f59e0b}.contract-row-expired td{background:#fef2f2!important;border-top:1px solid #fecaca;border-bottom:1px solid #fecaca}.contract-row-expired{box-shadow:inset 4px 0 0 #dc2626}.contract-row-renewed td{background:#f0f9ff!important;border-top:1px solid #bae6fd;border-bottom:1px solid #bae6fd}.contract-row-renewed{box-shadow:inset 4px 0 0 #0284c7}.contract-row-closed td{background:#f8fafc!important;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0}.contract-row-closed{box-shadow:inset 4px 0 0 #64748b}
.contract-summary-card{padding:16px;display:grid;gap:6px}.contract-summary-card.warning{border-color:#fcd34d}.contract-summary-card.danger{border-color:#fca5a5}.contract-summary-card.renewed{border-color:#7dd3fc}.contract-summary-card.muted{border-color:#cbd5e1}.summary-value{font-size:28px;line-height:1.1;color:#0f172a}
.contract-no-content small{display:block;opacity:.8;margin-top:2px}.contract-chain-link:hover{color:#1d4ed8;text-decoration:underline}.contract-no-cell{display:flex;align-items:flex-start;gap:8px;min-width:0}.contract-no-cell.is-child{padding-left:8px}.contract-no-content{display:flex;flex-direction:column;gap:6px;min-width:0;width:100%}.contract-no-main{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.contract-chain-indent{display:inline-flex;min-width:14px;opacity:.55;margin-top:2px;font-size:13px}.contract-chain-link{padding:0;border:0;background:transparent;color:#2563eb;font-size:12px;font-weight:700;line-height:1.3;cursor:pointer;text-align:left}.contract-chain-link-block{display:flex;width:100%;margin-top:2px}.contract-chain-link-label{display:block;width:100%;padding:8px 10px;border-radius:10px;background:rgba(37,99,235,.06);border:1px solid rgba(37,99,235,.12);color:#2563eb;font-size:12px;font-weight:700;line-height:1.35;transition:background .18s ease,border-color .18s ease,color .18s ease}.contract-chain-link:hover .contract-chain-link-label,.contract-no-cell[data-chain-row-clickable="true"]:hover .contract-chain-link-label{background:rgba(37,99,235,.1);border-color:rgba(37,99,235,.2);color:#1d4ed8}.contract-no-cell[data-chain-row-clickable="true"]{cursor:pointer}.contract-no-cell[data-chain-row-clickable="true"].is-expanded .contract-chain-link-label{background:rgba(37,99,235,.12);border-color:rgba(37,99,235,.22)}
.contract-row-root td{font-weight:600}.contract-row-child td{background:#f8fafc}.contract-row-warning.contract-row-root td{background:#fff7ed}.contract-row-warning.contract-row-child td{background:#fffbeb}.contract-row-expired.contract-row-root td{background:#fef2f2}.contract-row-expired.contract-row-child td{background:#fff5f5}.contract-row-renewed.contract-row-root td{background:#f5f3ff}.contract-row-renewed.contract-row-child td{background:#faf5ff}
.contract-row-child .contract-badge.status-active,.contract-table tbody tr.contract-row-child .contract-badge.status-active{background:#dcfce7!important;color:#166534!important}
.contract-row-child .contract-badge.status-expired,.contract-table tbody tr.contract-row-child .contract-badge.status-expired{background:#ffe4e6!important;color:#be123c!important}
.contract-row-child .contract-badge.status-closed,.contract-table tbody tr.contract-row-child .contract-badge.status-closed{background:#f3e8ff!important;color:#7e22ce!important}
.contract-row-child .contract-badge.status-draft,.contract-table tbody tr.contract-row-child .contract-badge.status-draft{background:#e2e8f0!important;color:#475569!important}
.contract-table tr[data-chain-row-toggle],.contract-table tbody tr[data-chain-row-toggle]{cursor:pointer}.contract-table tr[data-chain-row-toggle] td[data-label="Aksi"],.contract-table tr[data-chain-row-toggle] td[data-label="Dokumen"],.contract-table tbody tr[data-chain-row-toggle] td[data-label="Aksi"],.contract-table tbody tr[data-chain-row-toggle] td[data-label="Dokumen"]{cursor:default}
.contract-table tbody tr.contract-row-root>td{font-weight:600}.contract-table tbody tr.contract-row-child>td{font-weight:500;background:#e2e8f0!important}.contract-table tbody tr.contract-row-warning.contract-row-root>td{background:#fff7ed!important}.contract-table tbody tr.contract-row-expired.contract-row-root>td{background:#fef2f2!important}.contract-table tbody tr.contract-row-renewed.contract-row-root>td{background:#f5f3ff!important}.contract-table tbody tr.contract-row-warning.contract-row-child>td{background:#fcd34d!important}.contract-table tbody tr.contract-row-expired.contract-row-child>td{background:#fecdd3!important}.contract-table tbody tr.contract-row-renewed.contract-row-child>td{background:#e9d5ff!important}.contract-table tbody tr.contract-row-child:not(.contract-row-warning):not(.contract-row-expired):not(.contract-row-renewed)>td{background:#e2e8f0!important}.contract-table tbody tr.contract-row-root:hover>td{filter:brightness(.995)}.contract-table tbody tr.contract-row-child:hover>td{filter:brightness(.985)}
.dashboard-hierarchy-table .dashboard-upcoming-row.is-root>td{font-weight:600;cursor:pointer}.dashboard-hierarchy-table .dashboard-upcoming-row.is-child>td{background:#f8fafc}.dashboard-hierarchy-table .dashboard-upcoming-row.is-root.status-active>td{background:#ecfdf3}.dashboard-hierarchy-table .dashboard-upcoming-row.is-root.status-expired>td{background:#fef2f2}.dashboard-hierarchy-table .dashboard-upcoming-row.is-root.status-draft>td{background:#f8fafc}.dashboard-hierarchy-table .dashboard-upcoming-row.is-child.status-active>td{background:#f0fdf4}.dashboard-hierarchy-table .dashboard-upcoming-row.is-child.status-expired>td{background:#fff1f2}.dashboard-hierarchy-table .dashboard-upcoming-row.is-child.status-draft>td{background:#f8fafc}
.dashboard-contract-no{display:flex;align-items:flex-start;gap:8px}.dashboard-contract-no.is-child{padding-left:8px}.dashboard-chain-indent{display:inline-flex;min-width:14px;opacity:.6;margin-top:2px}.dashboard-chain-row td{text-align:center;background:#fff!important;border-bottom:1px solid #e5e7eb}.dashboard-chain-meta-cell{padding:0 10px 12px 10px!important}.dashboard-chain-toggle{min-width:min(100%,540px);min-height:38px;padding:10px 16px;border-radius:12px;border:1px dashed #cbd5e1;background:#f8fafc;color:#475569;font-weight:700;cursor:pointer}.dashboard-chain-toggle[aria-expanded="true"]{background:#eff6ff;color:#1d4ed8;border-color:#93c5fd}
.locale-switcher{display:grid;gap:6px}.locale-switcher-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.locale-switcher-control{display:flex;align-items:center}.locale-switcher-select{min-width:96px;height:42px;padding:10px 12px;border-radius:12px;font-weight:700;cursor:pointer}.locale-switcher-sidebar{margin-top:16px;gap:8px}.locale-switcher-sidebar .locale-switcher-label{color:rgba(226,232,240,.66);font-size:10px;letter-spacing:.12em}.locale-switcher-sidebar .locale-switcher-select{background:rgba(255,255,255,.08);color:#f8fafc;border:1px solid rgba(148,163,184,.2);border-radius:14px;min-height:44px}.locale-switcher-sidebar .locale-switcher-select:focus{border-color:rgba(96,165,250,.55);box-shadow:0 0 0 4px rgba(37,99,235,.16)}.locale-switcher-guest{min-width:110px;align-self:center}.locale-switcher-guest .locale-switcher-label{color:var(--text-soft)}.locale-switcher-guest .locale-switcher-select{background:rgba(255,255,255,.96);color:var(--text);border:1px solid var(--border)}
.customer-live-search{position:relative;width:100%}.customer-live-search-input{width:100%}.customer-live-search-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:50;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 18px 40px rgba(15,23,42,.12);overflow:hidden}.customer-live-search-list{max-height:280px;overflow-y:auto;padding:8px}.customer-live-search-option{width:100%;border:0;background:transparent;text-align:left;padding:12px 14px;border-radius:12px;cursor:pointer;color:#111827;transition:background .18s ease,transform .18s ease}.customer-live-search-option:hover,.customer-live-search-option.is-active{background:#eff6ff;color:#1d4ed8}.customer-live-search-empty{padding:14px 16px;color:#6b7280;font-size:13px;border-top:1px solid #eef2f7}.customer-live-search-dropdown.is-hidden,.customer-live-search-empty.is-hidden{display:none!important}
.contract-chain-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;line-height:1;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .2s ease}.contract-chain-chip:hover{background:#dbeafe;border-color:#93c5fd;transform:translateY(-1px)}.contract-chain-chip-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#1d4ed8;color:#fff;font-size:11px;font-weight:800}.contract-chain-chip-text{letter-spacing:.04em}.contract-chain-chip-caret{font-size:11px;transition:transform .2s ease}.contract-chain-chip[aria-expanded="true"] .contract-chain-chip-caret{transform:rotate(180deg)}
@keyframes idleTimeoutPulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-1px)}}
@media (max-width:1200px){:root{--sidebar-width:300px}}
@media (max-width:1180px){.grid-two{grid-template-columns:1fr}.table-wrap table{min-width:680px}}
@media (max-width:1100px){.dashboard-grid.two-col,.donut-layout,.dashboard-grid.three-col{grid-template-columns:1fr}}
@media (max-width:1080px){.contract-filter-grid{grid-template-columns:1fr 220px 1fr 180px auto}}
@media (max-width:980px){.layout-shell,body.menu-hidden .layout-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(84vw,300px);transform:translateX(-100%);visibility:visible;opacity:1;border-top-right-radius:24px;border-bottom-right-radius:24px}body.menu-open .sidebar{transform:translateX(0)}.backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:15}body.menu-open .backdrop{display:block}.config-notif-grid,.config-preview-grid{grid-template-columns:1fr}}
@media (max-width:920px){.contract-filter-grid,.contract-form-grid{grid-template-columns:1fr}.contract-list-foot,.contract-list-head,.contract-toolbar{align-items:stretch}}
@media (max-width:820px){.customer-table-wrap,.sla-table-wrap{overflow:visible;padding:16px}.contract-table-wrap{overflow:visible;padding:14px}.customer-table,.customer-table thead,.customer-table tbody,.customer-table th,.customer-table td,.customer-table tr,.contract-table,.contract-table thead,.contract-table tbody,.contract-table th,.contract-table td,.contract-table tr,.sla-table,.sla-table thead,.sla-table tbody,.sla-table th,.sla-table td,.sla-table tr{display:block;width:100%}.customer-table thead,.contract-table thead,.sla-table thead{display:none}.customer-table tbody,.contract-table tbody,.sla-table tbody{display:grid;gap:14px}.customer-table tr,.sla-table tr{border:1px solid rgba(148,163,184,.14);border-radius:18px;background:rgba(255,255,255,.9);box-shadow:0 12px 26px rgba(15,23,42,.06);overflow:hidden}.contract-table tr{border:1px solid #e5e7eb;border-radius:16px;background:#fff;box-shadow:0 8px 24px rgba(15,23,42,.06);overflow:hidden}.customer-table td,.sla-table td{display:flex;justify-content:space-between;gap:14px;padding:14px 16px;border:0;border-bottom:1px solid rgba(148,163,184,.1);background:transparent}.contract-table tbody td{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid #f1f5f9;background:transparent}.customer-table td:last-child,.contract-table tbody td:last-child,.sla-table td:last-child{border-bottom:0}.customer-table td::before,.sla-table td::before{content:attr(data-label);flex:0 0 110px;max-width:110px;font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft)}.contract-table tbody td::before{content:attr(data-label);min-width:100px;max-width:100px;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#6b7280}.customer-table td>*,.sla-table td>*{min-width:0}.customer-list-foot,.sla-list-foot{flex-direction:column;align-items:stretch}.customer-pagination,.sla-pagination{justify-content:flex-start}.app-modal-scroll{padding:18px 12px}.app-modal-body,.app-modal-header{padding-left:16px;padding-right:16px}.gdrive-test-grid{grid-template-columns:1fr}.config-menu-hero{align-items:stretch}.config-menu-role-dialog,.config-menu-modal-dialog{width:100%;max-width:100%}.config-menu-action-row{flex-wrap:wrap}}
@media (max-width:768px){.dashboard-hero{flex-direction:column;align-items:stretch}.column-chart{gap:6px}.dashboard-kpis{grid-template-columns:1fr}}
@media (max-width:760px){.site-header,.guest-header,.content-area,.guest-content,.site-footer,.guest-footer{padding-left:18px;padding-right:18px;margin-left:0;margin-right:0}.site-header,.guest-header,.site-footer,.guest-footer{flex-direction:column;align-items:stretch}.header-main{width:100%;align-items:flex-start;flex-direction:column}.user-panel{width:100%;min-width:0;text-align:left;padding:16px 0 0;border-left:0;border-top:1px solid rgba(148,163,184,.18)}.header-actions{justify-content:flex-start}.form-grid{grid-template-columns:1fr}.card{padding:18px}.table-wrap table{min-width:560px}.locale-switcher-guest{width:100%}.locale-switcher-guest .locale-switcher-select{width:100%}}
.brand-block{display:flex;flex-direction:column;gap:14px;padding:20px 18px 18px}
.brand-block .idle-timeout-widget{margin-top:2px}
.idle-timeout-head{align-items:center;gap:8px;min-height:20px}
.idle-timeout-dot{margin-top:0}
.idle-timeout-label{display:flex;align-items:center;min-height:20px}
.idle-timeout-value{line-height:1.1}
.idle-timeout-note{margin-top:2px}

.locale-switcher-sidebar{margin-top:12px}
.locale-switcher-sidebar .locale-switcher-control{width:100%}
.locale-switcher-sidebar .locale-switcher-select{width:100%;background:rgba(255,255,255,.12);color:#f8fafc;border:1px solid rgba(148,163,184,.24);appearance:auto;-webkit-appearance:menulist;-moz-appearance:menulist}
.locale-switcher-sidebar .locale-switcher-select:hover{background:rgba(255,255,255,.18);color:#fff}
.locale-switcher-sidebar .locale-switcher-select:focus{background:#fff;color:#0f172a;border-color:rgba(96,165,250,.55);box-shadow:0 0 0 4px rgba(37,99,235,.16)}
.locale-switcher-sidebar .locale-switcher-select option{background:#fff;color:#0f172a}
.locale-switcher-sidebar .locale-switcher-select option:checked{background:#e2e8f0;color:#0f172a}

@media (max-width:980px){
.sidebar{padding:24px 18px 20px}
.brand-block{padding:18px 16px 16px;gap:12px}
.locale-switcher-sidebar{margin-top:10px}
}

@media (max-width:760px){
.brand-block{padding:16px 14px 14px;border-radius:20px}
.idle-timeout-widget{padding:12px 13px;border-radius:16px}
.idle-timeout-label{font-size:9px}
.idle-timeout-value{font-size:1rem}
.idle-timeout-note{font-size:10px;line-height:1.4}
}

.liveconsole-page-shell{
    display:grid;
    gap:18px;
    min-width:0;
}

.liveconsole-section{
    min-width:0;
    overflow:hidden;
}

.liveconsole-console-box{
    width:100%;
    max-width:100%;
    min-width:0;
    overflow:auto;
    border-radius:16px;
    background:#0f172a;
    border:1px solid rgba(148,163,184,.18);
}

.liveconsole-console-pre{
    display:block;
    width:100%;
    max-width:100%;
    min-width:0;
    margin:0;
    padding:16px;
    color:#e2e8f0;
    background:#0f172a;
    box-sizing:border-box;
    white-space:pre;
    word-break:normal;
    overflow-wrap:normal;
    overflow-x:auto;
    overflow-y:auto;
    line-height:1.55;
    font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
    font-size:13px;
    tab-size:4;
}

.liveconsole-console-pre.is-main{
    min-height:420px;
    max-height:70vh;
}

.liveconsole-console-pre.is-modal{
    min-height:420px;
    max-height:70vh;
}

.liveconsole-runs-table{
    min-width:760px;
}

.liveconsole-actions{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.liveconsole-status-note{
    word-break:break-word;
    overflow-wrap:anywhere;
}

.liveconsole-refresh-meta{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    align-items:center;
    margin-top:10px;
    font-size:12px;
    color:#64748b;
}

.liveconsole-pin-pill{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:6px 10px;
    border-radius:999px;
    background:rgba(37,99,235,.1);
    color:#1d4ed8;
    font-weight:700;
    font-size:12px;
}

.liveconsole-info-banner{
    margin-bottom:12px;
}

#live-console-output,
#console-history-output{
    overscroll-behavior:contain;
}

@media (max-width: 820px){
    .liveconsole-runs-table{
        min-width:100%;
    }

    .liveconsole-console-pre{
        font-size:12px;
        padding:14px;
    }
}
/* Enhanced global confirmation modal tones */
#global-confirm-modal .app-confirm-dialog{width:min(520px,calc(100vw - 32px));border-radius:26px;box-shadow:0 32px 90px rgba(15,23,42,.30)}
#global-confirm-modal .app-modal-header{background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%)}
#global-confirm-modal .app-confirm-body{padding:2px 0 4px}
#global-confirm-modal .app-confirm-icon{box-shadow:inset 0 1px 0 rgba(255,255,255,.7),0 14px 30px rgba(15,23,42,.10)}
#global-confirm-modal.app-confirm-modal-tone-warning .app-confirm-icon{color:#c2410c;background:#fff7ed;border-color:#fed7aa}
#global-confirm-modal.app-confirm-modal-tone-danger .app-confirm-icon{color:#b91c1c;background:#fef2f2;border-color:#fecaca}
#global-confirm-modal.app-confirm-modal-tone-info .app-confirm-icon{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}
#global-confirm-modal .app-confirm-actions .btn{min-width:112px;justify-content:center}

/* Maintenance Contract: show/hide action column */
.contract-list-head-actions{display:flex;align-items:flex-start;justify-content:flex-end;gap:10px;flex:0 0 auto}
.contract-action-column-toggle{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.contract-action-column-toggle-icon{display:inline-flex;align-items:center;justify-content:center;min-width:18px}
.maintenance-contract-table.is-action-hidden th[data-contract-action-column="true"],.maintenance-contract-table.is-action-hidden td[data-contract-action-column="true"]{display:none!important}
@media (max-width:820px){.contract-list-head-actions{width:100%;justify-content:flex-start}.contract-action-column-toggle{width:100%;justify-content:center}.maintenance-contract-table.is-action-hidden td[data-contract-action-column="true"]{display:none!important}}
