/* ============================================================
   MAHAVIR EXPORTS — Clean Medical-Device Design System
   Light · Professional · Trustworthy  (v3)
   ============================================================ */

:root {
  --bg:        #ffffff;
  --bg-soft:   #f4f7fc;
  --bg-soft2:  #eef3fa;
  --bg-deep:   #0c2340;   /* deep navy */
  --bg-deep2:  #0a1d36;

  --primary:   #0d5cab;
  --primary-d: #0a4887;
  --primary-l: #2c7de0;
  --primary-05:rgba(13,92,171,0.05);
  --primary-10:rgba(13,92,171,0.10);
  --accent:    #0d9488;   /* teal, used sparingly */

  --ink:       #102a43;
  --ink-2:     #243b53;
  --body:      #51647d;
  --muted:     #7b8aa0;
  --line:      #e4eaf2;
  --line-2:    #d6deea;

  --shadow-sm: 0 1px 3px rgba(16,42,67,0.06), 0 1px 2px rgba(16,42,67,0.04);
  --shadow:    0 10px 30px rgba(16,42,67,0.08);
  --shadow-lg: 0 24px 60px rgba(16,42,67,0.12);
  --shadow-blue: 0 16px 40px rgba(13,92,171,0.18);

  --fh: 'Plus Jakarta Sans', sans-serif;
  --fb: 'Inter', sans-serif;
  --ease: cubic-bezier(0.22,1,0.36,1);
  --t: all 0.3s cubic-bezier(0.22,1,0.36,1);
  --r: 12px;
  --r-sm: 8px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; -webkit-font-smoothing:antialiased; }
body {
  font-family:var(--fb);
  background:var(--bg);
  color:var(--body);
  line-height:1.7;
  overflow-x:hidden;
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; height:auto; display:block; }
button { cursor:pointer; font-family:var(--fb); }
::selection { background:var(--primary-10); color:var(--ink); }

/* === SCROLL PROGRESS === */
.prog {
  position:fixed; top:0; left:0; height:3px;
  background:linear-gradient(90deg, var(--primary), var(--primary-l));
  z-index:1001; transition:width 0.1s linear; width:0;
}

/* === TYPOGRAPHY === */
h1,h2,h3,h4,h5,h6 { font-family:var(--fh); font-weight:700; line-height:1.18; letter-spacing:-0.02em; color:var(--ink); }
.t-primary { color:var(--primary); }
.t-accent { color:var(--accent); }

.label {
  display:inline-flex; align-items:center; gap:9px;
  padding:7px 16px; border-radius:100px;
  background:var(--primary-05); border:1px solid rgba(13,92,171,0.14);
  font-size:12px; font-weight:600; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--primary); margin-bottom:22px;
}
.label-dot { width:6px; height:6px; background:var(--primary); border-radius:50%; box-shadow:0 0 0 4px rgba(13,92,171,0.12); }

/* === LAYOUT === */
.container { max-width:1240px; margin:0 auto; padding:0 28px; }
section { padding:110px 0; }

/* === BUTTONS === */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  padding:14px 28px; border-radius:var(--r-sm);
  font-size:15px; font-weight:600; border:1.5px solid transparent;
  cursor:pointer; transition:var(--t); text-decoration:none; white-space:nowrap;
}
.btn svg { width:17px; height:17px; transition:transform .3s ease; }
.btn:hover svg { transform:translateX(3px); }

.btn-primary { background:var(--primary); color:#fff; box-shadow:var(--shadow-blue); }
.btn-primary:hover { background:var(--primary-d); transform:translateY(-2px); box-shadow:0 20px 44px rgba(13,92,171,0.28); }

.btn-light { background:#fff; color:var(--primary); border-color:var(--line-2); box-shadow:var(--shadow-sm); }
.btn-light:hover { border-color:var(--primary); color:var(--primary-d); transform:translateY(-2px); box-shadow:var(--shadow); }

.btn-ghost { background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover { border-color:var(--primary); color:var(--primary); }

.btn-white { background:#fff; color:var(--primary); border-color:#fff; }
.btn-white:hover { transform:translateY(-2px); box-shadow:0 16px 40px rgba(0,0,0,0.2); }

.btn-outline-white { background:transparent; color:#fff; border-color:rgba(255,255,255,0.3); }
.btn-outline-white:hover { background:rgba(255,255,255,0.1); border-color:#fff; }

/* === NAV === */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:8px 0; transition:all .4s var(--ease);
  background:rgba(255,255,255,0);
}
.nav.on {
  padding:4px 0; background:rgba(255,255,255,0.92);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line); box-shadow:0 4px 24px rgba(16,42,67,0.06);
}
.nav-in { max-width:1240px; margin:0 auto; padding:0 28px; display:flex; align-items:center; gap:44px; }

.logo { display:flex; align-items:center; gap:11px; }
.logo-img { height:110px; width:auto; display:block; }
.ft-logo-img { height:90px; width:auto; display:block; background:#fff; padding:8px 14px; border-radius:10px; }
.logo-mark {
  width:40px; height:40px; border-radius:9px;
  background:linear-gradient(135deg, var(--primary), var(--primary-l));
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  box-shadow:var(--shadow-blue);
}
.logo-mark svg { width:22px; height:22px; color:#fff; }
.logo-txt { display:flex; flex-direction:column; line-height:1.1; }
.logo-n { font-family:var(--fh); font-size:18px; font-weight:800; color:var(--ink); letter-spacing:-0.02em; }
.logo-s { font-size:9.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); font-weight:600; margin-top:2px; }

.nav-links { display:flex; align-items:center; gap:34px; list-style:none; margin-left:auto; }
.nl { font-size:14.5px; font-weight:500; color:var(--ink-2); transition:color .25s; position:relative; cursor:pointer; padding:4px 0; }
.nl::after { content:''; position:absolute; bottom:-2px; left:0; width:0; height:2px; background:var(--primary); border-radius:2px; transition:width .3s var(--ease); }
.nl:hover, .nl.active { color:var(--primary); }
.nl:hover::after, .nl.active::after { width:100%; }

.ndrop { position:relative; }
.ndrop-menu {
  position:absolute; top:calc(100% + 16px); left:50%; transform:translateX(-50%) translateY(-8px);
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:10px; min-width:280px; opacity:0; visibility:hidden;
  transition:all .3s var(--ease); box-shadow:var(--shadow-lg);
}
.ndrop:hover .ndrop-menu { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.ndi { display:flex; align-items:center; gap:13px; padding:11px 13px; border-radius:var(--r-sm); transition:var(--t); }
.ndi:hover { background:var(--bg-soft); }
.ndi-ic { width:36px; height:36px; border-radius:8px; background:var(--primary-05); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--primary); }
.ndi-ic svg { width:18px; height:18px; }
.ndi-tx { display:flex; flex-direction:column; }
.ndi-t { font-size:14px; font-weight:600; color:var(--ink); }
.ndi-d { font-size:11.5px; color:var(--muted); }

.nav-cta { padding:11px 22px; font-size:14px; }

.ham { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:6px; margin-left:auto; }
.ham span { width:24px; height:2px; background:var(--ink); border-radius:2px; transition:var(--t); display:block; }
.ham.on span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.ham.on span:nth-child(2) { opacity:0; }
.ham.on span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

.mob-nav {
  position:fixed; top:0; right:-100%; width:min(360px,100vw); height:100vh;
  background:#fff; border-left:1px solid var(--line); z-index:998;
  transition:right .4s var(--ease); padding:90px 30px 40px; overflow-y:auto;
  box-shadow:-20px 0 60px rgba(16,42,67,0.1);
}
.mob-nav.on { right:0; }
.mob-links { list-style:none; display:flex; flex-direction:column; }
.mob-link { display:block; padding:15px 0; font-size:17px; font-weight:600; color:var(--ink); border-bottom:1px solid var(--line); transition:var(--t); }
.mob-link:hover { color:var(--primary); padding-left:6px; }
.mob-sub { list-style:none; padding:6px 0 6px 14px; }
.mob-sub-l { display:block; padding:9px 0; font-size:14px; color:var(--body); transition:var(--t); }
.mob-sub-l:hover { color:var(--primary); }
.mob-cta { margin-top:24px; width:100%; justify-content:center; }

.overlay { position:fixed; inset:0; background:rgba(12,35,64,0.4); backdrop-filter:blur(3px); z-index:997; opacity:0; visibility:hidden; transition:all .3s; }
.overlay.on { opacity:1; visibility:visible; }

/* === HERO === */
.hero {
  position:relative; padding:170px 0 110px; overflow:hidden;
  background:linear-gradient(180deg, var(--bg-soft) 0%, #fff 100%);
}
.hero-deco { position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.hero-blob {
  position:absolute; top:-180px; right:-160px; width:680px; height:680px;
  background:radial-gradient(circle, rgba(13,92,171,0.10) 0%, transparent 65%);
  border-radius:50%;
}
.hero-blob2 {
  position:absolute; bottom:-220px; left:-180px; width:560px; height:560px;
  background:radial-gradient(circle, rgba(13,148,136,0.07) 0%, transparent 65%);
  border-radius:50%;
}
.hero-grid-bg {
  position:absolute; inset:0;
  background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:54px 54px; opacity:.5;
  mask-image:radial-gradient(ellipse 70% 60% at 70% 30%, black, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 70% 30%, black, transparent 75%);
}
.hero-in { position:relative; z-index:2; display:grid; grid-template-columns:1.05fr 0.95fr; gap:60px; align-items:center; }

.hero-eyebrow { display:inline-flex; align-items:center; gap:9px; padding:7px 16px; border-radius:100px; background:#fff; border:1px solid var(--line-2); box-shadow:var(--shadow-sm); font-size:12.5px; font-weight:600; color:var(--primary); margin-bottom:26px; }
.hero-eyebrow .dot { width:7px; height:7px; border-radius:50%; background:var(--accent); }

.hero h1 { font-size:clamp(38px,5vw,62px); font-weight:800; letter-spacing:-0.03em; line-height:1.08; color:var(--ink); margin-bottom:24px; }
.hero-sub { font-size:18px; color:var(--body); max-width:520px; line-height:1.75; margin-bottom:38px; }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:44px; }

.hero-trust { display:flex; gap:30px; flex-wrap:wrap; padding-top:34px; border-top:1px solid var(--line); }
.htrust { display:flex; flex-direction:column; gap:2px; }
.htrust-n { font-family:var(--fh); font-size:30px; font-weight:800; color:var(--ink); letter-spacing:-0.02em; }
.htrust-n span { color:var(--primary); }
.htrust-l { font-size:12.5px; color:var(--muted); font-weight:500; }

/* hero visual */
.hero-visual { position:relative; }
.hero-img-main {
  border-radius:18px; overflow:hidden; box-shadow:var(--shadow-lg);
  aspect-ratio:4/5; border:6px solid #fff; position:relative; z-index:2;
}
.hero-img-main img { width:100%; height:100%; object-fit:cover; }
.hero-badge-float {
  position:absolute; z-index:3; background:#fff; border-radius:14px;
  box-shadow:var(--shadow-lg); padding:16px 20px; display:flex; align-items:center; gap:13px;
}
.hero-badge-1 { top:32px; left:-34px; }
.hero-badge-2 { bottom:40px; right:-30px; }
.hbf-ic { width:42px; height:42px; border-radius:10px; background:var(--primary-05); display:flex; align-items:center; justify-content:center; color:var(--primary); flex-shrink:0; }
.hbf-ic.teal { background:rgba(13,148,136,0.08); color:var(--accent); }
.hbf-t { font-family:var(--fh); font-size:16px; font-weight:700; color:var(--ink); line-height:1.1; }
.hbf-s { font-size:11.5px; color:var(--muted); }
.hero-dotgrid { position:absolute; bottom:-26px; left:-26px; width:130px; height:130px; z-index:1;
  background-image:radial-gradient(var(--line-2) 1.6px, transparent 1.6px); background-size:16px 16px; }

/* === TRUST STRIP / MARQUEE === */
.strip { background:var(--bg-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:26px 0; overflow:hidden; position:relative; }
.strip::before, .strip::after { content:''; position:absolute; top:0; width:100px; height:100%; z-index:2; pointer-events:none; }
.strip::before { left:0; background:linear-gradient(90deg, var(--bg-soft), transparent); }
.strip::after { right:0; background:linear-gradient(270deg, var(--bg-soft), transparent); }
.strip-track { display:flex; width:max-content; animation:marquee 38s linear infinite; }
.strip-track:hover { animation-play-state:paused; }
.si { display:flex; align-items:center; gap:11px; padding:0 38px; white-space:nowrap; font-size:15px; font-weight:600; color:var(--ink-2); }
.si svg { width:19px; height:19px; color:var(--primary); flex-shrink:0; }

/* === SECTION HEADER === */
.sec-hd { margin-bottom:56px; }
.sec-hd.ctr { text-align:center; }
.sec-hd.ctr .sec-desc { margin-left:auto; margin-right:auto; }
.sec-title { font-size:clamp(28px,3.6vw,44px); font-weight:800; letter-spacing:-0.025em; margin-bottom:16px; }
.sec-desc { font-size:17px; color:var(--body); max-width:560px; line-height:1.7; }

/* === ABOUT === */
.about-g { display:grid; grid-template-columns:1fr 1.1fr; gap:70px; align-items:center; }
.about-visual { position:relative; }
.about-img { border-radius:18px; overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:5/4; }
.about-img img { width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.about-img:hover img { transform:scale(1.05); }
.about-exp {
  position:absolute; bottom:-30px; right:-26px;
  background:var(--primary); color:#fff; border-radius:16px; padding:24px 28px;
  box-shadow:var(--shadow-blue); text-align:center;
}
.about-exp .n { font-family:var(--fh); font-size:40px; font-weight:800; line-height:1; }
.about-exp .l { font-size:12px; font-weight:600; opacity:.9; margin-top:4px; letter-spacing:0.02em; }

.about-content h2 { font-size:clamp(26px,3vw,40px); margin-bottom:18px; }
.about-content > p { font-size:16px; color:var(--body); line-height:1.85; margin-bottom:18px; }
.about-points { display:flex; flex-direction:column; gap:16px; margin:30px 0; }
.about-point { display:flex; gap:14px; align-items:flex-start; }
.about-point-ic { width:30px; height:30px; border-radius:8px; background:var(--primary-05); display:flex; align-items:center; justify-content:center; color:var(--primary); flex-shrink:0; margin-top:2px; }
.about-point-ic svg { width:16px; height:16px; }
.about-point-tx h4 { font-size:15.5px; font-weight:700; color:var(--ink); margin-bottom:2px; }
.about-point-tx p { font-size:14px; color:var(--body); margin:0; line-height:1.6; }

/* === PRODUCTS GRID === */
.products { background:var(--bg-soft); }
.pgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.pcard {
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden; transition:var(--t); display:flex; flex-direction:column;
}
.pcard:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:transparent; }
.pcard-img { aspect-ratio:16/10; overflow:hidden; position:relative; }
.pcard-img img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.pcard:hover .pcard-img img { transform:scale(1.07); }
.pcard-tag { position:absolute; top:14px; left:14px; background:rgba(255,255,255,0.95); backdrop-filter:blur(4px); color:var(--primary); font-size:11px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; padding:6px 12px; border-radius:100px; box-shadow:var(--shadow-sm); }
.pcard-body { padding:26px; display:flex; flex-direction:column; flex:1; }
.pcard-ic { width:46px; height:46px; border-radius:11px; background:var(--primary-05); display:flex; align-items:center; justify-content:center; color:var(--primary); margin-bottom:16px; transition:var(--t); }
.pcard-ic svg { width:24px; height:24px; }
.pcard:hover .pcard-ic { background:var(--primary); color:#fff; }
.pcard h3 { font-size:19px; font-weight:700; margin-bottom:9px; }
.pcard p { font-size:14.5px; color:var(--body); line-height:1.7; margin-bottom:20px; flex:1; }
.pcard-lnk { display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:600; color:var(--primary); }
.pcard-lnk svg { width:16px; height:16px; transition:transform .3s; }
.pcard:hover .pcard-lnk svg { transform:translateX(5px); }

/* === WHY US (dark band) === */
.why { background:var(--bg-deep); position:relative; overflow:hidden; }
.why::before { content:''; position:absolute; top:-200px; right:-150px; width:600px; height:600px; background:radial-gradient(circle, rgba(44,125,224,0.16) 0%, transparent 65%); border-radius:50%; }
.why::after { content:''; position:absolute; bottom:-200px; left:-150px; width:500px; height:500px; background:radial-gradient(circle, rgba(13,148,136,0.1) 0%, transparent 65%); border-radius:50%; }
.why .container { position:relative; z-index:2; }
.why .sec-title, .why .label { color:#fff; }
.why .label { background:rgba(255,255,255,0.08); border-color:rgba(255,255,255,0.16); color:#9fc3ef; }
.why .label-dot { background:#5ea0ec; box-shadow:0 0 0 4px rgba(94,160,236,0.2); }
.why .sec-desc { color:#a9bdd6; }
.why-g { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.wcard { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.09); border-radius:var(--r); padding:32px 26px; transition:var(--t); }
.wcard:hover { background:rgba(255,255,255,0.07); transform:translateY(-6px); border-color:rgba(94,160,236,0.4); }
.wcard-ic { width:52px; height:52px; border-radius:12px; background:rgba(44,125,224,0.16); display:flex; align-items:center; justify-content:center; color:#7ab2f0; margin-bottom:20px; }
.wcard-ic svg { width:26px; height:26px; }
.wcard h3 { color:#fff; font-size:17px; font-weight:700; margin-bottom:10px; }
.wcard p { color:#a9bdd6; font-size:14px; line-height:1.7; }

/* === PROCESS === */
.proc-g { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; }
.proc-s { position:relative; }
.proc-num { width:54px; height:54px; border-radius:14px; background:var(--primary); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-size:20px; font-weight:800; margin-bottom:22px; box-shadow:var(--shadow-blue); }
.proc-s h3 { font-size:17px; font-weight:700; margin-bottom:9px; }
.proc-s p { font-size:14px; color:var(--body); line-height:1.7; }
.proc-arrow { position:absolute; top:18px; right:-16px; color:var(--line-2); z-index:1; }
.proc-arrow svg { width:24px; height:24px; }

/* === STATS BAND === */
.stats-band { background:linear-gradient(135deg, var(--primary) 0%, var(--primary-d) 100%); padding:70px 0; }
.stats-g { display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.stat { text-align:center; color:#fff; }
.stat-n { font-family:var(--fh); font-size:52px; font-weight:800; line-height:1; letter-spacing:-0.03em; }
.stat-l { font-size:14px; margin-top:8px; opacity:.85; font-weight:500; }
.stat-divider { }

/* === TESTIMONIALS === */
.testi { background:var(--bg-soft); }
.tcar { position:relative; max-width:880px; margin:0 auto; overflow:hidden; }
.tcar-track { display:flex; transition:transform .6s var(--ease); }
.tslide { flex:0 0 100%; padding:0 8px; box-sizing:border-box; }
.tcard { background:#fff; border:1px solid var(--line); border-radius:18px; padding:48px; text-align:center; box-shadow:var(--shadow); }
.tcard-stars { display:flex; gap:4px; justify-content:center; margin-bottom:22px; color:#f5a623; }
.tcard-stars svg { width:20px; height:20px; }
.tcard-q { font-size:21px; line-height:1.6; color:var(--ink-2); font-weight:500; margin-bottom:30px; letter-spacing:-0.01em; }
.tcard-author { display:flex; align-items:center; justify-content:center; gap:14px; }
.tcard-av { width:52px; height:52px; border-radius:50%; background:linear-gradient(135deg, var(--primary), var(--primary-l)); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-weight:700; font-size:18px; flex-shrink:0; }
.tcard-name { font-family:var(--fh); font-size:16px; font-weight:700; color:var(--ink); text-align:left; }
.tcard-role { font-size:13px; color:var(--muted); text-align:left; }
.tcar-nav { display:flex; align-items:center; justify-content:center; gap:16px; margin-top:34px; }
.tcar-btn { width:46px; height:46px; border-radius:50%; background:#fff; border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; color:var(--ink); cursor:pointer; transition:var(--t); box-shadow:var(--shadow-sm); }
.tcar-btn:hover { background:var(--primary); border-color:var(--primary); color:#fff; transform:scale(1.05); }
.tcar-btn svg { width:18px; height:18px; }
.tcar-dots { display:flex; gap:8px; }
.tcar-dot { width:8px; height:8px; border-radius:50%; background:var(--line-2); cursor:pointer; transition:var(--t); }
.tcar-dot.on { width:26px; border-radius:4px; background:var(--primary); }

/* === CTA BAND === */
.cta { background:var(--bg-deep); position:relative; overflow:hidden; }
.cta::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:900px; height:500px; background:radial-gradient(ellipse, rgba(44,125,224,0.18) 0%, transparent 65%); }
.cta-in { position:relative; z-index:2; text-align:center; }
.cta h2 { color:#fff; font-size:clamp(28px,3.8vw,46px); margin-bottom:16px; }
.cta p { color:#a9bdd6; font-size:18px; max-width:520px; margin:0 auto 38px; line-height:1.7; }
.cta-row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* === FOOTER === */
footer { background:var(--bg-deep2); color:#a9bdd6; padding:80px 0 32px; }
.ft-g { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:54px; margin-bottom:54px; }
.ft-logo { display:flex; align-items:center; gap:11px; margin-bottom:18px; }
.ft-logo .logo-mark { box-shadow:none; }
.ft-logo-n { font-family:var(--fh); font-size:18px; font-weight:800; color:#fff; }
.ft-brand p { font-size:14px; line-height:1.8; max-width:280px; color:#8da4c0; }
.ft-social { display:flex; gap:10px; margin-top:22px; }
.ft-social a { width:38px; height:38px; border-radius:9px; background:rgba(255,255,255,0.06); display:flex; align-items:center; justify-content:center; color:#a9bdd6; transition:var(--t); }
.ft-social a:hover { background:var(--primary); color:#fff; transform:translateY(-2px); }
.ft-social svg { width:17px; height:17px; }
.ft-col h4 { font-family:var(--fh); font-size:14px; font-weight:700; color:#fff; margin-bottom:20px; }
.ft-links { list-style:none; display:flex; flex-direction:column; gap:11px; }
.ft-lnk { font-size:14px; color:#8da4c0; transition:var(--t); display:inline-block; }
.ft-lnk:hover { color:#fff; transform:translateX(4px); }
.ft-ci { display:flex; gap:12px; margin-bottom:16px; align-items:flex-start; }
.ft-ci-ic { width:34px; height:34px; border-radius:8px; background:rgba(255,255,255,0.06); display:flex; align-items:center; justify-content:center; color:#7ab2f0; flex-shrink:0; margin-top:2px; }
.ft-ci-ic svg { width:15px; height:15px; }
.ft-ci-t { font-size:13.5px; line-height:1.6; color:#8da4c0; }
.ft-ci-t a:hover { color:#fff; }
.ft-bot { border-top:1px solid rgba(255,255,255,0.08); padding-top:28px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; }
.ft-copy { font-size:13px; color:#6f86a3; }
.ft-leg { display:flex; gap:24px; }
.ft-leg a { font-size:13px; color:#8da4c0; transition:var(--t); }
.ft-leg a:hover { color:#fff; }

/* === REVEAL ANIMATIONS === */
.rev { opacity:0; transform:translateY(34px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.rev-l { opacity:0; transform:translateX(-34px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.rev-r { opacity:0; transform:translateX(34px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.rev-sc { opacity:0; transform:scale(.96); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.rev.vis, .rev-l.vis, .rev-r.vis, .rev-sc.vis { opacity:1; transform:none; }
.stag > * { opacity:0; transform:translateY(26px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.stag.vis > * { opacity:1; transform:none; }
.stag.vis > *:nth-child(2){ transition-delay:.08s } .stag.vis > *:nth-child(3){ transition-delay:.16s }
.stag.vis > *:nth-child(4){ transition-delay:.24s } .stag.vis > *:nth-child(5){ transition-delay:.32s }
.stag.vis > *:nth-child(6){ transition-delay:.40s }

/* === PAGE HERO (inner pages) === */
.phero { padding:160px 0 80px; background:linear-gradient(180deg, var(--bg-soft) 0%, #fff 100%); position:relative; overflow:hidden; }
.phero-deco { position:absolute; top:-150px; right:-120px; width:520px; height:520px; background:radial-gradient(circle, rgba(13,92,171,0.08) 0%, transparent 65%); border-radius:50%; pointer-events:none; }
.phero-in { position:relative; z-index:2; }
.breadcrumb { display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--muted); margin-bottom:22px; }
.breadcrumb a { color:var(--body); transition:var(--t); }
.breadcrumb a:hover { color:var(--primary); }
.breadcrumb-sep { color:var(--line-2); }
.phero h1 { font-size:clamp(32px,4.6vw,56px); font-weight:800; letter-spacing:-0.03em; margin-bottom:18px; max-width:820px; }
.phero-in > p { font-size:18px; color:var(--body); max-width:620px; line-height:1.75; }

/* === INNER: feature/subcat/benefit === */
.feat-g { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.feat-card { padding:32px; background:#fff; border:1px solid var(--line); border-radius:var(--r); transition:var(--t); display:flex; flex-direction:column; gap:13px; }
.feat-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); border-color:transparent; }
.feat-ic { width:48px; height:48px; border-radius:11px; background:var(--primary-05); display:flex; align-items:center; justify-content:center; color:var(--primary); }
.feat-ic svg { width:24px; height:24px; }
.feat-card h3 { font-size:18px; font-weight:700; }
.feat-card p { font-size:14.5px; color:var(--body); line-height:1.7; }

.subcat-g { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.scat { padding:32px; background:#fff; border:1px solid var(--line); border-radius:var(--r); transition:var(--t); }
.scat:hover { box-shadow:var(--shadow); transform:translateY(-4px); border-color:transparent; }
.scat-ic { width:48px; height:48px; border-radius:11px; background:var(--primary-05); display:flex; align-items:center; justify-content:center; color:var(--primary); margin-bottom:16px; }
.scat-ic svg { width:24px; height:24px; }
.scat h3 { font-size:18px; font-weight:700; margin-bottom:9px; }
.scat p { font-size:14.5px; color:var(--body); line-height:1.7; }

.bene-g { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.bene { display:flex; gap:15px; align-items:flex-start; padding:24px; background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--r); transition:var(--t); }
.bene:hover { background:#fff; box-shadow:var(--shadow); }
.bene-chk { width:30px; height:30px; border-radius:8px; background:var(--primary); color:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.bene-chk svg { width:16px; height:16px; }
.bene h4 { font-size:15.5px; font-weight:700; color:var(--ink); margin-bottom:4px; }
.bene p { font-size:14px; color:var(--body); line-height:1.6; }

/* === FAQ === */
.faq-list { max-width:840px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.faq { background:#fff; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:var(--t); }
.faq.open { border-color:var(--primary-l); box-shadow:var(--shadow); }
.faq-q { padding:22px 26px; display:flex; justify-content:space-between; align-items:center; gap:16px; cursor:pointer; font-size:16px; font-weight:600; color:var(--ink); transition:color .3s; }
.faq-q:hover { color:var(--primary); }
.faq-ic { width:30px; height:30px; border-radius:8px; background:var(--primary-05); color:var(--primary); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:var(--t); }
.faq-ic svg { width:16px; height:16px; transition:transform .3s; }
.faq.open .faq-ic { background:var(--primary); color:#fff; }
.faq.open .faq-ic svg { transform:rotate(180deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq.open .faq-a { max-height:300px; }
.faq-a-in { padding:0 26px 24px; font-size:15px; color:var(--body); line-height:1.8; }

/* === CONTACT === */
.ct-g { display:grid; grid-template-columns:1fr 1.4fr; gap:44px; align-items:start; }
.ct-info { background:var(--bg-deep); border-radius:18px; padding:40px; color:#fff; position:relative; overflow:hidden; }
.ct-info::before { content:''; position:absolute; top:-100px; right:-100px; width:300px; height:300px; background:radial-gradient(circle, rgba(44,125,224,0.18), transparent 65%); border-radius:50%; }
.ct-info-in { position:relative; z-index:2; }
.ct-info h3 { color:#fff; font-size:23px; margin-bottom:10px; }
.ct-info > .ct-info-in > p { color:#a9bdd6; font-size:14.5px; line-height:1.7; margin-bottom:30px; }
.ct-item { display:flex; gap:14px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,0.1); }
.ct-item:last-child { border-bottom:none; }
.ct-ic { width:44px; height:44px; border-radius:11px; background:rgba(255,255,255,0.08); display:flex; align-items:center; justify-content:center; color:#7ab2f0; flex-shrink:0; }
.ct-ic svg { width:19px; height:19px; }
.ct-lbl { font-size:11.5px; color:#7e96b5; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:3px; }
.ct-val { font-size:15px; color:#fff; font-weight:500; line-height:1.5; }
.ct-val a { color:#fff; }
.ct-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:42px; box-shadow:var(--shadow); }
.fg { margin-bottom:20px; }
.fl { display:block; font-size:13px; font-weight:600; color:var(--ink-2); margin-bottom:8px; }
.fi, .ft2 { width:100%; padding:13px 16px; background:var(--bg-soft); border:1.5px solid var(--line); border-radius:var(--r-sm); color:var(--ink); font-family:var(--fb); font-size:15px; transition:var(--t); outline:none; }
.fi:focus, .ft2:focus { border-color:var(--primary); background:#fff; box-shadow:0 0 0 4px var(--primary-05); }
.fi::placeholder, .ft2::placeholder { color:var(--muted); }
.ft2 { height:130px; resize:vertical; min-height:90px; }
.fr { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-ok { display:none; padding:14px 18px; margin-top:16px; background:rgba(13,148,136,0.08); border:1px solid rgba(13,148,136,0.25); border-radius:var(--r-sm); font-size:14px; color:var(--accent); font-weight:500; }

/* === ABOUT PAGE === */
.mv-g { display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.mv { padding:42px; border-radius:18px; border:1px solid var(--line); }
.mv-mis { background:var(--primary-05); border-color:rgba(13,92,171,0.14); }
.mv-vis { background:rgba(13,148,136,0.04); border-color:rgba(13,148,136,0.14); }
.mv-ic { width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:22px; }
.mv-mis .mv-ic { background:var(--primary); color:#fff; }
.mv-vis .mv-ic { background:var(--accent); color:#fff; }
.mv-ic svg { width:28px; height:28px; }
.mv h3 { font-size:24px; margin-bottom:13px; }
.mv p { font-size:16px; color:var(--body); line-height:1.85; }

.vals-g { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.val-card { padding:34px 28px; background:#fff; border:1px solid var(--line); border-radius:var(--r); text-align:center; transition:var(--t); }
.val-card:hover { transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.val-ic { width:60px; height:60px; border-radius:15px; background:var(--primary-05); display:flex; align-items:center; justify-content:center; color:var(--primary); margin:0 auto 20px; transition:var(--t); }
.val-card:hover .val-ic { background:var(--primary); color:#fff; }
.val-ic svg { width:28px; height:28px; }
.val-card h3 { font-size:17px; font-weight:700; margin-bottom:9px; }
.val-card p { font-size:14px; color:var(--body); line-height:1.7; }

/* === PRODUCT OVERVIEW PAGE === */
.pov-g { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.pov-card { background:#fff; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:var(--t); }
.pov-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:transparent; }
.pov-img { aspect-ratio:16/10; overflow:hidden; }
.pov-img img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.pov-card:hover .pov-img img { transform:scale(1.07); }
.pov-body { padding:26px; }
.pov-body h3 { font-size:19px; font-weight:700; margin-bottom:10px; }
.pov-body p { font-size:14.5px; color:var(--body); line-height:1.7; margin-bottom:18px; }
.pov-lnk { display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:600; color:var(--primary); }
.pov-lnk svg { width:16px; height:16px; transition:transform .3s; }
.pov-card:hover .pov-lnk svg { transform:translateX(5px); }

/* === LEGAL PAGES === */
.legal { max-width:840px; margin:0 auto; }
.legal-block { margin-bottom:38px; }
.legal-block h2 { font-size:22px; margin-bottom:12px; display:flex; align-items:center; gap:12px; }
.legal-block h2 .num { width:34px; height:34px; border-radius:9px; background:var(--primary-05); color:var(--primary); display:inline-flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
.legal-block p { font-size:15.5px; color:var(--body); line-height:1.85; }

/* === KEYFRAMES === */
@keyframes marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* === RESPONSIVE === */
@media(max-width:1100px){
  .why-g { grid-template-columns:repeat(2,1fr); }
  .proc-g { grid-template-columns:repeat(2,1fr); gap:34px; }
  .proc-arrow { display:none; }
  .vals-g { grid-template-columns:repeat(2,1fr); }
  .ft-g { grid-template-columns:1fr 1fr; gap:36px; }
}
@media(max-width:960px){
  .hero-in { grid-template-columns:1fr; gap:60px; }
  .hero-visual { max-width:440px; margin:0 auto; }
  .about-g { grid-template-columns:1fr; gap:60px; }
  .pgrid { grid-template-columns:repeat(2,1fr); }
  .pov-g { grid-template-columns:repeat(2,1fr); }
  .ct-g { grid-template-columns:1fr; }
  .mv-g { grid-template-columns:1fr; }
  .stats-g { grid-template-columns:repeat(2,1fr); gap:40px; }
}
@media(max-width:768px){
  section { padding:74px 0; }
  .nav-links, .nav-cta { display:none; }
  .ham { display:flex; }
  .pgrid { grid-template-columns:1fr; }
  .why-g { grid-template-columns:1fr; }
  .feat-g, .subcat-g, .bene-g { grid-template-columns:1fr; }
  .fr { grid-template-columns:1fr; }
  .ft-g { grid-template-columns:1fr; gap:40px; }
  .pov-g { grid-template-columns:1fr; }
  .vals-g { grid-template-columns:1fr 1fr; }
  .ft-bot { flex-direction:column; text-align:center; }
  .hero-badge-1 { left:-10px; } .hero-badge-2 { right:-10px; }
  .tcard { padding:32px 24px; } .tcard-q { font-size:18px; }
}
@media(max-width:480px){
  .hero-cta { flex-direction:column; } .hero-cta .btn { width:100%; justify-content:center; }
  .hero-trust { gap:22px; }
  .ct-form, .ct-info { padding:26px; }
  .cta-row { flex-direction:column; align-items:stretch; }
  .vals-g { grid-template-columns:1fr; }
  .stats-g { grid-template-columns:1fr 1fr; gap:30px; }
  .about-exp { right:-10px; padding:18px 20px; }
}
