/* ============================================================
   Energy Bridge Telecommunications — Theme styles
   Consolidated from the source design, scoped per page.
   Local brand tokens layered on top of colors_and_type.css.
   ============================================================ */
:root{--red:#E30613;--red2:#c40010;--pink1:#fbe6e3;--pink2:#fdefec;--paper:#f4f2f1;--dark:#2b2624}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
img{max-width:100%}
a{color:inherit}
.page{background:#fff;font-family:var(--font-sans);color:#141413;font-weight:450;overflow-x:clip}
.wrap{max-width:1560px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.eb{color:var(--red);font-size:15px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;margin:0}
.title{font-weight:800;font-size:clamp(30px,4vw,46px);line-height:1.1;letter-spacing:-1px;margin:0}
.center{text-align:center}
.center .eb{margin-bottom:14px}
.center .title{margin:0 auto}
.sec{padding:clamp(64px,8vw,110px) 0}

/* ---------- NAV / HEADER ---------- */
.sn *{box-sizing:border-box}
@keyframes snDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:none}}
.nav{position:relative;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:26px 0;animation:snDown .55s var(--ease) both}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo-img{height:60px;width:auto;display:block;transition:transform var(--dur) var(--ease)}
.brand:hover .logo-img{transform:scale(1.04)}
.navlinks{display:flex;align-items:center;gap:30px}
.navlinks>a,.navdrop>a{color:#1b1b1b;font-size:14px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;text-decoration:none;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;position:relative;transition:color var(--dur) var(--ease)}
.navlinks>a:after,.navdrop>a:after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--red);transition:right var(--dur) var(--ease)}
.navlinks>a:hover,.navdrop>a:hover{color:var(--red)}
.navlinks>a:hover:after,.navdrop:hover>a:after{right:0}
.navlinks a.on{color:var(--red)}
.navlinks a.on:after{right:0}
.caret{width:15px;height:15px;border-radius:50%;background:var(--red);display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:transform var(--dur) var(--ease)}
.navdrop{position:relative}
.navdrop:hover .caret{transform:rotate(180deg)}
.navmenu{position:absolute;top:100%;left:-14px;padding-top:12px;display:none;z-index:1200}
.navdrop:hover .navmenu{display:block}
.navmenu-in{display:block;background:#fff;border:1px solid rgba(20,20,19,.08);border-radius:16px;box-shadow:0 18px 44px -14px rgba(60,20,25,.35);padding:10px;min-width:220px;animation:snDown .28s var(--ease) both}
.navmenu-in a{display:block;color:#1b1b1b;padding:12px 16px;border-radius:10px;text-decoration:none;font-size:14px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.navmenu-in a:hover{background:var(--pink2);color:var(--red)}
.navcta{display:flex;align-items:center;gap:16px}
.login{display:inline-flex;align-items:center;gap:9px;border:1.6px solid var(--red);color:#141413;background:transparent;border-radius:999px;padding:11px 26px;font-size:14px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;transition:all var(--dur) var(--ease);font-family:inherit}
.login:hover{background:var(--red);color:#fff}
.apply{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:#111;color:#fff;border:none;border-radius:999px;padding:13px 30px;font-size:14px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;transition:transform var(--dur) var(--ease),background var(--dur) var(--ease);font-family:inherit}
.apply:hover{background:#000}.apply:active{transform:scale(.97)}
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:48px;height:48px;border:1.6px solid rgba(20,20,19,.16);border-radius:50%;background:#fff;cursor:pointer;padding:0;transition:border-color var(--dur) var(--ease)}
.burger:hover{border-color:var(--red)}
.burger span{display:block;width:20px;height:2px;background:#141413;margin:0 auto;border-radius:2px;transition:transform .3s var(--ease),opacity .2s var(--ease)}
.burger.on span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.on span:nth-child(2){opacity:0}
.burger.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.drawer{position:fixed;inset:0;z-index:3000;visibility:hidden;pointer-events:none}
.drawer.on{visibility:visible;pointer-events:auto}
.dscrim{position:absolute;inset:0;background:rgba(20,10,12,.44);opacity:0;transition:opacity .34s var(--ease)}
.drawer.on .dscrim{opacity:1}
.dpanel{position:absolute;top:0;right:0;height:100%;width:min(86vw,370px);background:#fff;box-shadow:-24px 0 60px -20px rgba(60,20,25,.4);transform:translateX(100%);transition:transform .38s var(--ease);display:flex;flex-direction:column;padding:22px 26px 34px;overflow-y:auto}
.drawer.on .dpanel{transform:none}
.dtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.dclose{width:44px;height:44px;border-radius:50%;border:1.6px solid rgba(20,20,19,.16);background:#fff;color:#141413;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--dur) var(--ease)}
.dclose:hover{background:var(--red);color:#fff;border-color:var(--red)}
.dlink{display:block;color:#141413;font-size:17px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;text-decoration:none;padding:15px 4px;border-bottom:1px solid rgba(20,20,19,.08);transition:color var(--dur) var(--ease),padding-left var(--dur) var(--ease)}
.dlink:hover,.dlink.on{color:var(--red);padding-left:10px}
.dgl{display:block;font-size:12px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:#a09a99;padding:16px 4px 8px}
.dsub{display:block;color:#3a3736;font-size:15px;font-weight:700;letter-spacing:.3px;text-decoration:none;padding:11px 4px 11px 18px;transition:color var(--dur) var(--ease),padding-left var(--dur) var(--ease)}
.dsub:hover{color:var(--red);padding-left:26px}
.dcta{display:flex;flex-direction:column;gap:12px;margin-top:26px}
.dcta .login,.dcta .apply{justify-content:center;padding-top:15px;padding-bottom:15px}

/* ---------- TOP BANDS ---------- */
.top{background:linear-gradient(180deg,var(--pink1) 0%,var(--pink2) 46%,#fff 100%)}
.top--soft{background:linear-gradient(110deg,#ffffff 0%,#fdf0f0 30%,#f9dcdc 62%,#f3c9cc 100%);position:relative}
.top--soft:before{content:"";position:absolute;inset:0;background:radial-gradient(900px 500px at 12% 90%,rgba(255,255,255,.9),rgba(255,255,255,0) 60%),radial-gradient(1100px 600px at 88% 10%,rgba(240,170,175,.35),rgba(255,255,255,0) 65%);pointer-events:none}
.top--soft .wrap{position:relative;z-index:1}

/* ---------- HERO (shared box) ---------- */
.herobox{position:relative;border-radius:34px;overflow:hidden;background:#000;box-shadow:var(--shadow-2);margin-top:8px}
.herotext{font-size:16.5px;line-height:1.6;margin:0}

/* Home slider hero */
.pg-home .hero{position:relative;z-index:0;padding:8px 0 0}
.pg-home .herobox{margin-top:0}
.harrow{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:#f2f2f2;cursor:pointer;padding:8px;z-index:3;opacity:.9;transition:opacity var(--dur)}
.harrow:hover{opacity:1}
.harrow.l{left:14px}.harrow.r{right:14px}
.slides{position:relative;width:100%;height:clamp(360px,44vw,620px)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease}
.slide.on{opacity:1}
.slide img{width:100%;height:100%;object-fit:cover;display:block}
.pg-home .heroscrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.6),rgba(0,0,0,.08) 55%),linear-gradient(0deg,rgba(0,0,0,.5),transparent 52%);pointer-events:none;z-index:1}
.herocap{position:absolute;left:clamp(28px,4vw,64px);bottom:clamp(60px,6vw,80px);right:64px;z-index:2;max-width:660px}
.herocap .eb{color:#fff;margin:0}
.pg-home .herotitle{color:#fff;font-weight:800;font-size:clamp(28px,4.4vw,58px);line-height:1.05;letter-spacing:-1px;margin:12px 0 0}
.herodots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.hdot{width:38px;height:5px;border-radius:3px;background:rgba(255,255,255,.42);border:none;cursor:pointer;padding:0;transition:background .3s}
.hdot.on{background:#fff}

/* Corporate — centered hero */
.pg-corporate .heroscrim{position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(0,0,0,.55) 0%,rgba(0,0,0,.28) 55%,rgba(0,0,0,.15) 100%);pointer-events:none;z-index:1}
.pg-corporate .herocopy{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;max-width:640px;width:calc(100% - 48px);color:#fff;text-align:center}
.pg-corporate .herotitle{font-weight:800;font-size:clamp(38px,4.6vw,72px);line-height:1.05;letter-spacing:-1px;text-transform:uppercase;margin:0 0 24px}
.pg-corporate .herotext{font-size:16px}

/* Side heroes (Fiber / Gaming / DSL) — left aligned */
.pg-side .heroscrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.62) 0%,rgba(0,0,0,.28) 42%,rgba(0,0,0,0) 68%);pointer-events:none;z-index:1}
.pg-side .herocopy{position:absolute;left:clamp(24px,4vw,64px);top:50%;transform:translateY(-50%);z-index:2;max-width:420px;color:#fff}
.pg-side .herotitle{font-weight:800;font-size:clamp(44px,5.5vw,84px);line-height:1.02;letter-spacing:-1px;text-transform:uppercase;margin:0 0 26px}
.herostrong{font-weight:800;font-size:17px;margin:0 0 6px}
.heroimg{display:block;width:100%;object-fit:cover}

/* ---------- HOME: services ---------- */
.services{background:linear-gradient(150deg,#fdeeec 0%,#fbe7e4 60%,#f7dedb 100%);border-radius:36px;padding:clamp(36px,5vw,72px);position:relative;overflow:hidden}
.svc-head{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
.svc-head .title{max-width:560px}
.svc-lead{color:#333;font-size:16px;line-height:1.6;max-width:520px}
.svc-body{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-top:clamp(40px,6vw,90px)}
.acc{display:flex;flex-direction:column;gap:16px}
.accitem{background:rgba(255,255,255,.55);border-radius:22px;padding:20px 26px;cursor:pointer;transition:background var(--dur) var(--ease)}
.accitem.on{background:#fff;box-shadow:var(--shadow-1)}
.accrow{display:flex;align-items:center;gap:18px}
.accnum{color:var(--red);font-weight:800;font-size:17px;width:26px}
.acctitle{font-weight:800;font-size:21px;letter-spacing:-.3px}
.accblurb{color:#444;font-size:15px;line-height:1.6;margin:12px 0 2px 44px}
.accitem:not(.on) .accblurb{display:none}
.wifislot{width:100%;height:clamp(280px,28vw,420px);object-fit:cover;border-radius:6px}

/* ---------- HOME: plans ---------- */
.plangrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;align-items:center;margin-top:56px}
.plan{background:linear-gradient(150deg,#f3f2f1,#eceae9);border-radius:26px;padding:40px 34px;text-align:center;position:relative}
.plan.pop{background:linear-gradient(150deg,#f7e0dd,#f4cbc6);padding:56px 40px;box-shadow:var(--shadow-2)}
.badge{position:absolute;top:-16px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:9px 22px;border-radius:999px}
.pname{font-weight:800;font-size:23px}
.pspeed{color:#333;font-size:16px;margin-top:6px}
.pprice{font-size:23px;font-weight:800;margin:26px 0 24px}
.pprice small{font-weight:500;font-size:16px;color:#444}
.plist{display:flex;flex-direction:column;gap:15px;text-align:left;max-width:230px;margin:0 auto 30px}
.pli{display:flex;align-items:center;gap:12px;font-size:15px;color:#222}
.pdot{width:8px;height:8px;border-radius:50%;background:var(--red);flex:none}
.choose{background:#111;color:#fff;border:none;border-radius:999px;padding:14px 34px;font-size:13px;font-weight:800;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:transform var(--dur) var(--ease);font-family:inherit;text-decoration:none;display:inline-block}
.choose:hover{background:#000}.choose:active{transform:scale(.97)}

/* ---------- HOME: why ---------- */
.pg-home .whygrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;margin-top:20px}
.mapslot{width:100%;height:clamp(360px,40vw,560px);object-fit:cover;border-radius:6px}
.whysub{font-weight:800;font-size:20px;margin:0 0 22px}
.pg-home .whytext{color:#333;font-size:16px;line-height:1.7;margin:0 0 34px;max-width:560px}
.wlist{display:flex;flex-direction:column;gap:16px}
.wli{display:flex;gap:14px;align-items:flex-start;font-size:15.5px;line-height:1.5}
.wli .pdot{margin-top:7px;width:9px;height:9px}
.wli b{font-weight:800}

/* ---------- HOME: newsletter ---------- */
.nlfoot{position:relative;margin-top:80px}
.newsletter{position:relative;z-index:2;background:linear-gradient(120deg,#f3eeed 0%,#f8e4e1 60%,#f6d7d3 100%);border-radius:30px;padding:clamp(36px,5vw,64px);display:grid;grid-template-columns:1fr 1.15fr;gap:40px;align-items:center;box-shadow:var(--shadow-2);max-width:1560px;margin:0 auto -150px;overflow:hidden}
.nltitle{font-weight:800;font-size:clamp(34px,5vw,52px);letter-spacing:-1px}
.nlsub{color:#333;font-size:16px;margin-top:22px;max-width:340px;line-height:1.5}
.nlform{display:flex;align-items:center;gap:10px;background:#fff;border-radius:999px;padding:9px 9px 9px 26px;box-shadow:var(--shadow-1)}
.nlinput{flex:1;border:none;outline:none;background:none;font-family:var(--font-sans);font-size:16px;color:#222;padding:12px 0;min-width:0}
.nlbtn{background:#111;color:#fff;border:none;border-radius:999px;padding:16px 34px;font-size:13px;font-weight:800;letter-spacing:1px;text-transform:uppercase;cursor:pointer;white-space:nowrap;font-family:inherit}
.nlbtn:hover{background:#000}
.nlnote{margin:14px 4px 0;font-size:14px;font-weight:700;color:var(--red);min-height:18px}
.nlnote.ok{color:#1f8a4c}

/* ---------- SERVICE PAGES: packages ---------- */
.pkgsec{padding:clamp(70px,8vw,120px) 0 0}
.pkggrid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:56px}
.pg-gaming .pkggrid{grid-template-columns:repeat(3,1fr)}
.pkg{background:linear-gradient(150deg,#f5f4f4 0%,#eeecec 60%,#e9e7e7 100%);border-radius:22px;padding:40px 32px;box-shadow:0 24px 48px -30px rgba(90,40,45,.22)}
.pkgname{font-weight:800;font-size:22px;letter-spacing:-.2px;text-align:center;margin:0 0 10px;text-transform:uppercase}
.pkgrange{text-align:center;color:#333;font-size:16.5px;margin:0 0 34px}
.pkglist{display:flex;flex-direction:column;gap:15px}
.pkgcta{display:flex;justify-content:center;padding:56px 0 0}

/* ---------- SERVICE PAGES: details ---------- */
.details{padding:clamp(80px,9vw,130px) 0}
.detgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,3vw,44px);align-items:stretch}
.detcard{background:linear-gradient(140deg,#f6f3f2 0%,#f8e9e7 55%,#f5dcd9 100%);border-radius:26px;padding:clamp(30px,4vw,70px);display:flex;flex-direction:column;justify-content:center}
.dettitle{font-weight:800;font-size:clamp(26px,2.6vw,38px);letter-spacing:-.6px;margin:0 0 34px}
.dettext{color:#222;font-size:16.5px;line-height:1.7;margin:0 0 28px;max-width:760px}
.dettext.last{margin-bottom:0}
.dterm{font-weight:800}
.subhead{font-weight:800;font-size:clamp(22px,2vw,28px);letter-spacing:-.4px;margin:0 0 18px}
.sublist{margin:0 0 34px}
.detnote{display:flex;gap:6px;color:#222;font-size:16px;line-height:1.8}
.detcta{display:flex;padding-top:6px}
.detimg{border-radius:26px;overflow:hidden;background:#111;min-height:clamp(340px,36vw,560px);box-shadow:0 24px 50px -28px rgba(90,40,45,.28)}
.detimg img{display:block;width:100%;height:100%;object-fit:cover}

/* ---------- IPTV ---------- */
.packs{padding:clamp(60px,7vw,110px) 0 clamp(40px,5vw,70px)}
.packhead{text-align:center;margin-bottom:clamp(36px,4vw,60px)}
.packhead .title{margin-top:12px}
.packgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,3vw,44px)}
.pack{background:linear-gradient(140deg,#f6f3f2 0%,#f1eeee 55%,#f5e7e5 100%);border-radius:18px;padding:clamp(30px,4vw,56px);min-height:clamp(320px,30vw,480px)}
.packname{font-weight:800;font-size:clamp(24px,2.2vw,32px);letter-spacing:-.4px;text-align:center;margin:0 0 10px}
.packprice{font-size:clamp(17px,1.4vw,22px);text-align:center;margin:0 0 clamp(28px,3vw,44px)}
.feat{display:flex;align-items:baseline;gap:12px;font-size:16.5px;line-height:1.7;padding:6px 0}
.dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex:none;transform:translateY(-2px)}
.packcta{display:flex;justify-content:center;padding:clamp(36px,4vw,56px) 0 0}
.how{padding:clamp(50px,6vw,90px) 0 clamp(80px,9vw,130px)}
.howgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,3vw,44px);align-items:stretch}
.howcard{background:linear-gradient(140deg,#f6f3f2 0%,#f8e9e7 55%,#f5dcd9 100%);border-radius:26px;padding:clamp(30px,4vw,70px);display:flex;flex-direction:column;justify-content:center}
.howtitle{font-weight:800;font-size:clamp(18px,1.5vw,22px);margin:0 0 26px}
.step{color:#222;font-size:16.5px;line-height:1.8;margin:0}
.step-strong{font-weight:800}
.howimg{border-radius:26px;overflow:hidden;background:#111;min-height:clamp(340px,36vw,560px);box-shadow:0 24px 50px -28px rgba(90,40,45,.28)}
.howimg img{display:block;width:100%;height:100%;object-fit:cover}

/* ---------- ABOUT ---------- */
.abouthead{text-align:center;padding:clamp(70px,9vw,150px) 0 clamp(50px,6vw,90px)}
.abouthead .title{margin-top:18px;font-size:clamp(32px,4.4vw,54px)}
.aboutlead{max-width:1080px;margin:34px auto 0;color:#222;font-size:17px;line-height:1.65}
.mvgrid{display:grid;grid-template-columns:1fr 1fr;gap:26px;padding:clamp(50px,6vw,90px) 0 0;position:relative;z-index:1;transform:translateY(clamp(40px,6vw,110px));margin-top:calc(-1 * clamp(20px,3vw,60px))}
.mvcard{background:linear-gradient(140deg,#f7f6f6 0%,#efeeee 55%,#e9e8e8 100%);border-radius:26px;box-shadow:0 30px 60px -30px rgba(90,40,45,.25);display:grid;grid-template-columns:.42fr .58fr;align-items:center;overflow:hidden;min-height:clamp(280px,26vw,400px)}
.mvimg{width:100%;height:100%;object-fit:contain;object-position:center;padding:clamp(18px,2.5vw,40px);display:block}
.mvbody{padding:clamp(22px,3vw,44px) clamp(22px,3vw,52px) clamp(22px,3vw,44px) 0}
.mvtitle{font-weight:800;font-size:clamp(24px,2.2vw,30px);letter-spacing:-.4px;margin:0 0 16px}
.mvtext{color:#2c2c2c;font-size:16.5px;line-height:1.65;margin:0}
.trusted{background:#efeeee;padding:clamp(140px,14vw,220px) 0 clamp(70px,8vw,110px)}
.trustgrid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,80px);align-items:center}
.cityimg{width:100%;height:auto;display:block;border-radius:26px;box-shadow:0 24px 50px -28px rgba(90,40,45,.28)}
.trusttitle{font-weight:800;font-size:clamp(30px,3.4vw,44px);letter-spacing:-.8px;line-height:1.12;margin:0 0 30px}
.trusttext{color:#222;font-size:16.5px;line-height:1.7;margin:0 0 28px;max-width:900px}
.seclabel{font-size:16.5px;color:#222;margin:0 0 22px}
.seclist{display:flex;flex-direction:column;gap:8px}
.secitem{display:flex;gap:10px;font-size:16.5px;color:#222;line-height:1.5}

/* ---------- CAREERS ---------- */
.carhead{text-align:center;padding:clamp(60px,8vw,120px) 0 clamp(40px,5vw,70px)}
.carhead .title{margin-top:18px;font-size:clamp(32px,4.4vw,54px)}
.carlead{max-width:1080px;margin:26px auto 0;color:#222;font-size:17px;line-height:1.65}
.photogrid{display:grid;grid-template-columns:1fr 1fr;gap:26px;padding-bottom:clamp(50px,6vw,90px)}
.photo{border-radius:26px;overflow:hidden;box-shadow:0 30px 60px -30px rgba(90,40,45,.25);display:block;width:100%;height:clamp(300px,34vw,540px);object-fit:cover}
.vacs{background:linear-gradient(110deg,#f3f2f2 0%,#faeceb 45%,#f6d9da 100%);padding:clamp(70px,9vw,140px) 0}
.vacgrid{display:grid;grid-template-columns:.9fr 1.6fr;gap:clamp(30px,5vw,80px);align-items:start}
.vactitle{font-weight:800;font-size:clamp(30px,3.4vw,44px);letter-spacing:-.8px;line-height:1.18;margin:18px 0 0;max-width:640px}
.vaclist{display:flex;flex-direction:column;gap:26px}
.vaccard{background:#fff;border-radius:24px;padding:clamp(24px,2.6vw,40px) clamp(24px,3vw,48px);box-shadow:0 24px 50px -34px rgba(90,40,45,.28);text-align:left;border:none;cursor:pointer;font:inherit;color:inherit;width:100%;transition:transform var(--dur) var(--ease)}
.vaccard:hover{transform:translateY(-3px)}
.vachead{display:flex;align-items:center;gap:14px}
.vacnum{color:var(--red);font-weight:800;font-size:18px}
.vacrole{font-weight:800;font-size:clamp(20px,1.8vw,25px);letter-spacing:-.3px;margin:0;flex:1}
.vacarrow{color:var(--red);flex:none;transition:transform var(--dur) var(--ease)}
.vaccard:hover .vacarrow{transform:translateX(6px)}
.vacsum{color:#222;font-size:16.5px;line-height:1.7;margin:18px 0 0}
.vacsum b{color:#141413}
.why{background:#f4f2f1;padding:clamp(60px,7vw,100px) 0}
.pg-careers .whygrid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,80px);align-items:center}
.whyimg{border-radius:26px;overflow:hidden;box-shadow:0 24px 50px -28px rgba(90,40,45,.28);display:block;width:100%;height:clamp(340px,40vw,600px);object-fit:cover}
.whytitle{font-weight:800;font-size:clamp(30px,3.4vw,44px);letter-spacing:-.8px;line-height:1.12;margin:0 0 26px}
.pg-careers .whytext{color:#222;font-size:16.5px;line-height:1.7;margin:0 0 34px;max-width:900px}
.why.dark{background:var(--dark)}
.why.dark .whytitle{color:#fff}
.why.dark .whytext{color:#e9e5e4}

/* ---------- CONTACT ---------- */
.cthead{text-align:center;padding:clamp(56px,7vw,104px) 0 clamp(48px,6vw,88px)}
.cthead .title{margin-top:18px;font-size:clamp(32px,4.4vw,54px)}
.ctlead{max-width:820px;margin:24px auto 0;color:#222;font-size:17px;line-height:1.65}
.ctsec{padding:clamp(56px,7vw,100px) 0}
.ctgrid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,4vw,72px);align-items:start}
.infolist{display:flex;flex-direction:column;gap:18px}
.infocard{display:flex;gap:18px;align-items:flex-start;background:linear-gradient(120deg,#fdeeec,#f8dedb);border-radius:22px;padding:26px 28px}
.icoball{width:52px;height:52px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
.infok{font-weight:800;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:#141413;margin:0 0 7px}
.infov{font-size:16px;line-height:1.6;color:#333;margin:0}
.infov a{color:#333;text-decoration:none}
.infov a:hover{color:var(--red)}
.socrow{display:flex;gap:12px;margin-top:6px}
.socbtn{width:46px;height:46px;border-radius:50%;border:1.6px solid rgba(20,20,19,.16);background:#fff;color:#141413;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--dur) var(--ease);text-decoration:none}
.socbtn:hover{background:var(--red);color:#fff;border-color:var(--red)}
.formcard{background:#fff;border-radius:26px;padding:clamp(28px,3vw,48px);box-shadow:0 30px 66px -34px rgba(90,40,45,.32);border:1px solid rgba(20,20,19,.07)}
.formtitle{font-weight:800;font-size:clamp(22px,2.2vw,30px);letter-spacing:-.5px;margin:0}
.formsub{color:#555;font-size:15.5px;line-height:1.6;margin:12px 0 30px;max-width:520px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:9px;margin-bottom:18px}
.lbl{font-weight:800;font-size:12.5px;letter-spacing:.8px;text-transform:uppercase;color:#141413}
.inp{border:1.5px solid rgba(20,20,19,.16);border-radius:14px;background:#faf8f8;padding:14px 18px;font-family:var(--font-sans);font-size:16px;color:#141413;outline:none;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease);width:100%}
.inp:focus{border-color:var(--red);background:#fff}
.inp::placeholder{color:#a7a2a1}
textarea.inp{resize:vertical;min-height:130px;line-height:1.6}
select.inp{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 10 10'%3E%3Cpath d='M2 4l3 3 3-3' stroke='%23E30613' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center}
.submit{background:#111;color:#fff;border:none;border-radius:999px;padding:16px 40px;font-size:14px;font-weight:800;letter-spacing:.9px;text-transform:uppercase;cursor:pointer;transition:transform var(--dur) var(--ease),background var(--dur) var(--ease);margin-top:6px;font-family:inherit}
.submit:hover{background:#000}.submit:active{transform:scale(.98)}
.submit[disabled]{opacity:.6;cursor:default}
.sent{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;padding:clamp(30px,5vw,70px) 10px}
.sentball{width:78px;height:78px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center}
.senttitle{font-weight:800;font-size:26px;letter-spacing:-.5px;margin:0}
.senttext{color:#555;font-size:16px;line-height:1.6;max-width:400px;margin:0}
.again{background:none;border:1.6px solid var(--red);color:var(--red);border-radius:999px;padding:12px 30px;font-size:13px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;margin-top:6px;font-family:inherit}
.again:hover{background:var(--red);color:#fff}
.formerr{color:var(--red);font-weight:700;font-size:14px;margin:0 0 16px;min-height:18px}
.mapband{padding:0 0 clamp(60px,7vw,100px)}
.mapbox{border-radius:26px;overflow:hidden;box-shadow:0 30px 60px -34px rgba(90,40,45,.28);position:relative}
.mapbox iframe{display:block;width:100%;height:clamp(320px,36vw,520px);border:0}
.maptag{position:absolute;left:clamp(20px,3vw,40px);bottom:clamp(20px,3vw,40px);background:#fff;border-radius:18px;padding:20px 26px;box-shadow:0 16px 40px -16px rgba(60,20,25,.3);max-width:340px}
.maptag .infok{margin-bottom:9px}

/* ---------- FOOTER ---------- */
.footer{background:var(--dark);color:#fff;padding:80px 0 40px}
body.home .footer{padding:230px 0 40px}
.footlogo{height:52px;color:#fff;margin-bottom:44px}
.footgrid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px}
.fh{font-weight:800;font-size:15px;letter-spacing:.6px;text-transform:uppercase;margin:0 0 16px}
.faddr{font-size:15px;line-height:1.7;color:#e9e5e4;margin:0 0 30px}
.fcontact a{color:#e9e5e4}
.flink{display:block;color:#f2efee;font-size:15px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;text-decoration:none;padding:11px 0}
.flink:hover{color:var(--red)}
.social{display:flex;align-items:center;gap:12px;color:#f2efee;font-size:15px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;text-decoration:none;padding:9px 0}
.social:hover{color:var(--red)}
.sicon{width:30px;height:30px;flex:none}
.fdiv{height:1px;background:rgba(255,255,255,.16);margin:44px 0 22px}
.copy{font-size:14px;color:#cfc9c8}
.copy a{color:#fff}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1200px){.navlinks{display:none}.navcta{display:none}.burger{display:flex}}
@media(max-width:1100px){.pkggrid,.pg-gaming .pkggrid{grid-template-columns:1fr 1fr}}
@media(max-width:900px){
 .nav{padding:20px 0}.logo-img{height:50px}
 .svc-head,.svc-body,.pg-home .whygrid,.bloggrid,.plangrid,.newsletter{grid-template-columns:1fr}
 .pkggrid,.pg-gaming .pkggrid,.detgrid,.packgrid,.howgrid{grid-template-columns:1fr}
 .mvgrid,.trustgrid,.photogrid,.vacgrid,.pg-careers .whygrid,.ctgrid,.frow{grid-template-columns:1fr}
 .mvcard{grid-template-columns:1fr;min-height:0}.mvbody{padding:0 26px 30px}
 .pg-corporate .herocopy{max-width:80%}.pg-side .herocopy{max-width:80%}
 .footgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
 .wrap{padding:0 18px}
 .footgrid{grid-template-columns:1fr;gap:22px}
 .herocap{left:20px;right:20px;bottom:36px}
 .nltitle{font-size:30px}
 .pg-corporate .herocopy,.pg-side .herocopy{max-width:88%}
 .nlform{flex-wrap:wrap}.nlbtn{width:100%}
}

/* ---------- MOTION ---------- */
@keyframes ebRise{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:none}}
@keyframes ebRiseHero{from{opacity:0;transform:translate(-50%,calc(-50% + 34px))}to{opacity:1;transform:translate(-50%,-50%)}}
@keyframes ebRiseHeroLeft{from{opacity:0;transform:translateY(calc(-50% + 34px))}to{opacity:1;transform:translateY(-50%)}}
@media (prefers-reduced-motion:no-preference){
 .services,.plangrid>*,.center,.newsletter,.pg-home .whygrid>*,.abouthead,.mvgrid>*,.trustgrid>*,.carhead,.photogrid>*,.vacgrid>*,.pg-careers .whygrid>*,.detgrid>*,.pkggrid>*,.cthead,.infocard,.formcard,.mapbox,.packhead,.packgrid>*,.howgrid>*{animation:ebRise both linear;animation-timeline:view();animation-range:entry 4% cover 30%}
 .herocap{animation:ebRise .85s .3s var(--ease) both}
 .pg-corporate .herocopy{animation:ebRiseHero .85s .3s var(--ease) both}
 .pg-side .herocopy{animation:ebRiseHeroLeft .85s .3s var(--ease) both}
}
