/* ============================================================
   URBANIA RENTALS CHENNAI — v3 · bespoke B&W editorial
   Archivo (sans) + Instrument Serif Italic (accent)
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#0a0a0a; --white:#fff; --soft:#f4f4f4; --soft-d:#131313;
  --line:#e3e3e3; --line-strong:#bdbdbd; --line-d:rgba(255,255,255,.15); --line-d-strong:rgba(255,255,255,.42);
  --gray:#7c7c7c;
  --sans:'Archivo',system-ui,sans-serif; --serif:'Instrument Serif',Georgia,serif;
  --pad:clamp(1.25rem,4vw,4.5rem); --sec:clamp(4.5rem,9vw,8.5rem);
}
html{scroll-behavior:auto}
body{font-family:var(--sans);background:var(--white);color:var(--black);font-size:1rem;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip}
img,svg,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}
::selection{background:var(--black);color:var(--white)}
.skip{position:absolute;left:-9999px;top:0;background:var(--black);color:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:0}
.wrap{padding-inline:var(--pad);max-width:1480px;margin-inline:auto}
.sec{padding-block:var(--sec)}
.sec-dark{background:var(--black);color:var(--white)}

/* ---- type ---- */
h1,h2,h3,h4{font-weight:500;line-height:1.04;letter-spacing:-.022em}
.d1{font-size:clamp(2.6rem,7.4vw,6.4rem)}
.d2{font-size:clamp(2rem,4.8vw,3.9rem)}
.d3{font-size:clamp(1.4rem,2.6vw,2.1rem)}
.serif,em.s{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:0}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);line-height:1.6;color:#3c3c3c;max-width:62ch}
.sec-dark .lead{color:#cfcfcf}
.small{font-size:.84rem;color:var(--gray)}

/* ---- kicker (editorial section label) ---- */
.kick{display:flex;align-items:baseline;gap:1rem;margin-bottom:1.7rem;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gray);font-weight:500}
.kick .ki{font-family:var(--serif);font-style:italic;font-size:1.05rem;letter-spacing:0;text-transform:none;color:currentColor}
.kick .kl{white-space:nowrap}
.kick::after{content:"";flex:1;height:1px;background:currentColor;opacity:.25;align-self:center;min-width:2rem}
.kick .kc{font-family:var(--serif);font-style:italic;font-size:.95rem;letter-spacing:0;text-transform:none;opacity:.7}
.kick.center{justify-content:center}.kick.center::after{display:none}

/* ---- buttons: sharp, divided arrow cell ---- */
.btn{position:relative;display:inline-flex;align-items:center;background:var(--black);color:var(--white);
  border:1px solid var(--black);font-weight:500;font-size:.93rem;letter-spacing:.01em;
  padding:1rem 4.1rem 1rem 1.5rem;transition:background .3s,color .3s}
.btn::before{content:"";position:absolute;right:48px;top:0;bottom:0;width:1px;background:currentColor;opacity:.28;transition:opacity .3s}
.btn::after{content:"↗";position:absolute;right:0;top:0;bottom:0;width:48px;display:grid;place-items:center;font-size:1rem;transition:transform .35s}
.btn:hover{background:var(--white);color:var(--black)}
.btn:hover::after{transform:rotate(45deg)}
.btn .arr{display:none}
.btn-light{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-light:hover{background:transparent;color:var(--white)}
.btn-ghost{background:transparent;color:var(--black)}
.btn-ghost:hover{background:var(--black);color:var(--white)}
.sec-dark .btn-ghost,.p-hero .btn-ghost,.hero .btn-ghost,.cta-band .btn-ghost{color:var(--white);border-color:var(--white)}
.sec-dark .btn-ghost:hover,.p-hero .btn-ghost:hover,.hero .btn-ghost:hover,.cta-band .btn-ghost:hover{background:var(--white);color:var(--black)}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}

/* ---- header + dropdowns ---- */
.hdr{position:fixed;inset:0 0 auto 0;z-index:100;transition:background .35s,border-color .35s;border-bottom:1px solid transparent}
.hdr.solid{background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-color:var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem var(--pad);max-width:1480px;margin-inline:auto}
.logo{font-size:1.28rem;font-weight:600;letter-spacing:-.02em;line-height:1;z-index:102}
.logo em{font-family:var(--serif);font-style:italic;font-weight:400}
.hdr.on-dark:not(.solid){color:#fff}
.nav{display:flex;gap:1.7rem;font-size:.92rem}
.nav>li{position:relative}
.nav>li>a{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 0;opacity:.85;transition:opacity .25s}
.nav>li>a:hover{opacity:1}
.nav .car{font-size:.55rem;transition:transform .3s;translate:0 1px}
.nav li.open>a .car,.nav li:hover>a .car{transform:rotate(180deg)}
.sub{position:absolute;top:100%;left:-1.2rem;min-width:290px;background:var(--black);color:#fff;border:1px solid #262626;
  padding:.7rem;opacity:0;visibility:hidden;transform:translateY(12px);transition:.25s;z-index:110}
.nav li:hover>.sub,.nav li:focus-within>.sub,.nav li.open>.sub{opacity:1;visibility:visible;transform:translateY(6px)}
.sub a{display:flex;align-items:baseline;gap:.8rem;padding:.55rem .8rem;font-size:.88rem;color:#d9d9d9;transition:.2s}
.sub a:hover{background:#1b1b1b;color:#fff}
.sub a .i{font-family:var(--serif);font-style:italic;font-size:.78rem;color:#7c7c7c;min-width:1.5rem}
.sub a small{margin-left:auto;color:#7c7c7c;font-size:.72rem}
.sub .all{border-top:1px solid #262626;margin-top:.4rem;padding-top:.65rem;color:#fff;font-weight:500}
.hdr-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.62rem 1.2rem;font-size:.88rem;font-weight:500;
  background:var(--black);color:#fff;border:1px solid var(--black);transition:.3s}
.hdr.on-dark:not(.solid) .hdr-cta{background:#fff;color:var(--black);border-color:#fff}
.hdr-cta:hover{transform:translateY(-2px)}
.burger{display:none;flex-direction:column;gap:5px;z-index:102;padding:.4rem}
.burger span{width:24px;height:2px;background:currentColor;transition:.3s}
.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-open .burger span:nth-child(2){opacity:0}
.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.m-nav{position:fixed;inset:0;background:var(--black);color:#fff;z-index:101;display:none;flex-direction:column;justify-content:center;padding:var(--pad);gap:.35rem;overflow:auto}
.menu-open .m-nav{display:flex}
.m-nav a{font-size:clamp(1.5rem,6vw,2.4rem);font-weight:500;letter-spacing:-.02em;padding:.3rem 0;border-bottom:1px solid var(--line-d)}
.m-nav a em{font-family:var(--serif);font-style:italic;font-weight:400}
.m-nav .m-call{margin-top:1.4rem;font-size:1rem;color:#bdbdbd;border:0}
@media(max-width:1020px){.nav,.hdr-cta{display:none}.burger{display:flex}}

/* ---- home hero ---- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;background:var(--black);color:#fff;overflow:hidden;padding-top:6rem}
.hero-bg{position:absolute;inset:0;opacity:.42}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.97) 8%,rgba(10,10,10,.3) 60%,rgba(10,10,10,.65))}
.hero-in{position:relative;z-index:2;padding:0 var(--pad) clamp(2.5rem,5vw,4.5rem);max-width:1480px;margin-inline:auto;width:100%}
.hero-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.2rem;border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d);padding:1rem 0;margin-bottom:clamp(2rem,4vw,3.5rem)}
.hero-meta div span{display:block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:#9a9a9a;margin-bottom:.35rem}
.hero-meta div b{font-weight:500;font-size:.95rem}
.hero h1{max-width:13ch}
.hero .lead{margin-top:1.4rem;color:#d6d6d6}
.hero-award{position:absolute;right:var(--pad);bottom:clamp(2.5rem,5vw,4.5rem);background:rgba(255,255,255,.06);border:1px solid var(--line-d);backdrop-filter:blur(8px);padding:1.1rem 1.3rem;max-width:240px;font-size:.85rem}
.hero-award span{display:block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#9a9a9a;margin-bottom:.5rem}
@media(max-width:900px){.hero-award{display:none}}
.line-mask{overflow:hidden;display:block}.line-mask>span{display:block}

/* ---- crossing ribbons ---- */
.x-mq{position:relative;height:clamp(150px,18vw,240px);overflow:hidden;background:var(--white)}
.ribbon{position:absolute;top:50%;left:-6%;width:112%;padding:.85rem 0;overflow:hidden;white-space:nowrap}
.ribbon .trk{display:inline-flex;gap:2.6rem;animation:mq 26s linear infinite;font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,2vw,1.5rem);padding-right:2.6rem}
.ribbon .sep{opacity:.45}
.ribbon-a{background:var(--black);color:#fff;transform:translateY(-78%) rotate(-3deg);z-index:2;box-shadow:0 14px 40px rgba(0,0,0,.18)}
.ribbon-b{background:var(--white);color:var(--black);border-block:1px solid var(--black);transform:translateY(-26%) rotate(2.4deg)}
.ribbon-b .trk{animation-direction:reverse}
.x-mq.on-dark{background:var(--black)}
.x-mq.on-dark .ribbon-b{background:var(--black);color:#fff;border-color:var(--line-d-strong)}
@keyframes mq{to{transform:translateX(-50%)}}
.marquee-giant{overflow:hidden;padding:2.5rem 0 1rem}
.mq-giant{display:flex;gap:4rem;width:max-content;animation:mq 40s linear infinite;white-space:nowrap;font-family:var(--serif);font-style:italic;font-size:clamp(4rem,11vw,10rem);line-height:1;color:transparent;-webkit-text-stroke:1px var(--line-strong)}

/* ---- section heads ---- */
.sec-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-bottom:clamp(2.2rem,5vw,4rem)}
.sec-head .lead{margin-top:1rem}

/* ---- cards: soft surfaces, generous gaps ---- */
.grid{display:grid;gap:clamp(1rem,2vw,1.6rem)}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1000px){.g4,.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.g4,.g3,.g2{grid-template-columns:1fr}}
.ncard{background:var(--soft);padding:2.1rem 1.9rem 2.3rem;display:flex;flex-direction:column;gap:.9rem;min-height:240px;position:relative;transition:background .35s,color .35s,transform .35s}
.sec-dark .ncard{background:var(--soft-d)}
.ncard .num{font-family:var(--serif);font-style:italic;font-size:1.45rem;color:var(--gray);align-self:flex-end}
.ncard h3{font-size:1.18rem;margin-top:auto}
.ncard p{font-size:.92rem;color:#5a5a5a;line-height:1.6}
.sec-dark .ncard p{color:#b6b6b6}
a.ncard:hover{background:var(--black);color:#fff;transform:translateY(-5px)}
a.ncard:hover p{color:#c4c4c4}
.sec-dark a.ncard:hover{background:#fff;color:var(--black)}
.sec-dark a.ncard:hover p{color:#4d4d4d}
a.ncard .go{position:absolute;top:1.6rem;left:1.9rem;transition:transform .3s}
a.ncard:hover .go{transform:translate(3px,-3px)}

/* staircase */
.stair{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;align-items:start}
.stair .ncard{background:var(--white);color:var(--black);min-height:280px}
.stair .ncard p{color:#5a5a5a}
.stair .ncard .num{font-size:1.6rem;color:#a8a8a8}
@media(min-width:1001px){
  .stair .ncard:nth-child(2){margin-top:3.2rem}
  .stair .ncard:nth-child(3){margin-top:6.4rem}
  .stair .ncard:nth-child(4){margin-top:9.6rem}
  .stair{padding-bottom:9.6rem}
}
@media(max-width:1000px){.stair{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.stair{grid-template-columns:1fr}}

/* ---- arch carousel ---- */
.arch-wrap{position:relative}
.arch-row{display:flex;gap:1.3rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:2.5rem .2rem 1.2rem;scrollbar-width:none}
.arch-row::-webkit-scrollbar{display:none}
.arch-card{flex:0 0 252px;scroll-snap-align:start;border:1.5px dashed var(--line-d-strong);border-radius:170px 170px 0 0;
  padding:2rem 1.3rem 1.6rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.9rem;transition:.4s}
.arch-card .disc{width:150px;height:150px;border-radius:50%;overflow:hidden;border:1px solid var(--line-d)}
.arch-card .disc img{width:100%;height:100%;object-fit:cover}
.arch-card .i{font-family:var(--serif);font-style:italic;font-size:.85rem;color:#8d8d8d}
.arch-card h3{font-size:1.05rem;line-height:1.25}
.arch-card p{font-size:.8rem;color:#9b9b9b;line-height:1.5}
.arch-card .from{margin-top:auto;font-size:.84rem}
.arch-card:hover{background:var(--white);color:var(--black);border-color:var(--white);border-style:solid;transform:translateY(8px)}
.arch-card:hover p,.arch-card:hover .i{color:#666}
.arch-light .arch-card{border-color:var(--line-strong)}
.arch-light .arch-card .disc{border-color:var(--line)}
.arch-light .arch-card:hover{background:var(--black);color:#fff;border-color:var(--black)}
.arch-light .arch-card:hover p,.arch-light .arch-card:hover .i{color:#bdbdbd}
.arch-nav{display:flex;gap:.6rem}
.arch-nav button{width:46px;height:46px;border:1px solid currentColor;display:grid;place-items:center;font-size:1.05rem;transition:.3s;opacity:.85}
.arch-nav button:hover{opacity:1;background:currentColor}
.arch-nav button:hover span{filter:invert(1)}

/* ---- hover list (+thumb) ---- */
.h-list{border-top:1px solid var(--line)}
.sec-dark .h-list{border-color:var(--line-d)}
.h-list .row{display:grid;grid-template-columns:auto auto 1fr auto auto;align-items:center;gap:1.3rem;padding:1.3rem .3rem;border-bottom:1px solid var(--line);transition:opacity .35s,filter .35s,padding .3s}
.sec-dark .h-list .row{border-color:var(--line-d)}
.h-list .row .ar{font-size:1.05rem;transition:transform .3s}
.h-list .row .thumb{width:96px;aspect-ratio:3/2;overflow:hidden;background:var(--soft)}
.h-list .row .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.h-list .row:hover .thumb img{transform:scale(1.07)}
.h-list .row h3{font-size:clamp(1.15rem,2.3vw,1.7rem);font-weight:500}
.h-list .row .meta{font-size:.85rem;color:var(--gray);text-align:right;line-height:1.45}
.h-list .row .price{font-size:.95rem;font-weight:500;white-space:nowrap}
.h-list .row .price em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--gray);font-size:.82rem}
@media(hover:hover){.h-list:hover .row{opacity:.3;filter:blur(1.6px)}.h-list .row:hover{opacity:1;filter:none;padding-left:.9rem}}
.h-list .row:hover .ar{transform:rotate(45deg)}
@media(max-width:680px){.h-list .row{grid-template-columns:auto 1fr}.h-list .row .thumb{display:none}
.h-list .row .meta{grid-column:2;text-align:left}.h-list .row .price{grid-column:2}}

/* ---- tables: rate-card style ---- */
.t-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.95rem;min-width:660px}
thead th{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray);font-weight:500;
  text-align:left;padding:0 1.1rem 1rem;border-bottom:2px solid var(--black)}
td{padding:1.45rem 1.1rem;border-bottom:1px solid var(--line);vertical-align:middle;transition:background .25s}
tbody tr:hover td{background:var(--soft)}
td b{font-weight:600;font-size:1.02rem}
td .sm{display:block;font-size:.78rem;color:var(--gray);margin-top:.25rem;font-weight:400}
td .big{font-family:var(--serif);font-style:italic;font-size:1.25rem;white-space:nowrap}
.sec-dark thead th{color:#9a9a9a;border-color:#fff}
.sec-dark td{border-color:var(--line-d)}
.sec-dark tbody tr:hover td{background:var(--soft-d)}

/* ---- steps: editorial split list ---- */
.steplist{display:flex;flex-direction:column}
.steplist .st{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;padding:1.5rem 0;border-bottom:1px solid var(--line);align-items:start}
.sec-dark .steplist .st{border-color:var(--line-d)}
.steplist .st:first-child{border-top:1px solid var(--line)}
.sec-dark .steplist .st:first-child{border-color:var(--line-d)}
.steplist .sn{width:52px;height:52px;border:1px solid currentColor;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:1.1rem}
.steplist h3{font-size:1.15rem;margin-bottom:.4rem}
.steplist p{font-size:.92rem;color:#5a5a5a;max-width:52ch}
.sec-dark .steplist p{color:#b6b6b6}

/* ---- stat row: borderless editorial numbers ---- */
.statrow{display:flex;flex-wrap:wrap;gap:clamp(2.5rem,7vw,6.5rem);align-items:flex-start}
.statrow .st b{display:block;font-size:clamp(2.8rem,6vw,4.6rem);font-weight:500;letter-spacing:-.035em;line-height:1}
.statrow .st b em{font-family:var(--serif);font-style:italic;font-weight:400}
.statrow .st span{font-size:.85rem;color:var(--gray);display:block;margin-top:.55rem;max-width:18ch}

/* ---- accordion ---- */
.acc{border-top:1px solid var(--line)}
.acc-item{border-bottom:1px solid var(--line)}
.sec-dark .acc,.sec-dark .acc-item{border-color:var(--line-d)}
.acc-q{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%;text-align:left;padding:1.4rem .2rem;font-size:1.05rem;font-weight:500}
.acc-q .ic{flex:0 0 auto;width:14px;height:14px;position:relative}
.acc-q .ic::before,.acc-q .ic::after{content:"";position:absolute;background:currentColor;transition:transform .3s}
.acc-q .ic::before{inset:0 6px;width:2px;left:6px}
.acc-q .ic::after{inset:6px 0;height:2px;top:6px}
.acc-item.open .acc-q .ic::before{transform:rotate(90deg)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1)}
.acc-a p{padding:0 .2rem 1.5rem;color:#4d4d4d;max-width:70ch}
.sec-dark .acc-a p{color:#bdbdbd}

/* ---- PAGE HEADER (phx) — light editorial, no black band ---- */
.phx{padding-top:7.5rem;background:var(--white);color:var(--black)}
.phx-top{display:flex;align-items:center;gap:1.4rem;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.phx-rule{flex:1;height:1px;background:var(--line-strong);opacity:.55}
.phx-label{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gray);font-weight:500;white-space:nowrap}
.phx-label .ki{font-family:var(--serif);font-style:italic;font-size:1.05rem;letter-spacing:0;text-transform:none;color:var(--black);margin-right:.2rem}
.phx-head{display:grid;grid-template-columns:1.35fr .65fr;gap:clamp(2rem,5vw,4.5rem);align-items:end;padding:clamp(2.6rem,6vw,5rem) 0 clamp(2.4rem,5vw,4rem)}
@media(max-width:920px){.phx-head{grid-template-columns:1fr;align-items:start;gap:1.8rem}}
.phx-lead h1{max-width:15ch}
.phx-side{padding-bottom:.4rem}
.phx-side .lead{color:#3c3c3c}
.phx-side .hero-meta{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);margin:0}
.phx-side .hero-meta div{background:var(--white);padding:.95rem 1.1rem}
.phx-side .hero-meta div span{display:block;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gray);margin-bottom:.3rem}
.phx-side .hero-meta div b{font-weight:500;font-size:.92rem}
.phx-side .btn-row{margin-top:1.6rem}
.phx-media{position:relative;overflow:hidden;margin-top:.5rem}
.phx-media .ph{aspect-ratio:21/8;border-left:0;border-right:0}
@media(max-width:760px){.phx-media .ph{aspect-ratio:16/10}}
.phx-tag{position:absolute;left:var(--pad);bottom:1.1rem;z-index:2;font-family:var(--serif);font-style:italic;font-size:clamp(2.2rem,6vw,4.5rem);color:#fff;mix-blend-mode:difference;line-height:1;pointer-events:none}
/* 404 */
.err404{padding:9rem var(--pad) 5rem;position:relative;overflow:hidden;text-align:center;background:var(--black);color:#fff;min-height:70vh;display:flex;align-items:center;justify-content:center}
.err404 .wrap{position:relative;z-index:2}
.err404 .lead{color:#cfcfcf;margin:1.2rem auto 0}
.err404 .btn-row{justify-content:center}
.err404 .err-kick{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:#9a9a9a;display:block;margin-bottom:1.2rem}
.err-big{position:absolute;inset:0;display:grid;place-items:center;z-index:1;font-size:clamp(12rem,40vw,30rem);font-weight:600;color:transparent;-webkit-text-stroke:1px #222;pointer-events:none;line-height:1}
/* page-header buttons live on white → force dark treatment */
.phx .btn-light{background:var(--black);color:#fff;border-color:var(--black)}
.phx .btn-light:hover{background:transparent;color:var(--black)}
.phx .btn-ghost{background:transparent;color:var(--black);border-color:var(--black)}
.phx .btn-ghost:hover{background:var(--black);color:#fff}
.phx .chip{border-color:var(--line-strong)}

/* ---- imagery ---- */
.ph{background:var(--white);border:1px dashed var(--line-strong);position:relative;overflow:hidden;display:block}
.sec-dark .ph,.p-hero .ph{background:#101010;border-color:#3a3a3a}
.ph img{width:100%;height:100%;object-fit:cover}
figure.fig figcaption{font-size:.8rem;color:var(--gray);padding-top:.7rem}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.strip3{display:grid;grid-template-columns:1.2fr 1fr .85fr;gap:clamp(1rem,2.5vw,2rem);align-items:start}
.strip3 figure:nth-child(2){margin-top:clamp(1.5rem,4vw,3.5rem)}
.strip3 figure:nth-child(3){margin-top:clamp(.5rem,2vw,1.5rem)}
@media(max-width:760px){.strip3{grid-template-columns:1fr 1fr}.strip3 figure:nth-child(3){display:none}}
.band{padding:0}
.band .ph{border-left:0;border-right:0}

/* ---- quotes ---- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media(max-width:900px){.quotes{grid-template-columns:1fr}}
.quote{background:var(--soft);padding:2.2rem 1.9rem;display:flex;flex-direction:column;gap:1.1rem;transition:transform .45s}
.quote.inv{background:var(--black);color:#fff}
@media(min-width:901px){
  .quote:nth-child(1){transform:rotate(-1.6deg) translateY(10px)}
  .quote:nth-child(2){transform:rotate(1.1deg)}
  .quote:nth-child(3){transform:rotate(-.8deg) translateY(18px)}
  .quote:hover{transform:rotate(0) translateY(0)}
}
.quote p{font-size:.95rem;line-height:1.7;color:#454545}
.quote.inv p{color:#c9c9c9}
.quote .who{display:flex;align-items:center;gap:.8rem}
.quote .who .av{width:42px;height:42px;border-radius:50%;overflow:hidden;flex:0 0 auto;background:#ddd}
.quote .who .av img{width:100%;height:100%;object-fit:cover}
.quote .who b{display:block;font-weight:600;font-size:.95rem}
.quote .who span{font-size:.8rem;color:var(--gray)}
.quote .mark{font-family:var(--serif);font-style:italic;font-size:2.2rem;line-height:.6;margin-top:auto;opacity:.35}

/* ---- footer ---- */
.cta-band{background:var(--black);color:#fff;text-align:center;padding:var(--sec) var(--pad)}
.cta-band h2{margin-inline:auto;max-width:16ch}
footer{background:var(--black);color:#fff;border-top:1px solid var(--line-d)}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;padding:4rem var(--pad);max-width:1480px;margin-inline:auto}
@media(max-width:1000px){.ft-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ft-grid{grid-template-columns:1fr}}
.ft-grid h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:#8c8c8c;margin-bottom:1.1rem;font-weight:500}
.ft-grid li{margin-bottom:.55rem}
.ft-grid a{font-size:.92rem;color:#cfcfcf;transition:color .25s}
.ft-grid a:hover{color:#fff}
.ft-brand p{color:#b0b0b0;font-size:.92rem;max-width:34ch;margin:1rem 0 1.4rem}
.ft-brand .c a{display:block;color:#e6e6e6;margin-bottom:.4rem;font-size:.95rem}
.ft-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding:1.4rem var(--pad);border-top:1px solid var(--line-d);font-size:.8rem;color:#8c8c8c;max-width:1480px;margin-inline:auto}
.wordmark{overflow:hidden;line-height:.82;text-align:center;padding:0 .5rem;user-select:none}
.wordmark span{font-size:clamp(4.4rem,17.5vw,17rem);font-weight:600;letter-spacing:-.04em;display:block;color:transparent;-webkit-text-stroke:1px #3a3a3a;transform:translateY(12%)}
.wordmark em{font-family:var(--serif);font-style:italic;font-weight:400;-webkit-text-stroke:1px #3a3a3a}

/* ---- floating contact ---- */
.float-cta{position:fixed;right:1.1rem;bottom:1.1rem;z-index:90;display:flex;flex-direction:column;gap:.6rem}
.float-cta a{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;background:var(--black);color:#fff;border:1px solid #2c2c2c;box-shadow:0 8px 28px rgba(0,0,0,.22);transition:transform .25s}
.float-cta a:hover{transform:translateY(-3px)}
.float-cta svg{width:22px;height:22px;fill:currentColor}

/* ---- misc ---- */
.rel-links{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.chip{display:inline-flex;align-items:baseline;gap:.55rem;padding:.55rem 1.05rem;border:1px solid var(--line-strong);font-size:.84rem;transition:.25s}
.chip .ci{font-family:var(--serif);font-style:italic;font-size:.78rem;color:var(--gray)}
.chip:hover{background:var(--black);color:#fff;border-color:var(--black)}
.chip:hover .ci{color:#bdbdbd}
.sec-dark .chip,.p-hero .chip{border-color:var(--line-d-strong)}
.sec-dark .chip:hover,.p-hero .chip:hover{background:#fff;color:var(--black);border-color:#fff}
.sec-dark .chip:hover .ci{color:#777}
.prose{max-width:72ch}
.prose p{margin-bottom:1.1rem;color:#333}
.sec-dark .prose p{color:#c9c9c9}
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:2.4rem 0 1rem}
.prose h3{font-size:1.15rem;margin:1.8rem 0 .7rem}
.prose ul{padding:0;margin-bottom:1.1rem}
.prose ul li{position:relative;padding-left:1.4rem;margin-bottom:.45rem;color:#333}
.sec-dark .prose ul li{color:#c9c9c9}
.prose ul li::before{content:"→";position:absolute;left:0;font-size:.85rem;color:var(--gray)}
.note{font-size:.82rem;color:var(--gray);margin-top:.9rem;max-width:75ch}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.5rem)}
.gal figure:nth-child(3n+2){margin-top:clamp(1rem,2.5vw,2rem)}
@media(max-width:900px){.gal{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gal{grid-template-columns:1fr}}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem)}
@media(max-width:800px){.two-col{grid-template-columns:1fr}}

/* ---- reveal gating ---- */
html.js [data-reveal]{opacity:0;transform:translateY(26px);will-change:opacity,transform}
html.js.no-anim [data-reveal]{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html.js [data-reveal]{opacity:1;transform:none}
  .ribbon .trk,.mq-giant{animation:none}
}

/* ============================================================
   v3 build.js component classes (reconciled)
   ============================================================ */
/* eyebrow — serif index + tracked label, no left line */
.eyebrow{display:inline-flex;align-items:baseline;gap:.85rem;margin-bottom:1.5rem}
.eyebrow .ix{font-family:var(--serif);font-style:italic;font-size:1.3rem;line-height:1;color:var(--gray)}
.eyebrow .lb{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gray);font-weight:500;position:relative;top:-.15em}
.sec-dark .eyebrow .ix,.sec-dark .eyebrow .lb,.cta-band .eyebrow .ix,.cta-band .eyebrow .lb{color:#9a9a9a}
.anno{font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,1.5vw,1.35rem);color:var(--gray);max-width:42ch;line-height:1.45}
.sec-dark .anno{color:#a9a9a9}

/* split-cell button */
.btn{position:relative;display:inline-flex;align-items:stretch;background:var(--black);color:#fff;border:1px solid var(--black);font-weight:500;font-size:.93rem;padding:0;overflow:hidden;transition:background .3s,color .3s}
.btn .tx{padding:1rem 1.4rem;display:flex;align-items:center}
.btn .arr{width:50px;display:grid;place-items:center;border-left:1px solid currentColor;font-size:1rem;position:relative;overflow:hidden}
.btn .arr span{transition:transform .35s}
.btn::after{display:none}.btn::before{display:none}
.btn:hover{background:#fff;color:var(--black)}
.btn:hover .arr span{transform:rotate(45deg)}
.btn-light{background:#fff;color:var(--black);border-color:#fff}
.btn-light:hover{background:transparent;color:#fff}
.btn-ghost{background:transparent;color:var(--black)}
.btn-ghost:hover{background:var(--black);color:#fff}
.sec-dark .btn-ghost,.p-hero .btn-ghost,.hero .btn-ghost,.cta-band .btn-ghost{color:#fff;border-color:#fff}
.sec-dark .btn-ghost:hover,.p-hero .btn-ghost:hover,.hero .btn-ghost:hover,.cta-band .btn-ghost:hover{background:#fff;color:var(--black)}

/* underline text link */
.lnk{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;font-size:.95rem;padding-bottom:.2rem;border-bottom:1px solid currentColor}
.lnk .ar{transition:transform .3s}
.lnk:hover .ar{transform:translateX(4px)}

/* legacy grid → soft cards with gaps (no hairline bg) */
.grid.g3,.grid.g4,.grid.g2{background:none}
.frame{border:1px solid var(--line)}
.sec-dark .frame{border-color:var(--line-d)}
.frame .grid{gap:1px;background:var(--line)}
.sec-dark .frame .grid{background:var(--line-d)}

/* steps grid (legacy) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-d);border:1px solid var(--line-d)}
@media(max-width:1000px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.steps{grid-template-columns:1fr}}
.step{background:var(--black);padding:2.2rem 1.8rem;min-height:260px;display:flex;flex-direction:column}
.step:nth-child(2),.step:nth-child(4){transform:translateY(1.6rem)}
@media(max-width:1000px){.step:nth-child(2),.step:nth-child(4){transform:none}}
.step .num{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:#8d8d8d}
.step h3{margin-top:auto;font-size:1.15rem}
.step p{font-size:.9rem;color:#b3b3b3;margin-top:.6rem;line-height:1.6}
.step.inv{background:#fff;color:var(--black)}
.step.inv p{color:#5a5a5a}
.ncard .num{font-family:var(--serif);font-style:italic;font-size:1.45rem;color:var(--gray);align-self:flex-end}

/* split-steps (editorial image + panel) */
.split-steps{display:grid;grid-template-columns:1fr 1fr;background:var(--black);color:#fff}
@media(max-width:900px){.split-steps{grid-template-columns:1fr}}
.split-steps .media{position:relative;overflow:hidden;min-height:340px}
.split-steps .media .ph{height:100%;border:0}
.split-steps .ss-panel{padding:clamp(2.5rem,5vw,4.5rem)}
.ss-item{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;padding:1.4rem 0;border-bottom:1px solid var(--line-d);align-items:start}
.ss-item:first-of-type{border-top:1px solid var(--line-d);margin-top:1.5rem}
.ss-item .nq{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:#9a9a9a}
.ss-item h3{font-size:1.1rem;margin-bottom:.35rem}
.ss-item p{font-size:.9rem;color:#b3b3b3;line-height:1.6}

/* stats (legacy borderless editorial) */
.stats{display:flex;flex-wrap:wrap;gap:clamp(2.5rem,7vw,6rem)}
.stat,.stats .stat{background:none;padding:0}
.stat b{display:block;font-size:clamp(2.6rem,5.5vw,4.2rem);font-weight:500;letter-spacing:-.035em;line-height:1}
.stat span{font-size:.85rem;color:var(--gray);display:block;margin-top:.55rem;max-width:20ch}

/* rate cards */
.rate-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:820px){.rate-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.rate-cards{grid-template-columns:1fr}}
.rcard{background:var(--white);padding:1.7rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}
.rcard .lb{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray)}
.rcard b{font-family:var(--serif);font-style:italic;font-size:2rem;line-height:1;font-weight:400}
.rcard .sm{font-size:.78rem;color:var(--gray);margin-top:auto}

/* spec row */
.spec-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);margin:1.6rem 0}
.spec-row>div{background:var(--white);padding:1.3rem 1.4rem}
.spec-row span{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gray);margin-bottom:.4rem}
.spec-row b{font-weight:500;font-size:1.05rem}

/* banner */
.banner{position:relative;overflow:hidden}
.banner .ph{border-left:0;border-right:0}
.banner .cap{position:absolute;left:var(--pad);bottom:1.2rem;color:#fff;font-family:var(--serif);font-style:italic;font-size:1.1rem;mix-blend-mode:difference;z-index:2}

/* newsletter footer strip */
.news{border-bottom:1px solid var(--line-d)}
.news-in{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;padding:clamp(2.5rem,5vw,3.5rem) var(--pad);max-width:1480px;margin-inline:auto}
.news h4{font-size:clamp(1.4rem,2.6vw,2rem);font-weight:500;color:#fff;max-width:18ch}
.news h4 em{font-family:var(--serif);font-style:italic;font-weight:400}
.news form{display:flex;border:1px solid var(--line-d-strong);min-width:min(420px,100%)}
.news input{flex:1;background:none;border:0;padding:1rem 1.2rem;color:#fff;font:inherit;outline:none}
.news input::placeholder{color:#8c8c8c}
.news button{width:58px;background:#fff;color:var(--black);font-size:1.2rem;transition:background .25s}
.news button:hover{background:#cfcfcf}

/* arch card 'from' link reset */
.arch-card .from.lnk{border:0;padding:0}
.arch-card .from .ar{transition:transform .3s}
.arch-card:hover .from .ar{transform:translateX(4px)}

/* ============================================================
   v4 — ELEVATION LAYER · monochrome, motion + typography first
   Layered on top of v3. Preserves all existing class names;
   later cascade retunes color, type, depth & micro-interaction.
   ============================================================ */
:root{
  --black:#080807; --ink:#080807; --white:#ffffff; --paper:#f7f6f3;
  --soft:#f1f0ec; --soft-2:#e9e8e3; --soft-d:#121211; --soft-d2:#1a1a18;
  --line:#dcd9d1; --line-strong:#bbb7ac; --line-d:rgba(255,255,255,.15); --line-d-strong:rgba(255,255,255,.42);
  --gray:#5c5a54; --gray-2:#7c7a73;
  --ease:cubic-bezier(.22,.61,.36,1); --ease-io:cubic-bezier(.65,.05,.36,1);
  --sec:clamp(5rem,10vw,9.5rem);
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E");
}
html{-webkit-text-size-adjust:100%}
body{background:var(--paper);color:var(--ink);letter-spacing:-.005em;text-rendering:optimizeLegibility}
/* NOTE: the global mix-blend grain overlay was removed — it forced a full-viewport
   re-blend on every scroll frame and was the main cause of scroll jank. */
::selection{background:var(--ink);color:var(--paper)}

/* ---- typography: bolder, tighter display; finer body ---- */
h1,h2,h3,h4{letter-spacing:-.032em;font-weight:600}
.d1{font-size:clamp(2.9rem,8.6vw,7.6rem);letter-spacing:-.045em;line-height:.96}
.d2{font-size:clamp(2.15rem,5.3vw,4.5rem);letter-spacing:-.038em;line-height:1}
.d3{font-size:clamp(1.5rem,2.9vw,2.4rem);letter-spacing:-.03em}
.serif,em.s,.anno,.arch-card .i,.eyebrow .ix,.ribbon .trk,.mq-giant,.kick .ki{font-feature-settings:"liga" 1}
em.s,.serif{font-weight:400}
.lead{font-size:clamp(1.08rem,1.55vw,1.32rem);line-height:1.62;color:#3a3936;letter-spacing:-.01em}
.sec-dark .lead,.hero .lead,.cta-band .lead{color:#d2d1cc}
.eyebrow .lb,.kick,.phx-label,thead th,.ft-grid h4,.hero-meta div span,.spec-row span,.rcard .lb,.err-kick{letter-spacing:.26em}

/* ---- de-wireframe imagery: dark editorial panels, motion-ready ---- */
.ph{background:#0c0c0b;border:0;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.sec-dark .ph,.p-hero .ph,.hero .ph{background:#0c0c0b;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.ph img{transition:transform 1.1s var(--ease),filter 1.1s var(--ease)}
a:hover .ph img,figure:hover .ph img{transform:scale(1.045)}
figure.fig figcaption{color:var(--gray);letter-spacing:-.005em}
.sec-dark figure.fig figcaption{color:#9b9b96}

/* ---- header: crisper glass, refined logo ---- */
.hdr.solid{background:rgba(247,246,243,.82);backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);border-color:var(--line)}
.logo{font-size:1.32rem;letter-spacing:-.03em}
.nav>li>a{opacity:.78;font-weight:500}
.nav>li>a::after{content:"";position:absolute;left:0;bottom:.28rem;height:1px;width:0;background:currentColor;transition:width .4s var(--ease)}
.nav>li:hover>a::after{width:calc(100% - 16px)}
.hdr-cta{letter-spacing:.01em;font-weight:600}
.hdr-cta:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.18)}

/* ---- hero: deeper grade, kinetic meta ---- */
.hero{padding-top:7rem}
.hero-bg{opacity:.5}
.hero-bg::after{background:linear-gradient(to top,rgba(8,8,7,.97) 6%,rgba(8,8,7,.34) 58%,rgba(8,8,7,.7))}
.hero h1{letter-spacing:-.05em}
.hero-meta div b{font-size:1rem}
.hero-award{background:rgba(255,255,255,.045);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}

/* ---- buttons: premium slide-fill + tracked label ---- */
.btn{font-weight:600;letter-spacing:.02em;border-radius:0;isolation:isolate}
.btn .tx{padding:1.05rem 1.55rem;z-index:1}
.btn .arr{width:54px;z-index:1}
.btn .arr span{display:inline-block}
.btn::before{content:"";display:block;position:absolute;inset:0;background:var(--paper);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease);z-index:0}
.btn:hover::before{transform:scaleX(1);transform-origin:left}
.btn:hover{color:var(--ink)}
.btn:hover .arr span{transform:translate(3px,-3px) rotate(45deg)}
.btn-light::before{background:var(--ink)}
.btn-light:hover{color:var(--paper)}
.btn-ghost::before{background:var(--ink)}
.btn-ghost:hover{color:var(--paper)}
.sec-dark .btn-ghost::before,.hero .btn-ghost::before,.cta-band .btn-ghost::before,.p-hero .btn-ghost::before{background:#fff}
.sec-dark .btn-ghost:hover,.hero .btn-ghost:hover,.cta-band .btn-ghost:hover,.p-hero .btn-ghost:hover{color:var(--ink)}
.phx .btn-light{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.phx .btn-light::before{background:var(--paper)}
.phx .btn-light:hover{color:var(--ink)}
.phx .btn-ghost{color:var(--ink);border-color:var(--ink)}
.phx .btn-ghost::before{background:var(--ink)}
.phx .btn-ghost:hover{color:var(--paper)}

/* ---- links: underline wipes out as the arrow advances ---- */
.lnk{border-bottom:0;position:relative;padding-bottom:.28rem;letter-spacing:.01em}
.lnk::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:currentColor;transform-origin:left;transition:transform .45s var(--ease)}
.lnk:hover::after{transform:scaleX(0);transform-origin:right}
.lnk:hover .ar{transform:translateX(5px)}
.from.lnk{padding-bottom:0}
.from.lnk::after{display:none}

/* ---- section heads & rhythm ---- */
.sec-head .anno,.anno{color:var(--gray)}
.eyebrow .ix{font-size:1.45rem}

/* ---- soft cards: hairline depth + smoother lift ---- */
.ncard{background:var(--soft);box-shadow:inset 0 0 0 1px rgba(0,0,0,.04);transition:background .5s var(--ease),color .5s var(--ease),transform .5s var(--ease),box-shadow .5s var(--ease)}
.sec-dark .ncard{background:var(--soft-d);box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.stair .ncard{box-shadow:inset 0 0 0 1px var(--line)}
a.ncard:hover{transform:translateY(-7px);box-shadow:0 24px 50px -22px rgba(0,0,0,.45)}
.ncard h3{font-size:1.22rem;letter-spacing:-.02em}

/* ---- hover list: tighter, gold-free emphasis via weight+scale ---- */
.h-list .row{padding:1.5rem .35rem;transition:opacity .45s var(--ease),filter .45s var(--ease),padding .4s var(--ease),background .4s var(--ease)}
.h-list .row h3{transition:transform .4s var(--ease)}
.h-list .row:hover h3{transform:translateX(6px)}
@media(hover:hover){.h-list:hover .row{opacity:.32;filter:blur(1.4px)}.h-list .row:hover{opacity:1;filter:none;padding-left:1.1rem}}
.h-list .row .price{font-weight:600}

/* ---- arch carousel cards ---- */
.arch-card{border-width:1px;transition:transform .5s var(--ease),background .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease)}
.arch-card:hover{box-shadow:0 28px 60px -28px rgba(0,0,0,.5)}

/* ---- tables ---- */
table{font-size:.96rem}
thead th{border-bottom-color:var(--ink)}
td{transition:background .3s var(--ease)}
td b{font-weight:700}
.t-wrap{box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.sec-dark .t-wrap{box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}

/* ---- quotes / testimonials ---- */
.quote,.masonry .quote{box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);transition:transform .55s var(--ease),box-shadow .55s var(--ease)}
.quote.inv{box-shadow:inset 0 0 0 1px rgba(255,255,255,.07)}
.quote:hover{box-shadow:0 26px 56px -26px rgba(0,0,0,.4)}
.stars{font-size:.95rem;letter-spacing:.12em}

/* ---- accordion ---- */
.acc-q{font-size:1.08rem;font-weight:600;letter-spacing:-.01em;transition:padding-left .35s var(--ease)}
.acc-q:hover{padding-left:.6rem}

/* ---- marquees: refined stroke type ---- */
.mq-giant{-webkit-text-stroke:1px var(--line-strong)}
.ribbon-a{box-shadow:0 18px 48px -18px rgba(0,0,0,.4)}

/* ---- page header (phx) ---- */
.phx{background:var(--paper)}
.phx-media .ph{aspect-ratio:21/8}
.phx-tag{font-size:clamp(2.4rem,6.5vw,5rem)}
.phx-side .hero-meta div{background:var(--paper)}

/* ---- footer wordmark + grid ---- */
.wordmark span{-webkit-text-stroke:1px #313130}
.wordmark em{-webkit-text-stroke:1px #313130}
.ft-grid a{letter-spacing:-.005em}
.float-cta a{box-shadow:0 10px 30px rgba(0,0,0,.3)}
.float-cta a:hover{transform:translateY(-3px) scale(1.04)}

/* ---- cta band ---- */
.cta-band h2{letter-spacing:-.04em}

/* ============================================================
   MOTION — JS-gated entrance states (typography + clip reveals)
   ============================================================ */
/* line-mask headings: each [data-reveal] heading slides up under a mask.
   will-change:auto cancels v3's permanent will-change (too many layers = jank). */
html.js [data-reveal]{opacity:0;transform:translateY(30px);transition:none;will-change:auto}
html.js.no-anim [data-reveal]{opacity:1;transform:none}

/* mask-rise headings (wrapper added by JS) — pad to avoid descender clipping */
.sx-line{display:block;overflow:hidden;padding-bottom:.14em;margin-bottom:-.14em}
.sx-rise{display:block}
.sx-word{display:inline-block}
html.js [data-split] .sx-word{transform:translateY(110%);opacity:0}
html.js.no-anim [data-split] .sx-word{transform:none;opacity:1}

/* image clip + scale reveal (applied by JS to .ph wrappers) */
html.js .ph.sx-clip>img{transform:scale(1.18);filter:saturate(.9)}
html.js.no-anim .ph.sx-clip>img{transform:none}

/* (removed permanent will-change on buttons — GSAP promotes layers only during tweens) */

@media(prefers-reduced-motion:reduce){
  html.js [data-reveal]{opacity:1;transform:none}
  html.js [data-split] .sx-word{transform:none;opacity:1}
  html.js .ph.sx-clip>img{transform:none}
  .ph img{transition:none}
}

/* ============================================================
   v5 — HOMEPAGE SCROLL HERO ("Urbania drives in")
   Pinned scene: van scrubs in from the right as you scroll.
   Degrades to a clean static hero with no JS / reduced motion.
   ============================================================ */
.hero-x{position:relative;background:#070707;color:#fff}
.hero-x-stage{position:relative;height:100svh;min-height:640px;overflow:hidden;display:flex;align-items:center;padding:7rem 0 6.5rem}
.hero-x-stage::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:radial-gradient(110% 80% at 72% 26%,rgba(255,255,255,.06),transparent 55%),
  linear-gradient(to bottom,rgba(7,7,7,.62) 0,transparent 16%,transparent 70%,#070707 100%)}

.hx-word{position:absolute;left:50%;top:43%;transform:translate(-50%,-50%);z-index:1;
  font-family:var(--serif);font-style:italic;font-size:clamp(8rem,27vw,26rem);line-height:.8;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.1);white-space:nowrap;pointer-events:none;user-select:none}

.hx-streaks{position:absolute;right:0;top:43%;z-index:1;display:flex;flex-direction:column;gap:20px;align-items:flex-end;pointer-events:none}
.hx-streaks i{display:block;height:2px;background:linear-gradient(to left,rgba(255,255,255,.55),transparent)}
.hx-streaks i:nth-child(1){width:240px}.hx-streaks i:nth-child(2){width:380px}
.hx-streaks i:nth-child(3){width:300px}.hx-streaks i:nth-child(4){width:440px}.hx-streaks i:nth-child(5){width:200px}

.hx-van{position:absolute;right:-2%;bottom:11%;z-index:2;width:min(64%,1000px);
  filter:drop-shadow(0 46px 60px rgba(0,0,0,.55))}
.hx-van img{width:100%;height:auto}

.hx-scrim{position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(90deg,rgba(7,7,7,.95) 18%,rgba(7,7,7,.55) 42%,rgba(7,7,7,0) 64%)}

.hx-content{position:relative;z-index:5;width:100%;max-width:1480px;margin-inline:auto;padding:0 var(--pad)}
.hx-col{max-width:660px}
.hx-eyebrow{display:inline-flex;align-items:center;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:#cfcec9;margin-bottom:1.4rem}
.hx-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#fff;margin-right:.7rem;animation:hxpulse 2.4s infinite}
@keyframes hxpulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.5)}70%{box-shadow:0 0 0 10px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.hx-title{font-size:clamp(2.9rem,7.6vw,6.8rem);line-height:.96;letter-spacing:-.046em;font-weight:600}
.hx-title .sx-line>span{display:block}
.hx-title em.s{font-weight:400}
.hx-lead{margin-top:1.5rem;max-width:44ch;color:#d2d1cc;font-size:clamp(1.05rem,1.5vw,1.28rem);line-height:1.6}
.hero-x .btn-row{margin-top:2rem}
.hero-x .btn-ghost{color:#fff;border-color:#fff}
.hero-x .btn-ghost::before{background:#fff}
.hero-x .btn-ghost:hover{color:var(--ink)}

.hx-meta{position:absolute;left:0;right:0;bottom:0;z-index:5;display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:rgba(255,255,255,.12);border-top:1px solid rgba(255,255,255,.14)}
.hx-meta div{background:#070707;padding:.95rem var(--pad)}
.hx-meta div:not(:first-child){padding-inline:1.25rem}
.hx-meta span{display:block;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:#8f8e89;margin-bottom:.35rem}
.hx-meta b{font-weight:500;font-size:.92rem}

.hx-cue{position:absolute;left:50%;transform:translateX(-50%);bottom:6.6rem;z-index:6;display:flex;flex-direction:column;align-items:center;gap:.7rem;
  font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:#9a9994;pointer-events:none}
.hx-cue i{width:1px;height:42px;background:rgba(255,255,255,.18);position:relative;overflow:hidden}
.hx-cue i::after{content:"";position:absolute;left:0;top:0;width:1px;height:50%;background:#fff;animation:hxcue 1.8s var(--ease) infinite}
@keyframes hxcue{0%{transform:translateY(-100%)}60%,100%{transform:translateY(300%)}}

@media(max-width:900px){
  .hero-x-stage{align-items:flex-start;padding-top:7.5rem;padding-bottom:11rem;min-height:100svh}
  .hx-word{top:33%;font-size:38vw}
  .hx-van{width:128%;right:-14%;bottom:8.5rem;opacity:.92}
  .hx-streaks{display:none}
  .hx-scrim{background:linear-gradient(180deg,rgba(7,7,7,.9) 28%,rgba(7,7,7,.4) 56%,rgba(7,7,7,.72))}
  .hx-meta{grid-template-columns:repeat(2,1fr)}
  .hx-cue{display:none}
}
@media(max-width:520px){.hx-van{bottom:10rem;width:140%;right:-20%}}

/* JS-gated initial states (prevent flash before the timeline runs) */
html.js .hero-x .hx-title .sx-line>span{transform:translateY(118%)}
html.js .hero-x [data-hx="up"],html.js .hero-x [data-hx="up2"],html.js .hero-x [data-hx="up3"],html.js .hero-x [data-hx="meta"],html.js .hero-x [data-hx="cue"]{opacity:0}
html.js .hero-x .hx-van{opacity:0}
html.js.no-anim .hero-x .hx-title .sx-line>span{transform:none}
html.js.no-anim .hero-x [data-hx]{opacity:1}
html.js.no-anim .hero-x .hx-van{opacity:1}
@media(prefers-reduced-motion:reduce){
  html.js .hero-x .hx-title .sx-line>span{transform:none}
  html.js .hero-x [data-hx]{opacity:1}
  html.js .hero-x .hx-van{opacity:1}
  .hx-eyebrow .dot,.hx-cue i::after{animation:none}
}

/* ============================================================
   v7 — BACKGROUND-IMAGE HERO (transparent nav over a full-bleed photo)
   Image lives at assets/img/photos/hero-luxury-urbania-rental-chennai.webp
   (add it later). Until then the hero shows a clean solid-dark fallback.
   ============================================================ */
.hero{background:#070707}
.hero-bg{opacity:1}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{background:
  linear-gradient(to top,rgba(7,7,7,.92) 4%,rgba(7,7,7,.22) 44%,rgba(7,7,7,.6) 100%),
  linear-gradient(90deg,rgba(7,7,7,.6),rgba(7,7,7,0) 56%)}
.hero-kick{display:inline-flex;align-items:center;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:#dadad6;margin-bottom:1.3rem}
.hero-kick .dot{width:8px;height:8px;border-radius:50%;background:#fff;margin-right:.7rem;animation:hxpulse 2.4s infinite}
.hero .hero-meta{margin-bottom:0;margin-top:clamp(1.6rem,3vw,2.6rem)}
.hero .hx-cue{left:auto;right:var(--pad);transform:none;bottom:clamp(1.6rem,4vw,2.4rem)}
@media(max-width:900px){.hero .hx-cue{display:none}}
@media(prefers-reduced-motion:reduce){.hero-kick .dot{animation:none}}
