.case-list-hero{
  position:relative;
  isolation:isolate;
  min-height:423px;
  height:423px;
  background:
    linear-gradient(90deg,rgba(248,243,234,.99) 0%,rgba(248,243,234,.96) 38%,rgba(248,243,234,.38) 64%,rgba(248,243,234,0) 88%),
    url("/assets/case-list-banner-concept-20260612.png");
  background-color:#f8f3ea;
  background-size:auto 100%;
  background-position:right center;
  background-repeat:no-repeat;
}
.case-list-hero::before{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  left:0;
  z-index:0;
  width:76%;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(248,243,234,1) 0%,rgba(248,243,234,.98) 46%,rgba(248,243,234,.72) 64%,rgba(248,243,234,.18) 88%,rgba(248,243,234,0) 100%);
}
.case-list-hero .product-hero-copy{
  position:relative;
  z-index:1;
  padding-top:36px;
  padding-bottom:36px;
}
.case-list-hero .product-hero-copy h1{
  margin:14px 0 10px;
  max-width:720px;
  font-size:clamp(34px,3.2vw,46px);
}
.case-list-hero .product-hero-copy p{
  max-width:650px;
  font-size:16px;
  line-height:1.58;
}
.case-list-hero .hero-chips{
  margin-top:22px;
}
.case-hero-visual{
  position:relative;
  z-index:0;
  min-height:0;
  height:100%;
  background:transparent;
}
.case-hero-visual picture{
  display:block;
  width:100%;
  height:100%;
}
.case-list-hero .hero-scene{
  display:none;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:right center;
  filter:saturate(.96) contrast(1.02);
}
.case-hero-visual::after{
  background:linear-gradient(180deg,rgba(23,22,20,0) 62%,rgba(23,22,20,.1) 100%);
}
.case-catalog-section{
  background:#f8f3ea;
}
.case-catalog-card a{
  grid-template-columns:minmax(0,1fr) 140px;
  min-height:458px;
}
.case-catalog-card img{
  width:140px;
  height:108px;
  border:1px solid rgba(184,121,44,.16);
  border-radius:6px;
  background:#f4eadc;
  object-fit:cover;
  filter:none;
}
.case-catalog-card .product-summary{
  min-height:66px;
}
.case-catalog-card dl div{
  background:#fbf1e4;
}
.case-catalog-card .product-scenes{
  min-height:56px;
  background:#fff7ea;
}
.case-selection-band{
  background:#fffaf2;
}

.case-variant-hero,
.case-variant-section{
  width:min(100%,1680px);
  margin:0 auto;
  padding:54px clamp(22px,4vw,72px);
  border-bottom:1px solid var(--line);
  background:#f8f3ea;
}
.case-variant-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:34px;
  align-items:end;
  background:
    linear-gradient(90deg,rgba(248,243,234,.98),rgba(248,243,234,.92) 46%,rgba(248,243,234,.42)),
    url("/assets/case-list-banner-concept-20260612.png");
  background-size:auto 100%;
  background-position:right center;
  background-repeat:no-repeat;
}
.case-variant-hero h1{
  max-width:860px;
  margin:18px 0 14px;
  color:var(--ink);
  font-size:clamp(38px,4vw,58px);
  font-weight:950;
  line-height:1.08;
}
.case-variant-hero p,
.case-variant-head p,
.case-preview-grid p,
.case-featured-card p{
  margin:0;
  color:var(--muted);
  font-weight:650;
  line-height:1.7;
}
.case-variant-hero p{
  max-width:720px;
  font-size:18px;
}
.case-variant-switcher{
  display:grid;
  gap:10px;
  padding:18px;
  border:1px solid var(--line);
  border-radius:8px;
  background:rgba(255,253,248,.88);
}
.case-variant-switcher a{
  display:flex;
  align-items:center;
  min-height:42px;
  padding:0 14px;
  border:1px solid var(--line);
  border-radius:6px;
  background:#fffaf2;
  color:var(--ink);
  font-weight:850;
  text-decoration:none;
}
.case-variant-switcher a:hover{
  border-color:rgba(184,121,44,.42);
  color:var(--copper-strong);
}
.case-variant-section.is-soft{
  background:#fffaf2;
}
.case-variant-head{
  max-width:820px;
  margin-bottom:26px;
}
.case-variant-head h2{
  margin:14px 0 10px;
  color:var(--ink);
  font-size:clamp(30px,3vw,42px);
  font-weight:920;
  line-height:1.16;
}
.case-preview-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.case-preview-grid article,
.case-featured-card,
.case-featured-list a,
.case-metric-list a{
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-preview-grid article{
  overflow:hidden;
}
.case-preview-grid img{
  display:block;
  width:100%;
  height:210px;
  object-fit:cover;
}
.case-preview-grid span,
.case-featured-card span{
  display:inline-flex;
  width:max-content;
  margin:18px 18px 0;
  padding:4px 8px;
  border-radius:4px;
  background:#f0e4d4;
  color:#7a6244;
  font-size:12px;
  font-weight:850;
}
.case-preview-grid h3{
  margin:12px 18px 8px;
  color:var(--ink);
  font-size:22px;
  line-height:1.25;
}
.case-preview-grid p{
  min-height:58px;
  margin:0 18px;
  font-size:14px;
}
.case-preview-grid dl,
.case-featured-card dl,
.case-metric-list dl{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin:18px;
}
.case-preview-grid dl div,
.case-featured-card dl div,
.case-metric-list dl div{
  padding:10px;
  border-radius:6px;
  background:#fbf1e4;
}
.case-preview-grid dt,
.case-featured-card dt,
.case-metric-list dt{
  color:#8b7d6e;
  font-size:11px;
  font-weight:850;
}
.case-preview-grid dd,
.case-featured-card dd,
.case-metric-list dd{
  margin:4px 0 0;
  color:var(--copper-strong);
  font-size:19px;
  font-weight:950;
}
.case-featured-layout{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);
  gap:22px;
  align-items:stretch;
}
.case-featured-card{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1fr);
  overflow:hidden;
  color:inherit;
  text-decoration:none;
}
.case-featured-card img{
  width:100%;
  height:100%;
  min-height:390px;
  object-fit:cover;
}
.case-featured-card div{
  display:grid;
  align-content:center;
  padding:30px;
}
.case-featured-card span{
  margin:0 0 14px;
}
.case-featured-card h3{
  margin:0 0 12px;
  color:var(--ink);
  font-size:32px;
  line-height:1.16;
}
.case-featured-card dl{
  margin:24px 0 0;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.case-featured-list{
  display:grid;
  gap:12px;
}
.case-featured-list a{
  display:grid;
  align-content:center;
  min-height:88px;
  padding:18px;
  color:inherit;
  text-decoration:none;
}
.case-featured-list strong{
  color:var(--ink);
  font-size:18px;
  line-height:1.28;
}
.case-featured-list span{
  margin-top:8px;
  color:var(--muted);
  font-size:13px;
  font-weight:650;
}
.case-metric-list{
  display:grid;
  gap:12px;
}
.case-metric-list a{
  display:grid;
  grid-template-columns:132px minmax(0,1fr) 320px;
  gap:18px;
  align-items:center;
  min-height:130px;
  padding:16px 18px;
  color:inherit;
  text-decoration:none;
}
.case-metric-list img{
  width:132px;
  height:96px;
  border-radius:6px;
  object-fit:cover;
}
.case-metric-list strong,
.case-metric-list small{
  display:block;
}
.case-metric-list strong{
  color:var(--ink);
  font-size:21px;
  line-height:1.28;
}
.case-metric-list small{
  margin-top:8px;
  color:var(--muted);
  font-size:13px;
  font-weight:650;
}
.case-metric-list dl{
  margin:0;
}

.case-detail-page{
  width:min(100%,1680px);
  margin:0 auto;
  padding:54px clamp(22px,4vw,72px) 64px;
  border-bottom:1px solid var(--line);
  background:#f8f3ea;
}
.case-detail-head{
  max-width:1040px;
}
.case-detail-head h1{
  margin:18px 0 16px;
  max-width:980px;
  color:var(--ink);
  font-size:clamp(38px,4.2vw,62px);
  font-weight:950;
  line-height:1.08;
}
.case-detail-head p{
  max-width:920px;
  margin:0;
  color:var(--muted);
  font-size:19px;
  font-weight:650;
  line-height:1.78;
}
.case-detail-cover{
  margin:34px 0 46px;
}
.case-detail-cover img{
  display:block;
  width:100%;
  height:min(42vw,560px);
  min-height:360px;
  border:1px solid rgba(218,201,177,.9);
  border-radius:8px;
  object-fit:cover;
  object-position:center;
}
.case-detail-cover figcaption{
  margin-top:12px;
  color:#8b7d6e;
  font-size:14px;
  font-weight:650;
}
.case-detail-layout{
  display:grid;
  grid-template-columns:minmax(0,980px) 260px;
  gap:54px;
  align-items:start;
}
.case-detail-body{
  min-width:0;
}
.case-detail-body section{
  padding:34px 0;
  border-top:1px solid var(--line);
}
.case-detail-body section:first-child{
  padding-top:0;
  border-top:0;
}
.case-detail-body h2{
  margin:0 0 18px;
  color:var(--ink);
  font-size:32px;
  font-weight:920;
  line-height:1.22;
}
.case-detail-body h3{
  margin:18px 0 8px;
  color:var(--ink);
  font-size:22px;
  font-weight:900;
}
.case-detail-body p{
  margin:0 0 16px;
  color:#5f584f;
  font-size:17px;
  font-weight:620;
  line-height:1.9;
}
.case-detail-body p:last-child{
  margin-bottom:0;
}
.case-info-table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-info-table th,
.case-info-table td{
  padding:16px 18px;
  border:1px solid var(--line);
  color:#5f584f;
  font-size:15px;
  font-weight:650;
  line-height:1.55;
  text-align:left;
  vertical-align:top;
}
.case-info-table th{
  width:116px;
  background:#f2e7d6;
  color:var(--ink);
  font-weight:900;
}
.case-plain-list{
  display:grid;
  gap:10px;
  margin:0;
  padding-left:22px;
  color:#5f584f;
  font-size:17px;
  font-weight:650;
  line-height:1.75;
}
.case-simple-steps{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px;
  margin-top:24px;
}
.case-simple-steps span{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 12px;
  border:1px solid rgba(184,121,44,.26);
  border-radius:6px;
  background:#fff7ea;
  color:var(--copper-strong);
  font-size:14px;
  font-weight:900;
  text-align:center;
}
.case-result-table{
  display:grid;
  gap:10px;
  margin-top:22px;
}
.case-result-table div{
  padding:16px 18px;
  border-left:3px solid var(--copper);
  background:#fffdf8;
}
.case-result-table strong,
.case-result-table span{
  display:block;
}
.case-result-table strong{
  margin-bottom:6px;
  color:var(--ink);
  font-size:17px;
}
.case-result-table span{
  color:#5f584f;
  font-size:15px;
  font-weight:650;
  line-height:1.65;
}
.case-detail-body blockquote{
  margin:0;
  padding:22px 24px;
  border-left:4px solid var(--copper);
  background:#fffdf8;
  color:#4f4840;
  font-size:19px;
  font-weight:760;
  line-height:1.75;
}
.case-related-list{
  display:grid;
  gap:12px;
}
.case-related-list a{
  display:grid;
  grid-template-columns:112px minmax(0,1fr);
  gap:18px;
  align-items:center;
  min-height:112px;
  padding:14px 18px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
  color:inherit;
  text-decoration:none;
}
.case-related-list img{
  width:96px;
  height:82px;
  border-radius:6px;
  object-fit:cover;
}
.case-related-list strong,
.case-related-list small{
  display:block;
}
.case-related-list strong{
  margin-bottom:7px;
  color:var(--ink);
  font-size:18px;
  line-height:1.3;
}
.case-related-list small{
  color:var(--muted);
  font-size:14px;
  font-weight:650;
  line-height:1.6;
}
.case-detail-toc{
  position:sticky;
  top:92px;
  display:grid;
  gap:2px;
  padding:18px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.case-detail-toc strong{
  margin-bottom:10px;
  color:var(--ink);
  font-size:18px;
  font-weight:920;
}
.case-detail-toc a{
  padding:10px 0;
  color:#6c6258;
  font-size:14px;
  font-weight:750;
  text-decoration:none;
}
.case-detail-toc a:hover{
  color:var(--copper-strong);
}
.case-detail-toc .case-detail-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  margin-top:14px;
  padding:0 16px;
  border-radius:6px;
  background:var(--copper);
  color:#fff;
  font-weight:900;
}

.case-story-page{
  width:min(100%,1680px);
  margin:0 auto;
  border-bottom:1px solid var(--line);
  background:#f8f3ea;
}
.case-story-hero{
  display:grid;
  grid-template-columns:minmax(0,.86fr) minmax(480px,1.14fr);
  gap:38px;
  align-items:stretch;
  padding:54px clamp(22px,4vw,72px) 46px;
  min-height:610px;
}
.case-story-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-width:0;
  padding:28px 0 22px;
}
.case-story-copy h1{
  margin:18px 0 18px;
  color:var(--ink);
  font-size:clamp(42px,5.1vw,74px);
  font-weight:950;
  line-height:1.02;
}
.case-story-copy p{
  max-width:680px;
  margin:0;
  color:#665f55;
  font-size:20px;
  font-weight:650;
  line-height:1.78;
}
.case-story-facts{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1px;
  width:min(100%,680px);
  margin:34px 0 0;
  padding:0;
  overflow:hidden;
  border:1px solid rgba(218,201,177,.92);
  border-radius:8px;
  background:rgba(218,201,177,.8);
}
.case-story-facts div{
  min-height:86px;
  padding:18px;
  background:#fffaf2;
}
.case-story-facts dt{
  color:#8b7d6e;
  font-size:12px;
  font-weight:850;
}
.case-story-facts dd{
  margin:8px 0 0;
  color:var(--ink);
  font-size:18px;
  font-weight:920;
  line-height:1.25;
}
.case-story-media{
  position:relative;
  min-height:520px;
  margin:0;
  overflow:hidden;
  border:1px solid rgba(218,201,177,.92);
  border-radius:8px;
  background:#e8ddcf;
}
.case-story-media::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(23,22,20,0) 54%,rgba(23,22,20,.68) 100%);
}
.case-story-media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}
.case-story-media figcaption{
  position:absolute;
  left:22px;
  right:22px;
  bottom:20px;
  z-index:1;
  margin:0;
  color:#fff7ea;
  font-size:14px;
  font-weight:750;
  line-height:1.55;
}
.case-story-label{
  display:block;
  margin:0 0 12px;
  color:var(--copper-strong);
  font-size:13px;
  font-weight:900;
}
.case-story-snapshot,
.case-story-narrative,
.case-story-response,
.case-story-kit,
.case-story-impact,
.case-story-quote,
.case-story-summary,
.case-story-related{
  padding:58px clamp(22px,4vw,72px);
  border-top:1px solid var(--line);
}
.case-story-snapshot{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(420px,.55fr);
  gap:42px;
  align-items:center;
  background:#fffaf2;
}
.case-story-snapshot h2,
.case-story-narrative h2,
.case-story-section-head h2,
.case-story-impact h2,
.case-story-quote h2{
  margin:0;
  color:var(--ink);
  font-size:clamp(31px,3.5vw,48px);
  font-weight:930;
  line-height:1.16;
}
.case-story-snapshot p,
.case-story-narrative aside p,
.case-story-impact p{
  margin:18px 0 0;
  color:#5f584f;
  font-size:18px;
  font-weight:640;
  line-height:1.86;
}
.case-story-metrics{
  display:grid;
  gap:12px;
}
.case-story-metrics div{
  display:grid;
  grid-template-columns:130px minmax(0,1fr);
  gap:18px;
  align-items:center;
  min-height:96px;
  padding:16px 20px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-story-metrics strong{
  color:var(--copper-strong);
  font-size:44px;
  font-weight:950;
  letter-spacing:0;
  line-height:1;
  white-space:nowrap;
}
.case-story-metrics span{
  color:var(--ink);
  font-size:17px;
  font-weight:860;
}
.case-story-narrative{
  display:grid;
  grid-template-columns:320px minmax(0,1fr);
  gap:64px;
}
.case-story-narrative aside{
  position:sticky;
  top:104px;
  align-self:start;
}
.case-story-timeline{
  display:grid;
  gap:0;
  border-top:1px solid var(--line);
}
.case-story-timeline article{
  display:grid;
  grid-template-columns:82px minmax(0,1fr);
  gap:24px;
  padding:26px 0;
  border-bottom:1px solid var(--line);
}
.case-story-timeline article span{
  grid-row:1 / span 2;
  color:#cbb79c;
  font-size:34px;
  font-weight:950;
  line-height:1;
}
.case-story-timeline h3,
.case-story-timeline p{
  grid-column:2;
}
.case-story-timeline h3{
  margin:0 0 9px;
  color:var(--ink);
  font-size:25px;
  font-weight:920;
}
.case-story-timeline p,
.case-response-grid p,
.case-kit-row em{
  margin:0;
  color:#5f584f;
  font-size:16px;
  font-weight:640;
  font-style:normal;
  line-height:1.78;
}
.case-story-section-head{
  max-width:860px;
  margin-bottom:28px;
}
.case-response-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  border:1px solid var(--line);
  border-radius:8px;
  overflow:hidden;
  background:#fffdf8;
}
.case-response-grid article{
  min-height:280px;
  padding:24px;
  border-left:1px solid var(--line);
}
.case-response-grid article:first-child{
  border-left:0;
}
.case-response-grid b{
  display:inline-flex;
  margin-bottom:20px;
  padding:5px 9px;
  border-radius:4px;
  background:#f2e7d6;
  color:#7a6244;
  font-size:12px;
  font-weight:900;
}
.case-response-grid h3{
  margin:0 0 12px;
  color:var(--ink);
  font-size:24px;
  font-weight:920;
}
.case-response-grid strong{
  display:block;
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--line);
  color:var(--copper-strong);
  font-size:16px;
  font-weight:900;
  line-height:1.5;
}
.case-story-kit,
.case-story-quote{
  background:#fffaf2;
}
.case-solution-layout{
  display:grid;
  grid-template-columns:minmax(0,.72fr) minmax(440px,.8fr);
  gap:28px;
  align-items:start;
  margin-bottom:24px;
}
.case-solution-copy h3,
.case-deploy-panel h3,
.case-summary-list h3{
  margin:0 0 12px;
  color:var(--ink);
  font-size:24px;
  font-weight:920;
  line-height:1.25;
}
.case-solution-copy p,
.case-deploy-panel p,
.case-deploy-panel li span,
.case-summary-list p{
  margin:0;
  color:#5f584f;
  font-size:16px;
  font-weight:640;
  line-height:1.78;
}
.case-source-table,
.case-effect-table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-source-table th,
.case-source-table td,
.case-effect-table th,
.case-effect-table td{
  padding:15px 17px;
  border:1px solid var(--line);
  color:#5f584f;
  font-size:15px;
  font-weight:650;
  line-height:1.58;
  text-align:left;
  vertical-align:top;
}
.case-source-table th,
.case-effect-table th{
  background:#f2e7d6;
  color:var(--ink);
  font-weight:920;
}
.case-source-table th{
  width:150px;
}
.case-kit-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.case-kit-row a{
  display:grid;
  grid-template-rows:230px minmax(0,1fr);
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
  color:inherit;
  text-decoration:none;
}
.case-kit-row img{
  width:100%;
  height:100%;
  padding:22px;
  background:#f4eadc;
  object-fit:contain;
}
.case-kit-row a:nth-child(3) img{
  padding:0;
  object-fit:cover;
}
.case-kit-row span{
  display:grid;
  gap:8px;
  padding:20px;
}
.case-kit-row small{
  color:#8b7d6e;
  font-size:12px;
  font-weight:850;
}
.case-kit-row strong{
  color:var(--ink);
  font-size:21px;
  font-weight:930;
  line-height:1.28;
}
.case-architecture-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:22px;
}
.case-architecture-grid article{
  min-height:210px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-architecture-grid small{
  color:#cbb79c;
  font-size:26px;
  font-weight:950;
}
.case-architecture-grid h3{
  margin:12px 0 10px;
  color:var(--ink);
  font-size:22px;
  font-weight:920;
}
.case-architecture-grid p{
  margin:0;
  color:#5f584f;
  font-size:15px;
  font-weight:640;
  line-height:1.72;
}
.case-deploy-panel{
  display:grid;
  grid-template-columns:minmax(0,.62fr) minmax(0,1fr);
  gap:28px;
  margin-top:26px;
  padding:26px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-deploy-panel ul{
  display:grid;
  gap:12px;
  margin:0;
  padding:0;
  list-style:none;
}
.case-deploy-panel li{
  padding:16px;
  border-radius:6px;
  background:#fbf1e4;
}
.case-deploy-panel li strong{
  display:block;
  margin-bottom:7px;
  color:var(--ink);
  font-size:17px;
  font-weight:920;
}
.case-story-impact{
  display:grid;
  grid-template-columns:minmax(0,.72fr) minmax(520px,1fr);
  gap:42px;
  align-items:start;
}
.case-impact-board{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.case-impact-board div{
  min-height:150px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-impact-board .case-impact-main{
  grid-row:span 2;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:#2c2925;
}
.case-impact-board strong{
  display:block;
  color:var(--ink);
  font-size:21px;
  font-weight:930;
  line-height:1.25;
}
.case-impact-board span{
  display:block;
  margin-top:10px;
  color:#5f584f;
  font-size:15px;
  font-weight:650;
  line-height:1.7;
}
.case-impact-main strong{
  color:#fff7ea;
  font-size:72px;
  line-height:1;
}
.case-impact-main span{
  color:#f3dfc3;
  font-size:18px;
  font-weight:820;
}
.case-effect-table{
  grid-column:1 / -1;
}
.case-story-quote{
  max-width:none;
}
.case-story-quote blockquote{
  max-width:1020px;
  margin:0;
  color:#3f3a34;
  font-size:clamp(24px,2.5vw,36px);
  font-weight:820;
  line-height:1.55;
}
.case-story-quote p{
  margin:18px 0 0;
  color:#7a6244;
  font-size:16px;
  font-weight:850;
}
.case-summary-list{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  border:1px solid var(--line);
  border-radius:8px;
  overflow:hidden;
  background:#fffdf8;
}
.case-summary-list article{
  min-height:260px;
  padding:22px;
  border-left:1px solid var(--line);
}
.case-summary-list article:first-child{
  border-left:0;
}
.case-story-related .case-related-list{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.case-story-related .case-related-list a{
  grid-template-columns:104px minmax(0,1fr);
}
.case-detail-variant-hero{
  background:
    linear-gradient(90deg,rgba(248,243,234,.98),rgba(248,243,234,.92) 46%,rgba(248,243,234,.42)),
    url("/assets/visual-direction-2/model-redraw/elements/case-urban-flood-background-redraw.webp");
  background-size:auto 100%;
  background-position:right center;
  background-repeat:no-repeat;
}
.case-detail-variant .case-variant-head{
  max-width:900px;
}
.case-variant-label{
  margin:0 0 10px;
  color:var(--copper-strong);
  font-size:13px;
  font-weight:850;
}
.case-article-sample{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1fr);
  gap:24px;
  align-items:center;
}
.case-article-sample img,
.case-report-sample img{
  width:100%;
  border:1px solid var(--line);
  border-radius:8px;
  object-fit:cover;
}
.case-article-sample img{
  height:360px;
}
.case-article-sample>div,
.case-sidebar-sample article,
.case-sidebar-sample aside,
.case-report-sample table{
  border:1px solid var(--line);
  border-radius:8px;
  background:#fffdf8;
}
.case-article-sample>div,
.case-sidebar-sample article,
.case-sidebar-sample aside{
  padding:24px;
}
.case-article-sample h3,
.case-sidebar-sample h3{
  margin:0 0 10px;
  color:var(--ink);
  font-size:24px;
}
.case-article-sample p,
.case-sidebar-sample p{
  margin:0 0 18px;
  color:var(--muted);
  font-size:16px;
  font-weight:650;
  line-height:1.75;
}
.case-sidebar-sample{
  display:grid;
  grid-template-columns:minmax(0,1fr) 330px;
  gap:22px;
}
.case-sidebar-sample aside strong{
  display:block;
  margin-bottom:14px;
  color:var(--ink);
  font-size:22px;
}
.case-sidebar-sample dl{
  display:grid;
  gap:10px;
  margin:0;
}
.case-sidebar-sample dl div{
  padding:12px;
  border-radius:6px;
  background:#fbf1e4;
}
.case-sidebar-sample dt{
  color:#8b7d6e;
  font-size:12px;
  font-weight:850;
}
.case-sidebar-sample dd{
  margin:5px 0 0;
  color:var(--ink);
  font-weight:850;
}
.case-report-sample{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:22px;
  align-items:start;
}
.case-report-sample table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
}
.case-report-sample th,
.case-report-sample td{
  padding:18px 20px;
  border-bottom:1px solid var(--line);
  color:#5f584f;
  font-size:16px;
  font-weight:650;
  line-height:1.75;
  text-align:left;
  vertical-align:top;
}
.case-report-sample th{
  width:110px;
  background:#f2e7d6;
  color:var(--ink);
  font-weight:920;
}
.case-report-sample tr:last-child th,
.case-report-sample tr:last-child td{
  border-bottom:0;
}
.case-report-sample img{
  height:310px;
}

@media (max-width:1320px){
  .case-featured-layout,
  .case-featured-card{
    grid-template-columns:1fr;
  }
  .case-featured-card img{
    min-height:320px;
  }
  .case-metric-list a{
    grid-template-columns:118px minmax(0,1fr);
  }
  .case-metric-list dl{
    grid-column:2;
  }
  .case-detail-layout,
  .case-article-sample,
  .case-sidebar-sample,
  .case-report-sample{
    grid-template-columns:1fr;
  }
  .case-story-hero,
  .case-story-snapshot,
  .case-story-narrative,
  .case-story-impact,
  .case-solution-layout,
  .case-deploy-panel{
    grid-template-columns:1fr;
  }
  .case-story-narrative aside{
    position:static;
  }
  .case-response-grid,
  .case-kit-row,
  .case-architecture-grid,
  .case-summary-list,
  .case-story-related .case-related-list{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .case-summary-list article:nth-child(odd){
    border-left:0;
  }
  .case-summary-list article:nth-child(n+3){
    border-top:1px solid var(--line);
  }
  .case-detail-toc{
    position:static;
    order:-1;
  }
}

@media (max-width:980px){
  .case-list-hero{
    height:auto;
    min-height:386px;
    background:#f8f3ea;
  }
  .case-list-hero::before{
    content:none;
  }
  .case-list-hero .product-hero-copy{
    padding-top:42px;
    padding-bottom:28px;
  }
  .case-list-hero .product-hero-copy h1{
    font-size:31px;
  }
  .case-list-hero .product-hero-copy p{
    font-size:16px;
    line-height:1.6;
  }
  .case-hero-visual{
    min-height:330px;
    height:330px;
    background:#efe3d4;
  }
  .case-list-hero .hero-scene{
    display:block;
    object-fit:cover;
  }
  .case-variant-hero{
    grid-template-columns:1fr;
    background:#f8f3ea;
  }
  .case-variant-switcher{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .case-preview-grid{
    grid-template-columns:1fr;
  }
  .case-preview-grid p{
    min-height:0;
  }
  .case-detail-layout{
    gap:34px;
  }
  .case-detail-toc{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:6px 16px;
  }
  .case-detail-toc strong,
  .case-detail-toc .case-detail-cta{
    grid-column:1 / -1;
  }
  .case-simple-steps{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .case-story-hero{
    min-height:0;
    padding-top:42px;
  }
  .case-story-media{
    min-height:390px;
  }
  .case-story-facts,
  .case-response-grid,
  .case-kit-row,
  .case-architecture-grid,
  .case-summary-list,
  .case-impact-board,
  .case-story-related .case-related-list{
    grid-template-columns:1fr;
  }
  .case-response-grid article,
  .case-response-grid article:first-child{
    border-left:0;
    border-top:1px solid var(--line);
  }
  .case-response-grid article:first-child{
    border-top:0;
  }
  .case-summary-list article,
  .case-summary-list article:first-child,
  .case-summary-list article:nth-child(odd),
  .case-summary-list article:nth-child(n+3){
    border-left:0;
    border-top:1px solid var(--line);
  }
  .case-summary-list article:first-child{
    border-top:0;
  }
  .case-effect-table,
  .case-effect-table thead,
  .case-effect-table tbody,
  .case-effect-table tr,
  .case-effect-table th,
  .case-effect-table td,
  .case-source-table,
  .case-source-table tbody,
  .case-source-table tr,
  .case-source-table th,
  .case-source-table td{
    display:block;
    width:100%;
  }
  .case-effect-table thead{
    display:none;
  }
  .case-effect-table tr{
    border-bottom:1px solid var(--line);
  }
  .case-effect-table tr:last-child{
    border-bottom:0;
  }
  .case-effect-table td:first-child{
    background:#f2e7d6;
    color:var(--ink);
    font-weight:920;
  }
  .case-impact-board .case-impact-main{
    grid-row:auto;
  }
}

@media (max-width:640px){
  .case-catalog-card a{
    grid-template-columns:minmax(0,1fr) 104px;
    min-height:0;
  }
  .case-catalog-card img{
    width:104px;
    height:86px;
  }
  .case-variant-hero,
  .case-variant-section{
    padding-left:20px;
    padding-right:20px;
  }
  .case-variant-hero h1{
    font-size:34px;
  }
  .case-variant-switcher,
  .case-featured-card dl,
  .case-metric-list dl{
    grid-template-columns:1fr;
  }
  .case-featured-card div{
    padding:22px;
  }
  .case-featured-card h3{
    font-size:26px;
  }
  .case-metric-list a{
    grid-template-columns:86px minmax(0,1fr);
    padding:14px;
  }
  .case-metric-list img{
    width:86px;
    height:76px;
  }
  .case-metric-list dl{
    grid-column:1 / -1;
  }
  .case-detail-page{
    padding:38px 20px 48px;
  }
  .case-story-hero,
  .case-story-snapshot,
  .case-story-narrative,
  .case-story-response,
  .case-story-kit,
  .case-story-impact,
  .case-story-quote,
  .case-story-summary,
  .case-story-related{
    padding-left:20px;
    padding-right:20px;
  }
  .case-story-copy{
    padding-top:0;
  }
  .case-story-copy h1{
    font-size:38px;
  }
  .case-story-copy p,
  .case-story-snapshot p,
  .case-story-narrative aside p,
  .case-story-impact p{
    font-size:16px;
  }
  .case-story-media{
    min-height:300px;
  }
  .case-story-facts div{
    min-height:76px;
    padding:15px 16px;
  }
  .case-story-metrics div{
    grid-template-columns:108px minmax(0,1fr);
    min-height:82px;
    padding:14px 16px;
  }
  .case-story-metrics strong{
    font-size:34px;
  }
  .case-story-timeline article{
    grid-template-columns:52px minmax(0,1fr);
    gap:14px;
  }
  .case-story-timeline article span{
    font-size:25px;
  }
  .case-story-timeline h3,
  .case-response-grid h3{
    font-size:22px;
  }
  .case-kit-row a{
    grid-template-rows:190px minmax(0,1fr);
  }
  .case-deploy-panel{
    padding:20px;
  }
  .case-summary-list article{
    min-height:0;
  }
  .case-impact-main strong{
    font-size:54px;
  }
  .case-story-quote blockquote{
    font-size:23px;
  }
  .case-detail-head h1{
    font-size:34px;
  }
  .case-detail-head p{
    font-size:17px;
  }
  .case-detail-cover{
    margin:28px 0 34px;
  }
  .case-detail-cover img{
    height:310px;
    min-height:310px;
  }
  .case-detail-body section{
    padding:30px 0;
  }
  .case-detail-body h2{
    font-size:28px;
  }
  .case-detail-body p,
  .case-plain-list{
    font-size:16px;
  }
  .case-info-table,
  .case-info-table tbody,
  .case-info-table tr,
  .case-info-table th,
  .case-info-table td{
    display:block;
    width:100%;
  }
  .case-info-table th,
  .case-info-table td{
    border-left:0;
    border-right:0;
  }
  .case-simple-steps,
  .case-detail-toc,
  .case-related-list a{
    grid-template-columns:1fr;
  }
  .case-related-list a{
    gap:12px;
  }
  .case-related-list img{
    width:100%;
    height:150px;
  }
  .case-article-sample img,
  .case-report-sample img{
    height:250px;
  }
  .case-report-sample th,
  .case-report-sample td{
    display:block;
    width:100%;
  }
}


.case-list-hero{
  height:auto;
  min-height:423px;
  background:
    linear-gradient(90deg,rgba(248,243,234,.98) 0%,rgba(248,243,234,.9) 34%,rgba(248,243,234,.42) 55%,rgba(248,243,234,.08) 74%,rgba(248,243,234,0) 100%),
    url("/assets/generated/case-list-banner-urban-drainage-concept-v4.webp");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.case-list-hero::before{
  content:none;
}
.case-hero-visual{
  min-height:423px;
  background:transparent;
}
.case-list-hero .hero-scene{
  display:none;
}
.case-hero-visual::after{
  background:none;
}
.case-list-hero .product-hero-copy{
  position:relative;
  z-index:1;
}

.case-catalog-card:not(.case-catalog-featured) img{
  width:140px;
  height:112px;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  object-fit:contain;
  mix-blend-mode:multiply;
  filter:saturate(.98) contrast(1.04) drop-shadow(0 14px 18px rgba(31,29,26,.12));
  box-shadow:none;
}

.case-catalog-card .case-card-meta{
  grid-column:1 / -1;
  display:grid;
  gap:10px;
  margin-top:14px;
}
.case-catalog-card .case-card-products,
.case-catalog-card .case-card-implementation{
  margin:0;
  border:1px solid rgba(184,121,44,.18);
  border-radius:6px;
  background:
    linear-gradient(180deg,rgba(255,250,242,.96),rgba(255,244,228,.88)),
    #fff7ea;
}
.case-catalog-card .case-card-products{
  display:grid;
  gap:8px;
  padding:11px 12px 12px;
}
.case-catalog-card .case-card-products strong,
.case-catalog-card .case-card-implementation strong{
  display:flex;
  align-items:center;
  gap:7px;
  color:var(--copper-strong);
  font-size:12px;
  line-height:1;
  font-weight:900;
}
.case-catalog-card .case-card-products strong::before,
.case-catalog-card .case-card-implementation strong::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--copper);
  box-shadow:0 0 0 4px rgba(184,121,44,.12);
}
.case-catalog-card .case-card-products div{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.case-catalog-card .case-card-products span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  max-width:100%;
  padding:5px 9px;
  border:1px solid rgba(184,121,44,.2);
  border-radius:999px;
  background:rgba(255,253,248,.88);
  color:#62594e;
  font-size:12px;
  line-height:1.35;
  font-weight:800;
}
.case-catalog-card .case-card-implementation{
  display:grid;
  gap:7px;
  padding:11px 12px 12px;
}
.case-catalog-card .case-card-implementation span{
  display:-webkit-box;
  overflow:hidden;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:3;
  color:var(--muted);
  font-size:12px;
  line-height:1.58;
  font-weight:700;
}
.case-catalog-featured{
  grid-column:1 / -1;
}
.case-catalog-featured a{
  grid-template-columns:minmax(320px,.92fr) minmax(0,1.08fr);
  grid-template-rows:auto auto auto auto auto;
  min-height:356px;
  gap:0 28px;
  padding:24px;
  background:
    linear-gradient(120deg,rgba(255,253,248,.98),rgba(255,247,234,.94)),
    #fffdf8;
}
.case-catalog-featured img{
  grid-column:1;
  grid-row:1 / -1;
  width:100%;
  height:100%;
  min-height:308px;
  margin:0;
  padding:0;
  border-radius:8px;
  background:#f4eadc;
  object-fit:cover;
  mix-blend-mode:normal;
  filter:none;
  box-shadow:none;
}
.case-catalog-featured .product-series,
.case-catalog-featured h3,
.case-catalog-featured .product-summary,
.case-catalog-featured dl,
.case-catalog-featured .product-scenes,
.case-catalog-featured .case-card-meta,
.case-catalog-featured em{
  grid-column:2;
}
.case-catalog-featured .product-series{
  grid-row:auto;
  margin-bottom:12px;
}
.case-catalog-featured h3{
  max-width:720px;
  font-size:clamp(30px,3vw,44px);
  line-height:1.12;
}
.case-catalog-featured .product-summary{
  max-width:720px;
  min-height:0;
  margin-top:14px;
  font-size:16px;
  line-height:1.72;
}
.case-catalog-featured dl{
  max-width:680px;
  margin-top:22px;
}
.case-catalog-featured .product-scenes{
  max-width:720px;
  min-height:0;
  margin-top:16px;
}
.case-catalog-featured .case-card-meta{
  grid-template-columns:minmax(220px,.82fr) minmax(0,1.18fr);
  max-width:760px;
  margin-top:18px;
}
.case-catalog-featured .case-card-products,
.case-catalog-featured .case-card-implementation{
  min-height:118px;
  align-content:start;
}
.case-catalog-featured .case-card-implementation span{
  -webkit-line-clamp:4;
  font-size:13px;
  line-height:1.68;
}
.case-catalog-featured em{
  width:max-content;
  margin-top:18px;
}

@media (max-width:980px){
  .case-catalog-featured a{
    grid-template-columns:1fr;
    min-height:0;
    gap:18px;
  }
  .case-catalog-featured img,
  .case-catalog-featured .product-series,
  .case-catalog-featured h3,
  .case-catalog-featured .product-summary,
  .case-catalog-featured dl,
  .case-catalog-featured .product-scenes,
  .case-catalog-featured .case-card-meta,
  .case-catalog-featured em{
    grid-column:1;
  }
  .case-catalog-featured .case-card-meta{
    grid-template-columns:1fr;
    max-width:none;
  }
  .case-catalog-featured img{
    grid-row:auto;
    min-height:260px;
    max-height:380px;
  }
}

@media (max-width:640px){
  .case-list-hero{
    min-height:0;
    background:
      linear-gradient(180deg,rgba(248,243,234,.99) 0%,rgba(248,243,234,.9) 54%,rgba(248,243,234,.38) 100%),
      url("/assets/generated/case-list-banner-urban-drainage-concept-v4.webp");
    background-size:cover;
    background-position:62% center;
  }
  .case-hero-visual{
    display:none;
  }
  .case-catalog-featured a{
    padding:18px;
  }
  .case-catalog-featured img{
    width:100%;
    height:220px;
    min-height:220px;
  }
  .case-catalog-featured h3{
    font-size:24px;
  }
}
