/* =========================================================
   ALICE SUNROSÉ ART — styles.css limpio final
   ========================================================= */

:root{
  --bg:#f8edf0;
  --paper:rgba(255,255,255,.62);
  --text:#20343d;
  --muted:#314d58;
  --line:rgba(26,64,75,.16);
  --pink:#e8007d;
  --rose:#f5b9cf;
  --deep:#0d4652;
  --deep2:#11343e;
  --gold:#b07a18;
  --gold-soft:#f7df9d;
  --white:#fff;
  --shadow:0 22px 50px rgba(37,72,82,.18);
  --container:1180px;
  --bg-parallax:0px;
  --script-purple:#e8007d;
}

@font-face{
  font-family:"AliceSignature";
  src:url("../fonts/Gistesy.ttf") format("truetype");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

@font-face{
  font-family:"MagnoliaSky";
  src:url("../fonts/magnolia_sky.ttf") format("truetype");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

@font-face{
  font-family:"TheSeasons";
  src:url("../fonts/the-seasons.ttf") format("truetype");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
  overflow-x:hidden;
}

body{
  margin:0;
  font-family:Montserrat,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
  overflow-x:hidden;
  width:100%;
  position:relative;
}

a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

.container{
  width:min(calc(100% - 24px),1320px);
  margin-inline:auto;
  min-width:0;
}

.section{
  padding:clamp(38px,5vw,72px) 0;
}

/* Fondo */
.page-bg{
  position:absolute;
  inset:0 0 auto 0;
  height:100%;
  min-height:200vh;
  z-index:-2;
  background:url("../img/bg-ocean-painting.webp") center top / 120% auto repeat-y;
  background-attachment:scroll;
}

.page-bg:after{display:none}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.14);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.20);
}

.nav-wrap{
  height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  position:relative;
}

.brand-mini{
  font-family:Montserrat,sans-serif;
  font-weight:400;
  font-size:1.05rem;
  line-height:1;
  white-space:nowrap;
  color:rgba(5,5,5,.55);
  letter-spacing:.01em;
}

.site-nav{
  display:flex;
  align-items:center;
  gap:24px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:500;
}

.site-nav a:not(:last-child):after{
  content:"|";
  margin-left:24px;
  color:var(--pink);
  opacity:.55;
}

.phone-link{display:none!important}

.nav-toggle{
  display:none;
  background:transparent;
  border:0;
  width:44px;
  height:44px;
}

.nav-toggle span{
  display:block;
  width:27px;
  height:2px;
  background:var(--deep);
  margin:5px auto;
}

/* Web: menú centrado, web a la derecha */
@media(min-width:761px){
  .site-nav{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
  }

  .brand-mini{
    margin-left:auto;
  }
}

/* Hero */
.hero{
  min-height:calc(100svh - 78px);
  display:grid;
  align-items:center;
  padding-top:8px;
  padding-bottom:132px;
}

.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
  gap:clamp(18px,2.4vw,38px);
  align-items:center;
  min-width:0;
}

.hero-copy,
.hero-art,
.about-copy,
.about-collage{min-width:0}

.hero-copy{
  order:1;
  margin-left:2vw;
  max-width:700px;
  transform:translateY(-42px);
  position:relative;
  z-index:3;
}

.hero-art{
  order:2;
  position:relative;
  z-index:2;
}

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.34em;
  color:var(--deep);
  font-size:.92rem;
  margin:38px 0 34px;
}

.hero h1{
  font-family:"AliceSignature",cursive!important;
  font-weight:400!important;
  color:#e8007d!important;
  display:block;
  width:max-content;
  max-width:100%;
  margin:0 auto 62px;
  padding:20px 10px 22px;
  font-size:clamp(4.15rem,6.8vw,6.25rem);
  line-height:.88;
  white-space:nowrap;
  letter-spacing:0;
  overflow:visible;
  position:relative;
  z-index:1;
 
}

.hero h1:before{
  content:"";
  position:absolute;
  left:-7%;
  right:-7%;
  top:8%;
  bottom:2%;
  z-index:-1;
  border-radius:999px;
  background:radial-gradient(ellipse at center,rgba(255,255,255,.62) 0%,rgba(255,238,248,.42) 42%,rgba(255,238,248,.16) 68%,transparent 100%);
  filter:blur(16px);
  pointer-events:none;
}

.hero h1 .logo-e-accent{
  position:relative;
  display:inline-block;
  font:inherit;
  color:inherit;
  line-height:inherit;
  vertical-align:baseline;
}

.hero h1 .logo-accent-mark{
  position:absolute;
  left:50%;
  top:-0.18em;
  transform:translateX(-35%) rotate(-10deg) scale(.58);
  transform-origin:center;
  font:inherit;
  line-height:1;
  color:inherit;
  pointer-events:none;
}

.hero-text,
.section-subtitle{
  font-size:clamp(.9 rem,1.22vw,1.08rem);
  max-width:62ch;
  color:var(--muted);
}

.hero-text-long{
  line-height:1.46;
  max-width:58ch;
}

.text-panel-soft,
.text-panel{
  border-radius:28px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.24);
  box-shadow:0 14px 34px rgba(37,72,82,.045);
  backdrop-filter:blur(2px);
}

.text-panel-soft{padding:20px 24px}

.text-panel{
  max-width:660px;
  padding:22px 26px;
}

.text-panel-soft p,
.text-panel p{
  font-family:"Caveat",cursive;
  font-weight:600;
  color:#21414d;
  font-size:clamp(1.45rem,1.9vw,1.7rem);
  line-height:1.35;
  letter-spacing:.01em;
}

.text-panel-soft p{margin:0 0 12px}
.text-panel p{margin:0 0 16px}
.text-panel-soft p:last-child,
.text-panel p:last-child{margin-bottom:0}

.hero-photo{
  width:min(65vw,1000px);
  height:auto;
  margin-left:auto;
  margin-right:-14.5vw;
  margin-top:-40px;
}

.hero-photo img{
  width:62%;
  height:auto;
  object-fit:contain;
  object-position:center center;
}

.hero-actions,
.contact-strip{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:24px;
}

.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-height:54px;
  padding:0 26px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.58);
  box-shadow:var(--shadow);
  font-weight:700;
  letter-spacing:.05em;
  transition:.25s ease;
}

.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--deep2),var(--deep));color:#fff}
.btn-secondary{background:rgba(255,255,255,.66);color:var(--deep)}
.btn-showroom{display:none!important}

/* WEB: coloca los dos botones hacia la derecha, junto a los iconos */
@media(min-width:1101px){
  .hero-actions{
    position:absolute;
    left:50%;
    bottom:-104px;
    width:min(42vw,660px);
    margin:0;
    display:flex;
    justify-content:flex-start;
    align-items:center;
    gap:18px;
    z-index:14;
  }

  .hero-actions .btn{
    width:auto;
    min-width:245px;
  }
}

/* Iconos hero */
.feature-list{
  position:absolute;
  right:-3.8vw;
  top:auto;
  bottom:-112px;
  z-index:12;
  width:min(42vw,640px);
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin:0;
  padding:0;
  pointer-events:auto;
  align-items:start;
  justify-items:center;
}

.feature-list .feature-link,
.feature-list a{
  display:block;
  width:100%;
  color:inherit;
  text-decoration:none;
  cursor:pointer;
  pointer-events:auto;
}

.feature-list article{
  text-align:center;
  padding:0 6px;
  margin:0;
  border:0;
}

.feature-list span{
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  margin:0 auto 8px;
  border-radius:50%;
  background:linear-gradient(135deg,#fff3cb 0%,#f5d98d 48%,#d5a84e 100%);
  box-shadow:
    0 10px 22px rgba(120,82,24,.18),
    inset 0 0 14px rgba(255,255,255,.45);
  color:var(--gold);
  font-size:2rem;
  font-weight:700;
  line-height:1;
  pointer-events:none;
}

.feature-list b{
  display:block;
  text-transform:uppercase;
  line-height:1.05;
  font-size:.8rem;
  color:var(--deep);
  letter-spacing:.04em;
  pointer-events:none;
}

/* Títulos */
.section-script,
.about-title-script,
.main-section-title,
.about-signature{
  font-family:"Allura",cursive!important;
  font-weight:400!important;
  letter-spacing:0!important;

}

.section-script{
  font-size:clamp(4rem,7vw,6rem);
  margin:0 0 18px;
  color:var(--pink);
  line-height:.86;
}

.main-section-title,
.section-head .main-section-title{
  color:#e8007d!important;
  font-size:clamp(2.75rem,4.7vw,4.45rem)!important;
  line-height:.96!important;
  margin:0 0 12px!important;
}

.about-copy > .section-script{
  color:#e8007d!important;
  font-size:clamp(2.65rem,4.2vw,4rem)!important;
  line-height:1!important;
  margin:0 0 24px!important;
}

.about-title-script{
  color:var(--script-purple)!important;
  font-size:clamp(2.35rem,3.7vw,3.55rem)!important;
  line-height:1.02!important;
  margin:0 0 42px!important;
  max-width:760px!important;
}

.centered{text-align:center}
.about h2,.collection h2{margin-top:0}

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

.section-subtitle{margin-inline:auto}
.collection{padding-top:clamp(30px,4vw,56px)}

/* Sobre mí */
.about-grid{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:clamp(30px,5vw,76px);
  align-items:center;
  min-width:0;
}

.about-signature{
  color:var(--pink)!important;
  font-size:2.8rem!important;
  line-height:1!important;
  margin-top:24px!important;
}

.about-signature__name{
  display:inline-block;
  font-family:"MagnoliaSky","Allura",cursive!important;
  font-size:1.18em;
  font-weight:400!important;
  letter-spacing:.01em;
}

.about-collage{
  position:relative;
  min-height:760px;
  overflow:visible;
}

.collage-wrap{
  position:relative;
  width:min(100%,760px);
  height:760px;
  margin-inline:auto;
}

.collage-main-photo{
  position:absolute;
  right:0;
  top:0;
  width:88%;
  height:70%;
  z-index:1;
}

.collage-small{
  position:absolute;
  z-index:2;
}

.collage-small-one{
  left:0;
  bottom:6%;
  width:42%;
  height:38%;
}

.collage-small-two{
  right:4%;
  bottom:0;
  width:50%;
  height:42%;
}

.collage-small img,
.collage-main-photo img{
  object-fit:cover;
}

.social-line{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  font-weight:600;
  margin-top:14px;
}

@media(min-width:761px){
  .about-grid .contact-strip{
    grid-column:2;
    grid-row:2;
    justify-content:flex-end;
    align-items:flex-end;
    margin-top:-40px;
    flex-direction:column;
    gap:12px;
  }

  .contact-strip .social-line{
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    gap:4px;
    margin-top:0;
  }

  .contact-strip .btn{align-self:flex-end}
}

/* Galería */
.collection .section-head{max-width:980px}

.cards-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
}

.collection-card{
  display:flex;
  flex-direction:column;
  min-height:100%;
  background:rgba(255,255,255,.52);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.58);
  border-radius:28px;
  box-shadow:0 18px 38px rgba(38,73,82,.14);
  overflow:hidden;
  transition:transform .28s ease,box-shadow .28s ease;
  cursor:pointer;
}

.collection-card:hover{
  transform:translateY(-6px);
  box-shadow:0 26px 50px rgba(38,73,82,.18);
}

.collection-card__image{
  position:relative;
  aspect-ratio:1/1.14;
  background:rgba(255,255,255,.30);
  overflow:hidden;
  border:0;
  padding:0;
  cursor:pointer;
  width:100%;
  display:block;
}

.collection-card__image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transition:transform .45s ease;
}

.collection-card:hover .collection-card__image img{transform:scale(1.035)}

.collection-card__more{
  position:absolute;
  right:10px;
  bottom:9px;
  z-index:3;
  display:inline-block;
  color:#fff;
  font-family:Montserrat,sans-serif;
  font-weight:900;
  font-size:clamp(.66rem,.9vw,.82rem);
  letter-spacing:.04em;
  line-height:1;
  text-transform:lowercase;
  opacity:.98;

  pointer-events:none;
}

.collection-card__body{
  display:flex;
  flex-direction:column;
  flex:1;
  padding:18px 18px 20px;
}

.collection-card__topline{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

.collection-card__id,
.collection-card__year{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:5px 10px;
  border-radius:999px;
  font-size:.74rem;
  font-weight:800;
  letter-spacing:.05em;
  text-transform:uppercase;
}

.collection-card__id{
  color:var(--deep);
  background:rgba(255,255,255,.54);
}

.collection-card__year{
  color:var(--gold);
  background:rgba(247,223,157,.34);
}

.collection-card__title{
  font-family:"TheSeasons","Cormorant Garamond",serif;
  text-transform:uppercase;
  color:var(--pink);
  font-size:clamp(1.35rem,2vw,1.35rem);
  line-height:.95;
  letter-spacing:.02em;
  margin:0 0 12px;

}

.collection-card__meta,
.collection-card__concept,
.collection-card__technique{
  font-size:.82rem;
  line-height:1.35;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 7px;
}

.collection-card__description{
  margin:8px 0 16px;
  color:#21414d;
  font-size:.94rem;
  line-height:1.48;
}

.collection-card__footer{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.collection-card__price{
  color:var(--deep);
  font-weight:800;
  font-size:.86rem;
}

.collection-card__interest{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  border:0;
  background:linear-gradient(135deg,var(--deep2),var(--deep));
  color:#fff;
  font-family:Montserrat,sans-serif;
  font-weight:800;
  font-size:.82rem;
  letter-spacing:.04em;
  box-shadow:0 12px 26px rgba(17,52,62,.18);
  white-space:nowrap;
  cursor:pointer;
}

.collection-card.is-sold .collection-card__price,
.collection-card.is-sold .collection-card__interest{display:none!important}

/* Modal */
body.modal-open{overflow:hidden}

.alice-modal{
  position:fixed;
  inset:0;
  z-index:999;
  display:none;
  padding:clamp(12px,2vw,28px);
}

.alice-modal.is-open{
  display:flex;
  align-items:center;
  justify-content:center;
}

.alice-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(13,42,48,.58);
  backdrop-filter:blur(8px);
}

.alice-modal__dialog{
  position:relative;
  z-index:1;
  width:min(1400px,96vw);
  max-height:96vh;
  overflow:hidden;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.44);
  box-shadow:0 30px 90px rgba(0,0,0,.28);
}

.alice-modal__dialog--work{
  background:linear-gradient(135deg,rgba(255,186,220,.96),rgba(255,216,232,.92) 48%,rgba(255,238,202,.86));
}

.alice-modal__dialog--form{
  width:min(880px,92vw);
  background:rgba(255,216,229,.80);
  backdrop-filter:blur(16px);
  overflow:hidden;
  max-height:calc(100svh - 24px);
}

.alice-modal__close{
  position:sticky;
  top:12px;
  float:right;
  z-index:5;
  width:44px;
  height:44px;
  margin:12px 12px 0 0;
  border:0;
  border-radius:50%;
  background:rgba(255,255,255,.78);
  color:var(--deep);
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
}

.alice-work-detail{
  display:grid;
  grid-template-columns:1.4fr .8fr;
  gap:clamp(20px,3vw,42px);
  padding:clamp(12px,2vw,24px);
  clear:both;
  transform:translateY(-50px);
}

.alice-work-detail__image{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:0;
}

.alice-work-detail__image img{
  max-width:100%;
  max-height:88vh;
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:24px;
  box-shadow:0 18px 46px rgba(17,52,62,.18);
}

.alice-work-detail__info{
  align-self:center;
  font-size:.95rem;
}

.alice-work-detail__id{
  display:inline-flex;
  margin-bottom:12px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.62);
  color:var(--gold);
  font-weight:800;
  font-size:.78rem;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.alice-work-detail__info h2{
  font-family:"TheSeasons","Cormorant Garamond",serif;
  color:var(--pink);
  font-size:clamp(1.4rem,2vw,1.7rem);
  line-height:.9;
  margin:0 0 14px;
  text-transform:uppercase;

}

.alice-work-detail__concept{
  display:block;
  padding:0;
  margin:10px 0 22px;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  border-radius:0;
  font-family:Montserrat,sans-serif!important;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.09em;
  font-size:clamp(.9rem,1.05vw,1.02rem);
  line-height:1.22;
  color:var(--script-purple);

}

.alice-work-detail__description,
.alice-work-detail__info p{
  color:#21414d;
  font-size:1.05rem;
  line-height:1.6;
  max-width:420px;
}

.alice-work-detail__info dl{
  display:grid;
  gap:10px;
  margin:22px 0;
}

.alice-work-detail__info dl div{
  padding-bottom:10px;
  border-bottom:1px solid rgba(13,70,82,.14);
}

.alice-work-detail__info dt{
  font-weight:800;
  text-transform:uppercase;
  font-size:.76rem;
  letter-spacing:.08em;
  color:var(--deep);
}

.alice-work-detail__info dd{
  margin:3px 0 0;
  color:var(--muted);
}

/* Formulario */
.alice-form{
  padding:34px 54px 42px;
  clear:both;
  max-height:calc(100svh - 24px);
  overflow-y:auto;
  border-radius:inherit;
  scroll-padding-bottom:40px;
}

.alice-modal__dialog--form .alice-modal__close{
  position:absolute;
  top:16px;
  right:16px;
  margin:0;
}

.alice-form__title{
  color:var(--script-purple);

}

.alice-form__title--hello{
  font-family:"Allura",cursive;
  font-weight:400;
  font-size:clamp(2.85rem,4.2vw,4.35rem);
  line-height:.9;
  margin:0 0 8px;
}

.alice-form__title--welcome{
  font-family:Montserrat,sans-serif;
  font-weight:900;
  letter-spacing:.08em;
  font-size:clamp(1.05rem,1.55vw,1.35rem);
  line-height:1.18;
  margin:0 0 22px;
  color:var(--script-purple);
}

.alice-form h2{
  margin:0 0 20px;
  font-family:"Cormorant Garamond",serif;
  color:var(--deep);
  font-size:clamp(1.8rem,3vw,2.6rem);
  line-height:1;
}

.alice-form__selected{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:20px;
  padding:12px;
  border-radius:20px;
  background:rgba(255,255,255,.42);
  color:var(--deep);
  font-weight:700;
}

.alice-form__selected img{
  width:74px;
  height:74px;
  object-fit:cover;
  border-radius:16px;
}

.alice-form__selected span{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:.9rem;
  font-weight:600;
}

.alice-form__grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

.alice-form label{
  display:grid;
  gap:7px;
  margin-bottom:14px;
  color:var(--deep);
  font-weight:800;
  font-size:.86rem;
  letter-spacing:.03em;
}

.alice-form input,
.alice-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.58);
  border-radius:16px;
  background:rgba(255,255,255,.72);
  color:var(--deep);
  font:600 1rem Montserrat,sans-serif;
  padding:14px 15px;
  outline:none;
}

.alice-form textarea{resize:vertical}

.alice-form input:focus,
.alice-form textarea:focus{
  border-color:rgba(228,134,185,.9);
  box-shadow:0 0 0 4px rgba(228,134,185,.18);
}

.alice-form__submit{
  width:100%;
  border:0;
  cursor:pointer;
  margin-top:4px;
}

.alice-form__note{
  margin:12px 0 0;
  color:var(--muted);
  font-size:.86rem;
  text-align:center;
}


.alice-form__privacy{
  display:flex!important;
  grid-template-columns:none!important;
  align-items:flex-start;
  gap:10px!important;
  margin:4px 0 16px!important;
  color:var(--deep);
  font-size:.82rem!important;
  line-height:1.45;
  font-weight:700!important;
  letter-spacing:0!important;
}

.alice-form__privacy input{
  width:18px!important;
  min-width:18px;
  height:18px;
  margin:2px 0 0;
  padding:0!important;
  accent-color:var(--pink);
}

.alice-form__privacy a{
  color:var(--pink);
  text-decoration:underline;
  text-underline-offset:3px;
}

.footer-links{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:18px;
  flex-wrap:wrap;
}

.privacy-page{
  padding:clamp(40px,6vw,86px) 0;
}

.privacy-card{
  width:min(calc(100% - 24px),920px);
  margin:0 auto;
  padding:clamp(26px,4vw,54px);
  border:1px solid rgba(255,255,255,.55);
  border-radius:32px;
  background:rgba(255,255,255,.7);
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
}

.privacy-card h1{
  margin:0 0 22px;
  font-family:"TheSeasons","Cormorant Garamond",serif;
  color:var(--pink);
  font-size:clamp(1.8rem,4vw,2.4rem);
  line-height:.95;

}

.privacy-card h2{
  margin:28px 0 8px;
  font-family:"TheSeasons","Cormorant Garamond",serif;
  color:var(--deep);
  text-transform:uppercase;
  font-size:1.35rem;
}

.privacy-card p,.privacy-card li{
  color:var(--muted);
}

.privacy-card ul{
  padding-left:20px;
}

.privacy-back{
  display:inline-flex;
  margin-top:24px;
}

/* Vendido */
.sold-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  border-radius:999px;
  background:linear-gradient(135deg,#ffb6dc 0%,#d84f9e 50%,#8d236d 100%);
  color:#fff;
  font-family:Montserrat,sans-serif;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  text-shadow:0 2px 8px rgba(70,0,45,.25);
  box-shadow:
    0 14px 28px rgba(188,47,143,.22),
    inset 0 0 14px rgba(255,255,255,.28);
}

.sold-badge--card{
  min-height:38px;
  padding:0 16px;
  font-size:.78rem;
}

.sold-badge--modal{
  min-height:52px;
  padding:0 28px;
  font-size:.95rem;
  margin-top:6px;
}

/* Scrollbars */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,221,238,.92));
  border-radius:999px;
}
::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,rgba(255,255,255,1),rgba(255,205,230,.98));
}
*{
  scrollbar-width:thin;
  scrollbar-color:rgba(255,230,242,.95) transparent;
}

/* Footer */
.site-footer{
  padding:16px 0 20px;
  margin-top:-30px;
}

.footer-wrap{
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding-top:10px;
}

.reveal{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .75s ease,transform .75s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:none;
}

.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.2s}

/* Responsive */
@media(max-width:1180px){
  .cards-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}

@media(max-width:1100px){
  .container{
    width:min(calc(100% - 22px),var(--container));
  }

  .hero{
    padding-bottom:28px;
  }

  .hero-grid,
  .about-grid{
    grid-template-columns:1fr;
  }

  .hero-art{order:1}

  .hero-copy{
    order:2;
    margin-left:0!important;
    max-width:none;
    transform:translateY(-28px);
  }

  .eyebrow{margin:0 0 20px}

  .hero-photo{
    width:calc(100vw - 24px);
    height:auto;
    margin:0 auto;
  }

  .hero-photo img{
    width:100%;
    height:auto;
    object-fit:contain;
  }

  .hero h1{
    white-space:normal;
    text-align:center;
  }

  .hero-actions{
    position:static;
    width:auto;
    justify-content:center;
    margin-top:24px;
  }

  .feature-list{
    position:static;
    width:100%;
    pointer-events:auto;
  }

  .about-collage{min-height:680px}
  .collage-wrap{height:680px}
  .site-nav{gap:14px}
  .site-nav a:not(:last-child):after{margin-left:14px}
}

@media(max-width:900px){
  .alice-work-detail{
    grid-template-columns:1fr;
  }

  .alice-work-detail__image img{
    max-height:52svh;
  }

  .alice-work-detail__info{
    align-self:start;
  }
}

@media(max-width:760px){
  .page-bg{
    position:fixed;
    inset:-8vh 0;
    height:auto;
    min-height:0;
    background:url("../img/bg-ocean-painting.webp") center calc(var(--bg-parallax) + 0px) / 260% auto no-repeat;
    background-attachment:scroll;
  }

  .container{width:min(calc(100% - 22px),var(--container))}
  .section{padding:32px 0}
  .site-header{background:rgba(255,255,255,.18);backdrop-filter:blur(10px)}
  .nav-wrap{height:66px}
  .brand-mini{font-size:.8rem;margin-left:0}
  .nav-toggle{display:block}

  .site-nav{
    position:absolute;
    left:12px;
    right:12px;
    top:76px;
    transform:translateY(-12px);
    display:grid;
    gap:0;
    background:rgba(255,255,255,.74);
    box-shadow:var(--shadow);
    border-radius:22px;
    padding:10px;
    opacity:0;
    pointer-events:none;
    transition:.25s ease;
  }

  .site-nav.is-open{
    opacity:1;
    pointer-events:auto;
    transform:none;
  }

  .site-nav a{padding:14px}
  .site-nav a:after{display:none}

  .hero{
    min-height:auto;
    padding-top:0;
  }

  .hero-grid{gap:16px}

  .hero-photo{
    width:100vw;
    height:auto;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
  }

  .hero-photo img{
    width:100%;
    height:auto;
    object-fit:contain;
    object-position:center center;
  }

  .hero h1{
    color:#e8007d!important;
    font-family:"AliceSignature",cursive!important;
    font-size:clamp(4.2rem,18vw,5.9rem);
    line-height:.72;
    white-space:normal;
    text-align:center;
  }

  .hero-copy{text-align:center}
  .hero-text{margin-inline:auto}
  .hero-text-long{font-size:.95rem;line-height:1.48}

  .text-panel-soft{
    padding:16px 18px;
    background:rgba(255,255,255,.14);
  }

  .text-panel-soft p,
  .text-panel p{
    font-size:1.38rem;
    line-height:1.32;
  }

  .hero-actions{
    justify-content:center;
  }

  .btn{
    width:100%;
    min-height:54px;
  }

  .feature-list{
    position:static;
    width:100%;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:4px;
    margin-top:18px;
    pointer-events:auto;
  }

  .feature-list article{
    border:0;
    padding:3px 2px;
  }

  .feature-list span{
    width:48px;
    height:48px;
    margin-bottom:6px;
    font-size:1.5rem;
  }

  .feature-list b{
    font-size:.7rem;
    line-height:1.06;
    letter-spacing:.02em;
  }

  .about-grid .contact-strip{
    order:3;
    margin-top:18px;
  }

  .about-collage{
    order:2;
    margin-top:22px;
    min-height:620px;
  }

  .about-copy{order:1}

  .collage-wrap{
    width:100%;
    height:620px;
  }

  .collage-main-photo{
    width:100%;
    height:60%;
    right:0;
  }

  .collage-small-one{
    width:48%;
    height:34%;
    left:0;
    bottom:8%;
  }

  .collage-small-two{
    width:56%;
    height:36%;
    right:0;
    bottom:0;
  }

  .cards-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
  }

  .collection-card{border-radius:22px}
  .collection-card__body{padding:14px}

  .collection-card__description,
  .collection-card__technique{
    display:none;
  }

  .collection-card__footer{
    display:grid;
    gap:8px;
  }

  .collection-card__interest{width:100%}

  .collection-card__more{
    right:8px;
    bottom:8px;
    font-size:.72rem;
  }

  .main-section-title,
  .section-head .main-section-title{
    font-size:3.05rem!important;
    line-height:1!important;
  }

  .about-copy > .section-script{
    font-size:3.05rem!important;
    margin-bottom:18px!important;
  }

  .about-title-script{
    font-size:2.65rem!important;
    line-height:1.02!important;
    margin-bottom:28px!important;
    text-align:center!important;
  }

  .social-line{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:4px;
    margin-top:4px;
  }

  .social-line a,
  .footer-wrap p,
  .footer-wrap a{
    color:#fff;
    font-weight:700;
    text-shadow:0 2px 8px rgba(0,0,0,.28);
  }

  .instagram-link{
    display:inline-flex;
    align-items:center;
    gap:7px;
  }

  .site-footer{
    padding:12px 0 22px;
    margin-top:-10px;
  }

  .footer-wrap{
    display:grid;
    gap:4px;
    padding-top:10px;
  }

  .alice-modal{
    padding:8px;
    align-items:flex-start!important;
    justify-content:center!important;
  }

  .alice-modal__dialog{
    width:min(1400px,96vw);
    max-height:96vh;
  }

  .alice-modal__dialog--work{
    position:relative;
    overflow-y:scroll!important;
    overflow-x:hidden!important;
    max-height:calc(100svh - 16px)!important;
    scrollbar-gutter:stable both-edges;
    -webkit-overflow-scrolling:touch;
  }

  .alice-modal__dialog--work::-webkit-scrollbar{
    width:10px;
    display:block;
    -webkit-appearance:none;
  }

  .alice-modal__dialog--work::-webkit-scrollbar-track{
    background:rgba(255,255,255,.28);
    border-radius:999px;
    margin:88px 0 28px;
  }

  .alice-modal__dialog--work::-webkit-scrollbar-thumb{
    background:linear-gradient(180deg,#ffffff 0%,#ffd4ea 100%);
    border:2px solid rgba(255,192,222,.72);
    border-radius:999px;
    min-height:70px;
  }

  .alice-modal__dialog--work:after{
    content:"";
    position:fixed;
    right:18px;
    top:124px;
    bottom:86px;
    width:5px;
    border-radius:999px;
    background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,210,234,.92));
    box-shadow:0 0 0 1px rgba(255,255,255,.28),0 8px 20px rgba(0,0,0,.10);
    z-index:18;
    pointer-events:none;
  }

  .alice-work-scrollhint{
    position:fixed!important;
    top:auto!important;
    left:auto!important;
    right:26px!important;
    bottom:24px!important;
    z-index:30!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:58px!important;
    height:58px!important;
    margin:0!important;
    padding:0!important;
    border-radius:999px!important;
    background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(255,218,238,.96))!important;
    color:var(--script-purple)!important;
    font-family:Montserrat,sans-serif!important;
    font-size:0!important;
    font-weight:900!important;
    line-height:1!important;
    box-shadow:
      0 14px 34px rgba(17,52,62,.24),
      inset 0 0 16px rgba(255,255,255,.62)!important;
    pointer-events:none!important;
  }

  .alice-work-scrollhint:before{
    content:"↓";
    display:block;
    font-size:2rem;
    line-height:.9;
    color:var(--script-purple);
    transform:translateY(-2px);
  }

  .alice-work-scrollhint:after{
    content:"scroll";
    position:absolute;
    left:50%;
    bottom:8px;
    transform:translateX(-50%);
    font-size:.48rem;
    line-height:1;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--deep);
  }

  .alice-work-detail{
    grid-template-columns:1fr;
    padding:16px;
    gap:16px;
    transform:none;
    min-height:auto;
    height:auto;
    padding-bottom:28px;
  }

  .alice-work-detail__image img{
    max-height:48svh;
    border-radius:20px;
  }

  .alice-work-detail__info h2{font-size:1.4rem}

  .alice-work-detail__concept{
    font-size:.86rem;
    line-height:1.2;
    margin:8px 0 18px;
  }

  .alice-modal__dialog--form{
    width:96vw;
    max-height:calc(100svh - 20px);
    border-radius:28px;
  }

  .alice-modal__dialog--form .alice-modal__close{
    width:46px;
    height:46px;
    top:14px;
    right:14px;
  }

  .alice-form{
    padding:18px 18px 34px;
    max-height:calc(100svh - 20px);
  }

  .alice-form__grid{
    grid-template-columns:1fr;
    gap:0;
  }

  .alice-form__selected{
    align-items:flex-start;
    margin-bottom:18px;
  }

  .alice-form__selected img{
    width:64px;
    height:64px;
  }

  .alice-form__title--hello{
    font-size:2.75rem;
    margin-bottom:6px;
  }

  .alice-form__title--welcome{
    font-size:.98rem;
    line-height:1.22;
    margin-bottom:18px;
  }
}

@media(max-width:430px){
  .page-bg{
    inset:-6vh 0;
    background:url("../img/bg-ocean-painting.webp") center calc(var(--bg-parallax) + 0px) / 300% auto no-repeat;
  }

  .brand-mini{font-size:.6rem}
  .container{width:min(calc(100% - 18px),var(--container))}
  .hero h1{font-size:3.65rem}
  .about-collage{min-height:540px}
  .collage-wrap{height:540px}
  .cards-grid{grid-template-columns:1fr}
  .collection-card__image{aspect-ratio:1/1.08}

  .feature-list span{
    width:44px;
    height:44px;
    font-size:1.35rem;
  }

  .feature-list b{font-size:.66rem}
}

/* =========================================================
   Ajustes contacto / footer / ficha / firma Alicia
   ========================================================= */
.contact-section{
  grid-column:1 / -1;
  width:100%;
  margin-top:clamp(28px,5vw,72px);
  scroll-margin-top:110px;
}

.contact-title{
  color:var(--pink)!important;
  font-size:clamp(2.65rem,4.2vw,4rem)!important;
  line-height:1!important;
  margin:0 0 18px!important;
  text-align:left;
}

.contact-section .contact-strip{
  margin-top:0;
}

.contact-section .social-line{
  width:100%;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:18px 28px;
}

.contact-section .social-line a,
.site-footer,
.site-footer p,
.site-footer a{
  color:#fff!important;
  font-weight:700;
  text-shadow:0 2px 8px rgba(0,0,0,.34);
}

.instagram-link,
.media-link{
  display:inline-flex;
  align-items:center;
  gap:9px;
}

.media-icon{
  width:24px;
  height:24px;
  display:inline-block;
  fill:currentColor;
  flex:0 0 auto;
  filter:drop-shadow(0 2px 5px rgba(0,0,0,.18));
}

.youtube-link{
  gap:12px;
}

.youtube-thumb{
  width:86px;
  height:50px;
  object-fit:cover;
  border-radius:12px;
  box-shadow:0 10px 24px rgba(0,0,0,.20);
  border:1px solid rgba(255,255,255,.45);
}

.footer-wrap{
  border-top-color:rgba(255,255,255,.34)!important;
}

.alice-work-detail__image img{
  border-radius:0!important;
}

.about-signature{
  margin-top:34px!important;
  line-height:.92!important;
}

.about-signature__name{
  display:inline-block;
  margin-top:18px;
  margin-bottom:18px;
  font-size:.72em!important;
  font-weight:300!important;
  line-height:.82!important;
  text-shadow:0 1px 0 rgba(255,255,255,.52),0 7px 16px rgba(20,40,48,.10)!important;
  transform:translateY(8px);
}



@media(max-width:760px){
  .contact-section{
    margin-top:58px;
    padding-top:10px;
    scroll-margin-top:92px;
  }

  .contact-title{
    font-size:3.05rem!important;
    margin-bottom:22px!important;
    text-align:left!important;
  }

  .contact-section .social-line{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
    margin-top:0;
  }

  .youtube-link{
    align-items:center;
  }

  .youtube-thumb{
    width:78px;
    height:45px;
    border-radius:10px;
  }

  .about-signature{
    margin-top:30px!important;
  }

  .about-signature__name{
    margin-top:20px;
    font-size:.92em!important;
    transform:translateY(12px);
  }
}

/* =========================================================
   Ajuste final contacto: alineado izquierda, orden claro
   ========================================================= */
.contact-section{
  grid-column:1 / -1;
  width:100%;
  margin-top:clamp(34px,5vw,76px);
  scroll-margin-top:110px;
  text-align:left!important;
}

.contact-section .contact-strip{
  margin-top:0!important;
  justify-content:flex-start!important;
  align-items:flex-start!important;
}

.contact-section .social-line{
  width:100%!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  justify-content:flex-start!important;
  text-align:left!important;
  gap:8px!important;
  margin-top:0!important;
}

.contact-section .contact-email{
  margin-bottom:10px!important;
}

.contact-section .social-line a,
.contact-section .media-link,
.contact-section .instagram-link,
.contact-section .youtube-link,
.contact-section .spotify-link{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  text-align:left!important;
  color:#fff!important;
  font-weight:700!important;
  text-shadow:0 2px 8px rgba(0,0,0,.34)!important;
}

.contact-section .youtube-thumb{
  display:none!important;
}

@media(min-width:761px){
  .about-grid .contact-strip{
    grid-column:auto!important;
    grid-row:auto!important;
    justify-content:flex-start!important;
    align-items:flex-start!important;
    margin-top:0!important;
    flex-direction:column!important;
  }

  .contact-strip .social-line{
    align-items:flex-start!important;
    text-align:left!important;
    gap:8px!important;
  }
}

@media(max-width:760px){
  .about-copy{order:1;}
  .about-collage{order:2;}
  .contact-section{
    order:3;
    margin-top:58px!important;
    padding-top:10px!important;
    text-align:left!important;
  }
  .contact-section .social-line{
    align-items:flex-start!important;
    gap:8px!important;
  }
}

/* =========================================================
   Ajustes finales: sin burbuja scroll, sombra 3D cuadros,
   iconos hero izquierda y botones derecha
   ========================================================= */
.alice-work-scrollhint,
.alice-work-scrollhint:before,
.alice-work-scrollhint:after{
  display:none!important;
  content:none!important;
}

.collection-card{
  box-shadow:
    0 18px 34px rgba(38,73,82,.14),
    0 22px 38px rgba(91,20,73,.20),
    0 34px 58px rgba(63,12,58,.16)!important;
}

.collection-card:hover{
  box-shadow:
    0 22px 42px rgba(38,73,82,.16),
    0 30px 52px rgba(91,20,73,.26),
    0 44px 72px rgba(63,12,58,.18)!important;
}

.collection-card__image{
  box-shadow:0 18px 28px -18px rgba(73,12,68,.72);
}

.collection-card__image:after{
  content:"";
  position:absolute;
  left:7%;
  right:7%;
  bottom:-10px;
  height:34px;
  border-radius:50%;
  background:radial-gradient(ellipse at center,rgba(89,18,78,.44) 0%,rgba(89,18,78,.22) 44%,transparent 72%);
  filter:blur(10px);
  opacity:.85;
  pointer-events:none;
  z-index:1;
}

.alice-work-detail__image img{
  box-shadow:
    0 18px 32px rgba(17,52,62,.14),
    0 28px 52px rgba(91,20,73,.28),
    0 44px 78px rgba(63,12,58,.22)!important;
}

@media(min-width:1101px){
  .feature-list{
    left:0!important;
    right:auto!important;
    bottom:-118px!important;
    width:min(42vw,640px)!important;
    justify-items:start!important;
    gap:18px!important;
  }

  .feature-list article{
    text-align:center!important;
    width:100%!important;
  }

  .hero-actions{
    left:auto!important;
    right:0!important;
    bottom:-104px!important;
    width:min(48vw,720px)!important;
    justify-content:flex-end!important;
    gap:18px!important;
  }

  .hero-actions .btn{
    min-width:255px!important;
  }
}

@media(max-width:760px){
  .collection-card{
    box-shadow:
      0 16px 28px rgba(38,73,82,.14),
      0 20px 34px rgba(91,20,73,.22),
      0 30px 48px rgba(63,12,58,.16)!important;
  }

  .alice-modal__dialog--work:after{
    display:none!important;
    content:none!important;
  }
}

/* =========================================================
   FIX DEFINITIVO HERO: iconos izquierda + botones derecha
   ========================================================= */
@media(min-width:1101px){
  .hero-grid{
    position:relative!important;
    padding-bottom:165px!important;
  }

  .hero-copy{
    position:static!important;
  }

  .feature-list{
    position:absolute!important;
    left:0!important;
    right:auto!important;
    bottom:-118px!important;
    width:460px!important;
    display:grid!important;
    grid-template-columns:repeat(3, minmax(0, 1fr))!important;
    gap:18px!important;
    margin:0!important;
    padding:0!important;
    justify-items:center!important;
    align-items:start!important;
    z-index:10!important;
  }

  .hero-actions{
    position:absolute!important;
    left:auto!important;
    right:0!important;
    bottom:-106px!important;
    width:max-content!important;
    max-width:none!important;
    display:flex!important;
    flex-direction:row!important;
    flex-wrap:nowrap!important;
    align-items:center!important;
    justify-content:flex-end!important;
    gap:18px!important;
    margin:0!important;
    z-index:14!important;
  }

  .hero-actions .btn{
    width:auto!important;
    min-width:255px!important;
    white-space:nowrap!important;
    flex:0 0 auto!important;
  }
}

@media(max-width:1100px){
  .hero-copy{
    display:flex!important;
    flex-direction:column!important;
  }

  .feature-list{
    order:20!important;
  }

  .hero-actions{
    order:30!important;
  }
}

/* =========================================================
   FIX RESPONSIVE FOTOS PINTORA — desktop estrecho/tablet landscape
   Evita que las fotos gigantes desplacen textos/contacto en 900-1100px
   ========================================================= */
@media (min-width:761px) and (max-width:1100px){
  .hero{
    min-height:auto!important;
    padding-top:22px!important;
    padding-bottom:56px!important;
  }

  .hero-grid{
    grid-template-columns:minmax(0,0.95fr) minmax(0,1.05fr)!important;
    align-items:center!important;
    gap:24px!important;
    padding-bottom:0!important;
  }

  .hero-copy{
    order:1!important;
    margin-left:0!important;
    max-width:none!important;
    transform:none!important;
    text-align:left!important;
  }

  .hero-art{
    order:2!important;
    align-self:center!important;
  }

  .hero-photo{
    width:100%!important;
    max-width:560px!important;
    margin:0 auto!important;
  }

  .hero-photo img{
    width:100%!important;
    max-height:calc(100svh - 130px)!important;
    object-fit:contain!important;
    object-position:center!important;
  }

  .hero h1{
    text-align:center!important;
    white-space:nowrap!important;
    font-size:clamp(3.7rem,7vw,5.2rem)!important;
    margin-bottom:36px!important;
  }

  .hero-actions,
  .feature-list{
    position:static!important;
    width:100%!important;
    max-width:none!important;
    margin-top:22px!important;
  }

  .feature-list{
    order:20!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:12px!important;
    justify-items:center!important;
  }

  .hero-actions{
    order:30!important;
    display:flex!important;
    flex-direction:row!important;
    flex-wrap:nowrap!important;
    justify-content:center!important;
    gap:14px!important;
  }

  .hero-actions .btn{
    width:auto!important;
    min-width:220px!important;
    flex:0 0 auto!important;
    white-space:nowrap!important;
  }

  .about-grid{
    grid-template-columns:minmax(0,0.95fr) minmax(0,1.05fr)!important;
    align-items:center!important;
    gap:30px!important;
  }

  .about-copy{
    order:1!important;
  }

  .about-collage{
    order:2!important;
    min-height:auto!important;
    align-self:center!important;
  }

  .collage-wrap{
    width:100%!important;
    max-width:560px!important;
    height:auto!important;
    min-height:0!important;
    display:grid!important;
    grid-template-columns:0.82fr 1.18fr!important;
    gap:0!important;
    align-items:end!important;
  }

  .collage-main-photo,
  .collage-small,
  .collage-small-two{
    position:relative!important;
    inset:auto!important;
    right:auto!important;
    left:auto!important;
    top:auto!important;
    bottom:auto!important;
    width:100%!important;
    height:auto!important;
  }

  .collage-main-photo img,
  .collage-small img,
  .collage-small-two img{
    width:100%!important;
    height:auto!important;
    max-height:520px!important;
    object-fit:contain!important;
  }

  .contact-section{
    margin-top:36px!important;
    padding-top:0!important;
  }
}

@media (min-width:901px) and (max-width:1100px){
  .container{
    width:min(calc(100% - 32px),1180px)!important;
  }

  .text-panel-soft p,
  .text-panel p{
    font-size:clamp(1.25rem,1.65vw,1.48rem)!important;
    line-height:1.28!important;
  }
}

/* =========================================================
   FIX 1090px DESKTOP: botones derecha + contacto siempre abajo
   ========================================================= */
@media (min-width:981px) and (max-width:1100px){
  .hero-grid{
    position:relative!important;
    grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr)!important;
    padding-bottom:142px!important;
  }

  .hero-copy{
    position:static!important;
  }

  .feature-list{
    position:absolute!important;
    left:0!important;
    right:auto!important;
    bottom:18px!important;
    width:430px!important;
    max-width:43%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:12px!important;
    margin:0!important;
    padding:0!important;
    justify-items:center!important;
    align-items:start!important;
    z-index:10!important;
  }

  .feature-list span{
    width:58px!important;
    height:58px!important;
    font-size:1.8rem!important;
  }

  .feature-list b{
    font-size:.72rem!important;
    line-height:1.02!important;
  }

  .hero-actions{
    position:absolute!important;
    left:auto!important;
    right:0!important;
    bottom:30px!important;
    width:auto!important;
    max-width:54%!important;
    display:flex!important;
    flex-direction:row!important;
    flex-wrap:nowrap!important;
    align-items:center!important;
    justify-content:flex-end!important;
    gap:12px!important;
    margin:0!important;
    z-index:14!important;
  }

  .hero-actions .btn{
    width:auto!important;
    min-width:0!important;
    flex:0 1 auto!important;
    padding-inline:24px!important;
    min-height:50px!important;
    white-space:nowrap!important;
    font-size:.86rem!important;
  }

  .about-grid{
    grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr)!important;
    align-items:start!important;
  }

  .contact-section{
    grid-column:1 / -1!important;
    order:3!important;
    margin-top:34px!important;
    padding-top:0!important;
    clear:both!important;
  }
}


/* =========================================================
   COLLAGE SOBRE MÍ — 3 fotos con brillo blanco sutil
   ========================================================= */
.collage-wrap{
  isolation:isolate;
}

.about-collage .photo-fade{
  overflow:hidden;
  box-shadow:
    0 18px 38px rgba(17,52,62,.13),
    0 0 0 1px rgba(255,255,255,.30),
    inset 0 0 38px rgba(255,255,255,.10);
}

.about-collage .photo-fade:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 16%,rgba(255,255,255,.30),transparent 28%),
    linear-gradient(135deg,rgba(255,255,255,.18),transparent 34%,rgba(255,255,255,.10));
  mix-blend-mode:screen;
  opacity:.58;
}

.about-collage .photo-fade img{
  position:relative;
  z-index:1;
}

.collage-small-three{
  position:absolute;
  z-index:3;
  right:0;
  bottom:5%;
  width:36%;
  height:35%;
}

.collage-small-three img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

@media(min-width:1101px){
  .collage-wrap{
    width:min(100%,780px)!important;
    height:780px!important;
  }

  .collage-main-photo{
    right:4%!important;
    top:0!important;
    width:72%!important;
    height:62%!important;
    z-index:1!important;
  }

  .collage-small-two{
    left:18%!important;
    right:auto!important;
    bottom:4%!important;
    width:44%!important;
    height:38%!important;
    z-index:2!important;
  }

  .collage-small-three{
    right:0!important;
    bottom:0!important;
    width:38%!important;
    height:34%!important;
    z-index:3!important;
  }

  .collage-main-photo img,
  .collage-small-two img,
  .collage-small-three img{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
  }

  .collage-main-photo img{object-position:center center!important;}
  .collage-small-two img{object-position:center center!important;}
  .collage-small-three img{object-position:center center!important;}
}

@media (min-width:761px) and (max-width:1100px){
  .collage-wrap{
    max-width:580px!important;
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    grid-template-rows:auto auto!important;
    gap:10px!important;
    align-items:stretch!important;
  }

  .collage-main-photo,
  .collage-small-two,
  .collage-small-three{
    position:relative!important;
    inset:auto!important;
    width:100%!important;
    height:auto!important;
  }

  .collage-main-photo{
    grid-column:1 / -1!important;
    aspect-ratio:1.45 / 1!important;
  }

  .collage-small-two,
  .collage-small-three{
    aspect-ratio:1 / 1.04!important;
  }

  .collage-main-photo img,
  .collage-small-two img,
  .collage-small-three img{
    width:100%!important;
    height:100%!important;
    max-height:none!important;
    object-fit:cover!important;
  }
}

@media(max-width:760px){
  .about-collage{
    min-height:720px!important;
    margin-top:18px!important;
  }

  .collage-wrap{
    height:720px!important;
    width:100%!important;
  }

  .collage-main-photo{
    width:88%!important;
    height:44%!important;
    left:0!important;
    right:auto!important;
    top:0!important;
    z-index:1!important;
  }

  .collage-small-two{
    width:58%!important;
    height:32%!important;
    right:0!important;
    left:auto!important;
    top:33%!important;
    bottom:auto!important;
    z-index:2!important;
  }

  .collage-small-three{
    width:54%!important;
    height:30%!important;
    left:6%!important;
    right:auto!important;
    bottom:4%!important;
    z-index:3!important;
  }

  .collage-main-photo img,
  .collage-small-two img,
  .collage-small-three img{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
  }

  .collage-main-photo img{object-position:center center!important;}
  .collage-small-two img{object-position:center center!important;}
  .collage-small-three img{object-position:center center!important;}
}

@media(max-width:430px){
  .about-collage{min-height:640px!important;}
  .collage-wrap{height:640px!important;}
}

/* =========================================================
   SOBRE MÍ — slider suave en la foto grande (2 fotos)
   ========================================================= */
.collage-small-three{
  display:none!important;
}

.about-collage .photo-fade{
  position:relative;
}

.collage-slider{
  overflow:hidden!important;
  background:rgba(255,255,255,.18);
}

.collage-slider__img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  object-fit:cover!important;
  object-position:center center!important;
  opacity:0;
  z-index:1!important;
  animation:aliceCollageFade 6s ease-in-out infinite;
  will-change:opacity;
}

.collage-slider__img--one{
  opacity:1;
  animation-delay:0s;
}

.collage-slider__img--two{
  animation-delay:3s;
}

@keyframes aliceCollageFade{
  0%{opacity:0;}
  10%{opacity:1;}
  48%{opacity:1;}
  58%{opacity:0;}
  100%{opacity:0;}
}

@media (prefers-reduced-motion:reduce){
  .collage-slider__img{
    animation:none!important;
  }
  .collage-slider__img--one{
    opacity:1!important;
  }
  .collage-slider__img--two{
    opacity:0!important;
  }
}

@media(min-width:1101px){
  .collage-main-photo.collage-slider{
    right:4%!important;
    top:0!important;
    width:72%!important;
    height:62%!important;
    z-index:1!important;
  }

  .collage-small-two{
    left:18%!important;
    right:auto!important;
    bottom:4%!important;
    width:44%!important;
    height:38%!important;
    z-index:2!important;
  }
}

@media (min-width:761px) and (max-width:1100px){
  .collage-main-photo.collage-slider{
    grid-column:1 / -1!important;
    aspect-ratio:1.45 / 1!important;
    min-height:0!important;
  }
}

@media(max-width:760px){
  .about-collage{
    min-height:620px!important;
    margin-top:16px!important;
  }

  .collage-wrap{
    height:620px!important;
    width:100%!important;
  }

  .collage-main-photo.collage-slider{
    width:96%!important;
    height:48%!important;
    left:0!important;
    right:auto!important;
    top:0!important;
    z-index:1!important;
  }

  .collage-small-two{
    width:68%!important;
    height:36%!important;
    right:0!important;
    left:auto!important;
    top:42%!important;
    bottom:auto!important;
    z-index:2!important;
  }
}

@media(max-width:430px){
  .about-collage{min-height:560px!important;}
  .collage-wrap{height:560px!important;}
}

/* =========================================================
   AJUSTE FINAL SOBRE MÍ — foto grande fija + slider pequeño
   ========================================================= */
.collage-small-three{
  display:none!important;
}

.collage-slider{
  position:absolute!important;
  overflow:hidden!important;
  background:rgba(255,255,255,.18);
}

.collage-slider__img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  object-fit:cover!important;
  object-position:center center!important;
  opacity:0;
  z-index:1!important;
  animation:aliceSmallCollageFade 12s ease-in-out infinite!important;
  will-change:opacity;
}

.collage-slider__img--one{
  animation-delay:0s!important;
}

.collage-slider__img--two{
  animation-delay:6s!important;
}

@keyframes aliceSmallCollageFade{
  0%{opacity:0;}
  8%{opacity:1;}
  46%{opacity:1;}
  54%{opacity:0;}
  100%{opacity:0;}
}

@media (prefers-reduced-motion:reduce){
  .collage-slider__img{animation:none!important;}
  .collage-slider__img--one{opacity:1!important;}
  .collage-slider__img--two{opacity:0!important;}
}

@media(min-width:1101px){
  .collage-wrap{
    width:min(100%,780px)!important;
    height:780px!important;
    transform:translateX(38px);
  }

  .collage-main-photo{
    right:0!important;
    left:auto!important;
    top:0!important;
    width:74%!important;
    height:62%!important;
    z-index:1!important;
  }

  .collage-main-photo img{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
    object-position:center center!important;
  }

  .collage-small-two.collage-slider{
    left:26%!important;
    right:auto!important;
    bottom:4%!important;
    top:auto!important;
    width:48%!important;
    height:38%!important;
    z-index:2!important;
  }
}

@media (min-width:761px) and (max-width:1100px){
  .collage-wrap{
    display:block!important;
    max-width:580px!important;
    height:620px!important;
    transform:translateX(26px);
  }

  .collage-main-photo{
    position:absolute!important;
    right:0!important;
    left:auto!important;
    top:0!important;
    width:82%!important;
    height:58%!important;
    z-index:1!important;
  }

  .collage-main-photo img{
    width:100%!important;
    height:100%!important;
    max-height:none!important;
    object-fit:cover!important;
    object-position:center center!important;
  }

  .collage-small-two.collage-slider{
    position:absolute!important;
    left:28%!important;
    right:auto!important;
    top:auto!important;
    bottom:2%!important;
    width:56%!important;
    height:34%!important;
    z-index:2!important;
    aspect-ratio:auto!important;
  }
}

@media(max-width:760px){
  .about-collage{
    min-height:560px!important;
    margin-top:12px!important;
  }

  .collage-wrap{
    height:560px!important;
    width:100%!important;
    transform:translateX(10px);
  }

  .collage-main-photo{
    width:88%!important;
    height:50%!important;
    left:auto!important;
    right:0!important;
    top:0!important;
    z-index:1!important;
  }

  .collage-main-photo img{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
    object-position:center center!important;
  }

  .collage-small-two.collage-slider{
    width:66%!important;
    height:34%!important;
    left:auto!important;
    right:4%!important;
    top:43%!important;
    bottom:auto!important;
    z-index:2!important;
  }
}

@media(max-width:430px){
  .about-collage{min-height:510px!important;}
  .collage-wrap{height:510px!important;}
}


/* =========================================================
   COLLAGE SOBRE MÍ — 3 fotos tipo editorial
   CONTROLES RÁPIDOS PARA MOVER A MANO:
   - Cambia las variables --main-*, --top-* y --bottom-*
   - main = alice-4 grande / top = alice-3 arriba izquierda / bottom = alice-1 abajo derecha
   ========================================================= */
.about-collage{
  min-height:820px!important;
  overflow:visible!important;
}

.about-collage .collage-wrap{
  --main-x:18%;
  --main-y:0%;
  --main-w:72%;
  --main-h:74%;

  --top-x:-5%;
  --top-y:-22%;
  --top-w:42%;
  --top-h:32%;

  --bottom-x:auto;
  --bottom-right:-2%;
  --bottom-y:auto;
  --bottom-bottom:-1%;
  --bottom-w:42%;
  --bottom-h:32%;

  position:relative!important;
  display:block!important;
  width:min(100%,860px)!important;
  height:800px!important;
  margin-inline:auto!important;
  transform:none!important;
  isolation:isolate!important;
}

.about-collage .photo-fade{
  position:absolute!important;
  overflow:hidden!important;
  background:rgba(255,255,255,.18)!important;
  border:3px solid rgba(255,255,255,.70)!important;
  box-shadow:
    12px 16px 0 rgba(95,44,92,.32),
    0 18px 36px rgba(17,52,62,.15)!important;
}

.about-collage .photo-fade:before{
  display:none!important;
  content:none!important;
}

.about-collage .photo-fade img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  object-fit:cover!important;
  object-position:center center!important;
  opacity:1!important;
  animation:none!important;
}

.about-collage .collage-main-photo{
  left:var(--main-x)!important;
  right:auto!important;
  top:var(--main-y)!important;
  bottom:auto!important;
  width:var(--main-w)!important;
  height:var(--main-h)!important;
  z-index:1!important;
}

.about-collage .collage-small-one{
  left:var(--top-x)!important;
  right:auto!important;
  top:var(--top-y)!important;
  bottom:auto!important;
  width:var(--top-w)!important;
  height:var(--top-h)!important;
  z-index:3!important;
}

.about-collage .collage-small-two{
  left:var(--bottom-x)!important;
  right:var(--bottom-right)!important;
  top:var(--bottom-y)!important;
  bottom:var(--bottom-bottom)!important;
  width:var(--bottom-w)!important;
  height:var(--bottom-h)!important;
  z-index:4!important;
}

/* Ajuste para pantallas medias */
@media (min-width:761px) and (max-width:1100px){
  .about-collage{
    min-height:650px!important;
  }

  .about-collage .collage-wrap{
    --main-x:18%;
    --main-y:0%;
    --main-w:74%;
    --main-h:72%;

    --top-x:-4%;
    --top-y:42%;
    --top-w:40%;
    --top-h:30%;

    --bottom-right:-2%;
    --bottom-bottom:0%;
    --bottom-w:42%;
    --bottom-h:30%;

    width:min(100%,620px)!important;
    height:640px!important;
    transform:none!important;
  }
}

/* Mobile: misma idea, más vertical y sin tapar demasiado */
@media(max-width:760px){
  .about-collage{
    min-height:600px!important;
    margin-top:16px!important;
  }

  .about-collage .collage-wrap{
    --main-x:8%;
    --main-y:0%;
    --main-w:88%;
    --main-h:58%;

    --top-x:0%;
    --top-y:52%;
    --top-w:52%;
    --top-h:28%;

    --bottom-right:0%;
    --bottom-bottom:-5%;
    --bottom-w:58%;
    --bottom-h:45%;

    width:100%!important;
    height:590px!important;
    transform:none!important;
  }

  .about-collage .photo-fade{
    border-width:2px!important;
    box-shadow:
      8px 10px 0 rgba(95,44,92,.26),
      0 14px 28px rgba(17,52,62,.13)!important;
  }
}

@media(max-width:430px){
  .about-collage{min-height:540px!important;}
  .about-collage .collage-wrap{height:530px!important;}
}


/* =========================
   FIX MODAL FINAL DEFINITIVO
   ========================= */

/* popup más grande */
.alice-modal__dialog--work{
  width: min(1400px, 98vw) !important;
  max-height: calc(100svh - 16px) !important;
  overflow: hidden !important;
}

/* scroll SOLO dentro */
.alice-modal__dialog--work{
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
}

/* evita scroll fondo */
body.modal-open{
  overflow: hidden !important;
  touch-action: none;
}

/* mobile ajuste extra */
@media(max-width:760px){
  .alice-modal{
    padding:6px !important;
  }

  .alice-modal__dialog--work{
    width: 100% !important;
    max-height: calc(100svh - 10px) !important;
    border-radius: 22px !important;
  }

  .alice-work-detail{
    padding:14px !important;
  }
}