/* =========================================================
   PEREZ AEP — LIQUID GLASS PORTFOLIO
   Palette: #0A0B0D base, #7CFF4F accent, glass white-alpha
   Type: SF Pro / system stack
   ========================================================= */

:root{
  --bg: #0a0b0d;
  --accent: #7CFF4F;
  --accent-dim: #4fbf30;
  --glass: rgba(255,255,255,0.06);
  --glass-border: rgba(255,255,255,0.14);
  --glass-strong: rgba(255,255,255,0.10);
  --text: #f3f5f1;
  --text-dim: rgba(243,245,241,0.62);
  --radius: 22px;
  --ease: cubic-bezier(.16,.84,.44,1);
}

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

html{
  scroll-behavior:smooth;
  font-size:16px;
}

body{
  font-family:'SF Pro Rounded', ui-rounded, 'Quicksand', -apple-system,
    BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background:url("BGG.png") center/cover fixed no-repeat, var(--bg);
  color:var(--text);
  overflow-x:hidden;
  min-height:100vh;
}

/* ---------- noise overlay ---------- */
.noise{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:2;
  opacity:.035;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ambient glows removed — background is the pure BGG.png, no gradient overlays */

a{color:inherit;}

/* ================= WELCOME ================= */

#welcome{
  position:fixed;
  inset:0;
  background:rgba(6,7,8,0.88);
  backdrop-filter:blur(34px) saturate(140%);
  display:flex;
  justify-content:center;
  align-items:center;
  z-index:9999;
  padding:20px;
  transition:opacity .9s var(--ease), visibility .9s var(--ease);
}

#welcome.hide{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}

.welcome-content{
  text-align:center;
  animation:fadeUp 1.1s var(--ease) forwards;
  max-width:90%;
}

.welcome-ring{
  width:140px;height:140px;
  margin:0 auto 24px;
  border-radius:50%;
  padding:3px;
  background:conic-gradient(from 0deg, var(--accent), transparent 60%, var(--accent));
  animation:spin 6s linear infinite;
}

.welcome-ring img{
  width:100%;height:100%;
  border-radius:50%;
  object-fit:cover;
  display:block;
  background:var(--bg);
}

@keyframes spin{ to{ transform:rotate(360deg);} }

.welcome-content h1{
  font-size:clamp(2rem, 6vw, 2.8rem);
  font-weight:700;
  letter-spacing:-0.02em;
}

.welcome-content p{
  margin:12px 0 30px;
  color:var(--text-dim);
  font-size:clamp(.9rem, 2.5vw, 1.05rem);
}

.welcome-content button{
  padding:14px 38px;
  border-radius:50px;
  border:1px solid rgba(255,255,255,0.3);
  background:rgba(255,255,255,0.04);
  backdrop-filter:url(#liquid-distort-soft);
  color:var(--text);
  cursor:pointer;
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.01em;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.35),
    inset 0 -1px 2px rgba(0,0,0,0.25);
  transition:.4s var(--ease);
}

.welcome-content button:hover{
  background:var(--accent);
  color:#06210a;
  border-color:var(--accent);
  box-shadow:0 0 40px rgba(124,255,79,0.45);
  transform:translateY(-2px);
}

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

/* ================= NAV ================= */

nav{
  position:fixed;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  width:auto;
  max-width:90%;
  padding:14px 26px 14px 16px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:46px;
  z-index:1000;
  border-radius:999px;
  background:
    linear-gradient(155deg, rgba(255,255,255,0.14), rgba(255,255,255,0.02) 45%, rgba(0,0,0,0.3) 100%),
    rgba(15,16,18,0.5);
  border:1px solid rgba(255,255,255,0.2);
  backdrop-filter:url(#liquid-distort-soft);
  box-shadow:
    0 14px 40px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.3),
    inset 0 -1px 0 rgba(0,0,0,0.3);
  transition:padding .4s var(--ease), top .4s var(--ease), gap .4s var(--ease);
}

nav.scrolled{
  top:12px;
  padding:10px 22px 10px 14px;
  gap:34px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:700;
  letter-spacing:-0.01em;
  white-space:nowrap;
}

.brand img{
  width:34px;
  height:34px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid var(--glass-border);
}

.brand i{
  color:var(--accent);
  font-style:normal;
}

.nav-links{
  display:flex;
  white-space:nowrap;
}

.nav-links a{
  position:relative;
  text-decoration:none;
  margin-left:26px;
  color:var(--text-dim);
  font-size:.9rem;
  font-weight:500;
  transition:.3s;
}

.nav-links a::after{
  content:'';
  position:absolute;
  left:0; bottom:-6px;
  width:0%;
  height:2px;
  background:var(--accent);
  transition:width .35s var(--ease);
  box-shadow:0 0 8px var(--accent);
}

.nav-links a:hover{ color:var(--text); }

.nav-links a.active{
  color:var(--text);
}
.nav-links a.active::after{ width:100%; }

/* ================= HERO ================= */

header{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:110px 8% 60px;
  position:relative;
  z-index:1;
}

.hero-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:60px;
  flex-wrap:wrap;
}

.hero-text{
  max-width:620px;
}

.eyebrow{
  display:inline-block;
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:18px;
  font-weight:600;
}

header h1{
  font-size:clamp(2.6rem, 7vw, 4.6rem);
  font-weight:700;
  letter-spacing:-0.03em;
  line-height:1.04;
}

.hero-sub{
  margin-top:24px;
  font-size:clamp(1rem,2.2vw,1.15rem);
  max-width:520px;
  color:var(--text-dim);
  line-height:1.65;
}

.hero-buttons{
  margin-top:38px;
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}

.btn{
  padding:15px 34px;
  border-radius:50px;
  text-decoration:none;
  font-weight:600;
  font-size:.95rem;
  transition:.35s var(--ease);
  white-space:nowrap;
  display:inline-block;
}

.btn-solid{
  background:var(--accent);
  color:#06210a;
  box-shadow:0 0 0 rgba(124,255,79,0);
}
.btn-solid:hover{
  box-shadow:0 0 35px rgba(124,255,79,0.5);
  transform:translateY(-3px);
}

.btn-outline{
  border:1px solid rgba(255,255,255,0.3);
  background:rgba(255,255,255,0.04);
  backdrop-filter:url(#liquid-distort);
  -webkit-backdrop-filter:blur(0.1px);
  color:var(--text);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.35),
    inset 0 -1px 2px rgba(0,0,0,0.25);
  position:relative;
}
.btn-outline:hover{
  border-color:var(--accent);
  color:var(--accent);
  transform:translateY(-3px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.4),
    0 0 30px rgba(124,255,79,0.25);
}

/* hero stat cards */
.hero-stats{
  display:flex;
  flex-direction:column;
  gap:22px;
}

.stat-card{
  background:
    linear-gradient(155deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02) 45%, rgba(0,0,0,0.3) 100%),
    rgba(15,16,18,0.5);
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(26px) saturate(160%);
  border-radius:var(--radius);
  padding:24px 34px;
  min-width:220px;
  box-shadow:
    0 10px 34px rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.28),
    inset 0 -1px 0 rgba(0,0,0,0.3);
}

.stat-num{
  font-size:2rem;
  font-weight:700;
  color:var(--accent);
  text-shadow:0 0 18px rgba(124,255,79,0.4);
}

.stat-label{
  margin-top:4px;
  font-size:.85rem;
  color:var(--text-dim);
}

.float-1{ animation:floaty 6s ease-in-out infinite; }
.float-2{ animation:floaty 7s ease-in-out infinite .6s; }
.float-3{ animation:floaty 6.5s ease-in-out infinite 1.2s; }

@keyframes floaty{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-12px); }
}

.scroll-cue{
  position:absolute;
  bottom:36px;
  left:50%;
  transform:translateX(-50%);
  width:26px;
  height:42px;
  border:1px solid var(--glass-border);
  border-radius:20px;
}
.scroll-cue span{
  position:absolute;
  top:8px; left:50%;
  width:4px; height:8px;
  margin-left:-2px;
  border-radius:2px;
  background:var(--accent);
  animation:scrollDown 1.8s ease-in-out infinite;
}
@keyframes scrollDown{
  0%{ opacity:1; top:8px; }
  70%{ opacity:0; top:20px; }
  100%{ opacity:0; top:8px; }
}

/* ================= SECTIONS ================= */

section{
  padding:130px 8%;
  position:relative;
  z-index:1;
}

.section-head{
  text-align:center;
  margin-bottom:54px;
}

.section-head .eyebrow{ display:block; }

.section-title{
  font-size:clamp(1.8rem,4.5vw,2.6rem);
  font-weight:700;
  letter-spacing:-0.02em;
}

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:30px;
}

/* ---------- glass card (liquid glass) ---------- */
.card{
  position:relative;
  background:
    linear-gradient(155deg, rgba(255,255,255,0.10), rgba(255,255,255,0.02) 40%, rgba(0,0,0,0.25) 100%),
    rgba(15,16,18,0.55);
  border:1px solid rgba(255,255,255,0.16);
  backdrop-filter:blur(28px) saturate(160%);
  border-radius:var(--radius);
  padding:32px 28px;
  overflow:hidden;
  box-shadow:
    0 12px 40px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.25),
    inset 0 -1px 0 rgba(0,0,0,0.3);
  transition:transform .15s ease, box-shadow .4s var(--ease), border-color .4s var(--ease);
  transform-style:preserve-3d;
  will-change:transform;
}

.card::before{
  content:'';
  position:absolute;
  top:0; left:8%;
  width:84%;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.6), transparent);
}

.card:hover{
  border-color:rgba(124,255,79,0.45);
  box-shadow:
    0 20px 60px rgba(0,0,0,0.6),
    inset 0 1px 0 rgba(255,255,255,0.3),
    0 0 50px rgba(124,255,79,0.16);
}

.card-icon{
  width:46px;
  height:46px;
  object-fit:contain;
  margin-bottom:18px;
  filter:drop-shadow(0 0 10px rgba(124,255,79,0.25));
}

.card h3{
  font-size:1.15rem;
  font-weight:600;
  margin-bottom:10px;
  letter-spacing:-0.01em;
}

.card p{
  color:var(--text-dim);
  font-size:.92rem;
  line-height:1.6;
}

.price{
  margin-top:18px;
  font-weight:600;
  color:var(--accent);
  font-size:.92rem;
}

/* cursor-follow glow inside card */
.card-shine{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%),
    rgba(124,255,79,0.16), transparent 60%);
  opacity:0;
  transition:opacity .35s ease;
}
.card:hover .card-shine{ opacity:1; }

/* TikTok video card */
.video-card h3{
  margin-bottom:14px;
}

.tiktok-frame{
  width:100%;
  height:clamp(420px, 60vw, 580px);
  border:none;
  border-radius:14px;
  position:relative;
  z-index:1;
}

/* contact */
.contact-card{
  max-width:520px;
  margin:0 auto;
}

.contact-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 0;
  border-bottom:1px solid var(--glass-border);
  font-size:.95rem;
}
.contact-row:last-child{ border-bottom:none; }

.contact-label{
  color:var(--text-dim);
  font-weight:500;
}

.contact-row a{
  text-decoration:none;
  font-weight:600;
  transition:.3s;
}
.contact-row a:hover{
  color:var(--accent);
  text-shadow:0 0 10px rgba(124,255,79,0.5);
}

footer{
  text-align:center;
  padding:40px;
  color:var(--text-dim);
  font-size:.85rem;
  border-top:1px solid var(--glass-border);
  position:relative;
  z-index:1;
}

/* ================= SCROLL REVEAL ================= */

.reveal{
  opacity:0;
  transform:translateY(36px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal.in-view{
  opacity:1;
  transform:translateY(0);
}

/* ================= TABLET ================= */

@media(max-width:1024px){
  header{ padding:120px 6% 60px; }
  section{ padding:100px 6%; }
  .hero-inner{ flex-direction:column; align-items:flex-start; }
  .hero-stats{ flex-direction:row; flex-wrap:wrap; width:100%; }
  .stat-card{ flex:1; min-width:160px; }
}

/* ================= MOBILE ================= */

@media(max-width:768px){
  nav{
    flex-direction:column;
    gap:10px;
    padding:14px 22px;
    border-radius:28px;
    max-width:92%;
  }
  .nav-links a{ margin:0 10px; }
  header{ padding-top:170px; }
  section{ padding:80px 5%; }
  .tiktok-frame{ height:480px; }
  .hero-stats{ flex-direction:column; }
}

@media(max-width:480px){
  html{ font-size:15px; }
  .welcome-ring{ width:110px; height:110px; }
  .btn{ width:100%; text-align:center; }
  .stat-card{ min-width:100%; }
}

@media (prefers-reduced-motion: reduce){
  *{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
}
