@charset "UTF-8";
/*
Theme Name: Tenreiro Law
Theme URI: https://www.ten.law/
Author: Tenreiro Law LLC
Author URI: https://www.ten.law/
Description: A professional immigration law theme with LGBTQ+ focus, featuring a modern design with hero sections, stats, services, and consultation assessment tool.
Version: 1.2.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: tenreiro-law
Tags: legal, immigration, professional, business, one-column, custom-menu, featured-images
*/

/* ==========================
   GLOBAL TOKENS
========================== */
:root{
  --navy:#0C233D;
  --deep:#0A192D;
  --lightband:#15325a;

  --cream:#F8F6F4;
  --ink:#111;
  --muted:#475569;
  --line:#E6E6E6;

  --blue:#3AA0FF;
  --celery:#8FB63E;
  --celery-dark:#7AA32F;

  --max:1150px;
  --pad:22px;
  --section-pad:80px;

  --cardShadow:0 10px 28px rgba(13,34,61,.08);
}

/* ==========================
   BASE
========================== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
a{color:var(--navy);text-decoration:none}

.container{max-width:var(--max);margin-inline:auto;padding-inline:var(--pad)}
.inner{max-width:var(--max);margin-inline:auto;padding-inline:var(--pad)}

section:not(.hero):not(.stats-band):not(.quote){padding:var(--section-pad) 0}
section{padding:var(--section-pad) 0}

.sr-only{
  position:absolute;
  left:-9999px;
  width:1px;height:1px;
  overflow:hidden;
}

/* ==========================
   BUTTONS
========================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;

  padding:14px 22px;
  border-radius:999px;
  font-weight:800;
  border:1.5px solid transparent;
  cursor:pointer;
  line-height:1;
  text-align:center;

  transition:background .2s,border-color .2s,color .2s,transform .15s;
}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:3px solid var(--blue);outline-offset:2px}

.btn.blue{background:var(--blue);border-color:var(--blue);color:#fff}
.btn.blue:hover{background:var(--celery);border-color:var(--celery);color:#0C233D}

.btn.clear{background:transparent;border-color:#fff;color:#fff}
.btn.clear:hover{background:rgba(255,255,255,0.08)}

.btn.outline{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn.outline:hover{background:var(--celery);border-color:var(--celery);color:#0C233D}

.btn.small{padding:10px 14px;font-weight:900}

/* ==========================
   HEADER / NAV
========================== */
header{
  position:sticky;
  top:0;
  z-index:50;
  background:#fff;
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease;
}
header.elevated{box-shadow:0 4px 20px rgba(0,0,0,.08)}

.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px var(--pad);
  gap:12px;
}
.brand img{height:34px;width:auto}

.navlinks{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
}
.navlinks>a:not(.btn){
  position:relative;
  padding:8px 2px;
  font-weight:800;
}
.navlinks>a:not(.btn)::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-2px;
  height:2px;
  width:0;
  background:var(--navy);
  transition:width .25s ease;
}
.navlinks>a:not(.btn):hover::after,
.navlinks>a:not(.btn):focus-visible::after{width:100%}

.navlinks .btn.nav-cta{background:var(--blue);border-color:var(--blue);color:#fff}
.navlinks .btn.nav-cta.scrolled{background:var(--celery);border-color:var(--celery);color:#0C233D}

.navlinks .btn.pay{background:transparent;border-color:var(--navy);color:var(--navy)}
.navlinks .btn.pay:hover{background:var(--celery);border-color:var(--celery);color:#0C233D}

/* Mobile menu button */
.menu-btn{
  display:none;
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  padding:10px 12px;
  line-height:0;
  cursor:pointer;
}
.menu-btn svg{width:22px;height:22px;color:var(--navy)}
.menu-btn:focus-visible{outline:3px solid var(--blue);outline-offset:2px}

/* Mobile drawer */
.mobile-drawer{
  display:none;
  border-top:1px solid var(--line);
  background:#fff;
}
.mobile-drawer.open{display:block}
.mobile-links{
  display:grid;
  gap:10px;
  padding:14px var(--pad) 18px;
}
.mobile-links a:not(.btn){
  padding:10px 8px;
  border-radius:10px;
  background:#f8fafc;
  border:1px solid #eef2f7;
  font-weight:800;
}
.mobile-links .btn{width:100%}

/* ==========================
   HOME HERO (full-bleed image)
========================== */
.hero{
  position:relative;
  min-height:82vh;
  color:#fff;
  display:flex;
  align-items:center;
  background:var(--navy);
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to right,
      rgba(7,18,35,0.05) 0%,
      rgba(7,18,35,0.20) 20%,
      rgba(7,18,35,0.45) 50%,
      rgba(7,18,35,0.70) 75%,
      rgba(7,18,35,0.85) 100%
    ),
    url("/wp-content/uploads/2026/01/HeroImage.webp") left center/cover no-repeat;
  z-index:0;
}
.hero-inner{
  position:relative;
  z-index:1;
  max-width:720px;
  padding:80px var(--pad);
  margin-left:auto;
}
.hero-card{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  border-radius:18px;
  padding:26px;
  backdrop-filter:blur(8px);
}
.hero h1{
  font-family:Poppins,sans-serif;
  font-weight:900;
  font-size:clamp(40px,8vw,84px);
  margin:0 0 16px;
}
.hero p{
  font-size:clamp(16px,3.6vw,22px);
  margin:0 0 24px;
}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}

/* ==========================
   STATS
========================== */
.stats-band{
  background:linear-gradient(135deg,var(--navy),var(--lightband) 65%);
  color:#fff;
  text-align:center;
  padding:var(--section-pad) 0;
}
.stats-band > * {
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}
.stats-grid{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
}
.stat-card{
  border:1px solid #113058;
  background:#0b1f39;
  border-radius:14px;
  padding:16px;
  color:#BEE0FF;
}
.stat-num{font-weight:900;font-size:32px;margin-bottom:6px}
.stat-lbl{font-size:13px;opacity:.95}
.stats-foot{margin-top:10px;font-size:12px;opacity:.8;color:#BEE0FF}

/* ==========================
   SECTION TITLES
========================== */
.section-title{
  font-family:Poppins,sans-serif;
  font-size:clamp(28px,4.5vw,42px);
  margin:0 0 10px;
  color:var(--navy);
}
.section-sub{
  color:#334155;
  margin:0 0 16px;
  font-size:18px;
  line-height:1.7;
}

/* ==========================
   TEAM (About section on home)
========================== */
#about > * {
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

#about .header-row{
  display:flex;
  align-items:flex-end;
  gap:14px;
  margin-bottom:12px;
  flex-wrap:wrap;
}
#about .header-row .spacer{flex:1}

#about .team-banner{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#0b1f39;
  min-height:360px;
}
#about .team-banner .photo{
  position:absolute;
  top:0;right:0;bottom:0;
  width:min(45%,520px);
  background:url('https://www.ten.law/wp-content/uploads/2022/06/profile_george.jpg') center right / cover no-repeat;
  -webkit-mask-image: linear-gradient(to left,
    rgba(0,0,0,1) 66%, rgba(0,0,0,.95) 72%, rgba(0,0,0,.8) 78%,
    rgba(0,0,0,.55) 84%, rgba(0,0,0,.3) 90%, rgba(0,0,0,0) 100%);
  mask-image: linear-gradient(to left,
    rgba(0,0,0,1) 66%, rgba(0,0,0,.95) 72%, rgba(0,0,0,.8) 78%,
    rgba(0,0,0,.55) 84%, rgba(0,0,0,.3) 90%, rgba(0,0,0,0) 100%);
  filter:contrast(1.02) saturate(1.02) blur(.15px);
}
#about .team-banner .blend{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(12,35,61,.94) 0%, rgba(12,35,61,.72) 35%, rgba(12,35,61,.36) 67%, rgba(12,35,61,0) 92%);
  mix-blend-mode:multiply;
}
#about .team-banner::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:44%;
  background:linear-gradient(0deg, rgba(12,35,61,0.45), rgba(12,35,61,0));
  pointer-events:none;
}
.team-banner .copy{
  position:absolute;
  top:22px;left:22px;right:24px;
  z-index:1;
  color:#fff;
  max-width:min(720px,66%);
}
.team-banner h3{margin:0 0 6px;font-size:30px;line-height:1.1}
.team-banner p{margin:0 0 8px;color:#E7F2FF;font-weight:600}
.team-banner .bio{margin:10px 0 12px;color:#DCEBFF;font-weight:600;line-height:1.55}

.team-grid{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin-top:16px;
}
.team-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  transition:all .25s;
  box-shadow:0 10px 22px rgba(13,34,61,.06);
  display:flex;
  flex-direction:column;
}
.team-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 34px rgba(13,34,61,.14);
}
.team-photo{width:100%;aspect-ratio:4/5;object-fit:cover}
.team-body{padding:14px}
.team-name{font-weight:900;color:var(--navy);margin:0 0 4px}
.team-role{color:#334155;font-weight:750;margin:0}

.team-more{
  padding:0 14px 16px;
  color:#475569;
  font-weight:500;
  line-height:1.75;
  font-size:14.5px;
}

.team-meta{
  margin-top:auto;
  padding:12px 14px 14px;
  border-top:1px solid #eef2f7;
  background:#fafafa;
  color:#334155;
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between;
}
.contact-icons{display:flex;gap:10px;align-items:center}
.icon-link{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:12px;
  border:1px solid #e8eef7;background:#fff;
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
  color:#0C233D;
}
.icon-link:hover{transform:translateY(-1px);border-color:#B3DCFF;box-shadow:0 10px 18px rgba(13,34,61,.08)}
.icon-link svg{width:18px;height:18px}

/* ==========================
   SERVICES (Home section)
========================== */
#services > * {
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

.services-header{
  margin-bottom:16px;
  text-align:left;
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:flex-end;
}
.services-header .section-title{
  font-size:clamp(32px,6vw,52px);
  margin:0;
}
.services-header .section-sub{flex-basis:100%}
.services-header .actions{margin-left:auto}

.services-scroll-wrapper{
  position:relative;
  margin:24px 0 10px;
  margin-left:calc(-1 * var(--pad));
  margin-right:calc(-1 * var(--pad));
  padding-left:0;
  padding-right:0;
}
.services-scroll-container{
  display:flex;
  gap:24px;
  overflow-x:auto;
  scroll-behavior:smooth;
  padding:8px var(--pad) 16px var(--pad);
  scrollbar-width:none;
  scroll-snap-type:x mandatory;
}
.services-scroll-container::-webkit-scrollbar{display:none}

.service-card{
  flex:0 0 360px;
  background:#fff;
  border:1.5px solid var(--line);
  border-radius:18px;
  padding:32px;
  position:relative;
  overflow:hidden;
  transition:all .4s cubic-bezier(.34,1.56,.64,1);
  display:flex;
  flex-direction:column;
  min-height:420px;
  scroll-snap-align:start;
}
.service-card::before{
  content:'';
  position:absolute;
  top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(58,160,255,.08),transparent);
  transition:left .6s ease;
  pointer-events:none;
}
.service-card:hover::before{left:100%}
.service-card:hover{
  border-color:var(--blue);
  box-shadow:0 20px 50px rgba(13,34,61,.15);
  transform:translateY(-6px);
}

.service-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;height:44px;
  background:linear-gradient(135deg,var(--blue),#1e7be8);
  color:#fff;
  border-radius:12px;
  font-weight:900;
  font-size:20px;
  margin-bottom:16px;
}
.service-card h3{
  font-family:Poppins,sans-serif;
  font-size:22px;
  font-weight:900;
  margin:0 0 12px;
  color:var(--navy);
}
.service-card p{
  color:#475569;
  font-size:15px;
  line-height:1.7;
  margin:0 0 18px;
  flex-grow:1;
}
.service-features{margin:8px 0 0;padding:0;list-style:none}
.service-features li{
  padding-left:22px;
  margin-bottom:10px;
  font-size:14px;
  color:#334155;
  position:relative;
  line-height:1.5;
}
.service-features li::before{
  content:'\25B8';
  position:absolute;
  left:4px;
  color:#3AA0FF;
  font-weight:900;
  font-size:18px;
}

.scroll-controls{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:10px;
  padding-left:var(--pad);
  padding-right:var(--pad);
}
.scroll-controls .btn{min-width:44px;min-height:44px}

/* ==========================
   QUOTE BAND
========================== */
.quote{
  background:linear-gradient(135deg,var(--navy),var(--lightband)65%);
  color:#fff;
  text-align:center;
  padding:var(--section-pad) 0;
}
.quote > * {
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}
.quote h2{
  font-family:Poppins,sans-serif;
  font-size:clamp(26px,5.2vw,44px);
  margin:0 auto;
  text-align:center;
}

/* ==========================
   REVIEWS (Home section)
========================== */
#reviews > * {
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

#reviews .header-row{
  display:flex;
  align-items:flex-end;
  gap:14px;
  margin-bottom:12px;
  flex-wrap:wrap;
}
#reviews .header-row .spacer{flex:1}

.reviews{background:#fff}
.review-grid{
  display:grid;
  gap:24px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.review{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:20px;
  box-shadow:0 4px 14px rgba(13,34,61,.06);
}
.stars{color:#f59e0b;font-weight:900}
.who{color:#334155;font-weight:800;margin-top:10px}

/* ==========================
   CONTACT
========================== */
#contact > * {
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

.contact{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:start;
}
.map iframe{
  width:100%;
  height:100%;
  min-height:320px;
  border:0;
  border-radius:18px;
}

/* ==========================
   FOOTER
========================== */
footer{
  padding:var(--section-pad) 0;
  text-align:center;
  background:#fff;
  border-top:1px solid var(--line);
  color:#666;
}
footer > * {
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}
.social{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:10px;
}
.social a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  color:#0c233d;
  background:#fff;
}
.social svg{width:16px;height:16px}

/* ==========================
   TRANSLATE DOCK
========================== */
#translate-dock{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:999;
  background:#0b1f39;
  border:1px solid #113058;
  border-radius:12px;
  padding:8px 10px;
  color:#BEE0FF;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
#translate-dock label{font-size:12px;display:block;margin-bottom:6px}
#google_translate_element{transform:scale(.9);transform-origin:100% 100%}
.goog-logo-link,.goog-te-gadget span{display:none!important}

/* ==========================
   CASE ASSESSMENT WIDGET
========================== */
#ca-widget{
  background:#fff;
  margin:0 auto;
  padding:34px 28px;
  border:1px solid var(--line);
  border-radius:18px;
  max-width:var(--max);
}

@media (max-width: 760px) {
  #ca-widget {
    margin-left:var(--pad) !important;
    margin-right:var(--pad) !important;
    max-width:calc(100% - (var(--pad) * 2)) !important;
    padding-left: var(--pad) !important;
    padding-right: var(--pad) !important;
  }
  
  /* If the heading/lead is OUTSIDE #ca-widget, this catches common wrappers */
  section:has(#ca-widget){
    padding-left: var(--pad) !important;
    padding-right: var(--pad) !important;
  }
  
  /* Catch all common wrapper class names */
  .ca-wrap, .case-assessment-wrap, .case-assessment, #case-assessment{
    padding-left: var(--pad) !important;
    padding-right: var(--pad) !important;
  }
}
#ca-widget h2{font-weight:900;color:var(--navy);margin:0 0 6px;font-size:28px}
#ca-widget p.lead{margin:0 0 14px;color:#333}
#ca-widget .notice{
  background:#F6FBFF;
  border:1px solid #CDE6FF;
  color:#0C233D;
  border-radius:12px;
  padding:12px 14px;
  font-size:14px;
  margin:10px 0;
}
.ca-progress{height:8px;background:#f3f4f6;border-radius:999px;overflow:hidden;margin:8px 0 18px}
.ca-progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),#8AC7FF);transition:width .3s}
.ca-step{display:none}
.ca-step.active{display:block;animation:fade .18s ease-in}
@keyframes fade{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}}
.ca-q{font-weight:900;margin:0 0 8px;color:var(--navy)}
.ca-help{color:var(--muted);margin:-4px 0 10px;font-size:.95rem}
.ca-grid{display:grid;gap:10px}
.ca-grid.two{grid-template-columns:1fr 1fr}
.ca-grid.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:600px){.ca-grid.two,.ca-grid.three{grid-template-columns:1fr}}
.ca-opt{
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px 16px;
  display:flex;
  gap:10px;
  align-items:flex-start;
  background:#fff;
  cursor:pointer;
  transition:all .2s;
}
.ca-opt:hover{border-color:#B3DCFF;background:#F6FBFF}
.ca-opt input[type="radio"]{margin-top:2px;cursor:pointer}
.ca-actions{display:flex;gap:10px;justify-content:space-between;margin-top:14px;flex-wrap:wrap}
.ca-actions .right{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}
.ca-btn{
  padding:10px 16px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
  cursor:pointer;
  transition:all .2s;
}
.ca-btn:hover{background:#f9f9f9}
.ca-btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}
.ca-btn.primary:hover{background:var(--celery);border-color:var(--celery);color:#0C233D}
.ca-result{border:1px solid var(--line);border-radius:14px;padding:20px;margin-top:14px;background:#fafafa}
.ca-badge{display:inline-block;border-radius:999px;padding:6px 10px;font-weight:900;margin-right:8px;margin-bottom:10px}
.ca-badge.strong{background:#eaf7f0;color:#0f5132;border:1px solid #b7e1c3}
.ca-badge.moderate{background:#fff6e6;color:#7a3e00;border:1px solid #ffd89a}
.ca-badge.weak{background:#fde8e7;color:#7a1d1d;border:1px solid #f7b3ad}
.ca-section-title{font-weight:900;color:#0C233D;margin:16px 0 10px;font-size:16px}
.ca-doc-item{display:flex;gap:10px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff;margin-bottom:8px;font-size:.95rem}
.ca-doc-item strong{color:#0C233D;display:block;margin-bottom:2px}
.ca-doc-item small{color:#666}
.ca-free-qual{margin-top:16px;padding:12px;border-radius:10px;border:1px solid;font-weight:900}
.ca-free-qual.yes{background:#eaf7f0;border-color:#b7e1c3;color:#0f5132}
.ca-free-qual.no{background:#fff6e6;border-color:#ffd89a;color:#7a3e00}
.ca-small{color:#6b7280;font-size:.9rem;margin-top:8px}

/* ==========================
   PAGE HERO (generic pages)
========================== */
.page-hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,var(--navy),var(--lightband) 65%);
  color:#fff;
  padding:76px 0 56px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.22;
  background:
    radial-gradient(900px 360px at 10% 20%, rgba(58,160,255,.55), transparent 60%),
    radial-gradient(700px 300px at 75% 10%, rgba(143,182,62,.45), transparent 62%),
    radial-gradient(900px 520px at 80% 90%, rgba(255,255,255,.22), transparent 58%);
  pointer-events:none;
}
.page-hero .inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:center;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  padding:8px 12px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  letter-spacing:.04em;
}
.page-hero h1{
  font-family:Poppins,sans-serif;
  font-weight:900;
  font-size:clamp(34px,6vw,62px);
  margin:12px 0 12px;
  line-height:1.02;
}
.page-hero p{
  margin:0 0 12px;
  color:#E7F2FF;
  font-weight:650;
  font-size:clamp(16px,2.8vw,20px);
  line-height:1.6;
  max-width:75ch;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}

.page-hero .btn.outline{
  background:#fff;
  border-color:#fff;
  color:#0C233D;
  font-weight:900;
}
.page-hero .btn.outline:hover{
  background:#F1F5F9;
  border-color:#F1F5F9;
  color:#0C233D;
}

/* ==========================
   TRUST/PILL CARDS (UNIFIED)
========================== */
.trust-card,
.page-hero .hero-card{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.22);
  border-radius:18px;
  padding:18px;
  backdrop-filter:blur(8px);
}
.trust-title,
.page-hero .hero-card h3{
  font-family:Poppins,sans-serif;
  font-weight:900;
  margin:0 0 10px;
  font-size:18px;
}
.trust-grid,
.page-hero .hero-card .pill-grid{
  display:grid;
  gap:10px;
}
.trust-item,
.page-hero .hero-card .pill{
  display:flex;
  gap:10px;
  align-items:flex-start;
  background:rgba(12,35,61,.35);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:12px;
}
.trust-ico,
.page-hero .hero-card .pill .ico{
  width:38px;
  height:38px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(58,160,255,.18);
  border:1px solid rgba(58,160,255,.35);
  flex:0 0 auto;
  color:#fff;
}
.trust-item b,
.page-hero .hero-card .pill b{
  display:block;
  margin:0;
  color:#fff;
}
.trust-item span,
.page-hero .hero-card .pill span{
  display:block;
  margin-top:2px;
  color:#DCEBFF;
  font-weight:650;
  font-size:13px;
  line-height:1.45;
}

/* ==========================
   GENERIC CARDS & UTILITIES
========================== */
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--cardShadow);
}
.card.pad{
  padding:18px;
  height:100%;
  display:flex;
  flex-direction:column;
}

.callout{
  background:#F6FBFF;
  border:1px solid #CDE6FF;
  border-left:4px solid var(--celery);
  border-radius:14px;
  padding:14px;
  color:#0C233D;
  font-weight:800;
  line-height:1.6;
}

.fine,.fineprint{
  color:#64748b;
  font-size:13px;
  line-height:1.6;
}
.mini{
  font-size:13px;
  line-height:1.55;
  color:#64748b;
  font-weight:600;
  margin:10px 0 0;
}

/* ==========================
   ABOUT PAGE SPECIFICS
========================== */
.about-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:20px;
  align-items:stretch;
}

.people-pledge{display:grid;gap:12px;margin-top:14px}
.pledge{
  display:flex;gap:12px;align-items:flex-start;
  border:1px solid #e8eef7;background:#f8fafc;border-radius:16px;padding:14px;
}
.pledge .ico{
  width:44px;height:44px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(58,160,255,.12);border:1px solid rgba(58,160,255,.22);
  flex:0 0 auto;
  color:#0C233D;
}
.pledge b{display:block;color:#0C233D}
.pledge p{margin:4px 0 0;color:#475569;font-weight:650;line-height:1.7;font-size:14.5px}

.humanity-photo{
  margin-top:14px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 10px 22px rgba(13,34,61,.06);
  background:#fff;
}
.humanity-photo img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
}
.humanity-photo .cap{
  padding:12px 14px;
  border-top:1px solid #eef2f7;
  background:#fafafa;
  color:#334155;
  font-weight:750;
  font-size:13px;
  line-height:1.5;
}

.lead-banner{
  position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  background:#0b1f39;min-height:360px;box-shadow:0 10px 28px rgba(13,34,61,.10);
}
.lead-banner .photo{
  position:absolute;top:0;right:0;bottom:0;width:min(46%,520px);
  background:url('https://www.ten.law/wp-content/uploads/2022/06/profile_george.jpg') center right / cover no-repeat;
  -webkit-mask-image: linear-gradient(to left,
    rgba(0,0,0,1) 66%, rgba(0,0,0,.95) 72%, rgba(0,0,0,.8) 78%,
    rgba(0,0,0,.55) 84%, rgba(0,0,0,.3) 90%, rgba(0,0,0,0) 100%);
  mask-image: linear-gradient(to left,
    rgba(0,0,0,1) 66%, rgba(0,0,0,.95) 72%, rgba(0,0,0,.8) 78%,
    rgba(0,0,0,.55) 84%, rgba(0,0,0,.3) 90%, rgba(0,0,0,0) 100%);
  filter:contrast(1.02) saturate(1.02) blur(.15px);
}
.lead-banner .blend{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg, rgba(12,35,61,.94) 0%, rgba(12,35,61,.72) 35%, rgba(12,35,61,.36) 67%, rgba(12,35,61,0) 92%);
  mix-blend-mode:multiply;
}
.lead-banner::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:44%;
  background:linear-gradient(0deg, rgba(12,35,61,0.45), rgba(12,35,61,0));
  pointer-events:none;
}
.lead-banner .copy{
  position:absolute;top:22px;left:22px;right:24px;z-index:1;color:#fff;
  max-width:min(740px,66%);
}
.lead-banner h2{margin:0 0 6px;font-family:Poppins,sans-serif;font-size:30px;line-height:1.1}
.lead-banner .role{margin:0 0 10px;color:#E7F2FF;font-weight:800}
.lead-banner .bio{margin:0;color:#DCEBFF;font-weight:620;line-height:1.7}

.team-header{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;margin-bottom:12px}
.team-header .spacer{flex:1}

.cta-band{
  background:linear-gradient(135deg,var(--navy),var(--lightband) 65%);
  color:#fff;border-top:1px solid rgba(255,255,255,.12);
  padding:56px 0;
}
.cta-inner{display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cta-band h2{margin:0;font-family:Poppins,sans-serif;font-weight:900;font-size:clamp(22px,4vw,34px)}
.cta-band p{margin:6px 0 0;color:#DCEBFF;font-weight:750;max-width:70ch}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap}
.cta-band .btn.outline{background:#fff;border-color:#fff;color:#0C233D;font-weight:900}
.cta-band .btn.outline:hover{background:#F1F5F9;border-color:#F1F5F9;color:#0C233D}

/* ==========================
   SERVICES PAGE SPECIFICS
========================== */
.services-layout{
  display:grid;
  grid-template-columns: 360px 1fr;
  gap:18px;
  align-items:start;
}

.menu.card{position:sticky;top:88px}
.menu-head{padding:16px 16px 0}
.menu-title{margin:0 0 6px;font-family:Poppins,sans-serif;font-weight:900;color:var(--navy);font-size:22px}
.menu-sub{margin:0 0 12px;color:#475569;font-weight:650;line-height:1.6}
.menu-list{padding:10px 10px 14px;display:grid;gap:8px}
.menu-btn-item{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid #e8eef7;
  background:#f8fafc;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
  font-weight:900;color:#0C233D;
  text-align:left;
}
.menu-btn-item:hover{transform:translateY(-1px);box-shadow:0 10px 18px rgba(13,34,61,.08);border-color:#cfe8ff}
.menu-btn-item.active{background:#0C233D;color:#fff;border-color:#0C233D}
.menu-btn-item.active .chev{opacity:.95}
.menu-btn-item .left{display:flex;gap:10px;align-items:center}
.badge{
  width:38px;height:38px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(58,160,255,.12);border:1px solid rgba(58,160,255,.22);
  color:#0C233D;font-weight:1000;
}
.menu-btn-item.active .badge{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22);color:#fff}
.chev{opacity:.6}
.menu-foot{padding:0 16px 16px}
.menu-foot .btn{width:100%}

.panel.card{padding:18px}
.panel-top{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding-bottom:12px;border-bottom:1px solid #eef2f7;margin-bottom:12px;
}
.panel h2{margin:0;font-family:Poppins,sans-serif;font-weight:900;color:var(--navy);font-size:clamp(22px,4vw,34px)}
.panel .desc{margin:10px 0 0;color:#334155;font-weight:650;line-height:1.75;max-width:90ch}
.meta{
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;
}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:999px;
  border:1px solid #e8eef7;background:#f8fafc;
  color:#0C233D;font-weight:900;font-size:12px;
}
.chip svg{width:16px;height:16px}

.faq-wrap{margin-top:14px}
.faq-head{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;flex-wrap:wrap}
.faq-head h3{margin:0;font-family:Poppins,sans-serif;font-weight:900;color:var(--navy);font-size:20px}
.faq-actions{display:flex;gap:10px;flex-wrap:wrap}
.faq-actions .btn.small{border-color:#e8eef7}
details.faq{
  border:1px solid #e8eef7;background:#f8fafc;border-radius:16px;
  padding:12px 12px; margin-top:10px;
  transition:border-color .2s ease, box-shadow .2s ease, transform .15s ease;
}
details.faq:hover{border-color:#cfe8ff;box-shadow:0 10px 18px rgba(13,34,61,.06);transform:translateY(-1px)}
details.faq[open]{background:#fff;border-color:#bfe1ff}
summary{
  list-style:none;cursor:pointer;font-weight:950;color:#0C233D;
  display:flex;align-items:flex-start;justify-content:space-between;gap:10px;
  outline:none;
}
summary::-webkit-details-marker{display:none}
.q{display:flex;gap:10px;align-items:flex-start}
.qnum{
  width:28px;height:28px;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid #e8eef7;background:#fff;color:#0C233D;font-weight:1000;
  flex:0 0 auto;
  margin-top:1px;
}
.ans{margin:10px 0 0;color:#475569;font-weight:650;line-height:1.75;padding-left:38px}
.caret{
  width:18px;height:18px;flex:0 0 auto;opacity:.7;margin-top:2px;
  transition:transform .2s ease;
}
details[open] .caret{transform:rotate(180deg)}

/* ==========================
   CONSULTATION PAGE SPECIFICS
========================== */
.sched-grid{
  display:grid;
  grid-template-columns: 1.6fr .95fr;
  gap:22px;
  align-items:start;
}
.sched-head{
  display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:12px;
}
.sched-head .spacer{flex:1}
.list{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.list li{
  padding:12px 12px 12px 14px;border:1px solid #e8eef7;background:#f8fafc;border-radius:14px;
  color:#0C233D;font-weight:800;line-height:1.5;
}

.cal-wrap{padding:14px}
.calendly-inline-widget{
  width:100%;
  min-width:320px;
  height:min(980px, 1200px);
  border-radius:14px;
  overflow:hidden;
}

/* ==========================
   REVIEWS PAGE SPECIFICS
========================== */
.intro-band{padding:40px 0 0}
.intro-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:22px;box-shadow:0 10px 28px rgba(13,34,61,.08);
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
}
.intro-card h2{margin:0 0 8px}
.pill-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.pill-row .pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  border:1px solid #e8eef7;background:#f8fafc;
  font-weight:900;color:#0C233D;font-size:12px;
}
.note{
  border-left:4px solid var(--celery);
  background:#F6FBFF;border:1px solid #CDE6FF;border-radius:14px;
  padding:14px;color:#0C233D;
  font-weight:800;line-height:1.55;
}

.reviews-wrap{
  background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:var(--section-pad) 0;
}
.reviews-head{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.reviews-head .spacer{flex:1}
.reviews-shell{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:18px;box-shadow:0 10px 28px rgba(13,34,61,.08);
}

.highlights{padding:var(--section-pad) 0;}
.hl-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch;}
.hl-photo{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:
    linear-gradient(90deg, rgba(12,35,61,.70) 0%, rgba(12,35,61,.25) 55%, rgba(12,35,61,0) 90%),
    url("/wp-content/uploads/2026/01/clientssay.webp") center / cover no-repeat;
  min-height:320px;
  position:relative;
}
.hl-copy{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;
  box-shadow:0 10px 28px rgba(13,34,61,.08);
}
.hl-list{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.hl-list li{
  padding:12px 12px 12px 14px;border:1px solid #e8eef7;background:#f8fafc;border-radius:14px;
  color:#0C233D;font-weight:800;line-height:1.5;
}
.hl-list li b{color:var(--navy)}

/* ==========================
   RESPONSIVE
========================== */
@media (max-width: 900px){
  :root{ 
    --section-pad:64px; 
    --pad:20px; /* Increased from default for tablets */
  }

  .hero{min-height:70vh}
  .hero-inner{margin-left:0;max-width:760px}

  #about .team-banner .photo{width:52%}

  .services-header .actions{margin-left:0}

  .page-hero .inner{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .services-layout{grid-template-columns:1fr}
  .menu.card{position:relative;top:auto}
  .sched-grid{grid-template-columns:1fr}
  .intro-card{grid-template-columns:1fr}
  .hl-grid{grid-template-columns:1fr}
  .hl-photo{min-height:260px}
  .calendly-inline-widget{height:1050px;}
}

@media (max-width: 760px){
  :root{ 
    --pad:18px; /* Increased from 16px for better mobile spacing */
    --section-pad:56px; 
  }

  .navlinks{display:none}
  .menu-btn{display:inline-flex;align-items:center;justify-content:center}

  .hero{
    min-height:100vh !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:flex-end !important;
    align-items:stretch !important;
  }
  .hero::before{
    background:
      linear-gradient(to bottom,
        rgba(7,18,35,0) 0%,
        rgba(7,18,35,0) 60%,
        rgba(7,18,35,0.35) 80%,
        rgba(7,18,35,0.88) 100%
      ),
      url("/wp-content/uploads/2026/01/HeroImage.webp") 0% center/cover no-repeat !important;
    background-position: 0% center !important;
    background-size: cover !important;
  }
  .hero-inner{
    padding:0 var(--pad) 24px !important;
    margin-left:0 !important;
    margin-right:0 !important;
    max-width:100% !important;
    margin-top:auto !important;
    position:relative !important;
    top:0 !important;
  }
  .hero-card{
    background:rgba(255,255,255,.12) !important;
    border:1px solid rgba(255,255,255,.25) !important;
    padding:16px !important;
    backdrop-filter:blur(8px) !important;
  }
  .hero h1{
    font-size:clamp(28px,6.5vw,42px) !important;
    margin:0 0 8px !important;
    line-height:1.1 !important;
  }
  .hero p{
    font-size:clamp(13px,2.8vw,16px) !important;
    margin:0 0 12px !important;
    line-height:1.4 !important;
  }
  .cta-row{flex-direction:column !important; gap:10px !important;}
  .cta-row .btn{width:100% !important; padding:12px 16px !important;}

  #about .team-banner{min-height:unset}
  #about .team-banner .photo,
  #about .team-banner .blend,
  #about .team-banner::after{
    position:static;
    width:100%;
    height:240px;
    -webkit-mask-image:none;
    mask-image:none;
  }
  #about .team-banner .blend{display:none}
  #about .team-banner::after{display:none}
  .team-banner .copy{
    position:static;
    max-width:100%;
    padding:16px;
  }
  .team-banner h3{font-size:24px}
  .team-banner p,.team-banner .bio{font-weight:600}

  .service-card{flex:0 0 86%; min-height:unset; padding:22px}
  .scroll-controls{justify-content:space-between}
  .scroll-controls .btn{flex:1}

  .contact{grid-template-columns:1fr;gap:18px}
  .map iframe{min-height:280px}

  #translate-dock{right:12px;bottom:12px}

  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}

  .lead-banner{min-height:unset}
  .lead-banner .photo,
  .lead-banner .blend,
  .lead-banner::after{
    position:static;width:100%;height:240px;
    -webkit-mask-image:none;mask-image:none;
  }
  .lead-banner .blend{display:none}
  .lead-banner::after{display:none}
  .lead-banner .copy{position:static;max-width:100%;padding:16px}
  .lead-banner h2{font-size:24px}
  .team-meta{justify-content:flex-start}

  .panel.card{padding:16px}
  .menu-list{grid-template-columns:1fr}
  
  .calendly-inline-widget{height:1150px;}
}

@media (max-width: 520px){
  :root{
    --pad:16px; /* Comfortable spacing for phones */
  }
  
  .calendly-inline-widget{height:1150px;}
}

@media (max-width: 420px){
  :root{
    --pad:14px; /* Minimum comfortable spacing for small phones */
  }
  
  .stat-num{font-size:28px}
  .social a{width:100%;justify-content:center}
  #ca-widget{padding:22px 16px}
}
/* ==========================
   GRAVITY FORMS STYLING
========================== */
body .gform_wrapper {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 28px !important;
  box-shadow: 0 10px 28px rgba(13,34,61,.08) !important;
  max-width: 800px !important;
  margin: 40px auto !important;
}

body .gform_wrapper .gfield_label {
  font-weight: 800 !important;
  color: var(--navy) !important;
  margin-bottom: 8px !important;
  font-size: 15px !important;
}

body .gform_wrapper input[type="text"],
body .gform_wrapper input[type="email"],
body .gform_wrapper input[type="tel"],
body .gform_wrapper input[type="url"],
body .gform_wrapper textarea,
body .gform_wrapper select {
  width: 100% !important;
  padding: 12px 16px !important;
  border: 1px solid #E6E6E6 !important;
  border-radius: 12px !important;
  font-size: 15px !important;
  font-family: Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif !important;
  background: #fff !important;
}

body .gform_wrapper input:focus,
body .gform_wrapper textarea:focus,
body .gform_wrapper select:focus {
  outline: none !important;
  border-color: #3AA0FF !important;
  box-shadow: 0 0 0 3px rgba(58, 160, 255, 0.1) !important;
}

body .gform_wrapper textarea {
  min-height: 150px !important;
  resize: vertical !important;
}

body .gform_wrapper .gform_footer input[type="submit"],
body .gform_wrapper .gform_page_footer input[type="submit"],
body .gform_wrapper input.gform_button {
  background: #3AA0FF !important;
  border: 1.5px solid #3AA0FF !important;
  color: #fff !important;
  padding: 14px 32px !important;
  border-radius: 999px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  font-size: 16px !important;
}

body .gform_wrapper .gform_footer input[type="submit"]:hover,
body .gform_wrapper input.gform_button:hover {
  background: #8FB63E !important;
  border-color: #8FB63E !important;
  color: #0C233D !important;
  transform: translateY(-1px) !important;
}

body .gform_wrapper .validation_error {
  border-radius: 12px !important;
  padding: 16px !important;
  background: #fef2f2 !important;
  border: 1px solid #fca5a5 !important;
  color: #991b1b !important;
  margin-bottom: 20px !important;
}

body .gform_wrapper li.gfield.gfield_error {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

body .gform_wrapper .gfield_error input,
body .gform_wrapper .gfield_error textarea,
body .gform_wrapper .gfield_error select {
  border-color: #ef4444 !important;
}

/* Mobile */
@media (max-width: 760px) {
  body .gform_wrapper {
    padding: 20px 18px !important;
    margin: 20px 18px !important;
  }
}