*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{background:#e8eaf0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif}.app-shell{width:100%;max-width:480px;min-height:100vh;margin:0 auto;background:#fff;overflow:hidden;position:relative;display:flex;flex-direction:column}.screens{flex:1;overflow:hidden;position:relative}.screen{display:none;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden}.screen.active{display:flex}.sidebar-brand{display:none}.bottom-nav{background:#fff;border-top:1px solid #E5E7EB;padding:8px 0 20px;display:flex;justify-content:space-around;align-items:center;flex-shrink:0;position:sticky;bottom:0;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:4px 12px;border-radius:10px;transition:all .15s}.nav-item svg{width:22px;height:22px}.nav-item span{font-size:10px;color:#9ca3af}.nav-item.active span{color:#2563eb;font-weight:600}.nav-item.active svg path,.nav-item.active svg rect,.nav-item.active svg circle{stroke:#2563eb}.header-dark{background:#0d1629;padding:20px 24px 28px;flex-shrink:0}.header-dark .logo-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.logo-text{color:#fff;font-size:18px;font-weight:800;letter-spacing:1px}.logo-sub{color:#ffffff80;font-size:10px;letter-spacing:3px;display:block;text-align:center}.header-logo-img{height:24px;display:block}.notif-btn{width:36px;height:36px;background:#ffffff1a;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer}.notif-badge{position:absolute;top:-2px;right:-2px;width:16px;height:16px;background:#ef4444;border-radius:50%;font-size:9px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.greeting{color:#fff9;font-size:13px;margin-bottom:4px}.greeting-name{color:#fff;font-size:24px;font-weight:700;margin-bottom:12px}.status-pill{display:inline-flex;align-items:center;gap:6px;background:#ffffff1a;border-radius:20px;padding:4px 12px;font-size:12px;color:#fff}.green-dot{width:7px;height:7px;background:#22c55e;border-radius:50%}.content-area{background:#f0f2f7;flex:1;padding:20px 16px}.card{background:#fff;border-radius:16px;padding:16px;margin-bottom:16px;box-shadow:0 1px 4px #0000000f}.section-title{font-size:15px;font-weight:600;color:#111827;margin-bottom:14px}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.kpi-item{background:#f9fafb;border-radius:12px;padding:12px;display:flex;align-items:flex-start;gap:10px}.kpi-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-icon.blue{background:#eff6ff}.kpi-icon.green{background:#f0fdf4}.kpi-icon.purple{background:#f5f3ff}.kpi-icon.orange{background:#fff7ed}.kpi-label{font-size:11px;color:#6b7280;margin-bottom:2px}.kpi-value{font-size:17px;font-weight:700;color:#111827}.quick-access{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.qa-item{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer}.qa-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center}.qa-icon.blue{background:#eff6ff}.qa-icon.green{background:#f0fdf4}.qa-icon.purple{background:#f5f3ff}.qa-icon.orange{background:#fff7ed}.qa-label{font-size:10px;color:#374151;font-weight:500;text-align:center}.evidence-preview{display:flex;gap:12px;align-items:flex-start}.evidence-img{width:72px;height:72px;border-radius:10px;object-fit:cover;background:#1a2744;flex-shrink:0;overflow:hidden}.evidence-info{flex:1}.evidence-loc{font-size:13px;font-weight:600;color:#111827;margin-bottom:4px}.evidence-date{font-size:11px;color:#6b7280;margin-bottom:8px}.link-blue{font-size:13px;color:#2563eb;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px}.header-light{background:#fff;padding:20px 24px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #F3F4F6;flex-shrink:0}.header-title{font-size:18px;font-weight:700;color:#111827}.back-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer}.tabs{background:#fff;display:flex;padding:0 16px;border-bottom:1px solid #F3F4F6;flex-shrink:0}.tab{padding:12px 16px;font-size:13px;font-weight:500;color:#9ca3af;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}.tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.campaign-list{flex:1;overflow-y:auto;padding:12px 16px;background:#f0f2f7}.campaign-card{background:#fff;border-radius:14px;padding:14px;margin-bottom:10px;display:flex;align-items:center;gap:12px;cursor:pointer;box-shadow:0 1px 3px #0000000f}.campaign-thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;flex-shrink:0}.campaign-info{flex:1;min-width:0}.campaign-name{font-size:14px;font-weight:600;color:#111827;margin-bottom:6px}.badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;margin-bottom:6px}.badge.activa{background:#d1fae5;color:#059669}.badge.programada{background:#dbeafe;color:#2563eb}.badge.finalizada{background:#f3f4f6;color:#6b7280}.campaign-meta{font-size:11px;color:#6b7280;display:flex;align-items:center;gap:4px;margin-bottom:3px}.progress-bar{background:#e5e7eb;border-radius:3px;height:4px;margin-top:6px}.progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#2563eb,#3b82f6)}.progress-label{font-size:10px;color:#9ca3af;margin-top:3px}.chevron{color:#d1d5db;font-size:16px;flex-shrink:0}.new-campaign-footer{background:#f0f2f7;padding:12px 16px 8px;flex-shrink:0}.hint-text{text-align:center;font-size:12px;color:#9ca3af;margin-bottom:10px}.btn-primary{width:100%;background:#2563eb;color:#fff;border:none;border-radius:12px;padding:14px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.btn-primary:hover{background:#1d4ed8}.detail-header{background:#fff;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #F3F4F6;flex-shrink:0}.campaign-hero{background:#fff;padding:16px;display:flex;gap:14px;align-items:flex-start;flex-shrink:0;border-bottom:1px solid #F3F4F6}.hero-thumb{width:80px;height:80px;border-radius:12px;background:#c00;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff;text-align:center}.hero-info{flex:1}.hero-name{font-size:17px;font-weight:700;color:#111827;margin-bottom:6px}.hero-meta{font-size:12px;color:#6b7280;display:flex;align-items:center;gap:5px;margin-bottom:3px}.detail-tabs{background:#fff;display:flex;border-bottom:1px solid #E5E7EB;flex-shrink:0}.detail-tab{flex:1;text-align:center;padding:12px 4px;font-size:12px;font-weight:500;color:#9ca3af;cursor:pointer;border-bottom:2px solid transparent}.detail-tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.detail-content{flex:1;overflow-y:auto;background:#f0f2f7;padding:14px}.status-card{background:#fff;border-radius:14px;padding:14px;margin-bottom:12px;display:flex;align-items:center;gap:12px}.status-icon-big{width:42px;height:42px;background:#22c55e;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-main-text{font-size:14px;font-weight:600;color:#111827}.status-sub-text{font-size:12px;color:#6b7280}.alcance-card{background:#fff;border-radius:14px;padding:14px;margin-bottom:12px}.alcance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}.alcance-item{text-align:center}.alcance-label{font-size:10px;color:#9ca3af;margin-bottom:3px}.alcance-value{font-size:16px;font-weight:700;color:#111827}.map-placeholder{width:100%;height:110px;background:linear-gradient(135deg,#e8f4f8,#d4e9f7);border-radius:10px;margin-top:10px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.map-pin{position:absolute;width:10px;height:10px;background:#2563eb;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 4px #0003}.evidencias-header{background:#0d1629;padding:20px 24px 18px;flex-shrink:0}.ev-logo-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.ev-filter-row{display:flex;gap:8px}.filter-chip{padding:6px 14px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:5px;color:#fff9;background:#ffffff14}.filter-chip.active{background:#ffffff2e;color:#fff}.filter-btn-right{margin-left:auto;background:#ffffff14;color:#fff9}.ev-section-title{font-size:13px;font-weight:600;color:#374151;padding:14px 16px 6px}.ev-campaign-row{background:#fff;padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid #F3F4F6;cursor:pointer}.ev-campaign-thumb{width:36px;height:36px;background:#c00;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:800;color:#fff;flex-shrink:0}.ev-campaign-name{font-size:13px;font-weight:600;color:#111827}.ev-campaign-dates{font-size:11px;color:#9ca3af}.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:8px 16px}.photo-item{border-radius:10px;overflow:hidden;position:relative;aspect-ratio:1;background:#1a2744}.photo-placeholder{width:100%;height:100%;display:flex;align-items:flex-end;background:linear-gradient(180deg,#1a2744,#0d1629)}.photo-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#0009);padding:6px 8px}.photo-time{font-size:10px;color:#fff;font-weight:600}.photo-loc{font-size:9px;color:#fffc}.photo-type-icon{position:absolute;top:6px;right:6px;width:24px;height:24px;background:#0006;border-radius:6px;display:flex;align-items:center;justify-content:center}.ev-content{flex:1;overflow-y:auto;background:#f0f2f7}.report-card{background:#fff;border-radius:14px;padding:14px;margin-bottom:10px}.report-header-blue{background:#eff6ff;border-radius:12px;padding:14px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}.report-header-blue .text-blue{color:#2563eb;font-size:14px;font-weight:600}.report-header-blue .text-sub{color:#6b7280;font-size:12px;margin-top:2px}.report-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid #F3F4F6}.report-item:last-child{border-bottom:none;padding-bottom:0}.report-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-icon.orange{background:#fff7ed}.report-icon.green{background:#f0fdf4}.report-icon.purple{background:#f5f3ff}.report-icon.blue{background:#eff6ff}.report-info{flex:1}.report-name{font-size:13px;font-weight:600;color:#111827;margin-bottom:2px}.report-desc{font-size:11px;color:#9ca3af;margin-bottom:4px}.report-meta{font-size:10px;color:#9ca3af;display:flex;align-items:center;gap:8px}.report-tag{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-size:9px;font-weight:600;color:#6b7280}.download-btn{width:32px;height:32px;border-radius:8px;background:#eff6ff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;margin-top:4px}.profile-header{background:#0d1629;padding:24px 24px 28px;display:flex;align-items:center;gap:16px;flex-shrink:0}.profile-avatar{width:64px;height:64px;background:#c00;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0}.profile-name{font-size:18px;font-weight:700;color:#fff}.profile-since{font-size:12px;color:#ffffff80;margin:2px 0}.verified-badge{display:inline-flex;align-items:center;gap:4px;background:#22c55e;color:#fff;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600}.profile-section-title{font-size:12px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;padding:14px 16px 6px}.menu-item{background:#fff;padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #F9FAFB;cursor:pointer}.menu-item-icon{width:32px;height:32px;border-radius:8px;background:#f3f4f6;display:flex;align-items:center;justify-content:center;flex-shrink:0}.menu-item-label{flex:1;font-size:14px;color:#111827}.menu-item-value{font-size:13px;color:#9ca3af}.menu-item-chevron{color:#d1d5db;font-size:14px}.menu-item.danger .menu-item-label{color:#ef4444}.menu-item.danger .menu-item-icon{background:#fef2f2}.wizard-header{background:#fff;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #F3F4F6;flex-shrink:0}.wizard-steps{background:#fff;padding:16px 20px;display:flex;align-items:center;gap:0;border-bottom:1px solid #F3F4F6;flex-shrink:0}.step-item{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.step-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:#e5e7eb;color:#9ca3af;z-index:1}.step-circle.active{background:#2563eb;color:#fff}.step-circle.done{background:#d1fae5;color:#059669}.step-label{font-size:9px;color:#9ca3af;margin-top:4px;font-weight:500}.step-label.active{color:#2563eb;font-weight:600}.step-line{position:absolute;top:14px;left:50%;right:-50%;height:2px;background:#e5e7eb;z-index:0}.step-item:last-child .step-line{display:none}.form-content{flex:1;overflow-y:auto;padding:16px;background:#f0f2f7}.form-group{margin-bottom:14px}.form-label{font-size:12px;font-weight:600;color:#374151;margin-bottom:6px;display:block}.form-input{width:100%;background:#fff;border:1px solid #E5E7EB;border-radius:10px;padding:12px 14px;font-size:13px;color:#9ca3af;outline:none}.form-input:focus{border-color:#2563eb;color:#111827}.form-textarea{min-height:70px;resize:none}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.upload-zone{background:#fff;border:2px dashed #E5E7EB;border-radius:12px;padding:24px;text-align:center;cursor:pointer}.upload-icon{font-size:28px;margin-bottom:8px;color:#2563eb}.upload-text{font-size:13px;color:#374151;font-weight:500;margin-bottom:4px}.upload-sub{font-size:11px;color:#9ca3af}.form-footer{background:#fff;border-top:1px solid #E5E7EB;padding:12px 16px 20px;flex-shrink:0}.billboard-img{width:100%;height:100%;object-fit:cover}.bb-cocacola{background:linear-gradient(135deg,#c00,#800);display:flex;align-items:center;justify-content:center;border-radius:inherit}.bb-sprite{background:linear-gradient(135deg,#1565c0,#0d47a1);display:flex;align-items:center;justify-content:center;border-radius:inherit}.bb-powerade{background:linear-gradient(135deg,#1a1a1a,#333);display:flex;align-items:center;justify-content:center;border-radius:inherit}.bb-text{color:#fff;font-size:9px;font-weight:800;text-align:center;line-height:1.3}.bb-text.lg{font-size:12px}.ev-photo-billboard{width:100%;height:100%;position:relative}.billboard-night{width:100%;height:100%;background:linear-gradient(180deg,#1a1a2e,#0a0a1a);display:flex;align-items:center;justify-content:center;position:relative}.billboard-night .billboard-screen{width:60%;aspect-ratio:16/9;background:#c00;border-radius:3px;position:absolute;top:20%;display:flex;align-items:center;justify-content:center;font-size:6px;color:#fff;font-weight:800;box-shadow:0 0 20px #c006}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:2px}.login-shell{flex:1;display:flex;flex-direction:column;justify-content:center;padding:32px 28px;background-image:linear-gradient(180deg,#080e1c8c,#080e1cb8 55%,#060c1aeb),url(/login-bg.jpg);background-size:cover;background-position:center}.login-logo{text-align:center;margin-bottom:36px}.login-logo img{height:56px;max-width:90%}.login-card{background:#fff;border-radius:20px;padding:28px 22px}.login-title{font-size:19px;font-weight:800;color:#111827;margin-bottom:6px}.login-sub{font-size:13px;color:#6b7280;margin-bottom:22px}.login-error{background:#fef2f2;color:#dc2626;font-size:12.5px;padding:10px 12px;border-radius:10px;margin-bottom:14px}.login-btn{width:100%;background:#2563eb;color:#fff;border:none;border-radius:12px;padding:14px;font-size:14px;font-weight:700;cursor:pointer;margin-top:6px}.login-btn:disabled{opacity:.6;cursor:default}.login-foot{text-align:center;font-size:11px;color:#ffffff73;margin-top:18px}@media(min-width:900px){body{margin:0}.app-shell{flex-direction:row;width:100%;height:100%;max-width:none;min-height:0;margin:0;border-radius:0;box-shadow:none;overflow:hidden}.app-shell:has(.login-shell),.app-shell:has(.state-screen),.app-shell:has(.admin-picker-shell){flex-direction:column}.login-logo,.login-card,.login-foot{width:100%;max-width:400px;margin-left:auto;margin-right:auto}.sidebar-brand{display:block;padding:8px 20px 30px}.sidebar-brand img{height:26px}.bottom-nav{order:-1;position:static;bottom:auto;flex-direction:column;align-items:stretch;justify-content:flex-start;width:260px;min-width:260px;height:100%;background:#0d1629;border-top:none;border-right:1px solid rgba(255,255,255,.06);padding:24px 16px;gap:2px}.nav-item{flex-direction:row;justify-content:flex-start;width:100%;padding:12px 16px;border-radius:10px;gap:13px}.nav-item svg{width:19px;height:19px;flex-shrink:0}.nav-item span{font-size:14px;font-weight:500}.nav-item:not(.active) span{color:#ffffff8c}.nav-item:not(.active) svg{stroke:#ffffff8c}.nav-item.active{background:#2563eb2e}.nav-item.active span{color:#fff;font-weight:600}.nav-item.active svg{stroke:#2563eb}.nav-item.active svg path,.nav-item.active svg rect,.nav-item.active svg circle{stroke:#2563eb}.nav-item:hover:not(.active){background:#ffffff0d}.screens{background:#f0f2f7}.content-area{padding:36px 48px}.header-dark,.header-light,.evidencias-header,.profile-header,.wizard-header,.wizard-steps{padding-left:48px;padding-right:48px}.form-content{padding:28px 48px}.campaign-list{padding:24px 48px}.ev-content .ev-section-title,.ev-content .ev-campaign-row{padding-left:48px;padding-right:48px}.ev-content .photo-grid{padding:8px 48px}.kpi-grid,.photo-grid{grid-template-columns:repeat(4,1fr)}.campaign-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;align-content:start}.campaign-card{margin-bottom:0}.nav-item-switch{margin-top:auto}.header-dark .logo-row{justify-content:flex-end}.header-dark .header-logo-img{display:none}.admin-picker-header{padding:48px 56px 40px}.admin-picker-title{font-size:28px}.admin-picker-sub{font-size:14px}.admin-picker-search{max-width:420px}.admin-picker-body{padding:36px 56px}.admin-picker-grid{grid-template-columns:repeat(3,1fr);max-width:1080px;margin:0 auto}.admin-picker-footer{padding:20px 56px 32px;display:flex;justify-content:flex-end}.admin-picker-logout{max-width:200px}}.state-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;gap:10px}.state-title{font-size:15px;font-weight:700;color:#111827}.state-sub{font-size:13px;color:#6b7280;max-width:280px}.evidence-photo-real{width:100%;height:100%;object-fit:cover;display:block}.report-download{font-size:11px;font-weight:600;color:#2563eb;text-decoration:none;flex-shrink:0;padding:6px 10px;border-radius:8px;background:#eff6ff}.admin-context-pill{display:inline-flex;align-items:center;gap:7px;background:#2563eb2e;color:#ffffffd9;border-radius:20px;padding:5px 12px;font-size:12px;margin-bottom:10px}.admin-context-pill strong{color:#fff;font-weight:700}.admin-context-dot{width:6px;height:6px;background:#5b9bff;border-radius:50%;flex-shrink:0}.admin-picker-shell{display:flex;flex-direction:column;height:100%;background:#f0f2f7}.admin-picker-header{background:#0d1629;padding:30px 22px 24px;flex-shrink:0}.admin-picker-logo{height:22px;display:block;margin-bottom:16px}.admin-picker-badge{display:inline-block;background:#2563eb33;color:#8fb8ff;font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:4px 10px;border-radius:20px;margin-bottom:14px}.admin-picker-title{color:#fff;font-size:20px;font-weight:800;margin-bottom:6px}.admin-picker-sub{color:#ffffff8c;font-size:12.5px;margin-bottom:18px}.admin-picker-search{display:block;width:100%;background:#ffffff14;border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:12px 14px;font-size:13px;color:#fff;outline:none}.admin-picker-search::placeholder{color:#fff6}.admin-picker-search:focus{border-color:#2563eb}.admin-picker-body{flex:1;overflow-y:auto;padding:18px 16px}.admin-picker-grid{display:flex;flex-direction:column;gap:10px}.admin-picker-card{background:#fff;border-radius:14px;padding:13px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;box-shadow:0 1px 3px #0000000f;transition:transform .12s ease,box-shadow .12s ease}.admin-picker-card:hover{transform:translateY(-1px);box-shadow:0 8px 20px #0000001a}.admin-picker-avatar{width:40px;height:40px;border-radius:50%;background:#2563eb;color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-picker-card-info{flex:1;min-width:0}.admin-picker-card-name{font-size:14px;font-weight:700;color:#111827}.admin-picker-card-city{font-size:12px;color:#9ca3af;margin-top:2px}.admin-picker-footer{padding:14px 16px 20px;flex-shrink:0}.admin-picker-logout{width:100%;padding:12px;border-radius:10px;border:1px solid #E5E7EB;background:#fff;color:#dc2626;font-weight:700;font-size:13px;cursor:pointer}
