:root{
    --paper:#FBF8F2;--paper-2:#F2ECE0;--paper-3:#E8E0D0;
    --ink:#181410;--ink-2:#403930;--muted:#766D5F;
    --gold:#7C5E30;--gold-2:#C7A86B;--gold-soft:#E4D2AC;
    --line:rgba(24,20,16,.12);--line-2:rgba(24,20,16,.06);
    --wa:#25D366;
    --serif:'Cormorant Garamond',Georgia,serif;
    --sans:'Jost',system-ui,sans-serif;
    --pad:clamp(1.4rem,5vw,5rem);
    --maxw:1200px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:300;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  body:not(.ready){overflow:hidden;height:100vh}
  img{max-width:100%;display:block}
  a{color:inherit}
  ::selection{background:var(--gold-soft);color:var(--ink)}
  body::after{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='90'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

  .overline{font-family:var(--sans);font-weight:400;text-transform:uppercase;letter-spacing:.4em;font-size:.66rem;color:var(--gold)}

  /* ---------- INTRO ---------- */
  #intro{position:fixed;inset:0;z-index:200;background:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.1rem;opacity:1;transition:opacity 1s cubic-bezier(.7,0,.3,1),transform 1s cubic-bezier(.7,0,.3,1),visibility 1s}
  body.ready #intro{opacity:0;visibility:hidden;transform:translateY(-12px);pointer-events:none}
  .ring-svg{width:148px;height:auto;overflow:visible}
  .ring-svg .draw{fill:none;stroke:var(--ink);stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1;stroke-dashoffset:1;animation:draw var(--d,1.6s) cubic-bezier(.45,.05,.25,1) forwards var(--delay,0s)}
  .ring-svg .gem-stroke{stroke:var(--gold)}
  @keyframes draw{to{stroke-dashoffset:0}}
  .ring-svg .gem-fill{fill:url(#shine);opacity:0;animation:gemFill 1.1s ease forwards 1.4s}
  @keyframes gemFill{to{opacity:1}}
  .ring-svg .sparkle{opacity:0;transform-box:fill-box;transform-origin:center}
  .ring-svg .s1{animation:spark 1.4s ease-out 1.5s 1}
  .ring-svg .s2{animation:spark 1.4s ease-out 1.7s 1}
  @keyframes spark{0%{opacity:0;transform:scale(0) rotate(0)}45%{opacity:1;transform:scale(1) rotate(15deg)}100%{opacity:0;transform:scale(.5) rotate(25deg)}}
  .intro-name{text-align:center;opacity:0;animation:fadeUp 1.1s ease forwards 1.25s}
  .intro-name .o{display:block;margin-bottom:.55rem}
  .intro-name .n{font-family:var(--serif);font-weight:400;font-size:clamp(2.3rem,9vw,3.5rem);letter-spacing:.02em;line-height:1}
  @keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

  /* ---------- NAV ---------- */
  nav{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;justify-content:space-between;padding:1.2rem var(--pad);opacity:0;transform:translateY(-10px);transition:opacity .9s ease .2s,transform .9s ease .2s,background .4s,box-shadow .4s,padding .4s,color .4s;color:#FBF8F2}
  body.ready nav{opacity:1;transform:none}
  nav.scrolled{background:var(--paper);color:var(--ink);box-shadow:0 1px 0 var(--line);padding-top:.85rem;padding-bottom:.85rem}
  nav .brand{font-family:var(--serif);font-size:1.45rem;letter-spacing:.04em;text-decoration:none;cursor:pointer;line-height:1.05;text-shadow:0 1px 12px rgba(18,15,11,.45)}
  nav.scrolled .brand{text-shadow:none}
  nav .brand small{display:block;font-family:var(--sans);font-size:.5rem;letter-spacing:.34em;text-transform:uppercase;opacity:.8;margin-top:7px}
  .nav-links{display:none;gap:2.4rem}
  .nav-links a{font-family:var(--sans);font-weight:400;font-size:.74rem;text-transform:uppercase;letter-spacing:.2em;color:inherit;text-decoration:none;position:relative;padding-bottom:3px;cursor:pointer;background:none;border:none;opacity:.92}
  .lang{display:inline-flex;align-items:center;gap:.25rem;font-family:var(--sans);font-weight:500;font-size:.66rem;letter-spacing:.12em;color:inherit;background:none;border:1px solid currentColor;border-radius:100px;padding:.3rem .6rem;cursor:pointer;opacity:.92;transition:opacity .3s,background .3s,color .3s;margin-left:auto}
  @media(min-width:760px){.lang{margin-left:0}}
  .lang:hover{opacity:1}
  .lang .on{color:var(--gold-2)}
  .lang .off{opacity:.5}
  nav.scrolled .lang .on{color:var(--gold)}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .4s ease}
  .nav-links a:hover{opacity:1}.nav-links a:hover::after{width:100%}
  .burger{width:30px;height:16px;position:relative;cursor:pointer;background:none;border:none;padding:0;margin-left:1rem}
  .burger span{position:absolute;left:0;height:1.5px;width:100%;background:currentColor;transition:.35s ease}
  .burger span:nth-child(1){top:0}.burger span:nth-child(2){top:7px}.burger span:nth-child(3){top:14px}
  body.menu-open .burger span:nth-child(1){top:7px;transform:rotate(45deg)}
  body.menu-open .burger span:nth-child(2){opacity:0}
  body.menu-open .burger span:nth-child(3){top:7px;transform:rotate(-45deg)}
  #menu{position:fixed;inset:0;z-index:80;background:var(--paper);color:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;opacity:0;visibility:hidden;transform:translateY(-2%);transition:.45s cubic-bezier(.2,.7,.2,1)}
  body.menu-open #menu{opacity:1;visibility:visible;transform:none}
  #menu a{font-family:var(--serif);font-size:2.2rem;font-weight:300;text-decoration:none;cursor:pointer}
  #menu .overline{margin-top:1.3rem}

  /* ---------- STRUCTURE ---------- */
  .view{position:relative;z-index:2}
  section{padding:clamp(4.5rem,12vw,9rem) var(--pad);position:relative}
  /* el navegador no renderiza estas secciones hasta acercarse a ellas (carga más fluida) */
  .story,.workshop,.reviews,.visit,.contact{content-visibility:auto;contain-intrinsic-size:1px 720px}
  .wrap{max-width:var(--maxw);margin:0 auto}
  .dark{background:var(--ink);color:var(--paper)}
  .dark .overline{color:var(--gold-2)}
  .tint{background:var(--paper-2)}
  /* unified section header */
  .head{margin-bottom:clamp(2.6rem,6vw,4.2rem)}
  .head .overline{display:inline-flex;align-items:center;gap:.85rem}
  .head .overline::before{content:"";width:30px;height:1px;background:var(--gold)}
  .head h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.3rem,6.5vw,4.2rem);line-height:1.02;letter-spacing:-.02em;margin-top:1.1rem;max-width:18ch}
  .head p{color:var(--ink-2);font-size:1.04rem;line-height:1.8;max-width:48ch;margin-top:1.2rem}
  .dark .head p{color:#C6BEAF}
  .head.ctr{text-align:center}
  .head.ctr .overline{justify-content:center}
  .head.ctr h2{margin-left:auto;margin-right:auto}
  .head.ctr p{margin-left:auto;margin-right:auto}

  .btn{display:inline-flex;align-items:center;gap:.7rem;padding:1.05rem 2.4rem;border:1px solid currentColor;font-family:var(--sans);font-weight:400;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;background:none;cursor:pointer;color:var(--ink);transition:background .45s,color .45s,box-shadow .45s,transform .3s}
  .btn:hover{background:var(--ink);color:var(--paper);box-shadow:0 18px 36px -18px rgba(24,20,16,.55);transform:translateY(-2px)}
  .btn .ar{transition:transform .35s}.btn:hover .ar{transform:translateX(4px)}
  .dark .btn{color:var(--paper)}
  .dark .btn:hover{background:var(--gold-2);color:var(--ink);border-color:var(--gold-2);box-shadow:0 18px 36px -18px rgba(199,168,107,.6)}
  .center{text-align:center;margin-top:clamp(2.8rem,6vw,4.2rem)}

  .reveal{opacity:0;transform:translateY(28px) translateZ(0);backface-visibility:hidden;transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:translateZ(0)}
  .reveal.d1{transition-delay:.09s}.reveal.d2{transition-delay:.18s}.reveal.d3{transition-delay:.27s}.reveal.d4{transition-delay:.36s}.reveal.d5{transition-delay:.45s}

  /* ---------- HERO ---------- */
  .hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 var(--pad) calc(clamp(3.8rem,12vh,7.5rem) + env(safe-area-inset-bottom));color:#FBF8F2;overflow:hidden}
  .hero .bg{position:absolute;inset:0;z-index:-2}
  .hero .bg img{width:100%;height:100%;object-fit:cover;transform:scale(1) translateZ(0)}
  body.ready .hero .bg img{animation:kenburns 32s ease-out forwards}
  @keyframes kenburns{from{transform:scale(1) translateZ(0)}to{transform:scale(1.06) translateZ(0)}}
  .hero::after{content:"";position:absolute;inset:0;z-index:-1;background:
    linear-gradient(180deg,rgba(16,13,9,.62) 0%,rgba(16,13,9,.26) 24%,rgba(16,13,9,.16) 48%,rgba(16,13,9,.5) 74%,rgba(16,13,9,.84) 100%)}
  .hero-inner{max-width:var(--maxw);margin:0 auto;width:100%}
  .hero .overline{color:#ECE3D2;font-size:.64rem;letter-spacing:.28em;opacity:0;text-shadow:0 1px 10px rgba(16,13,9,.4)}
  body.ready .hero .overline{animation:fadeUp 1s ease forwards .15s}
  .hero .htag{display:inline-flex;flex-wrap:wrap;align-items:center}
  .hero .htag i{font-style:normal;display:inline-flex;align-items:center}
  .hero .htag i:not(:first-child)::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--gold-2);margin:0 .9rem;box-shadow:0 0 6px rgba(199,168,107,.6)}
  .hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(4.4rem,25vw,13rem);line-height:.85;letter-spacing:-.02em;margin:.5rem 0 1.1rem;opacity:0;text-shadow:0 2px 30px rgba(16,13,9,.4)}
  body.ready .hero h1{animation:fadeUp 1.1s ease forwards .3s}
  .hero .tagline{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.3rem,5.5vw,2.1rem);line-height:1.3;color:#F1EADC;max-width:24ch;opacity:0;text-shadow:0 1px 16px rgba(16,13,9,.4)}
  body.ready .hero .tagline{animation:fadeUp 1.1s ease forwards .55s}
  .hero .scroll{display:none;position:absolute;left:50%;bottom:1.5rem;transform:translateX(-50%);flex-direction:column;align-items:center;gap:.5rem;opacity:0}
  body.ready .hero .scroll{animation:fadeUp 1.1s ease forwards .9s}
  .hero .scroll span{font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:#ECE3D2}
  .hero .scroll i{width:1px;height:38px;background:linear-gradient(var(--gold-2),transparent);display:block;animation:scrolldot 2.2s ease-in-out infinite}
  @keyframes scrolldot{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

  /* ---------- MARQUEE ---------- */
  .marquee{background:var(--ink);color:var(--paper);overflow:hidden;padding:1.1rem 0;border-block:1px solid rgba(255,255,255,.08)}
  .marquee .track{display:flex;width:max-content;backface-visibility:hidden;transform:translateZ(0)}
  body.ready .marquee .track{will-change:transform;animation:scrollx 60s linear infinite}
  .marquee:hover .track{animation-play-state:paused}
  .marquee .group{display:flex;flex:0 0 auto;align-items:center}
  .marquee .group>span{display:inline-flex;align-items:center;font-family:var(--serif);font-weight:400;font-size:1.2rem;letter-spacing:.015em;color:#EFE7D6;white-space:nowrap}
  .marquee .group>span::after{content:"";display:inline-block;width:5px;height:5px;margin:0 2.4rem;background:var(--gold-2);transform:rotate(45deg);opacity:.85;flex:0 0 auto}
  @keyframes scrollx{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}

  /* ---------- ESCAPARATE ---------- */
  .showcase{display:none;position:relative;overflow:hidden;background:var(--ink);color:var(--paper);padding:clamp(4rem,10vw,7rem) var(--pad)}
  .showcase.on{display:block}
  .showcase::before{content:"";position:absolute;inset:0;background:
    radial-gradient(120% 90% at 85% 0%,rgba(199,168,107,.18),transparent 55%),
    radial-gradient(90% 90% at 0% 100%,rgba(199,168,107,.08),transparent 50%);pointer-events:none}
  .showcase .swrap{max-width:var(--maxw);margin:0 auto;position:relative}
  .showcase .shead{text-align:center;margin-bottom:clamp(2.4rem,6vw,3.6rem)}
  .showcase .stag{font-family:var(--sans);font-weight:400;text-transform:uppercase;letter-spacing:.3em;font-size:.64rem;color:var(--gold-2);display:inline-flex;align-items:center;gap:.7rem}
  .showcase .stag::before,.showcase .stag::after{content:"";width:18px;height:1px;background:var(--gold-2);opacity:.6}
  .showcase .shead h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.1rem,6.5vw,3.8rem);line-height:1.04;letter-spacing:-.02em;margin-top:1rem;color:var(--paper)}
  .showcase .shead p{color:#C6BEAF;font-size:1rem;line-height:1.7;max-width:44ch;margin:1.1rem auto 0}
  .sgrid{display:flex;gap:clamp(.9rem,2.5vw,1.5rem);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.3rem .3rem 1.4rem;margin:0 -.3rem;scroll-padding-left:.3rem}
  .sgrid::-webkit-scrollbar{display:none}
  .gift{text-decoration:none;color:inherit;display:block;cursor:pointer;flex:0 0 64%;max-width:280px;scroll-snap-align:start}
  .gift .frame{position:relative;aspect-ratio:1/1;overflow:hidden;background:radial-gradient(125% 90% at 50% 16%,#FFFEFB,var(--paper-2) 60%,var(--paper-3));display:flex;align-items:center;justify-content:center;transition:transform .55s cubic-bezier(.2,.7,.2,1),box-shadow .55s}
  .gift .frame::before{content:"";position:absolute;inset:10px;border:1px solid rgba(199,168,107,.35);pointer-events:none;z-index:2;transition:inset .5s ease,border-color .5s}
  .gift:hover .frame::before{inset:7px;border-color:rgba(199,168,107,.7)}
  .gift .frame svg{width:42%;height:auto;opacity:.92;transition:transform .65s cubic-bezier(.2,.7,.2,1)}
  .gift .frame::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 55% at 50% 34%,rgba(199,168,107,.28),transparent 72%);opacity:0;transition:opacity .55s}
  .gift:hover .frame{transform:translateY(-7px);box-shadow:0 28px 50px -22px rgba(0,0,0,.6)}
  .gift:hover .frame svg{transform:scale(1.08)}
  .gift:hover .frame::after{opacity:1}
  .gift .meta{margin-top:1rem}
  .gift .meta .top{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem}
  .gift .name{font-family:var(--serif);font-size:clamp(1.25rem,4.8vw,1.6rem);font-weight:400;line-height:1.1;color:var(--paper);transition:color .35s}
  .gift .go{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:#B7AE9F;white-space:nowrap;transition:color .35s,transform .35s}
  .gift .note{display:block;margin-top:.35rem;font-family:var(--sans);font-weight:300;font-size:.82rem;letter-spacing:.02em;color:#C6BEAF;line-height:1.4}
  .gift:hover .name{color:var(--gold-2)}
  .gift:hover .go{color:var(--gold-2);transform:translateX(3px)}
  .scarousel{position:relative}
  .snav{display:none;position:absolute;top:38%;transform:translateY(-50%);z-index:4;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(24,20,16,.6);color:var(--paper);align-items:center;justify-content:center;cursor:pointer;transition:background .35s,border-color .35s,color .35s,opacity .35s}
  .snav:hover{background:var(--gold-2);color:var(--ink);border-color:var(--gold-2)}
  .snav svg{width:20px;height:20px}
  .snav.prev{left:-10px}.snav.next{right:-10px}
  .snav[disabled]{opacity:.25;cursor:default;pointer-events:none}
  .sprog{height:2px;background:rgba(255,255,255,.14);border-radius:2px;margin-top:.4rem;overflow:hidden}
  .sprog span{display:block;height:100%;width:30%;background:var(--gold-2);border-radius:2px;transition:width .25s,transform .25s}
  .showcase .sfoot{text-align:center;margin-top:clamp(2.6rem,6vw,3.8rem)}
  .showcase .sfoot .btn{color:var(--paper)}
  .showcase .sfoot .btn:hover{background:var(--gold-2);color:var(--ink);border-color:var(--gold-2);box-shadow:0 18px 36px -18px rgba(199,168,107,.6)}

  /* ---------- HISTORIA + STATS ---------- */
  .story .top{display:grid;grid-template-columns:1fr;gap:clamp(2.2rem,5vw,4.5rem);align-items:center}
  .story .photo{position:relative;overflow:hidden}
  .story .photo::before{content:"";position:absolute;inset:14px;border:1px solid rgba(251,248,242,.5);z-index:2;pointer-events:none}
  .story .photo img{width:100%;height:auto;transform:scale(1.12);transition:transform 1.5s cubic-bezier(.2,.7,.2,1)}
  .story .photo::after{content:"";position:absolute;inset:0;background:var(--paper);transform-origin:right;transition:transform 1.05s cubic-bezier(.7,0,.3,1);z-index:3}
  .story .photo.in img{transform:scale(1)}
  .story .photo.in::after{transform:scaleX(0)}
  .story .lead h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.1rem,6vw,3.6rem);line-height:1.04;letter-spacing:-.02em}
  .story .lead p{color:var(--ink-2);font-size:1.04rem;line-height:1.85;margin-top:1.3rem;max-width:50ch}
  .story .sign{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--ink);margin-top:1.4rem}
  .stats{display:flex;margin-top:clamp(2.6rem,6vw,4.2rem);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .stat{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.6rem .5rem;border-right:1px solid var(--line)}
  .stat:last-child{border-right:0}
  .stat .num{font-family:var(--serif);font-weight:300;font-size:clamp(2rem,8vw,3.4rem);line-height:1;color:var(--ink);white-space:nowrap}
  .stat .num em{font-style:normal;color:var(--gold);font-size:.78em;margin-right:.06em}
  .stat .lbl{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.75rem;line-height:1.4}

  /* ---------- COLECCIÓN (cards) ---------- */
  .pgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.9rem,2.5vw,1.8rem)}
  .pcard{text-decoration:none;color:inherit;display:block;cursor:pointer}
  .pcard .frame{position:relative;aspect-ratio:1/1;overflow:hidden;background:radial-gradient(125% 90% at 50% 14%,#FFFFFF,var(--paper) 55%,var(--paper-2));border:1px solid var(--line);display:flex;align-items:center;justify-content:center;box-shadow:0 1px 2px rgba(24,20,16,.03);transition:transform .55s cubic-bezier(.2,.7,.2,1),box-shadow .55s,border-color .55s}
  .pcard .frame::before{content:"";position:absolute;inset:11px;border:1px solid rgba(156,122,67,.22);pointer-events:none;transition:inset .5s ease,border-color .5s}
  .pcard:hover .frame::before{inset:8px;border-color:rgba(156,122,67,.5)}
  .pcard .idx{position:absolute;top:.9rem;left:1rem;z-index:2;font-family:var(--serif);font-size:.85rem;color:var(--muted);letter-spacing:.05em}
  .pcard .frame svg{width:42%;height:auto;opacity:.85;transition:transform .65s cubic-bezier(.2,.7,.2,1),opacity .4s}
  .pcard .frame::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 55% at 50% 32%,rgba(199,168,107,.24),transparent 72%);opacity:0;transition:opacity .55s}
  .pcard:hover .frame{transform:translateY(-7px);box-shadow:0 28px 52px -24px rgba(24,20,16,.42);border-color:rgba(156,122,67,.45)}
  .pcard:hover .frame svg{transform:scale(1.08);opacity:1}
  .pcard:hover .frame::after{opacity:1}
  .pcard .meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:1.05rem;gap:.6rem;padding-bottom:.45rem;border-bottom:1px solid transparent;transition:border-color .4s}
  .pcard:hover .meta{border-color:var(--line)}
  .pcard .name{font-family:var(--serif);font-size:clamp(1.2rem,4.5vw,1.6rem);font-weight:400;line-height:1.1;transition:color .35s}
  .pcard .go{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);white-space:nowrap;transition:color .35s,transform .35s}
  .pcard:hover .name{color:var(--gold)}
  .pcard:hover .go{color:var(--gold);transform:translateX(3px)}

  /* ---------- TALLER (dark) ---------- */
  .workshop .grid{display:grid;grid-template-columns:1fr;gap:clamp(2.4rem,6vw,4.5rem);align-items:center}
  .workshop .photo{position:relative;overflow:hidden;aspect-ratio:4/3}
  .workshop .photo::before{content:"";position:absolute;inset:14px;border:1px solid rgba(199,168,107,.35);z-index:2;pointer-events:none}
  .workshop .photo img{width:100%;height:100%;object-fit:cover;transform:scale(1.12);transition:transform 1.6s cubic-bezier(.2,.7,.2,1)}
  .workshop .photo.in img{transform:scale(1)}
  .svc-list{list-style:none;margin-top:2rem}
  .svc{display:flex;gap:1.1rem;align-items:flex-start;padding:1.3rem 0;border-top:1px solid rgba(255,255,255,.12)}
  .svc:last-child{border-bottom:1px solid rgba(255,255,255,.12)}
  .svc .ic{flex:0 0 auto;width:44px;height:44px;border:1px solid rgba(199,168,107,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .4s,border-color .4s}
  .svc:hover .ic{background:rgba(199,168,107,.12);border-color:var(--gold-2)}
  .svc .ic svg{width:21px;height:21px}
  .svc .tx h3{font-family:var(--serif);font-weight:400;font-size:1.35rem;line-height:1.1;margin-bottom:.25rem}
  .svc .tx p{font-size:.9rem;line-height:1.55;color:#C8C0B2}

  /* ---------- RESEÑAS ---------- */
  .reviews{text-align:center}
  .reviews .rate{margin:1.3rem 0 .45rem}
  .reviews .rate .stars{color:var(--gold);letter-spacing:.34em;font-size:1.1rem}
  .reviews .rsub{color:var(--muted);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase}
  .rgrid{display:grid;grid-template-columns:1fr;gap:clamp(1.6rem,4vw,2.8rem);text-align:left;margin-top:clamp(3rem,7vw,4.8rem)}
  .review{border-top:1px solid var(--line);padding-top:1.6rem}
  .review .stars{color:var(--gold);letter-spacing:.16em;font-size:.74rem;margin-bottom:.9rem}
  .review p{font-family:var(--serif);font-style:italic;font-size:1.18rem;line-height:1.55;color:var(--ink-2)}
  .review .who{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:1.1rem}

  /* ---------- VISÍTANOS ---------- */
  .visit .grid{display:grid;grid-template-columns:1fr;gap:clamp(1.8rem,5vw,3.5rem);align-items:start}
  .map-card{display:block;position:relative;text-decoration:none;border:1px solid var(--line);overflow:hidden;background:var(--paper-2)}
  .map-card iframe{display:block;width:100%;height:320px;border:0;filter:grayscale(.3) contrast(.95)}
  .map-card .open-map{position:absolute;left:1rem;bottom:1rem;display:inline-flex;align-items:center;gap:.5rem;background:var(--paper);color:var(--ink);padding:.7rem 1.1rem;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;box-shadow:0 6px 20px rgba(24,20,16,.18)}
  .addr .row{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1.05rem;color:var(--ink-2);font-size:1rem;line-height:1.55}
  .addr .row svg{flex:0 0 auto;margin-top:3px}
  .addr .row a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--gold)}
  .hours{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);padding:1.5rem 1.6rem;margin-top:1.8rem;box-shadow:0 18px 40px -28px rgba(24,20,16,.5)}
  .hours .htitle{display:flex;align-items:center;justify-content:space-between;gap:.7rem;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:1.1rem;padding-bottom:1rem;border-bottom:1px solid var(--line)}
  .status{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--sans);font-weight:400;font-size:.7rem;letter-spacing:.04em;text-transform:none;padding:.34rem .75rem;border-radius:100px;border:1px solid var(--line);color:var(--ink-2)}
  .status .dot{width:7px;height:7px;border-radius:50%;background:var(--muted)}
  .status.open{color:#1f7a3d;border-color:rgba(31,122,61,.35);background:rgba(31,157,78,.06)}
  .status.open .dot{background:#1f9d4e;position:relative}
  .status.open .dot::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid rgba(31,157,78,.5);animation:livedot 2s ease-out infinite}
  @keyframes livedot{0%{opacity:.6;transform:scale(1)}70%,100%{opacity:0;transform:scale(2.6)}}
  .hours ul{list-style:none}
  .hours li{display:flex;justify-content:space-between;gap:1rem;font-size:.95rem;color:var(--ink-2);padding:.64rem 0;border-bottom:1px solid var(--line)}
  .hours li:last-child{border-bottom:0;padding-bottom:0}
  .hours li .day{color:var(--ink)}
  .hours li.closed .time{color:var(--muted)}
  .hours li.now{background:linear-gradient(90deg,rgba(156,122,67,.12),transparent);margin:0 -1.6rem;padding-left:1.6rem;padding-right:1.6rem;border-radius:2px}
  .hours li.now .day,.hours li.now .time{color:var(--ink)}
  .hours li .time{font-variant-numeric:tabular-nums;text-align:right}

  /* ---------- CONTACTO ---------- */
  .contact{text-align:center}
  .contact h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.5rem,8vw,5.4rem);line-height:1;margin:1.1rem 0 2.2rem;letter-spacing:-.02em}
  .contact .lines{display:flex;flex-direction:column;gap:.6rem;font-size:1.02rem;color:#D6CDBE;line-height:1.7}
  .contact .lines a{color:#D6CDBE;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .3s}
  .contact .lines a:hover{border-color:var(--gold-2)}

  footer{position:relative;z-index:2;background:var(--ink);color:#8a8276;padding:2.2rem var(--pad) calc(2.2rem + env(safe-area-inset-bottom));display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem;border-top:1px solid rgba(255,255,255,.08);font-size:.72rem;letter-spacing:.08em}
  footer .fb{font-family:var(--serif);font-size:1.2rem;letter-spacing:.04em;color:var(--paper)}

  /* ---------- CATALOG VIEW ---------- */
  #view-catalog{display:none;min-height:100vh}
  .cat-head{padding-top:calc(clamp(3.4rem,9vw,5.5rem) + 1.5rem)}
  .cat-back{margin-bottom:1.4rem}
  .back{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);background:none;border:none;cursor:pointer}
  .back:hover{color:var(--ink)}
  .cat-head .overline{display:flex;align-items:center;gap:.85rem;margin-bottom:.9rem}
  .cat-head .overline::before{content:"";width:30px;height:1px;background:var(--gold)}
  .cat-title{font-family:var(--serif);font-weight:300;font-size:clamp(2.8rem,10vw,5.4rem);line-height:1;letter-spacing:-.02em;margin-bottom:.5rem}
  .cat-sub{color:var(--muted);font-size:.95rem;margin-bottom:2rem;max-width:52ch;line-height:1.7}
  /* filtros tipo tienda */
  .filters{display:flex;align-items:center;gap:.55rem;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:.5rem;margin-bottom:.6rem}
  .filters::-webkit-scrollbar{display:none}
  .chip{flex:0 0 auto;display:inline-flex;align-items:center;gap:.5rem;padding:.62rem 1.15rem;border:1px solid var(--line);background:none;border-radius:100px;font-family:var(--sans);font-weight:400;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);cursor:pointer;white-space:nowrap;transition:background .35s,color .35s,border-color .35s}
  .chip .n{font-size:.62rem;color:var(--muted);transition:color .35s}
  .chip:hover{border-color:var(--gold)}
  .chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
  .chip.active .n{color:var(--gold-2)}
  .cat-count{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1.8rem}
  .filters-2{margin-top:-.2rem;margin-bottom:.2rem}
  .filters-2 .chip{font-size:.68rem;padding:.5rem 1rem;border-style:dashed}
  .filters-2 .chip.active{border-style:solid;background:var(--gold);color:#fff;border-color:var(--gold)}
  .filters-2 .chip.active .n{color:rgba(255,255,255,.7)}
  /* catálogo: contenedor de subgrupos */
  #catalogGrid{display:block}
  .shop-group.enter{opacity:0;transform:translateY(14px)}
  .shop-group{transition:opacity .45s ease,transform .45s cubic-bezier(.2,.7,.2,1)}
  .cat-empty{display:none;color:var(--muted);font-size:1rem;padding:2rem 0}
  /* subgrupos (marca / material) */
  .shop-group{margin-top:clamp(2rem,5vw,3rem)}
  .shop-group:first-child{margin-top:0}
  .shop-group .gh{display:flex;align-items:center;gap:.85rem;margin-bottom:1.1rem}
  .shop-group .gh h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.2rem,5vw,1.7rem);letter-spacing:.01em;white-space:nowrap}
  .shop-group .gh .gc{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
  .shop-group .gh::after{content:"";flex:1;height:1px;background:var(--line);order:3}
  .shop-group .gh .swipe{order:4}
  .shop-group.crowded .gh .swipe{display:inline-flex}
  .shop-row{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.7rem,2.5vw,1.8rem)}
  /* en móvil, los grupos con muchas piezas se vuelven carrusel horizontal */
  .shop-row.carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.7rem;padding:.2rem .2rem .6rem;margin:0 -.2rem;scroll-padding-left:.2rem}
  .shop-row.carousel::-webkit-scrollbar{display:none}
  .shop-row.carousel .prod{flex:0 0 46%;scroll-snap-align:start}
  .shop-group .swipe{display:none;align-items:center;gap:.4rem;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-left:auto}
  .shop-group .gh .swipe svg{width:14px;height:14px}

  /* tarjeta de producto */
  .prod{display:flex;flex-direction:column;text-decoration:none;color:inherit;cursor:pointer;background:var(--paper);border:1px solid var(--line);transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s,border-color .5s}
  .prod:hover{transform:translateY(-6px);box-shadow:0 26px 50px -26px rgba(24,20,16,.4);border-color:rgba(156,122,67,.4)}
  .prod .frame{position:relative;aspect-ratio:1/1;overflow:hidden;background:radial-gradient(125% 90% at 50% 16%,#FFFFFF,var(--paper) 55%,var(--paper-2));display:flex;align-items:center;justify-content:center}
  .prod .frame::before{content:"";position:absolute;inset:10px;border:1px solid rgba(156,122,67,.16);pointer-events:none;transition:inset .5s,border-color .5s}
  .prod:hover .frame::before{inset:7px;border-color:rgba(156,122,67,.4)}
  .prod .frame svg{width:42%;height:auto;opacity:.85;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
  .prod:hover .frame svg{transform:scale(1.07)}
  .prod .tag{position:absolute;top:.7rem;left:.7rem;z-index:2;font-family:var(--sans);font-size:.5rem;letter-spacing:.16em;text-transform:uppercase;padding:.32rem .6rem;border-radius:100px;background:rgba(251,248,242,.85);color:var(--gold);border:1px solid rgba(156,122,67,.35);backdrop-filter:blur(2px)}
  .prod .info{padding:.8rem .85rem 1rem;display:flex;flex-direction:column;gap:.22rem;flex:1}
  .prod .brand{font-family:var(--sans);font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
  .prod .pname{font-family:var(--serif);font-size:clamp(1.05rem,4.2vw,1.35rem);font-weight:400;line-height:1.15;transition:color .35s}
  .prod:hover .pname{color:var(--gold)}
  .prod .bottom{margin-top:auto;padding-top:.7rem;display:flex;align-items:baseline;justify-content:space-between;gap:.6rem}
  .prod .price{font-family:var(--serif);font-size:1.1rem;color:var(--ink)}
  .prod .price small{font-family:var(--sans);font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-right:.3rem}
  .prod .price.ask{font-family:var(--sans);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
  .prod .wa{font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);white-space:nowrap;opacity:0;transition:opacity .35s,transform .35s;transform:translateX(-4px)}
  .prod:hover .wa{opacity:1;transform:none}

  /* ---------- WHATSAPP FAB ---------- */
  .wa-fab{position:fixed;z-index:95;right:clamp(1rem,4vw,1.6rem);bottom:calc(clamp(1rem,4vw,1.6rem) + env(safe-area-inset-bottom));width:58px;height:58px;border-radius:50%;background:var(--wa);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.4);text-decoration:none;opacity:0;transform:scale(.6);pointer-events:none;transition:transform .5s cubic-bezier(.2,1.3,.4,1),opacity .5s,box-shadow .3s}
  body.ready .wa-fab{opacity:1;transform:scale(1);pointer-events:auto}
  .wa-fab:hover{box-shadow:0 10px 30px rgba(37,211,102,.55)}
  .wa-fab svg{width:30px;height:30px;fill:#fff}
  .wa-fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--wa);animation:pulse 2.6s ease-out infinite}
  @keyframes pulse{0%{transform:scale(1);opacity:.6}70%,100%{transform:scale(1.7);opacity:0}}

  /* ---------- DESKTOP ---------- */
  @media(min-width:760px){
    .nav-links{display:flex}.burger{display:none}
    .hero .overline{font-size:.68rem;letter-spacing:.4em}
    .hero .scroll{display:flex}
    .stat{padding:1.9rem 1rem 1.6rem}
    .stat .lbl{font-size:.64rem;letter-spacing:.22em}
    .sgrid .gift{flex:0 0 calc((100% - 3 * clamp(.9rem,2.5vw,1.5rem)) / 4)}
    .snav{display:flex}
    .story .top{grid-template-columns:1.05fr 1fr}
    .pgrid{grid-template-columns:repeat(4,1fr)}
    .shop-row{grid-template-columns:repeat(4,1fr)}
    .shop-row.carousel{display:grid;overflow:visible;margin:0;padding:0}
    .shop-row.carousel .prod{flex:none}
    .shop-group .swipe{display:none !important}
    .prod .info{padding:1.05rem 1.1rem 1.2rem}
    .workshop .grid{grid-template-columns:1fr 1fr}
    .rgrid{grid-template-columns:repeat(3,1fr);gap:clamp(2rem,4vw,3rem)}
    .visit .grid{grid-template-columns:1.25fr 1fr;gap:clamp(2rem,5vw,4rem)}
    .map-card iframe{height:100%;min-height:470px}
    .visit .map-card{height:100%}
  }
  @media(min-width:1000px){
    .svc-list{display:grid;grid-template-columns:1fr 1fr;column-gap:2.5rem}
    .svc-list .svc:nth-child(2){border-top:1px solid rgba(255,255,255,.12)}
  }
  @media (prefers-reduced-motion: reduce){
    #intro{display:none}*{animation:none !important}
    .reveal,.story .photo img,.workshop .photo img{opacity:1;transform:none}
    .story .photo::after{transform:scaleX(0)}.wa-fab::after{display:none}
  }