/*
Theme Name: Platinum Properties
Theme URI: https://platinumproperties.ca
Author: Platinum Properties
Description: A premium, Elementor-compatible WordPress theme for Platinum Properties. Dark luxury palette, Oswald display + Inter body. Fully dynamic: every page is editable via WP admin and Elementor. No hardcoded per-slug templates.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: platinum-properties
Tags: business, real-estate, elementor, full-width-template, custom-menu, featured-images, threaded-comments, translation-ready
*/

:root{
  --ink:#0a0d12;
  --ink-soft:#181d27;
  --surface:#f4f5f7;
  --surface-alt:#e7e9ee;
  --primary:#6ea8e2;
  --primary-strong:#4f8fd1;
  --foreground:#0f131a;
  --white:#ffffff;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--white);
  color:var(--foreground);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,.font-display{
  font-family:'Oswald','Arial Narrow',sans-serif;
  letter-spacing:.02em;
  margin:0;
}

.pp-container{max-width:80rem;margin-inline:auto;padding-inline:1rem}
.section-pad{padding-block:clamp(3.5rem,8vw,6rem)}
.bg-ink{background:var(--ink);color:#fff}
.bg-ink-soft{background:var(--ink-soft);color:#fff}
.bg-surface{background:var(--surface)}
.bg-surface-alt{background:var(--surface-alt)}
.text-primary{color:var(--primary)}
.text-white{color:#fff}
.text-muted{color:rgba(255,255,255,.7)}

.btn-blue{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.75rem;border-radius:9999px;
  background:linear-gradient(180deg,#8ebdee,#4f8fd1);
  color:#0a0d12;font-weight:700;font-size:.8rem;letter-spacing:.08em;
  text-transform:uppercase;border:0;cursor:pointer;
  box-shadow:0 6px 20px -8px rgba(79,143,209,.6);
  transition:transform .2s,filter .2s,box-shadow .2s;
}
.btn-blue:hover{transform:translateY(-1px);filter:brightness(1.08);box-shadow:0 10px 28px -10px rgba(79,143,209,.75)}

.btn-outline-light{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.7rem 1.5rem;border-radius:9999px;
  border:1px solid rgba(255,255,255,.25);color:#fff;
  font-weight:600;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;
  transition:background .2s;
}
.btn-outline-light:hover{background:rgba(255,255,255,.08)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:translateY(0)}

.text-gradient-blue{
  background:linear-gradient(180deg,#f0f5ff,#6ea8e2);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.bg-grid-dark{
  background-image:
    radial-gradient(ellipse at top,rgba(40,55,80,.6),transparent 60%),
    linear-gradient(180deg,#070a10,#10141c);
  color:#fff;
}

/* ============== HEADER ============== */
.pp-topbar{background:var(--ink-soft);color:rgba(255,255,255,.8);font-size:.75rem}
.pp-topbar .pp-container{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-block:.5rem}
.pp-topbar .tb-left{display:flex;align-items:center;gap:1rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.15em}
.pp-topbar .tb-left .sep{color:rgba(255,255,255,.3)}
.pp-topbar .tb-left .strong{color:rgba(255,255,255,.85)}
@media(max-width:639px){.pp-topbar .tb-left .hide-sm{display:none}}
.pp-topbar .btn-blue{padding:.4rem 1rem;font-size:.65rem}

.pp-header{position:sticky;top:0;z-index:50;background:var(--ink);border-bottom:1px solid rgba(255,255,255,.05);transition:box-shadow .3s}
.pp-header.is-scrolled{box-shadow:0 8px 30px -15px rgba(0,0,0,.8)}
.pp-header .row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.75rem}
.pp-header .brand{display:block;flex-shrink:0;max-width:68vw}
@media(min-width:640px){.pp-header .brand{max-width:none}}
.pp-header .brand img{width:230px;height:auto;object-fit:contain}
@media(min-width:640px){.pp-header .brand img{width:270px}}
@media(min-width:1024px){.pp-header .brand img{width:300px}}
@media(min-width:1280px){.pp-header .brand img{width:330px}}

.pp-nav-primary{display:none;align-items:center;gap:.125rem}
@media(min-width:1024px){.pp-nav-primary{display:flex}}
.pp-nav-primary a{
  padding:.5rem .75rem;font-size:.75rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.85);
}
.pp-nav-primary a:hover,.pp-nav-primary .current-menu-item>a{color:var(--primary)}

.pp-phone{display:none;align-items:center;gap:.5rem;color:rgba(255,255,255,.8);font-size:.875rem;letter-spacing:.05em}
@media(min-width:768px){.pp-phone{display:inline-flex}}
.pp-phone:hover{color:#fff}
.pp-phone svg{width:1rem;height:1rem}

.pp-burger{background:transparent;color:#fff;border:0;padding:.25rem;cursor:pointer}
@media(min-width:1024px){.pp-burger{display:none}}

.pp-nav-secondary-wrap{display:none;border-top:1px solid rgba(255,255,255,.05)}
@media(min-width:1024px){.pp-nav-secondary-wrap{display:block}}
.pp-nav-secondary{display:flex;align-items:center;justify-content:center;gap:.25rem;padding-block:.5rem;background:rgba(110,168,226,.15)}
.pp-nav-secondary a{
  padding:.35rem .75rem;font-size:.7rem;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.9);border-radius:.25rem;
}
.pp-nav-secondary a:hover{color:#fff;background:rgba(255,255,255,.05)}
.pp-nav-secondary .current-menu-item>a{color:#fff;background:rgba(255,255,255,.1)}

.pp-mobile-panel{display:none;border-top:1px solid rgba(255,255,255,.1);background:var(--ink)}
.pp-mobile-panel.open{display:block}
@media(min-width:1024px){.pp-mobile-panel{display:none!important}}
.pp-mobile-panel ul{list-style:none;margin:0;padding:1rem;display:grid;gap:.25rem}
.pp-mobile-panel a{
  display:block;padding:.625rem .75rem;border-radius:.25rem;
  font-size:.875rem;font-weight:600;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.85);
}
.pp-mobile-panel a:hover{color:var(--primary);background:rgba(255,255,255,.05)}

/* ============== HERO ============== */
.pp-hero{position:relative;overflow:hidden;background:var(--ink)}
.pp-hero .bg{position:absolute;inset:0}
.pp-hero .bg img{width:100%;height:100%;object-fit:cover;opacity:.55}
.pp-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,13,18,.7),rgba(10,13,18,.6),var(--ink))}
.pp-hero .inner{position:relative;max-width:64rem;margin-inline:auto;padding:6rem 1rem;text-align:center}
@media(min-width:640px){.pp-hero .inner{padding-block:8rem}}
@media(min-width:1024px){.pp-hero .inner{padding-block:10rem}}
.pp-hero .eyebrow{color:#fff;font-family:'Oswald',sans-serif;letter-spacing:.25em;text-transform:uppercase;font-size:.875rem;text-decoration:underline;text-underline-offset:8px;text-decoration-color:rgba(255,255,255,.4)}
.pp-hero h1{margin-top:1.5rem;font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;font-size:clamp(2.5rem,7vw,6rem);letter-spacing:.04em;line-height:.95;background:linear-gradient(180deg,#f0f5ff,#6ea8e2);-webkit-background-clip:text;background-clip:text;color:transparent}
.pp-hero .lead{margin:2rem auto 0;max-width:48rem;color:rgba(255,255,255,.85);font-size:1.125rem}
.pp-hero .lead .accent{color:var(--primary);font-weight:600}
.pp-hero .card{display:inline-block;margin-top:3rem;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.5);backdrop-filter:blur(8px);border-radius:.75rem;padding:2.5rem 3.5rem;box-shadow:0 20px 60px -15px rgba(0,0,0,.7)}
.pp-hero .card .line{font-family:'Oswald',sans-serif;font-size:2rem;letter-spacing:.18em;color:#fff;margin-top:.5rem}
@media(min-width:640px){.pp-hero .card .line{font-size:2.25rem}}
.pp-hero .card .line:first-child{margin-top:0}
.pp-hero .card .line.dim{color:rgba(255,255,255,.8)}
.pp-hero .card .line.accent{color:var(--primary)}
.pp-hero .areas{margin-top:2rem;color:rgba(255,255,255,.7);font-size:.875rem;letter-spacing:.2em;text-transform:uppercase}
.pp-hero .cta{margin-top:2.5rem}
.pp-hero .cut{position:relative;height:4rem}
@media(min-width:640px){.pp-hero .cut{height:6rem}}
.pp-hero .cut div{position:absolute;inset:0;background:var(--surface);clip-path:polygon(0 100%,100% 0,100% 100%)}

/* ============== SERVICES ============== */
.pp-services h2{text-align:center;text-transform:uppercase;font-size:clamp(1.5rem,3vw,2.25rem);letter-spacing:.15em;color:var(--ink)}
.pp-services .rule{height:1px;width:10rem;background:rgba(10,13,18,.15);margin:1rem auto 0}
.pp-grid-3{margin-top:3rem;display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:768px){.pp-grid-3{grid-template-columns:repeat(3,1fr)}}
.pp-card{overflow:hidden;border-radius:2px;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.08);transition:box-shadow .3s}
.pp-card:hover{box-shadow:0 20px 40px -15px rgba(0,0,0,.25)}
.pp-card .imgwrap{position:relative;height:14rem;overflow:hidden}
.pp-card .imgwrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.pp-card:hover .imgwrap img{transform:scale(1.05)}
.pp-card .imgwrap .label{position:absolute;left:0;right:0;bottom:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.85),transparent);font-family:'Oswald',sans-serif;letter-spacing:.18em;font-size:.875rem;text-transform:uppercase;color:#fff}
.pp-card .body{padding:1.5rem;text-align:center}
.pp-card .body p{font-size:.875rem;color:rgba(10,13,18,.7);min-height:3.5rem;margin:0 0 1.25rem}

/* ============== WHY HIRE ============== */
.pp-why{position:relative;overflow:hidden}
.pp-why h2{text-align:center;text-transform:uppercase}
.pp-why h2 .eyebrow{display:block;font-size:.875rem;letter-spacing:.4em;color:rgba(255,255,255,.6)}
.pp-why h2 .big{display:block;margin-top:.5rem;font-size:clamp(2rem,5vw,3rem);letter-spacing:.1em;background:linear-gradient(180deg,#f0f5ff,#6ea8e2);-webkit-background-clip:text;background-clip:text;color:transparent}
.pp-why .grid{margin-top:3.5rem;display:grid;gap:3rem;align-items:center}
@media(min-width:1024px){.pp-why .grid{grid-template-columns:1fr 1fr}}
.pp-why .badges{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:28rem;margin:0 auto}
.pp-why .badge{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.pp-why .badge .ring{position:relative;height:7rem;width:7rem;border-radius:9999px;background:linear-gradient(135deg,rgba(110,168,226,.4),rgba(255,255,255,.05));border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px -10px rgba(110,168,226,.45)}
.pp-why .badge .inner{position:absolute;inset:6px;border-radius:9999px;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:.5rem;gap:.25rem}
.pp-why .badge .inner svg{width:1.25rem;height:1.25rem;color:var(--primary)}
.pp-why .badge .inner span{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.8);line-height:1.1}
.pp-why .badge.offset{grid-column:2}
.pp-why .checks{list-style:none;margin:0;padding:0;display:grid;gap:1.25rem}
.pp-why .checks li{display:flex;align-items:flex-start;gap:1rem}
.pp-why .chk{flex-shrink:0;margin-top:.25rem;height:1.75rem;width:1.75rem;border-radius:9999px;border:1px solid rgba(110,168,226,.6);background:rgba(110,168,226,.15);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.pp-why .chk svg{width:1rem;height:1rem}
.pp-why .checks .txt{font-size:1rem;color:rgba(255,255,255,.85)}
.pp-why .checks .pre{color:rgba(255,255,255,.6)}
.pp-why .checks .strong{font-family:'Oswald',sans-serif;letter-spacing:.15em;text-transform:uppercase;color:#fff}

/* ============== SPLIT (Investor / Tenant) ============== */
.pp-split{position:relative}
.pp-split .grid{position:relative;display:grid;gap:2rem}
@media(min-width:768px){.pp-split .grid{grid-template-columns:1fr 1fr}}
.pp-split .card{position:relative;border-radius:2px;border:1px solid rgba(255,255,255,.1);background:rgba(24,29,39,.6);backdrop-filter:blur(4px);padding:2rem;text-align:center}
@media(min-width:640px){.pp-split .card{padding:2.5rem}}
.pp-split .card h3{font-family:'Oswald',sans-serif;font-size:1.5rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;line-height:1.2}
.pp-split .card h3 .hl{color:var(--primary)}
.pp-split .card .img{margin-top:1.5rem;overflow:hidden;border-radius:2px}
.pp-split .card .img img{width:100%;height:14rem;object-fit:cover;transition:transform .7s}
.pp-split .card:hover .img img{transform:scale(1.05)}
.pp-split .or{position:absolute;inset-block:0;left:50%;transform:translateX(-50%);display:none;align-items:center;pointer-events:none}
@media(min-width:768px){.pp-split .or{display:flex}}
.pp-split .or span{font-family:'Oswald',sans-serif;font-size:1.5rem;letter-spacing:.2em;color:rgba(255,255,255,.7);background:var(--ink);padding:.5rem 1rem;border-radius:9999px;border:1px solid rgba(255,255,255,.1)}

/* ============== RENOVATIONS ============== */
.pp-reno .pre{text-align:center;font-family:'Oswald',sans-serif;letter-spacing:.3em;color:rgba(10,13,18,.6);font-size:.875rem;text-transform:uppercase}
.pp-reno h2{margin-top:.75rem;text-align:center;text-transform:uppercase;font-size:clamp(1.25rem,2.5vw,1.875rem);letter-spacing:.1em;color:var(--ink)}
.pp-reno h2 .hl{color:var(--primary)}
.pp-reno .cta-row{margin-top:1.5rem;display:flex;justify-content:center}
.pp-reno-grid{margin-top:3rem;display:grid;gap:1.5rem}
@media(min-width:640px){.pp-reno-grid{grid-template-columns:1fr 1fr}}
.pp-reno-fig{position:relative;overflow:hidden;border-radius:2px;box-shadow:0 1px 3px rgba(0,0,0,.08);transition:box-shadow .3s;margin:0;background:#fff}
.pp-reno-fig:hover{box-shadow:0 20px 40px -15px rgba(0,0,0,.25)}
.pp-reno-fig img{width:100%;height:16rem;object-fit:cover;transition:transform .7s}
.pp-reno-fig:hover img{transform:scale(1.05)}
.pp-reno-fig .before,.pp-reno-fig .after{position:absolute;top:.75rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;font-weight:700;padding:.25rem .5rem;border-radius:.25rem}
.pp-reno-fig .before{left:.75rem;background:rgba(0,0,0,.7);color:#fff}
.pp-reno-fig .after{right:.75rem;background:var(--primary);color:var(--ink)}
.pp-reno-fig figcaption{padding:.75rem 1rem;font-size:.875rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(10,13,18,.8);background:#fff}

/* ============== REVIEWS ============== */
.pp-reviews .grid{display:grid;gap:3rem;align-items:center}
@media(min-width:768px){.pp-reviews .grid{grid-template-columns:1fr 1fr}}
.pp-reviews .left{background:#fff;color:var(--ink);border-radius:2px;padding:2rem}
@media(min-width:640px){.pp-reviews .left{padding:2.5rem}}
.pp-reviews .gtag{display:flex;align-items:center;gap:.5rem}
.pp-reviews .gtag .g{font-family:'Oswald',sans-serif;font-size:1.5rem;font-weight:700}
.pp-reviews .gtag .g .b{color:#4285F4}.pp-reviews .gtag .g .r{color:#EA4335}.pp-reviews .gtag .g .y{color:#FBBC05}.pp-reviews .gtag .g .gn{color:#34A853}
.pp-reviews .stars{color:#FBBC05;display:flex;gap:2px}
.pp-reviews .stars svg{width:1rem;height:1rem;fill:#FBBC05}
.pp-reviews h3{margin-top:1.5rem;font-family:'Oswald',sans-serif;font-size:1.5rem;letter-spacing:.05em}
.pp-reviews .left p{margin-top:1rem;font-size:.875rem;color:rgba(10,13,18,.7)}
.pp-reviews .right{position:relative;background:var(--ink-soft);border:1px solid rgba(255,255,255,.1);border-radius:2px;padding:2rem}
@media(min-width:640px){.pp-reviews .right{padding:2.5rem}}
.pp-reviews .quote-icon{position:absolute;top:-1rem;left:1.5rem;width:2.5rem;height:2.5rem;background:var(--ink);color:var(--primary);border-radius:9999px;padding:.5rem;display:flex;align-items:center;justify-content:center}
.pp-reviews .body{color:rgba(255,255,255,.85);line-height:1.6;min-height:7rem}
.pp-reviews .meta{margin-top:1.5rem;display:flex;align-items:center;justify-content:space-between}
.pp-reviews .name{font-family:'Oswald',sans-serif;letter-spacing:.15em;text-transform:uppercase;color:#fff}
.pp-reviews .role{font-size:.75rem;color:rgba(255,255,255,.6)}
.pp-reviews .controls{display:flex;align-items:center;gap:.5rem}
.pp-reviews .controls button{height:2.25rem;width:2.25rem;border-radius:9999px;border:1px solid rgba(255,255,255,.15);background:transparent;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}
.pp-reviews .controls button:hover{background:rgba(255,255,255,.1)}
.pp-reviews .dots{margin-top:1rem;display:flex;gap:.375rem}
.pp-reviews .dots button{height:6px;border-radius:9999px;background:rgba(255,255,255,.2);border:0;cursor:pointer;width:12px;transition:all .3s}
.pp-reviews .dots button.active{width:24px;background:var(--primary)}

/* ============== ABOUT ============== */
.pp-about .grid{display:grid;gap:3rem;align-items:center}
@media(min-width:768px){.pp-about .grid{grid-template-columns:1fr 1fr}}
.pp-about .imgbox{position:relative}
.pp-about .imgbox::before{content:"";position:absolute;inset:0;transform:translate(-.75rem,-.75rem);border:1px solid rgba(10,13,18,.15)}
.pp-about .imgbox img{position:relative;width:100%;height:auto;object-fit:cover;filter:grayscale(15%)}
.pp-about .wm{position:absolute;bottom:1.5rem;left:1.5rem;width:8rem;opacity:.7;mix-blend-mode:screen;pointer-events:none}
@media(min-width:640px){.pp-about .wm{width:10rem}}
.pp-about h2{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.15em;font-size:clamp(1.875rem,4vw,2.25rem);color:var(--primary)}
.pp-about .copy{margin-top:1.5rem;display:grid;gap:1rem;color:rgba(10,13,18,.8);font-size:.95rem;line-height:1.7}
.pp-about .sig{text-align:right;font-style:italic;color:rgba(10,13,18,.6)}

/* ============== CONTACT CTA ============== */
.pp-cta{background:var(--ink)}
.pp-cta .grid{display:grid;grid-template-columns:1fr}
@media(min-width:768px){.pp-cta .grid{grid-template-columns:1fr 1fr}}
.pp-cta .left{position:relative;background:var(--ink-soft);padding:2.5rem;min-height:20rem;display:flex;flex-direction:column;justify-content:center}
@media(min-width:640px){.pp-cta .left{padding:3.5rem}}
@media(min-width:1024px){.pp-cta .left{padding:5rem}}
.pp-cta .eyebrow{font-family:'Oswald',sans-serif;letter-spacing:.3em;text-transform:uppercase;color:var(--primary);font-size:.75rem}
.pp-cta h2{margin-top:1rem;font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:clamp(1.875rem,4vw,3rem);letter-spacing:.05em;color:#fff;line-height:1.1}
.pp-cta h2 .hl{color:var(--primary)}
.pp-cta .lead{margin-top:1rem;color:rgba(255,255,255,.7);font-size:.875rem}
.pp-cta .ctarow{margin-top:2rem}
.pp-cta .right{position:relative;min-height:20rem}
.pp-cta .right img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}

/* ============== FOOTER ============== */
.pp-footer{background:var(--ink);color:rgba(255,255,255,.7);border-top:1px solid rgba(255,255,255,.05)}
.pp-footer .top{padding-block:4rem;display:grid;gap:2.5rem;grid-template-columns:1fr}
@media(min-width:768px){.pp-footer .top{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.pp-footer .top{grid-template-columns:2fr 1fr 1fr 1fr}}
.pp-footer .brand-col img{width:14rem;height:auto;object-contain:contain;opacity:.9}
.pp-footer .brand-col .btn-blue{margin-top:1.5rem}
.pp-footer .brand-col .contact{margin-top:1.5rem;display:grid;gap:.5rem;font-size:.875rem}
.pp-footer .brand-col .contact a,.pp-footer .brand-col .contact p{display:flex;align-items:center;gap:.5rem;margin:0;color:rgba(255,255,255,.7)}
.pp-footer .brand-col .contact a:hover{color:var(--primary)}
.pp-footer .brand-col .contact svg{width:1rem;height:1rem}
.pp-footer h4{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.15em;color:#fff;font-size:.875rem;margin-bottom:1rem}
.pp-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem;font-size:.875rem}
.pp-footer ul a:hover{color:var(--primary)}
.pp-footer .social{margin-top:1.5rem;display:flex;gap:.75rem}
.pp-footer .social a{height:2.5rem;width:2.5rem;border-radius:9999px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;transition:all .2s}
.pp-footer .social a:hover{background:var(--primary);color:var(--ink);border-color:transparent}
.pp-footer .bottom{border-top:1px solid rgba(255,255,255,.05);padding-block:1.5rem;font-size:.75rem;color:rgba(255,255,255,.4);display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:.5rem}
@media(min-width:640px){.pp-footer .bottom{flex-direction:row}}

/* ============== PAGE HERO (subpages) ============== */
.pp-page-hero{background:var(--ink);padding:4rem 0 3rem;border-bottom:1px solid rgba(255,255,255,.05)}
@media(min-width:640px){.pp-page-hero{padding:6rem 0 4rem}}
.pp-page-hero .inner{text-align:center}
.pp-page-hero .eyebrow{font-family:'Oswald',sans-serif;letter-spacing:.3em;text-transform:uppercase;color:var(--primary);font-size:.75rem}
.pp-page-hero .title-wrap{margin-top:1rem;display:inline-block}
.pp-page-hero .rule{height:1px;width:100%;background:rgba(110,168,226,.6);margin-bottom:1rem}
.pp-page-hero h1{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:clamp(2.5rem,6vw,4.5rem);letter-spacing:.08em;color:#fff}
.pp-page-hero .sub{margin:1.5rem auto 0;max-width:42rem;color:rgba(255,255,255,.7);font-size:1rem;line-height:1.6}

/* Page (Elementor or content) */
.pp-page-content{background:var(--surface);color:var(--foreground);padding-block:4rem}
.pp-page-content .pp-container{max-width:48rem}
.pp-page-content h2{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.15em;color:var(--ink);margin:2rem 0 1rem}
.pp-page-content p{margin:0 0 1rem;line-height:1.7;color:rgba(15,19,26,.8)}
.pp-page-content a{color:var(--primary-strong);text-decoration:underline}
.pp-page-content ul,.pp-page-content ol{padding-left:1.5rem;margin:0 0 1rem}

/* Elementor full-width / canvas support */
.elementor-template-full-width .pp-page-content,
.elementor-template-canvas .pp-page-content{padding:0;background:transparent}
.elementor-template-full-width .pp-page-content .pp-container,
.elementor-template-canvas .pp-page-content .pp-container{max-width:none;padding:0}
