/* =============================================
   PROXIMAMENTE.CSS
   Página "en construcción" — Reytor Portfolio
   Self-contained: no depende de style.css
   ============================================= */

:root {
  --orange:   #E84E1B;
  --orange-d: #C03D12;
  --bg:       #0D0D0D;
  --surface:  #161616;
  --border:   rgba(255,255,255,0.07);
  --text:     #F0EDE8;
  --muted:    #666;
  --dim:      #333;
  --white:    #fff;
  --font:     'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  height: 100%;
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ---- Grain texture ---- */
.grain {
  position: fixed;
  inset: -50%;
  width: 200%;
  height: 200%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.032;
  pointer-events: none;
  z-index: 10;
  animation: grainMove 0.4s steps(1) infinite;
}
@keyframes grainMove {
  0%   { transform: translate(0,   0);   }
  20%  { transform: translate(-3%, 4%);  }
  40%  { transform: translate(4%, -2%);  }
  60%  { transform: translate(-2%, 5%);  }
  80%  { transform: translate(3%, -4%);  }
  100% { transform: translate(-4%, 2%);  }
}

/* ---- Background blobs ---- */
.bg {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.bg__blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.18;
}

.bg__blob--1 {
  width: 600px;
  height: 600px;
  background: var(--orange);
  top: -160px;
  right: -100px;
  animation: blobFloat 9s ease-in-out infinite alternate;
}

.bg__blob--2 {
  width: 400px;
  height: 400px;
  background: #C03D12;
  bottom: -100px;
  left: -80px;
  animation: blobFloat 12s ease-in-out infinite alternate-reverse;
}

@keyframes blobFloat {
  from { transform: translate(0, 0) scale(1);     }
  to   { transform: translate(40px, 30px) scale(1.12); }
}

/* ---- Page layout ---- */
.page {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: 28px 32px;
  max-width: 900px;
  margin: 0 auto;
}

/* ---- Logo ---- */
.logo {
  display: inline-block;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--white);
  transition: opacity 0.2s ease;
}
.logo span { color: var(--orange); }
.logo:hover { opacity: 0.7; }

/* ---- Main content ---- */
.main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 0 40px;
}

.eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.eyebrow::before {
  content: '';
  display: inline-block;
  width: 32px;
  height: 1px;
  background: var(--orange);
}

/* ---- Headline ---- */
.headline {
  font-size: clamp(3.5rem, 10vw, 7.5rem);
  font-weight: 300;
  letter-spacing: -0.04em;
  line-height: 0.95;
  color: var(--white);
  margin-bottom: 36px;
}

.headline strong {
  font-weight: 900;
  color: var(--orange);
  display: block;
  position: relative;
}

/* Subrayado animado en "cocinando" */
.headline strong::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 100%;
  height: 3px;
  background: var(--orange);
  transform-origin: left;
  animation: underlineGrow 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.4s both;
}

@keyframes underlineGrow {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* ---- Body text ---- */
.body-text {
  font-size: clamp(1rem, 2.5vw, 1.2rem);
  color: var(--muted);
  line-height: 1.7;
  max-width: 480px;
  margin-bottom: 40px;
}

.body-text em {
  font-style: normal;
  color: var(--text);
  font-weight: 500;
}

/* ---- Tags ---- */
.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 48px;
}

.tags span {
  padding: 6px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--muted);
  animation: tagPop 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
  transition: border-color 0.2s ease, color 0.2s ease;
}

.tags span:hover {
  border-color: var(--orange);
  color: var(--orange);
}

@keyframes tagPop {
  from { opacity: 0; transform: translateY(8px) scale(0.95); }
  to   { opacity: 1; transform: translateY(0)   scale(1);    }
}

/* ---- Button ---- */
.btn {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 13px 26px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-family: var(--font);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: border-color 0.25s ease, color 0.25s ease, transform 0.2s ease;
}

.btn:hover {
  border-color: var(--orange);
  color: var(--orange);
  transform: translateX(-4px);
}

/* ---- Footer ---- */
.foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 12px;
}

.foot p {
  font-size: 0.75rem;
  color: var(--dim);
  letter-spacing: 0.04em;
}

.foot a {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px dotted var(--dim);
  padding-bottom: 1px;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.foot a:hover {
  color: var(--orange);
  border-color: var(--orange);
}

/* ---- Entrada general ---- */
.main > * {
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.eyebrow   { animation-delay: 0.05s; }
.headline  { animation-delay: 0.12s; }
.body-text { animation-delay: 0.20s; }
.tags      { animation-delay: 0.28s; }
.btn       { animation-delay: 0.36s; }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0);    }
}

/* ---- Responsive ---- */
@media (max-width: 600px) {
  .page { padding: 20px; }
  .headline { font-size: clamp(3rem, 14vw, 4.5rem); }
  .btn { align-self: stretch; justify-content: center; }
  .foot { flex-direction: column; align-items: flex-start; }
}
