/* ════════════════════════════════════════════════════════════
   DESIGN SYSTEM — "Precision Dark"
   Tokens idénticos al resto del sitio
════════════════════════════════════════════════════════════ */
:root {
  --g:    #1FA463;
  --b:    #1FA0C8;
  --o:    #F1872D;
  --dk:   #0E1A14;
  --dk2:  #141F19;
  --dk3:  #1B2820;
  --dk4:  #0A1210;
  --lt:   #F4F7F5;
  --tx:   #E8EEE9;
  --tx2:  #8BA694;
  --wh:   #FFFFFF;
  --ff-h: 'Poppins', sans-serif;
  --ff-b: 'Open Sans', sans-serif;
  --r:    12px;
  --r-lg: 20px;
  --ease: cubic-bezier(.4,0,.2,1);
  --t:    .32s;
  --sh:   0 8px 32px rgba(0,0,0,.35);
  --sh-g: 0 8px 40px rgba(31,164,99,.28);
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--ff-b); background:var(--dk); color:var(--tx); overflow-x:hidden; }
h1,h2,h3,h4,h5,h6 { font-family:var(--ff-h); }
a { text-decoration:none; }
img { display:block; max-width:100%; }

/* ── UTILITIES ── */
.sp    { padding:100px 0; }
.sp-sm { padding:64px 0; }

.lbl {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ff-h); font-size:.7rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--g); margin-bottom:16px;
}
.lbl::before { content:''; width:28px; height:2px; background:var(--g); border-radius:2px; }

.hdg {
  font-size:clamp(1.9rem,3.5vw,2.8rem);
  font-weight:800; line-height:1.1; color:var(--wh); margin-bottom:14px;
}
.hdg em { font-style:normal; color:var(--g); }
.sub { font-size:.96rem; color:var(--tx2); line-height:1.8; max-width:560px; }
.divider { width:40px; height:3px; background:linear-gradient(90deg,var(--g),var(--b)); border-radius:2px; margin:16px 0 28px; }

/* Buttons */
.btn-g {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--g); color:#fff;
  font-family:var(--ff-h); font-weight:600; font-size:.88rem;
  padding:13px 28px; border-radius:50px; border:none;
  transition:all var(--t) var(--ease);
}
.btn-g:hover { background:#168a52; transform:translateY(-2px); box-shadow:var(--sh-g); color:#fff; }

.btn-out {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:var(--wh);
  font-family:var(--ff-h); font-weight:600; font-size:.88rem;
  padding:12px 28px; border-radius:50px; border:1.5px solid rgba(255,255,255,.25);
  transition:all var(--t) var(--ease);
}
.btn-out:hover { border-color:var(--g); color:var(--g); transform:translateY(-2px); }

/* ════════════════════════════════════════════════════════════
   NAVBAR — idéntico al resto del sitio
════════════════════════════════════════════════════════════ */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:20px 0;
  transition:padding var(--t) var(--ease), background var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
#nav.stuck {
  background:rgba(14,26,20,.95);
  backdrop-filter:blur(20px);
  padding:12px 0;
  box-shadow:0 1px 0 rgba(31,164,99,.15), 0 8px 32px rgba(0,0,0,.4);
}
.nav-logo { display:flex; align-items:center; gap:12px; }
/* Nuevo estilo para tu logo en imagen */
.site-logo {
  height: 46px; /* Misma altura que pusimos en el index */
  width: auto;
  display: block;
  transition: height var(--t) var(--ease);
}

/* Reducir tamaño del logo al hacer scroll */
#nav.stuck .site-logo {
  height: 40px; 
}
.logo-name { font-family:var(--ff-h); font-weight:700; font-size:.86rem; color:var(--wh); line-height:1.2; }
.logo-name small { display:block; font-weight:300; font-size:.68rem; color:rgba(255,255,255,.5); letter-spacing:.06em; }

.navbar-nav .nav-link {
  font-family:var(--ff-h); font-size:.84rem; font-weight:500;
  color:rgba(255,255,255,.75) !important; padding:6px 12px !important;
  position:relative; transition:color var(--t);
}
.navbar-nav .nav-link::after {
  content:''; position:absolute; bottom:-2px; left:12px;
  width:0; height:2px; background:var(--g); border-radius:2px;
  transition:width var(--t) var(--ease);
}
.navbar-nav .nav-link:hover { color:var(--wh) !important; }
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after { width:calc(100% - 24px); }

.nav-cta {
  font-family:var(--ff-h); font-weight:600; font-size:.82rem;
  color:#fff !important; background:var(--g);
  padding:8px 20px !important; border-radius:50px !important;
  transition:background var(--t), transform var(--t), box-shadow var(--t) !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:#168a52 !important; transform:translateY(-2px); box-shadow:var(--sh-g) !important; }

.navbar-toggler { border:1.5px solid rgba(255,255,255,.25) !important; padding:6px 10px !important; }
.navbar-toggler-icon {
  background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.8)' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}
@media(max-width:991px){
  .navbar-collapse {
    margin-top:10px; background:rgba(14,26,20,.97);
    border-radius:var(--r); padding:20px; box-shadow:var(--sh);
    border:1px solid rgba(31,164,99,.15);
  }
}

/* ════════════════════════════════════════════════════════════
   PAGE HERO
════════════════════════════════════════════════════════════ */
#page-hero {
  min-height:54vh; padding-top:100px;
  position:relative; overflow:hidden;
  display:flex; align-items:center;
}
.ph-bg {
  position:absolute; inset:0;
  background:url('Imagenes/Generales/proyectos.png') center 80%/cover no-repeat;
  animation:phZoom 16s ease-in-out infinite alternate;
  will-change:transform;
}
@keyframes phZoom {
  from { transform:scale(1.04); }
  to   { transform:scale(1.09); }
}
.ph-ov {
  position:absolute; inset:0;
  background:linear-gradient(110deg,rgba(8,18,13,.94) 0%,rgba(10,22,30,.80) 58%,rgba(0,0,0,.52) 100%);
}
.ph-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(31,164,99,.05) 1px, transparent 1px),
    linear-gradient(90deg,rgba(31,164,99,.05) 1px, transparent 1px);
  background-size:60px 60px;
  animation:gridMove 40s linear infinite;
}
@keyframes gridMove {
  from { background-position:0 0; }
  to   { background-position:60px 60px; }
}
.ph-glow {
  position:absolute; pointer-events:none;
  top:-20%; right:-5%; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(31,160,200,.09) 0%,transparent 65%);
}
.ph-inner { position:relative; z-index:2; }

/* Breadcrumb */
.breadcrumb { background:none; padding:0; margin-bottom:14px; }
.breadcrumb-item { font-family:var(--ff-h); font-size:.75rem; color:var(--tx2); }
.breadcrumb-item a { color:var(--tx2); transition:color var(--t); }
.breadcrumb-item a:hover { color:var(--g); }
.breadcrumb-item.active { color:var(--g); }
.breadcrumb-item+.breadcrumb-item::before { color:rgba(255,255,255,.2); }

.ph-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-h); font-size:.7rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--g); margin-bottom:20px;
  padding:7px 16px; border-radius:50px;
  border:1px solid rgba(31,164,99,.3); background:rgba(31,164,99,.08);
}
.ph-h1 {
  font-size:clamp(2.2rem,5.5vw,4rem);
  font-weight:900; color:var(--wh); line-height:1.08; margin-bottom:18px;
}
.ph-h1 em { font-style:normal; color:var(--g); }
.ph-p { font-size:1.06rem; color:rgba(255,255,255,.65); line-height:1.85; max-width:520px; }

/* Diagonal cut */
.ph-cut {
  position:absolute; bottom:-1px; left:0; right:0;
  height:72px; background:var(--dk2);
  clip-path:polygon(0 100%,100% 100%,100% 0);
}

/* ════════════════════════════════════════════════════════════
   FILTER BAR
════════════════════════════════════════════════════════════ */
#filter-bar { background:var(--dk2); padding:40px 0 0; }

.filter-wrap {
  display:flex; flex-wrap:wrap; gap:10px;
  justify-content:center;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.filter-btn {
  font-family:var(--ff-h); font-size:.78rem; font-weight:600;
  padding:9px 22px; border-radius:50px;
  border:1.5px solid rgba(255,255,255,.12);
  background:transparent; color:var(--tx2);
  cursor:pointer; transition:all var(--t) var(--ease);
  letter-spacing:.04em;
}
.filter-btn:hover { border-color:var(--g); color:var(--g); }
.filter-btn.active {
  background:var(--g); border-color:var(--g); color:#fff;
  box-shadow:0 4px 16px rgba(31,164,99,.3);
}

/* ════════════════════════════════════════════════════════════
   PROJECTS GRID
════════════════════════════════════════════════════════════ */
#projects-grid { background:var(--dk2); padding:56px 0 100px; }

/* Masonry-style grid */
.proj-masonry {
  columns:3 320px;
  column-gap:20px;
}
.proj-item {
  break-inside:avoid;
  margin-bottom:20px;
  border-radius:var(--r-lg);
  overflow:hidden;
  position:relative;
  cursor:pointer;
  /* hidden until JS filter */
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.proj-item.hide { opacity:0; pointer-events:none; transform:scale(.95); }

.proj-ph {
  width:100%; display:flex;
  flex-direction:column; align-items:center; justify-content:center;
  gap:10px; color:rgba(255,255,255,.18); font-size:.78rem;
  transition:transform .55s var(--ease);
}
.proj-ph i { font-size:2.2rem; }
.proj-item:hover .proj-ph { transform:scale(1.06); }

/* Aspect ratios for visual variety */
.proj-item.tall  .proj-ph { aspect-ratio:3/4;  }
.proj-item.wide  .proj-ph { aspect-ratio:16/9; }
.proj-item.sq    .proj-ph { aspect-ratio:1/1;  }
.proj-item.std   .proj-ph { aspect-ratio:4/3;  }

/* Unique placeholder gradients per project */
.proj-item:nth-child(1)  .proj-ph { background:linear-gradient(135deg,#0c2018,#0d1e30); }
.proj-item:nth-child(2)  .proj-ph { background:linear-gradient(135deg,#101e10,#0e1a2a); }
.proj-item:nth-child(3)  .proj-ph { background:linear-gradient(135deg,#1a160c,#201208); }
.proj-item:nth-child(4)  .proj-ph { background:linear-gradient(135deg,#0e1e20,#0a1620); }
.proj-item:nth-child(5)  .proj-ph { background:linear-gradient(135deg,#1e100a,#201010); }
.proj-item:nth-child(6)  .proj-ph { background:linear-gradient(135deg,#0c1a20,#10202a); }
.proj-item:nth-child(7)  .proj-ph { background:linear-gradient(135deg,#0d2010,#112018); }
.proj-item:nth-child(8)  .proj-ph { background:linear-gradient(135deg,#181810,#1e1408); }
.proj-item:nth-child(9)  .proj-ph { background:linear-gradient(135deg,#0e1820,#0c1428); }
.proj-item:nth-child(10) .proj-ph { background:linear-gradient(135deg,#1e1008,#1a0e06); }
.proj-item:nth-child(11) .proj-ph { background:linear-gradient(135deg,#0c1e18,#0e1e28); }
.proj-item:nth-child(12) .proj-ph { background:linear-gradient(135deg,#181214,#201018); }

/* Overlay */
.proj-ov {
  position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 28%,rgba(6,14,10,.96) 100%);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:22px;
  transition:background var(--t);
}
.proj-item:hover .proj-ov {
  background:linear-gradient(180deg,rgba(6,14,10,.1) 0%,rgba(6,14,10,.97) 100%);
}

.proj-cat {
  font-family:var(--ff-h); font-size:.64rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--g); margin-bottom:6px;
  display:flex; align-items:center; gap:6px;
}
.proj-cat::before { content:''; width:16px; height:1.5px; background:var(--g); border-radius:1px; }

.proj-ov h4 {
  font-size:1rem; font-weight:700; color:var(--wh);
  margin-bottom:4px; line-height:1.25;
}
.proj-ov .proj-meta {
  font-size:.76rem; color:rgba(255,255,255,.45);
  display:flex; align-items:center; gap:10px;
}
.proj-ov .proj-meta i { font-size:.7rem; }

/* Arrow icon */
.proj-arrow {
  position:absolute; top:14px; right:14px;
  width:36px; height:36px; border-radius:50%;
  background:var(--g); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:.88rem;
  opacity:0; transform:scale(.5) rotate(-45deg);
  transition:all var(--t) var(--ease);
}
.proj-item:hover .proj-arrow { opacity:1; transform:scale(1) rotate(0); }

/* Year badge */
.proj-year {
  position:absolute; top:14px; left:14px;
  background:rgba(14,26,20,.85); backdrop-filter:blur(8px);
  border:1px solid rgba(31,164,99,.25);
  border-radius:50px; padding:4px 12px;
  font-family:var(--ff-h); font-size:.68rem; font-weight:600; color:var(--g);
}

/* Empty state */
.no-results {
  text-align:center; padding:80px 20px; display:none;
}
.no-results i { font-size:3rem; color:rgba(255,255,255,.1); margin-bottom:16px; display:block; }
.no-results p { color:var(--tx2); font-size:.9rem; }

@media(max-width:767px){
  .proj-masonry { columns:2 240px; }
}
@media(max-width:480px){
  .proj-masonry { columns:1; }
}

/* ════════════════════════════════════════════════════════════
   PROJECT MODAL
════════════════════════════════════════════════════════════ */
.proj-modal-backdrop {
  position:fixed; inset:0; z-index:2000;
  background:rgba(6,12,9,.92); backdrop-filter:blur(16px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  opacity:0; pointer-events:none;
  transition:opacity var(--t) var(--ease);
}
.proj-modal-backdrop.open { opacity:1; pointer-events:all; }

.proj-modal {
  background:var(--dk3); border-radius:24px;
  border:1px solid rgba(31,164,99,.18);
  max-width:860px; width:100%;
  max-height:90vh; overflow-y:auto;
  transform:scale(.95) translateY(20px);
  transition:transform var(--t) var(--ease);
  position:relative;
}
.proj-modal-backdrop.open .proj-modal { transform:scale(1) translateY(0); }

.modal-img-ph {
  width:100%; aspect-ratio:16/7;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; color:rgba(255,255,255,.2); font-size:.85rem;
  background:linear-gradient(135deg,#0d2018,#0c1e2c);
  border-radius:24px 24px 0 0;
}
.modal-img-ph i { font-size:3.5rem; }

.modal-body-inner { padding:36px; }
.modal-cat {
  font-family:var(--ff-h); font-size:.68rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--g);
  margin-bottom:10px; display:flex; align-items:center; gap:6px;
}
.modal-cat::before { content:''; width:16px; height:1.5px; background:var(--g); border-radius:1px; }
.modal-body-inner h2 { font-size:1.7rem; font-weight:800; color:var(--wh); margin-bottom:14px; }
.modal-body-inner p  { font-size:.9rem; color:var(--tx2); line-height:1.85; margin-bottom:20px; }

.modal-details {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:28px;
}
.detail-box {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r); padding:14px 16px;
}
.detail-box .dl { font-size:.68rem; color:var(--tx2); text-transform:uppercase; letter-spacing:.1em; margin-bottom:4px; }
.detail-box .dv { font-family:var(--ff-h); font-size:.9rem; font-weight:600; color:var(--wh); }

.modal-close {
  position:absolute; top:16px; right:16px;
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.08); border:none;
  color:rgba(255,255,255,.6); font-size:1rem;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all var(--t);
}
.modal-close:hover { background:rgba(255,255,255,.16); color:var(--wh); }

@media(max-width:575px){
  .modal-details { grid-template-columns:1fr 1fr; }
  .modal-body-inner { padding:22px; }
}

/* ════════════════════════════════════════════════════════════
   CTA BANNER
════════════════════════════════════════════════════════════ */
#cta { background:var(--dk); }
.cta-inner {
  background:linear-gradient(105deg,#0d2018 0%,#0c1e2c 100%);
  border-radius:24px; padding:72px 60px;
  position:relative; overflow:hidden;
  border:1px solid rgba(31,164,99,.18);
}
.cta-inner::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(31,164,99,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(31,164,99,.05) 1px,transparent 1px);
  background-size:40px 40px;
}
.cta-glow {
  position:absolute; top:-50%; left:-10%;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle,rgba(31,164,99,.15),transparent 60%);
  pointer-events:none;
}
.cta-glow.r { left:auto; right:-10%; top:auto; bottom:-50%;
  background:radial-gradient(circle,rgba(31,160,200,.12),transparent 60%); }
@media(max-width:767px){ .cta-inner { padding:48px 28px; } }

/* ════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════ */
footer {
  background:#07110D; padding:72px 0 0;
  border-top:1px solid rgba(31,164,99,.12);
}
.ft-logo { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.ft-desc { font-size:.875rem; color:var(--tx2); line-height:1.8; margin-bottom:24px; max-width:280px; }
footer h6 {
  font-family:var(--ff-h); font-size:.7rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.3); margin-bottom:18px;
}
footer ul { list-style:none; padding:0; }
footer ul li { margin-bottom:8px; }
footer ul li a {
  font-size:.875rem; color:var(--tx2);
  transition:color var(--t),padding-left var(--t); display:inline-block;
}
footer ul li a:hover { color:var(--g); padding-left:6px; }
.ft-contact-item { display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; }
.ft-ico {
  width:34px; height:34px; border-radius:8px;
  background:rgba(31,164,99,.12); color:var(--g);
  display:flex; align-items:center; justify-content:center; font-size:.85rem; flex-shrink:0;
}
.ft-contact-item p { font-size:.84rem; color:var(--tx2); margin:0; line-height:1.5; }
.social-row { display:flex; gap:10px; margin-top:16px; }
.soc {
  width:38px; height:38px; border-radius:9px;
  background:rgba(255,255,255,.06); color:rgba(255,255,255,.5);
  display:flex; align-items:center; justify-content:center; font-size:.95rem;
  transition:all var(--t) var(--ease);
}
.soc:hover { background:var(--g); color:#fff; transform:translateY(-3px) scale(1.05); }
.ft-bottom {
  margin-top:52px; padding:20px 0;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:8px;
  font-size:.78rem; color:rgba(255,255,255,.28);
}

/* ════════════════════════════════════════════════════════════
   WHATSAPP FAB
════════════════════════════════════════════════════════════ */
.wa-fab {
  position:fixed; bottom:26px; right:26px; z-index:9999;
  width:56px; height:56px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:1.6rem;
  box-shadow:0 6px 24px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,.5);
  animation:waRing 3s ease-in-out infinite;
  transition:transform var(--t),box-shadow var(--t);
}
@keyframes waRing {
  0%  { box-shadow:0 6px 24px rgba(37,211,102,.5),0 0 0 0 rgba(37,211,102,.45); }
  60% { box-shadow:0 6px 24px rgba(37,211,102,.5),0 0 0 18px rgba(37,211,102,0); }
  100%{ box-shadow:0 6px 24px rgba(37,211,102,.5),0 0 0 0 rgba(37,211,102,0); }
}
.wa-fab:hover { transform:scale(1.12); box-shadow:0 10px 32px rgba(37,211,102,.65); color:#fff; animation:none; }
.wa-tip {
  position:absolute; right:66px;
  background:#07110D; color:var(--wh);
  font-family:var(--ff-h); font-size:.76rem; font-weight:600;
  padding:7px 14px; border-radius:8px; white-space:nowrap;
  border:1px solid rgba(31,164,99,.25);
  pointer-events:none; opacity:0;
  transition:opacity var(--t),right var(--t);
}
.wa-tip::after {
  content:''; position:absolute; right:-6px; top:50%; transform:translateY(-50%);
  border:6px solid transparent; border-left-color:#07110D;
}
.wa-fab:hover .wa-tip { opacity:1; right:70px; }

@media(max-width:575px){
  .sp { padding:72px 0; }
  .ph-h1 { font-size:2rem; }
  .wa-fab { bottom:18px; right:18px; width:50px; height:50px; font-size:1.4rem; }
}

/* ═══════════════════════════════════════════════════════════
   REDES SOCIALES PREMIUM (Colores oficiales)
═══════════════════════════════════════════════════════════ */
.social-link {
  width: 38px; 
  height: 38px;
  display: inline-flex; 
  align-items: center; 
  justify-content: center;
  border-radius: 8px;
  background: rgba(255,255,255,.04) !important;
  color: rgba(255,255,255,.6) !important;
  font-size: 1.15rem;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  text-decoration: none;
  border: 1px solid transparent;
}

/* Efecto de elevación base */
.social-link:hover {
  color: #ffffff !important;
  transform: translateY(-3px);
}

/* Colores por red social */
.social-link.facebook:hover { 
  background: #1877F2 !important; 
  box-shadow: 0 4px 12px rgba(24,119,242,.3); 
}
.social-link.instagram:hover { 
  background: #E4405F !important; 
  box-shadow: 0 4px 12px rgba(228,64,95,.3); 
}
.social-link.linkedin:hover { 
  background: #0A66C2 !important; 
  box-shadow: 0 4px 12px rgba(10,102,194,.3); 
}
.social-link.youtube:hover { 
  background: #FF0000 !important; 
  box-shadow: 0 4px 12px rgba(255,0,0,.3); 
}

/* ═══════════════════════════════════════════════════════════
   CARRUSEL DEL MODAL DE PROYECTOS (Página Proyectos)
═══════════════════════════════════════════════════════════ */
.modal-carousel-custom {
  width: 100%;
  aspect-ratio: 16 / 9; /* Proporción panorámica perfecta */
  background: #0a0a0a;
  border-radius: 24px 24px 0 0;
  overflow: hidden;
  position: relative;
}

.modal-carousel-custom .carousel-inner,
.modal-carousel-custom .carousel-item {
  height: 100%;
  width: 100%;
}

.modal-carousel-custom .carousel-item img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Evita que las fotos se aplasten o estiren */
  object-position: center;
}

/* Botones de flecha elegantes con tu verde corporativo */
.modal-carousel-custom .carousel-control-prev-icon,
.modal-carousel-custom .carousel-control-next-icon {
  background-color: rgba(31,164,99, 0.8); 
  border-radius: 50%;
  padding: 20px;
  background-size: 50%;
}

/* ═══════════════════════════════════════════════════════════
   OCULTAR PROYECTOS FILTRADOS (FILTRO INTELIGENTE)
═══════════════════════════════════════════════════════════ */
.proj-masonry .proj-item.hide {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  height: 0 !important;
  width: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}