/* ===========================================================================
   rokn-afdal — components
   =========================================================================== */

/* ---- Buttons sizing extra ---- */
.btn--sm{padding:10px 18px;font-size:14px}
.btn--block{display:flex;justify-content:center;width:100%;margin-bottom:10px}

/* ===== Header ===== */
.skip-link{position:absolute;right:0;top:0}
.site-header{position:sticky;top:0;z-index:900;background:var(--white);transition:box-shadow var(--t)}
.site-header.is-stuck{box-shadow:0 6px 24px rgba(10,35,71,.10)}

.topbar{background:var(--navy-dark);color:#cdd7e6;font-size:13.5px}
.topbar__in{display:flex;align-items:center;justify-content:space-between;min-height:42px;gap:16px}
.topbar__info{display:flex;gap:22px;flex-wrap:wrap}
.topbar__info li{display:flex;align-items:center;gap:7px}
.topbar__info i{color:var(--gold);font-size:16px}
.topbar__right{display:flex;align-items:center;gap:16px}
.topbar__phone{display:flex;align-items:center;gap:7px;color:#fff;font-weight:700;font-family:var(--ff-head)}
.topbar__phone i{color:var(--gold)}
.topbar__phone:hover{color:var(--gold-light)}
.topbar__social{display:flex;gap:6px}
.topbar__social a{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);font-size:15px;transition:background var(--t),color var(--t)}
.topbar__social a:hover{background:var(--gold);color:var(--navy-dark)}

.navbar{background:var(--white)}
.navbar__in{display:flex;align-items:center;gap:18px;min-height:88px}
.navbar__brand{flex-shrink:0;display:flex;align-items:center}
.brand-link{display:inline-flex;align-items:center;transition:transform var(--t)}
.brand-link:hover{transform:scale(1.04)}
.brand-logo{height:74px;width:auto;object-fit:contain;display:block}
.site-header.is-stuck .brand-logo{height:62px;transition:height var(--t)}
.navbar__menu{margin-inline-start:auto}
.menu{display:flex;align-items:center;gap:4px}
.menu li{position:relative}
.menu>li>a{display:flex;align-items:center;gap:5px;padding:12px 14px;font-family:var(--ff-head);font-weight:700;font-size:15.5px;color:var(--navy-dark);border-radius:10px;transition:color var(--t),background var(--t)}
.menu>li>a:hover,.menu>li.current-menu-item>a{color:var(--gold-dark);background:var(--surface)}
.menu .caret{font-size:15px;transition:transform var(--t)}
.sub-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:230px;background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--t);z-index:50}
.menu li:hover>.sub-menu{opacity:1;visibility:visible;transform:none}
.sub-menu li a{display:block;padding:10px 12px;border-radius:8px;font-size:14.5px;color:var(--text)}
.sub-menu li a:hover{background:var(--surface);color:var(--gold-dark)}

.navbar__actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border-radius:10px;background:var(--surface);align-items:center;justify-content:center}
.nav-toggle span{width:22px;height:2px;background:var(--navy-dark);border-radius:2px;transition:all var(--t)}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Hero (light) ===== */
.btn--lg{padding:15px 32px;font-size:16px}
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#ffffff 0%,#eef4fb 55%,#e7eff8 100%);color:var(--text);padding:84px 0 96px}
.hero__bg{position:absolute;inset:0;overflow:hidden}
.hero__bg::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(14,58,107,.06) 1px,transparent 1px);background-size:30px 30px;opacity:.6;animation:heroGridShift 40s linear infinite}
@keyframes heroGridShift{to{background-position:300px 300px}}
.hero__grid{position:absolute;inset:0;background:radial-gradient(640px 460px at 26% 48%,rgba(14,58,107,.18),transparent 62%),radial-gradient(560px 380px at 8% 112%,rgba(201,162,75,.16),transparent 60%),radial-gradient(520px 360px at 95% -10%,rgba(42,111,196,.12),transparent 60%)}
/* blobs (soft pastel on light) */
.hero__blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55}
.hero__blob--1{width:480px;height:480px;background:rgba(201,162,75,.28);top:-150px;inset-inline-end:-80px;animation:blobFloat 14s ease-in-out infinite}
.hero__blob--2{width:440px;height:440px;background:rgba(42,111,196,.22);bottom:-170px;inset-inline-start:-70px;animation:blobFloat 18s ease-in-out infinite reverse}
.hero__blob--3{width:320px;height:320px;background:rgba(201,162,75,.14);top:42%;inset-inline-start:40%;animation:blobFloat 22s ease-in-out infinite}
@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.1)}66%{transform:translate(-30px,40px) scale(.95)}}
/* particles */
.hero__particles i{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:.0;top:calc(var(--i) * 7%);inset-inline-start:calc(var(--i) * 6.5% );animation:particleRise calc(9s + var(--i) * 1s) linear infinite;animation-delay:calc(var(--i) * -1.3s)}
.hero__particles i:nth-child(odd){width:4px;height:4px;background:var(--navy)}
@keyframes particleRise{0%{transform:translateY(40px);opacity:0}10%{opacity:.5}90%{opacity:.35}100%{transform:translateY(-160px);opacity:0}}

.hero__in{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:40px}

/* entrance animation */
.js .hero [data-anim]{opacity:0;transform:translateY(26px);animation:heroIn .8s cubic-bezier(.2,.7,.2,1) forwards}
.js .hero [data-anim="1"]{animation-delay:.05s}.js .hero [data-anim="2"]{animation-delay:.18s}
.js .hero [data-anim="3"]{animation-delay:.30s}.js .hero [data-anim="4"]{animation-delay:.42s}
.js .hero [data-anim="5"]{animation-delay:.54s}.js .hero [data-anim="6"]{animation-delay:.66s}
.js .hero [data-anim="7"]{animation-delay:.78s}.js .hero [data-anim="8"]{animation-delay:.30s;transform:scale(.9)}
@keyframes heroIn{to{opacity:1;transform:none}}

.hero__eyebrow{position:relative;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(90deg,rgba(201,162,75,.16),rgba(14,58,107,.10));color:var(--gold-dark);border:1px solid rgba(201,162,75,.5);padding:8px 18px;border-radius:var(--pill);font-family:var(--ff-head);font-weight:700;font-size:13.5px;margin-bottom:20px;overflow:hidden}
.hero__eyebrow::after{content:"";position:absolute;top:0;inset-inline-start:-60%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);transform:skewX(-20deg);animation:ctaShine 4s ease-in-out infinite}
.hero__eyebrow i{animation:crownPulse 2.4s ease-in-out infinite}
@keyframes crownPulse{50%{transform:translateY(-3px) rotate(-6deg)}}
.hero__title{font-size:clamp(32px,5vw,60px);line-height:1.18;color:var(--navy-dark);margin-bottom:18px;font-weight:800;letter-spacing:-.5px}
.hero__line{display:block;background:linear-gradient(90deg,#0e3a6b 0%,#2a6fc4 18%,#c9a24b 36%,#e0c074 50%,#c9a24b 64%,#2a6fc4 82%,#0e3a6b 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:heroShine 2.6s linear infinite}
@keyframes heroShine{0%{background-position:0% center}100%{background-position:-200% center}}
.hero__typed-wrap{display:block;min-height:1.3em}
.hero__typed{background:linear-gradient(90deg,var(--gold-dark),var(--gold) 50%,var(--gold-light));background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:goldFlow 3.5s linear infinite}
@keyframes goldFlow{to{background-position:200% 0}}
.hero__typed::after{content:"";display:inline-block;width:3px;height:.95em;background:var(--gold);margin-inline-start:4px;vertical-align:-2px;animation:blink 1s steps(1) infinite;-webkit-text-fill-color:initial}
@keyframes blink{50%{opacity:0}}
.hero__sub{font-size:17px;color:var(--text-muted);max-width:600px;margin-bottom:28px;line-height:1.9}
.hero__btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero__cta{position:relative;overflow:hidden;animation:ctaPulse 2.6s ease-in-out infinite}
.hero__cta::after{content:"";position:absolute;top:0;inset-inline-start:-120%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg);animation:ctaShine 3.2s ease-in-out infinite}
@keyframes ctaShine{0%,60%{inset-inline-start:-120%}100%{inset-inline-start:140%}}
@keyframes ctaPulse{0%,100%{box-shadow:0 8px 22px rgba(201,162,75,.30)}50%{box-shadow:0 10px 34px rgba(201,162,75,.55)}}
.hero__features{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;max-width:560px;margin-bottom:24px}
.hero__features li{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 8px;font-size:13.5px;font-weight:500;color:var(--navy-dark);box-shadow:0 6px 18px rgba(14,58,107,.06);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.hero__features li:hover{transform:translateY(-5px);box-shadow:0 12px 28px rgba(14,58,107,.14);border-color:var(--gold)}
.hero__features i{font-size:26px;color:var(--gold-dark)}
.hero__trust{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:14px}
.hero__stars{color:var(--gold);display:inline-flex;gap:2px;font-size:16px}
.hero__stars i{animation:starPop .5s ease backwards}
.hero__stars i:nth-child(1){animation-delay:.8s}.hero__stars i:nth-child(2){animation-delay:.9s}.hero__stars i:nth-child(3){animation-delay:1s}.hero__stars i:nth-child(4){animation-delay:1.1s}.hero__stars i:nth-child(5){animation-delay:1.2s}
@keyframes starPop{from{opacity:0;transform:scale(0) rotate(-40deg)}to{opacity:1;transform:none}}

/* media / orbit */
.hero__media{position:relative;display:flex;justify-content:center;align-items:center}
/* floating info chips */
.hero__chip{position:absolute;z-index:6;display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:16px;padding:11px 16px;box-shadow:0 16px 36px rgba(14,58,107,.20)}
.hero__chip i{flex-shrink:0;width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:22px}
.hero__chip-tx{display:flex;flex-direction:column;line-height:1.25}
.hero__chip b{font-family:var(--ff-head);font-weight:800;color:var(--navy-dark);font-size:16px}
.hero__chip small{color:var(--text-muted);font-size:11.5px}
.hero__chip--1{top:6%;inset-inline-end:-4%;animation:chipFloat 4.5s ease-in-out infinite}
.hero__chip--1 i{background:rgba(201,162,75,.15);color:var(--gold-dark)}
.hero__chip--2{bottom:8%;inset-inline-start:-6%;animation:chipFloat 5.5s ease-in-out infinite reverse}
.hero__chip--2 i{background:rgba(14,58,107,.12);color:var(--navy)}
@keyframes chipFloat{50%{transform:translateY(-13px)}}
/* scroll indicator */
.hero__scroll{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:4;display:inline-flex;flex-direction:column;align-items:center;gap:7px;color:var(--text-muted);font-family:var(--ff-head);font-weight:700;font-size:12.5px}
.hero__scroll:hover{color:var(--gold-dark)}
.hero__mouse{width:24px;height:38px;border:2px solid var(--navy);border-radius:13px;position:relative}
.hero__mouse::before{content:"";position:absolute;top:7px;left:50%;width:4px;height:7px;border-radius:3px;background:var(--gold);transform:translateX(-50%);animation:mouseScroll 1.6s ease-in-out infinite}
@keyframes mouseScroll{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}
.hero__orbit{position:relative;width:380px;height:380px;display:grid;place-items:center}
.hero__orbit::before{content:"";position:absolute;inset:-10%;border-radius:50%;background:radial-gradient(circle,rgba(14,58,107,.16),rgba(201,162,75,.08) 45%,transparent 68%);z-index:-1;animation:orbitGlow 6s ease-in-out infinite}
@keyframes orbitGlow{50%{transform:scale(1.08);opacity:.8}}
.hero__ring{position:absolute;border-radius:50%}
.hero__ring--1{inset:0;border:1.5px dashed rgba(201,162,75,.45);animation:spin 40s linear infinite}
.hero__ring--2{inset:54px;border:1.5px solid rgba(42,111,196,.18);animation:spin 28s linear infinite reverse}
.hero__orbit-img{position:absolute;top:50%;left:50%;width:84px;height:84px;margin:-42px;border-radius:50%;overflow:hidden;background:#fff;border:4px solid #fff;box-shadow:0 12px 26px rgba(14,58,107,.22),0 0 0 1px rgba(201,162,75,.5);transform:rotate(calc(var(--n) * (360deg / var(--total)))) translate(186px) rotate(calc(var(--n) * (-360deg / var(--total))));animation:orbit 34s linear infinite}
.hero__orbit-img img{width:100%;height:100%;object-fit:cover;display:block}
@keyframes orbit{to{transform:rotate(calc(var(--n) * (360deg / var(--total)) + 360deg)) translate(186px) rotate(calc(var(--n) * (-360deg / var(--total)) - 360deg))}}
.hero__badge{position:relative;z-index:2;width:230px;height:230px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 50% 40%,#ffffff,#f1f6fc 80%);border:5px solid #fff;box-shadow:0 0 0 1px rgba(201,162,75,.5),0 24px 50px rgba(14,58,107,.22);animation:float 5s ease-in-out infinite}
.hero__badge::before{content:"";position:absolute;inset:-14px;border-radius:50%;background:conic-gradient(from 0deg,transparent,rgba(201,162,75,.55),transparent 32%);animation:spin 8s linear infinite;z-index:-1;filter:blur(7px)}
.hero__badge img{height:74%;width:auto;max-width:78%;object-fit:contain;filter:drop-shadow(0 8px 16px rgba(14,58,107,.18))}
@keyframes float{50%{transform:translateY(-14px)}}
@keyframes spin{to{transform:rotate(360deg)}}

@media(prefers-reduced-motion:reduce){
  .hero *{animation:none !important}
  .js .hero [data-anim]{opacity:1;transform:none}
}

/* ===== Cards grid generic ===== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cards-grid--3{grid-template-columns:repeat(3,1fr)}

/* service card */
.service-card,.post-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform var(--t),box-shadow var(--t)}
.service-card:hover,.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.service-card__media,.post-card__media{position:relative;display:block;aspect-ratio:16/10;overflow:hidden;background:var(--surface)}
.rokn-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-card:hover .rokn-img,.post-card:hover .rokn-img{transform:scale(1.06)}
.rokn-img--ph{object-fit:contain;padding:24px;background:var(--navy-dark)}
.service-card__icon{position:absolute;bottom:-22px;inset-inline-start:18px;width:48px;height:48px;border-radius:50%;background:var(--gold);color:var(--navy-dark);display:grid;place-items:center;font-size:24px;box-shadow:var(--shadow-gold)}
.service-card__body{padding:30px 20px 22px}
.post-card__body{padding:20px}
.service-card__title,.post-card__title{font-size:18.5px;margin-bottom:10px;line-height:1.45}
.service-card__title a:hover,.post-card__title a:hover{color:var(--gold-dark)}
.service-card__excerpt,.post-card p{color:var(--text-muted);font-size:14.5px;margin-bottom:14px}
.service-card__link,.post-card__link{display:inline-flex;align-items:center;gap:6px;color:var(--navy);font-family:var(--ff-head);font-weight:700;font-size:14.5px}
.service-card__link:hover,.post-card__link:hover{color:var(--gold-dark);gap:10px}
.post-card__date{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:13px;margin-bottom:8px}
.post-card__date i{color:var(--gold-dark)}

/* ===== Why grid ===== */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why-card{position:relative;overflow:hidden;background:#fff;border-radius:var(--radius);padding:34px 28px 30px;border:1px solid var(--line);transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease,background-color .4s ease}
.why-card:hover{transform:translateY(-8px);border-color:transparent;box-shadow:0 22px 48px rgba(10,35,71,.30);background-color:var(--navy-dark)}
.why-card__num{position:absolute;top:14px;inset-inline-end:24px;z-index:1;font-family:var(--ff-head);font-weight:800;font-size:64px;line-height:1;color:rgba(14,58,107,.07);transition:color .4s ease}
.why-card:hover .why-card__num{color:rgba(201,162,75,.20)}
.why-card__icon{position:relative;z-index:1;width:66px;height:66px;border-radius:50%;display:grid;place-items:center;font-size:31px;background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:var(--gold-light);margin-bottom:18px;transition:background .4s ease,color .4s ease,transform .4s ease}
.why-card__icon::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1.5px dashed rgba(201,162,75,.5);opacity:0;transition:opacity .4s ease,transform .6s ease}
.why-card:hover .why-card__icon{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy-dark);transform:rotate(-6deg) scale(1.06)}
.why-card:hover .why-card__icon::after{opacity:1;transform:rotate(120deg)}
.why-card h3{position:relative;z-index:1;font-size:19.5px;margin-bottom:10px;transition:color .4s ease}
.why-card p{position:relative;z-index:1;color:var(--text-muted);font-size:14.5px;line-height:1.85;transition:color .4s ease}
.why-card:hover h3{color:#fff}
.why-card:hover p{color:#c9d3e2}
.why-card__bar{position:absolute;z-index:2;bottom:0;inset-inline-start:0;height:4px;width:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));transform:scaleX(0);transform-origin:right;transition:transform .4s ease}
.why-card:hover .why-card__bar{transform:scaleX(1)}

/* ===== Process ===== */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
/* connector line behind the number nodes */
.process-line{position:absolute;top:33px;inset-inline:13%;height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,var(--gold) 12%,var(--gold) 88%,transparent);z-index:0}
.process-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:22px}
.process-step__num{position:relative;z-index:2;width:66px;height:66px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy-dark);font-family:var(--ff-head);font-weight:800;display:grid;place-items:center;font-size:26px;border:5px solid var(--bg);box-shadow:0 8px 20px rgba(201,162,75,.4);transition:transform .35s ease}
.process-step__card{position:relative;overflow:hidden;width:100%;flex:1;text-align:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 20px 26px;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.process-step__card::before{content:"";position:absolute;top:0;inset-inline:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));transform:scaleX(0);transition:transform .35s ease}
.process-step:hover .process-step__num{transform:translateY(-4px) scale(1.08)}
.process-step:hover .process-step__card{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.process-step:hover .process-step__card::before{transform:scaleX(1)}
.process-step__icon{width:70px;height:70px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:var(--gold-light);font-size:32px;margin:0 auto 16px;transition:transform .4s ease}
.process-step:hover .process-step__icon{transform:rotateY(180deg)}
.process-step h3{font-size:18.5px;margin-bottom:8px}
.process-step p{color:var(--text-muted);font-size:14px;line-height:1.8}

/* ===== Stats band ===== */
.stats-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--navy-darker),var(--navy-dark) 55%,var(--navy));color:#fff;padding:62px 0}
.stats-band__bg{position:absolute;inset:0;background:radial-gradient(800px 300px at 80% 0,rgba(201,162,75,.18),transparent 60%)}
.stats-band::before{content:"";position:absolute;top:0;inset-inline:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.stats-band::after{content:"";position:absolute;inset:0;background:url(../img/logo.webp) no-repeat center/300px;opacity:.03;filter:grayscale(1)}
.stats-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}
.stat{position:relative;display:flex;flex-direction:column;align-items:center;gap:14px;padding:6px 18px}
.stat:not(:last-child)::after{content:"";position:absolute;inset-inline-start:0;top:18%;height:64%;width:1px;background:rgba(255,255,255,.12)}
.stat__icon{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;font-size:34px;color:var(--gold-light);background:rgba(201,162,75,.12);border:1px solid rgba(201,162,75,.4);transition:transform .4s ease,background .4s ease,color .4s ease}
.stat:hover .stat__icon{transform:translateY(-5px) scale(1.07);background:var(--gold);color:var(--navy-dark)}
.stat__head{display:inline-flex;align-items:baseline;line-height:1}
.stat__num,.stat__plus{font-family:var(--ff-head);font-weight:800;font-size:clamp(32px,4vw,48px);line-height:1;background:linear-gradient(180deg,#fff,#dfe8f5);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat__plus{background:linear-gradient(180deg,var(--gold-light),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-inline-end:2px}
.stat__lbl{display:block;color:#c9d3e2;font-size:15.5px;font-family:var(--ff-head);font-weight:500}

/* ===== Categories chips ===== */
.cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cat-chip{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 18px 24px;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease,background-color .4s ease}
.cat-chip:hover{transform:translateY(-7px);box-shadow:0 22px 48px rgba(10,35,71,.28);border-color:transparent;background-color:var(--navy-dark)}
.cat-chip__count{position:absolute;top:14px;inset-inline-end:14px;font-family:var(--ff-head);font-weight:700;font-size:11.5px;color:var(--gold-dark);background:rgba(201,162,75,.12);border:1px solid rgba(201,162,75,.35);padding:3px 11px;border-radius:999px;transition:all var(--t)}
.cat-chip:hover .cat-chip__count{background:var(--gold);color:var(--navy-dark);border-color:var(--gold)}
.cat-chip__icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;font-size:30px;background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:var(--gold-light);transition:background .4s ease,color .4s ease,transform .4s ease;margin-top:6px}
.cat-chip:hover .cat-chip__icon{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy-dark);transform:rotate(-8deg) scale(1.08)}
.cat-chip__name{font-family:var(--ff-head);font-weight:700;font-size:16px;color:var(--navy-dark);transition:color .4s ease}
.cat-chip:hover .cat-chip__name{color:#fff}
.cat-chip__go{display:inline-flex;align-items:center;gap:5px;font-family:var(--ff-head);font-weight:700;font-size:13px;color:var(--gold-dark);opacity:0;transform:translateY(6px);transition:all var(--t)}
.cat-chip:hover .cat-chip__go{opacity:1;transform:none;color:var(--gold-light)}

/* ===== Testimonials ===== */
.rating-line{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--text-muted)}
.stars,.review-card__stars{color:var(--gold);display:inline-flex;gap:2px}
.reviews-wrap{position:relative;overflow:hidden}
.reviews{display:flex;gap:24px;padding:6px 2px 16px;transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform}
.review-card{flex:0 0 calc((100% - 48px) / 3);box-sizing:border-box}
.review-card{position:relative;overflow:hidden;scroll-snap-align:start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px 26px;box-shadow:var(--shadow-sm);transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.review-card::before{content:"\201D";position:absolute;top:6px;inset-inline-start:22px;font-family:Georgia,serif;font-size:96px;line-height:1;color:rgba(201,162,75,.16);pointer-events:none}
.review-card::after{content:"";position:absolute;top:0;inset-inline:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));transform:scaleX(0);transition:transform .35s ease}
.review-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.review-card:hover::after{transform:scaleX(1)}
.review-card__stars{position:relative;font-size:18px;margin-bottom:14px;letter-spacing:2px}
.review-card blockquote{position:relative;color:var(--text);font-size:15.5px;line-height:1.95;margin-bottom:20px;min-height:90px}
.review-card figcaption{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--line)}
.review-card__avatar{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;font-family:var(--ff-head);font-weight:700;font-size:19px;box-shadow:0 0 0 3px var(--bg),0 0 0 4px rgba(201,162,75,.5)}
.review-card__name{display:block;font-family:var(--ff-head);font-weight:700;color:var(--navy-dark);font-size:15.5px}
.review-card__meta{display:block;font-size:13px;color:var(--gold-dark);font-weight:500}

/* ===== FAQ ===== */
.faq-wrap{max-width:820px}
.faq-item{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;transition:box-shadow var(--t),border-color var(--t)}
.faq-item::before{content:"";position:absolute;top:0;bottom:0;inset-inline-start:0;width:4px;background:linear-gradient(180deg,var(--gold),var(--gold-light));transform:scaleY(0);transform-origin:top;transition:transform .3s ease}
.faq-item:hover{border-color:var(--gold)}
.faq-item.open{box-shadow:0 12px 30px rgba(10,35,71,.12);border-color:transparent}
.faq-item.open::before{transform:scaleY(1)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:20px 24px;font-family:var(--ff-head);font-weight:700;font-size:16.5px;color:var(--navy-dark);text-align:start;transition:color var(--t)}
.faq-item.open .faq-q{color:var(--gold-dark)}
.faq-q i{flex-shrink:0;width:34px;height:34px;border-radius:50%;background:var(--surface);color:var(--navy);display:grid;place-items:center;font-size:20px;transition:transform .3s ease,background var(--t),color var(--t)}
.faq-q:hover i{background:var(--gold);color:var(--navy-dark)}
.faq-item.open .faq-q i{transform:rotate(135deg);background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:var(--gold-light)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:360px}
.faq-a p{padding:0 24px 22px;color:var(--text-muted);font-size:15px;line-height:1.95}

/* ===== Footer ===== */
.footer-cta{background:linear-gradient(135deg,var(--gold),var(--gold-light))}
.footer-cta__in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:34px 0;flex-wrap:wrap}
.footer-cta h2{color:var(--navy-darker);font-size:clamp(20px,2.4vw,28px);margin-bottom:4px}
.footer-cta p{color:#5a4a1e}
.footer-cta__btns{display:flex;gap:12px;flex-wrap:wrap}
.footer-cta .btn-gold{background:var(--navy-dark);color:#fff;box-shadow:none}
.footer-cta .btn-gold:hover{background:var(--navy-darker)}

.footer-main{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--navy-dark),var(--navy-darker));color:#aebbd0;padding:66px 0 44px}
.footer-main::before{content:"";position:absolute;top:0;inset-inline:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold) 35%,var(--gold) 65%,transparent)}
.footer-main::after{content:"";position:absolute;bottom:-40px;inset-inline-start:-30px;width:280px;height:280px;background:url(../img/logo.webp) no-repeat center/contain;opacity:.03;filter:grayscale(1);pointer-events:none}
.footer-grid{position:relative;display:grid;grid-template-columns:1.6fr 1fr 1.2fr 1.2fr;gap:40px}
.footer-logo{height:96px;width:auto;background:#fff;padding:14px 26px;border-radius:18px;border:1px solid rgba(201,162,75,.35);box-shadow:0 14px 34px rgba(0,0,0,.3);margin-bottom:22px;transition:transform var(--t),box-shadow var(--t)}
.footer-logo:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,.38)}
.footer-about p{font-size:14.5px;line-height:1.95;margin-bottom:20px;max-width:340px}
.footer-contact li{display:flex;align-items:center;gap:13px;margin-bottom:14px}
.footer-contact i{flex-shrink:0;width:42px;height:42px;border-radius:14px;background:rgba(201,162,75,.12);border:1px solid rgba(201,162,75,.3);color:var(--gold);font-size:19px;display:grid;place-items:center;transition:background var(--t),color var(--t)}
.footer-contact li:hover i{background:var(--gold);color:var(--navy-dark)}
.footer-contact .fc-body{display:flex;flex-direction:column;gap:2px;line-height:1.45}
.footer-contact .fc-label{font-family:var(--ff-head);font-weight:700;font-size:11.5px;color:#7d8ca6;letter-spacing:.3px}
.footer-contact .fc-body a,.footer-contact .fc-body span{color:#dbe3ef;font-size:14.5px;font-weight:500}
.footer-contact .fc-body a:hover{color:var(--gold-light)}
.footer-title{color:#fff;font-size:18.5px;margin-bottom:22px;position:relative;padding-bottom:12px}
.footer-title::after{content:"";position:absolute;bottom:0;inset-inline-start:0;width:46px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:3px}
.footer-links li{margin-bottom:13px}
.footer-links a{display:inline-flex;align-items:center;gap:10px;font-size:14.5px;color:#aebbd0;transition:color var(--t),gap var(--t)}
.footer-links a::before{content:"";width:7px;height:7px;border-radius:50%;border:2px solid var(--gold);flex-shrink:0;transition:background var(--t),box-shadow var(--t)}
.footer-links a:hover{color:#fff;gap:14px}
.footer-links a:hover::before{background:var(--gold);box-shadow:0 0 8px rgba(201,162,75,.6)}
.footer-posts a{display:flex;gap:12px;align-items:center}
.fp-thumb{flex-shrink:0;width:62px;height:50px;border-radius:8px;overflow:hidden;background:rgba(255,255,255,.06)}
.fp-thumb .rokn-img{width:100%;height:100%;object-fit:cover}
.fp-title{display:block;font-size:13.8px;color:#dfe6f0;line-height:1.5}
.footer-posts a:hover .fp-title{color:var(--gold-light)}
.fp-date{display:flex;align-items:center;gap:5px;font-size:12px;color:#8da0bb;margin-top:3px}
.footer-map{border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.footer-map iframe{display:block;filter:grayscale(.3)}

.footer-bottom{background:var(--navy-darker);border-top:1px solid rgba(255,255,255,.07);color:#9fb0c8;font-size:13.5px}
.footer-bottom__in{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;padding:18px 0}
.footer-bottom__copy{text-align:start}
.footer-bottom__links{display:inline-flex;align-items:center;gap:10px;justify-self:end;flex-wrap:wrap}
.footer-bottom__links a{color:#9fb0c8;transition:color var(--t)}
.footer-bottom__links a:hover{color:var(--gold-light)}
.footer-bottom__links .sep{color:rgba(255,255,255,.25)}
/* SEO Partners credit — inline, centered inside footer-bottom row */
.footer-bottom__in .sp-credit-bar{background:transparent !important;border:0 !important;padding:0 !important;display:inline-flex;width:auto;justify-self:center}
@media(max-width:768px){
  .footer-bottom__in{grid-template-columns:1fr;justify-items:center;text-align:center;gap:12px}
  .footer-bottom__copy{text-align:center}
  .footer-bottom__links{justify-self:center}
}
.footer-socials{display:flex;gap:8px}
.footer-socials a{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.07);display:grid;place-items:center;font-size:16px;transition:background var(--t),color var(--t)}
.footer-socials a:hover{background:var(--gold);color:var(--navy-dark)}

/* ===== Breadcrumbs ===== */
.breadcrumbs{background:var(--surface);padding:14px 0;font-size:14px}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.breadcrumbs li{display:flex;align-items:center;gap:8px;color:var(--text-muted)}
.breadcrumbs li:not(:last-child)::after{content:"\ea60";font-family:"tabler-icons";font-size:14px;color:var(--text-muted)}
.breadcrumbs a:hover{color:var(--gold-dark)}
.breadcrumbs .current{color:var(--navy-dark);font-weight:700}

/* ===== Content layout (single/archive) ===== */
.content-layout{display:grid;grid-template-columns:1fr 320px;gap:36px;padding:42px 18px 60px}
.content-layout--full{grid-template-columns:1fr;max-width:900px}
.article{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm)}
.article__cat{display:inline-block;background:var(--surface);color:var(--gold-dark);font-family:var(--ff-head);font-weight:700;font-size:13px;padding:5px 14px;border-radius:var(--pill);margin-bottom:14px}
.article__title{font-size:clamp(24px,3.2vw,34px);line-height:1.4;margin-bottom:14px}
.article__meta{display:flex;gap:18px;color:var(--text-muted);font-size:13.5px;margin-bottom:22px}
.article__meta i{color:var(--gold-dark)}
.article__thumb{border-radius:var(--radius);overflow:hidden;margin-bottom:24px}
.article__thumb .rokn-img{width:100%;height:auto}
.article__content{font-size:16.5px;line-height:2;color:#33415a}
.article__content h2{font-size:25px;margin:30px 0 14px}
.article__content h3{font-size:21px;margin:24px 0 12px}
.article__content p{margin-bottom:16px}
.article__content ul,.article__content ol{margin:0 22px 18px;}
.article__content li{margin-bottom:8px}
.article__content img{border-radius:12px;margin:16px 0}
.article__content a{color:var(--navy);text-decoration:underline;text-decoration-color:var(--gold)}
.article__content blockquote{border-inline-start:4px solid var(--gold);background:var(--surface);padding:16px 20px;border-radius:0 12px 12px 0;margin:18px 0;color:var(--navy-dark)}

.article__share{display:flex;align-items:center;gap:10px;margin:28px 0;padding-top:22px;border-top:1px solid var(--line);flex-wrap:wrap}
.article__share>span:first-child{font-family:var(--ff-head);font-weight:700;color:var(--navy-dark)}
.share{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:19px;transition:transform var(--t)}
.share:hover{transform:translateY(-3px)}
.share--wa{background:var(--whatsapp)}.share--fb{background:#1877f2}.share--tw{background:#111}.share--tg{background:#229ed9}

.article__cta{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:#fff;border-radius:var(--radius);padding:24px 26px;margin:24px 0;flex-wrap:wrap}
.article__cta strong{display:block;font-family:var(--ff-head);font-size:19px;margin-bottom:4px}
.article__cta span{color:#c9d3e2;font-size:14.5px}
.article__cta-btns{display:flex;gap:10px;flex-wrap:wrap}

.related{margin-top:36px}
.related__title{font-size:22px;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--gold);display:inline-block}

/* ===== Sidebar / widgets ===== */
.sidebar{display:flex;flex-direction:column;gap:24px}
.widget{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.widget-title{font-size:18px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--line);position:relative}
.widget-title::after{content:"";position:absolute;bottom:-1px;inset-inline-start:0;width:40px;height:2px;background:var(--gold)}
.widget-cats li a{display:flex;align-items:center;gap:8px;padding:9px 0;border-bottom:1px dashed var(--line);font-size:14.5px;color:var(--text)}
.widget-cats li a i{color:var(--gold-dark)}
.widget-cats li a span{margin-inline-start:auto;background:var(--surface);color:var(--text-muted);border-radius:var(--pill);padding:1px 9px;font-size:12px}
.widget-cats li a:hover{color:var(--gold-dark)}

/* ===== Search form ===== */
.search-form{display:flex;gap:8px}
.search-form input{flex:1;height:46px;border:1px solid var(--line);border-radius:10px;padding:0 14px;font-size:15px;background:var(--bg)}
.search-form input:focus{outline:none;border-color:var(--gold)}
.search-form button{width:46px;height:46px;border-radius:10px;background:var(--navy);color:#fff;font-size:20px;display:grid;place-items:center;flex-shrink:0}
.search-form button:hover{background:var(--gold);color:var(--navy-dark)}

/* ===== Archive head / pagination ===== */
.archive-head{text-align:center;padding:42px 0 8px}
.archive-head__title{font-size:clamp(24px,3.4vw,38px);position:relative;display:inline-block;padding-bottom:14px}
.archive-head__title::after{content:"";position:absolute;bottom:0;inset-inline-start:50%;transform:translateX(50%);width:60px;height:3px;background:var(--gold);border-radius:3px}
.archive-head__desc{color:var(--text-muted);max-width:680px;margin:10px auto 0}
.pagination{margin:42px 0 60px;display:flex;justify-content:center}
.pagination .nav-links{display:flex;gap:8px;flex-wrap:wrap}
.pagination .page-numbers{min-width:44px;height:44px;padding:0 12px;border-radius:10px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;font-family:var(--ff-head);font-weight:700;color:var(--navy-dark)}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.no-results{text-align:center;padding:40px 0 60px;color:var(--text-muted)}

/* ===== 404 ===== */
.error-404{text-align:center;padding:70px 18px 90px;max-width:560px;margin:0 auto}
.error-404__code{font-family:var(--ff-head);font-weight:800;font-size:clamp(80px,16vw,150px);line-height:1;color:var(--navy);opacity:.12}
.error-404 h1{font-size:28px;margin:-10px 0 12px}
.error-404 p{color:var(--text-muted);margin-bottom:22px}
.error-404 .search-form{max-width:380px;margin:0 auto 22px}

/* ===== Comments ===== */
.comments{margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.comments__title{font-size:20px;margin-bottom:18px}
.comments__list{margin-bottom:24px}
.comments__list .comment{margin-bottom:16px}
.comment-respond{background:var(--surface);border-radius:var(--radius);padding:24px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 14px;margin-bottom:12px;font-size:15px;background:#fff}
.comment-form .submit{background:var(--gold);color:var(--navy-dark);border-radius:var(--pill);padding:12px 28px;font-family:var(--ff-head);font-weight:700;cursor:pointer}

/* ===========================================================================
   Responsive
   =========================================================================== */
@media(max-width:1024px){
  .hero__in{grid-template-columns:1fr;text-align:center}
  .hero__media{order:-1}
  .hero__orbit{transform:scale(.82)}
  .hero__features{margin:0 auto;max-width:520px}
  .hero__btns{justify-content:center}
  .hero__trust{justify-content:center}
  .cards-grid,.cards-grid--3,.why-grid,.cats-grid{grid-template-columns:repeat(2,1fr)}
  .review-card{flex-basis:calc((100% - 24px) / 2)}
  .process-grid{grid-template-columns:repeat(2,1fr);row-gap:34px}
  .process-line{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .content-layout{grid-template-columns:1fr}
  .sidebar{order:2}
}

@media(max-width:768px){
  .topbar__info li:first-child{display:none}
  .navbar__menu{position:fixed;inset:0 auto 0 0;top:0;height:100dvh;width:84%;max-width:330px;background:#fff;transform:translateX(-105%);transition:transform var(--t);z-index:1000;padding:80px 16px 24px;overflow-y:auto;box-shadow:8px 0 40px rgba(0,0,0,.2)}
  body.nav-open .navbar__menu{transform:none}
  body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(10,35,71,.5);z-index:950}
  .menu{flex-direction:column;align-items:stretch;gap:2px}
  .menu>li>a{justify-content:space-between;font-size:16px;padding:14px 12px;border-bottom:1px solid var(--line)}
  .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;max-height:0;overflow:hidden;padding:0;transition:max-height var(--t)}
  .menu li.open>.sub-menu{max-height:600px;padding:4px 0 8px}
  .menu .caret{transition:transform var(--t)}
  .menu li.open>a .caret{transform:rotate(180deg)}
  .nav-toggle{display:flex}
  .navbar__actions .btn span{display:none}
  .navbar__actions .btn{padding:11px;border-radius:50%}
  .navbar__actions .btn i{font-size:19px}

  .hero{padding:54px 0 80px}
  .hero__features{grid-template-columns:repeat(2,1fr)}
  .hero__sub{font-size:15.5px}
  .hero__orbit{transform:scale(.66)}
  .hero__chip,.hero__scroll{display:none}
  .cards-grid,.cards-grid--3,.why-grid,.cats-grid,.stats-grid,.process-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px 12px}
  .cats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-cta__in{flex-direction:column;text-align:center}
  .footer-bottom__in{flex-direction:column;text-align:center}
  .article{padding:20px}
  .article__content{font-size:15.5px}
  .review-card{flex-basis:100%}
}

@media(max-width:420px){
  .stats-grid{grid-template-columns:1fr}
  .brand-logo{height:54px}
  .site-header.is-stuck .brand-logo{height:48px}
  .hero__features{grid-template-columns:1fr 1fr}
  .hero__orbit{transform:scale(.56)}
}

/* ===========================================================================
   Enhancements v1.1 — before/after, mega menu, progress, back-to-top, trust
   =========================================================================== */

/* ---- Scroll progress bar ---- */
#scroll-progress{position:fixed;top:0;inset-inline-start:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold-light));z-index:1100;transition:width .1s linear}

/* ---- Back to top ---- */
#to-top{position:fixed;bottom:22px;inset-inline-start:22px;width:48px;height:48px;border-radius:50%;background:var(--navy);color:var(--gold-light);display:grid;place-items:center;font-size:22px;box-shadow:0 10px 24px rgba(7,26,54,.4);opacity:0;visibility:hidden;transform:translateY(14px);transition:all var(--t);z-index:1000}
#to-top.show{opacity:1;visibility:visible;transform:none}
#to-top:hover{background:var(--gold);color:var(--navy-dark);transform:translateY(-3px)}

/* ---- Mega menu ---- */
.sub-menu.mega{width:min(540px,90vw);display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:12px}
.sub-menu.mega li a{display:flex;align-items:center;gap:10px}
.sub-menu li a .mi{flex-shrink:0;width:34px;height:34px;border-radius:50%;background:var(--surface);color:var(--navy);display:grid;place-items:center;font-size:17px;transition:background var(--t),color var(--t)}
.sub-menu li a:hover .mi{background:var(--gold);color:var(--navy-dark)}

/* ---- Trust band ---- */
.trust-band{position:relative;z-index:6;margin-top:34px;margin-bottom:10px;background:transparent}
.trust-grid{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:#fff;border-radius:var(--radius);box-shadow:0 24px 60px rgba(10,35,71,.16);overflow:hidden}
.trust-grid::before{content:"";position:absolute;top:0;inset-inline:0;height:4px;background:linear-gradient(90deg,var(--navy),var(--gold) 50%,var(--navy))}
.trust-item{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:30px 16px 26px;transition:background var(--t)}
.trust-item:not(:last-child)::after{content:"";position:absolute;inset-inline-start:0;top:24%;height:52%;width:1px;background:var(--line)}
.trust-item:hover{background:linear-gradient(180deg,rgba(201,162,75,.08),transparent)}
.trust-item__icon{flex-shrink:0;width:62px;height:62px;border-radius:50%;display:grid;place-items:center;font-size:30px;background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:var(--gold-light);position:relative;transition:transform var(--t),box-shadow var(--t)}
.trust-item__icon::before{content:"";position:absolute;inset:-4px;border-radius:50%;border:1.5px dashed rgba(201,162,75,.45);opacity:0;transition:opacity var(--t),transform .5s ease}
.trust-item:hover .trust-item__icon{transform:translateY(-4px) scale(1.06);box-shadow:0 12px 26px rgba(10,35,71,.3)}
.trust-item:hover .trust-item__icon::before{opacity:1;transform:rotate(90deg)}
.trust-item__t{font-family:var(--ff-head);font-weight:700;color:var(--navy-dark);font-size:16px;line-height:1.35}
.trust-item__t b{color:var(--gold-dark)}
.trust-item__s{font-size:13px;color:var(--text-muted)}
/* stagger reveal */
.js .trust-item{opacity:0;transform:translateY(18px);animation:heroIn .6s ease forwards}
.js .trust-item:nth-child(1){animation-delay:.05s}.js .trust-item:nth-child(2){animation-delay:.14s}
.js .trust-item:nth-child(3){animation-delay:.23s}.js .trust-item:nth-child(4){animation-delay:.32s}
.js .trust-item:nth-child(5){animation-delay:.41s}

/* ---- Before / After slider ---- */
.ba{position:relative;max-width:960px;margin:0 auto;aspect-ratio:1200/648;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);user-select:none;touch-action:pan-y;cursor:ew-resize;--pos:50%}
.ba__img{position:absolute;inset:0}
.ba__img img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba__img--before{clip-path:inset(0 0 0 var(--pos))}
.ba__tag{position:absolute;top:14px;padding:5px 14px;border-radius:var(--pill);font-family:var(--ff-head);font-weight:700;font-size:13px;color:#fff;backdrop-filter:blur(4px)}
.ba__tag--before{inset-inline-start:14px;background:rgba(10,35,71,.78)}
.ba__tag--after{inset-inline-end:14px;background:rgba(201,162,75,.92);color:var(--navy-dark)}
.ba__handle{position:absolute;top:0;bottom:0;left:var(--pos);transform:translateX(-50%);width:44px;display:grid;place-items:center;cursor:ew-resize}
.ba__line{position:absolute;top:0;bottom:0;width:3px;background:#fff;box-shadow:0 0 12px rgba(0,0,0,.4)}
.ba__grip{position:relative;width:46px;height:46px;border-radius:50%;background:#fff;color:var(--navy);display:grid;place-items:center;font-size:22px;box-shadow:0 6px 18px rgba(0,0,0,.35)}
.ba__handle:focus-visible{outline:none}
.ba__handle:focus-visible .ba__grip{outline:3px solid var(--gold)}
.ba__range{position:absolute;inset:0;width:100%;height:100%;opacity:0;margin:0;pointer-events:none}

/* ---- Testimonials controls ---- */
.reviews-wrap{position:relative}
.reviews-nav{display:flex;justify-content:center;gap:10px;margin-top:18px}
.reviews-nav button{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--navy);font-size:20px;display:grid;place-items:center;transition:all var(--t)}
.reviews-nav button:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

@media(max-width:768px){
  .trust-band{margin-top:20px}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .trust-item{padding:22px 12px}
  .trust-item::after{display:none}
  .trust-item:not(:nth-last-child(-n+1))::before{content:"";position:absolute;bottom:0;inset-inline:14%;height:1px;background:var(--line)}
  .trust-item:nth-child(5){grid-column:1 / -1}
  .trust-item__icon{width:54px;height:54px;font-size:26px}
  .ba__grip{width:40px;height:40px;font-size:19px}
}
@media(max-width:420px){
  .trust-grid{grid-template-columns:1fr 1fr}
}

/* ===========================================================================
   Polish v1.2 — image overlays, gallery, dividers, watermark, preloader, header
   =========================================================================== */

/* ---- Service/post image overlay (hides baked-in banners, unifies look) ---- */
.service-card__media img,.post-card__media img{object-position:center 22%}
.service-card__media::after,.post-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,35,71,0) 30%,rgba(10,35,71,.55) 52%,rgba(7,26,54,.92) 78%,rgba(7,26,54,.98) 100%);z-index:1;pointer-events:none;transition:opacity var(--t)}
.service-card:hover .service-card__media::after,.post-card:hover .post-card__media::after{opacity:.92}
.service-card__icon{z-index:2}

/* ---- Section title accent (ornamental divider: line — diamond — line) ---- */
.section-head h2{position:relative;display:inline-block;padding-bottom:22px}
.section-head h2::after{content:"";position:absolute;bottom:8px;inset-inline-start:50%;transform:translateX(50%);width:150px;height:2px;background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold) 70%,transparent)}
.section-head h2::before{content:"";position:absolute;bottom:3px;inset-inline-start:50%;transform:translateX(50%) rotate(45deg);width:12px;height:12px;background:var(--gold);border-radius:2px;box-shadow:0 0 0 4px var(--bg),0 0 0 5px rgba(201,162,75,.4)}
.bg-soft .section-head h2::before{box-shadow:0 0 0 4px var(--surface),0 0 0 5px rgba(201,162,75,.4)}

/* ---- Brand watermark in sections ---- */
.section{position:relative}
.section--watermark::before{content:"";position:absolute;top:50%;inset-inline-end:-60px;transform:translateY(-50%);width:340px;height:340px;background:url(../img/logo.webp) no-repeat center/contain;opacity:.04;pointer-events:none;filter:grayscale(1)}

/* ---- Section divider (wave) ---- */
.divider{line-height:0;margin:0;overflow:hidden}
.divider svg{display:block;width:100%;height:60px}

/* ---- Gallery ---- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:220px;gap:16px}
.gallery-item{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm)}
.gallery-item--tall{grid-row:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item figcaption{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:space-between;gap:8px;padding:16px;color:#fff;font-family:var(--ff-head);font-weight:700;font-size:15px;background:linear-gradient(180deg,transparent 45%,rgba(7,26,54,.82));opacity:0;transform:translateY(10px);transition:all var(--t)}
.gallery-item:hover figcaption{opacity:1;transform:none}
.gallery-item figcaption i{width:36px;height:36px;border-radius:50%;background:var(--gold);color:var(--navy-dark);display:grid;place-items:center;font-size:18px;flex-shrink:0}

/* ---- Lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(7,18,38,.92);display:none;align-items:center;justify-content:center;padding:40px;backdrop-filter:blur(6px)}
.lightbox.open{display:flex;animation:lbFade .25s ease}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lightbox__stage{margin:0;max-width:1000px;width:100%;text-align:center}
.lightbox__stage img{max-width:100%;max-height:78vh;border-radius:var(--radius);box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__stage figcaption{color:#e8eef6;font-family:var(--ff-head);font-weight:700;margin-top:16px;font-size:17px}
.lightbox__close{position:absolute;top:22px;inset-inline-end:26px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:24px;display:grid;place-items:center;transition:background var(--t)}
.lightbox__close:hover{background:var(--gold);color:var(--navy-dark)}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:26px;display:grid;place-items:center;transition:background var(--t)}
.lightbox__nav:hover{background:var(--gold);color:var(--navy-dark)}
.lightbox__prev{inset-inline-end:24px}.lightbox__next{inset-inline-start:24px}

/* ---- Preloader ---- */
#preloader{position:fixed;inset:0;z-index:3000;background:var(--navy-darker);display:grid;place-items:center;transition:opacity .5s ease,visibility .5s ease}
#preloader.done{opacity:0;visibility:hidden}
.preloader__box{display:grid;place-items:center;gap:20px}
.preloader__box img{width:120px;height:auto;animation:plPulse 1.6s ease-in-out infinite}
.preloader__ring{width:54px;height:54px;border-radius:50%;border:3px solid rgba(201,162,75,.25);border-top-color:var(--gold);animation:spin .9s linear infinite}
@keyframes plPulse{50%{transform:scale(1.08);opacity:.85}}

/* ---- Header: animated underline + search ---- */
.menu>li>a{position:relative}
.menu>li>a::after{content:"";position:absolute;bottom:6px;inset-inline-start:14px;inset-inline-end:14px;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:center;transition:transform var(--t)}
.menu>li:hover>a::after,.menu>li.current-menu-item>a::after{transform:scaleX(1)}
.nav-search{width:44px;height:44px;border-radius:10px;background:var(--surface);color:var(--navy);display:grid;place-items:center;font-size:20px;transition:background var(--t),color var(--t)}
.nav-search:hover{background:var(--gold);color:var(--navy-dark)}
.search-overlay{position:fixed;inset:0;z-index:1500;background:rgba(7,18,38,.92);display:none;align-items:flex-start;justify-content:center;padding-top:18vh;backdrop-filter:blur(6px)}
.search-overlay.open{display:flex;animation:lbFade .25s ease}
.search-overlay__inner{width:min(620px,90vw)}
.search-overlay form{display:flex;gap:10px}
.search-overlay input{flex:1;height:60px;border:0;border-radius:14px;padding:0 20px;font-size:19px;font-family:var(--ff-body)}
.search-overlay button[type=submit]{width:60px;height:60px;border-radius:14px;background:var(--gold);color:var(--navy-dark);font-size:24px;display:grid;place-items:center}
.search-overlay__close{position:absolute;top:24px;inset-inline-end:28px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:24px;display:grid;place-items:center}

/* ---- Button ripple ---- */
.btn{position:relative;overflow:hidden}
.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.45);transform:translate(-50%,-50%) scale(0);animation:ripple .6s ease-out;pointer-events:none}
@keyframes ripple{to{transform:translate(-50%,-50%) scale(18);opacity:0}}

/* ---- Card tilt ---- */
.cards-grid{perspective:1000px}
.service-card,.post-card{transform-style:preserve-3d;will-change:transform}

@media(max-width:1024px){
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px;gap:10px}
  .gallery-item--tall{grid-row:span 2}
  .section--watermark::before{display:none}
  .lightbox{padding:16px}
  .lightbox__nav{width:44px;height:44px;font-size:22px}
}

/* ===========================================================================
   Service cards — premium redesign v1.3
   =========================================================================== */
.service-card{display:flex;flex-direction:column;border:1px solid var(--line);position:relative}
.service-card::before{content:"";position:absolute;top:0;inset-inline:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));transform:scaleX(0);transform-origin:center;transition:transform .35s ease;z-index:3;border-radius:var(--radius) var(--radius) 0 0}
.service-card:hover::before{transform:scaleX(1)}
.service-card__media{aspect-ratio:4/3}
/* title over image */
.service-card__title-over{position:absolute;inset-inline:18px;bottom:16px;z-index:2;color:#fff;font-size:19px;font-weight:800;line-height:1.4;margin:0;text-shadow:0 2px 10px rgba(0,0,0,.5);transition:transform var(--t)}
.service-card:hover .service-card__title-over{transform:translateY(-2px)}
/* badge top corner */
.service-card__badge{position:absolute;top:16px;inset-inline-end:16px;z-index:2;width:54px;height:54px;border-radius:16px;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.35);color:#fff;display:grid;place-items:center;font-size:26px;transition:background var(--t),color var(--t),transform var(--t)}
.service-card:hover .service-card__badge{background:var(--gold);color:var(--navy-dark);transform:rotate(-8deg) scale(1.08)}
/* body */
.service-card__body{display:flex;flex-direction:column;flex:1;padding:20px 20px 18px;gap:14px}
.service-card__excerpt{color:var(--text-muted);font-size:14.5px;margin:0;flex:1}
.service-card__foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:14px;border-top:1px solid var(--line)}
.service-card__link{display:inline-flex;align-items:center;gap:6px;color:var(--navy);font-family:var(--ff-head);font-weight:700;font-size:14.5px;transition:gap var(--t),color var(--t)}
.service-card__link:hover{color:var(--gold-dark);gap:10px}
.service-card__call{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-size:19px;background:var(--surface);color:var(--navy);transition:background var(--t),color var(--t),transform var(--t)}
.service-card__call:hover{background:var(--gold);color:var(--navy-dark);transform:translateY(-3px)}
@media(max-width:768px){
  .service-card__media{aspect-ratio:16/10}
  .service-card__title-over{font-size:18px}
}

/* ---- Footer tidy v1.4 ---- */
.footer-socials--top{margin-top:18px}
.footer-bottom__links a{color:#9fb0c8;transition:color var(--t)}
.footer-bottom__links a:hover{color:var(--gold-light)}

/* ---- Manual Table of Contents (v1.5) ---- */
.toc{background:linear-gradient(180deg,var(--surface),#fff);border:1px solid var(--line);border-inline-start:4px solid var(--gold);border-radius:var(--radius);margin:0 0 28px;overflow:hidden}
.toc__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px;padding:16px 20px;background:transparent;cursor:pointer}
.toc__title{display:inline-flex;align-items:center;gap:9px;font-family:var(--ff-head);font-weight:800;font-size:16.5px;color:var(--navy-dark)}
.toc__title i{color:var(--gold-dark);font-size:20px}
.toc__caret{font-size:20px;color:var(--navy);transition:transform var(--t)}
.toc.is-collapsed .toc__caret{transform:rotate(-90deg)}
.toc__list{list-style:none;margin:0;padding:0 20px 18px;max-height:1500px;overflow:hidden;transition:max-height .4s ease,padding .4s ease,opacity .3s ease;counter-reset:toc}
.toc.is-collapsed .toc__list{max-height:0;padding-top:0;padding-bottom:0;opacity:0}
.toc__item{margin:0}
.toc__item a{display:flex;gap:10px;align-items:flex-start;padding:8px 0;color:var(--text);font-size:15px;border-bottom:1px dashed var(--line);transition:color var(--t),padding var(--t)}
.toc__item a::before{counter-increment:toc;content:counter(toc);flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--surface);color:var(--gold-dark);font-family:var(--ff-head);font-weight:700;font-size:12px;display:grid;place-items:center;transition:background var(--t),color var(--t)}
.toc__item a:hover{color:var(--gold-dark);padding-inline-start:6px}
.toc__item a:hover::before{background:var(--gold);color:var(--navy-dark)}
.toc__item--h3 a{padding-inline-start:30px;font-size:14px;color:var(--text-muted)}
.toc__item--h3 a::before{width:8px;height:8px;background:var(--gold);content:"";counter-increment:none;margin-top:8px}
/* offset anchor targets so the sticky header doesn't cover them */
.article__content h2[id],.article__content h3[id]{scroll-margin-top:110px}
