/* Pretty Suite — Marketing Site UI Kit styles
   Consumes tokens from ../../colors_and_type.css */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-weight:500;color:var(--ps-navy);background:var(--ps-off-white);-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 32px}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ps-deep-green)}
.display{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;line-height:1.02;color:var(--ps-navy)}
h1,h2,h3{margin:0}
.midline{color:var(--ps-lime-600)}

/* ---------- Buttons ---------- */
.btn{font-family:var(--font-body);font-weight:600;font-size:16px;border-radius:11px;padding:13px 24px;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:9px;transition:all var(--dur-fast) var(--ease-out);white-space:nowrap;line-height:1}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--ps-deep-green);color:#fff;box-shadow:var(--shadow-xs)}
.btn-primary:hover{background:var(--ps-deep-green-hover);box-shadow:var(--shadow-green);transform:translateY(-1px)}
.btn-primary:active{background:var(--ps-deep-green-700);transform:scale(.985)}
.btn-lime{background:var(--ps-lime);color:var(--ps-deep-green)}
.btn-lime:hover{background:var(--ps-lime-600)}
.btn-lime:active{transform:scale(.985)}
.btn-ghost{background:transparent;color:var(--ps-deep-green);border:1.5px solid var(--ps-deep-green)}
.btn-ghost:hover{background:var(--ps-green-tint)}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost.on-dark:hover{background:rgba(255,255,255,.12)}
.btn-sm{font-size:14px;padding:10px 18px}
.btn-lg{font-size:17px;padding:16px 30px}
.btn-full{width:100%;justify-content:center}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:50;background:rgba(247,248,246,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:box-shadow var(--dur),border-color var(--dur),background var(--dur)}
.header.scrolled{background:rgba(255,255,255,.9);border-color:var(--ps-grey-200);box-shadow:var(--shadow-sm)}
.header .bar{display:flex;align-items:center;gap:28px;height:74px}
.header .logo{height:30px}
.nav{display:flex;gap:28px;margin-left:8px}
.nav a{font-size:15px;font-weight:600;color:var(--ps-light-navy);position:relative;padding:4px 0;transition:color var(--dur-fast)}
.nav a:hover{color:var(--ps-deep-green)}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--ps-deep-green);transition:right var(--dur) var(--ease-out)}
.nav a:hover::after{right:0}
.header .right{margin-left:auto;display:flex;align-items:center;gap:18px}
.phone-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--ps-deep-green)}
.phone-link svg{width:17px;height:17px}

/* ---------- Hero ---------- */
.hero{padding:72px 0 84px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:62px;margin:18px 0 22px}
.hero .lead{font-size:20px;line-height:1.6;color:var(--ps-light-navy);max-width:520px;margin:0 0 30px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.trust{display:flex;align-items:center;gap:14px;margin-top:18px;color:var(--ps-light-navy);font-size:14px;font-weight:600}
.stars{display:flex;gap:2px;color:#E0A93B}
.stars svg{width:17px;height:17px;fill:#E0A93B;stroke:none}
.hero-media{position:relative}
.hero-media image-slot,.hero-media .ph{width:100%;height:460px;border-radius:20px;box-shadow:var(--shadow-lg)}
.badge-float{position:absolute;left:-22px;bottom:34px;background:#fff;border-radius:14px;box-shadow:var(--shadow-md);padding:16px 20px;display:flex;align-items:center;gap:13px}
.badge-float .mono{width:42px;height:42px}
.badge-float b{display:block;font-family:var(--font-display);font-weight:900;font-size:22px;color:var(--ps-deep-green);line-height:1}
.badge-float span{font-size:12.5px;color:var(--ps-light-navy);font-weight:600}

/* Hero watermark — section level, crops left + bottom */
.hero{position:relative;overflow:hidden}
.hero-copy{position:relative}
.hero-wm{position:absolute;width:860px;height:860px;object-fit:contain;opacity:.11;top:auto;bottom:-180px;left:-220px;z-index:0;pointer-events:none}
.hero-copy > *{position:relative;z-index:1}

/* ---------- Trust strip ---------- */
.strip{background:var(--ps-deep-green);color:#fff}
.strip .row{display:flex;justify-content:space-between;gap:20px;padding:22px 0;flex-wrap:wrap}
.strip .item{display:flex;align-items:center;gap:11px;font-weight:600;font-size:15px}
.strip .item svg{width:20px;height:20px;color:var(--ps-lime)}

/* ---------- Section ---------- */
.section{padding:88px 0}
.section-head{max-width:640px;margin-bottom:44px}
.section-head h2{font-size:42px;margin:14px 0 0}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- Services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:#fff;border:1px solid var(--ps-grey-200);border-radius:14px;padding:28px;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur);cursor:default}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.svc .ic{width:52px;height:52px;border-radius:12px;background:var(--ps-green-tint);display:flex;align-items:center;justify-content:center;color:var(--ps-deep-green);margin-bottom:18px}
.svc .ic svg{width:26px;height:26px}
.svc h3{font-size:21px;font-weight:700;margin-bottom:9px}
.svc p{font-size:15px;line-height:1.55;color:var(--ps-light-navy);margin:0}
.svc .more{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-weight:700;font-size:14px;color:var(--ps-deep-green)}
.svc .more svg{width:16px;height:16px;transition:transform var(--dur-fast)}
.svc:hover .more svg{transform:translateX(3px)}
.svc.feat{background:var(--ps-deep-green);border-color:var(--ps-deep-green);position:relative;overflow:hidden}
.svc.feat h3{color:#fff}
.svc.feat p{color:#cfe0d9}
.svc.feat .ic{background:rgba(255,255,255,.12);color:var(--ps-lime)}
.svc.feat .more{color:var(--ps-lime)}
.svc.feat .tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ps-deep-green);background:var(--ps-lime);padding:4px 10px;border-radius:999px;margin-bottom:14px}
.svc.feat .wm{position:absolute;right:-30px;bottom:-30px;width:150px;opacity:.10}

/* ---------- Gallery ---------- */
.gallery{background:#fff}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px}
.filter{font-family:var(--font-body);font-weight:600;font-size:14px;padding:9px 18px;border-radius:999px;border:1.5px solid var(--ps-grey-200);background:#fff;color:var(--ps-light-navy);cursor:pointer;transition:all var(--dur-fast)}
.filter:hover{border-color:var(--ps-deep-green);color:var(--ps-deep-green)}
.filter.active{background:var(--ps-deep-green);border-color:var(--ps-deep-green);color:#fff}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gal-item{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-sm)}
.gal-item image-slot,.gal-item .ph{width:100%;height:100%}
.gal-cap{position:absolute;left:0;right:0;bottom:0;padding:18px 16px 14px;background:linear-gradient(to top,rgba(1,73,54,.82),rgba(1,73,54,0));color:#fff;display:flex;justify-content:space-between;align-items:flex-end}
.gal-cap b{font-size:15px;font-weight:700}
.gal-cap span{font-size:12px;font-weight:600;color:var(--ps-lime);text-transform:uppercase;letter-spacing:.06em}

/* photo placeholder fallback */
.ph{background:var(--ps-green-tint);display:flex;align-items:center;justify-content:center;color:var(--ps-deep-green);position:relative}
.ph img{width:64px;opacity:.22}

/* ---------- Process band ---------- */
.process{background:var(--ps-navy);color:#fff;position:relative;overflow:hidden}
.proc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative;z-index:1}
.proc .num{font-family:var(--font-display);font-weight:900;font-size:20px;width:46px;height:46px;border-radius:50%;background:var(--ps-lime);color:var(--ps-deep-green);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.proc h3{font-size:22px;font-weight:700;margin-bottom:8px}
.proc p{font-size:15px;line-height:1.55;color:#aeb6c2;margin:0}
.process .wm{position:absolute;right:-60px;top:-40px;width:300px;opacity:.06;z-index:0}

/* ---------- Testimonials ---------- */
.testi-section{background:var(--ps-green-tint)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{background:#fff;border:1px solid var(--ps-grey-200);border-radius:16px;padding:28px;margin:0;box-shadow:var(--shadow-sm)}
.t-stars{display:flex;gap:3px;color:#E0A93B;margin-bottom:16px}
.t-stars svg{width:18px;height:18px;fill:#E0A93B;stroke:none}
.testi blockquote{margin:0 0 20px;font-size:17px;line-height:1.55;font-weight:600;color:var(--ps-navy)}
.testi figcaption b{display:block;font-size:15px;font-weight:700;color:var(--ps-deep-green)}
.testi figcaption span{font-size:13px;color:var(--ps-light-navy);font-weight:500}

/* ---------- Quote ---------- */
.quote-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:start}
.quote h2{font-size:40px;margin:14px 0 18px}
.quote .lead{font-size:18px;line-height:1.6;color:var(--ps-light-navy);margin:0 0 28px}
.contact-list{display:flex;flex-direction:column;gap:18px}
.contact-list .ci{display:flex;gap:14px;align-items:flex-start}
.contact-list .ci .ic{width:42px;height:42px;border-radius:10px;background:var(--ps-green-tint);color:var(--ps-deep-green);display:flex;align-items:center;justify-content:center;flex:none}
.contact-list .ci .ic svg{width:19px;height:19px}
.contact-list .ci b{display:block;font-size:15px;font-weight:700;color:var(--ps-navy)}
.contact-list .ci span{font-size:14px;color:var(--ps-light-navy);font-weight:500}

.form-card{background:#fff;border:1px solid var(--ps-grey-200);border-radius:18px;padding:32px;box-shadow:var(--shadow-md)}
.form-card h3{font-size:22px;font-weight:700;margin-bottom:4px}
.form-card .sub{font-size:14px;color:var(--ps-light-navy);margin:0 0 22px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.fld label{font-size:12.5px;font-weight:600;color:var(--ps-light-navy);display:block;margin-bottom:6px}
.fld input,.fld select,.fld textarea{font-family:var(--font-body);font-size:15px;font-weight:500;width:100%;padding:12px 14px;border-radius:9px;border:1.5px solid var(--ps-grey-200);background:#fff;color:var(--ps-navy);transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}
.fld textarea{resize:vertical;min-height:88px}
.fld input::placeholder,.fld textarea::placeholder{color:var(--ps-grey-400)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:0;border-color:var(--ps-deep-green);box-shadow:0 0 0 3px rgba(1,73,54,.16)}
.form-success{text-align:center;padding:34px 16px}
.form-success .ok{width:64px;height:64px;border-radius:50%;background:var(--ps-green-tint);color:var(--ps-deep-green);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.form-success .ok svg{width:30px;height:30px}
.form-success h3{font-size:24px;margin-bottom:8px}
.form-success p{color:var(--ps-light-navy);font-size:15px;margin:0 auto;max-width:340px;line-height:1.55}

/* Quote CTA card (links to live form) */
.quote-cta{background:var(--ps-deep-green);border-radius:18px;padding:38px 34px;box-shadow:var(--shadow-green);color:#fff;text-align:center}
.quote-cta .mono{width:58px;margin:0 auto 18px;filter:brightness(0) invert(1);opacity:.9}
.quote-cta h3{font-family:var(--font-display);font-weight:900;font-size:28px;letter-spacing:-.02em;margin:0 0 10px;color:#fff}
.quote-cta p{font-size:15px;line-height:1.55;color:#cfe0d9;margin:0 auto 26px;max-width:300px}
.quote-cta .call-alt{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-size:14px;font-weight:600;color:var(--ps-lime)}
.quote-cta .call-alt svg{width:16px;height:16px}

/* ---------- Footer ---------- */
.footer{background:var(--ps-navy);color:#cdd3dc}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:64px 0 48px}
.footer .logo{height:34px;margin-bottom:18px}
.footer .blurb{font-size:14px;line-height:1.6;color:#aeb6c2;max-width:300px;margin:0 0 20px}
.footer h4{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.footer a{font-size:14px;color:#aeb6c2;transition:color var(--dur-fast)}
.footer a:hover{color:var(--ps-lime)}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#fff;transition:background var(--dur-fast)}
.socials a:hover{background:var(--ps-deep-green)}
.socials svg{width:18px;height:18px}
.footer .bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;justify-content:space-between;gap:16px;font-size:13px;color:#8a93a1;flex-wrap:wrap}

@media(max-width:900px){
  .hero-grid,.quote-grid{grid-template-columns:1fr;gap:36px}
  .hero h1{font-size:44px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .gal-grid,.proc-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .footer .top{grid-template-columns:1fr 1fr}
  .nav,.phone-link{display:none}
}

@media(max-width:600px){
  .container{padding:0 18px}
  .header .bar{height:62px}
  .header .logo{height:25px}
  .hero{padding:44px 0 56px}
  .hero h1{font-size:34px;margin:12px 0 16px}
  .hero .lead{font-size:16px;margin:0 0 22px}
  .hero-media image-slot,.hero-media .ph{height:280px}
  .hero-wm{width:520px;height:520px;bottom:-100px;left:-140px}
  .badge-float{display:none}
  .strip .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:18px 0}
  .strip .item{font-size:13px}
  .section{padding:56px 0}
  .section-head h2{font-size:30px}
  .svc-grid{grid-template-columns:1fr;gap:16px}
  .gal-grid{grid-template-columns:1fr 1fr;gap:12px}
  .proc-grid{grid-template-columns:1fr;gap:24px}
  .testi-grid{grid-template-columns:1fr;gap:16px}
  .testi blockquote{font-size:15px}
  .frow{grid-template-columns:1fr;gap:12px}
  .form-card{padding:22px 18px}
  .quote-cta{padding:28px 20px}
  .footer .top{grid-template-columns:1fr;gap:28px;padding:40px 0 28px}
  .footer .bottom{flex-direction:column;gap:8px;text-align:center}
}
