/* ============================================================
   modelo-7 · Diseño "Albri Lashes" (re-skin genérico)
   Tokens + componentes (landing + link-in-bio /limpio).
   Los acentos (--accent/--accent-2/--accent-ink) se sobrescriben
   por cliente desde el head con color_principal_1/2/3.
   ============================================================ */

:root{
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Jost', system-ui, sans-serif;
  --r-sm: 10px; --r-md: 16px; --r-lg: 24px; --r-xl: 34px; --r-pill: 999px;
  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 56px);
  --wa: #25D366;
  --ease: cubic-bezier(.22,.7,.27,1);

  --bg:        oklch(0.976 0.008 55);
  --bg-2:      oklch(0.955 0.013 45);
  --surface:   #ffffff;
  --surface-2: oklch(0.972 0.010 45);
  --ink:       oklch(0.33 0.022 25);
  --ink-soft:  oklch(0.45 0.020 25);
  --muted:     oklch(0.57 0.016 30);
  --accent:    oklch(0.66 0.078 18);
  --accent-2:  oklch(0.78 0.060 22);
  --accent-ink:oklch(0.46 0.085 18);
  --on-accent: #fff;
  --gold:      oklch(0.74 0.072 76);
  --line:      oklch(0.90 0.012 40);
  --deep:      oklch(0.30 0.026 20);
  --deep-2:    oklch(0.25 0.024 20);
  --on-deep:   oklch(0.95 0.012 50);
  --deep-muted:oklch(0.78 0.018 35);
  --shadow-sm: 0 1px 2px rgba(60,30,35,.05), 0 2px 8px -4px rgba(60,30,35,.10);
  --shadow-md: 0 10px 30px -12px rgba(70,35,40,.22);
  --shadow-lg: 0 30px 70px -28px rgba(70,35,40,.34);
  --hero-overlay: linear-gradient(180deg, rgba(40,22,26,.30), rgba(40,22,26,.12) 35%, rgba(40,22,26,.55));
  color-scheme: light;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.65;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.08;letter-spacing:-0.01em;color:var(--ink)}

.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);font-weight:500;font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--accent-ink)}
.kicker::before,.kicker.center::after{content:"";width:30px;height:1px;background:var(--accent);opacity:.6}
.kicker.center{justify-content:center}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--font-body);font-weight:500;font-size:.86rem;letter-spacing:.12em;text-transform:uppercase;padding:15px 30px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer;transition:transform .25s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-md)}
.btn-primary:hover{background:var(--accent-ink);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent-ink)}
.btn-ghost-light{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn-ghost-light:hover{background:rgba(255,255,255,.22)}
.btn .ico{width:17px;height:17px;flex:none}
.btn-block{width:100%}

/* floating WhatsApp */
.fab{position:fixed;right:18px;bottom:18px;z-index:90;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-lg);transition:transform .3s var(--ease)}
.fab:hover{transform:translateY(-3px) scale(1.04)}
.fab svg{width:30px;height:30px}
.fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--accent);animation:fabpulse 2.6s var(--ease) infinite;z-index:-1}
@keyframes fabpulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important}
  .reveal{opacity:1;transform:none;transition:none}
  /* Sin animación, los elementos animados deben quedar VISIBLES (no opacity:0) */
  .reveal2,.bio .reveal2,.bio .tabpanel,.bslide .bs-inner > *{opacity:1 !important;transform:none !important}
  .cover img,.bio .cover img{animation:none !important;transform:none !important}
}

/* ============ HEADER ============ */
header.bar{position:fixed;top:0;left:0;right:0;z-index:70;transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);padding:22px 0}
header.bar.scrolled{background:color-mix(in oklab,var(--surface) 90%,transparent);backdrop-filter:saturate(1.3) blur(16px);box-shadow:var(--shadow-sm);padding:12px 0}
.bar .wrap{display:flex;align-items:center;justify-content:space-between}
.brand{font-family:var(--font-display);font-weight:600;font-size:1.5rem;letter-spacing:.02em;line-height:1;color:#fff;display:flex;flex-direction:column;transition:color .4s var(--ease)}
.brand img{height:40px;width:auto;max-width:170px;object-fit:contain}
.brand span{font-family:var(--font-body);font-weight:400;font-size:.56rem;letter-spacing:.42em;text-transform:uppercase;margin-top:3px;opacity:.85}
.bar.scrolled .brand{color:var(--ink)}
.bar nav{display:none;align-items:center;gap:34px}
.bar nav a{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;opacity:.86;transition:opacity .2s,color .4s var(--ease);font-weight:400}
.bar.scrolled nav a{color:var(--ink)}
.bar nav a:hover{opacity:1}
.bar .bar-cta{display:none}
.bar .bar-cta .btn{padding:11px 22px;font-size:.72rem}
.bar.scrolled .bar-cta .btn-ghost-light{background:var(--accent);color:var(--on-accent);border-color:transparent}
.menu-toggle{display:inline-flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.menu-toggle span{width:24px;height:1.5px;background:#fff;transition:background .4s var(--ease)}
.bar.scrolled .menu-toggle span{background:var(--ink)}
.drawer{position:fixed;inset:0;z-index:75;background:var(--bg);transform:translateX(100%);transition:transform .45s var(--ease);display:flex;flex-direction:column;padding:26px var(--gut)}
.drawer.open{transform:none}
.drawer .dr-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.drawer .dr-top .brand{color:var(--ink)}
.drawer .dr-x{background:none;border:0;font-size:1.8rem;color:var(--ink);cursor:pointer;line-height:1}
.drawer nav{display:flex;flex-direction:column;gap:4px}
.drawer nav a{font-family:var(--font-display);font-size:2rem;color:var(--ink);padding:10px 0;border-bottom:1px solid var(--line)}
.drawer .dr-cta{margin-top:auto;display:flex;flex-direction:column;gap:12px}

/* ============ HERO ============ */
.hero{position:relative;height:100svh;min-height:580px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s var(--ease)}
.hero-bg .slide.active{opacity:1}
.hero-bg .slide img{width:100%;height:100%;object-fit:cover}
.hero-bg .slide.active img{animation:kenburns 9s var(--ease) forwards}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.13)}}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:var(--hero-overlay)}
.hero .wrap{position:relative;z-index:2;color:#fff}
.hero .kicker{color:rgba(255,255,255,.9)}
.hero .kicker::before{background:rgba(255,255,255,.7)}
.hero h1{color:#fff;font-size:clamp(3rem,11vw,7rem);font-weight:400;line-height:.98;margin:22px 0 0;max-width:14ch;letter-spacing:-0.015em}
.hero h1 em{font-style:italic;color:var(--accent-2)}
.hero p.lead{font-size:clamp(1rem,2.4vw,1.2rem);max-width:42ch;margin-top:24px;color:rgba(255,255,255,.9);font-weight:300}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.scroll-hint{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;color:#fff;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;opacity:.8}
.scroll-hint i{width:1px;height:40px;background:linear-gradient(#fff,transparent);animation:scrolldash 2s var(--ease) infinite}
@keyframes scrolldash{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============ BANNER SLIDER ============ */
.bslider{position:relative;height:clamp(420px,68vh,660px);overflow:hidden;background:var(--deep)}
.bslide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s var(--ease);display:flex;align-items:center;background-size:cover;background-position:center}
.bslide.active{opacity:1}
.bslide.active .bs-inner > *{animation:bsrise .9s var(--ease) both}
.bslide::after{content:"";position:absolute;inset:0;background:var(--hero-overlay)}
@keyframes bsrise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.bs-inner{position:relative;z-index:2;color:#fff;max-width:620px;width:100%;margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.bs-inner .kicker{color:rgba(255,255,255,.92)}
.bs-inner .kicker::before{background:rgba(255,255,255,.7)}
.bs-inner h2{color:#fff;font-size:clamp(2rem,6.4vw,3.8rem);font-weight:400;line-height:1.02;margin:16px 0 14px}
.bs-inner h2 em{font-style:italic;color:var(--accent-2)}
.bs-inner p{color:rgba(255,255,255,.9);font-weight:300;max-width:46ch;margin-bottom:26px;font-size:1.05rem}
.bdots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:9px;z-index:3}
.bdot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45);border:0;cursor:pointer;transition:.3s var(--ease);padding:0}
.bdot.active{background:var(--accent);width:28px;border-radius:5px}
.barrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.16);color:#fff;border:0;font-size:1.5rem;cursor:pointer;z-index:3;backdrop-filter:blur(4px);transition:background .3s var(--ease)}
.barrow:hover{background:rgba(255,255,255,.3)}
.barrow.prev{left:16px}.barrow.next{right:16px}
@media(max-width:680px){.barrow{display:none}}

/* ============ MARQUEE ============ */
.marquee{background:var(--deep);color:var(--on-deep);overflow:hidden;padding:18px 0;white-space:nowrap}
.marquee .track{display:inline-flex;gap:0;animation:scrollx 28s linear infinite;will-change:transform}
.marquee span{font-family:var(--font-display);font-style:italic;font-size:1.5rem;padding:0 26px;display:inline-flex;align-items:center;gap:52px}
.marquee span::after{content:"✦";font-style:normal;font-size:.7rem;color:var(--accent-2);transform:translateY(-2px)}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ SECTION SHELL ============ */
.section{padding:clamp(64px,11vw,128px) 0}
.sec-head{max-width:600px;margin-bottom:54px}
.sec-head.center{margin:0 auto 54px;text-align:center}
.sec-head h2{font-size:clamp(2.2rem,6vw,3.8rem);font-weight:400;margin:18px 0 14px;letter-spacing:-0.01em}
.sec-head h2 em{font-style:italic;color:var(--accent-ink)}
.sec-head p{color:var(--muted);font-size:1.06rem;font-weight:300}

/* ============ ABOUT ============ */
.about{background:var(--bg-2)}
.about-grid{display:grid;grid-template-columns:1fr;gap:clamp(34px,6vw,72px);align-items:center}
.about-media{position:relative;max-width:420px;margin:0 auto}
.about-media .frame{border-radius:999px 999px 18px 18px;overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg);background:var(--surface)}
.about-media .frame img{width:100%;height:100%;object-fit:cover}
.about-media.is-logo .frame img{object-fit:contain;background:var(--surface);padding:14%}
.about-media .deco{position:absolute;inset:-14px;border:1px solid var(--accent);border-radius:999px 999px 30px 30px;z-index:-1;opacity:.4}
.about-body h2{font-size:clamp(2rem,5.5vw,3.4rem);font-weight:400;margin:16px 0 20px}
.about-body p{color:var(--ink-soft);margin-bottom:18px;font-weight:300;font-size:1.06rem}
.about-body .btn{margin-top:12px}
.about-body ul,.about-body ol{margin:8px 0 18px;padding-left:1.3em;color:var(--ink-soft);font-weight:300}
.about-body li{margin-bottom:7px}

/* ============ SERVICES ============ */
.svc-grid{display:grid;grid-template-columns:1fr;gap:24px}
.svc{position:relative;background:var(--surface);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.svc:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.svc .pic{aspect-ratio:4/5;overflow:hidden;background:var(--bg-2)}
.svc .pic img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svc:hover .pic img{transform:scale(1.07)}
.svc .body{padding:26px 26px 30px}
.svc .num{font-family:var(--font-display);font-style:italic;color:var(--accent-ink);font-size:1.1rem}
.svc h3{font-size:1.7rem;font-weight:500;margin:6px 0 12px}
.svc p{color:var(--muted);font-size:.98rem;font-weight:300;margin-bottom:20px}
.svc .solicitar{display:inline-flex;align-items:center;gap:10px;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-ink);font-weight:500}
.svc .solicitar svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.svc:hover .solicitar svg{transform:translateX(5px)}

/* ============ WORKS / IG GALLERY ============ */
.works{background:var(--bg-2)}
.ig-head{display:flex;flex-wrap:wrap;gap:18px;align-items:flex-end;justify-content:space-between;margin-bottom:44px}
.ig-head .handle{display:inline-flex;align-items:center;gap:10px;color:var(--accent-ink);font-size:.9rem;letter-spacing:.1em}
.ig-head .handle svg{width:20px;height:20px}
.gal{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.igcell{position:relative;overflow:hidden;border-radius:var(--r-md);aspect-ratio:1;cursor:pointer;background:var(--surface)}
.igcell img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.igcell:hover img{transform:scale(1.1)}
.igcell .ov{position:absolute;inset:0;background:linear-gradient(rgba(40,22,26,0),rgba(40,22,26,.5));opacity:0;transition:opacity .4s var(--ease);display:grid;place-items:center}
.igcell:hover .ov{opacity:1}
.igcell .ov svg{width:34px;height:34px;color:#fff}

/* ============ AGENDAR (deep CTA) ============ */
.agendar{background:var(--deep);color:var(--on-deep);text-align:center}
.agendar .kicker{color:var(--accent-2)}
.agendar .kicker::before,.agendar .kicker.center::after{background:var(--accent-2)}
.agendar h2{color:var(--on-deep);font-size:clamp(2.4rem,7vw,4.6rem);font-weight:400;margin:18px 0 16px}
.agendar h2 em{font-style:italic;color:var(--accent-2)}
.agendar p{color:var(--deep-muted);max-width:48ch;margin:0 auto 30px;font-weight:300;font-size:1.08rem}
.agendar .pick{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:30px}
.agendar .pick button{background:transparent;border:1px solid rgba(255,255,255,.28);color:var(--on-deep);padding:11px 20px;border-radius:var(--r-pill);font-size:.78rem;letter-spacing:.08em;cursor:pointer;transition:all .3s var(--ease);font-weight:300;font-family:inherit}
.agendar .pick button:hover,.agendar .pick button.active{background:var(--accent);border-color:transparent;color:var(--on-accent)}
.agendar .contact-row{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;margin-top:38px;color:var(--deep-muted);font-size:.92rem}
.agendar .contact-row a{display:inline-flex;align-items:center;gap:9px;color:var(--on-deep);letter-spacing:.04em}
.agendar .contact-row svg{width:16px;height:16px;color:var(--accent-2)}

/* ============ UBICACIÓN ============ */
.loc-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:stretch}
.loc-map{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);min-height:320px;border:1px solid var(--line)}
.loc-map iframe{width:100%;height:100%;min-height:320px;border:0;display:block;filter:grayscale(.3)}
.loc-info{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;display:flex;flex-direction:column;gap:22px;box-shadow:var(--shadow-sm)}
.loc-info h3{font-size:1.9rem;font-weight:500}
.loc-line{display:flex;gap:14px;align-items:flex-start}
.loc-line .li{width:42px;height:42px;border-radius:12px;background:var(--bg-2);display:grid;place-items:center;flex:none}
.loc-line .li svg{width:20px;height:20px;color:var(--accent-ink)}
.loc-line b{display:block;font-weight:500;font-size:1rem;color:var(--ink)}
.loc-line span{color:var(--muted);font-size:.94rem;font-weight:300}
.loc-qr{display:flex;align-items:center;gap:18px;border-top:1px solid var(--line);padding-top:22px;margin-top:auto}
.loc-qr img{width:90px;height:90px;border-radius:12px;background:#fff;padding:6px;border:1px solid var(--line)}
.loc-qr .qt b{display:block;font-weight:500;color:var(--ink)}
.loc-qr .qt span{color:var(--muted);font-size:.88rem;font-weight:300;display:block;margin-bottom:8px}
.loc-qr .qt a{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink);font-weight:500}

/* ============ CONTACT FORM ============ */
.cform{max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.cform .two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform input,.cform select,.cform textarea{width:100%;font-family:inherit;font-size:1rem;font-weight:300;color:var(--ink);padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);outline:none;transition:border-color .2s}
.cform input:focus,.cform select:focus,.cform textarea:focus{border-color:var(--accent)}
.cform textarea{min-height:120px;resize:vertical}

/* ============ FOOTER ============ */
footer.site{background:var(--deep-2);color:var(--deep-muted);padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:34px}
footer.site .brand{color:var(--on-deep);font-size:1.7rem}
footer.site .brand img{height:42px}
footer.site .ftxt{margin-top:14px;font-weight:300;font-size:.94rem;max-width:34ch;line-height:1.8}
footer.site h4{color:var(--on-deep);font-family:var(--font-body);font-weight:500;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px}
footer.site ul{list-style:none;display:flex;flex-direction:column;gap:11px}
footer.site ul a{font-weight:300;font-size:.96rem;opacity:.9;display:inline-flex;align-items:center;gap:9px}
footer.site ul a:hover{opacity:1;color:var(--accent-2)}
footer.site ul svg{width:15px;height:15px;color:var(--accent-2);flex:none}
.foot-social{display:flex;gap:12px;margin-top:20px}
.foot-social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;transition:all .3s var(--ease)}
.foot-social a:hover{background:var(--accent);border-color:transparent}
.foot-social svg{width:18px;height:18px;color:var(--on-deep)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:44px;padding-top:22px;text-align:center;font-size:.8rem;font-weight:300;letter-spacing:.04em}

/* ============ AGENDA / CALENDARIO ============ */
/* Wrapper que añade index-modelos para el bloque calendario */
.contact-area{padding:clamp(64px,11vw,118px) 0;background:var(--bg-2)}
.contact-area .container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.contact-area .row.contact-forms{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
.contact-area .title-default-left{font-family:var(--font-display);font-weight:400;font-size:clamp(2rem,5.5vw,3.4rem);color:var(--ink);line-height:1.1;letter-spacing:-0.01em}
@media(min-width:900px){.contact-area .row.contact-forms{grid-template-columns:.82fr 1.18fr}}
/* Widget */
.agenda-cal{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-md)}
.agenda-cal .service-name{font-family:var(--font-display);font-style:italic;color:var(--accent-ink);font-size:1.35rem;margin-bottom:16px}
.agenda-cal .ac-label{display:flex;align-items:center;gap:10px;font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin:0 0 13px}
.agenda-cal .ac-label::after{content:"";height:1px;background:var(--line);flex:1}
.agenda-cal .days{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:24px}
.agenda-cal .day{padding:10px 17px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--bg-2);color:var(--ink-soft);font-size:.84rem;cursor:pointer;transition:all .25s var(--ease);font-weight:400;letter-spacing:.02em}
.agenda-cal .day:hover{border-color:var(--accent);color:var(--accent-ink)}
.agenda-cal .day.active{background:var(--accent);color:var(--on-accent);border-color:transparent}
.agenda-cal .slots{display:flex;flex-wrap:wrap;gap:10px;min-height:46px}
.agenda-cal .slot{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:var(--r-pill);border:1px solid var(--accent);background:var(--surface);color:var(--accent-ink);font-size:.86rem;text-decoration:none;transition:all .25s var(--ease)}
.agenda-cal .slot:hover{background:var(--accent);color:var(--on-accent);border-color:transparent;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.agenda-cal .slot svg{width:15px;height:15px}
.agenda-cal .ac-empty{color:var(--muted);font-size:.92rem;font-weight:300}

/* ============ LIGHTBOX ============ */
.lb{position:fixed;inset:0;background:rgba(25,14,17,.94);z-index:120;display:none;align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:var(--shadow-lg)}
.lb .x{position:absolute;top:20px;right:20px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;border:0;font-size:1.5rem;cursor:pointer}
.lb .nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;border:0;font-size:1.6rem;cursor:pointer}
.lb .prev{left:18px}.lb .next{right:18px}

@media(min-width:720px){
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .gal{grid-template-columns:repeat(4,1fr)}
  .foot-grid{grid-template-columns:1.6fr 1fr 1fr}
  .loc-grid{grid-template-columns:1.25fr .75fr}
}
@media(min-width:900px){
  .bar nav{display:flex}.bar .bar-cta{display:inline-flex}.menu-toggle{display:none}
  .about-grid{grid-template-columns:.9fr 1.1fr}
  .about-media{margin:0}
}

/* ============================================================
   LINK-IN-BIO  (vista /limpio) — scope .bio
   ============================================================ */
body.bio-page{display:flex;justify-content:center;align-items:flex-start;background:radial-gradient(120% 80% at 50% -10%, color-mix(in oklab,var(--accent) 26%,transparent), transparent 60%),var(--bg);padding:0 0 40px;min-height:100svh}
.bio{width:100%;max-width:480px;position:relative}
.bio .cover{position:relative;height:230px;overflow:hidden;border-radius:0 0 var(--r-xl) var(--r-xl)}
.bio .cover img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);animation:coverdrift 14s var(--ease) infinite alternate}
@keyframes coverdrift{from{transform:scale(1.05) translateY(0)}to{transform:scale(1.14) translateY(-10px)}}
.bio .cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,22,26,.18),color-mix(in oklab,var(--bg) 92%,transparent))}
.bio .avatar{position:relative;width:118px;height:118px;margin:-66px auto 0;z-index:2;border-radius:50%;background:var(--surface);box-shadow:var(--shadow-lg);display:grid;place-items:center;padding:10px;border:1px solid var(--line)}
.bio .avatar img{width:100%;height:100%;object-fit:contain}
.bio .head{text-align:center;padding:16px var(--gut) 6px}
.bio .head h1{font-size:2.5rem;font-weight:500;line-height:1}
.bio .head .tag{color:var(--accent-ink);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;margin-top:8px}
.bio .head .meta{color:var(--muted);font-size:.86rem;font-weight:300;margin-top:10px}
.bio .socials{display:flex;justify-content:center;gap:12px;margin:18px 0 8px}
.bio .socials a{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);color:var(--accent-ink);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease)}
.bio .socials a:hover{transform:translateY(-3px);background:var(--accent);color:var(--on-accent);border-color:transparent}
.bio .socials svg{width:22px;height:22px}
.bio .links{display:flex;flex-direction:column;gap:13px;padding:18px var(--gut) 8px}
.bio .lk{position:relative;display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:15px 22px;box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.bio .lk:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.bio .lk::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:color-mix(in oklab,var(--accent) 12%,transparent);transition:width .35s var(--ease);z-index:0}
.bio .lk:hover::before{width:100%}
.bio .lk .ic,.bio .lk .txt,.bio .lk .arw{position:relative;z-index:1}
.bio .lk .ic{width:38px;height:38px;border-radius:50%;background:var(--bg-2);display:grid;place-items:center;flex:none;color:var(--accent-ink)}
.bio .lk .ic svg{width:19px;height:19px}
.bio .lk .txt{flex:1;font-weight:400;font-size:1rem;letter-spacing:.01em}
.bio .lk .txt small{display:block;font-weight:300;font-size:.76rem;color:var(--muted);letter-spacing:.02em}
.bio .lk .arw{color:var(--muted);transition:transform .3s var(--ease)}
.bio .lk:hover .arw{transform:translateX(4px);color:var(--accent-ink)}
.bio .lk .arw svg{width:18px;height:18px}
.bio .lk.primary{background:var(--accent);border-color:transparent;color:var(--on-accent)}
.bio .lk.primary .ic{background:rgba(255,255,255,.18);color:var(--on-accent)}
.bio .lk.primary .txt small{color:color-mix(in oklab,var(--on-accent) 75%,transparent)}
.bio .lk.primary .arw{color:color-mix(in oklab,var(--on-accent) 80%,transparent)}
.bio .lk.primary::before{background:rgba(0,0,0,.08)}
.bio .blk{padding:22px var(--gut) 4px}
.bio .blk-h{display:flex;align-items:center;gap:12px;margin-bottom:14px;color:var(--muted);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase}
.bio .blk-h::before,.bio .blk-h::after{content:"";height:1px;background:var(--line);flex:1}
.bio .svcs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.bio .svcs a{display:block;border-radius:var(--r-md);overflow:hidden;position:relative;aspect-ratio:3/4;box-shadow:var(--shadow-sm)}
.bio .svcs a img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.bio .svcs a:hover img{transform:scale(1.08)}
.bio .svcs a span{position:absolute;left:0;right:0;bottom:0;padding:18px 8px 8px;font-size:.66rem;letter-spacing:.04em;color:#fff;background:linear-gradient(transparent,rgba(40,22,26,.78));text-align:center;font-weight:400}
/* tabs del link-in-bio */
.bio .tabs{display:flex;gap:8px;justify-content:center;padding:10px var(--gut) 2px}
.bio .tabbtn{flex:1;max-width:150px;padding:11px 8px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .25s var(--ease);font-family:var(--font-body);font-weight:400;box-shadow:var(--shadow-sm)}
.bio .tabbtn:hover{border-color:var(--accent);color:var(--accent-ink)}
.bio .tabbtn.active{background:var(--accent);color:var(--on-accent);border-color:transparent}
.bio .tabpanel{display:none}
.bio .tabpanel.active{display:block;animation:rise .55s var(--ease)}
.bio .contact-list{display:flex;flex-direction:column;gap:13px;padding:18px var(--gut) 8px}
.bio .qr-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px;margin:6px var(--gut) 0;box-shadow:var(--shadow-sm)}
.bio .qr-card img{width:84px;height:84px;border-radius:12px;background:#fff;padding:6px;border:1px solid var(--line);flex:none}
.bio .qr-card b{display:block;font-weight:500;color:var(--ink)}
.bio .qr-card span{display:block;color:var(--muted);font-size:.82rem;font-weight:300;margin-bottom:6px}
.bio .qr-card a{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink);font-weight:500}
.bio .biofoot{text-align:center;padding:30px var(--gut) 0;color:var(--muted);font-size:.74rem;font-weight:300;letter-spacing:.04em}
.bio .biofoot a{color:var(--accent-ink)}
/* Visible por defecto (si la animación no corre, el contenido SIEMPRE se ve).
   La animación de entrada solo se aplica cuando el sistema permite movimiento. */
.bio .reveal2{opacity:1;transform:none}
@media(prefers-reduced-motion:no-preference){
  .bio .reveal2{opacity:0;transform:translateY(16px);animation:rise .7s var(--ease) forwards}
}
@keyframes rise{to{opacity:1;transform:none}}
