/* ── HERO BACKGROUND IMAGE ───────────────────────────── */
.hero{
  min-height:100dvh;position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 52px;
  border-bottom:1px solid var(--border);
  background-image: url('assets/hero-bg.jpg');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
.hero-bg-overlay{
  position:absolute;inset:0;pointer-events:none;
  background: linear-gradient(
    to bottom,
    rgba(10,10,10,0.55) 0%,
    rgba(10,10,10,0.45) 50%,
    rgba(10,10,10,0.75) 100%
  );
}

/* ── TEMPLATE PREVIEW BUTTON ─────────────────────────── */
.tpl-overlay-btn.tpl-preview{
  background:rgba(255,255,255,0.15);
  color:#fff;
  border:1px solid rgba(255,255,255,0.35);
  backdrop-filter:blur(8px);
}
.tpl-overlay-btn.tpl-preview:hover{background:rgba(255,255,255,0.25)}
.tpl-card:hover .tpl-overlay-btn.tpl-preview{opacity:1;transform:translateY(0)}

/* Staggered delay for two buttons */
.tpl-card:hover .tpl-overlay-btn:nth-child(1){transition-delay:.03s}
.tpl-card:hover .tpl-overlay-btn:nth-child(2){transition-delay:.07s}

/* Template modal back button (mobile) */
.tpl-modal-back{
  display:none;align-items:center;gap:6px;
  background:none;border:none;border-radius:6px;
  padding:9px 14px;font-size:0.76rem;font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;color:var(--muted);transition:all .15s;
  border:1px solid var(--border2);
}
.tpl-modal-back svg{flex-shrink:0}
.tpl-modal-back:hover{color:var(--text);background:rgba(255,255,255,0.05)}
@media(max-width:700px){
  .tpl-modal-back{display:flex}
  .tpl-close-btn{display:none}
  .tpl-modal-top{flex-wrap:wrap;gap:12px}
  .tpl-modal-btns{width:100%;justify-content:space-between}
  .tpl-modal-body{padding:12px}
  .tpl-modal-inner{border-radius:14px}
}

/* ── ABOUT REVAMP ────────────────────────────────────── */
.about-layout{
  display:grid;grid-template-columns:1fr 380px;gap:52px;align-items:start;
}
.about-identity{
  display:flex;align-items:center;gap:16px;
  padding:18px 20px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border2);
  border-radius:12px;margin-bottom:24px;
  position:relative;overflow:hidden;
}
.about-identity::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,0.05),transparent);
  pointer-events:none;
}
.about-avatar-wrap{
  position:relative;flex-shrink:0;
}
.about-avatar-ring{
  position:absolute;inset:-4px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.3);opacity:0.4;
  animation:avatarPulse 3s ease-in-out infinite;
}
@keyframes avatarPulse{0%,100%{opacity:0.4;transform:scale(1)}50%{opacity:0.7;transform:scale(1.05)}}
.about-avatar-inner{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,rgba(255,255,255,0.12),rgba(255,255,255,0.04));
  border:1px solid rgba(255,255,255,0.2);
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:1rem;
  color:#fff;letter-spacing:0.05em;
}
.about-name{font-family:'DM Serif Display',serif;font-size:1rem;color:var(--text);font-weight:400}
.about-role{font-size:0.7rem;color:rgba(242,240,235,0.65);margin-top:3px;font-weight:300}
.about-content .about-p{font-size:0.86rem;color:rgba(242,240,235,0.75);line-height:1.78;font-weight:300;margin-bottom:18px}
.about-content .about-links{display:flex;flex-direction:column;gap:6px;margin-top:28px}
.about-content .about-link{
  display:inline-flex;align-items:center;gap:9px;
  padding:9px 12px;border:1px solid var(--border);border-radius:6px;
  color:var(--muted);font-size:0.75rem;transition:all .15s;cursor:pointer;
  background:none;font-family:'DM Sans',sans-serif;text-align:left;text-decoration:none;
}
.about-content .about-link:hover{background:rgba(255,255,255,0.05);color:var(--text);border-color:var(--border2)}

/* About stats column */
.about-stats-col{display:flex;flex-direction:column;gap:12px}
.about-stat-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:24px 22px;position:relative;overflow:hidden;
  transition:border-color .2s;
}
.about-stat-card:hover{border-color:var(--border2)}
.about-stat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
}
.about-stat-num{
  font-family:'DM Serif Display',serif;
  font-size:2.4rem;color:var(--accent);
  line-height:1;letter-spacing:-0.03em;margin-bottom:4px;
}
.about-stat-label{font-size:0.72rem;font-weight:700;color:var(--text);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:8px}
.about-stat-desc{font-size:0.74rem;color:rgba(242,240,235,0.65);line-height:1.65;font-weight:300}
.about-partners{
  background:rgba(255,255,255,0.02);border:1px solid var(--border);
  border-radius:12px;padding:18px 20px;
}
.about-partners-label{font-size:0.59rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--subtle);margin-bottom:10px}
.about-partner-row{display:flex;gap:8px;flex-wrap:wrap}
.about-partner-badge{
  font-size:0.72rem;font-weight:600;padding:5px 12px;
  border-radius:5px;background:rgba(255,255,255,0.05);
  color:rgba(242,240,235,0.7);border:1px solid var(--border);
}
@media(max-width:900px){
  .about-layout{grid-template-columns:1fr;gap:32px}
  .about-stats-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .about-partners{grid-column:1/-1}
}
@media(max-width:540px){
  .about-stats-col{grid-template-columns:1fr}
  .about-identity{padding:14px 16px;gap:12px}
  .about-avatar-inner{width:44px;height:44px;font-size:0.9rem}
  .about-stat-num{font-size:1.9rem}
}

/* ── CONTACT SOCIAL REVAMP ───────────────────────────── */
.contact-social-block{margin-top:4px}
.contact-btn-icon-wa{
  background:rgba(37,211,102,0.1) !important;
  border:1px solid rgba(37,211,102,0.2) !important;
  color:#25d366;
}
.soc-item{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-radius:8px;border:1px solid var(--border);
  text-decoration:none;color:var(--muted);font-size:0.78rem;
  transition:all .18s;
}
.soc-item:hover{background:rgba(255,255,255,0.04);color:var(--text);border-color:var(--border2);transform:translateX(3px)}
.soc-platform-icon{
  width:26px;height:26px;border-radius:6px;
  background:rgba(255,255,255,0.06);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.soc-name{font-weight:600;color:var(--text);flex-shrink:0}
.soc-handle{font-size:0.68rem;opacity:0.35;margin-left:auto;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:160px}


*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#080808;
  --bg2:#0D0D0D;
  --bg3:#111111;
  --card:#141414;
  --card2:#1A1A1A;
  --border:rgba(255,255,255,0.07);
  --border2:rgba(255,255,255,0.12);
  --text:#F2F0EB;
  --muted:rgba(242,240,235,0.45);
  --subtle:rgba(242,240,235,0.28);
  --accent:#FFFFFF;
  --accent2:#E0E0E0;
  --glow-1:rgba(120,180,255,0.12);
  --glow-2:rgba(180,120,255,0.08);
  --glow-3:rgba(80,200,160,0.07);
}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ── MODALS ───────────────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:999;
  background:rgba(0,0,0,0.75);backdrop-filter:blur(12px);
  align-items:center;justify-content:center;padding:20px;
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--card2);border:1px solid var(--border2);
  border-radius:16px;padding:36px 32px;max-width:440px;
  width:100%;position:relative;
  animation:modalIn .22s ease;
  box-shadow:0 40px 100px rgba(0,0,0,0.6);
}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(0.97)}to{opacity:1;transform:none}}
.modal-close{
  position:absolute;top:14px;right:16px;background:none;border:none;
  color:var(--muted);font-size:1.2rem;cursor:pointer;
  padding:4px 8px;border-radius:4px;transition:color .15s;
}
.modal-close:hover{color:var(--text)}
.modal-icon{
  width:48px;height:48px;border-radius:12px;display:flex;
  align-items:center;justify-content:center;
  margin-bottom:18px;background:rgba(255,255,255,0.06);
  border:1px solid var(--border);
}
.modal h3{
  font-family:'DM Serif Display',serif;font-size:1.4rem;
  font-weight:400;color:var(--text);margin-bottom:8px;
}
.modal p{font-size:0.83rem;color:var(--muted);line-height:1.65;font-weight:300;margin-bottom:22px}
.modal-actions{display:flex;flex-direction:column;gap:9px}
.modal-btn{
  display:flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 18px;border-radius:8px;font-size:0.83rem;font-weight:600;
  text-decoration:none;cursor:pointer;transition:all .15s;border:none;
  font-family:'DM Sans',sans-serif;width:100%;
}
.modal-btn.primary{background:#fff;color:#000}
.modal-btn.primary:hover{background:rgba(255,255,255,0.88)}
.modal-btn.secondary{background:transparent;color:var(--text);border:1px solid var(--border2)}
.modal-btn.secondary:hover{background:rgba(255,255,255,0.06)}
.modal-divider{display:flex;align-items:center;gap:10px;margin:4px 0}
.modal-divider span{font-size:0.68rem;color:var(--subtle);white-space:nowrap}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.copy-row{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:8px;padding:10px 13px;
}
.copy-val{flex:1;font-size:0.82rem;color:var(--muted);font-weight:300;word-break:break-all}
.copy-btn{
  background:#fff;color:#000;border:none;border-radius:5px;
  padding:6px 12px;font-size:0.72rem;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:all .15s;
  font-family:'DM Sans',sans-serif;
}
.copy-btn:hover{background:rgba(255,255,255,0.88)}
.copy-btn.copied{background:#25d366;color:#fff}
.modal-note{font-size:0.7rem;color:var(--subtle);text-align:center;margin-top:10px;line-height:1.5}

/* ── TEMPLATE VIEWER ─────────────────────────────────── */
.tpl-modal-overlay{
  display:none;position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,0.92);backdrop-filter:blur(20px);
  align-items:center;justify-content:center;padding:24px;
}
.tpl-modal-overlay.open{display:flex}
.tpl-modal-inner{
  background:var(--card);border-radius:20px;border:1px solid var(--border2);
  max-width:920px;width:100%;max-height:90vh;overflow:hidden;
  display:flex;flex-direction:column;
  animation:modalIn .22s ease;
  box-shadow:0 60px 120px rgba(0,0,0,0.8);
}
.tpl-modal-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.tpl-modal-name{font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--text)}
.tpl-modal-desc{font-size:0.74rem;color:var(--muted);font-weight:300;margin-top:2px}
.tpl-modal-btns{display:flex;gap:8px;align-items:center;flex-shrink:0}
.tpl-choose-btn{
  background:#fff;color:#000;border:none;border-radius:6px;
  padding:9px 20px;font-size:0.76rem;font-weight:600;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .15s;
}
.tpl-choose-btn:hover{background:rgba(255,255,255,0.88);transform:translateY(-1px)}
.tpl-close-btn{
  background:none;border:1px solid var(--border2);border-radius:6px;
  padding:9px 14px;font-size:0.76rem;font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;color:var(--muted);transition:all .15s;
}
.tpl-close-btn:hover{color:var(--text);background:rgba(255,255,255,0.05)}
.tpl-modal-body{flex:1;overflow-y:auto;padding:20px 24px}
.tpl-modal-foot{
  padding:14px 24px;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;background:rgba(255,255,255,0.03);
}
.tpl-foot-l{font-size:0.73rem;color:var(--muted);font-weight:300}
.tpl-foot-l strong{color:var(--text);font-weight:600}
.tpl-foot-r{font-size:0.7rem;color:var(--subtle)}

/* ── NAV ─────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:0 52px;height:58px;
  background:rgba(8,8,8,0.8);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  transition:background .3s;
}
.nav-brand{
  font-family:'DM Serif Display',serif;font-size:1rem;
  color:var(--text);text-decoration:none;letter-spacing:-0.01em;
}
.nav-brand em{font-style:italic}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-link{
  font-size:0.7rem;font-weight:500;color:var(--muted);
  text-decoration:none;letter-spacing:0.06em;text-transform:uppercase;
  transition:color .15s;
}
.nav-link:hover{color:var(--text)}
.nav-wa{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.09);color:var(--text);
  padding:8px 18px;border-radius:6px;font-size:0.74rem;font-weight:600;
  cursor:pointer;transition:all .18s;
  border:1px solid var(--border2);
  font-family:'DM Sans',sans-serif;
}
.nav-wa:hover{background:rgba(255,255,255,0.15);transform:translateY(-1px)}
.nav-wa svg{width:13px;height:13px;flex-shrink:0;fill:var(--text)}


/* Floating pills */
.float-pill{
  position:absolute;display:flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:100px;
  background:rgba(255,255,255,0.06);
  border:1px solid var(--border2);
  backdrop-filter:blur(8px);
  font-size:0.72rem;color:var(--muted);font-weight:500;
  pointer-events:none;
}
.float-pill-1{top:22%;right:8%}
.float-pill-2{bottom:28%;right:12%}
.pill-dot{width:6px;height:6px;border-radius:50%;background:var(--muted);flex-shrink:0}
.pill-dot-green{background:#25d366}

.hero-inner{max-width:1120px;margin:0 auto;width:100%;position:relative;padding-top:58px}
.hero-label{
  display:block;font-size:0.62rem;font-weight:600;letter-spacing:0.2em;
  text-transform:uppercase;color:#fff;margin-bottom:28px;
}
.hero-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(3.4rem,7.5vw,7rem);
  font-weight:400;line-height:0.95;letter-spacing:-0.03em;
  color:var(--text);margin-bottom:28px;
}
.hero-title em{font-style:italic;color:#fff}
.hero-sub{
  font-size:1rem;font-weight:300;color:#fff;
  line-height:1.72;max-width:500px;margin-bottom:40px;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:56px}

.btn-primary{
  display:inline-flex;align-items:center;gap:9px;
  background:#fff;color:#000;
  padding:14px 28px;border-radius:7px;
  font-size:0.88rem;font-weight:600;cursor:pointer;
  transition:all .2s;border:none;font-family:'DM Sans',sans-serif;
}
.btn-primary:hover{background:rgba(255,255,255,0.88);transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,0,0,0.4)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:#fff;
  padding:14px 24px;border-radius:7px;
  font-size:0.88rem;font-weight:500;cursor:pointer;
  border:1px solid rgba(255,255,255,0.4);
  transition:all .18s;font-family:'DM Sans',sans-serif;
}
.btn-ghost:hover{background:rgba(255,255,255,0.1);color:#fff;transform:translateY(-1px)}

/* Stats bar */
.hero-stats{
  display:flex;align-items:center;gap:0;
  border:1px solid var(--border);border-radius:10px;
  overflow:hidden;background:rgba(255,255,255,0.03);
  max-width:600px;
}
.hstat{padding:18px 28px;flex:1}
.hstat-n{
  font-family:'DM Serif Display',serif;font-size:1.6rem;
  color:var(--text);line-height:1;margin-bottom:4px;letter-spacing:-0.02em;
}
.hstat-l{font-size:0.62rem;color:var(--subtle);text-transform:uppercase;letter-spacing:0.1em;font-weight:500}
.hstat-divider{width:1px;background:var(--border);align-self:stretch;flex-shrink:0}

/* Scroll cue */
.scroll-cue{
  position:absolute;bottom:36px;left:52px;
  display:flex;align-items:center;gap:10px;
  font-size:0.63rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--subtle);
}
.scroll-cue-line{width:32px;height:1px;background:var(--subtle)}

/* ── ANIMATIONS ──────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.fi{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards;opacity:0}
.d1{animation-delay:.05s}.d2{animation-delay:.15s}.d3{animation-delay:.26s}.d4{animation-delay:.38s}.d5{animation-delay:.5s}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.reveal.vis{opacity:1;transform:translateY(0)}

/* ── STRIP ───────────────────────────────────────────── */
.strip{border-bottom:1px solid var(--border);background:var(--bg2)}
.strip-inner{
  max-width:1120px;margin:0 auto;padding:0 52px;
  display:grid;grid-template-columns:repeat(4,1fr);
}
.strip-item{
  padding:22px;border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:5px;
  transition:background .18s;
}
.strip-item:last-child{border-right:none}
.strip-item:hover{background:rgba(255,255,255,0.03)}
.strip-num{font-size:0.58rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--subtle);margin-bottom:4px}
.strip-title{font-family:'DM Serif Display',serif;font-size:0.88rem;color:var(--text);font-weight:400}
.strip-desc{font-size:0.7rem;color:var(--muted);line-height:1.55;font-weight:300}

/* ── SECTIONS ────────────────────────────────────────── */
.section{padding:96px 52px;border-bottom:1px solid var(--border)}
.section-alt{background:var(--bg2)}
.sec-inner{max-width:1120px;margin:0 auto}
.sec-head{margin-bottom:52px}
.sec-label{
  display:block;font-size:0.6rem;font-weight:600;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--muted);
  padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:20px;
}
.sec-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(2rem,3.8vw,3.2rem);
  font-weight:400;letter-spacing:-0.025em;
  color:var(--text);line-height:1.06;
}
.sec-title em{font-style:italic;color:rgba(242,240,235,0.55)}
.sec-sub{font-size:0.85rem;color:rgba(242,240,235,0.6);line-height:1.72;font-weight:300;margin-top:12px;max-width:540px}

/* Reviews section — brighter overrides */
#reviews .sec-label{color:#00dcff;border-bottom-color:rgba(0,220,255,0.2)}
#reviews .sec-title{color:#fff}
#reviews .sec-title em{color:rgba(0,220,255,0.8)}
#reviews .sec-sub{color:rgba(242,240,235,0.75);font-weight:400}

/* ── SERVICES ────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.svc-grid .svc-card:last-child:nth-child(3n+1){grid-column:1/-1}
.svc-card{
  background:var(--bg);display:flex;flex-direction:column;
  transition:background .2s;cursor:default;
}
.svc-card:hover{background:var(--card)}
.svc-img-wrap{
  position:relative;height:200px;overflow:hidden;
  background:var(--card2);flex-shrink:0;
}
.svc-img-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;filter:brightness(0.55) saturate(0.7);
  display:block;
}
.svc-card:hover .svc-img-wrap img{transform:scale(1.05);filter:brightness(0.65) saturate(0.8)}
.svc-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 40%,var(--bg) 100%);
}
.svc-card:hover .svc-img-overlay{background:linear-gradient(to bottom,transparent 40%,var(--card) 100%)}
.svc-num-badge{
  position:absolute;top:14px;left:16px;
  font-size:0.58rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);
}
.svc-body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.svc-title{
  font-family:'DM Serif Display',serif;font-size:1.05rem;
  color:var(--text);margin-bottom:8px;font-weight:400;
}
.svc-desc{font-size:0.75rem;color:var(--muted);line-height:1.72;font-weight:300;flex:1}
.svc-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:14px}
.stag{
  font-size:0.58rem;font-weight:600;padding:3px 8px;border-radius:4px;
  background:rgba(255,255,255,0.06);color:var(--muted);
  border:1px solid var(--border);text-transform:uppercase;letter-spacing:0.05em;
}

/* ── PC SUPPORT ──────────────────────────────────────── */
.pc-audience{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.pc-audience-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:0.68rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  padding:6px 12px;border-radius:20px;
  border:1px solid rgba(0,220,255,0.25);
  color:rgba(0,220,255,0.8);background:rgba(0,220,255,0.07);
}
.pc-hero-img{
  position:relative;border-radius:10px;overflow:hidden;
  height:340px;margin-bottom:48px;
}
.pc-hero-img img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(0.5) saturate(0.7);display:block;
}
.pc-hero-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 40%,var(--bg2) 100%);
}
.pc-cats-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:10px;overflow:hidden;
  margin-bottom:1px;
}
.pc-cats-grid-2{grid-template-columns:repeat(2,1fr);border-radius:0 0 10px 10px;margin-top:0;border-top:none}
.pc-cat-card{
  background:var(--card);padding:26px 24px 28px;
  display:flex;flex-direction:column;gap:14px;
  transition:background .2s;
}
.pc-cat-card:hover{background:var(--card2)}
.pc-cat-icon{
  width:38px;height:38px;border-radius:8px;
  background:rgba(255,255,255,0.05);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:rgba(0,220,255,0.7);flex-shrink:0;
}
.pc-cat-title{
  font-family:'DM Serif Display',serif;font-size:0.98rem;
  color:var(--text);font-weight:400;
}
.pc-cat-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:6px;
}
.pc-cat-list li{
  font-size:0.73rem;color:var(--muted);line-height:1.6;font-weight:300;
  padding-left:14px;position:relative;
}
.pc-cat-list li::before{
  content:'';position:absolute;left:0;top:8px;
  width:5px;height:1px;background:rgba(0,220,255,0.4);
}
.pc-cat-note{
  color:rgba(0,220,255,0.55) !important;font-style:italic;
}
@media(max-width:900px){
  .pc-cats-grid{grid-template-columns:repeat(2,1fr)}
  .pc-cats-grid-2{grid-template-columns:1fr;border-radius:0 0 10px 10px}
  .pc-hero-img{height:220px}
}
/* pc-cats-grid mobile overrides are in the main 600px block below */

/* ── PRICING ─────────────────────────────────────────── */
/* ── PRICING ─────────────────────────────────────────── */

/* Billing Toggle */
.pricing-toggle-wrap{
  display:flex;align-items:center;justify-content:center;
  gap:14px;margin-top:32px;margin-bottom:8px;
}
.ptoggle-label{
  font-size:0.75rem;font-weight:600;letter-spacing:0.04em;
  color:var(--muted);transition:color .2s;cursor:pointer;
  text-transform:uppercase;
}
.ptoggle-label.active{color:var(--text)}
.ptoggle-switch{
  position:relative;width:52px;height:28px;
  background:rgba(255,255,255,0.08);border:1px solid var(--border2);
  border-radius:14px;cursor:pointer;transition:background .2s;flex-shrink:0;
}
.ptoggle-switch.monthly-active{background:rgba(255,255,255,0.14)}
.ptoggle-knob{
  position:absolute;top:3px;left:3px;
  width:20px;height:20px;border-radius:50%;
  background:#fff;transition:transform .25s cubic-bezier(.4,0,.2,1);
  box-shadow:0 1px 4px rgba(0,0,0,0.4);
}
.ptoggle-switch.monthly-active .ptoggle-knob{transform:translateX(24px)}
.ptoggle-save-pill{
  display:inline-flex;align-items:center;
  background:rgba(37,211,102,0.12);border:1px solid rgba(37,211,102,0.25);
  color:#25d366;font-size:0.58rem;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;padding:3px 8px;border-radius:20px;white-space:nowrap;
}

/* Grid */
.pricing-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
  border-radius:14px;overflow:hidden;
  margin-top:24px;margin-bottom:20px;
}
.price-card{
  background:var(--card);padding:28px 20px;
  position:relative;transition:background .18s;
  display:flex;flex-direction:column;
}
.price-card:hover{background:var(--card2)}

/* Featured (Professional) */
.price-card-featured{background:#fff;color:#000}
.price-card-featured:hover{background:rgba(255,255,255,0.96)}
.featured-badge{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  background:#000;color:#fff;font-size:0.55rem;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:3px 12px;border-radius:0 0 6px 6px;white-space:nowrap;
}
.price-card-featured .featured-badge{background:#000;color:#fff}

/* Tier label */
.price-tier{
  font-size:0.57rem;font-weight:700;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--muted);margin-bottom:8px;
}
.price-card-featured .price-tier{color:rgba(0,0,0,0.45)}

/* Tagline */
.price-tagline{
  font-size:0.71rem;color:var(--muted);font-style:italic;
  font-weight:300;margin-bottom:12px;line-height:1.4;
}
.price-card-featured .price-tagline{color:rgba(0,0,0,0.5)}

/* Price display */
.price-display{min-height:72px;margin-bottom:4px}
.price-amount{
  font-family:'DM Serif Display',serif;font-size:2.2rem;font-weight:400;
  color:var(--text);line-height:1;letter-spacing:-0.03em;
  transition:opacity .15s;
}
.price-card-featured .price-amount{color:#000}
.price-label{font-size:0.61rem;color:var(--subtle);font-weight:300;margin-bottom:14px}
.price-card-featured .price-label{color:rgba(0,0,0,0.35)}

/* Monthly alt price badge */
.price-monthly-alt{
  display:none;align-items:baseline;gap:5px;margin-bottom:3px;
}
.price-monthly-alt .pma-amount{
  font-family:'DM Serif Display',serif;font-size:2.2rem;
  color:var(--text);line-height:1;letter-spacing:-0.03em;
}
.price-card-featured .price-monthly-alt .pma-amount{color:#000}
.pma-per{font-size:0.62rem;color:var(--subtle);font-weight:300}
.price-card-featured .pma-per{color:rgba(0,0,0,0.4)}

/* Savings note */
.price-savings{
  display:none;
  font-size:0.62rem;color:#25d366;font-weight:600;margin-bottom:12px;
}
.price-card-featured .price-savings{color:#1a8f45}

/* Monthly active states */
.pricing-grid.show-monthly .price-display .price-amount{opacity:0.28}
.pricing-grid.show-monthly .price-display .price-label{opacity:0.28}
.pricing-grid.show-monthly .price-monthly-alt{display:flex}
.pricing-grid.show-monthly .price-savings{display:block}

/* Breakdown box */
.price-breakdown{
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:7px;padding:11px 13px;margin-bottom:14px;
}
.price-card-featured .price-breakdown{background:rgba(0,0,0,0.06);border-color:rgba(0,0,0,0.1)}
.pb-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.7rem;padding:3px 0;color:var(--muted);
}
.price-card-featured .pb-row{color:rgba(0,0,0,0.5)}
.pb-row:not(:last-child){border-bottom:1px solid rgba(255,255,255,0.05)}
.price-card-featured .pb-row:not(:last-child){border-bottom-color:rgba(0,0,0,0.07)}
.pb-row span:last-child{font-weight:600;color:var(--text)}
.price-card-featured .pb-row span:last-child{color:#000}
.pb-row em{font-style:normal;font-size:0.57rem;font-weight:400;color:var(--subtle);margin-left:4px}
.free{color:#25d366 !important}
.price-card-featured .free{color:#1a8f45 !important}

/* Feature list */
.price-list{list-style:none;margin-bottom:14px;flex:1}
.price-list li{
  font-size:0.73rem;color:var(--muted);padding:5px 0;
  border-bottom:1px solid rgba(255,255,255,0.04);
  display:flex;gap:8px;align-items:flex-start;line-height:1.45;
}
.price-card-featured .price-list li{color:rgba(0,0,0,0.55);border-bottom-color:rgba(0,0,0,0.06)}
.price-list li:last-child{border-bottom:none}
.price-list li::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--subtle);margin-top:5px;flex-shrink:0;
}
.price-card-featured .price-list li::before{background:rgba(0,0,0,0.3)}

/* Eg line */
.price-eg{font-size:0.66rem;color:var(--subtle);font-style:italic;margin-bottom:12px;line-height:1.4}
.price-card-featured .price-eg{color:rgba(0,0,0,0.3)}

/* CTA button */
.price-btn{
  display:block;text-align:center;padding:13px;border-radius:7px;
  font-size:0.77rem;font-weight:600;background:#fff;color:#000;
  transition:all .15s;margin-top:auto;cursor:pointer;border:none;
  font-family:'DM Sans',sans-serif;width:100%;
}
.price-btn:hover{background:rgba(255,255,255,0.88);transform:translateY(-1px)}
.price-btn-featured{background:#000;color:#fff}
.price-btn-featured:hover{background:rgba(0,0,0,0.85)}

/* Custom banner */
.custom-banner{
  position:relative;overflow:hidden;
  background:var(--card);border:1px solid var(--border2);border-radius:14px;
  padding:44px 48px;display:grid;grid-template-columns:1fr 1fr;
  gap:56px;align-items:center;margin-top:16px;
}
.custom-banner-glow{
  position:absolute;top:50%;left:40%;
  transform:translate(-50%,-50%);
  width:500px;height:300px;
  background:radial-gradient(ellipse,rgba(120,180,255,0.08) 0%,transparent 70%);
  pointer-events:none;
}
.cb-label{font-size:0.6rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--subtle);margin-bottom:10px}
.cb-title{font-family:'DM Serif Display',serif;font-size:clamp(1.6rem,2.6vw,2.2rem);color:var(--text);font-weight:400;line-height:1.1;letter-spacing:-0.02em;margin-bottom:14px}
.cb-title em{font-style:italic;color:rgba(242,240,235,0.55)}
.cb-desc{font-size:0.78rem;color:var(--muted);line-height:1.72;font-weight:300}
.cb-desc{font-size:0.78rem;color:var(--muted);line-height:1.72;font-weight:300}
.cb-examples{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px;margin-bottom:24px}
.cb-ex{display:flex;align-items:center;gap:8px;font-size:0.73rem;color:var(--muted);font-weight:300}
.cb-dot{width:4px;height:4px;border-radius:50%;background:var(--subtle);flex-shrink:0}
.cb-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:#000;border:none;
  padding:13px 28px;border-radius:7px;
  font-size:0.82rem;font-weight:700;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .18s;
}
.cb-cta:hover{background:rgba(255,255,255,0.88);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.4)}
.cb-cta span{opacity:0.5;font-size:0.78rem}

/* ── TEMPLATES ───────────────────────────────────────── */
.tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tpl-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;cursor:pointer;
  transition:all .25s;
}
.tpl-card:hover{transform:translateY(-6px);box-shadow:0 28px 60px rgba(0,0,0,0.5);border-color:var(--border2)}
.tpl-img-wrap{position:relative;height:200px;overflow:hidden;background:var(--card2)}
.tpl-img-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .45s ease;
  filter:brightness(0.6) saturate(0.8);
  display:block;
}
.tpl-card:hover .tpl-img-wrap img{transform:scale(1.06);filter:brightness(0.7) saturate(0.9)}
.tpl-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,0);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s;gap:8px;
}
.tpl-card:hover .tpl-overlay{background:rgba(0,0,0,0.5)}
.tpl-overlay-btn{
  background:rgba(255,255,255,0.95);color:#000;border:none;border-radius:6px;
  padding:10px 18px;font-size:0.74rem;font-weight:600;cursor:pointer;
  font-family:'DM Sans',sans-serif;
  opacity:0;transform:translateY(9px);transition:all .25s;
}
.tpl-card:hover .tpl-overlay-btn{opacity:1;transform:translateY(0)}
.tpl-select{background:#000;color:#fff}
.tpl-info{padding:16px 18px 18px}
.tpl-name{font-family:'DM Serif Display',serif;font-size:0.95rem;color:var(--text);margin-bottom:3px;font-weight:400}
.tpl-sub{font-size:0.66rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px}
.tpl-footer-row{display:flex;align-items:center;justify-content:space-between}
.tpl-badge{
  font-size:0.67rem;font-weight:600;color:var(--text);
  background:rgba(255,255,255,0.07);padding:3px 10px;
  border-radius:4px;border:1px solid var(--border);
}
.tpl-type-badge{
  position:absolute;top:12px;left:12px;
  font-size:0.6rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:4px;
  background:rgba(14,14,14,0.85);color:var(--text);
  border:1px solid rgba(255,255,255,0.14);backdrop-filter:blur(8px);
}
.tpl-badge-app{background:rgba(120,80,255,0.25);border-color:rgba(160,120,255,0.3);color:#c4a8ff}
.tpl-badge-store{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.2);color:#fff}

/* View all templates CTA */
.tpl-view-all{
  display:flex;align-items:center;justify-content:space-between;gap:28px;
  background:var(--card);border:1px solid var(--border2);
  border-radius:14px;padding:28px 36px;margin-top:16px;
}
.tva-left{flex:1}
.tva-count{font-family:'DM Serif Display',serif;font-size:1.6rem;color:var(--accent);margin-bottom:6px;font-weight:400}
.tva-text{font-size:0.78rem;color:var(--muted);line-height:1.65;font-weight:300}
.tva-btn{
  display:inline-flex;align-items:center;gap:9px;flex-shrink:0;
  background:#fff;color:#000;text-decoration:none;
  padding:14px 28px;border-radius:8px;
  font-size:0.82rem;font-weight:700;font-family:'DM Sans',sans-serif;
  transition:all .18s;white-space:nowrap;
}
.tva-btn:hover{background:rgba(255,255,255,0.88);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.4)}
@media(max-width:600px){
  .tpl-view-all{flex-direction:column;align-items:flex-start;gap:18px;padding:22px 18px}
  .tva-btn{width:100%;justify-content:center}
  .tva-count{font-size:1.3rem}
}

/* ── TRUST SECTION ───────────────────────────────────── */
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-radius:12px;overflow:hidden;margin-bottom:24px}
.trust-card{
  background:var(--card);padding:28px 26px;
  transition:background .18s;
}
.trust-card:hover{background:var(--card2)}
.trust-icon{
  width:40px;height:40px;border-radius:9px;
  background:rgba(255,255,255,0.06);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;color:var(--text);flex-shrink:0;
}
.trust-title{font-family:'DM Serif Display',serif;font-size:1rem;color:var(--text);margin-bottom:8px;font-weight:400;line-height:1.2}
.trust-desc{font-size:0.75rem;color:var(--muted);line-height:1.72;font-weight:300}

/* Process strip */
.process-strip{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  gap:0;align-items:center;
  background:var(--card);border:1px solid var(--border2);
  border-radius:12px;padding:28px 32px;
  margin-top:4px;
}
.process-step{padding:0 8px}
.ps-num{font-size:0.58rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--subtle);margin-bottom:7px}
.ps-title{font-family:'DM Serif Display',serif;font-size:0.95rem;color:var(--text);margin-bottom:6px;font-weight:400}
.ps-desc{font-size:0.72rem;color:var(--muted);line-height:1.6;font-weight:300}
.process-arrow{font-size:1.1rem;color:var(--subtle);padding:0 12px;align-self:center;flex-shrink:0}

/* ── ABOUT ───────────────────────────────────────────── */
.about-single{max-width:720px}
.about-single .about-p{font-size:0.86rem;color:var(--muted);line-height:1.78;font-weight:300;margin-bottom:18px}
.about-links{display:flex;flex-direction:column;gap:6px;margin-top:28px}
.about-link{
  display:inline-flex;align-items:center;gap:9px;
  padding:9px 12px;border:1px solid var(--border);border-radius:6px;
  color:var(--muted);font-size:0.75rem;transition:all .15s;cursor:pointer;
  background:none;font-family:'DM Sans',sans-serif;text-align:left;text-decoration:none;
}
.about-link:hover{background:rgba(255,255,255,0.05);color:var(--text);border-color:var(--border2)}

/* ── CONTACT ─────────────────────────────────────────── */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.contact-actions{display:flex;flex-direction:column;gap:10px;margin-top:32px;margin-bottom:28px}
.contact-btn-wa,.contact-btn-em{
  display:flex;align-items:center;gap:16px;padding:20px 22px;
  border-radius:10px;border:1px solid var(--border2);
  color:var(--text);transition:all .2s;cursor:pointer;
  font-family:'DM Sans',sans-serif;width:100%;text-align:left;
  background:var(--card);
}
.contact-btn-wa:hover{background:rgba(37,211,102,0.08);border-color:rgba(37,211,102,0.25);transform:translateX(4px)}
.contact-btn-em:hover{background:rgba(255,255,255,0.04);border-color:var(--border2);transform:translateX(4px)}
.contact-btn-icon{
  width:40px;height:40px;border-radius:8px;
  background:rgba(255,255,255,0.07);display:flex;align-items:center;
  justify-content:center;flex-shrink:0;
}
.cb-label-sm{font-size:0.61rem;text-transform:uppercase;letter-spacing:0.12em;color:rgba(242,240,235,0.55);margin-bottom:3px}
.cb-val-lg{font-size:0.92rem;font-weight:600}
.cb-arrow{margin-left:auto;opacity:0.22;font-size:1rem}
.soc-hd{font-size:0.6rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(242,240,235,0.5);margin-bottom:10px}
.soc-row{display:flex;flex-direction:column;gap:5px}
.soc-item{
  display:flex;align-items:center;gap:9px;
  padding:10px 14px;border-radius:7px;border:1px solid var(--border);
  text-decoration:none;color:var(--muted);font-size:0.78rem;
  transition:all .15s;
}
.soc-item:hover{background:rgba(255,255,255,0.04);color:var(--text);border-color:var(--border2)}
.soc-dot{width:5px;height:5px;border-radius:50%;background:var(--subtle);flex-shrink:0}
.soc-handle{font-size:0.71rem;opacity:0.35;margin-left:auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}

/* Contact form */
.contact-form-card{
  background:var(--card);border:1px solid var(--border2);
  border-radius:14px;padding:32px;
}
.form-head{
  font-family:'DM Serif Display',serif;font-size:1.3rem;
  color:var(--text);margin-bottom:24px;font-weight:400;
}
.form-fields{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.finput{
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:7px;padding:12px 14px;font-size:0.83rem;
  color:var(--text);font-family:'DM Sans',sans-serif;
  outline:none;transition:border .15s;width:100%;
}
.finput:focus{border-color:var(--border2)}
.finput::placeholder{color:var(--subtle)}
.fselect{cursor:pointer;background-color:rgba(255,255,255,0.04)}
.fselect option{background:#1a1a1a;color:var(--text)}
.ftextarea{resize:vertical;min-height:96px}
.form-btn{
  width:100%;padding:14px;background:#fff;color:#000;
  border:none;border-radius:7px;font-size:0.84rem;font-weight:600;
  cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .18s;
}
.form-btn:hover{background:rgba(255,255,255,0.88);transform:translateY(-1px)}
.form-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none}
.form-note{font-size:0.68rem;color:var(--subtle);text-align:center;margin-top:12px}
.form-status{border-radius:6px;padding:11px 14px;font-size:0.81rem;margin-bottom:14px}

/* ── STICKY BAR ──────────────────────────────────────── */
.sticky-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:99;
  padding:10px 14px;background:var(--card);border-top:1px solid var(--border);
  gap:10px;
}
.sbar-wa,.sbar-em{
  flex:1;display:flex;align-items:center;justify-content:center;
  gap:7px;padding:13px;border-radius:7px;
  font-size:0.82rem;font-weight:600;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .15s;
}
.sbar-wa{background:#fff;color:#000;border:none}
.sbar-wa:hover{background:rgba(255,255,255,0.88)}
.sbar-em{background:transparent;color:var(--text);border:1px solid var(--border2)}
.sbar-em:hover{background:rgba(255,255,255,0.05)}

@media(max-width:520px){
  .hero-stats{flex-direction:column;border-radius:8px}
  .hstat{padding:14px 18px;border-right:none;border-bottom:1px solid var(--border)}
  .hstat:last-child{border-bottom:none}
  .hstat-divider{display:none}
  .hstat-n{font-size:1.3rem}
}
/* ── FOOTER ──────────────────────────────────────────── */
footer{border-top:1px solid var(--border);background:var(--bg2)}
.footer-inner{
  max-width:1120px;margin:0 auto;padding:32px 52px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;
}
.f-brand{font-family:'DM Serif Display',serif;font-size:0.9rem;color:var(--text)}
.f-brand em{font-style:italic}
.f-tagline{font-size:0.66rem;color:var(--subtle);margin-top:2px}
.f-links{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.f-links a,.f-links button{
  font-size:0.67rem;color:var(--subtle);text-decoration:none;
  transition:color .15s;background:none;border:none;cursor:pointer;
  font-family:'DM Sans',sans-serif;padding:0;
}
.f-links a:hover,.f-links button:hover{color:var(--text)}
.f-copy{font-size:0.65rem;color:var(--subtle)}
.f-legal{display:flex;flex-direction:column;gap:5px;align-items:flex-end}
.f-legal-links{display:flex;align-items:center;gap:8px}
.f-legal-links a{font-size:0.62rem;color:var(--subtle);text-decoration:none;transition:color .15s}
.f-legal-links a:hover{color:var(--text)}
.f-legal-sep{font-size:0.55rem;color:rgba(242,240,235,0.18)}
@media(max-width:700px){.f-legal{align-items:flex-start}}

/* ── REVIEWS ─────────────────────────────────────────── */
.reviews-wrap{
  position:relative;
  margin-bottom:28px;
}
.reviews-track{
  display:flex;gap:18px;
  overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;-ms-overflow-style:none;
  padding-bottom:6px;padding-top:4px;padding-left:2px;
}
.reviews-track::-webkit-scrollbar{display:none}
.reviews-fade-l,.reviews-fade-r{
  position:absolute;top:0;bottom:6px;width:60px;pointer-events:none;z-index:2;
}
.reviews-fade-l{left:0;background:linear-gradient(to right,var(--bg2) 0%,transparent 100%);opacity:0}
.reviews-fade-r{right:0;background:linear-gradient(to left,var(--bg2) 0%,transparent 100%)}
.review-card{
  flex-shrink:0;width:340px;scroll-snap-align:start;
  background:var(--card);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:16px;padding:28px 26px;
  display:flex;flex-direction:column;gap:16px;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  position:relative;overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,0.3);
}
.review-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(0,220,255,0.5),transparent);
  opacity:0;transition:opacity .3s;
}
.review-card:hover{
  border-color:rgba(0,220,255,0.25);
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(0,0,0,0.5);
}
.review-card:hover::before{opacity:1}
.review-stars{display:flex;gap:4px}
.review-star-filled{color:#00dcff;font-size:1rem}
.review-star-empty{color:rgba(255,255,255,0.15);font-size:1rem}
.review-text{
  font-size:0.86rem;color:rgba(242,240,235,0.82);line-height:1.76;
  font-weight:400;flex:1;
}
.review-text::before{
  content:'\201C';font-family:'Georgia','DM Serif Display',serif;
  font-size:3rem;color:rgba(0,220,255,0.3);
  display:block;line-height:0.75;margin-bottom:12px;
  font-style:normal;
}
.review-author{
  display:flex;align-items:center;gap:12px;
  padding-top:14px;border-top:1px solid rgba(255,255,255,0.08);
}
.review-avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,rgba(0,220,255,0.15),rgba(0,220,255,0.04));
  border:1px solid rgba(0,220,255,0.2);
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:0.88rem;
  color:#00dcff;flex-shrink:0;
  letter-spacing:0.02em;
}
.review-name{font-size:0.82rem;font-weight:700;color:#fff}
.review-business{font-size:0.7rem;color:rgba(242,240,235,0.5);margin-top:2px;font-weight:400}
.reviews-empty{
  width:100%;padding:56px 24px;text-align:center;
  color:rgba(242,240,235,0.6);font-size:0.85rem;font-weight:300;
}

/* Reviews CTA bar */
.reviews-cta{margin-top:4px}
.reviews-cta-inner{
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg,rgba(0,220,255,0.06) 0%,rgba(0,220,255,0.02) 100%);
  border:1px solid rgba(0,220,255,0.2);
  border-radius:16px;padding:28px 36px;gap:24px;
  position:relative;overflow:hidden;
}
.reviews-cta-inner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 80% 50%,rgba(0,220,255,0.06),transparent 60%);
  pointer-events:none;
}
.reviews-cta-text{position:relative}
.reviews-cta-title{
  font-family:'DM Serif Display',serif;font-size:1.4rem;
  color:#fff;font-weight:400;margin-bottom:6px;line-height:1.2;
}
.reviews-cta-sub{font-size:0.78rem;color:rgba(242,240,235,0.65);font-weight:400;line-height:1.5}
.reviews-cta-btn{
  background:#00dcff;color:#000;border:none;border-radius:10px;
  padding:15px 30px;font-size:0.85rem;font-weight:800;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  transition:all .2s;white-space:nowrap;flex-shrink:0;
  position:relative;letter-spacing:0.01em;
  box-shadow:0 0 32px rgba(0,220,255,0.2);
}
.reviews-cta-btn:hover{
  background:#33e5ff;
  transform:translateY(-2px);
  box-shadow:0 8px 40px rgba(0,220,255,0.35);
}

/* Google review step 2 */
.rv-google-box{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);
  border-radius:10px;padding:16px;margin-bottom:4px;text-align:left;
}
.rv-google-copy-label{
  font-size:0.62rem;text-transform:uppercase;letter-spacing:0.12em;
  color:rgba(242,240,235,0.4);margin-bottom:8px;font-weight:600;
}
.rv-google-copy-text{
  font-size:0.8rem;color:rgba(242,240,235,0.75);line-height:1.65;
  margin-bottom:12px;font-style:italic;
}
.rv-copy-btn{
  background:#fff;color:#000;border:none;border-radius:6px;
  padding:8px 16px;font-size:0.75rem;font-weight:700;
  cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;
}
.rv-copy-btn:hover{background:rgba(255,255,255,0.88)}
.rv-copy-btn.copied{background:#00dcff;color:#000}
.rv-google-btn{
  background:#fff !important;color:#000 !important;
  font-weight:700;border-radius:8px;
}
.rv-google-btn:hover{background:rgba(255,255,255,0.9) !important;transform:translateY(-1px)}

/* Star rating input */
.rv-stars-wrap{
  display:flex;align-items:center;gap:14px;
  padding:12px 14px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:7px;
}
.rv-stars-label{font-size:0.78rem;color:rgba(242,240,235,0.7);font-weight:400}
.rv-stars{display:flex;gap:4px}
.rv-star{
  font-size:1.5rem;cursor:pointer;color:rgba(255,255,255,0.15);
  transition:color .1s,transform .12s;user-select:none;
}
.rv-star:hover,.rv-star.active{color:#00dcff;transform:scale(1.2)}

/* ── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:1100px){
  nav{padding:0 18px;gap:10px}
  .nav-links{display:none}
  .hero,.section{padding-left:20px;padding-right:20px}
  .strip-inner{padding:0 20px}
  .footer-inner{padding:24px 20px}
  .hero{padding-top:72px;padding-bottom:48px;min-height:auto}
  .scroll-cue{left:20px}
  .nav-hamburger{display:flex}
}
/* Mobile nav drawer */
.nav-hamburger{
  display:none;background:none;border:none;
  color:var(--text);cursor:pointer;padding:6px;
  flex-direction:column;gap:4px;align-items:center;justify-content:center;
  border-radius:6px;transition:background .15s;
}
.nav-hamburger:hover{background:rgba(255,255,255,0.07)}
.nav-hamburger span{
  display:block;width:18px;height:1.5px;
  background:var(--text);border-radius:2px;
  transition:transform .22s,opacity .22s;
}
.nav-hamburger.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
.mobile-nav-drawer{
  display:none;
  position:fixed;top:58px;left:0;right:0;bottom:0;
  background:rgba(8,8,8,0.97);backdrop-filter:blur(20px);
  z-index:99;flex-direction:column;padding:32px 24px;
  gap:4px;
  border-top:1px solid var(--border);
  overflow-y:auto;
}
.mobile-nav-drawer.open{display:flex}
.mobile-nav-item{
  display:flex;align-items:center;
  padding:15px 12px;
  font-size:1.1rem;font-family:'DM Serif Display',serif;
  color:var(--text);text-decoration:none;
  border-bottom:1px solid var(--border);
  transition:color .15s;
  background:none;border-left:none;border-right:none;border-top:none;
  cursor:pointer;font-weight:400;
  text-align:left;width:100%;
}
.mobile-nav-item:last-child{border-bottom:none}
.mobile-nav-item:hover{color:rgba(242,240,235,0.55)}
.mobile-nav-wa{
  display:flex;align-items:center;gap:10px;justify-content:center;
  background:#fff;color:#000;border:none;border-radius:8px;
  padding:16px;font-size:0.9rem;font-weight:700;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  margin-top:20px;transition:background .15s;
}
.mobile-nav-wa:hover{background:rgba(255,255,255,0.9)}
@media(max-width:1050px){
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .process-strip{grid-template-columns:1fr 1fr;gap:20px}
  .process-arrow{display:none}
  .pricing-toggle-wrap{flex-wrap:wrap;justify-content:center}
}
@media(max-width:700px){
  .process-strip{grid-template-columns:1fr;gap:0;padding:0;border-radius:10px}
  .process-step{
    padding:20px 22px;
    border-bottom:1px solid var(--border);
    position:relative;
  }
  .process-step:last-child{border-bottom:none}
}
@media(max-width:900px){
  /* Services grid: 2-col, last odd card spans full width */
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid .svc-card:last-child:nth-child(3n+1){grid-column:auto}
  .svc-grid .svc-card:last-child:nth-child(2n+1){grid-column:1/-1}
  /* Service image height */
  .svc-img-wrap{height:180px}
  /* Trust grid */
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .about-single{max-width:100%}
  /* Contact */
  .contact-wrap{grid-template-columns:1fr;gap:36px}
  /* Pricing custom banner */
  .custom-banner{grid-template-columns:1fr;gap:24px;padding:28px 24px}
  .cb-examples{grid-template-columns:1fr}
  /* Templates */
  .tpl-grid{grid-template-columns:repeat(2,1fr)}
  /* Strip (now removed but keep for safety) */
  .strip-inner{grid-template-columns:repeat(2,1fr)}
  .strip-item:nth-child(2){border-right:none}
  .strip-item:nth-child(3){border-right:1px solid var(--border)}
  .strip-item:nth-child(4){border-top:1px solid var(--border)}
  .strip-item:nth-child(4){border-right:none}
  /* Show sticky bar */
  .sticky-bar{display:flex}
  body{padding-bottom:80px}
  /* Reviews */
  .review-card{width:290px}
  .reviews-cta-inner{padding:22px 24px}
  /* Pricing grid: 2-col at tablet */
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  /* Section padding */
  .section{padding:72px 20px}
  .sec-title{font-size:clamp(1.9rem,5vw,2.8rem)}
  /* PC hero image */
  .pc-hero-img{height:220px;margin-bottom:36px}
}

@media(max-width:600px){
  /* ── Layout ── */
  .section{padding:56px 16px}
  .sec-head{margin-bottom:28px}
  .sec-title{font-size:1.85rem;line-height:1.08}
  .sec-sub{font-size:0.82rem}
  /* ── Services ── */
  .svc-grid{grid-template-columns:1fr}
  .svc-grid .svc-card:last-child:nth-child(2n+1){grid-column:auto}
  .svc-img-wrap{height:200px}
  .svc-body{padding:18px 18px 22px}
  .svc-title{font-size:1rem}
  /* ── Templates ── */
  .tpl-grid{grid-template-columns:1fr}
  /* ── Trust ── */
  .trust-grid{grid-template-columns:1fr}
  /* ── Pricing ── */
  .pricing-grid{grid-template-columns:1fr}
  .price-card{padding:22px 16px}
  .price-amount{font-size:1.95rem}
  .price-monthly-alt .pma-amount{font-size:1.95rem}
  .featured-badge{font-size:0.52rem}
  .pricing-toggle-wrap{gap:10px}
  .ptoggle-label{font-size:0.7rem}
  /* ── Custom banner ── */
  .custom-banner{padding:22px 18px;gap:20px}
  .cb-title{font-size:1.5rem}
  .cb-cta{width:100%;justify-content:center;padding:13px 20px}
  /* ── Hero ── */
  .hero{padding:68px 16px 48px}
  .hero-title{font-size:2.3rem;letter-spacing:-0.025em;line-height:0.97}
  .hero-sub{font-size:0.88rem;line-height:1.68}
  .hero-cta{flex-direction:column;gap:10px}
  .hero-cta .btn-primary,.hero-cta .btn-ghost{width:100%;justify-content:center}
  .btn-primary,.btn-ghost{padding:14px 20px;font-size:0.85rem}
  /* ── PC support ── */
  .pc-hero-img{height:175px;margin-bottom:28px;border-radius:8px}
  .pc-cats-grid{grid-template-columns:1fr}
  .pc-cats-grid-2{grid-template-columns:1fr}
  .pc-cat-card{padding:20px 18px 22px}
  /* ── Contact buttons ── */
  .contact-btn-wa,.contact-btn-em{padding:16px 14px;gap:12px}
  .cb-val-lg{font-size:0.84rem}
  .cb-arrow{display:none}
  /* ── Nav ── */
  .nav-wa span{display:none}
  /* ── Reviews ── */
  .review-card{width:calc(100vw - 52px)}
  .reviews-cta-inner{flex-direction:column;align-items:flex-start;gap:16px;padding:20px 18px}
  .reviews-cta-btn{width:100%;text-align:center;padding:14px}
  .reviews-cta-title{font-size:1.15rem}
  /* ── Footer ── */
  .footer-inner{flex-direction:column;align-items:flex-start;gap:20px}
  .f-links{gap:12px;flex-wrap:wrap}
  .f-legal{align-items:flex-start}
  /* ── Process ── */
  .process-strip{padding:0}
  .ps-title{font-size:0.9rem}
  .ps-desc{font-size:0.71rem}
  /* ── Strip (legacy safety) ── */
  .strip-inner{grid-template-columns:1fr}
  .strip-item{border-right:none}
  /* ── 3D section pricing ── */
  #3d-websites .pricing-grid{grid-template-columns:1fr}
  /* ── Modals ── */
  .modal{padding:26px 18px;border-radius:14px}
  .modal h3{font-size:1.2rem}
  .modal-overlay{padding:12px}
  /* ── Contact form ── */
  .contact-form-card{padding:22px 18px}
  /* ── About ── */
  .about-stat-num{font-size:1.9rem}
  .about-identity{padding:14px 14px;gap:12px}
  /* ── Template view-all ── */
  .tpl-view-all{flex-direction:column;align-items:flex-start;gap:16px;padding:20px 18px}
  .tva-btn{width:100%;justify-content:center}
  .tva-count{font-size:1.2rem}
}

/* Mobile touch - show overlay on tap by adding active state */
@media(hover:none){
  .tpl-card:active .tpl-overlay{background:rgba(0,0,0,0.6)}
  .tpl-card:active .tpl-overlay-btn{opacity:1;transform:translateY(0)}
  /* Always show preview hint text on mobile since hover doesn't exist */
  .tpl-footer-row::after{
    content:'Tap to preview';
    font-size:0.62rem;color:var(--subtle);font-weight:400;
  }
}

.reviews-view-all{
  text-align:center;padding:12px 0 4px;
}
.reviews-view-all-btn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.78rem;font-weight:600;color:#00dcff;
  text-decoration:none;letter-spacing:0.04em;
  border:1px solid rgba(0,220,255,0.25);
  padding:10px 22px;border-radius:7px;
  background:rgba(0,220,255,0.06);
  transition:all .18s;
}
.reviews-view-all-btn:hover{
  background:rgba(0,220,255,0.12);
  border-color:rgba(0,220,255,0.4);
  transform:translateX(3px);
}

/* ── HERO SPLIT LAYOUT ───────────────────────────── */
.hero-inner-split {
  display: flex;
  align-items: center;
  gap: 48px;
  padding-top: 58px;
}
.hero-text-col {
  flex: 1;
  min-width: 0;
}
.hero-img-col {
  flex-shrink: 0;
  width: clamp(280px, 36vw, 480px);
}
.hero-img-wrap {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 4/5;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
}
.hero-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Placeholder shown when image is missing */
.hero-img-wrap.hero-img-placeholder .hero-img-placeholder-label,
.hero-img-wrap:not(:has(img[style*="none"])) .hero-img-placeholder-label {
  display: flex;
}
.hero-img-placeholder-label {
  position: absolute;
  inset: 0;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: rgba(242,240,235,0.35);
  font-size: 0.78rem;
  text-align: center;
  line-height: 1.6;
  padding: 24px;
}
.hero-img-placeholder-label svg {
  opacity: 0.4;
}
.hero-img-placeholder-label code {
  font-size: 0.72rem;
  color: rgba(242,240,235,0.5);
  background: rgba(255,255,255,0.06);
  padding: 3px 8px;
  border-radius: 4px;
  font-family: monospace;
}
/* Always show placeholder label when img fails (onerror hides img + adds class) */
.hero-img-wrap.hero-img-placeholder .hero-img-placeholder-label {
  display: flex !important;
}

@media(max-width:860px){
  .hero-inner-split { flex-direction: column; gap: 32px; }
  .hero-img-col { width: 100%; max-width: 360px; margin: 0 auto; }
  .hero-img-wrap { aspect-ratio: 16/10; }
}
@media(max-width:480px){
  /* Hero */
  .hero{padding:64px 14px 40px}
  .hero-title{font-size:1.95rem;letter-spacing:-0.02em;line-height:0.97}
  .hero-sub{font-size:0.84rem;line-height:1.65}
  .btn-primary,.btn-ghost{padding:13px 18px;font-size:0.82rem}
  /* Sections */
  .section{padding:48px 14px}
  .sec-title{font-size:1.7rem}
  /* Services */
  .svc-img-wrap{height:160px}
  .svc-body{padding:16px 16px 20px}
  /* PC */
  .pc-hero-img{height:150px}
  .pc-cat-card{padding:18px 16px 20px}
  /* Custom banner */
  .custom-banner{padding:20px 16px}
  .cb-title{font-size:1.4rem}
  /* Pricing */
  .price-card{padding:20px 14px}
  .price-amount{font-size:1.8rem}
  .price-monthly-alt .pma-amount{font-size:1.8rem}
  .pricing-toggle-wrap{gap:8px}
  /* Reviews */
  .review-card{width:calc(100vw - 40px)}
  /* Sticky bar */
  body{padding-bottom:76px}
  .sticky-bar{padding:10px 12px}
  /* Footer */
  .footer-inner{padding:20px 14px}
  /* Nav */
  nav{padding:0 14px}
}

/* ── TEMPLATE PREVIEW PLACEHOLDER ───────────────── */
.tpl-preview-wrap { position: relative; }
.tpl-preview-placeholder {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 12px;
  height: 460px;
  border-radius: 8px;
  background: rgba(255,255,255,0.03);
  border: 1px dashed rgba(255,255,255,0.1);
  color: rgba(242,240,235,0.5);
  padding: 32px;
}
.tpl-preview-placeholder svg { opacity: 0.35; margin-bottom: 4px; }
.tpl-placeholder-title {
  font-family: 'DM Serif Display', serif;
  font-size: 1.2rem;
  color: var(--text);
}
.tpl-placeholder-sub {
  font-size: 0.8rem;
  line-height: 1.65;
  max-width: 380px;
  color: rgba(242,240,235,0.45);
}
.tpl-placeholder-sub strong { color: rgba(242,240,235,0.7); }

/* ── TEMPLATE PREVIEW IMAGE ─────────────────────── */
.tpl-preview-img {
  display: block;
  width: 100%;
  max-height: 620px;
  object-fit: contain;
  object-position: top;
  border-radius: 8px;
  background: #0e0e0e;
  border: 1px solid rgba(255,255,255,0.07);
}
/* ── 3D/4D SECTION ───────────────────────────────────── */
#3d-websites{background:var(--bg)}
.threed-video-wrap{
  margin:0 auto 8px;max-width:860px;
}
.threed-video-label{
  font-size:0.7rem;letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(0,220,255,0.7);margin-bottom:14px;font-weight:500;
}
.threed-video-container{
  width:100%;aspect-ratio:16/9;border-radius:16px;overflow:hidden;
  border:1px solid rgba(0,220,255,0.2);
  background:rgba(0,0,0,0.5);
  position:relative;
}
.threed-video-container video{
  width:100%;height:100%;border:none;display:block;
  object-fit:cover;
}
.threed-video-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:14px;
  cursor:pointer;z-index:3;
  background:rgba(0,0,0,0.25);
  transition:background .3s;
}
.threed-video-overlay:hover{background:rgba(0,0,0,0.1)}
.threed-video-overlay.hidden{display:none}
.threed-play-btn{
  filter:drop-shadow(0 0 24px rgba(0,220,255,0.4));
  transition:transform .2s,filter .2s;
}
.threed-video-overlay:hover .threed-play-btn{
  transform:scale(1.08);
  filter:drop-shadow(0 0 36px rgba(0,220,255,0.65));
}
.threed-play-label{
  font-size:1.05rem;font-family:'DM Serif Display',serif;
  color:rgba(242,240,235,0.92);letter-spacing:0.01em;
}
.threed-play-sub{
  font-size:0.7rem;color:rgba(0,220,255,0.65);
  letter-spacing:0.08em;text-transform:uppercase;font-weight:500;
}

/* ── REVIEW ARROWS ───────────────────────────────────── */
.reviews-arrow{
  display:none;
  position:absolute;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:rgba(0,220,255,0.12);border:1px solid rgba(0,220,255,0.3);
  color:rgba(0,220,255,0.9);font-size:1.1rem;
  cursor:pointer;z-index:5;
  align-items:center;justify-content:center;
  transition:background .2s;
  padding:0;line-height:1;
}
.reviews-arrow:hover{background:rgba(0,220,255,0.25)}
.reviews-arrow-l{left:-18px}
.reviews-arrow-r{right:-18px}
/* Swipe hint pill shown on mobile below the track */
.reviews-swipe-hint{
  display:none;
  align-items:center;justify-content:center;gap:6px;
  margin-top:10px;margin-bottom:2px;
  font-size:0.68rem;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(0,220,255,0.55);font-weight:500;
  animation:swipeHintPulse 2.2s ease-in-out infinite;
}
.reviews-swipe-hint svg{
  flex-shrink:0;
}
@keyframes swipeHintPulse{
  0%,100%{opacity:0.55;transform:translateX(0)}
  50%{opacity:1;transform:translateX(3px)}
}
@media(max-width:768px){
  .reviews-wrap{
    padding:0 2px;
  }
  .reviews-track{
    padding-left:40px;
    padding-right:40px;
  }
  .reviews-arrow{
    display:flex;
    width:34px;height:34px;font-size:1rem;
    background:rgba(6,6,10,0.82);
    backdrop-filter:blur(6px);
    border:1px solid rgba(0,220,255,0.35);
    box-shadow:0 2px 12px rgba(0,0,0,0.4);
  }
  .reviews-arrow-l{left:4px}
  .reviews-arrow-r{right:4px}
  .reviews-swipe-hint{display:flex}
}

/* ── VIDEO CONTROLS ──────────────────────────────────── */
.vid-controls{
  position:absolute;bottom:0;left:0;right:0;
  padding:0 14px 10px;
  background:linear-gradient(to top,rgba(0,0,0,0.75) 0%,transparent 100%);
  opacity:0;transition:opacity .25s;
  z-index:4;
}
.threed-video-container:hover .vid-controls,
.threed-video-container:focus-within .vid-controls{
  opacity:1;
}
/* Always show on mobile (no hover) */
@media(max-width:768px){
  .vid-controls{opacity:1}
}
.vid-progress-wrap{
  width:100%;padding:8px 0 6px;cursor:pointer;
}
.vid-progress-bg{
  width:100%;height:3px;border-radius:2px;
  background:rgba(255,255,255,0.2);
  position:relative;
}
.vid-progress-fill{
  height:100%;border-radius:2px;
  background:rgba(0,220,255,0.9);
  width:0%;transition:width .1s linear;
  pointer-events:none;
}
.vid-progress-thumb{
  position:absolute;top:50%;right:auto;
  width:11px;height:11px;border-radius:50%;
  background:#00dcff;
  transform:translate(-50%,-50%);
  left:0%;
  opacity:0;transition:opacity .2s;
  pointer-events:none;
  box-shadow:0 0 6px rgba(0,220,255,0.6);
}
.vid-progress-wrap:hover .vid-progress-bg{height:5px}
.vid-progress-wrap:hover .vid-progress-thumb{opacity:1}
.vid-bar{
  display:flex;align-items:center;
  justify-content:space-between;gap:8px;
}
.vid-bar-left,.vid-bar-right{
  display:flex;align-items:center;gap:4px;
}
.vid-btn{
  background:none;border:none;
  color:rgba(242,240,235,0.9);
  cursor:pointer;padding:5px;
  display:flex;align-items:center;justify-content:center;
  border-radius:6px;transition:color .15s,background .15s;
  line-height:1;
}
.vid-btn:hover{
  color:#00dcff;background:rgba(0,220,255,0.12);
}
.vid-time{
  font-size:0.68rem;color:rgba(242,240,235,0.7);
  font-variant-numeric:tabular-nums;letter-spacing:0.03em;
  white-space:nowrap;padding:0 4px;
  font-family:'DM Sans',sans-serif;
}

@media(max-width:480px){
  .vid-time{display:none}
  .vid-btn{padding:6px}
  .vid-controls{padding:0 10px 8px}
  .modal{padding:26px 18px;border-radius:14px}
  .modal h3{font-size:1.2rem}
  .modal-overlay{padding:12px}
}

/* ══════════════════════════════════════════════════════════
   PRICING — MONTHLY INCLUDES BLOCK
   ══════════════════════════════════════════════════════════ */

/* The includes block: hidden by default, shown in monthly mode */
.price-includes {
  display: none;
  margin-bottom: 12px;
}
.price-includes-label {
  font-size: 0.57rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 5px;
}
.price-card-featured .price-includes-label {
  color: rgba(0,0,0,0.4);
}
/* Show includes when monthly toggle is active */
.pricing-grid.show-monthly .price-includes {
  display: block;
}
/* In monthly mode, dim the breakdown box slightly — keep it visible */
.pricing-grid.show-monthly .price-breakdown {
  opacity: 0.55;
}
/* Style the includes list differently from features list */
.price-list-includes li::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: #25d366;
  margin-top: 5px;
  flex-shrink: 0;
}
.price-card-featured .price-list-includes li::before {
  background: #1a8f45;
}

/* ══════════════════════════════════════════════════════════
   FULL MOBILE OPTIMISATION — max-width: 600px
   Completely rewrites the phone layout for every section.
   Desktop styles above are untouched.
   ══════════════════════════════════════════════════════════ */

/* ── Scroll hint pill above carousel ────────────────────── */
.pricing-scroll-hint,
.pc-swipe-hint {
  display: none;
  text-align: center;
  font-size: 0.66rem;
  color: var(--subtle);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 6px;
  margin-bottom: -4px;
}

@media (max-width: 600px) {

  /* ── Global section padding ────────────────────────────── */
  .section { padding: 48px 16px 52px; }
  .sec-head { margin-bottom: 24px; }
  .sec-title { font-size: 1.75rem; line-height: 1.06; }
  .sec-sub { font-size: 0.81rem; line-height: 1.65; }
  .sec-eyebrow, .sec-label { font-size: 0.62rem; }

  /* ── Hero ──────────────────────────────────────────────── */
  .hero { padding: 64px 16px 44px; min-height: auto; }
  .hero-title { font-size: 2.1rem; letter-spacing: -0.025em; line-height: 0.96; }
  .hero-sub { font-size: 0.86rem; line-height: 1.65; margin-top: 14px; }
  .hero-cta { flex-direction: column; gap: 10px; margin-top: 22px; }
  .hero-cta .btn-primary, .hero-cta .btn-ghost { width: 100%; justify-content: center; padding: 14px 20px; }
  .btn-primary, .btn-ghost { font-size: 0.85rem; padding: 14px 20px; }

  /* ── Nav ───────────────────────────────────────────────── */
  .nav-wa span { display: none; }
  nav { padding: 0 14px; }

  /* ── Services — horizontal scroll carousel ─────────────── */
  .svc-grid {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 0;
    margin-left: -16px;
    margin-right: -16px;
    padding: 4px 16px 12px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .svc-grid::-webkit-scrollbar { display: none; }
  .svc-card {
    flex: 0 0 80vw !important;
    max-width: 300px !important;
    scroll-snap-align: start;
    margin-right: 10px;
    border-radius: 12px !important;
    grid-column: auto !important;
  }
  .svc-card:last-child { margin-right: 0; }
  .svc-img-wrap { height: 170px; }
  .svc-body { padding: 16px 16px 20px; }
  .svc-title { font-size: 0.95rem; }
  .svc-desc { font-size: 0.76rem; }

  /* ── Pricing section ───────────────────────────────────── */
  .pricing-scroll-hint,
  .pc-swipe-hint { display: block; }
  .pricing-toggle-wrap { gap: 10px; margin-top: 18px; margin-bottom: 2px; flex-wrap: wrap; justify-content: center; }
  .ptoggle-label { font-size: 0.7rem; }
  .ptoggle-save-pill { font-size: 0.57rem; }

  /* Pricing carousel */
  .pricing-grid {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch;
    gap: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    margin-left: -16px !important;
    margin-right: -16px !important;
    padding: 4px 16px 12px !important;
    scrollbar-width: none;
    -ms-overflow-style: none;
    margin-top: 16px !important;
    margin-bottom: 4px !important;
  }
  .pricing-grid::-webkit-scrollbar { display: none; }

  .price-card {
    flex: 0 0 82vw !important;
    max-width: 310px !important;
    scroll-snap-align: start !important;
    border-radius: 14px !important;
    border: 1px solid var(--border2) !important;
    margin-right: 10px !important;
    padding: 20px 16px 18px !important;
    background: var(--card) !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .price-card:last-child { margin-right: 0 !important; }
  .price-card-featured {
    background: #fff !important;
    color: #000 !important;
    border-color: transparent !important;
    box-shadow: 0 4px 28px rgba(0,0,0,0.35) !important;
  }
  .price-amount { font-size: 1.9rem !important; }
  .price-monthly-alt .pma-amount { font-size: 1.9rem !important; }
  .price-display { min-height: 52px !important; }
  .price-tier { margin-bottom: 4px; font-size: 0.56rem; }
  .price-tagline { font-size: 0.68rem; margin-bottom: 8px; }
  .price-savings { font-size: 0.6rem; margin-bottom: 8px; }
  .price-label { font-size: 0.59rem; }
  .price-breakdown { padding: 9px 11px; margin-bottom: 10px; }
  .pb-row { font-size: 0.67rem; padding: 3px 0; }
  .price-list li { font-size: 0.71rem; padding: 4px 0; }
  .price-list { margin-bottom: 10px; }
  .price-btn { padding: 12px; font-size: 0.78rem; }
  .featured-badge { font-size: 0.5rem; padding: 2px 10px; }

  /* Includes always visible on mobile */
  .price-includes { display: block !important; }
  .price-includes-label { margin-bottom: 4px; }
  .pricing-grid.show-monthly .price-breakdown { display: none; }

  /* Dot indicator */
  .pricing-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 10px;
    margin-bottom: 0;
  }
  .pricing-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--border2);
    transition: background 0.2s, transform 0.2s;
  }
  .pricing-dot.active {
    background: var(--text);
    transform: scale(1.35);
  }

  /* Custom banner */
  .custom-banner { grid-template-columns: 1fr !important; gap: 20px; padding: 22px 18px; }
  .cb-title { font-size: 1.45rem; }
  .cb-examples { grid-template-columns: 1fr; }
  .cb-cta { width: 100%; justify-content: center; padding: 13px 20px; }

  /* ── Templates carousel ────────────────────────────────── */
  .tpl-grid {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 0;
    margin-left: -16px;
    margin-right: -16px;
    padding: 4px 16px 12px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .tpl-grid::-webkit-scrollbar { display: none; }
  .tpl-card {
    flex: 0 0 78vw !important;
    max-width: 290px !important;
    scroll-snap-align: start;
    margin-right: 10px;
    border-radius: 12px;
    overflow: hidden;
  }
  .tpl-card:last-child { margin-right: 0; }
  .tpl-img-wrap { height: 180px; }
  .tpl-view-all {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    padding: 22px 20px 24px;
    margin-top: 12px;
    border-radius: 14px;
    border: 1px solid var(--border2);
    background: var(--card);
  }
  .tva-btn { width: 100%; justify-content: center; }
  .tva-count { font-size: 1.1rem; }

  /* ── PC Support section ────────────────────────────────── */
  .pc-hero-img { height: 165px; margin-bottom: 24px; border-radius: 8px; }

  /* Swipe hint for PC cards carousel */
  .pc-swipe-hint { display: block; }

  /* Both grids become a single unified horizontal carousel */
  .pc-cats-grid,
  .pc-cats-grid-2 {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    margin-left: -16px !important;
    margin-right: -16px !important;
    padding: 4px 16px 12px !important;
    scrollbar-width: none;
    -ms-overflow-style: none;
    grid-template-columns: none !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
  }
  .pc-cats-grid { margin-top: 8px !important; padding-bottom: 4px !important; }
  .pc-cats-grid-2 { padding-top: 0 !important; border-top: none !important; }
  .pc-cats-grid::-webkit-scrollbar,
  .pc-cats-grid-2::-webkit-scrollbar { display: none; }

  .pc-cat-card {
    flex: 0 0 76vw !important;
    max-width: 280px !important;
    scroll-snap-align: start;
    margin-right: 10px !important;
    padding: 18px 16px 20px !important;
    border-radius: 12px !important;
    border: 1px solid var(--border) !important;
  }
  .pc-cat-card:last-child { margin-right: 0 !important; }
  .pc-audience { flex-wrap: wrap; gap: 8px; }

  /* ── Process strip ─────────────────────────────────────── */
  .process-strip { grid-template-columns: 1fr !important; gap: 0; padding: 0; border-radius: 10px; }
  .process-step { padding: 18px 20px; border-bottom: 1px solid var(--border); }
  .process-step:last-child { border-bottom: none; }
  .process-arrow { display: none; }
  .ps-title { font-size: 0.9rem; }
  .ps-desc { font-size: 0.7rem; }

  /* ── Trust ─────────────────────────────────────────────── */
  .trust-grid { grid-template-columns: 1fr !important; }

  /* ── Reviews ───────────────────────────────────────────── */
  .review-card { width: calc(100vw - 48px); }
  .reviews-track { padding-left: 38px; padding-right: 38px; }
  .reviews-arrow { display: flex; width: 32px; height: 32px; font-size: 0.95rem; }
  .reviews-arrow-l { left: 4px; }
  .reviews-arrow-r { right: 4px; }
  .reviews-swipe-hint { display: flex; }
  .reviews-cta-inner { flex-direction: column; align-items: flex-start; gap: 16px; padding: 20px 18px; }
  .reviews-cta-btn { width: 100%; text-align: center; padding: 14px; }
  .reviews-cta-title { font-size: 1.1rem; }

  /* ── About ─────────────────────────────────────────────── */
  .about-layout { grid-template-columns: 1fr !important; gap: 28px; }
  .about-stats-col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
  .about-partners { grid-column: 1/-1; }
  .about-stat-num { font-size: 1.8rem; }
  .about-identity { padding: 13px 14px; gap: 11px; }
  .about-avatar-inner { width: 44px; height: 44px; font-size: 0.88rem; }

  /* ── Contact ───────────────────────────────────────────── */
  .contact-wrap { grid-template-columns: 1fr !important; gap: 32px; }
  .contact-btn-wa, .contact-btn-em { padding: 16px 14px; gap: 12px; }
  .cb-val-lg { font-size: 0.84rem; }
  .cb-arrow { display: none; }
  .contact-form-card { padding: 20px 16px; }

  /* ── 3D section ────────────────────────────────────────── */
  #3d-websites .pricing-grid { display: grid !important; grid-template-columns: 1fr !important; }
  #3d-websites .price-card { flex: none !important; max-width: none !important; margin-right: 0 !important; border-radius: 0 !important; border: none !important; }
  .threed-video-wrap { margin-bottom: 0; }

  /* ── Footer ────────────────────────────────────────────── */
  .footer-inner { flex-direction: column; align-items: flex-start; gap: 20px; }
  .f-links { gap: 12px; flex-wrap: wrap; }
  .f-legal { align-items: flex-start; }
  .footer-inner { padding: 24px 16px; }

  /* ── Sticky bar ────────────────────────────────────────── */
  body { padding-bottom: 76px; }
  .sticky-bar { display: flex; padding: 10px 12px; }

  /* ── Modals ────────────────────────────────────────────── */
  .modal { padding: 24px 16px; border-radius: 14px; }
  .modal h3 { font-size: 1.15rem; }
  .modal-overlay { padding: 12px; align-items: flex-end; }
  .modal { border-radius: 18px 18px 0 0; width: 100%; max-width: 100% !important; }

  /* ── Template modal ────────────────────────────────────── */
  .tpl-modal-back { display: flex; }
  .tpl-close-btn { display: none; }
  .tpl-modal-top { flex-wrap: wrap; gap: 12px; }
  .tpl-modal-btns { width: 100%; justify-content: space-between; }
  .tpl-modal-body { padding: 12px; }
  .tpl-modal-inner { border-radius: 14px; }

  /* ── Strip ─────────────────────────────────────────────── */
  .strip-inner { grid-template-columns: 1fr; }
  .strip-item { border-right: none; }
}

/* ── Very small (≤380px) ─────────────────────────────────── */
@media (max-width: 380px) {
  .price-card { flex: 0 0 88vw !important; }
  .price-amount { font-size: 1.7rem !important; }
  .price-monthly-alt .pma-amount { font-size: 1.7rem !important; }
  .svc-card { flex: 0 0 88vw !important; }
  .tpl-card { flex: 0 0 86vw !important; }
  .pc-cat-card { flex: 0 0 84vw !important; }
  .hero-title { font-size: 1.85rem; }
  .sec-title { font-size: 1.6rem; }
}

/* ── Dot indicators (hidden on desktop) ──────────────────── */
.pricing-dots, .services-dots, .templates-dots {
  display: none;
}
@media (max-width: 600px) {
  .pricing-dots, .services-dots, .templates-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 10px;
  }
}
