/* ── PW Fonts: UntitledSerif + ABCDiatype ── */
@font-face { font-family: 'UntitledSerif'; src: url('fonts/untitled-serif-regular.woff2') format('woff2'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'UntitledSerif'; src: url('fonts/untitled-serif-regular-italic.woff2') format('woff2'); font-weight: 400; font-style: italic; font-display: swap; }
@font-face { font-family: 'UntitledSerif'; src: url('fonts/untitled-serif-medium.woff2') format('woff2'); font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: 'UntitledSerif'; src: url('fonts/untitled-serif-medium-italic.woff2') format('woff2'); font-weight: 500; font-style: italic; font-display: swap; }
@font-face { font-family: 'UntitledSerif'; src: url('fonts/untitled-serif-bold.woff2') format('woff2'); font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: 'UntitledSerif'; src: url('fonts/untitled-serif-bold-italic.woff2') format('woff2'); font-weight: 700; font-style: italic; font-display: swap; }
@font-face { font-family: 'ABCDiatype'; src: url('fonts/ABCDiatype-Regular.woff2') format('woff2'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'ABCDiatype'; src: url('fonts/ABCDiatype-RegularItalic.woff2') format('woff2'); font-weight: 400; font-style: italic; font-display: swap; }
@font-face { font-family: 'ABCDiatype'; src: url('fonts/ABCDiatype-Medium.woff2') format('woff2'); font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: 'ABCDiatype'; src: url('fonts/ABCDiatype-MediumItalic.woff2') format('woff2'); font-weight: 500; font-style: italic; font-display: swap; }
@font-face { font-family: 'ABCDiatype'; src: url('fonts/ABCDiatype-Bold.woff2') format('woff2'); font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: 'ABCDiatype'; src: url('fonts/ABCDiatype-BoldItalic.woff2') format('woff2'); font-weight: 700; font-style: italic; font-display: swap; }
@font-face { font-family: 'ABCDiatype'; src: url('fonts/ABCDiatype-Black.woff2') format('woff2'); font-weight: 900; font-style: normal; font-display: swap; }

:root {
    --navy: #001e46;
    --navy-mid: #0B3D71;
    --pw-blue: #B9C8DA;
    --pw-gray: #DCE3E1;
    --pw-light: #F5F7FB;
    --white: #ffffff;
    --gray-100: #F5F5F5;
    --gray-200: #E1E6E4;
    --gray-400: #8a8a8a;
    --gray-600: #666666;
    --text-primary: #03203D;
    --text-secondary: #454545;
    --whatsapp: #25D366;
    --whatsapp-dark: #128C7E;
    --font-serif: 'UntitledSerif', Georgia, serif;
    --font-sans: 'ABCDiatype', sans-serif;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
    font-family: var(--font-sans);
    color: var(--text-primary);
    background: var(--white);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

/* ══════════════ HEADER (PW-style sticky) ══════════════ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--white);
    transition: box-shadow 0.3s;
}
.site-header.scrolled {
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    box-shadow: 0 1px 12px rgba(3, 32, 61, 0.08);
}
.site-header.scrolled .header-secondary {
    background: transparent;
    border-bottom-color: rgba(3, 32, 61, 0.08);
}
.site-header.scrolled .header-primary {
    background: transparent;
}

.header-secondary {
    display: none;
    background: var(--pw-light);
    border-bottom: 1px solid var(--gray-200);
}
.header-secondary-inner {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}
.header-secondary-left {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--navy-mid);
    font-weight: 700;
}
.header-secondary-left span {
    color: var(--gray-400);
    margin: 0 8px;
    font-weight: 400;
}
.header-wa-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--navy);
    color: var(--white);
    font-family: var(--font-sans);
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    padding: 9px 18px;
    text-decoration: none;
    transition: background 0.3s;
    line-height: 1;
}
.header-wa-btn:hover { background: var(--navy-mid); }
.header-wa-btn svg {
    width: 14px;
    height: 14px;
    fill: var(--white);
    flex-shrink: 0;
}

/* Hero WhatsApp overlay (hidden on desktop, shown on mobile) */
.hero-wa-overlay { display: none; }

.header-primary {
    background: var(--white);
}
.header-primary-inner {
    max-width: none;
    margin: 0;
    padding: 0 48px 0 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 93px;
}

.logo {
    display: flex;
    align-items: stretch;
    text-decoration: none;
    padding: 0;
    margin: 0;
    height: 100%;
    position: relative;
    z-index: 10;
}
.logo-img {
    height: 100%;
    width: auto;
    display: block;
    object-fit: contain;
}
/* legacy classes (kept for backward compatibility, not rendered in current markup) */
.logo-mark {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}
.logo-mark img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0) invert(1);
}
.logo-text {
    display: flex;
    flex-direction: column;
    line-height: 1.15;
}
.logo-text .firm-name {
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--white);
    white-space: nowrap;
}
.logo-text .firm-type {
    font-family: var(--font-sans);
    font-size: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: rgba(255,255,255,0.5);
    font-weight: 400;
    margin-top: 1px;
}

.main-nav {
    display: flex;
    align-items: center;
    gap: 0;
}
.main-nav a {
    font-family: var(--font-sans);
    color: var(--navy);
    text-decoration: none;
    font-size: 0.88rem;
    font-weight: 400;
    padding: 20px 20px;
    transition: color 0.3s;
}
.main-nav a:hover { color: var(--navy-mid); }
.main-nav a.active { color: var(--navy-mid); font-weight: 500; }

.lang-switcher {
    display: flex;
    align-items: center;
    gap: 6px;
    padding-left: 24px;
    margin-left: 4px;
    border-left: 1px solid var(--gray-200);
    font-family: var(--font-sans);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 500;
}
.lang-switcher a {
    color: rgba(3, 32, 61, 0.5);
    text-decoration: none;
    padding: 4px 6px;
    transition: color 0.3s;
}
.lang-switcher a:hover { color: var(--navy); }
.lang-switcher a.active { color: var(--navy); font-weight: 700; }
.lang-switcher .lang-sep { color: var(--gray-300); }

.mobile-nav-overlay .lang-switcher {
    border-left: none;
    padding-left: 0;
    margin-left: 0;
    margin-top: 32px;
    justify-content: center;
    font-size: 0.95rem;
}
.mobile-nav-overlay .lang-switcher a { color: rgba(255,255,255,0.6); }
.mobile-nav-overlay .lang-switcher a.active { color: var(--white); }

.nav-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
}
.nav-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--navy);
    margin: 5px 0;
    transition: all 0.3s;
}

/* ══════════════ HERO (home) ══════════════ */
.hero {
    position: relative;
    width: 100%;
    overflow: hidden;
    max-height: 560px;
}
.hero img {
    width: 100%;
    height: 560px;
    display: block;
    object-fit: cover;
    object-position: center 30%;
}
.hero-overlay {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    background: rgba(11, 61, 113, 0.78);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 48px 56px 64px;
    gap: 28px;
}
.hero-tagline {
    font-family: var(--font-serif);
    font-size: clamp(2.25rem, 3.4vw, 3.5rem);
    font-weight: 700;
    color: var(--white);
    line-height: 1.08;
    letter-spacing: -0.025em;
    max-width: 620px;
}

/* ══════════════ PAGE HERO (interior pages) ══════════════ */
.page-hero {
    background: var(--navy);
    padding: 80px 0 64px;
    position: relative;
    overflow: hidden;
}
.page-hero::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 40%;
    height: 100%;
    background: linear-gradient(135deg, transparent 40%, rgba(185, 200, 218, 0.08) 100%);
    pointer-events: none;
}
.page-hero .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
    position: relative;
}
.page-hero-overline {
    font-family: var(--font-sans);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--pw-blue);
    font-weight: 500;
    margin-bottom: 20px;
}
.page-hero-title {
    font-family: var(--font-serif);
    font-size: clamp(2.8rem, 5.5vw, 4.5rem);
    font-weight: 700;
    color: var(--white);
    line-height: 1.05;
    letter-spacing: -0.015em;
    max-width: 900px;
}
.hero-title-prefix {
    display: block;
    font-family: var(--font-serif);
    font-size: clamp(0.85rem, 1vw, 1rem);
    font-weight: 400;
    font-style: italic;
    color: var(--pw-blue);
    letter-spacing: 0.04em;
    margin-bottom: 14px;
    text-transform: lowercase;
    opacity: 0.85;
    line-height: 1;
}
.page-hero-subtitle {
    font-family: var(--font-serif);
    font-size: clamp(1.05rem, 1.4vw, 1.2rem);
    color: rgba(255,255,255,0.65);
    line-height: 1.55;
    margin-top: 24px;
    max-width: 720px;
    font-style: italic;
    font-weight: 400;
}
.page-hero-breadcrumb {
    font-family: var(--font-sans);
    font-size: 0.75rem;
    color: rgba(255,255,255,0.45);
    margin-top: 28px;
}
.page-hero-breadcrumb a {
    color: rgba(255,255,255,0.45);
    text-decoration: none;
    transition: color 0.3s;
}
.page-hero-breadcrumb a:hover { color: var(--white); }
.page-hero-breadcrumb span {
    margin: 0 8px;
}

/* ══════════════ WHATSAPP BUTTON ══════════════ */
.btn-whatsapp {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--whatsapp);
    color: var(--white);
    font-family: var(--font-sans);
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 14px 24px;
    text-decoration: none;
    transition: background 0.3s, transform 0.2s;
    border: none;
    cursor: pointer;
    width: fit-content;
}
.btn-whatsapp:hover {
    background: var(--whatsapp-dark);
    transform: translateY(-1px);
}
.btn-whatsapp--navy {
    background: var(--navy);
}
.btn-whatsapp--navy:hover {
    background: var(--navy-mid);
}
.btn-whatsapp svg {
    width: 20px;
    height: 20px;
    fill: currentColor;
}
.btn-whatsapp-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.15;
}
.btn-whatsapp-main {
    font-size: inherit;
    font-weight: inherit;
    text-transform: inherit;
    letter-spacing: inherit;
}
.btn-whatsapp-sub {
    font-size: 0.7rem;
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0.02em;
    opacity: 0.85;
    margin-top: 3px;
}

/* Floating WhatsApp button */
.btn-whatsapp-floating {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--whatsapp);
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    box-shadow: 0 4px 16px rgba(37, 211, 102, 0.4);
    z-index: 90;
    transition: transform 0.3s, box-shadow 0.3s;
}
.btn-whatsapp-floating:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 20px rgba(37, 211, 102, 0.5);
}
.btn-whatsapp-floating svg {
    width: 28px;
    height: 28px;
    fill: var(--white);
}

/* ══════════════ FIRM INTRO (editorial pull-quote style) ══════════════ */
.firm-intro {
    padding: 96px 0 100px;
    background: var(--pw-light);
    position: relative;
    overflow: hidden;
}
.firm-intro .container {
    max-width: 920px;
    margin: 0 auto;
    padding: 0 48px;
    text-align: center;
    position: relative;
}
.firm-intro-overline {
    display: block;
    background: var(--pw-blue);
    color: var(--navy);
    font-family: var(--font-sans);
    font-size: 0.95rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 18px 28px;
    margin: 0 0 56px;
    text-align: left;
}
.firm-intro-text {
    font-family: var(--font-serif);
    font-size: clamp(1.15rem, 1.45vw, 1.35rem);
    font-weight: 400;
    color: var(--navy);
    line-height: 1.65;
    letter-spacing: -0.003em;
}
.firm-intro-text + .firm-intro-text {
    margin-top: 24px;
}
.firm-intro-text strong {
    font-weight: 700;
    color: var(--navy);
}
.firm-intro-text em {
    font-style: italic;
    color: var(--navy-mid);
    font-weight: 500;
}
.firm-intro-divider {
    display: none;
}

/* ══════════════ PRACTICE AREAS ══════════════ */
.practices {
    padding: 72px 0 56px;
    background: var(--white);
}
.practices--first { padding: 72px 0 40px; }
.practices--second { padding: 40px 0 72px; }
.practices-heading .section-overline {
    color: var(--navy-mid);
    letter-spacing: 0.22em;
    margin-bottom: 18px;
}
.practices .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.practices-inner {
    border-top: 4px solid var(--pw-blue);
    padding-top: 48px;
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 56px;
    align-items: start;
}
.practices-title {
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 4vw, 3.6rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.02;
    letter-spacing: -0.015em;
    hyphens: none;
    word-break: normal;
    overflow-wrap: normal;
}
.practices-right {
    display: flex;
    flex-direction: column;
}
.practices-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0 48px;
}
.practices-list a {
    font-family: var(--font-serif);
    font-size: 1.3rem;
    font-weight: 500;
    color: var(--navy);
    text-decoration: none;
    display: block;
    padding: 20px 0;
    border-bottom: 1px solid var(--gray-200);
    transition: color 0.3s;
    line-height: 1.3;
    letter-spacing: -0.005em;
}
.practices-list a:hover { color: var(--navy-mid); }
.practices-viewall {
    margin-top: 32px;
}
.practices-viewall a {
    display: block;
    background: var(--pw-blue);
    padding: 14px 24px;
    font-family: var(--font-sans);
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--navy);
    text-decoration: none;
    transition: background 0.3s;
}
.practices-viewall a:hover { background: #a8bace; }

/* ══════════════ STATS ══════════════ */
.stats-section {
    padding: 72px 0;
    background: var(--white);
    border-top: 1px solid var(--gray-200);
}
.stats-section .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.stats-inner {
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 56px;
    align-items: start;
}
.stats-title {
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 4vw, 3.6rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.02;
    letter-spacing: -0.015em;
}
.stats-grid {
    display: flex;
    gap: 56px;
    align-items: flex-start;
}
.stat-item {
    flex: 1;
}
.stat-number {
    font-family: var(--font-serif);
    font-size: 4rem;
    font-weight: 400;
    color: var(--navy);
    line-height: 1;
    margin-bottom: 4px;
}
.stat-label {
    font-family: var(--font-sans);
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 12px;
}
.stat-link {
    font-family: var(--font-sans);
    font-size: 0.78rem;
    color: var(--navy);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.3s;
}
.stat-link:hover { color: var(--navy-mid); }

/* ══════════════ STATS — DARK VARIANT (PW "Our Firm" style) ══════════════ */
.stats-section--dark {
    background: var(--navy);
    border-top: none;
    padding: 120px 0;
    position: relative;
    overflow: hidden;
}
.stats-section--dark::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 45%;
    height: 100%;
    background: linear-gradient(135deg, transparent 30%, rgba(185, 200, 218, 0.05) 100%);
    pointer-events: none;
}
.stats-section--dark .container {
    max-width: 1600px;
    position: relative;
}
.stats-section--dark .stats-inner {
    display: grid;
    grid-template-columns: 300px 1fr 420px;
    gap: 56px;
    align-items: start;
}
.stats-section--dark .stats-title {
    color: var(--white);
    font-size: clamp(2.4rem, 4vw, 3.6rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.015em;
    border-top: 1px solid var(--pw-blue);
    padding-top: 36px;
}
.stats-section--dark .stats-grid {
    display: flex;
    flex-direction: column;
    flex: initial;
    gap: 0;
    padding-top: 0;
    border-top: 1px solid rgba(185, 200, 218, 0.3);
}
.stats-section--dark .stat-item {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 40px;
    align-items: end;
    padding: 28px 0 24px;
    border-bottom: 1px solid rgba(185, 200, 218, 0.18);
    flex: initial;
}
.stats-section--dark .stat-item:last-child { border-bottom: none; }
.stats-section--dark .stat-number {
    font-family: var(--font-serif);
    font-size: clamp(4rem, 7vw, 6.2rem);
    font-weight: 400;
    color: var(--white);
    line-height: 0.95;
    margin-bottom: 0;
}
.stats-section--dark .stat-content {
    display: flex;
    flex-direction: column;
    gap: 22px;
    padding-bottom: 12px;
}
.stats-section--dark .stat-label {
    font-family: var(--font-sans);
    font-size: 0.88rem;
    color: rgba(255,255,255,0.88);
    font-weight: 700;
    line-height: 1.4;
    margin-bottom: 0;
    letter-spacing: 0.01em;
}
.stats-section--dark .stat-link {
    font-family: var(--font-sans);
    font-size: 0.78rem;
    color: rgba(255,255,255,0.65);
    text-decoration: none;
    text-transform: none;
    letter-spacing: 0.02em;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: color 0.3s, gap 0.3s;
}
.stats-section--dark .stat-link:hover {
    color: var(--white);
    gap: 12px;
}
.stats-section--dark .stat-link::after {
    content: '→';
    color: var(--pw-blue);
    font-size: 0.95rem;
}

.stats-quote {
    background: var(--navy-mid);
    padding: 48px 44px 40px;
    margin: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 100%;
    align-self: stretch;
}
.stats-quote blockquote {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: clamp(1.3rem, 1.9vw, 1.75rem);
    line-height: 1.35;
    color: var(--white);
    margin: 0;
    letter-spacing: -0.005em;
}
.stats-quote blockquote em {
    font-style: italic;
    color: var(--white);
    font-weight: 500;
}
.stats-quote figcaption {
    font-family: var(--font-sans);
    font-size: 0.78rem;
    font-weight: 700;
    color: rgba(255,255,255,0.85);
    letter-spacing: 0.06em;
    margin-top: 40px;
    text-transform: uppercase;
}

/* ══════════════ ABOUT / BIO ══════════════ */
.about {
    padding: 100px 0;
    background: var(--navy);
    position: relative;
    overflow: hidden;
}
.about .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}
.about-content { position: relative; z-index: 1; }
.section-overline {
    font-family: var(--font-sans);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--pw-blue);
    font-weight: 500;
    margin-bottom: 16px;
}
.section-title {
    font-family: var(--font-serif);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 700;
    color: var(--white);
    line-height: 1.2;
}
.section-line {
    width: 50px;
    height: 2px;
    background: var(--pw-blue);
    margin-top: 20px;
}
.about-role {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    color: var(--pw-blue);
    font-style: italic;
    font-weight: 400;
    margin-bottom: 28px;
}
.about-text {
    font-size: 0.88rem;
    color: rgba(255,255,255,0.6);
    line-height: 1.85;
    margin-bottom: 16px;
}
.credentials-list {
    list-style: none;
    margin-top: 28px;
    padding-top: 28px;
    border-top: 1px solid rgba(255,255,255,0.1);
}
.credentials-list li {
    font-size: 0.8rem;
    color: rgba(255,255,255,0.5);
    padding: 7px 0 7px 18px;
    position: relative;
}
.credentials-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 6px;
    height: 1px;
    background: var(--pw-blue);
}
.about-photo { position: relative; }
.about-photo .photo-frame {
    aspect-ratio: 3/4;
    background: rgba(255,255,255,0.05);
    overflow: hidden;
}
.about-photo .photo-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.about-photo .photo-accent {
    position: absolute;
    bottom: -16px;
    right: -16px;
    width: 100px;
    height: 100px;
    border: 1px solid var(--pw-blue);
    opacity: 0.25;
}

/* Light variant of about (for pages with white bg) */
.about-light { background: var(--white); }
.about-light .section-title { color: var(--navy); }
.about-light .about-text { color: var(--text-secondary); }
.about-light .credentials-list { border-top-color: var(--gray-200); }
.about-light .credentials-list li { color: var(--text-secondary); }
.about-light .about-photo .photo-frame { background: var(--gray-100); }

/* ══════════════ TEASER (small about block on homepage) ══════════════ */
.founder-teaser {
    padding: 100px 0;
    background: var(--navy);
    position: relative;
    overflow: hidden;
}
.founder-teaser .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.founder-teaser-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
.founder-teaser-photo {
    aspect-ratio: 4/5;
    overflow: hidden;
    background: rgba(255,255,255,0.05);
    position: relative;
}
.founder-teaser-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.founder-teaser-content .section-overline { color: var(--pw-blue); }
.founder-teaser-name {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 3.5vw, 3rem);
    font-weight: 700;
    color: var(--white);
    line-height: 1.1;
    margin-bottom: 12px;
}
.founder-teaser-role {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    color: var(--pw-blue);
    font-style: italic;
    margin-bottom: 24px;
}
.founder-teaser-excerpt {
    font-size: 0.95rem;
    color: rgba(255,255,255,0.65);
    line-height: 1.75;
    margin-bottom: 32px;
}
.founder-teaser-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-sans);
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--pw-blue);
    text-decoration: none;
    padding: 14px 0;
    border-bottom: 1px solid var(--pw-blue);
    transition: color 0.3s, border-color 0.3s;
}
.founder-teaser-cta:hover {
    color: var(--white);
    border-color: var(--white);
}
.founder-teaser-cta svg {
    width: 14px;
    height: 14px;
    fill: currentColor;
    transition: transform 0.3s;
}
.founder-teaser-cta:hover svg {
    transform: translateX(4px);
}

/* ══════════════ NEWS ══════════════ */
.news-section {
    padding: 72px 0;
    background: var(--white);
    border-top: 1px solid var(--gray-200);
}
.news-section .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.news-inner {
    display: block;
}
.news-title {
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 4vw, 3.6rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.02;
    letter-spacing: -0.015em;
    margin-bottom: 40px;
}
.news-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
}
.news-card-featured {
    grid-column: 1 / -1;
    position: relative;
    overflow: hidden;
    background: var(--navy);
    min-height: 340px;
    display: flex;
    align-items: flex-end;
    margin-bottom: 2px;
    text-decoration: none;
}
.news-card-featured img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.45;
    transition: opacity 0.4s, transform 0.6s;
}
.news-card-featured:hover img {
    opacity: 0.55;
    transform: scale(1.03);
}
.news-card-featured .news-card-content {
    position: relative;
    z-index: 2;
    padding: 32px;
    width: 100%;
}
.news-card-featured .news-card-category {
    color: var(--white);
    font-weight: 700;
}
.news-card-featured .news-card-date {
    color: rgba(255,255,255,0.6);
}
.news-card-featured .news-card-headline {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.25;
    margin-top: 8px;
}
.news-card-small {
    position: relative;
    overflow: hidden;
    background: var(--navy);
    min-height: 240px;
    display: flex;
    align-items: flex-end;
    border-right: 2px solid var(--white);
    text-decoration: none;
}
.news-card-small:last-child { border-right: none; }
.news-card-small img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.4;
    filter: grayscale(0.3);
    transition: opacity 0.4s, transform 0.6s;
}
.news-card-small:hover img {
    opacity: 0.5;
    transform: scale(1.03);
}
.news-card-small .news-card-content {
    position: relative;
    z-index: 2;
    padding: 20px;
    width: 100%;
}
.news-card-category {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--white);
}
.news-card-date {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    color: rgba(255,255,255,0.5);
    margin-top: 1px;
}
.news-card-small .news-card-headline {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.3;
    margin-top: 10px;
}
.news-viewmore {
    margin-top: 24px;
}
.news-viewmore a {
    display: block;
    background: var(--pw-blue);
    padding: 14px 24px;
    font-family: var(--font-sans);
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--navy);
    text-decoration: none;
    transition: background 0.3s;
}
.news-viewmore a:hover { background: #a8bace; }

/* News list (full page) */
.news-list-page {
    padding: 72px 0 100px;
    background: var(--white);
}
.news-list-page .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 48px;
}
.news-article {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 40px;
    padding: 40px 0;
    border-bottom: 1px solid var(--gray-200);
    text-decoration: none;
    transition: background 0.3s;
}
.news-article:first-child { padding-top: 0; }
.news-article:last-child { border-bottom: none; }
.news-article-img {
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
    background: var(--gray-100);
}
.news-article-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s;
}
.news-article:hover .news-article-img img {
    transform: scale(1.04);
}
.news-article-body {
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.news-article-meta {
    display: flex;
    gap: 16px;
    font-family: var(--font-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
}
.news-article-category {
    color: var(--navy-mid);
    font-weight: 700;
}
.news-article-date {
    color: var(--gray-400);
}
.news-article-title {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.25;
    margin-bottom: 12px;
    transition: color 0.3s;
}
.news-article:hover .news-article-title { color: var(--navy-mid); }
.news-article-excerpt {
    font-size: 0.92rem;
    color: var(--text-secondary);
    line-height: 1.7;
}

/* ══════════════ LEGAL / LONG-FORM CONTENT PAGE ══════════════ */
.legal-page {
    padding: 72px 0 100px;
    background: var(--white);
}
.legal-page .container {
    max-width: 820px;
    margin: 0 auto;
    padding: 0 48px;
}
.legal-content p {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    color: var(--text-primary);
    line-height: 1.8;
    margin-bottom: 24px;
}
.legal-content p strong {
    font-weight: 700;
    color: var(--navy);
}
.legal-content h2 {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.25;
    margin: 48px 0 20px;
}
.legal-content h2:first-child { margin-top: 0; }

.legal-callout {
    background: var(--pw-light);
    border-left: 4px solid var(--pw-blue);
    padding: 28px 32px;
    margin: 36px 0;
}
.legal-callout-label {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--navy-mid);
    font-weight: 700;
    margin-bottom: 10px;
}
.legal-callout-value {
    font-family: var(--font-serif);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.25;
    margin-bottom: 6px;
}
.legal-callout-note {
    font-family: var(--font-sans);
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

.legal-warning {
    background: var(--pw-light);
    border-left: 4px solid var(--navy);
    padding: 28px 32px;
    margin: 36px 0;
}
.legal-warning-label {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--navy);
    font-weight: 700;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.legal-warning-label::before {
    content: '!';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    background: var(--navy);
    color: var(--white);
    border-radius: 50%;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0;
    flex-shrink: 0;
}
.legal-warning p {
    font-family: var(--font-sans);
    font-size: 0.92rem;
    color: var(--text-primary);
    line-height: 1.7;
    margin-bottom: 0;
}

.legal-reference {
    background: var(--pw-light);
    border-left: 4px solid var(--pw-blue);
    padding: 28px 32px;
    margin-top: 56px;
    font-family: var(--font-sans);
    font-size: 0.9rem;
    color: var(--text-primary);
    line-height: 1.7;
}
.legal-reference-label {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--navy-mid);
    font-weight: 700;
    margin-bottom: 10px;
}

/* ══════════════ AWARDS ══════════════ */
.awards-section {
    padding: 72px 0;
    background: var(--pw-light);
    border-top: 1px solid var(--gray-200);
}
.awards-section .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.awards-inner {
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 56px;
    align-items: start;
}
.awards-title {
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 4vw, 3.6rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.02;
    letter-spacing: -0.015em;
}
.awards-list { list-style: none; }
.awards-list li {
    padding: 20px 0 20px 20px;
    border-bottom: 1px solid var(--gray-200);
    border-left: 3px solid transparent;
    transition: border-left-color 0.3s, padding-left 0.3s;
}
.awards-list li:first-child { padding-top: 0; }
.awards-list li:last-child { border-bottom: none; }
.awards-list li:hover {
    border-left-color: var(--pw-blue);
    padding-left: 28px;
}
.award-year {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--navy-mid);
    margin-bottom: 6px;
}
.award-text {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--navy);
    line-height: 1.4;
}
.award-source {
    font-family: var(--font-sans);
    font-size: 0.75rem;
    color: var(--gray-400);
    margin-top: 6px;
    font-style: italic;
}

/* ══════════════ LOCATIONS ══════════════ */
.locations {
    padding: 80px 0;
    background: var(--pw-light);
}
.locations .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.locations-header { margin-bottom: 48px; }
.locations-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border: 1px solid var(--gray-200);
    background: var(--white);
}
.location-card {
    border-right: 1px solid var(--gray-200);
    overflow: hidden;
    position: relative;
    text-decoration: none;
    color: inherit;
    display: block;
}
.location-card:last-child { border-right: none; }
.location-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: var(--pw-blue);
    transform: scaleX(0);
    transition: transform 0.4s ease;
    z-index: 2;
}
.location-card:hover::after { transform: scaleX(1); }
.location-card-img {
    width: 100%;
    height: 200px;
    overflow: hidden;
}
.location-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
    filter: grayscale(0.2);
}
.location-card:hover .location-card-img img {
    transform: scale(1.05);
    filter: grayscale(0);
}
.location-card-body { padding: 28px 32px 36px; }
.location-flag {
    font-family: var(--font-sans);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--navy-mid);
    font-weight: 500;
    margin-bottom: 10px;
}
.location-city {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: 12px;
}
.location-detail {
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.8;
}

/* Studio page: expanded location blocks */
.studio-location-block {
    padding: 80px 0;
    background: var(--white);
    border-bottom: 1px solid var(--gray-200);
}
.studio-location-block:nth-child(even) {
    background: var(--pw-light);
}
.studio-location-block .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 48px;
}
.studio-location-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
.studio-location-block:nth-child(even) .studio-location-grid {
    grid-template-columns: 1fr 1fr;
}
.studio-location-block:nth-child(even) .studio-location-content {
    order: 2;
}
.studio-location-block:nth-child(even) .studio-location-img {
    order: 1;
}
.studio-location-img {
    aspect-ratio: 4/3;
    overflow: hidden;
}
.studio-location-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.studio-location-content .location-flag {
    color: var(--navy-mid);
    margin-bottom: 16px;
}
.studio-location-name {
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 4vw, 3.5rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.05;
    margin-bottom: 20px;
}
.studio-location-description {
    font-size: 0.95rem;
    color: var(--text-secondary);
    line-height: 1.85;
    margin-bottom: 20px;
}
.studio-location-address {
    padding: 20px 24px;
    background: var(--white);
    border-left: 3px solid var(--pw-blue);
    font-family: var(--font-serif);
    font-size: 1rem;
    color: var(--navy);
    line-height: 1.7;
}
.studio-location-block:nth-child(even) .studio-location-address {
    background: var(--pw-light);
}

/* ══════════════ CONTACT ══════════════ */
.contact {
    padding: 80px 0;
    background: var(--white);
    border-top: 1px solid var(--gray-200);
}
.contact .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}
.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: start;
}
.contact-info-block { margin-bottom: 28px; }
.contact-label {
    font-family: var(--font-sans);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--gray-400);
    margin-bottom: 6px;
    font-weight: 500;
}
.contact-value {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    color: var(--navy);
}
.contact-value a {
    color: var(--navy);
    text-decoration: none;
    transition: color 0.3s;
}
.contact-value a:hover { color: var(--navy-mid); }

.contact-form { display: flex; flex-direction: column; gap: 18px; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gray-600);
    font-weight: 500;
}
.form-group input,
.form-group textarea {
    font-family: var(--font-sans);
    font-size: 0.88rem;
    padding: 12px 14px;
    border: 1px solid var(--gray-200);
    background: var(--gray-100);
    color: var(--text-primary);
    transition: border-color 0.3s, background 0.3s;
    outline: none;
}
.form-group input:focus,
.form-group textarea:focus {
    border-color: var(--navy);
    background: var(--white);
}
.form-group textarea { resize: vertical; min-height: 110px; }
.form-submit {
    font-family: var(--font-sans);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 700;
    padding: 14px 36px;
    background: var(--navy);
    color: var(--white);
    border: none;
    cursor: pointer;
    transition: background 0.3s;
    align-self: flex-start;
}
.form-submit:hover { background: var(--navy-mid); }

/* ══════════════ FOOTER ══════════════ */
.site-footer {
    background: var(--navy);
    padding: 56px 0 0;
}
.site-footer .container {
    max-width: none;
    margin: 0;
    padding: 0 48px 0 0;
}
.footer-grid {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 56px;
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.footer-brand .footer-logo {
    display: inline-block;
    background: transparent;
    padding: 0;
    margin-bottom: 28px;
    text-decoration: none;
    opacity: 0.95;
    transition: opacity 0.3s;
}
.footer-brand .footer-logo:hover {
    opacity: 1;
}
.footer-brand .footer-logo-mark {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    overflow: hidden;
}
.footer-brand .footer-logo-mark img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0) invert(1);
}
.footer-brand .footer-logo-text {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-weight: 700;
    color: var(--white);
}
.footer-brand p {
    font-size: 0.92rem;
    color: rgba(255,255,255,0.6);
    line-height: 1.65;
    margin-bottom: 22px;
    max-width: 320px;
}
.footer-social {
    display: flex;
    gap: 18px;
}
.footer-social a {
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    transition: color 0.3s;
}
.footer-social a:hover { color: var(--white); }

.footer-columns {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 36px;
}
.footer-col h4 {
    font-family: var(--font-sans);
    font-size: 0.95rem;
    text-transform: none;
    letter-spacing: -0.005em;
    color: var(--white);
    margin-bottom: 18px;
    font-weight: 600;
}
.footer-col a {
    display: block;
    font-size: 0.9rem;
    color: rgba(255,255,255,0.6);
    text-decoration: none;
    padding: 6px 0;
    font-weight: 400;
    line-height: 1.5;
    transition: color 0.3s;
}
.footer-col a:hover { color: var(--white); }

.footer-bottom {
    padding: 20px 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}
.footer-bottom p {
    font-size: 0.78rem;
    color: rgba(255,255,255,0.45);
    line-height: 1.5;
    font-weight: 400;
}
.footer-bottom-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.footer-logo-img {
    height: auto;
    width: 100%;
    max-width: 340px;
    display: block;
}
.footer-credentials {
    margin-top: 18px;
    margin-bottom: 22px;
}
.footer-credentials p {
    font-family: var(--font-sans);
    font-size: 0.78rem;
    color: rgba(255,255,255,0.55);
    line-height: 1.55;
    margin: 0 0 4px;
}
.btn-navy-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    background: transparent;
    border: 1px solid var(--navy);
    color: var(--navy);
    font-family: var(--font-sans);
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    text-decoration: none;
    transition: background 0.3s, color 0.3s;
}
.btn-navy-outline:hover {
    background: var(--navy);
    color: var(--white);
}
.footer-bottom-left .footer-policy {
    font-size: 0.78rem;
    color: rgba(255,255,255,0.4);
    letter-spacing: 0.01em;
    font-weight: 400;
}

/* Contact CTA (refined editorial, above footer) */
.contact-cta {
    padding: 110px 0 120px;
    background: var(--white);
    border-top: 1px solid var(--gray-200);
}
.contact-cta-title {
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 4vw, 3.6rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin-bottom: 24px;
}
.contact-cta-text {
    font-family: var(--font-serif);
    font-size: clamp(1rem, 1.3vw, 1.18rem);
    line-height: 1.6;
    color: var(--text-secondary);
    margin: 0 auto 40px;
    max-width: 600px;
    font-style: italic;
}
.contact-cta-buttons {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 32px;
}
.contact-cta-buttons .btn-whatsapp,
.contact-cta-buttons .btn-navy-outline {
    width: 340px;
    max-width: 100%;
    justify-content: center;
    box-sizing: border-box;
}
.contact-cta-hours {
    font-family: var(--font-sans);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--navy-mid);
    font-weight: 700;
    margin-top: 8px;
}
.footer-legal {
    display: flex;
    gap: 20px;
}
.footer-legal a {
    font-size: 0.68rem;
    color: rgba(255,255,255,0.25);
    text-decoration: none;
    transition: color 0.3s;
}
.footer-legal a:hover { color: rgba(255,255,255,0.5); }

/* ══════════════ UTILITY ══════════════ */
.container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 48px;
}

.reveal,
.reveal.visible {
    opacity: 1;
    transform: none;
}

/* Mobile nav overlay */
.mobile-lang-stack { display: none; }

.mobile-nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: var(--navy);
    z-index: 200;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.mobile-nav-overlay.active { display: flex; }
.mobile-nav-overlay a {
    font-family: var(--font-serif);
    font-size: 1.8rem;
    color: var(--white);
    text-decoration: none;
    padding: 14px 0;
}
.mobile-nav-overlay a:hover { color: var(--pw-blue); }
.mobile-nav-close {
    position: absolute;
    top: 20px;
    right: 28px;
    background: none;
    border: none;
    color: var(--white);
    font-size: 2rem;
    cursor: pointer;
}

/* ══════════════ PRACTICE AREA PAGES ══════════════ */
.practice-intro {
    padding: 100px 0 80px;
    background: var(--white);
}
.practice-intro .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 48px;
}
.practice-intro-grid {
    display: grid;
    grid-template-columns: 340px 1fr;
    gap: 64px;
    align-items: start;
}
.practice-intro-heading .section-overline {
    color: var(--navy-mid);
    margin-bottom: 18px;
}
.practice-intro-title {
    font-family: var(--font-serif);
    font-size: clamp(1.8rem, 2.8vw, 2.4rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.15;
    letter-spacing: -0.01em;
}
.practice-intro-content p {
    font-family: var(--font-serif);
    font-size: 1.08rem;
    line-height: 1.75;
    color: var(--navy);
    margin-bottom: 20px;
}
.practice-intro-content p:last-child { margin-bottom: 0; }
.practice-intro-content p strong { color: var(--navy); }
.practice-intro-content p em {
    color: var(--navy-mid);
    font-style: italic;
}

.practice-topics {
    padding: 80px 0 100px;
    background: var(--pw-light);
    border-top: 4px solid var(--pw-blue);
}
.practice-topics .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 48px;
}
.practice-topics-header {
    max-width: 760px;
    margin-bottom: 56px;
}
.practice-topics-header .section-overline {
    color: var(--navy-mid);
    margin-bottom: 18px;
}
.practice-topics-title {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 3.5vw, 2.8rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.12;
    letter-spacing: -0.01em;
}
.practice-topics-lead {
    font-family: var(--font-serif);
    font-size: 1.08rem;
    line-height: 1.7;
    color: var(--text-secondary);
    margin-top: 18px;
}
.practice-topics-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
}
.practice-topic {
    background: var(--white);
    padding: 32px 32px 32px 36px;
    border-left: 3px solid var(--pw-blue);
    transition: border-color 0.3s;
}
.practice-topic:hover { border-left-color: var(--navy); }
.practice-topic-title {
    font-family: var(--font-serif);
    font-size: 1.22rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.25;
    margin-bottom: 14px;
    letter-spacing: -0.005em;
}
.practice-topic-text {
    font-family: var(--font-sans);
    font-size: 0.92rem;
    color: var(--text-secondary);
    line-height: 1.7;
}

/* Detailed variant — long-form sections (e.g. separazione-divorzio) */
.practice-topics--detailed {
    background: var(--white);
    border-top: 4px solid var(--pw-blue);
}
.practice-topics--detailed .container {
    max-width: 1000px;
}
.practice-topics--detailed .practice-topics-grid {
    grid-template-columns: 1fr;
    gap: 0;
}
.practice-topics--detailed .practice-topic {
    background: transparent;
    border-left: none;
    border-bottom: 1px solid var(--gray-200);
    padding: 40px 0;
}
.practice-topics--detailed .practice-topic:first-child { padding-top: 0; }
.practice-topics--detailed .practice-topic:last-child { border-bottom: none; padding-bottom: 0; }
.practice-topics--detailed .practice-topic-title {
    font-size: 1.55rem;
    margin-bottom: 16px;
}
.practice-topics--detailed .practice-topic-text {
    font-family: var(--font-serif);
    font-size: 1.05rem;
    line-height: 1.8;
    color: var(--navy);
}

/* "Chips" variant — simple tag-style list of keywords */
.practice-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
}
.practice-chips span {
    font-family: var(--font-sans);
    font-size: 0.82rem;
    color: var(--navy);
    background: var(--white);
    padding: 10px 16px;
    border: 1px solid var(--gray-200);
    line-height: 1.3;
}

/* Related areas footer section */
.practice-related {
    padding: 72px 0;
    background: var(--white);
    border-top: 1px solid var(--gray-200);
}
.practice-related .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 48px;
    text-align: center;
}
.practice-related .section-overline {
    color: var(--navy-mid);
    margin-bottom: 12px;
}
.practice-related-title {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    font-weight: 700;
    color: var(--navy);
    margin-bottom: 32px;
    letter-spacing: -0.01em;
}
.practice-related-list {
    display: flex;
    gap: 12px 28px;
    justify-content: center;
    flex-wrap: wrap;
}
.practice-related-list a {
    font-family: var(--font-serif);
    font-size: 1rem;
    color: var(--navy);
    text-decoration: none;
    padding: 8px 0;
    border-bottom: 1px solid var(--pw-blue);
    transition: color 0.3s, border-color 0.3s;
}
.practice-related-list a:hover {
    color: var(--navy-mid);
    border-bottom-color: var(--navy-mid);
}

/* ══════════════ ARTICLE SINGLE PAGE ══════════════ */
.article-hero {
    background: var(--navy);
    padding: 72px 0 56px;
    position: relative;
    overflow: hidden;
}
.article-hero::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 40%;
    height: 100%;
    background: linear-gradient(135deg, transparent 40%, rgba(185, 200, 218, 0.08) 100%);
    pointer-events: none;
}
.article-hero .container {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 48px;
    position: relative;
}
.article-hero-meta {
    display: flex;
    gap: 14px;
    align-items: center;
    font-family: var(--font-sans);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    margin-bottom: 28px;
}
.article-category {
    color: var(--pw-blue);
    font-weight: 700;
}
.article-separator { color: rgba(255,255,255,0.3); }
.article-date { color: rgba(255,255,255,0.55); }
.article-title {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 3.8vw, 3.2rem);
    font-weight: 700;
    color: var(--white);
    line-height: 1.12;
    letter-spacing: -0.01em;
    margin-bottom: 28px;
}
.article-author {
    font-family: var(--font-serif);
    font-size: 1rem;
    color: rgba(255,255,255,0.55);
    font-style: italic;
}
.article-breadcrumb {
    font-family: var(--font-sans);
    font-size: 0.72rem;
    color: rgba(255,255,255,0.4);
    margin-top: 36px;
}
.article-breadcrumb a {
    color: rgba(255,255,255,0.4);
    text-decoration: none;
    transition: color 0.3s;
}
.article-breadcrumb a:hover { color: var(--white); }
.article-breadcrumb span { margin: 0 10px; color: rgba(255,255,255,0.25); }

.article-hero-image {
    background: var(--white);
    padding: 0;
}
.article-hero-image .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0;
}
.article-hero-image img {
    width: 100%;
    height: auto;
    max-height: 440px;
    object-fit: cover;
    display: block;
}

.article-body {
    background: var(--white);
    padding: 72px 0 80px;
}
.article-body .container {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 48px;
}
.article-body p {
    font-family: var(--font-serif);
    font-size: 1.12rem;
    line-height: 1.85;
    color: var(--navy);
    margin-bottom: 26px;
}
.article-body p:last-child { margin-bottom: 0; }
.article-body p strong { color: var(--navy); font-weight: 700; }
.article-body p em { color: var(--navy-mid); font-style: italic; }
.article-body p.article-lead {
    font-size: 1.28rem;
    line-height: 1.65;
    color: var(--navy);
    font-weight: 500;
    padding-bottom: 8px;
    margin-bottom: 32px;
    border-bottom: 1px solid var(--gray-200);
}
.article-body h2 {
    font-family: var(--font-serif);
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.25;
    letter-spacing: -0.01em;
    margin-top: 48px;
    margin-bottom: 20px;
}
.article-body blockquote {
    border-left: 3px solid var(--pw-blue);
    padding: 8px 0 8px 28px;
    margin: 32px 0;
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--navy-mid);
    font-size: 1.08rem;
    line-height: 1.7;
}

.article-signature {
    margin-top: 48px;
    padding-top: 28px;
    border-top: 1px solid var(--gray-200);
    font-family: var(--font-sans);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--navy-mid);
    font-weight: 700;
}

.article-back {
    background: var(--pw-light);
    padding: 32px 0;
    border-top: 1px solid var(--gray-200);
}
.article-back .container {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 48px;
}
.article-back a {
    font-family: var(--font-sans);
    font-size: 0.82rem;
    color: var(--navy);
    text-decoration: none;
    letter-spacing: 0.04em;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    transition: color 0.3s;
}
.article-back a:hover { color: var(--navy-mid); }
.article-back a::before {
    content: '←';
    font-size: 1.1rem;
}

.article-related {
    padding: 72px 0;
    background: var(--white);
    border-top: 1px solid var(--gray-200);
}
.article-related .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 48px;
}
.article-related-header {
    margin-bottom: 40px;
}
.article-related-header .section-overline {
    color: var(--navy-mid);
    margin-bottom: 12px;
}
.article-related-title {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    font-weight: 700;
    color: var(--navy);
    letter-spacing: -0.01em;
}
.article-related-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
}
.article-related-card {
    display: block;
    text-decoration: none;
    border-top: 2px solid var(--pw-blue);
    padding-top: 24px;
    transition: border-color 0.3s;
}
.article-related-card:hover { border-top-color: var(--navy); }
.article-related-card .meta {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--navy-mid);
    font-weight: 700;
    margin-bottom: 10px;
}
.article-related-card h3 {
    font-family: var(--font-serif);
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.3;
    transition: color 0.3s;
}
.article-related-card:hover h3 { color: var(--navy-mid); }

/* ══════════════ FOUNDER APPROACH (long-form on fondatore.html) ══════════════ */
.founder-approach {
    padding: 96px 0 100px;
    background: var(--pw-light);
    border-top: 4px solid var(--pw-blue);
}
.founder-approach .container {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 48px;
}
.founder-approach-header {
    margin-bottom: 56px;
}
.founder-approach-header .section-overline {
    color: var(--navy-mid);
    margin-bottom: 18px;
}
.founder-approach-title {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 3.5vw, 2.8rem);
    font-weight: 700;
    color: var(--navy);
    line-height: 1.12;
    letter-spacing: -0.01em;
}
.founder-approach-content p {
    font-family: var(--font-serif);
    font-size: 1.08rem;
    line-height: 1.85;
    color: var(--navy);
    margin-bottom: 24px;
    max-width: 820px;
}
.founder-approach-content p:last-child { margin-bottom: 0; }
.founder-approach-content p strong { font-weight: 700; color: var(--navy); }
.founder-approach-content p em {
    font-style: italic;
    color: var(--navy-mid);
}

/* ══════════════ FOOTER POLICY LINE ══════════════ */
.footer-policy {
    font-family: var(--font-sans);
    font-size: 0.72rem;
    color: rgba(255,255,255,0.4);
    letter-spacing: 0.02em;
    margin-top: 8px;
}

/* ══════════════ RESPONSIVE ══════════════ */
@media (max-width: 1024px) {
    .container, .practices .container, .stats-section .container,
    .about .container, .locations .container, .contact .container,
    .news-section .container, .awards-section .container,
    .founder-teaser .container, .page-hero .container,
    .studio-location-block .container, .news-list-page .container,
    .legal-page .container, .firm-intro .container,
    .site-footer .container {
        padding: 0 24px;
    }
    .site-footer .container { padding: 0 24px 0 12px; }
    .firm-intro { padding: 80px 0; }
    .firm-intro::after { top: 44px; height: 32px; }
    .header-primary-inner { padding: 0 24px 0 0; height: 69px; }
    .header-primary-inner .logo {
        background: #001e44;
        padding-right: 30px;
    }
    .mobile-lang-stack {
        display: flex;
        flex-direction: column;
        gap: 3px;
        margin-right: 14px;
        align-items: stretch;
        justify-content: center;
    }
    .mobile-lang-stack a {
        font-family: var(--font-sans);
        font-size: 0.6rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        color: var(--navy);
        text-decoration: none;
        padding: 2px 6px;
        border: 1px solid var(--navy);
        background: var(--white);
        line-height: 1.1;
        text-align: center;
        min-width: 28px;
    }
    .mobile-lang-stack a.active {
        background: var(--navy);
        color: var(--white);
    }
    .header-secondary { display: none; }
    .news-grid { grid-template-columns: repeat(2, 1fr); }
    .news-card-small:nth-child(2n) { border-right: none; }
    .news-card-small:nth-child(n+3) { border-top: 2px solid var(--white); }

    .hero-wa-overlay { display: none; }
    .practices-inner, .stats-inner, .news-inner, .awards-inner {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .practices-title, .stats-title, .locations-title, .news-title, .awards-title {
        font-size: clamp(2rem, 5vw, 2.8rem);
    }
    .footer-grid { grid-template-columns: 1fr; gap: 32px; }
    .footer-columns { grid-template-columns: repeat(2, 1fr); }
    .hero-overlay { width: 50%; padding: 36px 32px 48px; }
    .founder-teaser-grid { gap: 40px; }
    .studio-location-grid { gap: 40px; }
    .practice-intro-grid { grid-template-columns: 280px 1fr; gap: 40px; }
    .practice-topics-grid { gap: 20px; }
    .stats-section--dark .stats-inner {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .stats-quote { padding: 36px 32px; min-height: auto; }
}

@media (max-width: 768px) {
    .main-nav { display: none; }
    .nav-toggle { display: block; }

    .hero { max-height: none; }
    .hero img { height: 280px; }
    .hero-overlay {
        width: 100%;
        position: relative;
        background: var(--navy);
        padding: 36px 24px 44px;
    }
    .hero-tagline { font-size: clamp(1.85rem, 6vw, 2.4rem); line-height: 1.1; }
    .header-secondary-inner { height: 36px; }
    .header-secondary-left { display: none; }
    .header-wa-btn {
        font-size: 0.65rem;
        padding: 8px 14px;
        letter-spacing: 0.08em;
    }
    .header-wa-btn span.hide-mobile { display: none; }

    .page-hero { padding: 56px 0 48px; }

    .practices-list { grid-template-columns: 1fr; }
    .news-grid { grid-template-columns: 1fr; }
    .news-card-small { border-right: none; border-top: 2px solid var(--white); }
    .stats-grid { flex-direction: column; gap: 32px; }
    .stats-section--dark { padding: 48px 0 56px; }

    /* Tighter vertical rhythm on mobile (smaller gaps between sections) */
    .firm-intro { padding: 48px 0; }
    .practices { padding: 40px 0; }
    .practices--first { padding: 40px 0 24px; }
    .practices--second { padding: 24px 0 40px; }
    .news-section { padding: 40px 0; }
    .locations { padding: 56px 0; }
    .awards-section { padding: 48px 0; }
    .contact-cta { padding: 56px 0 64px; }
    .legal-page { padding: 40px 0 56px; }
    .news-list-page { padding: 40px 0 56px; }
    .about { padding: 56px 0; }
    .founder-teaser { padding: 56px 0; }

    .stats-section--dark .stat-item {
        grid-template-columns: auto 1fr;
        gap: 24px;
        padding: 20px 0;
    }
    .stats-section--dark .stat-number { font-size: clamp(3rem, 10vw, 4.5rem); }
    .stats-section--dark .stats-title { padding-top: 28px; }
    .stats-quote blockquote { font-size: 1.15rem; }
    .stats-quote figcaption { margin-top: 28px; }
    .about-grid { grid-template-columns: 1fr; gap: 40px; }
    .about-photo { order: -1; max-width: 320px; }
    .locations-grid { grid-template-columns: 1fr; }
    .location-card { border-right: none !important; border-bottom: 1px solid var(--gray-200); }
    .location-card:last-child { border-bottom: none; }
    .contact-grid { grid-template-columns: 1fr; gap: 48px; }
    .footer-columns { grid-template-columns: 1fr; }
    .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
    .footer-logo-img { max-width: 270px; }

    .founder-teaser-grid { grid-template-columns: 1fr; }
    .founder-teaser-photo { max-width: 320px; }

    .article-hero { padding: 40px 0 32px; }
    .article-hero .container { padding: 0 24px; }
    .article-title { font-size: clamp(1.7rem, 5vw, 2.2rem); }
    .article-body { padding: 36px 0 40px; }
    .article-body .container { padding: 0 24px; }
    .article-body p { font-size: 1.04rem; line-height: 1.75; }
    .article-body p.article-lead { font-size: 1.15rem; }
    .article-body h2 { font-size: 1.4rem; margin-top: 36px; }
    .article-back .container { padding: 0 24px; }
    .article-related { padding: 40px 0; }
    .article-related .container { padding: 0 24px; }
    .article-related-grid { grid-template-columns: 1fr; gap: 24px; }

    .founder-approach { padding: 48px 0 56px; }
    .founder-approach .container { padding: 0 24px; }
    .founder-approach-header { margin-bottom: 32px; }

    .practice-intro { padding: 40px 0 32px; }
    .practice-intro-grid { grid-template-columns: 1fr; gap: 28px; }
    .practice-topics { padding: 40px 0 48px; }
    .practice-topics-header { margin-bottom: 40px; }
    .practice-topics-grid { grid-template-columns: 1fr; gap: 20px; }
    .practice-topic { padding: 24px 20px 24px 24px; }
    .practice-topics--detailed .practice-topic { padding: 28px 0; }
    .practice-topics--detailed .practice-topic-title { font-size: 1.3rem; }
    .practice-related { padding: 56px 0; }

    .studio-location-grid {
        grid-template-columns: 1fr !important;
        gap: 32px;
    }
    .studio-location-block:nth-child(even) .studio-location-content { order: 2; }
    .studio-location-block:nth-child(even) .studio-location-img { order: 1; }

    .news-article {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .btn-whatsapp-floating {
        width: 52px;
        height: 52px;
        bottom: 16px;
        right: 16px;
    }
}

@media (max-width: 480px) {
    .logo-text .firm-name { font-size: 0.95rem; }
}
