/* ============ Syprus design system ============ */
:root{
  --green:#2A5C3F; --green-d:#1b3d29; --amber:#f59e0b; --amber-d:#d97f06;
  --ink:#15201a; --mut:#5f6b63; --bg:#f7faf8; --line:#e7ece8; --white:#fff;
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'DM Sans',system-ui,sans-serif;
  --wrap:1240px; --radius:12px; --shadow:0 1px 3px rgba(0,0,0,.05);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 30px}
section{padding:78px 0}
.center{text-align:center}.center .sub{margin-inline:auto}

/* typography */
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:.3px}
.lab{display:inline-block;color:var(--amber-d);font-family:var(--sans);font-weight:700;font-size:12.5px;letter-spacing:1.6px;text-transform:uppercase}
h2.t{font-size:40px;margin:12px 0 8px}
h2.t em,h1 em{font-style:italic;color:var(--amber)}
.sub{color:var(--mut);font-size:16px;max-width:600px}

/* buttons */
.btn{display:inline-block;padding:15px 30px;border-radius:8px;font-family:var(--sans);font-weight:700;font-size:15px;cursor:pointer;border:1.5px solid transparent;transition:transform .15s,box-shadow .2s,background .2s}
.btn-amber{background:var(--amber);color:#fff;box-shadow:0 6px 20px rgba(245,158,11,.4)}
.btn-amber:hover{transform:translateY(-2px);background:var(--amber-d)}
.btn-ghost-light{border-color:rgba(255,255,255,.7);color:#fff}
.btn-ghost-light:hover{background:rgba(255,255,255,.12)}
.btn-ghost{border-color:var(--green);color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;height:80px;display:flex;align-items:center;transition:background .3s,box-shadow .3s,height .3s}
.nav.transparent{background:transparent}
.nav.solid{background:#fff;box-shadow:0 2px 16px rgba(0,0,0,.07);height:68px}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:800;font-size:20px;letter-spacing:.5px}
.brand .lite{font-weight:500;opacity:.85}
.brand img{height:56px;width:auto;display:block}
.nav.transparent .brand .logo-c{display:none}
.nav.transparent .brand .logo-w{display:block}
.nav.solid .brand .logo-w{display:none}
.nav.solid .brand .logo-c{display:block}
.flogo{height:60px;width:auto;display:block}
.nav.transparent .brand,.nav.transparent .menu>li>a{color:#fff}
.nav.solid .brand{color:var(--green)} .nav.solid .brand .lite{color:var(--ink)}
.nav.solid .menu>li>a{color:#33433a}
.menu{display:flex;align-items:center;gap:28px;list-style:none}
.menu>li{position:relative}
.menu>li>a{font-family:var(--sans);font-weight:600;font-size:14.5px;padding:8px 0;transition:color .2s}
.menu>li>a:hover{color:var(--amber)}
.dropdown{position:absolute;top:100%;left:-16px;min-width:230px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 30px rgba(0,0,0,.12);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s}
.menu>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:10px 14px;border-radius:7px;font-family:var(--sans);font-size:14px;color:#33433a}
.dropdown a:hover{background:var(--bg);color:var(--green)}
.nav-cta{background:var(--amber);color:#fff!important;padding:11px 20px;border-radius:30px;font-family:var(--sans);font-weight:700;font-size:14px}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.hamb span{width:26px;height:2.5px;background:currentColor;border-radius:2px;transition:.3s}
.nav.transparent .hamb{color:#fff}.nav.solid .hamb{color:var(--ink)}
.mobile{position:fixed;inset:0 0 0 auto;width:min(320px,82vw);background:#fff;z-index:60;transform:translateX(100%);transition:transform .3s;padding:90px 26px 30px;box-shadow:-10px 0 40px rgba(0,0,0,.15);overflow-y:auto}
.mobile.open{transform:translateX(0)}
.mobile a{display:block;padding:13px 0;border-bottom:1px solid var(--line);font-family:var(--sans);font-weight:600;color:#33433a}
.mobile .nav-cta{margin-top:18px;text-align:center}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55;opacity:0;visibility:hidden;transition:.3s}
.backdrop.open{opacity:1;visibility:visible}

/* ============ HERO ============ */
.hero{position:relative;height:92vh;min-height:620px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease}
.hero-slide.active{opacity:1}
.hero-ov{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,16,12,.5),rgba(10,16,12,.25) 45%,rgba(10,16,12,.55));z-index:2}
.hero-c{position:relative;z-index:3;color:#fff;max-width:920px;padding:0 24px}
.hero-badge{display:inline-block;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);padding:7px 18px;border-radius:30px;font-family:var(--sans);font-size:12.5px;font-weight:600;letter-spacing:.5px;margin-bottom:26px;backdrop-filter:blur(6px)}
.hero h1{font-size:72px;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero p{margin:22px auto 36px;font-size:18px;color:#eef2ef;max-width:600px;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.hero-acts{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-dots{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:4}
.hero-dots button{width:34px;height:4px;border:0;border-radius:3px;background:rgba(255,255,255,.4);cursor:pointer;transition:.3s}
.hero-dots button.on{background:var(--amber);width:46px}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;background:none;border:0;color:rgba(255,255,255,.75);font-size:42px;cursor:pointer;padding:18px;line-height:1}
.hero-arrow.l{left:10px}.hero-arrow.r{right:10px}

/* simple page header (non-home pages) */
.phead{position:relative;padding:150px 0 70px;text-align:center;color:#fff;background-size:cover;background-position:center}
.phead::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(15,32,22,.7),rgba(15,32,22,.7))}
.phead .wrap{position:relative;z-index:2}
.phead h1{font-size:58px}.phead p{color:#dfe9e2;margin-top:10px}
.crumb{font-family:var(--sans);font-size:13px;color:#cfe0d6;margin-top:14px}

/* trust strip */
.trust{background:var(--green-d);color:#cfe0d6}
.trust .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:18px 30px;font-family:var(--sans);font-weight:600;font-size:13.5px}
.trust span.i{display:flex;gap:9px;align-items:center}
.dot{width:9px;height:9px;border-radius:50%;background:var(--amber);flex:none}

/* grids + cards */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(0,0,0,.1)}
.card .im{height:200px;background:#dde6e0 center/cover;overflow:hidden}
.card .im img{height:100%;width:100%;object-fit:cover;transition:transform .5s}
.card:hover .im img{transform:scale(1.06)}
.card .bd{padding:20px 22px}
.card h3{font-size:21px}.card p{font-family:var(--sans);font-size:14px;color:var(--mut);margin-top:6px}
.card .more{font-family:var(--sans);font-weight:700;font-size:13.5px;color:var(--amber-d);margin-top:12px;display:inline-block}
.card.solid{background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center}
.card.solid h3{color:#fff}

/* feature tiles */
.feat{background:#fff;border:1px solid var(--line);border-radius:11px;padding:24px}
.feat .ic{width:46px;height:46px;border-radius:11px;background:#fdf0d8;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:14px}
.feat h3{font-size:19px}.feat p{font-family:var(--sans);font-size:13.5px;color:var(--mut);margin-top:5px}

/* tabs */
.tabs{display:flex;gap:10px;justify-content:center;margin:26px 0 30px}
.tab{font-family:var(--sans);font-weight:600;font-size:14.5px;padding:10px 24px;border-radius:30px;border:1px solid var(--line);background:#fff;cursor:pointer}
.tab.on{background:var(--green);color:#fff;border-color:var(--green)}
.panel{display:none}.panel.on{display:block;animation:fade .4s}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* colour swatches */
.swatch{height:150px;border-radius:10px;box-shadow:var(--shadow)}
.colcap{font-family:var(--sans);font-weight:600;font-size:14.5px;margin-top:10px;text-align:center}

/* process */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:34px}
.step .n{font-family:var(--serif);font-size:42px;font-weight:700;color:var(--amber)}
.step h3{font-size:19px;margin:6px 0}.step p{font-family:var(--sans);font-size:13.5px;color:var(--mut)}

/* stats band */
.band{background:linear-gradient(100deg,var(--green-d),var(--green));color:#fff}
.band .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:54px 30px;text-align:center}
.band b{font-family:var(--serif);font-size:46px;font-weight:700;display:block}
.band b em{font-style:normal;color:var(--amber)}
.band small{font-family:var(--sans);color:#cdddd2}

/* client logos */
.logos{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:30px}
.clogo{height:70px;background:var(--bg);border:1px solid var(--line);border-radius:9px;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 10px;font-family:var(--sans);font-weight:600;font-size:12.5px;color:#7d8c83}

/* testimonials */
.tslider{position:relative;max-width:760px;margin:34px auto 0;overflow:hidden}
.ttrack{display:flex;transition:transform .5s}
.tcard{min-width:100%;padding:34px;background:var(--bg);border:1px solid var(--line);border-radius:14px;text-align:center}
.tcard p{font-family:var(--serif);font-size:22px;font-style:italic;color:var(--ink)}
.tcard .who{font-family:var(--sans);font-weight:700;margin-top:16px}
.tcard .stars{color:var(--amber);margin-top:8px}
.tdots{display:flex;gap:8px;justify-content:center;margin-top:18px}
.tdots button{width:10px;height:10px;border-radius:50%;border:0;background:var(--line);cursor:pointer}
.tdots button.on{background:var(--amber)}

/* CTA banner */
.cat{background:linear-gradient(100deg,var(--green-d),var(--green));color:#fff;border-radius:18px;padding:48px;display:flex;justify-content:space-between;align-items:center;gap:24px;position:relative;overflow:hidden}
.cat::after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:rgba(245,158,11,.18)}
.cat h2{font-size:30px}.cat p{font-family:var(--sans);color:#cfe0d6;margin-top:8px}
.cat .btn{position:relative;z-index:2;white-space:nowrap}

/* FAQ accordion */
.acc{max-width:780px;margin:32px auto 0}
.acc-item{border:1px solid var(--line);border-radius:10px;margin-bottom:12px;background:#fff;overflow:hidden}
.acc-q{width:100%;text-align:left;background:none;border:0;padding:18px 20px;font-family:var(--sans);font-weight:600;font-size:15.5px;cursor:pointer;display:flex;justify-content:space-between;gap:16px;align-items:center}
.acc-q .pm{color:var(--amber-d);font-size:22px;transition:transform .3s;flex:none}
.acc-item.open .acc-q .pm{transform:rotate(45deg)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.acc-a p{padding:0 20px 18px;font-family:var(--sans);font-size:14.5px;color:var(--mut)}

/* contact */
.ct{background:var(--bg);border-radius:18px;padding:40px;display:grid;grid-template-columns:1fr 1fr;gap:38px}
.ct .info{font-family:var(--sans);font-size:14.5px;color:#43524a;line-height:2.1}
form.enq{display:grid;gap:13px}
.enq input,.enq select,.enq textarea{font-family:var(--sans);font-size:14.5px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#fff;width:100%}
.enq textarea{min-height:96px;resize:vertical}
.enq .err{color:#c0392b;font-size:12.5px;display:none}
.enq .field.bad .err{display:block}
.enq .field.bad input,.enq .field.bad select{border-color:#c0392b}
.form-msg{display:none;padding:14px;border-radius:8px;font-family:var(--sans);font-size:14px}
.form-msg.ok{display:block;background:#e8f5ee;color:var(--green)}
.form-msg.fail{display:block;background:#f9e7e7;color:#c0392b}

/* map + video */
.mapbox,.videobox{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.mapbox iframe{width:100%;height:380px;border:0;display:block}
.videobox{display:flex;justify-content:center;background:#000}
.videobox video{max-height:78vh;max-width:100%;width:auto;height:auto;display:block;margin:0 auto;background:#000}

/* footer */
footer.site{background:#15201a;color:#a9b8af;padding:60px 0 26px;font-family:var(--sans);font-size:14px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:32px}
footer.site h4{color:#fff;font-size:14px;margin-bottom:14px}
footer.site .fl{display:block;margin-bottom:10px}
footer.site .fl:hover{color:var(--amber)}
.fbrand{font-weight:800;font-size:19px;color:#fff}.fbrand .lite{color:#a9b8af;font-weight:500}
.fsoc{display:flex;gap:12px;margin-top:14px}
.fsoc a{width:36px;height:36px;border-radius:50%;background:#22312a;display:flex;align-items:center;justify-content:center}
.fbar{border-top:1px solid #2a3a31;margin-top:36px;padding-top:18px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:12.5px}

/* floating whatsapp */
.float-wa{position:fixed;left:22px;bottom:22px;z-index:40;background:#25D366;color:#fff;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 6px 20px rgba(0,0,0,.25);transition:transform .2s}
.float-wa:hover{transform:scale(1.08)}

/* scroll reveal */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].in{opacity:1;transform:none}

/* responsive */
@media(max-width:1000px){
  h2.t{font-size:32px}.hero h1{font-size:54px}.phead h1{font-size:44px}
  .g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(2,1fr)}
  .proc-grid,.band .wrap,.logos{grid-template-columns:repeat(2,1fr)}
  .ct{grid-template-columns:1fr}.fgrid{grid-template-columns:1fr 1fr}
  .menu,.nav-cta.desk{display:none}.hamb{display:flex}
}
@media(max-width:600px){
  section{padding:56px 0}.wrap{padding:0 20px}
  .hero h1{font-size:40px}.hero p{font-size:16px}
  .g2,.g3,.g4{grid-template-columns:1fr}.cat{flex-direction:column;text-align:center}
  .trust .wrap{justify-content:center}.fgrid{grid-template-columns:1fr}
  .brand img{height:46px}.flogo{height:52px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}
  .hero-slide{transition:none}
}
