@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800;900&family=Mulish:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

:root {
  --bg:#070e10;--bg2:#0b181c;--surface:#0f2028;--surface2:#142830;
  --border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.12);
  --teal:#00c8b8;--teal-l:#00dece;--teal-d:#009080;--teal-g:rgba(0,200,184,.1);
  --lime:#aaeb3d;--lime-d:#84b82d;--lime-g:rgba(170,235,61,.1);
  --text:#e8f0f2;--text2:#b0c4c8;--text3:#6b8c92;--text-inv:#07151a;
  --red:#e85050;
  --fd:"Manrope",sans-serif;--fb:"Mulish",sans-serif;
  --r-sm:8px;--r-md:14px;--r-lg:20px;--r-xl:32px;--r-2xl:44px;
  --shadow-sm:0 2px 14px rgba(0,0,0,.28);
  --shadow:0 8px 40px rgba(0,0,0,.45);
  --shadow-lg:0 20px 64px rgba(0,0,0,.55);
  --glow-t:0 0 32px rgba(0,200,184,.2);
  --nav:72px;--t:.28s cubic-bezier(.4,0,.2,1);--t2:.5s cubic-bezier(.4,0,.2,1);
}
[data-theme="light"] {
  --bg:#f0f5f7;--bg2:#e4ecef;--surface:#ffffff;--surface2:#eef3f5;
  --border:rgba(0,0,0,.08);--border2:rgba(0,0,0,.13);
  --teal:#007f74;--teal-l:#009a8e;--teal-d:#006660;--teal-g:rgba(0,127,116,.09);
  --lime:#5d8f00;--lime-d:#4a7200;--lime-g:rgba(93,143,0,.09);
  --text:#0d1f24;--text2:#2e4a50;--text3:#5a7880;--text-inv:#f0f5f7;
  --shadow-sm:0 2px 14px rgba(0,0,0,.06);
  --shadow:0 8px 40px rgba(0,0,0,.1);
  --shadow-lg:0 20px 64px rgba(0,0,0,.13);
  --glow-t:0 0 32px rgba(0,127,116,.14);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fb);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.65;transition:background var(--t2),color var(--t2)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--teal-d);border-radius:3px}
::selection{background:var(--teal);color:var(--bg)}

/* UTILS */
.container{max-width:1200px;margin:0 auto;padding:0 28px}
.section{padding:96px 0}.section-sm{padding:60px 0}
.divider{height:1px;background:var(--border)}
.h-xl{font-family:var(--fd);font-size:clamp(2.3rem,4.2vw,3.7rem);font-weight:900;line-height:1.1;letter-spacing:-.04em}
.h-lg{font-family:var(--fd);font-size:clamp(1.75rem,3vw,2.7rem);font-weight:800;line-height:1.14;letter-spacing:-.03em}
.h-md{font-family:var(--fd);font-size:clamp(1.25rem,2vw,1.85rem);font-weight:700;line-height:1.2;letter-spacing:-.02em}
.h-sm{font-family:var(--fd);font-size:1.12rem;font-weight:700;letter-spacing:-.015em}
.tc{color:var(--teal)}.lc{color:var(--lime)}.mc{color:var(--text3)}.t2{color:var(--text2)}
.center{text-align:center}

.label{display:inline-flex;align-items:center;gap:6px;font-family:var(--fd);font-size:.71rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--lime);background:var(--lime-g);border:1px solid rgba(170,235,61,.22);padding:5px 13px;border-radius:100px;margin-bottom:16px}
[data-theme="light"] .label{border-color:rgba(93,143,0,.22)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--fd);font-size:.87rem;font-weight:700;padding:13px 26px;border-radius:100px;transition:var(--t);white-space:nowrap;letter-spacing:-.01em;cursor:pointer;border:none}
.btn svg{width:17px;height:17px;flex-shrink:0;transition:transform var(--t)}
.btn:hover svg{transform:translateX(3px)}
.btn-p{background:var(--teal);color:var(--text-inv);box-shadow:0 4px 20px rgba(0,200,184,.25)}
.btn-p:hover{background:var(--teal-l);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,200,184,.38)}
.btn-l{background:var(--lime);color:#162200;box-shadow:0 4px 18px rgba(170,235,61,.2)}
.btn-l:hover{filter:brightness(1.07);transform:translateY(-2px);box-shadow:0 8px 28px rgba(170,235,61,.33)}
.btn-g{background:transparent;color:var(--text);border:1.5px solid var(--border2)}
.btn-g:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-g)}
.btn-sm{padding:9px 18px;font-size:.8rem;gap:7px}
.btn-sm svg{width:15px;height:15px}

/* CARD */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px;transition:var(--t);position:relative;overflow:hidden}
.card::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--teal),var(--lime));opacity:0;transition:opacity var(--t)}
.card:hover{border-color:rgba(0,200,184,.28);transform:translateY(-4px);box-shadow:var(--shadow)}
.card:hover::after{opacity:1}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.reveal.vis{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}

/* SECTION HEADER */
.sh{margin-bottom:52px}.sh.c{text-align:center}
.sh p{font-size:.98rem;color:var(--text3);margin-top:13px;max-width:540px;line-height:1.72}
.sh.c p{margin-left:auto;margin-right:auto}

/* PAGE LOADER */
#page-loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity .5s ease,visibility .5s ease}
#page-loader.out{opacity:0;visibility:hidden}
.pl-logo{font-family:var(--fd);font-size:1.8rem;font-weight:900;color:var(--teal);letter-spacing:-.05em}
.pl-bar{width:180px;height:3px;background:var(--surface2);border-radius:2px;overflow:hidden}
.pl-fill{height:100%;width:0;border-radius:2px;background:linear-gradient(90deg,var(--teal),var(--lime));animation:plfill 1.1s ease forwards}
@keyframes plfill{to{width:100%}}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:500;height:var(--nav);display:flex;align-items:center;background:transparent;border-bottom:1px solid transparent;transition:background var(--t2),backdrop-filter var(--t2),border-color var(--t2)}
.site-header.scrolled{background:rgba(7,14,16,.88);backdrop-filter:blur(22px) saturate(180%);border-color:var(--border)}
[data-theme="light"] .site-header.scrolled{background:rgba(240,245,247,.92)}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:14px}
.site-logo{display:flex;align-items:center;gap:11px;flex-shrink:0;cursor:pointer}
.logo-mark{width:42px;height:42px;flex-shrink:0;background:linear-gradient(135deg,var(--teal),var(--lime));border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--bg);font-weight:900;box-shadow:var(--glow-t)}
.logo-words strong{display:block;font-family:var(--fd);font-size:1.05rem;font-weight:900;color:var(--text);letter-spacing:-.04em}
.logo-words span{font-size:.67rem;color:var(--teal);letter-spacing:.07em;text-transform:uppercase;font-weight:600}
.nav-primary{display:flex;align-items:center;gap:2px}
.nav-primary a{font-family:var(--fd);font-size:.81rem;font-weight:600;color:var(--text3);padding:7px 12px;border-radius:var(--r-sm);transition:color var(--t),background var(--t);position:relative;cursor:pointer}
.nav-primary a:hover,.nav-primary a.active{color:var(--text)}
.nav-primary a:hover{background:rgba(255,255,255,.05)}
[data-theme="light"] .nav-primary a:hover{background:rgba(0,0,0,.05)}
.nav-primary a.active::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:18px;height:2px;background:var(--teal);border-radius:1px}
.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.btn-login{font-family:var(--fd);font-size:.79rem;font-weight:700;padding:8px 18px;border-radius:100px;background:transparent;color:var(--text2);border:1.5px solid var(--border2);transition:var(--t);cursor:pointer}
.btn-login:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-g)}
.btn-cta{font-family:var(--fd);font-size:.79rem;font-weight:700;padding:9px 20px;border-radius:100px;background:var(--teal);color:var(--text-inv);transition:var(--t);cursor:pointer;border:none;box-shadow:0 3px 14px rgba(0,200,184,.24)}
.btn-cta:hover{background:var(--teal-l);transform:translateY(-1px);box-shadow:0 6px 22px rgba(0,200,184,.34)}
.hamburger{display:none;flex-direction:column;gap:5px;width:40px;height:40px;padding:8px;cursor:pointer;border-radius:var(--r-sm);border:1.5px solid var(--border2);background:none;align-items:center;justify-content:center}
.hamburger span{display:block;width:20px;height:2px;background:var(--text);border-radius:1px;transition:var(--t)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{position:fixed;top:var(--nav);left:0;right:0;bottom:0;background:var(--bg);border-top:1px solid var(--border);z-index:490;padding:28px 28px 40px;display:flex;flex-direction:column;transform:translateX(110%);transition:transform .38s cubic-bezier(.4,0,.2,1);overflow-y:auto}
.mobile-nav.open{transform:none}
.mobile-nav a{font-family:var(--fd);font-size:1.35rem;font-weight:800;color:var(--text3);padding:13px 0;border-bottom:1px solid var(--border);transition:color var(--t);cursor:pointer;letter-spacing:-.02em}
.mobile-nav a:hover{color:var(--teal)}
.mob-actions{margin-top:24px;display:flex;flex-direction:column;gap:10px}

/* FLOATING ACTION BAR */
.fab-bar{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:480;display:flex;flex-direction:column;gap:8px}
.fab-btn{width:46px;height:46px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:var(--t);box-shadow:var(--shadow-sm);position:relative}
.fab-btn:hover{background:var(--teal);border-color:var(--teal);transform:translateX(-3px) scale(1.06);box-shadow:var(--glow-t)}
.fab-btn:hover .fab-tip{opacity:1;pointer-events:auto;transform:translateY(-50%) translateX(0)}
.fab-tip{position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%) translateX(8px);background:var(--surface);border:1px solid var(--border2);color:var(--text);font-family:var(--fd);font-size:.71rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:5px 11px;border-radius:var(--r-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:var(--t);box-shadow:var(--shadow-sm)}
.fab-sep{height:1px;background:var(--border);margin:2px 6px}
#fab-top{opacity:0;pointer-events:none;transition:opacity var(--t)}
#fab-top.show{opacity:1;pointer-events:auto}
.share-panel{position:absolute;right:calc(100% + 12px);top:0;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);padding:10px;width:190px;box-shadow:var(--shadow);display:none;flex-direction:column;gap:4px;z-index:10}
.share-panel.open{display:flex}
.share-item{display:flex;align-items:center;gap:10px;font-family:var(--fd);font-size:.81rem;font-weight:600;color:var(--text2);padding:9px 12px;border-radius:var(--r-sm);transition:var(--t);cursor:pointer;border:none;background:none;width:100%;text-align:left}
.share-item:hover{background:var(--teal-g);color:var(--teal)}
.share-item svg{width:16px;height:16px;flex-shrink:0}

/* PAGE HERO */
.page-hero{padding:calc(var(--nav) + 64px) 0 60px;background:radial-gradient(ellipse 70% 80% at 85% 40%,var(--teal-g) 0%,transparent 60%),var(--bg);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:52px 52px;mask-image:radial-gradient(ellipse 80% 80% at 85% 50%,black 0%,transparent 65%)}
.page-hero-inner{position:relative;z-index:1;max-width:680px}
.breadcrumb{display:flex;align-items:center;gap:7px;font-size:.77rem;color:var(--text3);margin-bottom:16px}
.breadcrumb a{color:var(--teal);cursor:pointer;font-weight:600}
.breadcrumb span{color:var(--border2)}

/* HOME HERO */
.hero-section{min-height:100vh;display:flex;align-items:center;padding-top:var(--nav);position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 72% 50%,rgba(0,200,184,.1) 0%,transparent 55%),radial-gradient(ellipse 40% 40% at 18% 82%,rgba(170,235,61,.07) 0%,transparent 55%),linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 70% 80% at 40% 50%,black 0%,transparent 65%)}
.hero-content{position:relative;z-index:1;max-width:640px}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:var(--teal-g);border:1px solid rgba(0,200,184,.22);padding:6px 16px 6px 8px;border-radius:100px;margin-bottom:28px;font-family:var(--fd);font-size:.73rem;font-weight:700;color:var(--teal);letter-spacing:.06em;text-transform:uppercase}
.badge-pulse{width:9px;height:9px;border-radius:50%;background:var(--teal);animation:bpulse 2s infinite}
@keyframes bpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.65)}}
.hero-content h1{margin-bottom:22px}
.hero-content h1 em{font-style:normal;color:var(--teal)}
.hero-desc{font-size:1.04rem;color:var(--text2);margin-bottom:38px;max-width:520px;line-height:1.78}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:54px}
.hero-stats{display:flex;gap:38px;flex-wrap:wrap}
.hs-num{font-family:var(--fd);font-size:1.95rem;font-weight:900;line-height:1;letter-spacing:-.05em}
.hs-num span{color:var(--lime)}
.hs-label{font-size:.77rem;color:var(--text3);margin-top:4px;font-weight:500}
.hero-visual{position:absolute;right:0;top:50%;transform:translateY(-50%);width:40%;z-index:1;display:flex;flex-direction:column;gap:14px;padding-right:10px}
.hvc{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);padding:18px 22px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.hvc:nth-child(1){animation:hvcf 6s ease-in-out infinite}
.hvc:nth-child(2){animation:hvcf 6s ease-in-out -2s infinite;margin-left:28px}
.hvc:nth-child(3){animation:hvcf 6s ease-in-out -4s infinite}
@keyframes hvcf{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.hvc-icon{width:46px;height:46px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.hvc-icon.t{background:var(--teal-g)}.hvc-icon.l{background:var(--lime-g)}.hvc-icon.r{background:rgba(232,80,80,.1)}
.hvc-body strong{display:block;font-family:var(--fd);font-size:.87rem;font-weight:700}
.hvc-body span{font-size:.75rem;color:var(--text3)}

/* TRUST BAR */
.trust-bar{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:17px 0}
.trust-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.t-item{display:flex;align-items:center;gap:9px;font-size:.79rem;font-weight:600;color:var(--text3)}
.t-item svg{width:17px;height:17px;color:var(--teal);flex-shrink:0}

/* SERVICES */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:18px}
.srv-icon{width:52px;height:52px;border-radius:var(--r-sm);background:var(--teal-g);border:1px solid rgba(0,200,184,.2);display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:18px;transition:var(--t)}
.card:hover .srv-icon{background:var(--lime-g);border-color:rgba(170,235,61,.25)}
.card h3{font-family:var(--fd);font-size:1rem;font-weight:700;margin-bottom:9px;letter-spacing:-.015em}
.card p{font-size:.87rem;color:var(--text3);line-height:1.65}
.srv-more{display:inline-flex;align-items:center;gap:6px;font-family:var(--fd);font-size:.79rem;font-weight:700;color:var(--teal);margin-top:14px;transition:gap var(--t)}
.srv-more svg{width:14px;height:14px;transition:transform var(--t)}
.card:hover .srv-more{gap:10px}
.card:hover .srv-more svg{transform:translateX(3px)}

/* STATS */
.stats-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);padding:52px 56px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center;position:relative;overflow:hidden}
.stats-wrap::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 70% at 50% 0%,var(--teal-g) 0%,transparent 65%);pointer-events:none}
.sbn{font-family:var(--fd);font-size:clamp(2rem,3.2vw,2.8rem);font-weight:900;line-height:1;letter-spacing:-.05em}
.sbn span{color:var(--teal)}
.sbl{font-size:.81rem;color:var(--text3);margin-top:7px;font-weight:500}

/* ABOUT */
.about-2col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img-box{border-radius:var(--r-2xl);overflow:hidden;position:relative;background:linear-gradient(135deg,var(--surface2),var(--surface));aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.about-img-box img{width:100%;height:100%;object-fit:cover}
.about-placeholder{text-align:center;padding:40px}
.about-placeholder .big-icon{font-size:5rem;margin-bottom:14px}
.cert-chip{position:absolute;bottom:20px;left:20px;background:var(--bg);border:1px solid var(--border2);border-radius:var(--r-md);padding:12px 16px;display:flex;align-items:center;gap:10px;backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}
.cert-dot{width:10px;height:10px;border-radius:50%;background:var(--lime);flex-shrink:0}
.cert-words strong{display:block;font-family:var(--fd);font-size:.83rem;font-weight:700}
.cert-words span{font-size:.72rem;color:var(--text3)}
.about-bullets{display:flex;flex-direction:column;gap:12px;margin:24px 0 32px}
.ab-item{display:flex;align-items:flex-start;gap:12px;font-size:.9rem;color:var(--text2);line-height:1.55}
.ab-item::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:6px}

/* PROCESS */
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.proc-steps::before{content:"";position:absolute;top:32px;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,var(--teal),var(--lime),transparent);z-index:0}
.proc-step{text-align:center;padding:0 16px;position:relative;z-index:1}
.proc-num{width:64px;height:64px;border-radius:50%;background:var(--surface);border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:1rem;font-weight:900;color:var(--teal);margin:0 auto 18px;transition:var(--t)}
.proc-step:hover .proc-num{border-color:var(--teal);background:var(--teal-g);box-shadow:0 0 0 6px rgba(0,200,184,.07)}
.proc-step h4{font-family:var(--fd);font-size:.92rem;font-weight:700;margin-bottom:7px}
.proc-step p{font-size:.82rem;color:var(--text3);line-height:1.55}

/* TESTIMONIALS */
.test-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:18px}
.test-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 30px;transition:var(--t)}
.test-card:hover{border-color:rgba(0,200,184,.22);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.stars{display:flex;gap:3px;margin-bottom:14px}
.star{color:var(--lime);font-size:.95rem}
.test-text{font-size:.88rem;color:var(--text2);line-height:1.72;margin-bottom:22px;font-style:italic}
.test-author{display:flex;align-items:center;gap:12px}
.test-av{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--teal),var(--lime));display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:.82rem;font-weight:800;color:var(--bg)}
.test-meta strong{display:block;font-family:var(--fd);font-size:.87rem;font-weight:700}
.test-meta span{font-size:.75rem;color:var(--text3)}

/* GALLERY — combined images + videos */
.gallery-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.gf-btn{font-family:var(--fd);font-size:.79rem;font-weight:700;padding:8px 18px;border-radius:100px;cursor:pointer;color:var(--text3);border:1.5px solid var(--border);background:transparent;transition:var(--t)}
.gf-btn.active,.gf-btn:hover{background:var(--teal-g);color:var(--teal);border-color:rgba(0,200,184,.3)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.g-item{position:relative;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;background:var(--surface2);aspect-ratio:4/3}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.g-item:hover img{transform:scale(1.05)}
.g-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3.5rem;transition:transform .5s ease}
.g-item:hover .g-placeholder{transform:scale(1.06)}
.g-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(7,14,16,.9) 100%);opacity:0;transition:opacity var(--t);display:flex;align-items:flex-end;padding:18px}
.g-item:hover .g-overlay{opacity:1}
.g-label{font-family:var(--fd);font-size:.84rem;font-weight:700}
.g-sub{font-size:.71rem;color:var(--teal);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.g-badge{position:absolute;top:12px;left:12px;background:rgba(7,14,16,.75);backdrop-filter:blur(8px);border:1px solid var(--border2);border-radius:100px;padding:3px 10px;font-family:var(--fd);font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.g-badge.photo{color:var(--teal)}.g-badge.video{color:var(--lime)}
.g-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t)}
.g-item.is-video:hover .g-play{opacity:1}
.g-play-circle{width:52px;height:52px;border-radius:50%;background:var(--teal);display:flex;align-items:center;justify-content:center;box-shadow:var(--glow-t)}
.g-play-circle svg{width:20px;height:20px;fill:var(--bg);margin-left:2px}
.gallery-count{font-family:var(--fd);font-size:.82rem;font-weight:600;color:var(--text3);margin-left:auto;align-self:center}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:800;background:rgba(7,14,16,.96);backdrop-filter:blur(18px);display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox-img{max-width:88vw;max-height:82vh;border-radius:var(--r-xl);object-fit:contain;box-shadow:var(--shadow-lg)}
.lb-ph{text-align:center;padding:48px;max-width:500px;background:var(--surface);border-radius:var(--r-2xl);border:1px solid var(--border2)}
.lb-ph .lb-ico{font-size:7rem;margin-bottom:20px}
.lb-ph h3{font-family:var(--fd);font-size:1.5rem;font-weight:800;margin-bottom:8px}
.lb-ph p{font-size:.88rem;color:var(--text3)}
.lb-close{position:absolute;top:22px;right:22px;width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;color:var(--text);font-size:1.1rem;cursor:pointer;transition:var(--t)}
.lb-close:hover{background:var(--red);border-color:var(--red)}

/* VIDEO MODAL */
.video-modal{position:fixed;inset:0;z-index:800;background:rgba(7,14,16,.97);backdrop-filter:blur(22px);display:none;align-items:center;justify-content:center;padding:24px}
.video-modal.open{display:flex}
.vm-inner{position:relative;width:100%;max-width:920px}
.vm-inner iframe{width:100%;aspect-ratio:16/9;border-radius:var(--r-xl);border:none}
.vm-close{position:absolute;top:-52px;right:0;width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;color:var(--text);font-size:1.1rem;cursor:pointer;transition:var(--t)}
.vm-close:hover{background:var(--red);border-color:var(--red)}

/* LOGIN MODAL */
.login-modal{position:fixed;inset:0;z-index:700;background:rgba(7,14,16,.85);backdrop-filter:blur(14px);display:none;align-items:center;justify-content:center;padding:20px}
.login-modal.open{display:flex}
.login-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-2xl);width:100%;max-width:440px;padding:44px;position:relative;box-shadow:var(--shadow-lg)}
.lm-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--text3);cursor:pointer;transition:var(--t)}
.lm-close:hover{background:var(--red);color:#fff;border-color:var(--red)}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.login-logo .logo-mark{width:36px;height:36px;font-size:1.1rem;border-radius:9px}
.login-logo span{font-family:var(--fd);font-size:.95rem;font-weight:900}
.lm-tabs{display:flex;gap:4px;background:var(--surface2);border-radius:100px;padding:4px;margin-bottom:28px}
.lm-tab{flex:1;text-align:center;padding:9px;font-family:var(--fd);font-size:.82rem;font-weight:700;cursor:pointer;border-radius:100px;transition:var(--t);color:var(--text3)}
.lm-tab.active{background:var(--teal);color:var(--text-inv)}
.lm-form{display:none}
.lm-form.active{display:block}
.lm-g{margin-bottom:16px}
.lm-g label{display:block;font-family:var(--fd);font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text3);margin-bottom:7px}
.lm-g input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);padding:12px 16px;color:var(--text);font-family:var(--fb);font-size:.9rem;outline:none;transition:border-color var(--t),box-shadow var(--t)}
.lm-g input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,200,184,.1)}
.lm-g input::placeholder{color:var(--text3)}
.lm-forgot{font-size:.77rem;color:var(--teal);cursor:pointer;display:block;text-align:right;margin-top:-8px;margin-bottom:20px;font-weight:600}
.lm-or{display:flex;align-items:center;gap:12px;margin:18px 0}
.lm-or::before,.lm-or::after{content:"";flex:1;height:1px;background:var(--border)}
.lm-or span{font-size:.74rem;color:var(--text3);font-weight:600}

/* CONTACT */
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:64px}
.contact-info-list{display:flex;flex-direction:column;gap:24px}
.ci-item{display:flex;gap:16px;align-items:flex-start}
.ci-icon{width:44px;height:44px;flex-shrink:0;border-radius:var(--r-sm);background:var(--teal-g);border:1px solid rgba(0,200,184,.18);display:flex;align-items:center;justify-content:center}
.ci-icon svg{width:20px;height:20px;color:var(--teal)}
.ci-text strong{display:block;font-family:var(--fd);font-size:.87rem;font-weight:700;margin-bottom:3px}
.ci-text span,.ci-text a{font-size:.87rem;color:var(--text3)}
.ci-text a:hover{color:var(--teal)}
.contact-form-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-2xl);padding:44px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{margin-bottom:18px}
.fg label{display:block;font-family:var(--fd);font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text3);margin-bottom:7px}
.fg input,.fg select,.fg textarea{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);padding:12px 16px;color:var(--text);font-family:var(--fb);font-size:.9rem;outline:none;resize:none;transition:border-color var(--t),box-shadow var(--t)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,200,184,.1)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--text3)}
.fg select option{background:var(--surface)}
.form-success{display:none;text-align:center;padding:24px;background:var(--lime-g);border:1px solid rgba(170,235,61,.22);border-radius:var(--r-lg);margin-top:16px}
.form-success svg{width:40px;height:40px;color:var(--lime)}
.form-success p{font-size:.88rem;color:var(--text2);margin-top:8px}
.map-placeholder{background:var(--surface);height:210px;border-radius:var(--r-lg);border:1px solid var(--border);margin-top:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text3);font-size:.88rem}

/* MISSION VISION */
.mv-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.mv-card{border-radius:var(--r-2xl);padding:48px 42px;position:relative;overflow:hidden}
.mv-card.mission{background:linear-gradient(135deg,rgba(0,200,184,.12),rgba(0,200,184,.03));border:1px solid rgba(0,200,184,.18)}
.mv-card.vision{background:linear-gradient(135deg,rgba(170,235,61,.09),rgba(170,235,61,.02));border:1px solid rgba(170,235,61,.16)}
.mv-icon{font-size:2.8rem;margin-bottom:22px}
.mv-card h3{font-family:var(--fd);font-size:1.5rem;font-weight:800;margin-bottom:16px;letter-spacing:-.03em}
.mv-card p{font-size:.94rem;color:var(--text2);line-height:1.78}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.value-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;text-align:center;transition:var(--t)}
.value-card:hover{border-color:rgba(0,200,184,.28);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.val-icon{font-size:1.9rem;margin-bottom:10px}
.value-card h4{font-family:var(--fd);font-size:.96rem;font-weight:700;margin-bottom:7px}
.value-card p{font-size:.8rem;color:var(--text3);line-height:1.6}

/* SERVICES DETAIL */
.srv-detail-block{display:grid;grid-template-columns:1fr 1.35fr;gap:64px;align-items:center;margin-bottom:88px}
.srv-detail-block.rev{grid-template-columns:1.35fr 1fr}
.srv-detail-block.rev .srv-visual{order:-1}
.srv-visual{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);padding:52px;text-align:center}
.srv-visual .big-icon{font-size:5rem;margin-bottom:18px}
.srv-feat li{display:flex;align-items:flex-start;gap:11px;font-size:.88rem;color:var(--text2);margin-bottom:9px}
.srv-feat li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:5px}

/* CERT DISPLAY */
.cert-display{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-2xl);padding:44px;max-width:700px;margin:0 auto;text-align:center}
.cert-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}
.cert-brand{font-family:var(--fd);font-size:1rem;font-weight:900;color:var(--teal);letter-spacing:-.04em}
.cert-det{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 24px;margin:22px 0;text-align:left}
.cdr{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:.86rem}
.cdr:last-child{border-bottom:none}
.cdr span:first-child{color:var(--text3)}
.cdr span:last-child{font-weight:700}

/* CTA BANNER */
.cta-band{background:linear-gradient(135deg,var(--teal) 0%,var(--teal-d) 100%);border-radius:var(--r-2xl);padding:58px 52px;display:flex;align-items:center;justify-content:space-between;gap:36px;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:-50%;right:-6%;width:380px;height:380px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.cta-band h2{font-family:var(--fd);font-size:clamp(1.5rem,2.8vw,2.1rem);font-weight:900;color:var(--bg);max-width:500px;line-height:1.2;letter-spacing:-.03em}
.cta-band h2 span{color:rgba(7,14,16,.5)}
.cta-band .btn-l{flex-shrink:0}

/* FOOTER */
.site-footer{background:var(--surface);border-top:1px solid var(--border);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.foot-brand p{font-size:.85rem;color:var(--text3);line-height:1.72;margin:16px 0 22px;max-width:280px}
.foot-socials{display:flex;gap:8px}
.foot-soc{width:37px;height:37px;border-radius:var(--r-sm);background:rgba(255,255,255,.04);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:var(--t);cursor:pointer}
.foot-soc:hover{background:var(--teal-g);border-color:rgba(0,200,184,.3);color:var(--teal)}
.foot-soc svg{width:15px;height:15px}
.foot-col h5{font-family:var(--fd);font-size:.81rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--text);margin-bottom:18px}
.foot-col ul li{margin-bottom:9px}
.foot-col ul li a{font-size:.84rem;color:var(--text3);transition:color var(--t)}
.foot-col ul li a:hover{color:var(--teal)}
.fci{display:flex;gap:9px;margin-bottom:11px;font-size:.84rem;color:var(--text3);align-items:flex-start}
.fci svg{width:15px;height:15px;flex-shrink:0;color:var(--teal);margin-top:2px}
.foot-bottom{border-top:1px solid var(--border);padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.foot-bottom p{font-size:.79rem;color:var(--text3)}
.foot-bottom a{color:var(--teal)}
.foot-cert{display:flex;align-items:center;gap:7px;font-size:.73rem;color:var(--text3);background:var(--teal-g);border:1px solid rgba(0,200,184,.14);padding:5px 13px;border-radius:100px}
.foot-cert svg{width:13px;height:13px;color:var(--teal)}
.nl-wrap{background:var(--surface2);border-radius:var(--r-lg);padding:22px;margin-top:22px}
.nl-wrap h6{font-family:var(--fd);font-size:.83rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px}
.nl-row{display:flex;gap:8px}
.nl-row input{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:9px 14px;color:var(--text);font-family:var(--fb);font-size:.85rem;outline:none;transition:border-color var(--t)}
.nl-row input:focus{border-color:var(--teal)}
.nl-row input::placeholder{color:var(--text3)}
.nl-row button{padding:9px 16px;font-size:.79rem;font-family:var(--fd);font-weight:700;border-radius:var(--r-sm);background:var(--teal);color:var(--bg);border:none;cursor:pointer;flex-shrink:0;transition:var(--t)}
.nl-row button:hover{background:var(--teal-l)}

/* TOAST */
.toast{position:fixed;bottom:28px;right:80px;z-index:600;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);padding:13px 20px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);min-width:270px;transform:translateY(90px);opacity:0;transition:transform .38s ease,opacity .38s ease}
.toast.show{transform:none;opacity:1}
.t-icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.toast.success .t-icon{background:var(--lime-g);color:var(--lime)}
.toast.error .t-icon{background:rgba(232,80,80,.1);color:var(--red)}
.t-body strong{display:block;font-family:var(--fd);font-size:.85rem;font-weight:700}
.t-body span{font-size:.77rem;color:var(--text3)}

/* RESPONSIVE */
@media(max-width:1100px){
  .about-2col{grid-template-columns:1fr;gap:48px}
  .about-img-box{display:none}
  .hero-visual{display:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:900px){
  .nav-primary,.btn-cta{display:none}
  .hamburger{display:flex}
  .stats-wrap{grid-template-columns:repeat(2,1fr);padding:36px 28px}
  .proc-steps{grid-template-columns:repeat(2,1fr);gap:28px}
  .proc-steps::before{display:none}
  .mv-cards{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .cta-band{flex-direction:column;text-align:center;padding:40px 32px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .fab-bar{right:12px}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .form-row-2{grid-template-columns:1fr}
  .srv-detail-block,.srv-detail-block.rev{grid-template-columns:1fr}
  .srv-detail-block.rev .srv-visual{order:0}
  .toast{right:16px;left:16px;min-width:auto}
}
@media(max-width:640px){
  :root{--nav:64px}
  .section{padding:64px 0}.container{padding:0 18px}
  .stats-wrap{grid-template-columns:1fr 1fr;padding:28px 20px}
  .proc-steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;gap:10px}
  .hero-actions{flex-direction:column}
  .hero-stats{gap:22px}
  .cta-band{padding:32px 22px}
  .values-grid{grid-template-columns:1fr}
  .contact-form-box{padding:28px 22px}
  .fab-bar{right:10px}
  .fab-btn{width:40px;height:40px}
  .fab-tip{display:none}
}
@media(max-width:420px){
  .gallery-grid{grid-template-columns:1fr}
  .login-box{padding:30px 20px}
}

/* ════════════════════════════════════════════════
   SUPPLEMENT — additional page-specific styles
════════════════════════════════════════════════ */

/* Page hero alias */
.pg-hero{padding:calc(var(--nav) + 64px) 0 60px;background:radial-gradient(ellipse 70% 80% at 85% 40%,var(--teal-g) 0%,transparent 60%),var(--bg);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.pg-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:52px 52px;mask-image:radial-gradient(ellipse 80% 80% at 85% 50%,black 0%,transparent 65%)}
.pg-hero .container{position:relative;z-index:1}

/* Hero section alias + inner */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:var(--nav);position:relative;overflow:hidden}
.hero-inner{display:flex;align-items:center;justify-content:space-between;width:100%;position:relative;z-index:1}
.hero-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);flex-shrink:0;animation:hdot 2s infinite}
@keyframes hdot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.6)}}
.hero-content p{font-size:1.04rem;color:var(--text2);margin-bottom:38px;max-width:520px;line-height:1.78}
.hero-stat{display:flex;flex-direction:column}
.hs-label{font-size:.77rem;color:var(--text3);margin-top:4px;font-weight:500}

/* Hero floating visual cards */
.hv-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);padding:16px 20px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.hv-1{animation:hfc 6s ease-in-out infinite}
.hv-2{animation:hfc 6s ease-in-out -2s infinite;margin-left:32px}
.hv-3{animation:hfc 6s ease-in-out -4s infinite}
@keyframes hfc{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hv-ico{width:46px;height:46px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.hv-ico-t{background:rgba(0,200,184,.14)}
.hv-ico-l{background:rgba(170,235,61,.14)}
.hv-ico-r{background:rgba(232,80,80,.1)}
.hv-body strong{display:block;font-family:var(--fd);font-size:.88rem;font-weight:700}
.hv-body span{font-size:.74rem;color:var(--text3)}

/* Trust bar */
.trust-item{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;color:var(--text3)}
.trust-item svg{width:16px;height:16px;color:var(--teal);flex-shrink:0}
.trust-sep{width:1px;height:16px;background:var(--border)}

/* Services grid */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(268px,1fr));gap:18px}
.srv-card{cursor:default}
.srv-card .srv-icon{width:50px;height:50px;border-radius:var(--r-sm);background:var(--teal-g);border:1px solid rgba(0,200,184,.18);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:18px;transition:var(--t)}
.srv-card:hover .srv-icon{background:var(--lime-g);border-color:rgba(170,235,61,.28)}
.srv-card h3{font-family:var(--fd);font-size:1rem;font-weight:700;margin-bottom:8px}
.srv-card p{font-size:.85rem;color:var(--text3);line-height:1.65}
.srv-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--fd);font-size:.8rem;font-weight:700;color:var(--teal);margin-top:14px;transition:gap var(--t)}
.srv-card:hover .srv-link{gap:11px}
.srv-link svg{width:14px;height:14px}

/* Stats */
.stat-item{text-align:center}
.stat-num{font-family:var(--fd);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:900;line-height:1;letter-spacing:-.05em;color:var(--teal)}
.stat-lbl{font-size:.83rem;color:var(--text3);margin-top:8px}

/* About image box */
.about-img-inner{text-align:center;padding:40px}
.about-img-icon{font-size:5rem;margin-bottom:18px}
.about-img-label{font-family:var(--fd);font-size:1.1rem;font-weight:800;color:var(--teal)}
.about-img-sub{font-size:.78rem;color:var(--text3);margin-top:5px}
.cert-badge-float{position:absolute;bottom:20px;left:20px;background:var(--bg);border:1px solid var(--border2);border-radius:var(--r-md);padding:12px 16px;display:flex;align-items:center;gap:10px;backdrop-filter:blur(8px)}
.cbf-dot{width:10px;height:10px;border-radius:50%;background:var(--lime);flex-shrink:0}
.cbf-text strong{display:block;font-family:var(--fd);font-size:.82rem;font-weight:700}
.cbf-text span{font-size:.71rem;color:var(--text3)}

/* Check list */
.check-list{display:flex;flex-direction:column;gap:11px;margin:22px 0 30px}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--text2);line-height:1.6}
.check-list li::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:6px}

/* Section header */
.sh{margin-bottom:52px}
.sh p{font-size:.98rem;color:var(--text3);margin-top:13px;max-width:540px;line-height:1.72}
.center .sh p,.sh.c p{margin-left:auto;margin-right:auto}

/* Testimonials */
.tc-stars{display:flex;gap:3px;margin-bottom:14px}
.star{color:var(--lime);font-size:.95rem}
.tc-text{font-size:.88rem;color:var(--text2);line-height:1.72;margin-bottom:20px;font-style:italic}
.tc-author{display:flex;align-items:center;gap:12px}
.tc-avt{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--lime));display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:.82rem;font-weight:800;color:var(--bg);flex-shrink:0}
.tc-info strong{display:block;font-family:var(--fd);font-size:.86rem;font-weight:700}
.tc-info span{font-size:.75rem;color:var(--text3)}
.test-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 30px;transition:var(--t)}
.test-card:hover{border-color:rgba(0,200,184,.22);transform:translateY(-4px);box-shadow:var(--shadow)}

/* Mission & Vision */
.mv-mission{background:linear-gradient(135deg,rgba(0,200,184,.12),rgba(0,200,184,.03));border:1px solid rgba(0,200,184,.18)}
.mv-vision{background:linear-gradient(135deg,rgba(170,235,61,.09),rgba(170,235,61,.02));border:1px solid rgba(170,235,61,.16)}
.mv-card-icon{font-size:2.8rem;margin-bottom:22px}
.mv-card h2{font-family:var(--fd);font-size:1.6rem;font-weight:900;margin-bottom:16px;letter-spacing:-.04em}
.mv-card p{font-size:.94rem;color:var(--text2);line-height:1.78}

/* Values grid */
.val-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 24px;text-align:center;transition:var(--t)}
.val-item:hover{border-color:rgba(0,200,184,.28);transform:translateY(-4px);box-shadow:var(--shadow)}
.val-item h4{font-family:var(--fd);font-size:.95rem;font-weight:700;margin-bottom:7px;margin-top:12px}
.val-item p{font-size:.82rem;color:var(--text3);line-height:1.6}

/* Contact items */
.ct-info{display:flex;flex-direction:column;gap:4px}
.ct-items{display:flex;flex-direction:column;gap:22px;margin:28px 0 24px}
.ct-item{display:flex;align-items:flex-start;gap:14px}
.ct-icon{width:44px;height:44px;flex-shrink:0;border-radius:var(--r-sm);background:var(--teal-g);border:1px solid rgba(0,200,184,.18);display:flex;align-items:center;justify-content:center}
.ct-icon svg{width:19px;height:19px;color:var(--teal)}
.ct-text strong{display:block;font-family:var(--fd);font-size:.86rem;font-weight:700;margin-bottom:3px}
.ct-text span,.ct-text a{font-size:.86rem;color:var(--text3)}
.ct-text a:hover{color:var(--teal)}

/* Services detail (services.php) */
.srv-text .label{margin-bottom:12px}
.srv-text h2{margin-bottom:14px}
.srv-text p{font-size:.92rem;color:var(--text2);line-height:1.82;margin-bottom:20px}
.srv-vis-inner{text-align:center}
.srv-vis-icon{font-size:5.5rem;margin-bottom:18px;filter:drop-shadow(0 8px 24px rgba(0,200,184,.2))}
.srv-vis-label{font-family:var(--fd);font-size:1rem;font-weight:700;color:var(--teal)}

/* Gallery count */
.gf-count{font-size:.75rem;color:var(--text3);font-weight:600;margin-left:4px}

/* Map placeholder */
.map-pin{font-size:2.5rem}

/* Responsive additions */
@media(max-width:1100px){
  .hero-visual{display:none}
  .trust-sep:nth-child(n+8){display:none}
}
@media(max-width:900px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .trust-inner{justify-content:flex-start;gap:14px}
  .trust-sep{display:none}
}
@media(max-width:640px){
  .services-grid{grid-template-columns:1fr}
  .hero-stats{gap:24px}
  .pg-hero{padding:calc(var(--nav) + 48px) 0 48px}
}

/* ════════════════════════════════════════════════════════
   LOGO
════════════════════════════════════════════════════════ */
.logo-emblem{width:50px;height:50px;flex-shrink:0;transition:transform var(--t)}
.site-logo:hover .logo-emblem{transform:rotate(15deg) scale(1.08)}

/* ════════════════════════════════════════════════════════
   FACILITY PHOTOS STRIP (index)
════════════════════════════════════════════════════════ */
.facility-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.fp-item{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;cursor:pointer}
.fp-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.fp-item:hover img{transform:scale(1.05)}
.fp-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.72));color:#fff;font-family:var(--fd);font-size:.84rem;font-weight:700;padding:18px 14px 12px;text-align:center}
@media(max-width:700px){.facility-photos{grid-template-columns:1fr}}

/* ════════════════════════════════════════════════════════
   NAV VERIFY CERTIFICATE LINK
════════════════════════════════════════════════════════ */
.nav-verify{display:inline-flex!important;align-items:center;gap:5px;color:var(--teal)!important;font-weight:700!important;background:var(--teal-g)!important;border-radius:100px;padding:6px 14px!important;}
.nav-verify:hover{background:rgba(0,200,184,.18)!important}

/* ════════════════════════════════════════════════════════
   TESTIMONIAL CAROUSEL
════════════════════════════════════════════════════════ */
.test-carousel{position:relative;overflow:hidden}
.test-track{display:flex;gap:18px;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.test-track .test-card{flex:0 0 calc((100% - 36px) / 3);min-width:0}
.test-dots{display:flex;gap:7px;justify-content:center;margin-top:22px}
.test-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);border:none;cursor:pointer;transition:var(--t);padding:0}
.test-dot.active{background:var(--teal);width:22px;border-radius:4px}
@media(max-width:900px){.test-track .test-card{flex:0 0 calc((100% - 18px) / 2)}}
@media(max-width:640px){.test-track .test-card{flex:0 0 100%}}

/* ════════════════════════════════════════════════════════
   SHARE MODAL
════════════════════════════════════════════════════════ */
.share-modal{position:fixed;inset:0;z-index:900;background:rgba(7,14,16,.85);backdrop-filter:blur(16px);display:none;align-items:center;justify-content:center;padding:20px}
.share-modal.open{display:flex}
.share-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-2xl);width:100%;max-width:460px;padding:44px 40px;position:relative;text-align:center;box-shadow:var(--shadow-lg)}
.share-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;color:var(--text);transition:var(--t)}
.share-close:hover{background:var(--red);border-color:var(--red)}
.share-box h3{font-family:var(--fd);font-size:1.3rem;font-weight:800;margin-bottom:6px}
.share-sub{font-size:.85rem;color:var(--text3);margin-bottom:20px}
.share-qr-wrap{display:flex;align-items:center;justify-content:center;margin:0 auto 18px;width:168px;height:168px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:8px}
.share-qr-wrap canvas,.share-qr-wrap img{border-radius:var(--r-sm)}
.share-url-row{display:flex;gap:8px;margin-bottom:18px}
.share-url-row input{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 14px;color:var(--text);font-family:var(--fb);font-size:.82rem;outline:none;cursor:text}
.share-url-row input:focus{border-color:var(--teal)}
.share-platforms{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.sp-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;border-radius:var(--r-md);font-size:.7rem;font-family:var(--fd);font-weight:700;color:var(--text2);border:1px solid var(--border);transition:var(--t);text-decoration:none;cursor:pointer}
.sp-btn svg{width:20px;height:20px}
.sp-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.sp-wa:hover{background:#25d366;color:#fff;border-color:#25d366}
.sp-fb:hover{background:#1877f2;color:#fff;border-color:#1877f2}
.sp-tw:hover{background:#000;color:#fff;border-color:#000}
.sp-li:hover{background:#0a66c2;color:#fff;border-color:#0a66c2}
.sp-mail:hover{background:var(--teal);color:var(--bg);border-color:var(--teal)}

/* ════════════════════════════════════════════════════════
   VERIFY CERTIFICATE MODAL
════════════════════════════════════════════════════════ */
.verify-modal{position:fixed;inset:0;z-index:900;background:rgba(7,14,16,.85);backdrop-filter:blur(16px);display:none;align-items:center;justify-content:center;padding:20px}
.verify-modal.open{display:flex}
.verify-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-2xl);width:100%;max-width:420px;padding:44px 38px;position:relative;text-align:center;box-shadow:var(--shadow-lg)}
.verify-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;color:var(--text);transition:var(--t)}
.verify-close:hover{background:var(--red);border-color:var(--red)}
.verify-icon{font-size:2.8rem;margin-bottom:14px}
.verify-box h3{font-family:var(--fd);font-size:1.25rem;font-weight:800;margin-bottom:8px}
.verify-box p{font-size:.85rem;color:var(--text3);margin-bottom:22px}
.verify-input-wrap{display:flex;align-items:center;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:border-color var(--t)}
.verify-input-wrap:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,200,184,.1)}
.verify-prefix{font-family:var(--fd);font-weight:800;font-size:.95rem;color:var(--teal);padding:12px 0 12px 16px;white-space:nowrap}
.verify-input-wrap input{flex:1;background:transparent;border:none;padding:12px 16px 12px 6px;color:var(--text);font-family:var(--fb);font-size:.95rem;outline:none}

/* ════════════════════════════════════════════════════════
   CERTIFICATE DESIGN (verify-certificate.php)
════════════════════════════════════════════════════════ */
.dks-cert{background:#fff;color:#1a1a1a;border:3px solid #1a1a1a;border-radius:8px;padding:0;font-family:'Times New Roman',serif;box-shadow:0 12px 48px rgba(0,0,0,.22);overflow:hidden;max-width:760px;margin:0 auto}
[data-theme="light"] .dks-cert{box-shadow:0 8px 32px rgba(0,0,0,.15)}

.dks-cert-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:22px 28px 16px;border-bottom:2px solid #1a1a1a}
.dks-cert-logo-left{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:80px}
.zw-text{font-size:.72rem;font-weight:700;color:#2e7d32;text-align:center;letter-spacing:.03em}
.dks-cert-title-block{flex:1;text-align:center;padding:0 10px}
.dks-cert-red-banner{background:#c0392b;color:#fff;font-size:1.1rem;font-weight:900;letter-spacing:.05em;text-transform:uppercase;padding:8px 20px;border-radius:2px;margin-bottom:8px;display:inline-block}
.dks-cert-subtitle{font-size:.88rem;font-weight:700;letter-spacing:.08em;color:#1a1a1a;text-transform:uppercase}
.dks-cert-logo-right{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:80px}
.bh-symbol{font-size:2.4rem;color:#1a1a1a}
.bh-text{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}

.dks-cert-body{padding:20px 28px 16px}
.dks-cert-intro{font-style:italic;font-size:.88rem;margin-bottom:12px}
.dks-cert-field{display:flex;align-items:flex-end;gap:8px;border-bottom:1px solid #1a1a1a;padding-bottom:3px;margin-bottom:10px}
.dks-cf-label{font-size:.82rem;font-weight:700;white-space:nowrap;flex-shrink:0}
.dks-cf-value{flex:1;font-size:.88rem;font-weight:700;color:#c0392b;padding-left:4px}
.dks-cert-field-row{display:flex;gap:20px;margin-bottom:10px}
.dks-cert-compliance{font-style:italic;font-size:.84rem;font-weight:700;line-height:1.7;margin:12px 0;border-left:3px solid #c0392b;padding-left:12px}
.dks-cert-meta{display:flex;align-items:center;justify-content:space-between;margin:12px 0}
.cert-no-box{border:1.5px solid #1a1a1a;padding:8px 14px;border-radius:3px;font-size:.82rem;font-weight:700}
.cert-no-box strong{color:#c0392b}
.sdr-stamp{width:72px;height:72px;border-radius:50%;border:3px double #1a1a1a;display:flex;align-items:center;justify-content:center;font-family:'Times New Roman',serif;font-size:1.5rem;font-weight:900;letter-spacing:.08em;color:#1a1a1a}
.dks-cert-valid{display:flex;align-items:center;gap:6px;font-size:.85rem;margin-top:10px}
.dks-valid-date{border-bottom:1.5px solid #1a1a1a;min-width:100px;font-weight:700;padding:0 4px 1px}

.dks-cert-footer{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 28px;border-top:2px solid #1a1a1a;background:#fffde7}
.dks-tagline{font-family:'Comic Sans MS',cursive,sans-serif;font-size:.88rem;color:#2e7d32;line-height:1.5;font-style:italic}
.dks-cert-footer-centre{flex:1;text-align:center}
.dks-certified-name{font-size:1.2rem;font-weight:900;color:#c0392b;text-transform:uppercase;letter-spacing:.03em;font-family:Arial,sans-serif;margin:4px 0}
.dks-cert-address{font-size:.72rem;line-height:1.65;color:#333}
.cert-badge-gold{width:76px;height:76px;border-radius:50%;background:linear-gradient(135deg,#ffd700,#ffb300,#e65100);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px rgba(255,165,0,.45)}
.cbg-inner{text-align:center}
.cbg-text{font-size:.52rem;font-weight:900;color:#fff;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 1px 2px rgba(0,0,0,.3)}

.dks-cert-bottom{display:flex;align-items:flex-end;justify-content:space-between;padding:10px 28px;border-top:1.5px solid #ccc;font-size:.8rem}
.dks-cert-bottom strong{font-size:.88rem;color:#c0392b}
.dks-cert-work{text-align:center;padding:8px 28px;border-top:1px solid #ccc;font-size:.74rem;color:#555;background:#f9f9f9}

@media print{
  header,footer,.fab-bar,.verify-modal,.share-modal,.login-modal,.pg-hero,.section:not(:has(.dks-cert)){display:none!important}
  .dks-cert{box-shadow:none;border:2px solid #000}
  body{background:#fff}
}
@media(max-width:600px){
  .dks-cert-head{flex-direction:column;align-items:center;text-align:center}
  .dks-cert-field-row{flex-direction:column}
  .dks-cert-footer{flex-direction:column;align-items:center;text-align:center}
  .share-platforms{grid-template-columns:repeat(3,1fr)}
}

/* ════════════════════════════════════════════════════════
   PRODUCTION FIXES — header, nav, layout
════════════════════════════════════════════════════════ */

/* Light mode header scrolled */
[data-theme="light"] .site-header{background:transparent}
[data-theme="light"] .site-header.scrolled{background:rgba(240,245,247,.95);box-shadow:0 2px 20px rgba(0,0,0,.08)}

/* Header inner wrapper */
.h-inner,.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:14px}
.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Light mode nav links */
[data-theme="light"] .nav-primary a{color:var(--text2)}
[data-theme="light"] .nav-primary a:hover,.nav-primary a.active{color:var(--teal)}

/* Nav verify highlight */
.nav-verify{background:var(--teal-g)!important;border-radius:100px;color:var(--teal)!important;font-weight:700!important}
.nav-verify svg{color:var(--teal)}

/* Btn-cta (header Get a Quote) */
.btn-cta{display:inline-flex;align-items:center;gap:6px;text-decoration:none}

/* Light mode btn-login */
[data-theme="light"] .btn-login{color:var(--text2);border-color:rgba(0,0,0,.18)}
[data-theme="light"] .btn-login:hover{border-color:var(--teal);color:var(--teal)}

/* Mobile nav backdrop */
[data-theme="light"] .mobile-nav{background:rgba(240,245,247,.98)}

/* Light mode hero text */
[data-theme="light"] .hero-badge{background:rgba(0,127,116,.09);border-color:rgba(0,127,116,.22)}
[data-theme="light"] .hv-card{background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.1);border-color:rgba(0,0,0,.08)}

/* Trust bar light mode */
[data-theme="light"] .trust-bar{background:#fff;border-color:rgba(0,0,0,.08)}

/* Loader light */
[data-theme="light"] #page-loader{background:var(--bg)}

/* FAB light mode */
[data-theme="light"] .fab-btn{background:#fff;border-color:rgba(0,0,0,.1);box-shadow:0 2px 12px rgba(0,0,0,.1)}
[data-theme="light"] .fab-tip{background:#fff;border-color:rgba(0,0,0,.1);color:var(--text)}

/* Stats wrap light */
[data-theme="light"] .stats-wrap{border-color:rgba(0,0,0,.08)}

/* Ensure section bg in light mode uses surface correctly */
[data-theme="light"] section[style*="background:var(--surface)"]{background:var(--surface)!important}

/* Proc-num light */
[data-theme="light"] .proc-num{background:#fff;border-color:rgba(0,0,0,.1)}

/* Testimonial carousel extra fixes */
.test-carousel{overflow:hidden;position:relative}

/* Gallery grid — hide empty icon for items with real images */
.g-item img~.g-placeholder{display:none}

/* Lightbox centre */
.lightbox{justify-content:center;align-items:center}

/* Scrollbar light */
[data-theme="light"] ::-webkit-scrollbar-track{background:#e8eef0}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:var(--teal-d)}

/* Responsive media: trust bar items */
@media(max-width:900px){
  .trust-inner{flex-wrap:wrap;gap:12px 20px}
  .trust-sep{display:none}
}

/* Print — only show certificate */
@media print{
  header,footer,.fab-bar,.verify-modal,.share-modal,.login-modal,.pg-hero,
  section:not(.cert-section),.toast,#page-loader{display:none!important}
  .dks-cert{box-shadow:none!important;border:2px solid #000!important}
  body{background:#fff!important}
}
