.cat{
  --primary:#550e05;
  --primary-2:#6b1207;
  --cream:#fffaf6;
  --gray:#2a2a2a;
  --muted:#6b6b6b;
  --line:#ead8d2;
  --bg:#faf6f3;
  --gold:#b8893b;
  color:var(--gray);
  line-height:1.65;
}
.cat *{box-sizing:border-box}
.cat .wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.cat .eyebrow{
  display:inline-block;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--primary);font-weight:600;margin-bottom:14px;
}

/* HERO */
.cat .hero{
  background:#3a0a04;
  color:#fff;padding:120px 0 110px;position:relative;overflow:hidden;
  isolation:isolate;
}
.cat .hero .wrap{position:relative;z-index:4}
.cat .hero-photo{
  position:absolute;inset:-8%;z-index:0;pointer-events:none;
  background:var(--hero-bg) center/cover no-repeat;
  will-change:transform;
  filter:saturate(.85) contrast(1.05);
}
.cat .hero-tint{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(135deg,rgba(85,14,5,.82) 0%,rgba(107,18,7,.78) 50%,rgba(58,10,4,.88) 100%),
    radial-gradient(ellipse at 70% 40%,rgba(184,137,59,.18),transparent 60%);
  mix-blend-mode:multiply;
}
.cat .hero-veil{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(58,10,4,.35) 0%,rgba(58,10,4,0) 30%,rgba(58,10,4,.55) 100%);
}
.cat .hero-bg{
  position:absolute;inset:0;z-index:3;pointer-events:none;
  will-change:transform;
}
.cat .hero-blob{
  position:absolute;border-radius:50%;filter:blur(2px);
  will-change:transform;
}
.cat .hero-blob.b1{
  right:-160px;top:-140px;width:480px;height:480px;
  background:radial-gradient(circle,rgba(255,250,246,.18),transparent 70%);
}
.cat .hero-blob.b2{
  left:-200px;bottom:-180px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(184,137,59,.18),transparent 70%);
}
.cat .hero-blob.b3{
  right:18%;bottom:-80px;width:240px;height:240px;
  background:radial-gradient(circle,rgba(255,250,246,.10),transparent 70%);
}
.cat .hero-grid{
  position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.08;
  background-image:
    linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:60px 60px;
  will-change:transform;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
}
.cat .hero .eyebrow{color:#f7d9c8}
@media (prefers-reduced-motion: reduce){
  .cat .hero-bg,.cat .hero-blob,.cat .hero-grid,.cat .hero-photo{transform:none !important}
}
.cat h1,.cat .hero h1{
  font-size:clamp(30px,4.4vw,52px);line-height:1.2;margin:0 0 18px;
  font-weight:300;letter-spacing:.5px;color:#fff;text-transform:uppercase;
}
.cat .hero p.lead{
  font-size:clamp(16px,1.5vw,19px);max-width:760px;color:#f5e6df;margin:0 0 28px;
}
.cat .hero-text{max-width:820px;font-size:16.5px;color:#f5e6df}
.cat .hero-text strong{color:#fff}

/* STATS */
.cat .stats{background:var(--bg);padding:64px 0;border-bottom:1px solid var(--line)}
.cat .stats h2{font-size:clamp(24px,2.6vw,34px);margin:0 0 36px;text-align:center;color:var(--primary);font-weight:700}
.cat .stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:32px}
.cat .stat{
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:34px 22px;text-align:center;
  box-shadow:0 4px 18px rgba(85,14,5,.05);
}
.cat .stat .num{
  font-size:clamp(36px,4.5vw,52px);font-weight:800;color:var(--primary);
  line-height:1;margin-bottom:10px;letter-spacing:-1px;
}
.cat .stat .lbl{color:var(--muted);font-size:14.5px}
.cat .stats-note{max-width:820px;margin:0 auto;text-align:center;color:var(--gray);font-size:16px}

/* SECTIONS */
.cat section.block{padding:70px 0;background:#fff}
.cat section.block.alt{background:var(--bg)}
.cat section.block h2{
  font-size:clamp(26px,3vw,38px);margin:0 0 12px;color:var(--primary);
  font-weight:700;letter-spacing:-.3px;
}
.cat section.block .sub{color:var(--muted);max-width:820px;margin:0 0 36px;font-size:16px}

/* SERVICE GROUP */
.cat .group{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:34px 32px;margin-bottom:24px;
  box-shadow:0 2px 12px rgba(85,14,5,.04);
}
.cat .group .num-pill{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  background:var(--primary);color:#fff;font-weight:700;font-size:17px;
  margin-right:14px;flex-shrink:0;
}
.cat .group h3{
  font-size:22px;margin:0 0 10px;color:var(--gray);font-weight:700;
  display:flex;align-items:center;gap:0;
}
.cat .group h3 .title{flex:1}
.cat .group .intro{color:var(--muted);margin:0 0 22px;padding-left:56px;font-size:15.5px}
.cat .group ul{list-style:none;padding:0 0 0 56px;margin:0}
.cat .group ul li{
  padding:12px 0;border-top:1px solid var(--line);
  font-size:15px;display:flex;gap:12px;align-items:flex-start;
}
.cat .group ul li:first-child{border-top:none}
.cat .group ul li::before{
  content:"";display:inline-block;flex-shrink:0;
  width:6px;height:6px;border-radius:50%;background:var(--primary);
  margin-top:9px;
}
.cat .group ul li b{color:var(--primary);font-weight:600}
.cat .group ul li span.desc{color:var(--muted)}

/* WHY US */
.cat .why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:30px}
.cat .why-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:26px 26px 24px;position:relative;
  box-shadow:0 2px 10px rgba(85,14,5,.04);
}
.cat .why-card .check{
  width:36px;height:36px;border-radius:50%;
  background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;margin-bottom:14px;
}
.cat .why-card h4{margin:0 0 8px;font-size:18px;color:var(--primary);font-weight:700}
.cat .why-card p{margin:0;color:var(--gray);font-size:15px}

/* STEPS */
.cat .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:30px}
.cat .step{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:26px 22px;position:relative;
}
.cat .step .step-num{
  position:absolute;top:-18px;left:22px;
  background:var(--primary);color:#fff;
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:17px;
  box-shadow:0 4px 12px rgba(85,14,5,.25);
}
.cat .step h4{margin:18px 0 8px;font-size:17px;color:var(--gray);font-weight:700}
.cat .step p{margin:0;color:var(--muted);font-size:14.5px}

/* FAQ */
.cat .faq-list{display:grid;gap:12px;margin-top:30px}
.cat .faq-item{
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:0;overflow:hidden;transition:box-shadow .2s;
}
.cat .faq-item[open]{box-shadow:0 4px 18px rgba(85,14,5,.08)}
.cat .faq-item summary{
  cursor:pointer;list-style:none;padding:20px 24px;font-weight:600;
  color:var(--gray);font-size:16.5px;display:flex;justify-content:space-between;
  align-items:center;gap:16px;
}
.cat .faq-item summary::-webkit-details-marker{display:none}
.cat .faq-item summary::after{
  content:"+";color:var(--primary);font-size:24px;font-weight:300;
  flex-shrink:0;transition:transform .2s;
}
.cat .faq-item[open] summary::after{transform:rotate(45deg)}
.cat .faq-answer{padding:0 24px 22px;color:var(--muted);font-size:15.5px;line-height:1.7}

/* CTA */
.cat .cta-final{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-2) 100%);
  color:#fff;padding:70px 0;text-align:center;
}
.cat .cta-final h2{color:#fff;font-size:clamp(26px,3vw,36px);margin:0 0 16px;font-weight:700}
.cat .cta-final p{color:#f5e6df;max-width:760px;margin:0 auto 16px;font-size:16.5px}

/* RESPONSIVE */
@media (max-width: 860px){
  .cat .stats-grid{grid-template-columns:1fr;gap:16px}
  .cat .why-grid{grid-template-columns:1fr}
  .cat .steps{grid-template-columns:1fr;gap:28px}
  .cat .group{padding:26px 20px}
  .cat .group .intro,.cat .group ul{padding-left:0}
  .cat .group h3{flex-wrap:wrap}
  .cat section.block{padding:50px 0}
  .cat .hero{padding:96px 0 50px}
}
