:root{
  --bg:#f6f7fb; --fg:#0b1020; --muted:#5b6275;
  --card:#fff; --line:#e7e9f2;
  --brand:#0b5fff; --brand-600:#0a4dd4;
  --accent:#1ea97c;
  --radius-xl:20px; --radius-lg:14px;
  --shadow-sm:0 2px 10px rgba(16,24,40,.06);
  --shadow-md:0 10px 30px rgba(16,24,40,.10);
  --maxw:1100px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:var(--bg); color:var(--fg);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,"Noto Sans","Helvetica Neue",sans-serif;
  line-height:1.55; display:flex; flex-direction:column; min-height:100vh;
  background:
    radial-gradient(1000px 520px at 85% -10%, rgba(11,95,255,.08), transparent 60%),
    radial-gradient(800px 420px at -10% 5%, rgba(58,176,138,.08), transparent 60%),
    var(--bg);
}
.wrap{width:min(var(--maxw),92%); margin:0 auto}

header{
  padding:28px 0 8px; border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.7));
  backdrop-filter:blur(6px);
}
.brand-row{
  display:flex; align-items:center; gap:14px;
}
.brand-logo{
  width:48px; height:48px; border-radius:12px; overflow:hidden;
  display:grid; place-items:center; background:#fff; border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.brand-logo img{width:100%; height:100%; object-fit:cover}
h1{margin:0; font-size:clamp(1.3rem,1rem + 1.5vw,1.9rem)}
.subtitle{margin:.25rem 0 0; color:var(--muted)}

.hero{
  position:relative; margin:16px 0 0; padding:24px 0 8px;
}
.hero::before{
  /* Watermark background with MIC logo */
  content:""; position:absolute; inset:0;
  background: url("../assets/mic-watermark.svg") no-repeat right -40px top -10px / clamp(280px, 30vw, 480px);
  opacity:.10; pointer-events:none;
}
.hero .info{
  position:relative; z-index:1;
}

main{padding:24px 0 40px}
.grid{
  display:grid; gap:22px; margin-top:18px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
@media (max-width: 880px){
  .grid{grid-template-columns:1fr}
}
.card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm); padding:24px;
  transition:box-shadow .18s ease, transform .18s ease, border-color .18s ease;
  display:flex; flex-direction:column; gap:14px;
}
.card:hover{box-shadow:var(--shadow-md); transform:translateY(-2px); border-color:#dfe3ee}
.card h2{margin:.2rem 0; font-size:1.22rem}
.card p{margin:0; color:var(--fg)}
.muted{color:var(--muted)}
.meta{display:flex; gap:10px; align-items:center; color:var(--muted); font-size:.92rem}
.dot{width:6px; height:6px; border-radius:50%; background:var(--accent)}
.actions{display:flex; gap:12px; flex-wrap:wrap}

.btn{
  appearance:none; border:1px solid transparent; cursor:pointer;
  background:var(--brand); color:#fff; font-weight:700;
  padding:12px 16px; border-radius:var(--radius-lg);
  text-decoration:none; display:inline-flex; align-items:center; gap:8px;
  transition: transform .12s ease, background .12s ease, box-shadow .12s ease;
  box-shadow:0 2px 8px rgba(11,95,255,.18); letter-spacing:.2px;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0); background:var(--brand-600)}
.btn.secondary{
  background:#fff; color:var(--brand); border-color:#cfe0ff; box-shadow:none;
}
.btn.secondary:hover{background:#f5f9ff}

.small{font-size:.92rem; color:var(--muted)}

footer{
  margin-top:auto; border-top:1px solid var(--line); background:#fff7; color:var(--muted);
}
.foot{padding:16px 0; display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap}

:focus-visible{outline:3px solid rgba(11,95,255,.45); outline-offset:2px; border-radius:10px}
@media print{header,footer{display:none!important} body{background:#fff}}

/* Contacto */
.contact{
  padding:40px 0; text-align:center;
}
.contact h2{
  margin:0 0 24px; font-size:1.6rem; color:var(--fg);
}
.contact-card{
  display:flex; align-items:center; justify-content:center;
  gap:24px; flex-wrap:wrap;
}
.contact-card .photo{
  flex:0 0 140px; width:140px; height:140px;
  border-radius:50%; overflow:hidden;
  border:6px solid var(--brand);
}
.contact-card .photo img{width:100%; height:100%; object-fit:cover}
.contact-card .details{text-align:left; max-width:400px}
.contact-card h3{margin:0; font-size:1.2rem; font-weight:700}
.contact-card .role{margin:4px 0 12px; color:var(--muted)}
.contact-card p{margin:6px 0; display:flex; align-items:center; gap:8px}
.contact-card a{text-decoration:none; color:var(--fg)}
.contact-card a:hover{color:var(--brand)}

/* Hero con más vida */
.hero{
  text-align:center;
  padding:60px 20px 40px;
  background:linear-gradient(180deg, rgba(11,95,255,.08), rgba(255,255,255,1) 70%);
  border-radius:0 0 32px 32px;
  margin-bottom:32px;
  position:relative;
  overflow:hidden;
}

.hero::after{
  content:"";
  position:absolute;
  top:-50px; left:-50px;
  width:180px; height:180px;
  border-radius:50%;
  background:rgba(30,169,124,.15);
  z-index:0;
}

.hero-title{
  margin:0;
  font-size:clamp(1.8rem, 1rem + 2.5vw, 2.8rem);
  font-weight:800;
  color:#FFF;
  text-shadow: 0 2px 50px rgba(11,95,255,0.6);
  position:relative; z-index:1;
}

.hero-subtitle{
  margin-top:14px;
  font-size:1.15rem;
  color:var(--muted);
  text-shadow: 0 2px 50px rgba(11,95,255,0.6);
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
  line-height:1.6;
  position:relative; z-index:1;
}
.hero img{
  margin-top:24px;
  max-width:100%;
  height:auto;
  border-radius:16px;
  box-shadow:var(--shadow-md);
  position:relative; z-index:1;
} 
/* SVG icon adjustments */
svg{display:block; flex-shrink:0} 
svg path{transition:stroke .18s ease}
.btn svg path{stroke:#fff}
.btn.secondary svg path{stroke:var(--brand)}

/* Dark mode */
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1020; --fg:#e7e9f2;

    --muted:#8f95a6; --card:#161b2e; --line:#252a40;
    --brand:#0b5fff; --brand-600:#0a4dd4;
    --accent:#1ea97c;
    --shadow-sm:0 2px 10px rgba(0,0,0,.6);
    --shadow-md:0 10px 30px rgba(0,0,0,.8);
  }
  body{background:
    radial-gradient(1000px 520px at 85% -10%, rgba(11,95,255,.15), transparent 60%),
    radial-gradient(800px 420px at -10% 5%, rgba(58,176,138,.15), transparent 60%),
    var(--bg);        
  }
  header{
    background:linear-gradient(180deg, rgba(16,24,40,.85), rgba(16,24,40,.7));
  }
  .hero{
    background:linear-gradient(180deg, rgba(11,95,255,.12), rgba(16,24,40,1) 70%);
  }
  .hero::after{background:rgba(30,169,124,.25)}
  .card{box-shadow:var(--shadow-sm)}
  .card:hover{box-shadow:var(--shadow-md); border-color:#3a3a40}
  .btn{box-shadow:0 2px 8px rgba(11,95,255,.36)}
  .btn.secondary{background:#161b2e; border-color:#252a40; box-shadow:none}
  footer{background:#161b2e; color:var(--muted)}
  .contact-card .photo{border-color:var(--brand)}
  .contact-card a:hover{color:var(--brand)}
} 

/* Bloque NFC */
.nfc-info{
  background:#78adf1;
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow-sm);
  padding:40px 28px;
  margin:40px auto;
  text-align:center;
}
.nfc-info h2{
  margin:0 0 24px;
  font-size:1.6rem;
  color:#fff;
}
.steps{
  display:flex;
  justify-content:space-around;
  gap:20px;
  flex-wrap:wrap;
  margin-bottom:24px;
}
.step{
  flex:1 1 200px;
  background:#1b2444;
  border-radius:16px;
  padding:20px;
  box-shadow:0 2px 6px rgba(0,0,0,0.05);
  transition:transform .2s ease;
}
.step:hover{transform:translateY(-4px)}
.icon{
  font-size:2rem;
  margin-bottom:12px;
}
.note{
  font-size:.95rem;
  color:var(--muted);
  margin-top:10px;
}
.nfc-info a.btn{
  margin-top:12px;
} 


/* Galería / Carrete */
.gallery{
  margin:60px auto;
  text-align:center;
}
.gallery h2{
  margin-bottom:20px;
  font-size:1.6rem;
  color:var(--brand);
}

.carousel{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  box-shadow:var(--shadow-md);
}
.carousel .slides{
  display:flex;
  transition:transform .5s ease-in-out;
}
.carousel img{
  width:100%;
  flex-shrink:0;
  max-height:420px;
  object-fit:cover;
}
.carousel button{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(0,0,0,0.5);
  color:#fff;
  border:none;
  font-size:2rem;
  padding:6px 12px;
  cursor:pointer;
  border-radius:50%;
}
.carousel button:hover{background:rgba(0,0,0,0.7)}
.carousel .prev{left:10px}
.carousel .next{right:10px}
