/*
Theme Name: Hello Elementor - Slide Experts
Theme URI: https://theslideexperts.com/
Description: Child theme for The Slide Experts WordPress rebuild. Registers service_area + portfolio CPTs, preserves legacy /content/ URLs (zero 301), header/footer, and the rebuild's custom templates.
Author: Maly Internet Marketing
Template: hello-elementor
Version: 1.1.0
*/

:root{
  --tse-font-head:'Poppins','Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --tse-font-body:'Inter','Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --tse-navy:#003a5c;     /* Deep Ocean (from logo) */
  --tse-blue:#1a6fb5;     /* Ocean Blue */
  --tse-blue-d:#0e5f8c;   /* gradient / hover */
  --tse-cyan:#39c5f0;     /* Splash accent */
  --tse-yellow:#ffc62e;   /* CTA */
  --tse-orange:#ffc62e;   /* legacy alias -> yellow */
  --tse-ink:#1f2d3d;
  --tse-muted:#7a8aa0;
  --tse-gold:#ffc62e;
}
*{box-sizing:border-box;}
body{margin:0;font-family:var(--tse-font-body);}
h1,h2,h3,h4,h5,h6,.tse-h2,.tse-eyebrow,.tse-btn,.tse-cta,.tse-stat__n,.tse-card h3,.tse-why h3,.tse-ctaband h2{font-family:var(--tse-font-head);}

/* ---------- Header ---------- */
.tse-header{position:sticky;top:0;z-index:999;background:#fff;box-shadow:0 2px 14px rgba(10,37,64,.08);}
.tse-header__inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;gap:20px;}
.tse-logo{display:inline-flex;}
.tse-logo img{height:66px;width:auto;display:block;}
.tse-nav ul{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:2px;}
.tse-nav li{position:relative;}
.tse-nav a{color:var(--tse-ink);text-decoration:none;font-weight:600;font-size:15px;padding:10px 14px;border-radius:6px;display:block;transition:color .15s,background .15s;}
.tse-nav a:hover{color:var(--tse-blue);background:rgba(26,111,181,.07);}
.tse-nav .current-menu-item>a,.tse-nav .current_page_item>a{color:var(--tse-blue);}
.tse-actions{display:flex;align-items:center;gap:16px;}
.tse-phone{color:var(--tse-navy);font-weight:800;font-size:18px;text-decoration:none;white-space:nowrap;line-height:1.1;}
.tse-phone span{display:block;font-size:11px;font-weight:600;color:var(--tse-muted);letter-spacing:.06em;text-transform:uppercase;}
.tse-cta{background:var(--tse-yellow);color:var(--tse-navy);font-weight:700;font-size:15px;padding:12px 22px;border-radius:7px;text-decoration:none;white-space:nowrap;box-shadow:0 6px 16px rgba(255,198,46,.36);}
.tse-cta:hover{filter:brightness(1.05);color:var(--tse-navy);}
.tse-nav .tse-cta--mobile{display:none;}
.tse-burger{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.tse-burger span{display:block;width:26px;height:3px;background:var(--tse-navy);margin:5px 0;border-radius:2px;transition:.2s;}
@media(max-width:980px){
  .tse-nav{position:fixed;left:0;right:0;top:78px;background:#fff;padding:8px 18px 18px;box-shadow:0 14px 26px rgba(10,37,64,.14);transform:translateY(-160%);transition:transform .25s ease;}
  .tse-nav.open{transform:translateY(0);}
  .tse-nav ul{flex-direction:column;align-items:stretch;gap:0;}
  .tse-nav a{padding:14px 8px;border-bottom:1px solid #eef2f6;}
  .tse-nav .tse-cta--mobile{display:block;text-align:center;margin-top:14px;}
  .tse-burger{display:block;}
  .tse-actions .tse-cta{display:none;}
  .tse-phone span{display:none;}
  .tse-phone{font-size:16px;}
}

/* ---------- Footer ---------- */
.tse-footer{background:var(--tse-navy);color:#cfe0f0;padding:54px 24px 26px;font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;}
.tse-footer__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1.1fr;gap:40px;}
.tse-footer h4{color:#fff;font-size:16px;margin:0 0 16px;letter-spacing:.02em;}
.tse-footer p{line-height:1.6;font-size:15px;margin:0 0 14px;color:#b9cde0;}
.tse-footer a{color:#cfe0f0;text-decoration:none;}
.tse-footer a:hover{color:#fff;}
.tse-footer__brand img{height:54px;margin-bottom:16px;}
.tse-footer ul{list-style:none;padding:0;margin:0;line-height:2.1;}
.tse-arc{background:rgba(127,212,255,.1);border:1px solid rgba(127,212,255,.25);border-radius:8px;padding:14px 16px;margin-top:6px;font-size:13.5px;color:#dceaf6;}
.tse-footer__bottom{max-width:1200px;margin:32px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);font-size:13px;color:#8ba3bd;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px 28px;}
.tse-footer__badges{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.tse-footer__badges .tse-seal{flex:0 0 auto;display:block;}
.tse-footer__badges a.tse-seal-link{display:inline-flex;line-height:0;border-radius:50%;transition:transform .15s ease,filter .15s ease;}
.tse-footer__badges a.tse-seal-link:hover{transform:translateY(-2px);filter:brightness(1.08);}
.tse-footer__badges a.tse-seal-link:focus-visible{outline:2px solid #FFC62E;outline-offset:3px;}
@media(max-width:760px){.tse-footer__inner{grid-template-columns:1fr;gap:30px;}
.tse-footer__bottom{justify-content:center;text-align:center;}
.tse-footer__badges{justify-content:center;}}
@media(max-width:600px){.tse-footer__badges{gap:11px;flex-wrap:nowrap;}
.tse-footer__badges .tse-seal{width:56px;height:56px;}}

/* ================= Homepage sections ================= */
.tse-sec{padding:88px 24px;}
.tse-sec--tint{background:#f5f9fc;}
.tse-sec--navy{background:var(--tse-navy);}
.tse-wrap{max-width:1180px;margin:0 auto;}
.tse-eyebrow{display:inline-block;font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--tse-blue);margin:0 0 12px;}
.tse-h2{font-size:clamp(28px,3.4vw,42px);font-weight:800;line-height:1.12;color:var(--tse-navy);margin:0 0 16px;letter-spacing:-.01em;}
.tse-lead{font-size:18px;line-height:1.6;color:#5c6b7a;max-width:680px;margin:0;}
.tse-head{text-align:center;margin:0 auto 48px;max-width:720px;}
.tse-head .tse-lead{margin:0 auto;}

.tse-svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.tse-card{background:#fff;border:1px solid #e6eef5;border-radius:14px;padding:30px 26px;box-shadow:0 6px 22px rgba(10,37,64,.06);transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;}
.tse-card:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(10,37,64,.13);}
.tse-card__icon{width:54px;height:54px;border-radius:13px;background:linear-gradient(135deg,#1a6fb5,#0e4f86);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.tse-card__icon svg{width:27px;height:27px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.tse-card h3{font-size:19px;font-weight:700;color:var(--tse-navy);margin:0 0 10px;}
.tse-card p{font-size:15px;line-height:1.6;color:#5c6b7a;margin:0 0 18px;flex:1;}
.tse-card a{color:var(--tse-blue);font-weight:700;font-size:14px;text-decoration:none;display:inline-flex;align-items:center;gap:6px;}
.tse-card a:hover{color:var(--tse-blue-d);}

.tse-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;}
.tse-stat__n{font-size:clamp(30px,4vw,44px);font-weight:800;color:#fff;line-height:1;}
.tse-stat__n span{color:var(--tse-gold,#ffd23f);}
.tse-stat__l{font-size:14px;color:#9fc0dd;margin-top:10px;font-weight:600;}

.tse-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.tse-why{background:#fff;border:1px solid #e6eef5;border-radius:14px;padding:32px 28px;box-shadow:0 6px 22px rgba(10,37,64,.06);}
.tse-why h3{font-size:20px;color:var(--tse-navy);margin:0 0 18px;font-weight:700;display:flex;align-items:center;gap:12px;}
.tse-why h3 .tse-dot{width:40px;height:40px;border-radius:10px;background:#eaf3fb;display:inline-flex;align-items:center;justify-content:center;flex:none;}
.tse-why h3 .tse-dot svg{width:22px;height:22px;stroke:var(--tse-blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.tse-why ul{list-style:none;margin:0;padding:0;}
.tse-why li{display:flex;align-items:flex-start;gap:10px;padding:11px 0;font-size:15px;color:#3c4a59;border-top:1px solid #f0f5fa;}
.tse-why li:first-child{border-top:0;}
.tse-why li svg{width:18px;height:18px;flex:none;margin-top:2px;stroke:var(--tse-blue);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;}

.tse-quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.tse-quote{background:rgba(255,255,255,.06);border:1px solid rgba(127,212,255,.18);border-radius:14px;padding:28px;}
.tse-quote__stars{color:#ffc62e;font-size:15px;letter-spacing:3px;margin-bottom:14px;}
.tse-quote p{font-size:16px;line-height:1.62;color:#eaf2fa;margin:0 0 18px;}
.tse-quote__by{font-size:13px;color:#9fc0dd;}
.tse-quote__by strong{color:#fff;display:block;font-weight:700;font-size:15px;margin-bottom:2px;}

.tse-ctaband{background:linear-gradient(120deg,#003a5c,#0e5f8c);padding:74px 24px;text-align:center;}
.tse-ctaband h2{font-size:clamp(26px,3.2vw,38px);font-weight:800;color:#fff;margin:0 0 14px;}
.tse-ctaband p{color:#bcd2e6;font-size:18px;margin:0 0 30px;}
.tse-btn-row{display:flex;gap:20px;justify-content:center;align-items:center;flex-wrap:wrap;}
.tse-btn{display:inline-block;background:var(--tse-yellow);color:var(--tse-navy);font-weight:700;font-size:17px;padding:17px 38px;border-radius:8px;text-decoration:none;box-shadow:0 10px 28px rgba(255,198,46,.42);transition:filter .15s,transform .15s;}
.tse-btn:hover{filter:brightness(1.05);transform:translateY(-2px);color:var(--tse-navy);}
.tse-btn-ph{color:#fff;font-weight:800;font-size:19px;text-decoration:none;white-space:nowrap;}
.tse-btn-ph:hover{color:var(--tse-gold,#ffd23f);}
a:focus-visible,.tse-btn:focus-visible,.tse-nav a:focus-visible{outline:3px solid #7fd4ff;outline-offset:2px;border-radius:4px;}

@media(prefers-reduced-motion:reduce){*{transition:none!important;}}
@media(max-width:980px){
 .tse-svc-grid{grid-template-columns:repeat(2,1fr);}
 .tse-why-grid,.tse-quote-grid{grid-template-columns:1fr;}
 .tse-stats{grid-template-columns:repeat(2,1fr);gap:34px 16px;}
}
@media(max-width:560px){
 .tse-svc-grid{grid-template-columns:1fr;}
 .tse-sec{padding:60px 20px;}
}

/* ================= Service detail pages ================= */
.tse-svchero{position:relative;min-height:62vh;display:flex;align-items:center;overflow:hidden;background:var(--tse-navy);}
.tse-svchero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.tse-svchero__ov{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(5,20,38,.84) 0%,rgba(5,20,38,.55) 48%,rgba(5,20,38,.18) 100%);}
.tse-svchero__in{position:relative;z-index:2;width:100%;max-width:1180px;margin:0 auto;padding:84px 24px 70px;color:#fff;}
.tse-crumb{font-size:13px;font-weight:600;color:#9fc6e2;margin:0 0 18px;}
.tse-crumb a{color:#cfe7f6;text-decoration:none;}
.tse-crumb a:hover{color:#fff;}
.tse-crumb span{margin:0 8px;color:#5d87a8;}
.tse-svchero h1{font-size:clamp(30px,4.4vw,52px);font-weight:800;line-height:1.08;margin:0 0 16px;max-width:640px;text-shadow:0 2px 20px rgba(0,0,0,.4);}
.tse-svchero p{font-size:clamp(16px,1.9vw,19px);line-height:1.55;color:#dcebf7;margin:0 0 30px;max-width:560px;}
.tse-svchero .tse-btn-row{justify-content:flex-start;}

.tse-svc-copy{max-width:780px;}
.tse-svc-copy p{font-size:17px;line-height:1.75;color:#3c4a59;margin:0 0 20px;}
.tse-svc-copy strong{color:var(--tse-navy);}

.tse-steps{counter-reset:tsestep;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:10px;}
.tse-step{position:relative;background:#fff;border:1px solid #e6eef5;border-radius:14px;padding:26px 22px 22px;box-shadow:0 6px 22px rgba(10,37,64,.06);}
.tse-step::before{counter-increment:tsestep;content:counter(tsestep,decimal-leading-zero);display:inline-block;font-family:var(--tse-font-head);font-size:13px;font-weight:800;letter-spacing:.06em;color:var(--tse-navy);background:var(--tse-yellow);border-radius:8px;padding:7px 11px;margin-bottom:14px;}
.tse-step h3{font-size:17px;font-weight:700;color:var(--tse-navy);margin:0 0 8px;}
.tse-step p{font-size:14.5px;line-height:1.6;color:#5c6b7a;margin:0;}

.tse-ba-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.tse-ba-mini{position:relative;border-radius:14px;overflow:hidden;background:var(--tse-navy);box-shadow:0 10px 26px rgba(10,37,64,.14);cursor:pointer;}
.tse-ba-mini .ph{position:relative;aspect-ratio:35/32;}
.tse-ba-mini .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .5s ease;}
.tse-ba-mini .ph .b{opacity:0;}
.tse-ba-mini.show-b .ph .b{opacity:1;}
.tse-ba-mini.show-b .ph .a{opacity:0;}
.tse-ba-mini .tag{position:absolute;top:12px;left:12px;z-index:2;display:flex;border-radius:999px;overflow:hidden;font-family:var(--tse-font-head);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;backdrop-filter:blur(6px);}
.tse-ba-mini .tag span{padding:7px 11px;transition:background .3s,color .3s;}
.tse-ba-mini .tag .tb{background:rgba(31,45,61,.55);color:#cfd9e4;}
.tse-ba-mini .tag .ta{background:var(--tse-yellow);color:var(--tse-navy);}
.tse-ba-mini.show-b .tag .tb{background:#fff;color:var(--tse-navy);}
.tse-ba-mini.show-b .tag .ta{background:rgba(31,45,61,.55);color:#cfd9e4;}

.tse-xlinks{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.tse-xlink{display:block;background:#fff;border:1px solid #e6eef5;border-radius:14px;padding:24px 22px;text-decoration:none;box-shadow:0 6px 22px rgba(10,37,64,.06);transition:transform .2s ease,box-shadow .2s ease;}
.tse-xlink:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(10,37,64,.12);}
.tse-xlink h3{font-size:17px;font-weight:700;color:var(--tse-navy);margin:0 0 6px;}
.tse-xlink p{font-size:14px;line-height:1.55;color:#5c6b7a;margin:0 0 12px;}
.tse-xlink span{color:var(--tse-blue);font-weight:700;font-size:14px;}

@media(max-width:980px){
 .tse-steps{grid-template-columns:repeat(2,1fr);}
 .tse-ba-mini-grid,.tse-xlinks{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:640px){
 .tse-svchero{min-height:54vh;}
 .tse-steps,.tse-ba-mini-grid,.tse-xlinks{grid-template-columns:1fr;}
}

/* ================= Flume-tube CTA treatment =================
   Primary buttons read as glossy gel-coated tube sections joined by
   bolted flanges — the pieces the company restores. Subtle by design:
   a fiberglass sheen across the top, a flange seam at each end, and
   three small bolts per flange. */
.tse-btn,.tse-cta,.tse-ct__submit,.tse-qs__submit{
 position:relative;overflow:hidden;border-radius:11px!important;
 background-image:linear-gradient(180deg,rgba(255,255,255,.38),rgba(255,255,255,.10) 32%,rgba(255,255,255,0) 55%,rgba(0,58,92,.10) 100%)!important;
 box-shadow:inset 0 1.5px 0 rgba(255,255,255,.5),inset 0 -3px 6px rgba(0,58,92,.22),0 10px 26px rgba(255,198,46,.4)!important;
}
.tse-btn::before,.tse-cta::before,.tse-ct__submit::before,.tse-qs__submit::before,
.tse-btn::after,.tse-cta::after,.tse-ct__submit::after,.tse-qs__submit::after{
 content:"";position:absolute;top:5px;bottom:5px;width:7px;pointer-events:none;
 background:
  radial-gradient(circle at 3.5px 20%,rgba(255,255,255,.7) 0 .7px,rgba(0,58,92,.48) 1px 2px,transparent 2.7px),
  radial-gradient(circle at 3.5px 50%,rgba(255,255,255,.7) 0 .7px,rgba(0,58,92,.48) 1px 2px,transparent 2.7px),
  radial-gradient(circle at 3.5px 80%,rgba(255,255,255,.7) 0 .7px,rgba(0,58,92,.48) 1px 2px,transparent 2.7px);
}
.tse-btn::before,.tse-cta::before,.tse-ct__submit::before,.tse-qs__submit::before{left:7px;border-left:1.5px solid rgba(0,58,92,.22);}
.tse-btn::after,.tse-cta::after,.tse-ct__submit::after,.tse-qs__submit::after{right:7px;border-right:1.5px solid rgba(0,58,92,.22);}
