﻿@import url('https://fonts.googleapis.com/css2?family=Assistant:wght@300;400;600;700;800&display=swap');

:root {
  /* DEFCON 1 Premium Design System */
  --jt-bg: #f7f8fb;
  --jt-surface: rgba(255, 255, 255, 0.84);
  --jt-surface-strong: rgba(255, 255, 255, 0.95);
  --jt-border: rgba(20, 35, 60, 0.12);
  --jt-primary: #10264a;
  --jt-primary-deep: #07152f;
  --jt-muted: #667085;
  --jt-accent: #5f7ea8;
  --jt-radius-lg: 28px;
  --jt-radius-md: 18px;
  --jt-shadow-soft: 0 14px 40px rgba(7, 21, 47, 0.08);
  --jt-shadow-strong: 0 28px 80px rgba(7, 21, 47, 0.16);

  /* Mapping to existing variable names used across the site */
  --color-primary: var(--jt-primary);
  --color-primary-hover: var(--jt-primary-deep);
  --color-secondary: var(--jt-accent);
  --color-accent: var(--jt-accent);
  --color-accent-hover: #4e6b91;
  --color-dark: var(--jt-primary-deep);
  --color-heading: var(--jt-primary-deep);
  --color-text: #2d3748;
  --color-text-muted: var(--jt-muted);
  --color-muted: var(--jt-muted);
  
  --color-bg: var(--jt-bg);
  --color-bg-alt: #ffffff;
  --color-border: var(--jt-border);
  --color-surface: var(--jt-surface-strong);
  
  --font-main: 'Assistant', system-ui, -apple-system, sans-serif;
  
  --radius-sm: 8px;
  --radius-md: var(--jt-radius-md);
  --radius-lg: var(--jt-radius-lg);
  --radius-pill: 50px;
  
  --shadow-soft: var(--jt-shadow-soft);
  --shadow-card: var(--jt-shadow-soft);
  --shadow-hover: var(--jt-shadow-strong);
  
  --container: 1200px;
  --container-narrow: 850px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font-main); color: var(--color-text); background: var(--color-bg); line-height: 1.7; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-accent); text-decoration: none; transition: color 0.2s ease; }
a:hover { color: var(--color-accent-hover); text-decoration: underline; }

h1, h2, h3, h4, h5, h6 { color: var(--color-heading); font-weight: 800; margin-top: 0; letter-spacing: -0.01em; }

.container { width: min(100% - 3rem, var(--container)); margin-inline: auto; }
.container--narrow { width: min(100% - 3rem, var(--container-narrow)); margin-inline: auto; }
.section { padding-block: clamp(4rem, 8vw, 6rem); }
.site-main { min-height: 60vh; }

/* Buttons */
.button { display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem; min-height: 3.2rem; padding: 0.8rem 1.8rem; border-radius: var(--radius-sm); border: none; font-weight: 700; font-family: var(--font-main); text-decoration: none !important; cursor: pointer; transition: all 300ms ease; font-size: 1.05rem; }
.button:hover { transform: translateY(-2px); }
.button--gold, .button--primary { background: var(--color-accent); color: #fff; box-shadow: 0 4px 15px rgba(233, 98, 80, 0.3); }
.button--gold:hover, .button--primary:hover { background: var(--color-accent-hover); color: #fff; box-shadow: 0 8px 25px rgba(233, 98, 80, 0.4); }
.button--outline { background: transparent; color: var(--color-primary); border: 2px solid var(--color-primary); }
.button--outline:hover { background: var(--color-primary); color: #fff; }

/* Header */
.site-header { background: #fff; position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 20px rgba(0,0,0,0.05); border-bottom: 1px solid var(--color-border); }
.site-header__top { background: var(--color-bg-alt); font-size: 0.85rem; border-bottom: 1px solid var(--color-border); }
.site-header__top-inner { display: flex; justify-content: space-between; align-items: center; padding-block: 0.5rem; }
.site-header__trust { color: var(--color-dark); margin: 0; font-weight: 600; }
.site-header__secondary-nav .menu { list-style: none; display: flex; gap: 1.5rem; margin: 0; padding: 0; }
.site-header__secondary-nav a { color: var(--color-text); text-decoration: none; transition: color 0.2s; }
.site-header__secondary-nav a:hover { color: var(--color-accent); }
.site-header__main-inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; min-height: 5.5rem; }
.site-branding a { color: var(--color-primary); text-decoration: none; display: flex; flex-direction: column; }
.site-branding__name { font-size: 1.8rem; font-weight: 800; color: var(--color-primary); }
.site-branding__description { font-size: 0.8rem; color: var(--color-text-muted); }
.site-branding img { max-height: 60px; width: auto; }
.primary-navigation .menu { list-style: none; display: flex; gap: 0.5rem; margin: 0; padding: 0; }
.primary-navigation a { color: var(--color-heading); padding: 0.6rem 1.2rem; border-radius: var(--radius-sm); text-decoration: none; font-weight: 600; font-size: 1.05rem; transition: all 0.2s ease; }
.primary-navigation a:hover, .primary-navigation .current-menu-item > a { color: var(--color-accent); background: var(--color-bg-alt); }
.menu-toggle { display: none; background: none; border: none; color: var(--color-primary); font-size: 1.8rem; cursor: pointer; padding: 0.5rem; }
.menu-toggle__icon::before { content: "\2630"; }

/* Hero Section */
.hero { position: relative; background: var(--color-primary); color: #fff; padding-block: clamp(4rem, 10vw, 7rem); }
.hero__grid { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(380px, 0.8fr); gap: 4rem; align-items: center; }
.hero__title { font-size: clamp(2.4rem, 5vw, 3.8rem); line-height: 1.15; margin: 0 0 1.5rem; color: #fff; }
.hero__description { font-size: clamp(1.1rem, 2vw, 1.3rem); max-width: 600px; color: rgba(255,255,255,0.85); line-height: 1.6; }

/* Hero Search */
.hero-search { display: flex; gap: 0.5rem; margin-top: 2.5rem; background: #fff; padding: 0.6rem; border-radius: var(--radius-sm); box-shadow: 0 10px 30px rgba(0,0,0,0.2); }
.hero-search input { flex: 1; border: 0; background: transparent; padding: 1rem 1.5rem; font: inherit; min-width: 0; font-size: 1.05rem; color: var(--color-heading); }
.hero-search input:focus { outline: none; }
.hero-search button { border: 0; border-radius: var(--radius-sm); padding: 1rem 2rem; background: var(--color-accent); color: #fff; font-weight: 700; cursor: pointer; font-size: 1.05rem; transition: background 0.2s; }
.hero-search button:hover { background: var(--color-accent-hover); }
.hero-search__filters { display: flex; gap: 0.5rem; }
.hero-search__field { flex: 1; }
.hero-search__field select { width: 100%; padding: 1rem; border: none; background: transparent; font-size: 1rem; color: var(--color-heading); outline: none; cursor: pointer; }
.hero-search__actions { display: flex; gap: 0.5rem; margin-top: 0.5rem; }
.hero-search__actions input { flex: 1; }

.hero__stats { display: flex; gap: 3rem; margin-top: 3rem; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); }
.hero__stat { font-size: 1rem; color: rgba(255,255,255,0.7); }
.hero__stat strong { display: block; font-size: 1.8rem; color: #fff; font-weight: 800; margin-bottom: 0.2rem; }

/* Hero Panel (Glassmorphism) */
.hero__panel { 
	background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05)); 
	border: 1px solid rgba(255,255,255,0.2); 
	border-radius: var(--radius-lg); 
	padding: 2.5rem; 
	box-shadow: var(--shadow-soft);
	backdrop-filter: blur(18px) saturate(130%);
	-webkit-backdrop-filter: blur(18px) saturate(130%);
}
.hero__panel h2 { color: #fff; font-size: 1.3rem; margin-bottom: 1.5rem; }
.hero__quick-links { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.8rem; }
.hero__quick-links a { display: flex; justify-content: space-between; align-items: center; padding: 1rem 1.2rem; border-radius: var(--radius-sm); background: rgba(255,255,255,0.1); color: #fff; text-decoration: none; font-size: 1rem; font-weight: 600; transition: all 0.2s ease; border: 1px solid transparent; }
.hero__quick-links a:hover { background: rgba(255,255,255,0.15); transform: translateX(-5px); border-color: rgba(255,255,255,0.3); }
.hero__panel-cta { display: inline-block; margin-top: 1.5rem; color: #fff; font-weight: 700; text-decoration: underline; font-size: 1rem; }
.hero__panel-cta:hover { color: var(--color-accent); }

/* Premium Card Utility */
.premium-card {
  position: relative;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}
.premium-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 20% 0%, rgba(82,114,178,0.05), transparent 32%), linear-gradient(135deg, rgba(255,255,255,0.4), transparent 40%);
}
.premium-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
  border-color: rgba(82,114,178,0.28);
}

/* Section Headers */
.section-header { max-width: 800px; margin-bottom: 3rem; }
.section-header--split { display: flex; justify-content: space-between; align-items: flex-end; gap: 2rem; max-width: none; }
.section-header--center { text-align: center; margin-inline: auto; }
.section-header__eyebrow, .hero__eyebrow, .archive-header__eyebrow, .taxonomy-header__eyebrow { display: inline-block; color: var(--color-accent); font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em; font-size: 0.9rem; margin-bottom: 0.8rem; }
.section-header h2 { color: var(--color-heading); line-height: 1.2; margin: 0 0 1rem; font-size: clamp(2rem, 3.5vw, 2.5rem); }

/* Article & Practice Areas Grids */
.article-grid, .practice-areas-grid, .pillars-grid, .clusters-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 2rem; }
.article-grid--three { grid-template-columns: repeat(3, 1fr); }

/* Cards */
.article-card, .practice-area-card, .pillar-card, .cluster-card, .city-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-soft); transition: all 300ms ease; text-decoration: none; display: flex; flex-direction: column; }
.article-card:hover, .practice-area-card:hover, .pillar-card:hover, .cluster-card:hover, .city-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); border-color: var(--color-secondary); }

/* Practice Area Card */
.practice-area-card { padding: 0; }
.practice-area-card__link { display: block; padding: 2rem; height: 100%; text-decoration: none; color: var(--color-text); }
.practice-area-card__icon { display: inline-flex; align-items: center; justify-content: center; width: 3.5rem; height: 3.5rem; border-radius: var(--radius-sm); background: var(--color-bg-alt); color: var(--color-primary); font-weight: 900; margin-bottom: 1.2rem; font-size: 1.5rem; transition: all 300ms ease; }
.practice-area-card:hover .practice-area-card__icon { background: var(--color-accent); color: #fff; }
.practice-area-card__title { color: var(--color-heading); margin: 0 0 0.5rem; font-size: 1.2rem; font-weight: 700; }
.practice-area-card__description { color: var(--color-text); font-size: 0.95rem; margin: 0 0 1.2rem; line-height: 1.6; }
.practice-area-card__count { display: inline-block; color: var(--color-secondary); font-weight: 600; font-size: 0.85rem; padding: 0.2rem 0.6rem; background: var(--color-bg-alt); border-radius: var(--radius-pill); }

/* Article Card */
.article-card__media { position: relative; display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--color-bg-alt); }
.article-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 500ms ease; }
.article-card:hover .article-card__media img { transform: scale(1.05); }
.article-card__placeholder { display: grid; place-items: center; height: 100%; color: var(--color-primary); font-weight: 700; font-size: 1rem; }
.article-card__content { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.article-card__term { display: inline-flex; margin-bottom: 0.8rem; color: var(--color-accent); font-weight: 700; text-decoration: none; font-size: 0.85rem; text-transform: uppercase; }
.article-card__title { font-size: 1.2rem; line-height: 1.4; margin: 0 0 0.8rem; }
.article-card__title a { color: var(--color-heading); text-decoration: none; }
.article-card__title a:hover { color: var(--color-accent); }
.article-card__meta { display: flex; flex-wrap: wrap; gap: 1rem; color: var(--color-text-muted); font-size: 0.85rem; margin-bottom: 1rem; }
.article-card__excerpt { color: var(--color-text); margin: 0 0 1.5rem; font-size: 0.95rem; line-height: 1.6; flex: 1; }
.article-card__read-more { display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 700; text-decoration: none; color: var(--color-primary); font-size: 0.95rem; }
.article-card:hover .article-card__read-more { color: var(--color-accent); }

/* Pillars & Clusters */
.featured-pillars { background: var(--color-bg-alt); }
.pillar-card { padding: 2.5rem; text-align: center; }
.pillar-icon { display: inline-flex; align-items: center; justify-content: center; width: 4rem; height: 4rem; background: var(--color-bg-alt); border-radius: 50%; color: var(--color-primary); margin-bottom: 1.5rem; font-size: 1.8rem; transition: all 300ms ease; }
.pillar-card:hover .pillar-icon { background: var(--color-primary); color: #fff; transform: scale(1.1); }
.pillar-title { font-size: 1.3rem; font-weight: 800; margin: 0 0 0.8rem; }
.pillar-desc { font-size: 0.95rem; color: var(--color-text); margin: 0; line-height: 1.6; }

.cluster-card { padding: 2rem; }
.cluster-title { font-size: 1.4rem; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 0.8rem; }
.cluster-title::before { content: ''; display: block; width: 4px; height: 24px; background: var(--color-accent); border-radius: 4px; }
.cluster-title a { color: var(--color-heading); text-decoration: none; }
.cluster-title a:hover { color: var(--color-accent); }
.cluster-links { list-style: none; padding: 0; margin: 0 0 1.5rem 0; }
.cluster-links li { margin-bottom: 0.8rem; padding-inline-start: 1.2rem; position: relative; }
.cluster-links li::before { content: '→'; position: absolute; inset-inline-start: 0; color: var(--color-accent); }
.cluster-links a { color: var(--color-text); text-decoration: none; font-size: 1rem; transition: color 0.2s; }
.cluster-links a:hover { color: var(--color-accent); text-decoration: underline; }
.cluster-more { font-weight: 700; color: var(--color-primary); text-decoration: none; }
.cluster-more:hover { color: var(--color-accent); }

/* Lawyer Directory & Cards */
.lawyers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 2rem; }
.lawyer-card { padding: 2rem; align-items: center; text-align: center; }
.lawyer-card--promoted { border-width: 2px; border-color: var(--color-primary); position: relative; }
.lawyer-card--promoted::before { content: ''; position: absolute; top: 0; inset-inline-start: 50%; transform: translateX(-50%); width: 40%; height: 4px; background: var(--color-accent); border-radius: 0 0 4px 4px; }
.lawyer-card__badge { position: absolute; top: 1rem; inset-inline-start: 1rem; background: var(--color-accent); color: #fff; font-size: 0.75rem; font-weight: 700; padding: 0.3rem 0.8rem; border-radius: var(--radius-pill); z-index: 2; }
.lawyer-card__link { display: flex; flex-direction: column; align-items: center; text-decoration: none; color: var(--color-text); width: 100%; }
.lawyer-card__avatar { width: 90px; height: 90px; border-radius: 50%; overflow: hidden; margin-bottom: 1.2rem; background: var(--color-bg-alt); box-shadow: var(--shadow-soft); transition: transform 300ms ease; }
.lawyer-card:hover .lawyer-card__avatar { transform: scale(1.05); }
.lawyer-card__photo { width: 100%; height: 100%; object-fit: cover; }
.lawyer-card__name { font-size: 1.2rem; font-weight: 800; color: var(--color-heading); margin: 0 0 0.4rem; }
.lawyer-card__firm { color: var(--color-text-muted); font-size: 0.9rem; margin: 0 0 0.6rem; }
.lawyer-card__areas { color: var(--color-secondary); font-size: 0.85rem; font-weight: 600; margin: 0 0 1rem; }
.lawyer-card__meta { display: flex; gap: 1rem; color: var(--color-text-muted); font-size: 0.85rem; justify-content: center; flex-wrap: wrap; margin-bottom: 1.5rem; }
.lawyer-card__actions { width: 100%; }
.lawyer-card__cta { width: 100%; font-size: 0.95rem; padding: 0.7rem; border-radius: var(--radius-sm); background: var(--color-bg-alt); color: var(--color-primary); font-weight: 700; border: none; transition: all 0.2s; }
.lawyer-card:hover .lawyer-card__cta { background: var(--color-primary); color: #fff; }

.featured-lawyers__coming { background: var(--color-bg-alt); border: 2px dashed var(--color-border); border-radius: var(--radius-md); padding: 3rem 2rem; text-align: center; }
.featured-lawyers__icon { display: inline-flex; align-items: center; justify-content: center; width: 4rem; height: 4rem; background: #fff; border-radius: 50%; color: var(--color-primary); margin: 0 auto 1.2rem; font-size: 2rem; box-shadow: var(--shadow-soft); }
.featured-lawyers__message h3 { color: var(--color-heading); margin: 0 0 0.8rem; font-size: 1.5rem; }
.featured-lawyers__message > p { color: var(--color-text); font-size: 1.05rem; max-width: 600px; margin: 0 auto; line-height: 1.6; }

/* Lawyer CTA Section */
.lawyer-cta { background: var(--color-bg-alt); color: var(--color-heading); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.lawyer-cta__inner { display: grid; gap: 3rem; }
.lawyer-cta__content { text-align: center; max-width: 800px; margin: 0 auto; }
.lawyer-cta__content h2 { color: var(--color-heading); font-size: clamp(1.8rem, 3.5vw, 2.5rem); margin: 0 0 1rem; }
.lawyer-cta__content > p { color: var(--color-text); font-size: 1.1rem; line-height: 1.6; margin: 0; }
.lawyer-cta__features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.lawyer-cta__feature { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 2rem; text-align: center; transition: all 300ms ease; box-shadow: var(--shadow-soft); }
.lawyer-cta__feature:hover { border-color: var(--color-secondary); transform: translateY(-5px); box-shadow: var(--shadow-card); }
.lawyer-cta__icon { font-size: 2.2rem; display: block; margin-bottom: 1.2rem; color: var(--color-accent); }
.lawyer-cta__feature h3 { color: var(--color-heading); margin: 0 0 0.8rem; font-size: 1.2rem; }
.lawyer-cta__feature p { color: var(--color-text); font-size: 0.95rem; margin: 0; line-height: 1.6; }
.lawyer-cta__actions { display: flex; gap: 1.2rem; justify-content: center; margin-top: 2rem; }

/* Ask a Lawyer */
.ask-lawyer { background: var(--color-bg); }
.ask-lawyer__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.ask-lawyer__content h2 { font-size: clamp(1.8rem, 3.5vw, 2.5rem); margin: 0 0 1.2rem; }
.ask-lawyer__content > p { font-size: 1.1rem; color: var(--color-text); line-height: 1.6; margin: 0 0 2rem; }
.ask-lawyer__form { background: var(--color-bg-alt); padding: 2.5rem; border-radius: var(--radius-md); border: 1px solid var(--color-border); }
.ask-lawyer__fields { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin-bottom: 1.2rem; }
.ask-lawyer__field--full { grid-column: 1 / -1; }
.ask-lawyer__field label { display: block; font-weight: 700; margin-bottom: 0.4rem; font-size: 0.9rem; color: var(--color-heading); }
.ask-lawyer__field input, .ask-lawyer__field select, .ask-lawyer__field textarea { width: 100%; padding: 0.8rem 1rem; border: 1px solid var(--color-border); border-radius: var(--radius-sm); font: inherit; font-size: 0.95rem; background: #fff; transition: border-color 0.2s; }
.ask-lawyer__field input:focus, .ask-lawyer__field select:focus, .ask-lawyer__field textarea:focus { outline: none; border-color: var(--color-primary); }
.ask-lawyer__consent { margin-bottom: 1.2rem; font-size: 0.85rem; color: var(--color-text); display: flex; align-items: flex-start; gap: 0.5rem; }
.ask-lawyer__consent input[type="checkbox"] { margin-top: 0.2rem; accent-color: var(--color-primary); }
.ask-lawyer__disclaimer { color: var(--color-text-muted); font-size: 0.8rem; margin-top: 1.2rem; line-height: 1.5; text-align: center; }

/* Trust Section */
.trust-section { background: var(--color-primary); color: #fff; padding-block: clamp(3rem, 6vw, 4rem); }
.trust-section__grid { display: flex; justify-content: center; gap: clamp(2rem, 6vw, 6rem); flex-wrap: wrap; }
.trust-section__stat { text-align: center; }
.trust-section__number { display: block; font-size: clamp(2.5rem, 4vw, 3.5rem); font-weight: 800; color: var(--color-accent); line-height: 1; margin-bottom: 0.4rem; }
.trust-section__label { display: block; color: rgba(255,255,255,0.8); font-size: 1rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }

/* Newsletter */
.newsletter { background: var(--color-bg-alt); text-align: center; padding-block: clamp(3rem, 6vw, 5rem); border-top: 1px solid var(--color-border); }
.newsletter__inner { max-width: 600px; margin-inline: auto; }
.newsletter h2 { color: var(--color-heading); margin: 0 0 1rem; font-size: clamp(1.6rem, 3.5vw, 2.2rem); }
.newsletter__content > p { color: var(--color-text); margin: 0 0 2rem; font-size: 1.05rem; line-height: 1.6; }
.newsletter__form { display: flex; gap: 0.5rem; }
.newsletter__form input { flex: 1; padding: 0.8rem 1.2rem; border: 1px solid var(--color-border); background: #fff; border-radius: var(--radius-sm); font: inherit; font-size: 1rem; }
.newsletter__form input:focus { outline: none; border-color: var(--color-primary); }
.newsletter__disclaimer { color: var(--color-text-muted); font-size: 0.85rem; margin-top: 1rem; }

/* Cities Grid */
.cities-grid__list { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem; }
.city-card { display: flex; justify-content: space-between; align-items: center; padding: 1rem 1.2rem; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-sm); text-decoration: none; color: var(--color-heading); font-weight: 600; font-size: 1rem; transition: all 0.2s; }
.city-card:hover { border-color: var(--color-secondary); box-shadow: var(--shadow-soft); color: var(--color-primary); }
.city-card__arrow { color: var(--color-accent); font-size: 1.2rem; transition: transform 200ms ease; }
.city-card:hover .city-card__arrow { transform: translateX(-4px); }

/* Archives & Taxonomies */
.archive-header, .taxonomy-header, .search-header { background: var(--color-primary); color: #fff; padding-block: clamp(3rem, 6vw, 5rem); text-align: center; }
.archive-header h1, .taxonomy-header h1, .search-header h1 { color: #fff; margin: 0 0 1rem; font-size: clamp(2.2rem, 4vw, 3rem); }
.archive-header p, .taxonomy-header p { color: rgba(255,255,255,0.8); margin: 0 auto; max-width: 600px; font-size: 1.1rem; line-height: 1.6; }
.search-header { position: relative; overflow: hidden; }
.search-header::after { content: ""; position: absolute; inset-inline: 12%; bottom: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.38), transparent); }
.search-header .container { position: relative; z-index: 1; }
.search-header h1 span { color: var(--color-accent); display: inline-block; max-width: 100%; overflow-wrap: anywhere; }
.search-header .legal-search-form { margin-top: 1.5rem; }
.legal-search-form { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 0.7rem; align-items: stretch; max-width: 720px; margin-inline: auto; padding: 0.45rem; background: #fff; border: 1px solid rgba(7, 21, 47, 0.08); border-radius: var(--radius-md); box-shadow: 0 18px 50px rgba(7, 21, 47, 0.14); }
.legal-search-form input[type="search"] { min-width: 0; width: 100%; min-height: 3.3rem; border: 0; background: #f7f8fb; color: var(--color-heading); border-radius: calc(var(--radius-md) - 4px); padding: 0 1rem; font: inherit; font-size: 1rem; }
.legal-search-form input[type="search"]::placeholder { color: var(--color-text-muted); }
.legal-search-form input[type="search"]:focus { outline: 2px solid rgba(178, 58, 72, 0.22); background: #fff; }
.legal-search-form button { min-height: 3.3rem; border: 0; border-radius: calc(var(--radius-md) - 4px); padding: 0 1.35rem; background: var(--color-accent); color: #fff; font: inherit; font-weight: 800; cursor: pointer; white-space: nowrap; transition: background 160ms ease, transform 160ms ease; }
.legal-search-form button:hover, .legal-search-form button:focus-visible { background: var(--color-primary); transform: translateY(-1px); }
.content-none { max-width: 760px; margin: 0 auto; padding: clamp(2rem, 5vw, 3rem); background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-soft); text-align: center; }
.content-none h2 { margin: 0 0 0.8rem; color: var(--color-heading); font-size: clamp(1.5rem, 3vw, 2rem); }
.content-none p { margin: 0 auto 1.6rem; max-width: 560px; color: var(--color-text); line-height: 1.7; }
.error-404 { background: linear-gradient(180deg, #fff, var(--color-bg-alt)); }
.error-404__panel { text-align: center; padding: clamp(2.5rem, 6vw, 4rem) clamp(1.25rem, 4vw, 3rem); background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-soft); }
.error-404__panel h1 { margin: 0 0 0.85rem; color: var(--color-heading); font-size: clamp(2rem, 5vw, 3.2rem); }
.error-404__panel p { margin: 0 auto 1.6rem; max-width: 620px; color: var(--color-text); line-height: 1.8; font-size: 1.05rem; }
.error-404__home { margin-top: 1.4rem; }
.archive-layout { display: grid; grid-template-columns: 260px 1fr; gap: 3rem; margin-top: 3rem; }
.archive-sidebar h2 { font-size: 1.2rem; color: var(--color-heading); margin: 0 0 1.2rem; padding-bottom: 0.6rem; border-bottom: 2px solid var(--color-border); }
.term-list { list-style: none; padding: 0; margin: 0; }
.term-list li { margin-bottom: 0.5rem; }
.term-list a { display: flex; justify-content: space-between; align-items: center; padding: 0.6rem 0; border-bottom: 1px solid var(--color-bg-alt); text-decoration: none; color: var(--color-text); font-size: 0.95rem; transition: all 0.2s; }
.term-list a:hover { color: var(--color-accent); }
.term-list span { color: var(--color-text-muted); font-size: 0.85rem; }

/* Single Article */
.single-article__header { background: var(--color-primary); color: #fff; padding-block: clamp(2.5rem, 5vw, 4rem); text-align: center; }
.single-article__title { color: #fff; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.2; margin: 0 auto 1rem; max-width: 800px; }
.single-article__term { display: inline-block; margin-bottom: 1rem; color: var(--color-accent); font-weight: 700; text-decoration: none; font-size: 0.85rem; text-transform: uppercase; }
.single-article__meta { display: flex; justify-content: center; flex-wrap: wrap; gap: 1rem; color: rgba(255,255,255,0.7); font-size: 0.95rem; }
.single-article__layout { display: grid; grid-template-columns: 1fr 300px; gap: 3rem; padding-block: 3rem; }
.single-article__main { min-width: 0; }
.single-article__sidebar { order: 2; }
.single-article__image { margin: 0 0 2rem; border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-soft); }
.single-article__image img { width: 100%; height: auto; }
.entry-content { font-size: 1.1rem; line-height: 1.8; color: var(--color-text); }
.entry-content h2 { font-size: 1.6rem; color: var(--color-heading); margin: 2.5rem 0 1rem; line-height: 1.3; }
.entry-content h3 { font-size: 1.3rem; color: var(--color-heading); margin: 2rem 0 0.8rem; }
.entry-content p { margin: 0 0 1.5rem; }
.entry-content ul, .entry-content ol { padding-inline-start: 1.5rem; margin: 0 0 1.5rem; }
.entry-content li { margin-bottom: 0.5rem; }
.entry-content blockquote { border-inline-start: 4px solid var(--color-accent); padding: 1.2rem 1.5rem; margin: 2rem 0; background: var(--color-bg-alt); font-style: italic; color: var(--color-dark); font-size: 1.15rem; }
.editorial-note { margin-top: 3rem; padding: 1.5rem; background: var(--color-bg-alt); border-radius: var(--radius-sm); border-inline-start: 4px solid var(--color-primary); }
.editorial-note h2 { margin: 0 0 0.5rem; font-size: 1.1rem; color: var(--color-heading); }
.editorial-note p { margin: 0; color: var(--color-text); font-size: 0.95rem; }

/* Sticky Box */
.sticky-box { position: sticky; top: 6rem; background: var(--color-bg-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 1.5rem; }
.sticky-box h2 { margin: 0 0 0.8rem; font-size: 1.2rem; color: var(--color-heading); }
.sticky-box p { color: var(--color-text); font-size: 0.95rem; margin: 0 0 1.2rem; line-height: 1.5; }

/* Footer */
.site-footer { background: var(--color-dark); color: rgba(255,255,255,0.7); padding-top: clamp(3rem, 6vw, 5rem); }
.site-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; }
.site-footer h2 { color: #fff; font-size: 1.1rem; margin: 0 0 1.2rem; font-weight: 700; }
.site-footer ul, .site-footer .menu { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin-bottom: 0.6rem; }
.site-footer a { color: rgba(255,255,255,0.6); text-decoration: none; font-size: 0.95rem; transition: color 0.2s; }
.site-footer a:hover { color: var(--color-accent); }
.site-footer__about p { font-size: 0.95rem; line-height: 1.7; margin: 0.5rem 0 0; }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,0.1); margin-top: 3rem; padding: 1.5rem 0; }
.site-footer__bottom-inner { display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; flex-wrap: wrap; gap: 1rem; }
.site-footer__disclaimer { color: rgba(255,255,255,0.4); font-size: 0.8rem; max-width: 600px; line-height: 1.5; }

/* Lawyer Profile */
.lawyer-profile__badge { display: inline-block; background: var(--color-accent); color: #fff; font-size: 0.8rem; font-weight: 700; padding: 0.3rem 0.8rem; border-radius: var(--radius-pill); margin-bottom: 1rem; }
.lawyer-profile__grid { display: grid; grid-template-columns: 300px 1fr; gap: 3rem; align-items: start; }
.lawyer-profile__avatar { width: 100%; aspect-ratio: 1; border-radius: var(--radius-md); overflow: hidden; background: var(--color-bg-alt); margin-bottom: 1.5rem; box-shadow: var(--shadow-soft); }
.lawyer-profile__photo { width: 100%; height: 100%; object-fit: cover; }
.lawyer-profile__contact-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 1.5rem; display: flex; flex-direction: column; gap: 0.8rem; box-shadow: var(--shadow-soft); }
.lawyer-profile__contact-card h2 { font-size: 1.1rem; margin: 0 0 0.5rem; color: var(--color-heading); border-bottom: 1px solid var(--color-border); padding-bottom: 0.5rem; }
.button--whatsapp { background: #25d366; color: #fff; text-align: center; border-radius: var(--radius-sm); padding: 0.8rem 1rem; text-decoration: none !important; font-weight: 700; display: block; transition: background 0.2s; }
.button--whatsapp:hover { background: #1da851; color: #fff; }
.lawyer-profile__email, .lawyer-profile__website { display: block; text-align: center; color: var(--color-primary); text-decoration: none; font-size: 0.95rem; padding: 0.5rem; font-weight: 600; }
.lawyer-profile__email:hover, .lawyer-profile__website:hover { color: var(--color-accent); text-decoration: underline; }
.lawyer-profile__stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.5rem; }
.lawyer-profile__stat { text-align: center; background: var(--color-bg-alt); border-radius: var(--radius-sm); padding: 1rem 0.5rem; }
.lawyer-profile__stat strong { display: block; font-size: 1.4rem; color: var(--color-primary); font-weight: 800; }
.lawyer-profile__stat span { font-size: 0.8rem; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.lawyer-profile__header h1 { font-size: clamp(1.8rem, 3.5vw, 2.5rem); margin: 0 0 0.4rem; color: var(--color-heading); }
.lawyer-profile__firm { color: var(--color-text); font-size: 1.1rem; margin: 0 0 1rem; }
.lawyer-profile__tags { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 2rem; }
.lawyer-profile__tag { background: var(--color-bg-alt); color: var(--color-secondary); font-size: 0.85rem; font-weight: 600; padding: 0.3rem 0.8rem; border-radius: var(--radius-pill); text-decoration: none; border: 1px solid var(--color-border); transition: all 0.2s; }
.lawyer-profile__tag:hover { border-color: var(--color-secondary); background: #fff; }
.lawyer-profile__details { margin-top: 2rem; }
.lawyer-profile__details h2 { font-size: 1.3rem; margin: 0 0 1rem; color: var(--color-heading); }
.lawyer-profile__details table { width: 100%; border-collapse: collapse; }
.lawyer-profile__details th, .lawyer-profile__details td { padding: 0.8rem 1rem; border-bottom: 1px solid var(--color-border); text-align: right; }
.lawyer-profile__details th { font-weight: 700; color: var(--color-heading); width: 160px; background: var(--color-bg-alt); }
.lawyer-profile__inquiry { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--color-border); }
.lawyer-profile__inquiry h2 { font-size: 1.3rem; margin: 0 0 1.2rem; color: var(--color-heading); }

/* Directory Filters */
.directory-filters { background: #fff; padding: 1.5rem; border-radius: var(--radius-md); margin-bottom: 2rem; box-shadow: var(--shadow-soft); border: 1px solid var(--color-border); }
.directory-filters__fields { display: flex; gap: 1rem; align-items: flex-end; flex-wrap: wrap; }
.directory-filters__field { flex: 1; min-width: 180px; }
.directory-filters__field label { display: block; font-weight: 700; font-size: 0.9rem; margin-bottom: 0.4rem; color: var(--color-heading); }
.directory-filters__field select, .directory-filters__field input[type="text"] { width: 100%; padding: 0.8rem 1rem; border: 1px solid var(--color-border); border-radius: var(--radius-sm); font: inherit; background: #fff; }
.directory-empty { text-align: center; padding: 4rem 2rem; background: var(--color-bg-alt); border: 2px dashed var(--color-border); border-radius: var(--radius-md); }

/* Pagination */
.pagination, .directory-pagination { display: flex; justify-content: center; gap: 0.5rem; margin-top: 3rem; flex-wrap: wrap; }
.pagination .page-numbers, .directory-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 2.8rem; height: 2.8rem; padding: 0 0.8rem; border: 1px solid var(--color-border); border-radius: var(--radius-sm); font-weight: 600; text-decoration: none; color: var(--color-text); transition: all 0.2s ease; background: #fff; }
.pagination .page-numbers:hover, .directory-pagination .page-numbers:hover { border-color: var(--color-primary); color: var(--color-primary); }
.pagination .page-numbers.current, .directory-pagination .page-numbers.current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* Animations */
@keyframes fadeIn { from { opacity: 0; transform: translateY(15px); } to { opacity: 1; transform: translateY(0); } }
.section { animation: fadeIn 0.6s ease-out both; }

/* Mobile */
@media (max-width: 1024px) {
  .hero__grid, .archive-layout, .ask-lawyer__inner, .lawyer-cta__inner { grid-template-columns: 1fr; gap: 2rem; }
  .archive-sidebar { order: -1; }
  .site-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .single-article__layout { grid-template-columns: 1fr; }
  .single-article__sidebar { order: 0; }
  .lawyer-profile__grid { grid-template-columns: 1fr; }
  .lawyer-profile__avatar { max-width: 250px; margin-inline: auto; }
}
@media (max-width: 768px) {
  .article-grid, .practice-areas-grid, .pillars-grid, .clusters-grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
  .legal-search-form { grid-template-columns: 1fr; padding: 0.55rem; }
  .legal-search-form button { width: 100%; }
  .lawyer-cta__features { grid-template-columns: 1fr; }
  .ask-lawyer__fields { grid-template-columns: 1fr; }
  .newsletter__form { flex-direction: column; }
  .site-header__top { display: none; }
  .primary-navigation { display: none; position: absolute; top: 100%; inset-inline: 0; background: #fff; padding: 1.5rem; border-top: 1px solid var(--color-border); box-shadow: 0 10px 30px rgba(0,0,0,0.1); z-index: 99; }
  .primary-navigation .menu { flex-direction: column; gap: 1rem; }
  .menu-toggle { display: block; }
  body.nav-is-open .primary-navigation { display: block; }
}

/* Lawyer Card (Premium Bento) */
.lawyer-card {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 20px;
  padding: 20px;
  min-height: 190px;
  text-align: right;
}
.lawyer-card__media {
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(16,38,74,0.12), rgba(95,126,168,0.18));
}
.lawyer-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lawyer-card__placeholder {
  display: grid;
  place-items: center;
  height: 100%;
  min-height: 150px;
  color: var(--color-primary);
  font-size: 3rem;
  font-weight: 900;
  background: radial-gradient(circle at 20% 15%, rgba(255,255,255,.9), transparent 38%), linear-gradient(135deg, rgba(16,38,74,.08), rgba(95,126,168,.22));
}
.lawyer-card__name {
  margin: 0;
  font-size: 1.25rem;
  line-height: 1.25;
}
.lawyer-card__name a {
  color: var(--color-primary-deep);
  text-decoration: none;
}
.lawyer-card__firm,
.lawyer-card__areas {
  margin: 8px 0;
  color: var(--color-muted);
}
.lawyer-card__top { display: flex; justify-content: space-between; align-items: flex-start; }
.lawyer-card__city { font-size: 0.9rem; color: var(--color-muted); font-weight: 600; }
.lawyer-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
