/* B-Sharp AI — styles.css */
*{box-sizing:border-box;margin:0;padding:0}
html{scrollbar-gutter:stable;overflow-y:scroll}
:root{
  --r:#C00000;
  --bg:#121212;
  --w:#fff;
  --hf:'Plus Jakarta Sans',sans-serif;
  --bf:'DM Sans',sans-serif;
  --nh:72px;
}
body{font-family:var(--bf);background:var(--bg);color:#1a1a1a}

/* ── NAV ── */
nav#mainnav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:var(--bg);height:var(--nh);
  display:flex;align-items:center;
  padding:0 48px;border-bottom:1px solid #222;
}
nav#mainnav img.logo{height:56px;width:auto;display:block;mix-blend-mode:screen}
nav#mainnav a.logo-link:hover img.logo,nav#mainnav a:first-child:hover img.logo{transform:scale(1.15);transition:transform .2s}
.nl{margin-left:auto;display:flex;align-items:center;gap:26px}
.nl a{
  color:var(--w);text-decoration:none;
  font-family:var(--hf);font-size:15px;font-weight:500;
  cursor:pointer;white-space:nowrap;
}
.nl a:hover,.nl a:active{color:var(--r);text-decoration:underline}
.nl a.act{color:var(--w)}
.cbtn{background:var(--r)!important;padding:8px 20px;border-radius:5px;font-weight:600!important;min-height:44px;display:inline-flex!important;align-items:center;justify-content:center}
.hamburger{display:none}
.cbtn:hover,.cbtn:active{background:#a00000!important;color:var(--w)!important}

/* ── PAGE HEADER ── */
#page-header{
  position:fixed;top:var(--nh);left:0;right:0;z-index:100;
  background:var(--bg);border-bottom:1px solid #1e1e1e;
  display:flex;align-items:center;justify-content:flex-end;
  padding:16px 48px;
}
.ph1{
  font-family:var(--hf);
  font-size:clamp(30px,4vw,58px);
  font-weight:800;color:var(--w);line-height:1.05;
}
.sub{
  margin-top:7px;font-family:var(--hf);
  font-size:15px;color:#aaa;line-height:1.55;
}

/* ── HOME ── */
body.home{display:flex;flex-direction:column;height:100vh;overflow:hidden}
body.home>main{flex:1;display:flex;flex-direction:column}
.home-hero{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:0 48px;
  margin-top:var(--nh);
}
.home-h1{
  font-family:var(--hf);
  font-size:clamp(46px,5.8vw,78px);
  font-weight:800;color:var(--w);line-height:1.05;
}
.home-h1.red{color:var(--r)}
.btn-primary{
  background:var(--r);color:var(--w);
  padding:13px 30px;border-radius:6px;
  font-family:var(--hf);font-size:16px;font-weight:600;
  text-decoration:none;display:inline-block;
  text-align:center;min-height:44px;
}
.btn-primary:hover,.btn-primary:active{background:#a00000;color:var(--w);text-decoration:underline}
.btn-outline{
  background:transparent;color:var(--w);
  padding:13px 30px;border-radius:6px;
  border:1px solid rgba(255,255,255,0.35);
  font-family:var(--hf);font-size:16px;font-weight:500;
  text-decoration:none;display:inline-block;
  text-align:center;min-height:44px;
}
.btn-outline:hover,.btn-outline:active{border-color:var(--r);color:var(--r);text-decoration:underline}

/* ── CONTENT ── */
.scroll-content{background:var(--w);padding-top:0}
.ca{padding:40px 48px}
.ci{max-width:1160px;margin:0 auto}

/* ── FOOTER ── */
footer{
  background:var(--bg);padding:15px 48px;
  display:flex;align-items:center;
  justify-content:space-between;
  border-top:1px solid #222;gap:16px;flex-shrink:0;
  position:relative;
}
.copy{font-size:13px;color:#7e7e7e;font-family:var(--hf);white-space:nowrap}
.flegal{
  display:flex;gap:20px;
  position:absolute;left:0;right:0;
  justify-content:center;
  pointer-events:none;
}
.flegal a{pointer-events:auto;color:#aaa;text-decoration:none;font-family:var(--hf);font-size:13px;min-height:44px;display:inline-flex;align-items:center;padding:0 4px}
.flegal a:hover,.flegal a:active{color:var(--r);text-decoration:underline}
.ficons{display:flex;gap:20px;align-items:center}
.ficons a{color:#888;display:flex;text-decoration:none;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.ficons svg{fill:currentColor}
.ficons a:hover,.ficons a:active{color:var(--r);transform:scale(1.15)}

/* ── TYPOGRAPHY ── */
h2{font-family:var(--hf);font-size:23px;font-weight:700;margin:28px 0 9px;color:#111}
h3{font-family:var(--hf);font-size:17px;font-weight:600;margin:18px 0 5px;color:#111}
p{font-size:16px;line-height:1.8;margin-bottom:13px;color:#222}
ul{padding-left:20px;margin-bottom:13px}
li{font-size:16px;line-height:1.8;color:#222;margin-bottom:3px}

/* ── SERVICE CARDS ── */
.scard{border:1px solid #e0e0e0;border-radius:10px;padding:26px 26px 22px;margin-bottom:18px;transition:border-color .2s,box-shadow .2s}
.scard:hover{border-color:var(--r);box-shadow:0 2px 12px rgba(192,0,0,0.08)}
.snum{
  display:inline-block;background:#fce8e8;color:var(--r);
  font-family:var(--hf);font-weight:700;font-size:13px;
  padding:3px 12px;border-radius:20px;margin-bottom:8px;
  border:1px solid var(--r);
}
.dl{
  font-family:var(--hf);font-size:11px;font-weight:700;
  letter-spacing:.1em;color:#767676;text-transform:uppercase;
  margin:14px 0 5px;
}
.who{font-size:15px;color:#444;font-style:italic;line-height:1.75;margin-bottom:0}

/* ── ABOUT ── */
.igrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:10px 0 22px}
.icell{
  background:#f5f5f5;border-radius:8px;padding:13px 11px;
  font-family:var(--hf);font-size:14px;font-weight:600;
  text-align:center;color:#222;
  display:flex;align-items:center;justify-content:center;min-height:60px;
}
.rbox{background:#f7f7f7;border-radius:10px;padding:20px 24px;margin:10px 0}

/* ── FOUNDER ── */
.rl{width:48px;height:3px;background:var(--r);margin:20px 0}
.photo-float{
  float:left;width:190px;height:210px;
  background:#e8e8e8;border-radius:10px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  color:#aaa;font-size:13px;text-align:center;gap:8px;
  margin:0 32px 16px 0;
}
.bio-block::after{content:"";display:table;clear:both}
.founder-photo-link{display:block;float:left;margin:0 32px 16px 0;border-radius:10px;transition:transform .2s}
.founder-photo-link:hover,.founder-photo-link:active{transform:scale(1.15)}
.cred-t{width:100%;border-collapse:collapse;margin-top:22px}
.cred-t tr{border-bottom:1px solid #eee}
.cred-t td{padding:9px 8px;font-size:15px;vertical-align:top}
.cred-t td:first-child{
  font-family:var(--hf);font-size:12px;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  color:var(--r);width:140px;white-space:nowrap;
}

/* ── ENGAGEMENTS ── */
.ccard{border:1px solid #e0e0e0;border-radius:10px;padding:26px;margin-bottom:18px;transition:border-color .2s,box-shadow .2s}
.ccard:hover{border-color:var(--r);box-shadow:0 2px 12px rgba(192,0,0,0.08)}
.cbadge{
  display:inline-block;background:#fce8e8;color:var(--r);
  font-family:var(--hf);font-size:12px;font-weight:700;
  padding:3px 14px;border-radius:20px;margin-bottom:14px;
  border:1px solid var(--r);
}
.clbl{
  font-family:var(--hf);font-size:11px;font-weight:700;
  letter-spacing:.1em;color:#767676;text-transform:uppercase;
  margin:14px 0 4px;
}

/* ── INSIGHTS ── */
.fn{border-top:1px solid #eee;margin-top:28px;padding-top:14px}
.fn p{font-size:13px;color:#666;margin-bottom:6px}
a.sl{color:var(--r);text-decoration:none;font-weight:500}
a.sl:hover,a.sl:active{text-decoration:underline}

/* ── CONTACT ── */
body.contact-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}
body.contact-page .scroll-content{
  flex:1;background:var(--bg);
  display:flex;flex-direction:column;
  padding:0 48px;
  overflow-y:auto;
}
body.contact-page p{color:#ccc}
.cgrid{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:44px;align-items:center;
  max-width:1160px;margin:auto;width:100%;
}
.cleft h2{
  font-family:var(--hf);font-size:26px;font-weight:700;
  color:var(--w);margin:0 0 10px;
}
.cicons{display:flex;gap:22px;margin-top:16px}
.cicons a{color:#888;display:flex;text-decoration:none;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.cicons svg{fill:currentColor}
.cicons a:hover,.cicons a:active{color:var(--r);transform:scale(1.15)}
.fcard{background:#1e1e1e;border-radius:10px;padding:16px 18px}
.fgrp{margin-bottom:9px}
.fgrp label{
  display:block;font-family:var(--hf);font-size:12px;
  font-weight:500;color:#bbb;margin-bottom:4px;
}
.fgrp input,.fgrp textarea{
  width:100%;background:#2a2a2a;
  border:1px solid #333;border-radius:5px;
  padding:7px 11px;color:var(--w);
  font-size:14px;font-family:var(--bf);
  min-height:44px;
}
.fgrp input:focus,.fgrp textarea:focus{border-color:#555;outline:2px solid #aaaaaa;outline-offset:1px}
.fgrp textarea{height:50px;resize:none}
.fcons{display:flex;align-items:center;gap:8px;margin-bottom:9px;min-height:44px}
.fcons input[type=checkbox]{accent-color:var(--r);width:18px;height:18px;flex-shrink:0;cursor:pointer}
.fcons label{font-size:12px;color:#888;line-height:1.4}
.fcons a{color:#fff;text-decoration:underline}.fcons a:hover,.fcons a:active{color:var(--r)}
.sbtn{
  width:100%;background:var(--r);color:var(--w);
  border:none;border-radius:5px;padding:7px;
  font-family:var(--hf);font-size:14px;font-weight:600;cursor:pointer;
  min-height:44px;
}
.sbtn:hover,.sbtn:active{background:#a00000;text-decoration:underline}
.form-msg{
  display:none;margin-top:10px;padding:10px;
  border-radius:5px;font-size:13px;font-family:var(--hf);
  text-align:center;
}
.form-msg.ok{background:#1a3a1a;color:#6fcf6f}
.form-msg.err{background:#3a1a1a;color:#cf6f6f}

/* ── LEGAL ── */
.lc h2{font-size:18px;margin:24px 0 7px}
.lc p,.lc li{font-size:15px;line-height:1.75;color:#333}
.lmeta{font-size:14px;color:#666;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #eee}

/* ── ANCHOR SCROLL OFFSET (fixed nav + header) ── */
.scard{scroll-margin-top:180px}

/* ── MOBILE RESPONSIVE ───────────────────────────────────────────────────────────────── */
/* ── ANCHOR SCROLL OFFSET ── */
.scard{scroll-margin-top:180px}

/* ── MOBILE ───────────────────────────────────────────────────────────────────── */

/* Hide <br> in subtitles on mobile — let text reflow naturally */
@media(max-width:768px){
  .sub br{display:none}

.founder-photo-link{margin-right:20px!important}
}

@media(max-width:768px){

  /* NAV */
  nav#mainnav{padding:0 16px}
  nav#mainnav img.logo{height:44px}

  /* Hamburger button — shown on mobile */
  .hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;
    min-width:44px;min-height:44px;cursor:pointer;margin-left:auto;background:none;
    border:none;padding:0;flex-shrink:0;gap:5px}
  .hamburger span{display:block;width:24px;height:2px;background:#fff;
    border-radius:2px;transition:all .25s}
  .hamburger.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .hamburger.active span:nth-child(2){opacity:0}
  .hamburger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

  /* Nav dropdown */
  .nl{display:none;flex-direction:column;align-items:stretch;
    gap:0;position:fixed;top:72px;left:0;right:0;
    background:#121212;padding:8px 0 16px;
    border-bottom:1px solid #333;z-index:150}
  .nl.open{display:flex}
  .nl a{padding:14px 20px;width:100%;font-size:16px;
    border-bottom:1px solid #1e1e1e;white-space:normal;
    box-sizing:border-box}
  /* Contact button — full width, no overflow */
  .nl .cbtn{
    margin:12px 16px 0;
    width:calc(100% - 32px);
    text-align:center;
    border-radius:5px;
    padding:12px 16px!important;
    box-sizing:border-box;
  }

  /* PAGE HEADER */
  #page-header{padding:12px 16px}
  .ph1{font-size:clamp(24px,7vw,38px)}
  .sub{font-size:13px;text-align:right}

  /* CONTENT */
  .ca{padding:24px 16px}

  /* HOME — allow scroll on small screens, don't clip footer */
  body.home{height:auto;min-height:100vh;overflow-y:auto}
  .home-hero{padding:0 16px;margin-top:72px}
  .home-h1{font-size:clamp(34px,9vw,52px)}
  .home-ctas{flex-direction:column;align-items:stretch!important;width:100%}
  .home-ctas .btn-primary,.home-ctas .btn-outline{width:100%;margin-bottom:10px}
  /* Stack home CTAs vertically and make full width */
  .home-hero .btn-primary,
  .home-hero .btn-outline{
    display:block;width:100%;margin-bottom:12px;
  }
  .home-hero div[style*="display:flex"]{
    flex-direction:column;align-items:stretch;
  }

  /* FOOTER */
  footer{flex-direction:column;align-items:center;
    padding:16px;gap:10px;text-align:center}
  .flegal{position:static;transform:none;justify-content:center}
  .ficons{justify-content:center}

  /* ABOUT — industry grid 2 cols */
  .igrid{grid-template-columns:repeat(2,1fr)}

  /* CONTACT — allow scrolling on mobile, don't fix height */
  body.contact-page{height:auto;min-height:100vh;overflow-y:auto}
  body.contact-page .scroll-content{
    flex:none;display:block;
    padding-left:16px;padding-right:16px;padding-bottom:20px;
    /* padding-top set by JS offset script */
  }
  .cgrid{grid-template-columns:1fr;gap:24px}
  /* padding-top set by JS offset script to clear fixed nav+header */

  /* SERVICE / ENGAGEMENT CARDS */
  .scard{padding:18px 14px}
  .ccard{padding:18px 14px}

  /* FOUNDER — float to stack */
  .photo-float{float:none;width:100%;height:180px;margin:0 0 18px 0}

  /* CREDENTIALS TABLE */
  .cred-t td:first-child{white-space:normal;width:90px}
  .cred-t td{font-size:14px}
}

@media(max-width:480px){
  .igrid{grid-template-columns:1fr}
  .home-h1{font-size:clamp(30px,10vw,44px)}
}

/* -- COOKIE CONSENT BANNER -- */
#cookie-banner{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:500;
  background:#1a1a1a;border-top:1px solid #2e2e2e;outline:none;
}
#cookie-banner-inner{
  max-width:1160px;margin:0 auto;
  padding:14px 48px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  flex-wrap:wrap;
}
#cookie-banner p{
  font-family:var(--hf);font-size:13px;color:#aaa;
  margin:0;line-height:1.5;flex:1;min-width:200px;
}
#cookie-banner p a{color:var(--r);text-decoration:none}
#cookie-banner p a:hover{text-decoration:underline}
#cookie-btns{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
#cookie-reject-all,#cookie-manage{
  background:transparent;color:var(--w);
  border:1px solid rgba(255,255,255,0.35);border-radius:5px;
  padding:7px 18px;font-family:var(--hf);font-size:13px;font-weight:500;
  cursor:pointer;min-height:44px;
}
#cookie-reject-all:hover,#cookie-manage:hover{border-color:var(--r);color:var(--r);text-decoration:underline}
#cookie-accept-all{
  background:var(--r);color:#fff;border:none;
  border-radius:5px;padding:7px 18px;
  font-family:var(--hf);font-size:13px;font-weight:600;cursor:pointer;min-height:44px;
}
#cookie-accept-all:hover{background:#a00000;text-decoration:underline}
#cookie-prefs{
  display:none;width:100%;
  padding:12px 0 4px;border-top:1px solid #2e2e2e;margin-top:10px;
}
.cookie-pref-row{
  display:flex;align-items:center;gap:12px;
  padding:6px 0;min-height:44px;
}
.cookie-pref-row input[type="checkbox"]{
  accent-color:var(--r);width:18px;height:18px;flex-shrink:0;cursor:pointer;
}
.cookie-pref-row input[disabled]{cursor:default;opacity:.6}
.cookie-pref-row label{
  color:#ccc;font-family:var(--hf);font-size:13px;
  flex:1;cursor:pointer;line-height:1.4;
}
.cookie-pref-desc{display:block;color:#888;font-size:12px;margin-top:1px}
#cookie-save{
  background:var(--r);color:#fff;border:none;
  border-radius:5px;padding:7px 18px;width:100%;margin-top:10px;
  font-family:var(--hf);font-size:13px;font-weight:600;cursor:pointer;min-height:44px;
}
#cookie-save:hover{background:#a00000;text-decoration:underline}
#cookie-settings-link{pointer-events:auto;color:#aaa;text-decoration:none;font-family:var(--hf);font-size:13px;min-height:44px;display:inline-flex;align-items:center;padding:0 4px}
#cookie-settings-link:hover,#cookie-settings-link:active{color:var(--r);text-decoration:underline}
@media(max-width:768px){
  #cookie-banner-inner{padding:14px 16px;flex-direction:column;align-items:stretch;gap:12px}
  #cookie-btns{flex-direction:column;width:100%}
  #cookie-reject-all,#cookie-manage,#cookie-accept-all{width:100%}
}

/* ── WCAG 2.2 SC 2.4.13 FOCUS APPEARANCE ── */
/* Rule 1: Global baseline — dark bg elements (nav, footer, icons, svc-bar etc) */
:focus-visible{
  outline:2px solid #aaaaaa;
  outline-offset:2px;
}
/* Rule 2: Red background buttons — white ring */
.btn-primary:focus-visible,
.cbtn:focus-visible,
.sbtn:focus-visible,
#cookie-accept:focus-visible,
#cookie-accept-all:focus-visible,
#cookie-save:focus-visible{
  outline:2px solid #ffffff;
  outline-offset:2px;
}
/* Rule 3: White content area links — brand red ring */
.scroll-content a:focus-visible{
  outline:2px solid #C00000;
  outline-offset:2px;
}

/* ── HOME HERO H1 RESET ── */
.home-hero h1{margin:0;font-size:inherit;font-weight:inherit;font-family:inherit;line-height:inherit}

/* ── PARTNER CARDS ── */
.pcard{border:1px solid #e0e0e0;border-radius:10px;padding:26px;margin-bottom:18px;transition:border-color .2s,box-shadow .2s}
.pcard:hover{border-color:var(--r);box-shadow:0 2px 12px rgba(192,0,0,0.08)}
.pcard-inner{display:flex;gap:24px;align-items:flex-start}
.plogo{flex-shrink:0;width:130px;display:flex;flex-direction:column;align-items:center}
.plogo-link{display:block;border-radius:8px;}
.plogo-link:hover .plogo-box,.plogo-link:active .plogo-box{transform:scale(1.15);transition:transform .2s}
.plogo-box{width:120px;height:70px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:10px;background:#fce8e8;border:1px solid #C00000;transition:transform .2s;}
.pbody{flex:1;min-width:0}
.pname{font-family:var(--hf);font-size:18px;font-weight:700;color:#111;margin-bottom:3px}
.ptag{font-family:var(--hf);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--r);margin-bottom:10px}
.pdesc{font-size:16px;line-height:1.8;color:#222;margin-bottom:0}
.pdesc ul{padding-left:20px;margin-top:10px;margin-bottom:0}
.pdesc li{font-size:16px;line-height:1.8;color:#222;margin-bottom:8px}
.prod-section{margin-top:18px}
.prod-label{font-family:var(--hf);font-size:11px;font-weight:700;letter-spacing:.1em;color:#767676;text-transform:uppercase;margin:14px 0 10px}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.prod-card{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#fafafa}
.prod-img{display:flex;align-items:center;justify-content:center;height:170px;padding:12px;background:#f5f5f5}
.prod-img-link{display:flex;align-items:center;justify-content:center;width:100%;height:100%;}
.prod-img-link img{max-width:100%;max-height:146px;object-fit:contain;display:block;transition:transform .2s}
.prod-img-link:hover img,.prod-img-link:active img{transform:scale(1.15)}
.prod-name{padding:8px 12px 3px;font-family:var(--hf);font-size:13px;font-weight:700}
.prod-name a{color:#111;text-decoration:none}
.prod-name a:hover,.prod-name a:active{color:var(--r);text-decoration:underline}
.prod-desc{padding:0 12px 10px;font-size:14px;color:#555;line-height:1.65}
.pcta{margin-top:28px;padding:28px 32px;background:#f7f7f7;border-radius:10px;text-align:center}
.pcta p{font-family:var(--hf);font-size:17px;font-weight:600;color:#111;margin-bottom:16px}
.pcta-sub{font-size:14px;color:#666;margin-top:14px;margin-bottom:0}
.pcta-sub a{color:var(--r);text-decoration:none;font-weight:500}
.pcta-sub a:hover,.pcta-sub a:active{text-decoration:underline}
/* Partner cards — mobile */
@media(max-width:640px){
  .pcard-inner{flex-direction:column;align-items:flex-start;gap:14px}
  .plogo{flex-direction:row;width:auto;align-items:center;gap:12px}
  .pcard{padding:18px 14px}
  .prod-grid{grid-template-columns:1fr}
  .pcta{padding:20px 16px}
}

/* Skip to main content — WCAG 2.4.1 */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 4px;
  z-index: 9999;
  background: #C00000;
  color: #fff;
  padding: 8px 16px;
  font-weight: 700;
  border-radius: 4px;
}
.skip-link:focus {
  left: 8px;
}

/* Service bar link styles (moved from inline, index.html) */
.svc-bar a {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
}
.svc-bar a:hover,
.svc-bar a:active {
  color: var(--r) !important;
  text-decoration: underline !important;
}

/* -- INSIGHT INDEX CARDS -- */
a.icard-link{text-decoration:none;display:block;margin-bottom:18px}
.icard{border:1px solid #e0e0e0;border-radius:10px;padding:26px;transition:border-color .2s,box-shadow .2s}
.icard:hover{border-color:var(--r);box-shadow:0 2px 12px rgba(192,0,0,0.08)}
.icard-date{font-family:var(--hf);font-size:13px;color:#888;margin-bottom:6px}
.icard-title{font-family:var(--hf);font-size:22px;font-weight:700;color:#111;margin:0 0 8px;line-height:1.3}
.icard-desc{font-size:15px;color:#444;line-height:1.7;margin-bottom:10px}
.icard-read{font-family:var(--hf);font-size:14px;font-weight:600;color:var(--r)}
.icard:hover .icard-read{text-decoration:underline}
