:root{
  --primary:#1e2a5a;
  --primary-2:#2f3e85;
  --primary-3:#0f1b44;

  --gold:#d4b46a;
  --gold-2:#f2e3b8;

  --bg:#f6f7fb;
  --surface:#ffffff;
  --text:#0b1220;
  --muted:#667085;
  --border:rgba(15,23,42,.10);

--serif:'Cormorant Garamond', serif;
--sans:'Manrope', system-ui;


  --r:18px;
  --shadow: 0 20px 60px rgba(30,42,90,.16);
  --shadow2: 0 35px 95px rgba(30,42,90,.26);

  --ease: cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(30,42,90,.14), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(212,180,106,.12), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, var(--bg) 65%);
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.section{padding:92px 0}
.bg-soft{
  background:
    radial-gradient(800px 340px at 20% 0%, rgba(30,42,90,.10), transparent 60%),
    linear-gradient(180deg, rgba(30,42,90,.05), transparent 60%);
}
.muted{color:var(--muted)}
.small{font-size:13px}

.link{color:var(--primary);font-weight:700}
.h2{
  font-family:var(--serif);
  font-size:44px;
  line-height:1.12;
  letter-spacing:.2px;
}

/* =================== TOP PROGRESS =================== */
.top-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg, rgba(212,180,106,.4), rgba(212,180,106,1));
  z-index:999;
  box-shadow:0 10px 30px rgba(212,180,106,.35);
}

/* =================== NAV =================== */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.78);
  backdrop-filter: blur(14px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.brand{
  display:flex;
  flex-direction:column;
  gap:2px;
  font-family:var(--serif);
  font-weight:800;
  letter-spacing:1px;
}
.brand span{color:var(--gold)}
.brand small{font-family:var(--sans);letter-spacing:.2px;font-weight:700;color:rgba(11,18,32,.65);margin-top:-2px}

.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{font-weight:600;opacity:.92;position:relative}
.nav-links a::after{
  content:"";
  position:absolute;left:0;bottom:-8px;height:2px;width:0%;
  background:linear-gradient(90deg,var(--gold),transparent);
  transition:.35s var(--ease);
}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}

.pill{
  padding:10px 14px;border-radius:999px;
  border:1px solid rgba(30,42,90,.18);
  background:rgba(30,42,90,.04);
}

.nav-actions{display:flex;gap:10px;align-items:center;display: none;}

@media screen and (max-width:780px) {
  .nav-actions{
    display: block;
  }
}

.icon-btn{
  border:1px solid var(--border);
  background:rgba(255,255,255,.55);
  color:var(--text);
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  cursor:pointer;
  transition:.25s var(--ease);
}
.icon-btn:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(30,42,90,.12)}

.burger span{display:block;width:18px;height:2px;background:var(--text);margin:3px auto;border-radius:2px;opacity:.8}

/* Mobile menu slides from top */
.mobile-menu{
  position:absolute;left:0;right:0;top:72px;
  transform:translateY(-120%);
  opacity:0;
  pointer-events:none;
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  padding:14px 18px 18px;
  display:flex;flex-direction:column;gap:10px;
  transition:.35s var(--ease);
}
.mobile-menu a{
  padding:12px 12px;border-radius:14px;font-weight:800;
  background:rgba(30,42,90,.04);
  border:1px solid rgba(30,42,90,.10);
}
.mobile-menu a:hover{background:rgba(30,42,90,.07)}
.mobile-menu.open{
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}

/* =================== HERO =================== */
.hero{
  position:relative;
  min-height:calc(100vh - 72px);
  display:grid;
  align-items:center;
  overflow:hidden;
}
.hero-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transform:scale(1.06);
  filter:saturate(1.05) contrast(1.05);
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to top, rgba(7,10,19,.88), rgba(7,10,19,.35)),
    radial-gradient(900px 600px at 20% 20%, rgba(47,62,133,.28), transparent 60%);
}
.hero-content{
  position:relative;z-index:2;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  padding:52px 0;
}
.chip{
  display:inline-flex;align-items:center;
  padding:9px 14px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-weight:800;
  width:max-content;
}
.hero h1{
  margin-top:16px;
  font-family:var(--serif);
  font-size:64px;
  line-height:1.04;
  color:#fff;
}
.hero p{
  margin-top:14px;
  max-width:680px;
  color:rgba(255,255,255,.84);
  font-size:18px;
  line-height:1.65;
}
.hero-cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.hero-badges{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px}
.badge-pill{
  padding:8px 12px;border-radius:999px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.88);
  backdrop-filter: blur(10px);
  font-weight:800;
  font-size:13px;
}

/* Right glass card */
.glass-card{
  border-radius:26px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.10);
  backdrop-filter: blur(14px);
  box-shadow:0 30px 110px rgba(0,0,0,.35);
  padding:18px;
}
.stat-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.stat{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.14);
  padding:14px 12px;
}
.stat b{display:block;color:#fff;font-size:22px}
.stat span{display:block;color:rgba(255,255,255,.78);font-weight:800;font-size:12px;margin-top:2px}
.glass-note{
  margin-top:12px;
  border-radius:18px;
  padding:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.14);
  color:rgba(255,255,255,.86);
  display:flex;gap:10px;align-items:flex-start;
  font-weight:700;
}
.dot{width:10px;height:10px;border-radius:50%;background:var(--gold);margin-top:6px;flex:0 0 auto;box-shadow:0 0 22px rgba(212,180,106,.55)}
.glass-actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}

/* Scroll cue */
.scroll-cue{
  position:absolute;bottom:18px;left:50%;
  width:26px;height:42px;border:2px solid rgba(255,255,255,.55);
  border-radius:999px;transform:translateX(-50%);
}
.scroll-cue::after{
  content:"";position:absolute;top:8px;left:50%;
  width:5px;height:7px;background:var(--gold);
  border-radius:3px;transform:translateX(-50%);
  animation:dot 1.2s ease-in-out infinite;
}
@keyframes dot{
  0%{opacity:0;transform:translate(-50%,0)}
  30%{opacity:1}
  100%{opacity:0;transform:translate(-50%,16px)}
}

/* =================== BUTTONS =================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:14px;
  border:1px solid transparent;
  font-weight:900;
  cursor:pointer;
  transition:.25s var(--ease);
  user-select:none;
  white-space:nowrap;
}
.btn.sm{padding:10px 14px;border-radius:12px;font-weight:900}
.btn-primary{
  background:linear-gradient(135deg, var(--primary), var(--primary-2));
  color:#fff;
  box-shadow:0 18px 60px rgba(30,42,90,.35);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 28px 90px rgba(30,42,90,.42)}
.btn-ghost{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.22);
  color:#fff;
}
.btn-ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}
.btn-gold{
  background:linear-gradient(135deg, var(--gold), var(--gold-2));
  color:#10131f;
  box-shadow:0 18px 55px rgba(212,180,106,.28);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 26px 80px rgba(212,180,106,.33)}
.btn-ghost-dark{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.18);
  color:#fff;
}

/* =================== SECTION HEAD =================== */
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:18px;
  margin-bottom:22px;
}
.section-head p{margin-top:10px}
.head-actions{display:flex;gap:10px;flex-wrap:wrap}

/* =================== CARDS GRID =================== */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.img-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:26px;
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:.35s var(--ease);
}
.img-card:hover{transform:translateY(-10px);box-shadow:var(--shadow2)}
.img-card .img{
  height:210px;
  background-size:cover;background-position:center;
  position:relative;
}
.img-card .img::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(15,27,68,.70), transparent 60%);
  opacity:.9;
}
.img-card .content{padding:16px 16px 18px}
.img-card h3{font-family:var(--serif);font-size:24px;margin:0}
.img-card p{margin-top:8px;color:var(--muted);line-height:1.65;font-weight:600}

/* =================== APPLICATIONS STRIP =================== */
.apps{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
}
.app{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:22px;
  padding:14px;
  box-shadow:0 16px 50px rgba(30,42,90,.10);
  display:flex;gap:10px;align-items:center;
  transition:.25s var(--ease);
}
.app:hover{transform:translateY(-6px)}
.app-ico{font-size:20px}
.app b{display:block}
.app p{margin:2px 0 0}

/* =================== SWIPER =================== */
.swiper{overflow:hidden;padding:10px 0}
.track{
  display:flex;gap:14px;
  width:max-content;
  padding:10px 5vw 10px;
  animation:marquee 20s linear infinite;
}
.swiper:hover .track{animation-play-state:paused}
.bcard{
  width:180px;height:92px;
  border-radius:18px;
  background:var(--surface);
  border:1px solid var(--border);
  display:grid;place-items:center;
  box-shadow:var(--shadow);border-radius: 10px;
}
.bcard img{max-width:100%;height:95px;opacity:.95; border-radius:0px;padding: 10px;}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* =================== GALLERY =================== */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:260px;
  gap:16px;
}
.gcard{
  border:1px solid rgba(255,255,255,.18);
  border-radius:26px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  background-size:cover;background-position:center;
  box-shadow:var(--shadow);
  transition:.55s var(--ease);
  text-align:left;
}
.gcard:focus{outline:3px solid rgba(212,180,106,.35);outline-offset:3px}
.gcard::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(15,27,68,.88), rgba(15,27,68,.25), transparent);
}
.gcard:hover{transform:translateY(-10px) scale(1.01);box-shadow:var(--shadow2)}
.gmeta{
  position:absolute;left:0;right:0;bottom:0;
  padding:18px;
  color:#fff;
  z-index:2;
  display:flex;flex-direction:column;gap:4px;
}
.gmeta b{font-family:var(--serif);font-size:24px}
.gmeta small{opacity:.85;font-weight:800}
.gcard.wide{grid-column:span 2}

/* =================== PROCESS =================== */
.process{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.step{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:24px;
  padding:16px;
  box-shadow:0 18px 55px rgba(30,42,90,.10);
  transition:.25s var(--ease);
}
.step:hover{transform:translateY(-8px)}
.num{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:16px;
  background:linear-gradient(135deg, rgba(30,42,90,.12), rgba(212,180,106,.10));
  border:1px solid var(--border);
  font-weight:900;
  margin-bottom:10px;
}
.step b{display:block;font-size:18px}
.step p{margin-top:6px}

/* =================== TOUR =================== */
.tour iframe{
  width:100%;
  height:min(76vh, 720px);
  border:0;
  border-radius:26px;
  background:#0b1020;
  box-shadow:var(--shadow2);
}

/* =================== TESTIMONIALS =================== */
.testimonials{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.tcard{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:26px;
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:.35s var(--ease);
  display:grid;
  grid-template-columns: 1fr;
}
.tcard:hover{transform:translateY(-10px);box-shadow:var(--shadow2)}
.timg{height:170px;background-size:cover;background-position:center}
.tcard > div:last-child{padding:16px}
.tcard p{color:var(--text);font-weight:700;line-height:1.7}
.tcard b{display:block;margin-top:10px}

/* =================== FAQ =================== */
.faq{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:26px;
  box-shadow:var(--shadow);
  padding:10px;
}
details{
  padding:14px 14px;
  border-radius:18px;
  border:1px solid rgba(15,23,42,.08);
  background:rgba(255,255,255,.6);
  margin:10px 0;
}
summary{
  cursor:pointer;
  font-weight:900;
  list-style:none;
}
summary::-webkit-details-marker{display:none}
details p{margin-top:10px}

/* =================== CTA (DARK) =================== */
.dark{background:linear-gradient(135deg, var(--primary-3), var(--primary))}
.cta{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:18px;
  padding:28px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  box-shadow:0 30px 110px rgba(0,0,0,.35);
}
.cta h2{margin:0;color:#fff;font-family:var(--serif);font-size:36px;line-height:1.1}
.muted-on-dark{margin-top:10px;color:rgba(255,255,255,.78);font-weight:600}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.nap{
  margin-top:14px;
  border-radius:20px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.14);
  color:rgba(255,255,255,.90);
  font-weight:700;
  line-height:1.65;
}
.nap-link{color:#fff;text-decoration:underline;text-decoration-color:rgba(212,180,106,.7)}

/* =================== FOOTER =================== */
.footer{
  padding:34px 0 18px;
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.55);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap:18px;
  align-items:start;
}
.foot-brand{
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:1px;
  font-size:22px;
}
.foot-brand span{color:var(--gold)}
.foot-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.foot-links a{font-weight:800;opacity:.9}
.foot-links a:hover{opacity:1}
.foot-actions{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.mini-link{
  display:inline-flex;gap:10px;align-items:center;
  padding:10px 12px;border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:rgba(255,255,255,.65);
  font-weight:900;
}
.backtop{padding:14px 0;text-align:center}

/* =================== FLOATING + STICKY CTA =================== */
.float-btn{
  position:fixed;right:18px;z-index:120;
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-radius:999px;
  color:#081015;
  font-weight:1000;
  box-shadow:0 20px 70px rgba(0,0,0,.25);
  transition:.25s var(--ease);
}
.float-btn span{font-weight:900}
.float-btn:hover{transform:translateY(-2px)}
.float-btn.wa{bottom:106px;background:linear-gradient(135deg, #25D366, #1fb756)}
.float-btn.map{bottom:54px;background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff}
.float-btn.map span{color:#fff}

.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;
  display:none;
  z-index:110;
  background:rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
  border-top:1px solid var(--border);
}
.sticky-cta a{
  flex:1;
  padding:14px 10px;
  text-align:center;
  font-weight:1000;
  color:var(--text);
  border-right:1px solid var(--border);
}
.sticky-cta a:last-child{border-right:none}

/* =================== IMAGE MODAL =================== */
.img-modal{
  position:fixed;inset:0;
  background:rgba(0,0,0,.82);
  display:none;
  align-items:center;justify-content:center;
  z-index:200;
  padding:16px;
}
.img-modal.active{display:flex}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:46px;height:46px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:#fff;font-size:28px;
  cursor:pointer;
}
.img-modal img{
  max-width:92vw;max-height:82vh;
  border-radius:22px;
  box-shadow:0 30px 130px rgba(0,0,0,.55);
  animation:pop .25s ease;
}
@keyframes pop{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
.modal-nav{
  position:absolute;top:50%;
  transform:translateY(-50%);
  width:54px;height:54px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:36px;
  cursor:pointer;
  display:grid;place-items:center;
}
.modal-nav.prev{left:16px}
.modal-nav.next{right:16px}
.modal-caption{
  position:absolute;left:50%;bottom:18px;
  transform:translateX(-50%);
  color:rgba(255,255,255,.88);
  font-weight:900;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.14);
  padding:10px 12px;border-radius:999px;
  backdrop-filter: blur(10px);
}

/* =================== REVEAL =================== */
.reveal{opacity:0;transform:translateY(18px);transition:.65s var(--ease)}
.reveal.on{opacity:1;transform:none}

/* =================== GOLD SHIMMER HEADING =================== */
.shimmer{
  background: linear-gradient(
    110deg,
    rgba(212,180,106,.25) 0%,
    rgba(212,180,106,1) 20%,
    rgba(242,227,184,1) 35%,
    rgba(212,180,106,1) 50%,
    rgba(212,180,106,.25) 70%,
    rgba(212,180,106,1) 100%
  );
  background-size: 220% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  animation: shimmerMove 2.8s linear infinite;
}
.shimmer-on-dark{
  background: linear-gradient(
    110deg,
    rgba(242,227,184,.35) 0%,
    rgba(212,180,106,1) 20%,
    rgba(255,255,255,.92) 35%,
    rgba(212,180,106,1) 50%,
    rgba(242,227,184,.35) 70%,
    rgba(212,180,106,1) 100%
  );
  background-size: 240% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  animation: shimmerMove 3s linear infinite;
}
@keyframes shimmerMove{
  0%{background-position:0% 50%}
  100%{background-position:220% 50%}
}

/* =================== MOTION REDUCTION =================== */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  html{scroll-behavior:auto}
}

/* =================== RESPONSIVE =================== */
@media (max-width: 1100px){
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .apps{grid-template-columns:repeat(3,1fr)}
  .testimonials{grid-template-columns:1fr}
  .process{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 980px){
  .hero-content{grid-template-columns:1fr}
  .hero h1{font-size:52px}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:260px}
  .gcard.wide{grid-column:auto}
  .cta{flex-direction:column;align-items:flex-start}
  .cta-actions{justify-content:flex-start}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width: 780px){
  .nav-links{display:none}
  .sticky-cta{display:flex}
  .h2{font-size:34px}
  .hero h1{font-size:44px}
  .float-btn span{display:none}
}
@media (max-width: 420px){
  .hero h1{font-size:38px}
  .apps{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
}


.text-center{
  text-align: center;
}

/* ================= CTA IMAGE OPTIMIZATION ================= */

.cta-split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:26px;
}

.cta-left h2{
  margin-bottom:6px;
}

.cta-image{
  position:relative;
  margin-top:14px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 30px 110px rgba(0,0,0,.45);
}

.cta-image img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transform:scale(1.02);
}

.cta-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      to top,
      rgba(15,27,68,.75),
      rgba(15,27,68,.15),
      transparent
    );
}

.img-overlay{
  position:absolute;
  left:16px;
  bottom:16px;
  z-index:2;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(0,0,0,.35);
  backdrop-filter: blur(8px);
  color:#fff;
  font-weight:900;
  font-size:13px;
  border:1px solid rgba(255,255,255,.18);
}

/* ================= CTA RIGHT ================= */

.cta-right{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:18px;
}

.cta-actions{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.cta-actions .btn{
  justify-content:center;
}

/* ================= NAP ================= */

.nap{
  margin-top:6px;
  padding:14px 16px;
  border-radius:20px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.9);
  font-weight:700;
  line-height:1.65;
}

.nap-link{
  color:#fff;
  text-decoration:underline;
  text-decoration-color:rgba(212,180,106,.8);
}

/* ================= RESPONSIVE ================= */

@media (max-width: 980px){
  .cta-split{
    grid-template-columns:1fr;
  }

  .cta-image{
    margin-bottom:10px;
  }

  .cta-actions{
    flex-direction:row;
    flex-wrap:wrap;
  }

  .cta-actions .btn{
    flex:1 1 auto;
  }
}

@media (max-width: 520px){
  .cta-actions{
    flex-direction:column;
  }

  .img-overlay{
    font-size:12px;
    padding:8px 12px;
  }
}
/* =================== CATALOGUE =================== */

.catalogue-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.catalogue-card{
  display:block;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:26px;
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:.35s var(--ease);
}

.catalogue-card:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow2);
}

.catalogue-cover{
  height:240px;
  background-size:cover;
  background-position:center;
  position:relative;
}

.catalogue-cover::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to top,
      rgba(15,27,68,.85),
      rgba(15,27,68,.25),
      transparent
    );
}

.cat-badge{
  position:absolute;
  top:14px;
  left:14px;
  padding:8px 12px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));
  color:#10131f;
  font-weight:900;
  font-size:12px;
}

.catalogue-info{
  padding:16px 16px 18px;
}

.catalogue-info h3{
  font-family:var(--serif);
  font-size:24px;
  margin:0;
}

.catalogue-info p{
  margin-top:8px;
  color:var(--muted);
  font-weight:600;
  line-height:1.6;
}

/* Responsive */
@media (max-width: 1100px){
  .catalogue-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 520px){
  .catalogue-grid{grid-template-columns:1fr}
}
.catalogue-info{
  padding:16px 18px 20px;
}

.catalogue-info h3{
  margin:0;
  font-family:var(--serif);
  font-size:22px;
}

.catalogue-info p{
  margin:8px 0 12px;
  color:var(--muted);
  line-height:1.55;
  font-size:14px;
}

.cat-btn{
  display:inline-block;
  font-weight:800;
  font-size:14px;
  color:var(--primary);
  letter-spacing:.3px;
  transition:.25s ease;
}

.catalogue-card:hover .cat-btn{
  transform:translateX(4px);
}

.catalogue-cover{
  position:relative;
}

.cat-badge{
  position:absolute;
  top:14px;
  left:14px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  background:linear-gradient(135deg, #d4b46a, #f2e3b8);
  color:#10131f;
}
