:root {
  --bg: #070a0f;
  --bg-soft: #101721;
  --text: #f4efe7;
  --muted: rgba(244, 239, 231, .68);
  --line: rgba(255, 255, 255, .13);
  --glass: rgba(255, 255, 255, .075);
  --glass-strong: rgba(255, 255, 255, .12);
  --accent: #d9c9b4;
  --accent-2: #c7d3c2;
  --accent-3: #88a58e;
  --shadow: 0 24px 80px rgba(0, 0, 0, .34);
  --radius: 28px;
  --container: 1120px;
  --ease: cubic-bezier(.2, .75, .25, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 14% 8%, rgba(199, 211, 194, .22), transparent 31%),
    radial-gradient(circle at 92% 14%, rgba(217, 201, 180, .18), transparent 29%),
    linear-gradient(135deg, #07090f 0%, #101721 50%, #080b11 100%);
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 78px 78px;
  mask-image: radial-gradient(circle at 50% 24%, black, transparent 70%);
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
h1, h2, h3, p { margin: 0; }
h1, h2, h3 { font-family: "Space Grotesk", Inter, system-ui, sans-serif; }

.noise {
  position: fixed;
  inset: 0;
  z-index: 50;
  pointer-events: none;
  opacity: .15;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E");
}
.cursor-glow {
  position: fixed;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(217,201,180,.18), transparent 65%);
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 1;
}

.site-header {
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  width: min(var(--container), calc(100% - 32px));
  min-height: 66px;
  padding: 9px 10px 9px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(8, 11, 17, .68);
  backdrop-filter: blur(22px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  z-index: 20;
  box-shadow: 0 16px 60px rgba(0,0,0,.22);
}
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: max-content; font-weight: 850; letter-spacing: -.03em; }
 .brand-mark {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  position: relative;
  border-radius: 18px 12px 18px 12px;
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(circle at 30% 18%, rgba(255,255,255,.46), transparent 0 13%, transparent 38%),
    linear-gradient(145deg, rgba(255,255,255,.13), rgba(255,255,255,.025)),
    conic-gradient(from 215deg at 50% 50%, #090f18 0deg, #12222f 58deg, #37f2ff 112deg, #d8ff75 158deg, #ff9b3d 222deg, #6d5cff 292deg, #090f18 360deg);
  color: #fff8df;
  font-family: "Space Grotesk", Inter, system-ui, sans-serif;
  font-size: 1.62rem;
  line-height: 1;
  font-weight: 950;
  text-shadow: 0 0 18px rgba(216,255,117,.38), 0 0 24px rgba(55,242,255,.22);
  box-shadow:
    0 18px 44px rgba(0,0,0,.34),
    0 0 34px rgba(55,242,255,.13),
    0 0 38px rgba(216,255,117,.1),
    inset 0 1px 0 rgba(255,255,255,.48),
    inset 0 -14px 22px rgba(0,0,0,.24);
  transform: rotate(-6deg);
  transition: transform .35s var(--ease), filter .35s var(--ease), box-shadow .35s var(--ease);
}
.brand-mark::before {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 15px 10px 15px 10px;
  background: rgba(7,10,15,.46);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: inset 0 1px 18px rgba(255,255,255,.07);
  z-index: -1;
}
.brand-mark::after {
  content: "";
  position: absolute;
  width: 60%;
  height: 155%;
  left: -26%;
  top: -22%;
  background: linear-gradient(110deg, transparent, rgba(255,255,255,.52), transparent);
  transform: rotate(18deg);
  opacity: .32;
  animation: markSweep 5.5s ease-in-out infinite;
  z-index: -1;
}
.brand-mark {
  -webkit-text-stroke: .6px rgba(255,255,255,.18);
}
.brand-mark:not(:empty) {
  background-clip: padding-box;
}

.brand:hover .brand-mark { transform: rotate(0deg) translateY(-2px) scale(1.04); filter: saturate(1.12) contrast(1.06); box-shadow: 0 20px 50px rgba(0,0,0,.38), 0 0 42px rgba(55,242,255,.2), 0 0 46px rgba(216,255,117,.16), inset 0 1px 0 rgba(255,255,255,.58); }
.brand-text { font-size: 1rem; }
.main-nav { display: flex; align-items: center; justify-content: flex-end; gap: 5px; flex-wrap: nowrap; }
.main-nav a { padding: 12px 13px; border-radius: 999px; color: var(--muted); font-size: .88rem; white-space: nowrap; transition: .35s var(--ease); }
.main-nav a:hover { color: var(--text); background: rgba(255,255,255,.09); transform: translateY(-1px); }
.menu-toggle { display: none; background: transparent; border: 0; width: 48px; height: 48px; cursor: pointer; }
.menu-toggle span { display: block; height: 2px; background: var(--text); margin: 7px 8px; border-radius: 999px; }

.section { width: min(var(--container), calc(100% - 32px)); margin: 0 auto; position: relative; z-index: 2; }
.section:not(.hero):not(.intro-strip) { padding: 104px 0; }
.glass-card { border: 1px solid var(--line); background: linear-gradient(135deg, rgba(255,255,255,.11), rgba(255,255,255,.045)); backdrop-filter: blur(24px); box-shadow: var(--shadow); }

.hero {
  min-height: 100svh;
  padding: 148px 0 86px;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
  gap: clamp(34px, 5vw, 58px);
  align-items: center;
}
#particle-canvas { position: absolute; inset: 0 calc(50% - 50vw); width: 100vw; height: 100%; z-index: -1; opacity: .82; }
.grid-glow { position: absolute; inset: 12% -8% 4% -8%; z-index: -2; border-radius: 40px; background: radial-gradient(circle at var(--mx, 50%) var(--my, 42%), rgba(217,201,180,.14), transparent 30%); }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(16px); z-index: -1; animation: float 8s ease-in-out infinite; pointer-events: none; }
.orb-one { width: 230px; height: 230px; background: rgba(136,165,142,.16); top: 18%; left: -8%; }
.orb-two { width: 270px; height: 270px; background: rgba(217,201,180,.12); bottom: 18%; right: -9%; animation-delay: -3s; }
.hero-content, .hero-visual { min-width: 0; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; color: var(--muted); font-size: .86rem; letter-spacing: .04em; text-transform: uppercase; }
.eyebrow span { width: 30px; height: 1px; background: linear-gradient(90deg, var(--accent), transparent); }
h1 {
  margin-top: 16px;
  padding: .03em 0 0;
  max-width: 740px;
  font-size: clamp(3.05rem, 6.8vw, 5.72rem);
  line-height: .76;
  letter-spacing: -.056em;
  text-wrap: balance;
}
h2 { font-size: clamp(2.05rem, 4.8vw, 4.2rem); line-height: 1.06; letter-spacing: -.052em; text-wrap: balance; }
h3 { font-size: 1.35rem; letter-spacing: -.032em; }
.hero-copy { margin-top: 24px; max-width: 620px; color: var(--muted); font-size: clamp(1.04rem, 1.8vw, 1.22rem); line-height: 1.65; }
.hero-actions, .contact-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 34px; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: 0 22px; border-radius: 999px; border: 1px solid var(--line); font-weight: 780; transition: transform .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease); position: relative; overflow: hidden; }
.btn::after { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, transparent, rgba(255,255,255,.24), transparent); transform: translateX(-120%); transition: .6s var(--ease); }
.btn:hover::after { transform: translateX(120%); }
.btn-primary { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #111; box-shadow: 0 16px 50px rgba(217,201,180,.16); }
.btn-secondary { background: rgba(255,255,255,.06); backdrop-filter: blur(14px); color: var(--text); }
.btn:hover { transform: translateY(-3px); }
.metrics { margin-top: 38px; padding: 18px; border-radius: 24px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; max-width: 560px; }
.metrics div { padding: 8px 10px; min-width: 0; }
.metrics strong { display: block; font-size: 1.75rem; letter-spacing: -.05em; }
.metrics span { color: var(--muted); font-size: .82rem; }
.portrait-shell { position: relative; width: min(100%, 480px); margin-left: auto; border-radius: 38px; padding: 12px; background: rgba(255,255,255,.075); border: 1px solid var(--line); box-shadow: var(--shadow); transform-style: preserve-3d; }
.portrait-shell::after { content:""; position: absolute; inset: -1px; border-radius: inherit; background: linear-gradient(135deg, rgba(217,201,180,.28), transparent 35%, rgba(199,211,194,.22)); opacity: .5; z-index: -1; }
.portrait-shell img { width: 100%; border-radius: 30px; aspect-ratio: 4 / 5; object-fit: cover; object-position: center; filter: saturate(1.02) contrast(1.03); }
.floating-tag { position: absolute; padding: 12px 14px; border: 1px solid var(--line); border-radius: 999px; background: rgba(8,11,17,.64); backdrop-filter: blur(16px); font-size: .82rem; color: var(--text); box-shadow: 0 18px 40px rgba(0,0,0,.25); white-space: nowrap; }
.tag-one { top: 9%; left: -22px; animation: tagPulse 4s ease-in-out infinite; }
.tag-two { right: -18px; bottom: 14%; animation: tagPulse 4s ease-in-out infinite -1.6s; }

.intro-strip { padding: 42px; margin-top: -30px; border-block: 1px solid var(--line); overflow: hidden; }
.intro-strip p { font-size: clamp(1.35rem, 3vw, 2.35rem); line-height: 1.25; letter-spacing: -.04em; color: rgba(244,239,231,.84); }
.marquee { margin-bottom: 20px; opacity: .82; mask-image: linear-gradient(90deg, transparent, black 15%, black 85%, transparent); }
.marquee-track { display: flex; gap: 14px; width: max-content; animation: marqueeMove 22s linear infinite; }
.marquee span { display: inline-flex; align-items:center; height: 34px; padding: 0 14px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.055); color: rgba(244,239,231,.72); font-size: .78rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 800; white-space: nowrap; }

.section-heading { margin-bottom: 44px; max-width: 800px; }
.section-heading span { color: var(--accent); font-weight: 820; text-transform: uppercase; letter-spacing: .12em; font-size: .78rem; }
.section-heading p { margin-top: 18px; color: var(--muted); line-height: 1.7; max-width: 640px; }
.centered { text-align: center; margin-inline: auto; }
.centered p { margin-inline: auto; }
.about-grid { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 34px; align-items: stretch; }
.about-image { border-radius: var(--radius); padding: 10px; overflow: hidden; transition: .35s var(--ease); }
.about-image img { width: 100%; height: 100%; min-height: 470px; border-radius: 22px; object-fit: cover; object-position: center; }
.about-copy { padding: 20px 0 20px 18px; display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.about-copy > p { color: var(--muted); font-size: 1.08rem; line-height: 1.8; margin-bottom: 18px; }
.about-points { display: grid; gap: 12px; margin-top: 18px; }
.about-points div { padding: 18px; border-radius: 20px; border: 1px solid var(--line); background: rgba(255,255,255,.045); transition: .35s var(--ease); position: relative; overflow: hidden; }
.about-points div::after { content:""; position:absolute; inset:0; background: linear-gradient(110deg, transparent, rgba(255,255,255,.08), transparent); transform: translateX(-120%); transition: .7s var(--ease); }
.about-points div:hover { transform: translateX(8px); background: rgba(255,255,255,.075); }
.about-points div:hover::after { transform: translateX(120%); }
.about-points span { color: var(--accent); font-weight: 800; font-size: .78rem; }
.about-points strong { display: block; margin: 6px 0 4px; }
.about-points small { color: var(--muted); }
.cards-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.service-card { min-height: 292px; border-radius: var(--radius); padding: 26px; transition: .35s var(--ease); transform-style: preserve-3d; position: relative; overflow: hidden; }
.service-card::before { content:""; position:absolute; width: 150px; height: 150px; border-radius:50%; right:-60px; top:-60px; background: rgba(217,201,180,.1); filter: blur(2px); transition: .45s var(--ease); }
.service-card:hover { transform: translateY(-8px); background: linear-gradient(135deg, rgba(217,201,180,.16), rgba(255,255,255,.045)); }
.service-card:hover::before { transform: scale(1.6); opacity: .7; }
.card-icon { width: 46px; height: 46px; border-radius: 15px; display: grid; place-items: center; background: rgba(217,201,180,.16); color: var(--accent); margin-bottom: 54px; font-size: 1.3rem; }
.service-card p { color: var(--muted); line-height: 1.65; margin-top: 12px; font-size: .95rem; }
.project-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.project-card { border-radius: var(--radius); padding: 24px; display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; transition: .35s var(--ease); position: relative; overflow: hidden; min-height: 238px; }
.project-card::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 12% 50%, rgba(199,211,194,.12), transparent 35%); opacity:0; transition:.35s var(--ease); }
.project-card:hover { transform: translateY(-5px) scale(1.01); border-color: rgba(217,201,180,.38); }
.project-card:hover::before { opacity:1; }
.project-card > * { position: relative; z-index:1; }
.project-main { display: grid; grid-template-columns: 96px minmax(0, 1fr); gap: 16px; align-items: start; min-width: 0; }
.project-logo-box { width: 96px; height: 50px; border-radius: 18px; border: 1px solid rgba(255,255,255,.13); background: rgba(255,255,255,.055); display: grid; place-items: center; padding: 12px; overflow: hidden; box-shadow: inset 0 1px 0 rgba(255,255,255,.08); }
.project-logo-box img { width: 100%; max-height: 28px; object-fit: contain; filter: drop-shadow(0 14px 24px rgba(0,0,0,.28)); }
.project-letter { font-family: "Space Grotesk", Inter, system-ui, sans-serif; font-size: 2.35rem; font-weight: 900; letter-spacing: -.08em; color: #061018; background: conic-gradient(from 210deg, #00e5ff, #7c5cff, #ff4ecd, #ffcf5c, #40f0a0, #00e5ff); }
.project-kicker { font-size: .75rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 850; }
.kicker-sajiro { color: #8ed8ff; }
.kicker-komerzo { color: #d8ff75; }
.kicker-suet { color: #f2d6bd; }
.kicker-limpanel { color: #7ff2b3; }
.project-card h3 { margin: 9px 0 9px; font-size: clamp(1.4rem, 2.4vw, 1.9rem); }
.project-card p { color: var(--muted); max-width: 520px; line-height: 1.62; font-size: .95rem; }
.project-arrow { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,.075); font-size: 1.4rem; transition: .35s var(--ease); flex: 0 0 auto; }
.project-card:hover .project-arrow { transform: rotate(-35deg); background: var(--accent); color: #111; }
.case-photo { margin-top: 24px; border-radius: var(--radius); overflow: hidden; position: relative; display: grid; grid-template-columns: minmax(0, .95fr) minmax(260px, .82fr); gap: clamp(20px, 3vw, 34px); align-items: center; padding: clamp(20px, 3vw, 34px); background: rgba(8,11,17,.44); }
.case-bg { position:absolute; inset:0; background-image: url('assets/clase-formacion.jpeg'); background-size: cover; background-position: center 58%; filter: blur(30px) saturate(1.05); transform: scale(1.12); opacity: .18; }
.case-image-wrap { position: relative; z-index: 2; border-radius: 26px; overflow: hidden; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); padding: 10px; box-shadow: 0 30px 80px rgba(0,0,0,.28); }
.case-image-wrap img { width: 100%; aspect-ratio: 4 / 3.15; object-fit: cover; object-position: center 64%; border-radius: 20px; display: block; -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.55) 6%, #000 15%, #000 85%, rgba(0,0,0,.55) 94%, transparent 100%); mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.55) 6%, #000 15%, #000 85%, rgba(0,0,0,.55) 94%, transparent 100%); }
.case-caption { position: relative; z-index: 2; padding: clamp(20px, 3vw, 34px); border-radius: 26px; background: rgba(255,255,255,.055); backdrop-filter: blur(18px); border: 1px solid var(--line); }
.case-caption span { color: var(--accent); font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; }
.case-caption h3 { margin-top: 16px; font-size: clamp(1.55rem, 3vw, 2.45rem); line-height: 1.02; letter-spacing: -.05em; }
.case-caption p { margin-top: 14px; color: rgba(244,239,231,.82); line-height: 1.7; max-width: 520px; }
.media { padding-top: 72px !important; }
.media-stage { min-height: 430px; border-radius: 36px; padding: clamp(24px, 4vw, 46px); position: relative; overflow: hidden; display: grid; align-items: center; }
.media-stage::before { content:""; position:absolute; inset:-42%; background: conic-gradient(from 180deg, rgba(217,201,180,.12), transparent, rgba(199,211,194,.16), transparent, rgba(217,201,180,.12)); animation: slowSpin 16s linear infinite; opacity: .8; }
.media-orbit { position:absolute; width: 360px; height: 360px; right: -120px; top: -120px; border:1px solid rgba(255,255,255,.14); border-radius: 50%; animation: slowSpin 22s linear infinite reverse; }
.media-orbit::before, .media-orbit::after { content:""; position:absolute; width: 12px; height: 12px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 30px rgba(217,201,180,.6); }
.media-orbit::before { top: 50%; left: -6px; }
.media-orbit::after { bottom: 38px; right: 42px; background: var(--accent-2); }
.media-slider { position: relative; min-height: 330px; z-index: 1; }
.media-card { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: center; opacity: 0; transform: translateY(22px) scale(.98); pointer-events: none; transition: .65s var(--ease); padding-right: min(22vw, 230px); }
.media-card.active { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.media-topline { display: flex; align-items: center; flex-wrap: wrap; gap: 14px; margin-bottom: 52px; }
.media-logo { min-height: 40px; display: inline-flex; align-items: center; justify-content: center; padding: 0 15px; border-radius: 13px; background: rgba(255,255,255,.92); color: #080b11; font-weight: 950; letter-spacing: -.04em; box-shadow: 0 14px 34px rgba(0,0,0,.18); }
.media-logo-wide { letter-spacing: -.05em; }
.media-source { width: max-content; max-width: 100%; margin-bottom: 0; padding: 9px 12px; border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.06); color: var(--accent); font-size: .74rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.media-card h3 { max-width: 760px; font-size: clamp(1.9rem, 3.8vw, 3.4rem); line-height: 1.06; margin-top: 2px; }
.media-card p { margin-top: 18px; max-width: 650px; color: var(--muted); line-height: 1.7; }
.media-card small { width: max-content; margin-top: 34px; margin-bottom: 10px; color: var(--text); font-weight: 850; }
.media-controls { position: relative; z-index: 2; display: flex; gap: 10px; margin-top: 46px; padding-top: 6px; }
.media-dot { width: 34px; height: 8px; border: 0; border-radius: 999px; background: rgba(255,255,255,.18); cursor: pointer; transition: .35s var(--ease); }
.media-dot.active { width: 68px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); }
.contact { padding-bottom: 78px !important; }
.contact-card { border-radius: 36px; padding: clamp(28px, 6vw, 64px); display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 28px; align-items: end; overflow: hidden; position: relative; }
.contact-card::before { content: ""; position: absolute; inset: -30%; background: radial-gradient(circle at 75% 20%, rgba(217,201,180,.15), transparent 32%); pointer-events: none; }
.contact-card > * { position: relative; z-index: 1; }
.contact-card h2 { max-width: 780px; }
.contact-card p { margin-top: 18px; color: var(--muted); line-height: 1.7; max-width: 560px; }
.footer { width: min(var(--container), calc(100% - 32px)); margin: 0 auto; padding: 34px 0 46px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 18px; color: var(--muted); font-size: .9rem; position: relative; z-index: 2; }
.footer a:hover { color: var(--text); }
.reveal { opacity: 0; transform: translateY(24px); transition: .8s var(--ease); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: .12s; }
.delay-2 { transition-delay: .2s; }
.delay-3 { transition-delay: .28s; }

@keyframes float { 0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(18px,-18px,0); } }
@keyframes tagPulse { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@keyframes slowSpin { to { transform: rotate(360deg); } }
@keyframes marqueeMove { to { transform: translateX(-50%); } }
@keyframes markSweep { 0%, 62%, 100% { transform: translateX(-32px) rotate(18deg); opacity: .16; } 76% { transform: translateX(72px) rotate(18deg); opacity: .42; } }

@media (max-width: 1080px) {
  .site-header { width: calc(100% - 24px); }
  .main-nav a { padding: 11px 10px; font-size: .84rem; }
  .hero { grid-template-columns: minmax(0, 1fr) minmax(320px, .82fr); }
  h1 { font-size: clamp(2.9rem, 6.3vw, 4.8rem); }
  .cards-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; padding-top: 128px; text-align: left; }
  .hero-visual { width: min(100%, 520px); margin: 8px auto 0; }
  .portrait-shell { margin: 0 auto; }
  .about-grid { grid-template-columns: 1fr; }
  .about-copy { padding-left: 0; }
  .contact-card { grid-template-columns: 1fr; }
  .project-list { grid-template-columns: 1fr; }
  .project-card { min-height: auto; }
  .project-main { grid-template-columns: 96px minmax(0, 1fr); }
  .project-logo-box { width: 96px; }
  .media-card { padding-right: 0; }
}
@media (max-width: 760px) {
  .section { width: min(100% - 24px, var(--container)); }
  .section:not(.hero):not(.intro-strip) { padding: 78px 0; }
  .site-header { top: 12px; min-height: 60px; border-radius: 28px; }
  .menu-toggle { display: block; flex: 0 0 auto; }
  .main-nav { position: absolute; top: calc(100% + 10px); left: 0; right: 0; padding: 10px; border-radius: 24px; border: 1px solid var(--line); background: rgba(8,11,17,.94); backdrop-filter: blur(20px); flex-direction: column; align-items: stretch; opacity: 0; pointer-events: none; transform: translateY(-10px); transition: .35s var(--ease); box-shadow: 0 20px 60px rgba(0,0,0,.3); }
  .main-nav.open { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .main-nav a { text-align: center; padding: 13px 14px; font-size: .95rem; }
  .hero { gap: 34px; padding-bottom: 64px; }
  h1 { font-size: clamp(2.75rem, 14vw, 4.4rem); line-height: .9; letter-spacing: -.052em; }
  h2 { font-size: clamp(2rem, 10vw, 3.1rem); }
  .metrics { grid-template-columns: 1fr; }
  .intro-strip { width: 100%; padding: 32px 16px; }
  .cards-grid { grid-template-columns: 1fr; }
  .service-card { min-height: auto; }
  .card-icon { margin-bottom: 32px; }
  .project-card { align-items: flex-start; padding: 22px; }
  .project-main { grid-template-columns: 1fr; gap: 16px; }
  .project-logo-box { width: 100%; max-width: 210px; height: 64px; justify-content: start; }
  .project-arrow { width: 46px; height: 46px; }
  .case-photo { grid-template-columns: 1fr; padding: 14px; }
  .case-image-wrap { order: -1; }
  .case-caption { padding: 20px; }
  .media-stage { min-height: 610px; border-radius: 30px; }
  .media-slider { min-height: 430px; }
  .media-card h3 { font-size: clamp(1.7rem, 8.2vw, 2.55rem); }
  .media-source { white-space: normal; width: fit-content; }
  .footer { flex-direction: column; }
  .cursor-glow { display: none; }
  .floating-tag { font-size: .75rem; }
  .tag-one { left: 8px; top: 10px; }
  .tag-two { right: 8px; bottom: 10px; }
}
@media (max-width: 430px) {
  .brand-text { display: none; }
  .hero-actions, .contact-actions { flex-direction: column; }
  .btn { width: 100%; }
  .project-card { flex-direction: column; }
  .project-logo-box { max-width: 100%; }
  .media-stage { min-height: 650px; }
  .media-slider { min-height: 420px; }
}
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; animation: none !important; transition: none !important; }
}


/* v11 mobile viewport refinement: compact metrics so the first fold doesn't show a cut-off glass block under iOS Safari's bottom bar */
@media (max-width: 760px) {
  .hero {
    min-height: auto;
    padding-top: 118px;
    padding-bottom: calc(42px + env(safe-area-inset-bottom));
  }
  .hero-copy {
    margin-top: 18px;
    line-height: 1.52;
  }
  .hero-actions, .contact-actions {
    margin-top: 26px;
  }
  .metrics {
    margin-top: 26px;
    padding: 10px;
    border-radius: 20px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }
  .metrics div {
    padding: 10px 6px;
    text-align: center;
    border-radius: 16px;
    background: rgba(255,255,255,.035);
  }
  .metrics strong {
    font-size: clamp(1.05rem, 6vw, 1.35rem);
    line-height: 1;
  }
  .metrics span {
    display: block;
    margin-top: 5px;
    font-size: .62rem;
    line-height: 1.15;
  }
}

@media (max-width: 380px) {
  .metrics {
    grid-template-columns: 1fr;
  }
}


/* v12: iPhone Safari bottom-bar refinement. Remove the large glass rectangle around metrics on mobile so it doesn't look like a cut-off block under the browser bar. */
@media (max-width: 760px) {
  .hero {
    min-height: auto;
    padding-bottom: calc(28px + env(safe-area-inset-bottom));
  }
  .metrics.glass-card,
  .metrics {
    margin-top: 26px;
    padding: 0;
    border: 0;
    background: transparent !important;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
    border-radius: 0;
    overflow: visible;
  }
  .metrics div {
    padding: 12px 6px;
    border: 1px solid rgba(255,255,255,.10);
    background: linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow: 0 12px 34px rgba(0,0,0,.12);
  }
}

@supports (-webkit-touch-callout: none) {
  @media (max-width: 760px) {
    .hero { padding-bottom: calc(18px + env(safe-area-inset-bottom)); }
  }
}

/* v19 — Mobile first-fold cleanup.
   The iPhone Safari bottom toolbar was visually cutting the hero metrics card.
   On mobile we remove that first-fold glass stats block completely, keeping the hero clean like the Cristina Jipa layout. */
@media (max-width: 760px) {
  html, body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden !important;
  }

  body {
    background-color: #070a0f;
  }

  .hero {
    min-height: auto !important;
    height: auto !important;
    padding-top: 118px !important;
    padding-bottom: 46px !important;
    overflow: hidden !important;
    gap: 0 !important;
  }

  .hero-content {
    max-width: 100%;
  }

  .hero .metrics,
  .hero .metrics.glass-card,
  .metrics,
  .metrics.glass-card {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .hero-actions {
    margin-bottom: 0 !important;
  }

  .intro-strip {
    margin-top: 0 !important;
  }
}

@media (max-width: 430px) {
  .hero {
    padding-bottom: 40px !important;
  }
}


/* v19 — Rebuild mobile hero from Cristina Jipa approach: no first-fold glass bars, no viewport-height trap. */
html{
  background:#2b302d !important;
  background-color:#2b302d !important;
  width:100% !important;
  overflow-x:hidden !important;
}
body{
  background:
    radial-gradient(circle at 20% 0%, rgba(199, 211, 194, .20), transparent 34%),
    radial-gradient(circle at 100% 12%, rgba(217, 201, 180, .13), transparent 34%),
    linear-gradient(135deg, #232927 0%, #303431 44%, #171b1b 100%) !important;
  background-color:#2b302d !important;
  width:100% !important;
  overflow-x:hidden !important;
}

/* Ensure any old metrics/card residue can never appear in the hero */
.hero .metrics,
.hero .metrics.glass-card{
  display:none !important;
}

@media (max-width: 760px){
  html,
  body{
    margin:0 !important;
    width:100% !important;
    max-width:100% !important;
    min-height:100% !important;
    overflow-x:hidden !important;
    background:#2b302d !important;
    background-color:#2b302d !important;
  }

  body{
    padding:0 !important;
    background:
      radial-gradient(circle at 14% 0%, rgba(199,211,194,.17), transparent 34%),
      radial-gradient(circle at 94% 12%, rgba(217,201,180,.12), transparent 32%),
      linear-gradient(145deg, #252b29 0%, #303432 46%, #151919 100%) !important;
  }

  body::before{
    position:fixed !important;
    inset:calc(-1 * env(safe-area-inset-top)) 0 calc(-1 * env(safe-area-inset-bottom)) 0 !important;
    background-size:72px 72px !important;
    opacity:.72 !important;
    mask-image:none !important;
  }

  .noise{display:none !important;}
  .cursor-glow{display:none !important;}

  .site-header{
    position:fixed !important;
    top:max(12px, env(safe-area-inset-top)) !important;
    left:16px !important;
    right:16px !important;
    width:auto !important;
    transform:none !important;
    min-height:66px !important;
    border-radius:28px !important;
    z-index:9999 !important;
  }

  main{
    position:relative !important;
    z-index:2 !important;
    margin:0 !important;
    padding:0 !important;
    overflow:hidden !important;
  }

  .section.hero,
  .hero{
    width:100% !important;
    max-width:100% !important;
    min-height:auto !important;
    height:auto !important;
    display:block !important;
    margin:0 !important;
    padding:118px 20px 58px !important;
    overflow:hidden !important;
    border:0 !important;
    background:transparent !important;
  }

  #particle-canvas{
    position:absolute !important;
    inset:0 !important;
    width:100% !important;
    height:100% !important;
    opacity:.62 !important;
    z-index:-1 !important;
  }

  .grid-glow{
    inset:0 !important;
    border-radius:0 !important;
    background:radial-gradient(circle at 18% 18%, rgba(217,201,180,.13), transparent 32%) !important;
  }

  .hero-content{
    position:relative !important;
    z-index:4 !important;
    width:100% !important;
    max-width:100% !important;
    margin:0 !important;
    padding:0 !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;
  }

  .hero-visual,
  .portrait-shell,
  .floating-tag{
    display:none !important;
  }

  .eyebrow{
    font-size:.78rem !important;
    line-height:1.45 !important;
    letter-spacing:.075em !important;
    margin-top:14px !important;
    max-width:100% !important;
  }

  h1{
    margin-top:18px !important;
    max-width:100% !important;
    font-size:clamp(4.05rem, 16.6vw, 5.45rem) !important;
    line-height:.88 !important;
    letter-spacing:-.066em !important;
    padding:0 !important;
  }

  .hero-copy{
    margin-top:26px !important;
    max-width:100% !important;
    font-size:1.18rem !important;
    line-height:1.55 !important;
  }

  .hero-actions{
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    gap:14px !important;
    margin-top:34px !important;
    margin-bottom:0 !important;
    width:100% !important;
  }

  .hero-actions .btn{
    min-height:54px !important;
    padding:0 20px !important;
    white-space:nowrap !important;
  }

  .hero .metrics,
  .hero .metrics.glass-card,
  .metrics.glass-card{
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    height:0 !important;
    min-height:0 !important;
    max-height:0 !important;
    margin:0 !important;
    padding:0 !important;
    border:0 !important;
    overflow:hidden !important;
    position:absolute !important;
    pointer-events:none !important;
  }

  .intro-strip{
    width:calc(100% - 40px) !important;
    margin-top:0 !important;
  }
}

@media (max-width: 430px){
  .section.hero,
  .hero{
    padding-left:20px !important;
    padding-right:20px !important;
    padding-bottom:56px !important;
  }

  h1{
    font-size:clamp(3.78rem, 16.2vw, 5.05rem) !important;
  }

  .hero-actions .btn{
    min-width:0 !important;
    flex:0 1 auto !important;
  }
}

@media (max-width: 370px){
  .hero-actions{
    flex-direction:column !important;
  }
  h1{font-size:3.45rem !important;}
}


/* v19 cookie smooth: suaviza la aparición de textos y puntos en Conóceme sin tocar estructura/layout */
.about-copy.reveal {
  transition-duration: 1.05s;
  transition-timing-function: cubic-bezier(.16, 1, .3, 1);
}
.about-copy.reveal > p,
.about-copy.reveal .about-points > div {
  opacity: 0;
  transform: translate3d(0, 14px, 0);
  transition:
    opacity .95s cubic-bezier(.16, 1, .3, 1),
    transform .95s cubic-bezier(.16, 1, .3, 1),
    background .35s var(--ease),
    border-color .35s var(--ease);
  will-change: opacity, transform;
}
.about-copy.reveal.visible > p,
.about-copy.reveal.visible .about-points > div {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}
.about-copy.reveal.visible > p:nth-of-type(1) { transition-delay: .08s; }
.about-copy.reveal.visible > p:nth-of-type(2) { transition-delay: .18s; }
.about-copy.reveal.visible .about-points > div:nth-child(1) { transition-delay: .30s; }
.about-copy.reveal.visible .about-points > div:nth-child(2) { transition-delay: .40s; }
.about-copy.reveal.visible .about-points > div:nth-child(3) { transition-delay: .50s; }

@media (max-width: 760px) {
  .reveal {
    transform: translate3d(0, 16px, 0);
    transition-duration: .95s;
    transition-timing-function: cubic-bezier(.16, 1, .3, 1);
  }
  .about-copy.reveal {
    transform: translate3d(0, 10px, 0);
  }
  .about-copy.reveal > p,
  .about-copy.reveal .about-points > div {
    transform: translate3d(0, 10px, 0);
    transition-duration: .85s;
  }
}


/* Cookie banner */
.cookie-banner {
  position: fixed;
  left: 50%;
  bottom: max(18px, env(safe-area-inset-bottom));
  transform: translateX(-50%);
  width: min(720px, calc(100% - 32px));
  z-index: 80;
}
.cookie-banner[hidden] { display: none !important; }
.cookie-banner__content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  padding: 16px 16px 16px 18px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  background: rgba(8, 11, 17, .82);
  backdrop-filter: blur(22px);
  box-shadow: 0 22px 70px rgba(0,0,0,.38);
}
.cookie-banner strong {
  display: block;
  margin-bottom: 4px;
  font-size: .94rem;
  letter-spacing: -.02em;
}
.cookie-banner p {
  margin: 0;
  max-width: 490px;
  color: rgba(244,239,231,.72);
  font-size: .86rem;
  line-height: 1.45;
}
.cookie-banner__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}
.cookie-btn {
  appearance: none;
  border: 0;
  cursor: pointer;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  font: inherit;
  font-weight: 800;
  letter-spacing: -.02em;
  transition: transform .25s var(--ease), opacity .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.cookie-btn:hover { transform: translateY(-2px); }
.cookie-btn--primary {
  color: #090c11;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
}
.cookie-btn--ghost {
  color: var(--text);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.13);
}

@media (max-width: 640px) {
  .cookie-banner {
    width: calc(100% - 28px);
    bottom: max(14px, env(safe-area-inset-bottom));
  }
  .cookie-banner__content {
    display: block;
    padding: 16px;
    border-radius: 22px;
  }
  .cookie-banner p {
    font-size: .82rem;
    line-height: 1.42;
  }
  .cookie-banner__actions {
    margin-top: 14px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .cookie-btn {
    width: 100%;
    min-height: 44px;
    padding: 0 12px;
  }
}


/* v19 mobile smooth fix: en móvil el bloque Conóceme aparece como una sola pieza, sin escalonado interno */
@media (max-width: 760px) {
  .about-copy.reveal > p,
  .about-copy.reveal .about-points > div {
    opacity: 1 !important;
    transform: none !important;
    transition-delay: 0s !important;
    transition-property: background, border-color, transform !important;
  }

  .about-copy.reveal.visible > p,
  .about-copy.reveal.visible .about-points > div {
    opacity: 1 !important;
    transform: none !important;
    transition-delay: 0s !important;
  }

  .about-copy.reveal {
    transition: opacity 1.05s cubic-bezier(.16, 1, .3, 1), transform 1.05s cubic-bezier(.16, 1, .3, 1) !important;
  }
}
