/* Detail page template — shared CSS across service / solution / industry detail pages */
.dp-hero { padding: 160px 0 80px; background: var(--paper); border-bottom: 1px solid var(--line); }
.dp-hero.dark { background: var(--ink); color: var(--invert); border-bottom-color: var(--line-dark); }
.dp-breadcrumb { display: flex; gap: 10px; align-items: center; font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-mute); margin-bottom: 32px; }
.dp-hero.dark .dp-breadcrumb { color: var(--invert-mute); }
.dp-breadcrumb a { color: inherit; }
.dp-breadcrumb a:hover { color: var(--text); }
.dp-hero.dark .dp-breadcrumb a:hover { color: var(--invert); }
.dp-breadcrumb .sep { opacity: 0.4; }
.dp-hero h1 { font-size: clamp(44px, 7vw, 104px); line-height: 0.94; letter-spacing: -0.035em; font-weight: 500; max-width: 16ch; }
.dp-hero h1 em { font-style: italic; font-weight: 400; background: linear-gradient(96deg, var(--brand-1), var(--brand-2), var(--brand-3)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.dp-hero .lede { margin-top: 28px; max-width: 56ch; font-size: 18px; line-height: 1.5; color: var(--text-mute); }
.dp-hero.dark .lede { color: var(--invert-mute); }
.dp-hero .chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 32px; }
.dp-hero .chips span { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; padding: 6px 12px; border-radius: 999px; border: 1px solid var(--line); color: var(--text-mute); }
.dp-hero.dark .chips span { border-color: var(--line-dark); color: var(--invert-mute); }

.dp-section { padding: 96px 0; border-top: 1px solid var(--line); }
.dp-section.alt { background: var(--paper-2); }
.dp-section.dark { background: var(--ink); color: var(--invert); border-top-color: var(--line-dark); }
.dp-head { display: grid; grid-template-columns: 80px 1fr; gap: 40px; margin-bottom: 48px; align-items: start; }
.dp-head .big { font-family: var(--display); font-size: clamp(28px, 2.8vw, 38px); font-weight: 500; letter-spacing: -0.02em; color: var(--text-faint); line-height: 1; }
.dp-section.dark .dp-head .big { color: var(--invert-faint); }
.dp-head h2 { font-size: clamp(30px, 4vw, 52px); letter-spacing: -0.025em; line-height: 1; font-weight: 500; max-width: 18ch; }
.dp-head h2 em { font-style: italic; font-weight: 400; background: linear-gradient(96deg, var(--brand-1), var(--brand-2), var(--brand-3)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.dp-head p.sub { color: var(--text-mute); max-width: 64ch; margin-top: 16px; font-size: 16px; line-height: 1.55; }
.dp-section.dark .dp-head p.sub { color: var(--invert-mute); }
@media (max-width: 800px){ .dp-head { grid-template-columns: 1fr; gap: 12px; } }

/* Capability grid — 3-up */
.dp-cap { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
.dp-section.dark .dp-cap { background: var(--line-dark); border-color: var(--line-dark); }
.dp-c { background: var(--paper); padding: 26px; display: flex; flex-direction: column; gap: 10px; min-height: 220px; }
.dp-section.alt .dp-c { background: var(--paper-2); }
.dp-section.dark .dp-c { background: var(--ink); }
.dp-c .n { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; color: var(--text-faint); }
.dp-section.dark .dp-c .n { color: var(--invert-faint); }
.dp-c h4 { font-size: 19px; font-weight: 500; letter-spacing: -0.015em; margin-top: 2px; }
.dp-c p { color: var(--text-mute); font-size: 14px; line-height: 1.55; }
.dp-section.dark .dp-c p { color: var(--invert-mute); }
@media (max-width: 900px){ .dp-cap { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px){ .dp-cap { grid-template-columns: 1fr; } }

/* Two-column body */
.dp-two { display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px; }
@media (max-width: 900px){ .dp-two { grid-template-columns: 1fr; gap: 28px; } }
.dp-two .colA p { color: var(--text-mute); font-size: 15px; line-height: 1.6; }
.dp-section.dark .dp-two .colA p { color: var(--invert-mute); }
.dp-list { border-top: 1px solid var(--line); }
.dp-section.dark .dp-list { border-top-color: var(--line-dark); }
.dp-list .row { display: grid; grid-template-columns: 140px 1fr; gap: 28px; padding: 22px 0; border-bottom: 1px solid var(--line); }
.dp-section.dark .dp-list .row { border-bottom-color: var(--line-dark); }
.dp-list .row .k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-mute); padding-top: 3px; }
.dp-section.dark .dp-list .row .k { color: var(--invert-mute); }
.dp-list .row .v h5 { font-size: 17px; font-weight: 500; letter-spacing: -0.015em; margin-bottom: 6px; }
.dp-list .row .v p { color: var(--text-mute); font-size: 14px; line-height: 1.55; max-width: 62ch; }
.dp-section.dark .dp-list .row .v p { color: var(--invert-mute); }
@media (max-width: 700px){ .dp-list .row { grid-template-columns: 1fr; gap: 6px; } }

/* Success story block */
.dp-story { border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 40px; background: var(--paper); }
.dp-section.dark .dp-story { border-color: var(--line-dark); background: var(--ink-2); }
.dp-story .head { display: flex; justify-content: space-between; align-items: baseline; gap: 24px; margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px dashed var(--line); flex-wrap: wrap; }
.dp-section.dark .dp-story .head { border-bottom-color: var(--line-dark); }
.dp-story .head .tag { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-faint); }
.dp-section.dark .dp-story .head .tag { color: var(--invert-faint); }
.dp-story h4 { font-size: 22px; font-weight: 500; letter-spacing: -0.02em; }
.dp-story .client { color: var(--text-mute); font-size: 13px; margin-top: 4px; }
.dp-section.dark .dp-story .client { color: var(--invert-mute); }
.dp-story p { color: var(--text); font-size: 15px; line-height: 1.6; margin-top: 12px; max-width: 70ch; }
.dp-section.dark .dp-story p { color: var(--invert); }

/* Related links */
.dp-related { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
.dp-related a { background: var(--paper); padding: 24px; display: flex; flex-direction: column; gap: 8px; transition: background 140ms; }
.dp-related a:hover { background: var(--paper-2); }
.dp-related a .k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; color: var(--text-faint); }
.dp-related a h5 { font-size: 17px; font-weight: 500; letter-spacing: -0.015em; }
.dp-related a p { color: var(--text-mute); font-size: 13px; line-height: 1.5; }
.dp-related a .arrow { margin-top: 12px; font-family: var(--mono); font-size: 12px; color: var(--text-mute); }
@media (max-width: 800px){ .dp-related { grid-template-columns: 1fr; } }

/* CTA */
.dp-cta { background: var(--ink); color: var(--invert); padding: 96px 0; }
.dp-cta h2 { font-size: clamp(34px, 5vw, 72px); letter-spacing: -0.03em; line-height: 0.98; font-weight: 500; max-width: 18ch; }
.dp-cta h2 em { font-style: italic; font-weight: 400; background: linear-gradient(96deg, var(--brand-1), var(--brand-2), var(--brand-3)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.dp-cta .sub { color: var(--invert-mute); margin-top: 20px; max-width: 54ch; font-size: 16px; line-height: 1.55; }
.dp-cta .actions { margin-top: 32px; }
