/**
 * UrbanFiling — responsive.css v24
 * Upload widget · card alignment · form fixes · breakpoints · success/toast
 * Applied AFTER style.css
 */

/* ══ GLOBAL CARD ALIGNMENT ══════════════════════════════════════════ */
.svc-grid,.insights-grid,.why-grid,.testi-grid,.calc-grid,.emp-grid,.quick-grid,.related-articles-grid { align-items:stretch; }
.svc-card,.insight-card,.why-card,.wc,.emp-card,.testi-card,.calc-card,.related-card,.alert-card {
  display:flex; flex-direction:column; height:100%; min-height:0; box-sizing:border-box;
}
.card-body,.insight-card-body { flex:1 1 auto; min-height:0; }
.card-footer,.insight-card-footer { margin-top:auto; flex-shrink:0; }

/* svc-icon-card: square icons guaranteed */
.svc-icon-card { display:flex; flex-direction:column; height:100%; min-height:0; overflow:visible; }
.svc-icon-card .si,.svc-icon-card .sic-icon {
  width:48px; height:48px; min-width:48px; min-height:48px; aspect-ratio:1;
  display:flex; align-items:center; justify-content:center;
  border-radius:12px; font-size:1.4rem; flex-shrink:0;
}

/* ══ GREEN STRIP / lf-card::before FIX ═══════════════════════════════
   Fixes the slightly-left-tilted "Secure & Confidential" badge
   on the homepage enquiry form card. Cause: left:50% with translateX
   was fine but card had no explicit width → parent grid caused 1px drift.
   Fix: use margin:auto + position instead of left+transform trick.
   ════════════════════════════════════════════════════════════════════ */
.lf-card {
  position: relative;
  overflow: visible !important;
}
.lf-card::before {
  content: '🔒 Secure & Confidential';
  position: absolute;
  top: -13px;
  left: 0;
  right: 0;
  width: max-content;
  max-width: 100%;
  margin: 0 auto;
  /* Replace left:50% + translateX with inset-based centering */
  left: 50%;
  transform: translateX(-50%);
  /* Force pixel-perfect centering regardless of card width */
  transform: translateX(calc(-50% + 0.5px));
  background: var(--teal,#00B4A6);
  color: #fff;
  font-size: 0.64rem;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 10px;
  white-space: nowrap;
  /* Ensure no sub-pixel rendering drift */
  backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.01em;
}

/* ══ FORM FIELDS — CONSISTENT ════════════════════════════════════════ */
.fg,.form-group,.ins-fg,.hf-group { display:flex; flex-direction:column; gap:5px; width:100%; }
.fg label,.form-group label,.ins-fg label,.hf-group label {
  font-weight:700; font-size:0.78rem; color:var(--navy,#0C1F35); display:block;
}
.fg input,.fg select,.fg textarea,
.form-group input,.form-group select,.form-group textarea,
.ins-fg input,.ins-fg select,.ins-fg textarea,
.hf-group input,.hf-group select,.hf-group textarea {
  padding:11px 14px; border:1.5px solid var(--border,#D1D9E0);
  border-radius:10px; font-size:0.87rem; color:var(--text,#1A2E42);
  background:#fff; outline:none; width:100%; box-sizing:border-box;
  transition:border-color .18s,box-shadow .18s;
}
.fg input:focus,.form-group input:focus,.ins-fg input:focus,.hf-group input:focus,
.fg select:focus,.form-group select:focus,.ins-fg select:focus,
.fg textarea:focus,.form-group textarea:focus,.ins-fg textarea:focus { border-color:var(--p,#0B6E84); box-shadow:0 0 0 3px rgba(11,110,132,.1); }
.fg input.uf-field-err,.form-group input.uf-field-err,.ins-fg input.uf-field-err { border-color:#E53935 !important; box-shadow:0 0 0 3px rgba(229,57,53,.1) !important; }
.err-msg,.error-msg { font-size:0.72rem; color:#E53935; font-weight:600; display:none; margin-top:2px; }
.has-error .err-msg,.has-error .error-msg { display:block; }

/* form-grid standard */
.form-grid,.apply-form { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-grid .full,.apply-form .form-group.full,.form-grid.full { grid-column:1/-1; }

/* ══ DOCUMENT UPLOAD WIDGET ══════════════════════════════════════════ */
.uf-upload-label {
  font-size:0.78rem; font-weight:700; color:var(--navy,#0C1F35);
  margin-bottom:8px; display:flex; align-items:center; flex-wrap:wrap; gap:6px;
}
.uf-opt { font-weight:500; color:var(--slate,#475569); font-size:0.7rem; }
.uf-upload {
  border:2px dashed var(--border,#D1D9E0); border-radius:14px;
  padding:20px 16px; text-align:center; cursor:pointer;
  background:linear-gradient(135deg,rgba(11,110,132,.03),rgba(0,180,166,.02));
  transition:border-color .2s,background .2s; outline:none;
}
.uf-upload:hover,.uf-upload.uf-drag { border-color:var(--p,#0B6E84); border-style:solid; background:rgba(11,110,132,.04); }
.uf-drop-ico {
  width:44px; height:44px; border-radius:12px; margin:0 auto 8px;
  background:linear-gradient(135deg,var(--p,#0B6E84),var(--teal,#00B4A6));
  display:flex; align-items:center; justify-content:center; font-size:1.3rem;
  box-shadow:0 3px 12px rgba(11,110,132,.25);
}
.uf-drop-title { font-weight:700; font-size:0.85rem; color:var(--navy,#0C1F35); margin-bottom:4px; }
.uf-drop-hint { font-size:0.72rem; color:var(--slate,#475569); line-height:1.5; margin-bottom:8px; }
.uf-browse-btn {
  background:linear-gradient(135deg,var(--p,#0B6E84),var(--teal,#00B4A6));
  color:#fff; border:none; border-radius:50px; padding:8px 16px;
  font-size:0.76rem; font-weight:700; cursor:pointer; transition:opacity .18s;
}
.uf-browse-btn:hover { opacity:.88; }
.uf-filelist { display:flex; flex-direction:column; gap:8px; margin-top:12px; }
.uf-file {
  display:flex; align-items:center; gap:10px; background:#fff;
  border:1.5px solid var(--border,#D1D9E0); border-radius:10px; padding:9px 12px;
  animation:ufFileIn .2s ease;
}
@keyframes ufFileIn { from{opacity:0;transform:translateY(-4px)} to{opacity:1;transform:translateY(0)} }
.uf-fi { width:32px; height:32px; min-width:32px; border-radius:8px; background:rgba(11,110,132,.08); display:flex; align-items:center; justify-content:center; font-size:.95rem; flex-shrink:0; }
.uf-fn { flex:1; min-width:0; }
.uf-fname { font-size:.8rem; font-weight:600; color:var(--navy,#0C1F35); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uf-fsize { font-size:.68rem; color:var(--slate,#475569); margin-top:1px; }
.uf-fbar { height:3px; background:var(--border,#D1D9E0); border-radius:2px; margin-top:4px; overflow:hidden; }
.uf-fbar-fill { height:100%; background:linear-gradient(90deg,var(--p,#0B6E84),var(--teal,#00B4A6)); border-radius:2px; }
.uf-fdel { background:none; border:none; color:var(--slate,#475569); cursor:pointer; font-size:.9rem; padding:4px 6px; border-radius:6px; flex-shrink:0; }
.uf-fdel:hover { background:#FFEBEE; color:#E53935; }
.uf-err { display:none; align-items:center; gap:6px; background:#FFEBEE; border-left:3px solid #E53935; border-radius:8px; padding:9px 12px; margin-top:8px; font-size:.75rem; font-weight:600; color:#C62828; }
.uf-err.show { display:flex; }
.uf-strip { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:10px; padding-top:10px; border-top:1px solid rgba(11,110,132,.1); }
.uf-strip-item { font-size:.68rem; color:var(--slate,#475569); }
.uf-total { margin-left:auto; font-size:.71rem; font-weight:700; color:var(--slate,#475569); }
.uf-total.uf-over { color:#E53935; }

/* Upload container wrappers */
#enquiryUploadWrap,#contactUploadWrap,#regUploadWrap,#careerUploadWrap,#insUploadWrap,
[id$="UploadWrap"] { grid-column:1/-1; margin-top:6px; }

/* ══ SUCCESS CARD ═════════════════════════════════════════════════════ */
.uf-success-card { text-align:center; padding:36px 24px; background:linear-gradient(135deg,rgba(11,110,132,.04),rgba(0,180,166,.03)); border:1.5px solid rgba(11,110,132,.12); border-radius:20px; animation:ufSuccIn .4s ease; }
@keyframes ufSuccIn { from{opacity:0;transform:scale(.96)} to{opacity:1;transform:scale(1)} }
.uf-si { font-size:3rem; margin-bottom:12px; display:block; }
.uf-success-card h3 { font-size:1.25rem; font-weight:800; color:var(--navy,#0C1F35); margin-bottom:8px; }
.uf-success-card p  { font-size:.88rem; color:var(--slate,#475569); line-height:1.6; margin-bottom:18px; }
.uf-ref { display:inline-flex; flex-direction:column; align-items:center; background:rgba(11,110,132,.07); border:1px solid rgba(11,110,132,.15); border-radius:12px; padding:10px 22px; margin-bottom:20px; }
.uf-ref span   { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--slate,#475569); margin-bottom:4px; }
.uf-ref strong { font-size:1.1rem; font-weight:900; color:var(--p,#0B6E84); }
.uf-sa  { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
.uf-wa  { background:#25D366; color:#fff; padding:10px 20px; border-radius:50px; text-decoration:none; font-weight:700; font-size:.82rem; }
.uf-call{ background:var(--navy,#0C1F35); color:#fff; padding:10px 20px; border-radius:50px; text-decoration:none; font-weight:700; font-size:.82rem; }

/* ══ TOAST ════════════════════════════════════════════════════════════ */
.uf-toast {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(80px);
  opacity:0; background:var(--navy,#0C1F35); color:#fff; font-size:.85rem; font-weight:600;
  padding:13px 22px; border-radius:50px; box-shadow:0 8px 32px rgba(0,0,0,.2);
  z-index:9999; max-width:420px; width:90vw; text-align:center;
  transition:transform .3s,opacity .3s; pointer-events:none;
}
.uf-toast.show  { transform:translateX(-50%) translateY(0); opacity:1; pointer-events:auto; }
.uf-toast.success { border-left:4px solid #22c55e; }
.uf-toast.error   { border-left:4px solid #E53935; }
.uf-toast.info    { border-left:4px solid var(--teal,#00B4A6); }

/* ══ BUTTON SPINNER ══════════════════════════════════════════════════ */
.uf-spin { display:inline-block; width:16px; height:16px; border:2px solid rgba(255,255,255,.35); border-top-color:#fff; border-radius:50%; animation:ufSpin .7s linear infinite; vertical-align:middle; margin-right:6px; }
@keyframes ufSpin { to{ transform:rotate(360deg); } }

/* ══ RESPONSIVE BREAKPOINTS ══════════════════════════════════════════ */
@media(max-width:1024px){
  .svc-grid { grid-template-columns:repeat(2,1fr) !important; }
  .insights-grid { grid-template-columns:repeat(2,1fr); }
  .testi-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:28px; }
  .hero-inner { grid-template-columns:1fr !important; }
  .form-grid,.apply-form { grid-template-columns:1fr; }
  .featured-article,.article-layout,.insights-layout { grid-template-columns:1fr !important; }
  .insights-sidebar,.article-sidebar { display:none; }
}
@media(max-width:768px){
  .nav-links,.btn-consult { display:none !important; }
  .hamburger { display:flex !important; }
  .sec { padding:52px 18px; }
  .page-hero { padding:36px 18px 48px; }
  .cta-sec  { padding:52px 18px; }
  .trust-bar { padding:10px 16px; }
  .topbar   { padding:6px 18px; }
  .svc-grid { grid-template-columns:1fr 1fr !important; gap:12px !important; }
  #svc-grid { grid-template-columns:repeat(2,1fr) !important; }
  .insights-grid { grid-template-columns:1fr !important; }
  .testi-grid    { grid-template-columns:1fr !important; }
  .footer-grid   { grid-template-columns:1fr !important; }
  .form-grid,.apply-form { grid-template-columns:1fr !important; }
  .hero-inner { padding:0 20px !important; gap:32px !important; }
  .hero h1 { font-size:1.85rem !important; }
  .hero-btns { flex-direction:column; gap:10px; }
  .hb-primary,.hb-secondary { justify-content:center; }
  .uf-footer .footer-inner { padding:44px 18px 28px; }
  .call-float { display:none !important; }
  .wa-float   { bottom:18px; right:18px; width:48px; height:48px; font-size:1.25rem; }
  .card-footer { flex-direction:column; gap:10px; }
  .card-footer .btn-apply { width:100%; text-align:center; }
  .lf-card { padding:22px 18px; }
  .uf-strip { flex-direction:column; align-items:flex-start; }
  .uf-total { margin-left:0; }
}
@media(max-width:480px){
  .svc-grid,#svc-grid { grid-template-columns:1fr 1fr !important; gap:10px !important; }
  .hero h1 { font-size:1.65rem !important; }
  .hero-stats { gap:16px; }
  .hs .n { font-size:1.25rem; }
  .svc-icon-card { padding:14px 10px; }
  .svc-icon-card .si,.svc-icon-card .sic-icon { width:38px; height:38px; min-width:38px; min-height:38px; font-size:1.15rem; border-radius:9px; }
  .svc-icon-card h4 { font-size:.68rem; }
  .svc-icon-card .price { font-size:.63rem; }
  .page-hero h1 { font-size:1.55rem !important; }
  .cta-sec h2 { font-size:1.4rem; }
  .sec-hd h2 { font-size:1.45rem; }
  .card-body { padding:18px 16px 0; }
}
@media(max-width:360px){
  .svc-grid,#svc-grid { grid-template-columns:1fr 1fr !important; gap:8px !important; }
  .svc-icon-card { padding:11px 8px; }
}
@media print {
  nav,.topbar,.wa-float,.call-float,.mobile-nav,.hamburger,.cta-sec,.hero-search-wrap { display:none !important; }
  body { font-size:12pt; color:#000; }
  .svc-grid { grid-template-columns:repeat(3,1fr) !important; }
}
