  /* ============================================================
     ARALÉ — Brand tokens
     ============================================================ */
  :root{
    --bone:        #f1ede4;   /* page background */
    --bone-soft:   #ebe6dc;
    --linen:       #d9d2c2;   /* warm beige */
    --sage-soft:   #c7c8b6;
    --sage:        #9da08b;   /* primary sage */
    --olive:       #6b6f5a;   /* deep olive */
    --ink:         #1c1c1c;   /* near-black */
    --ink-soft:    #3a3a36;
    --rule:        rgba(28,28,28,.18);
    --rule-soft:   rgba(28,28,28,.08);

    --font-display: "Italiana", "Cormorant Garamond", serif;
    --font-serif:   "Cormorant Garamond", "EB Garamond", serif;
    --font-sans:    "Inter", system-ui, sans-serif;

    --tracking-xl: .42em;
    --tracking-lg: .28em;
    --tracking-md: .18em;

    --pad-x: clamp(24px, 5vw, 96px);
  }

  *{ box-sizing: border-box; }
  html,body{ margin:0; padding:0; }
  html{ scroll-behavior:smooth; }
  body{
    background: var(--bone);
    color: var(--ink);
    font-family: var(--font-serif);
    font-weight: 400;
    font-size: 17px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
  }
  img{ max-width:100%; display:block; }
  a{ color: inherit; text-decoration: none; }
  button{ font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }

  /* Subtle paper grain over the whole page */
  body::before{
    content:"";
    position:fixed; inset:0;
    pointer-events:none; z-index:1000;
    background-image:
      radial-gradient(rgba(28,28,28,.025) 1px, transparent 1px),
      radial-gradient(rgba(28,28,28,.02) 1px, transparent 1px);
    background-size: 3px 3px, 7px 7px;
    background-position: 0 0, 1px 2px;
    mix-blend-mode: multiply;
    opacity:.7;
  }

  /* Tiny eyebrow */
  .eyebrow{
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: var(--tracking-lg);
    text-transform: uppercase;
    color: var(--ink-soft);
  }
  .eyebrow .dot{ display:inline-block; width:4px; height:4px; background: var(--olive); border-radius:50%; vertical-align: middle; margin: 0 .55em .15em; }

  /* Divider with the brand's dash treatment */
  .dash{ display:inline-block; width: 38px; height:1px; background: currentColor; vertical-align: middle; }
  .dash.lg{ width: 72px; }

  /* =================== NAVIGATION =================== */
  .nav{
    position: fixed; inset: 0 0 auto 0; z-index: 50;
    display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
    gap: clamp(28px, 5vw, 64px);
    padding: 22px var(--pad-x);
    transition: background-color .4s ease, padding .3s ease, border-color .4s ease;
    border-bottom: 1px solid transparent;
  }
  .nav.scrolled{
    background: rgba(241,237,228,.86);
    backdrop-filter: blur(14px) saturate(110%);
    -webkit-backdrop-filter: blur(14px) saturate(110%);
    padding-top: 14px; padding-bottom: 14px;
    border-bottom-color: var(--rule-soft);
  }
  .nav-left, .nav-right{ display:flex; gap: 36px; align-items: center; }
  .nav-right{ justify-content: flex-end; }
  .nav a.link{
    font-family: var(--font-sans);
    font-size: 11px;
    letter-spacing: var(--tracking-md);
    text-transform: uppercase;
    color: var(--ink-soft);
    position: relative;
    padding: 4px 0;
  }
  .nav a.link::after{
    content:""; position:absolute; left:0; right:100%; bottom:0; height:1px; background: var(--ink);
    transition: right .4s ease;
  }
  .nav a.link:hover::after{ right: 0; }
  .nav-mark{
    font-family: var(--font-display);
    font-size: 20px;
    letter-spacing: .35em;
    padding-left: .35em;
    color: var(--ink);
  }
  .nav-cta{
    font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase;
    padding: 10px 18px; border: 1px solid var(--ink); color: var(--ink);
    transition: background .3s ease, color .3s ease;
  }
  .nav-cta:hover{ background: var(--ink); color: var(--bone); }
  .nav-burger{ display:none; }

  @media (max-width: 860px){
    .nav{ grid-template-columns: auto 1fr auto; }
    .nav-left{ display:none; }
    .nav-right .link{ display:none; }
    .nav-burger{ display:inline-flex; flex-direction:column; gap:5px; width: 28px; }
    .nav-burger span{ height:1px; background: var(--ink); display:block; }
    .nav-mark{ justify-self: start; padding-left: 0; font-size: 16px; }
  }

  /* =================== HERO =================== */
  .hero{
    position: relative;
    min-height: 100vh;
    padding: 140px var(--pad-x) 80px;
    display: grid;
    grid-template-rows: 1fr auto;
    overflow: hidden;
  }
  .hero-eyebrows{
    display:flex; justify-content: space-between; align-items: center;
    padding-bottom: 24px; border-bottom: 1px solid var(--rule-soft);
    margin-bottom: clamp(40px, 9vh, 100px);
  }
  .hero-eyebrows .right{ text-align: right; }
  .hero-stack{
    display:flex; flex-direction: column; align-items: center; gap: 24px;
    text-align: center;
  }
  .hero-tag{
    display:inline-flex; gap: 14px; align-items: center;
    font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--ink-soft);
  }
  .wordmark{
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(72px, 16vw, 248px);
    line-height: .9;
    letter-spacing: .04em;
    color: var(--ink);
    display: flex; gap: clamp(20px, 4vw, 60px); align-items: center;
    margin: 0;
  }
  .wordmark .letter{ display:inline-block; opacity:0; transform: translateY(40px); animation: rise .9s cubic-bezier(.2,.7,.2,1) forwards; }
  @media (prefers-reduced-motion: reduce){
    .wordmark .letter, .hero-co.reveal, .hero-services.reveal, .hero-foot .copy.reveal{ opacity:1 !important; transform:none !important; animation: none !important; }
    .wordmark .dash-l, .wordmark .dash-r{ opacity:1 !important; transform: scaleX(1) !important; animation: none !important; }
    .reveal{ opacity:1 !important; transform:none !important; }
  }
  .wordmark .letter:nth-child(1){ animation-delay:.05s }
  .wordmark .letter:nth-child(2){ animation-delay:.15s }
  .wordmark .letter:nth-child(3){ animation-delay:.25s }
  .wordmark .letter:nth-child(4){ animation-delay:.35s }
  .wordmark .letter:nth-child(5){ animation-delay:.45s }
  .wordmark .dash-l, .wordmark .dash-r{
    width: clamp(40px, 9vw, 130px); height: 2px; background: var(--ink); opacity:0;
    animation: stretch 1.2s cubic-bezier(.2,.7,.2,1) .55s forwards;
  }
  @keyframes rise{ to{ opacity:1; transform:none; } }
  @keyframes stretch{ from{ transform: scaleX(0); } to{ opacity:1; transform: scaleX(1); } }
  .wordmark .dash-l{ transform-origin: right center; }
  .wordmark .dash-r{ transform-origin: left center; }

  .hero-co{
    font-family: var(--font-display);
    font-size: clamp(18px, 1.8vw, 26px);
    letter-spacing: .6em;
    padding-left: .6em;
    margin-top: -.4em;
  }
  .hero-services{
    display:flex; gap: 20px; align-items:center;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: clamp(16px, 1.6vw, 22px);
    color: var(--ink-soft);
    margin-top: 8px;
  }
  .hero-services .sep{ width: 5px; height: 5px; background: var(--olive); border-radius: 50%; display:inline-block; }

  .hero-foot{
    display:grid; grid-template-columns: 1fr auto 1fr; align-items: end; gap: 24px;
    padding-top: 40px; border-top: 1px solid var(--rule-soft); margin-top: clamp(60px, 12vh, 140px);
  }
  .hero-foot .copy{
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 17px;
    color: var(--ink-soft);
    max-width: 280px;
    line-height: 1.5;
  }
  .hero-foot .copy.right{ justify-self: end; text-align: right; }
  .scroll-cue{ display:flex; flex-direction: column; align-items: center; gap: 12px; }
  .scroll-cue .line{ width:1px; height: 56px; background: var(--ink); position: relative; overflow: hidden; }
  .scroll-cue .line::after{
    content:""; position:absolute; left:0; right:0; top: -30%; height: 30%; background: var(--bone);
    animation: scrollPulse 2.4s ease-in-out infinite;
  }
  @keyframes scrollPulse{ 0%{ top:-30%; } 100%{ top:120%; } }
  .scroll-cue .label{ font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--ink-soft); }

  /* Decorative seals tucked at hero corners */
  .hero-seal{
    position: absolute; top: clamp(220px, 26vh, 280px); right: var(--pad-x);
    width: 96px; height: 120px;
    border: 1px solid var(--ink); border-radius: 50%/35%;
    display:flex; align-items:center; justify-content:center;
    flex-direction: column;
    font-family: var(--font-display);
    pointer-events:none;
    animation: gentleFloat 8s ease-in-out infinite;
  }
  .hero-seal .A{ font-size: 40px; line-height: 1; }
  .hero-seal .under{ width: 22px; height: 1px; background: var(--ink); margin: 6px 0 6px; }
  .hero-seal .co{ font-size: 8px; letter-spacing: .35em; color: var(--ink-soft); font-family: var(--font-sans); text-transform: uppercase; }
  @keyframes gentleFloat{ 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-8px); } }

  @media (max-width: 1100px){
    .hero-seal{ display:none; }
  }
  @media (max-width: 720px){
    .hero-eyebrows{ font-size: 10px; }
    .hero-foot{ grid-template-columns: 1fr; text-align: center; }
    .hero-foot .copy, .hero-foot .copy.right{ justify-self: center; text-align: center; }
  }

  /* =================== SECTION SHELLS =================== */
  section{ padding: clamp(80px, 14vh, 160px) var(--pad-x); position: relative; }
  .section-head{ display:flex; flex-direction: column; align-items: flex-start; gap: 14px; margin-bottom: 64px; }
  .section-head .num{ font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-lg); color: var(--olive); text-transform: uppercase; }
  .section-title{
    font-family: var(--font-display);
    font-size: clamp(40px, 6.4vw, 96px);
    line-height: .98;
    letter-spacing: .015em;
    font-weight: 400;
    margin: 0;
    max-width: 14ch;
  }
  .section-title .it{ font-family: var(--font-serif); font-style: italic; font-weight: 300; }

  /* =================== MANIFIESTO =================== */
  .manifiesto{ background: var(--bone-soft); }
  .manifiesto-inner{
    display:grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 8vw, 120px); align-items: start;
  }
  .manifiesto .lede{
    font-family: var(--font-serif);
    font-size: clamp(24px, 2.6vw, 36px);
    line-height: 1.35;
    font-weight: 400;
    color: var(--ink);
    margin: 0;
  }
  .manifiesto .lede em{ font-style: italic; color: var(--olive); }
  .manifiesto .body{ font-size: 17px; line-height: 1.7; color: var(--ink-soft); }
  .manifiesto .body p + p{ margin-top: 1.1em; }
  .signature{ margin-top: 36px; display:flex; align-items: center; gap: 16px; }
  .signature .swash{ font-family: var(--font-display); font-style: italic; font-size: 32px; }
  .signature .who{ font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase; color: var(--ink-soft); }
  @media (max-width: 860px){
    .manifiesto-inner{ grid-template-columns: 1fr; }
  }

  /* =================== SERVICIOS =================== */
  .servicios .grid{
    display:grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  }
  .service{
    padding: 56px 40px 64px; border-left: 1px solid var(--rule);
    display:flex; flex-direction: column; gap: 24px; position: relative;
    transition: background .4s ease;
  }
  .service:first-child{ border-left: 0; }
  .service:hover{ background: var(--bone-soft); }
  .service .ix{
    font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--olive);
  }
  .service h3{
    font-family: var(--font-display); font-weight: 400; font-size: clamp(36px, 4.4vw, 56px); line-height: 1; margin: 0; letter-spacing: .015em;
  }
  .service .blurb{ color: var(--ink-soft); margin: 0; }
  .service ul{ list-style: none; padding: 0; margin: 12px 0 0; display:flex; flex-direction: column; gap: 10px; }
  .service ul li{
    font-family: var(--font-serif); font-style: italic; font-size: 17px; color: var(--ink);
    padding-left: 22px; position: relative;
  }
  .service ul li::before{
    content:""; position: absolute; left: 0; top: 14px; width: 12px; height: 1px; background: var(--olive);
  }
  .service .arrow{
    margin-top: auto; padding-top: 28px; display:inline-flex; gap: 10px; align-items: center;
    font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase;
    color: var(--ink); transition: transform .4s ease;
  }
  .service .arrow svg{ transition: transform .4s ease; }
  .service:hover .arrow svg{ transform: translateX(8px); }

  @media (max-width: 860px){
    .servicios .grid{ grid-template-columns: 1fr; }
    .service{ border-left: 0; border-top: 1px solid var(--rule); }
    .service:first-child{ border-top: 0; }
  }

  /* =================== PORTAFOLIO =================== */
  .portafolio{ background: var(--bone); }
  .port-head{ display:grid; grid-template-columns: 1fr auto; align-items: end; gap: 30px; margin-bottom: 56px; }
  .port-filters{ display:flex; gap: 8px; flex-wrap: wrap; }
  .port-filters button{
    font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase;
    padding: 9px 16px; border: 1px solid var(--rule); border-radius: 999px; color: var(--ink-soft);
    transition: all .3s ease;
  }
  .port-filters button:hover{ color: var(--ink); border-color: var(--ink); }
  .port-filters button.active{ background: var(--ink); color: var(--bone); border-color: var(--ink); }

  .port-grid{
    display:grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: 90px;
    gap: 18px;
  }
  .port-card{
    position: relative; overflow: hidden;
    background: var(--linen);
    transition: transform .6s cubic-bezier(.2,.7,.2,1), opacity .4s ease;
  }
  .port-card.hide{ display: none; }
  .port-card .meta{
    position: absolute; left: 22px; right: 22px; bottom: 22px;
    color: var(--bone); z-index: 2;
    display:flex; align-items: flex-end; justify-content: space-between; gap: 12px;
    opacity: 0; transform: translateY(8px);
    transition: opacity .5s ease, transform .5s ease;
  }
  .port-card:hover .meta{ opacity: 1; transform: none; }
  .port-card .meta .ttl{ font-family: var(--font-display); font-size: 26px; line-height: 1; }
  .port-card .meta .loc{ font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-md); text-transform: uppercase; opacity:.85; }
  .port-card .shade{
    position:absolute; inset:0; background: linear-gradient(180deg, transparent 50%, rgba(28,28,28,.55) 100%); opacity: 0;
    transition: opacity .5s ease; z-index: 1;
  }
  .port-card:hover .shade{ opacity: 1; }
  .port-card image-slot{ width: 100%; height: 100%; }

  /* asymmetric placement */
  .p1{ grid-column: span 7; grid-row: span 5; }
  .p2{ grid-column: span 5; grid-row: span 5; }
  .p3{ grid-column: span 4; grid-row: span 4; }
  .p4{ grid-column: span 4; grid-row: span 4; }
  .p5{ grid-column: span 4; grid-row: span 4; }
  .p6{ grid-column: span 6; grid-row: span 4; }
  .p7{ grid-column: span 6; grid-row: span 4; }

  @media (max-width: 860px){
    .port-grid{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
    .p1,.p2,.p3,.p4,.p5,.p6,.p7{ grid-column: span 2; grid-row: span 2; }
  }

  /* =================== PROCESO =================== */
  .proceso{ background: var(--ink); color: var(--bone); }
  .proceso .section-head .num{ color: var(--sage); }
  .proceso .section-title{ color: var(--bone); }
  .proceso .grid{
    display:grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid rgba(241,237,228,.18);
  }
  .proceso .step{
    padding: 48px 32px 56px;
    border-right: 1px solid rgba(241,237,228,.18);
    display:flex; flex-direction: column; gap: 18px;
    position: relative;
  }
  .proceso .step:last-child{ border-right: 0; }
  .proceso .step .num{
    font-family: var(--font-display); font-size: 72px; line-height: 1; color: var(--sage);
  }
  .proceso .step h4{
    font-family: var(--font-display); font-weight: 400; font-size: 28px; margin: 0; letter-spacing: .015em;
  }
  .proceso .step p{ margin: 0; color: rgba(241,237,228,.7); font-size: 16px; line-height: 1.65; }
  .proceso .step .stage{ font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--sage); }
  @media (max-width: 860px){
    .proceso .grid{ grid-template-columns: 1fr 1fr; }
    .proceso .step:nth-child(2n){ border-right: 0; }
    .proceso .step{ border-bottom: 1px solid rgba(241,237,228,.18); }
  }

  /* =================== TESTIMONIOS =================== */
  .testimonios{ background: var(--linen); }
  .quote-wrap{
    max-width: 920px; margin: 0 auto; text-align: center;
    display:flex; flex-direction: column; gap: 32px; align-items: center;
  }
  .quote-mark{ font-family: var(--font-display); font-size: 96px; line-height: .3; color: var(--olive); }
  .quote{
    font-family: var(--font-serif); font-style: italic; font-weight: 300;
    font-size: clamp(24px, 3vw, 40px); line-height: 1.35;
    min-height: 4em;
    transition: opacity .5s ease;
  }
  .quote-author{ display:flex; flex-direction: column; gap: 4px; align-items: center; }
  .quote-author .name{ font-family: var(--font-display); font-size: 22px; letter-spacing: .04em; }
  .quote-author .role{ font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase; color: var(--ink-soft); }
  .quote-dots{ display:flex; gap: 10px; margin-top: 24px; }
  .quote-dots button{ width: 24px; height: 1px; background: var(--ink); opacity:.3; transition: opacity .3s ease; }
  .quote-dots button.active{ opacity: 1; }

  /* =================== CONTACTO =================== */
  .contacto{ background: var(--bone-soft); }
  .contacto-inner{ display:grid; grid-template-columns: 1.1fr 1fr; gap: clamp(40px, 6vw, 96px); align-items: start; }
  .contacto h2{ margin: 0 0 24px; }
  .contacto .lede{ font-family: var(--font-serif); font-style: italic; font-size: clamp(20px, 2vw, 26px); line-height: 1.4; color: var(--ink-soft); max-width: 28ch; margin: 0 0 36px; }
  .contact-list{ list-style: none; padding: 0; margin: 0; display:flex; flex-direction: column; gap: 22px; }
  .contact-list li{ display:flex; flex-direction: column; gap: 4px; }
  .contact-list .lbl{ font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--olive); }
  .contact-list .val{ font-family: var(--font-display); font-size: 24px; letter-spacing: .02em; }

  form.booking{
    display:grid; gap: 20px;
    background: var(--bone); padding: clamp(28px, 4vw, 48px); border: 1px solid var(--rule-soft);
  }
  form.booking .row{ display:grid; gap: 20px; grid-template-columns: 1fr 1fr; }
  form.booking label{ display:flex; flex-direction: column; gap: 8px; }
  form.booking .lbl{ font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--ink-soft); }
  form.booking input, form.booking select, form.booking textarea{
    font: inherit; font-family: var(--font-serif); font-size: 18px;
    border: 0; border-bottom: 1px solid var(--rule);
    background: transparent; padding: 10px 0 10px;
    color: var(--ink); outline: none;
    transition: border-color .3s ease;
  }
  form.booking input:focus, form.booking select:focus, form.booking textarea:focus{ border-color: var(--ink); }
  form.booking textarea{ resize: vertical; min-height: 90px; }
  form.booking .submit{
    margin-top: 8px; padding: 18px 24px;
    background: var(--ink); color: var(--bone);
    font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-lg); text-transform: uppercase;
    display:inline-flex; gap: 14px; align-items: center; justify-content: center;
    transition: background .3s ease, color .3s ease, letter-spacing .4s ease;
  }
  form.booking .submit:hover{ background: var(--olive); letter-spacing: .32em; }
  form.booking .submit.sent{ background: var(--sage); color: var(--ink); }
  @media (max-width: 860px){
    .contacto-inner{ grid-template-columns: 1fr; }
    form.booking .row{ grid-template-columns: 1fr; }
  }

  /* =================== FOOTER =================== */
  footer{
    background: var(--ink); color: var(--bone);
    padding: clamp(60px, 9vh, 100px) var(--pad-x) 36px;
    position: relative;
  }
  .foot-wordmark{
    font-family: var(--font-display);
    font-size: clamp(80px, 18vw, 280px); line-height: .9; letter-spacing: .04em;
    display:flex; align-items: center; gap: clamp(20px, 4vw, 60px); justify-content: center;
    margin: 0 0 60px;
  }
  .foot-wordmark .dash{ width: clamp(40px, 10vw, 140px); height: 2px; background: var(--bone); }
  .foot-grid{
    display:grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 40px;
    padding-top: 40px; border-top: 1px solid rgba(241,237,228,.2);
  }
  .foot-grid h5{ font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--sage); margin: 0 0 18px; font-weight: 500; }
  .foot-grid ul{ list-style: none; padding: 0; margin: 0; display:flex; flex-direction: column; gap: 10px; font-family: var(--font-serif); font-size: 17px; color: rgba(241,237,228,.85); }
  .foot-grid ul a:hover{ color: var(--bone); }
  .foot-tag{ font-family: var(--font-serif); font-style: italic; font-size: 17px; color: rgba(241,237,228,.7); max-width: 28ch; line-height: 1.5; }

  .foot-rule{ border-top: 1px solid rgba(241,237,228,.2); margin-top: 60px; padding-top: 24px; display:flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
  .foot-rule .meta{ font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-md); text-transform: uppercase; color: rgba(241,237,228,.55); }

  @media (max-width: 860px){
    .foot-grid{ grid-template-columns: 1fr 1fr; }
  }

  /* =================== SCROLL REVEALS =================== */
  .reveal{ opacity: 0; transform: translateY(28px); transition: opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1); }
  .reveal.in{ opacity: 1; transform: none; }
  .reveal.delay-1{ transition-delay: .08s; }
  .reveal.delay-2{ transition-delay: .16s; }
  .reveal.delay-3{ transition-delay: .24s; }

  /* placeholder image plates (used when image-slot is empty) */
  image-slot::part(placeholder),
  image-slot{
    --is-bg: var(--linen);
  }

  /* keep selected text on-brand */
  ::selection{ background: var(--olive); color: var(--bone); }

/* =====================================================================
   BLOG · pages
   ===================================================================== */
.blog-shell { max-width: 1200px; margin: 0 auto; padding: 140px var(--pad-x) 80px; }
.blog-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 48px 32px; }
@media (max-width: 720px) { .blog-grid { grid-template-columns: 1fr; } }
.blog-card { display: flex; flex-direction: column; gap: 16px; border-top: 1px solid var(--rule-soft); padding-top: 28px; }
.blog-card .cover { width: 100%; aspect-ratio: 4 / 3; background: var(--linen); overflow: hidden; }
.blog-card .cover img { width: 100%; height: 100%; object-fit: cover; }
.blog-card h3 { font-family: var(--font-display); font-weight: 400; font-size: clamp(28px, 3vw, 38px); letter-spacing: .015em; margin: 0; line-height: 1.05; }
.blog-card .meta { font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase; color: var(--olive); }
.blog-card .excerpt { color: var(--ink-soft); font-size: 17px; line-height: 1.6; }
.blog-card .more { font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase; display: inline-flex; gap: 10px; align-items: center; }

.post-shell { max-width: 760px; margin: 0 auto; padding: 140px var(--pad-x) 80px; }
.post-shell h1 { font-family: var(--font-display); font-weight: 400; font-size: clamp(40px, 6vw, 76px); line-height: 1.02; letter-spacing: .015em; margin: 24px 0 12px; }
.post-shell .meta { font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase; color: var(--olive); margin-bottom: 32px; }
.post-shell .cover { width: 100%; aspect-ratio: 16 / 9; margin: 32px 0; background: var(--linen); overflow: hidden; }
.post-shell .cover img { width: 100%; height: 100%; object-fit: cover; }
.post-content { font-family: var(--font-serif); font-size: 19px; line-height: 1.75; color: var(--ink); }
.post-content > * + * { margin-top: 1.2em; }
.post-content h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(28px, 3.4vw, 42px); letter-spacing: .015em; margin-top: 2em; }
.post-content h3 { font-family: var(--font-display); font-weight: 400; font-size: clamp(22px, 2.4vw, 30px); letter-spacing: .015em; margin-top: 1.6em; }
.post-content a { color: var(--olive); text-decoration: underline; text-underline-offset: 3px; }
.post-content a:hover { color: var(--ink); }
.post-content blockquote { font-style: italic; border-left: 2px solid var(--olive); padding-left: 20px; color: var(--ink-soft); }
.post-content code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.9em; background: var(--bone-soft); padding: 2px 6px; border-radius: 3px; }
.post-content pre { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; background: var(--ink); color: var(--bone); padding: 20px; overflow-x: auto; font-size: 14px; line-height: 1.6; }
.post-content pre code { background: transparent; padding: 0; color: inherit; }
.post-content ul, .post-content ol { padding-left: 22px; }
.post-content li + li { margin-top: .4em; }
.post-content img { width: 100%; margin: 24px 0; }

/* Mensaje de éxito/error del formulario de contacto */
form.booking .form-msg { font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase; margin: -10px 0 0; }
form.booking .form-msg.error { color: #8a2a2a; }
form.booking .form-msg.ok { color: #3d5a32; }

/* =====================================================================
   ADMIN
   ===================================================================== */
.admin-shell { min-height: 100vh; background: var(--bone); padding: 24px clamp(20px, 4vw, 48px) 80px; }
.admin-header { display: flex; justify-content: space-between; align-items: center; padding-bottom: 24px; border-bottom: 1px solid var(--rule-soft); margin-bottom: 40px; }
.admin-header .brand { font-family: var(--font-display); font-size: 22px; letter-spacing: .3em; }
.admin-header nav { display: flex; gap: 28px; }
.admin-header nav a { font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-md); text-transform: uppercase; color: var(--ink-soft); }
.admin-header nav a:hover { color: var(--ink); }
.admin-card { background: #fff; border: 1px solid var(--rule-soft); padding: clamp(24px, 4vw, 40px); }
.admin-grid { display: grid; gap: 20px; }
.admin-grid .row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 720px) { .admin-grid .row-2 { grid-template-columns: 1fr; } }
.admin-label { font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--ink-soft); display: block; margin-bottom: 8px; }
.admin-input, .admin-textarea, .admin-select { width: 100%; font: inherit; font-family: var(--font-serif); font-size: 17px; border: 1px solid var(--rule); background: #fff; padding: 12px 14px; color: var(--ink); outline: none; transition: border-color .2s ease; }
.admin-input:focus, .admin-textarea:focus, .admin-select:focus { border-color: var(--ink); }
.admin-textarea { min-height: 280px; resize: vertical; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 14px; line-height: 1.6; }
.admin-btn { padding: 14px 24px; background: var(--ink); color: var(--bone); font-family: var(--font-sans); font-size: 11px; letter-spacing: var(--tracking-lg); text-transform: uppercase; cursor: pointer; border: 0; transition: background .2s ease; display: inline-block; text-decoration: none; }
.admin-btn:hover { background: var(--olive); }
.admin-btn.ghost { background: transparent; color: var(--ink); border: 1px solid var(--rule); }
.admin-btn.ghost:hover { background: var(--bone-soft); }
.admin-btn.danger { background: #8a2a2a; }
.admin-btn.danger:hover { background: #6e1f1f; }
.admin-btn:disabled { opacity: .5; cursor: not-allowed; }
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th, .admin-table td { text-align: left; padding: 14px 12px; border-bottom: 1px solid var(--rule-soft); font-size: 15px; }
.admin-table th { font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-lg); text-transform: uppercase; color: var(--ink-soft); }
.admin-pill { display: inline-block; padding: 4px 10px; font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--tracking-md); text-transform: uppercase; border-radius: 999px; }
.admin-pill.draft { background: var(--bone-soft); color: var(--ink-soft); }
.admin-pill.published { background: var(--sage); color: var(--ink); }
.admin-notice { padding: 14px 18px; font-family: var(--font-sans); font-size: 12px; letter-spacing: var(--tracking-md); text-transform: uppercase; margin-bottom: 24px; }
.admin-notice.error { background: #fdecec; color: #8a2a2a; border: 1px solid #f3c8c8; }
.admin-notice.success { background: #eaf1e7; color: #3d5a32; border: 1px solid #c7d6bf; }
.login-shell { min-height: 100vh; display: grid; place-items: center; background: var(--bone); padding: 24px; }
.login-card { width: 100%; max-width: 420px; background: #fff; border: 1px solid var(--rule-soft); padding: 48px 36px; }
.login-card h1 { font-family: var(--font-display); font-weight: 400; font-size: 36px; margin: 0 0 24px; }
