/* ============================================================
   PolishedSites — Editorial Luxe design system  (site.css)
   Flagship model site (polishedsites.fyi)
   ============================================================ */
:root{
  /* palette */
  --cream:#FBF7F1; --cream-2:#EFE3D7; --paper:#FFFFFF;
  --ink:#2A2723; --ink-soft:#6B5F54; --muted:#9A8A7D;
  --rose:#C8A2A0; --coral:#D98263; --coral-deep:#C26A4A;
  --line:rgba(42,39,35,.12);
  /* type */
  --display:"Fraunces",Georgia,serif;
  --body:"Outfit",system-ui,sans-serif;
  /* rhythm */
  --pad:clamp(1.4rem,5vw,7rem);
  --sec:clamp(3.5rem,9vw,8rem);
  --radius:16px;
  --shadow:0 14px 40px rgba(42,39,35,.10);
  --shadow-soft:0 6px 20px rgba(42,39,35,.06);
  --ease:cubic-bezier(.2,.8,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{background:var(--cream);color:var(--ink);font-family:var(--body);font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--display);font-weight:400;line-height:1.04;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5.4vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.2rem,1.8vw,1.5rem)}
.eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.3em;color:var(--coral);font-weight:600}
.label{font-size:.7rem;text-transform:uppercase;letter-spacing:.24em;color:var(--muted);font-weight:500}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-soft);max-width:52ch}
section{padding:var(--sec) var(--pad)}
.wrap{max-width:1180px;margin:0 auto}
::selection{background:var(--coral);color:var(--cream)}
:focus-visible{outline:2px solid var(--coral);outline-offset:3px;border-radius:3px}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--body);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;padding:1.05em 2.1em;border-radius:100px;cursor:pointer;border:1px solid transparent;transition:transform .35s var(--ease),background .35s,color .35s,border-color .35s}
.btn--solid{background:var(--ink);color:var(--cream)}
.btn--solid:hover{transform:translateY(-3px);background:var(--coral-deep)}
.btn--ghost{border-color:var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--coral);color:var(--coral)}

/* ---- nav ---- */
header.nav{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;padding:1.05rem var(--pad);background:rgba(251,247,241,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
header.nav.scrolled{border-bottom-color:var(--line)}
.brand{font-family:var(--display);font-size:1.32rem;display:flex;align-items:center;gap:.1em}
.brand b{font-weight:500}.brand .dot{color:var(--coral)}
.nav-links{display:flex;gap:2rem;align-items:center;font-size:.88rem}
.nav-links a{color:var(--ink-soft);transition:color .25s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.btn{color:var(--cream)}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--ink)}
@media(max-width:860px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);flex-direction:column;justify-content:center;gap:1.6rem;background:var(--cream);transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:var(--shadow)}
  .nav-links.open{transform:none}
  .nav-links a.btn{color:var(--cream)}
  .nav-toggle{display:block;z-index:61}
}

/* ---- hairline rule + reveal ---- */
.rule{height:1px;background:var(--line);border:0;margin:0}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---- hero ---- */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center;min-height:88vh;padding-top:clamp(2rem,6vw,4rem);position:relative}
.hero-copy h1{margin:.5rem 0 1rem}
.hero-cta{margin-top:1.8rem;display:flex;gap:.7rem;flex-wrap:wrap}
.hero-demo{position:relative}
.hero-demo::after{content:"";position:absolute;inset:-12% -10% auto auto;width:62%;height:62%;background:radial-gradient(closest-side,rgba(217,130,99,.20),transparent);z-index:-1;filter:blur(26px)}
.hero-demo::before{content:"";position:absolute;inset:auto auto -14% -12%;width:55%;height:55%;background:radial-gradient(closest-side,rgba(200,162,160,.22),transparent);z-index:-1;filter:blur(26px)}
@media(max-width:860px){.hero{grid-template-columns:1fr;min-height:auto}.hero-demo{order:2}}

/* ---- inline-mounted assistant (flagship hero) ---- */
#ps-assistant.psa-inline{position:static;width:100%}
#ps-assistant.psa-inline .psa-launcher{display:none}
/* note: the panel's root element is a <section>, so the global section{padding}
   rule would inject huge padding into it — reset it here */
#ps-assistant.psa-inline .psa-panel{position:static;opacity:1;visibility:visible;pointer-events:auto;transform:none;width:100%;max-width:none;padding:0;height:auto;min-height:440px;max-height:min(72vh,620px);box-shadow:var(--shadow);border-radius:var(--radius)}
#ps-assistant.psa-inline .psa-close{display:none}
/* roomier message stream + a clearly separated reply zone so chips
   never crowd or merge with the conversation */
#ps-assistant.psa-inline .psa-stream{padding:20px 18px;gap:12px}
#ps-assistant.psa-inline .psa-choices{justify-content:flex-start;gap:9px;padding:14px 16px;border-top:1px solid var(--psa-line);background:var(--psa-panel)}
#ps-assistant.psa-inline .psa-dock{padding:14px 16px}

/* ---- trust strip ---- */
.trust{background:var(--cream-2)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,3vw,2.4rem)}
.trust-grid p{color:var(--ink-soft);font-size:.95rem;margin-top:.3rem}

/* ---- differentiator ---- */
.differ-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.differ-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.6rem 1.8rem;display:flex;flex-direction:column;gap:.4rem}
.differ-card p{color:var(--ink-soft);font-size:.95rem}
.differ-card strong{color:var(--ink)}
.lead-chip{align-self:flex-start;background:var(--coral);color:#fff;font-size:.72rem;border-radius:30px;padding:4px 11px;margin-bottom:.4rem}

/* ---- featured industries ---- */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(1rem,3vw,2rem);margin-top:1.6rem}
.feat-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-soft);transition:transform .35s var(--ease),box-shadow .35s;display:block}
.feat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feat-niche{font-family:var(--display);font-size:1.4rem;display:block}
.feat-card p{color:var(--ink-soft);font-size:.95rem;margin:.4rem 0 1rem}
.feat-go{color:var(--coral);font-weight:500;font-size:.9rem}

/* ---- how it works ---- */
.how-steps{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,3vw,2.4rem);margin-top:1.8rem}
.how-n{font-family:var(--display);font-size:2.2rem;color:var(--rose)}
.how-steps h3{margin:.3rem 0}
.how-steps p{color:var(--ink-soft)}

/* ---- pricing ---- */
.pricing{background:var(--cream-2)}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,3vw,2rem);margin-top:1.8rem;align-items:stretch}
.price-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;display:flex;flex-direction:column;gap:.6rem;box-shadow:var(--shadow-soft)}
.price-card--feature{border-color:var(--coral);box-shadow:var(--shadow);transform:translateY(-6px)}
.price{font-family:var(--display);font-size:1.1rem;color:var(--ink-soft)}
.price strong{font-size:2.1rem;color:var(--ink)}
.price-card ul{list-style:none;display:flex;flex-direction:column;gap:.45rem;font-size:.92rem;color:var(--ink-soft);margin:.4rem 0 1rem}
.price-card ul li::before{content:"✦ ";color:var(--coral)}
.price-card .btn{margin-top:auto;justify-content:center}

/* ---- done-for-you band ---- */
.dfy-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;background:var(--ink);color:var(--cream);border-radius:var(--radius);padding:clamp(1.8rem,4vw,3rem)}
.dfy-inner h2{color:var(--cream)}
.dfy-inner .lead{color:var(--cream);opacity:.85}
.dfy-inner .btn--solid{background:var(--coral);color:#fff}
.dfy-inner .btn--solid:hover{background:var(--cream);color:var(--ink)}

/* ---- about ---- */
.about-grid{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.4rem,4vw,3rem);align-items:center}
.about-photo{border-radius:50%;object-fit:cover;box-shadow:var(--shadow);width:220px;height:220px}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
#contact-form{display:flex;flex-direction:column;gap:.7rem}
#contact-form input,#contact-form textarea{font-family:var(--body);font-size:1rem;padding:.85em 1em;border:1px solid var(--line);border-radius:12px;background:var(--paper);color:var(--ink);width:100%}
#contact-form input:focus,#contact-form textarea:focus{outline:2px solid var(--coral);outline-offset:1px}
.form-status{font-size:.9rem;color:var(--ink-soft);min-height:1.2em}

/* ---- footer ---- */
footer.site{background:var(--ink);color:var(--cream);padding:var(--sec) var(--pad)}
footer.site a{color:var(--cream);opacity:.8;transition:opacity .25s}
footer.site a:hover{opacity:1}
.foot-grid{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.foot-links{display:flex;gap:1.5rem;font-size:.9rem}
.foot-fine{opacity:.7;font-size:.82rem;width:100%}

/* ---- industries page ---- */
.ind-intro{padding-bottom:0}
.ind-stage{padding-top:clamp(2rem,5vw,3rem)}
.ind-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.6rem}
.ind-tab{font-family:var(--body);font-size:.85rem;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);border-radius:100px;padding:.55em 1.1em;cursor:pointer;transition:.25s}
.ind-tab:hover{color:var(--ink);border-color:var(--rose)}
.ind-tab[aria-selected="true"]{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.ind-view{display:grid;grid-template-columns:1fr 320px;gap:clamp(1.4rem,3vw,2.4rem);align-items:start}
.ind-device{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.ind-chrome{background:var(--cream-2);padding:.55rem .8rem;display:flex;align-items:center;gap:.35rem}
.ind-chrome i{width:9px;height:9px;border-radius:50%;background:#cdbfb0;display:inline-block}
.ind-url{margin-left:.6rem;background:var(--paper);border-radius:30px;font-size:.66rem;color:var(--muted);padding:2px 10px}
.ind-live{margin-left:auto;font-size:.62rem;color:#3a9e57;font-weight:600}
.ind-frame{width:100%;height:clamp(440px,68vh,720px);border:0;display:block;background:var(--cream)}
.ind-info{position:sticky;top:90px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-soft)}
.ind-name{margin-bottom:.1rem}
.ind-price{font-family:var(--display);color:var(--ink-soft);margin:.2rem 0 .8rem}
.ind-price strong{font-size:1.9rem;color:var(--ink)}
.ind-bullets{list-style:none;display:flex;flex-direction:column;gap:.45rem;font-size:.92rem;color:var(--ink-soft);margin-bottom:1.2rem}
.ind-bullets li::before{content:"✦ ";color:var(--coral)}
.ind-actions{display:flex;flex-direction:column;gap:.6rem}
.ind-actions .btn{justify-content:center}
.ind-learn{margin-top:.9rem;font-size:.86rem;text-align:center}
.ind-learn a{color:var(--coral);font-weight:500}
.ind-learn a:hover{color:var(--coral-deep)}

/* ---- responsive collapses ---- */
@media(max-width:860px){
  .trust-grid{grid-template-columns:1fr 1fr}
  .differ-grid,.feat-grid,.how-steps,.price-grid,.contact-grid{grid-template-columns:1fr}
  .price-card--feature{transform:none}
  .dfy-inner{flex-direction:column;text-align:center}
  .about-grid{grid-template-columns:1fr;text-align:center;justify-items:center}
  .ind-view{grid-template-columns:1fr}
  .ind-info{position:static}
  .ind-frame{height:60vh}
}

/* ---- SEO landing pages (website-templates/) ---- */
.lp-hero{padding-top:clamp(2.4rem,6vw,4.5rem);padding-bottom:clamp(2rem,4vw,3rem)}
.lp-hero h1{margin:.6rem 0 1.2rem;max-width:18ch}
.lp-hero .lead{margin-bottom:1rem}
.lp-hero .eyebrow a{color:var(--coral)}
.lp-price{font-family:var(--display);font-size:1.05rem;color:var(--ink-soft);margin:1.4rem 0 .4rem}
.lp-price strong{font-size:1.7rem;color:var(--ink)}
.lp-cta{margin-top:1rem;display:flex;gap:.7rem;flex-wrap:wrap}
.lp-builtin{margin-top:1.1rem;font-size:.9rem;color:var(--ink-soft)}
.lp-section-h{margin:.3rem 0 1.6rem}
.lp-features{background:var(--cream-2)}
.lp-feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,3vw,2rem)}
.lp-feature{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.7rem;box-shadow:var(--shadow-soft)}
.lp-feature h2{font-size:clamp(1.15rem,1.7vw,1.4rem);margin-bottom:.5rem}
.lp-feature p{color:var(--ink-soft);font-size:.97rem}
.lp-forwho-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.lp-forwho-inner .lead{margin-top:.4rem}
.lp-faq-list{display:flex;flex-direction:column;gap:.7rem;max-width:820px}
.lp-faq-item{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:.2rem .4rem}
.lp-faq-item summary{cursor:pointer;font-weight:500;font-size:1.02rem;color:var(--ink);padding:1rem 1.1rem;list-style:none;position:relative}
.lp-faq-item summary::-webkit-details-marker{display:none}
.lp-faq-item summary::after{content:"+";position:absolute;right:1.1rem;top:50%;transform:translateY(-50%);color:var(--coral);font-size:1.3rem;line-height:1}
.lp-faq-item[open] summary::after{content:"−"}
.lp-faq-item p{padding:0 1.1rem 1.1rem;color:var(--ink-soft);font-size:.96rem}
.lp-final{background:var(--cream-2)}
.lp-final-inner{text-align:center;max-width:680px;margin:0 auto}
.lp-final-inner .lead{margin:.6rem auto 0}
.lp-final-inner .lp-cta{justify-content:center}
.lp-hub .lp-group{margin-bottom:clamp(2rem,5vw,3.4rem)}
.lp-group-h{font-size:clamp(1.5rem,2.4vw,2rem);margin-bottom:1.1rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}
.lp-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.9rem}
.lp-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.3rem;box-shadow:var(--shadow-soft);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;display:flex;flex-direction:column;gap:.25rem}
.lp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--rose)}
.lp-card-name{font-family:var(--display);font-size:1.18rem;color:var(--ink)}
.lp-card-meta{font-size:.8rem;color:var(--muted)}
@media(max-width:860px){
  .lp-feature-grid{grid-template-columns:1fr}
  .lp-forwho-inner{flex-direction:column;align-items:flex-start}
}

/* ---- reduced motion ---- */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.feat-card:hover,.lp-card:hover{transform:none}
}
