*,:before,:after{box-sizing:border-box}html,body{-webkit-text-size-adjust:100%;width:100%;max-width:100vw;overflow-x:hidden}input,select,textarea{font-size:16px!important}:root{--terra:#a33e09;--terra-light:#fc804a;--terra-bg:#fff3ec;--dark:#15305a;--sand:#f4f1ee;--sand-dark:#e8e4e0;--sage:#a7beae;--sage-dark:#7fa08b;--white:#fff;--gray:#747780;--gray-light:#c4c6d0;--gray-lighter:#eae7e7;--text:#1b1c1c;--text-muted:#44474f;--blue:#465e8b;--amber:#a33e09;--font-display:"Plus Jakarta Sans", "Segoe UI", system-ui, sans-serif;--font-body:"Manrope", "Segoe UI", system-ui, sans-serif;--sidebar-w:260px;--radius:16px;--shadow:0 2px 8px #15305a0a, 0 8px 24px #15305a08;--shadow-hover:0 4px 12px #15305a14, 0 12px 32px #15305a0f;--glass-bg:#ffffff73;--glass-border:#ffffff59;--glass-blur:20px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--text);background:var(--sand);-webkit-font-smoothing:antialiased;background-image:radial-gradient(at 20% 0,#a33e0917 0%,#0000 55%),radial-gradient(at 80% 100%,#15305a17 0%,#0000 55%),radial-gradient(#a7beae0f 0%,#0000 70%);background-attachment:fixed;min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);color:var(--white);z-index:100;background:linear-gradient(#15305a 0%,#1a3a6e 100%);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff14;flex-direction:column;align-items:center;gap:6px;padding:24px 20px;display:flex}.brand-mark{background:var(--terra);width:40px;height:40px;font-family:var(--font-display);letter-spacing:-.5px;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.brand-logo{object-fit:contain;border-radius:6px;flex-shrink:0;width:32px;height:32px}.brand-logo-full{object-fit:contain;width:100%;max-width:140px;height:auto}.brand-text{flex-direction:column;display:flex}.brand-name{letter-spacing:.2px;font-size:15px;font-weight:600}.brand-sub{color:#ffffff80;text-align:center;margin-top:2px;font-size:11px}.sidebar-nav{flex:1;padding:16px 12px;list-style:none}.nav-item{cursor:pointer;color:#fff9;border-radius:10px;align-items:center;gap:12px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{color:#ffffffe6;background:#ffffff14}.nav-item.active{color:var(--white);-webkit-backdrop-filter:blur(8px);background:#ffffff1f;border:1px solid #ffffff1a}.nav-item svg{opacity:.7;flex-shrink:0}.nav-item.active svg{opacity:1}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.sidebar-user{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--sage-dark);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:600;display:flex}.user-info{flex-direction:column;display:flex}.logout-btn{color:#fff9;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;align-items:center;gap:6px;width:100%;margin-top:12px;padding:8px 12px;font-size:12px;font-weight:500;transition:background .15s,color .15s;display:flex}.logout-btn:hover{color:#ffffffe6;background:#ffffff1f}.logout-btn svg{opacity:.7}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--gray);font-size:11px}.mobile-logout-btn{width:34px;height:34px;color:var(--gray,#888);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;display:none}.mobile-logout-btn:active{background:#0000001a}@media (width<=768px){.mobile-logout-btn{display:flex}}.main{margin-left:var(--sidebar-w);flex:1;max-width:1200px;padding:0 40px 40px;overflow-x:hidden}.header{justify-content:space-between;align-items:center;margin-bottom:28px;padding:32px 0 24px;display:flex}.page-title{font-family:var(--font-display);color:var(--dark);letter-spacing:-.5px;font-size:28px;font-weight:700}.header-sub-row{align-items:baseline;gap:12px;margin-top:4px;display:flex}.page-subtitle{color:var(--text-muted);font-size:14px}.header-date{color:var(--text-muted);font-size:13px;font-weight:500}.guide-fab{-webkit-backdrop-filter:blur(12px);color:#fff;z-index:90;-webkit-tap-highlight-color:transparent;background:#15305ad9;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;font-weight:700;text-decoration:none;transition:all .2s;display:flex;position:fixed;bottom:90px;right:16px;box-shadow:0 4px 16px #15305a40}.guide-fab:hover{transform:scale(1.1);box-shadow:0 6px 20px #15305a59}.guide-fab:active{transform:scale(.95)}@media (width>=769px){.guide-fab{bottom:24px;right:24px}}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:16px;padding:20px;transition:all .25s;display:flex}.stat-card:hover{box-shadow:var(--shadow-hover);background:#fffc;transform:translateY(-1px)}.stat-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.stat-icon-terra{background:var(--terra-bg);color:var(--terra)}.stat-icon-sage{color:var(--sage-dark);background:#eef4f0}.stat-icon-blue{color:var(--blue);background:#edf4f7}.stat-icon-amber{color:var(--amber);background:#fdf6ec}.stat-content{flex-direction:column;display:flex}.stat-value{letter-spacing:-.5px;font-size:26px;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);margin-top:4px;font-size:12px;font-weight:500}.content-grid{grid-template-columns:1fr 320px;gap:20px;margin-bottom:24px;display:grid}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-large{grid-column:1}.card>.card-body{-webkit-overflow-scrolling:touch;max-height:65vh;overflow-y:auto}.card-header{border-bottom:1px solid var(--gray-lighter);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.card-header h2{font-family:var(--font-display);color:var(--dark);font-size:17px;font-weight:700}.card-body{padding:24px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.empty-state svg{color:var(--gray-light);margin-bottom:16px}.empty-state p{color:var(--text-muted);font-size:14px}.empty-hint{color:var(--gray);margin-top:6px;font-size:13px}.action-btn{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);width:100%;font-family:var(--font-body);color:var(--text);cursor:pointer;text-align:left;border:1px solid #fff9;border-radius:12px;align-items:center;gap:10px;margin-bottom:8px;padding:14px 18px;font-size:14px;font-weight:500;transition:all .2s;display:flex;position:relative}.action-btn:hover:not(:disabled){border-color:var(--terra-light);background:var(--terra-bg)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-primary{background:linear-gradient(135deg, var(--terra) 0%, #c4501a 100%);color:var(--white);border-color:#0000;box-shadow:0 4px 16px #a33e0940}.action-primary:hover:not(:disabled){background:linear-gradient(135deg,#b84710 0%,#d45a22 100%);border-color:#0000;transform:translateY(-1px);box-shadow:0 6px 20px #a33e094d}.action-primary svg{opacity:.9}.badge-soon{text-transform:uppercase;letter-spacing:.5px;color:var(--gray);background:var(--gray-lighter);border-radius:10px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:600}.telegram-card{border:1px solid #e3edf3}.telegram-body{align-items:center;gap:20px;display:flex}.telegram-icon{color:#2aabee;background:#e3edf3;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.telegram-content{flex:1}.telegram-content h3{margin-bottom:4px;font-size:14px;font-weight:600}.telegram-content p{color:var(--text-muted);font-size:13px;line-height:1.5}.telegram-btn{color:var(--white);white-space:nowrap;background:#2aabee;border-radius:6px;flex-shrink:0;align-items:center;padding:10px 20px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.telegram-btn:hover{background:#229ed9}.upload-zone{border:2px dashed var(--gray-light);border-radius:var(--radius);text-align:center;cursor:pointer;padding:48px 32px;transition:all .2s}.upload-zone:hover,.upload-zone.dragover{border-color:var(--terra);background:var(--terra-bg)}.upload-zone svg{color:var(--gray-light);margin-bottom:12px}.upload-zone:hover svg{color:var(--terra-light)}.upload-title{color:var(--text);margin-bottom:4px;font-size:16px;font-weight:600}.upload-hint{color:var(--text-muted);font-size:13px}.upload-formats{color:var(--gray);margin-top:12px;font-size:11px}.upload-form{margin-top:20px}.file-preview{background:var(--sand);border-radius:6px;align-items:center;gap:12px;margin-bottom:20px;padding:14px 16px;display:flex}.file-preview svg{color:var(--terra);flex-shrink:0}.file-info{flex-direction:column;flex:1;display:flex}.file-name{font-size:14px;font-weight:600}.file-size{color:var(--text-muted);font-size:12px}.file-remove{width:28px;height:28px;color:var(--gray);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex}.file-remove:hover{background:var(--gray-lighter);color:var(--terra)}.form-group{margin-bottom:16px}.form-group label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group select,.form-group input,.form-group textarea{border:1px solid var(--gray-lighter);width:100%;font-family:var(--font-body);color:var(--text);background:var(--white);border-radius:6px;padding:10px 14px;font-size:16px;transition:border-color .15s}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{border-color:var(--terra);outline:none}.form-group textarea{resize:vertical}.btn-primary{background:linear-gradient(135deg, var(--terra) 0%, #c4501a 100%);color:var(--white);font-family:var(--font-body);cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:12px 28px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 4px 14px #a33e0933}.btn-primary:hover{background:linear-gradient(135deg,#b84710 0%,#d45a22 100%);transform:translateY(-1px);box-shadow:0 6px 20px #a33e094d}.btn-secondary{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);font-family:var(--font-body);color:var(--text);cursor:pointer;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.btn-secondary:hover{border-color:var(--terra);color:var(--terra);background:#fffc}.processing{flex-direction:column;align-items:center;padding:40px 20px;display:flex}.processing-spinner{border:3px solid var(--gray-lighter);border-top-color:var(--terra);border-radius:50%;width:48px;height:48px;margin-bottom:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.processing-steps{width:100%;max-width:400px}.step{color:var(--gray);align-items:center;gap:12px;padding:10px 0;font-size:13px;display:flex}.step.active{color:var(--text);font-weight:500}.step.done{color:var(--sage-dark)}.step-dot{background:var(--gray-lighter);border-radius:50%;flex-shrink:0;width:8px;height:8px}.step.active .step-dot{background:var(--terra);animation:1.5s infinite pulse}.step.done .step-dot{background:var(--sage-dark)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.4)}}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.content-grid{grid-template-columns:1fr}}@media (width<=768px){.sidebar{display:none}.main{width:100%;max-width:100vw;margin-left:0;padding:0 12px 80px}.mobile-logo{display:block!important}.header{align-items:center;margin-bottom:16px;padding:16px 0 12px}.page-title{font-size:23px}.header-sub-row{flex-wrap:wrap;gap:6px}.page-subtitle{font-size:12px}.header-date{font-size:11px}.stats-grid{grid-template-columns:1fr 1fr}.telegram-body{text-align:center;flex-direction:column}.card-header{gap:8px;padding:14px 16px}.card-body{padding:16px}.card-header h2{font-size:16px}.btn-secondary{white-space:nowrap;padding:6px 12px;font-size:13px}.mobile-nav{-webkit-backdrop-filter:blur(24px)saturate(180%);z-index:1000;padding:6px 0 env(safe-area-inset-bottom,8px);background:#ffffff80;border-top:1px solid #ffffff4d;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:var(--gray);cursor:pointer;font-size:10px;font-weight:600;font-family:var(--font-body);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 4px;text-decoration:none;display:flex}.mobile-nav-item.active{color:var(--terra)}.mobile-nav-item svg{width:22px;height:22px}}body.record-page{background-image:none;display:block}body.record-page #root{width:100%;min-height:100dvh}body.record-page:after,body.record-page .sidebar,body.record-page .mobile-nav,body.record-page .guide-fab{display:none!important}@media (width>=769px){.mobile-nav{display:none}body:after{content:"";pointer-events:none;z-index:0;opacity:.03;background:url(/img/gimmick-bg.png) 50%/80vmin no-repeat;position:fixed;inset:0}.main{z-index:1;position:relative}}a.nav-item,a.mobile-nav-item{color:inherit;text-decoration:none}.wizard-banner{z-index:100;-webkit-backdrop-filter:blur(12px);background:#ffffff1f;border-bottom:1px solid #ffffff26;align-items:center;gap:16px;height:44px;padding:0 20px;display:flex;position:sticky;top:0}.wizard-banner__ppe{white-space:nowrap;text-overflow:ellipsis;flex:1;margin:0;font-family:Plus Jakarta Sans,sans-serif;font-size:15px;font-weight:700;overflow:hidden}.wizard-banner__counter{opacity:.7;white-space:nowrap;font-size:12px}.wizard-banner__dots{align-items:center;gap:6px;display:flex}.wizard-banner__dot{background:#ffffff4d;border-radius:50%;width:6px;height:6px;transition:background .2s}.wizard-banner__dot--active{background:#ffffffe6}.wizard-banner__dot--done{background:#fff9}.wizard-container{flex-direction:column;height:100%;min-height:0;display:flex}.wizard-stepper{border-bottom:1px solid #ffffff1a;align-items:center;gap:8px;padding:16px 20px;display:flex}.wizard-step{opacity:.4;flex:1;align-items:center;gap:8px;transition:opacity .2s;display:flex}.wizard-step--active{opacity:1}.wizard-step--done{opacity:.7}.wizard-step__number{background:#ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.wizard-step--active .wizard-step__number{color:#1a1a2e;background:#ffffffe6}.wizard-step--done .wizard-step__number{background:#ffffff80}.wizard-step__label{white-space:nowrap;font-family:Manrope,sans-serif;font-size:13px}@media (width<=767px){.wizard-step__label{display:none}}.wizard-content{flex:1;padding:24px 20px;overflow-y:auto}.wizard-placeholder{opacity:.6;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:48px;font-family:Manrope,sans-serif;display:flex}.wizard-nav{border-top:1px solid #ffffff1a;justify-content:flex-end;gap:12px;padding:16px 20px;display:flex}.nav-section-title{text-transform:uppercase;letter-spacing:.08em;opacity:.5;align-items:center;gap:8px;padding:12px 16px 4px;font-family:Manrope,sans-serif;font-size:11px;font-weight:700;display:flex}.graph-api-badge{border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-family:Manrope,sans-serif;font-size:10px;font-weight:600;display:inline-flex}.graph-api-badge--connected{color:#81c784;background:#4caf5033}.graph-api-badge--disconnected{color:#e57373;background:#f4433626}.graph-api-badge__dot{background:currentColor;border-radius:50%;width:5px;height:5px}.dropzone-upload{flex-direction:column;gap:1rem;display:flex}.dropzone-area{text-align:center;cursor:pointer;background:#ffffff08;border:2px dashed #ffffff40;border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem 2rem;transition:border-color .2s,background .2s;display:flex}.dropzone-area:hover,.dropzone-area--active{background:#ffffff12;border-color:#ffffff8c}.dropzone-icon{font-size:2rem}.dropzone-area__label{color:#ffffffd9;font-size:1rem}.dropzone-area__hint{color:#fff6;font-size:.85rem}.dropzone-area__constraint{color:#ffffff59;margin-top:.25rem;font-size:.75rem}.dropzone-area__btn{margin-top:.25rem}.dropzone-errors{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.dropzone-error{color:#e57373;background:#f443361a;border-radius:6px;padding:.4rem .75rem;font-size:.85rem}.dropzone-filelist{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.dropzone-file{background:#ffffff0d;border-radius:8px;align-items:center;gap:.75rem;padding:.5rem .75rem;font-size:.875rem;display:flex}.dropzone-file__name{color:#ffffffe6;white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.dropzone-file__size{color:#fff6;flex-shrink:0;font-size:.75rem}.dropzone-file__remove{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:.1rem .3rem;font-size:.8rem;transition:color .15s}.dropzone-file__remove:hover{color:#e57373}.wizard-error{color:#e57373;background:#f443361a;border-radius:8px;padding:.5rem .75rem;font-size:.875rem}.wizard-step-content,.result-summary{flex-direction:column;gap:1.25rem;display:flex}.result-summary__banner{border-radius:10px;padding:1rem 1.25rem}.result-summary__banner--success{background:#4caf5026;border:1px solid #4caf504d}.result-summary__banner--warning{background:#ff980026;border:1px solid #ff98004d}.result-summary__banner--error{background:#f4433626;border:1px solid #f443364d}.result-summary__count{margin:0;font-size:1.1rem;font-weight:600}.result-summary__batch{opacity:.6;margin:.25rem 0 0;font-size:.75rem}.result-summary__failures{flex-direction:column;gap:.5rem;display:flex}.result-summary__failures-title{color:#e57373;margin:0;font-size:.95rem;font-weight:600}.result-summary__failures-list{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.result-summary__failure{background:#f4433614;border-radius:6px;gap:.75rem;padding:.4rem .6rem;font-size:.85rem;display:flex}.result-summary__failure-name{min-width:120px;font-weight:500}.result-summary__failure-email{opacity:.7}.result-summary__failure-error{color:#e57373;margin-left:auto}.result-summary__info{opacity:.8;background:#ffffff0a;border-radius:8px;padding:.75rem;font-size:.9rem}.wizard-confirm-summary{font-size:1rem}.result-summary__retry-success{color:#81c784;background:#4caf501a;border-radius:8px;padding:.5rem .75rem;font-size:.9rem;font-weight:500}.attestations-page{flex-direction:column;gap:2rem;display:flex}.attestations-divider{border:none;border-top:1px solid #ffffff14;margin:1rem 0}.ppe-dashboard{flex-direction:column;gap:1rem;display:flex}.dashboard-empty{opacity:.5;font-size:.9rem}.dashboard-today-badge{color:#81c784;background:#4caf5026;border-radius:20px;width:fit-content;padding:.35rem .75rem;font-size:.85rem;font-weight:500;display:inline-block}.dashboard-table{border-collapse:collapse;width:100%;font-size:.875rem}.dashboard-table th{text-align:left;opacity:.6;border-bottom:1px solid #ffffff14;padding:.5rem .75rem;font-weight:500}.dashboard-table td{border-bottom:1px solid #ffffff0a;padding:.5rem .75rem}.dashboard-cell--failed{color:#e57373;font-weight:500}
