/* ============================================================   
   jpchacha.com | Add-on CSS for Legal Page
============================================================ */

/* ------------------------------------------------------------
Layout
------------------------------------------------------------ */

.layout {
	display: grid;
	grid-template-columns: var(--sidebar-w) 1fr;
	align-items: start;
	max-width: 1000px;
}

/* ------------------------------------------------------------
Sidebar
------------------------------------------------------------ */

.sidebar {
	position: sticky;
	top: 56px;
	padding: 28px 0 28px 40px;
	border-right: 0.5px solid var(--navy-mid);
}

.sidebar-nav { 
	display: flex; 
	flex-direction: column; 
}

.sidebar-label {
	font-size: 10px;
	font-weight: 500;
	color: var(--text-faint);
	letter-spacing: 0.09em;
	text-transform: uppercase;
	margin-bottom: 10px;
}

.sidebar-link {
	display: block;
	font-size: 12px;
	color: var(--text-muted);
	padding: 5px 0 5px 10px;
	border-left: 1.5px solid transparent;
	transition: color 0.15s, border-color 0.15s;
	line-height: 1.4;
}

.sidebar-link:hover { 
	color: var(--text-secondary); 
}

.sidebar-link.active {
	color: var(--blue-pale);
	border-left-color: var(--blue);
}

.sidebar-link--section {
	margin-top: 16px;
	font-weight: 500;
	color: var(--text-secondary);
}

.sidebar-divider {
	height: 0.5px;
	background: var(--navy-mid);
	margin: 14px 0;
}

/* ------------------------------------------------------------
Main Content
------------------------------------------------------------ */

.main { 
	padding: 0 40px 60px 40px; 
}

.main a, .main * a { 
	text-decoration: none;
}

/* ------------------------------------------------------------
Document Sections
------------------------------------------------------------ */

.doc-section {
	padding: 32px 0;
	border-bottom: 0.5px solid var(--navy-mid);
	max-width: 800px;
}

.doc-section:last-child { 
	border-bottom: none; 
}

.doc-section h2 {
	font-size: 20px;
	font-weight: 500;
	color: var(--text-primary);
	letter-spacing: -0.015em;
	margin-bottom: 14px;
	scroll-margin-top: 80px;
}

.doc-section h3 {
	font-size: 14px;
	font-weight: 500;
	color: var(--text-primary);
	margin-bottom: 12px;
	scroll-margin-top: 80px;
}

.doc-section p {
	font-size: 14px;
	color: var(--text-secondary);
	line-height: 1.8;
	margin-bottom: 14px;
}

.doc-section p:last-child { 
	margin-bottom: 0; 
}

.doc-section p strong {
	color: var(--text-primary);
	font-weight: 500;
}

.doc-section ul {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin: 12px 0 16px;
	padding: 0;
}

.doc-section ul li {
	font-size: 14px;
	color: var(--text-secondary);
	padding-left: 18px;
	position: relative;
	line-height: 1.7;
}

.doc-section ul li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 9px;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--navy-light);
}

/* ------------------------------------------------------------
Divider Between Docs
------------------------------------------------------------ */

.doc-divider {
	height: 1px;
	background: var(--navy-light);
	margin: 8px 0 0;
	max-width: 660px;
	scroll-margin-top: 80px;
}

/* ------------------------------------------------------------
Callout
------------------------------------------------------------ */

.callout {
	background: var(--navy-mid);
	border: 0.5px solid var(--blue-dim);
	border-left: 2px solid var(--blue);
	border-radius: 0 8px 8px 0;
	padding: 14px 16px;
	font-size: 13px;
	color: var(--text-secondary);
	line-height: 1.7;
}

.callout strong { 
	color: var(--text-primary); 
	font-weight: 500; 
}

.callout a { 
	color: var(--blue-pale); 
	transition: opacity 0.15s; 
}

.callout a:hover { 
	opacity: 0.8; 
}

/* ------------------------------------------------------------
Responsive
------------------------------------------------------------ */

@media (max-width: 700px) {
  .nav { padding: 0 16px; gap: 16px; }
  .nav-link { display: none; }
  .breadcrumb { padding: 12px 16px; }

  .layout { grid-template-columns: 1fr; }

  .sidebar {
    position: static;
    padding: 16px 16px 0;
    border-right: none;
    border-bottom: 0.5px solid var(--navy-mid);
  }

  .sidebar-nav {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px;
  }

  .sidebar-label { display: none; }

  .sidebar-link {
    border-left: none;
    border-bottom: 1.5px solid transparent;
    padding: 4px 8px;
    font-size: 11px;
    background: var(--navy-mid);
    border-radius: 4px;
  }

  .sidebar-link.active { border-bottom-color: var(--blue); }
  .sidebar-link--section { margin-top: 0; }
  .sidebar-divider { display: none; }

  .main { padding: 0 16px 48px; }
  .page-header { padding: 28px 0 24px; }
  .page-header h1 { font-size: 22px; }

  .footer { padding: 16px; flex-direction: column; align-items: flex-start; }
}
