:root{
  --ink:#222a35;
  --slate:#4c5663;
  --gold:#b5872d;
  --gold-soft:#d9b25e;
  --paper:#fafbfc;
  --mist:#eef1f4;
  --line:#dde2e8;
  --gold-line:#cfa84f;
  --disp:'Montserrat',sans-serif;
  --body:'Source Sans 3',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{font-family:var(--body);background:var(--paper);color:var(--ink);line-height:1.7;font-size:16.5px;
  background-image:repeating-linear-gradient(0deg,rgba(34,42,53,.018) 0,rgba(34,42,53,.018) 1px,transparent 1px,transparent 7px)}
a{color:inherit}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}

/* ornament: gold rule with diamond, from the business card */
.orn{display:flex;align-items:center;gap:10px;justify-content:center;margin:18px auto}
.orn::before,.orn::after{content:"";height:1px;width:64px;background:var(--gold-line)}
.orn i{width:7px;height:7px;background:var(--gold);transform:rotate(45deg)}

.eyebrow{font-family:var(--disp);font-weight:500;font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold)}
h1,h2,h3{font-family:var(--disp)}
h2{font-weight:300;font-size:clamp(1.7rem,3.4vw,2.5rem);letter-spacing:.18em;text-transform:uppercase;line-height:1.25}
h2 b{font-weight:600}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(250,251,252,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px;max-width:1160px;margin:0 auto;padding:0 24px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo svg{width:34px;height:34px}
.logo-text{font-family:var(--disp);font-weight:400;font-size:1.06rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink)}
.nav-links{display:flex;gap:26px;list-style:none;align-items:center}
.nav-links a{text-decoration:none;font-family:var(--disp);font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);transition:color .2s}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--gold)}
.nav-cta{border:1px solid var(--gold-line);color:var(--gold)!important;padding:9px 18px}
.nav-cta:hover{background:var(--gold);color:#fff!important}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:var(--ink);padding:8px 14px;font-family:var(--disp);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;cursor:pointer}
@media(max-width:920px){
  .nav-links{display:none;position:absolute;top:70px;left:0;right:0;background:var(--paper);flex-direction:column;gap:0;border-bottom:1px solid var(--line);align-items:stretch}
  .nav-links.open{display:flex}
  .nav-links li{border-top:1px solid var(--line)}
  .nav-links a{display:block;padding:16px 24px}
  .nav-cta{border:none}
  .menu-btn{display:block}
}

/* ---------- hero ---------- */
header{padding:150px 0 70px;text-align:center;position:relative}
.hero-frame{border:1px solid var(--gold-line);max-width:920px;margin:0 auto;padding:64px 36px 56px;position:relative;background:rgba(255,255,255,.55)}
.hero-frame::after{content:"";position:absolute;inset:7px;border:1px solid rgba(181,135,45,.28);pointer-events:none}
.hero-logo{width:84px;height:84px;margin:0 auto 26px;display:block}
.chev{animation:rise .9s ease both}
.chev:nth-child(2){animation-delay:.1s}.chev:nth-child(3){animation-delay:.2s}
.chev:nth-child(4){animation-delay:.3s}.chev:nth-child(5){animation-delay:.4s}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
h1{font-weight:300;font-size:clamp(2rem,5.4vw,3.6rem);letter-spacing:.22em;text-transform:uppercase;line-height:1.15}
.hero-sub2{font-family:var(--disp);font-weight:400;font-size:.8rem;letter-spacing:.5em;text-transform:uppercase;color:var(--slate);margin-top:8px}
.hero-tag{font-family:var(--disp);font-weight:500;font-size:.78rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-top:4px}
.hero-desc{max-width:620px;margin:26px auto 34px;color:var(--slate);font-weight:300;font-size:1.05rem}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{font-family:var(--disp);font-size:.72rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;padding:15px 30px;transition:all .2s}
.btn-primary{background:var(--ink);color:#fff;border:1px solid var(--ink)}
.btn-primary:hover{background:var(--gold);border-color:var(--gold)}
.btn-ghost{border:1px solid var(--gold-line);color:var(--gold)}
.btn-ghost:hover{background:var(--gold);color:#fff}

/* strip */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.strip-in{display:flex;justify-content:center;gap:0;flex-wrap:wrap}
.strip-in span{font-family:var(--disp);font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--slate);padding:16px 26px;border-left:1px solid var(--line)}
.strip-in span:first-child{border-left:none}
.strip-in b{color:var(--gold);font-weight:600}

/* ---------- sections ---------- */
section{padding:92px 0}
.sec-head{text-align:center;margin-bottom:56px}
.sec-head p.lead{max-width:640px;margin:14px auto 0;color:var(--slate);font-weight:300}

/* decorative film feature */
.film{background:var(--ink);color:var(--mist);position:relative;overflow:hidden}
.film::before{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse at 85% 10%,rgba(217,178,94,.14),transparent 50%),
  radial-gradient(ellipse at 10% 90%,rgba(181,135,45,.1),transparent 50%)}
.film .wrap{position:relative}
.film-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.film .eyebrow{color:var(--gold-soft)}
.film h2{color:#fff;margin:14px 0 22px}
.film p{color:#c4cbd4;font-weight:300;margin-bottom:18px}
.film-points{list-style:none;margin-top:8px}
.film-points li{padding:14px 0;border-top:1px solid rgba(221,226,232,.16);display:flex;gap:14px;font-size:.95rem;color:#dfe4ea}
.film-points li::before{content:"◆";color:var(--gold-soft);font-size:.6rem;line-height:2.2}
.badge-first{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--gold-soft);background:rgba(217,178,94,.12);color:var(--gold-soft);font-family:var(--disp);font-size:.64rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;padding:11px 20px;margin-bottom:20px}
.badge-first i{width:6px;height:6px;background:var(--gold-soft);transform:rotate(45deg);flex:none}
.film-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-top:54px;position:relative}
.film-gallery .roll{margin:0}
.tex{width:100%;height:128px;display:block}
.gal-note{margin-top:22px;font-size:.85rem;color:#9aa3ae;font-weight:300;text-align:center}
.film-rolls{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.roll{border:1px solid rgba(217,178,94,.35);padding:6px;background:rgba(255,255,255,.03)}
.roll-face{height:130px}
.r-wood{background:repeating-linear-gradient(95deg,#6e4f2c 0,#8a6438 6px,#75552f 11px,#94703f 18px,#6a4b28 26px)}
.r-marble{background:linear-gradient(115deg,#e9ebee 0%,#cfd5db 28%,#f2f4f6 45%,#b9c1c9 62%,#e6e9ec 80%,#d2d8de 100%)}
.r-gold{background:linear-gradient(115deg,#8a6620 0%,#d9b25e 30%,#f3dfa6 48%,#b5872d 66%,#9a7426 100%)}
.r-carbon{background:repeating-linear-gradient(45deg,#23272e 0,#23272e 5px,#343a43 5px,#343a43 10px)}
.roll p{font-family:var(--disp);font-size:.62rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#c4cbd4;padding:10px 4px 6px;text-align:center;margin:0}
@media(max-width:880px){.film-grid{grid-template-columns:1fr}}

/* products */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.prod{border:1px solid var(--line);background:#fff;padding:36px 30px;text-align:center;transition:border-color .25s,box-shadow .25s}
.prod:hover{border-color:var(--gold-line);box-shadow:0 14px 36px rgba(34,42,53,.08)}
.prod-chip{height:6px;width:72px;margin:0 auto 24px}
.c-alu{background:linear-gradient(90deg,#9aa3ad,#dfe4e9,#8d96a0)}
.c-gal{background:linear-gradient(90deg,#a6aeb7,#cdd4da 45%,#98a1aa 60%,#c2c9d0)}
.c-ss{background:linear-gradient(90deg,#aeb6bf,#f1f3f5,#9da6af)}
.c-pvc{background:linear-gradient(90deg,#8a6438,#caa468,#75552f)}
.c-film{background:linear-gradient(90deg,#8a6620,#d9b25e,#9a7426)}
.prod h3{font-weight:500;font-size:.95rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:14px}
.prod p{font-size:.9rem;color:var(--slate);font-weight:300}
.prod ul{list-style:none;margin-top:18px;text-align:left}
.prod li{font-size:.84rem;color:var(--slate);padding:7px 0;border-top:1px solid var(--mist)}
.prod li::before{content:"◆ ";color:var(--gold);font-size:.55rem;vertical-align:middle;margin-right:6px}

/* finishes */
.finishes{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.swatch-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px}
.swatch{border:1px solid var(--line);background:var(--paper);padding:6px}
.swatch-face{height:108px}
.f-gold{background:linear-gradient(120deg,#8a6620,#d9b25e 30%,#f3dfa6 48%,#b5872d 66%,#9a7426)}
.f-rose{background:linear-gradient(120deg,#8a5644,#d49079 32%,#f0c6b5 50%,#b06b54 68%,#94604c)}
.f-mirror{background:linear-gradient(120deg,#a6b0ba,#e9eef3 30%,#ffffff 48%,#b3bec8 66%,#97a2ac)}
.f-black{background:linear-gradient(120deg,#1a1e24,#3a414b 32%,#5a636e 50%,#2c323a 68%,#20242b)}
.f-champ{background:linear-gradient(120deg,#9a8455,#d8c294 32%,#f4e7c4 50%,#bca36c 68%,#a48a51)}
.f-bronze{background:linear-gradient(120deg,#5e4220,#9c6d35 32%,#caa468 50%,#7e5526 68%,#64461f)}
.swatch p{font-family:var(--disp);font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:12px 8px 8px;color:var(--slate);text-align:center}
.finish-note{margin-top:30px;text-align:center;font-size:.92rem;color:var(--slate);font-weight:300;max-width:620px;margin-left:auto;margin-right:auto}

/* applications */
.app-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:22px}
.app{border:1px solid var(--line);background:#fff;overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s}
.app:hover{transform:translateY(-5px);border-color:var(--gold-line);box-shadow:0 16px 40px rgba(34,42,53,.09)}
.app-art{height:160px;background:linear-gradient(170deg,#fdfefe,#eef1f4);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line)}
.app-art svg{width:74%;height:74%}
.app-body{padding:22px 24px 26px}
.app-tag{font-family:var(--disp);font-size:.6rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:8px}
.app h3{font-weight:500;font-size:.92rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.app p{font-size:.86rem;color:var(--slate);font-weight:300}

/* machinery */
.mach{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.mach-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.mach-copy h2{text-align:left;margin:14px 0 20px}
.mach-copy .eyebrow{display:block}
.mach-copy p{color:var(--slate);font-weight:300;margin-bottom:18px}
.spec-table{width:100%;border-collapse:collapse;font-size:.9rem}
.spec-table td{padding:14px 10px;border-top:1px solid var(--line);color:var(--slate)}
.spec-table td:first-child{font-family:var(--disp);font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);width:44%;vertical-align:top;padding-top:17px}
@media(max-width:860px){.mach-grid{grid-template-columns:1fr}}

/* locations */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.loc{border:1px solid var(--gold-line);padding:40px 36px;position:relative;background:#fff;text-align:center}
.loc::after{content:"";position:absolute;inset:6px;border:1px solid rgba(181,135,45,.25);pointer-events:none}
.loc-tag{font-family:var(--disp);font-size:.64rem;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.loc h3{font-weight:400;font-size:1.3rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:12px}
.loc p{color:var(--slate);font-weight:300;font-size:.93rem}
@media(max-width:700px){.loc-grid{grid-template-columns:1fr}}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-copy h2{text-align:left;margin:14px 0 18px}
.contact-copy>p{color:var(--slate);font-weight:300;margin-bottom:26px;max-width:430px}
.contact-lines{list-style:none}
.contact-lines li{display:flex;gap:18px;padding:15px 0;border-top:1px solid var(--line);font-size:.97rem;align-items:baseline}
.contact-lines .k{font-family:var(--disp);font-size:.62rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);min-width:104px}
.contact-lines a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
.contact-lines a:hover{border-color:var(--gold);color:var(--gold)}
.enquiry{border:1px solid var(--gold-line);padding:36px;background:#fff;position:relative}
.enquiry::after{content:"";position:absolute;inset:6px;border:1px solid rgba(181,135,45,.22);pointer-events:none}
.enquiry>*{position:relative;z-index:1}
.enquiry h3{font-weight:400;font-size:1.05rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:8px;text-align:center}
.enquiry .orn{margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--disp);font-size:.62rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--slate);margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;background:var(--paper);border:1px solid var(--line);padding:12px 14px;color:var(--ink);font-family:var(--body);font-size:.95rem}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--gold);outline-offset:0;border-color:var(--gold)}
.enquiry button{width:100%;background:var(--ink);color:#fff;border:none;padding:16px;font-family:var(--disp);font-size:.72rem;font-weight:500;letter-spacing:.26em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.enquiry button:hover{background:var(--gold)}
.form-note{margin-top:14px;font-size:.82rem;color:var(--slate);text-align:center}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}

/* footer */
footer{padding:44px 0;border-top:1px solid var(--gold-line);background:#fff;text-align:center}
footer .logo{justify-content:center;margin-bottom:14px}
footer p{font-family:var(--disp);font-size:.64rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--slate);margin-top:6px}
footer a{text-decoration:none}
footer a:hover{color:var(--gold)}

/* about / mission / vision */
.about-intro{max-width:760px;margin:0 auto;text-align:center;color:var(--slate);font-weight:300}
.about-intro p{margin-bottom:16px}
.about-stats{display:flex;justify-content:center;gap:0;flex-wrap:wrap;margin:44px 0 56px}
.stat{padding:8px 42px;border-left:1px solid var(--line);text-align:center}
.stat:first-child{border-left:none}
.stat b{display:block;font-family:var(--disp);font-weight:300;font-size:2.2rem;color:var(--ink);line-height:1.2}
.stat span{font-family:var(--disp);font-size:.62rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.mv{border:1px solid var(--gold-line);padding:42px 38px;position:relative;background:#fff}
.mv::after{content:"";position:absolute;inset:6px;border:1px solid rgba(181,135,45,.25);pointer-events:none}
.mv>*{position:relative;z-index:1}
.mv svg{width:42px;height:42px;margin-bottom:18px}
.mv h3{font-weight:400;font-size:1.15rem;letter-spacing:.26em;text-transform:uppercase;margin-bottom:14px;color:var(--ink)}
.mv p{color:var(--slate);font-weight:300;font-size:.95rem}
.serve{border:1px solid var(--line);background:#fff;padding:34px 38px;text-align:center}
.serve p{color:var(--slate);font-weight:300;max-width:760px;margin:0 auto}
.serve .k{font-family:var(--disp);font-size:.64rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:12px}
@media(max-width:760px){.mv-grid{grid-template-columns:1fr}.stat{padding:8px 24px}}

.map-block{margin-top:24px;border:1px solid var(--gold-line);padding:6px;background:#fff}
.map-block iframe{width:100%;height:380px;border:0;display:block}
.map-caption{font-family:var(--disp);font-size:.64rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);text-align:center;padding:14px 8px 10px}

/* floating whatsapp */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:60;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(34,42,53,.28);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}