:root{
  --site-bg:#f4f7fb;
  --site-bg-soft:#fbfcfe;
  --card:#ffffff;
  --card-soft:rgba(255,255,255,.82);
  --line:#dce5f2;
  --line-strong:#c7d4e6;
  --text:#162033;
  --muted:#5b6b84;
  --accent:#315efb;
  --accent-dark:#2249d8;
  --accent-soft:rgba(49,94,251,.08);
  --shadow:0 20px 50px rgba(15,23,42,.08);
  --shadow-soft:0 12px 28px rgba(15,23,42,.06);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:18px;
}
html{scroll-behavior:smooth}
body.site-body{
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(49,94,251,.10), transparent 28%),
    radial-gradient(circle at top right, rgba(61,151,226,.08), transparent 26%),
    linear-gradient(180deg, var(--site-bg-soft) 0%, var(--site-bg) 100%);
  line-height:1.6;
}
a{text-decoration:none}
img{max-width:100%;display:block}
.site-nav{
  backdrop-filter:blur(12px);
  background:rgba(248,250,253,.84);
  border-color:rgba(22,32,51,.08)!important;
}
.site-nav .navbar-brand{
  display:flex;
  flex-direction:column;
  gap:.15rem;
  line-height:1.15;
}
.site-nav .brand-title{
  font-size:1rem;
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--text);
}
.site-nav .brand-subtitle{
  font-size:.76rem;
  color:var(--muted);
}
.site-nav .nav-link{
  color:var(--text);
  font-size:.95rem;
  font-weight:500;
  padding:.65rem .9rem!important;
  border-radius:999px;
}
.site-nav .nav-link:hover,
.site-nav .nav-link:focus{
  color:var(--accent);
  background:rgba(49,94,251,.06);
}
.hero-section{padding:2.6rem 0 1.2rem}
.hero-panel,
.section-card,
.cta-card,
.footer-card,
.contact-card,
.doc-card,
.meta-card{
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
  background:var(--card-soft);
  backdrop-filter:blur(10px);
}
.hero-panel{padding:2.5rem}
.hero-main{max-width:72rem}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.55rem .9rem;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--accent);
  font-size:.74rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:1rem;
}
.hero-title{
  margin:0 0 1rem;
  font-size:clamp(1.85rem,3vw,2.7rem);
  line-height:1.12;
  letter-spacing:-.045em;
  max-width:30ch;
}
.hero-text{
  margin:0;
  max-width:58ch;
  color:var(--muted);
  font-size:1.02rem;
}
.hero-chips{
  list-style:none;
  padding:0;
  margin:1.35rem 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
}
.hero-chips li{
  padding:.55rem .85rem;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--text);
  font-size:.92rem;
  font-weight:500;
}
.quick-panel{
  height:100%;
  border:1px solid var(--line);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.76));
  padding:1.5rem;
}
.quick-panel-bottom{margin-top:1rem}
.quick-panel-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}
.quick-points-inline{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:0}
.quick-panel h2{
  margin:0 0 .55rem;
  font-size:1.35rem;
  line-height:1.1;
  letter-spacing:-.03em;
}
.quick-panel p{margin:0 0 1rem;color:var(--muted);font-size:.98rem}
.quick-points{display:grid;gap:.85rem;margin-bottom:1rem}
.quick-point{
  padding:.95rem 1rem;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
}
.quick-point strong{
  display:block;
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--muted);
  margin-bottom:.3rem;
}
.quick-point span{font-size:1rem;color:var(--text);font-weight:600}
.stats-row{margin-top:1.25rem}
.stat-card{
  height:100%;
  padding:1rem 1.1rem;
  border:1px solid var(--line);
  border-radius:20px;
  background:rgba(255,255,255,.86);
}
.stat-card strong{
  display:block;
  font-size:1.7rem;
  line-height:1;
  margin-bottom:.35rem;
  letter-spacing:-.04em;
}
.stat-card span{
  color:var(--muted);
  font-size:.9rem;
}
.btn-brand{
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  color:#fff;
  border-color:transparent;
}
.btn-brand:hover,
.btn-brand:focus{
  color:#fff;
  background:linear-gradient(135deg,var(--accent-dark),#173ab4);
}
.btn-soft{
  background:#fff;
  border-color:var(--line-strong);
  color:var(--text);
}
.btn-soft:hover,
.btn-soft:focus{
  background:#fff;
  border-color:#9fb3d1;
  color:var(--text);
}
.section{padding:1rem 0}
.section-card{padding:2rem}
.section-head{
  display:flex;
  flex-wrap:wrap;
  align-items:end;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1.4rem;
}
.section-head h2{
  margin:0 0 .5rem;
  font-size:clamp(1.7rem,3vw,2.3rem);
  line-height:1.08;
  letter-spacing:-.04em;
}
.section-head p{
  margin:0;
  color:var(--muted);
  max-width:68ch;
  font-size:.98rem;
}
.section-note{
  max-width:21rem;
  padding:.95rem 1rem;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--muted);
  font-size:.9rem;
}
.search-wrap{display:grid;gap:.55rem;margin:0 0 1.35rem}
.search-wrap input{
  min-height:3.35rem;
  border:1px solid var(--line-strong);
  border-radius:18px;
  padding:.85rem 1rem;
  background:#fff;
  color:var(--text);
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.search-wrap input:focus{
  border-color:rgba(49,94,251,.45);
  box-shadow:0 0 0 .25rem rgba(49,94,251,.12);
}
.search-help{color:var(--muted);font-size:.9rem}
.results-pill{
  display:inline-flex;
  align-items:center;
  padding:.35rem .65rem;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--accent);
  font-size:.82rem;
  font-weight:600;
  width:max-content;
}
.group-block + .group-block{margin-top:1.65rem}
.group-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:1rem;
  margin-bottom:.95rem;
  padding-bottom:.8rem;
  border-bottom:1px solid var(--line);
}
.group-head h3{
  margin:0;
  font-size:1.08rem;
  line-height:1.3;
  letter-spacing:-.02em;
  font-weight:650;
}
.group-head span{font-size:.88rem;color:var(--muted)}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1rem;
}
.service-card{
  position:relative;
  min-height:104px;
  padding:1.1rem 1rem 1rem 4.3rem;
  border-radius:20px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.78));
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.service-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
  border-color:#b5c8e7;
}
.service-card .num{
  position:absolute;
  top:1rem;
  left:1rem;
  width:2.4rem;
  height:2.4rem;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:var(--accent-soft);
  color:var(--accent);
  font-size:.8rem;
  font-weight:700;
}
.service-card h3{
  margin:0;
  font-size:.98rem;
  line-height:1.45;
  letter-spacing:-.01em;
  font-weight:600;
}
.cta{padding:1rem 0 1.5rem}
.cta-card{padding:2rem}
.cta-card h2{
  margin:0 0 .55rem;
  font-size:clamp(1.8rem,3vw,2.45rem);
  line-height:1.05;
  letter-spacing:-.04em;
}
.cta-card p{margin:0;color:var(--muted);max-width:62ch}
.contact-section{padding:0 0 2.2rem}
.contact-card{padding:2rem}
.contact-card h2{
  margin:0 0 .65rem;
  font-size:clamp(1.7rem,3vw,2.2rem);
  line-height:1.08;
  letter-spacing:-.04em;
}
.contact-card > p{margin:0 0 1.4rem;color:var(--muted);max-width:60ch}
.contact-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1rem;
}
.contact-item{
  padding:1.1rem 1rem;
  border-radius:20px;
  background:#fff;
  border:1px solid var(--line);
}
.contact-item small{
  display:block;
  margin-bottom:.35rem;
  color:var(--muted);
  font-size:.74rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.contact-item strong,
.contact-item a{
  color:var(--text);
  font-size:1rem;
  font-weight:650;
  word-break:break-word;
}
.footer{
  padding:0 0 2.3rem;
}
.footer-card{
  padding:1.35rem 1.5rem;
}
.footer-card p{
  margin:0;
  color:var(--muted);
  font-size:.95rem;
}
.doc-hero{padding:2.4rem 0 1rem}
.doc-hero .hero-panel{padding:2rem}
.doc-hero h1{
  margin:0 0 .8rem;
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.04;
  letter-spacing:-.045em;
  max-width:14ch;
}
.doc-hero p{margin:0;color:var(--muted);max-width:70ch}
.meta{padding:0 0 1rem}
.meta-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1rem;
}
.meta-card{padding:1rem 1.1rem;background:rgba(255,255,255,.9)}
.meta-card small{
  display:block;
  margin-bottom:.35rem;
  color:var(--muted);
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.meta-card strong,
.meta-card a{
  color:var(--text);
  font-size:1rem;
  font-weight:650;
  word-break:break-word;
}
.doc{padding:0 0 1.4rem}
.doc-card{padding:2rem;background:rgba(255,255,255,.92)}
.toc{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.75rem;
  margin:0 0 1.5rem;
}
.toc a{
  display:block;
  padding:.8rem .95rem;
  border-radius:16px;
  border:1px solid var(--line);
  background:#f8fbff;
  color:var(--text);
  font-size:.92rem;
  font-weight:550;
}
.toc a:hover{border-color:#a9c0e7;background:#fff}
.doc-section + .doc-section{
  margin-top:1.4rem;
  padding-top:1.4rem;
  border-top:1px solid var(--line);
}
.doc-section h2{
  margin:0 0 .8rem;
  font-size:1.45rem;
  line-height:1.14;
  letter-spacing:-.02em;
}
.doc-section p{
  margin:0 0 .8rem;
  color:var(--text);
  font-size:.98rem;
}
.empty-state{
  display:none;
  padding:1rem 1.1rem;
  border-radius:18px;
  border:1px dashed var(--line-strong);
  background:#fff;
  color:var(--muted);
}
.empty-state.is-visible{display:block}
[data-hidden="true"]{display:none!important}
@media (max-width: 1199.98px){
  .services-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 991.98px){
  .quick-points-inline{grid-template-columns:1fr}
  .quick-panel-top{flex-direction:column;align-items:stretch}
  .hero-panel{padding:2rem}
  .section-card,.cta-card,.contact-card,.doc-card{padding:1.5rem}
  .meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 767.98px){
  .hero-section,.doc-hero{padding-top:1.2rem}
  .hero-panel{padding:1.4rem}
  .hero-title{max-width:none}
  .section-card,.cta-card,.contact-card,.doc-card{padding:1.15rem}
  .services-grid,.contact-grid,.meta-grid,.toc{grid-template-columns:1fr}
  .service-card{min-height:auto}
  .site-nav .brand-subtitle{display:none}
  .hero-chips li{font-size:.86rem}
}
