/* Agaram Palace — Premium Chettinad mockup | shared design system */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Hind+Madurai:wght@400;500;600&display=swap");

/* ============ TOKENS ============ */
:root{
  /* Palette — Chettinad heritage */
  --maroon:#6b1f2a;        /* Chettinad deep red */
  --maroon-deep:#4a141d;
  --terracotta:#bf5b2e;    /* Athangudi tile clay */
  --turmeric:#caa036;      /* gold / brass lamp */
  --turmeric-soft:#e3c66a;
  --teak:#3a2a20;          /* dark wood */
  --cobalt:#1b5e8c;        /* Chettinad window cobalt */
  --cobalt-deep:#13456a;
  --palm:#527d40;          /* parrot-green shutters */
  --sage:#7c8b5b;          /* inherited brand green */
  --sage-deep:#5f6e45;
  --cream:#fbf5e9;         /* limewash wall */
  --cream-2:#f4ead6;
  --paper:#fffdf8;
  --ink:#2a211c;
  --ink-soft:#5d524a;
  --line:rgba(58,42,32,.14);

  /* Type */
  --display:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --body:"Jost", "Segoe UI", system-ui, sans-serif;
  --tamil:"Hind Madurai", "Latha", "Nirmala UI", sans-serif;

  /* Space + motion */
  --r:18px;
  --r-lg:28px;
  --shadow:0 24px 60px -28px rgba(58,20,29,.45);
  --shadow-soft:0 14px 40px -22px rgba(58,20,29,.4);
  --ease:cubic-bezier(.22,.61,.36,1);
  --container:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.06;margin:0;letter-spacing:.004em}
p{margin:0 0 1rem}

/* Tamil-script text */
.ta{font-family:var(--tamil);font-weight:500;letter-spacing:0}
.ta-sub{font-family:var(--tamil);font-weight:500}

/* ============ LAYOUT ============ */
.container{max-width:var(--container);margin:0 auto;padding:0 28px}
.section{padding:clamp(64px,9vw,128px) 0}
.center{text-align:center}
.eyebrow{
  font-family:var(--body);font-size:.74rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--terracotta);font-weight:500;margin:0 0 18px;display:inline-flex;align-items:center;
}
.eyebrow::before{content:"";width:7px;height:7px;margin-right:.85em;flex:none;
  background:var(--cobalt);transform:rotate(45deg);
  box-shadow:0 0 0 4px rgba(27,94,140,.16)}
.eyebrow.solo::before{display:none}
.title{font-size:clamp(2.4rem,5.4vw,4.6rem);color:var(--maroon-deep);font-weight:600}
.title em{font-style:italic;font-weight:500;color:var(--terracotta)}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:60ch}
.center .lead{margin-left:auto;margin-right:auto}

/* ornamental kolam divider */
.divider{position:relative;display:block;height:42px;width:220px;margin:22px auto;
  font-size:0;line-height:0;
  background:url("img/kolam.svg") center/38px 38px no-repeat}
.divider::before,.divider::after{content:"";position:absolute;top:50%;width:78px;height:2px;
  background:linear-gradient(90deg,transparent,var(--turmeric))}
.divider::before{left:0}
.divider::after{right:0;background:linear-gradient(90deg,var(--turmeric),transparent)}
.center .divider{margin-left:auto;margin-right:auto}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:.6em;cursor:pointer;border:0;
  font-family:var(--body);font-weight:500;font-size:.95rem;letter-spacing:.02em;
  padding:15px 30px;border-radius:999px;transition:.35s var(--ease);
}
.btn-primary{background:var(--maroon);color:#fff;box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--maroon-deep);transform:translateY(-3px)}
.btn-gold{background:linear-gradient(135deg,var(--turmeric-soft),var(--turmeric) 45%,var(--terracotta));
  color:var(--maroon-deep);font-weight:500;
  box-shadow:0 10px 24px -12px rgba(191,91,46,.7),inset 0 1px 0 rgba(255,255,255,.4)}
.btn-gold:hover{transform:translateY(-3px);filter:brightness(1.04)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{background:transparent;color:var(--maroon);border:1px solid var(--maroon)}
.btn-outline:hover{background:var(--maroon);color:#fff}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ============ HEADER ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:16px clamp(20px,4vw,52px);
  background:linear-gradient(180deg,rgba(33,22,16,.82),rgba(33,22,16,.16));
  border-bottom:1px solid rgba(227,198,106,.18);
  transition:.4s var(--ease);
}
.site-header.solid{
  background:linear-gradient(180deg,#43301f,#2c1d13);
  border-bottom:2px solid var(--turmeric);
  box-shadow:0 14px 32px -22px rgba(0,0,0,.7)
}
.brand{display:flex;align-items:center;gap:14px;color:var(--cream)}
.brand .mark{
  width:50px;height:50px;border-radius:50%;display:grid;place-items:center;flex:none;
  background:radial-gradient(circle at 50% 36%,var(--turmeric-soft),var(--turmeric) 56%,var(--terracotta));
  font-family:var(--tamil);font-weight:600;font-size:1.55rem;color:var(--maroon-deep);
  box-shadow:0 6px 18px -8px rgba(0,0,0,.5),inset 0 0 0 2px rgba(255,255,255,.6),inset 0 0 0 4px rgba(107,31,42,.22)
}
.brand b{font-family:var(--display);font-weight:600;font-size:1.55rem;display:block;line-height:1.04;letter-spacing:.01em}
.brand span{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;opacity:.85}
.brand .ta-sub{font-size:.86rem;letter-spacing:.04em;text-transform:none;opacity:.94;display:block;margin-top:2px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  padding:10px 16px;border-radius:999px;font-size:.92rem;color:var(--cream);opacity:.92;
  transition:.3s var(--ease)
}
.nav a:not(.btn):hover,.nav a:not(.btn).active{background:rgba(227,198,106,.22);color:#fff;opacity:1}
.nav .btn{padding:11px 22px;margin-left:8px}
.burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2px;background:currentColor;display:block;color:var(--cream)}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;
}
/* hero slideshow */
.hero-slides{position:absolute;inset:0;z-index:-3;overflow:hidden}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transform:scale(1.06);transition:opacity 1.6s var(--ease);will-change:opacity,transform}
.hero-slide.is-active{opacity:1;transform:scale(1.12);
  transition:opacity 1.6s var(--ease),transform 7s linear}
.hero-bg{
  position:absolute;inset:0;z-index:-2;pointer-events:none;
}
/* hero kept clear — no tile/flower overlay over the banner photos */
.hero-arch{
  position:absolute;right:-4%;bottom:0;z-index:-1;width:min(46vw,620px);height:88%;
  background:linear-gradient(180deg,rgba(202,160,54,.22),rgba(191,91,46,.4));
  border-radius:50% 50% 0 0 / 60% 60% 0 0;
  border:2px solid rgba(227,198,106,.4);
  box-shadow:inset 0 0 120px rgba(0,0,0,.4);
}
/* kalasam finial atop the arch */
.hero-arch::after{content:"";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  width:14px;height:14px;border-radius:50%;background:var(--turmeric-soft);
  box-shadow:0 0 0 4px rgba(227,198,106,.28),0 0 18px rgba(227,198,106,.55)}
/* tiled plinth band along the hero base */
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:18px;z-index:1;
  background:url("img/chettinad-border.svg") center/auto 18px repeat-x;
  filter:drop-shadow(0 -2px 6px rgba(0,0,0,.35))}
.hero-inner{padding-top:120px;max-width:780px}
.hero .kicker{
  font-size:.78rem;letter-spacing:.4em;text-transform:uppercase;color:var(--turmeric-soft);
  margin-bottom:22px
}
.hero h1{font-size:clamp(2.8rem,7vw,5.6rem);margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--turmeric-soft)}
.hero p{font-size:1.18rem;max-width:54ch;color:rgba(255,255,255,.92);margin-bottom:34px}
.hero .kicker,.hero h1,.hero p{text-shadow:0 2px 20px rgba(18,6,10,.6),0 1px 3px rgba(18,6,10,.5)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-dots{display:flex;gap:11px;margin-top:34px}
.hero-dots button{width:11px;height:11px;border-radius:50%;padding:0;cursor:pointer;
  background:transparent;border:1px solid rgba(227,198,106,.7);transition:.3s var(--ease)}
.hero-dots button:hover{border-color:var(--turmeric-soft);transform:scale(1.1)}
.hero-dots button.is-active{background:var(--turmeric);border-color:var(--turmeric);
  transform:scale(1.15);box-shadow:0 0 10px rgba(227,198,106,.6)}
.scroll-hint{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.7);
  display:flex;flex-direction:column;align-items:center;gap:8px
}
.scroll-hint i{width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.8),transparent);animation:drop 1.8s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============ STATS BAR ============ */
.stats{background:var(--maroon-deep);color:var(--cream)}
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-top:40px;padding-bottom:40px}
.stat{text-align:center}
.stat b{font-family:var(--display);font-size:2.6rem;color:var(--turmeric-soft);display:block;line-height:1}
.stat span{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;opacity:.8}

/* ============ CARDS / GRID ============ */
.grid{display:grid;gap:26px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

.card{
  background:var(--paper);border-radius:var(--r-lg);padding:30px;border:1px solid var(--line);
  box-shadow:var(--shadow-soft);transition:.4s var(--ease);position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .ico{
  width:58px;height:58px;border-radius:16px;display:grid;place-items:center;font-size:1.5rem;
  background:var(--cream-2);color:var(--terracotta);margin-bottom:18px
}
.card h3{font-size:1.4rem;color:var(--maroon-deep);margin-bottom:8px}
.card p{color:var(--ink-soft);margin:0;font-size:.96rem}

/* space tiles (image-led) */
.tile{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:300px;
  display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow-soft);
  transition:.5s var(--ease)}
.tile:hover{transform:translateY(-6px)}
.tile{isolation:isolate}
.tile .ph{position:absolute;inset:0;z-index:0}
.tile .cap{padding:26px;position:relative;z-index:2;width:100%}
.tile .cap::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(0deg,rgba(42,13,18,.86),transparent)}
.tile h3{font-size:1.5rem;margin-bottom:4px}
.tile span{font-size:.86rem;opacity:.85}
.tile.tall{min-height:430px}

/* image placeholder styles (no real photos in mockup) */
.ph{background:linear-gradient(135deg,var(--terracotta),var(--maroon));position:relative;overflow:hidden}
.ph::after{content:attr(data-label);position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--display);font-style:italic;font-size:1.05rem;color:rgba(255,255,255,.5);
  letter-spacing:.04em;text-align:center;padding:16px}
.ph-1{background:linear-gradient(135deg,#bf5b2e,#6b1f2a)}
.ph-2{background:linear-gradient(135deg,#caa036,#bf5b2e)}
.ph-3{background:linear-gradient(135deg,#7c8b5b,#3a2a20)}
.ph-4{background:linear-gradient(135deg,#6b1f2a,#3a1118)}
.ph-5{background:linear-gradient(135deg,#4a141d,#bf5b2e)}
.ph-6{background:linear-gradient(135deg,#3a2a20,#caa036)}
/* athangudi tile texture overlay */
.ph.tex::before{content:"";position:absolute;inset:0;opacity:.22;
  background-image:radial-gradient(circle at 25% 25%,#fff 0 3px,transparent 4px),
                   radial-gradient(circle at 75% 75%,#fff 0 3px,transparent 4px);
  background-size:30px 30px}

/* real photographs dropped into placeholders */
.ph.shot{background-size:cover;background-position:center;background-repeat:no-repeat}
.ph.shot::after,.ph.shot::before{display:none}
.ph.shot.tint::after{content:"";display:block;position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(42,13,18,.28),transparent 55%)}

/* ============ SPLIT / FEATURE ============ */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.split .visual{border-radius:var(--r-lg);overflow:hidden;min-height:460px;box-shadow:var(--shadow);position:relative}
.framed{position:relative}
.framed::before{content:"";position:absolute;inset:14px;border:1px solid rgba(227,198,106,.6);
  border-radius:calc(var(--r-lg) - 8px);z-index:3;pointer-events:none}

/* ============ TESTIMONIAL ============ */
.quote{background:var(--cream-2);border-radius:var(--r-lg);padding:clamp(36px,5vw,64px);position:relative;overflow:hidden}
.quote::before{content:"\201C";position:absolute;top:-30px;left:24px;font-family:var(--display);
  font-size:12rem;color:rgba(202,160,54,.25);line-height:1}
.quote blockquote{font-family:var(--display);font-style:italic;font-size:clamp(1.3rem,2.6vw,2rem);
  color:var(--maroon-deep);margin:0 0 22px;line-height:1.4;position:relative}
.quote .who{display:flex;align-items:center;gap:14px}
.quote .who .av{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--turmeric),var(--terracotta))}
.quote .who b{display:block;font-family:var(--body);color:var(--ink)}
.quote .who span{font-size:.85rem;color:var(--ink-soft)}

/* ============ CTA BAND ============ */
.cta-band{position:relative;color:#fff;text-align:center;overflow:hidden;
  background:linear-gradient(160deg,var(--maroon),var(--maroon-deep))}
.cta-band::after{content:"";position:absolute;inset:0;opacity:.1;mix-blend-mode:soft-light;
  background-image:url("img/athangudi-tile.svg");background-size:120px 120px}
.cta-band .container{position:relative;z-index:2}
.cta-band h2{font-size:clamp(2rem,4.5vw,3.4rem);margin-bottom:16px}
.cta-band p{color:rgba(255,255,255,.85);max-width:52ch;margin:0 auto 30px}

/* ============ FORMS ============ */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.field label{font-size:.82rem;letter-spacing:.06em;color:var(--ink-soft);font-weight:500}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:1rem;padding:14px 16px;border-radius:14px;
  border:1px solid var(--line);background:var(--paper);color:var(--ink);transition:.25s
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--terracotta);
  box-shadow:0 0 0 4px rgba(191,91,46,.12)}
.field textarea{resize:vertical;min-height:120px}
.form-card{background:var(--paper);border-radius:var(--r-lg);padding:clamp(28px,4vw,44px);
  box-shadow:var(--shadow);border:1px solid var(--line)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* contact item */
.cinfo{display:flex;gap:18px;margin-bottom:30px}
.cinfo .ci{width:52px;height:52px;border-radius:14px;flex:none;display:grid;place-items:center;
  background:var(--cream-2);color:var(--terracotta);font-size:1.3rem}
.cinfo h4{font-family:var(--display);font-size:1.2rem;color:var(--maroon-deep);margin-bottom:2px}
.cinfo p{margin:0;color:var(--ink-soft)}
.cinfo a{color:var(--terracotta)}

/* ============ GALLERY ============ */
.filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.filters button{padding:10px 22px;border-radius:999px;border:1px solid var(--line);background:var(--paper);
  font-family:var(--body);cursor:pointer;color:var(--ink-soft);transition:.3s}
.filters button.active,.filters button:hover{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.masonry{columns:3;column-gap:20px}
.masonry .gitem{break-inside:avoid;margin-bottom:20px;border-radius:var(--r);overflow:hidden;
  cursor:pointer;position:relative;box-shadow:var(--shadow-soft);transition:.4s var(--ease)}
.masonry .gitem:hover{transform:scale(1.02)}
.masonry .gitem .ph{min-height:220px}
.masonry .gitem.t .ph{min-height:320px}
.gitem .glabel{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;font-size:.9rem;
  background:linear-gradient(0deg,rgba(42,13,18,.8),transparent);opacity:0;transition:.3s}
.gitem:hover .glabel{opacity:1}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(20,8,11,.92);display:none;
  align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex}
.lightbox .lb{width:min(900px,90vw);height:min(70vh,620px);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.lightbox .x{position:absolute;top:24px;right:30px;color:#fff;font-size:2rem;cursor:pointer;background:none;border:0}

/* ============ TIMELINE (about) ============ */
.timeline{position:relative;max-width:760px;margin:0 auto;padding-left:34px}
.timeline::before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:2px;
  background:linear-gradient(var(--turmeric),var(--terracotta))}
.tl{position:relative;margin-bottom:38px}
.tl::before{content:"";position:absolute;left:-34px;top:4px;width:18px;height:18px;border-radius:50%;
  background:var(--paper);border:3px solid var(--terracotta)}
.tl b{font-family:var(--display);font-size:1.3rem;color:var(--maroon-deep);display:block}
.tl .yr{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta)}

/* feature list with check */
.flist{list-style:none;padding:0;margin:0}
.flist li{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-bottom:1px dashed var(--line)}
.flist li::before{content:"✦";color:var(--turmeric);flex:none;margin-top:2px}

/* pricing */
.price-card{background:var(--paper);border-radius:var(--r-lg);padding:36px;border:1px solid var(--line);
  box-shadow:var(--shadow-soft);text-align:center;transition:.4s var(--ease)}
.price-card.feat{background:linear-gradient(165deg,var(--maroon),var(--maroon-deep));color:#fff;transform:scale(1.03)}
.price-card.feat .ink-soft,.price-card.feat p{color:rgba(255,255,255,.82)}
.price-card .amt{font-family:var(--display);font-size:2.6rem;color:var(--terracotta);margin:10px 0}
.price-card.feat .amt{color:var(--turmeric-soft)}
.price-card .tag{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--terracotta)}
.price-card.feat .tag{color:var(--turmeric-soft)}
.price-card ul{list-style:none;padding:0;margin:22px 0;text-align:left}
.price-card li{padding:8px 0;border-bottom:1px solid var(--line);font-size:.94rem}
.price-card.feat li{border-color:rgba(255,255,255,.15)}

/* ============ FOOTER ============ */
.site-footer{background:url("img/chettinad-border.svg") top center/auto 22px repeat-x,var(--teak);
  color:var(--cream-2);padding:90px 0 28px}
.site-footer .top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:48px}
.site-footer h4{font-family:var(--display);color:var(--turmeric-soft);margin-bottom:18px;font-size:1.15rem}
.site-footer a{color:rgba(251,245,233,.78);display:block;padding:6px 0;font-size:.94rem;transition:.25s}
.site-footer a:hover{color:var(--turmeric-soft);padding-left:5px}
.site-footer .brand b{color:#fff}
.site-footer .brand span{color:rgba(251,245,233,.6)}
.foot-p{color:rgba(251,245,233,.7);font-size:.95rem}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;padding:0;
  background:rgba(255,255,255,.08);transition:.3s}
.socials a:hover{background:var(--turmeric);color:var(--teak);transform:translateY(-3px)}
.copyright{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;
  justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem;color:rgba(251,245,233,.6)}
.copyright::before{content:"வாழ்க வளமுடன்  ·  May your celebration flourish";
  flex-basis:100%;text-align:center;font-family:var(--tamil);color:var(--turmeric-soft);
  font-size:1.02rem;letter-spacing:.02em;margin-bottom:18px;opacity:.95}

/* ============ PAGE HEAD (inner pages) ============ */
.pagehead{position:relative;padding:160px 0 80px;color:#fff;text-align:center;overflow:hidden;
  background:linear-gradient(160deg,var(--maroon),var(--maroon-deep))}
.pagehead::after{content:"";position:absolute;inset:0;opacity:.1;mix-blend-mode:soft-light;
  background-image:url("img/athangudi-tile.svg");background-size:116px 116px}
/* crafted tile-border base on every inner page header */
.pagehead .container::after{content:"";position:absolute;left:0;right:0;bottom:-46px;height:14px;
  background:url("img/chettinad-border.svg") center/auto 14px repeat-x;opacity:.92}
.pagehead .container{position:relative;z-index:2}
.pagehead h1{font-size:clamp(2.4rem,5.5vw,4.4rem);margin-bottom:14px}
.pagehead h1 em{font-style:italic;color:var(--turmeric-soft)}
.pagehead p{color:rgba(255,255,255,.82);max-width:56ch;margin:0 auto}
.crumbs{font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--turmeric-soft);margin-bottom:18px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:.8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}.split.rev{direction:ltr}
  .site-footer .top{grid-template-columns:1fr 1fr}
  .masonry{columns:2}
  .stats .container{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .nav{position:fixed;inset:64px 14px auto 14px;flex-direction:column;align-items:stretch;
    background:var(--cream);border-radius:var(--r-lg);padding:14px;box-shadow:var(--shadow);
    transform:translateY(-14px);opacity:0;pointer-events:none;transition:.3s var(--ease)}
  .nav.open{transform:none;opacity:1;pointer-events:auto}
  .nav a{color:var(--teak)}
  .burger{display:flex}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .row-2{grid-template-columns:1fr}
  .masonry{columns:1}
  .quote::before{display:none}
  .price-card.feat{transform:none}
  .divider{width:180px}
  .divider::before,.divider::after{width:58px}
}

/* ============ QUALITY FLOOR ============ */
/* visible keyboard focus */
a:focus-visible,button:focus-visible,.btn:focus-visible,
input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--cobalt);outline-offset:3px;border-radius:6px}

/* honour reduced-motion preference */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .scroll-hint i{animation:none}
}
