/* PontoPro Digital — Sistema de Controle de Ponto * Estilos principais * Gerado em 23/03/2026 */ :root { --bg: #f5f6fa; --surface: #ffffff; --surface2: #f0f1f7; --border: #e4e6ef; --text: #1a1d2e; --text2: #6b7290; --text3: #9499b7; --primary: #2563eb; --primary-light: #eff4ff; --primary-dark: #1d4ed8; --success: #10b981; --success-light: #ecfdf5; --warning: #f59e0b; --warning-light: #fffbeb; --danger: #ef4444; --danger-light: #fef2f2; --info: #6366f1; --info-light: #eef2ff; --sidebar-w: 248px; --header-h: 60px; --radius: 12px; --radius-sm: 8px; --shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04); --shadow-md: 0 4px 16px rgba(0,0,0,.08); --transition: .2s cubic-bezier(.4,0,.2,1); } [data-theme="dark"] { --bg: #0f1117; --surface: #1a1d2e; --surface2: #252840; --border: #51587d; --text: #e8eaf6; --text2: #9499b7; --text3: #5c6180; --primary-light: #1e2a4a; --success-light: #0d2d22; --warning-light: #2d2410; --danger-light: #2d1515; --info-light: #1e1f3a; --shadow: 0 1px 3px rgba(0,0,0,.3); --shadow-md: 0 4px 16px rgba(0,0,0,.4); } *,*::before,*::after{box-sizing:border-box;margin:0;padding:0} html{font-size:14px;scroll-behavior:smooth} body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);line-height:1.5;transition:background var(--transition),color var(--transition);min-height:100vh;overflow-x:hidden} body:not(.page-leaving) .public-page{animation:publicPageEnter .18s ease} body.page-leaving.page-to-login .public-page{animation:publicPageExitToLogin .09s ease forwards} body.page-leaving.page-to-landing .public-page{animation:publicPageExitToLanding .09s ease forwards} body.page-enter-login .public-page{animation:publicPageEnterFromRight .14s ease} body.page-enter-landing .public-page{animation:publicPageEnterFromLeft .14s ease} .app-transition-overlay{position:fixed;top:0;right:0;bottom:0;left:var(--sidebar-w);display:flex;align-items:center;justify-content:center;padding:28px;background:rgba(245,246,250,.34);backdrop-filter:blur(6px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,visibility .18s ease,left var(--transition);z-index:1300} .app-transition-overlay.active{opacity:1;visibility:visible} .app-transition-card{display:flex;align-items:center;justify-content:center;width:108px;height:108px;border-radius:32px;background:rgba(255,255,255,.84);border:1px solid rgba(148,163,184,.24);box-shadow:0 24px 60px rgba(15,23,42,.14)} .app-transition-icon{width:58px;height:58px;border-radius:20px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;font-size:1.3rem;box-shadow:0 14px 34px rgba(37,99,235,.28);flex:0 0 auto;animation:appTransitionPulse 1s ease-in-out infinite} .app-transition-copy{display:none} [data-theme="dark"] .app-transition-overlay{background:rgba(8,11,18,.36)} [data-theme="dark"] .app-transition-card{background:rgba(26,29,46,.88);border-color:rgba(255,255,255,.22);box-shadow:0 26px 60px rgba(0,0,0,.42)} html.app-sidebar-collapsed .app-transition-overlay{left:88px} body.master-page .app-transition-overlay{left:280px} html.master-sidebar-collapsed body.master-page .app-transition-overlay{left:92px} @keyframes publicPageEnter{ from{opacity:0} to{opacity:1} } @keyframes appTransitionPulse{ 0%,100%{transform:scale(1);box-shadow:0 12px 28px rgba(37,99,235,.28)} 50%{transform:scale(1.04);box-shadow:0 16px 34px rgba(37,99,235,.38)} } @keyframes publicPageExitToLogin{ from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(-10px)} } @keyframes publicPageExitToLanding{ from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(10px)} } @keyframes publicPageEnterFromRight{ from{opacity:0;transform:translateX(10px)} to{opacity:1;transform:translateX(0)} } @keyframes publicPageEnterFromLeft{ from{opacity:0;transform:translateX(-10px)} to{opacity:1;transform:translateX(0)} } /* ── SCROLLBAR ── */ ::-webkit-scrollbar{width:5px;height:5px} ::-webkit-scrollbar-track{background:transparent} ::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px} /* ── LOGIN ── */ .login-wrap{display:flex;min-height:100vh;align-items:stretch;background:linear-gradient(180deg,#eff6ff 0%,#f8fafc 100%);overflow:hidden;width:100vw} .public-page{width:100vw} html.has-session .public-page{display:none !important} html.has-session .login-wrap{display:none} .login-brand{flex:1;background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 45%,#0ea5e9 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6.25rem 3rem 3rem;position:relative;overflow:hidden;transition:flex-basis .38s ease,transform .38s ease,filter .38s ease} #landingPage .login-brand{flex:1 1 100%;width:100%} #landingPage{display:block;overflow-y:auto;overflow-x:hidden;background:linear-gradient(180deg,#f4f8ff 0%,#edf3ff 42%,#ffffff 100%)} .login-form-side{display:flex;flex:0 0 440px;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);border-left:1px solid rgba(148,163,184,.18);transform:translateX(108%);opacity:0;pointer-events:none;transition:transform .38s ease,opacity .24s ease} .login-screen .login-form-side{transform:none;opacity:1;pointer-events:auto} .login-screen .login-brand{flex:.82;transform:none;filter:none} .login-screen{align-items:stretch} .login-screen .login-form-side{align-self:stretch;justify-content:flex-start;padding-top:7.5rem} .login-route .login-screen .login-form-side{justify-content:center;padding-top:2rem} .login-route .login-screen .login-brand{flex:.88} .login-wrap.show-access .login-form-side{transform:translateX(0);opacity:1;pointer-events:auto} .login-wrap.show-access .login-brand{flex:.78;transform:translateX(-14px);filter:saturate(.94)} .login-brand::before{content:'';position:absolute;top:-30%;right:-20%;width:500px;height:500px;background:rgba(255,255,255,.04);border-radius:50%} .login-brand::after{content:'';position:absolute;bottom:-20%;left:-10%;width:350px;height:350px;background:rgba(255,255,255,.04);border-radius:50%} .brand-content{position:relative;z-index:1;color:#fff;width:100%;max-width:980px} .landing-hero{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:2rem;align-items:center;transition:transform .38s ease,opacity .28s ease} .login-wrap.show-access .landing-hero{transform:translateX(-10px) scale(.985)} .brand-logo{font-size:2rem;font-weight:600;letter-spacing:-1px;margin-bottom:.5rem} .brand-logo-large{font-size:3.1rem;margin-bottom:1rem} .brand-logo span{color:#7dd3fc} .brand-tagline{font-size:1.02rem;opacity:.9;margin-bottom:1.4rem;max-width:560px;line-height:1.6} .brand-stats{display:flex;gap:2rem;margin-top:2rem} .bstat{text-align:center;color:#fff} .bstat-n{font-size:2rem;font-weight:600;display:block} .bstat-l{font-size:.8rem;opacity:.7} .landing-topbar{position:absolute;top:1.35rem;left:2rem;right:2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;width:auto;z-index:2} .landing-toplinks{display:flex;gap:.95rem;flex-wrap:wrap;align-items:center;justify-content:flex-end;margin-left:auto} .landing-top-btn{font-size:.9rem;font-weight:800;padding:.86rem 1.45rem;border-radius:14px;min-width:160px} .landing-top-btn-light{background:transparent;color:#ffffff;border:1px solid rgba(255,255,255,.55)} .landing-top-btn-light:hover{background:rgba(255,255,255,.08);border-color:#ffffff;color:#ffffff} .landing-top-btn-primary{padding-inline:1.6rem;background:#ffffff;color:#1d4ed8;border:1px solid #ffffff} .landing-top-btn-primary:hover{background:#eff6ff;border-color:#eff6ff;color:#1e40af} [data-theme="dark"] .landing-top-btn-light{color:#f8fbff;border-color:rgba(191,219,254,.85);background:rgba(15,23,42,.18)} [data-theme="dark"] .landing-top-btn-light:hover{color:#ffffff;border-color:#ffffff;background:rgba(255,255,255,.1)} .landing-copy{min-width:0} .landing-pill{display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .8rem;border-radius:999px;background:rgba(255,255,255,.12);backdrop-filter:blur(10px);font-size:.78rem;font-weight:600;margin-bottom:1rem} .landing-feature-list{display:flex;flex-direction:column;gap:.65rem;margin-top:1.15rem} .landing-feature-list div{font-size:.88rem;opacity:.94;display:flex;align-items:center;gap:.55rem} .landing-feature-list div::before{content:'✦';color:#7dd3fc} .landing-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.35rem} .landing-cta{min-width:210px} .landing-cta.alt{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22);color:#fff} .landing-cta.alt:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.34)} .landing-showcase{position:relative;height:520px;display:flex;align-items:center;justify-content:center} .landing-glow{position:absolute;inset:auto 24px 20px auto;width:220px;height:220px;border-radius:50%;background:rgba(125,211,252,.18);filter:blur(18px)} .landing-shell{width:100%} .landing-surface{position:relative;max-width:1280px;margin:0 auto;padding:0 24px 48px} .landing-topbar-shell{position:sticky;top:0;left:auto;right:auto;width:calc(100% - 48px);margin:18px auto 0;background:rgba(7,16,39,.86);backdrop-filter:blur(18px);border:1px solid rgba(148,163,184,.16);border-radius:24px;padding:18px 24px;box-shadow:0 20px 50px rgba(15,23,42,.16)} .landing-topbar-shell .brand-logo{color:#e8f0ff} .landing-topbar-shell .brand-logo span{color:#7dd3fc} .landing-inline-link{text-decoration:none;color:#dbeafe;font-size:.86rem;font-weight:700;padding:.2rem 0} .landing-inline-link:hover{color:#ffffff} .landing-section{padding:34px 0} .landing-hero-v2{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(420px,.92fr);gap:34px;align-items:center;padding-top:48px} .landing-hero-copy{min-width:0;padding:22px 0 12px} .landing-headline{font-size:4.25rem;line-height:.94;letter-spacing:-.06em;color:#071027;max-width:760px;margin-bottom:20px;font-weight:700} .landing-subheadline{font-size:1.08rem;line-height:1.75;color:#52607a;max-width:640px} .landing-pill-strong{background:#e0ebff;color:#1d4ed8} .landing-pill-light{background:#eef4ff;color:#2563eb} .landing-proof{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px} .landing-proof span{display:inline-flex;align-items:center;gap:.45rem;font-size:.86rem;font-weight:700;color:#15346d;background:#ffffff;border:1px solid #d8e2f2;border-radius:999px;padding:.55rem .85rem} .landing-cta-main{min-width:220px} .landing-actions-end{justify-content:flex-end} .landing-hero-stage{position:relative;min-height:590px;display:flex;align-items:center;justify-content:center} .landing-stage-card{position:absolute;background:rgba(255,255,255,.9);border:1px solid rgba(203,213,225,.7);border-radius:28px;box-shadow:0 26px 70px rgba(15,23,42,.12);backdrop-filter:blur(12px)} .landing-stage-card-main{width:min(100%,560px);padding:22px;right:14px;top:24px;background:linear-gradient(180deg,#0f172a 0%,#132348 100%);color:#fff;border-color:rgba(125,211,252,.18)} .landing-stage-card-float{width:290px;left:0;bottom:38px;padding:16px;transform:rotate(-4deg)} .landing-stage-card-side{width:260px;right:0;bottom:26px;padding:16px;transform:rotate(6deg)} .landing-stage-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.85rem;margin-bottom:1rem} .landing-stage-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px} .landing-stage-metric{background:rgba(255,255,255,.08);border:1px solid rgba(148,163,184,.12);border-radius:18px;padding:14px} .landing-stage-metric span{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:.3rem} .landing-stage-metric strong{display:block;font-size:1.7rem;line-height:1;color:#fff} .landing-stage-metric small{display:block;margin-top:.35rem;font-size:.74rem;color:#cbd5e1} .landing-stage-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px} .landing-stage-strip>div{background:rgba(255,255,255,.06);border-radius:16px;padding:12px} .landing-stage-label{display:block;font-size:.72rem;color:#93c5fd;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem} .landing-trust-band{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:12px 0 18px} .landing-trust-item{background:#ffffff;border:1px solid #e1e9f6;border-radius:20px;padding:16px 18px;box-shadow:0 8px 28px rgba(37,99,235,.06)} .landing-trust-item strong{display:block;font-size:1rem;color:#0f172a;margin-bottom:.2rem} .landing-trust-item span{font-size:.84rem;color:#667085} .landing-section-head{max-width:740px;margin-bottom:22px} .landing-section-head h2{font-size:2.25rem;line-height:1.08;color:#071027;letter-spacing:-.04em;margin:12px 0} .landing-section-head p{font-size:1rem;line-height:1.7;color:#667085} .landing-module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px} .landing-module-card{background:#ffffff;border:1px solid #e3ebf8;border-radius:24px;padding:22px;box-shadow:0 14px 42px rgba(15,23,42,.06)} .landing-module-card i{width:46px;height:46px;border-radius:14px;background:#eef4ff;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:16px} .landing-module-card h3{font-size:1.1rem;color:#0f172a;margin-bottom:.55rem} .landing-module-card p{font-size:.92rem;line-height:1.7;color:#667085} .landing-role-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px} .landing-role-card{background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);border:1px solid #dde7f6;border-radius:24px;padding:24px} .landing-role-tag{display:inline-flex;padding:.34rem .7rem;border-radius:999px;background:#eff4ff;color:#2563eb;font-size:.74rem;font-weight:800;margin-bottom:14px} .landing-role-card h3{font-size:1.2rem;color:#0f172a;margin-bottom:.6rem} .landing-role-card p{font-size:.92rem;color:#667085;line-height:1.7;margin-bottom:1rem} .landing-role-card ul{display:flex;flex-direction:column;gap:.65rem;list-style:none} .landing-role-card li{position:relative;padding-left:1.15rem;color:#334155;font-size:.88rem} .landing-role-card li::before{content:'';position:absolute;left:0;top:.45rem;width:7px;height:7px;border-radius:50%;background:#38bdf8} .landing-compliance-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px} .landing-compliance-card{background:#0f172a;color:#e2e8f0;border-radius:24px;padding:24px;border:1px solid rgba(125,211,252,.16)} .landing-compliance-card h3{font-size:1.08rem;color:#f8fafc;margin-bottom:.55rem} .landing-compliance-card p{font-size:.9rem;line-height:1.7;color:#cbd5e1} .landing-faq-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px} .landing-faq-card{background:#ffffff;border:1px solid #e3ebf8;border-radius:22px;padding:22px} .landing-faq-card h3{font-size:1.02rem;color:#0f172a;margin-bottom:.5rem} .landing-faq-card p{font-size:.9rem;color:#667085;line-height:1.7} .landing-cta-section{padding-bottom:12px} .landing-cta-panel{background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 58%,#38bdf8 100%);border-radius:32px;padding:30px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:22px;align-items:end;color:#fff;box-shadow:0 24px 80px rgba(15,23,42,.22)} .landing-cta-panel h2{font-size:2.2rem;line-height:1.08;letter-spacing:-.04em;margin:14px 0 10px} .landing-cta-panel p{max-width:680px;color:rgba(255,255,255,.86);line-height:1.75} .landing-topbar-shell .landing-top-btn-light{color:#f8fbff;border-color:rgba(191,219,254,.85);background:rgba(15,23,42,.18)} .landing-topbar-shell .landing-top-btn-light:hover{color:#ffffff;border-color:#ffffff;background:rgba(255,255,255,.1)} .phone-mock{position:absolute;border-radius:34px;background:#0f172a;padding:12px;box-shadow:0 20px 60px rgba(15,23,42,.35);border:1px solid rgba(255,255,255,.12)} .phone-main{width:280px;right:22px;top:22px;transform:rotate(5deg)} .phone-float{width:230px;left:10px;bottom:36px;transform:rotate(-8deg)} .phone-notch{width:110px;height:18px;border-radius:0 0 14px 14px;background:#0b1120;margin:0 auto 10px} .phone-screen{background:linear-gradient(180deg,#f8fbff 0%,#eef5ff 100%);border-radius:24px;padding:16px;min-height:470px;color:#0f172a} .phone-screen-alt{min-height:330px} .screen-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem} .screen-header.compact{margin-bottom:.75rem} .screen-eyebrow{font-size:.72rem;color:#2563eb;font-weight:700;text-transform:uppercase;letter-spacing:.05em} .screen-title{font-size:1.05rem;font-weight:800;color:#0f172a} .screen-chip{background:#dcfce7;color:#166534;border-radius:999px;padding:.25rem .55rem;font-size:.72rem;font-weight:700} .screen-kpis{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:.9rem} .screen-kpis span{padding:.25rem .55rem;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:.7rem;font-weight:700} .screen-photo-card,.screen-request-card{margin-top:1rem;background:#fff;border-radius:18px;padding:.9rem;box-shadow:0 8px 24px rgba(15,23,42,.08)} .screen-photo-card{display:flex;align-items:center;gap:.8rem} .screen-photo-circle{width:48px;height:48px;border-radius:16px;background:#dbeafe;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:1rem} .screen-timeline{display:flex;flex-direction:column;gap:.55rem;margin-top:1rem} .screen-line{display:flex;justify-content:space-between;align-items:center;padding:.7rem .8rem;background:rgba(255,255,255,.9);border:1px solid rgba(191,219,254,.5);border-radius:14px;font-size:.78rem;box-shadow:0 8px 20px rgba(15,23,42,.08)} .screen-line span{color:#334155;font-weight:600} .screen-line strong{font-family:'DM Mono',monospace;color:#0f172a} .screen-request-status{display:inline-flex;padding:.2rem .55rem;border-radius:999px;background:#dcfce7;color:#166534;font-size:.68rem;font-weight:700;margin-bottom:.55rem} .screen-request-status.pending{background:#fef3c7;color:#92400e} .screen-request-card.soft{background:#f8fafc} .brand-dots{display:flex;gap:6px;margin-top:3rem} .brand-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3)} .brand-dots span.active{background:#fff;width:24px;border-radius:4px} .login-form-wrap{width:100%;max-width:380px} .login-form-wrap h2{font-size:1.6rem;font-weight:600;margin-bottom:.4rem;color:var(--text)} .login-form-wrap p{color:var(--text2);margin-bottom:2rem;font-size:.9rem} .login-access-head{display:flex;justify-content:flex-start;margin-bottom:.75rem} .login-screen .login-form-wrap{max-width:420px} .login-screen #loginAccess{display:flex;flex-direction:column;justify-content:flex-start;min-height:auto;width:100%} .login-route .login-screen #loginAccess{justify-content:center;min-height:100%} .login-wrap.show-access .login-form-wrap{animation:loginPanelIn .42s ease} @keyframes loginPanelIn{ from{opacity:0;transform:translateX(22px)} to{opacity:1;transform:translateX(0)} } .login-marketing-card{background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);border:1px solid var(--border);border-radius:22px;padding:1rem 1rem 1.1rem;margin-bottom:1.25rem;box-shadow:var(--shadow-sm)} .login-marketing-badge{display:inline-flex;padding:.3rem .65rem;border-radius:999px;background:var(--primary-light);color:var(--primary);font-size:.75rem;font-weight:700;margin-bottom:.65rem} .login-marketing-points{display:flex;flex-direction:column;gap:.45rem;margin-top:.9rem} .login-marketing-points span{font-size:.8rem;color:var(--text2);display:flex;align-items:center;gap:.45rem} .login-marketing-points i{color:var(--success)} .form-group{margin-bottom:1.2rem} .form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text2);margin-bottom:.4rem} .form-control{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-family:inherit;font-size:.9rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none} .form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.12)} .input-icon-wrap{position:relative} .input-icon-wrap .form-control{padding-left:2.4rem} .input-icon-wrap .input-icon{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);color:var(--text3);font-size:.85rem} .input-icon-wrap .input-toggle{position:absolute;right:.8rem;top:50%;transform:translateY(-50%);color:var(--text3);cursor:pointer;font-size:.85rem;background:none;border:none;color:var(--text3)} .form-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem} .form-check{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text2);cursor:pointer} .form-check input{accent-color:var(--primary)} .legal-consent-check{align-items:flex-start;gap:.65rem;margin:-.35rem 0 1rem;color:var(--text2);font-size:.82rem;line-height:1.55} .legal-consent-check input{margin-top:.2rem;flex:0 0 auto} .legal-consent-check span{display:block} .legal-consent-check .link{font-size:inherit;font-weight:600} .link{color:var(--primary);text-decoration:none;font-size:.85rem} .link:hover{text-decoration:underline} .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.2rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all var(--transition);white-space:nowrap} .btn-primary{background:var(--primary);color:#fff} .btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.35)} .btn-primary:active{transform:translateY(0)} .btn-full{width:100%} .btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)} .btn-outline:hover{background:var(--surface2);border-color:var(--text3)} .btn-sm{padding:.4rem .8rem;font-size:.8rem} .btn-danger{background:var(--danger);color:#fff} .btn-danger:hover{background:#dc2626} .btn-success{background:var(--success);color:#fff} .btn-success:hover{background:#059669} .btn-ghost{background:transparent;color:var(--text2);border:none} .btn-ghost:hover{background:var(--surface2);color:var(--text)} .divider{display:flex;align-items:center;gap:1rem;margin:1.2rem 0;color:var(--text3);font-size:.8rem} .divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)} .social-btns{display:flex;gap:.8rem} .onboarding-trigger{margin-top:1rem} .btn-social{flex:1;background:var(--bg);border:1.5px solid var(--border);color:var(--text);font-size:.82rem} .btn-social:hover{background:var(--surface2)} .btn-social img{width:16px;height:16px} body.login-route{background: radial-gradient(circle at 18% 18%, rgba(59,130,246,.14), transparent 26%), radial-gradient(circle at 82% 28%, rgba(14,165,233,.14), transparent 24%), linear-gradient(180deg,#eef4ff 0%,#f8fbff 100%); overflow-x:hidden} .login-route-shell{display:grid;grid-template-rows:auto minmax(0,1fr);min-height:100vh;width:100vw;max-width:100vw;background:transparent;overflow:hidden;padding:20px 24px 28px} .login-route-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;position:relative;z-index:3} .login-route-topbar .brand-logo{color:#0f172a;text-shadow:0 10px 30px rgba(255,255,255,.35)} .login-route-topbar .brand-logo span{color:#7dd3fc} .login-route-topbar .landing-inline-link{color:#475569} .login-route-topbar .landing-inline-link:hover{color:#0f172a} .login-route-topbar .landing-top-btn-light{color:#ffffff;border-color:var(--primary);background:var(--primary);box-shadow:0 14px 34px rgba(37,99,235,.24)} .login-route-topbar .landing-top-btn-light:hover{color:#ffffff;border-color:var(--primary-dark);background:var(--primary-dark)} .login-back-btn{font-weight:800} .login-route-stage{position:relative;min-height:calc(100vh - 92px);display:grid;grid-template-columns:minmax(260px,1fr) minmax(360px,420px) minmax(280px,1fr);align-items:center;gap:24px;padding:12px 4px 10px} .login-stage-visual{display:flex;align-items:center;justify-content:center;min-width:0} .login-stage-visual-left{justify-content:flex-end;padding-right:8px} .login-stage-visual-right{justify-content:flex-start;padding-left:8px} .login-device-stack{position:relative;width:min(100%,420px);height:620px} .login-device-stack-right{height:600px} .login-device{position:absolute;border-radius:34px;padding:14px;background:linear-gradient(180deg,rgba(255,255,255,.22) 0%,rgba(219,234,254,.16) 100%);border:1px solid rgba(191,219,254,.32);box-shadow:0 32px 80px rgba(15,23,42,.18);backdrop-filter:blur(16px)} .login-device-back{top:12px;left:0;width:260px;transform:rotate(-8deg)} .login-device-front{right:10px;bottom:38px;width:240px;transform:rotate(7deg)} .login-device-back-right{top:26px;left:18px;width:272px;transform:rotate(7deg)} .login-device-front-right{right:12px;bottom:46px;width:246px;transform:rotate(-7deg)} .login-device-screen{border-radius:26px;background:linear-gradient(180deg,#f8fbff 0%,#edf4ff 100%);padding:18px;color:#0f172a;box-shadow:inset 0 1px 0 rgba(255,255,255,.85)} .login-route-proofband{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.2rem} .login-route-proofband span{display:inline-flex;align-items:center;gap:.4rem;padding:.52rem .78rem;border-radius:999px;background:#ffffff;border:1px solid rgba(191,219,254,.72);font-size:.78rem;font-weight:700;color:#315fd8;box-shadow:0 10px 30px rgba(15,23,42,.06)} .login-insight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem} .login-insight-grid-compact{margin-top:.8rem} .login-insight-stat{padding:.95rem;border-radius:18px;background:#ffffff;border:1px solid rgba(191,219,254,.7)} .login-insight-stat span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#315fd8;margin-bottom:.28rem} .login-insight-stat strong{display:block;font-size:1.7rem;line-height:1;color:#0f172a} .login-insight-stat small{display:block;margin-top:.35rem;font-size:.74rem;color:#64748b} .login-route-access{display:flex;align-items:center;justify-content:center;padding:0} .login-stage-center{position:relative;z-index:2} .login-route-card{width:100%;max-width:420px;margin:auto;background:rgba(255,255,255,.96);border:1px solid rgba(191,219,254,.86);border-radius:30px;box-shadow:0 30px 90px rgba(37,99,235,.12);padding:1.7rem 1.45rem} .login-route-badge{display:inline-flex;padding:.32rem .68rem;border-radius:999px;background:var(--primary-light);color:var(--primary);font-size:.76rem;font-weight:700;margin-bottom:.8rem} .login-route-card h2{font-size:2rem;line-height:1.1;font-weight:700;color:#111827;margin-bottom:.5rem} .login-route-card p{font-size:.94rem;line-height:1.6;color:var(--text2);margin-bottom:1.15rem} .login-inline-points{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.3rem} .login-inline-points span{display:flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--text2)} .login-inline-points i{color:var(--success)} .login-route-note{display:flex;align-items:flex-start;gap:.7rem;padding:1rem;border-radius:16px;background:#f8fafc;border:1px solid #dbe5f1;color:#475569;font-size:.83rem;line-height:1.55;margin-top:1rem} .login-route-note i{color:var(--primary);margin-top:.1rem} .login-route-meta{margin-top:1.35rem;text-align:center;font-size:.75rem;color:var(--text3)} /* ── LEGAL PAGES ── */ body.legal-page{background: radial-gradient(circle at top left, rgba(59,130,246,.1), transparent 24%), linear-gradient(180deg,#eff5ff 0%,#f8fbff 100%); color:#0f172a} .legal-shell{min-height:100vh;padding:0 0 40px} .legal-topbar{position:sticky;top:0;z-index:5;width:min(1180px,calc(100% - 48px));margin:18px auto 0;background:rgba(7,16,39,.88);backdrop-filter:blur(18px);border:1px solid rgba(148,163,184,.16);border-radius:24px;padding:18px 24px;box-shadow:0 20px 50px rgba(15,23,42,.16);display:flex;align-items:center;justify-content:space-between;gap:1rem} .legal-topbar .brand-logo{color:#e8f0ff} .legal-topbar .brand-logo span{color:#7dd3fc} .legal-content{max-width:1080px;margin:28px auto 0;padding:0 24px} .legal-hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.7fr);gap:22px;align-items:start;margin-bottom:22px} .legal-hero-card,.legal-meta-card,.legal-section{background:rgba(255,255,255,.92);border:1px solid rgba(191,219,254,.82);border-radius:28px;box-shadow:0 20px 60px rgba(37,99,235,.08)} .legal-hero-card{padding:28px 30px} .legal-meta-card{padding:24px} .legal-kicker{display:inline-flex;align-items:center;padding:.38rem .8rem;border-radius:999px;background:#eef4ff;color:#315fd8;font-size:.74rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1rem} .legal-hero-card h1{font-size:2.4rem;line-height:1.04;letter-spacing:-.05em;margin-bottom:.9rem} .legal-hero-card p{font-size:1rem;line-height:1.8;color:#52617f} .legal-meta-list{display:grid;gap:12px} .legal-meta-item{padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid #d9e6fb} .legal-meta-item span{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:#6480c8;margin-bottom:.2rem;font-weight:700} .legal-meta-item strong{display:block;font-size:.95rem;color:#0f172a} .legal-grid{display:grid;gap:18px} .legal-section{padding:26px 28px} .legal-section h2{font-size:1.28rem;letter-spacing:-.03em;margin-bottom:.85rem} .legal-section p,.legal-section li{font-size:.95rem;line-height:1.8;color:#46536e} .legal-section ul{padding-left:1.15rem;display:grid;gap:.45rem} .legal-footer{max-width:1080px;margin:22px auto 0;padding:0 24px;font-size:.82rem;color:#64748b} .legal-modal-stack{display:grid;gap:16px} .legal-modal-section{padding:18px 20px;border-radius:20px;background:var(--bg);border:1px solid var(--border)} .legal-modal-section h3{font-size:1.02rem;letter-spacing:-.02em;color:var(--text);margin-bottom:.55rem} .legal-modal-section p,.legal-modal-section li{font-size:.9rem;line-height:1.75;color:var(--text2)} .legal-modal-section ul{padding-left:1.1rem;display:grid;gap:.4rem} @media (max-width: 900px){ .legal-topbar{width:calc(100% - 32px);padding:16px 18px;border-radius:20px} .legal-content,.legal-footer{padding:0 16px} .legal-hero{grid-template-columns:1fr} .legal-hero-card h1{font-size:2rem} } @media (max-width: 1240px){ .login-route-stage{grid-template-columns:minmax(240px,.92fr) minmax(340px,400px) minmax(240px,.92fr);gap:18px} .login-device-stack{transform:scale(.92)} } @media (max-width: 1100px){ .login-route-shell{padding:18px 18px 28px} .login-route-stage{grid-template-columns:1fr;gap:22px;min-height:auto} .login-stage-visual-left{order:2;justify-content:center;padding-right:0} .login-stage-center{order:1} .login-stage-visual-right{order:3;justify-content:center;padding-left:0} .login-route-access{width:100%;min-width:0} .login-route-card{max-width:560px} .login-device-stack{width:min(100%,440px);height:430px;transform:none} .login-device-back{top:8px;left:8px} .login-device-front{right:8px;bottom:8px} .login-device-back-right{top:8px;left:12px} .login-device-front-right{right:8px;bottom:10px} } @media (max-width: 680px){ .login-route-shell{padding:14px 14px 24px} .login-route-topbar{align-items:flex-start;flex-direction:column} .login-route-topbar .landing-toplinks{width:100%;flex-wrap:wrap} .login-stage-visual{display:none} .login-route-stage{grid-template-columns:1fr;gap:0} .login-route-card{max-width:none;padding:1.4rem 1.1rem;border-radius:26px} .login-route-card h2{font-size:1.8rem} } /* ── APP SHELL ── */ .app{display:none;height:100vh;overflow:hidden} .app.active{display:flex} html.has-session .app{display:flex;visibility:hidden} html.has-session .app.active{visibility:hidden} html.has-session.app-ready .app.active{visibility:visible} .sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#0f172a 0%,#111d3c 100%);border-right:1px solid rgba(148,163,184,.16);display:flex;flex-direction:column;flex-shrink:0;transition:width var(--transition),transform var(--transition);overflow:hidden;position:relative;z-index:100} .sidebar.collapsed{width:88px} .sidebar-top{padding:24px 20px 0;display:flex;flex-direction:column;gap:22px} .sidebar-brand{display:flex;flex-direction:column} .sidebar-brand-top{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-right:4px} .sidebar-logo{font-size:1.2rem;font-weight:600;color:#f8fbff;white-space:nowrap;overflow:hidden;letter-spacing:-.5px} .sidebar-logo span{color:#7dd3fc} .sidebar-brand-mini{display:none;width:42px;height:42px;border-radius:14px;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(148,163,184,.18);color:#e0f2fe} .sidebar-brand-mini i{font-size:1rem} .sidebar-brand-copy{font-size:.84rem;line-height:1.7;color:rgba(226,232,240,.72);margin-top:.8rem} .sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border:1px solid rgba(148,163,184,.22);background:rgba(255,255,255,.06);color:#dbeafe;cursor:pointer;padding:.45rem .65rem;border-radius:12px;transition:all var(--transition);margin-right:2px;line-height:1} .sidebar-toggle:hover{background:rgba(255,255,255,.12);color:#fff} .sidebar-nav{flex:1;overflow-y:auto;padding:18px 20px;display:flex;flex-direction:column;gap:8px} .sidebar-nav-card{background:rgba(255,255,255,.06);border:1px solid rgba(148,163,184,.12);border-radius:20px;margin-top:16px} .nav-section{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#93c5fd;padding:.4rem .35rem .2rem;white-space:nowrap;overflow:hidden} .nav-item{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;border-radius:14px;color:#dbeafe;cursor:pointer;transition:all var(--transition);white-space:nowrap;overflow:hidden;text-decoration:none;font-size:.95rem;font-weight:600;position:relative} .nav-item:hover{background:rgba(255,255,255,.08);color:#fff} .nav-item.active{background:rgba(255,255,255,.1);color:#ffffff;font-weight:700} .nav-item .nav-icon{font-size:.9rem;width:18px;text-align:center;flex-shrink:0} .nav-item .nav-badge{margin-left:auto;background:#ef4444;color:#fff;font-size:.65rem;padding:.1rem .35rem;border-radius:99px;font-weight:700;flex-shrink:0} .nav-item .nav-label{overflow:hidden;text-overflow:ellipsis} .sidebar.collapsed .nav-label,.sidebar.collapsed .nav-section,.sidebar.collapsed .nav-badge,.sidebar.collapsed .sidebar-brand-copy,.sidebar.collapsed .user-info,.sidebar.collapsed .user-mini .fa-chevron-right,.sidebar.collapsed .sidebar-logo{display:none} .sidebar.collapsed .sidebar-top{padding:18px 12px 0} .sidebar.collapsed .sidebar-brand-top{justify-content:center;padding-right:0} .sidebar.collapsed .sidebar-brand-mini{display:none} .sidebar.collapsed .sidebar-toggle{position:static;width:40px;height:40px;padding:0;justify-content:center;border-radius:14px;margin:2px auto 0} .sidebar.collapsed .sidebar-nav{padding:18px 10px;gap:10px} .sidebar.collapsed .sidebar-nav-card{padding:12px 8px;border-radius:22px} .sidebar.collapsed .nav-item{justify-content:center;align-items:center;width:48px;height:48px;padding:0;margin:0 auto;border-radius:16px} .sidebar.collapsed .nav-item .nav-icon{width:auto;font-size:1rem} .sidebar-bottom{padding:16px 20px 24px;position:relative} .user-mini{display:flex;align-items:center;gap:.85rem;padding:14px;border-radius:20px;cursor:pointer;transition:all var(--transition);background:rgba(255,255,255,.06);border:1px solid rgba(148,163,184,.12)} .user-mini:hover{background:rgba(255,255,255,.1)} .user-mini .avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#6366f1);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:600;flex-shrink:0} .user-mini .user-info{overflow:hidden} .user-mini .user-name{font-size:.92rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis} .user-mini .user-role{font-size:.76rem;color:#93c5fd;white-space:nowrap} .sidebar.collapsed .sidebar-bottom{padding:18px 10px 22px} .sidebar.collapsed .user-mini{justify-content:center;align-items:center;width:56px;min-height:56px;padding:0;margin:0 auto;border-radius:18px} .sidebar.collapsed .user-mini .avatar{margin:0} /* ── MAIN ── */ .main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)} .topbar{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;flex-shrink:0} .topbar-left{flex:1;display:flex;align-items:center;gap:.75rem} .page-title{font-size:1rem;font-weight:600;color:var(--text)} .breadcrumb{font-size:.78rem;color:var(--text3)} .topbar-right{display:flex;align-items:center;gap:.5rem} .topbar-btn{width:34px;height:34px;border-radius:var(--radius-sm);background:none;border:none;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);position:relative;font-size:.9rem} .topbar-btn:hover{background:var(--surface2);color:var(--text)} .topbar-sidebar-toggle{display:none} .topbar-btn .badge-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)} .topbar-btn-bell{width:40px;height:40px;border-radius:12px} .topbar-btn-bell.has-alert{background:linear-gradient(180deg,var(--surface),var(--primary-light));color:var(--primary);border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border))} .topbar-btn-bell.has-alert:hover{background:var(--primary-light);color:var(--primary-dark)} .topbar-badge-count{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--danger);color:#fff;font-size:.66rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(239,68,68,.3)} .page-content{flex:1;overflow-y:auto;padding:1.5rem;background:var(--bg)} /* ── MASTER WORKSPACE ── */ .master-page .app{display:flex} .master-page.master-booting #masterLoginPage, .master-page.master-booting #appShell{visibility:hidden} .master-login-wrap{min-height:100vh;background:linear-gradient(180deg,#f5f8ff 0%,#eef4ff 100%)} .master-login-layout{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(420px,.95fr);width:100%;min-height:100vh} .master-login-brand{background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 58%,#38bdf8 100%);padding:48px;display:flex;align-items:center;justify-content:center} .master-login-brand-inner{max-width:640px;color:#fff} .master-login-pill{display:inline-flex;align-items:center;padding:.42rem .85rem;border-radius:999px;background:rgba(255,255,255,.14);font-size:.76rem;font-weight:700;margin:1.25rem 0 1rem} .master-login-brand h1{font-size:3rem;line-height:.98;letter-spacing:-.05em;margin-bottom:1rem} .master-login-brand p{font-size:1rem;line-height:1.8;color:rgba(255,255,255,.84);max-width:560px} .master-login-points{display:flex;flex-direction:column;gap:.8rem;margin-top:1.5rem} .master-login-points div{display:flex;align-items:center;gap:.65rem;font-size:.92rem;color:#e0f2fe} .master-login-panel{display:flex;align-items:center;justify-content:center;padding:32px} .master-login-form-wrap{max-width:420px;width:100%} .master-login-actions{display:flex;flex-direction:column;gap:.8rem} .master-shell{display:grid;grid-template-columns:280px minmax(0,1fr);width:100%;height:100vh;transition:grid-template-columns .28s cubic-bezier(.22,.61,.36,1);background: radial-gradient(circle at top left, rgba(37,99,235,.08), transparent 28%), linear-gradient(180deg,#f6f8fc 0%,#eef3fb 100%)} .master-sidebar{background:linear-gradient(180deg,#0f172a 0%,#111d3c 100%);border-right:1px solid rgba(148,163,184,.16);padding:24px 20px;display:flex;flex-direction:column;gap:22px;transition:padding .28s cubic-bezier(.22,.61,.36,1),border-color .28s ease,background .28s ease} .master-brand-top{display:flex;align-items:center;justify-content:space-between;gap:10px} .master-brand .sidebar-logo{color:#f8fbff;display:inline-block;transform-origin:left center;transition:opacity .2s ease,max-width .28s cubic-bezier(.22,.61,.36,1),transform .28s cubic-bezier(.22,.61,.36,1),margin .28s ease} .master-brand .sidebar-logo span{color:#7dd3fc} .master-brand-mini{display:none;width:42px;height:42px;border-radius:14px;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(148,163,184,.18);color:#e0f2fe} .master-brand-mini i{font-size:1rem} .master-brand-copy{font-size:.84rem;line-height:1.7;color:rgba(226,232,240,.72);margin-top:.8rem;overflow:hidden;max-height:88px;transition:opacity .2s ease,max-height .28s cubic-bezier(.22,.61,.36,1),transform .28s cubic-bezier(.22,.61,.36,1),margin .28s ease} .master-nav-card,.master-user-card{background:rgba(255,255,255,.06);border:1px solid rgba(148,163,184,.12);border-radius:20px;padding:14px} .master-nav-card{margin-top:16px} .master-nav-card{display:flex;flex-direction:column;gap:8px;transition:padding .28s cubic-bezier(.22,.61,.36,1),border-radius .28s ease,margin .28s ease} .master-nav-link{display:flex;align-items:center;gap:.7rem;padding:.9rem 1rem;border-radius:14px;color:#dbeafe;text-decoration:none;font-weight:600;transition:all var(--transition);width:100%;border:none;background:transparent;text-align:left;cursor:pointer;font:inherit} .master-nav-link span{display:inline-block;overflow:hidden;white-space:nowrap;max-width:160px;opacity:1;transform:translateX(0);transition:opacity .18s ease,max-width .28s cubic-bezier(.22,.61,.36,1),transform .28s cubic-bezier(.22,.61,.36,1),margin .28s ease} .master-nav-link:hover,.master-nav-link.active{background:rgba(255,255,255,.1);color:#ffffff} .master-user-card{display:flex;align-items:center;gap:.9rem;margin-top:auto;transition:padding .28s cubic-bezier(.22,.61,.36,1),border-radius .28s ease,gap .28s ease} .master-user-copy{display:flex;flex-direction:column;gap:.18rem;overflow:hidden;max-width:160px;opacity:1;transform:translateX(0);transition:opacity .18s ease,max-width .28s cubic-bezier(.22,.61,.36,1),transform .28s cubic-bezier(.22,.61,.36,1)} .master-user-copy strong{color:#ffffff;font-size:.96rem} .master-user-copy span{color:#93c5fd;font-size:.78rem} .master-main-area{min-width:0;display:flex;flex-direction:column;overflow:hidden} .master-topbar-left{display:flex;align-items:center;gap:.9rem;min-width:0} .master-sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border-color:rgba(148,163,184,.22);background:rgba(255,255,255,.06);color:#dbeafe;line-height:1} .master-sidebar-toggle:hover{background:rgba(255,255,255,.12);color:#fff} .master-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:22px 28px;border-bottom:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.78);backdrop-filter:blur(18px)} .master-topbar-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end} .master-sidebar-collapsed .master-shell{grid-template-columns:92px minmax(0,1fr)} .master-sidebar-collapsed .master-sidebar{padding:24px 12px} .master-sidebar-collapsed .master-brand-copy{opacity:0;max-height:0;transform:translateX(-8px);margin-top:0;pointer-events:none} .master-sidebar-collapsed .master-nav-link span, .master-sidebar-collapsed .master-user-copy, .master-sidebar-collapsed .master-brand .sidebar-logo{opacity:0;max-width:0;transform:translateX(-8px);margin:0;pointer-events:none} .master-sidebar-collapsed .master-brand{display:flex;justify-content:center} .master-sidebar-collapsed .master-brand-top{flex-direction:row;align-items:center;justify-content:center} .master-sidebar-collapsed .master-brand-mini{display:none} .master-sidebar-collapsed .master-sidebar-toggle{position:static;width:38px;height:38px;padding:0;justify-content:center;border-radius:12px} .master-sidebar-collapsed .master-nav-card{padding:12px 10px} .master-sidebar-collapsed .master-nav-link{justify-content:center;padding:.9rem} .master-sidebar-collapsed .master-user-card{justify-content:center;padding:12px} .master-sidebar-collapsed .master-user-card .avatar{margin:0} .master-page-content{padding:28px 30px 40px;overflow-y:auto} .master-hero-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);gap:18px;margin-bottom:18px} .master-hero-card{background:linear-gradient(135deg,#ffffff 0%,#f7faff 100%);border:1px solid #dbe5f3;border-radius:28px;padding:26px 28px;box-shadow:0 18px 50px rgba(15,23,42,.06)} .master-hero-kicker{display:inline-flex;align-items:center;padding:.4rem .8rem;border-radius:999px;background:#eef4ff;color:#315fd8;font-size:.73rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1rem} .master-hero-card h2{font-size:1.9rem;letter-spacing:-.04em;color:#0f172a;margin-bottom:.7rem} .master-hero-card>p{max-width:760px;font-size:.95rem;line-height:1.75;color:#60708d;margin-bottom:1.35rem} .master-command-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.1rem} .master-command-search{flex:1;max-width:560px} .master-command-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end} .master-hero-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px} .master-hero-point{border:1px solid #e0e8f5;background:#fbfdff;border-radius:18px;padding:14px 15px} .master-hero-point strong{display:block;font-size:.86rem;color:#0f172a;margin-bottom:.35rem} .master-hero-point span{display:block;font-size:.84rem;line-height:1.55;color:#6b7a93} .master-current-card{background:linear-gradient(180deg,#10224c 0%,#1f4bd0 100%);color:#fff;border-radius:28px;padding:22px 22px 20px;box-shadow:0 22px 48px rgba(16,34,76,.26);display:flex;flex-direction:column;min-height:100%} .master-current-label{font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;color:#c7d9ff;margin-bottom:.6rem;font-weight:700} .master-current-name{font-size:1.4rem;font-weight:800;line-height:1.15} .master-current-meta{font-size:.88rem;color:rgba(255,255,255,.84);margin-top:.55rem;line-height:1.55} .master-current-divider{height:1px;background:rgba(255,255,255,.16);margin:18px 0 16px} .master-current-pill-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px} .master-current-pill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:15px;padding:11px 12px} .master-current-pill span{display:block;font-size:.68rem;color:#cfe0ff;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem} .master-current-pill strong{display:block;font-size:.88rem;color:#fff} .master-current-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px} .master-current-metric{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:12px 13px} .master-current-metric span{display:block;font-size:.72rem;color:#cfe0ff;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem} .master-current-metric strong{display:block;font-size:1.08rem;color:#fff} .master-kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px} .master-kpi-card{background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);border:1px solid #dce5f2;border-radius:24px;padding:18px 18px 16px;box-shadow:0 12px 28px rgba(15,23,42,.06);min-height:142px;display:flex;flex-direction:column} .master-kpi-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:.55rem} .master-kpi-icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(180deg,#eef4ff 0%,#dbeafe 100%);color:#1d4ed8;border:1px solid #d7e5ff;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)} .master-kpi-icon i{font-size:.95rem} .master-kpi-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#6b7a93;margin-bottom:.55rem} .master-kpi-value{font-size:2rem;font-weight:800;line-height:1;color:#0f172a;margin-bottom:.45rem;letter-spacing:-.04em} .master-kpi-meta{font-size:.84rem;line-height:1.55;color:#64748b;margin-top:auto} .master-kpi-meta strong{color:#0f172a;font-weight:800} .master-chart-shell{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:18px} .master-chart-card{background:#fff;border:1px solid #dde5f1;border-radius:24px;padding:18px 20px;box-shadow:0 10px 30px rgba(15,23,42,.05)} .master-chart-card-wide{grid-column:span 2} .master-chart-toolbar-card{background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)} .master-chart-toolbar-shell{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:16px;align-items:end} .master-chart-filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,260px));gap:12px} .master-chart-toolbar-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px} .master-chart-toolbar-stat{padding:13px 14px;border:1px solid #dde5f1;border-radius:16px;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)} .master-chart-toolbar-stat span{display:block;font-size:.7rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#64748b;margin-bottom:.35rem} .master-chart-toolbar-stat strong{display:block;font-size:1rem;color:#0f172a;line-height:1.2;overflow-wrap:anywhere} .master-chart-canvas-wrap{position:relative;min-height:290px} .master-chart-card .card-title{overflow-wrap:anywhere} .master-chart-card .card-subtitle{max-width:52ch;line-height:1.6;overflow-wrap:anywhere} .master-summary-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px} .master-summary-card{background:#fff;border:1px solid #dde5f1;border-radius:24px;padding:18px 20px;box-shadow:0 10px 30px rgba(15,23,42,.05)} .master-summary-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#2563eb;font-weight:700;margin-bottom:.45rem} .master-summary-card h3{font-size:1.02rem;margin-bottom:.45rem;color:#0f172a} .master-summary-card p{font-size:.88rem;line-height:1.65;color:#64748b} .master-catalog-grid,.master-plan-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px} .master-inline-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#2563eb;font-weight:700;margin-bottom:.45rem} .master-inline-card,.master-plan-card,.master-spotlight-card,.master-resource-card{background:#fff;border:1px solid #dde5f1;border-radius:24px;box-shadow:0 10px 30px rgba(15,23,42,.05)} .master-inline-card{padding:18px 20px} .master-inline-card strong{display:block;font-size:1.55rem;line-height:1;color:#0f172a;margin-bottom:.45rem} .master-inline-card span{display:block;font-size:.84rem;line-height:1.55;color:#64748b} .master-spotlight-card{display:grid;grid-template-columns:minmax(260px,.8fr) minmax(0,1fr);gap:16px;padding:18px 20px;margin-bottom:16px} .master-spotlight-copy p{font-size:.88rem;line-height:1.65;color:#64748b;margin-top:.55rem} .master-spotlight-list{display:grid;gap:10px} .master-spotlight-item{padding:13px 14px;border:1px solid #dde5f1;border-radius:16px;background:#fbfdff} .master-spotlight-item strong{display:block;font-size:.9rem;color:#0f172a;margin-bottom:.25rem} .master-spotlight-item span{font-size:.8rem;color:#64748b} .master-plan-catalog-card{padding:1.1rem;margin-bottom:1rem} .master-plan-card{padding:18px 20px} .master-plan-card.is-current{border-color:#93c5fd;box-shadow:0 14px 34px rgba(37,99,235,.12)} .master-plan-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:.8rem} .master-plan-head h4{font-size:1.05rem;color:#0f172a;margin-top:.2rem} .master-plan-card p{font-size:.86rem;line-height:1.65;color:#64748b;margin-bottom:.95rem} .master-plan-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:.95rem} .master-plan-metrics div,.master-resource-list div{padding:12px 13px;border:1px solid #dde5f1;border-radius:14px;background:#fbfdff} .master-plan-metrics span,.master-resource-list span{display:block;font-size:.7rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#64748b;margin-bottom:.35rem} .master-plan-metrics strong,.master-resource-list strong{font-size:.9rem;color:#0f172a} .master-plan-resources{display:flex;flex-wrap:wrap;gap:8px} .master-plan-inline-shell{margin:1rem 0 1.15rem;padding:1rem 1.05rem;border:1px solid #dde5f1;border-radius:20px;background:linear-gradient(180deg,#fbfdff 0%,#f8fbff 100%)} .master-plan-inline-shell h5{font-size:1rem;color:#0f172a;margin:.2rem 0 .35rem} .master-plan-inline-shell p{font-size:.88rem;line-height:1.6;color:#64748b;margin:0 0 1rem} .master-capacity-panel{display:grid;grid-template-columns:minmax(220px,.9fr) auto;gap:16px;padding:16px 18px;border-radius:20px;border:1px solid #d9e5fb;background:linear-gradient(180deg,#fbfdff 0%,#f3f7ff 100%)} .master-capacity-panel strong{display:block;font-size:.92rem;color:#0f172a;margin-bottom:.2rem} .master-capacity-panel span{font-size:.82rem;line-height:1.55;color:#64748b} .master-capacity-panel-side{display:flex;align-items:flex-start;justify-content:flex-end} .master-capacity-meter{grid-column:1 / -1;display:grid;gap:10px;padding:14px 16px;border-radius:16px;border:1px solid #d9e5fb;background:#fff} .master-capacity-meter-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap} .master-capacity-meter-head strong{font-size:.88rem;margin:0} .master-capacity-meter-head span{font-size:.78rem} .master-capacity-track{position:relative;height:10px;border-radius:999px;background:#e8eefb;overflow:hidden} .master-capacity-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#10b981,#34d399)} .master-capacity-meter.is-warning .master-capacity-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)} .master-capacity-meter.is-danger .master-capacity-fill{background:linear-gradient(90deg,#ef4444,#f87171)} .master-capacity-meter.is-neutral .master-capacity-fill{background:linear-gradient(90deg,#64748b,#94a3b8)} .master-plan-grid-inline{margin-bottom:0} .master-plan-feature-list{display:grid;gap:8px;margin-top:.95rem;padding-top:.95rem;border-top:1px dashed #d8e2f0} .master-plan-feature-item{display:flex;align-items:flex-start;gap:8px;font-size:.84rem;color:#334155} .master-plan-feature-item i{margin-top:.14rem;color:#2563eb;font-size:.8rem} .badge-soft{background:#f8fafc;color:#475569;border:1px solid #dde5f1} .master-resource-strip{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(0,1.15fr);gap:16px} .master-resource-card{padding:18px 20px} .master-resource-card h4{font-size:1.02rem;color:#0f172a;margin-bottom:.45rem} .master-resource-card p{font-size:.86rem;line-height:1.65;color:#64748b} .master-resource-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px} .master-table-card,.master-detail-card{padding:1.1rem;margin-bottom:1rem} .master-form-group-title{font-size:.86rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:#2563eb;margin:1rem 0 .8rem} .master-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px} .master-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;margin-bottom:1rem} .master-switch-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem} .master-form-actions{display:flex;gap:.75rem;flex-wrap:wrap} .master-tab-intro{margin-bottom:1rem} .master-tab-intro h4{margin-bottom:.3rem;font-size:1rem;color:#0f172a} .master-tab-intro p{font-size:.88rem;color:#64748b} .master-tabs{display:flex;gap:.65rem;flex-wrap:wrap;margin:1rem 0} .master-tab{border:1px solid #d7e2f0;background:#f8fbff;color:#46607f;border-radius:14px;padding:.78rem 1rem;display:flex;align-items:center;gap:.55rem;font-weight:700;cursor:pointer;transition:all var(--transition)} .master-tab.active{background:#edf4ff;border-color:#93c5fd;color:#1d4ed8;box-shadow:0 12px 24px rgba(37,99,235,.12)} .master-tab-panel{border:1px solid #dde5f1;border-radius:20px;padding:18px;background:#fff} .master-setup-stepper{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin-bottom:16px} .master-setup-step{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid #dbe6f6;cursor:pointer;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition),background var(--transition);min-height:82px;text-align:left} .master-setup-step:hover{transform:translateY(-1px);border-color:#bfd2f0;box-shadow:0 12px 24px rgba(15,23,42,.05)} .master-setup-step.is-active{background:#eff4ff;border-color:#8fb4ff;box-shadow:0 16px 32px rgba(37,99,235,.12)} .master-setup-step.is-complete{background:#f4fbf8;border-color:#b8e7d1} .master-setup-step-index{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#dbeafe;color:#2563eb;font-size:.84rem;font-weight:800;flex:0 0 auto} .master-setup-step.is-active .master-setup-step-index{background:#2563eb;color:#fff} .master-setup-step.is-complete .master-setup-step-index{background:#10b981;color:#fff} .master-setup-step-copy{min-width:0} .master-setup-step-copy strong{display:block;font-size:.95rem;color:#0f172a;margin-bottom:.2rem} .master-setup-step-copy span{display:block;font-size:.79rem;line-height:1.4;color:#64748b} .master-setup-summary-grid{display:grid;grid-template-columns:1.35fr .9fr;gap:16px;margin-bottom:16px} .master-setup-summary-card,.master-setup-checklist-card{background:#fff;border:1px solid #dde5f1;border-radius:24px;padding:20px;box-shadow:0 10px 30px rgba(15,23,42,.05)} .master-setup-summary-kicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#2563eb;font-weight:800;margin-bottom:.5rem} .master-setup-summary-card h3,.master-setup-checklist-card h4{font-size:1.18rem;color:#0f172a;margin-bottom:.35rem} .master-setup-summary-card p,.master-setup-checklist-card p{font-size:.88rem;line-height:1.6;color:#64748b} .master-setup-summary-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px} .master-setup-summary-metric{padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid #e0eaf7} .master-setup-summary-metric span{display:block;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:.35rem} .master-setup-summary-metric strong{font-size:1rem;color:#0f172a} .master-setup-checklist{display:flex;flex-direction:column;gap:10px;margin-top:14px} .master-setup-checklist-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:16px;background:#f8fbff;border:1px solid #e0eaf7} .master-setup-checklist-item i{margin-top:2px} .master-setup-checklist-item.is-ready i{color:#10b981} .master-setup-checklist-item.is-pending i{color:#f59e0b} .master-setup-checklist-item strong{display:block;font-size:.88rem;color:#0f172a;margin-bottom:.1rem} .master-setup-checklist-item span{display:block;font-size:.8rem;color:#64748b;line-height:1.45} .master-stage-shell{display:flex;flex-direction:column;gap:16px} .master-stage-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px;border-radius:24px;background:linear-gradient(180deg,#fbfdff 0%,#f5f9ff 100%);border:1px solid #dde7f6} .master-stage-hero h4{font-size:1.12rem;color:#0f172a;margin-bottom:.35rem} .master-stage-hero p{font-size:.88rem;line-height:1.6;color:#64748b;max-width:720px} .master-stage-chip{display:inline-flex;align-items:center;gap:8px;padding:.46rem .88rem;border-radius:999px;background:#eef4ff;color:#2563eb;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em} .master-stage-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:16px} .master-stage-side-card{background:#f8fbff;border:1px solid #dde7f6;border-radius:24px;padding:18px} .master-stage-side-card h5{font-size:1rem;color:#0f172a;margin-bottom:.45rem} .master-stage-side-card p{font-size:.84rem;line-height:1.6;color:#64748b;margin-bottom:1rem} .master-stage-note{display:flex;flex-direction:column;gap:8px} .master-stage-note-item{padding:12px 14px;border-radius:16px;background:#fff;border:1px solid #e1e9f6} .master-stage-note-item strong{display:block;font-size:.82rem;color:#0f172a;margin-bottom:.18rem} .master-stage-note-item span{display:block;font-size:.78rem;line-height:1.45;color:#64748b} .master-slug-preview{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:20px;background:#0f172a;color:#e2e8f0} .master-slug-preview strong{display:block;font-size:1rem;color:#fff} .master-table-headcount{display:flex;flex-direction:column;gap:2px} .master-table-headcount strong{font-size:.92rem;color:#0f172a} .master-table-headcount span{font-size:.74rem;color:#64748b} .master-slug-preview span{display:block;font-size:.8rem;color:#cbd5e1;margin-top:.2rem} .master-slug-preview code{display:inline-flex;padding:.5rem .8rem;border-radius:12px;background:rgba(255,255,255,.08);font-size:.83rem;color:#fff} .master-validation-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px} .master-validation-card{padding:18px;border-radius:22px;background:#f8fbff;border:1px solid #dde7f6} .master-validation-card h5{font-size:.95rem;color:#0f172a;margin-bottom:.35rem} .master-validation-card p{font-size:.82rem;line-height:1.55;color:#64748b} .master-validation-status{display:inline-flex;align-items:center;gap:8px;padding:.34rem .7rem;border-radius:999px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-top:10px} .master-validation-status.is-ready{background:#ecfdf5;color:#047857} .master-validation-status.is-pending{background:#fffbeb;color:#b45309} .master-rh-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px} .master-activation-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:16px} .master-activation-card{padding:20px;border-radius:24px;background:#f8fbff;border:1px solid #dde7f6} .master-activation-card h4{font-size:1.08rem;color:#0f172a;margin-bottom:.35rem} .master-activation-card p{font-size:.86rem;line-height:1.6;color:#64748b;margin-bottom:1rem} .master-activation-actions{display:flex;flex-wrap:wrap;gap:10px} .master-detail-actions{display:flex;gap:.75rem;flex-wrap:wrap} .master-detail-footer{justify-content:space-between;margin-top:1rem} .master-detail-placeholder{padding:1.2rem 0} .master-detail-placeholder h3{font-size:1rem;margin-bottom:.3rem;color:#0f172a} .master-detail-placeholder p{color:#64748b} .master-detail-headline{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.9rem} .master-detail-kicker{font-size:.72rem;font-weight:800;color:#2563eb;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem} .master-detail-headline h3{font-size:1.18rem;color:#0f172a;margin-bottom:.25rem} .master-detail-headline p{font-size:.9rem;color:#64748b} .master-detail-badges{display:flex;gap:.45rem;flex-wrap:wrap;justify-content:flex-end} .master-detail-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px} .master-table{width:100%} .master-table tbody tr{cursor:pointer} .master-table tbody tr.is-selected{background:#f7fbff} .master-table-company{display:flex;flex-direction:column;gap:.18rem} .master-table-company strong{font-size:.94rem;color:#0f172a} .master-table-company span{font-size:.76rem;color:#64748b} .master-table-actions{display:flex;gap:.45rem;flex-wrap:wrap} .master-users-layout{display:grid;grid-template-columns:minmax(320px,.95fr) minmax(0,1.35fr);gap:16px} .master-users-card{padding:1.1rem;margin-bottom:1rem} .master-users-note{margin-top:.85rem;font-size:.84rem;line-height:1.6;color:#64748b} .master-permission-row{display:grid;grid-template-columns:180px minmax(0,1fr);gap:14px;align-items:start;padding:.7rem 0;border-top:1px solid var(--border)} .master-permission-row:first-of-type{border-top:none} .master-permission-module{font-size:.83rem;font-weight:700;color:#334155;padding-top:.35rem} .master-mini-metric{background:#f8fbff;border:1px solid #d9e4f5;border-radius:16px;padding:12px} .master-mini-metric span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin-bottom:.3rem} .master-mini-metric strong{font-size:.95rem;color:#0f172a} .timeline-list{display:flex;flex-direction:column;gap:12px} .timeline-item{display:flex;gap:12px;align-items:flex-start} .timeline-dot{width:10px;height:10px;border-radius:50%;background:#2563eb;margin-top:7px;flex:0 0 auto} .timeline-content{display:flex;flex-direction:column;gap:.25rem} .timeline-content strong{font-size:.9rem;color:#0f172a} .timeline-content span{font-size:.84rem;color:#64748b;line-height:1.55} .empty-state{padding:1.2rem;border:1px dashed var(--border);border-radius:16px;color:#64748b;text-align:center} [data-theme="dark"] .master-shell{background: radial-gradient(circle at top left, rgba(56,189,248,.08), transparent 30%), linear-gradient(180deg,#0f1117 0%,#111827 100%)} [data-theme="dark"] .master-hero-card, [data-theme="dark"] .master-topbar, [data-theme="dark"] .master-kpi-card, [data-theme="dark"] .master-chart-card, [data-theme="dark"] .master-summary-card, [data-theme="dark"] .master-inline-card, [data-theme="dark"] .master-plan-card, [data-theme="dark"] .master-spotlight-card, [data-theme="dark"] .master-resource-card, [data-theme="dark"] .master-setup-summary-card, [data-theme="dark"] .master-setup-checklist-card, [data-theme="dark"] .master-stage-side-card, [data-theme="dark"] .master-validation-card, [data-theme="dark"] .master-activation-card, [data-theme="dark"] .master-mini-metric, [data-theme="dark"] .master-tab-panel, [data-theme="dark"] .master-plan-catalog-card{background:rgba(26,29,46,.92)} [data-theme="dark"] .master-setup-step{background:#20253a;border-color:rgba(255,255,255,.16)} [data-theme="dark"] .master-setup-step.is-active{background:#1e2a4a;border-color:#4c6acb} [data-theme="dark"] .master-setup-step.is-complete{background:#133327;border-color:#2d7f61} [data-theme="dark"] .master-setup-step-index{background:#293657;color:#cfe0ff} [data-theme="dark"] .master-hero-point, [data-theme="dark"] .master-kpi-card, [data-theme="dark"] .master-summary-card, [data-theme="dark"] .master-inline-card, [data-theme="dark"] .master-plan-card, [data-theme="dark"] .master-plan-inline-shell, [data-theme="dark"] .master-capacity-panel, [data-theme="dark"] .master-capacity-meter, [data-theme="dark"] .master-spotlight-item, [data-theme="dark"] .master-plan-metrics div, [data-theme="dark"] .master-resource-list div, [data-theme="dark"] .master-mini-metric, [data-theme="dark"] .master-hero-card, [data-theme="dark"] .master-tab-panel, [data-theme="dark"] .master-tab{border-color:rgba(255,255,255,.24)} [data-theme="dark"] .master-chart-card, [data-theme="dark"] .master-spotlight-card, [data-theme="dark"] .master-resource-card, [data-theme="dark"] .master-plan-catalog-card, [data-theme="dark"] .master-users-card, [data-theme="dark"] .master-table-card, [data-theme="dark"] .master-detail-card{border-color:rgba(255,255,255,.24)} [data-theme="dark"] .master-setup-summary-metric, [data-theme="dark"] .master-setup-checklist-item, [data-theme="dark"] .master-stage-note-item{background:#20253a;border-color:rgba(255,255,255,.14)} [data-theme="dark"] .master-stage-hero{background:linear-gradient(180deg,#1c2034 0%,#171b2c 100%);border-color:rgba(255,255,255,.16)} [data-theme="dark"] .master-slug-preview{background:#0f1425;border-color:rgba(255,255,255,.14)} [data-theme="dark"] .master-plan-card.is-current{border-color:rgba(147,197,253,.6);box-shadow:0 18px 44px rgba(15,23,42,.28)} [data-theme="dark"] .master-plan-metrics div, [data-theme="dark"] .master-resource-list div{background:rgba(255,255,255,.04)} [data-theme="dark"] .master-hero-point{background:rgba(255,255,255,.04)} [data-theme="dark"] .master-hero-card h2, [data-theme="dark"] .master-summary-card h3, [data-theme="dark"] .master-plan-head h4, [data-theme="dark"] .master-resource-card h4, [data-theme="dark"] .master-setup-summary-card h3, [data-theme="dark"] .master-setup-checklist-card h4, [data-theme="dark"] .master-stage-hero h4, [data-theme="dark"] .master-stage-side-card h5, [data-theme="dark"] .master-capacity-panel strong, [data-theme="dark"] .master-validation-card h5, [data-theme="dark"] .master-activation-card h4, [data-theme="dark"] .master-setup-step-copy strong, [data-theme="dark"] .master-setup-checklist-item strong, [data-theme="dark"] .master-inline-card strong, [data-theme="dark"] .master-spotlight-item strong{color:#f8fafc} [data-theme="dark"] .master-hero-card>p, [data-theme="dark"] .master-hero-point span, [data-theme="dark"] .master-kpi-label, [data-theme="dark"] .master-kpi-meta, [data-theme="dark"] .master-inline-card span, [data-theme="dark"] .master-spotlight-copy p, [data-theme="dark"] .master-spotlight-item span, [data-theme="dark"] .master-plan-card p, [data-theme="dark"] .master-plan-inline-shell p, [data-theme="dark"] .master-tab-intro h4, [data-theme="dark"] .master-detail-headline h3, [data-theme="dark"] .master-table-company strong, [data-theme="dark"] .timeline-content strong{color:#f8fafc} [data-theme="dark"] .master-summary-card p, [data-theme="dark"] .master-setup-summary-card p, [data-theme="dark"] .master-setup-checklist-card p, [data-theme="dark"] .master-setup-step-copy span, [data-theme="dark"] .master-setup-checklist-item span, [data-theme="dark"] .master-stage-hero p, [data-theme="dark"] .master-stage-side-card p, [data-theme="dark"] .master-capacity-panel span, [data-theme="dark"] .master-capacity-meter-head span, [data-theme="dark"] .master-stage-note-item span, [data-theme="dark"] .master-validation-card p, [data-theme="dark"] .master-activation-card p, [data-theme="dark"] .master-users-note, [data-theme="dark"] .master-mini-metric span, [data-theme="dark"] .master-setup-summary-metric span, [data-theme="dark"] .master-plan-metrics span, [data-theme="dark"] .master-resource-list span, [data-theme="dark"] .master-tab-intro p, [data-theme="dark"] .master-detail-headline p, [data-theme="dark"] .timeline-content span, [data-theme="dark"] .master-table-company span, [data-theme="dark"] .master-detail-placeholder p, [data-theme="dark"] .empty-state{color:#a7b1cf} [data-theme="dark"] .master-hero-point strong, [data-theme="dark"] .master-kpi-value, [data-theme="dark"] .master-mini-metric strong, [data-theme="dark"] .master-setup-summary-metric strong, [data-theme="dark"] .master-plan-metrics strong, [data-theme="dark"] .master-plan-inline-shell h5, [data-theme="dark"] .master-plan-feature-item, [data-theme="dark"] .master-resource-list strong{color:#e8eaf6} [data-theme="dark"] .master-stage-note-item strong{color:#e5e7eb} [data-theme="dark"] .master-plan-resources .badge-soft{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:#dbeafe} [data-theme="dark"] .master-hero-point span{color:#c7d2fe} [data-theme="dark"] .master-tab{background:rgba(20,24,40,.92);color:#b9c4de} [data-theme="dark"] .master-tab.active{background:rgba(37,99,235,.18);color:#dbeafe} [data-theme="dark"] .master-table tbody tr.is-selected{background:rgba(37,99,235,.12)} [data-theme="dark"] .master-kpi-icon{background:linear-gradient(180deg,rgba(59,130,246,.22),rgba(30,64,175,.26));border-color:#3453a1;color:#dbeafe} [data-theme="dark"] .master-current-pill{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12)} [data-theme="dark"] .master-chart-toolbar-card{background:rgba(26,29,46,.92)} [data-theme="dark"] .master-chart-toolbar-stat{background:rgba(255,255,255,.04);border-color:#2e3250} [data-theme="dark"] .master-chart-toolbar-stat strong{color:#f8fafc} /* ── CARDS ── */ .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;transition:box-shadow var(--transition)} .card:hover{box-shadow:var(--shadow-md)} .card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem} .card-title{font-size:.9rem;font-weight:600;color:var(--text)} .card-subtitle{font-size:.78rem;color:var(--text3);margin-top:.15rem} .report-group-label,.section-group-label{position:relative;padding:.8rem 1rem .8rem 1.1rem;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface) 82%,var(--bg)));overflow:hidden} .report-group-label::before,.section-group-label::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px} .report-group-label .card-title,.section-group-label .card-title{font-size:.92rem} .setup-guide-card{background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 34%,transparent), transparent 38%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 78%,var(--surface))); border:1px solid color-mix(in srgb,var(--primary) 14%,var(--border))} .setup-guide-progress{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;padding:.75rem .95rem;border-radius:18px;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--primary-light) 55%,var(--surface)));border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));min-width:180px} .setup-guide-progress strong{font-size:1.35rem;line-height:1;color:var(--primary)} .setup-guide-progress span{font-size:.76rem;color:var(--text2);text-align:right} .setup-guide-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem} .setup-guide-item{padding:1rem;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,var(--surface),var(--surface2));box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.8rem} .setup-guide-item.is-done{border-color:color-mix(in srgb,var(--success) 24%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 85%,#effcf6),color-mix(in srgb,var(--surface2) 82%,#dcfce7))} .setup-guide-item.is-optional{border-style:dashed} .setup-guide-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem} .setup-guide-item-title{font-size:.9rem;font-weight:700;color:var(--text)} .setup-guide-item-text{font-size:.8rem;line-height:1.5;color:var(--text2)} .setup-guide-item-meta{font-size:.72rem;color:var(--text3)} .setup-guide-item .badge{align-self:flex-start} .setup-guide-item .btn{margin-top:auto} .config-subgroup{padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid color-mix(in srgb,var(--border) 82%,transparent)} .config-subgroup-title{font-size:.92rem;font-weight:700;color:var(--text);margin-bottom:.2rem} .config-subgroup-note{font-size:.78rem;line-height:1.6;color:var(--text2);margin-bottom:.85rem} .config-inline-note{margin-top:.15rem;padding:.75rem .85rem;border-radius:14px;background:color-mix(in srgb,var(--primary-light) 75%,var(--surface));border:1px solid color-mix(in srgb,var(--primary) 14%,var(--border));font-size:.76rem;line-height:1.6;color:var(--text2)} .report-group-operational::before{background:linear-gradient(180deg,#2563eb,#0ea5e9)} .report-group-operational .card-title{color:#1d4ed8} .report-group-analytical::before{background:linear-gradient(180deg,#16a34a,#22c55e)} .report-group-analytical .card-title{color:#15803d} .report-group-compliance::before{background:linear-gradient(180deg,#7c3aed,#a855f7)} .report-group-compliance .card-title{color:#7c3aed} .report-selected-panel{background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 28%,transparent), transparent 36%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 82%,var(--surface))); border:1px solid color-mix(in srgb,var(--primary) 14%,var(--border))} .report-selected-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem} .report-selected-title{font-size:1.08rem} .report-selected-description{margin-top:.45rem;max-width:760px;font-size:.84rem;line-height:1.6;color:var(--text2)} .report-selected-meta{max-width:300px;padding:.8rem .95rem;border-radius:16px;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--primary-light) 52%,var(--surface)));border:1px solid color-mix(in srgb,var(--primary) 16%,var(--border));font-size:.78rem;line-height:1.55;color:var(--text2)} .report-filter-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;align-items:end} .report-selected-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem} .report-selected-summary{margin-top:.95rem;padding:.8rem .95rem;border-radius:14px;background:color-mix(in srgb,var(--primary-light) 72%,var(--surface));border:1px solid color-mix(in srgb,var(--primary) 12%,var(--border));font-size:.8rem;line-height:1.6;color:var(--text2)} .dashboard-shell,.employee-shell{display:grid;gap:1rem} .reports-shell{display:grid;gap:0} .report-card-grid .report-card{position:relative;overflow:hidden;min-height:168px;background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 20%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 82%,var(--surface)));border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border));box-shadow:0 10px 24px rgba(15,23,42,.04);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)} .report-card-grid .report-card::after{content:'';position:absolute;left:1.05rem;right:1.05rem;bottom:0;height:3px;border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--primary) 50%,transparent),transparent)} .report-card-grid .report-card:hover{transform:translateY(-2px);box-shadow:0 16px 30px rgba(15,23,42,.08);border-color:color-mix(in srgb,var(--primary) 18%,var(--border))} .report-card-grid .report-card .badge{margin-right:.25rem} .dashboard-kpi-panel{padding:1rem 1.05rem;border:1px solid color-mix(in srgb,var(--primary) 12%,var(--border));border-radius:20px;background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 24%,transparent), transparent 36%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 76%,var(--surface)))} .dashboard-stat-grid,.employee-stat-grid{margin-bottom:0} .dashboard-grid .card,.employee-filter-card,.employee-table-card,.team-shell{box-shadow:0 12px 28px rgba(15,23,42,.05)} .dashboard-grid .card .card-header,.section#sec-dashboard > .card .card-header,.section#sec-dashboard .col2 > .card .card-header{padding-bottom:.8rem} .section#sec-dashboard .card .card-title{margin-bottom:0} .section#sec-dashboard .card .card-subtitle{display:none} .section#sec-dashboard .section-group-label{padding-bottom:.15rem} .employee-filter-card{background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 24%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 82%,var(--surface))); border:1px solid color-mix(in srgb,var(--primary) 12%,var(--border))} .employee-filter-bar .search-input{min-width:280px} .employee-table-card .table-wrap{padding-top:.1rem} .team-shell{padding:1rem 1.05rem 1.1rem;background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 18%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 84%,var(--surface)))} .team-tabs-shell{display:flex;gap:.55rem;flex-wrap:wrap;padding:.35rem;border:1px solid var(--border);border-radius:18px;background:color-mix(in srgb,var(--surface2) 88%,var(--surface));margin-bottom:1rem} .team-tab{border-radius:12px;padding:.55rem .9rem} .team-tab:hover{background:color-mix(in srgb,var(--primary-light) 65%,var(--surface));color:var(--primary)} .priority-list,.ops-list{display:flex;flex-direction:column;gap:.75rem} .priority-item,.ops-item{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.85rem .95rem;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,var(--surface),var(--surface2))} .priority-title,.ops-title{font-size:.84rem;font-weight:700;color:var(--text)} .priority-desc,.ops-desc{margin-top:.18rem;font-size:.76rem;line-height:1.5;color:var(--text2)} .section-group-primary::before{background:linear-gradient(180deg,#2563eb,#3b82f6)} .section-group-primary .card-title{color:#1d4ed8} .section-group-warning::before{background:linear-gradient(180deg,#f59e0b,#f97316)} .section-group-warning .card-title{color:#c2410c} .section-group-operational::before{background:linear-gradient(180deg,#0891b2,#22c55e)} .section-group-operational .card-title{color:#0f766e} .section-group-analytical::before{background:linear-gradient(180deg,#7c3aed,#14b8a6)} .section-group-analytical .card-title{color:#6d28d9} .closure-shell{display:grid;gap:0} .closure-summary-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem} .closure-summary-tile{padding:1rem 1.05rem;border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border));border-radius:20px;background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 22%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 86%,var(--surface))); box-shadow:0 12px 28px rgba(15,23,42,.05)} .closure-summary-label{font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary)} .closure-summary-title{margin-top:.35rem;font-size:.96rem;font-weight:700;color:var(--text)} .closure-summary-text{margin-top:.28rem;font-size:.79rem;line-height:1.55;color:var(--text2)} .closure-card{background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 18%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 84%,var(--surface))); border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border)); box-shadow:0 12px 28px rgba(15,23,42,.05)} .closure-action-card{position:relative;overflow:hidden} .closure-action-card::after,.closure-export-card::after{content:'';position:absolute;left:1.2rem;right:1.2rem;top:0;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),color-mix(in srgb,var(--primary) 24%,transparent))} .closure-export-card::after{background:linear-gradient(90deg,#0891b2,#22c55e)} .closure-action-row{display:flex;gap:.75rem;flex-wrap:wrap} .closure-panel-head{align-items:flex-start} .closure-side-card .table-wrap{max-height:420px;overflow:auto} .closure-side-card{position:relative} .closure-side-card::after{content:'';position:absolute;left:1.2rem;right:1.2rem;top:0;height:3px;border-radius:999px;background:linear-gradient(90deg,#7c3aed,#14b8a6)} /* ── STAT CARDS ── */ .stat-grid,.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem} .stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.25rem;display:flex;align-items:flex-start;gap:.85rem;transition:all var(--transition)} .stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)} .stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0} .stat-body .stat-label{font-size:.75rem;color:var(--text3);font-weight:500;margin-bottom:.2rem} .stat-body .stat-value{font-size:1.5rem;font-weight:600;color:var(--text);line-height:1.1} .stat-body .stat-change{font-size:.72rem;margin-top:.2rem} .stat-body .stat-change.up{color:var(--success)} .stat-body .stat-change.down{color:var(--danger)} .stat-body .stat-change.neutral{color:var(--text3)} /* ── BADGE ── */ .badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:99px;font-size:.72rem;font-weight:600} .badge-success{background:var(--success-light);color:#059669} .badge-warning{background:var(--warning-light);color:#b45309} .badge-danger{background:var(--danger-light);color:#dc2626} .badge-info{background:var(--info-light);color:var(--info)} .badge-primary{background:var(--primary-light);color:var(--primary)} .badge-neutral{background:var(--surface2);color:var(--text2)} /* ── TABLE ── */ .table-wrap{overflow-x:auto} table{width:100%;border-collapse:collapse;font-size:.82rem} th{text-align:left;padding:.7rem 1rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);border-bottom:1px solid var(--border);white-space:nowrap} td{padding:.75rem 1rem;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle} tr:last-child td{border-bottom:none} tr:hover td{background:var(--bg)} .td-name{color:var(--text);font-weight:500} .td-mono{font-family:'DM Mono',monospace;font-size:.78rem} /* ── AVATAR ── */ .avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:#fff;flex-shrink:0} .avatar-sm{width:26px;height:26px;font-size:.65rem} .avatar-lg{width:44px;height:44px;font-size:.9rem} .avatar.has-image{padding:0;overflow:hidden;background:rgba(148,163,184,.18);color:transparent} .avatar-photo{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block} .employee-avatar-shell{position:relative;overflow:hidden;box-shadow:0 14px 28px rgba(37,99,235,.12)} .employee-avatar-shell.has-photo{border:2px solid rgba(255,255,255,.9)} .employee-avatar-photo{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block} .employee-avatar-badge{position:absolute;left:50%;bottom:6px;transform:translateX(-50%);display:inline-flex;align-items:center;gap:.28rem;padding:.22rem .48rem;border-radius:999px;background:rgba(15,23,42,.78);color:#fff;font-size:.58rem;font-weight:800;letter-spacing:.03em;box-shadow:0 6px 18px rgba(15,23,42,.18)} .profile-photo-actions{display:flex;flex-wrap:wrap;gap:.55rem;margin:-.35rem 0 1.1rem 0} .av-blue{background:linear-gradient(135deg,#2563eb,#6366f1)} .av-green{background:linear-gradient(135deg,#10b981,#0ea5e9)} .av-red{background:linear-gradient(135deg,#ef4444,#f97316)} .av-purple{background:linear-gradient(135deg,#8b5cf6,#ec4899)} .av-amber{background:linear-gradient(135deg,#f59e0b,#ef4444)} /* ── SEARCH / FILTER BAR ── */ .filter-bar{display:flex;gap:.75rem;align-items:center;margin-bottom:1.2rem;flex-wrap:wrap} .search-input{flex:1;min-width:200px;position:relative} .search-input input{width:100%;padding:.55rem .9rem .55rem 2.2rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-family:inherit;font-size:.85rem;outline:none;transition:border-color var(--transition)} .search-input input:focus{border-color:var(--primary)} .search-input .si-icon{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);color:var(--text3);font-size:.8rem} .select-filter{padding:.53rem .8rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-family:inherit;font-size:.82rem;outline:none;cursor:pointer} /* ── GLOBAL PAGE POLISH ── */ .section > .page-header{margin-bottom:1.25rem} .page-header h2{font-size:1.28rem;line-height:1.15;letter-spacing:-.02em} .page-header p{max-width:760px;line-height:1.55} .section > .card, .section > .section-group-label, .section > .report-group-label{scroll-margin-top:92px} .form-control:focus, .select-filter:focus, .btn:focus-visible, .topbar-btn:focus-visible, .modal-close:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 18%,transparent);border-color:color-mix(in srgb,var(--primary) 36%,var(--border))} /* ── PROGRESS ── */ .progress{height:6px;background:var(--surface2);border-radius:99px;overflow:hidden} .progress-bar{height:100%;border-radius:99px;transition:width .6s ease} /* ── PONTO BUTTONS ── */ .ponto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem;margin-bottom:1.5rem} .ponto-btn{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:1.5rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.6rem;cursor:pointer;transition:all var(--transition);font-family:inherit} .ponto-btn:hover{border-color:var(--primary);background:var(--primary-light);transform:translateY(-2px);box-shadow:var(--shadow-md)} .ponto-btn.active{border-color:var(--primary);background:var(--primary-light)} .ponto-btn.done{border-color:var(--success);background:var(--success-light);pointer-events:none} .ponto-btn .ponto-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem} .ponto-btn .ponto-label{font-size:.82rem;font-weight:500;color:var(--text);text-align:center} .ponto-btn .ponto-time{font-size:.78rem;color:var(--text3);font-family:'DM Mono',monospace} .camera-box{position:relative;border:1px dashed var(--border);border-radius:var(--radius-sm);background:var(--bg);min-height:220px;display:flex;align-items:center;justify-content:center;overflow:hidden} .camera-video,.camera-preview{width:100%;height:220px;object-fit:cover;background:#0f172a} .camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;color:var(--text3);font-size:.8rem;padding:1rem;text-align:center} .camera-placeholder i{font-size:1.6rem;color:var(--primary)} /* ── TIMELINE ── */ .timeline{display:flex;flex-direction:column;gap:0} .tl-item{display:flex;gap:1rem;padding:.8rem 0;position:relative} .tl-item:not(:last-child)::after{content:'';position:absolute;left:15px;top:40px;bottom:-8px;width:2px;background:var(--border)} .tl-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;position:relative;z-index:1} .tl-content{flex:1;padding-top:.35rem} .tl-title{font-size:.85rem;font-weight:500;color:var(--text)} .tl-time{font-size:.75rem;color:var(--text3);font-family:'DM Mono',monospace;margin-top:.1rem} /* ── VACATION AGENDA ── */ .vacation-agenda-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem;padding:1rem;border:1px solid color-mix(in srgb,var(--primary) 14%,var(--border));border-radius:24px;background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 34%,transparent), transparent 34%), linear-gradient(180deg,#ffffff,color-mix(in srgb,var(--bg) 86%,#eef4ff));box-shadow:0 16px 40px rgba(37,99,235,.06)} .vacation-agenda-weekday{padding:.35rem 0 .45rem;text-align:center;font-size:.76rem;font-weight:800;color:var(--text2);letter-spacing:.02em} .vacation-agenda-weekday.is-weekend{color:var(--primary);text-transform:uppercase} .vacation-agenda-spacer{min-height:104px} .vacation-agenda-day{min-height:104px;padding:.65rem;border:1px solid #dbe3f3;border-radius:16px;background:linear-gradient(180deg,#ffffff,#f8fbff);box-shadow:0 8px 22px rgba(15,23,42,.04),0 1px 0 rgba(255,255,255,.8) inset;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition),background var(--transition)} .vacation-agenda-day:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(37,99,235,.09);border-color:color-mix(in srgb,var(--primary) 30%,#dbe3f3)} .vacation-agenda-day.is-weekend{background:linear-gradient(180deg,#eef4ff,#e6eefc);border-color:#bfd2f8;box-shadow:0 10px 24px rgba(59,130,246,.08)} .vacation-agenda-day.is-today{background:linear-gradient(180deg,#effcf6,#dcfce7);border-color:color-mix(in srgb,var(--success) 35%,#bbf7d0);box-shadow:0 0 0 2px color-mix(in srgb,var(--success) 18%,transparent),0 16px 28px rgba(34,197,94,.12)} .vacation-agenda-day-number{font-size:.74rem;font-weight:800;color:#6478a8;margin-bottom:.45rem} .vacation-agenda-day.is-weekend .vacation-agenda-day-number{color:#315cb7} .vacation-agenda-day.is-today .vacation-agenda-day-number{color:#15803d} .vacation-agenda-item{font-size:.7rem;color:var(--text);border-radius:8px;padding:.24rem .42rem;margin-bottom:.24rem;font-weight:600;line-height:1.25;border:1px solid transparent} .vacation-agenda-item.is-ferias{background:linear-gradient(180deg,#effcf6,#dcfce7);border-color:color-mix(in srgb,var(--success) 20%,transparent)} .vacation-agenda-item.is-folga{background:linear-gradient(180deg,#fff7ed,#ffedd5);border-color:color-mix(in srgb,var(--warning) 22%,transparent)} /* ── MODAL ── */ .modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1000;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(2px)} .modal-overlay.open{display:flex} .modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:modalIn .2s ease} @keyframes modalIn{from{opacity:0;transform:scale(.96) translateY(8px)}} .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)} .modal-title{font-size:1rem;font-weight:600} .modal-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:1.1rem;padding:.25rem;border-radius:6px;transition:all var(--transition)} .modal-close:hover{background:var(--surface2);color:var(--text)} .modal-body{padding:1.5rem} .info-success{display:flex;gap:1rem;align-items:flex-start} .info-success-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary);font-size:1.1rem;flex-shrink:0} .info-success-title{font-weight:600;color:var(--text);margin-bottom:.35rem} .info-success-text{color:var(--text2);font-size:.95rem;line-height:1.5} .info-success-meta{margin-top:.6rem;color:var(--text3);font-size:.85rem} .ponto-btn.ponto-static{cursor:default;pointer-events:none} .ponto-btn.ponto-static:hover{transform:none;box-shadow:none} .modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end} .mfp-modal{max-width:min(1180px,94vw);max-height:92vh} .mfp-modal-body{padding:0;max-height:calc(92vh - 74px - 74px);overflow-y:auto} .mfp-hero{padding:1.6rem 1.8rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:1.3rem;background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 24%,transparent), transparent 34%), linear-gradient(180deg,var(--bg),color-mix(in srgb,var(--surface2) 82%,var(--bg)))} .mfp-hero-metrics{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;text-align:center;flex-shrink:0;min-width:280px} .mfp-kpi-card{background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 84%,var(--surface)));border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border));border-radius:16px;padding:.7rem .95rem;box-shadow:0 10px 22px rgba(15,23,42,.05)} .mfp-section-head{padding:1rem 1.2rem .15rem;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 82%,var(--surface)));border-bottom:1px solid var(--border)} .mfp-section-kicker{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary)} .mfp-section-note{margin-top:.2rem;font-size:.78rem;line-height:1.5;color:var(--text2)} .mfp-detail-grid{background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 84%,var(--surface)))} .mfp-history-shell{background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 88%,var(--surface)))} .mfp-tabs-shell{padding:.65rem .8rem 0;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 88%,var(--surface)));gap:.45rem;flex-wrap:wrap} .mfp-tabs-shell .mfp-tab{position:relative;flex:0 0 auto !important;padding:.78rem 1rem !important;border-radius:14px 14px 0 0;min-width:160px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface2) 90%,var(--surface)),var(--surface)) !important;color:var(--text2) !important;border:1px solid transparent !important;border-bottom:2px solid transparent !important;transition:all var(--transition)} .mfp-tabs-shell .mfp-tab.active{background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--primary-light) 40%,var(--surface))) !important;color:var(--primary) !important;border-color:color-mix(in srgb,var(--primary) 12%,var(--border)) !important;border-bottom-color:var(--primary) !important;box-shadow:0 -8px 22px rgba(37,99,235,.06)} .mfp-tabs-shell .mfp-tab:hover{color:var(--primary) !important;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--primary-light) 32%,var(--surface))) !important} .mfp-tab-toolbar{padding:.95rem 1rem;border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border));border-radius:18px;background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 18%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),var(--surface2))} .mfp-legend-row{padding:.65rem .85rem;border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,var(--surface),var(--surface2))} .onboarding-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem} .onboarding-card{border:1px solid var(--border);background:var(--surface2);border-radius:18px;padding:1rem} .onboarding-icon{width:44px;height:44px;border-radius:14px;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:.8rem} .onboarding-title{font-size:.92rem;font-weight:700;color:var(--text);margin-bottom:.35rem} .onboarding-text{font-size:.8rem;line-height:1.55;color:var(--text2)} .onboarding-highlight{margin-top:1rem;padding:1rem;border-radius:18px;background:linear-gradient(135deg,var(--primary-light),rgba(37,99,235,.06));border:1px solid rgba(37,99,235,.12)} /* ── ALERTS / TOAST ── */ .toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.7rem} .toast{position:relative;overflow:hidden;background:color-mix(in srgb,var(--surface) 94%,#ffffff 6%);border:1px solid var(--border);border-radius:16px;padding:.95rem 1rem .95rem 1.05rem;display:flex;align-items:flex-start;gap:.8rem;box-shadow:0 18px 48px rgba(15,23,42,.14);animation:toastIn .3s ease;min-width:290px;max-width:360px;backdrop-filter:blur(12px)} @keyframes toastIn{from{opacity:0;transform:translateX(16px)}} .toast.hide{animation:toastOut .3s ease forwards} @keyframes toastOut{to{opacity:0;transform:translateX(16px)}} .toast-accent{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary)} .toast-icon{font-size:1.02rem;flex-shrink:0;margin-top:.15rem} .toast-body{flex:1;min-width:0} .toast-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem} .toast-body .toast-title{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.2} .toast-body .toast-msg{font-size:.79rem;color:var(--text2);margin-top:.28rem;line-height:1.45} .toast-close{border:none;background:transparent;color:var(--text3);cursor:pointer;flex-shrink:0;padding:.1rem;font-size:.78rem;transition:color var(--transition),transform var(--transition)} .toast-close:hover{color:var(--text);transform:scale(1.05)} .toast.success .toast-icon,.toast.success .toast-accent{color:var(--success);background:var(--success)} .toast.error .toast-icon,.toast.error .toast-accent{color:var(--danger);background:var(--danger)} .toast.warning .toast-icon,.toast.warning .toast-accent{color:var(--warning);background:var(--warning)} .toast.info .toast-icon,.toast.info .toast-accent{color:var(--primary);background:var(--primary)} @media(max-width:640px){ .toast-container{left:1rem;right:1rem;bottom:1rem} .toast{min-width:0;max-width:none;width:100%} .app-transition-overlay{left:0 !important} } /* ── SECTIONS ── */ .section{display:none;background:var(--bg)} .section.active{display:block} .page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem} .page-header h2{font-size:1.2rem;font-weight:600;color:var(--text)} .page-header p{font-size:.82rem;color:var(--text3);margin-top:.15rem} /* ── 2-COL LAYOUT ── */ .col2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem} .col3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.2rem} .col4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem} .closure-layout{display:grid;grid-template-columns:minmax(0,1.75fr) minmax(340px,.95fr);gap:1.2rem;align-items:start} .closure-layout > div:first-child{margin-bottom:0} .closure-side-card{min-width:0;overflow:hidden} .closure-side-card .table-wrap{padding-right:.25rem} @media(max-width:900px){.col2,.col3,.col4{grid-template-columns:1fr}} /* ── CHART CONTAINERS ── */ .chart-wrap{position:relative;width:100%;height:200px} /* ── HEAT MAP ── */ .heatmap{display:grid;gap:4px;margin-top:.75rem} .heatmap-row{display:flex;gap:4px;align-items:center} .heatmap-label{font-size:.7rem;color:var(--text3);width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap} .heatmap-cells{display:flex;gap:4px;flex:1} .hm-cell{flex:1;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:600;cursor:default;transition:transform var(--transition)} .hm-cell:hover{transform:scale(1.1)} .hm-ok{background:var(--success-light);color:#059669} .hm-late{background:var(--warning-light);color:#b45309} .hm-absent{background:var(--danger-light);color:#dc2626} .hm-holiday{background:var(--surface2);color:var(--text3)} .hm-future{background:var(--surface2);color:transparent} .heatmap-head{display:flex;gap:4px;margin-left:84px;margin-bottom:2px} .heatmap-head span{flex:1;text-align:center;font-size:.65rem;color:var(--text3);font-weight:600} /* ── CLOCK ── */ .clock-display{font-family:'DM Mono',monospace;font-size:3rem;font-weight:500;color:var(--text);letter-spacing:-1px} .clock-date{font-size:.85rem;color:var(--text3);margin-top:.25rem} /* ── STEP FORM ── */ .step-header{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:1px solid var(--border);padding-bottom:0} .step-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.5rem;cursor:pointer;opacity:.5;transition:opacity var(--transition);position:relative} .step-item.active,.step-item.done{opacity:1} .step-item::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:transparent;border-radius:99px} .step-item.active::after{background:var(--primary)} .step-item.done::after{background:var(--success)} .step-num{width:26px;height:26px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--text2)} .step-item.active .step-num{background:var(--primary);color:#fff} .step-item.done .step-num{background:var(--success);color:#fff} .step-label{font-size:.72rem;font-weight:500;color:var(--text3);text-align:center} .step-panel{display:none} .step-panel.active{display:block} .employee-form-modal{max-width:min(1020px,96vw)} .employee-form-modal .modal-body{padding:1.35rem 1.5rem 1.5rem} .employee-form-intro{padding:.95rem 1rem;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,var(--surface),var(--surface2));margin-bottom:1rem} .employee-form-intro-title{font-size:.96rem;font-weight:700;color:var(--text);margin-bottom:.25rem} .employee-form-intro-text{font-size:.8rem;line-height:1.55;color:var(--text2)} .employee-form-section{display:grid;gap:.75rem;padding:1rem 1.05rem;border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:0 1px 2px rgba(15,23,42,.04)} .employee-form-section-head{display:grid;gap:.18rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)} .employee-form-section-title{font-size:.98rem;font-weight:700;color:var(--text)} .employee-form-section-text{font-size:.79rem;line-height:1.55;color:var(--text2)} .employee-form-grid{display:grid;gap:.75rem} .employee-form-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))} .employee-field-hint{margin-top:.38rem;font-size:.74rem;line-height:1.45;color:var(--text3)} @media(max-width:760px){ .employee-form-modal .modal-body{padding:1rem} .employee-form-grid-2{grid-template-columns:1fr} .report-selected-top{flex-direction:column} .report-selected-meta{max-width:none;width:100%} .report-filter-grid{grid-template-columns:1fr} .closure-summary-strip{grid-template-columns:1fr} .closure-layout{grid-template-columns:1fr} } /* ── DARK MODE TOGGLE ── */ .theme-toggle{display:flex;align-items:center;gap:.5rem;background:var(--surface2);border-radius:99px;padding:.25rem;cursor:pointer;border:none} .toggle-thumb{width:28px;height:28px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all var(--transition);box-shadow:0 1px 4px rgba(0,0,0,.15)} .theme-label{font-size:.75rem;color:var(--text3);padding:0 .3rem} /* ── CHART COLORS ── */ .chart-legend{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.75rem} .legend-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text2)} .legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0} /* ── RESPONSIVE ── */ @media(max-width:768px){ .login-route-shell{width:100vw;max-width:100vw} .login-route-access{padding:1.25rem 1rem} .login-route-card{max-width:none;width:100%} .login-brand{padding:5.3rem 1.6rem 1.6rem} .login-form-side{position:absolute;inset:0;z-index:3;padding:1.5rem} .login-screen .login-brand{display:none} .login-wrap.show-access .login-brand{display:none} .login-wrap.show-access .login-form-side{transform:none} .page-content{padding:1rem} .stat-grid{grid-template-columns:1fr 1fr} .stats-grid{grid-template-columns:1fr 1fr} .topbar{padding:0 1rem} .onboarding-grid{grid-template-columns:1fr} .landing-surface{padding:0 16px 32px} .landing-topbar-shell{width:calc(100% - 32px);padding:16px 18px;border-radius:20px} .landing-inline-link{display:none} .landing-headline{font-size:2.6rem} .landing-subheadline{font-size:.98rem} .landing-hero-v2{grid-template-columns:1fr;gap:18px;padding-top:28px} .landing-hero-stage{min-height:760px} .landing-stage-card-main{position:relative;right:auto;top:auto;width:100%} .landing-stage-card-float,.landing-stage-card-side{position:relative;left:auto;right:auto;bottom:auto;transform:none;width:100%;margin-top:14px} .landing-trust-band,.landing-module-grid,.landing-role-grid,.landing-compliance-grid,.landing-faq-grid{grid-template-columns:1fr} .landing-stage-grid,.landing-stage-strip{grid-template-columns:1fr 1fr} .landing-cta-panel{grid-template-columns:1fr} .login-route-feature-grid,.login-route-showcase-grid,.login-route-mini-metrics{grid-template-columns:1fr} } @media(max-width:1120px){ .landing-hero{grid-template-columns:1fr} .landing-showcase{height:420px} .phone-main{right:auto;left:50%;transform:translateX(-10%) rotate(4deg)} .phone-float{left:50%;transform:translateX(-95%) rotate(-8deg)} .landing-hero-v2{grid-template-columns:1fr} .landing-headline{font-size:3.2rem} .landing-hero-stage{min-height:640px} .landing-trust-band,.landing-module-grid,.landing-role-grid,.landing-compliance-grid,.landing-faq-grid{grid-template-columns:1fr 1fr} .landing-cta-panel{grid-template-columns:1fr} } @media(min-width:1121px){ .login-brand{padding:6.4rem 3.4rem 2.6rem} .landing-topbar{left:2.4rem;right:2.4rem} } @media(max-width:480px){ .stat-grid{grid-template-columns:1fr} .stats-grid{grid-template-columns:1fr} .sidebar{position:absolute;transform:translateX(-100%);height:100%} .sidebar.mobile-open{transform:translateX(0)} .topbar-sidebar-toggle{display:flex} } /* ── MISC ── */ .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text3);text-align:center} .empty-state .empty-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.4} .empty-state p{font-size:.85rem} .notif-empty-state{padding:2rem 1rem;border:1px dashed var(--border);border-radius:18px;background:linear-gradient(180deg,var(--surface),var(--surface2))} .notif-list{display:flex;flex-direction:column;gap:.8rem} .notif-card{display:flex;align-items:flex-start;gap:.9rem;padding:1rem;border:1px solid var(--border);border-radius:16px;background:var(--surface);transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);cursor:pointer} .notif-card:hover{border-color:color-mix(in srgb,var(--primary) 24%,var(--border));transform:translateY(-1px);box-shadow:var(--shadow)} .notif-card.unread{border-color:color-mix(in srgb,var(--primary) 28%,var(--border));background:linear-gradient(180deg,var(--surface),var(--primary-light))} .notif-card.read{opacity:.82} .notif-icon{width:40px;height:40px;border-radius:14px;background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0} .notif-main{flex:1;min-width:0} .notif-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem} .notif-title{font-size:.88rem;font-weight:700;color:var(--text)} .notif-time{font-size:.72rem;color:var(--text3);white-space:nowrap} .notif-body{font-size:.79rem;color:var(--text2);margin-top:.3rem;line-height:1.5} .notif-chip{display:inline-flex;align-items:center;gap:.35rem;margin-top:.55rem;padding:.28rem .55rem;border-radius:999px;background:var(--surface2);color:var(--text2);font-size:.68rem;font-weight:700} .divider-line{height:1px;background:var(--border);margin:1rem 0} .request-op-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem} .ops-shell{display:grid;gap:0} .ops-form-grid{margin-bottom:0} .ops-form-card,.ops-filter-card,.ops-summary-card,.ops-table-card{background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 18%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 86%,var(--surface))); border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border)); box-shadow:0 12px 28px rgba(15,23,42,.05)} .ops-filter-card .filter-bar{align-items:end} .ops-table-card .table-wrap{border-radius:18px;overflow:auto} .config-shell{display:grid;gap:0} .config-layout{margin-bottom:0} .config-panel-card{background: radial-gradient(circle at top right, color-mix(in srgb,var(--primary-light) 16%,transparent), transparent 34%), linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 88%,var(--surface))); border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border)); box-shadow:0 12px 28px rgba(15,23,42,.05)} .config-panel-card #jornadasList{display:grid;gap:.75rem} .config-panel-card #jornadasList > *{border-radius:16px} .request-op-card{background:linear-gradient(180deg,var(--surface),var(--surface2));border:1px solid color-mix(in srgb,var(--primary) 8%,var(--border));border-radius:18px;padding:1rem;box-shadow:0 10px 22px rgba(15,23,42,.05);min-height:100%} .request-op-card h4{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:.8rem} .request-op-metrics{display:grid;gap:.45rem} .request-op-metrics div,.request-op-list div{font-size:.82rem;color:var(--text2);line-height:1.5} .request-op-list{display:grid;gap:.45rem} @media (max-width: 1100px){ .request-op-grid{grid-template-columns:1fr} .setup-guide-grid{grid-template-columns:1fr} } .text-muted{color:var(--text3);font-size:.8rem} .text-success{color:var(--success)} .text-danger{color:var(--danger)} .text-warning{color:var(--warning)} .gap-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap} .ml-auto{margin-left:auto} .fw-6{font-weight:600} .fs-sm{font-size:.78rem} .mt-1{margin-top:.5rem} .mb-1{margin-bottom:.5rem} .mb-2{margin-bottom:1rem} textarea.form-control{resize:vertical;min-height:80px} .priority-list,.ops-list{display:flex;flex-direction:column;gap:.75rem} .priority-item,.ops-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.85rem .95rem;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,var(--surface),var(--surface2))} .priority-item:last-child,.ops-item:last-child{padding-bottom:.85rem} .priority-item:first-child,.ops-item:first-child{padding-top:.85rem} .priority-main,.ops-main{display:flex;flex-direction:column;gap:.2rem;min-width:0;flex:1} .priority-title,.ops-title{font-size:.85rem;font-weight:600;color:var(--text)} .priority-desc,.ops-desc{font-size:.76rem;color:var(--text2);line-height:1.5;overflow-wrap:anywhere} .priority-value,.ops-value{font-size:.78rem;font-weight:600;color:var(--text3);white-space:normal;overflow-wrap:anywhere} .profile-meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem} .profile-meta-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.8rem .9rem} .profile-meta-label{font-size:.68rem;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem} .profile-meta-value{font-size:.84rem;color:var(--text);font-weight:500;word-break:break-word} .mfp-modal #mfpHeader{padding:1.55rem 1.6rem;gap:1.35rem;align-items:flex-start} .mfp-modal #mfpDetails{padding:1rem 1.2rem} .mfp-modal .profile-meta-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem} .mfp-modal .profile-meta-card{min-height:74px} .mfp-modal .profile-meta-card{background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 88%,var(--surface)));border-color:color-mix(in srgb,var(--primary) 8%,var(--border))} .mfp-modal .table-wrap{border:1px solid color-mix(in srgb,var(--primary) 8%,var(--border));border-radius:18px;background:var(--surface);overflow:auto} .mfp-modal .table-wrap table thead th{background:color-mix(in srgb,var(--surface2) 82%,var(--surface))} .mfp-modal .table-wrap table tbody tr:hover td{background:color-mix(in srgb,var(--primary-light) 72%,var(--surface))} .mfp-modal #mfpHistoryList .timeline-item, .mfp-modal #mfpHistoryList > div{border-radius:14px} .mfp-modal #mfpHistoryList > .priority-item{padding:.8rem .95rem} .mfp-modal #mfpTab-espelho, .mfp-modal #mfpTab-bh, .mfp-modal #mfpTab-ocorrencias, .mfp-modal #mfpTab-sobreaviso{padding:1.15rem 1.2rem;max-height:none;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface2) 92%,var(--surface)))} @media(max-width:900px){.profile-meta-grid{grid-template-columns:1fr 1fr}} @media(max-width:560px){.profile-meta-grid{grid-template-columns:1fr}} @media(max-width:1100px){ .mfp-modal .profile-meta-grid{grid-template-columns:repeat(3,minmax(0,1fr))} } @media(max-width:900px){ .mfp-modal{max-width:min(96vw,860px)} .mfp-modal #mfpHeader{flex-wrap:wrap} .mfp-hero-metrics{min-width:0;width:100%} .mfp-tabs-shell .mfp-tab{min-width:calc(50% - .35rem);flex:1 1 calc(50% - .35rem) !important} .mfp-modal .profile-meta-grid{grid-template-columns:1fr 1fr} } @media(max-width:680px){ .mfp-modal{max-width:100%;max-height:94vh} .mfp-modal #mfpHeader{padding:1.2rem 1rem} .mfp-modal #mfpDetails{padding:1rem} .mfp-tabs-shell{padding:.55rem .55rem 0} .mfp-tabs-shell .mfp-tab{min-width:100%;flex:1 1 100% !important;border-radius:12px} .mfp-modal .profile-meta-grid{grid-template-columns:1fr} } .permission-card{padding:1rem;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,var(--surface),var(--surface2));box-shadow:var(--shadow-sm)} .permission-card-title{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:.8rem} .permission-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem .75rem} .permission-check{display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--text2);padding:.45rem .55rem;border:1px solid var(--border);border-radius:12px;background:var(--surface)} .permission-check input{accent-color:var(--primary)} .master-settings-shell{display:grid;gap:1rem} .master-settings-panel{padding:1rem 1.05rem;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,#ffffff,#f8fbff);box-shadow:var(--shadow-sm)} .master-settings-panel-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1rem} .master-settings-panel-head h5{margin:0 0 .25rem;font-size:1rem;color:var(--text)} .master-settings-panel-head p{margin:0;color:var(--text3);font-size:.86rem;line-height:1.55} .master-rule-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem} .master-rule-card{display:flex;align-items:flex-start;gap:.8rem;padding:1rem;border:1px solid #dbe7fb;border-radius:18px;background:#fff;box-shadow:0 10px 26px rgba(15,23,42,.04);cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease} .master-rule-card:hover{border-color:#bfd3fb;box-shadow:0 16px 36px rgba(37,99,235,.08);transform:translateY(-1px)} .master-rule-card input{margin-top:.15rem;accent-color:var(--primary)} .master-rule-card strong{display:block;font-size:.9rem;color:var(--text);margin-bottom:.25rem} .master-rule-card span{display:block;font-size:.82rem;line-height:1.55;color:var(--text3)} .master-contract-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;margin-bottom:1rem} .master-contract-metric{padding:.95rem 1rem;border:1px solid #dbe7fb;border-radius:18px;background:linear-gradient(180deg,#f9fbff,#eef5ff)} .master-contract-metric span{display:block;font-size:.78rem;color:var(--text3);margin-bottom:.28rem} .master-contract-metric strong{font-size:1.05rem;color:var(--text)} .geofence-toolbar{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:.9rem} .geofence-map{height:280px;border:1px solid var(--border);border-radius:18px;overflow:hidden;margin-top:.9rem;box-shadow:var(--shadow-sm);background:#e5eefb} .leaflet-container{font-family:'DM Sans',sans-serif} @media(max-width:860px){.permission-grid{grid-template-columns:1fr}} @media(max-width:1100px){ .master-login-layout{grid-template-columns:1fr} .master-login-brand{padding:32px} .master-login-brand h1{font-size:2.4rem} .master-shell{grid-template-columns:1fr} .master-sidebar{display:none} .master-sidebar-toggle{display:none} .master-hero-grid{grid-template-columns:1fr} .master-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))} .master-chart-shell,.master-summary-strip,.master-switch-grid,.master-detail-metrics,.master-users-layout,.master-hero-points,.master-catalog-grid,.master-plan-grid,.master-resource-strip,.master-setup-summary-grid,.master-stage-grid,.master-validation-grid,.master-activation-grid,.master-rh-grid{grid-template-columns:1fr} .master-chart-card-wide{grid-column:auto} .master-current-card{max-width:none;min-width:0;width:100%} .master-form-grid,.master-feature-grid,.master-setup-stepper{grid-template-columns:1fr} .master-rule-grid,.master-contract-summary{grid-template-columns:1fr} .master-current-pill-list,.master-chart-filter-grid,.master-chart-toolbar-stats{grid-template-columns:1fr} .master-chart-toolbar-shell{grid-template-columns:1fr} .master-resource-list{grid-template-columns:1fr} .master-spotlight-card{grid-template-columns:1fr} .master-command-bar{flex-direction:column;align-items:stretch} .master-command-search{max-width:none} .master-command-actions,.master-detail-actions,.master-detail-footer{justify-content:stretch} .master-detail-actions .btn,.master-detail-footer .btn{flex:1} .master-permission-row{grid-template-columns:1fr} } @media(max-width:640px){ .master-login-panel,.master-login-brand{padding:20px} .master-login-brand h1{font-size:2rem} .master-page-content{padding:18px} .master-topbar{padding:18px} .master-topbar-actions{width:100%;justify-content:stretch} .master-topbar-actions .btn{flex:1} .master-kpi-grid,.master-current-grid,.master-catalog-grid,.master-plan-grid,.master-chart-shell{grid-template-columns:1fr} .master-tabs{flex-direction:column} .master-tab{width:100%;justify-content:flex-start} }