*{box-sizing:border-box;margin:0;padding:0}body{color:#1a202c;background:#eef0f3;min-height:100vh;font-family:Poppins,Segoe UI,Arial,sans-serif}button,input,select{font:inherit}button{cursor:pointer}.auth-shell{background:linear-gradient(135deg,#102b3d 0%,#15384d 58%,#ee7203 160%);align-items:center;min-height:100vh;padding:24px;display:flex}.auth-panel{background:#fff;border-radius:8px;gap:20px;width:100%;max-width:460px;margin:0 auto;padding:32px;display:grid;box-shadow:0 24px 70px #0000003d}.auth-brand-logo{object-fit:contain;width:100%;max-width:220px;height:auto;display:block}.auth-panel.compact{max-width:360px}.eyebrow{color:#ee7203;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:.78rem;font-weight:800}.auth-panel h1{color:#112c3e;margin-bottom:10px;font-size:2rem;line-height:1.08}.auth-panel p{color:#55616d;line-height:1.6}.login-form{gap:14px;display:grid}.login-form label{color:#112c3e;gap:7px;font-size:.85rem;font-weight:700;display:grid}.login-form input{color:#112c3e;background:#fff;border:2px solid #dfe5ea;border-radius:8px;outline:none;padding:11px 12px}.login-form input:focus{border-color:#ee7203}.primary-btn,.secondary-btn,.logout-btn{border:0;border-radius:8px;font-weight:800;transition:background .2s,color .2s,transform .2s}.primary-btn{color:#fff;background:#112c3e;padding:12px 16px}.secondary-btn{color:#112c3e;background:#f4f6f8;padding:12px 16px}.primary-btn:hover,.logout-btn:hover{background:#ee7203}.secondary-btn:hover{color:#ee7203}.primary-btn:disabled,.secondary-btn:disabled{cursor:not-allowed;opacity:.55}.form-error,.setup-note{color:#9d2727;background:#fff2f2;border:1px solid #ffd4d4;border-radius:8px;padding:10px 12px;font-size:.86rem}.setup-note{color:#7a4309;background:#fff8ef;border-color:#ffd9ad}.header{color:#fff;background:#112c3e;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 36px;display:flex}.header-logos{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:0;display:flex}.logo-further{flex-shrink:0;align-items:center;display:flex}.logo-further svg,.logo-further-text{display:none}.logo-further-mark{object-fit:contain;flex-shrink:0;width:auto;height:62px;display:block}.logo-divider{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:30px;margin:0 6px;display:flex;position:relative}.logo-divider:before{content:"";background:linear-gradient(#ffffff2e,#ffffffe0,#ffffff2e);border-radius:999px;width:1px;height:26px;box-shadow:0 0 10px #ffffff1f}.logo-accenture{align-items:center;gap:6px;display:flex}.logo-accenture svg{width:auto;height:24px;display:block;transform:translateY(-2px)}.header-center{text-align:center;flex:1;padding:0 24px}.header-center h1{font-size:1.35rem;font-weight:800}.header-center p{opacity:.65;margin-top:4px;font-size:.82rem}.header-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.badge,.badge-outline{white-space:nowrap;border-radius:999px;padding:6px 14px;font-size:.8rem;font-weight:800}.badge{color:#fff;background:#ee7203}.badge-outline{color:#ee7203;border:2px solid #ee7203}.logout-btn{color:#fff;background:#ffffff1f;padding:8px 12px}.filter-bar{z-index:100;background:#fff;border-bottom:3px solid #ee7203;flex-wrap:wrap;align-items:center;gap:20px;padding:12px 36px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #00000012}.filter-group{align-items:center;gap:8px;display:flex}.filter-label{color:#112c3e;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;font-size:.75rem;font-weight:800}.filter-select{appearance:none;color:#112c3e;cursor:pointer;background:#fff;border:2px solid #dee2e6;border-radius:8px;outline:none;min-width:190px;padding:8px 14px}.filter-select:focus,.filter-select:hover{border-color:#ee7203}.reset-btn{color:#fff;white-space:nowrap;background:#112c3e;border:0;border-radius:8px;padding:9px 18px;font-size:.85rem;font-weight:800}.reset-btn:hover{background:#ee7203}.active-badge{color:#fff;background:#ee7203;border-radius:999px;padding:5px 12px;font-size:.76rem;font-weight:800}.results-count{color:#666;margin-left:auto;font-size:.82rem;font-weight:600}.results-count span{color:#112c3e;font-weight:800}.container{max-width:1440px;margin:0 auto;padding:24px 36px 40px}.notice,.user-strip{color:#7a4309;background:#fff8ef;border:1px solid #ffd9ad;border-radius:8px;margin-bottom:16px;padding:10px 12px;font-size:.86rem}.notice-error{color:#9d2727;background:#fff2f2;border-color:#ffd4d4}.user-strip{color:#64717f;background:#fff;border-color:#e7eaee;justify-content:flex-end;align-items:center;gap:8px;display:flex}.user-strip strong{color:#112c3e}.kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}.kpi-card{color:#fff;background:#112c3e;border-radius:8px;padding:22px 20px;position:relative;overflow:hidden}.kpi-card:before{content:"";background:#ee720326;border-radius:50%;width:80px;height:80px;position:absolute;top:-20px;right:-20px}.kpi-card.accent{background:linear-gradient(135deg,#ee7203,#f59234)}.kpi-label{color:#ee7203;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;font-size:.72rem;font-weight:800}.kpi-card.accent .kpi-label{color:#fff}.kpi-value{font-variant-numeric:tabular-nums;overflow-wrap:anywhere;font-size:2.6rem;font-weight:800;line-height:1}.kpi-value.kpi-city{padding-top:6px;font-size:1.45rem;line-height:1.15}.kpi-sub{opacity:.6;margin-top:7px;font-size:.76rem}.section-grid{grid-template-columns:2fr 1fr;gap:16px;margin-bottom:20px;display:grid}.section-grid-3{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;display:grid}.card{background:#fff;border-radius:8px;padding:22px;box-shadow:0 2px 10px #0000000d}.table-card{margin-bottom:20px}.card-title{color:#112c3e;letter-spacing:.05em;text-transform:uppercase;border-bottom:2px solid #ee7203;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:10px;font-size:.8rem;font-weight:800;display:flex}.card-title-tag{color:#666;letter-spacing:0;text-transform:none;background:#f4f6f8;border-radius:6px;padding:3px 8px;font-size:.72rem;font-weight:600}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:820px;font-size:.85rem}th{color:#fff;text-align:center;white-space:nowrap;background:#112c3e;padding:11px 12px;font-size:.75rem;font-weight:800}th:first-child{text-align:left;border-radius:6px 0 0 6px;min-width:120px}th:last-child{border-radius:0 6px 6px 0}th.col-highlight{background:#ee7203}td{text-align:center;border-bottom:1px solid #f0f2f5;padding:10px 12px}td:first-child{color:#112c3e;text-align:left;font-weight:700}tr:hover td{background:#f8f9fb}tr.total-row td{color:#fff;background:#112c3e;border-bottom:0;font-weight:800}tr.total-row td.col-highlight-cell{background:#ee7203}.muted-cell{color:#888;font-size:.8rem}.pill{border-radius:999px;min-width:44px;padding:3px 10px;font-size:.82rem;font-weight:800;display:inline-block}.pill-5{color:#fff;background:#2ecc71}.pill-4{color:#1a5c2e;background:#a8e6cf}.pill-3{color:#7a5000;background:#ffe066}.pill-2{color:#7a3000;background:#ffb347}.pill-1{color:#fff;background:#e74c3c}.pill-total{color:#fff;background:#ee7203}.ranking-list{list-style:none}.rank-item{border-bottom:1px solid #f0f2f5;align-items:center;gap:12px;padding:11px 0;display:flex}.rank-item:last-child{border-bottom:0}.rank-medal{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.9rem;font-weight:800;display:flex}.medal-1{color:#fff;background:#ee7203}.medal-2{color:#fff;background:#aab2bc}.medal-3{color:#fff;background:#c97b3a}.medal-4,.medal-5{color:#112c3e;background:#f0f2f5}.rank-info{flex:1}.rank-city{color:#112c3e;font-size:.95rem;font-weight:800}.rank-score{color:#888;margin-top:1px;font-size:.78rem}.rank-bar-bg{background:#f0f2f5;border-radius:4px;flex-shrink:0;width:80px;height:8px;overflow:hidden}.rank-bar-fill{background:#ee7203;border-radius:4px;height:100%}.dim-row{border-bottom:1px solid #f5f5f5;align-items:center;gap:12px;padding:7px 0;display:flex}.dim-row:last-child{border-bottom:0}.dim-name{color:#112c3e;flex-shrink:0;width:130px;font-size:.84rem;font-weight:700}.dim-bar-bg{background:#f0f2f5;border-radius:5px;flex:1;height:10px;overflow:hidden}.dim-bar-fill{border-radius:5px;height:100%}.dim-val{color:#112c3e;text-align:right;width:42px;font-size:.84rem;font-weight:800}.comment-list{max-height:320px;padding-right:4px;overflow-y:auto}.comment-item{border-bottom:1px solid #f5f5f5;padding:12px 0}.comment-item:last-child{border-bottom:0}.comment-tags{flex-wrap:wrap;gap:6px;margin-bottom:6px;display:flex}.tag{white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:.72rem;font-weight:800}.tag-prog{color:#112c3e;background:#e8eff4}.tag-city{color:#c05a00;background:#fff3e0}.comment-text{color:#555;font-size:.87rem;font-style:italic;line-height:1.55}.no-data{color:#aaa;text-align:center;padding:28px 16px;font-size:.9rem;font-style:italic}.gallery-section{background:#fff;margin-top:8px;padding-bottom:40px}.gallery-header{background:#112c3e;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:8px;padding:28px 36px 24px;display:flex}.gallery-title{color:#fff;font-size:1.5rem;font-weight:800}.gallery-title span{color:#ee7203}.gallery-subtitle{color:#ffffff94;margin-top:4px;font-size:.82rem}.gallery-tabs{background:#f4f6f8;border-bottom:2px solid #dee2e6;gap:0;padding:0 36px;display:flex;overflow-x:auto}.tab-btn{color:#666;white-space:nowrap;background:0 0;border:0;border-bottom:3px solid #0000;margin-bottom:-2px;padding:13px 20px;font-size:.85rem;font-weight:800}.tab-btn:hover{color:#112c3e}.tab-btn.active{color:#ee7203;border-bottom-color:#ee7203}.gallery-body{padding:28px 36px 0}.city-group{margin-bottom:36px}.city-label-row{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.city-name{color:#112c3e;align-items:center;gap:8px;font-size:1rem;font-weight:800;display:flex}.city-name:before{content:"";background:#ee7203;border-radius:2px;width:4px;height:18px;display:inline-block}.photo-count-tag{color:#888;background:#f4f6f8;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:800}.city-photos{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.photo-wrap{aspect-ratio:4/3;background:#f0f2f5;border:0;border-radius:8px;padding:0;display:block;position:relative;overflow:hidden}.photo-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .35s;display:block}.photo-wrap:hover img{transform:scale(1.06)}.lightbox{z-index:9999;background:#000000ed;flex-direction:column;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.lightbox.open{display:flex}.lightbox-img{object-fit:contain;border-radius:8px;max-width:88vw;max-height:82vh;box-shadow:0 20px 60px #00000080}.lb-close,.lb-nav{color:#fff;background:#ffffff1f;border:0}.lb-close{border-radius:999px;width:38px;height:38px;font-size:1.2rem;line-height:1;position:absolute;top:18px;right:26px}.lb-close:hover,.lb-nav:hover{background:#ee7203bf}.lb-caption{color:#ffffff9e;margin-top:12px;font-size:.82rem}.lb-nav{border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:1.8rem;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lb-prev{left:18px}.lb-next{right:18px}.footer{color:#aaa;text-align:center;background:#fff;border-top:1px solid #e0e0e0;padding:20px;font-size:.78rem}@media (max-width:1024px){.kpi-row{grid-template-columns:repeat(2,1fr)}.section-grid,.section-grid-3{grid-template-columns:1fr}}@media (max-width:700px){.auth-panel{padding:24px}.container,.header,.filter-bar{padding-left:16px;padding-right:16px}.header-center{display:none}.filter-group{flex-direction:column;align-items:stretch;width:100%}.filter-select,.reset-btn,.results-count{width:100%;margin-left:0}.kpi-row{grid-template-columns:1fr}.card-title{flex-direction:column;align-items:flex-start;gap:8px}.gallery-header,.gallery-tabs,.gallery-body{padding-left:16px;padding-right:16px}.city-photos{grid-template-columns:repeat(2,1fr);gap:8px}.lb-nav{width:40px;height:40px}}
