.dashboard-layout{display:flex;min-height:100vh;background:var(--pg-bg-page)}.dashboard-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow-x:hidden}.dashboard-content{flex:1;padding:24px 28px 40px;overflow-y:auto}.dashboard-header{background:var(--pg-bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px 30px;border-radius:var(--pg-radius-lg);margin-bottom:30px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--pg-shadow-md)}.dashboard-header h1{font-size:32px;background:var(--pg-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-user-info{display:flex;align-items:center;gap:15px}.dashboard-avatar{width:40px;height:40px;border-radius:50%;background:var(--pg-gradient);display:flex;align-items:center;justify-content:center;color:var(--pg-text-white);font-weight:600}.btn-logout{background:#ef44441a;color:#dc2626;border:none;padding:10px 20px;border-radius:var(--pg-radius-sm);cursor:pointer;font-weight:600;transition:var(--pg-transition)}.btn-logout:hover{background:#dc2626;color:var(--pg-text-white)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}@media (max-width: 1024px){.dashboard-sidebar{display:none}}.pg-dash-root{min-height:calc(100vh - var(--pg-header-h) - 48px);margin:-24px -28px -40px}.pg-dash-hero{position:relative;padding:36px 40px 40px;background:var(--pg-bg-page)}.pg-dash-stat-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1280px;margin:0 auto}.pg-dash-stat-card{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:24px;cursor:pointer;box-shadow:0 2px 12px #0f172a0f;border:1px solid var(--pg-border-subtle);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;display:flex;flex-direction:column;position:relative;overflow:hidden}.pg-dash-stat-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--pg-accent-orange) 0%,#f59e0b 100%);border-radius:4px 0 0 4px;opacity:0;transition:opacity .25s ease}.pg-dash-stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #0f172a14;border-color:#0664c42e}.pg-dash-stat-card:hover:before{opacity:1}.pg-dash-stat-card__icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;padding:10px}.pg-dash-stat-card__icon--users{background:var(--pg-gradient)}.pg-dash-stat-card__icon--projects{background:linear-gradient(180deg,#5baef7,#0664c4)}.pg-dash-stat-card__icon--sections{background:linear-gradient(180deg,#7ec5fa,#2b80d9)}.pg-dash-stat-card__icon--sensors{background:linear-gradient(180deg,#5baef7,#0664c4)}.pg-dash-stat-card__icon img{width:100%;height:100%;object-fit:contain}.pg-dash-stat-card__value{font-size:32px;font-weight:800;color:var(--pg-text-primary);letter-spacing:-.02em;margin-bottom:2px;line-height:1.1}.pg-dash-stat-card__label{font-size:12px;font-weight:700;color:var(--pg-text-muted);text-transform:uppercase;letter-spacing:.08em}.pg-dash-body{padding:28px 40px 48px;background:var(--pg-bg-page)}.pg-dash-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;max-width:1280px;margin:0 auto}.pg-dash-panel{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:24px;border:1px solid var(--pg-border-subtle);box-shadow:0 2px 12px #0f172a0f;display:flex;flex-direction:column}.pg-dash-panel__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--pg-border-subtle)}.pg-dash-panel__head h3{font-size:16px;font-weight:800;color:var(--pg-text-primary);margin:0;letter-spacing:-.01em}.pg-dash-btn-ghost{padding:6px 16px;font-size:12px;font-weight:700;border-radius:var(--pg-radius-full);border:1.5px solid var(--pg-primary);background:transparent;color:var(--pg-primary);cursor:pointer;font-family:inherit;transition:var(--pg-transition);text-transform:uppercase;letter-spacing:.04em}.pg-dash-btn-ghost:hover{background:var(--pg-primary);color:#fff}.pg-dash-btn-ghost--accent{border-color:var(--pg-primary);color:var(--pg-primary)}.pg-dash-btn-ghost--accent:hover{background:var(--pg-primary);color:#fff}.pg-dash-row{padding:14px 16px;background:var(--pg-bg-input);border-radius:var(--pg-radius-md);cursor:pointer;transition:all .2s ease;border:1.5px solid transparent}.pg-dash-row:hover{background:var(--pg-bg-hover);border-color:#0664c433;transform:translate(2px)}.pg-dash-row--sensor:hover{border-color:#0664c433;background:var(--pg-bg-hover)}.pg-dash-list{display:flex;flex-direction:column;gap:10px}.pg-dash-row__content{display:flex;justify-content:space-between;align-items:center;gap:12px}.pg-dash-row__info{flex:1;min-width:0}.pg-dash-row__sensor{display:flex;align-items:center;gap:12px}.pg-dash-row__sensor-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(180deg,#5baef7,#0664c4);display:flex;align-items:center;justify-content:center;padding:8px;flex-shrink:0}.pg-dash-row__sensor-icon img{width:100%;height:100%;object-fit:contain}.pg-dash-row__title{font-size:14px;font-weight:700;color:var(--pg-text-primary);margin-bottom:3px}.pg-dash-row__title--with-id{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pg-dash-row__id{display:inline-flex;max-width:100%;color:var(--pg-primary);font-family:SF Mono,Consolas,monospace;font-size:11px;font-weight:800;overflow-wrap:anywhere}.pg-dash-row__meta{font-size:12px;color:var(--pg-text-muted)}.pg-dash-pill{padding:4px 10px;background:var(--pg-success-bg);color:var(--pg-success);border-radius:var(--pg-radius-full);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.pg-dash-empty{text-align:center;padding:40px 16px;color:var(--pg-text-placeholder);flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.pg-dash-empty img{width:56px;height:56px;object-fit:contain;margin:0 auto 14px;display:block;opacity:.7}.pg-dash-empty p{margin-bottom:14px;font-size:14px}.pg-dash-btn-primary{padding:10px 22px;background:var(--pg-gradient);color:#fff;border:none;border-radius:var(--pg-radius-md);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:none;transition:var(--pg-transition)}.pg-dash-btn-primary:hover{transform:translateY(-1px)}.pg-dash-panel--map{overflow:hidden}.pg-dash-map{position:relative;display:grid;gap:14px;flex:1}.pg-dash-map:before{content:"";position:absolute;top:28px;bottom:28px;left:25px;width:2px;border-radius:999px;background:linear-gradient(180deg,var(--pg-primary) 0%,var(--pg-accent-orange) 100%);opacity:.26}.pg-dash-map-node{position:relative;display:grid;grid-template-columns:52px minmax(0,1fr);gap:14px;align-items:center;min-height:82px;padding:14px;border:1px solid var(--pg-border-subtle);border-radius:16px;background:#f8fbff;color:inherit;cursor:pointer;font:inherit;text-align:left;transition:transform .22s ease,border-color .22s ease,background .22s ease}.pg-dash-map-node:hover{transform:translateY(-2px);border-color:var(--pg-accent-orange);background:#fff}.pg-dash-map-node__icon{position:relative;z-index:1;width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:#fff;border:1px solid var(--pg-border);padding:9px}.pg-dash-map-node__icon img{width:100%;height:100%;object-fit:contain}.pg-dash-map-node__copy{min-width:0;display:grid;gap:4px}.pg-dash-map-node__copy strong{color:var(--pg-text-primary);font-size:26px;line-height:1;font-weight:900;letter-spacing:0}.pg-dash-map-node__copy>span:not(.pg-dash-map-node__bar){color:var(--pg-text-muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.07em}.pg-dash-map-node__bar{width:100%;height:7px;margin-top:4px;overflow:hidden;border-radius:999px;background:#e9f2fb}.pg-dash-map-node__bar span{display:block;width:var(--node-fill);height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--pg-primary) 0%,var(--pg-accent-orange) 100%)}.pg-dash-map-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.pg-dash-map-stat{min-height:78px;padding:12px;border:1px solid var(--pg-border-subtle);border-radius:16px;background:#fff;cursor:pointer;font:inherit;text-align:left;transition:border-color .22s ease,transform .22s ease}.pg-dash-map-stat:hover{transform:translateY(-2px);border-color:var(--pg-accent-orange)}.pg-dash-map-stat span{display:block;color:var(--pg-text-muted);font-size:10px;font-weight:900;line-height:1.3;text-transform:uppercase;letter-spacing:.06em}.pg-dash-map-stat strong{display:block;margin-top:8px;color:var(--pg-text-primary);font-size:24px;line-height:1;font-weight:900}.pg-dash-trend-panel{max-width:1280px;width:100%;margin:0 auto;padding:22px;border-radius:18px;background:var(--pg-bg-card-solid);border:1px solid var(--pg-border-subtle);box-shadow:0 2px 12px #0f172a0f}.pg-dash-trend-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--pg-border-subtle)}.pg-dash-trend-head h3{margin:0;color:var(--pg-text-primary);font-size:18px;font-weight:900;letter-spacing:0}.pg-dash-trend-layout{display:flex;flex-direction:column;gap:18px}.pg-dash-trend-details{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:16px;align-items:stretch}.pg-dash-trend-summary,.pg-dash-trend-metrics,.pg-dash-trend-chart{border:1px solid var(--pg-border-subtle);border-radius:16px;background:#f8fbff}.pg-dash-trend-summary{display:flex;gap:14px;align-items:center;padding:18px}.pg-dash-trend-icon{width:58px;height:58px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:16px;background:#fff;border:1px solid var(--pg-border);padding:11px}.pg-dash-trend-icon img{width:100%;height:100%;object-fit:contain}.pg-dash-trend-summary strong{display:block;color:var(--pg-text-primary);font-size:18px;font-weight:900;line-height:1.2;overflow-wrap:anywhere}.pg-dash-trend-summary span{display:inline-flex;margin-top:6px;color:var(--pg-primary);font-family:SF Mono,Consolas,monospace;font-size:12px;font-weight:900;overflow-wrap:anywhere}.pg-dash-trend-summary p{margin-top:8px;color:var(--pg-text-muted);font-size:13px;line-height:1.4}.pg-dash-trend-chart{min-height:340px;padding:18px;overflow:hidden;background:linear-gradient(#f8fbff,#f8fbff) padding-box,linear-gradient(135deg,#0664c41f,#fb670429) border-box}.pg-dash-trend-chart svg{display:block;width:100%;height:100%;min-height:304px}.pg-dash-trend-grid line{stroke:#dfeaf6;stroke-width:1;opacity:.9}.pg-dash-trend-empty{min-height:186px;display:flex;align-items:center;justify-content:center;color:var(--pg-text-muted);font-size:13px;font-weight:800;text-align:center}.pg-dash-trend-empty--full{min-height:210px;border:1px dashed var(--pg-border);border-radius:16px;background:#f8fbff}.pg-dash-trend-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:14px}.pg-dash-trend-metrics span{display:grid;gap:10px;padding:12px;border-radius:12px;background:#fff;color:var(--pg-text-muted);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.pg-dash-trend-metrics strong{color:var(--pg-text-primary);font-size:22px;font-weight:900;letter-spacing:0;text-transform:none}.pg-dash-quick-actions{display:flex;flex-direction:column;gap:10px;flex:1}.pg-dash-quick-btn{padding:14px 18px;border:none;border-radius:var(--pg-radius-md);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:14px;color:#fff;transition:transform .2s ease,box-shadow .2s ease;text-align:left}.pg-dash-quick-btn:hover{transform:translateY(-2px)}.pg-dash-quick-btn__icon{width:36px;height:36px;border-radius:10px;background:#fff3;display:flex;align-items:center;justify-content:center;padding:7px;flex-shrink:0}.pg-dash-quick-btn__icon img{width:100%;height:100%;object-fit:contain}.pg-dash-quick-btn--blue{background:var(--pg-gradient);box-shadow:none}.pg-dash-quick-btn--sky{background:linear-gradient(180deg,#5baef7,#0664c4);box-shadow:none}.pg-dash-quick-btn--accent{background:linear-gradient(180deg,#7ec5fa,#2b80d9);box-shadow:none}@media (max-width: 1100px){.pg-dash-stat-grid{grid-template-columns:repeat(2,1fr)}.pg-dash-columns{grid-template-columns:1fr}.pg-dash-hero{padding:28px 24px 32px}.pg-dash-body{padding:24px 24px 40px}}@media (max-width: 768px){.dashboard-content{padding:16px 16px 28px}.dashboard-header{flex-direction:column;gap:15px;text-align:center}.stats-grid{grid-template-columns:1fr}.pg-dash-stat-grid{grid-template-columns:1fr;gap:14px}.pg-dash-hero{padding:20px 16px 24px}.pg-dash-body{padding:20px 16px 32px}}.pg-dash-root{min-height:calc(100vh - var(--pg-header-h));margin:-24px -28px -40px;background:var(--pg-bg-page)}.pg-dash-overview{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;padding:30px 40px 18px;background:linear-gradient(135deg,#064f9d,#0b73cf 66%,#4fa2f6);color:#fff}.pg-dash-overview__copy{max-width:820px}.pg-eyebrow,.pg-panel-kicker{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.pg-eyebrow{color:#ffffffb8;margin-bottom:10px}.pg-dash-overview h1{font-size:clamp(30px,4vw,46px);line-height:1.02;letter-spacing:0;margin:0 0 12px}.pg-dash-overview p{max-width:680px;color:#ffffffdb;font-size:15px;line-height:1.65}.pg-dash-overview__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.pg-dash-btn-secondary{padding:10px 22px;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.32);border-radius:12px;font-size:13px;font-weight:800;cursor:pointer;font-family:inherit;transition:var(--pg-transition)}.pg-dash-btn-secondary:hover{background:#fff3;transform:translateY(-1px)}.pg-dash-command-card{align-self:stretch;min-height:210px;padding:24px;border-radius:18px;background:#ffffff24;border:1px solid rgba(255,255,255,.22);box-shadow:0 24px 60px #044a9138;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;justify-content:space-between}.pg-dash-command-card__status{display:inline-flex;align-items:center;gap:8px;width:fit-content;padding:7px 10px;border-radius:999px;background:#ffffff29;font-size:12px;font-weight:800}.pg-live-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 5px #22c55e2e}.pg-dash-command-card__value{font-size:56px;line-height:1;font-weight:900}.pg-dash-command-card__label{margin-top:-8px;color:#ffffffbd;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.07em}.pg-dash-command-card__meta{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pg-dash-command-card__meta span{padding:11px 12px;border-radius:12px;background:#ffffff24;color:#ffffffe0;font-size:12px;font-weight:800}.pg-dash-hero{padding:30px 40px 12px;background:transparent}.pg-dash-stat-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.pg-dash-stat-card{text-align:left;border-radius:16px;padding:22px;min-height:150px;box-shadow:0 14px 36px #0f172a14}.pg-dash-stat-card__top{display:flex;justify-content:flex-start;align-items:flex-start;margin-bottom:18px}.pg-dash-stat-card__arrow{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:var(--pg-primary);background:#eef6ff;border-radius:10px}.pg-dash-stat-card__arrow svg,.pg-dash-stat-card__icon svg{width:18px;height:18px}.pg-dash-stat-card__icon{color:#fff}.pg-dash-stat-card__helper{display:none}.pg-dash-stat-card--users .pg-dash-stat-card__icon{background:var(--pg-gradient)}.pg-dash-stat-card--sensors .pg-dash-stat-card__icon{background:linear-gradient(180deg,#5baef7,#0664c4)}.pg-dash-body{padding:16px 40px 48px;background:transparent;display:flex;flex-direction:column;gap:18px}.pg-dash-columns{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}.pg-dash-panel{border-radius:18px;padding:22px;min-height:380px}.pg-dash-panel__head{align-items:flex-start}.pg-panel-kicker{color:var(--pg-primary);margin-bottom:5px}.pg-dash-row{width:100%;text-align:left;font-family:inherit;border:1px solid transparent}.pg-dash-row__content,.pg-dash-row__sensor{width:100%}.pg-dash-pill{background:#dcfce7;color:#047857}.pg-dash-empty__sub{font-size:13px}.pg-dash-quick-btn{min-height:58px;border:1px solid transparent;border-radius:14px;padding:12px 16px;box-shadow:0 8px 20px #0f172a14}.pg-dash-quick-btn span:last-child{display:flex;flex-direction:column;min-width:0}.pg-dash-quick-btn strong{font-size:14px}.pg-dash-quick-btn small{display:none}.pg-dash-quick-btn--tone-1,.pg-dash-quick-btn--tone-2,.pg-dash-quick-btn--tone-3,.pg-dash-quick-btn--tone-4{background:linear-gradient(180deg,#5baef7,#0664c4)}@media (max-width: 1100px){.pg-dash-overview{grid-template-columns:1fr;padding:28px 24px 18px}.pg-dash-command-card{min-height:180px}.pg-dash-columns,.pg-dash-trend-details{grid-template-columns:1fr}.pg-dash-trend-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.pg-dash-hero,.pg-dash-body{padding-left:24px;padding-right:24px}}@media (max-width: 640px){.pg-dash-root{margin:-16px -16px -28px}.pg-dash-overview{padding:24px 18px 16px}.pg-dash-overview__actions{flex-direction:column}.pg-dash-overview__actions button{width:100%}.pg-dash-trend-head{flex-direction:column}.pg-dash-trend-metrics{grid-template-columns:1fr}.pg-dash-hero,.pg-dash-body{padding-left:16px;padding-right:16px}}.pg-dash-stat-grid,.pg-dash-trend-panel,.pg-dash-columns{width:100%;max-width:1280px;margin-left:auto;margin-right:auto}.pg-dash-body{gap:20px}.pg-dash-trend-panel{max-width:1280px;padding:16px;border-radius:18px;box-shadow:0 8px 24px #0f172a0f}.pg-dash-trend-head{margin-bottom:16px;padding-bottom:14px}.pg-dash-trend-layout{display:flex;flex-direction:column;gap:12px}.pg-dash-trend-details{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr);gap:12px;align-items:stretch}.pg-dash-trend-main{display:grid;grid-template-columns:minmax(0,1fr) 190px;gap:12px;align-items:stretch}.pg-dash-trend-summary,.pg-dash-trend-metrics,.pg-dash-trend-chart{background:#fff;border-color:#e8f0fa}.pg-dash-trend-chart{width:100%;height:clamp(350px,38vh,430px);min-height:350px;padding:16px 20px 18px;overflow:hidden}.pg-dash-trend-canvas{display:block;width:100%!important;height:100%!important}.pg-dash-trend-empty{min-height:280px}.pg-dash-trend-empty--full{min-height:240px}.pg-dash-btn-ghost{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:7px 16px;border:1px solid var(--pg-border);border-radius:var(--pg-radius-full);background:#fff;color:var(--pg-text-primary);box-shadow:none;text-transform:none;letter-spacing:0}.pg-dash-btn-ghost:hover{background:#fff7ed;border-color:var(--pg-accent-orange);color:var(--pg-text-primary);transform:translateY(-1px)}.pg-dash-trend-summary{display:grid;grid-template-columns:42px minmax(0,1fr) auto;gap:10px;align-items:center;min-height:72px;padding:8px 12px}.pg-dash-trend-icon{width:38px;height:38px;border-radius:11px;padding:7px}.pg-dash-trend-summary strong{font-size:15px}.pg-dash-trend-summary span{margin-top:3px;font-size:10px}.pg-dash-trend-summary p{margin-top:3px;font-size:11px}.pg-dash-trend-metrics{display:grid;grid-template-columns:1fr;padding:10px;gap:8px}.pg-dash-trend-metrics span{align-content:center;gap:7px;padding:10px;font-size:10px}.pg-dash-trend-metrics strong{font-size:19px}.pg-dash-trend-action{align-self:center;min-width:98px;min-height:34px;padding-inline:15px;justify-content:center;white-space:nowrap}.pg-dash-panel{min-height:340px}@media (max-width: 1100px){.pg-dash-trend-details{grid-template-columns:1fr}.pg-dash-trend-summary{grid-column:auto}}@media (max-width: 760px){.pg-dash-trend-main{grid-template-columns:1fr}.pg-dash-trend-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 640px){.pg-dash-trend-details{grid-template-columns:1fr}.pg-dash-trend-summary{grid-column:auto;grid-template-columns:44px minmax(0,1fr)}.pg-dash-trend-chart{height:320px;min-height:320px;padding:16px 12px}.pg-dash-trend-metrics{grid-template-columns:1fr}.pg-dash-trend-action{grid-column:1 / -1;width:100%}}.landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--pg-gradient-hero);padding:20px}.landing-content{text-align:center;animation:fadeIn .8s ease-in}.landing-text h1{font-size:48px;color:#fff;margin-bottom:15px;font-weight:800;letter-spacing:-.03em}.landing-text p{font-size:18px;color:#ffffffe0;margin-bottom:50px;font-weight:500}.landing-button{padding:16px 60px;font-size:18px;font-weight:700;color:var(--pg-primary);background:#fff;border:2px solid rgba(255,255,255,.65);border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 16px 40px #044a9159}.landing-button:hover{transform:translateY(-3px);box-shadow:0 22px 50px #044a9173;background:#fffffff5;border-color:#fff}.landing-button:active{transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.landing-text h1{font-size:36px}.landing-text p{font-size:16px}.landing-button{padding:14px 40px;font-size:16px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-container{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-xl);box-shadow:var(--pg-shadow-xl);width:100%;max-width:420px;padding:40px}.login-page-modern{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fff;padding:20px}.login-container-modern{position:relative;background:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;width:100%;max-width:420px;padding:50px 40px 40px;box-shadow:0 20px 60px #0000001a;overflow:hidden;border:1px solid #e5e7eb}.login-content{position:relative;z-index:1}.login-logo-container{text-align:center;margin-bottom:30px}.login-logo-container img{max-width:180px;height:auto;filter:none}.login-logo-text{font-size:28px;font-weight:700;color:var(--pg-text-primary);margin-top:15px}.login-logo-text .proxi{color:var(--pg-primary)}.login-logo-text .gen{color:var(--pg-accent)}.login-tagline{color:var(--pg-text-muted);font-size:14px;margin-top:5px}.login-welcome h1{font-size:28px;color:#1f2937;margin-bottom:8px;text-align:center;font-weight:700}.login-welcome p{color:#6b7280;font-size:14px;text-align:center;margin-bottom:30px}.login-alert{padding:12px;border-radius:var(--pg-radius-sm);margin-bottom:20px;font-size:14px}.login-alert--error{background-color:var(--pg-error-bg);color:#991b1b;border:1px solid #fecaca}.login-alert--success{background-color:var(--pg-success-bg);color:#065f46;border:1px solid #a7f3d0}.login-form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;font-size:14px}.login-remember{display:flex;align-items:center;gap:8px}.login-remember input[type=checkbox]{width:16px;height:16px;cursor:pointer}.login-remember label{color:#6b7280;cursor:pointer}.login-forgot{color:var(--pg-primary);font-weight:600;transition:color .3s ease}.login-forgot:hover{color:var(--pg-accent)}.btn-login{width:100%;padding:14px;background:var(--pg-gradient);color:#fff;border:none;border-radius:25px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:none}.btn-login:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0f172a1f;filter:brightness(1.03)}.btn-login:active{transform:translateY(0)}.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-signup{text-align:center;margin-top:25px;color:#6b7280;font-size:14px}.login-signup a{color:var(--pg-primary);font-weight:700;transition:color .3s ease}.login-signup a:hover{color:var(--pg-accent)}.login-footer{text-align:center;margin-top:25px;padding-top:20px;border-top:1px solid #e5e7eb}.login-footer a{color:#6b7280;font-size:13px;margin:0 10px;transition:color .3s ease}.login-footer a:hover{color:var(--pg-primary)}@media (max-width: 480px){.login-container-modern{padding:40px 20px 30px}.login-welcome h1{font-size:24px}}.signup-back-icon{position:absolute;top:20px;left:20px;background:none;border:none;color:var(--pg-primary);cursor:pointer;padding:8px;display:flex;align-items:center;transition:color .3s ease,transform .2s ease;z-index:10}.signup-back-icon:hover{color:var(--pg-accent);transform:translate(-3px)}.signup-back-icon:disabled{opacity:.5;cursor:not-allowed}.signup-header{display:flex;align-items:center;margin-bottom:20px;position:relative}.signup-back-btn{background:none;border:none;color:var(--pg-primary);cursor:pointer;padding:8px;display:flex;align-items:center;transition:color .3s ease;margin-right:15px}.signup-back-btn:hover{color:var(--pg-accent)}.signup-title{font-size:24px;color:#fff;font-weight:700;margin:0}.signup-subtitle{text-align:center;margin-bottom:25px}.signup-subtitle h2{font-size:24px;color:#1f2937;margin:0 0 8px;font-weight:700}.signup-subtitle p{color:#6b7280;font-size:14px;margin:0}.signup-form{display:flex;flex-direction:column;gap:15px}.phone-input-wrapper{display:grid;grid-template-columns:100px 1fr;gap:10px}.phone-code{padding:12px 8px 12px 12px!important}.phone-number{padding:12px!important}.signup-login-link{text-align:center;margin-top:20px;color:#6b7280;font-size:14px}.signup-login-link a{color:var(--pg-primary);font-weight:700;transition:color .3s ease}.signup-login-link a:hover{color:var(--pg-accent)}.login-method-tabs{display:flex;gap:10px;margin-bottom:25px;border-bottom:2px solid rgba(255,255,255,.1)}.login-method-tab{flex:1;padding:12px 16px;background:none;border:none;color:#b0b0b0;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;border-bottom:3px solid transparent;margin-bottom:-2px}.login-method-tab:hover{color:var(--pg-primary)}.login-method-tab.active{color:var(--pg-primary);border-bottom-color:var(--pg-primary)}.gmail-login-section{display:flex;flex-direction:column;gap:15px}.btn-gmail{width:100%;padding:14px;background:#fff;color:#1f2937;border:none;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 12px #00000026}.btn-gmail:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003}.btn-gmail:active{transform:translateY(0)}.btn-gmail:disabled{opacity:.6;cursor:not-allowed;transform:none}.gmail-note{text-align:center;color:#b0b0b0;font-size:13px;margin:0}.signup-steps{display:flex;align-items:center;justify-content:center;margin-bottom:30px;padding:0 20px}.step-indicator{display:flex;flex-direction:column;align-items:center;gap:8px}.step-circle{width:40px;height:40px;border-radius:50%;background:#f3f4f6;border:2px solid #e5e7eb;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#6b7280;transition:all .3s ease}.step-circle.active{background:var(--pg-gradient);border-color:var(--pg-primary);color:#fff;box-shadow:none}.step-line{width:80px;height:2px;background:#e5e7eb;margin:-15px 10px 0;transition:all .3s ease}.step-line.active{background:linear-gradient(90deg,#4fa2f6,#0664c4)}.step-label{font-size:12px;color:#6b7280;font-weight:500}.step-indicator .step-circle.active~.step-label,.step-indicator:has(.step-circle.active) .step-label{color:var(--pg-primary)}.btn-next{width:100%;padding:14px;background:var(--pg-gradient);color:#fff;border:none;border-radius:25px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:none;margin-top:10px}.btn-next:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0f172a1f;filter:brightness(1.03)}.btn-next:active{transform:translateY(0)}.btn-next:disabled{opacity:.6;cursor:not-allowed;transform:none}.signup-buttons{display:flex;gap:12px;margin-top:10px}.btn-back{flex:1;padding:14px;background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-back:hover{background:#e5e7eb;border-color:#d1d5db;transform:translateY(-2px)}.btn-back:active{transform:translateY(0)}.btn-back:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-submit{width:100%;padding:14px;background:var(--pg-gradient);color:#fff;border:none;border-radius:25px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:none;margin-top:10px;position:relative;z-index:10}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0f172a1f;filter:brightness(1.03)}.btn-submit:active{transform:translateY(0)}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px 8px;color:#6b7280;transition:color .3s ease;z-index:2;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--pg-primary)}.password-toggle:focus{outline:none}.password-toggle img{filter:brightness(0) saturate(100%) invert(70%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(90%) contrast(90%);transition:filter .3s ease}.password-toggle:hover img{filter:brightness(0) saturate(100%) invert(64%) sepia(98%) saturate(2477%) hue-rotate(163deg) brightness(101%) contrast(101%)}.input-wrapper:has(.password-toggle) input{padding-right:45px}.custom-select-wrapper{position:relative;width:100%}.custom-select-wrapper:after{content:"▼";position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#6b7280;font-size:10px;pointer-events:none;z-index:1}.custom-select-wrapper input{cursor:pointer}.custom-select-wrapper input::placeholder{color:#1f2937;opacity:1}.custom-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-top:4px;max-height:250px;overflow-y:auto;z-index:1000;box-shadow:0 10px 30px #0000001a}.dropdown-item{padding:12px 16px;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;gap:10px;color:#1f2937;font-size:14px}.dropdown-item:hover{background-color:#0664c414}.dropdown-item:active{background-color:#0664c424}.dropdown-empty{color:#6b7280;cursor:default;text-align:center;justify-content:center}.dropdown-empty:hover{background-color:transparent}.dropdown-flag{font-size:20px;flex-shrink:0}.dropdown-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-timezone-offset{color:var(--pg-accent);font-weight:600;min-width:90px;flex-shrink:0}.dropdown-timezone-name{color:#1f2937;flex:1}.custom-dropdown::-webkit-scrollbar{width:8px}.custom-dropdown::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.custom-dropdown::-webkit-scrollbar-thumb{background:#0664c440;border-radius:4px}.custom-dropdown::-webkit-scrollbar-thumb:hover{background:#0664c466}@media (max-width: 480px){.signup-steps{padding:0 10px}.step-circle{width:35px;height:35px;font-size:14px}.step-line{width:50px}.signup-buttons{flex-direction:column}.btn-back,.btn-submit{flex:1}.custom-dropdown{max-height:200px}}.form-group{margin-bottom:20px}.form-group label{display:block;color:#4b5563;font-size:14px;font-weight:500;margin-bottom:8px}.input-wrapper{position:relative}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6b7280;display:flex;align-items:center}.form-control{width:100%;padding:12px 12px 12px 40px;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;transition:all .3s ease;outline:none;font-family:inherit;background:#fff;color:#1f2937}.form-control-no-icon{padding:12px!important}.form-control::placeholder{color:#9ca3af}.form-control:focus{border-color:var(--pg-border-focus);box-shadow:0 0 0 3px #0f172a14;background:#fff}.form-control option{background:#1a1a2e;color:#fff}.form-control option:checked{background:var(--pg-primary);color:#fff}.form-control--error{border-color:#ff006e;box-shadow:0 0 0 3px #ff006e1a}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#00d4ff;cursor:pointer;padding:5px;display:flex;align-items:center;transition:color .3s ease}.password-toggle:hover{color:#ff006e}.search-box{padding:12px 16px;border:1px solid var(--pg-border);border-radius:12px;width:min(360px,100%);font-size:14px;transition:var(--pg-transition);font-family:inherit;color:var(--pg-text-primary);background:#fff;box-shadow:inset 0 1px #ffffffbf}.search-box:focus{outline:none;border-color:var(--pg-primary);box-shadow:0 0 0 3px #0f172a14}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:25px}.form-grid .form-group{margin-bottom:0}.form-grid .form-group label{font-size:13px;font-weight:600;color:#4b5563;margin-bottom:8px}.form-grid input{padding:12px 16px;border:1px solid var(--pg-border);border-radius:10px;font-size:14px;transition:var(--pg-transition);font-family:inherit}.form-grid input:focus{border-color:var(--pg-primary);box-shadow:0 0 0 3px #0f172a14;outline:none}.submit-btn{background:var(--pg-gradient);color:var(--pg-text-white);border:none;padding:12px 30px;border-radius:10px;font-weight:600;cursor:pointer;transition:transform .2s;font-family:inherit;font-size:14px}.submit-btn:hover{transform:translateY(-2px);box-shadow:none}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.tab-btn{background:none;border:none;font-size:16px;font-weight:600;color:var(--pg-text-muted);cursor:pointer;padding:5px 10px;border-bottom:3px solid transparent;font-family:inherit}.tab-btn--active{color:var(--pg-primary);border-bottom-color:var(--pg-primary)}.upload-zone{border:2px dashed #d1d5db;border-radius:var(--pg-radius-lg);padding:50px;text-align:center;cursor:pointer;transition:var(--pg-transition);background:#f9fafb}.upload-zone:hover,.upload-zone--drag-over{border-color:var(--pg-primary);background:#f3f4f6}.success-message{background:var(--pg-success-bg);color:#16a34a;padding:12px 20px;border-radius:10px;margin-top:15px;font-weight:600}.error-message{background:var(--pg-error-bg);color:#dc2626;padding:12px 20px;border-radius:10px;margin-top:15px;font-weight:600}@media (max-width: 768px){.search-box{width:100%}.form-grid{grid-template-columns:1fr}}:root{--pg-blue-sky: #4fa2f6;--pg-blue-deep: #0664c4;--pg-accent-orange: #fb6704;--pg-primary: #0664c4;--pg-primary-mid: #2b80d9;--pg-primary-dark: #044a91;--pg-secondary: #4fa2f6;--pg-accent: #fb6704;--pg-gradient: linear-gradient(180deg, #4fa2f6 0%, #0664c4 100%);--pg-gradient-hover: linear-gradient(180deg, #5baef7 0%, #0756ad 100%);--pg-gradient-hero: linear-gradient(145deg, #4fa2f6 0%, #0664c4 52%, #044a91 100%);--pg-gradient-soft: linear-gradient( 135deg, rgba(79, 162, 246, .14) 0%, rgba(6, 100, 196, .06) 100% );--pg-purple: #0664c4;--pg-purple-light: #4fa2f6;--pg-cyan: #0664c4;--pg-cyan-light: #4fa2f6;--pg-success: #059669;--pg-success-bg: #d1fae5;--pg-warning: #d97706;--pg-warning-bg: #fef3c7;--pg-error: #dc2626;--pg-error-bg: #fee2e2;--pg-bg-body: linear-gradient(180deg, #e9f2fb 0%, #f5f9fd 38%, #ffffff 100%);--pg-bg-page: #f4f8fd;--pg-bg-card: #ffffff;--pg-bg-card-solid: #ffffff;--pg-bg-input: #f5f9fe;--pg-bg-hover: #eef6ff;--pg-bg-table-stripe: #f8fafc;--pg-border: #dbe7f5;--pg-border-subtle: #e8f0fa;--pg-border-focus: #0664c4;--pg-text-primary: #0f172a;--pg-text-secondary: #334155;--pg-text-muted: #64748b;--pg-text-placeholder: #94a3b8;--pg-text-light: #94a3b8;--pg-text-white: #ffffff;--pg-font-sans: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--pg-shadow-sm: 0 4px 14px rgba(15, 23, 42, .05);--pg-shadow-md: 0 8px 30px rgba(15, 23, 42, .06);--pg-shadow-lg: 0 16px 48px rgba(15, 23, 42, .08);--pg-shadow-xl: 0 24px 64px rgba(15, 23, 42, .12);--pg-radius-sm: 8px;--pg-radius-md: 12px;--pg-radius-lg: 16px;--pg-radius-xl: 20px;--pg-radius-full: 999px;--pg-transition: all .25s ease;--pg-sidebar-width: 280px;--pg-header-h: 82px}.app-shell-header{position:sticky;top:0;z-index:100;min-height:82px;padding:10px 40px;background:#fffffff2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--pg-border-subtle);box-shadow:var(--pg-shadow-sm)}.app-shell-header__inner{width:100%;max-width:1280px;min-height:62px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.app-shell-header__brand{display:flex;align-items:center;gap:12px}.app-shell-header__logo{height:66px;width:150px;object-fit:contain}.app-shell-header__title{font-size:14px;font-weight:800;letter-spacing:-.03em;color:var(--pg-text-primary);display:none}@media (min-width: 1100px){.app-shell-header__title{display:block}}.app-shell-header__title span{background:var(--pg-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-main-nav{display:flex;flex:1;align-items:center;justify-content:center;gap:6px;min-width:0;overflow-x:auto;scrollbar-width:none;padding:4px}.app-main-nav::-webkit-scrollbar{display:none}.app-nav-link{padding:10px 16px;border-radius:var(--pg-radius-full);font-size:13px;font-weight:800;color:var(--pg-text-secondary);text-decoration:none;white-space:nowrap;transition:var(--pg-transition);border:1px solid transparent}.app-nav-link:hover{color:var(--pg-primary);background:#4fa2f61a;text-decoration:none}.app-nav-link--active{color:var(--pg-text-white);background:linear-gradient(135deg,var(--pg-accent-orange) 0%,#f97316 100%);box-shadow:none;border-color:#ffffff40;border-radius:var(--pg-radius-full)}.app-nav-link--active:hover{color:var(--pg-text-white);background:#e55d00}.app-shell-user{display:flex;align-items:center;gap:12px;padding:6px 8px 6px 6px;background:#f8fbff;border:1px solid var(--pg-border-subtle);border-radius:var(--pg-radius-full)}.app-shell-avatar{width:40px;height:40px;border-radius:50%;background:var(--pg-gradient);display:flex;align-items:center;justify-content:center;color:var(--pg-text-white);font-weight:800;font-size:15px;box-shadow:none}.app-shell-user-meta{display:flex;flex-direction:column;line-height:1.2}.app-shell-user-name{font-weight:700;font-size:14px;color:var(--pg-text-primary)}.app-shell-user-role{font-size:11px;font-weight:700;color:var(--pg-primary);text-transform:uppercase;letter-spacing:.04em}.app-shell-logout{width:44px;height:36px;display:flex;align-items:center;justify-content:center;background:#dc262614;border:none;border-radius:var(--pg-radius-full);color:var(--pg-error);font-size:18px;cursor:pointer;transition:var(--pg-transition);padding:0;line-height:1}.pg-back-button{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;padding:9px 14px;border:1px solid var(--pg-border);border-radius:12px;background:#fff;color:var(--pg-text-secondary);font-family:inherit;font-size:13px;font-weight:800;cursor:pointer;box-shadow:var(--pg-shadow-sm);transition:var(--pg-transition)}.pg-back-button:hover{color:var(--pg-primary);border-color:#0664c43d;background:var(--pg-bg-hover);transform:translate(-2px)}.app-shell-logout:hover{background:var(--pg-error);color:var(--pg-text-white);transform:scale(1.05)}.pg-breadcrumb{display:flex;gap:10px;align-items:center;margin-bottom:20px;color:var(--pg-text-muted);flex-wrap:wrap;font-size:14px}.pg-breadcrumb a{color:var(--pg-text-muted);text-decoration:none;font-weight:500}.pg-breadcrumb a:hover{color:var(--pg-primary);text-decoration:none}.pg-breadcrumb__sep{color:var(--pg-text-placeholder);-webkit-user-select:none;user-select:none}.pg-breadcrumb__current{color:var(--pg-text-primary);font-weight:700}.pg-breadcrumb__link{cursor:pointer;border:none;background:none;font:inherit;padding:0;color:var(--pg-text-muted)}.pg-breadcrumb__link:hover{color:var(--pg-primary)}.pg-empty-hint{text-align:center;color:var(--pg-text-placeholder);padding:40px}.pg-muted{color:var(--pg-text-muted)}.pg-sensor-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;flex-wrap:wrap;gap:16px}.pg-sensor-title{font-size:28px;font-weight:800;letter-spacing:-.02em;color:var(--pg-text-primary);margin-bottom:8px}.pg-sensor-meta{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.pg-id-chip{font-size:12px;padding:4px 12px;background:var(--pg-gradient);color:#fff;border-radius:var(--pg-radius-full);font-weight:700}.pg-meta-muted{font-size:13px;color:var(--pg-text-muted)}.pg-meta-dot{color:var(--pg-border);-webkit-user-select:none;user-select:none}.pg-export-group{display:flex;gap:12px;flex-wrap:wrap}.pg-btn-export{padding:10px 20px;border:none;border-radius:10px;cursor:pointer;font-weight:700;font-size:14px;font-family:inherit;display:flex;align-items:center;gap:8px;transition:var(--pg-transition)}.pg-btn-export--excel{background:var(--pg-gradient);color:#fff;box-shadow:none}.pg-btn-export--excel:hover{filter:brightness(1.03);transform:translateY(-1px)}.pg-btn-export--pdf{background:#fff;color:var(--pg-primary);border:2px solid var(--pg-primary)}.pg-btn-export--pdf:hover{background:var(--pg-bg-hover)}.pg-error-panel{text-align:center;padding:60px 20px;background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);margin-top:20px;border:1px solid var(--pg-border-subtle);box-shadow:var(--pg-shadow-sm)}@media (max-width: 820px){.app-shell-header{padding:10px 16px 14px}.app-shell-header__inner{align-items:flex-start;flex-wrap:wrap}.app-main-nav{order:3;flex-basis:100%;justify-content:flex-start}.app-shell-user-meta{display:none}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--pg-font-sans);background:var(--pg-bg-body);min-height:100vh;color:var(--pg-text-primary);-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--pg-primary);text-decoration:none}a:hover{color:var(--pg-primary-mid);text-decoration:underline}.pg-hidden{display:none!important}@keyframes pg-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pg-fade-in{0%{opacity:0}to{opacity:1}}@keyframes pg-slide-up{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pg-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes pg-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes pg-shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.pg-shake{animation:pg-shake .5s ease-in-out}.stat-card{background:var(--pg-bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:25px;border-radius:var(--pg-radius-lg);box-shadow:var(--pg-shadow-md);transition:var(--pg-transition);cursor:pointer}.stat-card:hover{transform:translateY(-5px);box-shadow:var(--pg-shadow-lg)}.stat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:15px;font-size:24px;background:var(--pg-gradient);color:var(--pg-text-white)}.stat-value{font-size:36px;font-weight:700;margin-bottom:5px}.stat-label{font-size:14px;opacity:.8}.kpi-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin:20px 0 30px}.kpi-card{background:var(--pg-bg-card-solid);border-radius:18px;padding:20px 14px;text-align:center;box-shadow:var(--pg-shadow-sm);border:1px solid var(--pg-border-subtle)}.kpi-icon{width:42px;height:42px;background:#0664c41a;color:var(--pg-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;font-size:20px}.kpi-label{font-size:13px;color:var(--pg-text-muted);margin-bottom:6px}.kpi-value{font-size:22px;font-weight:700;color:#111827;margin-bottom:8px}.kpi-status{display:inline-block;padding:4px 12px;font-size:12px;border-radius:var(--pg-radius-full);font-weight:600}.kpi-status--good{background:var(--pg-success-bg);color:#16a34a}.kpi-status--warn{background:var(--pg-warning-bg);color:#ca8a04}.kpi-status--bad{background:var(--pg-error-bg);color:#dc2626}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:30px}.summary-card{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:22px;box-shadow:var(--pg-shadow-sm);border-left:4px solid var(--pg-primary);transition:transform .3s}.summary-card:hover{transform:translateY(-3px)}.summary-card--warning{border-left-color:var(--pg-warning)}.summary-card--critical{border-left-color:var(--pg-error)}.summary-card--success{border-left-color:var(--pg-success)}.summary-label{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:8px}.summary-value{font-size:28px;font-weight:800;color:#1e293b}.summary-sub{font-size:12px;color:var(--pg-text-light);margin-top:4px}@media (max-width: 768px){.summary-grid,.kpi-container{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.summary-grid,.kpi-container{grid-template-columns:1fr}}.list-container{width:100%;max-width:1280px;margin:0 auto;background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:28px;box-shadow:var(--pg-shadow-md);border:1px solid var(--pg-border-subtle)}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.list-header h2{font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--pg-text-primary)}.list-item{padding:20px;border-bottom:1px solid var(--pg-border);cursor:pointer;transition:var(--pg-transition);display:flex;justify-content:space-between;align-items:center}.list-item:hover{background:var(--pg-bg-hover);transform:translate(5px)}.list-item:last-child{border-bottom:none}.list-item-info h3{margin-bottom:5px;font-size:18px}.list-item-info p{color:var(--pg-text-muted);font-size:14px}.list-item-actions{display:flex;gap:10px;align-items:center}.action-btn{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .2s ease;display:flex;align-items:center;gap:4px}.action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 5px #0000001a}.action-btn--info{background:#0664c41a;color:var(--pg-primary)}.action-btn--info:hover{background:#0664c42e}.action-btn--view{background:var(--pg-gradient);color:var(--pg-text-white)}.action-btn--view:hover{background:var(--pg-gradient-hover)}.table-card{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:28px;margin-top:24px;box-shadow:var(--pg-shadow-md);border:1px solid var(--pg-border-subtle)}.table-card h3{margin-bottom:20px;font-size:20px;color:var(--pg-text-primary)}.table-responsive{width:100%;overflow-x:auto;border-radius:10px;border:1px solid var(--pg-border)}.data-table{width:100%;border-collapse:collapse;min-width:800px}.data-table th{background:linear-gradient(180deg,#f4f8fd,#eef4fc);color:var(--pg-text-secondary);font-weight:600;padding:12px 16px;text-align:left;font-size:13px;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--pg-border)}.data-table td{padding:14px 16px;border-bottom:1px solid var(--pg-border);color:var(--pg-text-secondary);font-size:14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:var(--pg-bg-table-stripe)}.sensor-info-bar{display:flex;gap:15px;margin-bottom:25px;flex-wrap:wrap}.info-item{background:#ffffffe6;padding:12px 20px;border-radius:12px;box-shadow:var(--pg-shadow-sm);display:flex;align-items:center;gap:10px;font-size:14px;min-width:180px;border:1px solid rgba(0,0,0,.05)}.info-item .icon{color:var(--pg-primary);font-size:16px;display:flex;align-items:center}.info-item .text-group{display:flex;flex-direction:column;line-height:1.2}.info-item .label{color:var(--pg-text-placeholder);font-size:11px;font-weight:600;text-transform:uppercase}.info-item .value{color:var(--pg-text-primary);font-weight:600;font-size:15px}@media (max-width: 768px){.list-header{flex-direction:column;gap:15px;align-items:flex-start}.sensor-info-bar{flex-direction:column}.info-item{width:100%}}.entity-page{width:100%;max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.entity-hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:center;padding:28px;border-radius:18px;color:#fff;background:linear-gradient(135deg,#064f9d,#0b73cf 68%,#4fa2f6);box-shadow:none;overflow:hidden}.entity-hero--projects{background:linear-gradient(135deg,#064f9d,#0b73cf 68%,#4fa2f6)}.entity-hero--sections{background:linear-gradient(135deg,#0f766e,#0891b2 62%,#4fa2f6)}.entity-hero--sensors{background:linear-gradient(135deg,#0f172a,#0664c4 58%,#fb6704)}.entity-eyebrow{display:inline-flex;margin-bottom:8px;color:#ffffffc2;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.entity-hero h1{font-size:clamp(28px,3vw,40px);line-height:1.05;margin:0 0 10px;letter-spacing:0}.entity-hero p{max-width:700px;color:#ffffffd6;font-size:14px;line-height:1.6}.entity-hero__visual{width:112px;height:112px;border-radius:24px;display:flex;align-items:center;justify-content:center;background:#ffffff29;border:1px solid rgba(255,255,255,.24);box-shadow:inset 0 1px #ffffff2e}.entity-hero__visual img{width:66px;height:66px;object-fit:contain}.entity-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,220px));justify-content:start;gap:18px}.entity-metric{min-height:96px;padding:18px 20px;border-radius:16px;background:#fff;border:1px solid var(--pg-border-subtle);box-shadow:var(--pg-shadow-sm);display:flex;flex-direction:column;justify-content:center}.entity-metric span{display:block;color:var(--pg-text-muted);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}.entity-metric strong{color:var(--pg-text-primary);font-size:24px;line-height:1}.entity-toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px;border-radius:16px;background:#fff;border:1px solid var(--pg-border-subtle);box-shadow:var(--pg-shadow-sm)}.entity-toolbar__controls{min-width:0;display:flex;align-items:center;gap:14px;flex:1;flex-wrap:nowrap}.entity-search-range{min-height:56px;display:flex;align-items:center;gap:10px;flex:1 1 540px;min-width:430px;max-width:690px;padding:5px 6px 5px 14px;border-radius:999px;background:#fff;border:1px solid var(--pg-border-subtle);box-shadow:inset 0 1px #ffffffe6}.entity-search-range .search-box{width:100%;min-width:220px;min-height:44px;flex:1;padding:10px 4px;border:0;border-radius:0;box-shadow:none}.entity-search-range .search-box:focus{box-shadow:none}.entity-toolbar__meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.entity-chip{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:6px 10px;border-radius:999px;background:var(--pg-bg-hover);color:var(--pg-primary);border:1px solid rgba(6,100,196,.14);font-size:12px;font-weight:800;white-space:nowrap}.entity-chip--soft{background:#f8fafc;color:var(--pg-text-secondary);border-color:var(--pg-border-subtle)}.entity-chip--success{background:#dcfce7;color:#047857;border-color:#bbf7d0}.entity-chip--accent{background:#fff7ed;color:var(--pg-accent-orange);border-color:#fb670438}.entity-chip--with-icon{justify-content:flex-start;gap:8px}.entity-chip__icon{width:22px;height:22px;padding:0;border-radius:0;background:transparent;object-fit:contain;flex-shrink:0}.entity-date-filter{min-height:56px;display:inline-flex;align-items:center;gap:9px;flex:0 0 auto;padding:0;background:transparent;border:0;box-shadow:none;transition:var(--pg-transition)}.entity-date-filter.is-active{filter:none}.entity-date-filter__presets{display:inline-flex;align-items:center;gap:3px;padding:3px;border-radius:999px;background:#f8fbff;border:1px solid var(--pg-border-subtle);flex-shrink:0}.entity-date-filter__presets button{min-height:28px;padding:5px 9px;border:0;border-radius:999px;background:transparent;color:var(--pg-text-secondary);font-family:inherit;font-size:11px;font-weight:900;cursor:pointer;transition:var(--pg-transition)}.entity-date-filter__presets button:hover,.entity-date-filter__presets button.is-active{background:var(--pg-primary);color:#fff}.entity-date-filter__field{min-height:56px;height:56px;display:inline-flex;align-items:center;gap:9px;padding:8px 13px;border-radius:999px;background:#fff;border:1px solid var(--pg-border-subtle)}.entity-date-filter__field span{color:var(--pg-text-muted);font-size:10px;font-weight:900;line-height:1;text-transform:uppercase;white-space:nowrap}.entity-date-filter input{width:124px;min-height:18px;padding:0;border:0;border-radius:0;background:transparent;color:var(--pg-text-primary);color-scheme:light;font-family:inherit;font-size:12px;font-weight:900;outline:none}.entity-date-filter input:focus{box-shadow:none}.entity-date-filter__track{width:20px;height:2px;border-radius:999px;background:linear-gradient(90deg,#0664c459,#fb67048c)}.entity-date-filter__clear{min-height:28px;height:28px;padding:6px 10px;border:1px solid var(--pg-border);border-radius:999px;background:#fff;color:var(--pg-text-primary);font-family:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:var(--pg-transition)}.entity-date-filter__clear.is-hidden{visibility:hidden;pointer-events:none}.entity-date-filter__clear:hover{background:#fff7ed;border-color:var(--pg-accent-orange)}.entity-grid{display:grid;grid-template-columns:repeat(3,minmax(350px,450px));column-gap:clamp(20px,3vw,38px);row-gap:22px;justify-content:space-between;align-items:stretch}.entity-table-card{overflow:hidden;border:1px solid var(--pg-border-subtle);border-radius:16px;background:#fff;box-shadow:var(--pg-shadow-sm)}.entity-table-body{display:flex;flex-direction:column}.entity-table-row{position:relative;display:grid;align-items:center;gap:18px;min-height:78px;padding:16px 18px 16px 20px;border-bottom:1px solid var(--pg-border-subtle);background:#fff;transition:background .2s ease,border-color .2s ease}.entity-table-body .entity-table-row:before{content:"";position:absolute;left:0;top:16px;bottom:16px;width:3px;border-radius:0 999px 999px 0;background:transparent;transition:background .2s ease}.entity-table-body .entity-table-row:hover{background:#fbfdff}.entity-table-body .entity-table-row:hover:before{background:var(--pg-accent-orange)}.entity-table-body .entity-table-row:last-child{border-bottom:0}.entity-table-card--projects .entity-table-row{grid-template-columns:minmax(320px,1.8fr) minmax(100px,.45fr) minmax(100px,.45fr) minmax(210px,.8fr)}.entity-table-card--sections .entity-table-row{grid-template-columns:minmax(320px,1.65fr) minmax(220px,.95fr) minmax(100px,.45fr) minmax(210px,.8fr)}.entity-table-card--sensors .entity-table-row{grid-template-columns:minmax(260px,1.12fr) minmax(150px,.64fr) minmax(150px,.64fr) minmax(170px,.72fr) minmax(170px,.72fr) minmax(180px,.7fr)}.entity-table-row--head{min-height:44px;padding-top:13px;padding-bottom:13px;background:#f8fafc;color:var(--pg-text-muted);font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.entity-table-row--head span{min-width:0;justify-self:stretch;text-align:left}.entity-table-row--head span:first-child{text-transform:uppercase}.entity-table-row--head span:last-child{justify-self:stretch;text-align:center;padding-right:0}.entity-table-card--projects .entity-table-row--head span:nth-child(2),.entity-table-card--projects .entity-table-row--head span:nth-child(3),.entity-table-card--sections .entity-table-row--head span:nth-child(3){text-align:center}.entity-table-main{display:flex;align-items:center;gap:13px;min-width:0}.entity-table-icon{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border-radius:12px;background:linear-gradient(180deg,#5baef7,#0664c4)}.entity-table-icon img{width:23px;height:23px;object-fit:contain}.entity-table-copy{min-width:0}.entity-table-copy h3{margin:0;color:var(--pg-text-primary);font-size:16px;font-weight:900;line-height:1.25;overflow-wrap:anywhere}.entity-table-copy p{margin:5px 0 0;color:var(--pg-text-muted);font-size:12px;line-height:1.35;overflow-wrap:anywhere}.entity-table-card--sensors .entity-table-copy p{display:flex;align-items:center;color:var(--pg-primary);font-family:SF Mono,Consolas,monospace;font-size:11px;font-weight:850}.entity-sensor-id-label{display:inline-flex;gap:2px}.entity-table-stat,.entity-table-date,.entity-table-project{min-width:0}.entity-table-card--projects .entity-table-stat,.entity-table-card--sections .entity-table-stat{display:flex;justify-content:center;justify-self:stretch;text-align:center}.entity-table-stat span,.entity-table-date span,.entity-table-project span{display:none}.entity-table-stat strong{color:var(--pg-text-primary);font-size:20px;font-weight:950;font-variant-numeric:tabular-nums;line-height:1;min-width:2ch;text-align:center}.entity-table-date strong{color:var(--pg-text-primary);font-size:11px;font-weight:850;line-height:1.35;white-space:nowrap}.entity-table-project strong{display:inline-flex;align-items:center;justify-content:flex-start;gap:8px;max-width:100%;color:var(--pg-text-primary);font-size:11px;font-weight:850;line-height:1.35;overflow-wrap:anywhere}.entity-table-project img{width:16px;height:16px;flex:0 0 auto;object-fit:contain}.entity-table-actions{display:flex;justify-content:center;justify-self:stretch;gap:8px;min-width:0}.entity-card{min-height:340px;display:flex;flex-direction:column;justify-content:flex-start;gap:14px;padding:20px;border-radius:16px;border:1px solid var(--pg-border-subtle);background:#fff;box-shadow:var(--pg-shadow-sm);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.entity-card:hover{transform:translateY(-3px);border-color:#d6e2f1;box-shadow:0 12px 28px #0f172a14}.entity-card__top{display:flex;justify-content:space-between;gap:14px}.entity-card__icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:12px;background:linear-gradient(180deg,#5baef7,#0664c4);box-shadow:none}.entity-card__icon img{width:25px;height:25px;object-fit:contain}.entity-card__title{margin:0;color:var(--pg-text-primary);font-size:18px;font-weight:900;line-height:1.25;overflow-wrap:anywhere}.entity-sensor-id{display:inline-flex;margin-top:8px;color:var(--pg-primary);font-family:SF Mono,Consolas,monospace;font-size:12px;font-weight:800;line-height:1.4;overflow-wrap:anywhere}.entity-card__subtitle{margin-top:5px;color:var(--pg-text-muted);font-size:13px;line-height:1.45}.entity-card__meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}.entity-card__footer{display:flex;justify-content:space-between;align-items:center;gap:10px;padding-top:14px;border-top:1px solid var(--pg-border-subtle)}.entity-card__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.entity-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:36px;padding:8px 16px;border-radius:999px;border:1px solid transparent;font-family:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:var(--pg-transition)}.entity-btn--primary{color:var(--pg-text-primary);background:#fff;border-color:var(--pg-border);box-shadow:none}.entity-btn--primary:hover{transform:translateY(-1px);color:var(--pg-text-primary);background:#fff7ed;border-color:var(--pg-accent-orange);filter:none}.entity-btn--ghost{color:var(--pg-text-primary);background:#fff;border-color:var(--pg-border)}.entity-btn--ghost:hover{color:var(--pg-text-primary);background:#fff7ed;border-color:var(--pg-accent-orange)}.entity-code{font-family:SF Mono,Consolas,monospace;color:var(--pg-primary-dark);font-size:13px;font-weight:800;overflow-wrap:anywhere}.entity-empty{padding:56px 20px;text-align:center;border-radius:16px;background:#fff;border:1px dashed var(--pg-border);color:var(--pg-text-muted)}.entity-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.entity-detail-item{padding:14px;border-radius:12px;background:#f8fafc;border:1px solid var(--pg-border-subtle)}.entity-detail-item--wide{grid-column:1 / -1}.entity-detail-item label{display:block;margin-bottom:5px;color:var(--pg-text-muted);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.07em}.entity-detail-item p{color:var(--pg-text-primary);font-size:14px;line-height:1.5;overflow-wrap:anywhere}.entity-detail-item img{max-width:100%;border-radius:10px;border:1px solid var(--pg-border)}.pagination-controls{display:grid;grid-template-columns:minmax(180px,auto) minmax(160px,1fr) auto;align-items:center;gap:14px;padding:14px 18px;border-top:1px solid var(--pg-border-subtle);background:linear-gradient(180deg,#fff,#f8fbff)}.pagination-controls__size,.pagination-controls__buttons{display:inline-flex;align-items:center;gap:8px;min-width:0}.pagination-controls__size{color:var(--pg-text-muted);font-size:12px;font-weight:850;white-space:nowrap}.pagination-controls__size select{width:104px;min-height:36px;padding:7px 30px 7px 12px;border:1px solid var(--pg-border);border-radius:999px;background:#fff;color:var(--pg-text-primary);font-family:inherit;font-size:13px;font-weight:900;cursor:pointer;outline:none}.pagination-controls__size select:focus{border-color:var(--pg-primary);box-shadow:0 0 0 3px #0664c41f}.pagination-controls__summary{justify-self:center;color:var(--pg-text-secondary);font-size:13px;font-weight:900;text-align:center;white-space:nowrap}.pagination-controls__buttons{justify-content:flex-end;flex-wrap:wrap}.pagination-controls__buttons button,.pagination-controls__page{min-height:34px;border-radius:999px;font-family:inherit;font-size:12px;font-weight:900}.pagination-controls__buttons button{padding:7px 12px;border:1px solid var(--pg-border);background:#fff;color:var(--pg-text-primary);cursor:pointer;transition:var(--pg-transition)}.pagination-controls__buttons button:hover:not(:disabled){background:#fff7ed;border-color:var(--pg-accent-orange);transform:translateY(-1px)}.pagination-controls__buttons button:disabled{color:var(--pg-text-placeholder);cursor:not-allowed;background:#f8fafc}.pagination-controls__page{display:inline-flex;align-items:center;justify-content:center;min-width:64px;padding:7px 10px;background:var(--pg-primary);color:#fff}@media (max-width: 1100px){.entity-grid{grid-template-columns:repeat(2,minmax(350px,450px));justify-content:space-between}.entity-table-card{overflow-x:auto}.entity-table-card--projects .entity-table-row,.entity-table-card--sections .entity-table-row{min-width:860px}.entity-table-card--sensors .entity-table-row{min-width:1160px}}@media (max-width: 760px){.entity-hero{grid-template-columns:1fr}.entity-hero__visual{display:none}.entity-metrics{grid-template-columns:1fr}.entity-toolbar,.entity-toolbar__controls{align-items:stretch;flex-direction:column}.entity-search-range,.entity-toolbar .search-box{width:100%}.entity-search-range{max-width:none;align-items:stretch;flex-direction:column;border-radius:18px;padding:10px}.entity-date-filter{width:100%;align-items:center;flex-wrap:wrap}.entity-date-filter__presets{justify-content:center}.entity-date-filter__field{flex:1 1 190px}.entity-date-filter__field input{width:100%}.entity-date-filter__track{width:100%;height:1px}.entity-grid{grid-template-columns:1fr;justify-content:stretch}.entity-table-card{display:grid;gap:12px;overflow:visible;border:0;border-radius:0;background:transparent;box-shadow:none}.entity-table-row--head{display:none}.entity-table-body{display:grid;gap:12px}.entity-table-card--projects .entity-table-row,.entity-table-card--sections .entity-table-row,.entity-table-card--sensors .entity-table-row,.entity-table-row{min-width:0;min-height:0;grid-template-columns:1fr;gap:14px;padding:16px;border:1px solid var(--pg-border-subtle);border-radius:16px;box-shadow:var(--pg-shadow-sm)}.entity-table-body .entity-table-row:before{top:16px;bottom:auto;left:16px;width:28px;height:3px;border-radius:999px}.entity-table-body .entity-table-row:hover{background:#fff}.entity-table-stat,.entity-table-date,.entity-table-project{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--pg-border-subtle);border-radius:12px;background:#f8fafc}.entity-table-card--projects .entity-table-stat,.entity-table-card--sections .entity-table-stat,.entity-table-card--sections .entity-table-project,.entity-table-card--sensors .entity-table-project{justify-content:space-between;justify-self:auto;text-align:left}.entity-table-stat span,.entity-table-date span,.entity-table-project span{display:inline-flex;color:var(--pg-text-muted);font-size:10px;font-weight:900;letter-spacing:.07em;text-transform:uppercase}.entity-table-stat strong{font-size:18px}.entity-table-project strong{justify-content:flex-end;text-align:right}.entity-table-actions{justify-self:stretch;justify-content:space-between;padding-top:12px;border-top:1px solid var(--pg-border-subtle)}.entity-table-actions .entity-btn{flex:1 1 0}.entity-detail-grid{grid-template-columns:1fr}.pagination-controls{grid-template-columns:1fr;justify-items:stretch}.pagination-controls__summary{justify-self:start;text-align:left}.pagination-controls__buttons{justify-content:flex-start}}.sensor-data-page{display:flex;flex-direction:column;gap:18px;padding:0;background:transparent;border:0;border-radius:0;box-shadow:none}.sensor-data-page .pg-back-button{margin-bottom:0}.sensor-error-title{margin-bottom:8px;color:var(--pg-error);font-weight:800}.sensor-error-retry{margin-top:20px}.sensor-data-hero,.sensor-chart-card,.sensor-log-card{background:#fff;border:1px solid var(--pg-border-subtle);border-radius:18px;box-shadow:0 8px 24px #0f172a0f}.sensor-data-hero{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:18px}.sensor-data-identity{min-width:0;display:flex;align-items:flex-start}.sensor-data-hero__copy{min-width:0}.sensor-data-hero h2,.sensor-chart-card h3,.sensor-log-card h3{margin:0;color:var(--pg-text-primary);font-weight:900;letter-spacing:0}.sensor-data-hero h2{font-size:22px;line-height:1.15;overflow-wrap:anywhere}.sensor-data-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.sensor-data-meta span,.sensor-log-count{display:inline-flex;align-items:center;gap:7px;min-height:28px;padding:5px 10px;border-radius:999px;background:#f8fbff;border:1px solid var(--pg-border-subtle);color:var(--pg-text-secondary);font-size:12px;font-weight:800}.sensor-data-meta span:first-child{color:var(--pg-primary);font-family:SF Mono,Consolas,monospace}.sensor-data-meta__icon{width:18px;height:18px;object-fit:contain;flex-shrink:0}.sensor-data-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.sensor-data-export{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:8px 16px;border-radius:999px;border:1px solid var(--pg-border);background:#fff;color:var(--pg-text-primary);font-family:inherit;font-size:13px;font-weight:900;cursor:pointer;transition:var(--pg-transition)}.sensor-data-export:hover{background:#fff7ed;border-color:var(--pg-accent-orange);transform:translateY(-1px)}.sensor-data-export:disabled{color:var(--pg-text-placeholder);cursor:wait;background:#f8fafc;border-color:var(--pg-border-subtle);transform:none}.sensor-data-export--primary{border-color:#0664c43d}.sensor-data-export__icon{position:relative;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border-radius:7px;color:#fff;font-size:8px;font-weight:900;line-height:1}.sensor-data-export__icon:before{content:"";position:absolute;top:0;right:0;width:7px;height:7px;background:#ffffff9e;border-bottom-left-radius:4px}.sensor-data-export__icon--excel{background:#16a34a}.sensor-data-export__icon--pdf{background:#dc2626}.sensor-export-error{padding:12px 14px;border:1px solid rgba(220,38,38,.22);border-radius:12px;background:#fef2f2;color:#991b1b;font-size:13px;font-weight:800}.sensor-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.sensor-kpi-grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}.sensor-kpi-card{min-height:136px;padding:18px;display:flex;flex-direction:column;border-radius:18px;background:#fff;border:1px solid var(--pg-border-subtle);box-shadow:0 8px 24px #0f172a0d}.sensor-kpi-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.sensor-kpi-card__head span{color:var(--pg-text-muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:0}.sensor-kpi-card__head i{width:10px;height:10px;border-radius:999px;background:var(--kpi-tone)}.sensor-kpi-card__readings{display:grid;grid-template-columns:minmax(0,1fr) minmax(132px,1.28fr) minmax(0,1fr);align-items:end;gap:12px;flex:1}.sensor-kpi-card__reading{min-width:0;display:flex;flex-direction:column;gap:7px;padding-bottom:3px}.sensor-kpi-card__reading:last-child{align-items:flex-end;text-align:right}.sensor-kpi-card__reading span{color:var(--pg-text-muted);font-size:11px;font-weight:900;text-transform:uppercase;line-height:1}.sensor-kpi-card__reading b{color:var(--pg-text-primary);font-size:18px;font-weight:900;line-height:1.05;white-space:nowrap}.sensor-kpi-card__reading--current{align-items:center;justify-content:center;padding:0 12px;text-align:center;transform:translateY(-25px)}.sensor-kpi-card__reading--current strong{display:block;color:var(--pg-text-primary);font-size:31px;line-height:1;font-weight:900;white-space:nowrap}.sensor-kpi-card--blue{--kpi-tone: #0664c4}.sensor-kpi-card--green{--kpi-tone: #16a34a}.sensor-kpi-card--orange{--kpi-tone: #fb6704}.sensor-chart-card{overflow:hidden}.sensor-chart-card__head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid var(--pg-border-subtle)}.sensor-chart-card h3{display:flex;align-items:center;gap:10px;font-size:18px}.sensor-chart-card h3 span{padding:5px 9px;border-radius:999px;background:#fff7ed;color:var(--pg-accent-orange);font-size:11px;font-weight:900}.sensor-chart-card__records{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:5px 0 0;color:var(--pg-text-muted);font-size:13px}.sensor-chart-card__records span{color:inherit;font-size:inherit;font-weight:inherit}.sensor-chart-controls{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.sensor-chart-segment{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:#f8fbff;border:1px solid var(--pg-border-subtle)}.sensor-chart-segment button{min-height:30px;padding:5px 11px;border:0;border-radius:999px;background:transparent;color:var(--pg-text-secondary);font-family:inherit;font-size:12px;font-weight:900;text-transform:capitalize;cursor:pointer;transition:var(--pg-transition)}.sensor-chart-segment button:hover{color:var(--pg-primary)}.sensor-chart-segment button.is-active{background:var(--pg-primary);color:#fff}.sensor-chart-card__body{height:clamp(380px,46vh,520px);padding:22px 24px 24px}.sensor-chart-card__body canvas{width:100%!important;height:100%!important}.sensor-chart-empty,.sensor-log-empty{min-height:220px;display:flex;align-items:center;justify-content:center;color:var(--pg-text-muted);font-size:14px;font-weight:800}.sensor-log-card{padding:20px}.sensor-log-card .pagination-controls{margin-top:16px;border:1px solid var(--pg-border-subtle);border-radius:14px}.sensor-log-card__head{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px}.sensor-log-card h3{font-size:18px}.sensor-table-wrap{width:100%;overflow-x:auto;border:1px solid var(--pg-border-subtle);border-radius:14px}.sensor-data-table{width:100%;min-width:760px;border-collapse:collapse;background:#fff}.sensor-data-table th{padding:13px 14px;background:#f8fbff;color:var(--pg-text-muted);border-bottom:1px solid var(--pg-border-subtle);font-size:11px;font-weight:900;text-align:right;text-transform:uppercase;letter-spacing:0}.sensor-data-table th:first-child,.sensor-data-table td:first-child{text-align:center;width:62px}.sensor-data-table th:nth-child(2),.sensor-data-table td:nth-child(2){text-align:left}.sensor-data-table td{padding:13px 14px;color:var(--pg-text-secondary);border-bottom:1px solid var(--pg-border-subtle);font-size:13px;font-weight:700;text-align:right}.sensor-data-table tr:last-child td{border-bottom:0}.sensor-data-table tbody tr:hover{background:#f8fbff}.sensor-pagination{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-top:16px;padding-top:16px;border-top:1px solid var(--pg-border-subtle)}.sensor-pagination>span{color:var(--pg-text-muted);font-size:13px;font-weight:800}.sensor-pagination div{display:flex;gap:8px;flex-wrap:wrap}.sensor-pagination button{min-height:34px;padding:7px 12px;border-radius:999px;border:1px solid var(--pg-border);background:#fff;color:var(--pg-text-primary);font-family:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:var(--pg-transition)}.sensor-pagination button:hover:not(:disabled){background:#fff7ed;border-color:var(--pg-accent-orange)}.sensor-pagination button:disabled{color:var(--pg-text-placeholder);cursor:not-allowed;background:#f8fafc}@media (max-width: 920px){.sensor-data-hero,.sensor-chart-card__head,.sensor-log-card__head{align-items:stretch;flex-direction:column}.sensor-data-actions,.sensor-chart-controls{justify-content:flex-start}.sensor-kpi-grid,.sensor-kpi-grid--three{grid-template-columns:1fr}}@media (max-width: 640px){.sensor-data-identity{align-items:flex-start}.sensor-data-actions,.sensor-data-export{width:100%}.sensor-chart-card__body{height:340px;padding:18px 12px}}.modal-overlay{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;animation:pg-fade-in .3s ease}.modal-content{background:var(--pg-bg-card-solid);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);padding:0;border-radius:var(--pg-radius-xl);width:90%;max-width:600px;box-shadow:var(--pg-shadow-xl);border:1px solid var(--pg-border-subtle);animation:pg-slide-up .3s ease;overflow:hidden}.modal-header{background:var(--pg-gradient);color:var(--pg-text-white);padding:20px 30px;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:20px;font-weight:600}.modal-close-btn{color:var(--pg-text-white);font-size:28px;font-weight:700;cursor:pointer;transition:transform .2s;background:none;border:none;line-height:1}.modal-close-btn:hover{transform:scale(1.1);color:#e5e7eb}.modal-body{padding:30px;max-height:70vh;overflow-y:auto}.info-block{margin-bottom:25px;padding-bottom:20px;border-bottom:1px solid #f3f4f6}.info-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.info-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:#4b5563;margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}.info-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px}.info-row-label{color:var(--pg-text-muted);font-weight:500}.info-row-value{color:var(--pg-text-primary);font-weight:600;text-align:right;max-width:60%;word-wrap:break-word}.shared-users-container{display:flex;flex-wrap:wrap;gap:8px;margin-top:5px}.shared-user-pill{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#4b5563;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;border:1px solid #d1d5db;display:flex;align-items:center;gap:5px}.shared-user-pill:before{content:"@";color:var(--pg-text-placeholder)}.gap-hero{background:var(--pg-gradient-hero);border-radius:var(--pg-radius-xl);padding:35px;margin-bottom:30px;color:var(--pg-text-white);position:relative;overflow:hidden}.gap-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.22) 0%,transparent 70%);border-radius:50%}.gap-hero h2{font-size:26px;margin-bottom:8px;position:relative;z-index:1;font-weight:800;letter-spacing:-.02em}.gap-hero p{color:#ffffffe0;font-size:15px;position:relative;z-index:1}.gap-input-section{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:30px;margin-bottom:25px;box-shadow:var(--pg-shadow-md);display:flex;gap:15px;align-items:flex-end;flex-wrap:wrap}.gap-input-group{flex:1;min-width:250px}.gap-input-group label{display:block;font-size:13px;font-weight:600;color:#64748b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.gap-input-wrapper{position:relative}.gap-input-wrapper svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#94a3b8;width:20px;height:20px}.gap-input-field{width:100%;padding:14px 16px 14px 44px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;font-family:monospace;transition:var(--pg-transition);background:#f8fafc}.gap-input-field:focus{outline:none;border-color:var(--pg-primary);background:var(--pg-bg-card-solid);box-shadow:0 0 0 4px #0f172a14}.gap-analyze-btn{background:var(--pg-gradient);color:var(--pg-text-white);border:none;padding:14px 32px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:var(--pg-transition);display:flex;align-items:center;gap:10px;white-space:nowrap;height:fit-content;font-family:inherit}.gap-analyze-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:none}.gap-analyze-btn:disabled{opacity:.7;cursor:not-allowed}.quality-meter-container{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:25px;margin-bottom:30px;box-shadow:var(--pg-shadow-sm)}.quality-meter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.quality-meter-title{font-size:16px;font-weight:700;color:#1e293b}.quality-percentage{font-size:32px;font-weight:800;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.quality-track{height:12px;background:#e2e8f0;border-radius:var(--pg-radius-full);overflow:hidden}.quality-fill{height:100%;border-radius:var(--pg-radius-full);transition:width 1s cubic-bezier(.4,0,.2,1);background:linear-gradient(90deg,#ef4444,#f59e0b 30%,#10b981 70%,#10b981);position:relative}.quality-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:pg-shimmer 2s infinite}.quality-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--pg-text-light)}.gaps-table-container{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:25px;box-shadow:var(--pg-shadow-sm)}.gaps-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.gaps-table-title{font-size:18px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:10px}.gaps-count-badge{background:#fef2f2;color:#dc2626;padding:4px 12px;border-radius:var(--pg-radius-full);font-size:13px;font-weight:700}.gaps-count-badge--none{background:#f0fdf4;color:#16a34a}.gaps-table{width:100%;border-collapse:collapse}.gaps-table th{background:#f8fafc;padding:12px 16px;text-align:left;font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid #e2e8f0}.gaps-table td{padding:14px 16px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#475569}.gaps-table tr:hover{background:#f8fafc}.gap-duration{font-weight:700;font-family:SF Mono,monospace;font-size:15px}.gap-duration--critical{color:#dc2626}.gap-duration--warning{color:#d97706}.timestamp-cell{font-family:SF Mono,Monaco,monospace;font-size:13px;color:#64748b}.no-gaps-state{text-align:center;padding:50px 20px}.no-gaps-icon{width:80px;height:80px;background:#f0fdf4;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:36px}.no-gaps-title{font-size:20px;font-weight:700;color:#166534;margin-bottom:8px}.no-gaps-desc{color:#64748b;font-size:14px}.analysis-error-state{background:#fef2f2;border-radius:var(--pg-radius-lg);padding:30px;text-align:center;margin-top:20px}.analysis-error-state h3{color:#991b1b;margin-bottom:10px}.analysis-error-state p{color:#b91c1c;font-size:14px}.spike-hero{background:linear-gradient(135deg,#0664c4,#4fa2f6);border-radius:var(--pg-radius-xl);padding:35px;margin-bottom:30px;color:var(--pg-text-white);position:relative;overflow:hidden}.spike-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.22) 0%,transparent 70%);border-radius:50%}.spike-hero h2{font-size:26px;margin-bottom:8px;position:relative;z-index:1;font-weight:800;letter-spacing:-.02em}.spike-hero p{color:#ffffffe6;font-size:15px;position:relative;z-index:1}.spike-input-section{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:30px;margin-bottom:25px;box-shadow:var(--pg-shadow-md);display:flex;gap:15px;align-items:flex-end;flex-wrap:wrap}.spike-input-group{flex:1;min-width:200px}.spike-input-group label{display:block;font-size:13px;font-weight:600;color:#64748b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.spike-input-wrapper{position:relative}.spike-input-wrapper svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#94a3b8;width:20px;height:20px}.spike-input-field{width:100%;padding:14px 16px 14px 44px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;font-family:monospace;transition:var(--pg-transition);background:#f8fafc}.spike-input-field:focus{outline:none;border-color:var(--pg-primary);background:var(--pg-bg-card-solid);box-shadow:0 0 0 4px #0f172a14}.spike-input-field--no-icon{padding-left:16px}.spike-analyze-btn{background:var(--pg-gradient);color:var(--pg-text-white);border:none;padding:14px 32px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:var(--pg-transition);display:flex;align-items:center;gap:10px;white-space:nowrap;height:fit-content;font-family:inherit}.spike-analyze-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:none}.spike-analyze-btn:disabled{opacity:.7;cursor:not-allowed}.spike-chart-container{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:25px;margin-bottom:30px;box-shadow:var(--pg-shadow-sm)}.spike-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.spike-chart-title{font-size:18px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:10px}.spike-chart-wrapper{position:relative;height:350px}.spikes-table-container{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:25px;box-shadow:var(--pg-shadow-sm)}.spikes-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.spikes-table-title{font-size:18px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:10px}.spikes-count-badge{background:#fef2f2;color:#dc2626;padding:4px 12px;border-radius:var(--pg-radius-full);font-size:13px;font-weight:700}.spikes-count-badge--none{background:#f0fdf4;color:#16a34a}.spikes-table{width:100%;border-collapse:collapse}.spikes-table th{background:#eef6ff;padding:12px 16px;text-align:left;font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid #cfe4fc}.spikes-table td{padding:14px 16px;border-bottom:1px solid #e8f2fc;font-size:14px;color:#475569}.spikes-table tr:hover{background:#f4f9ff}.spike-value-cell{font-weight:800;font-family:SF Mono,monospace;font-size:16px;padding:6px 12px;border-radius:8px;display:inline-block}.spike-value-cell--high{background:#fef2f2;color:#dc2626}.spike-value-cell--low{background:#e8f2fc;color:#0664c4}.no-spikes-state{text-align:center;padding:50px 20px}.no-spikes-icon{width:80px;height:80px;background:#f0fdf4;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:36px}.no-spikes-title{font-size:20px;font-weight:700;color:#166534;margin-bottom:8px}.no-spikes-desc{color:#64748b;font-size:14px}.spike-direction-arrow{font-size:18px;font-weight:900;margin-right:4px}.spike-direction-up{color:#dc2626}.spike-direction-down{color:#2563eb}.qr-hero{background:var(--pg-gradient-hero);border-radius:var(--pg-radius-xl);padding:40px;margin-bottom:30px;color:var(--pg-text-white);position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:center}.qr-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.2) 0%,transparent 70%);border-radius:50%}.qr-hero-content{display:flex;gap:20px;align-items:center;position:relative;z-index:1}.qr-hero-icon{font-size:48px;width:80px;height:80px;background:#ffffff1a;border-radius:20px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.qr-hero h2{font-size:28px;margin-bottom:8px;font-weight:800;letter-spacing:-.02em}.qr-hero p{color:#ffffffe0;font-size:15px;max-width:600px;line-height:1.6}.qr-hero-badge{background:#10b98133;border:1px solid rgba(16,185,129,.4);padding:10px 20px;border-radius:12px;display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:#10b981;position:relative;z-index:1}.qr-input-section{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:30px;margin-bottom:25px;box-shadow:var(--pg-shadow-md);display:flex;gap:15px;align-items:flex-end;flex-wrap:wrap}.qr-input-group{flex:1;min-width:220px}.qr-input-group label{display:block;font-size:13px;font-weight:700;color:#64748b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.qr-input-wrapper{position:relative}.qr-input-wrapper svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#94a3b8;width:20px;height:20px}.qr-input-field{width:100%;padding:14px 16px 14px 44px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;font-family:SF Mono,Monaco,monospace;transition:var(--pg-transition);background:#f8fafc}.qr-input-field:focus{outline:none;border-color:var(--pg-primary);background:var(--pg-bg-card-solid);box-shadow:0 0 0 4px #0f172a14}.qr-input-field--no-icon{padding-left:16px}.qr-analyze-btn{background:var(--pg-gradient);color:var(--pg-text-white);border:none;padding:14px 32px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:var(--pg-transition);display:flex;align-items:center;gap:10px;white-space:nowrap;height:fit-content;font-family:inherit}.qr-analyze-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:none}.qr-analyze-btn:disabled{opacity:.7;cursor:not-allowed}.qr-summary-card{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:24px;box-shadow:var(--pg-shadow-sm);display:flex;align-items:center;gap:16px;transition:transform .3s;border-left:5px solid transparent}.qr-summary-card:hover{transform:translateY(-4px)}.qr-summary-card--blue{border-left-color:var(--pg-primary)}.qr-summary-card--orange{border-left-color:var(--pg-warning)}.qr-summary-card--red{border-left-color:var(--pg-error)}.qr-summary-card--green{border-left-color:var(--pg-success)}.qr-summary-icon{font-size:32px;width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#f1f5f9}.qr-quality-meter{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:28px;margin-bottom:30px;box-shadow:var(--pg-shadow-sm)}.qr-meter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.qr-meter-title{font-size:17px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:10px}.qr-meter-percentage{font-size:36px;font-weight:800;background:var(--pg-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.qr-meter-track{height:14px;background:#e2e8f0;border-radius:var(--pg-radius-full);overflow:hidden}.qr-meter-fill{height:100%;border-radius:var(--pg-radius-full);transition:width 1.2s cubic-bezier(.4,0,.2,1);background:linear-gradient(90deg,#ef4444,#f59e0b,#eab308,#84cc16,#10b981);position:relative}.qr-meter-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:pg-shimmer 2.5s infinite}.qr-meter-labels{display:flex;justify-content:space-between;margin-top:10px;font-size:11px;color:#94a3b8;font-weight:600}.qr-chart-section{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:28px;margin-bottom:30px;box-shadow:var(--pg-shadow-sm)}.qr-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.qr-chart-title{font-size:18px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:10px}.qr-chart-legend{display:flex;gap:16px}.qr-legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:#64748b;font-weight:600}.qr-legend-dot{width:12px;height:12px;border-radius:50%}.qr-chart-wrapper{position:relative;height:380px}.qr-issues-table-section{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-lg);padding:28px;margin-bottom:30px;box-shadow:var(--pg-shadow-sm)}.qr-issues-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.qr-issues-title{font-size:18px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:10px}.qr-issues-badge{background:#fef2f2;color:#dc2626;padding:6px 16px;border-radius:var(--pg-radius-full);font-size:13px;font-weight:700}.qr-issues-badge--none{background:#f0fdf4;color:#16a34a}.qr-issues-table{width:100%;border-collapse:collapse}.qr-issues-table th{background:#f8fafc;padding:14px 18px;text-align:left;font-size:12px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.07em;border-bottom:2px solid #e2e8f0}.qr-issues-table td{padding:16px 18px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#475569}.qr-issues-table tr:hover{background:#f8fafc}.qr-issue-type-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:10px;font-size:12px;font-weight:800}.qr-issue-type-badge--gap{background:#fffbeb;color:#d97706}.qr-issue-type-badge--spike{background:#fee2e2;color:#dc2626}.qr-no-issues-state{text-align:center;padding:60px 20px}.qr-no-issues-icon{width:90px;height:90px;background:#f0fdf4;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:42px}.qr-no-issues-title{font-size:22px;font-weight:800;color:#166534;margin-bottom:10px}.qr-no-issues-desc{color:#64748b;font-size:15px}.qr-fix-action-bar{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:var(--pg-radius-lg);padding:24px 30px;margin-bottom:30px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 8px 25px #fbbf2433}.qr-fix-info{display:flex;align-items:center;gap:16px}.qr-fix-icon{font-size:36px;width:64px;height:64px;background:var(--pg-bg-card-solid);border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #0000001a}.qr-fix-title{font-size:18px;font-weight:800;color:#92400e;margin-bottom:4px}.qr-fix-desc{font-size:14px;color:#b45309;max-width:500px}.qr-fix-actions{display:flex;gap:12px}.qr-preview-btn{background:var(--pg-bg-card-solid);color:#92400e;border:2px solid #fbbf24;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:var(--pg-transition);display:flex;align-items:center;gap:8px;font-family:inherit}.qr-preview-btn:hover{background:#fef3c7;transform:translateY(-2px)}.qr-execute-fix-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--pg-text-white);border:none;padding:14px 28px;border-radius:12px;font-size:15px;font-weight:800;cursor:pointer;transition:var(--pg-transition);display:flex;align-items:center;gap:10px;box-shadow:0 6px 20px #f59e0b66;font-family:inherit}.qr-execute-fix-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 30px #f59e0b80}.qr-execute-fix-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.qr-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000}.qr-modal-content{background:var(--pg-bg-card-solid);border-radius:var(--pg-radius-xl);padding:40px;max-width:520px;width:90%;box-shadow:0 25px 60px #0000004d}.qr-modal-header{text-align:center;margin-bottom:30px}.qr-modal-header h3{font-size:22px;color:#1e293b;margin-top:16px}.qr-spinner-large{width:60px;height:60px;border:4px solid #e2e8f0;border-top:4px solid var(--pg-primary);border-radius:50%;animation:pg-spin 1s linear infinite;margin:0 auto}.qr-progress-steps{display:flex;justify-content:space-between;margin-bottom:30px;position:relative}.qr-progress-steps:before{content:"";position:absolute;top:20px;left:40px;right:40px;height:2px;background:#e2e8f0;z-index:0}.qr-progress-step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:1}.qr-step-number{width:40px;height:40px;border-radius:50%;background:#e2e8f0;color:#64748b;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;transition:var(--pg-transition)}.qr-progress-step--active .qr-step-number{background:var(--pg-primary);color:var(--pg-text-white);box-shadow:none}.qr-progress-step--completed .qr-step-number{background:#10b981;color:var(--pg-text-white)}.qr-step-text{font-size:12px;color:#64748b;font-weight:600;text-align:center;max-width:80px}.qr-progress-step--active .qr-step-text{color:var(--pg-primary);font-weight:700}.qr-progress-bar-track{height:10px;background:#e2e8f0;border-radius:var(--pg-radius-full);overflow:hidden;margin-bottom:10px}.qr-progress-bar-fill{height:100%;background:linear-gradient(90deg,#0664c4,#4fa2f6);border-radius:var(--pg-radius-full);transition:width .5s ease}.qr-progress-percent{text-align:center;font-size:20px;font-weight:800;color:var(--pg-primary)}.qr-success-icon{font-size:72px;margin-bottom:20px;text-align:center}.qr-success-stats{background:#f0fdf4;border-radius:12px;padding:20px;margin:24px 0;text-align:left}.qr-success-stat-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;border-bottom:1px solid #bbf7d0}.qr-success-stat-row:last-child{border-bottom:none}.qr-success-stat-label{color:#166534;font-weight:600}.qr-success-stat-value{color:#15803d;font-weight:800}@media (max-width: 768px){.qr-hero{flex-direction:column;gap:20px;padding:30px}.qr-hero p{max-width:100%}.qr-fix-action-bar{flex-direction:column;gap:20px}.qr-fix-actions{width:100%}.qr-fix-actions button{flex:1;justify-content:center}}.combined-report-page{display:flex;flex-direction:column;gap:16px}.combined-report-page.has-report-dock{padding-bottom:116px}.combined-report-panel{padding:22px;border:1px solid var(--pg-border-subtle);border-radius:18px;background:#fff;box-shadow:var(--pg-shadow-sm)}.combined-report-panel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.combined-report-panel__head h3{margin:0;color:var(--pg-text-primary);font-size:20px;font-weight:950;line-height:1.2}.combined-report-panel__head p{margin:6px 0 0;color:var(--pg-text-muted);font-size:13px}.combined-report-search{width:min(430px,100%)}.combined-report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.combined-report-sensor{position:relative;min-height:150px;display:flex;flex-direction:column;align-items:stretch;gap:14px;padding:17px;border:1px solid var(--pg-border-subtle);border-radius:16px;background:linear-gradient(180deg,#fff,#fbfdff);color:inherit;font-family:inherit;text-align:left;cursor:pointer;box-shadow:0 10px 26px #0f172a0a;transition:var(--pg-transition)}.combined-report-sensor:hover:not(:disabled){border-color:#fb67046b;box-shadow:0 16px 34px #0f172a14;transform:translateY(-2px)}.combined-report-sensor:disabled{opacity:.52;cursor:not-allowed}.combined-report-sensor.is-selected{border-color:var(--pg-primary);background:#f8fbff;box-shadow:0 0 0 3px #0664c41c,0 16px 34px #0664c417}.combined-report-sensor__check{position:absolute;top:14px;right:14px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--pg-border);border-radius:10px;background:#fff;color:#fff;font-size:0;font-weight:950}.combined-report-sensor.is-selected .combined-report-sensor__check{background:var(--pg-primary);border-color:var(--pg-primary)}.combined-report-sensor.is-selected .combined-report-sensor__check:before{content:"✓";font-size:14px}.combined-report-sensor__top{display:flex;align-items:flex-start;gap:12px;padding-right:38px}.combined-report-sensor__icon{width:42px;height:42px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(6,100,196,.12);border-radius:14px;background:#f8fbff}.combined-report-sensor__icon img{width:24px;height:24px;object-fit:contain}.combined-report-sensor__main{min-width:0}.combined-report-sensor__main strong{display:block;color:var(--pg-text-primary);font-size:15px;font-weight:950;line-height:1.25;overflow-wrap:anywhere}.combined-report-sensor__main code{display:inline-flex;margin-top:7px;color:var(--pg-primary);font-family:SF Mono,Consolas,monospace;font-size:11px;font-weight:900;overflow-wrap:anywhere}.combined-report-sensor__meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}.combined-report-meta-chip{display:inline-flex;align-items:center;gap:6px;max-width:100%;min-height:28px;padding:5px 9px;border:1px solid var(--pg-border-subtle);border-radius:999px;background:#f8fafc;color:var(--pg-text-secondary);font-size:11px;font-weight:850}.combined-report-meta-chip img{width:16px;height:16px;flex:0 0 auto;object-fit:contain}.combined-report-meta-chip span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combined-report-dock{position:fixed;left:50%;bottom:18px;z-index:30;width:min(520px,calc(100vw - 56px));display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px;border:1px solid rgba(6,100,196,.2);border-radius:18px;background:#fffffff5;box-shadow:0 24px 60px #0f172a2e;transform:translate(-50%);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.combined-report-dock.is-ready{border-color:#0596693d}.combined-report-dock__summary{display:flex;align-items:center;gap:10px;min-width:0}.combined-report-dock__count{width:46px;height:46px;flex:0 0 auto;display:inline-flex;align-items:baseline;justify-content:center;gap:2px;padding-top:10px;border:1px solid var(--pg-border);border-radius:16px;background:#f8fbff;color:var(--pg-primary)}.combined-report-dock__count strong{font-size:19px;font-weight:950;line-height:1}.combined-report-dock__count span{color:var(--pg-text-muted);font-size:12px;font-weight:900}.combined-report-dock__copy{min-width:0}.combined-report-dock__copy>strong{display:block;color:var(--pg-text-primary);font-size:13px;font-weight:950}.combined-report-dock__actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:0 0 auto}.combined-report-generate{min-height:38px;padding:9px 14px;border:1px solid transparent;border-radius:999px;background:var(--pg-primary);color:#fff;font-family:inherit;font-size:12px;font-weight:950;cursor:pointer;white-space:nowrap;transition:var(--pg-transition)}.combined-report-generate:hover:not(:disabled){background:var(--pg-accent-orange);transform:translateY(-1px)}.combined-report-generate:disabled{cursor:not-allowed;background:#cbd5e1}.combined-report-dock .entity-btn:disabled{color:var(--pg-text-placeholder);cursor:not-allowed;background:#f8fafc}.combined-report-empty{grid-column:1 / -1;padding:46px 20px;border-radius:16px;background:#f8fafc;color:var(--pg-text-muted);text-align:center;font-size:14px;font-weight:850}.combined-report-alert{margin-bottom:14px;padding:12px 14px;border-radius:12px;font-size:13px;font-weight:850}.combined-report-alert--error{background:#fef2f2;color:#991b1b;border:1px solid rgba(220,38,38,.22)}.combined-report-alert--success{background:#f0fdf4;color:#047857;border:1px solid #bbf7d0}@media (max-width: 760px){.combined-report-page.has-report-dock{padding-bottom:206px}.combined-report-panel{padding:16px}.combined-report-panel__head,.combined-report-dock,.combined-report-dock__actions{align-items:stretch;flex-direction:column}.combined-report-grid{grid-template-columns:1fr}.combined-report-dock{width:calc(100vw - 24px);bottom:12px;gap:12px}.combined-report-dock__summary{align-items:flex-start}.combined-report-generate,.combined-report-dock .entity-btn{width:100%}}
