/* ============================================================
   XOCOLATES GENESCÀ — Opció D · Maison
   Crema, verd de marca, or. Serif editorial. Fotografia real.
   ============================================================ */
:root{
  --paper:#f3ece0;--paper2:#ece2d2;--card:#faf5ec;
  --ink:#241d15;--ink2:#5e5142;
  --green:oklch(0.46 0.082 156);--green-d:oklch(0.36 0.072 156);--green-l:oklch(0.58 0.085 156);
  --gold:oklch(0.66 0.085 78);--gold-d:oklch(0.55 0.085 76);
  --line:#d9cab2;
  --serif:"Cormorant Garamond",Georgia,serif;--sans:"Jost","Helvetica Neue",Arial,sans-serif;
  --maxw:1240px;--ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 36px;}
h1,h2,h3{font-family:var(--serif);font-weight:500;margin:0;line-height:1.03;}
p{margin:0 0 1em;}
.eyebrow{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-d);}
.display{font-size:clamp(48px,8vw,108px);letter-spacing:-.01em;}
.green-txt{color:var(--green);}
.it{font-style:italic;}

/* ornament */
.orn{display:flex;align-items:center;gap:14px;color:var(--gold-d);}
.orn.center{justify-content:center;}
.orn::before,.orn::after{content:"";height:1px;width:50px;background:var(--line);}
.orn .dia{width:6px;height:6px;background:var(--gold-d);transform:rotate(45deg);}
.orn span{font-family:var(--sans);font-size:12px;letter-spacing:.28em;text-transform:uppercase;}

/* ===== MOTION PRIMITIVES ===== */
[data-reveal]{opacity:0;transform:translateY(34px);filter:blur(6px);
  transition:opacity 1s var(--ease),transform 1s var(--ease),filter 1s var(--ease);}
[data-reveal].in{opacity:1;transform:none;filter:blur(0);}
[data-reveal][data-d="1"]{transition-delay:.10s;}
[data-reveal][data-d="2"]{transition-delay:.20s;}
[data-reveal][data-d="3"]{transition-delay:.30s;}
[data-reveal][data-d="4"]{transition-delay:.40s;}
.lines .ln{display:block;overflow:hidden;}
.lines .ln>span{display:block;transform:translateY(108%);transition:transform 1.05s var(--ease);}
.lines.in .ln>span{transform:none;}
.lines.in .ln:nth-child(2)>span{transition-delay:.09s;}
.lines.in .ln:nth-child(3)>span{transition-delay:.18s;}
.lines.in .ln:nth-child(4)>span{transition-delay:.27s;}
.frame{position:relative;overflow:hidden;background:var(--paper2);}
.frame img{width:100%;height:120%;object-fit:cover;position:absolute;top:-10%;left:0;will-change:transform;}
.frame .static{position:static;height:100%;top:0;}
.frame[data-clip]{clip-path:inset(0 0 100% 0);transition:clip-path 1.2s var(--ease);}
.frame[data-clip].in{clip-path:inset(0 0 0% 0);}
.frame .zoom{transform:scale(1.16);transition:transform 1.6s var(--ease);}
.frame.in .zoom{transform:scale(1);}

/* ===== topbar ===== */
.topbar{background:var(--green-d);color:#e9ddc7;font-family:var(--sans);}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:38px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;}
.topbar a{opacity:.85;color:inherit;}.topbar a:hover{opacity:1;color:#fff;}
.topbar .tr{display:flex;gap:22px;}

/* ===== header ===== */
header.site{position:sticky;top:0;z-index:60;background:rgba(243,236,224,.93);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:transform .5s var(--ease);}
header.site.hide{transform:translateY(-100%);}
header.site .wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;min-height:90px;}
.nav-left,.nav-right{display:flex;gap:30px;align-items:center;}
.nav-right{justify-content:flex-end;}
.nav a{font-family:var(--sans);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink2);white-space:nowrap;position:relative;padding:6px 0;}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--green);transition:width .4s var(--ease);}
.nav a:hover::after,.nav a.active::after{width:100%;}
.nav a:hover,.nav a.active{color:var(--green);}
.brand{text-align:center;}
.brand .bn{font-family:var(--serif);font-size:30px;color:var(--ink);letter-spacing:.01em;}
.brand .bt{font-family:var(--sans);font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-d);margin-top:3px;}
.ico{width:33px;height:33px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--green);transition:.25s;}
.ico:hover{background:var(--green);color:#f3ece0;border-color:var(--green);transform:translateY(-2px);}
.ico svg{width:15px;height:15px;}
.ico-row{display:flex;gap:12px;}
.menu-btn{display:none;width:42px;height:42px;border:1px solid var(--line);background:none;color:var(--green);cursor:pointer;place-items:center;border-radius:0;}
.mobile-nav{display:none;border-top:1px solid var(--line);padding:12px 36px 18px;background:var(--card);}
.mobile-nav a{display:block;padding:9px 0;font-family:var(--sans);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink2);}
.mobile-nav a:hover{color:var(--green);}

/* ===== buttons ===== */
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);font-size:12px;
  letter-spacing:.18em;text-transform:uppercase;padding:15px 30px;cursor:pointer;
  background:var(--green);color:#f3ece0;border:1px solid var(--green);
  transition:.3s var(--ease);position:relative;overflow:hidden;}
.btn span{position:relative;z-index:2;}
.btn::before{content:"";position:absolute;inset:0;background:var(--green-d);transform:translateY(101%);transition:transform .4s var(--ease);}
.btn:hover::before{transform:translateY(0);}
.btn.outline{background:transparent;color:var(--green);}
.btn.outline::before{background:var(--green);}
.btn.outline:hover{color:#f3ece0;}
.btn .arr{transition:transform .35s var(--ease);position:relative;z-index:2;}
.btn:hover .arr{transform:translateX(5px);}

/* announcement */
.announce{background:var(--green);color:#f3ece0;text-align:center;padding:10px 20px;
  font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;}
.announce a{color:inherit;text-decoration:underline;text-underline-offset:3px;}

/* ===== hero (homepage) ===== */
.hero{position:relative;min-height:94vh;display:flex;align-items:flex-end;overflow:hidden;}
.hero-slides{position:absolute;inset:0;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;}
.hero-slide.active{opacity:1;}
.hero-slide img{width:100%;height:116%;object-fit:cover;position:absolute;top:-8%;left:0;will-change:transform;}
.hero-slide::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,16,11,.36) 0%,rgba(20,16,11,.18) 38%,rgba(20,16,11,.74) 100%);}
.hero .inner{position:relative;z-index:3;color:#f6efe1;padding:0 0 76px;width:100%;}
.hero .eyebrow{color:#d8b878;}
.hero h1{color:#f8f1e4;margin:18px 0 0;text-shadow:0 2px 40px rgba(0,0,0,.3);}
.hero .sub{max-width:42ch;font-size:19px;color:rgba(246,239,225,.9);margin:26px 0 30px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.hero .btn.outline{color:#f6efe1;border-color:rgba(246,239,225,.5);}
.hero .btn.outline::before{background:#f6efe1;}
.hero .btn.outline:hover{color:var(--ink);}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;color:#f6efe1;
  font-family:var(--sans);font-size:10px;letter-spacing:.3em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.85;}
.scroll-cue .bar{width:1px;height:46px;background:linear-gradient(#f6efe1,transparent);animation:cue 2s var(--ease) infinite;}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top;}45%{transform:scaleY(1);transform-origin:top;}55%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}
.hero-dots{position:absolute;bottom:20px;right:36px;z-index:4;display:flex;gap:8px;}
.hero-dot{width:6px;height:6px;border-radius:50%;background:rgba(246,239,225,.4);border:none;cursor:pointer;padding:0;transition:background .3s,transform .3s;}
.hero-dot.active{background:#f6efe1;transform:scale(1.4);}

/* ===== marquee ===== */
.marquee{background:var(--green);color:#f0e6d2;overflow:hidden;white-space:nowrap;padding:18px 0;
  border-top:1px solid var(--green-d);border-bottom:1px solid var(--green-d);}
.marquee .track{display:inline-flex;gap:38px;animation:scroll 30s linear infinite;
  font-family:var(--serif);font-style:italic;font-size:26px;align-items:center;}
.marquee .dia{width:6px;height:6px;background:var(--gold);transform:rotate(45deg);display:inline-block;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ===== sections ===== */
.section{padding:108px 0;}
.section.alt{background:var(--paper2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section-head{text-align:center;max-width:62ch;margin:0 auto 60px;}
.section-head .orn{margin-bottom:20px;}
.section-head h2{font-size:clamp(36px,5vw,62px);}
.section-head p{color:var(--ink2);font-size:18px;margin-top:16px;}

/* ===== intro split ===== */
.intro{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;}
.intro .frame{aspect-ratio:4/5;}
.intro h2{font-size:clamp(32px,4.2vw,52px);margin-bottom:22px;}
.intro h2 .it{color:var(--green);}
.intro p{color:var(--ink2);font-size:17px;}
.quote{font-family:var(--serif);font-style:italic;font-size:27px;color:var(--green);line-height:1.35;
  border-left:1px solid var(--gold-d);padding-left:22px;margin:26px 0;}
.stat-row{display:flex;gap:54px;margin:30px 0 8px;}
.stat .n{font-family:var(--serif);font-size:54px;color:var(--green);line-height:1;}
.stat .l{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink2);margin-top:8px;}

/* ===== catalog grid ===== */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.cat-card{position:relative;display:block;}
.cat-card .frame{aspect-ratio:4/5;}
.cat-card .frame img{transition:transform 1.4s var(--ease);}
.cat-card:hover .frame img{transform:scale(1.06);}
.cat-card .body{padding:22px 4px 0;text-align:center;position:relative;}
.cat-card .idx{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--gold-d);}
.cat-card h3{font-size:29px;margin:4px 0 7px;transition:color .3s var(--ease);}
.cat-card:hover h3{color:var(--green);}
.cat-card .short{font-size:13px;color:var(--ink2);font-style:italic;}
.cat-card .pill{position:absolute;top:14px;left:14px;z-index:3;background:var(--green);color:#f3ece0;
  font-family:var(--sans);font-size:9px;letter-spacing:.18em;text-transform:uppercase;padding:5px 11px;}
.cat-card .frame::after{content:"";position:absolute;inset:0;background:rgba(36,29,21,0);transition:background .4s var(--ease);}
.cat-card:hover .frame::after{background:rgba(36,29,21,.12);}

/* ===== feature strip (full-bleed) ===== */
.bleed{position:relative;min-height:78vh;display:grid;place-items:center;overflow:hidden;text-align:center;}
.bleed .bg{position:absolute;inset:0;}
.bleed .bg img{width:100%;height:128%;object-fit:cover;position:absolute;top:-14%;left:0;will-change:transform;}
.bleed .bg::after{content:"";position:absolute;inset:0;background:rgba(20,16,11,.5);}
.bleed .inner{position:relative;z-index:3;color:#f6efe1;padding:60px 24px;max-width:760px;}
.bleed h2{color:#f8f1e4;font-size:clamp(34px,5vw,60px);}
.bleed p{color:rgba(246,239,225,.9);font-size:18px;margin:18px auto 28px;max-width:48ch;}
.bleed .btn.outline{color:#f6efe1;border-color:rgba(246,239,225,.55);}
.bleed .btn.outline::before{background:#f6efe1;}
.bleed .btn.outline:hover{color:var(--ink);}

/* ===== category / product hero ===== */
.cat-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden;}
.cat-hero .bg{position:absolute;inset:0;}
.cat-hero .bg img{width:100%;height:118%;object-fit:cover;position:absolute;top:-9%;left:0;will-change:transform;}
.cat-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,11,.3),rgba(20,16,11,.72));}
.cat-hero .inner{position:relative;z-index:3;color:#f6efe1;padding:0 0 56px;width:100%;}
.cat-hero .crumb{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(246,239,225,.85);}
.cat-hero .crumb a:hover{color:#fff;text-decoration:underline;}
.cat-hero h1{color:#f8f1e4;font-size:clamp(44px,7vw,92px);margin:14px 0 12px;}
.cat-hero p{color:rgba(246,239,225,.9);font-size:18px;max-width:54ch;margin:0;}

/* cat-nav (sticky chips) */
.cat-nav{position:sticky;top:90px;z-index:40;background:rgba(243,236,224,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);}
.cat-nav .inner{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;padding:16px 0;}
.chip{font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:9px 16px;
  border:1px solid var(--line);color:var(--ink2);transition:.25s var(--ease);white-space:nowrap;}
.chip:hover{border-color:var(--green);color:var(--green);}
.chip.active{background:var(--green);color:#f3ece0;border-color:var(--green);}

/* prod-grid */
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;margin-top:52px;}
.prod{display:grid;grid-template-columns:150px 1fr;gap:24px;align-items:center;
  background:var(--card);border:1px solid var(--line);padding:18px;transition:.3s var(--ease);}
.prod:hover{box-shadow:0 24px 48px -32px rgba(36,29,21,.5);transform:translateY(-3px);}
.prod .frame{width:150px;height:150px;flex-shrink:0;}
.prod h4{font-family:var(--serif);font-size:25px;font-weight:500;margin:0 0 6px;}
.prod p{font-size:14px;color:var(--ink2);margin:0;}

/* gallery */
.gallery-section{padding:80px 0;}
.gallery-grid{display:grid;gap:8px;}
.gallery-grid.cols-2{grid-template-columns:1fr 1fr;}
.gallery-grid.cols-3{grid-template-columns:2fr 1fr 1fr;}
.gallery-item{overflow:hidden;background:var(--paper2);}
.gallery-item img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform .6s var(--ease);}
.gallery-item:hover img{transform:scale(1.04);}
.gallery-item.tall img{aspect-ratio:3/4;}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);}
.contact-info{padding:54px;background:var(--card);}
.contact-info .row{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);align-items:flex-start;}
.contact-info .row:last-child{border-bottom:none;}
.contact-info .k{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-d);width:112px;flex:none;padding-top:5px;}
.contact-info .val{font-family:var(--serif);font-size:21px;}
.contact-info .val a:hover{color:var(--green);}
.map iframe{width:100%;height:100%;border:0;min-height:520px;filter:sepia(.16) saturate(.92);}
.hours{list-style:none;padding:0;margin:0;width:100%;}
.hours li{display:flex;justify-content:space-between;gap:16px;padding:8px 0;font-family:var(--sans);font-size:14px;color:var(--ink2);border-bottom:1px dashed var(--line);}
.hours li:last-child{border:none;}

/* contact-form */
.cf-wrap{margin-top:54px;padding:48px;background:var(--card);border:1px solid var(--line);}
.cf-wrap h3{font-family:var(--serif);font-size:2rem;font-weight:500;margin-bottom:6px;color:var(--ink);}
.cf-wrap .lead{color:var(--ink2);font-style:italic;font-size:1rem;margin-bottom:32px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-d);margin-bottom:6px;}
.form-group input,.form-group textarea{width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:15px;padding:12px 16px;outline:none;transition:border-color .25s;}
.form-group input:focus,.form-group textarea:focus{border-color:var(--green);}
.form-group textarea{resize:vertical;min-height:130px;}
.btn-submit{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:var(--green);color:#f3ece0;border:none;font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:background .3s;}
.btn-submit:hover{background:var(--green-d);}
.btn-submit:disabled{opacity:.6;cursor:not-allowed;}
.form-msg{display:none;margin-top:16px;padding:14px 18px;font-size:.9rem;}
.form-msg.success{background:rgba(70,120,80,.1);border:1px solid rgba(70,120,80,.3);color:#2d6040;}
.form-msg.error{background:rgba(180,50,50,.08);border:1px solid rgba(180,50,50,.2);color:#a03030;}

/* ===== timeline ===== */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.tl{padding:32px 26px;border-left:1px solid var(--line);}
.tl:first-child{border-left:none;}
.tl .yr{font-family:var(--serif);font-size:42px;color:var(--green);}
.tl p{font-size:14px;color:var(--ink2);margin-top:10px;}

/* ===== instagram ===== */
.ig-section{padding:108px 0;background:var(--paper2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.ig-handle{display:inline-flex;align-items:center;gap:10px;padding:10px 20px;
  border:1px solid var(--line);color:var(--ink2);margin:24px 0;transition:.25s var(--ease);}
.ig-handle:hover{border-color:var(--green);color:var(--green);}
.ig-handle .ig-dot{width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,#f09433,#dc2743,#bc1888);display:grid;place-items:center;flex-shrink:0;}
.ig-handle strong{font-family:var(--sans);font-size:13px;letter-spacing:.1em;}
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin:0 0 32px;}
.ig-cell{position:relative;overflow:hidden;aspect-ratio:1/1;display:block;background:var(--paper2);}
.ig-cell img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),filter .4s;}
.ig-cell:hover img{transform:scale(1.07);filter:brightness(.7);}
.ig-cell-ov{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .3s;}
.ig-cell:hover .ig-cell-ov{opacity:1;}
.ig-cell-ov svg{color:#fff;}

/* ===== footer ===== */
footer.site{background:var(--green-d);color:#e3d6bf;padding:74px 0 30px;}
footer.site .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.14);}
footer.site .bn{font-family:var(--serif);font-size:30px;color:#f4e9d4;}
footer.site .bt{font-family:var(--sans);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:6px;}
footer.site h4{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 16px;}
footer.site ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
footer.site a,footer.site p{color:#e3d6bf;font-size:14px;}
footer.site p{margin:0 0 6px;}
footer.site a:hover{color:#fff;}
footer.site .fb{display:flex;justify-content:space-between;padding-top:22px;font-size:12px;color:#bca983;flex-wrap:wrap;gap:10px;}

/* ===== utility ===== */
.tc{text-align:center;}
.body-text{color:var(--ink2);font-size:17px;margin-top:18px;}
.lead-text{color:var(--ink2);font-size:18px;}
.footer-addr{margin-top:20px;max-width:34ch;}
.green-link{color:var(--green);}

/* ===== bleed ornament (gold sobre fons fosc) ===== */
.orn.gold{color:#d8b878;}
.orn.gold .dia{background:#d8b878;}

/* ===== values row (about section) ===== */
.values-row{display:flex;gap:24px;margin-top:28px;flex-wrap:wrap;}
.val-item{text-align:center;min-width:80px;}
.val-item .vt{font-family:var(--serif);font-size:18px;color:var(--green);font-weight:500;}
.val-item .vl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink2);margin-top:4px;}

/* ===== btn-row ===== */
.btn-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}
.btn-row.start{justify-content:flex-start;margin-top:10px;}
.btn-row.mt{margin-top:24px;}

/* ===== pill inline (dins cat-hero) ===== */
.pill.inline{position:static;display:inline-block;margin-top:12px;}

/* ===== section-head compacte ===== */
.section-head.sm{margin-bottom:30px;}

/* ===== CTA block (producte, contacte) ===== */
.cta-block{text-align:center;margin-top:64px;}
.cta-block .orn{margin-bottom:20px;}
.cta-title{color:var(--ink2);max-width:46ch;margin:0 auto 8px;font-family:var(--serif);font-size:26px;}
.cta-text{color:var(--ink2);max-width:46ch;margin:0 auto 24px;font-size:17px;}

/* ===== prose center (descripció producte) ===== */
.prose-center{text-align:center;max-width:60ch;margin:0 auto 48px;}
.prose-center p{font-family:var(--serif);font-size:1.3rem;font-style:italic;color:var(--ink2);}

/* ===== CTA section (qui-som) ===== */
.cta-section{text-align:center;}
.cta-section .orn{margin-bottom:18px;}
.h2-cta{font-size:clamp(32px,4.4vw,56px);}
.cta-subtext{color:var(--ink2);font-size:18px;margin:16px auto 28px;max-width:44ch;}

/* ===== CTA footer (contacte) ===== */
.cta-footer{text-align:center;margin-top:54px;}
.cta-footer .orn{margin-bottom:20px;}
.cta-footer .btn-row{margin-top:24px;}

/* ===== schedule val ===== */
.schedule-val{font-family:var(--sans);font-size:15px;line-height:1.8;}

/* ===== map placeholder ===== */
.map-placeholder{width:100%;min-height:520px;background:var(--paper2);display:grid;place-items:center;}

/* ===== història — timeline vertical ===== */
.hist-tl{position:relative;padding:108px 0;}
.hist-tl::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--line);transform:translateX(-50%);}
.hist-item{display:grid;grid-template-columns:1fr 80px 1fr;gap:0;align-items:center;margin-bottom:80px;}
.hist-item:last-child{margin-bottom:0;}
.hist-body{padding:0 48px;}
.hist-item:nth-child(odd) .hist-body{grid-column:1;text-align:right;}
.hist-item:nth-child(odd) .hist-dot{grid-column:2;}
.hist-item:nth-child(odd) .hist-img{grid-column:3;}
.hist-item:nth-child(even) .hist-img{grid-column:1;order:-1;}
.hist-item:nth-child(even) .hist-dot{grid-column:2;}
.hist-item:nth-child(even) .hist-body{grid-column:3;text-align:left;}
.hist-dot{display:flex;align-items:center;justify-content:center;z-index:2;}
.hist-dot::after{content:"";width:12px;height:12px;background:var(--gold-d);transform:rotate(45deg);display:block;}
.hist-year{font-family:var(--serif);font-size:clamp(52px,7vw,96px);color:var(--green);line-height:1;margin-bottom:8px;}
.hist-title{font-family:var(--serif);font-size:clamp(20px,2.2vw,28px);margin-bottom:14px;}
.hist-body p{color:var(--ink2);font-size:16px;line-height:1.75;margin:0;}
.hist-img .frame{aspect-ratio:4/3;max-width:440px;}
.hist-item:nth-child(odd) .hist-img .frame{margin-left:0;}
.hist-item:nth-child(even) .hist-img .frame{margin-right:0;}
@media(max-width:920px){
  .hist-tl::before{left:24px;}
  .hist-item{grid-template-columns:48px 1fr;grid-template-rows:auto auto;}
  .hist-item:nth-child(odd) .hist-body,
  .hist-item:nth-child(even) .hist-body{grid-column:2;text-align:left;padding:0 0 0 24px;}
  .hist-item:nth-child(odd) .hist-dot,
  .hist-item:nth-child(even) .hist-dot{grid-column:1;grid-row:1;align-self:start;margin-top:16px;}
  .hist-item:nth-child(odd) .hist-img,
  .hist-item:nth-child(even) .hist-img{grid-column:2;grid-row:2;padding-left:24px;order:unset;}
  .hist-img .frame{max-width:100%;margin:16px 0 0;}
}

/* ===== responsive ===== */
@media(max-width:920px){
  .intro,.contact-grid{grid-template-columns:1fr;gap:40px;}
  .cat-grid{grid-template-columns:repeat(2,1fr);}
  .timeline{grid-template-columns:1fr 1fr;}
  .prod-grid{grid-template-columns:1fr;}
  .nav-left,.nav a.txtnav{display:none;}
  header.site .wrap{grid-template-columns:auto 1fr auto;}
  .brand{text-align:left;}
  .menu-btn{display:grid;}
  footer.site .cols{grid-template-columns:1fr 1fr;}
  .cat-nav{top:78px;}
  .ig-grid{grid-template-columns:repeat(3,1fr);}
  .form-row{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .wrap{padding:0 22px;}
  .cat-grid,.timeline,footer.site .cols{grid-template-columns:1fr;}
  .stat-row{gap:32px;}
  .marquee .track{font-size:20px;}
  .topbar .tl-left{display:none;}
  .ig-grid{grid-template-columns:repeat(3,1fr);}
  .prod{grid-template-columns:1fr;}
  .prod .frame{width:100%;height:180px;}
  .cf-wrap{padding:28px 22px;}
  .gallery-grid.cols-3{grid-template-columns:1fr 1fr;}
}
@media(prefers-reduced-motion:reduce){
  [data-reveal],.lines .ln>span,.frame[data-clip],.frame .zoom{transition:none!important;}
  [data-reveal]{opacity:1;transform:none;filter:none;}
  .lines .ln>span{transform:none;}
  .frame[data-clip]{clip-path:none;}
  .marquee .track,.scroll-cue .bar{animation:none;}
}
