/*
Theme Name: Dakfa Konstruksi
Theme URI: https://dakfakonstruksi.com
Author: Malakatech
Author URI: https://malakatech.com
Description: Tema WordPress untuk perusahaan jasa konstruksi, instalasi listrik, dan renovasi. Dilengkapi hero slider parallax, section layanan, testimoni, portofolio, area layanan, dan CTA WhatsApp. Semua bagian dapat dikustomisasi lewat Customizer.
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dakfa
Tags: business, construction, one-column, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, translation-ready
*/

/* =========================================================
   VARIABEL — nilai default; sebagian ditimpa oleh Customizer
   (lihat output di header.php via :root inline)
   ========================================================= */
:root{
  --navy:#0f1826;
  --navy2:#16233a;
  --navy3:#1e2f4d;
  --amber:#f5a623;
  --gold:#f7b32b;
  --sky:#eef2f7;
  --slate:#5a6a80;
  --white:#ffffff;
  --ink:#111a28;
  --line:rgba(15,24,38,.12);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Sora',system-ui,sans-serif;background:var(--white);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,.display{font-family:'Archivo',system-ui,sans-serif;letter-spacing:-.02em;line-height:1.02}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.bg-cream{background:var(--sky)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ---- Skip link ---- */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--amber);color:var(--navy);padding:10px 16px;z-index:100;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ---- Topbar ---- */
.topbar{background:var(--navy);color:rgba(238,242,247,.85);font-size:.82rem;border-bottom:1px solid rgba(255,255,255,.06)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:42px;gap:20px}
.topbar-left{display:flex;gap:22px;flex-wrap:wrap}
.topbar-left span{display:inline-flex;align-items:center;gap:7px}
.topbar-left svg{width:14px;height:14px;stroke:var(--amber)}
.topbar-social{display:flex;gap:14px}
.topbar-social a{display:inline-flex;color:rgba(238,242,247,.75);transition:color .15s}
.topbar-social a:hover{color:var(--amber)}
.topbar-social svg{width:15px;height:15px;fill:currentColor}

/* ---- Nav ---- */
header.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Archivo';font-weight:800;font-size:1.15rem;color:var(--navy)}
.brand img{max-height:46px;width:auto}
.mark{width:38px;height:38px;border-radius:9px;background:linear-gradient(150deg,var(--gold),var(--amber));display:grid;place-items:center;box-shadow:0 4px 14px rgba(245,166,35,.35)}
.mark svg{width:22px;height:22px}
.brand-text small{display:block;font-size:.62rem;letter-spacing:.22em;color:var(--amber);font-weight:700;margin-top:2px}
.navlinks{display:flex;gap:28px;font-size:.94rem;font-weight:500;color:var(--navy);list-style:none;margin:0;padding:0}
.navlinks li{list-style:none;position:relative}
.navlinks li::marker{content:none}
.navlinks a{position:relative;display:block;padding:4px 0}
.navlinks a:hover,.navlinks .current-menu-item > a{color:var(--amber)}
/* parent dengan submenu: beri panah kecil */
.navlinks .menu-item-has-children > a::after{content:"";display:inline-block;width:7px;height:7px;margin-left:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.7}
/* submenu dropdown */
.navlinks ul.sub-menu{list-style:none;margin:0;padding:8px;position:absolute;top:100%;left:0;min-width:220px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 40px rgba(15,24,38,.14);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .18s,transform .18s,visibility .18s;z-index:60}
.navlinks li:hover > ul.sub-menu,.navlinks li:focus-within > ul.sub-menu{opacity:1;visibility:visible;transform:translateY(6px)}
.navlinks ul.sub-menu li{margin:0}
.navlinks ul.sub-menu a{padding:9px 12px;border-radius:8px;font-weight:500;color:var(--navy);white-space:nowrap}
.navlinks ul.sub-menu a:hover{background:var(--sky);color:var(--amber)}
/* submenu tingkat 2 (opsional) */
.navlinks ul.sub-menu ul.sub-menu{top:0;left:100%;transform:translateX(8px)}
.navlinks ul.sub-menu li:hover > ul.sub-menu{transform:translateX(6px)}
.navcta{display:inline-flex;align-items:center;gap:8px;background:var(--amber);color:var(--navy);padding:11px 20px;border-radius:9px;font-weight:700;font-size:.9rem;transition:transform .15s,background .15s}
.navcta:hover{transform:translateY(-1px);background:var(--gold)}
.menutoggle{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:9px;cursor:pointer}

/* ---- Hero Slider (parallax) ---- */
.hslider{position:relative;width:100%;height:clamp(360px,64vh,660px);overflow:hidden;background:var(--navy)}
.hslides{position:absolute;inset:0}
.hslide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1s ease;overflow:hidden}
.hslide.active{opacity:1;visibility:visible;z-index:1}
.hslide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,24,38,.28),rgba(15,24,38,.12) 40%,rgba(15,24,38,.34))}
.hslide img{position:absolute;top:-6%;left:-6%;width:112%;height:112%;object-fit:cover;transform:scale(1.12) translate3d(0,0,0);will-change:transform;transition:transform 6s ease-out}
.hslide.active img{transform:scale(1) translate3d(0,-2%,0)}
.hslide:nth-child(even).active img{transform:scale(1) translate3d(-2%,0,0)}
.hs-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:52px;height:52px;border-radius:50%;background:rgba(15,24,38,.4);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;cursor:pointer;transition:background .2s,transform .15s}
.hs-arrow:hover{background:var(--amber);transform:translateY(-50%) scale(1.05)}
.hs-arrow svg{width:22px;height:22px;stroke:#fff}
.hs-arrow:hover svg{stroke:var(--navy)}
.hs-prev{left:22px}.hs-next{right:22px}
.hs-dots{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;display:flex;gap:10px}
.hs-dot{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.45);border:none;cursor:pointer;transition:background .2s,width .2s}
.hs-dot.active{background:var(--amber);width:30px;border-radius:6px}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;background:radial-gradient(1100px 480px at 88% -12%, rgba(247,179,43,.14), transparent 60%),linear-gradient(180deg,var(--white),var(--sky))}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding:78px 0 88px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-bottom:22px}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--amber)}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.15rem);font-weight:800;color:var(--navy)}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero p.lead{margin:24px 0 32px;font-size:1.12rem;color:var(--slate);max-width:34ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--amber);color:var(--navy);font-weight:700;padding:15px 26px;border-radius:11px;box-shadow:0 10px 26px rgba(245,166,35,.32);transition:transform .15s,box-shadow .15s,background .15s}
.btn-primary:hover{transform:translateY(-2px);background:var(--gold);box-shadow:0 16px 34px rgba(245,166,35,.4)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;border:1.5px solid var(--slate);color:var(--navy);font-weight:600;padding:15px 24px;border-radius:11px;transition:background .15s}
.btn-ghost:hover{background:rgba(90,106,128,.08)}
.hero-card{position:relative;background:var(--navy);border-radius:20px;padding:34px 30px;color:var(--sky);box-shadow:0 24px 60px rgba(15,24,38,.3);overflow:hidden}
.hero-card::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;background:radial-gradient(circle,var(--gold),transparent 70%);opacity:.3}
.hero-card h3{font-size:1.15rem;color:var(--gold);margin-bottom:6px}
.hero-card .sub{font-size:.86rem;color:rgba(238,242,247,.6);margin-bottom:22px}
.quickrow{display:flex;align-items:center;gap:14px;padding:13px 0;border-top:1px solid rgba(238,242,247,.12)}
.quickrow:first-of-type{border-top:none}
.qi{width:38px;height:38px;border-radius:9px;background:rgba(247,179,43,.14);display:grid;place-items:center;flex-shrink:0}
.qi svg{width:19px;height:19px;stroke:var(--gold)}
.quickrow span{font-size:.94rem}
.stats{display:flex;gap:34px;margin-top:44px}
.stat b{display:block;font-family:'Archivo';font-size:1.9rem;font-weight:800;color:var(--navy)}
.stat small{color:var(--amber);font-size:.82rem;font-weight:500}

/* ---- Section head ---- */
.sec-head{max-width:640px;margin-bottom:52px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head .eyebrow{margin-bottom:16px}
.sec-head h2{font-size:clamp(2rem,4vw,2.9rem);font-weight:800;color:var(--navy)}
.sec-head p{margin-top:14px;color:var(--slate);font-size:1.05rem}

/* ---- Promo countdown ---- */
.promo{background:linear-gradient(155deg,var(--navy),var(--navy2));color:var(--sky);position:relative;overflow:hidden}
.promo::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 90% 10%,rgba(247,179,43,.16),transparent 60%)}
.promo .wrap{padding:72px 24px;position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}
.promo .tag{display:inline-block;background:rgba(247,179,43,.16);color:var(--gold);font-weight:600;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:7px 14px;border-radius:50px;margin-bottom:18px}
.promo h2{font-size:clamp(1.9rem,3.8vw,2.8rem);color:#fff;font-weight:800}
.promo h2 em{font-style:normal;color:var(--gold)}
.promo p{margin-top:14px;color:rgba(238,242,247,.75);max-width:40ch}
.countdown{display:flex;gap:14px;flex-wrap:wrap}
.cd-box{background:rgba(255,255,255,.06);border:1px solid rgba(247,179,43,.25);border-radius:14px;padding:20px 8px;text-align:center;min-width:88px;flex:1}
.cd-box b{display:block;font-family:'Archivo';font-size:2.6rem;font-weight:800;color:var(--gold);line-height:1}
.cd-box small{display:block;margin-top:8px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(238,242,247,.65)}
.promo .btn-primary{margin-top:26px}

/* ---- Services ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{position:relative;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .18s,box-shadow .18s,border-color .18s}
.svc:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(15,24,38,.1);border-color:rgba(245,166,35,.4)}
.svc-cover{position:relative;aspect-ratio:16/10;overflow:hidden}
.svc-cover img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.svc:hover .svc-cover img{transform:scale(1.06)}
.svc .num{position:absolute;top:12px;left:12px;z-index:2;font-family:'Archivo';font-weight:700;font-size:.78rem;color:var(--navy);background:var(--gold);padding:5px 10px;border-radius:7px;letter-spacing:.05em;box-shadow:0 3px 10px rgba(0,0,0,.18)}
.svc-body{display:flex;flex-direction:column;flex:1;padding:22px 24px 24px}
.svc h3{font-size:1.16rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.svc p{font-size:.92rem;color:var(--slate);flex:1}
.svc-btns{display:flex;gap:10px;margin-top:20px}
.sb{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:.85rem;font-weight:600;padding:11px 10px;border-radius:9px;transition:transform .15s,background .15s}
.sb-detail{border:1.5px solid var(--line);color:var(--slate)}
.sb-detail:hover{background:var(--sky);transform:translateY(-1px)}
.sb-wa{background:#25D366;color:#fff}
.sb-wa:hover{background:#1eb857;transform:translateY(-1px)}
.sb svg{width:15px;height:15px}

/* ---- Testimoni ---- */
.testi-track{position:relative;overflow:hidden;border-radius:20px}
.testi-slides{display:flex;transition:transform .5s ease}
.testi{min-width:100%;padding:8px}
.testi-inner{background:var(--white);border:1px solid var(--line);border-radius:18px;padding:44px 46px;box-shadow:0 14px 40px rgba(15,24,38,.06);max-width:820px;margin:0 auto}
.stars{color:var(--amber);font-size:1.05rem;letter-spacing:2px;margin-bottom:16px}
.testi blockquote{font-family:'Archivo';font-size:1.35rem;font-weight:600;color:var(--navy);line-height:1.4}
.testi .who{display:flex;align-items:center;gap:14px;margin-top:24px}
.avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(150deg,var(--gold),var(--amber));display:grid;place-items:center;font-family:'Archivo';font-weight:700;color:var(--navy)}
.who b{display:block;color:var(--navy);font-size:.98rem}
.who small{color:var(--amber);font-size:.85rem}
.testi-nav{display:flex;justify-content:center;align-items:center;gap:18px;margin-top:28px}
.tn-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line);background:var(--white);display:grid;place-items:center;cursor:pointer;transition:background .15s,border-color .15s}
.tn-btn:hover{background:var(--sky);border-color:var(--amber)}
.tn-btn svg{width:18px;height:18px;stroke:var(--navy)}
.dots{display:flex;gap:8px}
.dot{width:9px;height:9px;border-radius:50%;background:var(--line);cursor:pointer;transition:background .2s,width .2s}
.dot.active{background:var(--amber);width:26px;border-radius:5px}

/* ---- Gallery ---- */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px}
.gal{position:relative;border-radius:14px;overflow:hidden;cursor:pointer}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gal:hover img{transform:scale(1.08)}
.gal .cap{position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,24,38,.82),transparent 55%);display:flex;align-items:flex-end;padding:16px;opacity:0;transition:opacity .3s}
.gal:hover .cap{opacity:1}
.gal .cap span{color:#fff;font-weight:600;font-size:.95rem}
.gal.wide{grid-column:span 2}
.gal.tall{grid-row:span 2}

/* ---- Coverage ---- */
.coverage{background:linear-gradient(160deg,var(--sky),var(--white))}
.cov-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.cov-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:28px}
.cov-item{display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--line);border-radius:12px;padding:15px 18px;font-weight:600;color:var(--navy)}
.cov-item .pin{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--gold),var(--amber));display:grid;place-items:center;flex-shrink:0}
.cov-item .pin svg{width:17px;height:17px;stroke:var(--navy)}
.cov-map{background:var(--navy);border-radius:20px;padding:40px;color:var(--sky);position:relative;overflow:hidden;min-height:320px;display:flex;flex-direction:column;justify-content:center}
.cov-map::after{content:"";position:absolute;right:-30px;bottom:-30px;width:200px;height:200px;background:radial-gradient(circle,var(--gold),transparent 70%);opacity:.24}
.cov-map h3{color:var(--gold);font-size:1.4rem;margin-bottom:12px}
.cov-map p{color:rgba(238,242,247,.75)}
.cov-map .big{font-family:'Archivo';font-size:3.4rem;font-weight:800;color:#fff;margin:18px 0 4px;line-height:1}

/* ---- CTA ---- */
.cta-box{background:linear-gradient(150deg,var(--gold),var(--amber));border-radius:22px;padding:54px 44px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;box-shadow:0 20px 50px rgba(245,166,35,.3)}
.cta-box h2{font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:800;color:var(--navy);max-width:16ch}
.cta-box p{color:var(--navy);opacity:.75;margin-top:8px;font-weight:500}
.cta-wa{display:inline-flex;align-items:center;gap:12px;background:var(--navy);color:var(--gold);font-weight:700;font-size:1.05rem;padding:18px 30px;border-radius:13px;transition:transform .15s}
.cta-wa:hover{transform:translateY(-2px)}
.cta-wa svg{width:24px;height:24px;fill:var(--gold)}

/* ---- Footer ---- */
footer.site-footer{background:var(--navy);color:rgba(238,242,247,.65);padding:52px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;margin-bottom:34px}
.foot-grid .brand{color:var(--gold)}
.foot-grid strong{display:block;margin-bottom:14px;font-size:.95rem;color:var(--gold);font-family:'Archivo'}
.foot-links{display:flex;flex-direction:column}
.foot-links a{margin-top:8px;color:rgba(238,242,247,.7);font-size:.94rem;transition:color .15s}
.foot-links a:hover{color:var(--gold)}
.site-footer .contact a{display:flex;align-items:center;gap:9px;margin-top:8px;color:rgba(238,242,247,.75);transition:color .15s}
.site-footer .contact a:hover{color:var(--gold)}
.site-footer .contact svg{width:17px;height:17px;stroke:var(--gold)}
.foot-bottom{border-top:1px solid rgba(238,242,247,.12);padding-top:20px;font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---- Floating WA ---- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;font-weight:600;padding:14px 20px;border-radius:50px;box-shadow:0 10px 30px rgba(37,211,102,.45);transition:transform .15s}
.wa-float:hover{transform:scale(1.04)}
.wa-float svg{width:24px;height:24px;fill:#fff}

/* ---- Page template ---- */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--navy),var(--navy2));color:var(--sky)}
.page-hero__bg{position:absolute;inset:0;background:radial-gradient(700px 320px at 88% -10%, rgba(247,179,43,.18), transparent 60%),radial-gradient(500px 260px at 5% 120%, rgba(245,166,35,.14), transparent 60%)}
.page-hero__inner{position:relative;padding:64px 24px 66px}
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:.86rem;color:rgba(238,242,247,.7);margin-bottom:22px}
.breadcrumb a{color:rgba(238,242,247,.85);transition:color .15s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .sep{display:inline-flex;width:15px;height:15px;color:rgba(238,242,247,.45)}
.breadcrumb .sep svg{width:100%;height:100%}
.breadcrumb .current{color:var(--gold);font-weight:600}
.page-hero__eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.76rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.page-hero__eyebrow::before{content:"";width:28px;height:2px;background:var(--amber)}
.page-hero__title{font-family:'Archivo';font-weight:800;line-height:1.05;font-size:clamp(2.1rem,4.6vw,3.4rem);color:#fff}
.page-hero__lead{margin-top:16px;max-width:60ch;color:rgba(238,242,247,.78);font-size:1.08rem}
.page-body{background:var(--white);padding:70px 0}
.page-content{max-width:820px;margin:0 auto}
.page-content__thumb{margin:0 0 34px;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.entry-content{color:var(--ink);font-size:1.06rem;line-height:1.75}
.entry-content > *{margin-bottom:1.25em}
.entry-content > *:last-child{margin-bottom:0}
.entry-content h2{font-family:'Archivo';font-weight:800;font-size:1.7rem;color:var(--navy);margin:1.6em 0 .6em}
.entry-content h3{font-family:'Archivo';font-weight:700;font-size:1.32rem;color:var(--navy);margin:1.4em 0 .5em}
.entry-content a{color:var(--amber);text-decoration:underline;text-underline-offset:2px}
.entry-content a:hover{color:var(--gold)}
.entry-content ul,.entry-content ol{padding-left:1.4em}
.entry-content li{margin-bottom:.5em}
.entry-content ul li::marker{color:var(--amber)}
.entry-content blockquote{margin:1.6em 0;padding:18px 24px;border-left:4px solid var(--amber);background:var(--sky);border-radius:0 12px 12px 0;color:var(--slate);font-style:italic}
.entry-content img{border-radius:12px}
.entry-content table{width:100%;border-collapse:collapse;font-size:.96rem}
.entry-content th,.entry-content td{padding:12px 14px;border:1px solid var(--line);text-align:left}
.entry-content th{background:var(--sky);color:var(--navy);font-family:'Archivo'}
.page-cta{background:linear-gradient(160deg,var(--sky),var(--white));padding:0 0 84px}
.page-cta__box{background:linear-gradient(150deg,var(--gold),var(--amber));border-radius:22px;padding:52px 46px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;box-shadow:0 20px 50px rgba(245,166,35,.3)}
.page-cta__eyebrow{display:inline-block;font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);opacity:.7;margin-bottom:10px}
.page-cta__text h2{font-family:'Archivo';font-weight:800;font-size:clamp(1.6rem,3.2vw,2.3rem);color:var(--navy);max-width:20ch;line-height:1.1}
.page-cta__text p{margin-top:10px;color:var(--navy);opacity:.8;font-weight:500;max-width:44ch}
.page-cta__actions{display:flex;gap:14px;flex-wrap:wrap}
.btn-wa{display:inline-flex;align-items:center;gap:11px;background:var(--navy);color:var(--gold);font-weight:700;font-size:1.02rem;padding:16px 26px;border-radius:12px;transition:transform .15s,background .15s}
.btn-wa:hover{transform:translateY(-2px);background:var(--navy2)}
.btn-wa svg{width:22px;height:22px}
.btn-outline{display:inline-flex;align-items:center;gap:10px;border:1.5px solid var(--navy);color:var(--navy);font-weight:600;padding:16px 24px;border-radius:12px;transition:background .15s}
.btn-outline:hover{background:rgba(15,24,38,.08)}

/* ---- Blog / archive ---- */
.post-list{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .18s,box-shadow .18s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(15,24,38,.1)}
.post-card__thumb{aspect-ratio:16/9;overflow:hidden}
.post-card__thumb img{width:100%;height:100%;object-fit:cover}
.post-card__body{padding:22px 22px 26px}
.post-card__meta{font-size:.8rem;color:var(--amber);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.post-card h3{font-size:1.2rem;color:var(--navy);margin:8px 0 10px}
.post-card p{color:var(--slate);font-size:.94rem}
.post-card__more{display:inline-block;margin-top:12px;font-weight:600;font-size:.9rem;color:var(--amber)}
.post-card__more:hover{color:var(--gold)}
.dakfa-articles__all{text-align:center;margin-top:40px}

/* ---- Artikel Slider ---- */
.dakfa-artikel-slider{position:relative}
.da-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:26px;scroll-behavior:smooth;padding-bottom:6px;-ms-overflow-style:none;scrollbar-width:none}
.da-track::-webkit-scrollbar{display:none}
.da-slide{flex:0 0 calc((100% - 52px) / 3);scroll-snap-align:start}
.da-slide .post-card{height:100%;display:flex;flex-direction:column}
.da-slide .post-card__thumb{display:block;aspect-ratio:16/10;overflow:hidden}
.da-slide .post-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.da-slide .post-card:hover .post-card__thumb img{transform:scale(1.06)}
.da-slide .post-card__body{display:flex;flex-direction:column;flex:1}
.da-slide .post-card__body p{flex:1}
.da-arrow{position:absolute;top:38%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:0 8px 22px rgba(15,24,38,.14);display:grid;place-items:center;cursor:pointer;transition:background .18s,transform .15s,opacity .18s}
.da-arrow:hover{background:var(--amber);transform:translateY(-50%) scale(1.06)}
.da-arrow svg{width:20px;height:20px;stroke:var(--navy)}
.da-arrow:hover svg{stroke:var(--navy)}
.da-arrow[disabled]{opacity:.35;cursor:default;pointer-events:none}
.da-prev{left:-14px}
.da-next{right:-14px}
.da-dots{display:flex;justify-content:center;gap:8px;margin-top:26px}
.da-dots button{width:9px;height:9px;border-radius:50%;background:var(--line);border:none;cursor:pointer;transition:background .2s,width .2s;padding:0}
.da-dots button.active{background:var(--amber);width:26px;border-radius:5px}
@media(max-width:1024px){
  .da-slide{flex-basis:calc((100% - 52px) / 3)}
}
@media(max-width:768px){
  .da-slide{flex-basis:calc((100% - 26px) / 2)}
  .da-prev{left:-6px}.da-next{right:-6px}
}
@media(max-width:520px){
  .da-slide{flex-basis:calc((100% - 26px) / 2)}
}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:44px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border:1px solid var(--line);border-radius:10px;color:var(--navy);font-weight:600}
.pagination .page-numbers.current{background:var(--amber);border-color:var(--amber);color:var(--navy)}
.pagination .page-numbers:hover{border-color:var(--amber)}

/* ---- Widgets in footer (optional) ---- */
.foot-grid .widget{margin-bottom:0}
.foot-grid .widget ul{list-style:none}

/* ---- Responsive ---- */
@media(max-width:900px){
  .hero-grid,.promo .wrap,.cov-grid{grid-template-columns:1fr;gap:36px}
  .hero-grid{padding:56px 0 64px}
  .svc-grid,.post-list{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .navlinks,.navcta{display:none}
  .navlinks.open{display:flex;position:absolute;top:76px;left:0;right:0;flex-direction:column;background:#fff;padding:18px 24px;gap:14px;border-bottom:1px solid var(--line);box-shadow:0 20px 40px rgba(15,24,38,.12)}
  .navlinks.open ul.sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:6px 0 2px 14px;min-width:0;background:transparent}
  .navlinks.open .menu-item-has-children > a::after{float:right;margin-top:6px}
  .menutoggle{display:block}
  .topbar-left{display:none}
}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:560px){
  .svc-grid,.gal-grid,.post-list{grid-template-columns:1fr}
  .gal.wide,.gal.tall{grid-column:auto;grid-row:auto}
  .stats{gap:22px}
  .cta-box,.page-cta__box{padding:38px 26px}
  .testi-inner{padding:32px 26px}
  .testi blockquote{font-size:1.15rem}
  .wa-float span{display:none}
  .cov-list{grid-template-columns:1fr}
}
@media(max-width:480px){.foot-grid{grid-template-columns:1fr}}
