/* =========================================================
   SA PORTFOLIO — Single Project page (built-in template)
   ========================================================= */

:root {
  --sa-teal:#589C9D;
  --sa-teal-deep:#4F6C70;
  --sa-cream:#E8EEEE;
  --sa-sand:#DAD0C6;
  --sa-ink:#0a0a0a;
  --sa-muted:#6b6b6b;
  --sa-line:rgba(10,10,10,.1);
  /* ใช้ font ของ theme/brand ถ้ามี — ไม่งั้น fallback */
  --sa-fhead:'Qochy','Cormorant Garamond','Playfair Display',Georgia,serif;
  --sa-fbody:'SF Pro Display',-apple-system,BlinkMacSystemFont,'Inter',sans-serif;
}
.sa-pd-page h1 .it,
.sa-pd-page h2 .it,
.sa-pd-page h3 .it { font-style:italic; color:var(--sa-teal); }

.sa-pd-page { font-family:var(--sa-fbody); color:var(--sa-ink); }

/* HERO */
.sa-pd-page .pd-hero {
  position:relative; min-height:80vh;
  color:#fff; overflow:hidden; background:#0a1518;
  display:flex; align-items:flex-end;
}
.sa-pd-page .pd-hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:brightness(.55) saturate(1.05);
}
.sa-pd-page .pd-hero-bg::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.15) 40%, rgba(0,0,0,.75) 100%);
}
.sa-pd-page .pd-hero-inner {
  position:relative; z-index:2;
  padding:140px 40px 70px;
  max-width:1400px; width:100%; margin:0 auto;
}
.sa-pd-page .pd-hero .crumbs {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:rgba(255,255,255,.8); margin-bottom:24px;
}
.sa-pd-page .pd-hero .crumbs a { color:rgba(255,255,255,.7); text-decoration:none; }
.sa-pd-page .pd-hero .crumbs a:hover { color:var(--sa-teal); }
.sa-pd-page .pd-hero .crumbs .sep { margin:0 10px; color:rgba(255,255,255,.4); }
.sa-pd-page .pd-chip {
  display:inline-block;
  background:rgba(255,255,255,.12); backdrop-filter:blur(8px);
  color:#fff; padding:8px 16px;
  font-family:var(--sa-fbody); font-size:11px;
  letter-spacing:2.5px; text-transform:uppercase; font-weight:700;
  margin-bottom:22px; border:1px solid rgba(255,255,255,.25);
}
.sa-pd-page .pd-hero h1 {
  font-family:var(--sa-fhead);
  font-size:clamp(48px, 7vw, 110px);
  font-weight:400; line-height:1.02;
  color:#fff; letter-spacing:-.005em;
  margin:0;
}
.sa-pd-page .pd-meta {
  margin-top:28px; display:flex; flex-wrap:wrap;
  font-family:var(--sa-fbody); font-size:13px; letter-spacing:2px;
  text-transform:uppercase; color:rgba(255,255,255,.85);
}
.sa-pd-page .pd-meta span {
  padding:0 20px;
  border-right:1px solid rgba(255,255,255,.28);
}
.sa-pd-page .pd-meta span:first-child { padding-left:0; }
.sa-pd-page .pd-meta span:last-child  { border-right:none; }

/* QUICK FACTS */
.sa-pd-page .pd-facts { background:var(--sa-cream); padding:0; }
.sa-pd-page .pd-facts-inner {
  max-width:1400px; margin:0 auto;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
}
.sa-pd-page .pd-facts .fact {
  padding:32px 18px; text-align:center;
  border-right:1px solid rgba(10,10,10,.08);
  display:flex; flex-direction:column; gap:8px;
}
.sa-pd-page .pd-facts .fact:last-child { border-right:none; }
.sa-pd-page .pd-facts .lbl {
  font-family:var(--sa-fbody); font-size:10px;
  letter-spacing:2.5px; text-transform:uppercase; color:var(--sa-muted);
}
.sa-pd-page .pd-facts .val {
  font-family:var(--sa-fhead); font-size:22px;
  color:var(--sa-ink); font-weight:500; line-height:1.1;
}

/* STORY */
.sa-pd-page .pd-story { background:#fff; padding:100px 40px; }
.sa-pd-page .pd-story-inner {
  max-width:1240px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.3fr;
  gap:64px; align-items:start;
}
.sa-pd-page .pd-story .eyebrow {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:var(--sa-teal-deep); margin-bottom:14px;
}
.sa-pd-page .pd-story h2 {
  font-family:var(--sa-fhead);
  font-size:clamp(32px, 4.2vw, 52px);
  font-weight:400; line-height:1.1; color:var(--sa-ink);
  margin:0;
}
.sa-pd-page .pd-story-right p {
  font-size:15.5px; line-height:1.85; color:#3d3d3d; margin-bottom:18px;
}

/* GALLERY */
.sa-pd-page .pd-gallery { background:#fff; padding:0 40px 100px; }
.sa-pd-page .pd-gallery-inner { max-width:1400px; margin:0 auto; }
.sa-pd-page .pd-gallery-head { text-align:center; margin-bottom:48px; }
.sa-pd-page .pd-gallery-head .eyebrow {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:var(--sa-teal-deep); margin-bottom:14px;
}
.sa-pd-page .pd-gallery-head h3 {
  font-family:var(--sa-fhead);
  font-size:clamp(30px, 4vw, 48px);
  font-weight:400; color:var(--sa-ink); margin:0;
}
.sa-pd-page .pd-gallery-head h3 .it { font-style:italic; color:var(--sa-teal); }

/* Gallery tabs (ALL / EXTERIORS / INTERIORS) */
.sa-pd-page .pd-gallery-tabs {
  display:flex; flex-wrap:wrap; gap:6px;
  justify-content:center; margin:0 0 36px;
  padding:0;
}
.sa-pd-page .pd-tab {
  font-family:var(--sa-fbody);
  font-size:12px; font-weight:600;
  letter-spacing:2.5px; text-transform:uppercase;
  padding:11px 24px; cursor:pointer;
  background:transparent; color:var(--sa-muted);
  border:1px solid var(--sa-line);
  transition:all .25s ease;
}
.sa-pd-page .pd-tab:hover {
  color:var(--sa-ink); border-color:var(--sa-teal-deep);
}
.sa-pd-page .pd-tab.is-active {
  background:var(--sa-ink); color:#fff;
  border-color:var(--sa-ink);
}
/* Hidden cells via filter */
.sa-pd-page .gallery-grid .g-cell.is-hidden { display:none; }

/* Equal 3-column grid — every cell same aspect ratio */
.sa-pd-page .gallery-grid {
  display:grid; grid-template-columns:repeat(3, 1fr); gap:14px;
}
.sa-pd-page .g-cell {
  position:relative; overflow:hidden;
  background:var(--sa-cream);
  aspect-ratio:4/3;
}
.sa-pd-page .g-cell img {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; transition:transform .7s ease;
}
.sa-pd-page .g-cell:hover img { transform:scale(1.04); }

/* FLOOR PLAN */
.sa-pd-page .pd-plan { background:#fff; padding:100px 40px; }
.sa-pd-page .pd-plan-inner {
  max-width:1240px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.4fr;
  gap:56px; align-items:center;
}
.sa-pd-page .pd-plan .eyebrow {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:var(--sa-teal-deep); margin-bottom:14px;
}
.sa-pd-page .pd-plan h3 {
  font-family:var(--sa-fhead);
  font-size:clamp(30px, 4vw, 48px);
  font-weight:400; line-height:1.1; color:var(--sa-ink); margin:0;
}
.sa-pd-page .pd-plan h3 .it { font-style:italic; color:var(--sa-teal); }
.sa-pd-page .pd-plan p {
  font-size:15.5px; line-height:1.8; color:var(--sa-muted); margin-top:18px;
}
.sa-pd-page .pd-plan-right img {
  width:100%; height:auto; display:block;
  background:var(--sa-cream); aspect-ratio:16/10; object-fit:cover;
}
.sa-pd-page .pd-plan-caption {
  margin-top:14px; font-size:11px;
  letter-spacing:2px; text-transform:uppercase; color:var(--sa-muted);
}

/* RELATED PROJECTS — "You might also like" */
.sa-pd-page .pd-related {
  background:var(--sa-cream);
  padding:100px 40px;
}
.sa-pd-page .pd-related-inner {
  max-width:1240px; margin:0 auto;
}
.sa-pd-page .pd-related-head {
  text-align:center; margin-bottom:56px;
}
.sa-pd-page .pd-related-head h2 {
  font-family:var(--sa-fhead);
  font-size:clamp(36px, 5vw, 60px);
  font-weight:400; color:var(--sa-ink);
  margin:0;
}
.sa-pd-page .pd-related-grid {
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:36px 32px;
}
.sa-pd-page .pd-rel-card {
  display:flex; flex-direction:column;
  background:#fff;
  text-decoration:none; color:inherit;
  transition:transform .35s ease, box-shadow .35s ease;
}
.sa-pd-page .pd-rel-card:hover {
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(10,10,10,.06);
}
.sa-pd-page .pd-rel-card .rel-img {
  position:relative; overflow:hidden;
  background:var(--sa-sand); aspect-ratio:4/3;
}
.sa-pd-page .pd-rel-card .rel-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .7s ease;
}
.sa-pd-page .pd-rel-card:hover .rel-img img { transform:scale(1.05); }
.sa-pd-page .pd-rel-card .rel-chip {
  position:absolute; top:14px; left:14px;
  background:rgba(255,255,255,.95); color:var(--sa-ink);
  padding:6px 12px;
  font-family:var(--sa-fbody); font-size:10px;
  letter-spacing:2px; text-transform:uppercase; font-weight:700;
}
.sa-pd-page .pd-rel-card .rel-body { padding:22px 24px 18px; }
.sa-pd-page .pd-rel-card .rel-date {
  font-family:var(--sa-fbody); font-size:11px; letter-spacing:2px;
  text-transform:uppercase; color:var(--sa-muted); margin-bottom:10px;
}
.sa-pd-page .pd-rel-card h4 {
  font-family:var(--sa-fhead);
  font-size:22px; font-weight:500; line-height:1.25;
  color:var(--sa-ink); margin:0 0 14px;
  transition:color .2s;
}
.sa-pd-page .pd-rel-card:hover h4 { color:var(--sa-teal-deep); }
.sa-pd-page .pd-rel-card .rel-foot {
  margin-top:14px; padding-top:14px;
  border-top:1px solid var(--sa-line);
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--sa-fbody); font-size:11px; letter-spacing:2px;
  text-transform:uppercase; color:var(--sa-muted);
}
.sa-pd-page .pd-rel-card .rel-foot .read { color:var(--sa-teal); font-weight:700; }


/* CTA STRIP — always visible at the bottom */
.sa-pd-page .pd-cta {
  position:relative; padding:120px 40px;
  color:#fff; background:#0a0a0a; overflow:hidden;
}
.sa-pd-page .pd-cta::before {
  content:""; position:absolute;
  top:-150px; right:-150px;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, rgba(88,156,157,.2) 0%, rgba(88,156,157,0) 70%);
  pointer-events:none;
}
.sa-pd-page .pd-cta-inner {
  position:relative; z-index:2;
  max-width:1100px; margin:0 auto; text-align:center;
}
.sa-pd-page .pd-cta-eyebrow {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:var(--sa-teal); margin-bottom:18px;
}
.sa-pd-page .pd-cta h2 {
  font-family:var(--sa-fhead);
  font-size:clamp(40px, 6vw, 80px);
  font-weight:400; line-height:1.02;
  color:#fff; letter-spacing:-.005em;
  max-width:880px; margin:0 auto;
}
.sa-pd-page .pd-cta h2 .it { font-style:italic; color:var(--sa-teal); }
.sa-pd-page .pd-cta p {
  margin:24px auto 36px; max-width:580px;
  color:rgba(255,255,255,.8); font-size:16px; line-height:1.75;
}
.sa-pd-page .pd-cta-actions {
  display:inline-flex; gap:32px; flex-wrap:wrap; justify-content:center;
}
/* Buttons styled by site brand CSS (.btn-solid / .btn-marks / .btn-marks.on-dark)
   — plugin does NOT override; it only renders <a class="btn-solid"> / <a class="btn-marks on-dark"> */

@media (max-width:760px){
  .sa-pd-page .pd-cta { padding:80px 20px; }
  .sa-pd-page .pd-cta-actions { flex-direction:column; gap:24px; align-items:center; }
}

/* ====== Floor plan structured stats ====== */
.sa-pd-page .pd-fp-stats {
  margin-top:32px;
  display:grid; grid-template-columns:repeat(2, 1fr); gap:14px;
  padding:24px;
  background:var(--sa-cream);
  border:1px solid var(--sa-line);
}
.sa-pd-page .pd-fp-stats .fp-stat {
  display:flex; align-items:center; gap:12px;
  font-family:var(--sa-fbody); font-size:13.5px;
  color:var(--sa-ink); letter-spacing:.2px;
}
.sa-pd-page .pd-fp-stats .fp-stat .ic {
  width:36px; height:36px; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  background:#fff; color:var(--sa-teal-deep);
  border:1px solid var(--sa-line);
}
.sa-pd-page .pd-fp-stats .fp-stat .ic svg {
  width:18px; height:18px;
}
.sa-pd-page .pd-fp-stats .fp-stat .ft {
  font-family:var(--sa-fhead); font-size:16px; font-weight:500;
}

/* ====== Features grid (16 icons) ====== */
.sa-pd-page .pd-features {
  background:#fff; padding:90px 40px;
}
.sa-pd-page .pd-features-inner { max-width:1240px; margin:0 auto; }
.sa-pd-page .pd-features-head { text-align:center; margin-bottom:48px; }
.sa-pd-page .pd-features-head .eyebrow {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:var(--sa-teal-deep); margin-bottom:14px;
}
.sa-pd-page .pd-features-head h3 {
  font-family:var(--sa-fhead);
  font-size:clamp(30px, 4vw, 48px);
  font-weight:400; color:var(--sa-ink); margin:0;
}
.sa-pd-page .pd-features-head h3 .it { font-style:italic; color:var(--sa-teal); }
.sa-pd-page .pd-features-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
}
.sa-pd-page .pd-feat {
  display:flex; align-items:center; gap:14px;
  padding:18px 20px;
  background:var(--sa-cream);
  border:1px solid transparent;
  font-family:var(--sa-fbody);
  font-size:14px; color:var(--sa-ink);
  letter-spacing:.2px;
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}
.sa-pd-page .pd-feat:hover {
  background:#fff; border-color:var(--sa-teal-deep);
  transform:translateY(-2px);
}
.sa-pd-page .pd-feat .ic {
  width:36px; height:36px; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  background:#fff; color:var(--sa-teal-deep);
}
.sa-pd-page .pd-feat .ic svg { width:20px; height:20px; }

/* ====== Payment progress ====== */
.sa-pd-page .pd-payment {
  background:var(--sa-cream); padding:90px 40px;
}
.sa-pd-page .pd-payment-inner { max-width:980px; margin:0 auto; }
.sa-pd-page .pd-payment-head { text-align:center; margin-bottom:40px; }
.sa-pd-page .pd-payment-head .eyebrow {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:var(--sa-teal-deep); margin-bottom:14px;
}
.sa-pd-page .pd-payment-head h3 {
  font-family:var(--sa-fhead);
  font-size:clamp(30px, 4vw, 48px);
  font-weight:400; color:var(--sa-ink); margin:0;
}
.sa-pd-page .pd-payment-head h3 .it { font-style:italic; color:var(--sa-teal); }
.sa-pd-page .pd-payment-bar {
  background:#fff; padding:28px 30px;
  border:1px solid var(--sa-line);
}
.sa-pd-page .pd-payment-track {
  position:relative; width:100%; height:8px;
  background:var(--sa-line);
  overflow:hidden;
}
.sa-pd-page .pd-payment-fill {
  position:absolute; left:0; top:0; bottom:0;
  background:linear-gradient(90deg, var(--sa-teal-deep), var(--sa-teal));
  transition:width .6s ease;
}
.sa-pd-page .pd-payment-status {
  margin-top:14px;
  font-family:var(--sa-fbody); font-size:11px;
  letter-spacing:2.5px; text-transform:uppercase;
  color:var(--sa-teal-deep); font-weight:700;
}
.sa-pd-page .pd-payment-cells {
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
  margin-top:18px;
}
.sa-pd-page .pd-pay-cell {
  background:#fff; padding:22px 24px;
  border:1px solid var(--sa-line);
  display:flex; flex-direction:column; gap:6px;
}
.sa-pd-page .pd-pay-cell .lbl {
  font-family:var(--sa-fbody); font-size:10.5px;
  letter-spacing:2.5px; text-transform:uppercase; color:var(--sa-muted);
}
.sa-pd-page .pd-pay-cell .val {
  font-family:var(--sa-fhead); font-size:24px; font-weight:500;
  color:var(--sa-ink); letter-spacing:.3px;
}

/* ====== Talk with designer ====== */
.sa-pd-page .pd-designer {
  background:#fff; padding:90px 40px;
}
.sa-pd-page .pd-designer-inner { max-width:880px; margin:0 auto; }
.sa-pd-page .pd-designer-head { text-align:center; margin-bottom:40px; }
.sa-pd-page .pd-designer-head .eyebrow {
  font-family:var(--sa-fbody); font-size:12px; letter-spacing:3px;
  text-transform:uppercase; color:var(--sa-teal-deep); margin-bottom:14px;
}
.sa-pd-page .pd-designer-head h3 {
  font-family:var(--sa-fhead);
  font-size:clamp(30px, 4vw, 48px);
  font-weight:400; color:var(--sa-ink); margin:0;
}
.sa-pd-page .pd-designer-head h3 .it { font-style:italic; color:var(--sa-teal); }
.sa-pd-page .pd-designer-card {
  display:grid; grid-template-columns:auto 1fr; gap:28px;
  align-items:center;
  padding:32px;
  background:var(--sa-cream);
  border:1px solid var(--sa-line);
}
.sa-pd-page .pd-designer-photo {
  width:120px; height:120px; flex-shrink:0;
  background:var(--sa-sand);
  border-radius:50%; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.sa-pd-page .pd-designer-photo img {
  width:100%; height:100%; object-fit:cover;
}
.sa-pd-page .pd-designer-photo .initials {
  font-family:var(--sa-fhead); font-size:48px; font-weight:500;
  color:var(--sa-teal-deep);
}
.sa-pd-page .pd-designer-body .role {
  font-family:var(--sa-fbody); font-size:11px;
  letter-spacing:2.5px; text-transform:uppercase;
  color:var(--sa-teal-deep); font-weight:700; margin-bottom:6px;
}
.sa-pd-page .pd-designer-body .name {
  font-family:var(--sa-fhead); font-size:28px; font-weight:500;
  color:var(--sa-ink); margin:0 0 16px; line-height:1.2;
}

/* RESPONSIVE */
@media (max-width:1024px) {
  .sa-pd-page .pd-story-inner,
  .sa-pd-page .pd-plan-inner { grid-template-columns:1fr; gap:36px; }
  .sa-pd-page .gallery-grid { grid-template-columns:repeat(2, 1fr); }
  .sa-pd-page .pd-related-grid { grid-template-columns:repeat(2, 1fr); }
  .sa-pd-page .pd-features-grid { grid-template-columns:repeat(2, 1fr); }
  .sa-pd-page .pd-fp-stats { grid-template-columns:1fr; }
}
@media (max-width:760px) {
  .sa-pd-page .pd-hero { min-height:70vh; }
  .sa-pd-page .pd-hero-inner { padding:120px 20px 50px; }
  .sa-pd-page .pd-meta { flex-direction:column; gap:8px; }
  .sa-pd-page .pd-meta span { border-right:none; padding:0; }
  .sa-pd-page .pd-story, .sa-pd-page .pd-plan, .sa-pd-page .pd-related,
  .sa-pd-page .pd-features, .sa-pd-page .pd-payment, .sa-pd-page .pd-designer { padding:60px 20px; }
  .sa-pd-page .pd-gallery { padding:0 20px 60px; }
  .sa-pd-page .gallery-grid { grid-template-columns:1fr; gap:10px; }
  .sa-pd-page .pd-related-grid { grid-template-columns:1fr; gap:24px; }
  .sa-pd-page .pd-features-grid { grid-template-columns:1fr; }
  .sa-pd-page .pd-payment-cells { grid-template-columns:1fr; }
  .sa-pd-page .pd-designer-card { grid-template-columns:1fr; text-align:center; }
  .sa-pd-page .pd-designer-photo { margin:0 auto; }
}
