*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;}
:root{
  --bg:#0E0C0A;
  --bg2:#141210;
  --bg3:#181510;
  --text:#F0E8DC;
  --muted:#7D6E5E;
  --muted2:#5A4E42;
  --accent:#C1440E;
  --accent2:#D95A20;
  --copper:#8B5E3C;
  --copper-light:#A8734E;
  --warm-line:rgba(240,220,190,0.07);
  --warm-surface:rgba(240,220,190,0.04);
  --warm-surface2:rgba(240,220,190,0.07);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'DM Sans',-apple-system,sans-serif;
  --logo:"Zalando Sans Expanded",sans-serif;
}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--sans);font-weight:300;
  font-size:16px;line-height:1.6;overflow-x:hidden;
}

/* ══ CURSOR ══ */
#cur{
  position:fixed;width:10px;height:10px;
  background:var(--accent);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .25s,height .25s,background .3s;
  mix-blend-mode:normal;
}
#cur-ring{
  position:fixed;width:36px;height:36px;
  border:1px solid rgba(139,94,60,.5);
  border-radius:50%;pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,border-color .3s;
}
#cur, #cur-ring{
  display:none;
}

@media(pointer: fine){
  #cur, #cur-ring{
    display:block;
  }
}
body:has(a:hover) #cur,
body:has(button:hover) #cur{width:5px;height:5px;}
body:has(a:hover) #cur-ring,
body:has(button:hover) #cur-ring{width:54px;height:54px;border-color:var(--accent);}

/* ══ CANVAS + BLOBS ══ */
#pcanvas{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;}
.blob{position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0;}
/* Blob principal: naranja profundo */
.b1{
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(193,68,14,.17) 0%,rgba(139,94,60,.06) 50%,transparent 70%);
  top:-200px;right:-130px;
  animation:bd1 20s ease-in-out infinite;
}
/* Blob secundario: cobre cálido */
.b2{
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(139,94,60,.13) 0%,rgba(100,60,20,.05) 50%,transparent 70%);
  bottom:8%;left:-110px;
  animation:bd2 24s ease-in-out infinite;
}
/* Blob terciario: ámbar muy sutil */
.b3{
  width:320px;height:320px;
  background:radial-gradient(circle,rgba(200,140,60,.07) 0%,transparent 65%);
  top:42%;left:38%;
  animation:bd3 16s ease-in-out infinite;
}
@keyframes bd1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-45px,30px) scale(1.1)}66%{transform:translate(30px,-20px) scale(.93)}}
@keyframes bd2{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-50px) scale(1.12)}}
@keyframes bd3{0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,30px)}}

/* ══ NAV ══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.2rem 4rem;
  background:rgba(14,12,10,.8);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--warm-line);
}
.nav-logo{
  display:flex;align-items:baseline;
  font-family:var(--logo);font-optical-sizing:auto;
  font-weight:500;font-size:1rem;letter-spacing:.03em;
  color:var(--text);cursor:default;user-select:none;text-transform:lowercase;
}
.logo-ma,.logo-vi{display:inline-block;}
.logo-ria,.logo-ctoria{
  display:inline-block;max-width:0;opacity:0;overflow:hidden;white-space:nowrap;
  transition:max-width .6s cubic-bezier(.4,0,.2,1),opacity .5s ease;
  font-family:var(--logo);font-weight:500;color:var(--text);
}
.logo-sep{display:inline-block;width:0;overflow:hidden;opacity:0;transition:width .4s ease .15s,opacity .3s ease .15s;}
.logo-baseline{
  font-family:var(--sans);font-weight:300;font-size:.5rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  margin-left:.75rem;align-self:center;white-space:nowrap;
  transition:opacity .1s ease;
}
nav:hover .logo-ria,nav:hover .logo-ctoria{max-width:8rem;opacity:1;}
nav:hover .logo-sep{width:.4em;opacity:1;}
nav:hover .logo-baseline{opacity:0;}

.nav-links{
  display:flex;gap:0;list-style:none;
  background:rgba(240,220,190,.04);
  border:1px solid var(--warm-line);
  border-radius:99px;padding:.25rem;
}
.nav-links a{
  text-decoration:none;color:var(--muted);
  font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;
  font-weight:400;padding:.4rem .95rem;border-radius:99px;
  transition:all .25s;white-space:nowrap;
}
.nav-links a:hover{color:var(--text);background:rgba(240,220,190,.07);}

/* ══ HERO ══ */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:7rem 4rem 5rem;text-align:center;
  position:relative;z-index:1;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(240,220,190,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(240,220,190,.025) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 65% 65% at 50% 50%,black 10%,transparent 100%);
  pointer-events:none;
}

.hero-logo{
  display:flex;align-items:baseline;justify-content:center;
  font-family:var(--logo);font-optical-sizing:auto;font-weight:500;
  font-size:clamp(4.5rem,11vw,17rem);
  color:var(--text);user-select:none;line-height:1;text-transform:lowercase;
  opacity:0;animation:heroIn .9s cubic-bezier(.2,0,.1,1) .15s forwards;
  cursor:default;position:relative;z-index:1;
}
.hl-ma,.hl-vi{display:inline-block;transition:color .45s ease;}
.hl-ria,.hl-ctoria{
  display:inline-block;max-width:0;opacity:0;overflow:hidden;white-space:nowrap;
  transition:max-width .75s cubic-bezier(.4,0,.2,1),opacity .6s ease,letter-spacing .65s ease;
  font-weight:500;color:var(--accent);
}
.hl-sep{display:inline-block;width:0;overflow:hidden;opacity:0;transition:width .4s ease .2s,opacity .3s ease .2s;}
.hero-logo:hover .hl-ria,.hero-logo:hover .hl-ctoria{max-width:55vw;opacity:1;letter-spacing:-.02em;}
.hero-logo:hover .hl-sep{width:.35em;opacity:1;}
.hero-logo:hover .hl-ma,.hero-logo:hover .hl-vi{color:var(--accent);}

/* glow suave detrás del logo al hover */
.hero-logo::after{
  content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:700px;height:220px;
  background:radial-gradient(ellipse,rgba(193,68,14,.1) 0%,rgba(139,94,60,.05) 40%,transparent 70%);
  pointer-events:none;z-index:-1;
  opacity:0;transition:opacity .5s;
}
.hero-logo:hover::after{opacity:1;}

.hero-sub{
  font-family:var(--sans);font-weight:300;font-size:1rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--muted);
  margin-top:1.1rem;
  opacity:0;animation:fadeUp .8s .7s forwards;
  position:relative;z-index:1;
}
.hero-desc{
  max-width:640px;font-size:.97rem;
  color:rgba(240,232,220,.55);
  line-height:1.75;margin-top:4.5rem;font-weight:300;
  opacity:0;animation:fadeUp .8s 1s forwards;
  position:relative;z-index:1;
}
.hero-desc p+p{margin-top:.9rem;}

.hero-ctas{
  display:flex;gap:.9rem;margin-top:2.8rem;flex-wrap:wrap;justify-content:center;
  opacity:0;animation:fadeUp .8s 1.25s forwards;position:relative;z-index:1;
}

/* Botón fuego — acento naranja */
.btn-fire{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 2rem;border-radius:99px;
  font-family:var(--sans);font-size:.7rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;border:none;
  background:var(--accent);color:#fff;
  box-shadow:0 8px 28px rgba(193,68,14,.3),0 0 0 0 rgba(193,68,14,.15);
  transition:background .25s,transform .25s,box-shadow .25s;
  animation:firePulse 3.5s ease-in-out 2s infinite;
}
.btn-fire:hover{background:var(--accent2);transform:translateY(-3px);box-shadow:0 18px 48px rgba(193,68,14,.45);}

/* Botón ghost — cobre sutil */
.btn-ghost{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 2rem;border-radius:99px;
  font-family:var(--sans);font-size:.7rem;font-weight:400;
  letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;
  background:rgba(240,220,190,.04);color:rgba(240,232,220,.7);
  border:1px solid rgba(240,220,190,.1);
  backdrop-filter:blur(8px);transition:all .25s;
}
.btn-ghost:hover{background:rgba(240,220,190,.08);transform:translateY(-2px);border-color:rgba(240,220,190,.18);color:var(--text);}

@keyframes firePulse{
  0%,100%{box-shadow:0 8px 28px rgba(193,68,14,.3),0 0 0 0 rgba(193,68,14,.15)}
  50%{box-shadow:0 8px 28px rgba(193,68,14,.3),0 0 0 13px rgba(193,68,14,0)}
}

.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  opacity:0;animation:fadeIn 1s 1.8s forwards;z-index:1;
}
.hero-scroll span{font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted2);}
.scroll-line{width:1px;height:36px;background:rgba(240,220,190,.07);position:relative;overflow:hidden;}
.scroll-line::after{
  content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;
  background:linear-gradient(transparent,var(--copper),transparent);
  animation:scrollAnim 1.8s ease-in-out infinite;
}
@keyframes scrollAnim{0%{top:-100%}100%{top:100%}}

/* ══ STRIP ══ */
.strip{
  position:relative;z-index:1;padding:.85rem 0;overflow:hidden;
  background:linear-gradient(90deg,rgba(139,94,60,.06),rgba(193,68,14,.04),rgba(139,94,60,.06));
  border-top:1px solid var(--warm-line);border-bottom:1px solid var(--warm-line);
}
.strip-inner{display:flex;animation:marquee 32s linear infinite;white-space:nowrap;}
.strip-inner:hover{animation-play-state:paused;}
.strip-text{font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted2);padding:0 2rem;flex-shrink:0;}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ SECCIONES ══ */
section{padding:8rem 4rem;position:relative;z-index:1;}

.sec-header{display:grid;grid-template-columns:auto 1fr;align-items:baseline;gap:1.5rem;margin-bottom:4rem;}
.sec-num{font-family:var(--serif);font-size:.85rem;font-style:italic;color:var(--copper);}
.sec-title{
  font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.6rem);
  font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--text);
}
.sec-line{width:100%;height:1px;background:var(--warm-line);margin-top:.5rem;}

/* ══ BIO ══ */
.bio-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.bio-hola{font-family:var(--serif);font-size:1.6rem;font-style:italic;color:var(--text);margin-bottom:.5rem;}
.bio-text{font-size:.97rem;line-height:1.85;color:rgba(240,232,220,.65);}
.bio-text p+p{margin-top:1.2rem;}
.bio-text i{font-style:italic;color:rgba(240,232,220,.88);}
.bio-text strong {
  font-weight: 500;
  color: var(--text);
}
.bio-aside{
  border-left:2px solid var(--copper);
  padding-left:2rem;display:flex;flex-direction:column;gap:2rem;
}
/* La cita en cobre, no en naranja — más sofisticado */
.bio-aside blockquote{
  font-family:var(--serif);color:var(--copper-light);
  font-size:1.5rem;font-style:italic;line-height:1.55;
}

.tags-label{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);margin-bottom:.65rem;}
.tags-group+.tags-group{margin-top:1.2rem;}
.tags{display:flex;flex-wrap:wrap;gap:.4rem;}
.tag{
  font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.35rem .8rem;border-radius:99px;
  border:1px solid rgba(240,220,190,.09);
  color:var(--muted);background:rgba(240,220,190,.03);
  transition:all .25s;cursor:default;
}
.tag:hover{border-color:var(--copper);color:var(--copper-light);background:rgba(139,94,60,.1);}

/* ══ SERVICIOS ══ */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;}
.svc-card{
  padding:2.8rem;border:1px solid var(--warm-line);
  background:var(--bg2);position:relative;overflow:hidden;
  transition:background .3s,border-color .3s,transform .4s cubic-bezier(.2,0,.1,1),box-shadow .4s;
}
.svc-card:nth-child(1){border-radius:22px 0 0 0;}
.svc-card:nth-child(2){border-radius:0 22px 0 0;}
.svc-card:nth-child(3){border-radius:0 0 0 22px;}
.svc-card:nth-child(4){border-radius:0 0 22px 0;}

/* Línea lateral en cobre */
.svc-card::before{
  content:'';position:absolute;top:0;left:0;width:2px;height:0;
  background:linear-gradient(to bottom,var(--accent),var(--copper));
  transition:height .4s ease;
}
/* Glow interno cálido */
.svc-card::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 10% 90%,rgba(139,94,60,.08) 0%,transparent 55%);
  opacity:0;transition:opacity .4s;
}
.svc-card:hover::before{height:100%;}
.svc-card:hover::after{opacity:1;}
.svc-card:hover{
  background:rgba(240,220,190,.03);
  border-color:rgba(139,94,60,.22);
  transform:translateY(-4px);
  box-shadow:0 24px 60px rgba(0,0,0,.45),0 0 30px rgba(139,94,60,.06);
  z-index:1;
}
/* Ícono en cobre */
.svc-icon{color:var(--copper);opacity:.7;margin-bottom:1.2rem;display:block;transition:opacity .3s,transform .3s,color .3s;}
.svc-card:hover .svc-icon{opacity:1;transform:scale(1.08);color:var(--accent);}
.svc-name{font-family:var(--serif);font-size:1.1rem;font-weight:700;margin-bottom:.7rem;color:var(--text);}
.svc-desc{font-size:.87rem;color:var(--muted);line-height:1.75;}

/* ══ PRECIOS ══ */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:start;}
.price-card{
  background:var(--bg2);border:1px solid var(--warm-line);
  border-radius:22px;padding:2.5rem;
  display:flex;flex-direction:column;gap:1.2rem;
  position:relative;overflow:hidden;
  transition:transform .4s cubic-bezier(.2,0,.1,1),box-shadow .4s,border-color .3s;
}
.price-card:hover{
  transform:translateY(-7px);
  border-color:rgba(139,94,60,.25);
  box-shadow:0 40px 90px rgba(0,0,0,.5),0 0 50px rgba(139,94,60,.06);
}
/* Featured: gradiente cobre-naranja, no solo naranja */
.price-card.featured{
  background:linear-gradient(148deg,rgba(193,68,14,.14) 0%,rgba(139,94,60,.12) 40%,rgba(14,12,10,.9) 100%);
  border-color:rgba(139,94,60,.35);
  transform:translateY(-10px);
  box-shadow:0 40px 90px rgba(0,0,0,.5),0 0 70px rgba(139,94,60,.1);
}
.price-card.featured:hover{transform:translateY(-16px);}

/* Shine top: gradiente cobre */
.price-card.featured::before{
  content:'';position:absolute;top:0;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(193,68,14,.6),rgba(139,94,60,.8),transparent);
}
.price-card.featured::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(139,94,60,.09) 0%,transparent 60%);
  pointer-events:none;
}

.price-badge{
  position:absolute;top:-1px;right:2rem;
  background:linear-gradient(90deg,var(--accent),var(--copper));
  color:#fff;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.28rem .85rem;border-radius:0 0 8px 8px;
  display:flex;align-items:center;gap:.4rem;
}
.price-badge::before{content:'';width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.6);animation:badgePulse 1.5s ease-in-out infinite;}
@keyframes badgePulse{0%,100%{opacity:1}50%{opacity:.25}}

.price-plan{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);position:relative;z-index:1;}
.price-card.featured .price-plan{color:rgba(240,220,190,.5);}

/* Precio en cobre en las cards laterales, naranja en la featured */
.price-amt{font-family:var(--serif);font-size:2.2rem;font-weight:700;line-height:1;color:var(--copper-light);position:relative;z-index:1;}
.price-card.featured .price-amt{color:var(--accent);}

.price-period{font-size:.72rem;color:var(--muted);margin-top:.2rem;position:relative;z-index:1;}
.price-card.featured .price-period{color:rgba(240,220,190,.38);}

.price-desc{font-size:.84rem;color:var(--muted);line-height:1.65;font-style:italic;position:relative;z-index:1;}
.price-card.featured .price-desc{color:rgba(240,220,190,.42);}

.price-div{height:1px;background:var(--warm-line);position:relative;z-index:1;}
.price-card.featured .price-div{background:rgba(139,94,60,.18);}

.price-feats{list-style:none;display:flex;flex-direction:column;flex:1;position:relative;z-index:1;}
.price-feats li{display:flex;flex-direction:column;gap:.12rem;border-bottom:1px solid var(--warm-line);padding:.8rem 0;}
.price-card.featured .price-feats li{border-bottom-color:rgba(139,94,60,.13);}
.price-feats li:last-child{border-bottom:none;}
.ft{font-weight:500;font-size:.78rem;color:var(--text);}
.fd{font-size:.73rem;color:var(--muted);line-height:1.45;}

.price-btn{
  display:block;text-align:center;padding:.9rem;border-radius:12px;
  font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;font-weight:500;
  border:1px solid rgba(240,220,190,.09);color:var(--muted);
  background:rgba(240,220,190,.03);
  transition:all .3s;position:relative;z-index:1;cursor:pointer;font-family:var(--sans);
}
.price-btn:hover{background:var(--copper);color:#fff;border-color:var(--copper);transform:translateY(-2px);box-shadow:0 10px 28px rgba(139,94,60,.3);}
.price-card.featured .price-btn{border-color:rgba(193,68,14,.45);color:var(--accent);}
.price-card.featured .price-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 10px 28px rgba(193,68,14,.35);}

/* ══ CONTACTO ══ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;}

.contact-quote{
  font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2.2rem);
  line-height:1.45;font-style:italic;color:var(--text);margin-bottom:3rem;
}
.contact-quote span{color:var(--copper-light);}

.c-links{display:flex;flex-direction:column;}
.c-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 0;border-bottom:1px solid var(--warm-line);
  text-decoration:none;position:relative;overflow:hidden;
}
.c-row::after{
  content:'';position:absolute;bottom:0;left:0;
  height:1px;width:0;
  background:linear-gradient(90deg,var(--accent),var(--copper));
  transition:width .45s ease;
}
.c-row:hover::after{width:100%;}
.c-row-meta{display:flex;flex-direction:column;gap:.2rem;}
.c-label{font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted2);}
.c-val{font-size:.92rem;color:rgba(240,232,220,.65);transition:color .3s;}
.c-row:hover .c-val{color:var(--text);}
.c-arrow{color:var(--muted2);transition:all .3s;font-size:1rem;}
.c-row:hover .c-arrow{transform:translate(3px,-3px);color:var(--copper-light);}

.contact-form{
  background:rgba(240,220,190,.03);
  border:1px solid var(--warm-line);
  border-radius:22px;padding:2.8rem;
  backdrop-filter:blur(12px);position:relative;overflow:hidden;
}
.contact-form::before{
  content:'';position:absolute;top:-80px;right:-80px;
  width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(139,94,60,.09) 0%,transparent 70%);
  pointer-events:none;
}
.fg{display:flex;flex-direction:column;gap:.4rem;position:relative;z-index:1;}
.fg+.fg{margin-top:1rem;}
.flabel{font-size:.54rem;letter-spacing:.18em;text-transform:uppercase;color:var(--copper);}
.finput,.ftextarea{
  background:rgba(240,220,190,.04);
  border:1px solid rgba(240,220,190,.08);
  border-radius:10px;padding:.7rem 1rem;
  font-family:var(--sans);font-size:.9rem;color:var(--text);
  outline:none;transition:all .3s;width:100%;
}
.finput:focus,.ftextarea:focus{
  border-color:rgba(139,94,60,.5);
  background:rgba(139,94,60,.04);
  box-shadow:0 0 0 3px rgba(139,94,60,.1);
}
.ftextarea{resize:none;height:80px;}
.fbtn{
  align-self:flex-start;margin-top:1.2rem;
  background:var(--accent);color:#fff;border:none;
  padding:.85rem 2.2rem;border-radius:99px;
  font-family:var(--sans);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;
  cursor:pointer;font-weight:500;
  transition:background .25s,transform .25s,box-shadow .25s;
  position:relative;z-index:1;
}
.fbtn:hover{background:var(--accent2);transform:translateY(-3px);box-shadow:0 14px 38px rgba(193,68,14,.38);}

/* ══ FOOTER ══ */
footer{
  position:relative;z-index:1;padding:1.8rem 4rem;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(0,0,0,.35);backdrop-filter:blur(10px);
  border-top:1px solid var(--warm-line);
}
.flogo{font-family:var(--logo);font-optical-sizing:auto;font-weight:500;font-size:.95rem;letter-spacing:.06em;color:var(--text);text-transform:lowercase;}
.fcopy{font-size:.64rem;letter-spacing:.1em;color:var(--muted2);}

/* ══ ANIMACIONES ══ */
@keyframes heroIn{from{opacity:0;transform:translateY(28px) skewY(.8deg)}to{opacity:1;transform:translateY(0) skewY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .75s cubic-bezier(.2,0,.1,1),transform .75s cubic-bezier(.2,0,.1,1);}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ══ RESPONSIVE ══ */
@media(max-width:860px){
  nav{padding:1rem 1.5rem;flex-direction:column;align-items:center;gap:.75rem;}
  .nav-links{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;width:100%;justify-content:center;padding:.15rem;}
  .nav-links::-webkit-scrollbar{display:none;}
  .nav-links li{flex-shrink:0;}
  section{padding:5rem 1.5rem;}
  .hero{padding:8rem 1.5rem 4rem;}
  .hero-logo{font-size:12vw;}
.hero-logo.expand .hl-ria,.hero-logo.expand .hl-ctoria{max-width:40vw;opacity:1;letter-spacing:-.03em;}
.hero-logo.expand .hl-sep{width:.35em;opacity:1;}
.hero-logo.expand .hl-ma,.hero-logo.expand .hl-vi{color:var(--accent);}
  .hero-desc{font-size:.9rem;padding:0 .5rem;}
  .bio-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem;}
  .svc-grid{grid-template-columns:1fr;}
  .svc-card:nth-child(1){border-radius:22px 22px 0 0;}
  .svc-card:nth-child(2){border-radius:0;}
  .svc-card:nth-child(3){border-radius:0;}
  .svc-card:nth-child(4){border-radius:0 0 22px 22px;}
  .price-grid{grid-template-columns:1fr;}
  .price-card.featured{transform:none;}
  footer{padding:1.5rem;flex-direction:column;gap:.4rem;text-align:center;}
  .blob {display: none;}
  #pcanvas {display: none;} 
}
