/* J & R Flooring — warm editorial flooring catalogue */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700&family=Inter:wght@400;500;600&display=swap');

:root{
  --ink:#2b2722;
  --primary:#7a5a3a;
  --accent:#b08a5e;
  --surface:#f4efe7;
  --stone:#d8cfc1;
  --card:#fbf8f2;
  --line:#e3dacb;
  --muted:#6f665a;
  --rail:#efe7da;
  --display:'Bricolage Grotesque',system-ui,sans-serif;
  --text:'Inter',system-ui,sans-serif;
  --maxw:1240px;
  --rail-w:240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--text);
  color:var(--ink);
  background:var(--surface);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.06;letter-spacing:-.015em;color:var(--ink)}
.eyebrow{
  font-family:var(--text);font-weight:600;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);
}

/* ---------- LAYOUT: left rail + content ---------- */
.shell{display:flex;min-height:100vh}
.rail{
  width:var(--rail-w);flex:0 0 var(--rail-w);
  background:var(--rail);border-right:1px solid var(--line);
  position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:34px 26px;z-index:40;
}
.rail .wordmark{font-family:var(--display);font-weight:700;font-size:1.32rem;letter-spacing:-.02em;line-height:1.05;color:var(--ink)}
.rail .wordmark span{display:block;font-weight:500;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-top:8px}
.railnav{display:flex;flex-direction:column;gap:3px;margin-top:42px}
.railnav a{
  font-family:var(--display);font-weight:500;font-size:1.04rem;color:var(--muted);
  padding:9px 0;border-bottom:1px solid transparent;transition:color .25s var(--ease),padding .25s var(--ease);
  position:relative;
}
.railnav a:hover,.railnav a.active{color:var(--ink);padding-left:14px}
.railnav a.active::before,.railnav a:hover::before{
  content:"";position:absolute;left:0;top:50%;width:7px;height:7px;border-radius:50%;
  background:var(--accent);transform:translateY(-50%);
}
.rail .railfoot{font-size:.78rem;color:var(--muted);line-height:1.7}
.rail .railfoot a.tel{display:block;font-family:var(--display);font-weight:600;font-size:1.18rem;color:var(--primary);margin-bottom:6px}

.content{flex:1 1 auto;min-width:0}

/* ---------- mobile top bar ---------- */
.topbar{display:none}
.mobnav{display:none}

/* ---------- demo banner ---------- */
.demo-banner{
  background:var(--ink);color:#f4efe7;font-size:.82rem;text-align:center;
  padding:9px 18px;letter-spacing:.01em;
}
.demo-banner b{color:var(--accent);font-weight:600}

/* ---------- containers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,5vw,64px)}
section{padding:clamp(64px,9vw,112px) 0}
.section-head{max-width:640px;margin-bottom:48px}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem);margin:14px 0 16px}
.section-head p{color:var(--muted);font-size:1.04rem}

/* ---------- HERO ---------- */
.hero{position:relative;padding:0;background:var(--card)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;min-height:78vh}
.hero-copy{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,6vw,84px) clamp(28px,5vw,72px)}
.hero-copy .eyebrow{margin-bottom:22px}
.hero-copy h1{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:600;max-width:11ch}
.hero-copy p.lead{font-size:1.12rem;color:var(--muted);margin:26px 0 8px;max-width:46ch}
.hero-meta{display:flex;flex-wrap:wrap;gap:14px 30px;margin:30px 0 36px}
.hero-meta div{display:flex;flex-direction:column;line-height:1.2}
.hero-meta b{font-family:var(--display);font-size:1.3rem;color:var(--primary)}
.hero-meta span{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}

.hero-photo{position:relative;overflow:hidden}
.hero-photo img{width:100%;height:100%;object-fit:cover;will-change:transform}
.hero-photo .kb{animation:kenburns 18s var(--ease) infinite alternate}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.1)}}
.hero-tag{
  position:absolute;left:22px;bottom:22px;background:rgba(43,39,34,.82);color:#f4efe7;
  padding:9px 16px;font-size:.78rem;letter-spacing:.04em;backdrop-filter:blur(3px);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;
  font-size:.96rem;padding:14px 26px;border-radius:2px;transition:transform .2s var(--ease),background .2s,color .2s;
  border:1.5px solid var(--primary);
}
.btn-primary{background:var(--primary);color:#f7f1e8}
.btn-primary:hover{background:var(--ink);border-color:var(--ink);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--primary)}
.btn-ghost:hover{background:var(--primary);color:#f7f1e8;transform:translateY(-2px)}
.btn svg{width:17px;height:17px}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface);overflow:hidden;padding:20px 0}
.marquee-track{display:flex;gap:54px;white-space:nowrap;width:max-content;animation:scrollx 28s linear infinite}
.marquee-track span{
  font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,3vw,2.1rem);
  color:transparent;-webkit-text-stroke:1px var(--accent);letter-spacing:.01em;
}
.marquee-track span.fill{color:var(--primary);-webkit-text-stroke:0}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- SIGNATURE: by-surface swatch grid ---------- */
.swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);background:var(--line)}
.swatch{
  position:relative;background:var(--card);padding:34px 28px 30px;min-height:340px;
  display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;
  transition:background .3s var(--ease);
}
.swatch::before{
  content:"";position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:.16;transition:opacity .4s var(--ease),transform .6s var(--ease);transform:scale(1.04);z-index:0;
}
.swatch:hover::before{opacity:.34;transform:scale(1.12)}
.swatch>*{position:relative;z-index:1}
.swatch .num{font-family:var(--display);font-size:.78rem;color:var(--accent);font-weight:600;margin-bottom:auto}
.swatch h3{font-size:1.32rem;margin:0 0 10px}
.swatch p{font-size:.92rem;color:var(--muted);margin-bottom:16px}
.swatch a.more{font-family:var(--display);font-weight:600;font-size:.86rem;color:var(--primary);display:inline-flex;align-items:center;gap:7px}
.swatch a.more svg{width:15px;height:15px;transition:transform .25s var(--ease)}
.swatch:hover a.more svg{transform:translateX(5px)}
.sw-carpet::before{background-image:url('/img/floor13.jpg')}
.sw-vinyl::before{background-image:url('/img/floor00.jpg')}
.sw-commercial::before{background-image:url('/img/floor06.jpg')}
.sw-garage::before{background-image:url('/img/floor10.jpg')}

/* ---------- split material rows ---------- */
.matrow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center;margin-bottom:clamp(56px,8vw,96px)}
.matrow:last-child{margin-bottom:0}
.matrow.flip .mat-media{order:2}
.mat-media{overflow:hidden;border:1px solid var(--line)}
.mat-media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.mat-copy .eyebrow{margin-bottom:14px}
.mat-copy h3{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:16px}
.mat-copy p{color:var(--muted);margin-bottom:14px}
.mat-copy ul{list-style:none;margin-top:18px;display:grid;gap:10px}
.mat-copy li{display:flex;gap:11px;align-items:flex-start;font-size:.96rem}
.mat-copy li svg{width:18px;height:18px;color:var(--accent);flex:0 0 18px;margin-top:3px}

/* ---------- gallery (catalogue grid) ---------- */
.gallery{columns:3;column-gap:16px}
.gallery figure{break-inside:avoid;margin:0 0 16px;overflow:hidden;border:1px solid var(--line);background:var(--card)}
.gallery img{width:100%;transition:transform .6s var(--ease)}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{padding:11px 14px;font-size:.8rem;color:var(--muted);letter-spacing:.02em}

/* ---------- quote band ---------- */
.quote-band{background:var(--ink);color:#f4efe7}
.quote-band .wrap{text-align:center}
.quote-band blockquote{font-family:var(--display);font-weight:500;font-size:clamp(1.4rem,3.4vw,2.2rem);line-height:1.25;max-width:18ch;margin:0 auto 22px;letter-spacing:-.01em}
.quote-band cite{font-style:normal;font-size:.86rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}

/* ---------- band CTA ---------- */
.cta-band{background:var(--primary);color:#f7f1e8}
.cta-band .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:28px}
.cta-band h2{color:#f7f1e8;font-size:clamp(1.6rem,3.4vw,2.3rem);max-width:16ch}
.cta-band .btn-primary{background:#f7f1e8;color:var(--primary);border-color:#f7f1e8}
.cta-band .btn-primary:hover{background:var(--ink);color:#f7f1e8;border-color:var(--ink)}
.cta-band .tel{font-family:var(--display);font-weight:700;font-size:1.5rem;color:#f7f1e8;display:block}

/* ---------- contact / form ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px)}
.contact-info dl{display:grid;gap:24px;margin-top:30px}
.contact-info dt{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
.contact-info dd{font-family:var(--display);font-size:1.2rem;color:var(--ink)}
.contact-info dd a{color:var(--primary)}
form .field{margin-bottom:18px}
form label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
form input,form select,form textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line);background:var(--card);
  font-family:var(--text);font-size:1rem;color:var(--ink);border-radius:2px;
}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--accent)}
form textarea{min-height:130px;resize:vertical}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.82rem;color:var(--muted);margin-top:12px}

/* ---------- footer ---------- */
.foot{background:var(--ink);color:#cdbfa9;padding:54px 0 30px}
.foot .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.foot h4{color:#f4efe7;font-size:1.1rem;margin-bottom:14px}
.foot .wordmark{font-family:var(--display);font-weight:700;font-size:1.3rem;color:#f4efe7}
.foot a{color:#cdbfa9}.foot a:hover{color:var(--accent)}
.foot ul{list-style:none;display:grid;gap:8px;font-size:.92rem}
.foot-bottom{border-top:1px solid #463f36;margin-top:40px;padding-top:22px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:.8rem}
.foot-bottom a{color:var(--accent)}

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

/* ---------- responsive ---------- */
@media(max-width:1080px){
  :root{--rail-w:200px}
  .swatches{grid-template-columns:repeat(2,1fr)}
  .gallery{columns:2}
}
@media(max-width:820px){
  .shell{flex-direction:column}
  .rail{display:none}
  .topbar{
    display:flex;align-items:center;justify-content:space-between;
    position:sticky;top:0;z-index:50;background:var(--rail);border-bottom:1px solid var(--line);
    padding:14px 20px;
  }
  .topbar .wordmark{font-family:var(--display);font-weight:700;font-size:1.1rem}
  .topbar .wordmark span{display:block;font-size:.55rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);font-weight:500}
  .topbar .tbtel{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;color:var(--primary);font-size:.95rem}
  .topbar .tbtel svg{width:17px;height:17px}
  .mobnav{
    display:flex;gap:4px;overflow-x:auto;background:var(--surface);border-bottom:1px solid var(--line);
    padding:0 12px;position:sticky;top:51px;z-index:49;
  }
  .mobnav a{flex:0 0 auto;font-family:var(--display);font-weight:500;font-size:.92rem;color:var(--muted);padding:13px 12px}
  .mobnav a.active{color:var(--primary);box-shadow:inset 0 -2px 0 var(--accent)}
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-photo{min-height:46vh;order:-1}
  .matrow,.matrow.flip .mat-media{grid-template-columns:1fr;order:0}
  .matrow{display:block}
  .mat-media{margin-bottom:24px}
  .contact-grid{grid-template-columns:1fr}
  .foot .wrap{grid-template-columns:1fr}
  .cta-band .wrap{flex-direction:column;align-items:flex-start}
}
@media(max-width:520px){
  .swatches{grid-template-columns:1fr}
  .gallery{columns:1}
  .hero-copy h1{font-size:2rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
