/* Shared page-level helpers and first-pass responsive rules. */
.search-box {
    display: flex;
    border: 1px solid var(--border);
}

.search-box input {
    padding: 10px;
    border: none;
    outline: none;
    width: 200px;
}

.search-box button {
    background: var(--accent);
    color: white;
    border: none;
    padding: 10px 20px;
    cursor: pointer;
}

.transparency-grid.home-shortcuts {
    grid-template-columns: repeat(2, 1fr);
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
}

.case-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

.case-card {
    border: 1px solid var(--border);
    padding: 25px;
    background: var(--surface);
}

.case-card img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    margin-bottom: 20px;
}

.case-card h4 {
    font-size: 20px;
    margin-bottom: 10px;
}

.case-card p {
    font-size: 15px;
    color: var(--muted);
    line-height: 1.6;
}

.section-title-spaced {
    margin-top: 60px;
}

.block-spaced {
    margin-top: 60px;
}

@media (max-width: 992px) {
    .container {
        padding: 0 24px;
    }

    .header-content,
    .top-bar .container {
        gap: 20px;
    }

    nav .container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding: 0;
        scrollbar-width: none;
    }

    nav .container::-webkit-scrollbar {
        display: none;
    }

    nav ul {
        justify-content: flex-start;
        min-width: max-content;
    }

    nav li a {
        padding: 16px 22px;
        font-size: 16px;
    }

    .section-grid,
    .about-content,
    .contact-grid,
    .modal-body {
        grid-template-columns: 1fr !important;
    }

    .practice-grid,
    .target-grid,
    .hardware-grid,
    .attorney-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 768px) {
    body {
        font-size: 16px;
    }

    header {
        padding: 28px 0;
    }

    .header-content,
    .top-bar .container,
    .logo-area {
        flex-direction: column;
        text-align: center;
    }

    .logo-emblem {
        width: 64px;
        height: 64px;
        font-size: 32px;
    }

    .logo-text h1 {
        font-size: 28px;
        letter-spacing: 2px;
    }

    .page-header {
        height: 240px !important;
        margin-bottom: 48px !important;
    }

    .page-header h2 {
        font-size: 36px !important;
        letter-spacing: 3px !important;
        padding: 0 20px;
        text-align: center;
    }

    .form-grid,
    .contact-grid,
    .about-content,
    .grid-table,
    .data-tabs {
        grid-template-columns: 1fr !important;
    }

    .transparency-grid,
    .transparency-grid.home-shortcuts,
    .case-grid,
    .practice-grid,
    .target-grid,
    .hardware-grid,
    .attorney-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .form-group.full-width {
        grid-column: span 1 !important;
    }

    .consultation-section,
    .about-section {
        padding: 48px 24px !important;
    }

    .attorney-photo {
        height: 360px !important;
    }

    .search-box,
    .search-input-group,
    .captcha-area,
    .radio-group,
    .header-meta,
    .data-tabs {
        flex-direction: column;
        align-items: stretch !important;
    }

    .search-box input,
    .search-input-group input,
    .search-input-group select,
    .search-input-group button {
        width: 100% !important;
    }
}


/* Mobile density pass: keep the phone layout polished, compact, and less scroll-heavy. */
@media (max-width: 768px) {
    :root {
        --section-padding: 48px;
    }

    .top-bar {
        display: none;
    }

    .container {
        padding: 0 16px;
    }

    header {
        padding: 16px 0;
        border-bottom-width: 2px;
    }

    .header-content,
    .logo-area {
        gap: 10px;
    }

    .logo-emblem {
        width: 52px;
        height: 52px;
        font-size: 26px;
        border-width: 2px;
    }

    .logo-text h1 {
        font-size: 24px;
        line-height: 1.25;
        letter-spacing: 1px;
    }

    .logo-text p,
    .header-contact,
    .header-meta {
        display: none !important;
    }

    nav {
        top: 0;
    }

    nav li a {
        padding: 11px 14px;
        font-size: 14px;
    }

    .page-header {
        height: 170px !important;
        margin-bottom: 28px !important;
    }

    .page-header h2 {
        font-size: 30px !important;
        letter-spacing: 2px !important;
    }

    .section-intro {
        margin-bottom: 28px !important;
    }

    .section-intro h3 {
        font-size: 24px !important;
        margin-bottom: 10px !important;
    }

    .section-intro p {
        font-size: 14px !important;
        line-height: 1.65 !important;
    }

    .main-content {
        padding: 42px 0 !important;
    }

    .section-grid {
        gap: 28px !important;
    }

    .news-block h2,
    .sidebar-title {
        font-size: 22px !important;
        margin-bottom: 18px !important;
        padding-left: 14px !important;
        border-left-width: 5px !important;
    }

    .section-title-spaced,
    .block-spaced {
        margin-top: 34px !important;
    }

    .news-item {
        display: block !important;
        padding: 12px 0 !important;
    }

    .news-item .title {
        display: block;
        font-size: 15px !important;
        line-height: 1.55 !important;
        padding-left: 14px !important;
    }

    .news-item .date {
        display: block;
        margin-top: 4px;
        padding-left: 14px;
        font-size: 12px !important;
    }

    .sidebar-services {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: 10px !important;
        margin-bottom: 26px !important;
    }

    .service-btn {
        padding: 14px 8px !important;
        gap: 8px !important;
        font-size: 13px !important;
        line-height: 1.35;
        min-height: 62px;
    }

    .service-btn i {
        font-size: 18px !important;
    }

    .judicial-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        padding: 0 !important;
        border: none !important;
        background: #8B0000 !important;
    }

    .judicial-list li a {
        min-height: 54px;
        padding: 10px !important;
        border: 1px solid var(--border) !important;
        background: var(--surface);
        font-size: 13px;
        line-height: 1.35;
    }

    .case-grid {
        gap: 12px !important;
    }

    .case-card {
        padding: 12px !important;
    }

    .case-card img {
        height: 96px !important;
        margin-bottom: 10px !important;
    }

    .case-card h4 {
        font-size: 15px !important;
        line-height: 1.45;
        margin-bottom: 6px !important;
    }

    .case-card p {
        font-size: 12px !important;
        line-height: 1.55 !important;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .consultation-section,
    .about-section {
        padding: 34px 18px !important;
    }

    footer {
        margin-top: 48px !important;
        padding-top: 42px !important;
    }

    .footer-grid {
        grid-template-columns: 1fr !important;
        gap: 26px !important;
        margin-bottom: 28px !important;
    }
}

@media (max-width: 420px) {
    .transparency-grid,
    .transparency-grid.home-shortcuts,
    .practice-grid,
    .target-grid,
    .hardware-grid,
    .attorney-grid {
        gap: 10px !important;
    }

    .attorney-photo {
        height: 210px !important;
    }
}

@media (max-width: 768px) {
    .hero {
        height: 310px !important;
        align-items: flex-start !important;
        padding-top: 62px;
    }

    .hero-text {
        padding: 0 18px;
    }

    .hero-text h2 {
        font-size: 30px !important;
        line-height: 1.3;
        letter-spacing: 2px !important;
        margin-bottom: 12px !important;
    }

    .hero-text p {
        font-size: 14px !important;
        line-height: 1.7;
        letter-spacing: 0.5px !important;
    }

    .transparency-grid,
    .transparency-grid.home-shortcuts {
        margin-top: -56px !important;
        gap: 12px !important;
    }

    .transparency-card {
        padding: 18px 10px !important;
        border-top-width: 4px !important;
        box-shadow: 0 10px 24px rgba(0,0,0,0.08) !important;
    }

    .transparency-card .icon {
        font-size: 28px !important;
        margin-bottom: 8px !important;
    }

    .transparency-card h3 {
        font-size: 17px !important;
        line-height: 1.35;
        margin-bottom: 5px !important;
    }

    .transparency-card p {
        font-size: 12px !important;
        line-height: 1.45 !important;
    }

    .attorney-card {
        min-width: 0;
    }

    .attorney-info {
        padding: 16px 10px !important;
    }

    .attorney-name {
        font-size: 20px !important;
        margin-bottom: 4px !important;
    }

    .attorney-title {
        font-size: 12px !important;
        margin-bottom: 8px !important;
    }

    .attorney-practice {
        font-size: 12px !important;
        line-height: 1.5 !important;
        padding-top: 8px !important;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
}

@media (max-width: 360px) {
    .transparency-card p,
    .attorney-practice {
        display: none !important;
    }

    .attorney-photo {
        height: 185px !important;
    }
}

/* 2026-05 grand institutional pass: red-white law firm header across pages. */
body:not(.attorneys-page) header {
    background: #8B0000;
    border-bottom: 0;
    padding: 26px 0 20px;
}

body:not(.attorneys-page) header .container,
body:not(.attorneys-page) nav .container {
    max-width: 1880px;
    padding-left: 88px;
    padding-right: 88px;
}

body:not(.attorneys-page) .header-content {
    justify-content: flex-start;
}

body:not(.attorneys-page) .logo-area {
    gap: 18px;
}

body:not(.attorneys-page) .logo-emblem {
    width: 72px;
    height: 72px;
    background: transparent;
    border: 11px solid #fff;
    color: transparent;
}

body:not(.attorneys-page) .logo-emblem i {
    display: none;
}

body:not(.attorneys-page) .logo-text h1 {
    color: #fff;
    font-family: var(--font-display);
    font-size: 30px;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: 1px;
}

body:not(.attorneys-page) .logo-text p {
    color: rgba(255,255,255,0.92) !important;
    font-size: 15px !important;
    font-weight: 700;
    letter-spacing: 0 !important;
    margin-top: 8px !important;
}

body:not(.attorneys-page) nav {
    position: absolute;
    top: 38px;
    left: 0;
    right: 0;
    z-index: 5;
    background: transparent;
    box-shadow: none;
    color: #fff;
}

body:not(.attorneys-page) nav ul {
    justify-content: flex-end;
    gap: 36px;
}

body:not(.attorneys-page) nav li a {
    padding: 12px 0;
    font-size: 18px;
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
}

body:not(.attorneys-page) nav li a:hover,
body:not(.attorneys-page) nav li a.active {
    background: transparent;
    color: #e8c56a;
}

body:not(.attorneys-page) .page-header {
    height: 318px !important;
    margin-bottom: 96px !important;
    background: #8B0000 !important;
    color: #fff;
}

body:not(.attorneys-page) .page-header::before,
body:not(.attorneys-page) .page-header::after {
    display: none !important;
}

body:not(.attorneys-page) .page-header h2 {
    font-family: var(--font-display) !important;
    font-size: 58px !important;
    font-weight: 900;
    letter-spacing: 0 !important;
    text-shadow: none !important;
}

@media (max-width: 1400px) {
    body:not(.attorneys-page) header .container,
    body:not(.attorneys-page) nav .container {
        padding-left: 30px;
        padding-right: 30px;
    }

    body:not(.attorneys-page) nav {
        position: static;
        background: #8B0000;
    }

    body:not(.attorneys-page) nav .container {
        overflow-x: auto;
        scrollbar-width: none;
    }

    body:not(.attorneys-page) nav .container::-webkit-scrollbar {
        display: none;
    }

    body:not(.attorneys-page) nav ul {
        justify-content: flex-start;
        gap: 28px;
        min-width: max-content;
    }
}

@media (max-width: 768px) {
    body:not(.attorneys-page) header {
        padding: 18px 0;
    }

    body:not(.attorneys-page) header .container,
    body:not(.attorneys-page) nav .container {
        padding-left: 16px;
        padding-right: 16px;
    }

    body:not(.attorneys-page) .header-content,
    body:not(.attorneys-page) .logo-area {
        flex-direction: row;
        text-align: left;
    }

    body:not(.attorneys-page) .logo-emblem {
        width: 54px;
        height: 54px;
        border-width: 8px;
    }

    body:not(.attorneys-page) .logo-text h1 {
        font-size: 23px;
    }

    body:not(.attorneys-page) .logo-text p {
        display: block !important;
        font-size: 11px !important;
    }

    body:not(.attorneys-page) nav li a {
        font-size: 14px;
        padding: 12px 0;
    }

    body:not(.attorneys-page) .page-header {
        height: 176px !important;
        margin-bottom: 44px !important;
    }

    body:not(.attorneys-page) .page-header h2 {
        font-size: 34px !important;
    }
}

/* 2026-05 grand institutional footer: deep red ending echoing the header. */
footer {
    background: #8B0000 !important;
    color: rgba(255,255,255,0.82) !important;
    border-top: 0 !important;
}

footer .logo-emblem {
    background: transparent !important;
    border: 9px solid #fff !important;
    color: transparent !important;
}

footer .logo-emblem i {
    display: none !important;
}

footer h1,
footer h3,
footer h4,
footer p,
footer li,
footer .footer-bottom p,
footer .logo-text h1,
footer .logo-text p {
    color: rgba(255,255,255,0.9) !important;
}

footer a,
footer .footer-col a,
footer .footer-col li a {
    color: rgba(255,255,255,0.82) !important;
}

footer a:hover,
footer .footer-col a:hover {
    color: #e8c56a !important;
}

footer i,
footer .footer-col li a i {
    color: #e8c56a !important;
}

footer .footer-bottom {
    border-top-color: rgba(255,255,255,0.2) !important;
}

/* 2026-05-27 Wanwang-inspired visual polish: keep content, refine style only. */
:root {
    --bg: #f7f8fb;
    --surface: #ffffff;
    --fg: #1f2329;
    --muted: #6b7280;
    --border: #eceff3;
    --accent: #a40000;
    --accent-deep: #860000;
    --accent-soft: #fff4f4;
    --accent-gold: #d9b45f;
    --shadow-soft: 0 12px 32px rgba(31, 35, 41, 0.08);
    --shadow-card: 0 8px 22px rgba(31, 35, 41, 0.06);
    --radius-lg: 18px;
    --radius-md: 12px;
    --container-width: 1440px;
}

body {
    background:
        radial-gradient(circle at 10% 0%, rgba(164, 0, 0, 0.035), transparent 28%),
        linear-gradient(180deg, #fff 0%, #f7f8fb 42%, #fff 100%);
    color: var(--fg);
    line-height: 1.75;
}

.top-bar {
    display: none !important;
}

header,
body:not(.attorneys-page) header {
    background: #8B0000 !important;
    border-bottom: 0 !important;
    padding: 18px 0 !important;
    position: relative;
    z-index: 20;
}

header .container,
nav .container,
body:not(.attorneys-page) header .container,
body:not(.attorneys-page) nav .container {
    max-width: 1440px !important;
    padding-left: 72px !important;
    padding-right: 72px !important;
}

.header-content {
    justify-content: space-between;
    min-height: 48px;
}

.logo-area {
    gap: 12px !important;
}

.logo-emblem,
body:not(.attorneys-page) .logo-emblem {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    border-radius: 999px !important;
    border: 9px solid #fff !important;
    background: transparent !important;
    color: transparent !important;
    box-shadow: 0 0 0 1px rgba(255,255,255,0.12);
}

.logo-emblem i,
body:not(.attorneys-page) .logo-emblem i {
    display: none !important;
}

.logo-text h1,
body:not(.attorneys-page) .logo-text h1 {
    color: #fff !important;
    font-family: var(--font-display) !important;
    font-size: 18px !important;
    font-weight: 850 !important;
    line-height: 1.12 !important;
    letter-spacing: 0 !important;
}

.logo-text p,
body:not(.attorneys-page) .logo-text p {
    display: block !important;
    color: rgba(255,255,255,0.84) !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    letter-spacing: .3px !important;
    line-height: 1.1 !important;
    margin-top: 2px !important;
    text-transform: uppercase;
}

.search-box {
    display: none !important;
}

nav,
body:not(.attorneys-page) nav {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 30 !important;
    background: #8B0000 !important;
    box-shadow: none !important;
    color: #fff !important;
    pointer-events: none;
}

nav .container {
    min-height: 72px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

nav ul,
body:not(.attorneys-page) nav ul {
    justify-content: flex-end !important;
    gap: 34px !important;
    pointer-events: auto;
}

nav li a,
body:not(.attorneys-page) nav li a {
    padding: 8px 0 !important;
    color: rgba(255,255,255,0.9) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    letter-spacing: 0 !important;
    position: relative;
}

nav li a::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -2px;
    height: 2px;
    border-radius: 99px;
    background: #fff;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .25s ease;
}

nav li a:hover,
nav li a.active,
body:not(.attorneys-page) nav li a:hover,
body:not(.attorneys-page) nav li a.active {
    background: transparent !important;
    color: #fff !important;
}

nav li a:hover::after,
nav li a.active::after {
    transform: scaleX(1);
}

.hero {
    height: 455px !important;
    align-items: center !important;
    background:
        linear-gradient(90deg, rgba(0,0,0,.82) 0%, rgba(0,0,0,.58) 42%, rgba(0,0,0,.28) 100%),
        radial-gradient(circle at 52% 30%, rgba(217,180,95,.18), transparent 26%),
        url('../images/stock/photo-01-78214b17.webp') center 48% / cover no-repeat !important;
    margin-top: 0;
    position: relative;
    overflow: hidden;
}

.hero::after {
    content: '';
    position: absolute;
    inset: auto 0 0;
    height: 120px;
    background: linear-gradient(180deg, transparent, rgba(255,255,255,.04));
}

.hero-text {
    position: relative;
    z-index: 2;
    max-width: 900px;
    padding-top: 28px;
}

.hero-text h2 {
    font-family: var(--font-display) !important;
    font-size: 48px !important;
    font-weight: 900 !important;
    letter-spacing: .5px !important;
    line-height: 1.18 !important;
    margin-bottom: 14px !important;
    text-shadow: 0 8px 28px rgba(0,0,0,.45) !important;
}

.hero-text p {
    font-size: 18px !important;
    letter-spacing: .8px !important;
    color: rgba(255,255,255,.86) !important;
}


.transparency-grid,
.transparency-grid.home-shortcuts {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    max-width: 1140px !important;
    gap: 18px !important;
    margin-top: 54px !important;
    margin-bottom: 84px;
}

.transparency-card,
.practice-card,
.target-card,
.case-card,
.authority-card,
.registration-panel,
.about-section,
.attorney-card {
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-md) !important;
    background: var(--surface) !important;
    box-shadow: var(--shadow-card) !important;
}

.transparency-card {
    padding: 26px 24px !important;
    text-align: left !important;
    border-top: 0 !important;
    display: block;
}

.transparency-card:hover,
.practice-card:hover,
.target-card:hover,
.case-card:hover,
.authority-card:hover,
.attorney-card:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--shadow-soft) !important;
    border-color: rgba(164, 0, 0, .18) !important;
}

/* Card link — wrap entire card as clickable link */
a.card-link {
    display: block;
    text-decoration: none;
    color: inherit;
}
a.card-link:hover {
    color: inherit;
}

.transparency-card .icon,
.practice-card .title-group i,
.authority-card i {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-soft);
    color: var(--accent) !important;
    font-size: 18px !important;
    margin-bottom: 18px !important;
}

.transparency-card h3 {
    font-family: var(--font-display) !important;
    font-size: 18px !important;
    font-weight: 850 !important;
    color: var(--fg) !important;
    margin-bottom: 8px !important;
}

.transparency-card p,
.case-card p,
.practice-card p,
.target-card p,
.attorney-practice {
    color: var(--muted) !important;
}

.main-content {
    padding: 0 0 84px !important;
}

.section-grid {
    grid-template-columns: 1fr !important;
    gap: 78px !important;
}

.news-block h2,
.sidebar-title,
.section-intro h3,
.section-title,
.about-section h3 {
    border-left: 0 !important;
    padding-left: 0 !important;
    text-align: center;
    justify-content: center;
    font-family: var(--font-display) !important;
    color: var(--fg) !important;
    font-size: 30px !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    margin-bottom: 14px !important;
}

.news-block h2 a {
    position: absolute;
    right: 0;
    font-size: 14px !important;
    color: var(--accent) !important;
}

.news-block h2 {
    position: relative;
    margin-bottom: 34px !important;
}

.news-block h2::after,
.section-intro h3::after,
.section-title::after,
.about-section h3::after {
    content: '';
    display: block;
    width: 42px;
    height: 3px;
    margin: 12px auto 0;
    border-radius: 999px;
    background: var(--accent);
}

.news-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.news-item {
    display: block !important;
    padding: 24px !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-md);
    background: var(--surface);
    box-shadow: var(--shadow-card);
}

.news-item:hover {
    padding-left: 24px !important;
    transform: translateY(-4px);
    box-shadow: var(--shadow-soft);
}

.news-item .title {
    display: block;
    min-height: 56px;
    padding-left: 0 !important;
    font-size: 17px !important;
    font-weight: 850;
    line-height: 1.6;
}

.news-item .title::before {
    display: none !important;
}

.news-item .date {
    display: block;
    margin-bottom: 12px;
    color: var(--accent) !important;
    font-size: 13px !important;
    font-weight: 800;
    order: -1;
}

.case-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.case-card {
    padding: 0 !important;
    overflow: hidden;
}

.case-card img {
    height: 230px !important;
    margin-bottom: 0 !important;
}

.case-card h4,
.case-card p {
    padding-left: 24px;
    padding-right: 24px;
}

.case-card h4 {
    padding-top: 22px;
    color: var(--fg);
    font-size: 19px !important;
}

.case-card p {
    padding-bottom: 24px;
}

.sidebar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.sidebar .news-block {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 32px;
    box-shadow: var(--shadow-card);
}

.block-spaced {
    margin-top: 0 !important;
}

.sidebar-services,
.judicial-list {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px !important;
    margin-bottom: 0 !important;
}

.service-btn,
.judicial-list li a {
    border-radius: 10px;
    border: 1px solid var(--border) !important;
    background: #fff !important;
    min-height: 58px;
    color: var(--fg) !important;
    box-shadow: none !important;
}

.service-btn:hover,
.judicial-list li a:hover {
    background: var(--accent) !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
    padding-left: 20px !important;
}

.page-header,
body:not(.attorneys-page) .page-header {
    height: 256px !important;
    margin-bottom: 72px !important;
    background: #8B0000 !important;
    position: relative;
}


.page-header h2,
body:not(.attorneys-page) .page-header h2 {
    position: relative;
    z-index: 1;
    font-family: var(--font-display) !important;
    font-size: 44px !important;
    font-weight: 900 !important;
    letter-spacing: 2px !important;
    text-shadow: 0 8px 26px rgba(0,0,0,.34) !important;
}

.about-section,
.consultation-section {
    padding: 64px !important;
    margin-bottom: 34px !important;
}

.about-section h3,
.section-title {
    margin-bottom: 36px !important;
}

.about-text p {
    font-size: 17px !important;
    color: #3f4652 !important;
}

.about-image img,
.hardware-item img,
.map-placeholder,
.attorney-photo img,
.modal-photo img {
    border-radius: var(--radius-md) !important;
    box-shadow: none !important;
}

.target-grid,
.hardware-grid,
.practice-grid,
.attorney-grid,
.authority-grid {
    gap: 22px !important;
}

.target-card,
.practice-card,
.authority-card {
    padding: 30px !important;
}

.practice-card .title-group {
    display: block !important;
}

.practice-card h3,
.target-card h4 {
    font-family: var(--font-display) !important;
    color: var(--fg) !important;
    font-size: 20px !important;
    font-weight: 850 !important;
}

.attorneys-page header {
    background: #8B0000 !important;
    border-bottom: 0 !important;
}

.attorneys-page .page-header {
    margin-bottom: 70px !important;
}

.attorney-grid::before {
    display: none !important;
}

.attorney-card {
    overflow: hidden;
}

.attorney-card::before {
    display: none !important;
}

.attorney-photo {
    height: 360px !important;
    background: #f3f4f6 !important;
}

.attorney-info {
    background: #fff !important;
    text-align: left !important;
    padding: 24px !important;
}

.attorney-name {
    font-family: var(--font-display) !important;
    color: var(--fg) !important;
    font-size: 22px !important;
    font-weight: 900 !important;
}

.attorney-title {
    color: var(--accent) !important;
    font-weight: 800 !important;
}

.registration-panel input,
.registration-panel select,
.registration-panel textarea,
.search-input-group input,
.search-input-group select {
    border-radius: 10px !important;
    border: 1px solid var(--border) !important;
    background: #fff !important;
}

.submit-btn,
.search-input-group button,
.authority-card .secondary {
    border-radius: 6px !important;
    background: var(--accent) !important;
    color: #fff !important;
    border-color: var(--accent) !important;
    box-shadow: 0 10px 22px rgba(164,0,0,.18);
}

footer {
    margin-top: 84px !important;
    padding: 54px 0 0 !important;
    background: #8B0000 !important;
}

footer .container {
    max-width: 1440px !important;
    padding-left: 72px !important;
    padding-right: 72px !important;
}

footer > .container > div:first-child {
    text-align: left !important;
    margin-bottom: 38px !important;
    padding-bottom: 28px !important;
    border-bottom-color: rgba(255,255,255,.14) !important;
}

footer .footer-grid {
    gap: 90px !important;
}

footer h3,
footer h4,
footer h4 {
    font-family: var(--font-display) !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
}

footer h4 span {
    background: rgba(255,255,255,.7) !important;
}

@media (max-width: 1200px) {
    header .container,
    nav .container,
    footer .container,
    body:not(.attorneys-page) header .container,
    body:not(.attorneys-page) nav .container {
        padding-left: 28px !important;
        padding-right: 28px !important;
    }

    nav,
    body:not(.attorneys-page) nav {
        position: static !important;
        background: #8B0000 !important;
        pointer-events: auto;
    }

    nav .container {
        min-height: auto;
        overflow-x: auto;
        justify-content: flex-start;
    }

    nav ul,
    body:not(.attorneys-page) nav ul {
        justify-content: flex-start !important;
        min-width: max-content;
        gap: 24px !important;
    }

    .transparency-grid,
    .transparency-grid.home-shortcuts,
    .news-list {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .sidebar {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    header .container,
    nav .container,
    footer .container,
    body:not(.attorneys-page) header .container,
    body:not(.attorneys-page) nav .container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    header,
    body:not(.attorneys-page) header {
        padding: 14px 0 !important;
    }

    .header-content,
    .logo-area,
    body:not(.attorneys-page) .header-content,
    body:not(.attorneys-page) .logo-area {
        flex-direction: row !important;
        text-align: left !important;
    }

    .hero {
        height: 360px !important;
        padding-top: 0 !important;
        align-items: center !important;
    }

    .hero-text h2 {
        font-size: 34px !important;
    }

    .hero-text p {
        font-size: 15px !important;
    }

    .transparency-grid,
    .transparency-grid.home-shortcuts,
    .news-list,
    .case-grid,
    .sidebar-services,
    .judicial-list {
        grid-template-columns: 1fr !important;
    }

    .transparency-grid,
    .transparency-grid.home-shortcuts {
        margin-top: 26px !important;
        margin-bottom: 48px !important;
    }

    .page-header,
    body:not(.attorneys-page) .page-header {
        height: 210px !important;
        margin-bottom: 42px !important;
    }

    .page-header h2,
    body:not(.attorneys-page) .page-header h2 {
        font-size: 32px !important;
    }

    .about-section,
    .consultation-section {
        padding: 30px 18px !important;
    }

    .news-block h2,
    .sidebar-title,
    .section-intro h3,
    .section-title,
    .about-section h3 {
        font-size: 24px !important;
    }

    .news-block h2 a {
        position: static;
        display: block;
        margin-top: 8px;
    }

    .attorney-photo {
        height: 260px !important;
    }

    footer > .container > div:first-child {
        text-align: center !important;
    }
}

/* Local preview correction: preserve container side gutters and centered section titles. */
.main-content.container {
    padding-left: 40px !important;
    padding-right: 40px !important;
}

.news-block h2,
.sidebar-title,
.section-intro h3,
.section-title,
.about-section h3 {
    display: block !important;
}

@media (max-width: 768px) {
    .main-content.container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}

/* Attorneys page final alignment with the same card language as the generated design. */
.attorneys-page > .container {
    max-width: 1440px !important;
    padding: 72px 72px 0 !important;
}

.attorneys-page .section-intro {
    display: block !important;
}

.attorneys-page .attorney-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 50px 60px !important;
    margin-bottom: 100px !important;
}

.attorneys-page .attorney-card {
    display: grid !important;
    min-height: 420px !important;
    border-radius: var(--radius-md) !important;
}

.attorneys-page .attorney-photo {
    height: 340px !important;
    min-height: 0 !important;
}

.attorneys-page .attorney-info {
    display: block !important;
    padding: 44px 50px 40px !important;
}

.attorneys-page .attorney-name {
    font-size: 28px !important;
}

.attorneys-page .attorney-title {
    display: block;
    font-size: 17px !important;
    margin-bottom: 12px !important;
}

.attorneys-page .attorney-practice {
    font-size: 16px !important;
    line-height: 1.65 !important;
    border-top: 1px solid var(--border) !important;
    padding-top: 12px !important;
}

.attorneys-page .attorney-practice::before,
.attorneys-page .attorney-practice::after {
    display: none !important;
}

@media (max-width: 1200px) {
    .attorneys-page > .container {
        padding-left: 28px !important;
        padding-right: 28px !important;
    }

    .attorneys-page .attorney-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 768px) {
    .attorneys-page > .container {
        padding: 42px 16px 0 !important;
    }

    .attorneys-page .attorney-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .attorneys-page .attorney-photo {
        height: 220px !important;
    }
}

/* Fixed site header: keep logo and navigation available while scrolling. */
:root {
    --fixed-header-height: 82px;
    --fixed-nav-height: 42px;
}

body {
    padding-top: calc(var(--fixed-header-height) + var(--fixed-nav-height));
}

header,
body:not(.attorneys-page) header,
.attorneys-page header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: var(--fixed-header-height) !important;
    min-height: var(--fixed-header-height) !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    z-index: 3000 !important;
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12) !important;
}

header .container,
body:not(.attorneys-page) header .container,
.attorneys-page header .container {
    width: 100% !important;
}

nav,
body:not(.attorneys-page) nav,
.attorneys-page nav {
    position: fixed !important;
    top: var(--fixed-header-height) !important;
    left: 0 !important;
    right: 0 !important;
    height: var(--fixed-nav-height) !important;
    min-height: var(--fixed-nav-height) !important;
    background: #8B0000 !important;
    box-shadow: 0 1px 0 rgba(255,255,255,0.12) inset, 0 8px 18px rgba(0,0,0,0.08) !important;
    z-index: 2999 !important;
    pointer-events: auto !important;
}

nav .container,
body:not(.attorneys-page) nav .container,
.attorneys-page nav .container {
    min-height: var(--fixed-nav-height) !important;
    height: var(--fixed-nav-height) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
    scrollbar-width: none;
}

nav .container::-webkit-scrollbar,
body:not(.attorneys-page) nav .container::-webkit-scrollbar,
.attorneys-page nav .container::-webkit-scrollbar {
    display: none;
}

nav ul,
body:not(.attorneys-page) nav ul,
.attorneys-page nav ul {
    justify-content: flex-start !important;
    gap: 28px !important;
    min-width: max-content;
}

nav li a,
body:not(.attorneys-page) nav li a,
.attorneys-page nav li a {
    padding: 10px 0 !important;
    font-size: 15px !important;
}

@media (max-width: 768px) {
    :root {
        --fixed-header-height: 68px;
        --fixed-nav-height: 40px;
    }

    body {
        padding-top: calc(var(--fixed-header-height) + var(--fixed-nav-height));
    }

    nav ul,
    body:not(.attorneys-page) nav ul,
    .attorneys-page nav ul {
        gap: 22px !important;
    }

    nav li a,
    body:not(.attorneys-page) nav li a,
    .attorneys-page nav li a {
        font-size: 14px !important;
        padding: 9px 0 !important;
    }
}

/* Merge navigation into the fixed top header: logo left, nav right in one bar. */
:root {
    --fixed-header-height: 86px;
    --fixed-nav-height: 0px;
}

body {
    padding-top: var(--fixed-header-height) !important;
}

header,
body:not(.attorneys-page) header,
.attorneys-page header {
    height: var(--fixed-header-height) !important;
    min-height: var(--fixed-header-height) !important;
}

header .container,
body:not(.attorneys-page) header .container,
.attorneys-page header .container,
nav .container,
body:not(.attorneys-page) nav .container,
.attorneys-page nav .container {
    max-width: 1440px !important;
    padding-left: 72px !important;
    padding-right: 72px !important;
}

nav,
body:not(.attorneys-page) nav,
.attorneys-page nav {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: var(--fixed-header-height) !important;
    min-height: var(--fixed-header-height) !important;
    background: transparent !important;
    box-shadow: none !important;
    z-index: 3001 !important;
    pointer-events: none !important;
}

nav .container,
body:not(.attorneys-page) nav .container,
.attorneys-page nav .container {
    height: var(--fixed-header-height) !important;
    min-height: var(--fixed-header-height) !important;
    justify-content: flex-end !important;
    overflow-x: visible !important;
    pointer-events: none !important;
}

nav ul,
body:not(.attorneys-page) nav ul,
.attorneys-page nav ul {
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 28px !important;
    pointer-events: auto !important;
}

nav li a,
body:not(.attorneys-page) nav li a,
.attorneys-page nav li a {
    padding: 8px 0 !important;
    font-size: 14px !important;
    color: rgba(255,255,255,0.92) !important;
}

nav li a::after {
    bottom: -4px !important;
}

@media (max-width: 1200px) {
    header .container,
    body:not(.attorneys-page) header .container,
    .attorneys-page header .container,
    nav .container,
    body:not(.attorneys-page) nav .container,
    .attorneys-page nav .container {
        padding-left: 28px !important;
        padding-right: 28px !important;
    }

    nav ul,
    body:not(.attorneys-page) nav ul,
    .attorneys-page nav ul {
        gap: 20px !important;
    }

    nav li a,
    body:not(.attorneys-page) nav li a,
    .attorneys-page nav li a {
        font-size: 13px !important;
    }
}

@media (max-width: 900px) {
    :root {
        --fixed-header-height: 108px;
    }

    body {
        padding-top: var(--fixed-header-height) !important;
    }

    header,
    body:not(.attorneys-page) header,
    .attorneys-page header {
        align-items: flex-start !important;
        padding-top: 12px !important;
    }

    nav,
    body:not(.attorneys-page) nav,
    .attorneys-page nav {
        top: 58px !important;
        height: 50px !important;
        min-height: 50px !important;
        background: #8B0000 !important;
    }

    nav .container,
    body:not(.attorneys-page) nav .container,
    .attorneys-page nav .container {
        height: 50px !important;
        min-height: 50px !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        pointer-events: auto !important;
    }

    nav ul,
    body:not(.attorneys-page) nav ul,
    .attorneys-page nav ul {
        justify-content: flex-start !important;
        gap: 18px !important;
    }
}

/* Attorney card layout: photo 40% | info 60% */
.attorneys-page .attorney-card {
    grid-template-columns: 38% 62% !important;
}
.attorneys-page .attorney-photo {
    width: 100% !important;
    flex: none !important;
}
.attorneys-page .attorney-photo img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
.attorneys-page .attorney-info {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

/* 2026-05-29 footer quick links alignment: unify icon column across all pages. */
footer .footer-grid .footer-col:nth-child(2) ul {
    list-style: none !important;
    padding-left: 0 !important;
}

footer .footer-grid .footer-col:nth-child(2) li {
    margin: 0 0 10px 0 !important;
}

footer .footer-grid .footer-col:nth-child(2) li a {
    display: grid !important;
    grid-template-columns: 16px max-content !important;
    column-gap: 10px !important;
    align-items: center !important;
    width: max-content !important;
    line-height: 1.7 !important;
    text-align: left !important;
}

footer .footer-grid .footer-col:nth-child(2) li a i {
    display: none !important;
}

footer .footer-grid .footer-col:nth-child(2) li a::before {
    content: "›";
    display: block;
    width: 16px;
    color: #e8c56a;
    font-size: 20px;
    font-weight: 800;
    line-height: 1;
    text-align: left;
}

/* 2026-05-29 footer brand logo: match the header's white ring mark on red background. */
footer > .container > div:first-child > div > div:first-child,
footer > .container > div:first-child .logo-emblem {
    width: 50px !important;
    height: 50px !important;
    min-width: 50px !important;
    border-radius: 999px !important;
    border: 12px solid #fff !important;
    background: transparent !important;
    color: transparent !important;
    box-shadow: 0 0 0 1px rgba(255,255,255,0.12) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

footer > .container > div:first-child > div > div:first-child i,
footer > .container > div:first-child .logo-emblem i {
    display: none !important;
}
