:root{--navy:#003057;--navyL:#0a4a7a;--navyD:#001a33;--teal:#00857c;--red:#c8102e;--redS:#e8394a;--bg:#f8f9fb;--bg2:#f0f2f5;--bg3:#e6e9ee;--white:#fff;--tx1:#1a2b3d;--tx2:#4d6175;--tx3:#8a9bb0;--tx4:#b0bcc8;--bdr:#dce1e8;--f:'Outfit',sans-serif;--fb:'DM Sans',sans-serif;--ease:cubic-bezier(.22,1,.36,1);--glass:rgba(255,255,255,.55);--glass-blur:saturate(180%) blur(20px);--glass-bdr:rgba(255,255,255,.4);--glass-highlight:inset 0 1px 0 rgba(255,255,255,.7);--glass-shadow:0 8px 32px rgba(0,40,80,.06);--rb:0 1px 3px rgba(0,30,60,.10),0 6px 16px rgba(0,30,60,.08),0 24px 48px rgba(255,128,168,.18),0 32px 64px rgba(167,139,250,.20),0 40px 80px rgba(94,234,212,.18),0 48px 100px rgba(255,153,51,.14),inset 0 1px 0 rgba(255,255,255,.55);--rb-hov:0 4px 8px rgba(0,30,60,.16),0 10px 24px rgba(0,30,60,.12),0 30px 60px rgba(255,128,168,.32),0 42px 84px rgba(167,139,250,.34),0 56px 110px rgba(94,234,212,.30),0 72px 140px rgba(255,153,51,.24),inset 0 1px 0 rgba(255,255,255,.55)}

[data-theme="dark"]{--glass:rgba(20,30,48,.6);--glass-bdr:rgba(255,255,255,.06);--glass-highlight:inset 0 1px 0 rgba(255,255,255,.05);--glass-shadow:0 8px 32px rgba(0,0,0,.3);--bg:#0c1220;--bg2:#141e30;--bg3:#1c2840;--white:#161f2e;--tx1:#e2e8f0;--tx2:#94a3b8;--tx3:#64748b;--tx4:#475569;--bdr:#1e2d44;--rb:0 1px 3px rgba(0,0,0,.55),0 6px 16px rgba(0,0,0,.4),0 24px 48px rgba(255,128,168,.16),0 32px 64px rgba(167,139,250,.20),0 40px 80px rgba(94,234,212,.16),0 48px 100px rgba(255,153,51,.12),inset 0 1px 0 rgba(255,255,255,.06);--rb-hov:0 4px 8px rgba(0,0,0,.6),0 10px 24px rgba(0,0,0,.45),0 30px 60px rgba(255,128,168,.28),0 42px 84px rgba(167,139,250,.32),0 56px 110px rgba(94,234,212,.26),0 72px 140px rgba(255,153,51,.20),inset 0 1px 0 rgba(255,255,255,.06)}
[data-theme="dark"] .sec-t{color:var(--tx1)}
[data-theme="dark"] .lg-name{color:var(--tx1)}
[data-theme="dark"] .ft-lg span{color:var(--tx1)}
[data-theme="dark"] .pj-tag.on{background:rgba(200,16,46,.15)}
[data-theme="dark"] .pj-tag.done{background:rgba(0,133,124,.15)}
[data-theme="dark"] nav.scrolled{background:rgba(12,18,32,.88)}
[data-theme="dark"] .lg img,[data-theme="dark"] .ft-lg img{background:#fff;padding:3px;border-radius:8px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--fb);background:var(--bg);color:var(--tx1);overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .4s,color .4s;position:relative;scroll-behavior:smooth}
body::before{content:'';position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 60% 50% at 15% 10%,rgba(255,128,168,.10),transparent 60%),radial-gradient(ellipse 50% 40% at 85% 30%,rgba(167,139,250,.10),transparent 60%),radial-gradient(ellipse 55% 45% at 50% 80%,rgba(94,234,212,.10),transparent 60%),radial-gradient(ellipse 40% 35% at 90% 90%,rgba(255,153,51,.08),transparent 60%);pointer-events:none}
[data-theme="dark"] body::before{background:radial-gradient(ellipse 60% 50% at 15% 10%,rgba(255,128,168,.08),transparent 60%),radial-gradient(ellipse 50% 40% at 85% 30%,rgba(167,139,250,.10),transparent 60%),radial-gradient(ellipse 55% 45% at 50% 80%,rgba(94,234,212,.08),transparent 60%)}
::selection{background:var(--teal);color:#fff}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--tx2);border-radius:2px}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

.tb{background:var(--bg2);border-bottom:1px solid var(--bdr);height:36px;display:flex;align-items:center;justify-content:flex-end;padding:0 40px;gap:24px;font-family:var(--fb);font-size:12px;color:var(--tx2)}
.tb a{color:var(--tx2);cursor:pointer;transition:color .2s}.tb a:hover{color:var(--navy)}

nav{background:linear-gradient(180deg,rgba(0,20,40,.55) 0%,rgba(0,20,40,.25) 60%,rgba(0,20,40,0) 100%);backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:1px solid transparent;position:sticky;top:0;z-index:1000;box-shadow:none;transition:background .35s ease,backdrop-filter .35s ease,box-shadow .35s ease,border-color .35s ease}
nav.scrolled{background:rgba(255,255,255,.92);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-bdr);box-shadow:var(--glass-shadow),0 1px 0 rgba(0,133,124,.08)}
nav:not(.scrolled) .lg-name,nav:not(.scrolled) .nl a{color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.4)}
nav:not(.scrolled) .lg-sub{color:rgba(255,255,255,.85);text-shadow:0 1px 6px rgba(0,0,0,.35)}
nav:not(.scrolled) .lg img{background:rgba(255,255,255,.95);padding:3px;border-radius:8px;box-shadow:0 4px 14px rgba(0,0,0,.18)}
nav:not(.scrolled) .nl a.a{color:#fff}
nav:not(.scrolled) .nl a::after{background:#fff}
.nav-in{max-width:1360px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;height:72px}
.lg{display:flex;align-items:center;gap:14px;cursor:pointer;text-decoration:none}
.lg img{height:48px;border-radius:10px;object-fit:contain;transition:transform .3s var(--ease)}
.lg:hover img{transform:scale(1.05) rotate(-1deg)}
.lg-name{font-family:var(--f);font-size:19px;font-weight:800;color:var(--navy);letter-spacing:-.2px;line-height:1.2}
.lg-sub{font-size:9.5px;color:var(--tx2);letter-spacing:1.5px;text-transform:uppercase;margin-top:2px}
.nl{display:flex;gap:0}
.nl a{font-family:var(--fb);font-size:14px;font-weight:500;color:var(--tx2);background:0;border:0;padding:26px 20px;cursor:pointer;position:relative;transition:color .2s;text-decoration:none}
.nl a::after{content:'';position:absolute;bottom:0;left:20px;right:20px;height:3px;background:var(--teal);transform:scaleX(0);transition:transform .25s}
.nl a:hover{color:var(--navy)}.nl a.a{color:var(--navy);font-weight:700}.nl a.a::after{transform:scaleX(1)}

/* HERO */
.hero-bgs{position:absolute;inset:0}
.hero-bg{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}.hero-bg.on{opacity:1}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:kenBurns 25s ease infinite alternate}
@keyframes kenBurns{0%{transform:scale(1)}100%{transform:scale(1.08)}}
.hero-ov{z-index:1}
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;background:var(--navy);overflow:hidden;margin-top:-72px}
.hero-c{position:relative;z-index:3;max-width:1360px;width:100%;margin:0 auto;padding:60px 40px 100px}
.h-rot{height:300px;position:relative;overflow:visible}
.h-sl{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;opacity:0;transform:translateY(20px);transition:all .7s ease;pointer-events:none}
.h-sl.act{opacity:1;transform:none;pointer-events:auto}
.h-sl h1{font-family:var(--f);font-size:clamp(34px,5.5vw,72px);font-weight:800;color:#fff;line-height:1.12;letter-spacing:-1.5px;max-width:700px}
.h-sl h1 span{color:var(--teal)}
.h-sl p{font-size:18px;color:rgba(255,255,255,.55);max-width:560px;line-height:1.75;margin-top:20px}
.h-dots{display:flex;gap:8px;margin-top:24px}
.h-dot{width:40px;height:4px;border-radius:2px;background:rgba(255,255,255,.15);overflow:hidden;cursor:pointer}
.h-dot-fill{height:100%;width:0;background:var(--teal);border-radius:2px}
.h-dot.act .h-dot-fill{animation:hProg 4.5s linear forwards}
@keyframes hProg{0%{width:0}100%{width:100%}}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1200px;margin:60px auto 0;padding:0 32px;position:relative;z-index:5}
.stat{position:relative;background:var(--white);border-radius:16px;padding:28px 20px;text-align:center;overflow:hidden;border:0;box-shadow:var(--rb);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.stat:hover{transform:translateY(-8px);box-shadow:var(--rb-hov)}
.stat-n{font-family:var(--f);font-size:clamp(30px,3.4vw,46px);font-weight:800;background:linear-gradient(135deg,var(--teal) 0%,var(--navy) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1;position:relative;z-index:1}
.stat-l{font-size:11px;color:var(--tx2);letter-spacing:2.5px;text-transform:uppercase;margin-top:8px;font-weight:700;position:relative;z-index:1}
[data-theme="dark"] .stat{background:var(--bg3)}

/* SECTIONS */
.sec{padding:90px 32px}
.mx{max-width:1320px;margin:0 auto}
.sec-lb{font-family:var(--f);font-size:11px;font-weight:700;color:var(--red);letter-spacing:3px;text-transform:uppercase;margin-bottom:12px}
.sec-t{font-family:var(--f);font-size:clamp(28px,3.5vw,44px);font-weight:800;color:var(--navy);line-height:1.15;letter-spacing:-.5px;margin-bottom:20px}
.sec-p{font-size:16px;color:var(--tx2);max-width:640px;line-height:1.8}

/* ZIGZAG */
.zz{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.zz.rv{direction:rtl}.zz.rv>*{direction:ltr}
.zz img{width:100%;border-radius:12px;object-fit:cover;aspect-ratio:4/3}

/* SERVICE CARDS */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.svc-card{position:relative;background:var(--white);border:0;border-radius:20px;padding:32px 28px 26px;overflow:hidden;box-shadow:var(--rb);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.svc-card::before{content:'';position:absolute;top:28px;left:28px;width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#ff80a8 0%,#ff9933 100%);box-shadow:0 10px 22px rgba(255,128,168,.4),inset 0 1px 0 rgba(255,255,255,.4);z-index:1}
.svc-card:nth-child(4n+2)::before{background:linear-gradient(135deg,#a78bfa 0%,#5eead4 100%);box-shadow:0 10px 22px rgba(167,139,250,.4),inset 0 1px 0 rgba(255,255,255,.4)}
.svc-card:nth-child(4n+3)::before{background:linear-gradient(135deg,#5eead4 0%,#a78bfa 100%);box-shadow:0 10px 22px rgba(94,234,212,.4),inset 0 1px 0 rgba(255,255,255,.4)}
.svc-card:nth-child(4n+4)::before{background:linear-gradient(135deg,#ff9933 0%,#ff80a8 100%);box-shadow:0 10px 22px rgba(255,153,51,.4),inset 0 1px 0 rgba(255,255,255,.4)}
.svc-card>*{position:relative;z-index:2}
.svc-card:hover{transform:translateY(-10px);box-shadow:var(--rb-hov)}
.svc-card h3{font-family:var(--f);font-size:20px;font-weight:800;color:var(--navy);margin:78px 0 10px;letter-spacing:-.3px;line-height:1.25}
.svc-card p{font-size:14px;color:var(--tx2);line-height:1.75}
.svc-card a{display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:0;background:none!important;color:var(--navy)!important;font-size:14px;font-weight:700;text-decoration:none;box-shadow:none!important;border:0;transition:gap .25s,color .25s}
.svc-card a::after{content:'→';font-size:18px;font-weight:800;transition:transform .25s;background:linear-gradient(135deg,#ff80a8,#ff9933);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.svc-card:nth-child(4n+2) a::after{background:linear-gradient(135deg,#a78bfa,#5eead4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.svc-card:nth-child(4n+3) a::after{background:linear-gradient(135deg,#5eead4,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.svc-card:nth-child(4n+4) a::after{background:linear-gradient(135deg,#ff9933,#ff80a8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.svc-card a:hover{gap:14px;color:#a78bfa!important}
.svc-card a:hover::after{transform:translateX(4px)}
[data-theme="dark"] .svc-card{background:var(--bg3)}
[data-theme="dark"] .svc-card h3{color:#e2e8f0}

/* BANNER */
.bn{background:linear-gradient(135deg,var(--navy),var(--navyL));padding:80px 32px;text-align:center}
.bn h2{font-family:var(--f);font-size:clamp(24px,3.5vw,40px);font-weight:800;color:#fff;max-width:760px;margin:0 auto 14px}
.bn p{font-size:16px;color:rgba(255,255,255,.55);max-width:560px;margin:0 auto}

/* PAGE HEROES */
.phero{position:relative;background:linear-gradient(135deg,var(--navyD) 0%,var(--navy) 50%,var(--navyL) 100%);padding:180px 32px 80px;overflow:hidden;margin-top:-72px;box-shadow:0 24px 64px rgba(0,48,87,.28),0 12px 32px rgba(167,139,250,.18),0 6px 16px rgba(255,128,168,.1)}
.phero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 15% 30%,rgba(255,128,168,.18),transparent 60%),radial-gradient(ellipse 45% 55% at 85% 70%,rgba(167,139,250,.20),transparent 60%),radial-gradient(ellipse 40% 50% at 50% 100%,rgba(94,234,212,.16),transparent 60%);pointer-events:none}
.phero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,128,168,.5) 25%,rgba(167,139,250,.6) 50%,rgba(94,234,212,.5) 75%,transparent 100%)}
.phero>div{position:relative;z-index:1}
.phero h1{font-family:var(--f);font-size:clamp(32px,4.5vw,56px);font-weight:800;color:#fff;max-width:1320px;margin:0 auto;letter-spacing:-1px;line-height:1.1}
.phero p{font-size:clamp(15px,1.4vw,18px);color:rgba(255,255,255,.78);max-width:780px;margin:14px auto 0 0;line-height:1.65;font-weight:400}
.phero .ph-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:rgba(255,255,255,.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.18);border-radius:99px;color:rgba(255,255,255,.9);font-family:var(--f);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px}
.phero .ph-tag::before{content:'';width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,#ff80a8,#a78bfa);box-shadow:0 0 12px rgba(255,128,168,.7)}
@media(max-width:768px){.phero{padding:140px 20px 60px}.phero p{margin-right:auto}}

/* PROJECT CARDS */
.pj{position:relative;background:var(--white);border:0;border-radius:18px;overflow:hidden;box-shadow:var(--rb);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.pj:hover{transform:translateY(-12px);box-shadow:var(--rb-hov)}
[data-theme="dark"] .pj{background:var(--bg3)}
[data-theme="dark"] .pj-info h3{color:var(--tx1)}
.pj img{transition:transform .5s var(--ease)}.pj:hover img{transform:scale(1.06)}
.pj-img{width:100%;height:220px;object-fit:cover;background:var(--bg2)}
.pj-info{padding:28px}
.pj-info h3{font-family:var(--f);font-size:20px;font-weight:700;color:var(--navy);margin-bottom:6px}
.pj-info p{font-size:14px;color:var(--tx2);line-height:1.7}
.pj-tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:4px;margin-bottom:10px}
.pj-tag.on{background:#fef3f3;color:var(--red)}.pj-tag.done{background:#e6faf2;color:#00857c}

/* TEAM CARDS — premium 3-col grid */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:36px}
.team-card{position:relative;background:var(--white);border:0;border-radius:24px;overflow:hidden;box-shadow:var(--rb);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.team-card:hover{transform:translateY(-12px);box-shadow:var(--rb-hov)}
.team-photo{position:relative;aspect-ratio:1/1.05;overflow:hidden;background:linear-gradient(135deg,#ff80a8,#a78bfa)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .55s var(--ease);display:block}
.team-card:hover .team-photo img{transform:scale(1.06)}
.team-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,26,51,.18) 100%);pointer-events:none}
.team-body{padding:28px 28px 30px;position:relative}
.team-body h3{font-family:var(--f);font-size:22px;font-weight:800;color:var(--navy);margin:0 0 6px;letter-spacing:-.3px;line-height:1.2}
.team-role{display:inline-block;font-family:var(--f);font-size:11px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;background:linear-gradient(135deg,#ff80a8,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 14px}
.team-bio{font-size:13.5px;color:var(--tx2);line-height:1.7;margin:0 0 20px}
.team-linkedin{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:#0a66c2;color:#fff!important;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none;box-shadow:0 6px 16px rgba(10,102,194,.32),0 2px 4px rgba(10,102,194,.2);transition:transform .25s,box-shadow .25s}
.team-linkedin:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(10,102,194,.45),0 4px 8px rgba(10,102,194,.28);text-decoration:none}
.team-linkedin svg{width:14px;height:14px;fill:#fff}
[data-theme="dark"] .team-card{background:var(--bg3)}
[data-theme="dark"] .team-card h3{color:#e2e8f0}
@media(max-width:900px){.team-grid{grid-template-columns:1fr;gap:24px;max-width:480px;margin-left:auto;margin-right:auto}.team-photo{aspect-ratio:4/3.5}}

/* TEST CARDS */
.test-card{position:relative;background:var(--white);border:0;border-radius:14px;padding:24px 22px;overflow:hidden;box-shadow:var(--rb);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.test-card>*{position:relative;z-index:1}
.test-card:hover{transform:translateY(-6px);box-shadow:var(--rb-hov)}
.test-card h4{font-family:var(--f);font-size:16px;font-weight:800;color:var(--navy);margin-bottom:6px;letter-spacing:-.1px}
.test-card p{font-size:14px;color:var(--tx2);line-height:1.65;margin:0}
[data-theme="dark"] .test-card{background:var(--bg3)}
[data-theme="dark"] .test-card h4{color:#e2e8f0}

/* CONTACT */
.ct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ct-card{position:relative;background:var(--white);border:0;border-radius:16px;padding:34px 28px;text-align:center;overflow:hidden;box-shadow:var(--rb);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.ct-card>*{position:relative;z-index:1}
.ct-card:hover{transform:translateY(-8px);box-shadow:var(--rb-hov)}
.ct-card h4{font-family:var(--f);font-size:16px;font-weight:800;color:var(--navy);margin:8px 0 4px}
.ct-card p{font-size:14px;color:var(--tx2)}
[data-theme="dark"] .ct-card{background:var(--bg3)}
[data-theme="dark"] .ct-card h4{color:var(--tx1)}

/* ADDRESS CARDS */
.addr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:36px}
.addr-card{position:relative;background:var(--white);border:0;border-radius:22px;padding:40px 36px;overflow:hidden;box-shadow:var(--rb);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.addr-card:hover{transform:translateY(-8px);box-shadow:var(--rb-hov)}
.addr-card::before{content:'';position:absolute;top:36px;left:36px;width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#ff80a8 0%,#ff9933 100%);box-shadow:0 12px 28px rgba(255,128,168,.45),inset 0 1px 0 rgba(255,255,255,.4);z-index:1}
.addr-card:nth-child(2)::before{background:linear-gradient(135deg,#a78bfa 0%,#5eead4 100%);box-shadow:0 12px 28px rgba(167,139,250,.45),inset 0 1px 0 rgba(255,255,255,.4)}
.addr-card .pin{position:absolute;top:50px;left:50px;z-index:2;pointer-events:none}
.addr-card .pin svg{width:36px;height:36px;stroke:#fff;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}
.addr-card>*{position:relative;z-index:3}
.addr-card .addr-tag{display:inline-block;font-family:var(--f);font-size:10px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);margin:88px 0 8px}
.addr-card h3{font-family:var(--f);font-size:26px;font-weight:800;color:var(--navy);margin:0 0 14px;letter-spacing:-.4px;line-height:1.2}
.addr-card .addr-line{font-size:15px;color:var(--tx2);line-height:1.75;margin:0 0 18px}
.addr-card .addr-meta{display:flex;flex-direction:column;gap:8px;padding:16px 0;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);margin-bottom:18px}
.addr-card .addr-meta a{display:inline-flex;align-items:center;gap:10px;color:var(--tx2);font-size:14px;font-weight:600;text-decoration:none;transition:color .2s}
.addr-card .addr-meta a:hover{color:var(--teal)}
.addr-card .addr-meta svg{width:16px;height:16px;stroke:var(--teal);stroke-width:2;fill:none;flex-shrink:0;stroke-linecap:round;stroke-linejoin:round}
.addr-card .addr-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;background:linear-gradient(135deg,#ff80a8 0%,#ff9933 100%);color:#fff;font-family:var(--f);font-size:14px;font-weight:700;text-decoration:none;border-radius:10px;box-shadow:0 8px 18px rgba(255,128,168,.35),0 2px 4px rgba(255,128,168,.2);transition:transform .25s,box-shadow .25s}
.addr-card:nth-child(2) .addr-cta{background:linear-gradient(135deg,#a78bfa 0%,#5eead4 100%);box-shadow:0 8px 18px rgba(167,139,250,.35),0 2px 4px rgba(167,139,250,.2)}
.addr-card .addr-cta:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(255,128,168,.5),0 4px 8px rgba(255,128,168,.3)}
.addr-card:nth-child(2) .addr-cta:hover{box-shadow:0 14px 28px rgba(167,139,250,.5),0 4px 8px rgba(167,139,250,.3)}
.addr-card .addr-cta svg{width:14px;height:14px;stroke:#fff;stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
[data-theme="dark"] .addr-card{background:var(--bg3)}
[data-theme="dark"] .addr-card h3{color:#e2e8f0}
@media(max-width:768px){.addr-grid{grid-template-columns:1fr;gap:24px}.addr-card{padding:32px 26px}.addr-card::before{width:56px;height:56px;top:28px;left:28px}.addr-card .pin{top:40px;left:40px}.addr-card .pin svg{width:32px;height:32px}.addr-card .addr-tag{margin-top:76px}.addr-card h3{font-size:22px}}

/* MARQUEE */
.mk-wrap{overflow:hidden;padding:16px 0;background:linear-gradient(135deg,rgba(0,133,124,.04),rgba(53,41,139,.03),rgba(0,48,87,.04));border-bottom:1px solid var(--glass-bdr);border-top:1px solid var(--glass-bdr)}
.mk{display:flex;gap:32px;white-space:nowrap;animation:mkL 35s linear infinite}
.mk span{font-family:var(--f);font-size:14px;font-weight:600;color:var(--tx1);display:flex;align-items:center;gap:12px}
.mk span::before{content:'◆';color:var(--teal);font-size:8px}
@keyframes mkL{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes mkR{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}
.mk.rev{animation-name:mkR}
.mk-title{font-family:var(--f);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;text-align:center;padding:10px 0 0;color:var(--tx3)}

/* MAP */
.map iframe{width:100%;height:400px;border:0;border-radius:12px}

/* MOBILE TAB BAR */
.tab-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--glass-bdr);box-shadow:0 -4px 20px var(--glass-shadow)}
.tab-bar-in{display:flex;justify-content:space-around;padding:8px 4px 6px}
.tab-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:0;border:0;padding:8px 12px;cursor:pointer;min-width:56px;text-decoration:none}
.tab-btn svg{width:20px;height:20px;fill:none;stroke:var(--tx2);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:all .2s}
.tab-btn span{font-family:var(--fb);font-size:9px;font-weight:500;color:var(--tx2);transition:all .2s}
.tab-btn.on svg{stroke:var(--teal)}.tab-btn.on span{color:var(--teal);font-weight:700}

/* FOOTER */
footer{background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);transition:background .4s;border-top:1px solid var(--bdr);padding:56px 32px 20px;font-size:13px;color:var(--tx2);position:relative;overflow:hidden}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ff80a8 0%,#ff9933 33%,#a78bfa 66%,#5eead4 100%);opacity:1}
.ft-g{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:32px}
.ft-lg{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.ft-lg img{height:40px;border-radius:8px}
.ft-lg span{font-family:var(--f);font-size:20px;font-weight:800;color:var(--navy)}
.ft-tag{font-size:13px;color:var(--tx2);line-height:1.7;max-width:340px;margin-bottom:18px}
.ft-contact-line{display:flex;align-items:center;gap:8px;color:var(--tx2);padding:5px 0;font-size:13px}
.ft-contact-line svg{width:14px;height:14px;color:var(--teal);flex-shrink:0}
footer h4{font-family:var(--f);font-size:11px;color:var(--navy);font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px}
footer a{display:block;color:var(--tx2);padding:5px 0;transition:color .2s,transform .2s;font-size:13px}footer a:hover{color:var(--teal);transform:translateX(3px)}
.ft-soc{display:flex;gap:10px;margin-top:14px}
.ft-soc a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;padding:0;transition:transform .2s,box-shadow .2s}
.ft-soc a:hover{transform:translateY(-2px) scale(1.05)}
.ft-bt{max-width:1320px;margin:0 auto;padding-top:18px;border-top:1px solid var(--bdr);display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:11px;color:var(--tx3)}

/* BENTO */
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.bento-card{position:relative;background:var(--white);border:0;border-radius:18px;overflow:hidden;box-shadow:var(--rb);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.bento-card:hover{transform:translateY(-10px);box-shadow:var(--rb-hov)}
[data-theme="dark"] .bento-card{background:var(--bg3)}
[data-theme="dark"] .bento-body h3{color:var(--tx1)}
[data-theme="dark"] footer h4{color:var(--tx1)}
[data-theme="dark"] footer{background:linear-gradient(180deg,#11192a 0%,var(--bg) 100%)}
[data-theme="dark"] .addr-card .addr-tag{color:#ff80a8}
[data-theme="dark"] .addr-card .addr-meta{border-color:rgba(255,255,255,.08)}
[data-theme="dark"] .ft-soc a[style*="background:#fff"]{background:#1c2840!important;border-color:rgba(255,255,255,.1)!important}
[data-theme="dark"] nav:not(.scrolled) .lg img{background:#fff}
.bento-card.feat{grid-column:span 2}
.bento-img{width:100%;height:280px;object-fit:cover;transition:transform .6s var(--ease)}
.bento-card:hover .bento-img{transform:scale(1.05)}
.bento-body{padding:24px}
.bento-body h3{font-family:var(--f);font-size:18px;font-weight:700;color:var(--tx1);margin-bottom:6px}
.bento-body p{font-size:13.5px;color:var(--tx2);line-height:1.7}
.bento-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:4px;background:rgba(0,133,124,.1);color:var(--teal);margin-bottom:8px}
.bento-link{display:inline-block;margin-top:10px;font-size:13px;font-weight:600;color:var(--teal);transition:transform .2s}
.bento-link:hover{transform:translateX(4px)}
@media(max-width:900px){.bento-grid{grid-template-columns:1fr!important}.bento-card.feat{grid-column:span 1}}

/* FADE */
.fi{opacity:0;transform:translateY(30px);transition:all .7s var(--ease)}.fi.vis{opacity:1;transform:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* RESPONSIVE */
@media(max-width:900px){
.nl{display:none}.tab-bar{display:flex}body{padding-bottom:80px}
.zz{grid-template-columns:1fr!important}.zz.rv{direction:ltr}
.svc-grid{grid-template-columns:1fr!important}
.ct-grid{grid-template-columns:1fr!important}
#pjG{grid-template-columns:1fr!important}
#teamCards div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
.stats{grid-template-columns:repeat(2,1fr)!important;gap:14px;padding:0 20px;margin-top:40px}
.ft-g{grid-template-columns:1fr!important}
.tb{display:none}
.hero{min-height:100vh;min-height:100dvh;padding-bottom:40px}.hero-c{padding:40px 20px 80px}.h-rot{height:240px}
}
