.xbca-agent{--xbca-brand:#f97316;--xbca-brand-dark:#c2410c;--xbca-text:#111827;--xbca-muted:#6b7280;--xbca-border:#e5e7eb;--xbca-soft:#f8fafc;--xbca-radius:24px;--xbca-button-radius:999px;--xbca-shadow:0 18px 50px rgba(15,23,42,.18);background:#fff;color:var(--xbca-text);border-radius:var(--xbca-radius);box-shadow:var(--xbca-shadow);border:1px solid rgba(15,23,42,.08);overflow:hidden;max-width:520px;margin:0 auto;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}.xbca-agent-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,var(--xbca-brand),var(--xbca-brand-dark,#111827));color:#fff;padding:18px 20px}.xbca-agent-header strong{display:block;font-size:1.05rem}.xbca-agent-header span:not(.xbca-status-dot){display:block;font-size:.85rem;opacity:.9}.xbca-status-dot{width:12px;height:12px;background:#22c55e;border-radius:99px;box-shadow:0 0 0 6px rgba(34,197,94,.18)}.xbca-agent-log{height:360px;overflow:auto;padding:18px;background:var(--xbca-soft);display:flex;flex-direction:column;gap:12px}.xbca-message{max-width:86%;padding:12px 14px;border-radius:16px;font-size:.96rem;line-height:1.45}.xbca-message.bot{background:#fff;border:1px solid var(--xbca-border);border-bottom-left-radius:4px;align-self:flex-start}.xbca-message.user{background:var(--xbca-brand);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.xbca-agent-form{display:flex;gap:10px;padding:14px;background:#fff;border-top:1px solid var(--xbca-border)}.xbca-agent-form input{flex:1;border:1px solid #d1d5db;border-radius:var(--xbca-button-radius);padding:12px 14px;font-size:1rem}.xbca-agent-form button,.xbca-submit{border:0;background:var(--xbca-brand);color:#fff;border-radius:var(--xbca-button-radius);padding:12px 18px;font-weight:800;cursor:pointer}.xbca-agent-form button:hover,.xbca-submit:hover{background:var(--xbca-brand-dark,var(--xbca-brand))}.xbca-built-by{display:block;text-align:center;font-size:.78rem;color:var(--xbca-muted);text-decoration:none;padding:0 0 12px}.xbca-hidden-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important}.xbca-quote-form{background:#fff;border:1px solid var(--xbca-border,#e5e7eb);border-radius:var(--xbca-radius,22px);padding:24px;box-shadow:var(--xbca-shadow,0 12px 35px rgba(15,23,42,.08))}.xbca-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.xbca-quote-form label{display:grid;gap:7px;font-weight:800}.xbca-quote-form input,.xbca-quote-form select,.xbca-quote-form textarea{width:100%;border:1px solid #d1d5db;border-radius:12px;padding:12px 13px;font:inherit}.xbca-form-response{margin-top:14px;font-weight:800}.xbca-services-grid,.xbca-project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.xbca-service-card,.xbca-project-card,.xbca-testimonial,.xbca-faq-list details{background:#fff;border:1px solid var(--xbca-border,#e5e7eb);border-radius:var(--xbca-radius,20px);box-shadow:var(--xbca-shadow,0 10px 28px rgba(15,23,42,.06));overflow:hidden}.xbca-service-card-body{padding:22px}.xbca-service-card h3,.xbca-project-card h3{margin-top:0}.xbca-service-card h3 a,.xbca-project-card h3 a{text-decoration:none;color:inherit}.xbca-card-link,.xbca-service-card a.xbca-card-link,.xbca-project-card a{color:var(--xbca-brand,#f97316);font-weight:900;text-decoration:none}.xbca-service-image img,.xbca-project-card img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}.xbca-project-card{padding:0}.xbca-project-card>div{padding:18px}.xbca-testimonial-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.xbca-testimonial{margin:0;padding:22px}.xbca-testimonial cite{display:block;margin-top:12px;font-weight:900}.xbca-service-areas{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;list-style:none;padding:0}.xbca-service-areas li{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;font-weight:800}.xbca-faq-list{display:grid;gap:12px}.xbca-faq-list details{padding:22px}.xbca-faq-list summary{font-weight:900;cursor:pointer}.xbca-faq-list p{margin-bottom:0}@media(max-width:900px){.xbca-services-grid,.xbca-project-grid,.xbca-testimonial-grid,.xbca-service-areas{grid-template-columns:1fr 1fr}.xbca-form-grid{grid-template-columns:1fr}}@media(max-width:600px){.xbca-services-grid,.xbca-project-grid,.xbca-testimonial-grid,.xbca-service-areas{grid-template-columns:1fr}.xbca-agent-log{height:330px}.xbca-agent-form{display:grid}.xbca-agent-form button{width:100%}}
.xbca-agent-locked{padding:22px;border:1px solid var(--xbct-border,#e5e7eb);border-radius:var(--xbct-radius,18px);background:var(--xbct-soft,#f8fafc);color:var(--xbct-dark,#111827);box-shadow:var(--xbct-shadow,0 10px 30px rgba(15,23,42,.08));max-width:720px}.xbca-agent-locked strong{display:block;font-size:1.1rem;margin-bottom:6px}.xbca-quote-form select{width:100%}.xbca-form-response{margin-top:12px;font-weight:700;color:var(--xbca-brand,var(--xbct-primary,#f97316))}

/* v1.6.0 portal cards */
.xbca-portal-box{border:1px solid var(--xbct-border,#e5e7eb);border-radius:var(--xbct-radius,22px);padding:28px;background:#fff;box-shadow:var(--xbct-shadow,0 12px 35px rgba(15,23,42,.08));margin:24px 0}.xbca-portal-section{margin:22px 0}.xbca-portal-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.xbca-portal-card{border:1px solid var(--xbct-border,#e5e7eb);border-radius:18px;padding:18px;background:var(--xbct-soft,#f8fafc)}.xbca-portal-card strong{color:var(--xbct-primary,#f97316)}

/* v1.7.0 client/vendor portals */
.xbca-portal-box { background:#fff; border:1px solid var(--xbct-border,#e5e7eb); border-radius:22px; padding:clamp(18px,3vw,34px); box-shadow:0 14px 40px rgba(15,23,42,.08); margin:24px 0; }
.xbca-login-box form p { margin-bottom:14px; }
.xbca-login-box input[type="text"], .xbca-login-box input[type="password"], .xbca-sign-form input { width:100%; border:1px solid #d1d5db; border-radius:12px; padding:12px 14px; }
.xbca-login-box input[type="submit"], .xbca-sign-form button { border:0; border-radius:999px; padding:12px 18px; background:var(--xbct-primary,#f97316); color:#fff; font-weight:700; cursor:pointer; }
.xbca-portal-section { margin-top:28px; }
.xbca-portal-list { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:16px; }
.xbca-portal-card { border:1px solid #e5e7eb; border-radius:18px; padding:18px; background:#f8fafc; }
.xbca-progress { width:100%; height:10px; background:#e5e7eb; border-radius:999px; overflow:hidden; }
.xbca-progress span { display:block; height:100%; background:var(--xbct-primary,#f97316); }
.xbca-portal-files ul { margin-left:20px; list-style:disc; }
.xbca-sign-form { margin-top:14px; padding-top:14px; border-top:1px solid #e5e7eb; }
.xbca-signed-box, .xbca-portal-notice { background:#ecfdf5; border:1px solid #bbf7d0; color:#166534; border-radius:14px; padding:12px; margin-top:12px; }

/* v1.8.0 portal PDF buttons */
.xbca-portal-pdf-actions { display: flex; flex-wrap: wrap; gap: 10px; margin: 12px 0; }
.xbca-portal-button { display: inline-flex; align-items: center; justify-content: center; padding: 10px 14px; border-radius: var(--xbct-button-radius, 999px); background: var(--xbct-primary, #f97316); color: #fff; text-decoration: none; font-weight: 700; }
.xbca-portal-button:hover { color: #fff; filter: brightness(.95); }

/* v1.9.0 employee portal */
.xbca-employee-portal .xbca-portal-section{border-top:1px solid #e5e7eb;padding-top:18px}.xbca-clock-box form{display:grid;gap:12px;max-width:420px}.xbca-clock-box select{width:100%;border:1px solid #d1d5db;border-radius:12px;padding:11px 12px}.xbca-task-mini-list{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;margin:12px 0}.xbca-task-mini-list ul{margin:8px 0 0 18px}.xbca-portal-card h5{margin-top:0;font-size:1.05rem}.xbca-portal-button{border:none;cursor:pointer}

/* v2.3.0: client portal signature pad and revision requests */
.xbca-revision-form { margin-top: 14px; padding-top: 14px; border-top: 1px solid #e5e7eb; display:grid; gap:10px; }
.xbca-revision-form textarea { width:100%; border:1px solid #d1d5db; border-radius:12px; padding:12px 14px; font:inherit; }
.xbca-secondary-button { background:#fff !important; color:var(--xbct-primary,#f97316) !important; border:1px solid var(--xbct-primary,#f97316) !important; }
.xbca-signature-pad-wrap { background:#fff; border:1px dashed #94a3b8; border-radius:14px; padding:10px; margin:10px 0; }
.xbca-signature-pad { width:100%; height:150px; display:block; background:#fff; border-radius:10px; touch-action:none; }
.xbca-sign-form p { display:flex; flex-wrap:wrap; gap:10px; align-items:center; }

.xbca-review-links-panel{margin-top:18px;background:#fff;border:1px solid var(--xbca-border,var(--xbct-border,#e5e7eb));border-radius:var(--xbca-radius,var(--xbct-radius,22px));padding:22px;box-shadow:var(--xbca-shadow,var(--xbct-shadow,0 12px 35px rgba(15,23,42,.08)))}.xbca-review-links-panel h3{margin:0 0 8px}.xbca-public-review-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px}.xbca-review-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.xbca-review-button:hover{color:#fff;text-decoration:none}

/* Front-end agent image skin system. Default/no-skin remains the original agent above. */
.xbca-agent.xbca-agent-skinned{
  position:relative;
  width:min(100%,var(--xbca-skin-max-width,660px));
  max-width:var(--xbca-skin-max-width,660px);
  aspect-ratio:var(--xbca-skin-aspect,1086 / 1448);
  margin:0 auto;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  overflow:visible;
  color:var(--xbca-skin-text-color,var(--xbca-text,#111827));
}
.xbca-agent-skinned .xbca-agent-skin-bg{
  position:absolute;
  inset:0;
  z-index:1;
  background-image:var(--xbca-skin-image);
  background-repeat:no-repeat;
  background-size:contain;
  background-position:center;
  pointer-events:none;
  filter:drop-shadow(0 24px 48px rgba(15,23,42,.22));
}
.xbca-agent-skinned .xbca-agent-core{
  position:absolute;
  left:var(--xbca-skin-core-left,15%);
  top:var(--xbca-skin-core-top,10%);
  width:var(--xbca-skin-core-width,70%);
  height:var(--xbca-skin-core-height,70%);
  z-index:2;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  backdrop-filter:none!important;
  min-width:0;
}
.xbca-agent-skinned .xbca-agent-log{
  flex:1;
  height:auto;
  min-height:0;
  overflow:auto;
  padding:var(--xbca-skin-log-padding,12px 10px 10px);
  background:transparent!important;
  display:flex;
  flex-direction:column;
  gap:8px;
  scrollbar-width:thin;
}
.xbca-agent-skinned .xbca-message{
  max-width:94%;
  padding:5px 3px;
  border-radius:0;
  font-size:clamp(.78rem,1.65vw,.95rem);
  line-height:1.38;
  box-shadow:none!important;
  border:0!important;
  word-break:break-word;
}
.xbca-agent-skinned .xbca-message.bot{
  background:transparent!important;
  color:var(--xbca-skin-text-color,var(--xbca-text,#111827));
  align-self:flex-start;
  border:0!important;
}
.xbca-agent-skinned .xbca-message.user{
  background:var(--xbca-skin-user-bubble-bg,rgba(15,23,42,.76))!important;
  color:var(--xbca-skin-user-text-color,#fff);
  border-radius:14px;
  padding:8px 10px;
  align-self:flex-end;
}
.xbca-agent-skinned .xbca-agent-form{
  display:flex;
  align-items:center;
  gap:var(--xbca-skin-form-gap,8px);
  padding:var(--xbca-skin-form-padding,8px 4px 0);
  background:transparent!important;
  border:0!important;
  min-width:0;
}
.xbca-agent-skinned .xbca-agent-form input[data-xbca-input]{
  flex:1 1 auto;
  min-width:0;
  width:var(--xbca-skin-input-width,100%);
  height:var(--xbca-skin-input-height,42px);
  border:0!important;
  outline:0;
  border-radius:var(--xbca-skin-input-radius,999px);
  padding:var(--xbca-skin-input-padding,11px 13px);
  font-size:clamp(.78rem,1.55vw,.95rem);
  background:var(--xbca-skin-input-bg,rgba(255,255,255,.82));
  color:var(--xbca-skin-input-text-color,#111827);
  box-shadow:0 8px 22px rgba(15,23,42,.14);
  box-sizing:border-box;
}
.xbca-agent-skinned .xbca-agent-form input[data-xbca-input]:focus{
  background:#fff;
  box-shadow:0 0 0 3px rgba(249,115,22,.22),0 8px 22px rgba(15,23,42,.14);
}
.xbca-agent-skinned .xbca-agent-form button{
  flex:0 0 auto;
  border:0!important;
  padding:var(--xbca-skin-button-padding,11px 13px);
  min-width:58px;
  max-width:38%;
  border-radius:var(--xbca-skin-button-radius,999px);
  background:var(--xbca-skin-button-bg,var(--xbca-brand,#f97316));
  color:var(--xbca-skin-button-text-color,#fff);
  font-size:clamp(.76rem,1.45vw,.9rem);
  line-height:1;
  white-space:nowrap;
  box-shadow:0 8px 22px rgba(15,23,42,.18);
}
.xbca-agent-skinned .xbca-built-by{
  position:absolute;
  left:0;
  right:0;
  bottom:2px;
  z-index:3;
  padding:0;
  font-size:.68rem;
  color:rgba(255,255,255,.78);
  text-shadow:0 1px 2px rgba(0,0,0,.75);
}
@media(max-width:720px){
  .xbca-agent.xbca-agent-skinned{max-width:min(100%,520px)}
  .xbca-agent-skinned .xbca-agent-core{
    left:var(--xbca-skin-mobile-core-left,var(--xbca-skin-core-left));
    top:var(--xbca-skin-mobile-core-top,var(--xbca-skin-core-top));
    width:var(--xbca-skin-mobile-core-width,var(--xbca-skin-core-width));
    height:var(--xbca-skin-mobile-core-height,var(--xbca-skin-core-height));
  }
  .xbca-agent-skinned .xbca-agent-log{padding:8px 6px 8px;gap:6px}
  .xbca-agent-skinned .xbca-message{font-size:.8rem;line-height:1.32}
  .xbca-agent-skinned .xbca-agent-form{gap:6px;padding:6px 2px 0}
  .xbca-agent-skinned .xbca-agent-form input[data-xbca-input]{padding:10px 11px;font-size:.84rem;min-height:36px}
  .xbca-agent-skinned .xbca-agent-form button{padding:10px 11px;font-size:.8rem;min-width:52px}
}
@media(max-width:420px){
  .xbca-agent-skinned .xbca-agent-form{display:grid;grid-template-columns:1fr;}
  .xbca-agent-skinned .xbca-agent-form button{width:100%;max-width:none;}
}


/* v2.6.4: skinned agent send-button placement, resizable reply box, and movable XoBytes badge */
.xbca-agent-skinned.xbca-agent-button-inline .xbca-agent-form{display:flex;align-items:center;}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form,
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form,
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form{display:grid;grid-template-columns:1fr;align-items:stretch;}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form{justify-items:start;}
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form{justify-items:center;}
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form{justify-items:end;}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form input[data-xbca-input]{width:var(--xbca-skin-input-width,100%);max-width:100%;box-sizing:border-box;}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form button,
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form button,
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form button{width:auto;max-width:100%;}
.xbca-agent-skinned .xbca-built-by{transform:translate(var(--xbca-skin-badge-x,0px),var(--xbca-skin-badge-y,0px));padding:var(--xbca-skin-badge-padding,0px)!important;}
@media(max-width:420px){
  .xbca-agent-skinned.xbca-agent-button-inline .xbca-agent-form{display:grid;grid-template-columns:1fr;}
  .xbca-agent-skinned.xbca-agent-button-inline .xbca-agent-form button{width:100%;max-width:none;}
}

/* v2.6.5: visual skin builder output values */
.xbca-agent.xbca-agent-skinned{height:var(--xbca-skin-height,auto);}
.xbca-agent-skinned .xbca-agent-form{transform:translate(var(--xbca-skin-form-x,0px),var(--xbca-skin-form-y,0px));}
.xbca-agent-skinned .xbca-agent-form input[data-xbca-input]{transform:translate(var(--xbca-skin-input-x,0px),var(--xbca-skin-input-y,0px));}
.xbca-agent-skinned .xbca-agent-form button{transform:translate(var(--xbca-skin-button-x,0px),var(--xbca-skin-button-y,0px));}

/* v2.6.6: expanded skin designer output */
.xbca-agent-skinned .xbca-agent-log{background:var(--xbca-skin-log-bg,transparent)!important;border-radius:12px;}
.xbca-agent-skinned .xbca-message{font-size:var(--xbca-skin-message-font-size,clamp(.78rem,1.65vw,.95rem));}
.xbca-agent-skinned .xbca-message.bot{background:var(--xbca-skin-bot-bubble-bg,transparent)!important;border-radius:10px;padding:6px 8px;}
.xbca-agent-skinned .xbca-message.user{border-radius:var(--xbca-skin-user-bubble-radius,14px);}
.xbca-agent-skinned .xbca-agent-form button{width:var(--xbca-skin-button-width,72px);height:var(--xbca-skin-button-height,42px);display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;}
.xbca-agent-skinned .xbca-built-by{left:50%;right:auto;width:var(--xbca-skin-badge-width,260px);max-width:100%;margin-left:calc(var(--xbca-skin-badge-width,260px) / -2);font-size:var(--xbca-skin-badge-font-size,11px);color:var(--xbca-skin-badge-text-color,#fff);background:var(--xbca-skin-badge-bg,transparent);border-radius:999px;box-sizing:border-box;}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form button,
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form button,
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form button{width:var(--xbca-skin-button-width,72px);}
.xbca-agent-skinned .xbca-agent-form button{max-width:100%;}

/* v2.7.6: production skinned agent uses separate message and input areas. */
.xbca-agent-skinned .xbca-agent-core{
  display:block;
  overflow:visible;
}
.xbca-agent-skinned .xbca-agent-log{
  position:absolute;
  left:var(--xbca-skin-message-left,0%);
  top:var(--xbca-skin-message-top,0%);
  width:var(--xbca-skin-message-width,100%);
  height:var(--xbca-skin-message-height,76%);
  max-width:none;
  box-sizing:border-box;
}
.xbca-agent-skinned .xbca-agent-form{
  position:absolute;
  left:var(--xbca-skin-chat-left,0%);
  top:var(--xbca-skin-chat-top,80%);
  width:var(--xbca-skin-chat-width,100%);
  min-height:var(--xbca-skin-chat-height,64px);
  height:auto;
  box-sizing:border-box;
  flex-wrap:nowrap;
  overflow:visible;
}
.xbca-agent-skinned .xbca-agent-form input[data-xbca-input]{
  flex:0 0 var(--xbca-skin-input-width,100%);
  max-width:none;
  box-sizing:border-box;
}
.xbca-agent-skinned.xbca-agent-button-inline .xbca-agent-form input[data-xbca-input]{
  flex-basis:var(--xbca-skin-input-width,100%);
}
.xbca-agent-skinned .xbca-agent-form button{
  min-width:0;
  max-width:none;
  box-sizing:border-box;
}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form input[data-xbca-input]{
  width:var(--xbca-skin-input-width,100%);
  max-width:none;
}
@media(max-width:720px){
  .xbca-agent-skinned .xbca-agent-log{
    left:var(--xbca-skin-message-left,0%);
    top:var(--xbca-skin-message-top,0%);
    width:var(--xbca-skin-message-width,100%);
    height:var(--xbca-skin-message-height,76%);
  }
  .xbca-agent-skinned .xbca-agent-form{
    left:var(--xbca-skin-chat-left,0%);
    top:var(--xbca-skin-chat-top,80%);
    width:var(--xbca-skin-chat-width,100%);
    min-height:var(--xbca-skin-chat-height,64px);
  }
}


/* v2.7.7: locked production skin frame + optional hidden send button. */
.xbca-agent-skinned.xbca-agent-button-hidden .xbca-agent-form{
  display:flex;
  align-items:center;
}
.xbca-agent-skinned.xbca-agent-button-hidden .xbca-agent-form input[data-xbca-input]{
  flex:0 0 var(--xbca-skin-input-width,100%);
  max-width:none;
}
.xbca-agent-skinned.xbca-agent-button-hidden .xbca-agent-form button{
  display:none!important;
}


/* v2.7.8: production-accurate separated reply box and send button designer output.
   The reply input and Send button are no longer a connected flex/grid row.
   Both are absolute production layers inside the input area, so designer X/Y/width/height values
   map directly to the live front end. */
.xbca-agent.xbca-agent-skinned{
  overflow:visible;
}
.xbca-agent-skinned .xbca-agent-core{
  display:block!important;
  overflow:visible!important;
}
.xbca-agent-skinned .xbca-agent-log{
  position:absolute!important;
  left:var(--xbca-skin-message-left,0%)!important;
  top:var(--xbca-skin-message-top,0%)!important;
  width:var(--xbca-skin-message-width,100%)!important;
  height:var(--xbca-skin-message-height,76%)!important;
  max-width:none!important;
  min-height:0!important;
  box-sizing:border-box!important;
}
.xbca-agent-skinned .xbca-agent-form{
  position:absolute!important;
  left:var(--xbca-skin-chat-left,0%)!important;
  top:var(--xbca-skin-chat-top,80%)!important;
  width:var(--xbca-skin-chat-width,100%)!important;
  min-height:0!important;
  height:var(--xbca-skin-chat-height,64px)!important;
  display:block!important;
  align-items:initial!important;
  justify-items:initial!important;
  grid-template-columns:none!important;
  gap:0!important;
  padding:var(--xbca-skin-form-padding,8px 4px 0)!important;
  transform:translate(var(--xbca-skin-form-x,0px),var(--xbca-skin-form-y,0px))!important;
  box-sizing:border-box!important;
  overflow:visible!important;
}
.xbca-agent-skinned .xbca-agent-form input[data-xbca-input]{
  position:absolute!important;
  left:var(--xbca-skin-input-left,0px)!important;
  top:var(--xbca-skin-input-top,0px)!important;
  width:var(--xbca-skin-input-width,calc(100% - var(--xbca-skin-button-width,72px) - var(--xbca-skin-form-gap,8px)))!important;
  height:var(--xbca-skin-input-height,42px)!important;
  max-width:none!important;
  min-width:0!important;
  flex:0 0 auto!important;
  flex-basis:auto!important;
  transform:none!important;
  box-sizing:border-box!important;
}
.xbca-agent-skinned .xbca-agent-form button{
  position:absolute!important;
  left:var(--xbca-skin-button-left,calc(100% - var(--xbca-skin-button-width,72px)))!important;
  top:var(--xbca-skin-button-top,0px)!important;
  width:var(--xbca-skin-button-width,72px)!important;
  height:var(--xbca-skin-button-height,42px)!important;
  min-width:0!important;
  max-width:none!important;
  transform:none!important;
  box-sizing:border-box!important;
}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form,
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form,
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form,
.xbca-agent-skinned.xbca-agent-button-inline .xbca-agent-form,
.xbca-agent-skinned.xbca-agent-button-hidden .xbca-agent-form{
  display:block!important;
}
.xbca-agent-skinned.xbca-agent-button-under-left .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-under-center .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-under-right .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-inline .xbca-agent-form input[data-xbca-input],
.xbca-agent-skinned.xbca-agent-button-hidden .xbca-agent-form input[data-xbca-input]{
  width:var(--xbca-skin-input-width,calc(100% - var(--xbca-skin-button-width,72px) - var(--xbca-skin-form-gap,8px)))!important;
  max-width:none!important;
  flex-basis:auto!important;
}
.xbca-agent-skinned.xbca-agent-button-hidden .xbca-agent-form button{
  display:none!important;
}
@media(max-width:720px){
  .xbca-agent-skinned .xbca-agent-form{
    display:block!important;
    left:var(--xbca-skin-chat-left,0%)!important;
    top:var(--xbca-skin-chat-top,80%)!important;
    width:var(--xbca-skin-chat-width,100%)!important;
    height:var(--xbca-skin-chat-height,64px)!important;
  }
  .xbca-agent-skinned .xbca-agent-form input[data-xbca-input]{
    left:var(--xbca-skin-input-left,0px)!important;
    top:var(--xbca-skin-input-top,0px)!important;
    width:var(--xbca-skin-input-width,calc(100% - var(--xbca-skin-button-width,72px) - var(--xbca-skin-form-gap,8px)))!important;
    height:var(--xbca-skin-input-height,42px)!important;
  }
  .xbca-agent-skinned .xbca-agent-form button{
    left:var(--xbca-skin-button-left,calc(100% - var(--xbca-skin-button-width,72px)))!important;
    top:var(--xbca-skin-button-top,0px)!important;
    width:var(--xbca-skin-button-width,72px)!important;
    height:var(--xbca-skin-button-height,42px)!important;
  }
}

/* v2.7.13: full mobile layout variables for the Agent Designer and front-end agent. */
@media (max-width:720px){
  .xbca-agent-skinned .xbca-agent-core{
    left:var(--xbca-skin-mobile-core-left,var(--xbca-skin-core-left,15%))!important;
    top:var(--xbca-skin-mobile-core-top,var(--xbca-skin-core-top,10%))!important;
    width:var(--xbca-skin-mobile-core-width,var(--xbca-skin-core-width,70%))!important;
    height:var(--xbca-skin-mobile-core-height,var(--xbca-skin-core-height,70%))!important;
  }
  .xbca-agent-skinned .xbca-agent-log{
    left:var(--xbca-skin-mobile-message-left,var(--xbca-skin-message-left,0%))!important;
    top:var(--xbca-skin-mobile-message-top,var(--xbca-skin-message-top,0%))!important;
    width:var(--xbca-skin-mobile-message-width,var(--xbca-skin-message-width,100%))!important;
    height:var(--xbca-skin-mobile-message-height,var(--xbca-skin-message-height,76%))!important;
  }
  .xbca-agent-skinned .xbca-agent-form{
    left:var(--xbca-skin-mobile-chat-left,var(--xbca-skin-chat-left,0%))!important;
    top:var(--xbca-skin-mobile-chat-top,var(--xbca-skin-chat-top,80%))!important;
    width:var(--xbca-skin-mobile-chat-width,var(--xbca-skin-chat-width,100%))!important;
    height:var(--xbca-skin-mobile-chat-height,var(--xbca-skin-chat-height,64px))!important;
  }
  .xbca-agent-skinned .xbca-agent-form input[data-xbca-input]{
    left:var(--xbca-skin-mobile-input-left,var(--xbca-skin-input-left,0px))!important;
    top:var(--xbca-skin-mobile-input-top,var(--xbca-skin-input-top,0px))!important;
    width:var(--xbca-skin-mobile-input-width,var(--xbca-skin-input-width,72%))!important;
    height:var(--xbca-skin-mobile-input-height,var(--xbca-skin-input-height,42px))!important;
  }
  .xbca-agent-skinned .xbca-agent-form button{
    left:var(--xbca-skin-mobile-button-left,var(--xbca-skin-button-left,calc(100% - var(--xbca-skin-mobile-button-width,var(--xbca-skin-button-width,72px)))))!important;
    top:var(--xbca-skin-mobile-button-top,var(--xbca-skin-button-top,0px))!important;
    width:var(--xbca-skin-mobile-button-width,var(--xbca-skin-button-width,72px))!important;
    height:var(--xbca-skin-mobile-button-height,var(--xbca-skin-button-height,42px))!important;
  }
  .xbca-agent-skinned .xbca-built-by{
    width:var(--xbca-skin-mobile-badge-width,var(--xbca-skin-badge-width,260px))!important;
    font-size:var(--xbca-skin-mobile-badge-font-size,var(--xbca-skin-badge-font-size,11px))!important;
    transform:translate(var(--xbca-skin-mobile-badge-x,var(--xbca-skin-badge-x,0px)),var(--xbca-skin-mobile-badge-y,var(--xbca-skin-badge-y,0px)))!important;
  }
}


/* v2.7.13: Contact page form + contact info layout. */
.xbca-contact-page{display:grid;grid-template-columns:minmax(260px,.85fr) minmax(0,1.4fr);gap:24px;align-items:start}
.xbca-contact-info-card{background:#fff;border:1px solid var(--xbca-border,#e5e7eb);border-radius:var(--xbca-radius,22px);padding:24px;box-shadow:var(--xbca-shadow,0 12px 35px rgba(15,23,42,.08))}
.xbca-contact-info-card h3{margin:.15rem 0 1rem;font-size:1.45rem;line-height:1.2}
.xbca-contact-eyebrow{margin:0;color:var(--xbca-brand,var(--xbct-primary,#f97316));font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem}
.xbca-contact-info-list{display:grid;gap:12px;margin:18px 0}
.xbca-contact-info-list p{display:grid;gap:3px;margin:0;padding:12px 0;border-bottom:1px solid var(--xbca-border,#e5e7eb)}
.xbca-contact-info-list strong,.xbca-contact-areas strong{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--xbca-muted,#6b7280)}
.xbca-contact-info-list a,.xbca-contact-agent-link{color:var(--xbca-brand,var(--xbct-primary,#f97316));font-weight:900;text-decoration:none}
.xbca-contact-areas ul{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:10px 0 0;padding:0}
.xbca-contact-areas li{background:var(--xbca-soft,#f8fafc);border:1px solid var(--xbca-border,#e5e7eb);border-radius:999px;padding:6px 10px;font-weight:800;font-size:.85rem}
.xbca-contact-agent-note{margin:18px 0 10px;color:var(--xbca-muted,#6b7280)}
.xbca-contact-agent-link{display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--xbca-brand,var(--xbct-primary,#f97316)) 38%,transparent);border-radius:var(--xbca-button-radius,999px);padding:10px 14px;background:color-mix(in srgb,var(--xbca-brand,var(--xbct-primary,#f97316)) 9%,white)}
.xbca-contact-form{min-width:0}
@media(max-width:900px){.xbca-contact-page{grid-template-columns:1fr}}

/* v2.7.17 employee clock rule notices */
.xbca-portal-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:14px;padding:12px;margin-top:12px;font-weight:700}

/* v2.7.18: Contact page address/map support. */
.xbca-contact-info-list span{white-space:normal}.xbca-contact-info-list a[target="_blank"]{display:inline-flex;align-items:center;gap:4px}

/* v2.7.23: Project media toppers for front-end project cards, single project pages, and portal cards. */
.xbca-project-card-modern{display:flex;flex-direction:column;height:100%;padding:0!important;overflow:hidden;position:relative;background:#fff;border:1px solid var(--xbca-border,var(--xbct-border,#e5e7eb));border-radius:var(--xbca-radius,var(--xbct-radius,22px));box-shadow:var(--xbca-shadow,var(--xbct-shadow,0 12px 35px rgba(15,23,42,.08)))}
.xbca-project-card-body{padding:20px 20px 22px;display:grid;gap:10px}.xbca-project-card-body h3,.xbca-project-card-body p{margin:0}.xbca-project-card-body p{color:var(--xbca-muted,var(--xbct-muted,#6b7280));line-height:1.55}
.xbca-project-media-carousel{position:relative;width:100%;overflow:hidden;background:#0f172a;border-bottom:1px solid var(--xbca-border,var(--xbct-border,#e5e7eb));isolation:isolate}.xbca-project-media-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none}.xbca-project-media-track::-webkit-scrollbar{display:none}.xbca-project-media-slide{position:relative;flex:0 0 100%;width:100%;aspect-ratio:16/10;min-height:190px;display:flex;align-items:center;justify-content:center;scroll-snap-align:start;overflow:hidden;background:linear-gradient(135deg,#0f172a,#1e293b)}.xbca-project-media-slide-image:before{content:"";position:absolute;inset:-22px;background-image:var(--xbca-project-media-image);background-size:cover;background-position:center;background-repeat:no-repeat;filter:blur(24px);transform:scale(1.12);opacity:.55}.xbca-project-media-slide-image:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,23,42,.34),rgba(255,255,255,.12))}.xbca-project-media-image-link{position:relative;z-index:2;display:flex;width:100%;height:100%;align-items:center;justify-content:center;text-decoration:none}.xbca-project-media-slide img{position:relative;z-index:2;display:block!important;width:100%!important;height:100%!important;max-width:100%!important;max-height:100%!important;padding:10px;box-sizing:border-box;object-fit:contain!important;object-position:center center!important;aspect-ratio:auto!important;transform:none!important;filter:drop-shadow(0 16px 28px rgba(15,23,42,.2))}.xbca-project-media-slide video{position:relative;z-index:2;width:100%;height:100%;object-fit:contain;background:#020617}.xbca-project-media-badge{position:absolute;z-index:3;left:12px;top:12px;background:rgba(15,23,42,.78);color:#fff;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.xbca-project-media-document{position:relative;z-index:2;display:grid;place-items:center;text-align:center;gap:10px;width:100%;height:100%;padding:22px;color:#fff!important;text-decoration:none!important;box-sizing:border-box;background:linear-gradient(135deg,#111827,#334155)}.xbca-project-media-document strong{display:block;font-size:1rem}.xbca-project-media-document em{display:block;margin-top:4px;font-style:normal;opacity:.86;line-height:1.3;word-break:break-word}.xbca-project-media-doc-icon,.xbca-project-media-placeholder span{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:16px;background:rgba(255,255,255,.12);font-size:24px}.xbca-project-media-placeholder{gap:8px;color:#fff;text-align:center;padding:22px;box-sizing:border-box}.xbca-project-media-placeholder strong,.xbca-project-media-placeholder em{position:relative;z-index:2}.xbca-project-media-placeholder em{font-style:normal;opacity:.75}.xbca-project-media-nav{position:absolute;z-index:5;top:50%;transform:translateY(-50%);width:36px;height:36px;border:0;border-radius:999px;background:rgba(255,255,255,.9);color:#0f172a;font-size:26px;line-height:1;font-weight:900;box-shadow:0 10px 24px rgba(15,23,42,.22);cursor:pointer}.xbca-project-media-prev{left:10px}.xbca-project-media-next{right:10px}.xbca-project-media-nav:hover{background:#fff}.xbca-project-media-count{position:absolute;z-index:4;right:12px;bottom:12px;background:rgba(15,23,42,.72);color:#fff;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.xbca-project-media-single{margin:0 0 28px;border-radius:var(--xbct-radius,22px);border:1px solid var(--xbct-border,#e5e7eb);box-shadow:var(--xbct-shadow,0 12px 35px rgba(15,23,42,.08))}.xbca-project-media-single .xbca-project-media-slide{aspect-ratio:16/8;min-height:280px}.xbca-portal-project-card{padding:0!important;overflow:hidden}.xbca-portal-project-card>h5,.xbca-portal-project-card>p,.xbca-portal-project-card>.xbca-progress,.xbca-portal-project-card>.xbca-portal-files,.xbca-portal-project-card>.xbca-task-mini-list{margin-left:18px;margin-right:18px}.xbca-portal-project-card>h5{margin-top:18px}@media(max-width:900px){.xbca-project-media-single .xbca-project-media-slide{aspect-ratio:16/10;min-height:220px}}@media(max-width:600px){.xbca-project-media-slide{aspect-ratio:16/11;min-height:170px}.xbca-project-media-nav{width:32px;height:32px;font-size:22px}.xbca-project-media-slide img{padding:8px}}


/* v2.7.24: Service card uploaded icons. */
.xbca-service-icon{width:64px;height:64px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(249,115,22,.12),rgba(15,23,42,.04));border:1px solid rgba(249,115,22,.18);box-shadow:0 10px 22px rgba(15,23,42,.06);margin:0 0 14px;overflow:hidden}.xbca-service-icon img{display:block;width:70%;height:70%;object-fit:contain;aspect-ratio:auto}.xbca-service-card .xbca-service-icon+h3{margin-top:0}.xbca-service-card-body{position:relative}.xbca-service-card{transition:transform .22s ease,box-shadow .22s ease}.xbca-service-card:hover{transform:translateY(-3px);box-shadow:0 18px 45px rgba(15,23,42,.11)}


/* v2.7.27: Front-end project cards use filled media toppers.
   Public project card images now fill the top frame without the blurred contain treatment. */
.xbca-project-card-modern > .xbca-project-media-carousel{
  padding:0!important;
}
.xbca-project-card-modern > .xbca-project-card-body{
  padding:20px 20px 22px!important;
}
.xbca-project-card-modern .xbca-project-media-public{
  background:#e5e7eb!important;
  border-bottom:1px solid var(--xbca-border,var(--xbct-border,#e5e7eb))!important;
}
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-slide{
  aspect-ratio:16/10!important;
  min-height:220px!important;
  padding:0!important;
  background:#e5e7eb!important;
}
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-slide-image:before,
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-slide-image:after{
  content:none!important;
  display:none!important;
}
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-image-link{
  display:block!important;
  width:100%!important;
  height:100%!important;
  padding:0!important;
}
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-slide img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  padding:0!important;
  margin:0!important;
  object-fit:cover!important;
  object-position:center center!important;
  filter:none!important;
  transform:none!important;
  aspect-ratio:auto!important;
}
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-slide video{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
}
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-placeholder{
  background:linear-gradient(135deg,#0f172a,#334155)!important;
}
@media(max-width:600px){
  .xbca-project-card-modern .xbca-project-media-public .xbca-project-media-slide{min-height:190px!important;aspect-ratio:16/11!important}
}

/* v2.7.28: homepage limits + full archive/detail card layouts. */
.xbca-card-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:4px}
.xbca-card-link-quote{display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--xbca-brand,var(--xbct-primary,#f97316)) 34%,transparent);border-radius:var(--xbca-button-radius,999px);padding:8px 12px;background:color-mix(in srgb,var(--xbca-brand,var(--xbct-primary,#f97316)) 8%,white)}
.xbca-services-grid-detail,.xbca-project-grid-detail{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.xbca-services-grid-detail .xbca-service-card-body,.xbca-project-grid-detail .xbca-project-card-body{padding:24px!important}
.xbca-services-grid-detail .xbca-service-card p,.xbca-project-grid-detail .xbca-project-card p{font-size:1rem;line-height:1.65}
.xbca-services-grid-detail .xbca-service-image{display:block;position:relative;aspect-ratio:16/9;min-height:190px;overflow:hidden;background:#e5e7eb;border-bottom:1px solid var(--xbca-border,var(--xbct-border,#e5e7eb))}
.xbca-services-grid-detail .xbca-service-image img{display:block!important;width:100%!important;height:100%!important;max-width:none!important;max-height:none!important;padding:0!important;margin:0!important;object-fit:cover!important;object-position:center center!important;aspect-ratio:auto!important}
.xbca-project-grid-detail .xbca-project-media-public .xbca-project-media-slide{min-height:250px!important}
.xbca-project-card-modern .xbca-project-media-public,.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-track,.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-image-link{height:100%}
.xbca-project-card-modern .xbca-project-media-public .xbca-project-media-slide img{object-fit:cover!important;object-position:center center!important}
@media(max-width:600px){.xbca-card-actions{display:grid}.xbca-card-link-quote{width:100%;box-sizing:border-box}.xbca-project-grid-detail .xbca-project-media-public .xbca-project-media-slide{min-height:200px!important}}


/* v2.7.29: Project archive cards are a fixed 3-column card grid on desktop with image toppers. */
.xbca-project-grid-detail{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:22px!important;
  align-items:stretch!important;
}
.xbca-project-grid-detail .xbca-project-card-modern{
  width:100%!important;
  height:100%!important;
}
.xbca-project-grid-detail .xbca-project-media-public,
.xbca-project-grid-detail .xbca-project-media-public .xbca-project-media-track,
.xbca-project-grid-detail .xbca-project-media-public .xbca-project-media-image-link{
  height:100%!important;
}
.xbca-project-grid-detail .xbca-project-media-public .xbca-project-media-slide{
  min-height:200px!important;
  aspect-ratio:16/10!important;
}
.xbca-project-grid-detail .xbca-project-card-body{
  padding:20px 20px 22px!important;
}
@media(max-width:1020px){
  .xbca-project-grid-detail{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media(max-width:640px){
  .xbca-project-grid-detail{grid-template-columns:1fr!important;}
  .xbca-project-grid-detail .xbca-project-media-public .xbca-project-media-slide{min-height:190px!important;}
}

/* v2.7.31: employee portal task performance summary. */
.xbca-employee-performance-panel{
  margin:18px 0;
  padding:16px;
  border:1px solid rgba(148,163,184,.35);
  border-radius:18px;
  background:rgba(248,250,252,.95);
}
.xbca-employee-performance-panel h4{
  margin:0 0 12px;
}
.xbca-employee-performance-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.xbca-employee-performance-card{
  background:#fff;
  border:1px solid rgba(148,163,184,.35);
  border-radius:16px;
  padding:12px;
  box-shadow:0 8px 22px rgba(15,23,42,.06);
}
.xbca-employee-performance-card span{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.xbca-employee-performance-card strong{
  display:block;
  margin-top:5px;
  color:#0f172a;
  font-size:24px;
  line-height:1.1;
}
.xbca-employee-performance-card small{
  display:block;
  margin-top:5px;
  color:#64748b;
}
@media(max-width:900px){.xbca-employee-performance-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:600px){.xbca-employee-performance-grid{grid-template-columns:1fr;}}

/* v2.7.32: optional service card topper layout. */
.xbca-service-card-with-topper{display:flex;flex-direction:column;padding:0;overflow:hidden}
.xbca-service-topper{display:block;position:relative;aspect-ratio:16/9;min-height:170px;overflow:hidden;background:#e5e7eb;border-bottom:1px solid var(--xbca-border,var(--xbct-border,#e5e7eb));text-decoration:none}
.xbca-service-topper img{display:block!important;width:100%!important;height:100%!important;max-width:none!important;max-height:none!important;margin:0!important;padding:0!important;object-fit:cover!important;object-position:center center!important;aspect-ratio:auto!important;transition:transform .28s ease}
.xbca-service-card-with-topper:hover .xbca-service-topper img{transform:scale(1.035)}
.xbca-service-card-with-topper .xbca-service-card-body-topper{padding:0 22px 22px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:0}
.xbca-service-card-with-topper .xbca-service-icon{width:70px;height:70px;margin:-35px auto 14px;position:relative;z-index:2;background:#fff;border-color:rgba(15,23,42,.08);box-shadow:0 14px 32px rgba(15,23,42,.14)}
.xbca-service-card-with-topper h3{margin:0 0 10px;font-size:1.18rem;line-height:1.25}
.xbca-service-card-with-topper p{margin:0 0 14px;color:#4b5563;line-height:1.6}
.xbca-service-bullets{width:100%;list-style:none;margin:4px 0 18px;padding:0;display:grid;gap:8px;text-align:left}
.xbca-service-bullets li{position:relative;padding-left:24px;font-weight:750;color:#111827;line-height:1.35}
.xbca-service-bullets li::before{content:'✓';position:absolute;left:0;top:0;color:var(--xbca-brand,var(--xbct-primary,#f97316));font-weight:900}
.xbca-card-actions-topper{display:flex;justify-content:center;flex-wrap:wrap;gap:10px;width:100%;margin-top:auto}
.xbca-card-link-learn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--xbca-brand,var(--xbct-primary,#f97316));color:#fff!important;padding:10px 16px;box-shadow:0 10px 22px rgba(15,23,42,.10)}
.xbca-card-actions-topper .xbca-card-link-quote{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#fff;border:1px solid var(--xbca-border,var(--xbct-border,#e5e7eb));padding:10px 16px;color:var(--xbca-brand,var(--xbct-primary,#f97316))!important}
@media(max-width:600px){.xbca-service-topper{min-height:155px}.xbca-service-card-with-topper .xbca-service-card-body-topper{padding-left:18px;padding-right:18px}.xbca-card-actions-topper{display:grid}.xbca-card-actions-topper a{width:100%}}

/* v2.7.33: modern client portal dashboard and branded email UX support. */
.xbca-portal-shell.xbca-client-portal-modern{
  width:min(1180px,100%);
  margin:28px auto;
  display:grid;
  gap:22px;
  color:#0f172a;
}
.xbca-client-portal-modern .xbca-portal-hero-modern{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:24px;
  align-items:end;
  padding:clamp(24px,4vw,42px);
  border:1px solid rgba(148,163,184,.26);
  border-radius:30px;
  background:
    radial-gradient(circle at 12% 0%, rgba(249,115,22,.22), transparent 34%),
    radial-gradient(circle at 90% 18%, rgba(15,23,42,.16), transparent 32%),
    linear-gradient(135deg,#fff7ed 0%,#ffffff 46%,#f8fafc 100%);
  box-shadow:0 24px 60px rgba(15,23,42,.10);
}
.xbca-client-portal-modern .xbca-portal-hero-modern::after{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-100px;
  width:280px;
  height:280px;
  border-radius:999px;
  background:rgba(249,115,22,.11);
  pointer-events:none;
}
.xbca-client-portal-modern .xbca-portal-kicker,
.xbca-client-portal-modern .xbca-portal-client-head span,
.xbca-client-portal-modern .xbca-portal-summary-card span{
  display:block;
  color:var(--xbct-primary,#f97316);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.xbca-client-portal-modern .xbca-portal-hero-copy,
.xbca-client-portal-modern .xbca-portal-hero-actions{
  position:relative;
  z-index:1;
}
.xbca-client-portal-modern .xbca-portal-hero-copy h2{
  margin:8px 0 10px;
  color:#0f172a;
  font-size:clamp(2rem,4vw,3.25rem);
  line-height:1;
  letter-spacing:-.05em;
}
.xbca-client-portal-modern .xbca-portal-hero-copy p{
  max-width:760px;
  margin:0;
  color:#475569;
  font-size:1.04rem;
  line-height:1.65;
}
.xbca-client-portal-modern .xbca-portal-hero-actions{
  display:grid;
  gap:10px;
  justify-items:end;
  font-size:.92rem;
  color:#64748b;
}
.xbca-client-portal-modern .xbca-portal-hero-actions span{
  display:inline-flex;
  max-width:280px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  padding:8px 12px;
  border:1px solid rgba(148,163,184,.32);
  border-radius:999px;
  background:rgba(255,255,255,.72);
}
.xbca-client-portal-modern .xbca-portal-hero-actions a,
.xbca-login-box #wp-submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 16px;
  border:0;
  border-radius:999px;
  background:var(--xbct-primary,#f97316);
  color:#fff!important;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 14px 30px rgba(249,115,22,.26);
  cursor:pointer;
}
.xbca-client-portal-modern .xbca-portal-summary-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.xbca-client-portal-modern .xbca-portal-summary-card{
  min-height:132px;
  padding:18px;
  border:1px solid rgba(148,163,184,.26);
  border-radius:22px;
  background:rgba(255,255,255,.94);
  box-shadow:0 16px 40px rgba(15,23,42,.07);
}
.xbca-client-portal-modern .xbca-portal-summary-card strong{
  display:block;
  margin:9px 0 5px;
  color:#0f172a;
  font-size:clamp(1.65rem,3vw,2.35rem);
  line-height:1;
  letter-spacing:-.04em;
}
.xbca-client-portal-modern .xbca-portal-summary-card small{
  display:block;
  color:#64748b;
  line-height:1.45;
}
.xbca-portal-client-modern{
  display:grid;
  gap:18px;
  padding:clamp(18px,3vw,26px);
  border:1px solid rgba(148,163,184,.26);
  border-radius:28px;
  background:#fff;
  box-shadow:0 20px 48px rgba(15,23,42,.08);
}
.xbca-portal-client-modern .xbca-portal-client-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(148,163,184,.22);
}
.xbca-portal-client-modern .xbca-portal-client-head h3{
  margin:6px 0 0;
  color:#0f172a;
  font-size:clamp(1.35rem,2.6vw,2rem);
  letter-spacing:-.03em;
}
.xbca-portal-client-modern .xbca-portal-client-notes{
  margin:0;
  padding:14px 16px;
  border:1px solid rgba(249,115,22,.18);
  border-radius:18px;
  background:#fff7ed;
  color:#7c2d12;
  line-height:1.6;
}
.xbca-client-portal-modern .xbca-portal-section{
  margin:0;
  padding-top:0;
}
.xbca-client-portal-modern .xbca-portal-section>h4{
  display:flex;
  align-items:center;
  gap:10px;
  margin:8px 0 14px;
  color:#0f172a;
  font-size:1.18rem;
  letter-spacing:-.02em;
}
.xbca-client-portal-modern .xbca-portal-section>h4::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--xbct-primary,#f97316);
  box-shadow:0 0 0 6px rgba(249,115,22,.12);
}
.xbca-client-portal-modern .xbca-portal-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.xbca-client-portal-modern .xbca-portal-card{
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:180px;
  padding:18px;
  border:1px solid rgba(148,163,184,.24);
  border-radius:22px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  box-shadow:0 14px 34px rgba(15,23,42,.07);
}
.xbca-client-portal-modern .xbca-portal-card h5{
  margin:0;
  color:#0f172a;
  font-size:1.08rem;
  line-height:1.25;
}
.xbca-client-portal-modern .xbca-portal-card p{
  margin:0;
  color:#475569;
  line-height:1.55;
}
.xbca-client-portal-modern .xbca-portal-card strong{
  color:#0f172a;
}
.xbca-client-portal-modern .xbca-portal-project-card{
  padding:0!important;
}
.xbca-client-portal-modern .xbca-portal-project-card>h5,
.xbca-client-portal-modern .xbca-portal-project-card>p,
.xbca-client-portal-modern .xbca-portal-project-card>.xbca-progress,
.xbca-client-portal-modern .xbca-portal-project-card>.xbca-portal-files,
.xbca-client-portal-modern .xbca-portal-project-card>.xbca-task-mini-list{
  margin-left:18px;
  margin-right:18px;
}
.xbca-client-portal-modern .xbca-portal-project-card>.xbca-portal-files,
.xbca-client-portal-modern .xbca-portal-project-card>.xbca-task-mini-list{
  margin-bottom:18px;
}
.xbca-client-portal-modern .xbca-portal-files{
  margin-top:4px;
  padding:12px;
  border:1px solid rgba(148,163,184,.22);
  border-radius:16px;
  background:#fff;
}
.xbca-client-portal-modern .xbca-portal-files ul{
  margin:8px 0 0 18px;
}
.xbca-client-portal-modern .xbca-portal-actions,
.xbca-client-portal-modern .xbca-portal-pdf-actions{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  margin-top:auto;
}
.xbca-client-portal-modern .xbca-portal-button{
  min-height:40px;
  border-radius:999px;
  box-shadow:0 10px 22px rgba(249,115,22,.18);
}
.xbca-client-portal-modern .xbca-secondary-button{
  background:#fff!important;
  color:var(--xbct-primary,#f97316)!important;
  border:1px solid rgba(249,115,22,.32)!important;
  box-shadow:none;
}
.xbca-client-portal-modern .xbca-progress{
  height:10px;
  overflow:hidden;
  border-radius:999px;
  background:#e2e8f0;
}
.xbca-client-portal-modern .xbca-progress span{
  display:block;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--xbct-primary,#f97316),#fb923c);
}
.xbca-login-box{
  max-width:520px;
  margin:34px auto;
  padding:clamp(22px,4vw,34px)!important;
  border-radius:28px!important;
  background:linear-gradient(180deg,#ffffff,#f8fafc)!important;
  box-shadow:0 24px 60px rgba(15,23,42,.10)!important;
}
.xbca-login-box h2{
  margin-top:0;
  font-size:clamp(1.8rem,4vw,2.45rem);
  letter-spacing:-.04em;
}
.xbca-login-box form{
  display:grid;
  gap:14px;
  margin-top:18px;
}
.xbca-login-box label{
  display:grid;
  gap:7px;
  color:#334155;
  font-weight:800;
}
.xbca-login-box input[type="text"],
.xbca-login-box input[type="password"]{
  width:100%;
  border:1px solid rgba(148,163,184,.55);
  border-radius:14px;
  padding:12px 13px;
  background:#fff;
}
.xbca-login-box .login-remember label{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
}
@media(max-width:1020px){
  .xbca-client-portal-modern .xbca-portal-summary-grid,
  .xbca-client-portal-modern .xbca-portal-list{grid-template-columns:repeat(2,minmax(0,1fr));}
  .xbca-client-portal-modern .xbca-portal-hero-modern{grid-template-columns:1fr;}
  .xbca-client-portal-modern .xbca-portal-hero-actions{justify-items:start;}
}
@media(max-width:640px){
  .xbca-portal-shell.xbca-client-portal-modern{margin:18px auto;gap:16px;}
  .xbca-client-portal-modern .xbca-portal-summary-grid,
  .xbca-client-portal-modern .xbca-portal-list{grid-template-columns:1fr;}
  .xbca-client-portal-modern .xbca-portal-hero-modern,
  .xbca-portal-client-modern{border-radius:22px;}
}

/* v2.7.34: estimate acceptance, PDF signing flow, and portal progress overflow fixes. */
.xbca-accept-box{
  margin-top:14px;
  padding:14px;
  border:1px solid rgba(249,115,22,.24);
  border-radius:16px;
  background:#fff7ed;
}
.xbca-accept-box p{margin:0 0 12px!important;color:#7c2d12!important;}
.xbca-accepted-box{background:#ecfdf5!important;border-color:#bbf7d0!important;color:#166534!important;}
.xbca-client-portal-modern .xbca-portal-project-card>.xbca-progress,
.xbca-portal-project-card>.xbca-progress{
  width:auto!important;
  max-width:none!important;
  box-sizing:border-box;
}
.xbca-client-portal-modern .xbca-progress span,
.xbca-progress span{
  max-width:100%;
}

/* v2.7.35: clickable client project cards, client uploads, and full project detail pages. */
.xbca-portal-project-click{
  display:block;
  color:inherit!important;
  text-decoration:none!important;
}
.xbca-portal-project-click:hover strong{
  color:var(--xbct-primary,#f97316);
}
.xbca-portal-project-content{
  display:grid;
  gap:9px;
  padding:18px 18px 0;
}
.xbca-portal-project-content strong{
  font-size:1.08rem;
  line-height:1.25;
  color:#0f172a;
}
.xbca-portal-project-content em,
.xbca-portal-project-content small{
  font-style:normal;
  color:#64748b;
  font-weight:800;
}
.xbca-portal-project-content .xbca-progress{
  margin:0!important;
}
.xbca-portal-project-summary{
  margin:12px 18px 0!important;
}
.xbca-portal-project-actions{
  margin:14px 18px 0!important;
}
.xbca-client-project-upload{
  display:grid;
  gap:10px;
  margin:14px 18px 18px;
  padding:12px;
  border:1px dashed rgba(148,163,184,.55);
  border-radius:16px;
  background:#fff;
}
.xbca-client-project-upload label{
  display:grid;
  gap:7px;
  margin:0;
  color:#334155;
  font-weight:900;
}
.xbca-client-project-upload label span{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:#64748b;
}
.xbca-client-project-upload input[type="file"]{
  width:100%;
  box-sizing:border-box;
  border:1px solid rgba(148,163,184,.45);
  border-radius:12px;
  padding:9px;
  background:#f8fafc;
}
.xbca-client-project-upload button{
  width:max-content;
}
.xbca-portal-notice-error{
  border-color:#fecaca!important;
  background:#fef2f2!important;
  color:#991b1b!important;
}
.xbca-project-detail-shell{
  width:min(1180px,100%);
  margin:0 auto 42px;
  display:grid;
  gap:26px;
  color:#0f172a;
}
.xbca-project-detail-hero{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);
  gap:24px;
  align-items:stretch;
}
.xbca-project-detail-media,
.xbca-project-detail-summary,
.xbca-project-detail-section{
  border:1px solid rgba(148,163,184,.28);
  border-radius:28px;
  background:#fff;
  box-shadow:0 20px 50px rgba(15,23,42,.08);
  overflow:hidden;
}
.xbca-project-detail-media .xbca-project-media-single{
  height:100%;
  min-height:360px;
  margin:0!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
}
.xbca-project-detail-media .xbca-project-media-single .xbca-project-media-track,
.xbca-project-detail-media .xbca-project-media-single .xbca-project-media-image-link{
  height:100%;
}
.xbca-project-detail-media .xbca-project-media-single .xbca-project-media-slide{
  min-height:360px;
  aspect-ratio:16/10;
}
.xbca-project-detail-summary{
  padding:clamp(22px,3vw,34px);
  display:flex;
  flex-direction:column;
  gap:16px;
}
.xbca-project-detail-kicker,
.xbca-project-detail-section-head span{
  display:block;
  color:var(--xbct-primary,#f97316);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.xbca-project-detail-summary h1,
.xbca-project-detail-section-head h2{
  margin:0;
  color:#0f172a;
  letter-spacing:-.04em;
  line-height:1.05;
}
.xbca-project-detail-summary h1{
  font-size:clamp(2rem,4vw,3.35rem);
}
.xbca-project-detail-excerpt{
  margin:0;
  color:#475569;
  line-height:1.65;
  font-size:1.02rem;
}
.xbca-project-detail-metrics{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.xbca-project-detail-metrics div{
  padding:14px;
  border:1px solid rgba(148,163,184,.28);
  border-radius:18px;
  background:#f8fafc;
}
.xbca-project-detail-metrics span{
  display:block;
  margin-bottom:5px;
  color:#64748b;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.xbca-project-detail-metrics strong{
  font-size:1.2rem;
}
.xbca-project-detail-progress{
  height:12px;
  overflow:hidden;
  border-radius:999px;
  background:#e2e8f0;
}
.xbca-project-detail-progress span{
  display:block;
  height:100%;
  max-width:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--xbct-primary,#f97316),#fb923c);
}
.xbca-project-detail-line{
  display:grid;
  gap:6px;
  margin:0;
  color:#475569;
  line-height:1.55;
}
.xbca-project-detail-line strong{
  color:#0f172a;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.xbca-project-detail-section{
  padding:clamp(20px,3vw,30px);
}
.xbca-project-detail-section-head{
  display:grid;
  gap:7px;
  margin:0 0 18px;
}
.xbca-project-detail-section-head h2{
  font-size:clamp(1.5rem,3vw,2.2rem);
}
.xbca-project-detail-content{
  color:#334155;
  line-height:1.75;
}
.xbca-project-task-grid,
.xbca-project-vendor-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.xbca-project-task-card,
.xbca-project-vendor-card{
  display:grid;
  gap:12px;
  padding:18px;
  border:1px solid rgba(148,163,184,.28);
  border-radius:20px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  box-shadow:0 12px 28px rgba(15,23,42,.06);
}
.xbca-project-task-card h3,
.xbca-project-vendor-card h3{
  margin:0;
  color:#0f172a;
  font-size:1.08rem;
  line-height:1.25;
}
.xbca-project-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.xbca-project-chip-row span{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:5px 9px;
  background:#fff7ed;
  color:#9a3412;
  font-size:12px;
  font-weight:900;
}
.xbca-project-detail-files{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  list-style:none;
  margin:0;
  padding:0;
}
.xbca-project-detail-files a{
  display:block;
  padding:12px 14px;
  border:1px solid rgba(148,163,184,.28);
  border-radius:14px;
  background:#f8fafc;
  color:#0f172a!important;
  font-weight:800;
  text-decoration:none!important;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.xbca-project-detail-files a:hover{
  color:var(--xbct-primary,#f97316)!important;
  border-color:rgba(249,115,22,.38);
  background:#fff7ed;
}
.xbca-project-detail-summary .xbca-client-project-upload{
  margin:0;
}
@media(max-width:1050px){
  .xbca-project-detail-hero{grid-template-columns:1fr;}
  .xbca-project-task-grid,.xbca-project-vendor-grid,.xbca-project-detail-files{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:640px){
  .xbca-client-project-upload button{width:100%;}
  .xbca-project-detail-shell{gap:18px;}
  .xbca-project-detail-hero{gap:18px;}
  .xbca-project-detail-media,.xbca-project-detail-summary,.xbca-project-detail-section{border-radius:22px;}
  .xbca-project-task-grid,.xbca-project-vendor-grid,.xbca-project-detail-files{grid-template-columns:1fr;}
  .xbca-project-detail-metrics{grid-template-columns:1fr;}
  .xbca-project-detail-media .xbca-project-media-single,.xbca-project-detail-media .xbca-project-media-single .xbca-project-media-slide{min-height:230px;}
}


/* v2.7.37: contract/change-order client portal signing decision UI. */
.xbca-sign-decision{margin-top:14px;padding:15px;border:1px solid rgba(148,163,184,.28);border-radius:18px;background:#fff;display:grid;gap:12px;}
.xbca-sign-question{display:grid;gap:4px;margin:0;color:#0f172a;}
.xbca-sign-question span{color:#64748b;font-size:.94rem;line-height:1.45;}
.xbca-sign-choice-buttons{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.xbca-sign-choice-panel{margin-top:4px!important;border-top:1px solid #e5e7eb;padding-top:14px;}
.xbca-sign-choice-panel[hidden]{display:none!important;}
.xbca-client-portal-modern .xbca-sign-decision .xbca-portal-button{margin:0;}

/* v2.7.39 subcontractor portal workflow */
.xbca-subcontractor-portal .xbca-portal-client{border:1px solid #e5e7eb;border-radius:24px;padding:22px;margin:22px 0;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 16px 36px rgba(15,23,42,.08)}
.xbca-subcontractor-portal .xbca-portal-list{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:stretch}
.xbca-sub-task-card{display:flex;flex-direction:column;gap:8px;background:#fff;border-color:#dbe3ef;box-shadow:0 10px 24px rgba(15,23,42,.06)}
.xbca-sub-task-actions{display:grid;gap:12px;margin-top:auto;padding-top:12px;border-top:1px solid #e5e7eb}
.xbca-sub-task-update-form{display:grid;gap:10px;margin:0;padding:12px;border:1px solid #e5e7eb;border-radius:16px;background:#f8fafc}
.xbca-sub-task-update-form textarea{width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:11px 12px;resize:vertical;min-height:92px;background:#fff}
.xbca-inline-action-form{margin:0}.xbca-secondary-button{background:#111827!important;color:#fff!important}.xbca-portal-notice{background:#ecfdf5;border:1px solid #bbf7d0;color:#166534;border-radius:14px;padding:12px 14px}.xbca-portal-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:14px;padding:12px 14px}

/* v2.7.40 employee + distributor guided task portals */
/* v2.7.41 settings-based emails and payment/accounting connections */
.xbca-workforce-portal .xbca-portal-client,
.xbca-employee-portal .xbca-portal-client{border:1px solid #e5e7eb;border-radius:24px;padding:22px;margin:22px 0;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 16px 36px rgba(15,23,42,.08)}
.xbca-workforce-task-list{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:stretch}
.xbca-workforce-task-card{min-height:100%}
.xbca-workforce-task-actions .xbca-portal-button{width:100%}
.xbca-workforce-task-update-form label{display:grid;gap:8px}
.xbca-distributor-portal .xbca-portal-list,
.xbca-employee-portal .xbca-workforce-task-list{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:stretch}

/* XoBytes modern front-end portal login */
.xbca-login-shell{--xbca-login-brand:#f97316;max-width:980px;margin:34px auto;padding:18px;display:flex;justify-content:center;font-family:inherit}.xbca-login-card{width:min(100%,520px);position:relative;overflow:hidden;border:1px solid rgba(226,232,240,.95);border-radius:30px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);box-shadow:0 24px 70px rgba(15,23,42,.16);padding:34px}.xbca-login-card:before{content:"";position:absolute;inset:-140px -160px auto auto;width:320px;height:320px;border-radius:999px;background:radial-gradient(circle, color-mix(in srgb,var(--xbca-login-brand) 28%, transparent), transparent 66%);pointer-events:none}.xbca-login-brand-block{position:relative;text-align:center;margin-bottom:24px}.xbca-login-logo{display:block;width:auto;max-width:190px;max-height:86px;margin:0 auto 16px;object-fit:contain}.xbca-login-logo-fallback{width:76px;height:76px;margin:0 auto 16px;border-radius:24px;display:grid;place-items:center;background:linear-gradient(135deg,var(--xbca-login-brand),#111827);color:#fff;font-weight:900;font-size:2rem;box-shadow:0 16px 34px rgba(15,23,42,.18)}.xbca-login-kicker{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(15,23,42,.08);border-radius:999px;padding:7px 12px;background:#fff;color:#64748b;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.xbca-login-brand-block h2{font-size:clamp(1.8rem,4vw,2.45rem);line-height:1.05;margin:14px 0 10px;color:#0f172a}.xbca-login-brand-block p{margin:0 auto;color:#64748b;font-size:1rem;line-height:1.55;max-width:38rem}.xbca-modern-login-form{position:relative;display:grid;gap:16px}.xbca-modern-login-form label{display:grid;gap:7px;color:#0f172a;font-weight:800}.xbca-modern-login-form label span{font-size:.9rem}.xbca-modern-login-form input[type="text"],.xbca-modern-login-form input[type="password"]{width:100%;box-sizing:border-box;border:1px solid #dbe3ee;border-radius:16px;background:#fff;padding:14px 15px;font-size:1rem;color:#0f172a;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.xbca-modern-login-form input[type="text"]:focus,.xbca-modern-login-form input[type="password"]:focus{border-color:var(--xbca-login-brand);box-shadow:0 0 0 4px color-mix(in srgb,var(--xbca-login-brand) 18%, transparent)}.xbca-login-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.92rem}.xbca-login-row a,.xbca-login-small a{color:#0f172a;font-weight:800;text-decoration:none}.xbca-login-row a:hover,.xbca-login-small a:hover{text-decoration:underline}.xbca-login-remember{display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;gap:8px!important;color:#475569!important;font-weight:700!important}.xbca-login-remember input{margin:0}.xbca-login-submit{width:100%;border:none;border-radius:18px;padding:15px 18px;background:linear-gradient(135deg,var(--xbca-login-brand),#111827);color:#fff!important;font-weight:900;font-size:1rem;cursor:pointer;text-align:center;text-decoration:none;box-shadow:0 16px 34px color-mix(in srgb,var(--xbca-login-brand) 22%, rgba(15,23,42,.18));transition:transform .18s ease,box-shadow .18s ease}.xbca-login-submit:hover{transform:translateY(-1px);box-shadow:0 20px 42px rgba(15,23,42,.22);text-decoration:none}.xbca-login-link-button{display:block;margin-top:16px}.xbca-login-notice{position:relative;margin:0 0 16px;border-radius:16px;padding:12px 14px;font-weight:800;font-size:.95rem}.xbca-login-notice-good{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.xbca-login-notice-bad{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.xbca-login-portal-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:18px 0 0}.xbca-login-portal-links a{display:flex;align-items:center;justify-content:center;min-height:44px;border:1px solid #e2e8f0;border-radius:15px;background:#fff;color:#0f172a;text-decoration:none;font-weight:850;text-align:center;padding:8px 10px}.xbca-login-portal-links a:hover{border-color:var(--xbca-login-brand);box-shadow:0 10px 22px rgba(15,23,42,.08)}.xbca-login-small{margin:18px 0 0;text-align:center;color:#64748b;font-size:.92rem;line-height:1.5}@media(max-width:640px){.xbca-login-shell{margin:18px auto;padding:10px}.xbca-login-card{border-radius:24px;padding:24px 18px}.xbca-login-portal-links{grid-template-columns:1fr}.xbca-login-row{align-items:flex-start;flex-direction:column}}
