/* ============================================================
   The Tile Shop — ultra-premium stylesheet (mobile-first)
   Brand palette (from logo): rust #8a3d16 · tan #b88a55 · cream #ece0cd
   espresso-brown #1a120b · warm ivory #f4ede1
   Type: Fraunces (display) · Manrope (body)
   ============================================================ */

:root{
  --ink:#241a10;
  --ivory:#f4ede1;
  --ivory-2:#e9ddc9;
  --espresso:#1a120b;
  --espresso-2:#241910;
  --brass:#b88a55;        /* swatch tan / camel — secondary accent */
  --brass-l:#dcc197;
  --terra:#8a3d16;        /* brand rust / sienna — primary accent */
  --terra-l:#a8551f;
  --cream:#ece0cd;
  --muted:#8a7b66;
  --muted-d:#6a5b48;
  --muted-light:#b9ab95;
  --line:rgba(36,26,16,.13);
  --line-d:rgba(244,237,225,.14);
  --r:14px;
  --maxw:1280px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:'Manrope',system-ui,sans-serif;background:var(--ivory);color:var(--ink);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.wrap--narrow{max-width:760px}

/* preloader */
.preloader{position:fixed;inset:0;z-index:500;background:var(--espresso);display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease),visibility .8s}
.preloader.done{opacity:0;visibility:hidden}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:26px;width:min(76vw,300px)}
.preloader__logo{width:100%;height:auto;opacity:0;transform:translateY(14px);animation:preIn 1s var(--ease) .1s forwards}
.preloader__bar{width:100%;height:2px;background:rgba(244,237,225,.14);border-radius:2px;overflow:hidden}
.preloader__bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brass),var(--terra-l));border-radius:2px;transition:width .2s linear}
.preloader__count{font-family:'Fraunces',serif;font-size:.9rem;letter-spacing:.3em;color:var(--muted-light)}
@keyframes preIn{to{opacity:1;transform:none}}
body.loading{overflow:hidden}

/* custom cursor (fine-pointer devices only) */
.cursor{position:fixed;top:0;left:0;width:42px;height:42px;border:1.5px solid var(--terra);border-radius:50%;
  pointer-events:none;z-index:400;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s,opacity .3s;mix-blend-mode:difference;opacity:0}
.cursor.ready{opacity:1}
.cursor.grow{width:74px;height:74px;background:rgba(244,237,225,.08);border-color:var(--brass-l)}
.cursor__dot{position:fixed;top:0;left:0;width:6px;height:6px;background:var(--terra);border-radius:50%;
  pointer-events:none;z-index:400;transform:translate(-50%,-50%);opacity:0;transition:opacity .3s}
.cursor__dot.ready{opacity:1}
@media (hover:none),(pointer:coarse){.cursor,.cursor__dot{display:none}}

/* film grain overlay */
.grain{position:fixed;inset:0;z-index:300;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- typography ---------- */
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--terra);margin-bottom:18px}
.eyebrow--light{color:var(--brass-l)}
.display{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2rem,7vw,3.8rem);line-height:1.04;letter-spacing:-.012em;max-width:16ch}
.display--light{color:var(--ivory)}
.display em,.hero__title em{font-style:italic;color:var(--terra)}
.display--light em{color:var(--brass-l)}
.lede{font-size:1.08rem;color:var(--muted-d);max-width:48ch;margin:22px 0}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.92rem;
  letter-spacing:.01em;padding:15px 28px;border-radius:50px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .3s var(--ease),background .3s,color .3s,box-shadow .3s,border-color .3s;min-height:52px;position:relative;overflow:hidden}
.btn:active{transform:scale(.97)}
.btn--gold{background:linear-gradient(135deg,var(--terra-l),var(--terra));color:#fff;box-shadow:0 12px 34px -12px rgba(138,61,22,.75)}
.btn--gold:hover{box-shadow:0 20px 48px -14px rgba(138,61,22,.85);transform:translateY(-2px)}
.btn--gold::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.28) 50%,transparent 70%);transform:translateX(-130%);transition:transform .8s var(--ease)}
.btn--gold:hover::before{transform:translateX(130%)}
.btn--glass{border-color:rgba(244,237,225,.5);color:var(--ivory);backdrop-filter:blur(8px)}
.btn--glass:hover{background:rgba(244,237,225,.12);border-color:rgba(244,237,225,.8);transform:translateY(-2px)}
.btn--dark{background:var(--espresso);color:var(--ivory)}
.btn--dark:hover{background:#000;transform:translateY(-2px)}

.link-arrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--terra);font-size:.95rem;margin-top:6px}
.link-arrow span{transition:transform .3s var(--ease)}
.link-arrow:hover span{transform:translateX(6px)}

/* ---------- scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--brass),var(--terra));transition:width .1s linear}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;transition:background .4s,backdrop-filter .4s,padding .4s,box-shadow .4s}
.nav.scrolled{background:rgba(26,18,11,.92);backdrop-filter:blur(16px);padding:12px 22px;box-shadow:0 1px 0 var(--line-d)}
.nav__brand{display:flex;align-items:center;color:var(--ivory);position:relative;z-index:103}
.nav__logo{width:auto;height:42px;transition:height .4s var(--ease),filter .4s}
.nav.scrolled .nav__logo{height:34px}
.nav__backdrop{position:fixed;inset:0;z-index:101;background:rgba(10,7,4,.55);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .45s var(--ease),visibility .45s}
.nav__backdrop.open{opacity:1;visibility:visible}
.nav__links{position:fixed;top:0;right:0;left:auto;height:100dvh;z-index:102;width:min(86vw,380px);background:var(--espresso);display:flex;flex-direction:column;
  justify-content:center;gap:2px;padding:96px 38px;overflow-y:auto;transform:translateX(100%);transition:transform .5s var(--ease);box-shadow:-30px 0 80px rgba(0,0,0,.55)}
.nav__links.open{transform:translateX(0)}
.nav__links a{color:var(--ivory);font-size:1.45rem;font-family:'Fraunces',serif;padding:14px 0;border-bottom:1px solid var(--line-d);transition:color .25s,padding-left .25s}
.nav__links a:hover{color:var(--brass-l);padding-left:8px}
.nav__cta{margin-top:20px;background:var(--brass);color:#fff!important;text-align:center;border-radius:50px;font-family:'Manrope'!important;font-size:1rem!important;padding:15px!important;border-bottom:none!important}
.nav__toggle{width:44px;height:44px;display:flex;flex-direction:column;justify-content:center;gap:5px;background:transparent;border:none;cursor:pointer;z-index:103;padding:9px;position:relative}
.nav__toggle span{height:2px;width:100%;background:var(--ivory);border-radius:2px;transition:transform .3s var(--ease),opacity .3s}
.nav__toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle.open span:nth-child(2){opacity:0}
.nav__toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:120px 22px 64px;overflow:hidden;color:var(--ivory)}
.hero__slides{position:absolute;inset:0;z-index:0}
.hero__slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;
  transform:scale(1.08);transition:opacity 1.4s var(--ease)}
.hero__slide.is-active{opacity:1;animation:kenburns 8s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1.2)}}
.hero__veil{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(20,17,14,.62) 0%,rgba(20,17,14,.42) 38%,rgba(20,17,14,.6) 66%,rgba(20,17,14,.95) 100%)}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%}
.hero__title{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2.7rem,12vw,6rem);line-height:1.0;letter-spacing:-.02em;margin-bottom:24px}
.hero__title .line{display:block;overflow:hidden}
.rotator{display:inline-block;position:relative;color:var(--brass-l);font-style:italic;min-width:5ch}
.rotator span{display:inline-block}
.hero__sub{font-size:clamp(1rem,3.4vw,1.18rem);color:rgba(243,236,225,.82);max-width:50ch;margin-bottom:32px;font-weight:300}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:30px}
.hero__actions .btn{flex:1 1 auto;min-width:170px}
.hero__meta{display:flex;align-items:center;gap:11px;font-size:.86rem;color:rgba(243,236,225,.8);flex-wrap:wrap}
.hero__meta strong{color:var(--ivory)}
.stars{color:var(--brass-l);letter-spacing:2px}.stars--lg{font-size:1.4rem}
.hero__dots{position:absolute;right:22px;bottom:64px;z-index:2;display:flex;flex-direction:column;gap:10px}
.hero__dots button{width:9px;height:9px;border-radius:50%;border:1.5px solid rgba(243,236,225,.6);background:transparent;cursor:pointer;transition:.3s}
.hero__dots button.is-active{background:var(--brass-l);border-color:var(--brass-l);transform:scale(1.25)}
.scroll-hint{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:2;width:24px;height:38px;border:2px solid rgba(243,236,225,.5);border-radius:14px;display:flex;justify-content:center;padding-top:6px}
.scroll-hint span{width:3px;height:8px;background:var(--brass-l);border-radius:2px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(10px)}}

/* ---------- marquee ---------- */
.marquee{background:var(--espresso);color:var(--brass-l);overflow:hidden;padding:18px 0;border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d)}
.marquee__track{display:flex;gap:22px;white-space:nowrap;width:max-content;align-items:center;animation:marquee 32s linear infinite;font-family:'Fraunces',serif;font-style:italic;font-size:1.25rem}
.marquee__track .dot{color:var(--terra);font-style:normal;font-size:.8rem}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
.section{padding:74px 0;position:relative}
.section__head{display:flex;flex-direction:column;gap:14px;margin-bottom:40px}
.section__head-note{color:var(--muted-d);max-width:42ch;font-size:.98rem}
.section__head-note--light{color:var(--muted-light)}

/* dark sections */
.series,.lookbook{background:var(--espresso);color:var(--ivory)}
.series .eyebrow,.lookbook .eyebrow{color:var(--brass-l)}

/* ---------- intro ---------- */
.intro__grid{display:grid;gap:36px}
.intro__stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:30px}
.stat{background:var(--ivory);padding:22px 16px}
.stat__num{font-family:'Fraunces',serif;font-size:2.1rem;font-weight:500;color:var(--brass)}
.stat__lbl{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.intro__media{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:0 30px 60px -28px rgba(28,23,18,.5)}
.intro__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.intro__media figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.6))}

/* ---------- collections ---------- */
.filters{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px}
.chip{padding:10px 18px;border-radius:50px;border:1.5px solid var(--line);background:transparent;color:var(--muted-d);font-weight:600;font-size:.84rem;cursor:pointer;transition:.3s var(--ease)}
.chip:hover{border-color:var(--brass)}
.chip.is-active{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.coll-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.coll{position:relative;border:none;background:none;padding:0;cursor:pointer;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;
  opacity:0;transform:translateY(30px) scale(.98);transition:opacity .7s var(--ease) var(--d,0ms),transform .7s var(--ease) var(--d,0ms),box-shadow .4s;display:block}
.coll.in{opacity:1;transform:none}
.coll.hide{display:none}
.coll__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .7s var(--ease)}
.coll::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 45%,rgba(20,17,14,.78));transition:opacity .4s}
.coll:hover .coll__img{transform:scale(1.08)}
.coll:hover{box-shadow:0 24px 50px -20px rgba(28,23,18,.55)}
.coll__tag{position:absolute;top:12px;left:12px;z-index:2;font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(20,17,14,.5);backdrop-filter:blur(6px);padding:6px 10px;border-radius:50px;border:1px solid rgba(255,255,255,.2)}
.coll__meta{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:16px;text-align:left;display:flex;flex-direction:column;gap:3px}
.coll__name{font-family:'Fraunces',serif;font-size:1.2rem;color:#fff;font-weight:500}
.coll__cat{font-size:.72rem;letter-spacing:.06em;color:var(--brass-l);opacity:0;transform:translateY(6px);transition:.4s var(--ease)}
.coll:hover .coll__cat{opacity:1;transform:none}

/* ---------- signature series ---------- */
.series .wrap:first-child{margin-bottom:40px}
.series-row{padding:30px 0}
.series-row__inner{display:grid;gap:26px}
.series__media{border-radius:var(--r);overflow:hidden;box-shadow:0 30px 70px -30px rgba(0,0,0,.7)}
.series__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.series__index{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-l);font-weight:600}
.series__name{font-family:'Fraunces',serif;font-size:clamp(1.8rem,6vw,2.8rem);font-weight:400;margin:10px 0 6px}
.series__size{color:var(--brass-l);font-weight:600;font-size:.9rem;margin-bottom:14px}
.series__blurb{color:var(--muted-light);font-size:1rem;max-width:42ch;margin-bottom:14px;font-weight:300}
.series .link-arrow{color:var(--brass-l)}

/* ---------- stock / categories ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.cat{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease) var(--d,0ms),transform .7s var(--ease) var(--d,0ms),box-shadow .4s,border-color .4s}
.cat.in{opacity:1;transform:none}
.cat:hover,.cat:focus{box-shadow:0 24px 48px -22px rgba(28,23,18,.4);border-color:var(--brass);outline:none}
.cat__img{overflow:hidden;aspect-ratio:4/3}
.cat__img span{display:block;width:100%;height:100%;background-size:cover;background-position:center;transition:transform .7s var(--ease)}
.cat:hover .cat__img span{transform:scale(1.07)}
.cat__body{padding:18px 16px 22px}
.cat__body h3{font-family:'Fraunces',serif;font-size:1.18rem;font-weight:500}
.cat__size{color:var(--brass);font-weight:600;font-size:.78rem;margin:3px 0 8px}
.cat__desc{font-size:.86rem;color:var(--muted)}

/* ---------- lookbook masonry ---------- */
.masonry{columns:2;column-gap:12px}
.ph{break-inside:avoid;margin-bottom:12px;width:100%;border:none;padding:0;background:none;cursor:pointer;position:relative;border-radius:10px;overflow:hidden;display:block;
  opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease) var(--d,0ms),transform .7s var(--ease) var(--d,0ms)}
.ph.in{opacity:1;transform:none}
.ph img{width:100%;display:block;transition:transform .6s var(--ease),filter .4s}
.ph__zoom{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:50%;background:rgba(20,17,14,.55);backdrop-filter:blur(6px);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;opacity:0;transition:.3s}
.ph:hover img{transform:scale(1.05)}
.ph:hover .ph__zoom{opacity:1}

/* ---------- why ---------- */
.why-list{display:grid;gap:0}
.why-item{display:flex;gap:20px;padding:26px 0;border-bottom:1px solid var(--line);transition:padding-left .3s var(--ease)}
.why-item:hover{padding-left:8px}
.why-item__num{font-family:'Fraunces',serif;font-size:1.6rem;color:var(--brass);font-weight:500;flex:none;width:2ch}
.why-item h3{font-family:'Fraunces',serif;font-size:1.22rem;font-weight:500;margin-bottom:4px}
.why-item p{font-size:.92rem;color:var(--muted)}

/* ---------- serve ---------- */
.serve{background:var(--ivory-2)}
.serve-grid{display:grid;gap:12px}
.serve-card{background:var(--ivory);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;transition:transform .35s var(--ease),box-shadow .35s}
.serve-card:hover{transform:translateY(-5px);box-shadow:0 20px 44px -22px rgba(28,23,18,.35)}
.serve-card__num{font-family:'Fraunces',serif;font-size:1.4rem;color:var(--brass);font-weight:500;display:block;margin-bottom:10px}
.serve-card h3{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:500;margin-bottom:5px}
.serve-card p{font-size:.9rem;color:var(--muted)}

/* ---------- reviews ---------- */
.reviews{background:var(--ivory-2)}
.reviews__head{display:flex;align-items:center;gap:22px;margin-bottom:36px}
.big-rating{font-family:'Fraunces',serif;font-size:4.5rem;line-height:.9;font-weight:500;color:var(--brass)}
.reviews__head p{color:var(--muted-d);font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;margin-top:6px}
.testimonials{display:grid;gap:16px}
.testimonial{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px}
.testimonial blockquote{font-family:'Fraunces',serif;font-size:1.22rem;line-height:1.45;margin:14px 0;font-style:italic;color:var(--ink)}
.testimonial figcaption{color:var(--brass);font-size:.85rem;font-weight:600}

/* ---------- visit ---------- */
.visit-grid{display:grid;gap:22px}
.visit__info{display:grid;gap:18px}
.info-row__lbl{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);font-weight:700;display:block;margin-bottom:4px}
.info-row p{font-size:.98rem;color:#3e352c}
.info-row a:hover{color:var(--terra)}
.hours-line{display:block}
.visit__map{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);min-height:320px;box-shadow:0 20px 50px -24px rgba(28,23,18,.4)}
.visit__map iframe{display:block;width:100%;height:100%;min-height:340px;border:0;filter:saturate(.92)}
.visit__map-cta{position:absolute;left:14px;bottom:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;padding:10px 16px;background:var(--espresso);color:var(--ivory);font-size:.82rem;font-weight:600;letter-spacing:.02em;border-radius:999px;box-shadow:0 8px 24px -8px rgba(28,23,18,.55)}
.visit__map-cta::after{content:"→";font-size:.95rem}
.visit__map-cta:hover{background:var(--terra);color:#fff}

/* ---------- faq ---------- */
.faqs{display:grid;gap:10px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:20px;font-family:'Fraunces',serif;font-weight:500;font-size:1.08rem;display:flex;align-items:center;justify-content:space-between;gap:14px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item__plus{position:relative;width:16px;height:16px;flex:none}
.faq-item__plus::before,.faq-item__plus::after{content:"";position:absolute;background:var(--brass);border-radius:2px;transition:transform .3s var(--ease)}
.faq-item__plus::before{top:7px;left:0;width:16px;height:2px}
.faq-item__plus::after{left:7px;top:0;width:2px;height:16px}
.faq-item[open] .faq-item__plus::after{transform:rotate(90deg);opacity:0}
.faq-item__a{padding:0 20px 22px;color:var(--muted);font-size:.95rem;animation:fadeIn .4s var(--ease)}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ---------- cta ---------- */
.cta{position:relative;padding:80px 0;color:#fff;overflow:hidden}
.cta__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.cta::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(20,17,14,.86),rgba(20,17,14,.92))}
.cta__inner{position:relative;z-index:2}
.cta__sub{font-size:1.06rem;color:var(--muted-light);margin:14px 0 30px;max-width:44ch}
.enquiry-form{display:grid;gap:14px}
.field{position:relative}
.field input,.field textarea{width:100%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.25);border-radius:12px;padding:20px 16px 8px;color:#fff;font-family:'Manrope';font-size:1rem;transition:border-color .25s,background .25s;resize:vertical}
.field textarea{padding-top:24px}
.field input::placeholder,.field textarea::placeholder{color:transparent}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brass-l);background:rgba(255,255,255,.14)}
.field label{position:absolute;left:16px;top:16px;color:rgba(255,255,255,.6);font-size:1rem;pointer-events:none;transition:.2s var(--ease)}
.field input:focus+label,.field input:not(:placeholder-shown)+label,.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{top:7px;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--brass-l)}
.enquiry-form__actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.enquiry-form__actions .btn{flex:1 1 auto;min-width:160px}
.form-note{font-size:.9rem;margin-top:4px;min-height:1.2em}
.form-note.ok{color:var(--brass-l);font-weight:600}
.form-note.err{color:#ffcdbf;font-weight:600}

/* ---------- footer ---------- */
.footer{background:var(--espresso);color:var(--ivory);padding:56px 0 32px}
.footer__top{display:flex;flex-direction:column;gap:24px;padding-bottom:28px;border-bottom:1px solid var(--line-d)}
.footer__brand{display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.footer__logo{width:auto;height:64px}
.footer__brand em{font-style:normal;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-light)}
.footer__nav{display:flex;flex-wrap:wrap;gap:8px 18px}
.footer__nav a{font-size:.9rem;color:var(--muted-light);transition:color .2s}
.footer__nav a:hover{color:var(--brass-l)}
.footer__cols{display:grid;gap:24px;padding:30px 0;border-bottom:1px solid var(--line-d)}
.footer__cols span{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-l);font-weight:700;display:block;margin-bottom:8px}
.footer__cols p{font-size:.9rem;color:var(--muted-light);line-height:1.7}
.footer__cols a:hover{color:var(--ivory)}
.footer__bar{display:flex;flex-direction:column;gap:6px;padding-top:24px;font-size:.78rem;color:var(--muted)}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:400;background:rgba(12,10,8,.94);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox__img{max-width:92vw;max-height:84vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6);transform:scale(.96);transition:transform .35s var(--ease)}
.lightbox.open .lightbox__img{transform:scale(1)}
.lightbox__close{position:absolute;top:18px;right:20px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.6rem;cursor:pointer;line-height:1}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:2rem;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center}
.lightbox__nav--prev{left:14px}.lightbox__nav--next{right:14px}
.lightbox__nav:hover,.lightbox__close:hover{background:rgba(255,255,255,.22)}
.lightbox__caption{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:var(--brass-l);font-family:'Fraunces',serif;font-style:italic;font-size:1rem}

/* ---------- floating WhatsApp ---------- */
.fab{position:fixed;right:18px;bottom:18px;z-index:90;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -6px rgba(37,211,102,.6);transition:transform .3s var(--ease);animation:fabIn .5s .8s both}
.fab:hover{transform:scale(1.1)}
.fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:pulse 2.2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}
@keyframes fabIn{from{transform:scale(0)}to{transform:scale(1)}}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal,.coll,.cat,.ph{opacity:1!important;transform:none!important;transition:none}
  .marquee__track,.scroll-hint span,.fab,.fab::after,.hero__slide.is-active{animation:none}
}

/* ============================================================
   TABLET / DESKTOP
   ============================================================ */
@media (min-width:720px){
  .section{padding:110px 0}
  .nav__links{position:static;width:auto;height:auto;top:auto;right:auto;left:auto;flex-direction:row;align-items:center;gap:30px;padding:0;background:transparent;transform:none;box-shadow:none;overflow:visible}
  .nav__links a{font-family:'Manrope';font-size:.92rem;padding:6px 0;border:none;color:var(--ivory);font-weight:500}
  .nav__links a:hover{padding-left:0;color:var(--brass-l)}
  .nav__cta{margin-top:0;padding:11px 22px!important;font-size:.9rem!important}
  .nav__toggle{display:none}
  .section__head{flex-direction:row;align-items:flex-end;justify-content:space-between}
  .intro__grid{grid-template-columns:1.1fr .9fr;align-items:center;gap:54px}
  .intro__stats{grid-template-columns:repeat(4,1fr)}
  .coll-grid{grid-template-columns:repeat(4,1fr);gap:16px}
  .cat-grid{grid-template-columns:repeat(4,1fr);gap:18px}
  .masonry{columns:3;column-gap:16px}
  .ph{margin-bottom:16px}
  .series-row__inner{grid-template-columns:1fr 1fr;align-items:center;gap:54px}
  .series-row--alt .series__media{order:2}
  .serve-grid{grid-template-columns:repeat(3,1fr)}
  .testimonials{grid-template-columns:repeat(3,1fr)}
  .visit-grid{grid-template-columns:1fr 1.1fr}
  .why-list{grid-template-columns:1fr 1fr;gap:0 54px}
  .footer__top{flex-direction:row;align-items:center;justify-content:space-between}
  .footer__cols{grid-template-columns:2fr 1fr 1fr}
  .footer__bar{flex-direction:row;justify-content:space-between}
  .enquiry-form{grid-template-columns:1fr 1fr}
  .enquiry-form .field:nth-child(3),.enquiry-form .field:nth-child(4),.enquiry-form__actions,.form-note{grid-column:1/-1}
}
@media (min-width:1024px){
  .masonry{columns:4}
  .display{font-size:clamp(2.6rem,4.4vw,4.2rem)}
}
