/* ============================================================
   Floory content / SEO pages (about, hybrid-flooring-perth, technical
   specifications, warranty, faq, reviews, projects). Used ONLY by the new
   crawlable pages. Reuses tokens.css + base.css. Does not affect existing pages.
   ============================================================ */
.cp { color: var(--ink-700); }
.cp a { color: var(--orange); }

/* Light solid header */
.cp-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.94); backdrop-filter: saturate(180%) blur(10px); border-bottom: 1px solid var(--line); }
.cp-header__in { max-width: var(--maxw); margin-inline: auto; padding: 0.7rem var(--gutter); display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.cp-header__brand { display: inline-flex; }
.cp-header__brand img { height: 26px; width: auto; }
.cp-header__cta { display: inline-flex; gap: 0.5rem; }
.cp-header__cta .btn { min-height: 42px; }

/* Hero band */
.cp-hero { background: linear-gradient(180deg, var(--cream) 0%, var(--white) 100%); border-bottom: 1px solid var(--cream-deep); }
.cp-hero__in { max-width: var(--maxw); margin-inline: auto; padding: var(--sp-6) var(--gutter) var(--sp-5); }
.cp-eyebrow { font-weight: 700; font-size: 0.72rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--orange); }
.cp h1 { font-family: var(--font-brand, inherit); font-size: clamp(1.9rem, 4.5vw, 2.8rem); letter-spacing: -0.025em; line-height: 1.08; color: var(--black); margin-top: 0.5rem; text-wrap: balance; }
.cp-hero__lead { font-size: 1.08rem; line-height: 1.6; color: var(--ink-700); margin-top: var(--sp-3); max-width: 60ch; }
.cp-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-4); }

/* Body */
.cp-main { max-width: var(--maxw); margin-inline: auto; padding: var(--sp-6) var(--gutter) var(--sp-7); }
.cp-section { margin-top: var(--sp-6); }
.cp-section:first-child { margin-top: 0; }
.cp h2 { font-size: clamp(1.3rem, 2.6vw, 1.7rem); letter-spacing: -0.02em; color: var(--black); }
.cp h3 { font-size: 1.05rem; color: var(--black); margin-top: var(--sp-4); }
.cp p { font-size: 1rem; line-height: 1.65; color: var(--ink-700); margin-top: var(--sp-2); max-width: 70ch; }
.cp ul, .cp ol { margin-top: var(--sp-2); padding-left: 1.3rem; display: grid; gap: 0.4rem; max-width: 70ch; }
.cp li { font-size: 1rem; line-height: 1.55; color: var(--ink-700); }

/* Cards */
.cp-cards { display: grid; gap: var(--sp-3); margin-top: var(--sp-4); }
@media (min-width: 700px) { .cp-cards { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .cp-cards--3 { grid-template-columns: 1fr 1fr 1fr; } }
.cp-card { background: var(--white); border: 1px solid var(--cream-deep); border-radius: var(--radius-lg); padding: var(--sp-4); box-shadow: var(--shadow-sm); }
.cp-card h3 { margin-top: 0; font-size: 1.05rem; font-weight: 700; }
.cp-card p { font-size: 0.95rem; }

/* Spec table */
.cp-spec { margin-top: var(--sp-4); border: 1px solid var(--cream-deep); border-radius: var(--radius-lg); overflow: hidden; background: var(--white); }
.cp-spec__row { display: flex; justify-content: space-between; gap: var(--sp-3); padding: 0.7rem 1rem; border-bottom: 1px solid #f4ece7; }
.cp-spec__row:last-child { border-bottom: 0; }
.cp-spec__k { color: var(--ink-500); font-size: 0.95rem; }
.cp-spec__v { color: var(--black); font-weight: 600; font-size: 0.95rem; text-align: right; }

/* FAQ accordion (details/summary, crawlable without JS) */
.cp-faq { margin-top: var(--sp-4); display: grid; gap: 0.6rem; }
.cp-faq details { background: var(--white); border: 1px solid var(--cream-deep); border-radius: var(--radius); padding: 0.2rem 0.2rem; }
.cp-faq summary { cursor: pointer; list-style: none; padding: 0.85rem 1rem; font-weight: 700; color: var(--black); font-size: 1rem; }
.cp-faq summary::-webkit-details-marker { display: none; }
.cp-faq details[open] summary { color: var(--orange); }
.cp-faq__a { padding: 0 1rem 1rem; }
.cp-faq__a p { margin-top: 0; }

/* Reviews */
.cp-reviews { display: grid; gap: var(--sp-3); margin-top: var(--sp-4); }
@media (min-width: 760px) { .cp-reviews { grid-template-columns: 1fr 1fr; } }
.cp-review { background: var(--white); border: 1px solid var(--cream-deep); border-radius: var(--radius-lg); padding: var(--sp-4); box-shadow: var(--shadow-sm); }
.cp-review__text { font-size: 0.98rem; line-height: 1.55; color: var(--black); }
.cp-review__by { margin-top: 0.7rem; font-size: 0.85rem; color: var(--ink-500); font-weight: 600; }

/* Empty state */
.cp-empty { margin-top: var(--sp-4); background: var(--cream); border: 1px dashed var(--cream-deep); border-radius: var(--radius-lg); padding: var(--sp-5); text-align: center; color: var(--ink-700); }

/* CTA band */
.cp-cta { margin-top: var(--sp-6); background: var(--black); color: #fff; border-radius: var(--radius-lg); padding: var(--sp-5); display: grid; gap: var(--sp-3); }
.cp-cta h2 { color: #fff; }
.cp-cta p { color: rgba(255,255,255,0.78); }
.cp-cta__row { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.cp-cta .btn--ghost { color: #fff; border-color: rgba(255,255,255,0.5); background: rgba(255,255,255,0.08); }

.cp-disclaimer { margin-top: var(--sp-4); font-size: 0.85rem; color: var(--ink-500); line-height: 1.5; }
.cp-verify { margin-top: var(--sp-3); font-size: 0.82rem; color: var(--ink-500); background: var(--cream); border-left: 3px solid var(--orange); border-radius: var(--radius); padding: 0.7rem 0.9rem; }

/* Footer */
.cp-footer { background: var(--black); color: rgba(255,255,255,0.78); margin-top: var(--sp-6); }
.cp-footer__in { max-width: var(--maxw); margin-inline: auto; padding: var(--sp-6) var(--gutter) var(--sp-4); display: grid; gap: var(--sp-4); }
@media (min-width: 760px) { .cp-footer__in { grid-template-columns: 1.4fr 1fr 1fr; } }
.cp-footer h3 { color: rgba(255,255,255,0.55); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 0.6rem; }
.cp-footer a { color: rgba(255,255,255,0.82); display: block; padding: 0.2rem 0; }
.cp-footer a:hover { color: var(--orange); }
.cp-footer__col { display: flex; flex-direction: column; }
.cp-footer__bar { border-top: 1px solid rgba(255,255,255,0.12); max-width: var(--maxw); margin-inline: auto; padding: var(--sp-3) var(--gutter); font-size: 0.8rem; color: rgba(255,255,255,0.45); display: flex; flex-wrap: wrap; gap: 0.4rem 1rem; }
