/* ==========================================================================
   HRS GLOBAL LLC — Premium Enterprise Design System
   Extends style.css. Load AFTER style.css so these rules win.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --p-ink:#05070d;
  --p-navy-950:#070c18;
  --p-navy-900:#0b1226;
  --p-navy-800:#111c37;
  --p-navy-700:#182a4d;
  --p-navy-600:#213863;
  --p-blue:#3b6df0;
  --p-blue-light:#7ea2ff;
  --p-blue-pale:#eef3ff;
  --p-gold:#c9a24b;
  --p-gold-light:#e6cd8a;
  --p-white:#ffffff;
  --p-ivory:#f7f5f0;
  --p-text-dim:rgba(255,255,255,0.72);
  --p-text-faint:rgba(255,255,255,0.52);
  --p-line:rgba(255,255,255,0.10);
  --p-glass-bg:rgba(255,255,255,0.045);
  --p-glass-bg-strong:rgba(255,255,255,0.07);
  --p-glass-border:rgba(255,255,255,0.12);
  --p-shadow-soft:0 20px 60px rgba(5,7,13,0.35);
  --p-shadow-lift:0 30px 70px rgba(5,7,13,0.45);
  --p-radius:18px;
  --p-radius-sm:12px;
  --p-radius-lg:26px;
  --p-serif:"Fraunces", Georgia, "Times New Roman", serif;
  --p-sans:"Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, Roboto, Helvetica, Arial, sans-serif;
  --p-ease:cubic-bezier(.16,.8,.28,1);
}

body{ font-family: var(--p-sans); }

/* ---------- Premium section base ---------- */
.p-dark{ background: var(--p-navy-950); color: var(--p-text-dim); }
.p-dark h1,.p-dark h2,.p-dark h3,.p-dark h4{ color:#fff; }
.p-dark p{ color: var(--p-text-dim); }

.p-section{ padding: 100px 0; position: relative; }
.p-section.p-tight{ padding: 64px 0; }
.p-container{ max-width: 1240px; margin: 0 auto; padding: 0 28px; position: relative; z-index: 2; }

.p-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--p-sans); font-size:0.74rem; font-weight:700;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--p-gold-light);
  margin-bottom: 18px;
}
.p-eyebrow::before{ content:""; width:22px; height:1px; background: var(--p-gold-light); display:inline-block; }
.p-eyebrow.on-light{ color:#946a12; }

.p-heading{
  font-family: var(--p-serif);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.08;
  font-size: clamp(2.1rem, 4vw, 3.4rem);
  margin: 0 0 20px;
}
.p-heading.small{ font-size: clamp(1.6rem, 2.6vw, 2.2rem); }
.p-lede{ font-size: 1.15rem; line-height:1.7; max-width: 620px; color: inherit; opacity:0.86; }
.p-section-head{ max-width: 760px; margin: 0 auto 56px; text-align:center; }

/* ---------- Header (glass) ---------- */
.p-header{
  position: sticky; top:0; z-index:1000;
  background: rgba(6,11,22,0.72);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  transition: background .3s var(--p-ease), padding .3s var(--p-ease);
}
.p-header .nav-wrap{ padding: 18px 24px; max-width:1240px; }
.p-header .brand{ color:#fff; }
.p-header .brand-sub{ color: rgba(255,255,255,0.5) !important; }
.p-header .brand img{ filter: brightness(0) invert(1); }
.p-header .nav-links a{ color: rgba(255,255,255,0.82); font-weight:500; font-size:0.92rem; }
.p-header .nav-links a.active, .p-header .nav-links a:hover{ color:#fff; }
.p-header .nav-cta{
  background: linear-gradient(135deg, var(--p-blue), #6d47d9);
  border-radius:10px; font-weight:600;
  box-shadow: 0 8px 24px rgba(59,109,240,0.35);
}
.p-header .nav-toggle span{ background:#fff; }
@media (max-width:720px){
  .p-header .nav-links{ background: var(--p-navy-900); border-color: rgba(255,255,255,0.08); }
  .p-header .nav-links li{ border-color: rgba(255,255,255,0.06); }
}

/* ---------- Hero ---------- */
.p-hero{
  position: relative;
  background: var(--p-navy-950);
  overflow: hidden;
  padding: 150px 0 110px;
}
.p-hero::before{
  content:"";
  position:absolute; inset:-20% -10%;
  background:
    radial-gradient(38% 42% at 82% 8%, rgba(59,109,240,0.35), transparent 70%),
    radial-gradient(30% 34% at 8% 82%, rgba(201,162,75,0.20), transparent 70%),
    radial-gradient(60% 60% at 50% 100%, rgba(109,71,217,0.16), transparent 70%);
  filter: blur(10px);
}
.p-hero::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 64px 64px;
  -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,0.5), transparent 75%);
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.5), transparent 75%);
  opacity:0.5;
}
.p-hero-grid{
  position:relative; z-index:2;
  display:grid; grid-template-columns: 1.1fr 0.9fr; gap:56px; align-items:center;
}
.p-hero-badge{
  display:inline-flex; align-items:center; gap:8px;
  font-size:0.76rem; font-weight:600; letter-spacing:1.2px; text-transform:uppercase;
  color: var(--p-gold-light);
  background: rgba(201,162,75,0.10);
  border:1px solid rgba(201,162,75,0.30);
  padding:8px 16px; border-radius:999px; margin-bottom:26px;
}
.p-hero h1{
  font-family: var(--p-serif); color:#fff; font-weight:600;
  font-size: clamp(2.4rem, 4.6vw, 3.9rem); line-height:1.06; letter-spacing:-0.015em;
  margin: 0 0 22px;
}
.p-hero .p-lede{ font-size:1.18rem; color: var(--p-text-dim); max-width:560px; margin-bottom:36px; }
.p-btn-row{ display:flex; gap:16px; flex-wrap:wrap; margin-bottom:44px; }
.p-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 28px; border-radius:11px; font-weight:600; font-size:0.96rem;
  border:1px solid transparent; cursor:pointer; transition: all .25s var(--p-ease);
  font-family: var(--p-sans);
}
.p-btn-primary{
  background: linear-gradient(135deg, var(--p-blue), #6d47d9); color:#fff;
  box-shadow: 0 14px 34px rgba(59,109,240,0.32);
}
.p-btn-primary:hover{ transform: translateY(-2px); box-shadow: 0 20px 44px rgba(59,109,240,0.42); color:#fff; }
.p-btn-ghost{ background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.22); color:#fff; }
.p-btn-ghost:hover{ background: rgba(255,255,255,0.09); color:#fff; }
.p-btn-gold{ background: linear-gradient(135deg, var(--p-gold), var(--p-gold-light)); color:#1a1400; }
.p-btn-gold:hover{ transform: translateY(-2px); color:#1a1400; }

.p-hero-visual{ position:relative; }
.p-hero-card{
  background: linear-gradient(160deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  border:1px solid var(--p-glass-border);
  border-radius: var(--p-radius-lg);
  padding: 30px;
  backdrop-filter: blur(18px);
  box-shadow: var(--p-shadow-soft);
}
.p-hero-card .p-hero-viz{
  aspect-ratio: 4/3; border-radius: var(--p-radius);
  background:
    radial-gradient(60% 60% at 30% 20%, rgba(59,109,240,0.55), transparent 60%),
    radial-gradient(50% 50% at 80% 80%, rgba(201,162,75,0.4), transparent 60%),
    linear-gradient(160deg, var(--p-navy-800), var(--p-navy-950));
  position:relative; overflow:hidden;
}
.p-hero-viz .p-crate{ position:absolute; border-radius:6px; background:rgba(255,255,255,0.10); border:1px solid rgba(255,255,255,0.18); }
.p-float-chip{
  position:absolute; display:flex; align-items:center; gap:10px;
  background: rgba(10,15,28,0.85); border:1px solid var(--p-glass-border);
  padding:12px 16px; border-radius:14px; font-size:0.84rem; font-weight:600; color:#fff;
  backdrop-filter: blur(10px); box-shadow: var(--p-shadow-soft);
}

/* ---------- Trust bar ---------- */
.p-trustbar{ background: var(--p-navy-900); border-top:1px solid var(--p-line); border-bottom:1px solid var(--p-line); }
.p-trust-row{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:28px; padding: 34px 0; }
.p-trust-item{ display:flex; align-items:center; gap:14px; flex:1 1 150px; }
.p-trust-item .p-ic{
  width:44px; height:44px; border-radius:12px; flex-shrink:0;
  background: rgba(59,109,240,0.14); color: var(--p-blue-light);
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
}
.p-trust-item b{ display:block; color:#fff; font-size:1.05rem; font-weight:700; line-height:1.2; }
.p-trust-item span{ display:block; color: var(--p-text-faint); font-size:0.8rem; margin-top:2px; }

/* ---------- Glass / highlight cards ---------- */
.p-grid{ display:grid; gap:26px; }
.p-grid-3{ grid-template-columns:repeat(3,1fr); }
.p-grid-4{ grid-template-columns:repeat(4,1fr); }
.p-grid-6{ grid-template-columns:repeat(6,1fr); }

.p-card{
  background: var(--p-glass-bg);
  border:1px solid var(--p-glass-border);
  border-radius: var(--p-radius);
  padding: 32px 28px;
  backdrop-filter: blur(16px);
  transition: transform .35s var(--p-ease), box-shadow .35s var(--p-ease), background .35s var(--p-ease);
}
.p-card:hover{ transform: translateY(-6px); background: var(--p-glass-bg-strong); box-shadow: var(--p-shadow-lift); }
.p-card .p-ic{
  width:52px; height:52px; border-radius:14px;
  background: linear-gradient(135deg, rgba(59,109,240,0.22), rgba(109,71,217,0.18));
  color: var(--p-blue-light);
  display:flex; align-items:center; justify-content:center; font-size:1.35rem;
  margin-bottom:20px; border:1px solid rgba(255,255,255,0.10);
}
.p-card h3{ color:#fff; font-family:var(--p-sans); font-size:1.08rem; margin-bottom:10px; }
.p-card p{ color: var(--p-text-faint); font-size:0.94rem; margin:0; }

.p-card.on-light{ background:#fff; border-color:var(--gray-200); box-shadow: 0 8px 24px rgba(15,45,82,0.06); }
.p-card.on-light:hover{ box-shadow: 0 24px 50px rgba(15,45,82,0.12); }
.p-card.on-light h3{ color: var(--p-navy-900); }
.p-card.on-light p{ color:#5c6478; }
.p-card.on-light .p-ic{ background: var(--p-blue-pale); color: var(--p-blue); border-color: transparent; }

/* ---------- Products (top selling, generic placeholders) ---------- */
.p-product-rail{ display:flex; gap:22px; overflow-x:auto; scroll-snap-type:x mandatory; padding: 8px 4px 22px; scrollbar-width:none; }
.p-product-rail::-webkit-scrollbar{ display:none; }
.p-product-card{
  scroll-snap-align:start; flex:0 0 240px;
  background:#fff; border:1px solid var(--gray-200); border-radius: var(--p-radius);
  overflow:hidden; transition: transform .3s var(--p-ease), box-shadow .3s var(--p-ease);
}
.p-product-card:hover{ transform: translateY(-6px); box-shadow: 0 26px 50px rgba(15,45,82,0.14); }
.p-product-thumb{
  height:150px; display:flex; align-items:center; justify-content:center;
  background: linear-gradient(160deg, var(--p-blue-pale), #f6f9ff);
  color: var(--p-blue); font-size:2.4rem;
}
.p-product-card .p-pbody{ padding:18px 18px 20px; }
.p-product-card h4{ margin:0 0 4px; font-size:0.96rem; color:var(--p-navy-900); }
.p-product-card .p-cat{ font-size:0.76rem; color:#8992a3; margin-bottom:8px; }
.p-product-card .p-tag{ display:inline-block; font-size:0.72rem; font-weight:700; color:#946a12; background:#fbf1dd; padding:3px 9px; border-radius:999px; margin-bottom:10px; }
.p-rail-controls{ display:flex; justify-content:flex-end; gap:10px; margin-top:-8px; margin-bottom:26px; }
.p-rail-btn{
  width:40px; height:40px; border-radius:50%; border:1px solid var(--gray-200); background:#fff;
  display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--p-navy-900);
  transition: all .2s ease;
}
.p-rail-btn:hover{ background: var(--p-blue); color:#fff; border-color:var(--p-blue); }

/* ---------- Category grid ---------- */
.p-cat-card{
  background:#fff; border:1px solid var(--gray-200); border-radius: var(--p-radius);
  padding:26px 18px; text-align:center; transition: all .3s var(--p-ease);
}
.p-cat-card:hover{ transform: translateY(-5px); box-shadow: 0 20px 40px rgba(15,45,82,0.10); border-color:transparent; }
.p-cat-card .p-ic{ width:52px; height:52px; margin:0 auto 14px; border-radius:14px; background:var(--p-blue-pale); color:var(--p-blue); display:flex; align-items:center; justify-content:center; font-size:1.4rem; }
.p-cat-card span{ font-size:0.88rem; font-weight:600; color:var(--p-navy-900); }

/* ---------- Process timeline ---------- */
.p-timeline{ position:relative; max-width:920px; margin:0 auto; }
.p-timeline::before{ content:""; position:absolute; left:27px; top:6px; bottom:6px; width:2px; background: linear-gradient(var(--p-blue), var(--p-gold)); opacity:0.35; }
.p-tl-item{ position:relative; display:flex; gap:26px; padding-bottom:44px; }
.p-tl-item:last-child{ padding-bottom:0; }
.p-tl-num{
  flex-shrink:0; width:56px; height:56px; border-radius:50%;
  background: var(--p-navy-900); border:1px solid var(--p-glass-border);
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-family:var(--p-serif); font-size:1.2rem; font-weight:600; z-index:2;
}
.p-tl-body h4{ color:#fff; margin:6px 0 8px; font-size:1.08rem; }
.p-tl-body p{ margin:0; color: var(--p-text-faint); font-size:0.94rem; max-width:560px; }

/* ---------- Founder ---------- */
.p-founder{ display:grid; grid-template-columns: 0.8fr 1.2fr; gap:60px; align-items:center; }
.p-founder-avatar{
  width:180px; height:180px; border-radius:50%; margin: 0 auto 26px;
  background: linear-gradient(135deg, var(--p-blue), #6d47d9);
  display:flex; align-items:center; justify-content:center;
  font-family: var(--p-serif); font-size:3rem; font-weight:600; color:#fff;
  box-shadow: 0 20px 50px rgba(59,109,240,0.35); border:4px solid rgba(255,255,255,0.12);
}
.p-founder-card{ text-align:center; }
.p-founder-card .role{ color: var(--p-gold-light); font-size:0.86rem; font-weight:600; letter-spacing:0.5px; }
.p-founder-card h3{ color:#fff; font-family:var(--p-serif); font-size:1.5rem; margin:4px 0 0; }
.p-founder-quote{ font-family: var(--p-serif); font-size:1.5rem; line-height:1.5; color:#fff; font-weight:500; margin-bottom:22px; }
.p-signature{ font-family: var(--p-serif); font-style:italic; font-size:1.6rem; color: var(--p-gold-light); margin-top:24px; }

/* ---------- Brand compatibility band ---------- */
.p-chip-row{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.p-chip{
  padding:12px 22px; border-radius:999px; font-size:0.88rem; font-weight:600;
  background: var(--p-glass-bg); border:1px solid var(--p-glass-border); color: var(--p-text-dim);
}

/* ---------- FAQ ---------- */
.p-faq{ max-width:820px; margin:0 auto; }
.p-faq-item{ border-bottom:1px solid var(--gray-200); }
.p-faq-q{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:22px 4px; cursor:pointer; font-weight:600; color: var(--p-navy-900); font-size:1.02rem;
}
.p-faq-q .p-plus{ flex-shrink:0; width:26px; height:26px; border-radius:50%; background:var(--p-blue-pale); color:var(--p-blue); display:flex; align-items:center; justify-content:center; transition: transform .3s ease; font-size:0.9rem; }
.p-faq-item.open .p-plus{ transform: rotate(45deg); }
.p-faq-a{ max-height:0; overflow:hidden; transition: max-height .35s var(--p-ease); }
.p-faq-a p{ padding: 0 4px 22px; margin:0; color:#5c6478; }

/* ---------- Footer premium ---------- */
.p-footer{ background: var(--p-ink); color: rgba(255,255,255,0.6); }
.p-footer .footer-brand span{ color:#fff; }
.p-footer h4{ color:#fff; }
.p-footer a{ color: rgba(255,255,255,0.62); }
.p-footer a:hover{ color:#fff; }
.p-newsletter{ display:flex; gap:10px; margin-top:14px; }
.p-newsletter input{
  flex:1; background: rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.14);
  border-radius:9px; padding:11px 14px; color:#fff; font-size:0.88rem;
}
.p-newsletter input::placeholder{ color: rgba(255,255,255,0.4); }
.p-social-row{ display:flex; gap:10px; margin-top:18px; }
.p-social-row a{
  width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,0.14);
  display:flex; align-items:center; justify-content:center; font-size:0.9rem;
}
.p-social-row a:hover{ background: rgba(255,255,255,0.08); }

/* ---------- Reveal / motion utilities ---------- */
.p-reveal{ opacity:0; transform: translateY(28px); transition: opacity .8s var(--p-ease), transform .8s var(--p-ease); }
.p-reveal.in{ opacity:1; transform:none; }
.p-reveal-blur{ opacity:0; filter: blur(10px); transform: translateY(16px); transition: opacity .9s var(--p-ease), filter .9s var(--p-ease), transform .9s var(--p-ease); }
.p-reveal-blur.in{ opacity:1; filter:blur(0); transform:none; }
.p-stagger .p-reveal:nth-child(1){ transition-delay:.05s; }
.p-stagger .p-reveal:nth-child(2){ transition-delay:.15s; }
.p-stagger .p-reveal:nth-child(3){ transition-delay:.25s; }
.p-stagger .p-reveal:nth-child(4){ transition-delay:.35s; }
.p-stagger .p-reveal:nth-child(5){ transition-delay:.45s; }
.p-stagger .p-reveal:nth-child(6){ transition-delay:.55s; }

/* ---------- Enterprise background system ---------- */
.p-bg-grid{ position:relative; }
.p-bg-grid::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(17,28,55,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(17,28,55,0.06) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(70% 70% at 50% 30%, rgba(0,0,0,0.6), transparent 85%);
  mask-image: radial-gradient(70% 70% at 50% 30%, rgba(0,0,0,0.6), transparent 85%);
}
.p-dark.p-bg-grid::before{
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
}
.p-bg-blueprint{ position:relative; overflow:hidden; }
.p-bg-blueprint::after{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:0.5;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 400'%3E%3Cg fill='none' stroke='%233b6df0' stroke-opacity='0.10' stroke-width='1'%3E%3Cpath d='M0 60H400M0 140H400M0 220H400M0 300H400'/%3E%3Cpath d='M60 0V400M140 0V400M220 0V400M300 0V400'/%3E%3Ccircle cx='140' cy='140' r='46'/%3E%3Ccircle cx='300' cy='300' r='30'/%3E%3Cpath d='M60 300L140 220L220 260L300 140' stroke-dasharray='4 6'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 480px 480px;
}
.p-bg-glow{ position:relative; }
.p-bg-glow::before{
  content:""; position:absolute; z-index:0; pointer-events:none; border-radius:50%;
  filter: blur(60px);
}
.p-bg-glow.gold::before{ width:360px; height:360px; top:-100px; right:-80px; background:rgba(201,162,75,0.18); }
.p-bg-glow.blue::before{ width:420px; height:420px; bottom:-140px; left:-100px; background:rgba(59,109,240,0.14); }

.p-bg-map{ position:relative; overflow:hidden; }
.p-bg-map::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:0.10;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1000 500'%3E%3Cg fill='%237ea2ff'%3E%3Ccircle cx='120' cy='140' r='3'/%3E%3Ccircle cx='180' cy='180' r='2'/%3E%3Ccircle cx='260' cy='120' r='2'/%3E%3Ccircle cx='340' cy='210' r='3'/%3E%3Ccircle cx='420' cy='150' r='2'/%3E%3Ccircle cx='500' cy='190' r='3'/%3E%3Ccircle cx='560' cy='130' r='2'/%3E%3Ccircle cx='640' cy='220' r='3'/%3E%3Ccircle cx='720' cy='160' r='2'/%3E%3Ccircle cx='800' cy='200' r='3'/%3E%3Ccircle cx='860' cy='150' r='2'/%3E%3Ccircle cx='300' cy='300' r='2'/%3E%3Ccircle cx='420' cy='340' r='3'/%3E%3Ccircle cx='560' cy='310' r='2'/%3E%3Ccircle cx='680' cy='350' r='3'/%3E%3Ccircle cx='150' cy='320' r='2'/%3E%3C/g%3E%3Cg fill='none' stroke='%237ea2ff' stroke-width='1' stroke-dasharray='3 5'%3E%3Cpath d='M120 140Q300 60 500 190'/%3E%3Cpath d='M500 190Q650 100 860 150'/%3E%3Cpath d='M340 210Q420 280 560 310'/%3E%3Cpath d='M150 320Q300 380 420 340'/%3E%3Cpath d='M420 340Q550 400 680 350'/%3E%3C/g%3E%3C/svg%3E");
  background-size: cover; background-position: center;
}
.p-float-shape{ position:absolute; z-index:0; pointer-events:none; opacity:0.5; }
.p-float-shape.sq{ border:1px solid rgba(255,255,255,0.14); border-radius:10px; }
.p-float-shape.circ{ border:1px solid rgba(201,162,75,0.30); border-radius:50%; }
.p-float-shape.on-light{ border-color: rgba(17,28,55,0.12); }

/* ---------- Illustration frames ---------- */
.p-illus{
  position:relative; border-radius: var(--p-radius-lg); overflow:hidden;
  box-shadow: var(--p-shadow-soft); border:1px solid var(--p-glass-border);
  aspect-ratio: 4/3; background: linear-gradient(160deg, var(--p-navy-800), var(--p-navy-950));
}
.p-illus img, .p-illus svg{ width:100%; height:100%; display:block; object-fit:cover; }
.p-illus.on-light{ border-color: var(--gray-200); box-shadow: 0 20px 50px rgba(15,45,82,0.10); }
.p-illus-cap{
  position:absolute; left:16px; bottom:16px; z-index:2;
  background: rgba(6,11,22,0.72); backdrop-filter: blur(8px);
  color:#fff; font-size:0.76rem; font-weight:600; letter-spacing:0.3px;
  padding:7px 13px; border-radius:999px; border:1px solid rgba(255,255,255,0.14);
}

/* ---------- Alternating media/text rows ---------- */
.p-row{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.p-row.rev .p-row-media{ order:2; }
.p-row.rev .p-row-text{ order:1; }
.p-row + .p-row{ margin-top:90px; }

/* ---------- Stat / counter ---------- */
.p-stat{ text-align:center; }
.p-stat .num{ font-family:var(--p-serif); font-size:clamp(2rem,3.4vw,2.8rem); font-weight:600; color:#fff; }
.p-stat .num.on-light{ color: var(--p-navy-900); }
.p-stat span{ display:block; font-size:0.82rem; color: var(--p-text-faint); margin-top:6px; letter-spacing:0.3px; }

/* ---------- Testimonial (placeholder) ---------- */
.p-testi{
  background: var(--p-glass-bg); border:1px solid var(--p-glass-border); border-radius: var(--p-radius-lg);
  padding:34px 32px; backdrop-filter: blur(16px);
}
.p-testi p{ font-family:var(--p-serif); font-size:1.15rem; line-height:1.6; color:#fff; margin:0 0 20px; font-style:italic; }
.p-testi .who{ display:flex; align-items:center; gap:12px; }
.p-testi .who .av{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--p-blue),#6d47d9); display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-family:var(--p-serif); }
.p-testi .who b{ color:#fff; display:block; font-size:0.9rem; }
.p-testi .who span{ color: var(--p-text-faint); font-size:0.78rem; }
.p-testi-note{ text-align:center; font-size:0.78rem; color: var(--p-text-faint); margin-top:18px; }

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .p-hero-grid{ grid-template-columns:1fr; }
  .p-hero-visual{ order:-1; max-width:420px; margin:0 auto 20px; }
  .p-grid-3, .p-grid-4{ grid-template-columns:repeat(2,1fr); }
  .p-grid-6{ grid-template-columns:repeat(3,1fr); }
  .p-founder{ grid-template-columns:1fr; text-align:center; }
  .p-trust-row{ justify-content:center; text-align:left; }
  .p-row{ grid-template-columns:1fr; gap:30px; }
  .p-row.rev .p-row-media{ order:1; }
  .p-row.rev .p-row-text{ order:2; }
  .p-row + .p-row{ margin-top:56px; }
}
@media (max-width:720px){
  .p-section{ padding:64px 0; }
  .p-hero{ padding:120px 0 70px; }
  .p-grid-3, .p-grid-4, .p-grid-6{ grid-template-columns:1fr 1fr; }
  .p-timeline::before{ left:23px; }
  .p-tl-num{ width:46px; height:46px; font-size:1rem; }
}
