/* ===== TMKN SHARED CSS ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Outfit:wght@700;800;900&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img,video,iframe{max-width:100%;display:block}
svg{max-width:100%}
:root{
  --brand:#2d2d52;--brand-dark:#1e1e3a;--brand-accent:#5b5bd6;
  --brand-light:#f0f0f9;--brand-mid:#d8d8ee;
  --bg:#ffffff;--bg2:#f8f8fc;--bg3:#f0f0f8;
  --text:#14141e;--text2:#4a4a62;--text3:#8888a8;
  --border:#e4e4f0;--card:#ffffff;
  --radius:14px;--radius-lg:20px;--radius-xl:28px;
  --shadow:0 1px 3px rgba(45,45,82,.06),0 4px 16px rgba(45,45,82,.08);
  --shadow-h:0 4px 8px rgba(45,45,82,.06),0 16px 48px rgba(45,45,82,.14);
  --shadow-xl:0 8px 16px rgba(45,45,82,.08),0 32px 64px rgba(45,45,82,.18);
}
[data-theme=dark]{
  --brand:#3a3a72;--brand-accent:#7c7cf0;
  --brand-light:#1a1a2e;--brand-mid:#2a2a48;
  --bg:#0b0b12;--bg2:#0f0f1a;--bg3:#141420;
  --text:#eeeef8;--text2:#b0b0c8;--text3:#7070a0;
  --border:#252535;--card:#111118;
  --shadow:0 2px 8px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.4);
  --shadow-h:0 4px 16px rgba(0,0,0,.4),0 20px 56px rgba(0,0,0,.5);
}
html{scroll-behavior:smooth;scroll-padding-top:72px}
*,*::before,*::after{box-sizing:border-box;min-width:0}
body{font-family:'Inter','Segoe UI',sans-serif;background:var(--bg);color:var(--text);transition:background .3s,color .3s;overflow-wrap:break-word;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* PREMIUM ENHANCEMENTS */
::selection{background:var(--brand);color:#fff}
[data-theme=dark] ::selection{background:#6060a8;color:#fff}

/* SCROLLBAR */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}
[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg)}
[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--border);border:2px solid var(--bg)}
[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--text2)}


/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .65s ease,transform .65s ease}
.reveal-left{opacity:0;transform:translateX(-36px);transition:opacity .65s ease,transform .65s ease}
.reveal-right{opacity:0;transform:translateX(36px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* NAV */
.nav{
  background:var(--brand);display:flex;align-items:center;
  justify-content:space-between;padding:0 48px;height:64px;
  position:sticky;top:0;z-index:200;
  transition:box-shadow .3s,background .3s,height .3s,backdrop-filter .3s;
  width:100%;max-width:100%
}
.nav.scrolled{
  height:56px;box-shadow:0 1px 0 rgba(255,255,255,.06),0 8px 32px rgba(0,0,0,.24);
  background:rgba(30,30,58,0.94);backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%)
}
[data-theme=dark] .nav{background:#0d0d1c}
[data-theme=dark] .nav.scrolled{background:rgba(9,9,20,0.94)}
.nav.menu-active{backdrop-filter:none !important;-webkit-backdrop-filter:none !important;transition:none !important}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:1;min-width:0;overflow:hidden}
.logo-icon{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,255,255,.08));
  border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;
  justify-content:center;font-size:15px;font-weight:800;color:#fff;
  font-family:'Outfit',sans-serif;letter-spacing:-.5px
}
.logo-text{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.4px;white-space:nowrap;font-family:'Outfit',sans-serif}
.logo-text span{color:rgba(255,255,255,.45);font-weight:400;font-family:'Inter',sans-serif}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:0}
.nav-links{display:flex;gap:1px}
.nav-links a{
  font-size:13px;font-weight:500;color:rgba(255,255,255,.7);
  text-decoration:none;padding:7px 14px;border-radius:8px;
  transition:background .15s,color .15s;white-space:nowrap
}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.11);color:#fff}
.nav-sep{width:1px;height:20px;background:rgba(255,255,255,.12);margin:0 4px;flex-shrink:0}
.nav-btn{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.9);padding:5px 14px;border-radius:8px;
  font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;
  transition:background .15s
}
.nav-btn:hover{background:rgba(255,255,255,.15)}
.nav-icon-btn{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);width:34px;height:34px;border-radius:9px;
  cursor:pointer;font-size:14px;display:flex;align-items:center;
  justify-content:center;flex-shrink:0;transition:background .15s
}
.nav-icon-btn:hover{background:rgba(255,255,255,.18)}
.cta-nav{
  background:#fff;color:var(--brand);border:none;padding:8px 20px;
  border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;
  font-family:inherit;white-space:nowrap;transition:box-shadow .2s,transform .2s
}
.cta-nav:hover{box-shadow:0 4px 16px rgba(0,0,0,.2);transform:translateY(-1px)}

/* SECTIONS */
.sec{padding:96px 48px}
.sec-alt{background:var(--bg2)}
.sec-inner{max-width:1120px;margin:0 auto;width:100%}
.sec-header{text-align:center;margin-bottom:64px}
.sec-tag{
  display:inline-block;font-size:11px;text-transform:uppercase;
  letter-spacing:3px;color:var(--brand-accent);margin-bottom:12px;
  font-weight:700;opacity:1
}
[data-theme=dark] .sec-tag{color:var(--brand-accent)}
.sec-title{
  font-size:36px;font-weight:800;color:var(--text);margin-bottom:14px;
  letter-spacing:-.8px;line-height:1.15;font-family:'Outfit',sans-serif
}
.sec-sub{font-size:16px;color:var(--text3);max-width:560px;margin:0 auto;line-height:1.75}

/* CARDS COMMON */
.chk{width:16px;height:16px;border-radius:50%;background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.85}
[data-theme=dark] .chk{background:#4a4a8a}
/* Fix SVG icons inside light-background containers for dark mode */
[data-theme=dark] .pfc-icon svg,
[data-theme=dark] .srv-ico svg,
[data-theme=dark] .wvc-icon-light svg{filter:brightness(0) invert(1);opacity:.75}
.tag{font-size:11px;padding:3px 10px;border-radius:20px;background:var(--brand-light);color:var(--brand);border:.5px solid var(--brand-mid)}
[data-theme=dark] .tag{background:#1e1e30;border-color:#2e2e48;color:#a0a0cc}
.tags{display:flex;gap:6px;flex-wrap:wrap}

/* CONTACT BTNS */
.btn-email{
  display:inline-flex;align-items:center;gap:9px;background:var(--card);
  color:var(--text);padding:14px 28px;border-radius:12px;text-decoration:none;
  font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s;
  border:1px solid var(--border);box-shadow:var(--shadow)
}
.btn-email:hover{transform:translateY(-2px);box-shadow:var(--shadow-h)}
[data-theme=dark] .btn-email{background:#1a1a2e;color:#c0c0e8;border-color:#2a2a48}
.btn-wa{
  display:inline-flex;align-items:center;gap:9px;background:#22c55e;
  color:#fff;padding:14px 28px;border-radius:12px;text-decoration:none;
  font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s
}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(34,197,94,.35)}
.contact-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* PAGE HERO (inner pages) */
.page-hero{
  background:linear-gradient(135deg,var(--brand) 0%,#1e1e4a 100%);
  padding:72px 48px;text-align:center;
  position:relative;overflow:hidden
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none
}
[data-theme=dark] .page-hero{background:linear-gradient(135deg,#0d0d1c 0%,#12122a 100%)}
.breadcrumb{font-size:12px;color:rgba(255,255,255,.45);margin-bottom:16px;position:relative}
.breadcrumb a{color:rgba(255,255,255,.6);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:rgba(255,255,255,.9)}
.page-badge{
  display:inline-block;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.9);padding:5px 18px;border-radius:24px;font-size:12px;
  margin-bottom:16px;font-weight:600;letter-spacing:.5px;position:relative
}
.page-hero h1{
  font-size:40px;font-weight:800;color:#fff;margin-bottom:14px;
  letter-spacing:-.8px;font-family:'Outfit',sans-serif;position:relative
}
.page-hero p{font-size:16px;color:rgba(255,255,255,.65);max-width:560px;margin:0 auto;line-height:1.8;position:relative}

/* CTA STRIP */
.cta-strip{
  background:linear-gradient(135deg,var(--brand) 0%,#1e1e4a 100%);
  border-radius:24px;padding:72px 56px;text-align:center;
  position:relative;overflow:hidden
}
[data-theme=dark] .cta-strip{background:linear-gradient(135deg,#141428,#0f0f22);border:1px solid var(--border)}
.cta-strip::before{
  content:'';position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,91,214,.25) 0%,transparent 70%);
  top:-150px;right:-150px;pointer-events:none
}
.cta-strip::after{
  content:'';position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,91,214,.15) 0%,transparent 70%);
  bottom:-80px;left:-80px;pointer-events:none
}
.cta-strip h2{
  font-size:34px;font-weight:800;color:#fff;margin-bottom:12px;
  position:relative;font-family:'Outfit',sans-serif;letter-spacing:-.5px
}
[data-theme=dark] .cta-strip h2{color:#eeeef8}
.cta-strip p{font-size:16px;color:rgba(255,255,255,.62);margin-bottom:36px;position:relative;max-width:500px;margin-left:auto;margin-right:auto}
[data-theme=dark] .cta-strip p{color:#9090b8}

/* FOOTER */
.footer{
  background:linear-gradient(180deg,var(--brand) 0%,#1a1a3a 100%);
  padding:64px 48px 28px;
  border-top:1px solid rgba(255,255,255,0.06)
}
[data-theme=dark] .footer{
  background:linear-gradient(180deg,#0e0e20 0%,#080812 100%);
  border-top:1px solid rgba(255,255,255,0.04)
}
.footer-inner{
  max-width:960px;margin:0 auto 48px;
  display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:56px;align-items:start
}
.footer-brand .footer-logo{
  font-size:24px;font-weight:900;color:#fff;
  letter-spacing:-.8px;margin-bottom:12px;
  font-family:'Outfit',sans-serif
}
.footer-brand .footer-tagline{
  font-size:13px;color:rgba(255,255,255,.38);
  line-height:1.75;max-width:240px
}
.footer-links,.footer-contact-info{display:flex;flex-direction:column;gap:10px}
.footer-links-title{
  font-size:10px;text-transform:uppercase;letter-spacing:2.5px;
  color:rgba(255,255,255,0.25);font-weight:700;margin-bottom:6px
}
.footer-links a,.footer-contact-info a{
  font-size:13.5px;color:rgba(255,255,255,0.52);
  text-decoration:none;transition:color .18s;
  display:flex;align-items:center;gap:7px
}
.footer-links a:hover,.footer-contact-info a:hover{color:rgba(255,255,255,0.9)}
.footer-bottom{
  max-width:960px;margin:0 auto;
  border-top:1px solid rgba(255,255,255,0.07);
  padding-top:20px;text-align:center
}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.25);letter-spacing:.3px}
[data-theme=dark] .footer-bottom p{color:rgba(255,255,255,0.18)}
@media(max-width:768px){
  .footer{padding:48px 24px 24px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:36px}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:480px){
  .footer-inner{grid-template-columns:1fr;gap:28px}
}
/* ACCESSIBILITY */
:focus-visible{
  outline:2px solid #6060a8;outline-offset:3px;border-radius:4px
}
[data-theme=dark] :focus-visible{outline-color:#9090c8}

/* BACK LINK */
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--brand);text-decoration:none;font-size:13px;margin-bottom:32px;font-weight:500}
[data-theme=dark] .back-link{color:#9090c8}

/* FAQ */
.faq-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:var(--brand)}
.faq-q{padding:18px 22px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;user-select:none}
.faq-icon{font-size:18px;color:var(--brand);transition:transform .3s;flex-shrink:0}
[data-theme=dark] .faq-icon{color:#9090c8}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{font-size:13px;color:var(--text2);line-height:1.75;max-height:0;overflow:hidden;transition:max-height .5s ease,padding .4s ease;padding:0 22px}
.faq-item.open .faq-a{max-height:400px;padding:0 22px 18px}

/* INNER PAGE CONTENT */
.content{max-width:900px;margin:0 auto;padding:60px 36px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:56px;align-items:start}
.sec-h{font-size:20px;font-weight:600;color:var(--brand);margin-bottom:16px}
[data-theme=dark] .sec-h{color:#9090c8}
.sec-p{font-size:14px;color:var(--text2);line-height:1.85;margin-bottom:12px}
.feat-list{list-style:none}
.feat-list li{font-size:14px;color:var(--text2);padding:8px 0;display:flex;align-items:flex-start;gap:10px;border-bottom:0.5px solid var(--border)}
.feat-list li:last-child{border-bottom:none}
.usecase-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:56px}
.usecase-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:20px;text-align:center;transition:border-color .2s,transform .2s}
.usecase-card:hover{border-color:var(--brand);transform:translateY(-3px)}
.usecase-icon{font-size:26px;margin-bottom:8px}
.usecase-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}
.usecase-desc{font-size:12px;color:var(--text3);line-height:1.5}

/* INNER PAGE CTA STRIP (smaller, used inside content pages) */
.cta-strip-sm{background:var(--brand);border-radius:14px;padding:36px;text-align:center}
[data-theme=dark] .cta-strip-sm{background:#1a1a2e;border:1px solid var(--border)}
.cta-strip-sm h3{font-size:20px;font-weight:600;color:#fff;margin-bottom:8px}
[data-theme=dark] .cta-strip-sm h3{color:#e8e8f8}
.cta-strip-sm p{font-size:13px;color:rgba(255,255,255,0.65);margin-bottom:20px}
[data-theme=dark] .cta-strip-sm p{color:#a0a0c0}
.cta-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.btn-w{display:inline-flex;align-items:center;gap:6px;background:#fff;color:var(--brand);padding:10px 22px;border-radius:8px;text-decoration:none;font-size:13px;font-weight:600;transition:transform .2s,box-shadow .2s}
.btn-w:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.15)}
[data-theme=dark] .btn-w{background:#2a2a48;color:#c0c0e8}

/* RICH SERVICES LAYOUT */
.srv-row{display:flex;align-items:center;gap:72px;margin-bottom:112px}
.srv-row:last-child{margin-bottom:0}
[dir=rtl] .srv-row{flex-direction:row-reverse}
[dir=rtl] .srv-row.rev{flex-direction:row}
[dir=ltr] .srv-row.rev{flex-direction:row-reverse}
.srv-img-wrap{
  flex:1;position:relative;border-radius:28px;overflow:hidden;
  box-shadow:var(--shadow-h)
}
.srv-img-wrap::after{
  content:'';position:absolute;inset:0;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
  border-radius:28px;pointer-events:none
}
.srv-img-wrap img{
  width:100%;height:auto;aspect-ratio:16/11;object-fit:cover;
  transition:transform .7s cubic-bezier(0.2,0.8,0.2,1)
}
.srv-row:hover .srv-img-wrap img{transform:scale(1.04)}
.srv-text{flex:1;display:flex;flex-direction:column}
.srv-text .srv-ico{
  width:60px;height:60px;border-radius:18px;background:var(--brand-light);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:28px;color:var(--brand);box-shadow:0 0 0 1px var(--brand-mid)
}
[data-theme=dark] .srv-text .srv-ico{
  background:var(--bg3);color:var(--brand-accent);
  box-shadow:inset 0 0 0 1px var(--border)
}
.srv-text h3{
  font-size:30px;font-weight:800;color:var(--text);margin-bottom:16px;
  letter-spacing:-.6px;line-height:1.2;font-family:'Outfit',sans-serif
}
.srv-text p{font-size:16px;color:var(--text2);line-height:1.8;margin-bottom:28px}
.srv-text .btn-outline{
  display:inline-flex;align-items:center;gap:9px;padding:13px 26px;
  border:1.5px solid var(--border);border-radius:12px;text-decoration:none;
  font-size:14px;font-weight:600;color:var(--text);
  transition:all .2s;align-self:flex-start;background:var(--card);
  box-shadow:var(--shadow)
}
.srv-text .btn-outline:hover{
  border-color:var(--brand-accent);background:var(--brand-accent);color:#fff;
  box-shadow:0 8px 24px rgba(91,91,214,.3)
}
[data-theme=dark] .srv-text .btn-outline:hover{border-color:var(--brand-accent);background:var(--brand-accent)}


/* ABOUT SECTION (in index.html) */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:stretch}
.about-text{display:flex;flex-direction:column}
.about-text .sec-tag{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:2.5px;color:var(--brand);opacity:.75;margin-bottom:10px;font-weight:600}
[data-theme=dark] .about-text .sec-tag{color:#9090c8;opacity:1}
.about-text .sec-title{font-size:32px;font-weight:700;color:var(--text);margin-bottom:16px;letter-spacing:-.5px}
.about-text .about-desc{font-size:14px;color:var(--text2);line-height:1.85;margin-bottom:14px}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:auto;padding-top:14px}
.av-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px 16px;transition:border-color .2s,transform .2s}
.av-card:hover{border-color:var(--brand);transform:translateY(-2px)}
.av-icon{font-size:22px;margin-bottom:8px}
.av-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}
.av-desc{font-size:12px;color:var(--text3);line-height:1.55}
.about-side{display:flex;flex-direction:column;gap:14px}
.about-stat-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px 24px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);transition:border-color .2s;flex:1}
.about-stat-card:hover{border-color:var(--brand)}
.asc-icon{width:46px;height:46px;border-radius:12px;background:var(--brand);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}
.asc-body strong{display:block;font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
.asc-body span{font-size:12px;color:var(--text3);line-height:1.5}

/* HAMBURGER BUTTON */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px 4px;background:none;border:none;flex-shrink:0}
.nav-hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.9);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* MOBILE MENU BACKDROP */
.mobile-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:490;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);opacity:0;transition:opacity .3s}
.mobile-backdrop.active{display:block;opacity:1}

/* MOBILE DRAWER CLOSE BUTTON */
.mobile-close{display:none;position:absolute;top:18px;inset-inline-end:16px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);color:#fff;font-size:18px;cursor:pointer;line-height:1;z-index:1;width:34px;height:34px;border-radius:8px;align-items:center;justify-content:center}
.mobile-close:hover{background:rgba(255,255,255,0.22)}

/* ===== LARGE TABLET / SMALL DESKTOP (max 900px) ===== */
@media(max-width:900px){
  /* NAV */
  .nav{padding:12px 16px}
  .nav-hamburger{display:flex}
  .nav-sep{display:none}
  .cta-nav{display:none}

  /* NAV LINKS → slide-in drawer from the side */
  .nav-links{
    display:flex;
    position:fixed;
    top:0;
    inset-inline-end:-320px;
    width:300px;
    max-width:85vw;
    height:100dvh;
    z-index:500;
    background:var(--brand);
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:4px;
    padding:72px 16px 32px;
    transition:inset-inline-end .32s cubic-bezier(.4,0,.2,1);
    box-shadow:-4px 0 32px rgba(0,0,0,0.3);
    overflow-y:auto;
  }
  [data-theme=dark] .nav-links{background:#0d0d1a}
  .nav-links.mobile-open{
    inset-inline-end:0;
  }
  .nav-links a{
    font-size:15px !important;
    padding:12px 16px !important;
    color:rgba(255,255,255,.85) !important;
    width:100%;
    text-align:start;
    border-radius:10px;
    border-bottom:1px solid rgba(255,255,255,0.06);
  }
  .nav-links a:last-child{border-bottom:none}
  .nav-links a:hover,.nav-links a.active{
    background:rgba(255,255,255,.13) !important;
    color:#fff !important;
  }
  .mobile-close{display:flex}

  /* SECTIONS */
  .sec{padding:56px 24px}
  .sec-title{font-size:26px}
  .sec-sub{font-size:14px}

  /* PAGE HERO */
  .page-hero{padding:44px 24px}
  .page-hero h1{font-size:26px}

  /* CTA STRIP */
  .cta-strip{padding:40px 24px}
  .cta-strip h2{font-size:22px}
  .cta-strip p{font-size:14px}

  /* INNER PAGE CONTENT */
  .content{padding:40px 24px}
  .two-col{grid-template-columns:1fr}

  /* ABOUT */
  .about-grid{grid-template-columns:1fr}
  .about-text .sec-title{font-size:26px}
  .about-values{grid-template-columns:1fr 1fr}

  /* RICH SERVICES */
  .srv-row{flex-direction:column;gap:32px;margin-bottom:64px}
  .srv-row.rev{flex-direction:column}
  .srv-text h3{font-size:24px}


  /* USE CASES */
  .usecase-grid{grid-template-columns:1fr 1fr}

  /* CTA STRIP SM */
  .cta-strip-sm{padding:28px 20px}
  .cta-strip-sm h3{font-size:18px}

  /* CONTACT BUTTONS */
  .contact-btns{flex-direction:column;align-items:center}
  .btn-email,.btn-wa{width:100%;max-width:320px;justify-content:center}

  /* Suppress large decorative circles on mobile to prevent overflow */
  .cta-strip::before{display:none}
}

/* ===== TABLET (max 768px) ===== */
@media(max-width:768px){
  .reveal-left,.reveal-right{transform:translateY(36px)}
  .sec{padding:48px 20px}
  .sec-title{font-size:24px}
  .about-side{display:grid;grid-template-columns:1fr 1fr;gap:12px}

  /* CTA BUTTONS */
  .cta-btns{flex-direction:column;align-items:center}
  .btn-w{width:100%;max-width:320px;justify-content:center}
}

/* ===== MOBILE (max 480px) ===== */
@media(max-width:480px){
  /* === GLOBAL OVERFLOW PREVENTION === */
  img,svg,video,canvas,iframe,table{
    max-width:100%;
  }

  /* NAV */
  .nav{padding:10px 14px;gap:8px}
  .nav-right{gap:6px}
  .logo-text{font-size:14px}
  .logo-icon{width:26px;height:26px;font-size:11px}
  .nav-btn{padding:4px 10px;font-size:11px}
  .nav-icon-btn{width:28px;height:28px;font-size:13px}

  /* SECTIONS */
  .sec{padding:40px 16px}
  .sec-inner{padding:0}
  .sec-title{font-size:22px;text-align:center}
  .sec-sub{font-size:13px;text-align:center}
  .sec-header{margin-bottom:36px}
  .sec-tag{display:block;text-align:center}

  /* PAGE HERO */
  .page-hero{padding:36px 16px;text-align:center}
  .page-hero h1{font-size:22px}
  .page-hero p{font-size:13px}
  .breadcrumb{justify-content:center}

  /* ABOUT */
  .about-text .sec-title{text-align:center}
  .about-text .sec-tag{text-align:center;display:block}
  .about-desc{text-align:center}
  .about-values{grid-template-columns:1fr 1fr;gap:10px}
  .about-side{grid-template-columns:1fr}
  .about-stat-card{padding:16px 14px;gap:12px}
  .asc-icon{width:38px;height:38px;font-size:17px}
  .asc-body strong{font-size:13px}
  .asc-body span{font-size:11px}

  /* USE CASES */
  .usecase-grid{grid-template-columns:1fr}
  .usecase-card{padding:18px}

  /* INNER PAGE */
  .content{padding:32px 16px}
  .two-col{gap:28px}
  .sec-h{text-align:center}

  /* RICH SERVICES */
  .srv-row{gap:24px;margin-bottom:48px}
  .srv-text .srv-ico{width:48px;height:48px;margin-bottom:16px;border-radius:12px}
  .srv-text h3{font-size:22px;margin-bottom:12px}
  .srv-text p{font-size:14px;margin-bottom:20px}
  .srv-text .btn-outline{width:100%;justify-content:center}

  /* FAQ */

  .faq-list{gap:10px}
  .faq-q{font-size:13px;padding:14px 16px}
  .faq-a{font-size:13px;padding:0 16px}
  .faq-item.open .faq-a{padding:0 16px 16px}

  /* CTA STRIP */
  .cta-strip{padding:32px 16px;text-align:center}
  .cta-strip h2{font-size:20px}
  .cta-strip::before{display:none}
  .btn-email,.btn-wa{width:100%;justify-content:center;padding:13px 20px}
  .contact-btns{flex-direction:column;align-items:stretch;gap:10px}

  /* VALUE CARDS equal height */
  .av-card,.usecase-card,.tg-card,.feat-card,.srv-card{
    height:auto;
    min-height:unset;
  }

  /* INNER PAGE CTA */
  .cta-strip-sm{padding:28px 16px;border-radius:12px}
  .cta-strip-sm h3{font-size:17px}
  .cta-btns{flex-direction:column;align-items:stretch;gap:10px}
  .btn-w{justify-content:center;width:100%}
}

/* ===== SCROLL PROGRESS BAR ===== */
#scrollProgress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:9999;
  background:linear-gradient(90deg,var(--brand-accent),#a78bfa);
  transition:width .1s linear;pointer-events:none;
  border-radius:0 2px 2px 0;
  box-shadow:0 0 8px rgba(91,91,214,.5);
}

/* ===== BACK TO TOP ===== */
#backToTop{
  position:fixed;bottom:28px;inset-inline-end:28px;z-index:800;
  width:44px;height:44px;border-radius:14px;
  background:var(--brand-accent);color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(91,91,214,.4);
  opacity:0;transform:translateY(16px);
  transition:opacity .3s,transform .3s,background .2s;
  pointer-events:none;
}
#backToTop.visible{opacity:1;transform:translateY(0);pointer-events:auto}
#backToTop:hover{background:var(--brand);transform:translateY(-3px);box-shadow:0 8px 28px rgba(91,91,214,.5)}
[data-theme=dark] #backToTop{background:#5b5bd6;box-shadow:0 4px 24px rgba(91,91,214,.35)}
[data-theme=dark] #backToTop:hover{background:#6e6ee8}

/* ===== PAGE TRANSITIONS ===== */
body{transition:opacity .28s ease,transform .28s ease}
body.page-entering{opacity:0;transform:translateY(10px)}
body.page-entered{opacity:1;transform:translateY(0)}
body.page-leaving{opacity:0;transform:translateY(-8px)}

/* ===== FOCUS / ACCESSIBILITY ===== */
:focus-visible{
  outline:2px solid #6060a8;outline-offset:3px;border-radius:4px;
}
a:focus-visible,button:focus-visible{outline:2px solid rgba(255,255,255,0.7);outline-offset:2px}

/* ===== TOAST NOTIFICATION ===== */
#formToast{
  position:fixed;bottom:80px;inset-inline-end:24px;z-index:900;
  background:#22c55e;color:#fff;padding:14px 22px;border-radius:12px;
  font-size:14px;font-weight:600;box-shadow:0 8px 28px rgba(34,197,94,0.35);
  transform:translateY(20px) scale(.95);opacity:0;
  transition:all .35s cubic-bezier(.4,0,.2,1);pointer-events:none;
}
#formToast.show{transform:translateY(0) scale(1);opacity:1}

/* ===== CONTACT FORM ===== */
.contact-form-wrap{
  max-width:620px;margin:0 auto;background:var(--card);
  border:1px solid var(--border);border-radius:20px;padding:40px;
}
[data-theme=dark] .contact-form-wrap{background:var(--bg2)}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cf-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.cf-field label{font-size:13px;font-weight:600;color:var(--text2)}
.cf-field input,.cf-field textarea,.cf-field select{
  background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  padding:12px 14px;font-size:14px;color:var(--text);font-family:inherit;
  transition:border-color .2s,box-shadow .2s;outline:none;width:100%;
}
.cf-field input:focus,.cf-field textarea:focus,.cf-field select:focus{
  border-color:var(--brand);box-shadow:0 0 0 3px rgba(50,50,84,0.1);
}
[data-theme=dark] .cf-field input,[data-theme=dark] .cf-field textarea,[data-theme=dark] .cf-field select{
  background:#1a1a2a;border-color:#2a2a3a;color:#e8e8f8;
}
[data-theme=dark] .cf-field input:focus,[data-theme=dark] .cf-field textarea:focus{
  border-color:#6060a8;box-shadow:0 0 0 3px rgba(96,96,168,0.15);
}
.cf-field textarea{resize:vertical;min-height:110px}
.cf-submit{
  width:100%;padding:14px;background:var(--brand);color:#fff;
  border:none;border-radius:10px;font-size:15px;font-weight:700;
  cursor:pointer;font-family:inherit;transition:background .2s,transform .2s,box-shadow .2s;
  margin-top:4px;
}
.cf-submit:hover{background:var(--brand-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(50,50,84,0.3)}
.cf-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
@media(max-width:600px){
  .cf-row{grid-template-columns:1fr}
  .contact-form-wrap{padding:28px 20px}
}

/* ===== HOW WE WORK / PROCESS ===== */
.process-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;counter-reset:step;
}
.process-grid::before{
  content:'';position:absolute;top:28px;left:12%;right:12%;height:2px;
  background:linear-gradient(90deg,var(--brand-mid),var(--brand-mid));
  z-index:0;
}
[dir=rtl] .process-grid::before{left:12%;right:12%}
.proc-step{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:0 20px;position:relative;z-index:1;
}
.proc-num{
  width:60px;height:60px;border-radius:50%;background:var(--brand-accent);
  color:#fff;font-size:20px;font-weight:900;display:flex;align-items:center;
  justify-content:center;margin-bottom:20px;border:4px solid var(--bg);
  box-shadow:0 0 0 2px var(--brand-accent);position:relative;
  transition:transform .3s,box-shadow .3s;
  font-family:'Outfit',sans-serif
}
.proc-step:hover .proc-num{transform:scale(1.12);box-shadow:0 0 0 2px var(--brand-accent),0 8px 28px rgba(91,91,214,.35)}
[data-theme=dark] .proc-num{border-color:var(--bg2)}
.proc-icon{font-size:26px;margin-bottom:14px}
.proc-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px;font-family:'Outfit',sans-serif}
.proc-desc{font-size:13px;color:var(--text3);line-height:1.65}
@media(max-width:768px){
  .process-grid{grid-template-columns:1fr 1fr;gap:32px}
  .process-grid::before{display:none}
}
@media(max-width:480px){
  .process-grid{grid-template-columns:1fr;gap:24px}
  .proc-step{flex-direction:row;text-align:start;gap:16px;align-items:flex-start}
  [dir=ltr] .proc-step{text-align:left}
  .proc-num{flex-shrink:0;margin-bottom:0}
  .proc-body{display:flex;flex-direction:column}
}

/* ===== FAVICON SVG helper ===== */
/* (favicon.svg served separately) */

