/* ==========================================================================
   Cassus Customer Service — shared stylesheet
   Corporate, Apple-esque: deep ocean blues, blue-to-blue gradients,
   parallax, scroll-reveal animations.
   ========================================================================== */

:root{
  --ink:#082638; --deep:#062331; --teal:#159BB5; --teal-d:#0E7C92; --teal-l:#36C2D8;
  --head:#0C3A52; --body:#5A7184; --line:#DCE6EC; --soft:#F5F9FB; --softer:#EFF5F8;
  --grad-deep:linear-gradient(135deg,#062331 0%,#0A3A54 55%,#0E5472 100%);
  --grad-ocean:linear-gradient(160deg,#0A3A54 0%,#0E5472 55%,#147A96 100%);
  --grad-teal:linear-gradient(135deg,#0E7C92 0%,#159BB5 100%);
  --grad-soft:linear-gradient(160deg,#F5F9FB 0%,#E7F1F6 100%);
  --shadow:0 14px 38px rgba(8,38,56,.12);
  --header-h:76px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--head);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-weight:500;letter-spacing:-0.02em;line-height:1.18;text-wrap:balance}
p{font-weight:400;text-wrap:pretty}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* ---------- layout ---------- */
.wrap{width:90%;max-width:980px;margin:0 auto}
.navwrap{width:95%;margin:0 auto}
.center{text-align:center}
.lead{font-size:clamp(17px,2vw,20px);color:var(--body)}
section{padding:84px 0}
.tight{padding:56px 0}

/* ---------- buttons ---------- */
.btn{display:inline-block;background:var(--teal);color:#fff;padding:12px 22px;border-radius:10px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:background .15s,transform .15s,box-shadow .15s}
.btn:hover{background:#127f96;transform:translateY(-1px);box-shadow:0 8px 20px rgba(21,155,181,.3)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.35);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);box-shadow:none}
.btn-dark{background:var(--ink)}
.btn-dark:hover{background:#0c3650}
.btn-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* ---------- header + mega menu ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:80;transition:background .3s,box-shadow .3s,backdrop-filter .3s}
.site-header.solid{background:rgba(8,38,56,.92);backdrop-filter:saturate(140%) blur(10px);box-shadow:0 1px 0 rgba(255,255,255,.06)}
.site-header nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:9px;color:#fff;font-size:17px;font-weight:600;white-space:nowrap}
.brand i{color:var(--teal-l);font-size:20px}
.brand-logo{height:50px;width:auto;display:block;max-width:72vw}
.foot-brand .brand-logo{height:36px}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links>a,.nav-trigger{color:#CDDDE6;font-size:14px;font-weight:500;background:none;border:none;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:5px;transition:color .15s}
.nav-links>a:hover,.nav-trigger:hover{color:#fff}
.nav-trigger i{font-size:15px;transition:transform .2s}
.has-mega.open .nav-trigger i{transform:rotate(180deg)}
.nav-links>a.nav-cta{background:var(--teal);color:#fff !important;padding:9px 18px;border-radius:9px}
.nav-links>a.nav-cta:hover{background:#127f96}
/* current page: white highlight on the dark header bar, muted light gray inside the white mega panel */
.nav-links>a.active{color:#fff}
.mega-col a.active{color:#9AA9B4}

/* full-width mega panel */
.mega{position:fixed;left:0;right:0;top:var(--header-h);width:100vw;background:#fff;
  box-shadow:var(--shadow);border-top:1px solid var(--line);
  opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .22s,transform .22s,visibility .22s;z-index:79}
.has-mega.open .mega{opacity:1;visibility:visible;transform:none}
.mega-inner{width:90%;max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:34px 0 38px}
.mega-col h4{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--teal-d);margin-bottom:14px;font-weight:600}
.mega-col a{display:block;color:var(--head);font-size:14.5px;padding:7px 0;border-radius:6px;transition:color .15s,padding .15s}
.mega-col a:hover{color:var(--teal);padding-left:4px}
.mega-col a span{display:block;font-size:12px;color:var(--body);font-weight:400}
.mega-feature{background:var(--grad-deep);border-radius:14px;padding:22px;color:#fff;display:flex;flex-direction:column;justify-content:space-between}
.mega-feature h4{color:#fff}
.mega-feature p{font-size:13px;color:#C6D6E0;margin:6px 0 14px}

/* hamburger */
.hamburger{display:none;background:none;border:none;color:#fff;font-size:26px;cursor:pointer}

/* ---------- hero (parallax) ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;overflow:hidden;color:#fff;text-align:center}
.hero-bg{position:absolute;inset:-10% 0;background:var(--grad-deep);background-size:cover;background-position:center;will-change:transform;z-index:0}
.hero-bg.photo{background-image:linear-gradient(rgba(6,28,42,.5),rgba(6,28,42,.72)),url('../img/ocean-hero.jpg')}
.hero-inner{position:relative;z-index:1;width:90%;max-width:760px;padding:140px 0 90px}
.hero h1{font-size:clamp(32px,5.4vw,52px);margin:0}
.hero p{font-size:clamp(16px,2.2vw,20px);color:#CFDEE7;margin:20px auto 0;font-weight:400}

/* compact page hero for inner pages */
.page-hero{position:relative;overflow:hidden;color:#fff;text-align:center;background:var(--grad-ocean)}
.page-hero .hero-bg{opacity:.4}
.page-hero-inner{position:relative;z-index:1;width:90%;max-width:820px;margin:0 auto;padding:calc(var(--header-h) + 70px) 0 72px}
.page-hero .eyebrow{color:var(--teal-l)}
.page-hero h1{font-size:clamp(30px,4.6vw,46px)}
.page-hero p{color:#CFDEE7;margin:18px auto 0;font-weight:400}

/* ---------- generic sections ---------- */
.eyebrow{font-size:12px;font-weight:600;color:var(--teal-d);letter-spacing:.07em;text-transform:uppercase;display:block}
.section-head{text-align:center;max-width:720px;margin:0 auto 44px}
.section-head h2{font-size:clamp(24px,3.6vw,36px);margin:10px 0 0}
.section-head p{margin-top:14px}
.grad-band{background:var(--grad-deep);color:#fff}
.grad-band .eyebrow{color:var(--teal-l)}
.grad-band p{color:#A9C0CD}
.soft-band{background:var(--grad-soft)}

.statement{background:#fff}
.statement p{font-size:clamp(20px,3vw,30px);color:var(--head);max-width:30ch;margin:0 auto;font-weight:500;line-height:1.35;text-wrap:balance}

/* card grids */
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.cols-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.card{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 24px;transition:transform .2s,box-shadow .2s}
a.card:hover h3{color:var(--teal)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card.soft{background:var(--soft);border-color:transparent}
.card.center{text-align:center}
.ic{display:inline-flex;width:52px;height:52px;border-radius:14px;background:var(--grad-teal);color:#fff;align-items:center;justify-content:center;font-size:25px;margin-bottom:16px}
.card h3{font-size:19px;margin-bottom:8px}
.card p{font-size:14.5px;color:var(--body)}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:26px}
.num{display:inline-flex;width:46px;height:46px;border-radius:50%;background:var(--grad-teal);color:#fff;align-items:center;justify-content:center;font-size:17px;font-weight:600;margin-bottom:14px}
.step h3{font-size:17px;margin-bottom:6px}
.step p{font-size:14px;color:var(--body)}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;text-align:center}
.stat .n{font-size:clamp(30px,4vw,44px);font-weight:600;color:var(--teal-l)}
.stat .l{font-size:14px;color:#A9C0CD;margin-top:4px}

/* prose (articles + text pages) */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:26px;margin:38px 0 14px}
.prose h3{font-size:20px;margin:28px 0 10px}
.prose p{font-size:17px;color:#33485a;margin:0 0 18px;line-height:1.75}
.prose ul,.prose ol{margin:0 0 18px 22px}
.prose li{font-size:17px;color:#33485a;margin:0 0 8px;line-height:1.7}
.prose a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.prose a:hover{color:var(--teal-d)}
.prose blockquote{border-left:3px solid var(--teal);padding:6px 0 6px 18px;margin:0 0 18px;color:var(--head);font-size:18px}

/* CTA band */
.cta{background:var(--grad-deep);color:#fff;text-align:center}
.cta h2{font-size:clamp(24px,3.6vw,36px)}
.cta p{color:#C6D6E0;margin:14px auto 0;max-width:48ch}

/* contact form */
form.lead-form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;width:100%;max-width:980px;margin:0 auto;text-align:left;box-shadow:var(--shadow)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label{display:block;font-size:13px;color:#456073;margin:0 0 6px}
.field{margin-bottom:14px}
input,select,textarea{width:100%;border:1px solid #D3DDE4;border-radius:10px;padding:12px;font-family:inherit;font-size:14px;color:var(--head);background:#fff}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(21,155,181,.15)}
textarea{min-height:100px;resize:vertical}
form.lead-form .btn{width:100%;padding:14px;margin-top:4px;font-size:15px}

/* ---------- footer ---------- */
footer{background:var(--deep);color:#fff;padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:40px}
.foot-brand .brand{margin-bottom:12px}
.foot-brand p{font-size:13px;color:#8CA3B2;max-width:30ch}
.foot-col h4{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--teal-l);margin-bottom:14px;font-weight:600}
.foot-col a{display:block;font-size:13.5px;color:#9FB6C4;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;text-align:center}
.flag-tag{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:#CDE6EE;margin:0 0 12px}
.flag-tag svg{flex:none}
.copyright{font-size:10px;color:#5E7787}

/* ---------- scroll-reveal animations ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- floating widgets ---------- */
.fab{position:fixed;bottom:22px;width:54px;height:54px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-size:26px;box-shadow:0 6px 20px rgba(8,38,56,.28);z-index:70;transition:transform .15s}
.fab:hover{transform:scale(1.06)}
.fab-chat{right:22px;background:var(--teal)}
.fab-a11y{left:22px;background:var(--ink)}
.popcard{position:fixed;bottom:88px;z-index:70;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 14px 38px rgba(8,38,56,.24);width:300px;overflow:hidden}
.popcard[hidden]{display:none}
.pop-right{right:22px}.pop-left{left:22px}
.pop-head{background:var(--ink);color:#fff;padding:13px 16px;font-size:15px;font-weight:600;display:flex;justify-content:space-between;align-items:center}
.pop-head button{background:none;border:none;color:#CDDDE6;cursor:pointer;font-size:20px;line-height:1}
.pop-body{padding:16px}
.pop-body>p{font-size:14px;color:var(--body);margin-bottom:14px}
.a11y-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:14px;color:var(--head);cursor:pointer;margin-bottom:8px;font-family:inherit}
.a11y-item i{font-size:18px;color:var(--teal-d)}
.a11y-item.on{background:var(--teal);border-color:var(--teal);color:#fff}
.a11y-item.on i{color:#fff}
.a11y-reset{width:100%;background:none;border:none;color:var(--teal-d);font-size:13px;font-weight:500;cursor:pointer;padding:6px;font-family:inherit;text-decoration:underline}

/* ---------- cookie banner ---------- */
.cookie{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;z-index:90;width:92%;max-width:680px;
  background:rgba(8,38,56,.97);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.1);
  border-radius:14px;box-shadow:0 16px 40px rgba(0,0,0,.3);padding:18px 20px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between}
.cookie[hidden]{display:none}
.cookie p{font-size:13.5px;color:#C6D6E0;flex:1;min-width:220px}
.cookie a{color:var(--teal-l);text-decoration:underline}
.cookie-actions{display:flex;gap:10px}
.cookie .btn{padding:9px 18px;font-size:13px}
.cookie .btn-decline{background:transparent;border:1px solid rgba(255,255,255,.3)}
.cookie .btn-decline:hover{background:rgba(255,255,255,.1);box-shadow:none}

/* ---------- accessibility states ---------- */
body.a11y-bigtext{zoom:1.15}
body.a11y-contrast{filter:contrast(1.35) saturate(1.1)}
body.a11y-readable,body.a11y-readable *{font-family:Verdana,Tahoma,Geneva,sans-serif !important;letter-spacing:.01em}
body.a11y-readable p,body.a11y-readable li{line-height:1.9 !important}
body.a11y-hilinks a:not(.btn):not(.brand):not(.nav-cta){background:#FFF3B0;color:#5C4A00 !important;text-decoration:underline;border-radius:3px;padding:0 2px}
body.a11y-bigcursor,body.a11y-bigcursor *{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Cpath d='M5 2 L5 33 L13 25 L19 37 L25 34 L19 23 L31 23 Z' fill='%23000' stroke='%23fff' stroke-width='2'/%3E%3C/svg%3E") 4 2, auto !important}
body.a11y-nomotion *{animation:none !important;transition:none !important}
body.a11y-nomotion{scroll-behavior:auto !important}
body.a11y-nomotion .reveal{opacity:1 !important;transform:none !important}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .nav-links{position:fixed;top:var(--header-h);left:0;right:0;background:rgba(8,38,56,.98);backdrop-filter:blur(10px);
    flex-direction:column;align-items:flex-start;gap:0;padding:0 5%;max-height:0;overflow:hidden;transition:max-height .3s,padding .3s;border-top:0}
  .nav-open .nav-links{max-height:80vh;overflow:auto;padding:10px 5% 24px;border-top:1px solid rgba(255,255,255,.08)}
  .nav-links>a,.nav-trigger{padding:14px 0;width:100%}
  .hamburger{display:block}
  .mega{position:static;width:100%;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;max-height:0;overflow:hidden;transition:max-height .3s}
  .has-mega.open .mega{max-height:1400px}
  .mega-inner{grid-template-columns:1fr;gap:18px;padding:8px 0 14px;width:100%}
  .mega-col a{color:#CDDDE6}.mega-col a:hover{color:#fff}.mega-col h4{color:var(--teal-l)}
  .mega-col a span{color:#8CA3B2}
  .mega-feature{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .row{grid-template-columns:1fr}
  .popcard{width:84vw}
  .foot-grid{grid-template-columns:1fr}
  section{padding:60px 0}
}

/* ---------- WordPress admin bar: keep the fixed header (and dropdowns) below it ---------- */
body.admin-bar .site-header{top:32px}
body.admin-bar .mega{top:calc(var(--header-h) + 32px)}
@media screen and (max-width:860px){
  body.admin-bar .nav-links{top:calc(var(--header-h) + 32px)}
}
@media screen and (max-width:782px){
  body.admin-bar .site-header{top:46px}
  body.admin-bar .mega{top:calc(var(--header-h) + 46px)}
  body.admin-bar .nav-links{top:calc(var(--header-h) + 46px)}
}

/* ---------- Gravity Forms: match the theme ---------- */
.lead-form-wrap{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow);text-align:left}
.gform_wrapper, .gform_wrapper *{font-family:'Inter',system-ui,-apple-system,sans-serif}
.gform_wrapper .gform_title{font-size:20px;color:var(--head);font-weight:500;letter-spacing:-0.02em}
.gform_wrapper .gfield_label{font-size:13px;color:#456073;font-weight:500;margin:0 0 6px}
.gform_wrapper .gfield_required{color:var(--teal-d)}
.gform_wrapper input[type=text],
.gform_wrapper input[type=email],
.gform_wrapper input[type=tel],
.gform_wrapper input[type=url],
.gform_wrapper input[type=number],
.gform_wrapper select,
.gform_wrapper textarea{
  width:100% !important;border:1px solid #D3DDE4 !important;border-radius:10px !important;
  padding:12px !important;font-size:14px !important;color:var(--head) !important;background:#fff !important;
  font-family:inherit !important;box-shadow:none !important;line-height:1.4 !important}
.gform_wrapper input:focus,
.gform_wrapper select:focus,
.gform_wrapper textarea:focus{outline:none !important;border-color:var(--teal) !important;box-shadow:0 0 0 3px rgba(21,155,181,.15) !important}
.gform_wrapper textarea{min-height:110px !important;resize:vertical}
.gform_wrapper .gfield{margin-bottom:14px !important}
.gform_wrapper .gfield_description,
.gform_wrapper .gform_fileupload_rules{color:var(--body);font-size:13px}
.gform_wrapper .gform_footer{margin-top:10px !important;padding:0 !important}
.gform_wrapper .gform_footer input[type=submit],
.gform_wrapper .gform_button,
.gform_wrapper button.gform_button,
.gform_wrapper input.gform_button{
  background:var(--teal) !important;color:#fff !important;border:none !important;border-radius:10px !important;
  padding:13px 24px !important;font-size:15px !important;font-weight:500 !important;font-family:inherit !important;
  cursor:pointer !important;width:100% !important;transition:background .15s, transform .15s, box-shadow .15s !important}
.gform_wrapper .gform_footer input[type=submit]:hover,
.gform_wrapper .gform_button:hover{background:#127f96 !important;transform:translateY(-1px);box-shadow:0 8px 20px rgba(21,155,181,.3) !important}
.gform_wrapper .gform_validation_errors{border-radius:12px;font-size:14px}
.gform_wrapper .gfield_validation_message,
.gform_wrapper .validation_message{color:#A32D2D !important;font-size:13px !important;background:none !important;border:none !important;padding:4px 0 0 !important}
.gform_wrapper .gfield_error input,
.gform_wrapper .gfield_error textarea,
.gform_wrapper .gfield_error select{border-color:#E24B4A !important}
.gform_confirmation_message,
.gform_wrapper .gform_confirmation_message{color:var(--head);font-size:16px;text-align:center;padding:14px 0}

/* ---------- Gravity Forms: tighten spacing + fix select height ---------- */
.gform_wrapper .gform_fields{grid-row-gap:0 !important;row-gap:0 !important}
.gform_wrapper .gfield{margin-bottom:16px !important;padding:0 !important}
.gform_wrapper .gform_fields > .gfield:last-child{margin-bottom:0 !important}
.gform_wrapper .gfield_label{margin:0 0 6px !important;line-height:1.3 !important}
.gform_wrapper select{height:auto !important;min-height:46px !important;line-height:1.4 !important;
  appearance:auto;-webkit-appearance:auto}
.gform_wrapper .ginput_container{margin-top:0 !important}

/* ---------- admin bar on phones: it becomes position:absolute (<=600px) and scrolls
   away, so the fixed header must sit at top:0 (no leftover gap) ---------- */
@media screen and (max-width:600px){
  body.admin-bar .site-header{top:0}
  body.admin-bar .mega{top:var(--header-h)}
  body.admin-bar .nav-links{top:var(--header-h)}
}

/* ---------- responsive nav logo / header height ---------- */
@media(max-width:860px){ :root{--header-h:72px} .brand-logo{height:46px} }
@media(max-width:560px){ :root{--header-h:64px} .brand-logo{height:40px} }

/* ---------- Articles index: search bar + lazy sentinel ---------- */
.article-search{position:relative;max-width:460px;margin:0 auto 32px}
.article-search i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--body);font-size:18px;pointer-events:none}
.article-search input{width:100%;border:1px solid var(--line);border-radius:999px;padding:13px 18px 13px 44px;font-size:15px;font-family:inherit;color:var(--head);background:#fff;box-shadow:var(--shadow)}
.article-search input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(21,155,181,.15)}
#articleSentinel{height:1px}
