/* ===== Corporate Essentials — shared site stylesheet ===== */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&display=swap');
:root{
  --ink:#0c0d10; --ink2:#15171d; --ink3:#1d2027;
  --gold:#FECC2A; --gold2:#e7b416; --gold-ink:#876400;
  --paper:#ffffff; --cream:#fbf4e2; --line:#e9e5d8; --muted:#6b7280; --body:#454a55;
  --maxw:1200px; --r:16px;
  --font:"Segoe UI",system-ui,-apple-system,Roboto,"Helvetica Neue",Arial,sans-serif;
  --font-head:"Sora",var(--font);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-print-color-adjust:exact;print-color-adjust:exact}
@media print{ html,body{-webkit-print-color-adjust:exact;print-color-adjust:exact} .topbar,header{position:static !important} }
body{font-family:var(--font);color:var(--body);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);font-weight:800;letter-spacing:-.02em;line-height:1.1}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.btn{display:inline-flex;align-items:center;gap:9px;border-radius:999px;padding:14px 28px;font-weight:700;font-size:15px;transition:.18s;border:2px solid transparent;cursor:pointer}
.btn-gold{background:var(--gold);color:#16140a} .btn-gold:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.3);color:#fff} .btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-dark{background:var(--ink);color:#fff} .btn-dark:hover{background:var(--ink3)}
.btn-outline{border-color:var(--ink);color:var(--ink)} .btn-outline:hover{background:var(--ink);color:#fff}
.ic{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.eyebrow{display:inline-flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.22em;font-size:12px;font-weight:700;color:var(--gold-ink)}
.sec{padding:88px 0}
.sec-head{text-align:center;max-width:660px;margin:0 auto 52px}
.sec-head h2{font-size:clamp(28px,4vw,42px);margin:14px 0 14px}
.sec-head p{font-size:16.5px;color:var(--muted)}
.cream{background:var(--cream)}

/* top bar */
.topbar{background:#000;color:rgba(255,255,255,.72);font-size:12.5px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar a{color:rgba(255,255,255,.72)} .topbar a:hover{color:var(--gold)}
.topbar .tb-r{display:flex;gap:20px;align-items:center}

/* header */
header.site{background:var(--ink);position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(255,255,255,.06)}
header.site .wrap{display:flex;align-items:center;gap:30px;height:78px}
.logo img{height:44px;width:auto}
nav.main{display:flex;gap:26px;margin-left:6px}
nav.main a{color:#d6d8de;font-size:14.5px;font-weight:600;padding:6px 0;border-bottom:2px solid transparent}
nav.main a:hover,nav.main a.active{color:#fff;border-bottom-color:var(--gold)}
header.site .spacer{flex:1}
.hdr-cta{display:flex;gap:12px;align-items:center}
.enq-pill{display:flex;align-items:center;gap:8px;color:#d6d8de;font-weight:700;font-size:14px;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px 14px}
.enq-pill:hover{border-color:var(--gold);color:#fff}
.enq-pill .n{background:var(--gold);color:#16140a;border-radius:999px;min-width:20px;height:20px;display:grid;place-items:center;font-size:12px}

/* hero */
.hero{background:radial-gradient(1100px 600px at 78% -10%, #2a2c34 0%, var(--ink) 55%);color:#e8e9ee;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(254,204,42,.18),transparent 65%);animation:heroGlowA 16s ease-in-out infinite;z-index:1}
.hero::before{content:"";position:absolute;left:-160px;bottom:-160px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(254,204,42,.10),transparent 65%);animation:heroGlowB 22s ease-in-out infinite;z-index:1}
@keyframes heroGlowA{0%,100%{transform:translate(0,0) scale(1);opacity:1}50%{transform:translate(-34px,32px) scale(1.18);opacity:.6}}
@keyframes heroGlowB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(44px,-40px) scale(1.12)}}
@media (prefers-reduced-motion:reduce){.hero::after,.hero::before{animation:none}}
/* hero ambience: floating sparkles + rotating word (2+4) */
.hero-fx{position:absolute;inset:0;overflow:hidden;z-index:1;pointer-events:none}
.spark{position:absolute;bottom:-12px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px 2px rgba(254,204,42,.5);opacity:0;animation:rise linear infinite}
@keyframes rise{0%{transform:translateY(0) scale(.5);opacity:0}12%{opacity:.9}88%{opacity:.65}100%{transform:translateY(-520px) scale(1);opacity:0}}
.rotw{display:inline-block;text-align:left}
.rotw.out{opacity:0;transform:translateY(-10px);transition:.28s}
.rotw.in{opacity:1;transform:translateY(0);transition:.28s}
@media (prefers-reduced-motion:reduce){.spark{animation:none;opacity:.35}}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:84px 24px 90px;position:relative;z-index:2}
.hero h1{color:#fff;font-size:clamp(34px,5vw,58px);margin:18px 0}
.hero h1 .gold{color:var(--gold)}
.hero p{font-size:18px;color:#b9bcc6;max-width:520px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:30px;margin-top:42px;flex-wrap:wrap}
.hero-stats div b{display:block;font-size:30px;color:#fff;font-weight:800;letter-spacing:-.02em}
.hero-stats div span{font-size:12.5px;color:#9498a4;text-transform:uppercase;letter-spacing:.08em}
.hero-art{position:relative;display:grid;place-items:center}
.hero-card{background:linear-gradient(160deg,#202229,#15161b);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:30px;width:100%;box-shadow:0 30px 70px rgba(0,0,0,.5)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hg-tile{background:#0f1014;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px;text-align:center;color:#cfd2da}
.hg-tile .ic{stroke:var(--gold);width:30px;height:30px;margin:0 auto 10px}
.hg-tile b{display:block;color:#fff;font-size:14px}
.hg-tile span{font-size:12px;color:#8b909b}
.hg-ribbon{margin-top:16px;background:var(--gold);color:#16140a;border-radius:12px;padding:14px 16px;font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:10px}

/* sub-page banner */
.page-banner{background:radial-gradient(900px 400px at 80% -20%, #2a2c34, var(--ink) 60%);color:#fff;padding:54px 0}
.page-banner .crumb{font-size:13px;color:#9498a4;margin-bottom:10px}
.page-banner .crumb a:hover{color:var(--gold)}
.page-banner h1{color:#fff;font-size:clamp(30px,4vw,46px)}
.page-banner p{color:#b9bcc6;margin-top:12px;max-width:620px;font-size:16px}

/* trusted strip */
.trusted{background:var(--paper);padding:42px 0;border-bottom:1px solid var(--line)}
.trusted p{text-align:center;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.16em;font-weight:700;margin-bottom:26px}
.logos{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:30px 26px;align-items:center;justify-items:center}
.logos img{height:34px;max-width:120px;width:auto;object-fit:contain;transition:.2s}
.logos img:hover{transform:translateY(-3px)}

/* solutions cards */
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.sol-card{border:1px solid var(--line);border-radius:var(--r);padding:30px;transition:.2s;background:#fff;position:relative;overflow:hidden}
.sol-card:hover{border-color:var(--gold);transform:translateY(-5px);box-shadow:0 20px 44px rgba(20,18,8,.08)}
.sol-card .sic{width:54px;height:54px;border-radius:14px;background:var(--cream);display:grid;place-items:center;margin-bottom:18px}
.sol-card .sic .ic{stroke:var(--gold2);width:26px;height:26px}
.sol-card h3{font-size:19px;margin-bottom:8px}
.sol-card p{font-size:14px;color:var(--muted)}
.sol-card .badge{position:absolute;top:18px;right:18px;background:var(--ink);color:var(--gold);font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.05em}

/* category tiles */
.cats{background:var(--cream)}
.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.cat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 10px;text-align:center;transition:.18s}
.cat:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(20,18,8,.08)}
.cat .ic{stroke:var(--ink);width:30px;height:30px;margin:0 auto 12px}
.cat b{font-size:13.5px;color:var(--ink);display:block}
.cat span{font-size:11.5px;color:var(--muted)}

/* guarantees band */
.band{background:var(--ink);color:#fff;text-align:center}
.band .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:64px 24px}
.band b{display:block;font-size:clamp(26px,3.2vw,38px);color:var(--gold);font-weight:800;letter-spacing:-.02em}
.band span{color:#aeb2bd;font-size:14px}

/* process */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{text-align:center}
.step .num{width:60px;height:60px;border-radius:50%;border:2px solid var(--gold);color:var(--ink);display:grid;place-items:center;margin:0 auto 18px;font-weight:800;font-size:20px;background:var(--cream)}
.step h4{font-size:17px;margin-bottom:6px}
.step p{font-size:13.5px;color:var(--muted)}

/* testimonial */
.quote{background:var(--cream)}
.quote .wrap{max-width:840px;text-align:center}
.quote .mark{font-size:64px;color:var(--gold);line-height:1;font-weight:800}
.quote blockquote{font-size:clamp(20px,2.6vw,28px);color:var(--ink);font-weight:600;line-height:1.4;margin:6px 0 22px}
.quote cite{font-style:normal;color:var(--muted);font-size:14px}
.quote cite b{color:var(--ink);display:block;font-size:15px}

/* cta band */
.cta{background:linear-gradient(120deg,var(--gold),#ffd95a)}
.cta .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:60px 24px;flex-wrap:wrap}
.cta h2{font-size:clamp(26px,3.4vw,38px);color:#16140a;max-width:640px}
.cta p{color:#5b5328;margin-top:8px;font-weight:600}

/* ===== catalogue ===== */
.cat-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px;align-items:center}
.chip{padding:8px 16px;border:1px solid var(--line);border-radius:999px;background:#fff;font-size:13px;font-weight:600;color:var(--body);cursor:pointer;transition:.15s;white-space:nowrap}
.chip:hover{border-color:var(--gold2);color:var(--ink)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.cat-count{margin-left:auto;color:var(--muted);font-size:13.5px;font-weight:600}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pcard{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:.2s}
.pcard:hover{border-color:var(--gold);box-shadow:0 16px 36px rgba(20,18,8,.08);transform:translateY(-4px)}
.pthumb{aspect-ratio:4/3;background:#fff;display:grid;place-items:center;padding:8px;border-bottom:1px solid var(--line)}
.pthumb img{width:100%;height:100%;object-fit:contain}
.pbody{padding:14px 16px;display:flex;flex-direction:column;gap:5px;flex:1}
.pcat{font-size:11px;color:var(--gold-ink);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.ptitle{font-size:14px;color:var(--ink);font-weight:600;line-height:1.3;min-height:36px}
.pfoot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:10px}
.pprice{font-weight:800;color:var(--ink);font-size:16px}
.pprice small{font-weight:600;color:var(--muted);font-size:11px}
.enq-btn{background:var(--ink);color:#fff;border:none;border-radius:999px;padding:8px 15px;font-size:12.5px;font-weight:700;cursor:pointer;transition:.15s}
.enq-btn:hover{background:var(--gold);color:#16140a}
.enq-btn.added{background:var(--gold2);color:#16140a}
.load-wrap{text-align:center;margin-top:34px}

/* ===== contact / forms ===== */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px;box-shadow:0 10px 30px rgba(18,24,38,.06)}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;font-size:14px;font-family:inherit;color:var(--ink);background:#fff;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold2)}
.field textarea{min-height:110px;resize:vertical}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-info .ci{display:flex;gap:14px;margin-bottom:22px}
.contact-info .ci .ic{stroke:var(--gold2);width:24px;height:24px;flex-shrink:0;margin-top:2px}
.contact-info .ci b{color:var(--ink);display:block;font-size:15px}
.contact-info .ci span{color:var(--muted);font-size:14px}
.enq-list{border:1px dashed var(--line);border-radius:12px;padding:14px;margin-bottom:18px;background:var(--cream)}
.enq-list h4{font-size:14px;margin-bottom:8px}
.enq-row{display:flex;justify-content:space-between;font-size:13px;padding:5px 0;border-bottom:1px solid rgba(0,0,0,.05)}
.enq-row button{background:none;border:none;color:var(--muted);cursor:pointer}
.form-ok{background:var(--cream);border:1px solid var(--gold);border-radius:12px;padding:16px;color:var(--ink);font-weight:600;display:none}

/* ===== about ===== */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.about-grid p{font-size:16px;margin-bottom:16px}
.about-art{background:linear-gradient(160deg,var(--ink),#23252d);border-radius:20px;padding:40px;color:#fff}
.about-art .hero-grid{margin:0}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ===== brand-stores page ===== */
.bs-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.bs-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;transition:.2s}
.bs-card:hover{transform:translateY(-5px);box-shadow:0 24px 60px rgba(18,24,38,.12)}
.bs-top{height:8px}
.bs-body{padding:32px}
.bs-body img.bl{height:46px;width:auto;margin-bottom:20px}
.bs-body .pc-cta{display:inline-flex;align-items:center;gap:8px;color:#fff;padding:12px 24px;border-radius:999px;font-weight:700;font-size:14px;margin-top:20px}

/* footer */
footer.site{background:#08090b;color:#9398a3}
.foot-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:36px;padding:64px 0 40px}
.foot-brand img{height:46px;margin-bottom:18px}
.foot-brand p{font-size:13.5px;max-width:330px}
.foot-col h4{color:#fff;font-size:15px;margin-bottom:16px}
.foot-col a{display:block;color:#9398a3;font-size:13.5px;padding:5px 0}
.foot-col a:hover{color:var(--gold)}
.foot-addr{font-size:13.5px;line-height:1.7}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;display:flex;justify-content:space-between;font-size:12.5px;flex-wrap:wrap;gap:10px}
.soc{display:flex;gap:10px;margin-top:16px}
.soc a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:grid;place-items:center}
.soc a:hover{background:var(--gold);color:#16140a}

@media (max-width:960px){
  nav.main,.enq-pill .lbl{display:none}
  .hero .wrap{grid-template-columns:1fr;padding:56px 24px}
  .hero-art{display:none}
  .sol-grid,.value-grid{grid-template-columns:1fr 1fr}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .band .wrap,.steps{grid-template-columns:1fr 1fr}
  .pgrid{grid-template-columns:repeat(2,1fr)}
  .contact-grid,.about-grid,.bs-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){ .sol-grid,.cat-grid,.value-grid{grid-template-columns:1fr 1fr} .pgrid{grid-template-columns:1fr 1fr} .foot-top{grid-template-columns:1fr} }

/* ===== hero trust microcopy (reciprocity + speed + risk-reversal) ===== */
.hero-fine{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px;color:#aeb2bd;font-size:13px;font-weight:600}
.hero-fine span{display:inline-flex;align-items:center;gap:6px}
.hero-fine span::before{content:"✓";color:var(--gold);font-weight:800}

/* ===== scroll reveal ===== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===== sticky enquiry bar ===== */
.enq-fab{position:fixed;left:50%;bottom:18px;z-index:60;transform:translateX(-50%) translateY(150%);background:var(--ink);color:#fff;border-radius:999px;display:flex;align-items:center;gap:16px;padding:10px 12px 10px 22px;box-shadow:0 14px 38px rgba(0,0,0,.3);transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.enq-fab.show{transform:translateX(-50%) translateY(0)}
.enq-fab .ef-txt{font-size:14px;font-weight:600;white-space:nowrap}
.enq-fab .ef-txt b{color:var(--gold)}
.enq-fab .ef-btn{background:var(--gold);color:#16140a;border-radius:999px;padding:9px 18px;font-weight:800;font-size:13.5px;white-space:nowrap}
.enq-fab:hover .ef-btn{background:var(--gold2)}
@media (max-width:560px){.enq-fab{left:14px;right:14px;bottom:14px;transform:translateY(150%);justify-content:space-between}.enq-fab.show{transform:translateY(0)}}

/* ===== catalogue: search + budget filter + skeletons (PR2) ===== */
.cat-search{position:relative;max-width:460px;margin:0 0 18px}
.cat-search .cs-ic{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;stroke:var(--muted);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.cat-search input{width:100%;border:1.5px solid var(--line);border-radius:999px;padding:13px 18px 13px 46px;font-size:15px;font-family:inherit;color:var(--ink);background:#fff;outline:none;transition:.15s}
.cat-search input:focus{border-color:var(--gold2);box-shadow:0 0 0 4px rgba(254,204,42,.13)}
.cat-budget{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0 0 22px}
.cat-budget .bud-label{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-right:2px}
.cat-empty{text-align:center;color:var(--muted);font-size:15px;padding:60px 0;grid-column:1/-1}

/* skeleton loaders */
.pcard.skel{pointer-events:none}
.pcard.skel .pthumb{background:#f1f0ea;border-bottom:1px solid var(--line)}
.pcard.skel .pbody{padding:14px 16px;display:flex;flex-direction:column;gap:9px}
.sk-line{display:block;border-radius:6px;height:12px;background:linear-gradient(90deg,#ececec 25%,#f6f5f0 37%,#ececec 63%);background-size:400% 100%;animation:sksh 1.3s ease infinite}
.sk-cat{width:38%;height:9px}.sk-title{width:90%}.sk-title2{width:62%}
.pcard.skel .pfoot{display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.sk-price{width:34%;height:16px}.sk-btn{width:30%;height:30px;border-radius:999px}
@keyframes sksh{0%{background-position:100% 0}100%{background-position:0 0}}
@media (prefers-reduced-motion:reduce){.sk-line{animation:none}}
