/* ================================================================
   MAUNA Agency — assets/pages/home.css
   Estilos EXCLUSIVOS de la homepage (index.php).
   Los estilos globales están en assets/components.css
   ================================================================ */

/* ----------------------------------------------------------------
   HERO
   ---------------------------------------------------------------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  padding: calc(var(--nav-h) + clamp(40px,8vw,80px)) var(--pad) clamp(36px,6vw,80px);
  overflow: hidden;
}
.hero-video-wrap { position: absolute; inset: 0; z-index: 0; }
.hero-video-wrap video {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.35) saturate(0.65);
}
.hero-video-wrap::before {
  content: '';
  position: absolute; inset: 0;
  background: url('https://images.unsplash.com/photo-1476480862126-209bfaa8edc8?w=1800&q=80&fit=crop') center/cover no-repeat;
  z-index: -1;
}
.hero-video-wrap::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(to top,  rgba(8,10,11,0.98) 0%, rgba(8,10,11,0.55) 45%, rgba(8,10,11,0.15) 75%),
    linear-gradient(to right, rgba(8,10,11,0.8) 0%, transparent 70%),
    linear-gradient(135deg,  rgba(21,245,112,0.07) 0%, transparent 55%);
}
.hero-glow {
  position: absolute;
  width: clamp(260px,50vw,600px); height: clamp(260px,50vw,600px);
  background: radial-gradient(circle, rgba(21,245,112,0.13) 0%, transparent 70%);
  bottom: -10%; left: -8%;
  pointer-events: none; z-index: 1;
}
.hero-content { position: relative; z-index: 2; width: 100%; max-width: 720px; }

.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(21,245,112,0.1); border: 1px solid var(--green-border);
  padding: 6px 14px;
  font-size: 10px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase;
  color: var(--green);
  margin-bottom: clamp(16px,3vw,28px);
  clip-path: polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
}
.hero-tag::before {
  content: ''; width: 6px; height: 6px;
  background: var(--green); border-radius: 50%;
  animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.3;transform:scale(0.6)} }

.hero h1 {
  font-size: clamp(40px, 8vw, 96px); font-weight: 900;
  line-height: 0.93; text-transform: uppercase; letter-spacing: -2px;
  margin-bottom: clamp(14px,2.5vw,24px);
}
.hero h1 em { font-style: normal; color: var(--green); text-shadow: 0 0 50px var(--green-glow); }

.hero-sub {
  font-size: clamp(13px, 2vw, 16px); font-weight: 300;
  color: var(--text2); line-height: 1.75; max-width: 460px;
  margin-bottom: clamp(24px,4vw,44px);
}
.hero-sub strong { color: var(--text); font-weight: 700; }

.hero-btns { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-bottom: clamp(28px,4.5vw,52px); }

.hero-stats {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 2px; max-width: min(100%, 440px);
}
.hero-stat {
  background: var(--glass); border: 1px solid var(--glass-border);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  padding: clamp(12px,2vw,18px) clamp(10px,1.8vw,16px);
  text-align: center; transition: border-color 0.3s;
}
.hero-stat:hover { border-color: var(--green-border); }
.hero-stat-num  { font-size: clamp(20px,4vw,34px); font-weight: 900; color: var(--green); line-height: 1; margin-bottom: 3px; }
.hero-stat-label { font-size: 9px; color: var(--text3); text-transform: uppercase; letter-spacing: 1px; font-weight: 700; }

/* ----------------------------------------------------------------
   PROBLEM
   ---------------------------------------------------------------- */
.problem-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: clamp(32px,5vw,56px); }
.problem-card {
  background: var(--glass); border: 1px solid var(--glass-border);
  backdrop-filter: blur(20px);
  padding: clamp(24px,3.5vw,40px) clamp(20px,3vw,32px);
  position: relative; overflow: hidden;
  transition: border-color var(--t-normal), transform var(--t-normal);
}
.problem-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--green-glass), transparent);
  opacity: 0; transition: opacity var(--t-normal);
}
.problem-card:hover { border-color: var(--green-border); transform: translateY(-4px); }
.problem-card:hover::before { opacity: 1; }
.problem-num { font-size: 68px; font-weight: 900; color: rgba(255,255,255,0.028); position: absolute; top: 4px; right: 12px; line-height: 1; pointer-events: none; }
.problem-icon {
  width: 46px; height: 46px;
  background: var(--green-glass); border: 1px solid var(--green-border);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
  clip-path: polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
  transition: all 0.3s;
}
.problem-card:hover .problem-icon { background: rgba(21,245,112,0.14); box-shadow: 0 0 18px var(--green-glow); }
.problem-card h3 { font-size: clamp(16px,2.2vw,22px); font-weight: 800; text-transform: uppercase; margin-bottom: 10px; line-height: 1.1; }
.problem-card p  { font-size: clamp(12px,1.4vw,13px); color: var(--text2); line-height: 1.65; }

/* ----------------------------------------------------------------
   VALUE
   ---------------------------------------------------------------- */
.value-section { background: var(--bg2); }
.value-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 2px; margin-top: clamp(32px,5vw,56px); }
.value-card {
  background: var(--glass); border: 1px solid var(--glass-border);
  backdrop-filter: blur(20px);
  padding: clamp(26px,3.5vw,44px) clamp(20px,3vw,36px);
  display: flex; align-items: flex-start; gap: clamp(16px,2.5vw,24px);
  transition: border-color var(--t-normal), transform var(--t-normal);
  position: relative; overflow: hidden;
}
.value-card::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--green); transition:width 0.4s; }
.value-card:hover { border-color: rgba(21,245,112,0.24); transform: translateY(-3px); }
.value-card:hover::after { width: 100%; }
.value-icon {
  width: 48px; height: 48px;
  background: var(--green-glass); border: 1px solid var(--green-border);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  clip-path: polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%); transition: all 0.3s;
}
.value-card:hover .value-icon { background: rgba(21,245,112,0.18); box-shadow: 0 0 20px var(--green-glow); }
.value-card h3 { font-size: clamp(18px,2.2vw,24px); font-weight: 800; text-transform: uppercase; margin-bottom: 8px; }
.value-card p  { font-size: clamp(12px,1.4vw,13px); color: var(--text2); line-height: 1.7; }
.value-full { grid-column: 1/-1; background: linear-gradient(135deg,rgba(21,245,112,0.07),rgba(21,245,112,0.01)); border-color: var(--green-border); flex-direction: column; align-items: flex-start; }
.value-full h3 { font-size: clamp(20px,2.8vw,30px); }

/* ----------------------------------------------------------------
   SERVICES BENTO
   ---------------------------------------------------------------- */
.services-bento { display: grid; grid-template-columns: repeat(12,1fr); gap: 2px; margin-top: clamp(32px,5vw,56px); }
.svc-a { grid-column: 1/7; }   .svc-b { grid-column: 7/10; }
.svc-c { grid-column: 10/13; } .svc-d { grid-column: 1/5; }
.svc-e { grid-column: 5/9; }   .svc-f { grid-column: 9/13; }
.svc-g { grid-column: 1/13; }

.svc {
  background: var(--glass); border: 1px solid var(--glass-border);
  backdrop-filter: blur(20px);
  padding: clamp(20px,2.8vw,32px) clamp(18px,2.5vw,28px);
  position: relative; overflow: hidden;
  transition: border-color var(--t-normal), transform var(--t-normal), box-shadow var(--t-normal);
}
.svc::before {
  content:''; position:absolute; top:-60%; right:-60%; width:150%; height:150%;
  background: radial-gradient(circle at top right, rgba(21,245,112,0.06), transparent 60%);
  opacity:0; transition:opacity 0.4s;
}
.svc:hover { border-color: var(--green-border); transform: translateY(-3px); box-shadow: 0 16px 44px rgba(0,0,0,0.44); }
.svc:hover::before { opacity: 1; }

.svc-cover {
  width: calc(100% + clamp(40px,5.6vw,64px));
  margin: calc(-1 * clamp(20px,2.8vw,32px)) calc(-1 * clamp(18px,2.5vw,28px)) clamp(18px,2.5vw,26px);
  height: clamp(150px,20vw,210px); overflow: hidden; position: relative;
}
.svc-cover img { width:100%; height:100%; object-fit:cover; filter:brightness(0.5) saturate(0.7); transition:all 0.45s; }
.svc:hover .svc-cover img { filter:brightness(0.65) saturate(1); transform:scale(1.04); }
.svc-cover::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(8,10,11,0.9) 0%, transparent 60%); }

.svc-badge {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(21,245,112,0.1); border: 1px solid var(--green-border);
  padding: 3px 10px; font-size: 9px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
  color: var(--green); margin-bottom: 10px;
  clip-path: polygon(4px 0%,100% 0%,calc(100% - 4px) 100%,0% 100%);
}
.svc h3 { font-size: clamp(16px,2vw,22px); font-weight: 800; text-transform: uppercase; margin-bottom: 7px; line-height: 1; }
.svc p  { font-size: clamp(11px,1.3vw,13px); color: var(--text2); line-height: 1.6; max-width: 380px; }
.svc-arrow {
  position: absolute; bottom: clamp(16px,2vw,22px); right: clamp(16px,2vw,24px);
  width: 30px; height: 30px;
  background: var(--green-glass); border: 1px solid var(--green-border);
  display:flex; align-items:center; justify-content:center; font-size: 13px;
  clip-path: polygon(4px 0%,100% 0%,calc(100% - 4px) 100%,0% 100%); transition: all 0.3s;
}
.svc:hover .svc-arrow { background: var(--green); color: #000; }
.svc-g .svc-inner { display:flex; gap:clamp(18px,3vw,40px); align-items:center; flex-wrap:wrap; }
.svc-g .svc-inner > div:first-child { flex:1; min-width:200px; }
.svc-merch-icons { display:flex; gap:8px; flex-wrap:wrap; }
.svc-merch-icon {
  width: clamp(52px,6.5vw,66px); height: clamp(52px,6.5vw,66px);
  background: var(--green-glass); border: 1px solid var(--green-border);
  display:flex; align-items:center; justify-content:center;
  font-size: clamp(20px,2.8vw,26px);
  clip-path: polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%); transition:all 0.3s;
}
.svc-merch-icon:hover { background:rgba(21,245,112,0.18); box-shadow:0 0 14px var(--green-glow); }

/* ----------------------------------------------------------------
   PROCESS
   ---------------------------------------------------------------- */
.process-section { background: var(--bg2); }
.process-track { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; margin-top: clamp(32px,5vw,56px); position: relative; }
.process-track::before {
  content:''; position:absolute; top:42px; left:12%; right:12%; height:1px;
  background:linear-gradient(to right, transparent, var(--green), transparent);
  opacity:0.22; pointer-events:none; z-index:0;
}
.process-step {
  background: var(--glass); border: 1px solid var(--glass-border); backdrop-filter: blur(20px);
  padding: clamp(22px,3vw,34px) clamp(18px,2.5vw,26px);
  transition: border-color var(--t-normal), transform var(--t-normal);
  position: relative; z-index: 1;
}
.process-step:hover { border-color: var(--green-border); transform: translateY(-4px); }
.process-num { font-size: 10px; font-weight: 800; letter-spacing: 3px; color: var(--green); margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.process-num::after { content:''; flex:1; height:1px; background:rgba(21,245,112,0.2); }
.process-step h3 { font-size: clamp(18px,2.2vw,24px); font-weight: 800; text-transform: uppercase; margin-bottom: 9px; }
.process-step p  { font-size: clamp(11px,1.3vw,13px); color: var(--text2); line-height: 1.65; }

/* ----------------------------------------------------------------
   RESULTS
   ---------------------------------------------------------------- */
.results-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: clamp(32px,5vw,56px); }
.result-card {
  background: var(--glass); border: 1px solid var(--glass-border); backdrop-filter: blur(20px);
  padding: clamp(24px,3.5vw,40px) clamp(20px,3vw,36px);
  position: relative; overflow: hidden; transition: border-color var(--t-normal);
}
.result-card:hover { border-color: var(--green-border); }
.result-hero { grid-column: 1/2; grid-row: 1/3; display: flex; flex-direction: column; justify-content: flex-end; min-height: 300px; border-color: var(--green-border); }
.result-bg { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1517649763962-0c623066013b?w=800&q=80&fit=crop') center/cover no-repeat; filter:brightness(0.25) saturate(0.4); transition:all 0.4s; }
.result-hero:hover .result-bg { filter:brightness(0.32) saturate(0.55); }
.result-content { position:relative; z-index:1; }
.result-icon { margin-bottom:14px; }
.result-num { display:block; font-size:clamp(40px,5vw,68px); font-weight:900; line-height:1; color:var(--green); text-shadow:0 0 34px var(--green-glow); margin-bottom:5px; }
.result-num-orange { color: var(--orange); text-shadow: 0 0 34px var(--orange-glow); }
.result-label { font-size:clamp(13px,1.7vw,17px); font-weight:800; text-transform:uppercase; margin-bottom:5px; }
.result-desc  { font-size:clamp(11px,1.2vw,13px); color:var(--text2); line-height:1.55; }

/* ----------------------------------------------------------------
   DIFFERENTIATION
   ---------------------------------------------------------------- */
.diff-section { background: var(--bg2); position:relative; overflow:hidden; }
.diff-section::before { content:''; position:absolute; width:560px; height:560px; background:radial-gradient(circle,rgba(21,245,112,0.055),transparent 70%); top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; }
.diff-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.diff-text h2 { font-size:clamp(32px,5vw,64px); font-weight:900; text-transform:uppercase; line-height:0.95; letter-spacing:-1px; margin-bottom:20px; }
.diff-text h2 em { font-style:normal; color:var(--green); }
.diff-text p { font-size:clamp(13px,1.6vw,15px); color:var(--text2); line-height:1.8; margin-bottom:28px; }
.diff-list { display:flex; flex-direction:column; gap:12px; }
.diff-list li { display:flex; align-items:flex-start; gap:11px; font-size:clamp(12px,1.4vw,14px); color:var(--text2); line-height:1.5; }
.diff-list li svg { flex-shrink:0; margin-top:2px; }
.diff-visual { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:2px; height:420px; }
.diff-img { overflow:hidden; position:relative; }
.diff-img:first-child { grid-row:1/3; }
.diff-img img { width:100%; height:100%; object-fit:cover; filter:brightness(0.52) saturate(0.78); transition:all 0.45s; }
.diff-img:hover img { filter:brightness(0.72) saturate(1); transform:scale(1.04); }

/* ----------------------------------------------------------------
   RESPONSIVE — homepage specific
   ---------------------------------------------------------------- */
@media (max-width: 1024px) {
  .services-bento { grid-template-columns: repeat(2,1fr); }
  .svc-a,.svc-b,.svc-c,.svc-d,.svc-e,.svc-f { grid-column: auto; }
  .svc-g { grid-column: 1/-1; }
  .results-grid { grid-template-columns: repeat(2,1fr); }
  .result-hero { grid-column:1/-1; grid-row:auto; min-height:220px; }
  .diff-grid { grid-template-columns: 1fr; }
  .diff-visual { display: none; }
}

@media (max-width: 640px) {
  .problem-grid  { grid-template-columns: 1fr; }
  .value-grid    { grid-template-columns: 1fr; }
  .value-full    { grid-column: auto; }
  .services-bento { grid-template-columns: 1fr; }
  .svc-g { grid-column: auto; }
  .process-track { grid-template-columns: 1fr 1fr; }
  .process-track::before { display: none; }
  .results-grid  { grid-template-columns: 1fr; }
  .hero-stats    { max-width: 100%; }
  .svc-g .svc-inner { flex-direction: column; }
}

@media (max-width: 400px) {
  .process-track { grid-template-columns: 1fr; }
  .hero-stat-label { font-size: 8px; }
  .hero-stats { gap: 1px; }
}
