*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#172033;
  --ink-2:#344054;
  --muted:#697586;
  --line:#dde5ef;
  --paper:#ffffff;
  --wash:#f3f7fb;
  --blue:#1769d2;
  --blue-dark:#0d3975;
  --teal:#12a594;
  --amber:#f5a524;
  --green:#22c55e;
  --coral:#ef6a5b;
  --shadow-sm:0 8px 24px rgba(16,32,56,.08);
  --shadow-md:0 18px 48px rgba(16,32,56,.14);
  --radius:8px;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Plus Jakarta Sans',system-ui,Segoe UI,sans-serif;background:var(--wash);color:var(--ink);line-height:1.5;overflow-x:hidden}
a{color:inherit}
img{max-width:100%;display:block}

.topbar{background:#10233f;color:rgba(255,255,255,.86);font-size:.78rem;font-weight:600;display:flex;justify-content:center;gap:28px;padding:8px 5%;flex-wrap:wrap}
.topbar span{display:flex;align-items:center;gap:7px;white-space:nowrap}

nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border-bottom:1px solid rgba(221,229,239,.88);padding:0 5%;display:flex;align-items:center;justify-content:space-between;height:68px;transition:box-shadow .2s,background .2s}
.is-scrolled nav{box-shadow:var(--shadow-sm);background:rgba(255,255,255,.98)}
.nav-brand{display:flex;align-items:center;gap:11px;font-size:1rem;font-weight:800;color:var(--blue-dark);text-decoration:none;min-width:0}
.nav-brand span:last-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-brand .icon{width:40px;height:40px;background:linear-gradient(135deg,var(--blue),var(--teal));border-radius:8px;display:grid;place-items:center;color:#fff;font-size:18px;flex:0 0 auto;transition:transform .25s}
.nav-brand:hover .icon{transform:translateY(-2px) rotate(-4deg)}
.nav-links{display:flex;gap:24px;list-style:none}
.nav-links a{text-decoration:none;font-size:.86rem;font-weight:700;color:var(--ink-2);transition:color .2s}
.nav-links a:hover{color:var(--blue)}
.nav-cta{background:#10233f;color:#fff;border:0;border-radius:8px;padding:10px 16px;font-size:.84rem;font-weight:800;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s;display:flex;align-items:center;gap:7px;text-decoration:none;white-space:nowrap}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(16,35,63,.24);background:var(--blue-dark)}

.hero{position:relative;min-height:72vh;padding:92px 5% 82px;overflow:hidden;display:flex;align-items:center;background:#101828;color:#fff}
.hero-bg{position:absolute;inset:0;background:url('hero-showroom.png') center/cover no-repeat;transform:scale(1.02);animation:slowZoom 14s ease-out both}
.hero-shade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(9,20,38,.92) 0%,rgba(9,20,38,.76) 42%,rgba(9,20,38,.34) 72%,rgba(9,20,38,.18) 100%)}
.hero-inner{position:relative;max-width:680px;animation:fadeUp .75s cubic-bezier(.2,.7,.3,1) both}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);color:#fff;font-size:.78rem;font-weight:800;padding:7px 13px;border-radius:8px;margin-bottom:20px;border:1px solid rgba(255,255,255,.22)}
.hero h1{font-size:3.55rem;line-height:1.03;margin-bottom:18px;font-weight:800;max-width:690px}
.hero p{color:rgba(255,255,255,.9);font-size:1.08rem;line-height:1.75;margin-bottom:30px;max-width:590px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary,.btn-ghost,.btn-secondary{border-radius:8px;padding:13px 20px;font-size:.9rem;font-weight:800;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .15s,box-shadow .2s,background .2s,border-color .2s}
.btn-primary{background:var(--amber);color:#1f2937;border:1px solid rgba(255,255,255,.12)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(245,165,36,.32)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.34)}
.btn-ghost:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}
.hero-stats{display:flex;gap:12px;margin-top:40px;flex-wrap:wrap}
.hero-stats>div{min-width:144px;padding:12px 14px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:rgba(255,255,255,.1);backdrop-filter:blur(10px)}
.stat-num{font-size:1.28rem;font-weight:800;color:#fff;white-space:nowrap}
.stat-label{font-size:.76rem;color:rgba(255,255,255,.68);font-weight:700;margin-top:2px}

section{padding:66px 5%}
.section-light{background:var(--paper)}
.section-kicker{font-size:.74rem;font-weight:800;letter-spacing:1.2px;color:var(--teal);text-transform:uppercase;margin-bottom:10px}
.section-title{font-size:2.05rem;font-weight:800;line-height:1.18;margin-bottom:10px;max-width:780px}
.section-sub{color:var(--muted);font-size:.95rem;line-height:1.7;max-width:620px}

.service-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:30px}
.service-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:20px;box-shadow:0 1px 0 rgba(16,32,56,.03);transition:transform .22s,box-shadow .22s,border-color .22s}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm);border-color:#c8d8eb}
.svc-ico{width:48px;height:48px;border-radius:8px;display:grid;place-items:center;font-size:20px;background:#e9f8f6;color:var(--teal);margin-bottom:15px;transition:transform .25s}
.service-card:hover .svc-ico{transform:translateY(-2px) rotate(-4deg)}
.service-card h3{font-size:1rem;margin-bottom:7px}
.service-card p{font-size:.86rem;color:var(--muted);line-height:1.65}

.katalog-section{background:linear-gradient(180deg,#f8fbff 0%,#edf4fb 100%)}
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:30px 0 16px;position:sticky;top:78px;z-index:20;background:rgba(248,251,255,.88);backdrop-filter:blur(12px);padding:12px;border:1px solid rgba(221,229,239,.82);border-radius:8px;box-shadow:0 10px 28px rgba(16,32,56,.06)}
.search-wrap{flex:1;min-width:250px;position:relative}
.search-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.88rem}
.search-wrap input{width:100%;padding:12px 16px 12px 40px;border:1.5px solid var(--line);border-radius:8px;font-size:.9rem;font-family:inherit;background:#fff;outline:none}
.filter-group{display:flex;gap:8px;flex-wrap:wrap}
.filter-sel{min-height:44px;padding:0 36px 0 13px;border-radius:8px;border:1.5px solid var(--line);background:#fff;font-size:.82rem;font-weight:800;color:var(--ink);font-family:inherit;cursor:pointer;max-width:190px}
.filter-reset{width:44px;height:44px;border-radius:8px;border:1.5px solid var(--line);background:#fff;color:var(--ink-2);cursor:pointer;display:grid;place-items:center;transition:transform .15s,border-color .2s,color .2s}
.filter-reset:hover{transform:translateY(-2px);border-color:var(--blue);color:var(--blue)}
.filter-sel,.search-wrap input{transition:border-color .2s,box-shadow .2s}
.filter-sel:hover,.filter-sel:focus,.search-wrap input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(23,105,210,.1);outline:none}
.catalog-meta-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.katalog-count,.catalog-note{font-size:.84rem;color:var(--muted);font-weight:700}
.catalog-note{display:flex;align-items:center;gap:7px;color:var(--teal)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:18px}
.card{background:#fff;border-radius:8px;border:1px solid var(--line);overflow:hidden;transition:transform .24s cubic-bezier(.2,.7,.3,1),box-shadow .24s,border-color .24s;text-decoration:none;color:inherit;display:flex;flex-direction:column;min-width:0}
.product-card{box-shadow:0 1px 0 rgba(16,32,56,.03)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:#bdd1e8}
.card-img{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#edf6ff,#e8fbf6);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .45s cubic-bezier(.2,.7,.3,1)}
.card:hover .card-img img{transform:scale(1.06)}
.ready-pill{position:absolute;left:10px;top:10px;background:rgba(20,30,48,.86);color:#fff;border:1px solid rgba(255,255,255,.24);border-radius:6px;padding:5px 9px;font-size:.7rem;font-weight:800;display:inline-flex;align-items:center;gap:5px}
.laptop-visual{width:78%;max-width:230px;aspect-ratio:1.42/1;position:relative;display:grid;place-items:center;animation:floatSoft 4.8s ease-in-out infinite}
.laptop-visual::before{content:'';position:absolute;inset:0 7% 19%;border-radius:10px;background:linear-gradient(135deg,#192846,#30486e);box-shadow:inset 0 0 0 4px rgba(255,255,255,.1),0 18px 36px rgba(20,40,70,.24)}
.laptop-visual::after{content:'';position:absolute;left:0;right:0;bottom:0;height:21%;border-radius:6px 6px 12px 12px;background:linear-gradient(180deg,#d9e4ef,#9aaec2);box-shadow:0 12px 22px rgba(28,48,78,.18)}
.laptop-visual span{position:relative;z-index:2;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--amber),#ffd166);color:#24364f;font-size:1.5rem;font-weight:800;box-shadow:0 10px 22px rgba(0,0,0,.2)}
.laptop-visual.large{max-width:390px}
.card-body{padding:15px;display:flex;flex-direction:column;flex:1;min-width:0}
.card-topline{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px}
.card-brand{font-size:.72rem;font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:.7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-code{font-size:.68rem;color:var(--muted);font-weight:800;background:#f3f6fa;border:1px solid var(--line);border-radius:6px;padding:3px 6px;white-space:nowrap}
.card-name{font-size:.94rem;font-weight:800;line-height:1.45;margin-bottom:10px;min-height:2.7em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.spec-chips{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;flex:1}
.spec-chips span{display:flex;align-items:flex-start;gap:7px;font-size:.76rem;color:var(--ink-2);line-height:1.45;background:#f8fafc;border:1px solid #e8eef6;border-radius:7px;padding:6px 8px;min-height:30px}
.spec-chips i{color:var(--teal);margin-top:2px;width:13px;flex:0 0 auto}
.card-footer{display:flex;justify-content:space-between;align-items:center;gap:10px;border-top:1px solid #edf2f7;padding-top:12px}
.card-price{font-size:1rem;font-weight:800;color:var(--blue-dark);line-height:1.2}
.btn-wa{width:38px;height:38px;border-radius:8px;background:#25d366;color:#fff;border:0;display:grid;place-items:center;cursor:pointer;font-size:16px;text-decoration:none;flex:0 0 auto;transition:transform .15s,background .2s,box-shadow .2s}
.btn-wa:hover{background:#128c7e;transform:translateY(-2px);box-shadow:0 10px 24px rgba(37,211,102,.3)}
.card.is-hidden{display:none}
.empty{grid-column:1/-1;text-align:center;padding:58px 20px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:8px;display:flex;flex-direction:column;align-items:center;gap:8px}
.empty i{font-size:2rem;color:var(--coral)}
.empty strong{color:var(--ink);font-size:1.05rem}
.no-result{display:none;margin-top:18px}
.no-result.show{display:flex}

.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:34px;flex-wrap:wrap}
.pagination:empty{display:none}
.pg-btn{min-width:40px;height:40px;padding:0 12px;border:1.5px solid var(--line);background:#fff;color:var(--ink-2);border-radius:8px;font-family:inherit;font-size:.86rem;font-weight:800;cursor:pointer;display:grid;place-items:center;transition:transform .15s,border-color .2s,color .2s,background .2s,box-shadow .2s}
.pg-btn:hover:not(:disabled){border-color:var(--blue);color:var(--blue);transform:translateY(-2px);box-shadow:0 8px 20px rgba(23,105,210,.14)}
.pg-btn.active{background:linear-gradient(135deg,var(--blue),var(--blue-dark));border-color:transparent;color:#fff;box-shadow:0 8px 22px rgba(23,105,210,.32)}
.pg-btn.active:hover{color:#fff;transform:translateY(-2px)}
.pg-btn:disabled{opacity:.4;cursor:not-allowed}
.pg-btn:active:not(:disabled){transform:translateY(0) scale(.95)}
.pg-dots{padding:0 2px;color:var(--muted);font-weight:800;align-self:flex-end}

.cta-banner{background:#10233f;padding:58px 5%;text-align:center;color:#fff}
.cta-banner h2{font-size:2rem;line-height:1.2;margin-bottom:12px;font-weight:800}
.cta-banner p{color:rgba(255,255,255,.78);font-size:.94rem;margin-bottom:24px}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

footer{background:#07172c;color:rgba(255,255,255,.72);padding:42px 5% 24px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand-name{font-size:1.1rem;font-weight:800;color:#fff;margin-bottom:10px}
.footer-desc{font-size:.84rem;line-height:1.7;max-width:330px}
.footer-col h4{color:#fff;font-size:.88rem;font-weight:800;margin-bottom:14px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col li,.footer-col ul a{color:rgba(255,255,255,.67);text-decoration:none;font-size:.84rem}
.footer-col ul a:hover{color:#fff}
.footer-bottom{padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;flex-wrap:wrap;gap:8px}

.floating-wa{position:fixed;bottom:22px;right:22px;z-index:999;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;border:0;display:grid;place-items:center;cursor:pointer;box-shadow:0 12px 30px rgba(37,211,102,.42);text-decoration:none;transition:transform .2s;font-size:27px;animation:pulseRing 2.4s infinite}
.floating-wa:hover{transform:scale(1.08)}

.detail-wrap{max-width:1440px;margin:34px auto 54px;padding:0 4%}
.back-link{display:inline-flex;align-items:center;gap:9px;color:var(--ink-2);text-decoration:none;font-size:.86rem;font-weight:800;margin-bottom:18px;padding:9px 16px 9px 12px;border:1.5px solid var(--line);border-radius:30px;background:var(--paper);box-shadow:var(--shadow-sm);transition:color .2s,border-color .2s,box-shadow .2s,transform .2s}
.back-link i{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--wash);color:var(--blue);font-size:.72rem;transition:transform .2s,background .2s,color .2s}
.back-link:hover{color:var(--blue);border-color:#bcd6f5;box-shadow:0 10px 22px rgba(23,105,210,.16);transform:translateY(-2px)}
.back-link:hover i{background:var(--blue);color:#fff;transform:translateX(-3px)}
.back-link:active{transform:translateY(0) scale(.98)}
.detail-card{background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);box-shadow:var(--shadow-sm);animation:fadeUp .6s both}
.detail-media{background:linear-gradient(135deg,#edf6ff,#e8fbf6);padding:20px;min-width:0;display:flex;flex-direction:column;justify-content:center}
.detail-main-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}
.detail-fallback{background:linear-gradient(135deg,#eff7ff,#e9fbf7)}
.detail-thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.detail-thumbs button{border:2px solid transparent;background:transparent;border-radius:8px;padding:0;cursor:pointer;transition:transform .2s,border-color .2s}
.detail-thumbs button:hover{transform:translateY(-3px)}
.detail-thumbs button.active{border-color:var(--blue)}
.detail-thumbs img{width:68px;height:68px;object-fit:cover;border-radius:6px}
.detail-info{padding:30px;min-width:0}
.badge-ready,.badge-sold{display:inline-flex;align-items:center;gap:6px;font-weight:800;font-size:.76rem;padding:5px 10px;border-radius:6px;margin-bottom:12px}
.badge-ready{background:#dcfce7;color:#15803d}
.badge-sold{background:#fee2e2;color:#b91c1c}
.detail-brand{font-size:.76rem;font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:.8px}
.detail-info h1{font-size:2rem;line-height:1.2;margin:5px 0 12px;font-weight:800}
.detail-price{font-size:1.75rem;font-weight:800;color:var(--blue-dark);margin-bottom:18px}
.detail-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.btn-wa-lg{background:#25d366;color:#fff;border:0;border-radius:8px;padding:13px 18px;font-size:.9rem;font-weight:800;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:transform .15s,box-shadow .2s,background .2s}
.btn-wa-lg:hover{background:#128c7e;transform:translateY(-2px);box-shadow:0 12px 26px rgba(37,211,102,.32)}
.btn-secondary{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-secondary:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.spec-table{width:100%;border-collapse:collapse;margin-bottom:18px;font-size:.9rem}
.spec-table td{padding:10px 6px;border-bottom:1px solid var(--line);vertical-align:top}
.spec-table td:first-child{color:var(--muted);width:38%;font-weight:700}
.spec-table td:last-child{font-weight:800;color:var(--ink)}
.note-box{background:#eef9f7;border:1px solid #c9eee9;border-radius:8px;padding:13px 14px;font-size:.86rem;line-height:1.65;margin-bottom:16px}
.muted-copy{color:var(--muted);font-size:.9rem}
.video-box{margin:16px 0}
.video-box iframe,.video-box video{width:100%;aspect-ratio:16/9;border:0;border-radius:8px;background:#000}
.detail-empty{min-height:320px}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s cubic-bezier(.2,.7,.3,1),transform .55s cubic-bezier(.2,.7,.3,1)}
.reveal.show{opacity:1;transform:none}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes slowZoom{from{transform:scale(1.06)}to{transform:scale(1.02)}}
@keyframes floatSoft{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes pulseRing{0%{box-shadow:0 0 0 0 rgba(37,211,102,.42)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

@media (max-width:980px){
  .hero{min-height:68vh;padding-top:76px}
  .hero h1{font-size:2.7rem}
  .service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .detail-card{grid-template-columns:1fr}
}
@media (max-width:760px){
  .topbar{justify-content:flex-start;gap:14px}
  .topbar span:nth-child(3){display:none}
  nav{height:64px}
  .nav-links{display:none}
  .nav-brand{font-size:.92rem;max-width:76%}
  .nav-cta{font-size:0;width:42px;height:42px;padding:0;justify-content:center;flex:0 0 42px;overflow:hidden}
  .nav-cta i{font-size:1rem}
  .hero{min-height:66vh;padding:64px 5% 56px}
  .hero-inner{max-width:340px}
  .hero-shade{background:linear-gradient(90deg,rgba(9,20,38,.9),rgba(9,20,38,.62))}
  .hero h1{font-size:2rem}
  .hero p{font-size:.98rem}
  .hero-stats{display:grid;grid-template-columns:1fr;width:100%;max-width:340px;gap:10px}
  .hero-stats>div{min-width:0}
  section{padding:50px 5%}
  .section-title{font-size:1.48rem;max-width:340px}
  .section-sub{max-width:340px}
  .toolbar{position:static}
  .search-wrap{min-width:100%}
  .filter-group{width:100%;display:grid;grid-template-columns:1fr 1fr}
  .filter-sel{max-width:none;width:100%}
  .filter-reset{width:100%}
  .service-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr;gap:12px}
  .card-body{padding:12px}
  .card-name{font-size:.86rem}
  .spec-chips span{font-size:.71rem}
  .card-price{font-size:.88rem}
  .footer-top{grid-template-columns:1fr;gap:24px}
  .detail-info{padding:22px}
  .detail-info h1{font-size:1.55rem}
}
@media (max-width:430px){
  .nav-brand{max-width:76%}
  .nav-brand .icon{width:36px;height:36px}
  .hero h1{font-size:2rem}
  .hero-stats{gap:9px}
  .hero-stats>div{min-width:0}
  .filter-group{grid-template-columns:1fr}
  .floating-wa{right:16px;bottom:16px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============ POLISH v2 — motion & micro-interactions ============ */
/* Scroll progress bar */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;background:linear-gradient(90deg,var(--amber),var(--teal));box-shadow:0 0 10px rgba(245,165,36,.5);transition:width .08s linear;pointer-events:none}

/* Back-to-top */
.back-to-top{position:fixed;right:22px;bottom:88px;z-index:998;width:46px;height:46px;border-radius:50%;border:0;background:#10233f;color:#fff;font-size:15px;display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(14px) scale(.9);pointer-events:none;transition:opacity .25s,transform .25s,background .2s;box-shadow:0 10px 26px rgba(16,35,63,.32)}
.back-to-top.show{opacity:1;transform:none;pointer-events:auto}
.back-to-top:hover{background:var(--blue);transform:translateY(-3px)}
.back-to-top:focus-visible{outline:3px solid var(--amber);outline-offset:3px}

/* Hero: stagger children (replace single-container fade) + headline underline */
.hero-inner{animation:none}
.hero-inner>*{animation:fadeUp .62s cubic-bezier(.2,.7,.3,1) both}
.hero-badge{animation-delay:.05s}
.hero h1{animation-delay:.14s;position:relative}
.hero p{animation-delay:.24s}
.hero-actions{animation-delay:.34s}
.hero-stats{animation-delay:.44s}
.hero h1::after{content:'';position:absolute;left:0;bottom:-10px;height:5px;width:0;border-radius:4px;z-index:1;background:linear-gradient(90deg,var(--amber),var(--teal));animation:lineGrow .8s cubic-bezier(.2,.7,.3,1) .55s forwards}
@keyframes lineGrow{to{width:min(230px,62%)}}

/* Product cards: load entrance + stagger (no scroll-reveal → aman dgn filter) */
#grid .product-card{animation:cardIn .5s cubic-bezier(.2,.7,.3,1) both}
#grid .product-card:nth-child(1){animation-delay:.03s}
#grid .product-card:nth-child(2){animation-delay:.07s}
#grid .product-card:nth-child(3){animation-delay:.11s}
#grid .product-card:nth-child(4){animation-delay:.15s}
#grid .product-card:nth-child(5){animation-delay:.19s}
#grid .product-card:nth-child(6){animation-delay:.23s}
#grid .product-card:nth-child(7){animation-delay:.27s}
#grid .product-card:nth-child(8){animation-delay:.31s}
@keyframes cardIn{from{opacity:0;transform:translateY(22px) scale(.97)}to{opacity:1;transform:none}}

/* Card hover: shine sweep + price accent + press */
.card{position:relative}
.card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.38) 50%,transparent 68%);transform:translateX(-130%);pointer-events:none;z-index:2}
.card:hover .card-img::after{animation:shine .75s ease}
@keyframes shine{to{transform:translateX(130%)}}
.ready-pill{z-index:3;animation:pillPop .5s cubic-bezier(.34,1.56,.64,1) .18s both}
@keyframes pillPop{0%{opacity:0;transform:scale(.7)}100%{opacity:1;transform:scale(1)}}
.card-price{position:relative;padding-bottom:3px}
.card-price::after{content:'';position:absolute;left:0;bottom:-1px;height:3px;width:0;border-radius:3px;background:var(--amber);transition:width .3s cubic-bezier(.2,.7,.3,1)}
.card:hover .card-price::after{width:64%}
.card:active{transform:translateY(-6px) scale(.99)}

/* Service cards: stagger + spring icon */
.service-grid .service-card.reveal:nth-child(1){transition-delay:.04s}
.service-grid .service-card.reveal:nth-child(2){transition-delay:.12s}
.service-grid .service-card.reveal:nth-child(3){transition-delay:.2s}
.service-grid .service-card.reveal:nth-child(4){transition-delay:.28s}
.service-card:hover .svc-ico{transform:translateY(-3px) rotate(-6deg) scale(1.12);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}

/* Section headers reveal (stagger) */
.section-title.reveal{transition-delay:.06s}
.section-sub.reveal{transition-delay:.12s}

/* CTA reveal */
.cta-banner.reveal .cta-inner{opacity:0;transform:translateY(26px)}
.cta-banner.reveal.show .cta-inner{opacity:1;transform:none;transition:opacity .6s,transform .6s cubic-bezier(.2,.7,.3,1)}

/* Filter & nav press feedback */
.filter-reset:active,.filter-sel:active{transform:scale(.96)}
.nav-cta:active,.btn-primary:active,.btn-ghost:active,.btn-secondary:active,.btn-wa:active,.btn-wa-lg:active{transform:translateY(0) scale(.97)}

/* Empty / no-result motion */
.empty i{animation:fadeFloat .8s cubic-bezier(.2,.7,.3,1) both}
@keyframes fadeFloat{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.no-result.show{animation:fadeUp .4s both}

/* Detail page: stagger media/info + thumbnail crossfade */
.detail-card{animation:none}
.detail-media{animation:fadeUp .55s cubic-bezier(.2,.7,.3,1) both}
.detail-info{animation:fadeUp .55s cubic-bezier(.2,.7,.3,1) .12s both}
.detail-main-img{transition:opacity .22s ease}
.detail-main-img.swapping{opacity:.2}
.detail-thumbs button.active{transform:translateY(-2px)}

@media (max-width:760px){
  .back-to-top{right:16px;bottom:86px;width:42px;height:42px}
  .hero h1::after{bottom:-6px}
}

/* Reduced-motion safety: pastikan konten yg ber-opacity:0 tetap TERLIHAT */
@media (prefers-reduced-motion:reduce){
  .cta-banner.reveal .cta-inner{opacity:1!important;transform:none!important}
  .hero h1::after{width:min(230px,62%)}
  #grid .product-card{opacity:1!important;transform:none!important}
}

/* ============ TESTIMONI ============ */
.testi-section{position:relative;overflow:hidden;background:radial-gradient(1100px 460px at 12% -12%,#e9f1ff 0%,rgba(233,241,255,0) 60%),linear-gradient(180deg,#fafcff 0%,#eef4fc 100%)}
.testi-section::before,.testi-section::after{content:'';position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.testi-section::before{width:340px;height:340px;right:-90px;top:-70px;background:radial-gradient(circle at 30% 30%,rgba(18,165,148,.20),rgba(18,165,148,0) 70%);filter:blur(8px);animation:testiBlob 14s ease-in-out infinite}
.testi-section::after{width:300px;height:300px;left:-80px;bottom:-80px;background:radial-gradient(circle at 50% 50%,rgba(23,105,210,.18),rgba(23,105,210,0) 70%);filter:blur(8px);animation:testiBlob 18s ease-in-out infinite reverse}
.testi-head{position:relative;z-index:1}

/* Ringkasan rating */
.testi-summary{display:inline-flex;align-items:center;gap:13px;margin-top:20px;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:999px;padding:9px 19px;box-shadow:var(--shadow-sm)}
.testi-summary .ts-stars{display:inline-flex;gap:2px;color:var(--amber);font-size:.82rem}
.testi-summary .ts-stars .far{color:#dde5ef}
.testi-summary .ts-score{font-weight:800;font-size:1rem;color:var(--ink);letter-spacing:.3px}
.testi-summary .ts-sep{width:1px;height:18px;background:var(--line)}
.testi-summary .ts-count{font-size:.8rem;font-weight:700;color:var(--muted);display:inline-flex;align-items:center;gap:6px}
.testi-summary .ts-count i{color:var(--teal)}

.testi-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:18px;margin-top:30px}
.testi-card{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 22px 20px;display:flex;flex-direction:column;box-shadow:0 2px 10px rgba(16,32,56,.05);transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s,border-color .3s}
.testi-card::before{content:'';position:absolute;left:0;top:0;height:4px;width:100%;background:linear-gradient(90deg,var(--blue),var(--teal),var(--amber));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.2,.7,.3,1)}
.testi-card:hover{transform:translateY(-8px);box-shadow:0 22px 46px rgba(16,32,56,.16);border-color:#bcd2ec}
.testi-card:hover::before{transform:scaleX(1)}
.testi-qmark{position:absolute;top:0;right:18px;font-family:Georgia,'Times New Roman',serif;font-size:5.4rem;line-height:1;color:var(--blue);opacity:.1;transition:opacity .3s,transform .3s;pointer-events:none;user-select:none}
.testi-card:hover .testi-qmark{opacity:.18;transform:translateY(3px) scale(1.06)}

.testi-stars{display:flex;gap:3px;color:var(--amber);font-size:.84rem;margin-bottom:14px}
.testi-stars .far{color:#dde5ef}
.testi-card.show .testi-stars i{animation:testiStar .5s cubic-bezier(.34,1.56,.64,1) backwards}
.testi-card.show .testi-stars i:nth-child(1){animation-delay:.14s}
.testi-card.show .testi-stars i:nth-child(2){animation-delay:.21s}
.testi-card.show .testi-stars i:nth-child(3){animation-delay:.28s}
.testi-card.show .testi-stars i:nth-child(4){animation-delay:.35s}
.testi-card.show .testi-stars i:nth-child(5){animation-delay:.42s}

.testi-quote{position:relative;z-index:1;font-style:italic;color:var(--ink-2);font-size:.85rem;line-height:1.7;margin:0 0 18px;flex:1}
.testi-author{display:flex;align-items:center;gap:12px;border-top:1px solid #edf2f7;padding-top:15px}
.testi-avatar{position:relative;width:44px;height:44px;flex:0 0 44px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue),var(--teal));color:#fff;font-weight:800;font-size:.86rem;letter-spacing:.5px;box-shadow:0 6px 16px rgba(23,105,210,.3)}
.testi-avatar::after{content:'';position:absolute;inset:-3px;border-radius:50%;padding:2px;background:linear-gradient(135deg,var(--blue),var(--amber));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transform:rotate(-30deg);transition:opacity .35s,transform .35s}
.testi-card:hover .testi-avatar::after{opacity:1;transform:rotate(0)}
.testi-meta{display:flex;flex-direction:column;min-width:0}
.testi-name{font-weight:800;font-size:.86rem;color:var(--ink);line-height:1.3}
.testi-city{font-size:.74rem;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:5px}
.testi-city i{color:var(--coral);font-size:.7rem}

/* Entrance: animasi (bukan transition) supaya hover tetap snappy & bebas konflik */
.testi-card.reveal:not(.show){opacity:0;transform:translateY(28px) scale(.985)}
.testi-card.reveal.show{animation:testiIn .65s cubic-bezier(.2,.7,.3,1) backwards}
.testi-grid .testi-card.reveal.show:nth-child(2){animation-delay:.08s}
.testi-grid .testi-card.reveal.show:nth-child(3){animation-delay:.16s}
.testi-grid .testi-card.reveal.show:nth-child(4){animation-delay:.24s}
.testi-grid .testi-card.reveal.show:nth-child(5){animation-delay:.32s}
.testi-grid .testi-card.reveal.show:nth-child(6){animation-delay:.40s}
.testi-grid .testi-card.reveal.show:nth-child(n+7){animation-delay:.46s}

@keyframes testiIn{from{opacity:0;transform:translateY(28px) scale(.985)}to{opacity:1;transform:none}}
@keyframes testiStar{0%{opacity:0;transform:scale(0) rotate(-35deg)}60%{transform:scale(1.28) rotate(5deg)}100%{opacity:1;transform:none}}
@keyframes testiBlob{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-16px,24px) scale(1.1)}}

/* ============ LOKASI & KONTAK ============ */
.kontak-section{position:relative;overflow:hidden;background:radial-gradient(900px 420px at 88% -10%,#e7f6f3 0%,rgba(231,246,243,0) 62%),linear-gradient(180deg,#f7fbff 0%,#e9f1fa 100%)}
.kontak-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(23,105,210,.10) 1.2px,transparent 1.2px);background-size:26px 26px;mask-image:linear-gradient(180deg,transparent 0%,#000 18%,#000 72%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,transparent 0%,#000 18%,#000 72%,transparent 100%);pointer-events:none}
.kontak-section::after{content:'';position:absolute;width:380px;height:380px;left:-110px;top:-90px;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(245,165,36,.16),rgba(245,165,36,0) 70%);filter:blur(10px);pointer-events:none;animation:testiBlob 16s ease-in-out infinite}
.kontak-head{position:relative;z-index:1}
.kontak-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.18fr);gap:26px;margin-top:30px;align-items:stretch}

/* Status buka/tutup */
.kontak-status{display:inline-flex;align-items:center;gap:9px;margin-top:18px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:999px;padding:9px 18px;font-size:.82rem;font-weight:800;box-shadow:var(--shadow-sm)}
.kontak-status .ks-dot{width:9px;height:9px;border-radius:50%;position:relative}
.kontak-status.is-open{color:#15803d}
.kontak-status.is-open .ks-dot{background:var(--green)}
.kontak-status.is-open .ks-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--green);animation:ksPing 1.6s cubic-bezier(0,.6,.4,1) infinite}
.kontak-status.is-closed{color:#b91c1c}
.kontak-status.is-closed .ks-dot{background:var(--coral)}
.kontak-status .ks-sep{width:1px;height:16px;background:var(--line)}
.kontak-status .ks-jam{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--ink-2);white-space:nowrap}
.kontak-status .ks-jam i{color:var(--muted)}

/* Kartu info kontak */
.kontak-info{display:flex;flex-direction:column;gap:13px}
.kontak-item{position:relative;overflow:hidden;display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 17px;box-shadow:0 2px 10px rgba(16,32,56,.05)}
.kontak-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--blue),var(--teal));transform:scaleY(0);transform-origin:top;transition:transform .35s cubic-bezier(.2,.7,.3,1)}
.kontak-item:hover::before{transform:scaleY(1)}
.kontak-link{text-decoration:none;color:inherit;transition:transform .22s cubic-bezier(.2,.7,.3,1),border-color .22s,box-shadow .22s}
.kontak-link:hover{transform:translateY(-4px) translateX(3px);border-color:#b9d2ee;box-shadow:0 16px 36px rgba(16,32,56,.13)}
.kontak-ico{width:48px;height:48px;flex:0 0 48px;border-radius:12px;display:grid;place-items:center;font-size:20px;background:#e9f2ff;color:var(--blue);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.kontak-item:hover .kontak-ico{transform:translateY(-3px) rotate(-7deg) scale(1.08)}
.kontak-ico.kontak-jam{background:#fdf3e3;color:#d97706}
.kontak-ico.kontak-wa{position:relative;background:#e4f9ee;color:#16a34a}
.kontak-ico.kontak-wa::after{content:'';position:absolute;inset:0;border-radius:12px;border:2px solid rgba(34,197,94,.55);animation:ksPing 2.2s cubic-bezier(0,.6,.4,1) infinite}
.kontak-ico.kontak-ig{background:linear-gradient(135deg,#feda75,#d62976 55%,#962fbf);color:#fff;background-size:160% 160%;animation:igShift 5s ease-in-out infinite}
.kontak-item>div{display:flex;flex-direction:column;min-width:0;flex:1}
.kontak-label{font-size:.68rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.kontak-val{font-size:.9rem;font-weight:700;color:var(--ink);line-height:1.4;word-break:break-word}
.kontak-go{width:32px;height:32px;flex:0 0 32px;border-radius:50%;display:grid;place-items:center;background:#f1f6fc;color:var(--blue);font-size:.8rem;opacity:0;transform:translateX(-8px);transition:opacity .25s,transform .25s,background .25s,color .25s}
.kontak-link:hover .kontak-go{opacity:1;transform:none;background:var(--blue);color:#fff}

/* CTA chat */
.kontak-cta{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:2px;background:linear-gradient(120deg,#10233f 0%,#143d6b 55%,#0f5132 130%);border-radius:12px;padding:18px 19px;text-decoration:none;color:#fff;box-shadow:0 14px 34px rgba(16,35,63,.28);transition:transform .22s cubic-bezier(.2,.7,.3,1),box-shadow .25s}
.kontak-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.14) 50%,transparent 70%);transform:translateX(-130%);animation:ctaShine 4.2s ease-in-out infinite}
.kontak-cta:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(16,35,63,.38)}
.kontak-cta-txt{display:flex;flex-direction:column;gap:3px;min-width:0}
.kontak-cta-txt strong{font-size:.94rem;font-weight:800}
.kontak-cta-txt span{font-size:.78rem;color:rgba(255,255,255,.75);font-weight:600;line-height:1.5}
.kontak-cta-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;background:#25d366;color:#fff;border-radius:9px;padding:11px 16px;font-size:.84rem;font-weight:800;box-shadow:0 8px 20px rgba(37,211,102,.35);transition:transform .18s,background .2s}
.kontak-cta:hover .kontak-cta-btn{transform:scale(1.05);background:#1fb958}

/* Peta */
.kontak-map{position:relative;display:flex;flex-direction:column;min-height:380px}
.kontak-map-frame{position:relative;flex:1;display:flex;border-radius:14px 14px 0 0;padding:3px 3px 0;background:linear-gradient(120deg,var(--blue),var(--teal),var(--amber),var(--blue));background-size:280% 280%;animation:mapBorder 9s ease infinite}
.kontak-map-frame iframe{width:100%;flex:1;min-height:300px;border:0;display:block;border-radius:11px 11px 0 0;background:#eef3f9;filter:saturate(1.04)}
.kontak-map-badge{position:absolute;z-index:2;top:16px;left:16px;display:inline-flex;align-items:center;gap:9px;background:rgba(16,35,63,.88);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:8px 15px;font-size:.78rem;font-weight:800;box-shadow:0 10px 26px rgba(16,35,63,.3);animation:badgeFloat 3.6s ease-in-out infinite}
.kontak-map-badge i{color:var(--amber)}
.kontak-map-badge .kmb-ping{width:8px;height:8px;border-radius:50%;background:var(--green);position:relative;flex:0 0 8px}
.kontak-map-badge .kmb-ping::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--green);animation:ksPing 1.6s cubic-bezier(0,.6,.4,1) infinite}
.kontak-map-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 17px;border:1px solid var(--line);border-top:0;border-radius:0 0 14px 14px;background:#fff;flex-wrap:wrap;box-shadow:0 16px 38px rgba(16,32,56,.10)}
.kontak-map-foot span{font-size:.8rem;color:var(--ink-2);font-weight:700;display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.kontak-map-foot span i{color:var(--coral);animation:pinBounce 2.4s ease-in-out infinite}
.btn-maps{position:relative;overflow:hidden;padding:11px 16px;font-size:.82rem;white-space:nowrap}
.btn-maps::after{content:'';position:absolute;inset:0;background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.45) 50%,transparent 68%);transform:translateX(-130%)}
.btn-maps:hover::after{animation:shine .7s ease}

/* Entrance: info slide dari kiri (stagger), peta dari kanan */
.kontak-info>.reveal:not(.show){opacity:0;transform:translateX(-30px)}
.kontak-info>.reveal.show{animation:kontakInL .6s cubic-bezier(.2,.7,.3,1) backwards}
.kontak-info>.reveal.show:nth-child(2){animation-delay:.09s}
.kontak-info>.reveal.show:nth-child(3){animation-delay:.18s}
.kontak-info>.reveal.show:nth-child(4){animation-delay:.27s}
.kontak-info>.reveal.show:nth-child(5){animation-delay:.36s}
.kontak-map.reveal:not(.show){opacity:0;transform:translateX(34px) scale(.985)}
.kontak-map.reveal.show{animation:kontakInR .7s cubic-bezier(.2,.7,.3,1) .12s backwards}

@keyframes kontakInL{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:none}}
@keyframes kontakInR{from{opacity:0;transform:translateX(34px) scale(.985)}to{opacity:1;transform:none}}
@keyframes ksPing{0%{transform:scale(.6);opacity:.9}80%,100%{transform:scale(1.9);opacity:0}}
@keyframes igShift{0%,100%{background-position:0% 30%}50%{background-position:100% 70%}}
@keyframes ctaShine{0%,55%{transform:translateX(-130%)}85%,100%{transform:translateX(130%)}}
@keyframes mapBorder{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes pinBounce{0%,100%{transform:translateY(0)}12%{transform:translateY(-4px)}24%{transform:translateY(0)}}

@media (max-width:980px){
  .kontak-grid{grid-template-columns:1fr;gap:18px}
  .kontak-map{min-height:340px}
}
@media (max-width:760px){
  .testi-grid{grid-template-columns:1fr;gap:12px}
  .kontak-status .ks-sep,.kontak-status .ks-jam{display:none}
  .kontak-cta{flex-direction:column;align-items:stretch;text-align:center}
  .kontak-cta-btn{justify-content:center}
  .kontak-map-badge{top:12px;left:12px;font-size:.72rem;padding:7px 12px}
  .kontak-map-foot{flex-direction:column;align-items:stretch}
  .kontak-map-foot .btn-primary{justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  .testi-card.reveal,.testi-card.reveal:not(.show),
  .kontak-info>.reveal,.kontak-info>.reveal:not(.show),
  .kontak-map.reveal,.kontak-map.reveal:not(.show){opacity:1!important;transform:none!important}
  .testi-card::before{transform:scaleX(1)}
  .kontak-go{opacity:1;transform:none}
}

/* ====== Galeri detail: hover-zoom + lightbox (marketplace style) ====== */
.detail-main-stage{position:relative;border-radius:8px;overflow:hidden;cursor:zoom-in;background:#fff}
.detail-main-stage .detail-main-img{transition:opacity .22s ease, transform .3s ease;will-change:transform}
@media (hover:hover){
  .detail-main-stage:hover .detail-main-img{transform:scale(2.15)}
  .detail-main-stage:hover .zoom-hint{opacity:0}
}
.zoom-hint{position:absolute;left:10px;bottom:10px;background:rgba(13,57,117,.85);color:#fff;font-size:.72rem;font-weight:600;padding:5px 11px;border-radius:20px;display:inline-flex;gap:6px;align-items:center;pointer-events:none;opacity:.92;transition:opacity .2s}
.media-label{font-size:.78rem;font-weight:700;color:var(--ink-2);margin-bottom:7px;display:flex;align-items:center;gap:6px}

.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(8,15,28,.95);display:none;align-items:center;justify-content:center;flex-direction:column;backdrop-filter:blur(2px);padding:20px}
.lightbox.open{display:flex;animation:lbFade .2s ease}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lb-stage{position:relative;width:min(94vw,1080px);height:min(74vh,760px);display:flex;align-items:center;justify-content:center;overflow:hidden;touch-action:none}
.lb-stage img{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px;transition:transform .25s ease;transform:scale(1);transform-origin:center center;cursor:zoom-in;user-select:none;-webkit-user-drag:none}
.lb-stage img.zoomed{transform:scale(2.6);cursor:zoom-out}
.lb-zoomhint{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);background:rgba(255,255,255,.16);color:#fff;font-size:.74rem;font-weight:600;padding:5px 12px;border-radius:20px;display:inline-flex;gap:6px;align-items:center;pointer-events:none}
.lb-close{position:absolute;top:16px;right:20px;width:46px;height:46px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:1.8rem;line-height:1;cursor:pointer;transition:background .2s;z-index:2}
.lb-close:hover{background:rgba(255,255,255,.3)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:1.15rem;cursor:pointer;display:grid;place-items:center;transition:background .2s;z-index:2}
.lb-nav:hover{background:rgba(255,255,255,.3)}
.lb-prev{left:18px}
.lb-next{right:18px}
.lb-counter{color:#fff;font-size:.9rem;font-weight:600;margin-top:14px;letter-spacing:.5px}
.lb-thumbs{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;justify-content:center;max-width:94vw}
.lb-thumbs button{border:2px solid transparent;background:none;padding:0;border-radius:6px;cursor:pointer;opacity:.5;transition:opacity .2s,border-color .2s}
.lb-thumbs button:hover{opacity:.85}
.lb-thumbs button.active{opacity:1;border-color:#fff}
.lb-thumbs img{width:58px;height:58px;object-fit:cover;border-radius:5px;display:block}
@media (max-width:560px){
  .lb-nav{width:42px;height:42px;font-size:1rem}
  .lb-prev{left:8px}.lb-next{right:8px}
  .lb-close{top:8px;right:10px;width:42px;height:42px}
  .lb-thumbs img{width:46px;height:46px}
}
@media (prefers-reduced-motion:reduce){
  .detail-main-stage:hover .detail-main-img{transition:none}
  .lb-stage img{transition:none}
}

/* ====== Spesifikasi: grid kartu ber-icon ====== */
.spec-title{font-size:.95rem;font-weight:800;color:var(--ink);margin:4px 0 12px;display:flex;align-items:center;gap:8px}
.spec-title i{color:var(--blue)}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.spec-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border:1px solid var(--line);border-radius:9px;background:var(--paper);transition:border-color .18s,box-shadow .18s,transform .18s}
.spec-item:hover{border-color:#cfe0f5;box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.spec-item.full{grid-column:1 / -1}
.spec-ic{flex:none;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:1.02rem}
.spec-meta{display:flex;flex-direction:column;min-width:0;line-height:1.3}
.spec-k{font-size:.7rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.spec-v{font-size:.92rem;color:var(--ink);font-weight:800;word-break:break-word}
@media (max-width:560px){ .spec-grid{grid-template-columns:1fr} }

/* ============ CARD BARANG — penyempurnaan ============ */
/* Badge "Baru" */
.new-pill{position:absolute;right:10px;top:10px;z-index:3;display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,var(--amber),#fb923c);color:#1f2937;border:1px solid rgba(255,255,255,.45);border-radius:6px;padding:5px 9px;font-size:.7rem;font-weight:800;box-shadow:0 6px 16px rgba(245,165,36,.4);animation:pillPop .5s cubic-bezier(.34,1.56,.64,1) .26s both,newGlow 2.6s ease-in-out 1s infinite}
@keyframes newGlow{0%,100%{box-shadow:0 6px 16px rgba(245,165,36,.4)}50%{box-shadow:0 6px 24px rgba(245,165,36,.75)}}

/* Overlay "Lihat Detail" saat hover */
.card-view{position:absolute;left:50%;bottom:12px;transform:translateX(-50%) translateY(14px);z-index:3;display:inline-flex;align-items:center;gap:7px;background:rgba(16,35,63,.9);backdrop-filter:blur(6px);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:8px 15px;font-size:.76rem;font-weight:800;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .25s,transform .3s cubic-bezier(.2,.7,.3,1)}
.card-view i{color:var(--amber)}
.card:hover .card-view{opacity:1;transform:translateX(-50%) translateY(0)}

/* Kode barang + chip kosong */
.card-code i{font-size:.62rem;opacity:.7;margin-right:2px}
.spec-chips .chip-empty{border-style:dashed;color:var(--muted);background:#fbfdff}
.spec-chips .chip-empty i{color:#25d366}

/* Harga dengan label kecil */
.card-price-wrap{display:flex;flex-direction:column;min-width:0}
.card-price-label{font-size:.64rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:1px}

/* Fallback visual: sembunyikan overlay detail di layar sentuh kasar */
@media (hover:none){ .card-view{display:none} }
@media (prefers-reduced-motion:reduce){ .card-view{opacity:1;transform:translateX(-50%)} }

/* ============ DETAIL — penyempurnaan ============ */
/* Breadcrumb */
.crumbs{display:flex;align-items:center;gap:10px;margin-bottom:18px;font-size:.82rem;font-weight:700;color:var(--muted);flex-wrap:wrap;animation:fadeUp .45s both}
.crumbs a{display:inline-flex;align-items:center;gap:6px;color:var(--blue);text-decoration:none;transition:color .2s}
.crumbs a:hover{color:var(--teal)}
.crumbs>i{font-size:.6rem;color:#b9c4d4}
.crumb-now{color:var(--ink);max-width:46vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Trust badges */
.trust-row{display:flex;gap:8px;flex-wrap:wrap;margin:2px 0 16px}
.trust-row span{display:inline-flex;align-items:center;gap:7px;background:#f4f9f7;border:1px solid #d8eee6;color:#0e7a64;border-radius:999px;padding:7px 13px;font-size:.74rem;font-weight:800}
.trust-row i{font-size:.78rem}

/* Share */
.share-row{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:20px}
.share-label{font-size:.78rem;font-weight:800;color:var(--muted);display:inline-flex;align-items:center;gap:7px}
.share-btn{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:8px 13px;font-size:.78rem;font-weight:800;color:var(--ink-2);font-family:inherit;cursor:pointer;text-decoration:none;transition:transform .15s,border-color .2s,color .2s,background .2s}
.share-btn:hover{transform:translateY(-2px);border-color:var(--blue);color:var(--blue)}
.share-btn.copied{border-color:var(--green);color:#15803d;background:#f0fdf4}
.share-btn.share-wa:hover{border-color:#25d366;color:#16a34a}

/* Spec items: entrance stagger */
.spec-item{animation:fadeUp .5s cubic-bezier(.2,.7,.3,1) both}
.spec-item:nth-child(1){animation-delay:.16s}.spec-item:nth-child(2){animation-delay:.22s}
.spec-item:nth-child(3){animation-delay:.28s}.spec-item:nth-child(4){animation-delay:.34s}
.spec-item:nth-child(5){animation-delay:.40s}.spec-item:nth-child(6){animation-delay:.46s}
.spec-item:nth-child(7){animation-delay:.52s}.spec-item:nth-child(8){animation-delay:.58s}

/* Produk serupa */
.related-sec{padding:46px 0 0}
.related-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.related-title{font-size:1.5rem;font-weight:800;line-height:1.2}
.related-all{display:inline-flex;align-items:center;gap:8px;color:var(--blue);text-decoration:none;font-size:.86rem;font-weight:800;transition:gap .2s,color .2s}
.related-all:hover{gap:12px;color:var(--teal)}
.related-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}

/* CTA lengket bawah (HP) */
.sticky-cta{display:none}
@media (max-width:760px){
  .sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:150;display:flex;align-items:center;justify-content:space-between;gap:12px;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line);box-shadow:0 -10px 30px rgba(16,32,56,.12);padding:11px 16px calc(11px + env(safe-area-inset-bottom));animation:scIn .4s cubic-bezier(.2,.7,.3,1) both}
  .sc-price{display:flex;flex-direction:column;min-width:0}
  .sc-price span{font-size:.62rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--muted)}
  .sc-price strong{font-size:1.05rem;font-weight:800;color:var(--blue-dark);white-space:nowrap}
  .sc-btn{padding:11px 18px;font-size:.84rem;flex:0 0 auto}
  body:has(.sticky-cta) .floating-wa{display:none}
  body:has(.sticky-cta) .back-to-top{bottom:84px}
  body:has(.sticky-cta) footer{padding-bottom:96px}
}
@keyframes scIn{from{transform:translateY(100%)}to{transform:none}}
@media (prefers-reduced-motion:reduce){
  .crumbs,.spec-item,.sticky-cta{animation:none!important;opacity:1!important;transform:none!important}
}

/* ============ HERO — penyempurnaan ============ */
/* Orbs cahaya mengambang */
.hero-orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-orbs span{position:absolute;border-radius:50%;filter:blur(14px);opacity:.5}
.hero-orbs span:nth-child(1){width:220px;height:220px;right:8%;top:12%;background:radial-gradient(circle at 35% 35%,rgba(245,165,36,.5),transparent 70%);animation:orbFloat 11s ease-in-out infinite}
.hero-orbs span:nth-child(2){width:150px;height:150px;right:26%;bottom:14%;background:radial-gradient(circle at 40% 40%,rgba(18,165,148,.45),transparent 70%);animation:orbFloat 14s ease-in-out 1.2s infinite reverse}
.hero-orbs span:nth-child(3){width:110px;height:110px;left:46%;top:22%;background:radial-gradient(circle at 40% 40%,rgba(23,105,210,.5),transparent 70%);animation:orbFloat 17s ease-in-out .6s infinite}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-22px,26px) scale(1.12)}}

/* Badge: titik live berdenyut */
.hb-dot{width:9px;height:9px;border-radius:50%;background:var(--green);position:relative;flex:0 0 9px}
.hb-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--green);animation:ksPing 1.8s cubic-bezier(0,.6,.4,1) infinite}

/* Nama kota: gradient hidup */
.grad-text{background:linear-gradient(90deg,var(--amber),#ffd166,var(--teal),var(--amber));background-size:240% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradFlow 7s ease infinite}
@keyframes gradFlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* Kata berputar (kerja/kuliah/gaming/bisnis) */
.word-rotate{display:inline-flex;height:1.45em;overflow:hidden;vertical-align:bottom}
.word-rotate b{display:flex;flex-direction:column;font-weight:800;color:var(--amber);animation:wordSpin 9s cubic-bezier(.2,.7,.3,1) infinite}
.word-rotate b span{height:1.45em;line-height:1.45em;display:block}
@keyframes wordSpin{
  0%,18%{transform:translateY(0)}
  25%,43%{transform:translateY(-1.45em)}
  50%,68%{transform:translateY(-2.9em)}
  75%,93%{transform:translateY(-4.35em)}
  100%{transform:translateY(-5.8em)}
}

/* Tombol hero: panah meluncur */
.btn-hero .btn-arr{transition:transform .25s cubic-bezier(.2,.7,.3,1)}
.btn-hero:hover .btn-arr{transform:translateX(5px)}

/* Stat cards: ikon + hover */
.hero-stats>div{display:flex;align-items:center;gap:12px;transition:transform .25s cubic-bezier(.2,.7,.3,1),border-color .25s,background .25s}
.hero-stats>div:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.16)}
.stat-ico{width:38px;height:38px;flex:0 0 38px;border-radius:10px;display:grid;place-items:center;font-size:15px;border:1px solid rgba(255,255,255,.25)}
.stat-ico.si-blue{background:rgba(23,105,210,.32);color:#9cc4f5}
.stat-ico.si-amber{background:rgba(245,165,36,.26);color:#ffd166}
.stat-ico.si-teal{background:rgba(18,165,148,.28);color:#7fe0d4}

/* Indikator scroll */
.hero-scroll{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:2;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);text-decoration:none;font-size:.9rem;backdrop-filter:blur(6px);animation:scrollBob 2.2s ease-in-out infinite;transition:background .2s,border-color .2s}
.hero-scroll:hover{background:rgba(255,255,255,.24);border-color:rgba(255,255,255,.55)}
@keyframes scrollBob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* ============ LAYANAN — penyempurnaan ============ */
.layanan-section{position:relative;overflow:hidden}
.layanan-section::before{content:'';position:absolute;width:420px;height:420px;right:-130px;top:-130px;border-radius:50%;background:radial-gradient(circle at 40% 40%,rgba(23,105,210,.07),transparent 70%);pointer-events:none}
.service-card{position:relative;overflow:hidden;display:flex;flex-direction:column}
.service-card p{flex:1;margin-bottom:14px}
.svc-c1{--ac:#1769d2;--ac-bg:#e8f1fc}
.svc-c2{--ac:#ef6a5b;--ac-bg:#fdecea}
.svc-c3{--ac:#12a594;--ac-bg:#e3f7f4}
.svc-c4{--ac:#d98a0b;--ac-bg:#fdf1da}
.service-card::before{content:'';position:absolute;left:0;top:0;height:4px;width:100%;background:linear-gradient(90deg,var(--ac),transparent 130%);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.2,.7,.3,1);z-index:1}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{transform:translateY(-7px);box-shadow:0 20px 44px rgba(16,32,56,.13);border-color:#c2d6ec}
.service-card .svc-ico{background:var(--ac-bg);color:var(--ac)}
.svc-watermark{position:absolute;right:-12px;bottom:-14px;font-size:6rem;color:var(--ac);opacity:.06;pointer-events:none;transform:rotate(-10deg);transition:transform .45s cubic-bezier(.2,.7,.3,1),opacity .45s}
.service-card:hover .svc-watermark{transform:rotate(-2deg) scale(1.12) translateY(-4px);opacity:.11}
.svc-link{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;color:var(--ac);text-decoration:none;font-size:.82rem;font-weight:800;margin-top:auto;transition:gap .22s}
.svc-link:hover{gap:13px}
.svc-link i{font-size:.74rem}

@media (max-width:760px){
  .hero-orbs span{display:none}
  .hero-scroll{display:none}
}
@media (prefers-reduced-motion:reduce){
  .hero-orbs span,.hb-dot::after,.grad-text,.word-rotate b,.hero-scroll{animation:none!important}
  .grad-text{color:var(--amber)}
}
