/* =========================================================
   Subpages — About / Services / Clients / Contact
   ========================================================= */

.page-hero{
  padding:150px var(--gutter) 20px;
  max-width:1440px; margin:0 auto;
}
.page-title{
  font-size:clamp(40px, 5.6vw, 68px);
  margin-top:14px;
  max-width:820px;
}

/* ---------- About ---------- */
.about-hero-grid{
  padding:150px var(--gutter) 90px;
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:1.1fr .9fr;
  gap:64px; align-items:start;
}
.about-page-title{ margin-top:20px; margin-bottom:0; }
.about-hero-copy p{
  font-size:16.5px; line-height:1.8; color:var(--ink-soft);
  max-width:520px; margin-bottom:18px;
}
.about-hero-portrait{
  width:100%; aspect-ratio:4/5; max-height:560px; border-radius:var(--radius-lg);
  background:linear-gradient(160deg, #D8CDEF 0%, #B8A8DE 45%, #E7B7A5 100%);
  position:relative; overflow:hidden;
}
.about-hero-portrait::after{
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.35), transparent 60%);
}

.facts-strip{
  padding:0 var(--gutter) 110px;
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.fact-card{
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:38px 34px;
}
.fact-icon{
  display:block;
  width:32px; height:32px; margin-bottom:14px;
  background-color:var(--accent);
  -webkit-mask-size:contain; mask-size:contain;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
  -webkit-mask-position:center; mask-position:center;
}
.fact-num{
  font-family:var(--serif);
  font-size:60px;
  font-weight:600;
  font-variant-numeric:lining-nums;
  color:var(--accent);
}
.fact-label{ font-size:13.5px; color:var(--ink-soft); margin-top:8px; }

.philosophy-block{
  padding:0 var(--gutter) 130px;
  max-width:900px; margin:0 auto;
  text-align:left;
}
.philosophy-block h2{
  font-size:clamp(26px,3vw,36px); line-height:1.4; margin-bottom:24px;
}
.philosophy-block p{ font-size:15px; line-height:1.85; color:var(--ink-soft); margin-bottom:16px; }

@media (max-width:900px){
  .about-hero-grid{ grid-template-columns:1fr; }
  .facts-strip{ grid-template-columns:1fr; }
}

/* ---------- Services ---------- */
.services-intro{
  padding:0 var(--gutter) 70px;
  max-width:720px; margin:0 auto;
  text-align:center;
}
.services-intro p{ font-size:16px; line-height:1.8; color:var(--ink-soft); margin-top:14px; }

.services-grid{
  padding:0 var(--gutter) 120px;
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.service-card{
  background:var(--card);
  border-radius:var(--radius-md);
  padding:38px 32px;
  box-shadow:0 18px 44px -28px rgba(47,41,69,.24);
  transition:transform .5s var(--ease-soft), box-shadow .5s var(--ease-soft);
}
.service-card:hover{ transform:translateY(-5px); box-shadow:0 26px 60px -26px rgba(47,41,69,.32); }
.service-card-ico{
  width:46px; height:46px; border-radius:14px;
  background:var(--surface);
  display:flex; align-items:center; justify-content:center;
  color:var(--accent); font-size:18px;
  margin-bottom:22px;
}
.service-card h3{ font-size:21px; margin-bottom:10px; }
.service-card p{ font-size:13.5px; line-height:1.7; color:var(--ink-soft); }

.process-section{
  padding:0 var(--gutter) 130px;
  max-width:1440px; margin:0 auto;
}
.process-head{ max-width:600px; margin-bottom:50px; }
.process-head p{ font-size:15px; color:var(--ink-soft); margin-top:12px; line-height:1.7; }
.process-steps{
  display:grid; grid-template-columns:repeat(3,1fr); gap:40px;
}
.process-step-num{
  font-family:var(--serif); font-size:15px; color:var(--lavender);
  border-bottom:1px solid rgba(196,164,255,.4);
  padding-bottom:16px; margin-bottom:18px;
}
.process-step h3{ font-size:19px; margin-bottom:10px; }
.process-step p{ font-size:13.5px; line-height:1.7; color:var(--ink-soft); }

@media (max-width:980px){
  .services-grid, .process-steps{ grid-template-columns:1fr; }
}

/* ---------- Clients ---------- */
.clients-grid{
  padding:0 var(--gutter) 60px;
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.client-card{
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:44px 30px;
  display:flex; align-items:center; justify-content:center;
  min-height:150px;
  transition:background .4s var(--ease-soft), transform .4s var(--ease-soft);
}
.client-card:hover{ background:#fff; transform:translateY(-4px); box-shadow:0 20px 44px -26px rgba(47,41,69,.28); }
.client-wordmark{
  font-family:var(--serif); font-size:26px; letter-spacing:.02em;
  color:var(--ink); opacity:.55;
  transition:opacity .4s var(--ease-soft);
}
.client-card:hover .client-wordmark{ opacity:1; color:var(--accent); }
.client-logo-img{
  max-width:70%; max-height:44px;
  object-fit:contain;
  filter:grayscale(1); opacity:.6;
  transition:filter .4s var(--ease-soft), opacity .4s var(--ease-soft);
}
.client-card:hover .client-logo-img{ filter:grayscale(0); opacity:1; }

/* Testimonial carousel */
.testimonial-carousel{
  padding:80px var(--gutter) 140px;
  max-width:1600px; margin:0 auto;
  display:flex; align-items:center; gap:20px;
}
.testimonial-carousel-viewport{
  flex:1; min-width:0; overflow:hidden;
  -webkit-mask-image:linear-gradient(to right, transparent 2%, black 20%, black 80%, transparent 98%);
  mask-image:linear-gradient(to right, transparent 2%, black 20%, black 80%, transparent 98%);
}
.testimonial-carousel-track{
  display:flex; gap:50px;
  transition:transform .3s var(--ease-soft);
}
.testimonial-carousel .testimonial-card{
  flex:0 0 29%;
  background:none;
  border:none;
  padding:8px 4px;
  min-height:260px;
  display:flex; flex-direction:column;
  box-sizing:border-box;
}
.testimonial-carousel .testimonial-text{ font-size:16.5px; line-height:1.75; flex:0 0 auto; }
.testimonial-carousel .testimonial-author{ margin-top:auto; padding-top:24px; }
.testimonial-carousel .testimonial-name{ color:var(--lavender); }

.carousel-nav{
  width:44px; height:44px; border-radius:50%;
  background:var(--card);
  border:1px solid rgba(47,41,69,.1);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink); flex-shrink:0;
  transition:background .3s var(--ease-soft);
}
.carousel-nav:hover{ background:var(--surface); }
.carousel-empty{ text-align:center; color:var(--ink-soft); font-size:14px; padding:60px 0; width:100%; }

@media (max-width:980px){
  .clients-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
  .clients-grid{ grid-template-columns:1fr; }
  .testimonial-carousel{ padding:60px 24px 100px; gap:10px; }
  .testimonial-carousel .testimonial-card{ flex:0 0 90%; }
}

/* ---------- Contact ---------- */
.contact-grid{
  padding:60px var(--gutter) 140px;
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:.85fr 1.15fr;
  align-items:start;
  gap:64px;
}
.contact-info{ padding-top:2px; }
.contact-info p{ font-size:15px; line-height:1.85; color:var(--ink-soft); margin:16px 0 36px; max-width:400px; }
.contact-detail{ margin-bottom:24px; }
.contact-detail-label{ font-size:10.5px; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-soft); margin-bottom:0; line-height:1.2; }
.contact-detail-value{ font-size:22px; font-family:var(--serif); margin-top:2px; line-height:1.3; }
.contact-detail-value a:hover{ color:var(--accent); }

.contact-form{
  background:var(--card);
  border-radius:var(--radius-lg);
  padding:44px;
  box-shadow:0 30px 70px -34px rgba(47,41,69,.28);
}
.contact-form .field{ margin-bottom:22px; }
.contact-form textarea{
  font-family:var(--sans);
  padding:14px 18px; border-radius:var(--radius-sm);
  border:1px solid rgba(47,41,69,.12);
  background:var(--surface);
  font-size:14px; color:var(--ink);
  resize:vertical; min-height:130px;
  transition:border-color .3s var(--ease);
}
.contact-form textarea:focus{ border-color:var(--accent-2); outline:none; }
.contact-form .btn{ width:100%; justify-content:center; }

@media (max-width:900px){
  .contact-grid{ grid-template-columns:1fr; }
}

/* ---------- Toast ---------- */
.toast{
  position:fixed; bottom:28px; right:28px; z-index:500;
  background:var(--ink); color:#fff;
  padding:16px 22px; border-radius:var(--radius-sm);
  font-size:13.5px; font-weight:500;
  box-shadow:0 20px 50px -20px rgba(47,41,69,.5);
  display:flex; align-items:center; gap:10px;
  transform:translateY(20px); opacity:0; pointer-events:none;
  transition:transform .5s var(--ease-soft), opacity .5s var(--ease-soft);
}
.toast.show{ transform:translateY(0); opacity:1; }
.toast-dot{ width:7px; height:7px; border-radius:50%; background:var(--lavender); flex-shrink:0; }
