/* iTVerse website starter
   Brand palette from guidelines:
   Yellow #FDCE00 | Light Grey #989898 | Dark Grey #717171 | Black #000000 | White #FFFFFF
   Typography:
   Body and headings: Inter (Google Fonts), with system-font fallback stack.
*/

:root{
  --brand-yellow:#FDCE00;
  --brand-black:#000000;
  --brand-dark:#171717;
  --brand-mid:#717171;
  --brand-light:#989898;
  --brand-bg:#f6f6f6;
  --brand-white:#FFFFFF;
  --container:1180px;
  --radius:24px;
  --shadow:0 18px 60px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  color:var(--brand-black);
  background:var(--brand-white);
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{
  width:min(var(--container), calc(100% - 2rem));
  margin-inline:auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,.08);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  min-height:90px;
}

.brand{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  font-weight:800;
  letter-spacing:.01em;
}

.brand-mark{
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border-radius:14px;
  background:var(--brand-yellow);
  color:var(--brand-black);
  font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-weight:800;
}

.brand-text{
  font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size:1.4rem;
  font-weight:800;
}

.main-nav,
.header-actions{
  display:flex;
  align-items:center;
  gap:.75rem;
}

.main-nav a{
  font-size:.92rem;
}

.main-nav a,
.text-link{
  font-weight:700;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:.85rem 1.25rem;
  border-radius:999px;
  font-weight:800;
  transition:.2s ease;
  border:2px solid transparent;
}

.btn:hover{transform:translateY(-1px)}

.btn-primary{
  background:var(--brand-yellow);
  color:var(--brand-black);
}

.btn-secondary{
  border-color:rgba(0,0,0,.16);
  background:var(--brand-white);
}

.hero{
  padding:5rem 0 3rem;
  background:
    radial-gradient(circle at top right, rgba(253,206,0,.24), transparent 26%),
    linear-gradient(180deg, #fff 0%, #f9f9f9 100%);
}

.hero-grid,
.about-grid,
.security-grid,
.contact-grid,
.cta-grid,
.trust-grid{
  display:grid;
  gap:2rem;
}

.hero-grid{
  grid-template-columns:1.15fr .85fr;
  align-items:center;
}

.eyebrow,
.section-kicker{
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.85rem;
  font-weight:800;
  color:var(--brand-mid);
  margin:0 0 1rem;
}

h1,h2,h3{
  font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  line-height:1.05;
  margin:0 0 1rem;
}

h1{font-size:clamp(2.4rem, 5vw, 4rem); letter-spacing:-0.02em}
h2{font-size:clamp(1.75rem, 3.5vw, 2.5rem); letter-spacing:-0.015em}
h3{font-size:1.35rem}

.lead{
  font-size:1.2rem;
  max-width:60ch;
  color:#202020;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.9rem;
  margin:1.75rem 0 1.5rem;
}

.hero-points{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  padding:0;
  list-style:none;
  margin:0;
}

.hero-points li,
.trust-list span{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:999px;
  padding:.7rem 1rem;
  font-weight:700;
}

.hero-card{
  background:var(--brand-dark);
  color:#fff;
  padding:1.3rem;
  border-radius:30px;
  box-shadow:var(--shadow);
}

.stat-card{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.1);
  padding:1.4rem;
  border-radius:22px;
  margin-bottom:1rem;
}

.stat-label{
  display:block;
  color:#d2d2d2;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.75rem;
  margin-bottom:.5rem;
}

.stat-card strong{
  display:block;
  font-size:2rem;
  margin-bottom:.6rem;
}

.mini-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1rem;
}

.mini-grid article{
  background:#fff;
  color:var(--brand-black);
  border-radius:20px;
  padding:1.15rem;
}

.mini-grid h3{
  margin-bottom:.35rem;
  font-size:1.2rem;
}

.trust-strip{
  padding:1rem 0 0;
}

.trust-grid{
  grid-template-columns:.8fr 1.2fr;
  align-items:center;
}

.trust-list{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:.75rem;
}

.section{
  padding:5rem 0;
}

.section-head{
  max-width:760px;
  margin-bottom:2rem;
}

.card-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.25rem;
}

.service-card{
  padding:1.5rem;
  border-radius:24px;
  background:var(--brand-bg);
  border:1px solid rgba(0,0,0,.06);
}

.section-dark{
  background:var(--brand-dark);
  color:#fff;
}

.about-grid{
  grid-template-columns:1fr .9fr;
  align-items:start;
}

.commitment-panel{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  border-radius:28px;
  padding:1.5rem;
}

.commitment-panel ol{
  margin:0;
  padding-left:1.2rem;
}

.commitment-panel li{
  margin-bottom:1rem;
}

.commitment-panel span{
  display:block;
  color:#d7d7d7;
  margin-top:.25rem;
}

.security-grid{
  grid-template-columns:1fr .8fr;
  align-items:center;
}

.check-list{
  margin:1.25rem 0 0;
  padding:0;
  list-style:none;
}

.check-list li{
  position:relative;
  padding-left:1.8rem;
  margin:.65rem 0;
}

.check-list li::before{
  content:"";
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--brand-yellow);
  position:absolute;
  left:0;
  top:.45rem;
}

.quote-box{
  background:var(--brand-yellow);
  border-radius:28px;
  box-shadow:var(--shadow);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.quote-box-inner{
  padding:2rem 2rem 1.5rem;
  flex:1;
}

.quote-icon{
  display:block;
  font-size:3.5rem;
  line-height:.85;
  font-family:Georgia, serif;
  color:rgba(0,0,0,.25);
  margin-bottom:.75rem;
}

.quote-text{
  font-size:1.15rem;
  font-weight:700;
  line-height:1.45;
  color:var(--brand-black);
  margin:0 0 1.25rem;
}

.quote-attribution{
  display:flex;
  align-items:center;
  gap:.5rem;
  font-size:.875rem;
  font-weight:600;
  color:rgba(0,0,0,.55);
}

.quote-dash{ font-size:1rem }

.quote-box-stat{
  background:rgba(0,0,0,.1);
  padding:1rem 2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}

.quote-box-stat strong{
  font-size:.9rem;
  font-weight:800;
  color:var(--brand-black);
}

.quote-box-stat span{
  font-size:.8rem;
  color:rgba(0,0,0,.6);
}

.cta-band{
  background:linear-gradient(180deg, #fafafa 0%, #f2f2f2 100%);
}

.cta-grid{
  grid-template-columns:1fr auto;
  align-items:center;
}

.cta-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.9rem;
}

.section-contact{
  padding-top:4.5rem;
}

.contact-grid{
  grid-template-columns:.95fr 1.05fr;
  align-items:start;
}

.contact-details p{
  margin:.35rem 0;
}

.contact-form{
  background:var(--brand-bg);
  padding:1.5rem;
  border-radius:28px;
  border:1px solid rgba(0,0,0,.06);
  display:grid;
  gap:1rem;
}

.contact-form label{
  display:grid;
  gap:.45rem;
  font-weight:700;
}

.contact-form input,
.contact-form textarea{
  width:100%;
  border:1px solid rgba(0,0,0,.12);
  border-radius:16px;
  padding:1rem;
  font:inherit;
  background:#fff;
}

.site-footer{background:#0f0f0f;color:#fff;padding:2.5rem 0 1.25rem;margin-top:3rem}
.footer-grid{display:grid;grid-template-columns:2fr 1.5fr 1.5fr;gap:2.5rem;padding-bottom:2rem}
.footer-grid>div:first-child p{font-size:.82rem;color:#888;line-height:1.65;margin-top:.55rem;max-width:26ch}
.brand-footer{margin-bottom:.75rem}
.footer-h{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#555;margin-bottom:.65rem}
.footer-links{display:flex;flex-direction:column;gap:.4rem}
.footer-links a{font-size:.83rem;color:#888;line-height:1.5}
.footer-links a:hover{color:#fff}
.footer-contact-item{font-size:.83rem;color:#888;line-height:1.6}
.footer-contact-item a{color:#888}
.footer-contact-item a:hover{color:#fff}
.footer-hours-inline{margin-top:.55rem;font-size:.72rem;color:#555}
.footer-bottom{border-top:1px solid #1f1f1f;padding-top:1.25rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.72rem;color:#555}
.footer-bottom span{color:#555}
.footer-bottom a{color:#555}
.footer-bottom a:hover{color:#888}
.footer-legal-links{display:flex;gap:1.25rem;flex-wrap:wrap}

@media (max-width: 980px){
  .main-nav{display:none}
  .hero-grid,
  .about-grid,
  .security-grid,
  .contact-grid,
  .cta-grid,
  .trust-grid,
  .card-grid{
    grid-template-columns:1fr;
  }

  .trust-list{justify-content:flex-start}
}

@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* ── Hamburger button ── */
.hamburger{
  display:none;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  width:44px;
  height:44px;
  background:none;
  border:none;
  cursor:pointer;
  padding:0;
  border-radius:12px;
  transition:background .2s;
}

.hamburger:hover{background:rgba(0,0,0,.06)}

.hamburger span{
  display:block;
  width:22px;
  height:2px;
  background:var(--brand-black);
  border-radius:2px;
  transition:transform .3s ease, opacity .3s ease, width .3s ease;
  transform-origin:center;
}

/* Animate to X */
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0;width:0}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Mobile drawer ── */
.mobile-menu{
  position:fixed;
  inset:0 0 0 auto;
  width:min(340px, 88vw);
  background:#fff;
  z-index:200;
  padding:6rem 2rem 2.5rem;
  display:flex;
  flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  box-shadow:-8px 0 40px rgba(0,0,0,.12);
}

.mobile-menu.is-open{transform:translateX(0)}

.mobile-menu nav{
  display:flex;
  flex-direction:column;
  gap:.25rem;
  flex:1;
}

.mobile-link{
  display:block;
  font-size:1.15rem;
  font-weight:700;
  padding:.85rem 1rem;
  border-radius:14px;
  transition:background .15s;
}

.mobile-link:hover{background:var(--brand-bg)}

.mobile-cta{
  margin-top:.5rem;
  text-align:center;
  font-size:1rem;
}

/* ── Overlay ── */
.mobile-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  z-index:199;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
  backdrop-filter:blur(2px);
}

.mobile-overlay.is-open{
  opacity:1;
  pointer-events:all;
}

@media (max-width: 980px){
  .hamburger{display:flex}
}

@media (max-width: 720px){
  .header-actions .text-link{display:none}
  .nav{min-height:64px}
  .hero{padding-top:3.5rem}
  .mini-grid{grid-template-columns:1fr}
  /* Only make buttons full-width inside content areas, NOT the header */
  .hero-actions .btn,
  .cta-actions .btn,
  .section .btn:not(.ce-strip-cta){width:100%}
  .hero-actions,
  .cta-actions{display:grid}

  /* Logo — prevent stretching */
  .site-logo{
    height:40px;
    width:auto;
    max-width:160px;
    object-fit:contain;
  }

  /* WhatsApp — hidden on mobile (accessible via hamburger menu) */
  .btn-wa{display:none !important}

  /* Free IT Review — compact in header */
  .header-actions .btn-primary{
    font-size:.8rem;
    padding:.55rem .85rem;
    min-height:36px;
    width:auto;
  }
}

/* ── Shared header/nav snippet for inner pages ── */
.nav a.active{
  color:var(--brand-black);
  border-bottom:2px solid var(--brand-yellow);
  padding-bottom:2px;
}

/* ── Page hero (inner pages) ── */
.page-hero{
  padding:5rem 0 3.5rem;
  background:
    radial-gradient(circle at top right, rgba(253,206,0,.20), transparent 30%),
    linear-gradient(180deg,#fff 0%,#f9f9f9 100%);
}

.page-hero-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:2.5rem;
  align-items:center;
}

.page-card{
  background:var(--brand-dark);
  color:#fff;
  padding:1.5rem;
  border-radius:30px;
  box-shadow:var(--shadow);
}

.page-card .check-list li::before{background:var(--brand-yellow)}

/* ── Split grid (used in dark sections) ── */
.split-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2.5rem;
  align-items:start;
}

/* ── Help page ── */
.help-hero{
  padding:5rem 0 4rem;
  background:
    radial-gradient(circle at top right,rgba(253,206,0,.18),transparent 30%),
    linear-gradient(180deg,#fff 0%,#f9f9f9 100%);
  text-align:center;
}

.help-intro{
  max-width:600px;
  margin:0 auto 3rem;
}

.help-intro h1{margin-bottom:1rem}
.help-intro p{font-size:1.15rem;color:#444}

.download-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
  max-width:700px;
  margin:0 auto;
}

.download-card{
  background:#fff;
  border-radius:28px;
  padding:2.5rem 2rem;
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.06);
  text-align:center;
  transition:transform .2s;
}

.download-card:hover{transform:translateY(-3px)}

.dl-icon{
  width:72px;
  height:72px;
  border-radius:20px;
  background:var(--brand-dark);
  color:#fff;
  display:grid;
  place-items:center;
  margin:0 auto 1.25rem;
  font-size:2rem;
}

.dl-icon.mac{background:var(--brand-dark)}
.dl-icon.win{background:#0078d4}

.download-card h3{margin-bottom:.5rem}
.download-card p{color:#555;margin-bottom:1.25rem}

.download-btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.85rem 1.5rem;
  background:var(--brand-yellow);
  color:var(--brand-black);
  font-weight:800;
  border-radius:999px;
  transition:.2s;
}

.download-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(253,206,0,.4)}

.help-note{
  max-width:580px;
  margin:2.5rem auto 0;
  background:var(--brand-bg);
  border-radius:20px;
  padding:1.25rem 1.5rem;
  border:1px solid rgba(0,0,0,.06);
  font-size:.95rem;
  color:#555;
}

.help-steps{
  padding:4rem 0;
}

.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  counter-reset:steps;
}

.step-card{
  background:var(--brand-bg);
  border-radius:24px;
  padding:1.75rem 1.5rem;
  border:1px solid rgba(0,0,0,.06);
  position:relative;
}

.step-num{
  display:grid;
  place-items:center;
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--brand-yellow);
  font-weight:800;
  font-size:.9rem;
  margin-bottom:1rem;
}

/* ── About page ── */
.about-hero-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2.5rem;
  align-items:center;
}

.values-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}

.value-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;
  padding:1.5rem;
}

.value-icon{
  width:44px;
  height:44px;
  border-radius:12px;
  background:var(--brand-yellow);
  display:grid;
  place-items:center;
  font-size:1.2rem;
  margin-bottom:1rem;
}

.team-band{
  background:var(--brand-bg);
  padding:4rem 0;
}

.stat-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.5rem;
  text-align:center;
}

.stat-item strong{
  display:block;
  font-size:2.8rem;
  font-weight:800;
  line-height:1;
  margin-bottom:.4rem;
}

.stat-item p{color:var(--brand-mid);font-size:.95rem;margin:0}

/* ── Microsoft 365 page ── */
.m365-features{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.25rem;
}

.m365-card{
  display:flex;
  gap:1rem;
  background:var(--brand-bg);
  border-radius:20px;
  padding:1.25rem;
  border:1px solid rgba(0,0,0,.06);
  align-items:flex-start;
}

.m365-icon{
  width:44px;
  height:44px;
  min-width:44px;
  border-radius:12px;
  background:var(--brand-yellow);
  display:grid;
  place-items:center;
  font-size:1.1rem;
}

/* ── Responsive for inner pages ── */
@media (max-width:980px){
  .page-hero-grid,
  .split-grid,
  .about-hero-grid{grid-template-columns:1fr}
  .steps-grid,
  .values-grid,
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .m365-features{grid-template-columns:1fr}
}

@media (max-width:600px){
  .steps-grid,
  .values-grid,
  .stat-row{grid-template-columns:1fr}
}

/* ── Real logo ── */
.site-logo{
  height:52px;
  width:auto;
  display:block;
  object-fit:contain;
}

.site-logo--footer{
  height:44px;
  filter:brightness(0) invert(1);
}

/* ── WhatsApp button ── */
.btn-wa{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  min-height:42px;
  padding:.65rem 1rem;
  border-radius:999px;
  font-weight:700;
  font-size:.9rem;
  background:#25D366;
  color:#fff;
  border:none;
  transition:.2s ease;
}

.btn-wa:hover{background:#1ebe5d;transform:translateY(-1px)}

.mobile-link--wa{
  color:#fff !important;
  background:#25D366;
  border-radius:999px;
  margin-top:.5rem;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  font-size:1rem;
  padding:.75rem 1rem;
  font-weight:800;
  text-align:center;
}

.mobile-link--wa:hover{background:#1ebe5d}

/* ── Tools section ── */
.tools-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}

.tool-card{
  display:flex;
  align-items:flex-start;
  gap:1rem;
  background:var(--brand-bg);
  border:1px solid rgba(0,0,0,.06);
  border-radius:24px;
  padding:1.5rem;
  text-decoration:none;
  color:inherit;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}

.tool-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--brand-yellow);
}

.tool-icon{
  font-size:1.75rem;
  line-height:1;
  flex-shrink:0;
}

.tool-body h3{margin:0 0 .35rem;font-size:1.1rem}
.tool-body p{margin:0;color:#555;font-size:.95rem}

.tool-arrow{
  margin-left:auto;
  font-size:1.25rem;
  color:var(--brand-mid);
  flex-shrink:0;
  transition:transform .2s;
}

.tool-card:hover .tool-arrow{transform:translateX(4px)}

/* ── Tool forms ── */
.tool-form fieldset{
  border:1px solid rgba(0,0,0,.08);
  border-radius:20px;
  padding:1.25rem 1.5rem;
  margin-bottom:1rem;
}

.tool-form legend{
  font-weight:800;
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--brand-mid);
  padding:0 .5rem;
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
}

.tool-form select{
  width:100%;
  border:1px solid rgba(0,0,0,.12);
  border-radius:16px;
  padding:1rem;
  font:inherit;
  background:#fff;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23717171' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 1rem center;
  cursor:pointer;
}

.form-note{
  font-size:.875rem;
  color:var(--brand-mid);
  margin-top:.75rem;
}

/* ── Success state ── */
.success-card{
  text-align:center;
  padding:3rem 2rem;
  background:var(--brand-bg);
  border-radius:28px;
  border:1px solid rgba(0,0,0,.06);
}

.success-icon{
  width:64px;
  height:64px;
  border-radius:50%;
  background:var(--brand-yellow);
  display:grid;
  place-items:center;
  font-size:1.75rem;
  font-weight:800;
  margin:0 auto 1.25rem;
}

/* ── Responsive ── */
@media (max-width:980px){
  .tools-grid{grid-template-columns:1fr}
  .tool-card{flex-wrap:wrap}
}

@media (max-width:600px){
  .form-row{grid-template-columns:1fr}
}

/* ── Cyber Essentials strip ── */
.ce-banner{
  background:#f0f0f0;
  border-top:1px solid rgba(0,0,0,.07);
  border-bottom:1px solid rgba(0,0,0,.07);
  padding:2rem 0;
}

.ce-strip{
  display:flex;
  align-items:center;
  gap:2rem;
  flex-wrap:wrap;
}

.ce-strip-text{flex:1;min-width:200px}

.ce-strip-heading{
  font-weight:800;
  font-size:1.05rem;
  margin:0 0 .2rem;
}

.ce-strip-sub{
  font-size:.875rem;
  color:var(--brand-mid);
  margin:0;
}

.ce-strip-logos{
  display:flex;
  align-items:center;
  gap:1.25rem;
  flex-shrink:0;
}

.ce-logo{
  height:72px;
  width:auto;
  display:block;
  transition:transform .2s, opacity .2s;
}

.ce-logo:hover{transform:translateY(-2px);opacity:.85}

.ce-strip-cta{
  flex-shrink:0;
  font-size:.875rem;
  padding:.65rem 1.25rem;
  min-height:40px;
}

@media(max-width:700px){
  .ce-strip{flex-direction:column;align-items:flex-start;gap:1.25rem}
  .ce-strip-cta{width:100%;text-align:center;justify-content:center}
}

/* ── Footer legal bar (now handled by .footer-bottom) ── */

/* ── Help page card alignment fix ── */
.download-grid{
  align-items: stretch;
}

.download-card{
  display: flex;
  flex-direction: column;
  align-items: center;
}

.download-card p{
  flex: 1;
}

/* ── Testimonials section ── */
.reviews-section{
  padding: 5rem 0;
  background: var(--brand-bg);
  overflow: hidden;
}

.reviews-inner{
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 3rem;
  align-items: center;
}

.reviews-meta .section-kicker{ margin-bottom:.75rem }
.reviews-meta h2{ margin-bottom:1rem }
.reviews-meta p{ color:#444; max-width:40ch; margin-bottom:2rem }

.reviews-rating{
  display:flex;
  align-items:center;
  gap:.75rem;
  margin-bottom:2rem;
}

.reviews-stars{ color: var(--brand-yellow); font-size:1.5rem; letter-spacing:2px }

.reviews-rating-text strong{ display:block; font-size:1.1rem }
.reviews-rating-text span{ font-size:.875rem; color:var(--brand-mid) }

.reviews-cta-row{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
}

/* Masonry-style cards column */
.reviews-cards{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  align-items: start;
}

.reviews-cards .review-card:nth-child(even){
  margin-top: 1.5rem;
}

.review-card{
  background: #fff;
  border-radius: 20px;
  padding: 1.25rem 1.25rem 1rem;
  box-shadow: 0 4px 20px rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.05);
  transition: transform .2s, box-shadow .2s;
}

.review-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 8px 30px rgba(0,0,0,.1);
}

.review-stars{
  color: var(--brand-yellow);
  font-size: 1rem;
  letter-spacing: 1px;
  margin-bottom: .6rem;
}

.review-card p{
  font-size: .9rem;
  color: #333;
  line-height: 1.6;
  margin: 0 0 .75rem;
}

.review-card cite{
  font-style: normal;
  font-weight: 700;
  font-size: .875rem;
  color: var(--brand-black);
}

@media(max-width:980px){
  .reviews-inner{ grid-template-columns:1fr }
  .reviews-cards{ grid-template-columns:1fr 1fr }
  .reviews-cards .review-card:nth-child(even){ margin-top:1.5rem }
}

@media(max-width:520px){
  .reviews-cards{ grid-template-columns:1fr }
  .reviews-cards .review-card:nth-child(even){ margin-top:0 }
}

/* ── Thank you page icon ── */
.thankyou-icon{
  width:80px;
  height:80px;
  border-radius:50%;
  background:var(--brand-yellow);
  display:grid;
  place-items:center;
  font-size:2rem;
  font-weight:800;
  margin:0 auto;
}

/* ── Cookie consent banner ── */
.cookie-banner{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:999;
  background:#fff;
  border-top:2px solid var(--brand-yellow);
  box-shadow:0 -4px 30px rgba(0,0,0,.12);
  padding:1.25rem 0;
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.4,0,.2,1), opacity .4s;
  opacity:0;
}

.cookie-banner.is-visible{
  transform:translateY(0);
  opacity:1;
}

.cookie-banner.is-hiding{
  transform:translateY(100%);
  opacity:0;
}

.cookie-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 1rem;
  display:flex;
  align-items:center;
  gap:2rem;
  flex-wrap:wrap;
}

.cookie-text{ flex:1; min-width:220px }
.cookie-text strong{ display:block; margin-bottom:.25rem; font-size:1rem }
.cookie-text p{ margin:0; font-size:.875rem; color:#555 }
.cookie-text a{ color:var(--brand-black); font-weight:700; text-decoration:underline }

.cookie-actions{
  display:flex;
  gap:.75rem;
  flex-shrink:0;
}

.cookie-accept,.cookie-decline{
  min-height:42px;
  padding:.6rem 1.25rem;
  font-size:.9rem;
  cursor:pointer;
}

@media(max-width:600px){
  .cookie-inner{ flex-direction:column; align-items:flex-start; gap:1rem }
  .cookie-actions{ width:100%; justify-content:flex-end }
}

/* ── Careers page ── */
.careers-benefit-icon{
  font-size:1.75rem;
  margin-bottom:.75rem;
  display:block;
}

.job-listings{
  display:flex;
  flex-direction:column;
  gap:1.5rem;
}

.job-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;
  overflow:hidden;
}

.job-card-header{
  padding:1.75rem 1.75rem 1.25rem;
}

.job-tag{
  display:inline-block;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:var(--brand-yellow);
  color:var(--brand-black);
  border-radius:999px;
  padding:.3rem .85rem;
  margin-right:.5rem;
  margin-bottom:.75rem;
}

.job-tag--location{
  background:rgba(255,255,255,.12);
  color:#fff;
}

.job-card-header h3{
  color:#fff;
  font-size:1.4rem;
  margin:.25rem 0 .6rem;
}

.job-card-header p{ color:#c8c8c8; margin:0 }

.job-card-body{
  padding:0 1.75rem 1.25rem;
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:1.25rem;
}

.job-section{ margin:1.25rem 0 }
.job-section h4{ color:#fff; font-size:1rem; margin:0 0 .6rem; text-transform:uppercase; letter-spacing:.08em; font-size:.8rem; }
.job-section p, .job-section li{ color:#c8c8c8; font-size:.95rem; line-height:1.65 }
.job-section ul{ padding-left:1.25rem; margin:0 }
.job-section li{ margin:.35rem 0 }

.job-card-footer{
  padding:1.25rem 1.75rem;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
}

.job-toggle{
  border-color:rgba(255,255,255,.2);
  color:#fff;
  background:transparent;
  cursor:pointer;
}

.careers-nothing{
  text-align:center;
  padding:2.5rem;
  color:#c8c8c8;
  border:1px dashed rgba(255,255,255,.15);
  border-radius:20px;
  margin-top:1rem;
}

@media(max-width:600px){
  .job-card-footer{ flex-direction:column }
  .job-card-footer .btn{ text-align:center; justify-content:center }
}

/* ── Case Studies ── */
.cs-article{
  border:1px solid rgba(0,0,0,.07);
  border-radius:28px;
  overflow:hidden;
  margin-bottom:2rem;
}

.cs-header{
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:2.5rem;
  padding:2.5rem;
  background:var(--brand-dark);
  color:#fff;
  align-items:start;
}

.cs-client{
  font-size:.875rem;
  color:#aaa;
  margin:.25rem 0 1rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
}

.cs-header h2{ color:#fff; margin-bottom:.5rem }
.cs-header p:not(.cs-client){ color:#c8c8c8 }
.cs-header .section-kicker{ color:var(--brand-yellow) }

.cs-meta-panel{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  padding:1.5rem;
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.cs-meta-item{ display:flex; flex-direction:column; gap:.2rem }
.cs-meta-label{ font-size:.75rem; text-transform:uppercase; letter-spacing:.1em; color:#aaa }
.cs-meta-item strong{ font-size:.95rem; color:#fff }

/* Meta panel on light background (cs-full-section--alt) */
.cs-full-section--alt .cs-meta-panel{
  background:#fff;
  border-color:rgba(0,0,0,.12);
}
.cs-full-section--alt .cs-meta-panel .cs-meta-label{
  color:#444;
}
.cs-full-section--alt .cs-meta-panel strong{
  color:#000;
}
.cs-full-section--alt .cs-meta-label{ color:#777 }
.cs-full-section--alt .cs-meta-item strong{ color:var(--brand-black) }

/* Meta panel inside cs-client-intro (two-project case studies — no dark cs-header wrapper) */
.cs-client-intro .cs-meta-panel{
  background:#f6f6f6;
  border:1px solid rgba(0,0,0,.08);
}
.cs-client-intro .cs-meta-panel .cs-meta-label{ color:#666 }
.cs-client-intro .cs-meta-panel strong,
.cs-client-intro .cs-meta-item strong{ color:var(--brand-black) }

.cs-section{
  padding:2rem 2.5rem;
  border-top:1px solid rgba(0,0,0,.07);
}

.cs-section--alt{ background:var(--brand-bg) }

.cs-section-label{ margin-bottom:1.5rem }

.cs-pill{
  display:inline-block;
  padding:.4rem 1rem;
  border-radius:999px;
  font-size:.8rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.cs-pill--challenge{ background:#fff0f0; color:#c0392b }
.cs-pill--solution{ background:#e8f8f0; color:#1a7a46 }
.cs-pill--results{ background:#fff9e0; color:#8a6000 }

.cs-challenge-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:1rem;
  justify-content:center;
}

.cs-challenge-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  padding:1.25rem;
}

.cs-challenge-icon{ font-size:1.5rem; margin-bottom:.6rem; display:block }
.cs-challenge-card h4{ font-size:.95rem; margin:0 0 .4rem }
.cs-challenge-card p{ font-size:.875rem; color:#555; margin:0 }

.cs-solution-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
}

.cs-solution-item h4{ font-size:1rem; margin:0 0 .6rem; color:var(--brand-black) }
.cs-solution-item p{ font-size:.9rem; color:#444; margin:0 }
.cs-solution-item ul{ padding-left:1.25rem; margin:0 }
.cs-solution-item li{ font-size:.9rem; color:#444; margin:.35rem 0 }

.cs-results-intro{
  background:var(--brand-yellow);
  border-radius:16px;
  padding:1.25rem 1.5rem;
  margin-bottom:1.5rem;
}
.cs-results-intro p{ margin:0; font-weight:600 }

.cs-results-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:1rem;
  margin-bottom:1.5rem;
  justify-content:center;
}

.cs-result-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  padding:1.25rem;
}

.cs-result-icon{
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--brand-yellow);
  display:grid;
  place-items:center;
  font-weight:800;
  font-size:.85rem;
  margin-bottom:.75rem;
}

.cs-result-card h4{ font-size:.95rem; margin:0 0 .4rem }
.cs-result-card p{ font-size:.875rem; color:#555; margin:0 }

.cs-future{
  background:var(--brand-bg);
  border-radius:16px;
  padding:1.25rem 1.5rem;
  border:1px solid rgba(0,0,0,.06);
}

.cs-future h4{ font-size:.95rem; margin:0 0 .4rem }
.cs-future p{ font-size:.875rem; color:#555; margin:0 }

.cs-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  background:var(--brand-dark);
  border-radius:24px;
  padding:2rem 2.5rem;
  flex-wrap:wrap;
}

.cs-cta h3{ color:#fff; margin:0 0 .4rem }
.cs-cta p{ color:#c8c8c8; margin:0; font-size:.95rem }

/* ── FAQ section ── */
.faq-list{
  display:flex;
  flex-direction:column;
  gap:.75rem;
  margin-top:2rem;
}

.faq-item{
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  overflow:hidden;
  background:#fff;
}

.faq-q{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1.1rem 1.5rem;
  cursor:pointer;
  font-weight:700;
  font-size:1rem;
  background:none;
  border:none;
  width:100%;
  text-align:left;
  color:var(--brand-black);
  transition:background .15s;
}

.faq-q:hover{ background:var(--brand-bg) }

.faq-q[aria-expanded="true"]{ background:var(--brand-bg) }

.faq-chevron{
  flex-shrink:0;
  width:20px;
  height:20px;
  border-radius:50%;
  background:var(--brand-yellow);
  display:grid;
  place-items:center;
  font-size:.7rem;
  transition:transform .25s;
}

.faq-q[aria-expanded="true"] .faq-chevron{ transform:rotate(180deg) }

.faq-a{
  display:none;
  padding:0 1.5rem 1.25rem;
  color:#444;
  font-size:.95rem;
  line-height:1.7;
}

.faq-a.is-open{ display:block }

/* ── Review trust strip ── */
.review-trust-strip{
  background:var(--brand-bg);
  border-top:1px solid rgba(0,0,0,.07);
  border-bottom:1px solid rgba(0,0,0,.07);
  padding:1.25rem 0;
}

.review-trust-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2rem;
  flex-wrap:wrap;
  text-align:center;
}

.review-trust-label{
  font-size:.8rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--brand-mid);
  margin:0;
  width:100%;
  text-align:center;
}

.review-trust-badges{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1.5rem;
  flex-wrap:nowrap;
}

.review-badge{
  display:flex;
  align-items:center;
  gap:.75rem;
  text-decoration:none;
  color:var(--brand-black);
  padding:.5rem .85rem;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  transition:border-color .15s, box-shadow .15s;
  white-space:nowrap;
}

.review-badge:hover{
  border-color:rgba(0,0,0,.2);
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}

.tp-wordmark,.g-wordmark{
  height:18px;
  width:auto;
}

.review-badge-stars{ font-size:1rem; letter-spacing:1px }
.review-badge-score{ font-size:.8rem; font-weight:700; color:var(--brand-mid) }

.review-badge-divider{
  width:1px;
  height:32px;
  background:rgba(0,0,0,.1);
  flex-shrink:0;
}

@media(max-width:480px){
  .review-trust-badges{ gap:1rem }
  .review-badge{ padding:.45rem .65rem; gap:.5rem }
  .review-badge-score{ display:none }
}

/* ── Opening hours in footer ── */
/* .footer-hours removed — replaced by .footer-hours-inline */

/* ── Responsive ── */
@media(max-width:980px){
  .cs-header{ grid-template-columns:1fr }
  .cs-challenge-grid{ grid-template-columns:repeat(2,1fr) }
  .cs-solution-grid{ grid-template-columns:1fr }
  .cs-results-grid{ grid-template-columns:repeat(2,1fr) }
}

@media(max-width:600px){
  .cs-header,.cs-section{ padding:1.5rem }
  .cs-challenge-grid,.cs-results-grid{ grid-template-columns:1fr }
  .cs-cta{ flex-direction:column; align-items:flex-start }
  .tp-inner{ flex-direction:column; gap:1rem; text-align:center }
}

/* ── Case study index cards ── */
.cs-index-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}

.cs-index-card{
  display:flex;
  flex-direction:column;
  gap:.6rem;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:20px;
  padding:1.25rem;
  text-decoration:none;
  color:inherit;
  transition:transform .2s, border-color .2s, box-shadow .2s;
}

.cs-index-card:hover{
  transform:translateY(-3px);
  border-color:var(--brand-yellow);
  box-shadow:var(--shadow);
}

.cs-index-tag{
  font-size:.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--brand-mid);
}

.cs-index-card h3{ font-size:1rem; margin:0 }
.cs-index-card p{ font-size:.875rem; color:#555; margin:0; flex:1 }

.cs-index-pills{
  display:flex;
  flex-wrap:wrap;
  gap:.35rem;
  margin-top:.25rem;
}

.cs-index-pills span{
  background:var(--brand-bg);
  border:1px solid rgba(0,0,0,.07);
  border-radius:999px;
  padding:.2rem .65rem;
  font-size:.75rem;
  font-weight:600;
  color:#555;
}

/* ── Case study section alternating backgrounds ── */
.cs-full-section{ padding-top:0!important }
.cs-full-section--alt{ background:var(--brand-bg) }

/* ── Multi-project client intro ── */
.cs-client-intro{
  display:grid;
  grid-template-columns:1fr auto;
  gap:2rem;
  align-items:start;
  margin-bottom:2rem;
}

.cs-client-desc{ color:#555; margin-top:.5rem }

/* ── Project banner ── */
.cs-project-banner{
  background:var(--brand-dark);
  color:#fff;
  padding:1.5rem 1.75rem;
}

.cs-project-label{
  display:inline-block;
  background:var(--brand-yellow);
  color:var(--brand-black);
  font-size:.75rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.1em;
  padding:.25rem .75rem;
  border-radius:999px;
  margin-bottom:.75rem;
}

.cs-project-banner h3{ color:#fff; margin:.25rem 0 .4rem; font-size:1.25rem }
.cs-project-banner p{ color:#c8c8c8; margin:0; font-size:.9rem }

@media(max-width:980px){
  .cs-index-grid{ grid-template-columns:repeat(2,1fr) }
  .cs-client-intro{ grid-template-columns:1fr }
  .cs-client-intro .cs-meta-panel{ max-width:100% !important }
}

@media(max-width:600px){
  .cs-index-grid{ grid-template-columns:1fr }
}
/* ═══════════════════════════════════════════════════════════
   CASE STUDY GRIDS — single definitive block, no conflicts
   ═══════════════════════════════════════════════════════════ */


/* ── Careers 5-card benefits: 6-col, rows of 3+2 centred ── */
.card-grid.careers-benefits {
  grid-template-columns: repeat(6, 1fr);
}
.card-grid.careers-benefits .service-card {
  grid-column: span 2;
}
.card-grid.careers-benefits .service-card:nth-child(4) {
  grid-column: 2 / span 2;
}
.card-grid.careers-benefits .service-card:nth-child(5) {
  grid-column: 4 / span 2;
}

/* ── Tablet breakpoint ── */
@media(max-width:980px) {
  .cs-challenge-grid,
  .cs-results-grid { grid-template-columns: repeat(2, 1fr); }
  .cs-challenge-card,
  .cs-result-card { grid-column: span 1 !important; }
  /* Benefits: reset to simple 3-col at tablet */
  .card-grid.careers-benefits { grid-template-columns: repeat(3, 1fr); }
  .card-grid.careers-benefits .service-card { grid-column: span 1 !important; }
}

/* ── Mobile breakpoint ── */
@media(max-width:600px) {
  .cs-challenge-grid,
  .cs-results-grid { grid-template-columns: 1fr; }
  /* Benefits: single column on mobile */
  .card-grid.careers-benefits { grid-template-columns: 1fr; }
  .card-grid.careers-benefits .service-card { grid-column: span 1 !important; }
}

/* ── Case study index card grid ── */
.cs-index-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
/* 7 cards: rows of 4+3, centre the bottom row */
.cs-index-grid .cs-index-card:nth-child(5) { grid-column: 1 / span 1; }
.cs-index-grid .cs-index-card:nth-child(6) { grid-column: 2 / span 1; }
.cs-index-grid .cs-index-card:nth-child(7) { grid-column: 3 / span 1; }

@media(max-width:980px) {
  .cs-index-grid { grid-template-columns: repeat(2, 1fr); }
  .cs-index-grid .cs-index-card:nth-child(n) { grid-column: span 1; }
}
@media(max-width:560px) {
  .cs-index-grid { grid-template-columns: 1fr; }
}

/* ── Social follow strip (homepage) ── */
.social-strip{
  background:var(--brand-dark);
  padding:2rem 0;
}

.social-strip-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  flex-wrap:wrap;
}

.social-strip-heading{
  font-size:1.1rem;
  font-weight:800;
  color:#fff;
  margin:0 0 .2rem;
}

.social-strip-sub{
  font-size:.9rem;
  color:#aaa;
  margin:0;
}

.social-strip-buttons{
  display:flex;
  gap:.75rem;
  flex-shrink:0;
  flex-wrap:wrap;
}

.social-btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.6rem 1.25rem;
  border-radius:999px;
  font-size:.9rem;
  font-weight:700;
  text-decoration:none;
  transition:opacity .15s, transform .15s;
}

.social-btn:hover{ opacity:.85; transform:translateY(-1px) }

.social-btn--instagram{
  background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  color:#fff;
}

.social-btn--linkedin{
  background:#0077b5;
  color:#fff;
}

@media(max-width:600px){
  .social-strip-inner{ flex-direction:column; align-items:flex-start }
  .social-strip-buttons{ width:100% }
  .social-btn{ flex:1; justify-content:center }
}

/* ── Footer social icons ── */
.footer-social{display:flex;gap:.6rem;align-items:center;margin-top:.9rem}
.footer-social-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.15);color:#888;text-decoration:none;transition:color .15s,border-color .15s}
.footer-social-icon:hover{color:#fff;border-color:rgba(255,255,255,.4)}



/* ── Download card meta line ── */
.download-meta{
  font-size:.75rem;
  color:var(--brand-mid);
  margin:.6rem 0 0;
  text-align:center;
}

/* ── Power Apps callout block (on M365 page) ── */
.pa-callout{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  background:#fff;
  border:1px solid rgba(0,0,0,.07);
  border-left:4px solid var(--brand-yellow);
  border-radius:16px;
  padding:1.75rem 2rem;
  flex-wrap:wrap;
}

.pa-callout h2{
  font-size:1.35rem;
  margin:.25rem 0 .6rem;
}

.pa-callout p{
  font-size:.95rem;
  color:#555;
  margin:0;
  max-width:640px;
}

.pa-callout .btn{
  flex-shrink:0;
  white-space:nowrap;
}

@media(max-width:700px){
  .pa-callout{ flex-direction:column; align-items:flex-start }
}

/* ── Disaster Recovery page ── */
.dr-layers{
  display:flex;
  flex-direction:column;
  gap:2rem;
}

.dr-layer{
  border:1px solid rgba(0,0,0,.07);
  border-radius:24px;
  overflow:hidden;
  background:#fff;
}

.dr-layer--cloud{ border-color:rgba(0,112,204,.15) }

.dr-layer-header{
  display:flex;
  align-items:center;
  gap:1.25rem;
  padding:1.5rem 2rem;
  background:var(--brand-dark);
  border-bottom:3px solid var(--brand-yellow);
}

.dr-layer--cloud .dr-layer-header{
  border-bottom-color:#0078d4;
}

.dr-layer-icon{
  font-size:2rem;
  flex-shrink:0;
}

.dr-layer-header h3{
  color:#fff;
  margin:.15rem 0 .25rem;
  font-size:1.3rem;
}

.dr-layer-sub{
  color:#aaa;
  font-size:.875rem;
  margin:0;
}

.dr-feature-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
}

.dr-feature{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  padding:1.25rem 1.5rem;
  border-right:1px solid rgba(0,0,0,.05);
  border-bottom:1px solid rgba(0,0,0,.05);
}

.dr-feature:nth-child(3n){ border-right:none }
.dr-feature:nth-child(n+4){ border-bottom:none }

.dr-feature-icon{
  font-size:1.3rem;
  flex-shrink:0;
  margin-top:.1rem;
}

.dr-feature strong{
  display:block;
  font-size:.9rem;
  margin-bottom:.3rem;
  color:var(--brand-black);
}

.dr-feature p{
  font-size:.825rem;
  color:#555;
  margin:0;
  line-height:1.5;
}

@media(max-width:820px){
  .dr-feature-grid{ grid-template-columns:repeat(2,1fr) }
  .dr-feature:nth-child(3n){ border-right:1px solid rgba(0,0,0,.05) }
  .dr-feature:nth-child(2n){ border-right:none }
  .dr-feature:nth-child(n+4){ border-bottom:1px solid rgba(0,0,0,.05) }
  .dr-feature:nth-last-child(-n+2){ border-bottom:none }
  .dr-layer-header{ padding:1.25rem 1.5rem }
}

@media(max-width:560px){
  .dr-feature-grid{ grid-template-columns:1fr }
  .dr-feature{ border-right:none !important }
  .dr-feature:not(:last-child){ border-bottom:1px solid rgba(0,0,0,.05) !important }
  .dr-feature:last-child{ border-bottom:none !important }
}

/* ── Careers page mobile fixes ── */
@media (max-width: 600px) {

  /* Hero — reduce top padding, hide the dark aside card on mobile (info is duplicated in the hero points) */
  .page-hero { padding: 2.5rem 0 2rem; }
  .page-hero .page-card { display: none; }

  /* Hero actions — stack buttons vertically */
  .page-hero .hero-actions {
    flex-direction: column;
    align-items: flex-start;
    gap: .6rem;
  }
  .page-hero .hero-actions .btn { width: 100%; justify-content: center; }

  /* Hero points — tighter on mobile */
  .hero-points { margin-top: 1rem; }

  /* Job card — tighter padding */
  .job-card-header { padding: 1.25rem 1.25rem .9rem; }
  .job-card-body { padding: 0 1.25rem 1rem; }
  .job-card-footer { padding: 1rem 1.25rem; gap: .6rem; }
  .job-card-header h3 { font-size: 1.15rem; }

  /* Job tags — smaller on mobile */
  .job-tag { font-size: .7rem; padding: .2rem .65rem; margin-bottom: .5rem; }

  /* Form fieldsets — less padding */
  .tool-form fieldset { padding: 1rem 1rem; }
  .tool-form .form-note { font-size: .825rem; }

  /* Benefits grid section head */
  .section-head h2 { font-size: 1.5rem; }
}

@media (max-width: 400px) {
  .job-card-header { padding: 1rem 1rem .75rem; }
  .job-card-body { padding: 0 1rem .75rem; }
  .job-card-footer { padding: .75rem 1rem; }
}

/* ── ce-strip inner container (was missing — fixes broken layout on managed-it-support.html) ── */
.ce-strip-inner{
  display:flex;
  align-items:center;
  gap:2rem;
  flex-wrap:wrap;
  padding:1.5rem 2rem;
  background:var(--brand-bg);
  border-radius:var(--radius);
}
.ce-strip-inner .ce-strip-text{flex:1;min-width:240px}
.ce-strip-title{
  font-weight:800;
  font-size:1.05rem;
  margin:0 0 .35rem;
  color:var(--brand-black);
}
.ce-strip-cta{white-space:nowrap}

@media (max-width:640px){
  .ce-strip-inner{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem}
  .ce-strip-cta{width:100%;text-align:center;justify-content:center}
}

/* ── Explicit column variants for cs-index-grid (responsive) ── */
.cs-index-grid--2col{
  grid-template-columns:repeat(2,1fr);
}
.cs-index-grid--3col{
  grid-template-columns:repeat(3,1fr);
}
.cs-index-grid--1col{
  grid-template-columns:1fr;
}

@media(max-width:900px){
  .cs-index-grid--3col{
    grid-template-columns:repeat(2,1fr);
  }
}
@media(max-width:640px){
  .cs-index-grid--2col,
  .cs-index-grid--3col{
    grid-template-columns:1fr;
  }
}

/* ── Accessibility: WCAG 2.4.7 Focus Visible ──
   Visible focus indicators for keyboard users. Uses :focus-visible so mouse
   clicks don't show outlines (better visual experience for sighted users)
   while keyboard navigation still gets clear focus rings. */

:focus-visible {
  outline: 3px solid var(--brand-yellow);
  outline-offset: 2px;
  border-radius: 4px;
}

/* Brand-yellow buttons need a darker outline to be visible against the yellow */
.btn-primary:focus-visible {
  outline: 3px solid var(--brand-black);
  outline-offset: 2px;
}

/* Form inputs - subtle yellow ring inside the field */
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 3px solid var(--brand-yellow);
  outline-offset: 0;
}

/* Skip-link target - keep things tidy if/when added */
a.skip-link:focus,
a.skip-link:focus-visible {
  position: fixed;
  top: 1rem;
  left: 1rem;
  z-index: 9999;
  padding: .75rem 1rem;
  background: var(--brand-yellow);
  color: var(--brand-black);
  font-weight: 800;
  text-decoration: none;
  border-radius: 6px;
}

/* Honour user OS preference for reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}
