*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a2e;background:#f0f2f5;font-family:Segoe UI,system-ui,sans-serif}.login-container{min-height:100vh;display:flex}.login-hero{background-image:url(/hero.jpg);background-position:50%;background-size:cover;flex:1;align-items:flex-end;padding:48px;display:flex;position:relative}.login-hero-overlay{background:linear-gradient(135deg,#1b2d6bd1 0%,#7d1f35b3 100%);position:absolute;inset:0}.login-hero-text{z-index:1;color:#fff;position:relative}.hero-sub{letter-spacing:2px;text-transform:uppercase;color:#ffffffa6;margin-bottom:12px;font-size:.8rem}.login-hero-text h2{color:#fff;font-size:2.6rem;font-weight:700;line-height:1.2}.login-hero-text h2 span{color:#f4a0b5}.login-panel{background:#fff;flex-direction:column;justify-content:center;align-items:center;gap:0;width:380px;padding:52px 44px;display:flex}.login-accent-bar{background:linear-gradient(90deg,#1b2d6b,#7d1f35);border-radius:2px;width:48px;height:4px;margin-bottom:28px}.login-logo{filter:drop-shadow(0 4px 12px #1b2d6b26);height:88px;margin-bottom:20px}.login-panel h1{color:#1b2d6b;letter-spacing:-.5px;margin-bottom:8px;font-size:1.8rem;font-weight:800}.version{color:#7d1f35}.tagline{color:#888;text-align:center;margin-bottom:36px;font-size:.88rem}.btn-google{color:#1b2d6b;background:#fff;border:2px solid #1b2d6b;border-radius:10px;align-items:center;gap:10px;padding:13px 28px;font-size:.95rem;font-weight:600;text-decoration:none;transition:background .2s,color .2s,transform .15s,box-shadow .2s;display:inline-flex;box-shadow:0 2px 8px #1b2d6b1a}.btn-google:hover{color:#fff;background:#1b2d6b;transform:translateY(-1px);box-shadow:0 4px 16px #1b2d6b38}.btn-google img{height:20px}@media (width<=768px){.login-hero{display:none}.login-panel{width:100%;min-height:100vh}}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;background:#1b2d6b;justify-content:space-between;align-items:center;padding:12px 32px;display:flex}.header-logo{height:36px}.header-user{align-items:center;gap:16px;font-size:.95rem;display:flex}.btn-logout{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #fff6;border-radius:6px;padding:6px 16px;font-size:.9rem;transition:background .2s}.btn-logout:hover{background:#ffffff40}.form-main{width:100%;max-width:640px;margin:40px auto;padding:0 16px}.form-main h2{color:#1b2d6b;margin-bottom:24px;font-size:1.4rem}.po-form{flex-direction:column;gap:20px;display:flex}.campo{flex-direction:column;gap:6px;display:flex}.campo label{color:#333;font-size:.9rem;font-weight:600}.campo select,.campo input[type=text],.campo input[type=file]{border:1.5px solid #ccc;border-radius:8px;padding:10px 12px;font-size:1rem;transition:border-color .2s}.campo select:focus,.campo input:focus{border-color:#1b2d6b;outline:none}.btn-procesar{color:#fff;cursor:pointer;background:#7d1f35;border:none;border-radius:8px;margin-top:8px;padding:14px;font-size:1rem;font-weight:700;transition:background .2s}.btn-procesar:hover:not(:disabled){background:#6a1a2c}.btn-procesar:disabled{opacity:.6;cursor:not-allowed}.mensaje{border-radius:8px;margin-top:24px;padding:16px 20px;line-height:1.6}.mensaje.error{color:#7d1f35;background:#fdecea;border:1px solid #f5c6cb}.mensaje.exito{color:#1b5e20;background:#e8f5e9;border:1px solid #a5d6a7}.mensaje ul{margin-top:8px;padding-left:20px}.mensaje a{color:#1b2d6b}.warnings{color:#7d1f35;margin-top:12px}.cargando{text-align:center;color:#666;padding:40px}.dashboard-main{width:100%;max-width:900px;margin:48px auto;padding:0 24px}.dashboard-bienvenida{margin-bottom:36px}.dashboard-bienvenida h2{color:#1b2d6b;margin-bottom:4px;font-size:1.6rem;font-weight:700}.dashboard-bienvenida p{color:#888;text-transform:capitalize;font-size:.95rem}.modulos-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.modulo-card{cursor:pointer;text-align:center;background:#fff;border:1.5px solid #e0e4f0;border-radius:14px;padding:28px 24px;transition:transform .15s,box-shadow .15s,border-color .15s}.modulo-card:hover{border-color:#1b2d6b;transform:translateY(-3px);box-shadow:0 8px 24px #1b2d6b1f}.modulo-card.modulo-disabled{cursor:default;opacity:.5}.modulo-card.modulo-disabled:hover{box-shadow:none;border-color:#e0e4f0;transform:none}.modulo-icono{margin-bottom:12px;font-size:2.4rem}.modulo-card h3{color:#1b2d6b;margin-bottom:6px;font-size:1rem;font-weight:700}.modulo-card p{color:#888;font-size:.85rem;line-height:1.4}
