/* =====================================================
   FOTOS.CSS · ÁLBUM PREMIUM
===================================================== */

#view-photos{
  padding-top:4px;
  padding-bottom:110px;
}

/* CABECERA */
#view-photos .section-title{
  display:grid !important;
  grid-template-columns:62px 1fr !important;
  align-items:center !important;
  gap:16px !important;
  margin:4px 0 18px !important;
}

#view-photos .section-title > span{
  width:58px !important;
  height:58px !important;
  border-radius:18px !important;
  background:rgba(255,255,255,.94) !important;
  border:1px solid rgba(22,55,69,.16) !important;
  box-shadow:0 12px 28px rgba(22,55,69,.12) !important;
}

#view-photos .section-title h2{
  font-family:"Caveat",cursive !important;
  font-size:clamp(3rem,5vw,4.4rem) !important;
  line-height:.9 !important;
  font-weight:700 !important;
  color:#123949 !important;
}

#view-photos .section-title p{
  font-family:"Inter",system-ui,sans-serif !important;
  color:#4f6670 !important;
}

/* UPLOAD */
#view-photos .upload-box{
  position:relative !important;
  overflow:hidden !important;
  padding:24px !important;
  border-radius:30px !important;
  background:rgba(255,255,255,.92) !important;
  border:1px solid rgba(22,55,69,.16) !important;
  box-shadow:0 18px 42px rgba(22,55,69,.13) !important;
  backdrop-filter:blur(10px) !important;
}

#view-photos .upload-box > span{
  width:62px !important;
  height:62px !important;
  margin:0 auto 10px !important;
  display:grid !important;
  place-items:center !important;
  border-radius:22px !important;
  background:rgba(255,255,255,.84) !important;
  border:1px solid rgba(22,55,69,.14) !important;
  box-shadow:0 10px 22px rgba(22,55,69,.10) !important;
}

#view-photos .upload-box p{
  font-family:"Caveat",cursive !important;
  font-size:2rem !important;
  color:#123949 !important;
  font-weight:700 !important;
}

#view-photos .upload-box select,
#view-photos .upload-box input{
  height:42px !important;
  border-radius:15px !important;
  background:linear-gradient(180deg,#fffefb,#fff7e9) !important;
  border:1px solid rgba(22,55,69,.14) !important;
  font-family:"Inter",system-ui,sans-serif !important;
}

#view-photos .upload-box button{
  height:42px !important;
  min-height:42px !important;
  border-radius:15px !important;
  background:linear-gradient(135deg,#123949,#0f5b73) !important;
  color:#fff8e8 !important;
  font-family:"Inter",system-ui,sans-serif !important;
  font-weight:900 !important;
}

/* GRID */
#view-photos .photo-grid{
  display:grid !important;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr)) !important;
  gap:18px !important;
  margin-top:20px !important;
}

/* FOTO */
#view-photos .photo-card{
  position:relative !important;
  padding:10px 10px 14px !important;
  border-radius:24px !important;
  background:rgba(255,255,255,.92) !important;
  border:1px solid rgba(22,55,69,.16) !important;
  box-shadow:0 16px 36px rgba(22,55,69,.12) !important;
  transform:rotate(var(--rot,-.35deg)) !important;
}

#view-photos .photo-card:nth-child(even){
  --rot:.35deg;
}

#view-photos .photo-card img{
  width:100% !important;
  aspect-ratio:1 !important;
  object-fit:cover !important;
  border-radius:18px !important;
}

#view-photos .photo-delete{
  top:14px !important;
  right:14px !important;
  width:32px !important;
  height:32px !important;
  border-radius:50% !important;
  background:rgba(18,57,73,.78) !important;
  color:#fff8e8 !important;
}

#view-photos .photo-day{
  margin-top:10px !important;
  font-family:"Inter",system-ui,sans-serif !important;
  color:#0f5b73 !important;
  font-size:.72rem !important;
  font-weight:900 !important;
  letter-spacing:.12em !important;
  text-transform:uppercase !important;
}

#view-photos .photo-person{
  font-family:"Inter",system-ui,sans-serif !important;
  color:#5d6f76 !important;
  font-size:.76rem !important;
  font-weight:900 !important;
}

#view-photos .photo-caption{
  margin-top:4px !important;
  font-family:"Caveat",cursive !important;
  font-size:1.45rem !important;
  line-height:1 !important;
  color:#123949 !important;
  font-weight:700 !important;
}

/* MOBILE */
@media(max-width:760px){
  #view-photos .section-title{
    grid-template-columns:52px 1fr !important;
  }

  #view-photos .section-title h2{
    font-size:2.6rem !important;
  }

  #view-photos .photo-grid{
    grid-template-columns:repeat(2,1fr) !important;
    gap:14px !important;
  }

  #view-photos .upload-box{
    padding:20px !important;
    border-radius:26px !important;
  }
}
/* =====================================================
   FOTOS · FIX DEFINITIVO FORMULARIO
===================================================== */

#view-photos .upload-box{
  display:block !important;
  width:calc(100vw - 52px) !important;
  max-width:calc(100vw - 52px) !important;
  min-width:calc(100vw - 52px) !important;
  margin:0 auto 22px !important;
  padding:26px 28px !important;
  box-sizing:border-box !important;
}

#view-photos .upload-box > span{
  display:grid !important;
  width:62px !important;
  height:62px !important;
  margin:0 auto 10px !important;
}

#view-photos .upload-box p{
  display:block !important;
  width:100% !important;
  text-align:center !important;
  font-size:1.85rem !important;
  margin:0 0 18px !important;
}

#view-photos .photo-upload-form{
  display:grid !important;
  grid-template-columns:120px 130px minmax(220px,1fr) minmax(260px,1.2fr) 180px !important;
  gap:10px !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  align-items:center !important;
}

#view-photos .photo-upload-form select,
#view-photos .photo-upload-form input,
#view-photos .photo-upload-form button{
  width:100% !important;
  min-width:0 !important;
  max-width:100% !important;
  height:42px !important;
  min-height:42px !important;
  box-sizing:border-box !important;
}

#view-photos input[type="file"]{
  overflow:hidden !important;
}

/* Polaroid */
#view-photos .photo-grid{
  display:grid !important;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr)) !important;
  gap:18px !important;
  margin-top:22px !important;
}

#view-photos .photo-card{
  background:#fffdf8 !important;
  border-radius:18px !important;
  padding:10px 10px 16px !important;
  transform:rotate(var(--rot,-1deg)) !important;
}

#view-photos .photo-card:nth-child(2n){ --rot:1deg; }
#view-photos .photo-card:nth-child(3n){ --rot:-.7deg; }

/* Tablet y móvil */
@media(max-width:1100px){
  #view-photos .upload-box{
    width:calc(100vw - 36px) !important;
    max-width:calc(100vw - 36px) !important;
    min-width:calc(100vw - 36px) !important;
  }

  #view-photos .photo-upload-form{
    grid-template-columns:1fr 1fr !important;
  }

  #view-photos input[type="file"],
  #view-photos .photo-upload-form button{
    grid-column:1 / -1 !important;
  }
}

@media(max-width:760px){
  #view-photos .photo-upload-form{
    grid-template-columns:1fr !important;
  }

  #view-photos .photo-grid{
    grid-template-columns:repeat(2,1fr) !important;
  }
}
/* =====================================================
   FOTOS · CAMPOS FINALES
===================================================== */

#view-photos .photo-upload-form{
  gap:12px !important;
}

#view-photos .photo-upload-form select,
#view-photos .photo-upload-form input[type="text"],
#view-photos .photo-upload-form input[type="file"]{
  height:44px !important;
  min-height:44px !important;
  padding:0 16px !important;
  border-radius:16px !important;
  background:rgba(255,250,238,.92) !important;
  border:1px solid rgba(22,55,69,.14) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9) !important;
  color:#123949 !important;
  font-family:"Inter",system-ui,sans-serif !important;
  font-size:.9rem !important;
}

#view-photos .photo-upload-form input[type="file"]{
  padding:0 !important;
  overflow:hidden !important;
}

#view-photos .photo-upload-form input[type="file"]::file-selector-button{
  height:44px !important;
  padding:0 16px !important;
  margin-right:14px !important;
  border:none !important;
  border-radius:16px 0 0 16px !important;
  background:linear-gradient(135deg,#123949,#0f5b73) !important;
  color:#fff8e8 !important;
  font-family:"Inter",system-ui,sans-serif !important;
  font-size:.82rem !important;
  font-weight:900 !important;
}

#view-photos .photo-upload-form button{
  height:46px !important;
  min-height:46px !important;
  border-radius:16px !important;
  font-size:.9rem !important;
  box-shadow:0 14px 26px rgba(22,55,69,.2) !important;
}

#view-photos .empty-photos{
  width:fit-content !important;
  max-width:360px !important;
  margin:22px 0 0 !important;
  padding:18px 22px !important;
  border-radius:24px !important;
  background:rgba(255,255,255,.88) !important;
  border:1px solid rgba(22,55,69,.14) !important;
  box-shadow:0 12px 26px rgba(22,55,69,.09) !important;
  color:#4f6670 !important;
  font-family:"Inter",system-ui,sans-serif !important;
  font-size:.95rem !important;
  line-height:1.35 !important;
}

@media(max-width:760px){
  #view-photos .photo-upload-form select,
  #view-photos .photo-upload-form input[type="text"],
  #view-photos .photo-upload-form input[type="file"],
  #view-photos .photo-upload-form button{
    height:42px !important;
    min-height:42px !important;
  }
}