/* Patriots' Roofing - design system v2 (premium American-craftsmanship).
   Real photography + real badges + triangle/roof motif + depth + motion.
   Scoped under .pr. No em dashes. */

:root{
  --pr-navy:#0f0f1c; --pr-navy-1:#141422; --pr-navy-2:#1c1c30; --pr-navy-3:#262640;
  --pr-red:#f6353b; --pr-red-deep:#cf1f25;
  --pr-white:#ffffff; --pr-ink:#15151f; --pr-slate:#454553; --pr-mute:#727282;
  --pr-line:#e6e7ec; --pr-cloud:#f5f6f8;
  --pr-gold:#f2b418; --pr-gold-soft:#ffce3a;
  --pr-shadow:0 14px 40px rgba(15,15,28,.12);
  --pr-shadow-lg:0 30px 70px rgba(15,15,28,.28);
  --pr-fd:'Plus Jakarta Sans',system-ui,sans-serif;
  --pr-fb:'DM Sans',system-ui,sans-serif;
  --pr-edge:clamp(20px,5vw,80px);
}

.pr,.pr *{box-sizing:border-box;}
.pr{font-family:var(--pr-fb);color:var(--pr-ink);font-size:1.0625rem;line-height:1.65;background:#fff;margin:0;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
.pr img{max-width:100%;display:block;}
.pr-content a{color:var(--pr-red-deep);text-decoration:underline;text-underline-offset:2px;}

.pr-wrap{max-width:1240px;margin:0 auto;padding:0 var(--pr-edge);}
.pr-sec{padding:clamp(60px,8vw,118px) 0;position:relative;}
.pr-sec--cloud{background:var(--pr-cloud);}
.pr-sec--navy{background:var(--pr-navy-1);color:#cfd0de;}

.pr h1,.pr h2,.pr h3,.pr h4{font-family:var(--pr-fd);font-weight:800;line-height:1.06;letter-spacing:-.015em;color:var(--pr-ink);margin:0 0 .5em;}
.pr h1{font-size:clamp(2.4rem,5.4vw,4.3rem);text-transform:uppercase;letter-spacing:-.025em;}
.pr h2{font-size:clamp(1.75rem,3.6vw,2.7rem);text-transform:uppercase;}
.pr h3{font-size:clamp(1.2rem,2vw,1.45rem);font-weight:700;}
.pr p{margin:0 0 1.15em;}
.pr-sec--navy h2,.pr-sec--navy h3{color:#fff;}

/* eyebrow + triangle motif */
.pr-ey{display:inline-flex;align-items:center;gap:9px;font-family:var(--pr-fd);font-weight:800;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--pr-red);margin-bottom:.85rem;}
.pr-ey::before{content:"";width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:11px solid var(--pr-red);display:inline-block;}
.pr-sec--navy .pr-ey,.pr-onphoto .pr-ey{color:var(--pr-gold-soft);}
.pr-sec--navy .pr-ey::before,.pr-onphoto .pr-ey::before{border-bottom-color:var(--pr-gold-soft);}
.pr-head{max-width:720px;}
.pr-head.center{margin:0 auto;text-align:center;}

/* buttons - explicit colors, high specificity so link color never bleeds in */
.pr a.pr-btn,.pr button.pr-btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--pr-fd);font-weight:700;font-size:1rem;line-height:1;padding:17px 32px;min-height:54px;border-radius:11px;border:2px solid transparent;cursor:pointer;transition:transform .14s,box-shadow .14s,background .16s;text-decoration:none;white-space:nowrap;}
.pr a.pr-btn:hover{text-decoration:none;transform:translateY(-2px);}
.pr a.pr-btn--primary{background:var(--pr-red);color:#fff;box-shadow:0 12px 26px rgba(246,53,59,.34);}
.pr a.pr-btn--primary:hover{background:var(--pr-red-deep);color:#fff;box-shadow:0 16px 34px rgba(246,53,59,.42);}
.pr a.pr-btn--ghost{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.45);backdrop-filter:blur(2px);}
.pr a.pr-btn--ghost:hover{background:rgba(255,255,255,.14);color:#fff;border-color:#fff;}
.pr a.pr-btn--dark{background:var(--pr-navy-1);color:#fff;}
.pr a.pr-btn--dark:hover{background:#000;color:#fff;}
.pr a.pr-btn--lg{font-size:1.08rem;padding:19px 38px;min-height:58px;}
.pr-btn .arr{font-size:1.15em;line-height:0;}

/* header */
.pr-hd{position:absolute;top:0;left:0;right:0;z-index:40;}
.pr-hd .pr-wrap{display:flex;align-items:center;gap:26px;height:88px;}
.pr-hd__logo img{height:46px;width:auto;}
.pr-nav{display:flex;gap:30px;margin-left:14px;}
.pr-nav a{color:#e7e8f2;font-family:var(--pr-fd);font-weight:600;font-size:.95rem;text-decoration:none;letter-spacing:.01em;}
.pr-nav a:hover{color:#fff;}
.pr-hd__r{margin-left:auto;display:flex;align-items:center;gap:22px;}
.pr-hd__ph{color:#fff;font-family:var(--pr-fd);font-weight:800;font-size:1.05rem;text-decoration:none;white-space:nowrap;}
.pr-hd__ph small{display:block;font-family:var(--pr-fb);font-weight:500;font-size:.66rem;color:#b7b9cc;letter-spacing:.13em;text-transform:uppercase;}

/* HERO - full-bleed photo + navy gradient + layered content + grant chip */
.pr-hero{position:relative;min-height:clamp(620px,82vh,820px);display:flex;align-items:center;color:#fff;background-size:cover;background-position:center;isolation:isolate;}
.pr-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(10,10,20,.93) 0%,rgba(12,12,24,.82) 42%,rgba(12,12,24,.46) 78%,rgba(12,12,24,.30) 100%);z-index:-1;}
.pr-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(900px 420px at 8% 110%,rgba(246,53,59,.30),transparent 60%);z-index:-1;}
.pr-hero .pr-wrap{padding-top:120px;padding-bottom:72px;width:100%;}
.pr-hero__in{max-width:760px;}
.pr-hero__chip{display:inline-flex;align-items:center;gap:12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:100px;padding:7px 7px 7px 16px;margin-bottom:22px;font-weight:600;font-size:.92rem;color:#eef0fa;backdrop-filter:blur(6px);animation:prUp .7s .05s both;}
.pr-hero__chip img{height:36px;width:auto;object-fit:contain;}
.pr-hero__chip b{color:var(--pr-gold-soft);}
.pr-hero h1{color:#fff;margin-bottom:.35em;text-shadow:0 2px 30px rgba(0,0,0,.35);animation:prUp .8s .12s both;}
.pr-hero h1 .hl{color:var(--pr-red);}
.pr-hero__lede{font-size:clamp(1.08rem,1.55vw,1.3rem);color:#d7d8e6;max-width:56ch;margin:0 0 1.9rem;animation:prUp .8s .2s both;}
.pr-hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;animation:prUp .8s .28s both;}
.pr-hero__rating{display:flex;align-items:center;gap:10px;margin-bottom:18px;font-weight:600;animation:prUp .7s 0s both;}
.pr-hero__rating .st{color:var(--pr-gold-soft);letter-spacing:3px;font-size:1.05rem;}
.pr-hero__rating .g{font-weight:700;}
@keyframes prUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}

/* badge trust strip (real badge images on white so they pop) */
.pr-badges{background:#fff;border-bottom:1px solid var(--pr-line);}
.pr-badges .pr-wrap{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:24px 46px;padding:26px 0;}
.pr-badges img{height:64px;width:auto;transition:transform .2s;}
.pr-badges img.bbb{height:48px;}
.pr-badges img:hover{transform:translateY(-3px) scale(1.04);}
.pr-badges .lic{color:var(--pr-navy);font-family:var(--pr-fd);font-weight:800;font-size:.84rem;letter-spacing:.05em;text-transform:uppercase;border-left:1px solid var(--pr-line);padding-left:30px;}

/* stats band */
.pr-stats{background:var(--pr-navy-1);color:#fff;position:relative;overflow:hidden;}
.pr-stats::before{content:"";position:absolute;left:50%;top:-40%;width:60%;height:180%;background:radial-gradient(closest-side,rgba(246,53,59,.16),transparent);transform:translateX(-50%);}
.pr-stats .pr-wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:48px 0;position:relative;}
.pr-stat{text-align:center;padding:0 14px;position:relative;}
.pr-stat + .pr-stat::before{content:"";position:absolute;left:0;top:14%;height:72%;width:1px;background:rgba(255,255,255,.12);}
.pr-stat b{display:block;font-family:var(--pr-fd);font-weight:800;font-size:clamp(2rem,3.4vw,2.9rem);line-height:1;color:#fff;letter-spacing:-.02em;}
.pr-stat b .u{color:var(--pr-red);}
.pr-stat span{display:block;margin-top:9px;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;color:#a9abc2;font-weight:600;}

/* 2-col content layout with sticky CTA card */
.pr-layout{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:clamp(40px,5vw,76px);align-items:start;}
.pr-content{font-size:1.085rem;line-height:1.74;color:#2b2b38;max-width:72ch;}
.pr-content h2{margin-top:2.4rem;}
.pr-content h2:first-child{margin-top:0;}
.pr-content h3{margin-top:1.6rem;color:var(--pr-navy);}
.pr-content > p:first-of-type{font-size:1.16rem;line-height:1.6;color:var(--pr-navy);}
.pr-content ul,.pr-content ol{margin:0 0 1.3em;padding-left:0;list-style:none;}
.pr-content ul li,.pr-content ol li{position:relative;padding-left:36px;margin-bottom:.7rem;}
.pr-content ul li::before{content:"";position:absolute;left:4px;top:.46em;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:10px solid var(--pr-red);}
.pr-content ol{counter-reset:pr;}
.pr-content ol li{counter-increment:pr;padding-left:46px;margin-bottom:1rem;}
.pr-content ol li::before{content:counter(pr);position:absolute;left:0;top:-.04em;width:30px;height:30px;border-radius:8px;background:var(--pr-navy-1);color:#fff;font-family:var(--pr-fd);font-weight:800;font-size:.9rem;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 14px rgba(15,15,28,.22);}
.pr-answer{background:linear-gradient(180deg,#fff,#fbfbfd);border:1px solid var(--pr-line);border-left:5px solid var(--pr-red);border-radius:0 14px 14px 0;padding:24px 28px;font-size:1.12rem;line-height:1.58;margin:0 0 2.2rem;color:var(--pr-navy);box-shadow:var(--pr-shadow);}

/* sticky eligibility CTA card */
.pr-cta-card{position:sticky;top:24px;background:var(--pr-navy-1);color:#fff;border-radius:18px;padding:30px;box-shadow:var(--pr-shadow-lg);overflow:hidden;}
.pr-cta-card::before{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;background:radial-gradient(closest-side,rgba(246,53,59,.5),transparent);}
.pr-cta-card img{height:54px;margin-bottom:14px;}
.pr-cta-card svg{width:46px;height:46px;margin-bottom:13px;color:var(--pr-red);}
.pr-cta-card h3{color:#fff;font-size:1.45rem;margin-bottom:.4rem;}
.pr-cta-card p{color:#bdbfd2;font-size:.96rem;margin-bottom:18px;}
.pr-cta-card .pr-btn{width:100%;justify-content:center;}
.pr-cta-card .ph{display:block;text-align:center;margin-top:14px;color:#fff;font-family:var(--pr-fd);font-weight:800;font-size:1.15rem;text-decoration:none;}
.pr-cta-card .ph small{display:block;font-weight:500;font-size:.72rem;color:#9a9cb4;letter-spacing:.08em;text-transform:uppercase;font-family:var(--pr-fb);}

/* tier cards with ribbon */
.pr-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:14px;}
.pr-tier{background:#fff;border:1px solid var(--pr-line);border-radius:16px;padding:30px 28px;box-shadow:var(--pr-shadow);position:relative;transition:transform .2s,box-shadow .2s;}
.pr-tier:hover{transform:translateY(-5px);box-shadow:var(--pr-shadow-lg);}
.pr-tier__ic{width:46px;height:46px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.pr-tier__ic svg{width:46px;height:46px;}
.pr-tier h3{margin:0 0 .5rem;color:var(--pr-navy);}
.pr-tier.feat{border-color:transparent;background:var(--pr-navy-1);color:#dcdde9;box-shadow:0 24px 54px rgba(15,15,28,.32);}
.pr-tier.feat h3{color:#fff;}
.pr-tier__ribbon{position:absolute;top:18px;right:-2px;background:var(--pr-gold);color:#1a1405;font-family:var(--pr-fd);font-weight:800;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:6px 14px;border-radius:6px 0 0 6px;box-shadow:0 6px 16px rgba(0,0,0,.25);}

/* split section (photo + text) */
.pr-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center;}
.pr-split__media{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--pr-shadow-lg);aspect-ratio:4/3;}
.pr-split__media > img{width:100%;height:100%;object-fit:cover;}
.pr-split__badge{position:absolute;left:18px;bottom:18px;background:#fff;border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:10px;box-shadow:var(--pr-shadow);}
.pr-split__badge img{width:auto;height:44px;object-fit:contain;flex:none;}
.pr-split__badge span{font-family:var(--pr-fd);font-weight:800;font-size:.82rem;color:var(--pr-navy);line-height:1.15;}
.pr-rev{font-family:var(--pr-fb);}
.pr-split ul{list-style:none;padding:0;margin:1rem 0 0;}
.pr-split ul li{position:relative;padding-left:32px;margin-bottom:.8rem;color:var(--pr-slate);}
.pr-split ul li::before{content:"";position:absolute;left:0;top:.4em;width:18px;height:18px;border-radius:50%;background:var(--pr-red);}
.pr-split ul li::after{content:"";position:absolute;left:6px;top:.62em;width:6px;height:3px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg);}

/* faq */
.pr-faq{max-width:840px;margin:0 auto;}
.pr-faq details{background:#fff;border:1px solid var(--pr-line);border-radius:12px;margin-bottom:12px;box-shadow:0 2px 10px rgba(15,15,28,.04);overflow:hidden;}
.pr-faq summary{cursor:pointer;list-style:none;font-family:var(--pr-fd);font-weight:700;font-size:1.08rem;color:var(--pr-navy);padding:20px 56px 20px 22px;position:relative;}
.pr-faq summary::-webkit-details-marker{display:none;}
.pr-faq summary::after{content:"";position:absolute;right:22px;top:24px;width:11px;height:11px;border-right:2.5px solid var(--pr-red);border-bottom:2.5px solid var(--pr-red);transform:rotate(45deg);transition:transform .2s;}
.pr-faq details[open] summary::after{transform:rotate(-135deg);top:28px;}
.pr-faq details[open] summary{color:var(--pr-red-deep);}
.pr-faq p{margin:0 22px 18px;color:#3a3a47;}

/* cta band on photo */
.pr-ctaband{position:relative;color:#fff;background-size:cover;background-position:center;border-radius:22px;overflow:hidden;padding:clamp(40px,6vw,72px);text-align:center;}
.pr-ctaband::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,12,24,.86),rgba(12,12,24,.92));z-index:0;}
.pr-ctaband > *{position:relative;z-index:1;}
.pr-ctaband h2{color:#fff;}
.pr-ctaband p{color:#cfd0de;max-width:60ch;margin:0 auto 1.6rem;}
.pr-ctaband__row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* footer */
.pr-ft{background:#0b0b15;color:#9fa1b6;padding:64px 0 30px;}
.pr-ft__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.2fr;gap:32px;}
.pr-ft img.logo{height:42px;margin-bottom:16px;}
.pr-ft p{font-size:.93rem;line-height:1.65;}
.pr-ft h4{font-family:var(--pr-fd);color:#fff;text-transform:uppercase;letter-spacing:.07em;font-size:.85rem;margin:0 0 16px;}
.pr-ft a{color:#9fa1b6;display:block;margin-bottom:9px;font-size:.94rem;text-decoration:none;}
.pr-ft a:hover{color:#fff;}
.pr-ft .nap{font-size:.9rem;line-height:1.55;margin-bottom:16px;}
.pr-ft .nap b{color:#fff;display:block;font-family:var(--pr-fd);}
.pr-ft__legal{border-top:1px solid rgba(255,255,255,.08);margin-top:42px;padding-top:20px;font-size:.82rem;color:#6c6e84;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

.pr-mbar{display:none;}

@media(max-width:980px){
  .pr-nav,.pr-hd__ph{display:none;}
  .pr-layout{grid-template-columns:1fr;}
  .pr-cta-card{position:static;}
  .pr-tiers,.pr-split{grid-template-columns:1fr;}
  .pr-stats .pr-wrap{grid-template-columns:1fr 1fr;gap:30px 8px;}
  .pr-ft__top{grid-template-columns:1fr 1fr;}
}
@media(max-width:560px){
  .pr-badges img{height:48px;} .pr-badges .lic{border:0;padding-left:0;}
  .pr-ft__top{grid-template-columns:1fr;}
  .pr-mbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;box-shadow:0 -6px 20px rgba(0,0,0,.2);}
  .pr-mbar a{flex:1;text-align:center;padding:15px;font-family:var(--pr-fd);font-weight:800;color:#fff;text-decoration:none;font-size:.98rem;}
  .pr-mbar a.c{background:var(--pr-navy-1);} .pr-mbar a.e{background:var(--pr-red);}
  .pr{padding-bottom:54px;}
}

/* ---- v3 additions: hub card grid + nav dropdown + intro lead ---- */
.pr-lead{font-size:1.22rem;line-height:1.6;color:var(--pr-slate);max-width:760px;}
.pr-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:18px;}
.pr-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--pr-line);border-radius:16px;padding:30px 26px;box-shadow:var(--pr-shadow);text-decoration:none;color:var(--pr-ink);transition:transform .2s,box-shadow .2s,border-color .2s;position:relative;overflow:hidden;}
.pr-card::after{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:linear-gradient(90deg,var(--pr-red),var(--pr-gold));transform:scaleX(0);transform-origin:left;transition:transform .25s;}
.pr-card:hover{transform:translateY(-6px);box-shadow:var(--pr-shadow-lg);border-color:transparent;}
.pr-card:hover::after{transform:scaleX(1);}
.pr-card__ic{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:13px;background:var(--pr-cloud);color:var(--pr-red);margin-bottom:17px;}
.pr-card__ic svg{width:28px;height:28px;}
.pr-card h3{margin:0 0 .5rem;color:var(--pr-navy);font-size:1.24rem;}
.pr-card p{margin:0 0 1.1rem;color:var(--pr-slate);font-size:.97rem;line-height:1.6;flex:1;}
.pr-card__more{font-family:var(--pr-fd);font-weight:700;color:var(--pr-red-deep);font-size:.92rem;display:inline-flex;align-items:center;gap:6px;}
.pr-card:hover .pr-card__more{gap:11px;}

.pr-nav .has-sub{position:relative;display:inline-flex;align-items:center;}
.pr-nav .has-sub > a::after{content:"";display:inline-block;margin-left:6px;width:5px;height:5px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-1px);opacity:.8;}
.pr-nav .sub{position:absolute;top:100%;left:-16px;min-width:264px;background:#fff;border-radius:14px;box-shadow:var(--pr-shadow-lg);padding:10px;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .18s,transform .18s,visibility .18s;z-index:60;}
.pr-nav .sub::before{content:"";position:absolute;top:-16px;left:0;right:0;height:18px;}
.pr-nav .has-sub:hover .sub{opacity:1;visibility:visible;transform:translateY(6px);}
.pr-nav .sub a{display:block;color:var(--pr-ink);padding:10px 14px;border-radius:9px;font-size:.93rem;font-weight:600;white-space:nowrap;}
.pr-nav .sub a:hover{background:var(--pr-cloud);color:var(--pr-red-deep);}

@media(max-width:980px){ .pr-cards{grid-template-columns:1fr 1fr;} }
@media(max-width:560px){ .pr-cards{grid-template-columns:1fr;} .pr-lead{font-size:1.1rem;} }

/* ---- mobile hamburger nav ---- */
.pr-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:9px;margin-left:8px;z-index:210;}
.pr-burger span{display:block;width:26px;height:2.5px;background:#fff;border-radius:2px;transition:transform .22s,opacity .22s;}
.pr-mobnav{position:fixed;top:0;right:0;bottom:0;width:min(85vw,350px);background:var(--pr-navy);z-index:200;display:flex;flex-direction:column;padding:92px 24px 36px;overflow-y:auto;box-shadow:-24px 0 70px rgba(0,0,0,.55);transform:translateX(106%);transition:transform .26s ease;}
.pr-mobnav a{color:#e7e8f2;text-decoration:none;font-family:var(--pr-fd);font-weight:600;font-size:1.04rem;padding:12px 2px;border-bottom:1px solid rgba(255,255,255,.08);}
.pr-mobnav a.sub{padding-left:18px;font-weight:500;font-size:.93rem;color:#b7b9cc;}
.pr-mobnav a.pr-btn{margin-top:18px;justify-content:center;border-bottom:0;color:#fff;}
.pr-mobnav a.ph{margin-top:14px;border-bottom:0;color:var(--pr-gold-soft);font-weight:800;font-size:1.12rem;text-align:center;}
.pr-navscrim{position:fixed;inset:0;background:rgba(8,8,16,.5);z-index:190;opacity:0;visibility:hidden;transition:opacity .26s,visibility .26s;}
body.pr-navopen{overflow:hidden;}
body.pr-navopen .pr-mobnav{transform:translateX(0);}
body.pr-navopen .pr-navscrim{opacity:1;visibility:visible;}
@media(max-width:980px){
  .pr-burger{display:flex;}
  body.pr-navopen .pr-burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
  body.pr-navopen .pr-burger span:nth-child(2){opacity:0;}
  body.pr-navopen .pr-burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
}
@media(min-width:981px){ .pr-mobnav,.pr-burger,.pr-navscrim{display:none!important;} }

/* ---- v4 tailored modules: before/after slider, claims timeline, checklist, compare table, gallery ---- */
.pr-ba{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--pr-shadow-lg);aspect-ratio:4/3;max-width:780px;margin:0 auto;user-select:none;touch-action:none;}
.pr-ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;}
.pr-ba__before{clip-path:inset(0 calc(100% - var(--pr-ba,50%)) 0 0);z-index:2;}
.pr-ba__div{position:absolute;top:0;bottom:0;left:var(--pr-ba,50%);width:3px;background:#fff;transform:translateX(-50%);z-index:3;box-shadow:0 0 0 1px rgba(0,0,0,.18);pointer-events:none;}
.pr-ba__grip{position:absolute;top:50%;left:var(--pr-ba,50%);transform:translate(-50%,-50%);z-index:4;width:48px;height:48px;border-radius:50%;background:#fff;box-shadow:var(--pr-shadow);display:flex;align-items:center;justify-content:center;color:var(--pr-navy);pointer-events:none;}
.pr-ba__grip::before{content:"\2194";font-size:1.35rem;font-weight:700;}
.pr-ba input[type=range]{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5;}
.pr-ba__tag{position:absolute;top:14px;z-index:3;font-family:var(--pr-fd);font-weight:800;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(15,15,28,.62);padding:5px 12px;border-radius:100px;}
.pr-ba__tag--b{left:14px;} .pr-ba__tag--a{right:14px;}

.pr-timeline{display:grid;grid-template-columns:repeat(var(--n,5),1fr);gap:0;counter-reset:tl;list-style:none;padding:0;margin:22px 0 0;}
.pr-timeline li{position:relative;padding:0 14px;text-align:center;counter-increment:tl;}
.pr-timeline li::before{content:counter(tl);display:flex;align-items:center;justify-content:center;width:48px;height:48px;margin:0 auto 18px;border-radius:50%;background:var(--pr-navy-1);color:#fff;font-family:var(--pr-fd);font-weight:800;font-size:1.1rem;position:relative;z-index:2;box-shadow:0 6px 16px rgba(15,15,28,.22);}
.pr-timeline li::after{content:"";position:absolute;top:24px;left:-50%;width:100%;height:3px;background:var(--pr-line);z-index:1;}
.pr-timeline li:first-child::after{display:none;}
.pr-timeline li.feat::before{background:var(--pr-red);box-shadow:0 8px 20px rgba(246,53,59,.4);}
.pr-timeline h4{font-family:var(--pr-fd);font-size:1.04rem;color:var(--pr-navy);margin:0 0 .35rem;}
.pr-timeline p{font-size:.92rem;color:var(--pr-slate);line-height:1.5;margin:0;}

.pr-check{list-style:none;padding:0;margin:1rem 0 0;display:grid;grid-template-columns:1fr 1fr;gap:13px 30px;}
.pr-check li{position:relative;padding-left:36px;color:var(--pr-ink);font-size:1.04rem;line-height:1.45;}
.pr-check li::before{content:"";position:absolute;left:0;top:0;width:23px;height:23px;border-radius:50%;background:var(--pr-success);}
.pr-check li::after{content:"";position:absolute;left:7px;top:7px;width:9px;height:5px;border-left:2.5px solid #fff;border-bottom:2.5px solid #fff;transform:rotate(-45deg);}

.pr-compare{width:100%;border-collapse:separate;border-spacing:0;margin:22px 0 0;font-size:1rem;box-shadow:var(--pr-shadow);border-radius:14px;overflow:hidden;background:#fff;}
.pr-compare th,.pr-compare td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--pr-line);}
.pr-compare thead th{background:var(--pr-navy-1);color:#fff;font-family:var(--pr-fd);font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;}
.pr-compare thead th.hl{background:var(--pr-red);}
.pr-compare tbody td:first-child{font-weight:600;color:var(--pr-navy);background:var(--pr-cloud);}
.pr-compare td.y{color:var(--pr-success);font-weight:700;} .pr-compare td.n{color:var(--pr-mute);}
.pr-compare tbody tr:last-child td{border-bottom:0;}

.pr-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px;}
.pr-gallery figure{margin:0;border-radius:14px;overflow:hidden;box-shadow:var(--pr-shadow);position:relative;aspect-ratio:4/3;}
.pr-gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s;}
.pr-gallery figure:hover img{transform:scale(1.05);}
.pr-gallery figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(15,15,28,.85));color:#fff;font-size:.88rem;font-weight:600;padding:28px 14px 13px;}

@media(max-width:820px){
  .pr-timeline{grid-template-columns:1fr!important;gap:24px;}
  .pr-timeline li{padding:0 0 0 66px;text-align:left;}
  .pr-timeline li::before{position:absolute;left:0;top:0;margin:0;}
  .pr-timeline li::after{top:0;left:24px;width:3px;height:100%;}
  .pr-check{grid-template-columns:1fr;}
  .pr-gallery{grid-template-columns:1fr;}
  .pr-compare{font-size:.92rem;} .pr-compare th,.pr-compare td{padding:11px 12px;}
}
