/* ============================================================
   sugar4.me · Pink Press — article system for public content pages
   Complements home.css (reuses --vars, .shell, .kicker, .btn, .faq, .closer).
   ============================================================ */

/* Title band */
.article-band { padding: clamp(2.6rem, 6vw, 4.6rem) 0 clamp(1.6rem, 3vw, 2.4rem); border-bottom: 1px solid var(--line); position: relative; }
.article-band .eyebrow { margin-bottom: 1.1rem; }
.article-h1 { font-family: var(--font-display); font-weight: 300; font-size: clamp(2.5rem, 5.6vw, 4.2rem); line-height: 1.08; letter-spacing: -0.02em; max-width: 20ch; }
.article-h1 .hl { color: var(--pink); }
.article-sub { color: var(--muted); max-width: 62ch; margin: 1.1rem 0 0; font-size: clamp(1.05rem, 1.3vw, 1.2rem); }

/* Body */
.article { padding: clamp(2.5rem, 5vw, 4rem) 0; }
.article .prose { max-width: 72ch; color: var(--text); }
.article .prose > p { margin: 0 0 1.15rem; }
.article .prose .lead-p { font-size: clamp(1.14rem, 1.6vw, 1.4rem); color: var(--text); font-family: var(--font); font-weight: 400; line-height: 1.7; }
.article .prose h2 { font-family: var(--font-head); font-weight: 600; font-size: clamp(1.5rem, 3vw, 2.1rem); letter-spacing: -0.015em; line-height: 1.12; margin: 2.6rem 0 0.8rem; }
.article .prose h3 { font-family: var(--font-head); font-weight: 600; font-size: 1.25rem; letter-spacing: -0.01em; margin: 1.9rem 0 0.4rem; }
.article .prose ul, .article .prose ol { margin: 0 0 1.25rem; padding-left: 1.3rem; max-width: 72ch; }
.article .prose li { margin-bottom: 0.45rem; color: var(--text); }
.article .prose li::marker { color: var(--pink); }
.article .prose a { color: var(--pink-deep); border-bottom: 1px solid var(--gold); transition: color .3s var(--ease), border-color .3s var(--ease); }
.article .prose a:hover { color: var(--pink); border-color: var(--pink); }
.article .prose strong { color: var(--ink); font-weight: 600; }
.article .prose blockquote { margin: 2rem 0; padding: 0.3rem 0 0.3rem 1.7rem; border-left: 2px solid var(--gold); color: var(--ink); font-family: var(--font-display); font-style: italic; font-weight: 300; font-size: clamp(1.3rem, 2.2vw, 1.7rem); line-height: 1.45; }

/* Press FAQ on an article */
.article-faq { max-width: 820px; }
.article-faq .faq { margin-top: 0.5rem; }

/* City hub — card grid */
.city-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin: 0.5rem 0 1rem; border: 1px solid var(--line); }
.city-card { position: relative; display: flex; flex-direction: column; gap: 0.4rem; padding: 1.6rem 1.5rem; text-decoration: none;
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--paper); transition: background-color .3s var(--ease), transform .3s var(--ease); }
.city-card:nth-child(3n) { border-right: 0; }
.city-card h3 { font-family: var(--font-head); font-weight: 600; font-size: 1.3rem; color: var(--ink); margin: 0; letter-spacing: -0.015em; }
.city-card p { color: var(--muted); font-size: 0.92rem; margin: 0; }
.city-card .city-go { font-family: var(--font-head); text-transform: uppercase; letter-spacing: 0.16em; font-size: 0.68rem; font-weight: 600; color: var(--gold-deep); margin-top: 0.35rem; }
.city-card:hover { background: var(--ink); transform: translateY(-2px); }
.city-card:hover h3, .city-card:hover p { color: #fff; }
.city-card:hover .city-go { color: var(--gold); }
@media (max-width: 760px) {
  .city-grid { grid-template-columns: repeat(2, 1fr); }
  .city-card:nth-child(3n) { border-right: 1px solid var(--line); }
  .city-card:nth-child(2n) { border-right: 0; }
}
@media (max-width: 460px) {
  .city-grid { grid-template-columns: 1fr; }
  .city-card { border-right: 0 !important; }
}

/* Contact / generic action row */
.action-row { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: 1.6rem; }

/* ---- Contact / Service-desk form (Pink Press) ---- */
.s4form-wrap { max-width: 760px; }
.s4form { border: 1px solid var(--line); border-top: 2px solid var(--gold); border-radius: 20px; overflow: hidden; padding: clamp(1.5rem, 4vw, 2.6rem); background: var(--paper);
  box-shadow: 0 30px 60px -42px rgba(26,20,23,0.45); margin: 0.4rem 0 1.2rem; }
.s4form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.3rem; }
.s4form-row { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: 1rem; }
.s4form label { font-family: var(--font-head); font-weight: 600; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.16em; color: var(--ink); }
.s4form-control { font-family: var(--font); font-size: 1rem; color: var(--text); background: #fff;
  border: 1px solid var(--line); border-radius: 12px; padding: 0.85rem 1rem; width: 100%; transition: border-color .3s var(--ease), box-shadow .3s var(--ease); }
.s4form-control:focus { outline: none; border-color: var(--pink); box-shadow: 0 0 0 3px rgba(210,68,123,0.16); }
.s4form-textarea { resize: vertical; min-height: 140px; }
select.s4form-control { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%2319131c' stroke-width='2'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 0.9rem center; padding-right: 2.4rem; }
.s4form .validation-message { color: var(--pink-deep); font-size: 0.82rem; font-weight: 600; }
.s4form-error { color: #b00020; font-weight: 600; border: 1.5px solid #b00020; padding: 0.7rem 0.9rem; margin-bottom: 1rem; }
.s4form-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; margin-top: 0.4rem; }
.s4form-actions .btn[disabled] { opacity: 0.6; cursor: progress; }
.s4form-fine { color: var(--muted); font-size: 0.82rem; }
.s4form-aside { margin-top: 1.4rem; }

.s4form-success { border: 1px solid var(--line); border-top: 2px solid var(--gold); border-radius: 20px; background: var(--paper-2);
  padding: clamp(1.8rem, 5vw, 2.8rem); text-align: center; }
.s4form-success-badge { width: 56px; height: 56px; margin: 0 auto 1rem; display: grid; place-items: center;
  background: var(--ink); color: var(--gold); font-size: 1.6rem; font-weight: 600; }
.s4form-success h2 { font-family: var(--font-head); font-weight: 500; font-size: clamp(1.5rem, 3vw, 2rem); margin: 0 0 0.5rem; }
.s4form-success p { color: var(--text); max-width: 48ch; margin: 0 auto 1.2rem; }

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

/* Closing CTA reuses .closer from home.css */

/* Prose tables */
.article .prose table { width: 100%; border-collapse: collapse; margin: 1.2rem 0 1.6rem; font-size: 0.96rem; }
.article .prose th, .article .prose td { text-align: left; padding: 0.7rem 0.9rem; border: 1px solid var(--line); vertical-align: top; }
.article .prose tbody tr:nth-child(odd) { background: var(--paper-2); }
.article .prose th { font-family: var(--font-head); font-weight: 600; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink); }
.article .prose td:first-child { font-family: var(--font-head); font-weight: 600; white-space: nowrap; color: var(--ink); }

/* Mobile (primary traffic) */
@media (max-width: 600px) {
  .article .prose { max-width: 100%; }
  .article .prose blockquote { font-size: 1.08rem; }
  /* let wide tables scroll instead of breaking the layout */
  .article .prose table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; }
  .article-faq .faq summary { padding-right: 2.4rem; }
}
