/* ------------------------------------------------------------------
   My NonStop Enterprise — Shared site chrome (nav / footer / wa fab)
   ------------------------------------------------------------------ */

@import url("../colors_and_type.css");

html,body{margin:0;background:var(--brand-paper);overflow-x:hidden;}

/* --- i18n: only show the active language --- */
[data-i18n]{display:none;}
html[lang="en"] [data-i18n="en"],
html[lang="zh"] [data-i18n="zh"],
html[lang="ms"] [data-i18n="ms"]{display:revert;}
/* helpers for inline use inside text */
html[lang="zh"] .if-zh-block,
html[lang="en"] .if-en-block,
html[lang="ms"] .if-ms-block{display:block;}
.if-zh-block,.if-en-block,.if-ms-block{display:none;}
html[lang="zh"] body{font-family:var(--font-cjk),var(--font-sans);}

/* --- Nav --- */
.nav{position:sticky;top:0;z-index:30;background:rgba(246,247,251,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav-in{max-width:1320px;margin:0 auto;padding:0 32px;height:72px;display:flex;align-items:center;gap:32px;}
.nav a{color:var(--fg-2);font-size:14px;text-decoration:none;font-weight:500;transition:color .15s;}
.nav a:hover{color:var(--fg);}
.nav .links{display:flex;gap:26px;margin-left:8px;align-items:center;}
.nav .links a.active{color:var(--brand-ink);font-weight:600;position:relative;}
.nav .links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-26px;height:2px;background:var(--brand-violet);}
.nav .cta{margin-left:auto;display:flex;gap:10px;align-items:center;}
.nav .logo img{height:36px;display:block;}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:12px;font-weight:600;font-size:14px;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:all .2s var(--ease-out);font-family:inherit;line-height:1;}
.btn-pri{background:var(--brand-ink);color:#fff;}
.btn-pri:hover{background:#1a2350;transform:translateY(-1px);}
.btn-violet{background:linear-gradient(135deg,var(--brand-violet),#5232d6);color:#fff;}
.btn-violet:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(107,69,244,.32);}
.btn-wa{background:#25D366;color:#fff;}
.btn-wa:hover{background:#1fbc59;transform:translateY(-1px);box-shadow:0 8px 20px rgba(37,211,102,.32);}
.btn-mail{background:var(--brand-ink);color:#fff;}
.btn-mail:hover{background:#1a2350;}
.btn-ghost{color:var(--fg);border-color:var(--line-strong);background:#fff;}
.btn-ghost:hover{background:var(--surface-2);}
.btn-lg{padding:14px 22px;font-size:15px;border-radius:14px;}

/* --- Language switch (in nav) --- */
.lang-switch{display:inline-flex;background:var(--surface-2);border-radius:11px;padding:3px;gap:2px;}
.lang-switch button{border:0;background:transparent;padding:7px 10px;border-radius:8px;font-weight:600;font-size:12px;font-family:inherit;cursor:pointer;color:var(--fg-3);transition:all .2s;letter-spacing:.02em;}
.lang-switch button.on{background:#fff;color:var(--brand-ink);box-shadow:var(--shadow-1);}
.lang-switch button:hover:not(.on){color:var(--fg);}

/* --- WhatsApp floating fab --- */
.wa-fab{position:fixed;right:26px;bottom:26px;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 32px rgba(37,211,102,.45);cursor:pointer;z-index:40;color:#fff;text-decoration:none;}
.wa-fab svg{width:30px;height:30px;}
.wa-fab::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid #25D366;animation:ns-pulse 1.8s var(--ease-out) infinite;}

/* --- Back to top --- */
.to-top{position:fixed;left:26px;bottom:26px;width:48px;height:48px;border-radius:50%;background:var(--brand-ink,#0B1240);color:#fff;border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:60;box-shadow:0 10px 26px rgba(11,18,64,.32);opacity:0;visibility:hidden;transform:translateY(12px) scale(.9);transition:opacity .28s var(--ease-out),transform .28s var(--ease-out),background .2s;}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0) scale(1);}
.to-top:hover{transform:translateY(-3px) scale(1.05);background:#16205c;}
.to-top svg{width:22px;height:22px;}
@media (max-width: 540px){
  .to-top{left:18px;bottom:24px;width:44px;height:44px;}
}

/* --- Product sub-heading + quick-jump nav (shared across pillar pages) --- */
.prod-nav{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 4px;}
.prod-nav a{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-family:var(--font-mono);font-size:11.5px;letter-spacing:.02em;color:var(--fg-2);text-decoration:none;font-weight:600;transition:all .18s var(--ease-out);}
.prod-nav a:hover{border-color:var(--brand-ink);color:var(--brand-ink);transform:translateY(-1px);}
.prod-nav a .dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0;}
.prod-h3{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:34px 0 12px;scroll-margin-top:84px;padding-bottom:12px;border-bottom:2px solid var(--line);}
.prod-h3 .pidx{font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:.06em;flex-shrink:0;}
.prod-h3 .pttl{font-size:23px;font-weight:800;letter-spacing:-.018em;color:var(--brand-ink);margin:0;line-height:1.15;}
.prod-h3 .psum{font-size:13.5px;color:var(--fg-2);line-height:1.5;flex:1;min-width:200px;}
.prod-h3 .plink{margin-left:auto;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;border:1px solid var(--line);padding:7px 12px;border-radius:999px;transition:all .18s var(--ease-out);}
.prod-h3 .plink:hover{transform:translateY(-1px);}
@media (max-width: 720px){
  .prod-h3 .plink{margin-left:0;}
}

/* --- AI Chatbot --- */
.ai-fab{position:fixed;right:26px;bottom:100px;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#6B45F4 0%,#4FE3E3 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 14px 32px rgba(107,69,244,.40);cursor:pointer;z-index:40;color:#fff;border:0;font-family:inherit;transition:transform .2s var(--ease-out);}
.ai-fab:hover{transform:translateY(-2px) scale(1.04);}
.ai-fab svg{width:26px;height:26px;}
.ai-fab .ai-fab-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#fff;color:var(--brand-violet);font-family:var(--font-mono);font-size:9.5px;font-weight:800;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-1);}
.ai-fab .ai-fab-pulse{position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--brand-violet);opacity:.45;animation:ns-pulse 2.4s var(--ease-out) infinite;}
.ai-fab[aria-expanded="true"]{transform:rotate(0) scale(.92);background:var(--brand-ink);}
.ai-fab[aria-expanded="true"] .ai-fab-badge,.ai-fab[aria-expanded="true"] .ai-fab-pulse{display:none;}

.ai-panel{position:fixed;right:26px;bottom:170px;width:380px;max-width:calc(100vw - 36px);height:560px;max-height:calc(100vh - 200px);background:#fff;border-radius:24px;box-shadow:0 30px 80px rgba(11,18,64,.28),0 2px 6px rgba(11,18,64,.08);display:flex;flex-direction:column;overflow:hidden;z-index:41;transform-origin:bottom right;transform:scale(.94) translateY(8px);opacity:0;pointer-events:none;transition:all .22s var(--ease-out);border:1px solid var(--line);}
.ai-panel.open{transform:scale(1) translateY(0);opacity:1;pointer-events:auto;}

.ai-head{background:linear-gradient(135deg,#0B1240 0%,#2A1E5E 65%,#1568E0 130%);color:#fff;padding:16px 18px;display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;}
.ai-head::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 100% 0%,rgba(79,227,227,.32),transparent 55%);pointer-events:none;}
.ai-avatar{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#6B45F4,#4FE3E3);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-mono);font-weight:800;font-size:13px;letter-spacing:-.02em;position:relative;z-index:1;flex-shrink:0;}
.ai-head-meta{flex:1;position:relative;z-index:1;}
.ai-head-meta .t{font-weight:700;font-size:15px;letter-spacing:-.01em;line-height:1.1;}
.ai-head-meta .s{font-family:var(--font-mono);font-size:10.5px;color:#A8D5E3;letter-spacing:.04em;margin-top:3px;display:flex;align-items:center;gap:6px;}
.ai-head-meta .s .live{width:6px;height:6px;border-radius:50%;background:#4FE3E3;box-shadow:0 0 0 3px rgba(79,227,227,.22);}
.ai-close{background:rgba(255,255,255,.08);border:0;width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;position:relative;z-index:1;transition:background .15s;}
.ai-close:hover{background:rgba(255,255,255,.16);}
.ai-close svg{width:16px;height:16px;}

.ai-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:#FAFBFD;scroll-behavior:smooth;}
.ai-body::-webkit-scrollbar{width:6px;}
.ai-body::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px;}

.ai-msg{max-width:84%;padding:11px 14px;border-radius:16px;font-size:13.5px;line-height:1.52;color:var(--fg);white-space:pre-wrap;word-wrap:break-word;}
.ai-msg.bot{background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px;align-self:flex-start;}
.ai-msg.user{background:var(--brand-ink);color:#fff;border-bottom-right-radius:5px;align-self:flex-end;}
.ai-msg.thinking{color:var(--fg-3);font-style:italic;display:flex;align-items:center;gap:6px;}
.ai-msg.thinking::after{content:"";width:14px;height:14px;border:2px solid var(--line);border-top-color:var(--brand-violet);border-radius:50%;animation:ns-spin .8s linear infinite;display:inline-block;}
@keyframes ns-spin{to{transform:rotate(360deg);}}

.ai-chips{display:flex;flex-wrap:wrap;gap:6px;padding:0 4px;}
.ai-chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 11px;font-size:12px;color:var(--fg-2);cursor:pointer;font-family:inherit;transition:all .15s;}
.ai-chip:hover{border-color:var(--brand-violet);color:var(--brand-violet);background:#F4F1FF;}

.ai-foot{padding:12px 14px;background:#fff;border-top:1px solid var(--line);}
.ai-input-row{display:flex;gap:8px;align-items:flex-end;}
.ai-input{flex:1;border:1px solid var(--line);border-radius:14px;padding:10px 14px;font-size:13.5px;font-family:inherit;resize:none;outline:none;line-height:1.4;max-height:96px;min-height:38px;transition:border-color .15s;color:var(--fg);background:#FAFBFD;}
.ai-input:focus{border-color:var(--brand-violet);background:#fff;}
.ai-send{background:var(--brand-ink);color:#fff;border:0;width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;}
.ai-send:hover:not(:disabled){background:var(--brand-violet);transform:translateY(-1px);}
.ai-send:disabled{opacity:.4;cursor:not-allowed;}
.ai-send svg{width:16px;height:16px;}

.ai-disclaimer{font-family:var(--font-mono);font-size:9.5px;color:var(--fg-3);text-transform:uppercase;letter-spacing:.06em;text-align:center;margin-top:8px;line-height:1.4;}
.ai-disclaimer a{color:var(--brand-violet);text-decoration:none;font-weight:700;}
.ai-disclaimer a:hover{text-decoration:underline;}

@media (max-width: 540px){
  .ai-panel{right:12px;left:12px;width:auto;max-width:none;bottom:170px;height:calc(100vh - 200px);}
  .ai-fab,.wa-fab{right:18px;}
  .ai-fab{bottom:96px;}
  .wa-fab{bottom:24px;}
}

/* --- Page hero (per-pillar) --- */
.page-hero{max-width:1320px;margin:32px auto 28px;padding:32px 32px 24px;}
.page-hero .eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-family:var(--font-mono);font-size:11.5px;color:var(--fg-2);letter-spacing:.02em;}
.page-hero .eyebrow .dot{width:7px;height:7px;border-radius:50%;}
.page-hero h1{font-size:64px;font-weight:800;letter-spacing:-.028em;line-height:1.02;margin:20px 0 18px;color:var(--brand-ink);max-width:1000px;}
.page-hero .lede{max-width:720px;color:var(--fg-2);font-size:18px;line-height:1.55;}
.page-hero .cta-row{display:flex;gap:10px;margin-top:28px;flex-wrap:wrap;}

/* --- Content wrap --- */
.wrap{max-width:1320px;margin:0 auto;padding:0 32px;}
.section{padding:48px 0;}
.section h2{font-size:36px;line-height:1.08;letter-spacing:-.022em;font-weight:700;margin:0 0 10px;color:var(--brand-ink);max-width:760px;}
.section .sub{color:var(--fg-2);font-size:16px;line-height:1.6;max-width:680px;margin:0 0 32px;}

/* --- Reusable cards --- */
.card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px;transition:transform .25s var(--ease-out), box-shadow .25s var(--ease-out);}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-3);}
.card h3{font-size:20px;font-weight:700;letter-spacing:-.012em;margin:0 0 8px;color:var(--brand-ink);}
.card p{font-size:14px;color:var(--fg-2);line-height:1.6;}
.card .num{font-family:var(--font-mono);font-size:11px;color:var(--fg-3);letter-spacing:.08em;font-weight:600;text-transform:uppercase;}

/* --- Contact band (used at end of every page) --- */
.contact-band{margin:64px auto 100px;max-width:1320px;padding:0 32px;}
.contact-card{background:linear-gradient(135deg,#0B1240 0%,#2A1E5E 60%,#1568E0 130%);color:#fff;border-radius:32px;padding:56px 56px;display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center;overflow:hidden;position:relative;}
.contact-card::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 100% 0%,rgba(107,69,244,.35),transparent 55%),radial-gradient(ellipse at 0% 100%,rgba(79,227,227,.16),transparent 55%);pointer-events:none;}
.contact-card .eyebrow{font-family:var(--font-mono);font-size:11.5px;color:var(--brand-cyan);font-weight:700;letter-spacing:.1em;text-transform:uppercase;position:relative;z-index:1;}
.contact-card h2{font-size:42px;line-height:1.06;letter-spacing:-.022em;font-weight:800;margin:14px 0 14px;color:#fff;max-width:560px;position:relative;z-index:1;}
.contact-card p{color:#C7CBE0;font-size:15.5px;line-height:1.6;max-width:540px;position:relative;z-index:1;}
.contact-actions{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px;}
.contact-row{display:flex;align-items:center;gap:14px;padding:18px 20px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);text-decoration:none;color:#fff;backdrop-filter:blur(4px);transition:all .2s;}
.contact-row:hover{background:rgba(255,255,255,.1);transform:translateY(-2px);}
.contact-row .ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-row.wa .ic{background:#25D366;}
.contact-row.mail .ic{background:rgba(255,255,255,.12);}
.contact-row .l{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;color:#A8ADC5;text-transform:uppercase;}
.contact-row .v{font-weight:700;font-size:16px;color:#fff;margin-top:3px;}
.contact-row .arr{margin-left:auto;opacity:.5;}

/* --- Shared content blocks (FAQ / testimonials / pricing / data tables) --- */

/* FAQ accordion */
.faq{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.faq details{background:#fff;border:1px solid var(--line);border-radius:18px;padding:0;overflow:hidden;transition:box-shadow .2s var(--ease-out);}
.faq details[open]{box-shadow:var(--shadow-2);}
.faq summary{list-style:none;padding:20px 22px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;font-weight:600;font-size:15px;color:var(--brand-ink);letter-spacing:-.005em;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .q{flex:1;}
.faq summary .pl{width:26px;height:26px;border-radius:50%;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--fg-3);font-family:var(--font-mono);font-weight:700;font-size:14px;line-height:1;flex-shrink:0;transition:all .2s;}
.faq details[open] summary .pl{background:var(--brand-ink);color:#fff;transform:rotate(45deg);}
.faq details .a{padding:0 22px 22px;color:var(--fg-2);font-size:14px;line-height:1.65;}
.faq details .a strong{color:var(--brand-ink);}

/* Testimonials */
.testis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.testi{background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px 28px;display:flex;flex-direction:column;position:relative;overflow:hidden;}
.testi::before{content:"\201C";position:absolute;top:6px;right:22px;font-family:Georgia,serif;font-size:120px;color:var(--surface-2);line-height:1;font-weight:700;}
.testi .quote{font-size:15px;color:var(--fg);line-height:1.6;margin:0 0 22px;position:relative;letter-spacing:-.005em;}
.testi .who{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line);}
.testi .avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#0B1240,#2A1E5E);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;font-family:var(--font-mono);flex-shrink:0;letter-spacing:-.01em;}
.testi .who-meta strong{display:block;color:var(--brand-ink);font-size:13.5px;font-weight:700;letter-spacing:-.005em;}
.testi .who-meta span{display:block;font-size:11.5px;color:var(--fg-3);margin-top:2px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;}
.testi .pillar-tag{position:absolute;top:22px;left:28px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;font-weight:700;text-transform:uppercase;padding:3px 8px;border-radius:6px;background:var(--surface-2);color:var(--fg-3);}

/* Data tables */
.dt{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;}
.dt table{width:100%;border-collapse:collapse;}
.dt thead th{background:var(--surface-2);font-size:11px;font-family:var(--font-mono);letter-spacing:.06em;color:var(--fg-3);text-transform:uppercase;font-weight:700;padding:14px 22px;text-align:left;border-bottom:1px solid var(--line);}
.dt tbody td{padding:16px 22px;border-bottom:1px solid var(--line);font-size:14px;color:var(--fg);vertical-align:top;line-height:1.5;}
.dt tbody tr:last-child td{border-bottom:0;}
.dt tbody tr:hover td{background:#FAFBFD;}
.dt td.num{font-family:var(--font-mono);font-weight:600;color:var(--brand-ink);white-space:nowrap;}
.dt td.label{font-weight:600;color:var(--brand-ink);}
.dt td.muted{color:var(--fg-3);font-size:13px;}
.dt .pill{display:inline-block;padding:3px 9px;border-radius:999px;background:var(--surface-2);font-family:var(--font-mono);font-size:10.5px;font-weight:700;letter-spacing:.04em;color:var(--fg-2);}
.dt .pill.pos{background:#E7FAEF;color:#0B5A2C;}
.dt .pill.neg{background:#FBE7E7;color:#8A1F1F;}
.dt .pill.warn{background:#FBF1D8;color:#7A4C0A;}

/* Comparison / pricing tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.tier{background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px 28px;display:flex;flex-direction:column;position:relative;}
.tier.feat{border:2px solid var(--brand-ink);box-shadow:var(--shadow-3);}
.tier.feat::before{content:"";position:absolute;top:-1px;right:24px;width:120px;height:30px;background:var(--brand-ink);color:#fff;border-radius:0 0 14px 14px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;font-weight:700;}
.tier .name{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;font-weight:700;color:var(--fg-3);text-transform:uppercase;}
.tier h4{font-size:22px;font-weight:800;margin:8px 0 6px;color:var(--brand-ink);letter-spacing:-.018em;}
.tier .price{font-family:var(--font-mono);font-size:30px;font-weight:700;color:var(--brand-ink);margin:8px 0 4px;line-height:1;letter-spacing:-.01em;}
.tier .price .u{font-size:13px;color:var(--fg-3);font-weight:500;margin-left:4px;}
.tier .desc{font-size:13.5px;color:var(--fg-2);line-height:1.55;margin:0 0 18px;}
.tier ul{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-direction:column;gap:9px;}
.tier ul li{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--fg);line-height:1.5;}
.tier ul li i{color:var(--brand-ink);flex-shrink:0;margin-top:2px;}
.tier ul li.dim{color:var(--fg-3);}
.tier ul li.dim i{color:var(--fg-3);}
.tier .tcta{margin-top:auto;}

/* Section header eyebrow */
.section .label{display:block;font-family:var(--font-mono);font-size:11.5px;color:var(--fg-3);letter-spacing:.08em;font-weight:700;text-transform:uppercase;margin-bottom:10px;}

@media (max-width: 980px){
  .faq,.testis,.tiers{grid-template-columns:1fr;}
  .dt{overflow-x:auto;}
}

/* --- Footer --- */
.footer{background:#0B1240;color:#A8ADC5;padding:56px 0 32px;}
.footer-in{max-width:1320px;margin:0 auto;padding:0 32px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-brand img{height:34px;margin-bottom:18px;background:#fff;padding:8px 12px;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.25);}
.footer-brand p{color:#A8ADC5;font-size:13px;line-height:1.6;max-width:340px;}
.footer-col h5{color:#fff;font-size:13px;font-weight:600;margin:0 0 14px;letter-spacing:.02em;}
.footer-col a{display:block;color:#A8ADC5;font-size:13px;text-decoration:none;padding:5px 0;}
.footer-col a:hover{color:var(--brand-cyan);}
.footer-bot{padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-family:var(--font-mono);font-size:11.5px;color:#5F6478;letter-spacing:.04em;}
.footer-bot a{color:#5F6478;text-decoration:none;margin-left:18px;}

/* --- Sub-page navigation (breadcrumb + sub-tabs) --- */
.crumbs{max-width:1320px;margin:18px auto 0;padding:0 32px;display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;letter-spacing:.04em;color:var(--fg-3);text-transform:uppercase;}
.crumbs a{color:var(--fg-3);text-decoration:none;font-weight:600;transition:color .15s;}
.crumbs a:hover{color:var(--brand-ink);}
.crumbs .sep{color:var(--line-strong);}
.crumbs .now{color:var(--brand-ink);font-weight:700;}

.subnav{max-width:1320px;margin:-12px auto 28px;padding:0 32px;display:flex;gap:6px;flex-wrap:wrap;align-items:center;}
.subnav .sn-lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;color:var(--fg-3);text-transform:uppercase;font-weight:700;margin-right:6px;}
.subnav a{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--fg-2);font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;}
.subnav a:hover{border-color:var(--line-strong);color:var(--brand-ink);}
.subnav a.on{background:var(--brand-ink);color:#fff;border-color:var(--brand-ink);}
.subnav a i{width:13px;height:13px;}
.subnav a .ct{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-3);margin-left:2px;}
.subnav a.on .ct{color:rgba(255,255,255,.6);}

/* Sub-page index grid (parent pillar surfaces all sub-pages) */
.subpages{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.spcard{background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px 22px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:10px;transition:all .22s var(--ease-out);position:relative;overflow:hidden;}
.spcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-3);}
.spcard .ic{width:38px;height:38px;border-radius:11px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--brand-ink);}
.spcard .num{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-3);letter-spacing:.08em;font-weight:700;}
.spcard h4{font-size:16px;font-weight:700;margin:0;color:var(--brand-ink);letter-spacing:-.01em;line-height:1.25;}
.spcard p{font-size:12.5px;color:var(--fg-2);line-height:1.55;margin:0;}
.spcard .arr{margin-top:auto;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10.5px;color:var(--brand-ink);font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding-top:8px;}
.spcard .arr i{width:12px;height:12px;transition:transform .2s;}
.spcard:hover .arr i{transform:translateX(3px);}

/* Regulatory note callout (for Malaysia / Johor references) */
.reg-note{background:#FFFDF5;border:1px solid #F2E5BF;border-left:4px solid #C5B07A;border-radius:14px;padding:18px 22px;display:flex;gap:14px;align-items:flex-start;}
.reg-note .ic{width:34px;height:34px;border-radius:10px;background:#F4EDDC;display:flex;align-items:center;justify-content:center;color:#7A5E1E;flex-shrink:0;}
.reg-note .body{flex:1;}
.reg-note .body .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;color:#7A5E1E;font-weight:700;text-transform:uppercase;margin-bottom:4px;}
.reg-note .body p{font-size:13.5px;color:#3C2A0E;line-height:1.6;margin:0;}
.reg-note .body p strong{color:#1F1300;}
.reg-note .body p + p{margin-top:6px;}

/* Two-col content (used on sub-pages) */
.two-col{display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:start;}
.two-col-eq{display:grid;grid-template-columns:1fr 1fr;gap:24px;}

/* Spec list (kv) */
.kv{display:grid;grid-template-columns:160px 1fr;gap:10px 16px;}
.kv .k{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--fg-3);font-weight:700;text-transform:uppercase;padding-top:3px;}
.kv .v{font-size:14px;color:var(--brand-ink);font-weight:500;line-height:1.55;}

/* Anchor for any document/standards reference */
.stamp-ref{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;background:var(--surface-2);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;color:var(--fg-2);font-weight:600;}

@media (max-width: 980px){
  .subpages{grid-template-columns:1fr;}
  .two-col,.two-col-eq{grid-template-columns:1fr;}
  .kv{grid-template-columns:120px 1fr;}
}

/* ------------------------------------------------------------------
   Scroll-reveal motion (flash-free, opt-out aware)
   — Hidden state is gated on html.ns-reveal (set pre-paint by a tiny
     head script) AND on prefers-reduced-motion:no-preference, so:
       · reduced-motion users  → never hidden, instant content
       · JS disabled / no IO    → ns-reveal removed → instant content
   — Motion uses the independent `translate` property so element hover
     `transform` stays free; transform/box-shadow kept in the transition
     list so card/tile hovers still animate at their usual speed.
   ------------------------------------------------------------------ */
@media (prefers-reduced-motion: no-preference){
  html.ns-reveal :is(
    .bento > .tile, .hero-band, .regstrip, .page-hero,
    .section > h2, .section > .sub, .section > .label, .section > p,
    .prod-h3, .card, .room, .sc, .testi, .tier, .spcard,
    .faq details, .reg-note, .dt, .contact-card,
    .two-col, .two-col-eq, .kv, [data-reveal]
  ){
    opacity:0;
    translate:0 22px;
    transition:opacity .62s var(--ease-out),
               translate .62s var(--ease-out),
               transform .28s var(--ease-out),
               box-shadow .28s var(--ease-out);
  }
  html.ns-reveal :is(
    .bento > .tile, .hero-band, .regstrip, .page-hero,
    .section > h2, .section > .sub, .section > .label, .section > p,
    .prod-h3, .card, .room, .sc, .testi, .tier, .spcard,
    .faq details, .reg-note, .dt, .contact-card,
    .two-col, .two-col-eq, .kv, [data-reveal]
  ).r-in{
    opacity:1;
    translate:0 0;
  }
}

/* --- Per-pillar dot accent for hero eyebrow --- */
.dot-re{background:#C5B07A;}
.dot-ins{background:#6FB089;}
.dot-it{background:#5BA8FF;}
.dot-edu{background:#E8A93C;}
.dot-home{background:var(--brand-violet);}
.dot-about{background:var(--brand-cyan);}

@media (max-width: 980px){
  .nav .links{display:none;}
  .page-hero h1{font-size:38px;}
  .section h2{font-size:28px;}
  .contact-card{grid-template-columns:1fr;padding:36px;}
  .contact-card h2{font-size:30px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}

/* ==================================================================
   RESPONSIVE LAYER — phone + tablet adaptation across all 23 pages
   (nav drawer · auto grid-collapse · fluid type & spacing)
   ================================================================== */

/* --- Mobile hamburger (hidden on desktop) --- */
.nav-burger{display:none;}
@media (max-width: 980px){
  .nav .cta{display:none;}
  .nav-burger{
    display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;
    margin-left:auto;width:46px;height:46px;padding:11px;border:0;background:transparent;cursor:pointer;
    border-radius:12px;-webkit-tap-highlight-color:transparent;
  }
  .nav-burger:active{background:var(--surface-2);}
  .nav-burger span{display:block;width:24px;height:2px;background:var(--brand-ink);border-radius:2px;
    transition:transform .26s var(--ease-out),opacity .18s var(--ease-out);}
  .nav-burger.on span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-burger.on span:nth-child(2){opacity:0;}
  .nav-burger.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
}

/* --- Slide-in drawer menu --- */
.ns-drawer{position:fixed;inset:0;z-index:80;background:rgba(11,18,64,.46);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transition:opacity .26s var(--ease-out),visibility .26s;}
.ns-drawer.open{opacity:1;visibility:visible;}
.ns-drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(87vw,360px);
  background:var(--brand-paper,#F6F7FB);box-shadow:-24px 0 70px rgba(11,18,64,.28);
  display:flex;flex-direction:column;transform:translateX(102%);
  transition:transform .32s var(--ease-out);}
.ns-drawer.open .ns-drawer-panel{transform:translateX(0);}
.ns-drawer-head{display:flex;align-items:center;justify-content:space-between;
  padding:20px 22px;border-bottom:1px solid var(--line);flex-shrink:0;}
.ns-drawer-ttl{display:flex;align-items:center;gap:10px;}
.ns-drawer-ttl img{height:30px;display:block;}
.ns-drawer-x{width:42px;height:42px;border:0;background:var(--surface-2);border-radius:11px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--fg);flex-shrink:0;}
.ns-drawer-x svg{width:18px;height:18px;}
.ns-drawer-links{display:flex;flex-direction:column;padding:14px 12px;gap:3px;overflow-y:auto;flex:1;}
.ns-drawer-links a{display:flex;align-items:center;padding:14px 16px;border-radius:13px;
  text-decoration:none;color:var(--fg);font-size:16px;font-weight:600;letter-spacing:-.01em;
  transition:background .15s,color .15s;}
.ns-drawer-links a:hover{background:var(--surface-2);}
.ns-drawer-links a.active{background:var(--brand-ink);color:#fff;}
.ns-drawer-foot{padding:18px 20px 28px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:16px;flex-shrink:0;}
.ns-drawer-foot .lang-switch{align-self:flex-start;}
.ns-drawer-foot .btn{justify-content:center;width:100%;padding:14px 18px;font-size:15px;}

/* --- Auto grid-collapse (tags applied by shared.js) --- */
@media (max-width: 900px){
  [data-ns-rg="3"],[data-ns-rg="4"],[data-ns-rg="5"],[data-ns-rg="6"]{
    grid-template-columns:repeat(2,1fr)!important;}
}
@media (max-width: 600px){
  [data-ns-rg]{grid-template-columns:1fr!important;}
  [data-ns-rg] > *{grid-column:auto!important;grid-row:auto!important;}
}

/* --- Homepage bento on phones (denylisted from auto-collapse) --- */
@media (max-width: 560px){
  .bento{grid-template-columns:1fr!important;grid-auto-rows:auto!important;}
  .bento > .tile{grid-column:auto!important;grid-row:auto!important;min-height:190px;}
  .t-hero{grid-row:auto!important;min-height:360px!important;}
  .t-hero-inner{grid-template-columns:1fr!important;}
  .t-hero-portrait{display:none!important;}
  .hero-band h1{font-size:30px!important;}
}

/* --- Fluid type, spacing & padding (tablet) --- */
@media (max-width: 768px){
  .wrap,.contact-band,.crumbs,.subnav{padding-left:18px;padding-right:18px;}
  .nav-in{padding:0 18px;gap:16px;}
  .page-hero{margin:18px auto 16px;padding:18px 18px 6px;}
  .page-hero h1{font-size:34px;}
  .page-hero .lede{font-size:16px;}
  .page-hero .cta-row{margin-top:22px;}
  .section{padding:34px 0;}
  .section h2{font-size:25px;}
  .section .sub{font-size:15px;}
  .contact-band{margin:44px auto 76px;}
  .contact-card{padding:32px 24px;border-radius:26px;}
  .contact-card h2{font-size:26px;}
  .footer{padding:44px 0 28px;}
}

/* --- Phone --- */
@media (max-width: 560px){
  .page-hero h1{font-size:28px;letter-spacing:-.02em;}
  .page-hero .lede{font-size:15px;}
  .page-hero .cta-row{flex-direction:column;align-items:stretch;}
  .page-hero .cta-row .btn{justify-content:center;}
  .section h2{font-size:23px;}
  .footer-grid{grid-template-columns:1fr;gap:30px;}
  .contact-card{padding:28px 20px;}
  .contact-card h2{font-size:23px;}
  .contact-row{padding:15px 16px;}
  .wa-fab{right:18px;bottom:22px;width:52px;height:52px;}
  .wa-fab svg{width:26px;height:26px;}
  .ai-fab{right:18px;bottom:88px;width:52px;height:52px;}
  .btn-lg{padding:13px 18px;font-size:14.5px;}
  .crumbs{flex-wrap:wrap;}
}
