/* ==========================================================================
   광주/전남 병의원 전문 한동노무법인 — v2 Editorial Design System
   ==========================================================================

   철학
   • 법무·컨설팅 프리미엄 톤 — 카드 남용 대신 에디토리얼 여백
   • 타이포그래피 중심 — 큰 헤드라인, 명료한 위계
   • 색 사용 최소화 — 단일 액센트, 무채색 기반
   • 박실로 센터장 개인 홈페이지(silronomu.com / blog.silronomu.com) 톤과 일관
   ========================================================================== */

:root {
  /* Palette — warm editorial */
  --bg:        #fafaf7;
  --bg-soft:   #f3efe6;
  --bg-dark:   #0b1628;
  --ink:       #0b1628;
  --ink-2:     #3b4963;
  --mute:      #7e8a9c;
  --rule:      #e7e1d4;
  --rule-2:    #d6cdb7;
  --brand:     #0e2a4a;
  --brand-2:   #1c477d;
  --accent:    #8a6e3f;
  --accent-2:  #6a5329;
  --white:     #ffffff;
  --danger:    #8b2b24;

  /* Typography */
  --serif: 'Noto Serif KR','Nanum Myeongjo',ui-serif,Georgia,'Times New Roman',serif;
  --sans:  'Pretendard','Apple SD Gothic Neo','Noto Sans KR',system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;

  /* Layout */
  --maxw: 1200px;
  --pad-x: 32px;
  --section-y: clamp(72px, 10vw, 128px);
  --radius: 2px;
  --radius-lg: 6px;

  /* Shadow (minimal) */
  --shadow-sm: 0 1px 2px rgba(11,22,40,.04), 0 2px 8px rgba(11,22,40,.04);
  --shadow-md: 0 2px 4px rgba(11,22,40,.06), 0 8px 24px rgba(11,22,40,.06);
}

/* ── Reset ─────────────────────────────────────────────────────── */

*,*::before,*::after{box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:88px;
}
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.72;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  word-break:keep-all;
  overflow-wrap:break-word;
}
img,svg{max-width:100%;display:block}

/* ── Typography ────────────────────────────────────────────────── */

h1,h2,h3,h4{
  font-family:var(--serif);
  color:var(--ink);
  font-weight:700;
  letter-spacing:-.015em;
  margin:0 0 .5em;
  line-height:1.22;
}
h1{font-size:clamp(34px,5.5vw,68px);font-weight:800;line-height:1.14}
h2{font-size:clamp(26px,3.4vw,42px)}
h3{font-size:clamp(19px,1.8vw,23px);font-weight:700}
h4{font-size:17px;font-weight:700}
p{margin:0 0 1em;color:var(--ink-2)}
a{color:var(--brand);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent)}
strong{font-weight:700;color:var(--ink)}
em{font-style:normal}
ul,ol{padding-left:1.25em;margin:0 0 1em;color:var(--ink-2)}
li{margin-bottom:.25em}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip{position:absolute;left:-9999px;top:8px;background:var(--ink);color:#fff;padding:10px 16px;border-radius:var(--radius);z-index:1000;font-weight:600}
.skip:focus{left:16px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.wrap--narrow{max-width:820px}
.section{padding:var(--section-y) 0}
.section--soft{background:var(--bg-soft)}
.section--dark{background:var(--bg-dark);color:#fff}
.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}
.section--dark p{color:rgba(255,255,255,.78)}

.section__head{margin-bottom:56px;max-width:720px}
.section__head--center{text-align:center;margin-left:auto;margin-right:auto}

.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:12px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 18px;
  padding-bottom:12px;
  border-bottom:1px solid var(--rule-2);
}
.lede{
  font-size:clamp(17px,1.7vw,21px);
  line-height:1.75;
  color:var(--ink-2);
  max-width:720px;
}
.muted{color:var(--mute)}
.center{text-align:center}
.divider{border:0;border-top:1px solid var(--rule);margin:0}

/* ── Header ────────────────────────────────────────────────────── */

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,250,247,.92);
  backdrop-filter:saturate(1.4) blur(12px);
  -webkit-backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid var(--rule);
}
.nav{
  display:flex;align-items:center;gap:32px;
  height:84px;
}
.brand{
  display:flex;align-items:center;gap:14px;
  color:var(--ink);text-decoration:none;
  min-width:0;
}
.brand:hover{color:var(--ink)}
.brand__mark{
  display:block;
  width:52px;height:auto;
  flex:none;
}
.brand__text{display:flex;flex-direction:column;line-height:1.15}
.brand__text strong{
  font-family:var(--serif);
  font-weight:800;
  font-size:18px;
  color:var(--ink);
}
.brand__text em{
  font-size:11px;
  color:var(--mute);
  letter-spacing:.02em;
  font-weight:500;
}

.menu{display:flex;gap:36px;margin-left:auto}
.menu a{
  color:var(--ink);
  font-weight:500;
  font-size:14.5px;
  position:relative;
  padding:4px 0;
}
.menu a[aria-current="page"]{color:var(--brand);font-weight:700}
.menu a[aria-current="page"]::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-4px;
  height:2px;background:var(--accent);
}
.menu a:hover{color:var(--brand)}
.menu a.external::after{content:" ↗";color:var(--mute);font-size:12px}

.nav__cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 20px;
  background:var(--brand);color:#fff;
  font-size:14px;font-weight:600;
  border-radius:var(--radius);
  white-space:nowrap;
  transition:background .15s;
}
.nav__cta:hover{background:var(--accent);color:#fff}

.hamburger{
  display:none;background:none;border:0;
  width:44px;height:44px;padding:10px;
  margin-left:auto;cursor:pointer;
}
.hamburger span{
  display:block;height:2px;background:var(--ink);
  margin:5px 0;border-radius:1px;transition:.2s;
}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile{
  display:flex;flex-direction:column;
  background:var(--bg);
  border-bottom:1px solid var(--rule);
  padding:16px var(--pad-x) 20px;
}
.mobile[hidden]{display:none}
.mobile a{
  padding:16px 0;
  border-bottom:1px solid var(--rule);
  font-size:16px;font-weight:500;color:var(--ink);
}
.mobile a:last-child{border-bottom:0}

/* 데스크톱에서는 모바일 드로어를 항상 숨김 — hidden 속성과 무관 */
@media (min-width:781px){
  .mobile{display:none !important}
}

/* ── CTA Buttons ───────────────────────────────────────────────── */

.cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 28px;
  font-family:var(--sans);
  font-size:15px;font-weight:600;
  letter-spacing:-.01em;
  border:1px solid transparent;
  border-radius:var(--radius);
  text-decoration:none;
  white-space:nowrap;
  transition:all .15s;
  cursor:pointer;
}
.cta--sm{padding:10px 18px;font-size:13.5px}
.cta--lg{padding:20px 36px;font-size:16.5px}
.cta--primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.cta--primary:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.cta--accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.cta--accent:hover{background:var(--accent-2);border-color:var(--accent-2);color:#fff}
.cta--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.cta--ghost:hover{background:var(--ink);color:#fff}
.cta--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta--ghost-light:hover{background:#fff;color:var(--brand)}
.cta--text{padding:8px 0;border-bottom:1px solid currentColor;border-radius:0}

.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ── Hero ──────────────────────────────────────────────────────── */

.hero{
  padding:clamp(100px,14vw,180px) 0 clamp(80px,10vw,140px);
  background:var(--bg);
  border-bottom:1px solid var(--rule);
  position:relative;
}
.hero__eyebrow{
  font-family:var(--sans);
  font-size:12px;font-weight:700;
  color:var(--accent);
  letter-spacing:.2em;
  text-transform:uppercase;
  margin:0 0 28px;
}
.hero__title{
  font-family:var(--serif);
  font-size:clamp(38px,6vw,76px);
  line-height:1.08;
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--ink);
  margin:0 0 32px;
  max-width:16ch;
}
.hero__title span{color:var(--brand)}
.hero__title em{font-style:normal;color:var(--accent)}
.hero__lead{
  font-size:clamp(17px,1.6vw,20px);
  line-height:1.75;
  color:var(--ink-2);
  max-width:640px;
  margin:0 0 44px;
}
.hero__lead strong{color:var(--ink);font-weight:700}
.hero__cta{margin-bottom:64px}

.hero__meta{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--rule);
  padding-top:36px;
  max-width:980px;
}
.hero__meta > li{
  list-style:none;
  padding:0 28px 0 0;
  border-right:1px solid var(--rule);
}
.hero__meta > li:last-child{border-right:0;padding-right:0}
.hero__meta strong{
  display:block;
  font-family:var(--serif);
  font-size:clamp(22px,2.6vw,32px);
  font-weight:700;
  color:var(--ink);
  margin-bottom:4px;
  letter-spacing:-.01em;
}
.hero__meta span{
  display:block;
  font-size:12.5px;
  color:var(--mute);
  line-height:1.45;
}

/* ── Page sub-hero ─────────────────────────────────────────────── */

.page-hero{
  padding:clamp(120px,14vw,180px) 0 clamp(56px,8vw,96px);
  background:var(--bg);
  border-bottom:1px solid var(--rule);
}
.page-hero h1{max-width:20ch}
.page-hero p{max-width:680px}
.crumb{
  font-size:12px;
  color:var(--mute);
  letter-spacing:.04em;
  margin:0 0 24px;
  text-transform:uppercase;
}
.crumb a{color:var(--mute)}
.crumb a:hover{color:var(--brand)}

/* ── Editorial sections (replaces card grids) ─────────────────── */

.edit-list{
  list-style:none;
  padding:0;margin:0;
  border-top:1px solid var(--rule);
}
.edit-list > li,
.edit-list > article{
  display:grid;
  grid-template-columns:80px 1fr auto;
  gap:40px;
  padding:36px 0;
  border-bottom:1px solid var(--rule);
  align-items:baseline;
}
.edit-list__num{
  font-family:var(--serif);
  font-size:24px;
  font-weight:600;
  color:var(--accent);
  letter-spacing:.02em;
}
.edit-list h3{
  margin:0 0 10px;
  font-size:clamp(22px,2.4vw,28px);
}
.edit-list p{margin:0;color:var(--ink-2);max-width:62ch}
.edit-list__aside{
  color:var(--mute);
  font-size:13px;
  text-align:right;
  white-space:nowrap;
}

/* ── Feature grid (used sparingly) ────────────────────────────── */

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

.feat{
  padding:36px 0;
  border-top:1px solid var(--rule);
}
.feat h3{
  font-size:20px;
  margin:0 0 12px;
  color:var(--ink);
}
.feat p{margin:0;color:var(--ink-2);font-size:15px;line-height:1.7}
.feat__num{
  display:block;
  font-family:var(--sans);
  font-size:12px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.15em;
  margin-bottom:14px;
}

/* ── Bullet list (body content) ───────────────────────────────── */

.bullet{list-style:none;padding:0;margin:0 0 1.2em}
.bullet li{
  position:relative;
  padding:6px 0 6px 22px;
  color:var(--ink-2);
  line-height:1.7;
}
.bullet li::before{
  content:"";
  position:absolute;
  left:0;top:17px;
  width:6px;height:1px;
  background:var(--accent);
}
.bullet li strong{color:var(--ink)}

/* ── Profile / Lawyers (editorial list) ───────────────────────── */

.profile-lead{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:48px;
  padding:48px 0;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--rule);
  align-items:start;
}
.profile-lead__mark{
  font-family:var(--serif);
  font-size:96px;
  font-weight:800;
  line-height:1;
  color:var(--brand);
  letter-spacing:-.02em;
}
.profile-lead h3{
  font-size:clamp(26px,3vw,36px);
  margin:0 0 6px;
}
.profile-lead h3 span{
  display:block;
  font-family:var(--sans);
  font-size:13px;
  font-weight:600;
  color:var(--accent);
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.profile-lead h4{
  font-family:var(--sans);
  font-size:12px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.15em;
  text-transform:uppercase;
  margin:24px 0 8px;
}
.profile-lead ul{
  list-style:none;
  padding:0;margin:0 0 16px;
}
.profile-lead ul li{
  padding:4px 0;
  color:var(--ink-2);
  font-size:15px;
}
.profile-lead ul li strong{color:var(--ink)}

.profile-row{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:40px;
  padding:36px 0;
  border-top:1px solid var(--rule);
  align-items:start;
}
.profile-row:last-child{border-bottom:1px solid var(--rule)}
.profile-row__name{
  font-family:var(--serif);
  font-size:22px;
  font-weight:700;
  color:var(--ink);
  margin:0 0 4px;
}
.profile-row__role{
  font-size:12px;
  color:var(--accent);
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
}
.profile-row__body{color:var(--ink-2);font-size:15px;line-height:1.7}
.profile-row__body ul{list-style:none;padding:0;margin:0 0 8px}
.profile-row__body ul li{padding:3px 0}
.profile-row__body p{margin:6px 0 0;color:var(--mute);font-size:13.5px}

/* ── FAQ ───────────────────────────────────────────────────────── */

.faq-list{max-width:860px;margin:0 auto}
.faq-list details{
  padding:28px 0;
  border-bottom:1px solid var(--rule);
}
.faq-list details:first-of-type{border-top:1px solid var(--rule)}
.faq-list summary{
  font-family:var(--serif);
  font-size:clamp(17px,1.6vw,21px);
  font-weight:700;
  color:var(--ink);
  cursor:pointer;
  outline:none;
  list-style:none;
  padding-right:40px;
  position:relative;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{
  content:"+";
  position:absolute;
  right:0;top:-2px;
  font-family:var(--sans);
  font-size:26px;
  color:var(--accent);
  font-weight:300;
  line-height:1;
}
.faq-list details[open] summary::after{content:"−"}
.faq-list details p{
  margin:18px 0 0;
  color:var(--ink-2);
  line-height:1.75;
  max-width:72ch;
}

/* ── Contact info block ────────────────────────────────────────── */

.offices{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--rule);
  margin-top:48px;
}
.office{
  padding:36px 40px 36px 0;
  border-bottom:1px solid var(--rule);
}
.office:nth-child(odd){padding-right:40px;border-right:1px solid var(--rule)}
.office:nth-child(even){padding-left:40px}
.office__label{
  font-size:12px;font-weight:700;
  color:var(--accent);
  letter-spacing:.15em;
  text-transform:uppercase;
  margin:0 0 10px;
}
.office__name{
  font-family:var(--serif);
  font-size:22px;font-weight:700;
  color:var(--ink);
  margin:0 0 12px;
}
.office address{
  font-style:normal;
  color:var(--ink-2);
  line-height:1.7;
  font-size:15px;
  margin:0 0 10px;
}
.office__phone{
  display:inline-block;
  font-size:16px;font-weight:600;
  color:var(--brand);
}

/* ── Consult CTA card (replaces form) ─────────────────────────── */

.consult-card{
  background:var(--bg-dark);
  color:#fff;
  padding:clamp(48px,6vw,80px);
  border-radius:var(--radius-lg);
  position:relative;
  overflow:hidden;
}
.consult-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 85% 15%, rgba(138,110,63,.18), transparent 40%),
    radial-gradient(circle at 15% 95%, rgba(28,71,125,.2), transparent 50%);
  pointer-events:none;
}
.consult-card > *{position:relative;z-index:1}
.consult-card .eyebrow{color:var(--accent);border-color:rgba(255,255,255,.2)}
.consult-card h2{color:#fff;max-width:18ch;margin-bottom:20px}
.consult-card p{color:rgba(255,255,255,.78);max-width:560px;margin-bottom:36px;font-size:17px}
.consult-card p strong{color:#fff}

/* ── Insights / Post cards (minimal) ──────────────────────────── */

.post-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--rule);
}
.post{
  padding:36px 28px 36px 0;
  border-bottom:1px solid var(--rule);
  border-right:1px solid var(--rule);
}
.post:nth-child(3n){border-right:0;padding-right:0}
.post:nth-child(3n-1),
.post:nth-child(3n-2){padding-right:32px;padding-left:32px}
.post:nth-child(3n-2){padding-left:0}
.post__tag{
  display:inline-block;
  font-size:11px;font-weight:700;
  color:var(--accent);
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:12px;
}
.post h3{
  font-size:19px;
  line-height:1.4;
  margin:0 0 12px;
}
.post h3 a{color:var(--ink)}
.post h3 a:hover{color:var(--brand)}
.post p{
  margin:0 0 16px;
  color:var(--ink-2);
  font-size:14px;
  line-height:1.65;
}
.post time{
  font-size:12px;
  color:var(--mute);
  letter-spacing:.04em;
}

/* ── Channels (insights page) ─────────────────────────────────── */

.channels{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  margin-bottom:80px;
}
.chan{
  display:block;
  padding:32px 24px;
  color:var(--ink);
  text-decoration:none;
  border-right:1px solid var(--rule);
  transition:background .2s;
}
.chan:last-child{border-right:0}
.chan:hover{background:var(--bg-soft);color:var(--ink)}
.chan__label{
  display:block;
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:8px;
}
.chan h3{
  font-size:18px;
  margin:0 0 4px;
}
.chan p{
  margin:0;
  color:var(--mute);
  font-size:13px;
}

/* ── Cases (editorial) ─────────────────────────────────────────── */

.case-list{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  border-top:1px solid var(--ink);
}
.case{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:48px;
  padding:48px 0;
  border-bottom:1px solid var(--rule);
}
.case__tag{
  font-size:12px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.14em;
  text-transform:uppercase;
  align-self:start;
}
.case h3{
  font-family:var(--serif);
  font-size:clamp(22px,2.4vw,28px);
  margin:0 0 8px;
}
.case__meta{
  font-size:13px;
  color:var(--mute);
  margin:0 0 16px;
}
.case p{
  margin:0;
  color:var(--ink-2);
  max-width:64ch;
  line-height:1.75;
}

/* ── Prose (privacy etc) ──────────────────────────────────────── */

.prose{max-width:760px;margin:0 auto}
.prose h2{
  font-size:24px;
  margin-top:48px;
  margin-bottom:12px;
  padding-top:24px;
  border-top:1px solid var(--rule);
}
.prose h2:first-child{margin-top:0;border-top:0;padding-top:0}
.prose p,.prose ul{color:var(--ink-2)}
.prose ul{padding-left:1.2em}

/* ── Footer ────────────────────────────────────────────────────── */

.site-footer{
  background:var(--bg-dark);
  color:rgba(255,255,255,.72);
  padding:72px 0 32px;
  margin-top:0;
  font-size:14px;
}
.site-footer a{color:rgba(255,255,255,.78)}
.site-footer a:hover{color:#fff}
.foot{
  display:grid;
  grid-template-columns:2.4fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:52px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.foot__brand{
  font-family:var(--serif);
  font-size:22px;
  font-weight:800;
  color:#fff;
  margin:0 0 6px;
  letter-spacing:-.01em;
}
.foot__brand em{
  display:block;
  font-family:var(--sans);
  font-size:11px;
  font-weight:500;
  color:var(--accent);
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-top:4px;
}
.foot__col p{margin:0 0 6px;color:rgba(255,255,255,.62);font-size:13px;line-height:1.65}
.foot__col p strong{color:#fff;font-weight:600}
.foot__col h3{
  font-family:var(--sans);
  font-size:11px;
  font-weight:700;
  color:#fff;
  letter-spacing:.15em;
  text-transform:uppercase;
  margin:0 0 16px;
}
.foot__col a{
  display:block;
  padding:5px 0;
  font-size:13.5px;
  color:rgba(255,255,255,.72);
}
.foot__col a.external::after{content:" ↗";color:rgba(255,255,255,.4);font-size:11px}

.foot__bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding-top:24px;
  font-size:12px;
  color:rgba(255,255,255,.4);
}

/* ── Responsive ────────────────────────────────────────────────── */

@media (max-width:1040px){
  .hero__meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px 0}
  .hero__meta > li{padding:0 24px;border-right:1px solid var(--rule)}
  .hero__meta > li:nth-child(2){border-right:0}
  .foot{grid-template-columns:1.4fr 1fr 1fr}
  .foot__col:last-child{grid-column:1/-1}
  .post-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .post:nth-child(3n){border-right:1px solid var(--rule)}
  .post:nth-child(2n){border-right:0;padding-right:0}
  .post:nth-child(2n-1){padding-right:32px;padding-left:0}
  .post:nth-child(2n){padding-left:32px}
  .channels{grid-template-columns:repeat(2,minmax(0,1fr))}
  .chan:nth-child(2n){border-right:0}
  .chan:nth-child(-n+2){border-bottom:1px solid var(--rule)}
}

@media (max-width:780px){
  :root{--pad-x:22px;--section-y:64px}
  .menu{display:none}
  .nav__cta{display:none}
  .hamburger{display:block;margin-left:auto}
  .nav{height:72px;gap:16px}

  h1{font-size:38px}
  .hero__title{font-size:42px;max-width:unset}
  .hero{padding:72px 0 56px}
  .hero__meta{
    grid-template-columns:1fr 1fr;
    gap:24px 0;
    padding-top:28px;
  }
  .hero__meta > li{padding:0 20px 16px 0;border-right:0;border-bottom:1px solid var(--rule)}
  .hero__meta > li:nth-last-child(-n+2){border-bottom:0;padding-bottom:0}

  .page-hero{padding:72px 0 40px}

  .grid--2,.grid--3,.post-list,.channels,.offices{grid-template-columns:1fr}

  .profile-lead{grid-template-columns:1fr;gap:24px;padding:36px 0}
  .profile-lead__mark{font-size:64px}

  .profile-row{grid-template-columns:1fr;gap:12px;padding:28px 0}
  .profile-row__name{font-size:19px}

  .edit-list > li,.edit-list > article{
    grid-template-columns:1fr;
    gap:12px;
    padding:28px 0;
  }
  .edit-list__aside{text-align:left}

  .case{grid-template-columns:1fr;gap:14px;padding:32px 0}

  .offices .office{
    padding:28px 0;
    border-right:0;
  }
  .offices .office:nth-child(odd){border-right:0;padding-right:0}
  .offices .office:nth-child(even){padding-left:0}

  .post{
    padding:32px 0 !important;
    border-right:0;
  }
  .chan{border-right:0;border-bottom:1px solid var(--rule)}
  .chan:last-child{border-bottom:0}

  .foot{grid-template-columns:1fr;gap:36px;padding-bottom:36px}
  .foot__bottom{flex-direction:column;align-items:flex-start;gap:8px;text-align:left}
}

/* ── Accessibility / Motion ────────────────────────────────────── */

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ── Print ─────────────────────────────────────────────────────── */

@media print{
  .site-header,.site-footer,.hamburger,.mobile,.nav__cta,.consult-card{display:none}
  body{color:#000;background:#fff}
  a{color:#000;text-decoration:underline}
}
